From 953ddd82e48dd206cef5ac94456549aed13b3ad5 Mon Sep 17 00:00:00 2001 From: RaindropsSys Date: Fri, 17 Nov 2023 23:25:29 +0100 Subject: Updated 30 files and deleted 2976 files (automated) --- .../lib/@types/IIdentityServerProvider.d.ts | 9 - .../lib/@types/IIdentityServerProvider.d.ts.map | 1 - .../lib/@types/IIdentityServerProvider.js | 6 - .../lib/@types/IIdentityServerProvider.js.map | 1 - .../matrix-js-sdk/lib/@types/PushRules.d.ts | 140 - .../matrix-js-sdk/lib/@types/PushRules.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/PushRules.js | 101 - .../matrix-js-sdk/lib/@types/PushRules.js.map | 1 - .../matrix-js-sdk/lib/@types/another-json.d.js | 1 - .../matrix-js-sdk/lib/@types/another-json.d.js.map | 1 - .../matrix-js-sdk/lib/@types/auth.d.ts | 78 - .../matrix-js-sdk/lib/@types/auth.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/@types/auth.js | 52 - .../matrix-js-sdk/lib/@types/auth.js.map | 1 - .../matrix-js-sdk/lib/@types/beacon.d.ts | 106 - .../matrix-js-sdk/lib/@types/beacon.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/beacon.js | 74 - .../matrix-js-sdk/lib/@types/beacon.js.map | 1 - .../matrix-js-sdk/lib/@types/crypto.d.ts | 75 - .../matrix-js-sdk/lib/@types/crypto.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/crypto.js | 6 - .../matrix-js-sdk/lib/@types/crypto.js.map | 1 - .../matrix-js-sdk/lib/@types/event.d.ts | 194 - .../matrix-js-sdk/lib/@types/event.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/@types/event.js | 233 - .../matrix-js-sdk/lib/@types/event.js.map | 1 - .../lib/@types/extensible_events.d.ts | 98 - .../lib/@types/extensible_events.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/extensible_events.js | 86 - .../lib/@types/extensible_events.js.map | 1 - .../matrix-js-sdk/lib/@types/global.d.js | 7 - .../matrix-js-sdk/lib/@types/global.d.js.map | 1 - .../lib/@types/local_notifications.d.ts | 4 - .../lib/@types/local_notifications.d.ts.map | 1 - .../lib/@types/local_notifications.js | 6 - .../lib/@types/local_notifications.js.map | 1 - .../matrix-js-sdk/lib/@types/location.d.ts | 60 - .../matrix-js-sdk/lib/@types/location.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/location.js | 40 - .../matrix-js-sdk/lib/@types/location.js.map | 1 - .../matrix-js-sdk/lib/@types/partials.d.ts | 58 - .../matrix-js-sdk/lib/@types/partials.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/partials.js | 64 - .../matrix-js-sdk/lib/@types/partials.js.map | 1 - .../matrix-js-sdk/lib/@types/polls.d.ts | 88 - .../matrix-js-sdk/lib/@types/polls.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/@types/polls.js | 66 - .../matrix-js-sdk/lib/@types/polls.js.map | 1 - .../matrix-js-sdk/lib/@types/read_receipts.d.ts | 36 - .../lib/@types/read_receipts.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/read_receipts.js | 31 - .../matrix-js-sdk/lib/@types/read_receipts.js.map | 1 - .../matrix-js-sdk/lib/@types/requests.d.ts | 184 - .../matrix-js-sdk/lib/@types/requests.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/requests.js | 6 - .../matrix-js-sdk/lib/@types/requests.js.map | 1 - .../matrix-js-sdk/lib/@types/search.d.ts | 90 - .../matrix-js-sdk/lib/@types/search.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/search.js | 36 - .../matrix-js-sdk/lib/@types/search.js.map | 1 - .../matrix-js-sdk/lib/@types/signed.d.ts | 9 - .../matrix-js-sdk/lib/@types/signed.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/signed.js | 6 - .../matrix-js-sdk/lib/@types/signed.js.map | 1 - .../matrix-js-sdk/lib/@types/spaces.d.ts | 16 - .../matrix-js-sdk/lib/@types/spaces.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/spaces.js | 6 - .../matrix-js-sdk/lib/@types/spaces.js.map | 1 - .../matrix-js-sdk/lib/@types/synapse.d.ts | 19 - .../matrix-js-sdk/lib/@types/synapse.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/synapse.js | 6 - .../matrix-js-sdk/lib/@types/synapse.js.map | 1 - .../matrix-js-sdk/lib/@types/sync.d.ts | 8 - .../matrix-js-sdk/lib/@types/sync.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/@types/sync.js | 31 - .../matrix-js-sdk/lib/@types/sync.js.map | 1 - .../matrix-js-sdk/lib/@types/threepids.d.ts | 12 - .../matrix-js-sdk/lib/@types/threepids.d.ts.map | 1 - .../matrix-js-sdk/lib/@types/threepids.js | 28 - .../matrix-js-sdk/lib/@types/threepids.js.map | 1 - .../matrix-js-sdk/lib/@types/topic.d.ts | 48 - .../matrix-js-sdk/lib/@types/topic.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/@types/topic.js | 56 - .../matrix-js-sdk/lib/@types/topic.js.map | 1 - .../node_modules/matrix-js-sdk/lib/@types/uia.d.ts | 12 - .../matrix-js-sdk/lib/@types/uia.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/@types/uia.js | 6 - .../matrix-js-sdk/lib/@types/uia.js.map | 1 - .../matrix-js-sdk/lib/NamespacedValue.d.ts | 33 - .../matrix-js-sdk/lib/NamespacedValue.d.ts.map | 1 - .../matrix-js-sdk/lib/NamespacedValue.js | 123 - .../matrix-js-sdk/lib/NamespacedValue.js.map | 1 - .../node_modules/matrix-js-sdk/lib/ReEmitter.d.ts | 16 - .../matrix-js-sdk/lib/ReEmitter.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/ReEmitter.js | 89 - .../matrix-js-sdk/lib/ReEmitter.js.map | 1 - .../matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts | 28 - .../lib/ToDeviceMessageQueue.d.ts.map | 1 - .../matrix-js-sdk/lib/ToDeviceMessageQueue.js | 136 - .../matrix-js-sdk/lib/ToDeviceMessageQueue.js.map | 1 - .../matrix-js-sdk/lib/autodiscovery.d.ts | 132 - .../matrix-js-sdk/lib/autodiscovery.d.ts.map | 1 - .../matrix-js-sdk/lib/autodiscovery.js | 437 -- .../matrix-js-sdk/lib/autodiscovery.js.map | 1 - .../matrix-js-sdk/lib/browser-index.d.ts | 9 - .../matrix-js-sdk/lib/browser-index.d.ts.map | 1 - .../matrix-js-sdk/lib/browser-index.js | 59 - .../matrix-js-sdk/lib/browser-index.js.map | 1 - .../node_modules/matrix-js-sdk/lib/client.d.ts | 3822 ---------- .../node_modules/matrix-js-sdk/lib/client.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/client.js | 7616 -------------------- .../node_modules/matrix-js-sdk/lib/client.js.map | 1 - .../lib/common-crypto/CryptoBackend.d.ts | 141 - .../lib/common-crypto/CryptoBackend.d.ts.map | 1 - .../lib/common-crypto/CryptoBackend.js | 6 - .../lib/common-crypto/CryptoBackend.js.map | 1 - .../matrix-js-sdk/lib/content-helpers.d.ts | 90 - .../matrix-js-sdk/lib/content-helpers.d.ts.map | 1 - .../matrix-js-sdk/lib/content-helpers.js | 256 - .../matrix-js-sdk/lib/content-helpers.js.map | 1 - .../matrix-js-sdk/lib/content-repo.d.ts | 16 - .../matrix-js-sdk/lib/content-repo.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/content-repo.js | 77 - .../matrix-js-sdk/lib/content-repo.js.map | 1 - .../node_modules/matrix-js-sdk/lib/crypto-api.d.ts | 55 - .../matrix-js-sdk/lib/crypto-api.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/crypto-api.js | 6 - .../matrix-js-sdk/lib/crypto-api.js.map | 1 - .../matrix-js-sdk/lib/crypto/CrossSigning.d.ts | 214 - .../matrix-js-sdk/lib/crypto/CrossSigning.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/CrossSigning.js | 711 -- .../matrix-js-sdk/lib/crypto/CrossSigning.js.map | 1 - .../matrix-js-sdk/lib/crypto/DeviceList.d.ts | 216 - .../matrix-js-sdk/lib/crypto/DeviceList.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/DeviceList.js | 877 --- .../matrix-js-sdk/lib/crypto/DeviceList.js.map | 1 - .../matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts | 150 - .../lib/crypto/EncryptionSetup.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/EncryptionSetup.js | 350 - .../lib/crypto/EncryptionSetup.js.map | 1 - .../matrix-js-sdk/lib/crypto/OlmDevice.d.ts | 454 -- .../matrix-js-sdk/lib/crypto/OlmDevice.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/OlmDevice.js | 1164 --- .../matrix-js-sdk/lib/crypto/OlmDevice.js.map | 1 - .../lib/crypto/OutgoingRoomKeyRequestManager.d.ts | 109 - .../crypto/OutgoingRoomKeyRequestManager.d.ts.map | 1 - .../lib/crypto/OutgoingRoomKeyRequestManager.js | 394 - .../crypto/OutgoingRoomKeyRequestManager.js.map | 1 - .../matrix-js-sdk/lib/crypto/RoomList.d.ts | 19 - .../matrix-js-sdk/lib/crypto/RoomList.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/RoomList.js | 63 - .../matrix-js-sdk/lib/crypto/RoomList.js.map | 1 - .../matrix-js-sdk/lib/crypto/SecretStorage.d.ts | 115 - .../lib/crypto/SecretStorage.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/SecretStorage.js | 491 -- .../matrix-js-sdk/lib/crypto/SecretStorage.js.map | 1 - .../node_modules/matrix-js-sdk/lib/crypto/aes.d.ts | 35 - .../matrix-js-sdk/lib/crypto/aes.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/crypto/aes.js | 128 - .../matrix-js-sdk/lib/crypto/aes.js.map | 1 - .../matrix-js-sdk/lib/crypto/algorithms/base.d.ts | 170 - .../lib/crypto/algorithms/base.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/algorithms/base.js | 226 - .../lib/crypto/algorithms/base.js.map | 1 - .../matrix-js-sdk/lib/crypto/algorithms/index.d.ts | 4 - .../lib/crypto/algorithms/index.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/algorithms/index.js | 19 - .../lib/crypto/algorithms/index.js.map | 1 - .../lib/crypto/algorithms/megolm.d.ts | 385 - .../lib/crypto/algorithms/megolm.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/algorithms/megolm.js | 1682 ----- .../lib/crypto/algorithms/megolm.js.map | 1 - .../matrix-js-sdk/lib/crypto/algorithms/olm.d.ts | 5 - .../lib/crypto/algorithms/olm.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/algorithms/olm.js | 269 - .../matrix-js-sdk/lib/crypto/algorithms/olm.js.map | 1 - .../node_modules/matrix-js-sdk/lib/crypto/api.d.ts | 89 - .../matrix-js-sdk/lib/crypto/api.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/crypto/api.js | 44 - .../matrix-js-sdk/lib/crypto/api.js.map | 1 - .../matrix-js-sdk/lib/crypto/backup.d.ts | 184 - .../matrix-js-sdk/lib/crypto/backup.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/backup.js | 654 -- .../matrix-js-sdk/lib/crypto/backup.js.map | 1 - .../matrix-js-sdk/lib/crypto/crypto.d.ts | 9 - .../matrix-js-sdk/lib/crypto/crypto.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/crypto.js | 48 - .../matrix-js-sdk/lib/crypto/crypto.js.map | 1 - .../matrix-js-sdk/lib/crypto/dehydration.d.ts | 34 - .../matrix-js-sdk/lib/crypto/dehydration.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/dehydration.js | 238 - .../matrix-js-sdk/lib/crypto/dehydration.js.map | 1 - .../matrix-js-sdk/lib/crypto/deviceinfo.d.ts | 102 - .../matrix-js-sdk/lib/crypto/deviceinfo.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/deviceinfo.js | 150 - .../matrix-js-sdk/lib/crypto/deviceinfo.js.map | 1 - .../matrix-js-sdk/lib/crypto/index.d.ts | 1083 --- .../matrix-js-sdk/lib/crypto/index.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/crypto/index.js | 3290 --------- .../matrix-js-sdk/lib/crypto/index.js.map | 1 - .../matrix-js-sdk/lib/crypto/key_passphrase.d.ts | 15 - .../lib/crypto/key_passphrase.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/key_passphrase.js | 68 - .../matrix-js-sdk/lib/crypto/key_passphrase.js.map | 1 - .../matrix-js-sdk/lib/crypto/keybackup.d.ts | 53 - .../matrix-js-sdk/lib/crypto/keybackup.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/keybackup.js | 6 - .../matrix-js-sdk/lib/crypto/keybackup.js.map | 1 - .../matrix-js-sdk/lib/crypto/olmlib.d.ts | 146 - .../matrix-js-sdk/lib/crypto/olmlib.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/olmlib.js | 467 -- .../matrix-js-sdk/lib/crypto/olmlib.js.map | 1 - .../matrix-js-sdk/lib/crypto/recoverykey.d.ts | 3 - .../matrix-js-sdk/lib/crypto/recoverykey.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/recoverykey.js | 62 - .../matrix-js-sdk/lib/crypto/recoverykey.js.map | 1 - .../matrix-js-sdk/lib/crypto/store/base.d.ts | 143 - .../matrix-js-sdk/lib/crypto/store/base.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/store/base.js | 6 - .../matrix-js-sdk/lib/crypto/store/base.js.map | 1 - .../store/indexeddb-crypto-store-backend.d.ts | 130 - .../store/indexeddb-crypto-store-backend.d.ts.map | 1 - .../crypto/store/indexeddb-crypto-store-backend.js | 918 --- .../store/indexeddb-crypto-store-backend.js.map | 1 - .../lib/crypto/store/indexeddb-crypto-store.d.ts | 360 - .../crypto/store/indexeddb-crypto-store.d.ts.map | 1 - .../lib/crypto/store/indexeddb-crypto-store.js | 601 -- .../lib/crypto/store/indexeddb-crypto-store.js.map | 1 - .../crypto/store/localStorage-crypto-store.d.ts | 49 - .../store/localStorage-crypto-store.d.ts.map | 1 - .../lib/crypto/store/localStorage-crypto-store.js | 333 - .../crypto/store/localStorage-crypto-store.js.map | 1 - .../lib/crypto/store/memory-crypto-store.d.ts | 144 - .../lib/crypto/store/memory-crypto-store.d.ts.map | 1 - .../lib/crypto/store/memory-crypto-store.js | 429 -- .../lib/crypto/store/memory-crypto-store.js.map | 1 - .../lib/crypto/verification/Base.d.ts | 87 - .../lib/crypto/verification/Base.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/verification/Base.js | 347 - .../lib/crypto/verification/Base.js.map | 1 - .../lib/crypto/verification/Error.d.ts | 35 - .../lib/crypto/verification/Error.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/verification/Error.js | 101 - .../lib/crypto/verification/Error.js.map | 1 - .../lib/crypto/verification/IllegalMethod.d.ts | 15 - .../lib/crypto/verification/IllegalMethod.d.ts.map | 1 - .../lib/crypto/verification/IllegalMethod.js | 50 - .../lib/crypto/verification/IllegalMethod.js.map | 1 - .../lib/crypto/verification/QRCode.d.ts | 54 - .../lib/crypto/verification/QRCode.d.ts.map | 1 - .../lib/crypto/verification/QRCode.js | 272 - .../lib/crypto/verification/QRCode.js.map | 1 - .../matrix-js-sdk/lib/crypto/verification/SAS.d.ts | 37 - .../lib/crypto/verification/SAS.d.ts.map | 1 - .../matrix-js-sdk/lib/crypto/verification/SAS.js | 453 -- .../lib/crypto/verification/SAS.js.map | 1 - .../lib/crypto/verification/SASDecimal.d.ts | 8 - .../lib/crypto/verification/SASDecimal.d.ts.map | 1 - .../lib/crypto/verification/SASDecimal.js | 40 - .../lib/crypto/verification/SASDecimal.js.map | 1 - .../lib/crypto/verification/request/Channel.d.ts | 18 - .../crypto/verification/request/Channel.d.ts.map | 1 - .../lib/crypto/verification/request/Channel.js | 6 - .../lib/crypto/verification/request/Channel.js.map | 1 - .../crypto/verification/request/InRoomChannel.d.ts | 113 - .../verification/request/InRoomChannel.d.ts.map | 1 - .../crypto/verification/request/InRoomChannel.js | 344 - .../verification/request/InRoomChannel.js.map | 1 - .../verification/request/ToDeviceChannel.d.ts | 105 - .../verification/request/ToDeviceChannel.d.ts.map | 1 - .../crypto/verification/request/ToDeviceChannel.js | 324 - .../verification/request/ToDeviceChannel.js.map | 1 - .../verification/request/VerificationRequest.d.ts | 208 - .../request/VerificationRequest.d.ts.map | 1 - .../verification/request/VerificationRequest.js | 876 --- .../request/VerificationRequest.js.map | 1 - .../node_modules/matrix-js-sdk/lib/embedded.d.ts | 86 - .../matrix-js-sdk/lib/embedded.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/embedded.js | 265 - .../node_modules/matrix-js-sdk/lib/embedded.js.map | 1 - .../node_modules/matrix-js-sdk/lib/errors.d.ts | 22 - .../node_modules/matrix-js-sdk/lib/errors.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/errors.js | 62 - .../node_modules/matrix-js-sdk/lib/errors.js.map | 1 - .../matrix-js-sdk/lib/event-mapper.d.ts | 10 - .../matrix-js-sdk/lib/event-mapper.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/event-mapper.js | 72 - .../matrix-js-sdk/lib/event-mapper.js.map | 1 - .../lib/extensible_events_v1/ExtensibleEvent.d.ts | 38 - .../extensible_events_v1/ExtensibleEvent.d.ts.map | 1 - .../lib/extensible_events_v1/ExtensibleEvent.js | 45 - .../extensible_events_v1/ExtensibleEvent.js.map | 1 - .../extensible_events_v1/InvalidEventError.d.ts | 7 - .../InvalidEventError.d.ts.map | 1 - .../lib/extensible_events_v1/InvalidEventError.js | 32 - .../extensible_events_v1/InvalidEventError.js.map | 1 - .../lib/extensible_events_v1/MessageEvent.d.ts | 45 - .../lib/extensible_events_v1/MessageEvent.d.ts.map | 1 - .../lib/extensible_events_v1/MessageEvent.js | 128 - .../lib/extensible_events_v1/MessageEvent.js.map | 1 - .../lib/extensible_events_v1/PollEndEvent.d.ts | 33 - .../lib/extensible_events_v1/PollEndEvent.d.ts.map | 1 - .../lib/extensible_events_v1/PollEndEvent.js | 81 - .../lib/extensible_events_v1/PollEndEvent.js.map | 1 - .../extensible_events_v1/PollResponseEvent.d.ts | 49 - .../PollResponseEvent.d.ts.map | 1 - .../lib/extensible_events_v1/PollResponseEvent.js | 143 - .../extensible_events_v1/PollResponseEvent.js.map | 1 - .../lib/extensible_events_v1/PollStartEvent.d.ts | 71 - .../extensible_events_v1/PollStartEvent.d.ts.map | 1 - .../lib/extensible_events_v1/PollStartEvent.js | 183 - .../lib/extensible_events_v1/PollStartEvent.js.map | 1 - .../lib/extensible_events_v1/utilities.d.ts | 14 - .../lib/extensible_events_v1/utilities.d.ts.map | 1 - .../lib/extensible_events_v1/utilities.js | 41 - .../lib/extensible_events_v1/utilities.js.map | 1 - .../node_modules/matrix-js-sdk/lib/feature.d.ts | 15 - .../matrix-js-sdk/lib/feature.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/feature.js | 77 - .../node_modules/matrix-js-sdk/lib/feature.js.map | 1 - .../matrix-js-sdk/lib/filter-component.d.ts | 64 - .../matrix-js-sdk/lib/filter-component.d.ts.map | 1 - .../matrix-js-sdk/lib/filter-component.js | 173 - .../matrix-js-sdk/lib/filter-component.js.map | 1 - .../node_modules/matrix-js-sdk/lib/filter.d.ts | 97 - .../node_modules/matrix-js-sdk/lib/filter.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/filter.js | 199 - .../node_modules/matrix-js-sdk/lib/filter.js.map | 1 - .../matrix-js-sdk/lib/http-api/errors.d.ts | 43 - .../matrix-js-sdk/lib/http-api/errors.d.ts.map | 1 - .../matrix-js-sdk/lib/http-api/errors.js | 85 - .../matrix-js-sdk/lib/http-api/errors.js.map | 1 - .../matrix-js-sdk/lib/http-api/fetch.d.ts | 105 - .../matrix-js-sdk/lib/http-api/fetch.d.ts.map | 1 - .../matrix-js-sdk/lib/http-api/fetch.js | 271 - .../matrix-js-sdk/lib/http-api/fetch.js.map | 1 - .../matrix-js-sdk/lib/http-api/index.d.ts | 33 - .../matrix-js-sdk/lib/http-api/index.d.ts.map | 1 - .../matrix-js-sdk/lib/http-api/index.js | 244 - .../matrix-js-sdk/lib/http-api/index.js.map | 1 - .../matrix-js-sdk/lib/http-api/interface.d.ts | 113 - .../matrix-js-sdk/lib/http-api/interface.d.ts.map | 1 - .../matrix-js-sdk/lib/http-api/interface.js | 28 - .../matrix-js-sdk/lib/http-api/interface.js.map | 1 - .../matrix-js-sdk/lib/http-api/method.d.ts | 7 - .../matrix-js-sdk/lib/http-api/method.d.ts.map | 1 - .../matrix-js-sdk/lib/http-api/method.js | 30 - .../matrix-js-sdk/lib/http-api/method.js.map | 1 - .../matrix-js-sdk/lib/http-api/prefix.d.ts | 31 - .../matrix-js-sdk/lib/http-api/prefix.d.ts.map | 1 - .../matrix-js-sdk/lib/http-api/prefix.js | 40 - .../matrix-js-sdk/lib/http-api/prefix.js.map | 1 - .../matrix-js-sdk/lib/http-api/utils.d.ts | 25 - .../matrix-js-sdk/lib/http-api/utils.d.ts.map | 1 - .../matrix-js-sdk/lib/http-api/utils.js | 145 - .../matrix-js-sdk/lib/http-api/utils.js.map | 1 - .../node_modules/matrix-js-sdk/lib/index.d.ts | 4 - .../node_modules/matrix-js-sdk/lib/index.d.ts.map | 1 - .../matrix/node_modules/matrix-js-sdk/lib/index.js | 44 - .../node_modules/matrix-js-sdk/lib/index.js.map | 1 - .../matrix-js-sdk/lib/indexeddb-helpers.d.ts | 10 - .../matrix-js-sdk/lib/indexeddb-helpers.d.ts.map | 1 - .../matrix-js-sdk/lib/indexeddb-helpers.js | 57 - .../matrix-js-sdk/lib/indexeddb-helpers.js.map | 1 - .../matrix-js-sdk/lib/indexeddb-worker.d.ts | 7 - .../matrix-js-sdk/lib/indexeddb-worker.d.ts.map | 1 - .../matrix-js-sdk/lib/indexeddb-worker.js | 13 - .../matrix-js-sdk/lib/indexeddb-worker.js.map | 1 - .../matrix-js-sdk/lib/interactive-auth.d.ts | 270 - .../matrix-js-sdk/lib/interactive-auth.d.ts.map | 1 - .../matrix-js-sdk/lib/interactive-auth.js | 488 -- .../matrix-js-sdk/lib/interactive-auth.js.map | 1 - .../node_modules/matrix-js-sdk/lib/logger.d.ts | 11 - .../node_modules/matrix-js-sdk/lib/logger.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/logger.js | 81 - .../node_modules/matrix-js-sdk/lib/logger.js.map | 1 - .../node_modules/matrix-js-sdk/lib/matrix.d.ts | 62 - .../node_modules/matrix-js-sdk/lib/matrix.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/matrix.js | 487 -- .../node_modules/matrix-js-sdk/lib/matrix.js.map | 1 - .../matrix-js-sdk/lib/models/MSC3089Branch.d.ts | 86 - .../lib/models/MSC3089Branch.d.ts.map | 1 - .../matrix-js-sdk/lib/models/MSC3089Branch.js | 214 - .../matrix-js-sdk/lib/models/MSC3089Branch.js.map | 1 - .../matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts | 164 - .../lib/models/MSC3089TreeSpace.d.ts.map | 1 - .../matrix-js-sdk/lib/models/MSC3089TreeSpace.js | 503 -- .../lib/models/MSC3089TreeSpace.js.map | 1 - .../matrix-js-sdk/lib/models/ToDeviceMessage.d.ts | 17 - .../lib/models/ToDeviceMessage.d.ts.map | 1 - .../matrix-js-sdk/lib/models/ToDeviceMessage.js | 6 - .../lib/models/ToDeviceMessage.js.map | 1 - .../matrix-js-sdk/lib/models/beacon.d.ts | 53 - .../matrix-js-sdk/lib/models/beacon.d.ts.map | 1 - .../matrix-js-sdk/lib/models/beacon.js | 184 - .../matrix-js-sdk/lib/models/beacon.js.map | 1 - .../matrix-js-sdk/lib/models/event-context.d.ts | 62 - .../lib/models/event-context.d.ts.map | 1 - .../matrix-js-sdk/lib/models/event-context.js | 118 - .../matrix-js-sdk/lib/models/event-context.js.map | 1 - .../matrix-js-sdk/lib/models/event-status.d.ts | 19 - .../matrix-js-sdk/lib/models/event-status.d.ts.map | 1 - .../matrix-js-sdk/lib/models/event-status.js | 36 - .../matrix-js-sdk/lib/models/event-status.js.map | 1 - .../lib/models/event-timeline-set.d.ts | 296 - .../lib/models/event-timeline-set.d.ts.map | 1 - .../matrix-js-sdk/lib/models/event-timeline-set.js | 725 -- .../lib/models/event-timeline-set.js.map | 1 - .../matrix-js-sdk/lib/models/event-timeline.d.ts | 211 - .../lib/models/event-timeline.d.ts.map | 1 - .../matrix-js-sdk/lib/models/event-timeline.js | 433 -- .../matrix-js-sdk/lib/models/event-timeline.js.map | 1 - .../matrix-js-sdk/lib/models/event.d.ts | 759 -- .../matrix-js-sdk/lib/models/event.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/models/event.js | 1433 ---- .../matrix-js-sdk/lib/models/event.js.map | 1 - .../matrix-js-sdk/lib/models/invites-ignorer.d.ts | 132 - .../lib/models/invites-ignorer.d.ts.map | 1 - .../matrix-js-sdk/lib/models/invites-ignorer.js | 360 - .../lib/models/invites-ignorer.js.map | 1 - .../matrix-js-sdk/lib/models/poll.d.ts | 60 - .../matrix-js-sdk/lib/models/poll.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/models/poll.js | 231 - .../matrix-js-sdk/lib/models/poll.js.map | 1 - .../matrix-js-sdk/lib/models/read-receipt.d.ts | 76 - .../matrix-js-sdk/lib/models/read-receipt.d.ts.map | 1 - .../matrix-js-sdk/lib/models/read-receipt.js | 267 - .../matrix-js-sdk/lib/models/read-receipt.js.map | 1 - .../lib/models/related-relations.d.ts | 11 - .../lib/models/related-relations.d.ts.map | 1 - .../matrix-js-sdk/lib/models/related-relations.js | 41 - .../lib/models/related-relations.js.map | 1 - .../lib/models/relations-container.d.ts | 44 - .../lib/models/relations-container.d.ts.map | 1 - .../lib/models/relations-container.js | 141 - .../lib/models/relations-container.js.map | 1 - .../matrix-js-sdk/lib/models/relations.d.ts | 114 - .../matrix-js-sdk/lib/models/relations.d.ts.map | 1 - .../matrix-js-sdk/lib/models/relations.js | 343 - .../matrix-js-sdk/lib/models/relations.js.map | 1 - .../matrix-js-sdk/lib/models/room-member.d.ts | 203 - .../matrix-js-sdk/lib/models/room-member.d.ts.map | 1 - .../matrix-js-sdk/lib/models/room-member.js | 377 - .../matrix-js-sdk/lib/models/room-member.js.map | 1 - .../matrix-js-sdk/lib/models/room-state.d.ts | 448 -- .../matrix-js-sdk/lib/models/room-state.d.ts.map | 1 - .../matrix-js-sdk/lib/models/room-state.js | 949 --- .../matrix-js-sdk/lib/models/room-state.js.map | 1 - .../matrix-js-sdk/lib/models/room-summary.d.ts | 29 - .../matrix-js-sdk/lib/models/room-summary.d.ts.map | 1 - .../matrix-js-sdk/lib/models/room-summary.js | 35 - .../matrix-js-sdk/lib/models/room-summary.js.map | 1 - .../matrix-js-sdk/lib/models/room.d.ts | 1087 --- .../matrix-js-sdk/lib/models/room.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/models/room.js | 2979 -------- .../matrix-js-sdk/lib/models/room.js.map | 1 - .../matrix-js-sdk/lib/models/search-result.d.ts | 20 - .../lib/models/search-result.d.ts.map | 1 - .../matrix-js-sdk/lib/models/search-result.js | 59 - .../matrix-js-sdk/lib/models/search-result.js.map | 1 - .../matrix-js-sdk/lib/models/thread.d.ts | 175 - .../matrix-js-sdk/lib/models/thread.d.ts.map | 1 - .../matrix-js-sdk/lib/models/thread.js | 581 -- .../matrix-js-sdk/lib/models/thread.js.map | 1 - .../lib/models/typed-event-emitter.d.ts | 39 - .../lib/models/typed-event-emitter.d.ts.map | 1 - .../lib/models/typed-event-emitter.js | 80 - .../lib/models/typed-event-emitter.js.map | 1 - .../matrix-js-sdk/lib/models/user.d.ts | 185 - .../matrix-js-sdk/lib/models/user.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/models/user.js | 220 - .../matrix-js-sdk/lib/models/user.js.map | 1 - .../matrix-js-sdk/lib/pushprocessor.d.ts | 124 - .../matrix-js-sdk/lib/pushprocessor.d.ts.map | 1 - .../matrix-js-sdk/lib/pushprocessor.js | 660 -- .../matrix-js-sdk/lib/pushprocessor.js.map | 1 - .../matrix-js-sdk/lib/randomstring.d.ts | 4 - .../matrix-js-sdk/lib/randomstring.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/randomstring.js | 45 - .../matrix-js-sdk/lib/randomstring.js.map | 1 - .../matrix-js-sdk/lib/realtime-callbacks.d.ts | 18 - .../matrix-js-sdk/lib/realtime-callbacks.d.ts.map | 1 - .../matrix-js-sdk/lib/realtime-callbacks.js | 180 - .../matrix-js-sdk/lib/realtime-callbacks.js.map | 1 - .../lib/rendezvous/MSC3906Rendezvous.d.ts | 74 - .../lib/rendezvous/MSC3906Rendezvous.d.ts.map | 1 - .../lib/rendezvous/MSC3906Rendezvous.js | 235 - .../lib/rendezvous/MSC3906Rendezvous.js.map | 1 - .../lib/rendezvous/RendezvousChannel.d.ts | 27 - .../lib/rendezvous/RendezvousChannel.d.ts.map | 1 - .../lib/rendezvous/RendezvousChannel.js | 6 - .../lib/rendezvous/RendezvousChannel.js.map | 1 - .../lib/rendezvous/RendezvousCode.d.ts | 9 - .../lib/rendezvous/RendezvousCode.d.ts.map | 1 - .../matrix-js-sdk/lib/rendezvous/RendezvousCode.js | 6 - .../lib/rendezvous/RendezvousCode.js.map | 1 - .../lib/rendezvous/RendezvousError.d.ts | 6 - .../lib/rendezvous/RendezvousError.d.ts.map | 1 - .../lib/rendezvous/RendezvousError.js | 30 - .../lib/rendezvous/RendezvousError.js.map | 1 - .../lib/rendezvous/RendezvousFailureReason.d.ts | 15 - .../rendezvous/RendezvousFailureReason.d.ts.map | 1 - .../lib/rendezvous/RendezvousFailureReason.js | 37 - .../lib/rendezvous/RendezvousFailureReason.js.map | 1 - .../lib/rendezvous/RendezvousIntent.d.ts | 5 - .../lib/rendezvous/RendezvousIntent.d.ts.map | 1 - .../lib/rendezvous/RendezvousIntent.js | 28 - .../lib/rendezvous/RendezvousIntent.js.map | 1 - .../lib/rendezvous/RendezvousTransport.d.ts | 36 - .../lib/rendezvous/RendezvousTransport.d.ts.map | 1 - .../lib/rendezvous/RendezvousTransport.js | 6 - .../lib/rendezvous/RendezvousTransport.js.map | 1 - .../channels/MSC3903ECDHv2RendezvousChannel.d.ts | 44 - .../MSC3903ECDHv2RendezvousChannel.d.ts.map | 1 - .../channels/MSC3903ECDHv2RendezvousChannel.js | 196 - .../channels/MSC3903ECDHv2RendezvousChannel.js.map | 1 - .../lib/rendezvous/channels/index.d.ts | 2 - .../lib/rendezvous/channels/index.d.ts.map | 1 - .../matrix-js-sdk/lib/rendezvous/channels/index.js | 17 - .../lib/rendezvous/channels/index.js.map | 1 - .../matrix-js-sdk/lib/rendezvous/index.d.ts | 8 - .../matrix-js-sdk/lib/rendezvous/index.d.ts.map | 1 - .../matrix-js-sdk/lib/rendezvous/index.js | 83 - .../matrix-js-sdk/lib/rendezvous/index.js.map | 1 - .../MSC3886SimpleHttpRendezvousTransport.d.ts | 35 - .../MSC3886SimpleHttpRendezvousTransport.d.ts.map | 1 - .../MSC3886SimpleHttpRendezvousTransport.js | 183 - .../MSC3886SimpleHttpRendezvousTransport.js.map | 1 - .../lib/rendezvous/transports/index.d.ts | 2 - .../lib/rendezvous/transports/index.d.ts.map | 1 - .../lib/rendezvous/transports/index.js | 17 - .../lib/rendezvous/transports/index.js.map | 1 - .../matrix-js-sdk/lib/room-hierarchy.d.ts | 35 - .../matrix-js-sdk/lib/room-hierarchy.d.ts.map | 1 - .../matrix-js-sdk/lib/room-hierarchy.js | 140 - .../matrix-js-sdk/lib/room-hierarchy.js.map | 1 - .../lib/rust-crypto/KeyClaimManager.d.ts | 30 - .../lib/rust-crypto/KeyClaimManager.d.ts.map | 1 - .../lib/rust-crypto/KeyClaimManager.js | 78 - .../lib/rust-crypto/KeyClaimManager.js.map | 1 - .../lib/rust-crypto/OutgoingRequestProcessor.d.ts | 29 - .../rust-crypto/OutgoingRequestProcessor.d.ts.map | 1 - .../lib/rust-crypto/OutgoingRequestProcessor.js | 94 - .../rust-crypto/OutgoingRequestProcessor.js.map | 1 - .../lib/rust-crypto/RoomEncryptor.d.ts | 57 - .../lib/rust-crypto/RoomEncryptor.d.ts.map | 1 - .../matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js | 126 - .../lib/rust-crypto/RoomEncryptor.js.map | 1 - .../lib/rust-crypto/browserify-index.d.ts | 5 - .../lib/rust-crypto/browserify-index.d.ts.map | 1 - .../lib/rust-crypto/browserify-index.js | 32 - .../lib/rust-crypto/browserify-index.js.map | 1 - .../matrix-js-sdk/lib/rust-crypto/constants.d.ts | 3 - .../lib/rust-crypto/constants.d.ts.map | 1 - .../matrix-js-sdk/lib/rust-crypto/constants.js | 26 - .../matrix-js-sdk/lib/rust-crypto/constants.js.map | 1 - .../matrix-js-sdk/lib/rust-crypto/index.d.ts | 6 - .../matrix-js-sdk/lib/rust-crypto/index.d.ts.map | 1 - .../matrix-js-sdk/lib/rust-crypto/index.js | 45 - .../matrix-js-sdk/lib/rust-crypto/index.js.map | 1 - .../matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts | 87 - .../lib/rust-crypto/rust-crypto.d.ts.map | 1 - .../matrix-js-sdk/lib/rust-crypto/rust-crypto.js | 301 - .../lib/rust-crypto/rust-crypto.js.map | 1 - .../node_modules/matrix-js-sdk/lib/scheduler.d.ts | 135 - .../matrix-js-sdk/lib/scheduler.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/scheduler.js | 314 - .../matrix-js-sdk/lib/scheduler.js.map | 1 - .../matrix-js-sdk/lib/secret-storage.d.ts | 55 - .../matrix-js-sdk/lib/secret-storage.d.ts.map | 1 - .../matrix-js-sdk/lib/secret-storage.js | 6 - .../matrix-js-sdk/lib/secret-storage.js.map | 1 - .../matrix-js-sdk/lib/service-types.d.ts | 5 - .../matrix-js-sdk/lib/service-types.d.ts.map | 1 - .../matrix-js-sdk/lib/service-types.js | 28 - .../matrix-js-sdk/lib/service-types.js.map | 1 - .../matrix-js-sdk/lib/sliding-sync-sdk.d.ts | 102 - .../matrix-js-sdk/lib/sliding-sync-sdk.d.ts.map | 1 - .../matrix-js-sdk/lib/sliding-sync-sdk.js | 881 --- .../matrix-js-sdk/lib/sliding-sync-sdk.js.map | 1 - .../matrix-js-sdk/lib/sliding-sync.d.ts | 343 - .../matrix-js-sdk/lib/sliding-sync.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/sliding-sync.js | 776 -- .../matrix-js-sdk/lib/sliding-sync.js.map | 1 - .../matrix-js-sdk/lib/store/index.d.ts | 191 - .../matrix-js-sdk/lib/store/index.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/store/index.js | 6 - .../matrix-js-sdk/lib/store/index.js.map | 1 - .../matrix-js-sdk/lib/store/indexeddb-backend.d.ts | 23 - .../lib/store/indexeddb-backend.d.ts.map | 1 - .../matrix-js-sdk/lib/store/indexeddb-backend.js | 6 - .../lib/store/indexeddb-backend.js.map | 1 - .../lib/store/indexeddb-local-backend.d.ts | 128 - .../lib/store/indexeddb-local-backend.d.ts.map | 1 - .../lib/store/indexeddb-local-backend.js | 568 -- .../lib/store/indexeddb-local-backend.js.map | 1 - .../lib/store/indexeddb-remote-backend.d.ts | 78 - .../lib/store/indexeddb-remote-backend.d.ts.map | 1 - .../lib/store/indexeddb-remote-backend.js | 199 - .../lib/store/indexeddb-remote-backend.js.map | 1 - .../lib/store/indexeddb-store-worker.d.ts | 35 - .../lib/store/indexeddb-store-worker.d.ts.map | 1 - .../lib/store/indexeddb-store-worker.js | 148 - .../lib/store/indexeddb-store-worker.js.map | 1 - .../matrix-js-sdk/lib/store/indexeddb.d.ts | 144 - .../matrix-js-sdk/lib/store/indexeddb.d.ts.map | 1 - .../matrix-js-sdk/lib/store/indexeddb.js | 295 - .../matrix-js-sdk/lib/store/indexeddb.js.map | 1 - .../lib/store/local-storage-events-emitter.d.ts | 30 - .../store/local-storage-events-emitter.d.ts.map | 1 - .../lib/store/local-storage-events-emitter.js | 44 - .../lib/store/local-storage-events-emitter.js.map | 1 - .../matrix-js-sdk/lib/store/memory.d.ts | 206 - .../matrix-js-sdk/lib/store/memory.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/store/memory.js | 425 -- .../matrix-js-sdk/lib/store/memory.js.map | 1 - .../node_modules/matrix-js-sdk/lib/store/stub.d.ts | 156 - .../matrix-js-sdk/lib/store/stub.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/store/stub.js | 256 - .../matrix-js-sdk/lib/store/stub.js.map | 1 - .../matrix-js-sdk/lib/sync-accumulator.d.ts | 163 - .../matrix-js-sdk/lib/sync-accumulator.d.ts.map | 1 - .../matrix-js-sdk/lib/sync-accumulator.js | 519 -- .../matrix-js-sdk/lib/sync-accumulator.js.map | 1 - .../node_modules/matrix-js-sdk/lib/sync.d.ts | 250 - .../node_modules/matrix-js-sdk/lib/sync.d.ts.map | 1 - .../matrix/node_modules/matrix-js-sdk/lib/sync.js | 1607 ----- .../node_modules/matrix-js-sdk/lib/sync.js.map | 1 - .../matrix-js-sdk/lib/timeline-window.d.ts | 158 - .../matrix-js-sdk/lib/timeline-window.d.ts.map | 1 - .../matrix-js-sdk/lib/timeline-window.js | 468 -- .../matrix-js-sdk/lib/timeline-window.js.map | 1 - .../node_modules/matrix-js-sdk/lib/utils.d.ts | 255 - .../node_modules/matrix-js-sdk/lib/utils.d.ts.map | 1 - .../matrix/node_modules/matrix-js-sdk/lib/utils.js | 742 -- .../node_modules/matrix-js-sdk/lib/utils.js.map | 1 - .../matrix-js-sdk/lib/webrtc/audioContext.d.ts | 15 - .../matrix-js-sdk/lib/webrtc/audioContext.d.ts.map | 1 - .../matrix-js-sdk/lib/webrtc/audioContext.js | 54 - .../matrix-js-sdk/lib/webrtc/audioContext.js.map | 1 - .../matrix-js-sdk/lib/webrtc/call.d.ts | 551 -- .../matrix-js-sdk/lib/webrtc/call.d.ts.map | 1 - .../node_modules/matrix-js-sdk/lib/webrtc/call.js | 2341 ------ .../matrix-js-sdk/lib/webrtc/call.js.map | 1 - .../matrix-js-sdk/lib/webrtc/callEventHandler.d.ts | 37 - .../lib/webrtc/callEventHandler.d.ts.map | 1 - .../matrix-js-sdk/lib/webrtc/callEventHandler.js | 347 - .../lib/webrtc/callEventHandler.js.map | 1 - .../matrix-js-sdk/lib/webrtc/callEventTypes.d.ts | 72 - .../lib/webrtc/callEventTypes.d.ts.map | 1 - .../matrix-js-sdk/lib/webrtc/callEventTypes.js | 20 - .../matrix-js-sdk/lib/webrtc/callEventTypes.js.map | 1 - .../matrix-js-sdk/lib/webrtc/callFeed.d.ts | 128 - .../matrix-js-sdk/lib/webrtc/callFeed.d.ts.map | 1 - .../matrix-js-sdk/lib/webrtc/callFeed.js | 296 - .../matrix-js-sdk/lib/webrtc/callFeed.js.map | 1 - .../matrix-js-sdk/lib/webrtc/groupCall.d.ts | 287 - .../matrix-js-sdk/lib/webrtc/groupCall.d.ts.map | 1 - .../matrix-js-sdk/lib/webrtc/groupCall.js | 1184 --- .../matrix-js-sdk/lib/webrtc/groupCall.js.map | 1 - .../lib/webrtc/groupCallEventHandler.d.ts | 31 - .../lib/webrtc/groupCallEventHandler.d.ts.map | 1 - .../lib/webrtc/groupCallEventHandler.js | 184 - .../lib/webrtc/groupCallEventHandler.js.map | 1 - .../matrix-js-sdk/lib/webrtc/mediaHandler.d.ts | 86 - .../matrix-js-sdk/lib/webrtc/mediaHandler.d.ts.map | 1 - .../matrix-js-sdk/lib/webrtc/mediaHandler.js | 399 - .../matrix-js-sdk/lib/webrtc/mediaHandler.js.map | 1 - .../lib/webrtc/stats/connectionStats.d.ts | 28 - .../lib/webrtc/stats/connectionStats.d.ts.map | 1 - .../lib/webrtc/stats/connectionStats.js | 34 - .../lib/webrtc/stats/connectionStats.js.map | 1 - .../lib/webrtc/stats/connectionStatsReporter.d.ts | 5 - .../webrtc/stats/connectionStatsReporter.d.ts.map | 1 - .../lib/webrtc/stats/connectionStatsReporter.js | 34 - .../webrtc/stats/connectionStatsReporter.js.map | 1 - .../lib/webrtc/stats/groupCallStats.d.ts | 19 - .../lib/webrtc/stats/groupCallStats.d.ts.map | 1 - .../lib/webrtc/stats/groupCallStats.js | 70 - .../lib/webrtc/stats/groupCallStats.js.map | 1 - .../lib/webrtc/stats/media/mediaSsrcHandler.d.ts | 10 - .../webrtc/stats/media/mediaSsrcHandler.d.ts.map | 1 - .../lib/webrtc/stats/media/mediaSsrcHandler.js | 65 - .../lib/webrtc/stats/media/mediaSsrcHandler.js.map | 1 - .../lib/webrtc/stats/media/mediaTrackHandler.d.ts | 11 - .../webrtc/stats/media/mediaTrackHandler.d.ts.map | 1 - .../lib/webrtc/stats/media/mediaTrackHandler.js | 65 - .../webrtc/stats/media/mediaTrackHandler.js.map | 1 - .../lib/webrtc/stats/media/mediaTrackStats.d.ts | 45 - .../webrtc/stats/media/mediaTrackStats.d.ts.map | 1 - .../lib/webrtc/stats/media/mediaTrackStats.js | 88 - .../lib/webrtc/stats/media/mediaTrackStats.js.map | 1 - .../webrtc/stats/media/mediaTrackStatsHandler.d.ts | 21 - .../stats/media/mediaTrackStatsHandler.d.ts.map | 1 - .../webrtc/stats/media/mediaTrackStatsHandler.js | 81 - .../stats/media/mediaTrackStatsHandler.js.map | 1 - .../lib/webrtc/stats/statsReport.d.ts | 33 - .../lib/webrtc/stats/statsReport.d.ts.map | 1 - .../matrix-js-sdk/lib/webrtc/stats/statsReport.js | 28 - .../lib/webrtc/stats/statsReport.js.map | 1 - .../lib/webrtc/stats/statsReportBuilder.d.ts | 7 - .../lib/webrtc/stats/statsReportBuilder.d.ts.map | 1 - .../lib/webrtc/stats/statsReportBuilder.js | 108 - .../lib/webrtc/stats/statsReportBuilder.js.map | 1 - .../lib/webrtc/stats/statsReportEmitter.d.ts | 11 - .../lib/webrtc/stats/statsReportEmitter.d.ts.map | 1 - .../lib/webrtc/stats/statsReportEmitter.js | 34 - .../lib/webrtc/stats/statsReportEmitter.js.map | 1 - .../lib/webrtc/stats/statsReportGatherer.d.ts | 23 - .../lib/webrtc/stats/statsReportGatherer.d.ts.map | 1 - .../lib/webrtc/stats/statsReportGatherer.js | 143 - .../lib/webrtc/stats/statsReportGatherer.js.map | 1 - .../lib/webrtc/stats/statsValueFormatter.d.ts | 4 - .../lib/webrtc/stats/statsValueFormatter.d.ts.map | 1 - .../lib/webrtc/stats/statsValueFormatter.js | 32 - .../lib/webrtc/stats/statsValueFormatter.js.map | 1 - .../lib/webrtc/stats/trackStatsReporter.d.ts | 11 - .../lib/webrtc/stats/trackStatsReporter.d.ts.map | 1 - .../lib/webrtc/stats/trackStatsReporter.js | 94 - .../lib/webrtc/stats/trackStatsReporter.js.map | 1 - .../lib/webrtc/stats/transportStats.d.ts | 11 - .../lib/webrtc/stats/transportStats.d.ts.map | 1 - .../lib/webrtc/stats/transportStats.js | 6 - .../lib/webrtc/stats/transportStats.js.map | 1 - .../lib/webrtc/stats/transportStatsReporter.d.ts | 5 - .../webrtc/stats/transportStatsReporter.d.ts.map | 1 - .../lib/webrtc/stats/transportStatsReporter.js | 41 - .../lib/webrtc/stats/transportStatsReporter.js.map | 1 - 728 files changed, 76977 deletions(-) delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts.map delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js delete mode 100644 includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js.map (limited to 'includes/external/matrix/node_modules/matrix-js-sdk/lib') diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts deleted file mode 100644 index e87906b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -export interface IIdentityServerProvider { - /** - * Gets an access token for use against the identity server, - * for the associated client. - * @returns Promise which resolves to the access token. - */ - getAccessToken(): Promise; -} -//# sourceMappingURL=IIdentityServerProvider.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts.map deleted file mode 100644 index a9f7ee4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"IIdentityServerProvider.d.ts","sourceRoot":"","sources":["../../src/@types/IIdentityServerProvider.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,uBAAuB;IACpC;;;;OAIG;IACH,cAAc,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;CAC5C"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js deleted file mode 100644 index 6b02530..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=IIdentityServerProvider.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js.map deleted file mode 100644 index 8d627cd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/IIdentityServerProvider.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"IIdentityServerProvider.js","names":[],"sources":["../../src/@types/IIdentityServerProvider.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport interface IIdentityServerProvider {\n /**\n * Gets an access token for use against the identity server,\n * for the associated client.\n * @returns Promise which resolves to the access token.\n */\n getAccessToken(): Promise;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts deleted file mode 100644 index bea41c8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts +++ /dev/null @@ -1,140 +0,0 @@ -export declare enum PushRuleActionName { - DontNotify = "dont_notify", - Notify = "notify", - Coalesce = "coalesce" -} -export declare enum TweakName { - Highlight = "highlight", - Sound = "sound" -} -export type Tweak = { - set_tweak: N; - value?: V; -}; -export type TweakHighlight = Tweak; -export type TweakSound = Tweak; -export type Tweaks = TweakHighlight | TweakSound; -export declare enum ConditionOperator { - ExactEquals = "==", - LessThan = "<", - GreaterThan = ">", - GreaterThanOrEqual = ">=", - LessThanOrEqual = "<=" -} -export type PushRuleAction = Tweaks | PushRuleActionName; -export type MemberCountCondition = `${Op}${N}` | (Op extends ConditionOperator.ExactEquals ? `${N}` : never); -export type AnyMemberCountCondition = MemberCountCondition; -export declare const DMMemberCountCondition: MemberCountCondition<2>; -export declare function isDmMemberCountCondition(condition: AnyMemberCountCondition): boolean; -export declare enum ConditionKind { - EventMatch = "event_match", - EventPropertyIs = "event_property_is", - EventPropertyContains = "event_property_contains", - ContainsDisplayName = "contains_display_name", - RoomMemberCount = "room_member_count", - SenderNotificationPermission = "sender_notification_permission", - CallStarted = "call_started", - CallStartedPrefix = "org.matrix.msc3914.call_started" -} -export interface IPushRuleCondition { - [k: string]: any; - kind: N; -} -export interface IEventMatchCondition extends IPushRuleCondition { - key: string; - pattern?: string; - value?: string; -} -export interface IEventPropertyIsCondition extends IPushRuleCondition { - key: string; - value: string | boolean | null | number; -} -export interface IEventPropertyContainsCondition extends IPushRuleCondition { - key: string; - value: string | boolean | null | number; -} -export interface IContainsDisplayNameCondition extends IPushRuleCondition { -} -export interface IRoomMemberCountCondition extends IPushRuleCondition { - is: AnyMemberCountCondition; -} -export interface ISenderNotificationPermissionCondition extends IPushRuleCondition { - key: string; -} -export interface ICallStartedCondition extends IPushRuleCondition { -} -export interface ICallStartedPrefixCondition extends IPushRuleCondition { -} -export type PushRuleCondition = IEventMatchCondition | IEventPropertyIsCondition | IEventPropertyContainsCondition | IContainsDisplayNameCondition | IRoomMemberCountCondition | ISenderNotificationPermissionCondition | ICallStartedCondition | ICallStartedPrefixCondition; -export declare enum PushRuleKind { - Override = "override", - ContentSpecific = "content", - RoomSpecific = "room", - SenderSpecific = "sender", - Underride = "underride" -} -export declare enum RuleId { - Master = ".m.rule.master", - IsUserMention = ".org.matrix.msc3952.is_user_mention", - IsRoomMention = ".org.matrix.msc3952.is_room_mention", - ContainsDisplayName = ".m.rule.contains_display_name", - ContainsUserName = ".m.rule.contains_user_name", - AtRoomNotification = ".m.rule.roomnotif", - DM = ".m.rule.room_one_to_one", - EncryptedDM = ".m.rule.encrypted_room_one_to_one", - Message = ".m.rule.message", - EncryptedMessage = ".m.rule.encrypted", - InviteToSelf = ".m.rule.invite_for_me", - MemberEvent = ".m.rule.member_event", - IncomingCall = ".m.rule.call", - SuppressNotices = ".m.rule.suppress_notices", - Tombstone = ".m.rule.tombstone", - PollStart = ".m.rule.poll_start", - PollStartUnstable = ".org.matrix.msc3930.rule.poll_start", - PollEnd = ".m.rule.poll_end", - PollEndUnstable = ".org.matrix.msc3930.rule.poll_end", - PollStartOneToOne = ".m.rule.poll_start_one_to_one", - PollStartOneToOneUnstable = ".org.matrix.msc3930.rule.poll_start_one_to_one", - PollEndOneToOne = ".m.rule.poll_end_one_to_one", - PollEndOneToOneUnstable = ".org.matrix.msc3930.rule.poll_end_one_to_one" -} -export type PushRuleSet = { - [k in PushRuleKind]?: IPushRule[]; -}; -export interface IPushRule { - actions: PushRuleAction[]; - conditions?: PushRuleCondition[]; - default: boolean; - enabled: boolean; - pattern?: string; - rule_id: RuleId | string; -} -export interface IAnnotatedPushRule extends IPushRule { - kind: PushRuleKind; -} -export interface IPushRules { - global: PushRuleSet; - device?: PushRuleSet; -} -export interface IPusher { - "app_display_name": string; - "app_id": string; - "data": { - format?: string; - url?: string; - brand?: string; - }; - "device_display_name": string; - "kind": "http" | string; - "lang": string; - "profile_tag"?: string; - "pushkey": string; - "enabled"?: boolean | null; - "org.matrix.msc3881.enabled"?: boolean | null; - "device_id"?: string | null; - "org.matrix.msc3881.device_id"?: string | null; -} -export interface IPusherRequest extends Omit { - append?: boolean; -} -//# sourceMappingURL=PushRules.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts.map deleted file mode 100644 index 11b4c9a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PushRules.d.ts","sourceRoot":"","sources":["../../src/@types/PushRules.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js deleted file mode 100644 index 9d78b8c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js +++ /dev/null @@ -1,101 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TweakName = exports.RuleId = exports.PushRuleKind = exports.PushRuleActionName = exports.DMMemberCountCondition = exports.ConditionOperator = exports.ConditionKind = void 0; -exports.isDmMemberCountCondition = isDmMemberCountCondition; -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -// allow camelcase as these are things that go onto the wire -/* eslint-disable camelcase */ -let PushRuleActionName; -exports.PushRuleActionName = PushRuleActionName; -(function (PushRuleActionName) { - PushRuleActionName["DontNotify"] = "dont_notify"; - PushRuleActionName["Notify"] = "notify"; - PushRuleActionName["Coalesce"] = "coalesce"; -})(PushRuleActionName || (exports.PushRuleActionName = PushRuleActionName = {})); -let TweakName; -exports.TweakName = TweakName; -(function (TweakName) { - TweakName["Highlight"] = "highlight"; - TweakName["Sound"] = "sound"; -})(TweakName || (exports.TweakName = TweakName = {})); -let ConditionOperator; -exports.ConditionOperator = ConditionOperator; -(function (ConditionOperator) { - ConditionOperator["ExactEquals"] = "=="; - ConditionOperator["LessThan"] = "<"; - ConditionOperator["GreaterThan"] = ">"; - ConditionOperator["GreaterThanOrEqual"] = ">="; - ConditionOperator["LessThanOrEqual"] = "<="; -})(ConditionOperator || (exports.ConditionOperator = ConditionOperator = {})); -const DMMemberCountCondition = "2"; -exports.DMMemberCountCondition = DMMemberCountCondition; -function isDmMemberCountCondition(condition) { - return condition === "==2" || condition === "2"; -} -let ConditionKind; -exports.ConditionKind = ConditionKind; -(function (ConditionKind) { - ConditionKind["EventMatch"] = "event_match"; - ConditionKind["EventPropertyIs"] = "event_property_is"; - ConditionKind["EventPropertyContains"] = "event_property_contains"; - ConditionKind["ContainsDisplayName"] = "contains_display_name"; - ConditionKind["RoomMemberCount"] = "room_member_count"; - ConditionKind["SenderNotificationPermission"] = "sender_notification_permission"; - ConditionKind["CallStarted"] = "call_started"; - ConditionKind["CallStartedPrefix"] = "org.matrix.msc3914.call_started"; -})(ConditionKind || (exports.ConditionKind = ConditionKind = {})); -let PushRuleKind; -exports.PushRuleKind = PushRuleKind; -(function (PushRuleKind) { - PushRuleKind["Override"] = "override"; - PushRuleKind["ContentSpecific"] = "content"; - PushRuleKind["RoomSpecific"] = "room"; - PushRuleKind["SenderSpecific"] = "sender"; - PushRuleKind["Underride"] = "underride"; -})(PushRuleKind || (exports.PushRuleKind = PushRuleKind = {})); -let RuleId; -exports.RuleId = RuleId; -(function (RuleId) { - RuleId["Master"] = ".m.rule.master"; - RuleId["IsUserMention"] = ".org.matrix.msc3952.is_user_mention"; - RuleId["IsRoomMention"] = ".org.matrix.msc3952.is_room_mention"; - RuleId["ContainsDisplayName"] = ".m.rule.contains_display_name"; - RuleId["ContainsUserName"] = ".m.rule.contains_user_name"; - RuleId["AtRoomNotification"] = ".m.rule.roomnotif"; - RuleId["DM"] = ".m.rule.room_one_to_one"; - RuleId["EncryptedDM"] = ".m.rule.encrypted_room_one_to_one"; - RuleId["Message"] = ".m.rule.message"; - RuleId["EncryptedMessage"] = ".m.rule.encrypted"; - RuleId["InviteToSelf"] = ".m.rule.invite_for_me"; - RuleId["MemberEvent"] = ".m.rule.member_event"; - RuleId["IncomingCall"] = ".m.rule.call"; - RuleId["SuppressNotices"] = ".m.rule.suppress_notices"; - RuleId["Tombstone"] = ".m.rule.tombstone"; - RuleId["PollStart"] = ".m.rule.poll_start"; - RuleId["PollStartUnstable"] = ".org.matrix.msc3930.rule.poll_start"; - RuleId["PollEnd"] = ".m.rule.poll_end"; - RuleId["PollEndUnstable"] = ".org.matrix.msc3930.rule.poll_end"; - RuleId["PollStartOneToOne"] = ".m.rule.poll_start_one_to_one"; - RuleId["PollStartOneToOneUnstable"] = ".org.matrix.msc3930.rule.poll_start_one_to_one"; - RuleId["PollEndOneToOne"] = ".m.rule.poll_end_one_to_one"; - RuleId["PollEndOneToOneUnstable"] = ".org.matrix.msc3930.rule.poll_end_one_to_one"; -})(RuleId || (exports.RuleId = RuleId = {})); -/* eslint-enable camelcase */ -//# sourceMappingURL=PushRules.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js.map deleted file mode 100644 index 7ee930b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/PushRules.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PushRules.js","names":["PushRuleActionName","exports","TweakName","ConditionOperator","DMMemberCountCondition","isDmMemberCountCondition","condition","ConditionKind","PushRuleKind","RuleId"],"sources":["../../src/@types/PushRules.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n// allow camelcase as these are things that go onto the wire\n/* eslint-disable camelcase */\n\nexport enum PushRuleActionName {\n DontNotify = \"dont_notify\",\n Notify = \"notify\",\n Coalesce = \"coalesce\",\n}\n\nexport enum TweakName {\n Highlight = \"highlight\",\n Sound = \"sound\",\n}\n\nexport type Tweak = {\n set_tweak: N;\n value?: V;\n};\n\nexport type TweakHighlight = Tweak;\nexport type TweakSound = Tweak;\n\nexport type Tweaks = TweakHighlight | TweakSound;\n\nexport enum ConditionOperator {\n ExactEquals = \"==\",\n LessThan = \"<\",\n GreaterThan = \">\",\n GreaterThanOrEqual = \">=\",\n LessThanOrEqual = \"<=\",\n}\n\nexport type PushRuleAction = Tweaks | PushRuleActionName;\n\nexport type MemberCountCondition =\n | `${Op}${N}`\n | (Op extends ConditionOperator.ExactEquals ? `${N}` : never);\n\nexport type AnyMemberCountCondition = MemberCountCondition;\n\nexport const DMMemberCountCondition: MemberCountCondition<2> = \"2\";\n\nexport function isDmMemberCountCondition(condition: AnyMemberCountCondition): boolean {\n return condition === \"==2\" || condition === \"2\";\n}\n\nexport enum ConditionKind {\n EventMatch = \"event_match\",\n EventPropertyIs = \"event_property_is\",\n EventPropertyContains = \"event_property_contains\",\n ContainsDisplayName = \"contains_display_name\",\n RoomMemberCount = \"room_member_count\",\n SenderNotificationPermission = \"sender_notification_permission\",\n CallStarted = \"call_started\",\n CallStartedPrefix = \"org.matrix.msc3914.call_started\",\n}\n\nexport interface IPushRuleCondition {\n [k: string]: any; // for custom conditions, there can be other fields here\n kind: N;\n}\n\nexport interface IEventMatchCondition extends IPushRuleCondition {\n key: string;\n pattern?: string;\n // Note that value property is an optimization for patterns which do not do\n // any globbing and when the key is not \"content.body\".\n value?: string;\n}\n\nexport interface IEventPropertyIsCondition extends IPushRuleCondition {\n key: string;\n value: string | boolean | null | number;\n}\n\nexport interface IEventPropertyContainsCondition extends IPushRuleCondition {\n key: string;\n value: string | boolean | null | number;\n}\n\nexport interface IContainsDisplayNameCondition extends IPushRuleCondition {\n // no additional fields\n}\n\nexport interface IRoomMemberCountCondition extends IPushRuleCondition {\n is: AnyMemberCountCondition;\n}\n\nexport interface ISenderNotificationPermissionCondition\n extends IPushRuleCondition {\n key: string;\n}\n\nexport interface ICallStartedCondition extends IPushRuleCondition {\n // no additional fields\n}\n\nexport interface ICallStartedPrefixCondition extends IPushRuleCondition {\n // no additional fields\n}\n\n// XXX: custom conditions are possible but always fail, and break the typescript discriminated union so ignore them here\n// IPushRuleCondition> unfortunately does not resolve this at the time of writing.\nexport type PushRuleCondition =\n | IEventMatchCondition\n | IEventPropertyIsCondition\n | IEventPropertyContainsCondition\n | IContainsDisplayNameCondition\n | IRoomMemberCountCondition\n | ISenderNotificationPermissionCondition\n | ICallStartedCondition\n | ICallStartedPrefixCondition;\n\nexport enum PushRuleKind {\n Override = \"override\",\n ContentSpecific = \"content\",\n RoomSpecific = \"room\",\n SenderSpecific = \"sender\",\n Underride = \"underride\",\n}\n\nexport enum RuleId {\n Master = \".m.rule.master\",\n IsUserMention = \".org.matrix.msc3952.is_user_mention\",\n IsRoomMention = \".org.matrix.msc3952.is_room_mention\",\n ContainsDisplayName = \".m.rule.contains_display_name\",\n ContainsUserName = \".m.rule.contains_user_name\",\n AtRoomNotification = \".m.rule.roomnotif\",\n DM = \".m.rule.room_one_to_one\",\n EncryptedDM = \".m.rule.encrypted_room_one_to_one\",\n Message = \".m.rule.message\",\n EncryptedMessage = \".m.rule.encrypted\",\n InviteToSelf = \".m.rule.invite_for_me\",\n MemberEvent = \".m.rule.member_event\",\n IncomingCall = \".m.rule.call\",\n SuppressNotices = \".m.rule.suppress_notices\",\n Tombstone = \".m.rule.tombstone\",\n PollStart = \".m.rule.poll_start\",\n PollStartUnstable = \".org.matrix.msc3930.rule.poll_start\",\n PollEnd = \".m.rule.poll_end\",\n PollEndUnstable = \".org.matrix.msc3930.rule.poll_end\",\n PollStartOneToOne = \".m.rule.poll_start_one_to_one\",\n PollStartOneToOneUnstable = \".org.matrix.msc3930.rule.poll_start_one_to_one\",\n PollEndOneToOne = \".m.rule.poll_end_one_to_one\",\n PollEndOneToOneUnstable = \".org.matrix.msc3930.rule.poll_end_one_to_one\",\n}\n\nexport type PushRuleSet = {\n [k in PushRuleKind]?: IPushRule[];\n};\n\nexport interface IPushRule {\n actions: PushRuleAction[];\n conditions?: PushRuleCondition[];\n default: boolean;\n enabled: boolean;\n pattern?: string;\n rule_id: RuleId | string;\n}\n\nexport interface IAnnotatedPushRule extends IPushRule {\n kind: PushRuleKind;\n}\n\nexport interface IPushRules {\n global: PushRuleSet;\n device?: PushRuleSet;\n}\n\nexport interface IPusher {\n \"app_display_name\": string;\n \"app_id\": string;\n \"data\": {\n format?: string;\n url?: string; // TODO: Required if kind==http\n brand?: string; // TODO: For email notifications only? Unspecced field\n };\n \"device_display_name\": string;\n \"kind\": \"http\" | string;\n \"lang\": string;\n \"profile_tag\"?: string;\n \"pushkey\": string;\n \"enabled\"?: boolean | null;\n \"org.matrix.msc3881.enabled\"?: boolean | null;\n \"device_id\"?: string | null;\n \"org.matrix.msc3881.device_id\"?: string | null;\n}\n\nexport interface IPusherRequest extends Omit {\n append?: boolean;\n}\n\n/* eslint-enable camelcase */\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA,IAEYA,kBAAkB;AAAAC,OAAA,CAAAD,kBAAA,GAAAA,kBAAA;AAAA,WAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;AAAA,GAAlBA,kBAAkB,KAAAC,OAAA,CAAAD,kBAAA,GAAlBA,kBAAkB;AAAA,IAMlBE,SAAS;AAAAD,OAAA,CAAAC,SAAA,GAAAA,SAAA;AAAA,WAATA,SAAS;EAATA,SAAS;EAATA,SAAS;AAAA,GAATA,SAAS,KAAAD,OAAA,CAAAC,SAAA,GAATA,SAAS;AAAA,IAeTC,iBAAiB;AAAAF,OAAA,CAAAE,iBAAA,GAAAA,iBAAA;AAAA,WAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;AAAA,GAAjBA,iBAAiB,KAAAF,OAAA,CAAAE,iBAAA,GAAjBA,iBAAiB;AAgBtB,MAAMC,sBAA+C,GAAG,GAAG;AAACH,OAAA,CAAAG,sBAAA,GAAAA,sBAAA;AAE5D,SAASC,wBAAwBA,CAACC,SAAkC,EAAW;EAClF,OAAOA,SAAS,KAAK,KAAK,IAAIA,SAAS,KAAK,GAAG;AACnD;AAAC,IAEWC,aAAa;AAAAN,OAAA,CAAAM,aAAA,GAAAA,aAAA;AAAA,WAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;AAAA,GAAbA,aAAa,KAAAN,OAAA,CAAAM,aAAA,GAAbA,aAAa;AAAA,IAmEbC,YAAY;AAAAP,OAAA,CAAAO,YAAA,GAAAA,YAAA;AAAA,WAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;AAAA,GAAZA,YAAY,KAAAP,OAAA,CAAAO,YAAA,GAAZA,YAAY;AAAA,IAQZC,MAAM;AAAAR,OAAA,CAAAQ,MAAA,GAAAA,MAAA;AAAA,WAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;AAAA,GAANA,MAAM,KAAAR,OAAA,CAAAQ,MAAA,GAANA,MAAM;AAuElB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js deleted file mode 100644 index 9a390c3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict"; \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js.map deleted file mode 100644 index ed298ab..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/another-json.d.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"another-json.d.js","names":[],"sources":["../../src/@types/another-json.d.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\ndeclare module \"another-json\" {\n export function stringify(o: object): string;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts deleted file mode 100644 index 6e36198..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts +++ /dev/null @@ -1,78 +0,0 @@ -import { UnstableValue } from "../NamespacedValue"; -/** - * Represents a response to the CSAPI `/refresh` endpoint. - */ -export interface IRefreshTokenResponse { - access_token: string; - expires_in_ms: number; - refresh_token: string; -} -/** - * Response to GET login flows as per https://spec.matrix.org/v1.3/client-server-api/#get_matrixclientv3login - */ -export interface ILoginFlowsResponse { - flows: LoginFlow[]; -} -export type LoginFlow = ISSOFlow | IPasswordFlow | ILoginFlow; -export interface ILoginFlow { - type: string; -} -export interface IPasswordFlow extends ILoginFlow { - type: "m.login.password"; -} -export declare const DELEGATED_OIDC_COMPATIBILITY: UnstableValue<"delegated_oidc_compatibility", "org.matrix.msc3824.delegated_oidc_compatibility">; -/** - * Representation of SSO flow as per https://spec.matrix.org/v1.3/client-server-api/#client-login-via-sso - */ -export interface ISSOFlow extends ILoginFlow { - type: "m.login.sso" | "m.login.cas"; - identity_providers?: IIdentityProvider[]; - [DELEGATED_OIDC_COMPATIBILITY.name]?: boolean; - [DELEGATED_OIDC_COMPATIBILITY.altName]?: boolean; -} -export declare enum IdentityProviderBrand { - Gitlab = "gitlab", - Github = "github", - Apple = "apple", - Google = "google", - Facebook = "facebook", - Twitter = "twitter" -} -export interface IIdentityProvider { - id: string; - name: string; - icon?: string; - brand?: IdentityProviderBrand | string; -} -/** - * Parameters to login request as per https://spec.matrix.org/v1.3/client-server-api/#login - */ -export interface ILoginParams { - identifier?: object; - password?: string; - token?: string; - device_id?: string; - initial_device_display_name?: string; -} -export declare enum SSOAction { - /** The user intends to login to an existing account */ - LOGIN = "login", - /** The user intends to register for a new account */ - REGISTER = "register" -} -/** - * The result of a successful [MSC3882](https://github.com/matrix-org/matrix-spec-proposals/pull/3882) - * `m.login.token` issuance request. - * Note that this is UNSTABLE and subject to breaking changes without notice. - */ -export interface LoginTokenPostResponse { - /** - * The token to use with `m.login.token` to authenticate. - */ - login_token: string; - /** - * Expiration in seconds. - */ - expires_in: number; -} -//# sourceMappingURL=auth.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts.map deleted file mode 100644 index c574cc4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/@types/auth.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAKnD;;GAEG;AACH,MAAM,WAAW,qBAAqB;IAClC,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;CACzB;AAID;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAChC,KAAK,EAAE,SAAS,EAAE,CAAC;CACtB;AAED,MAAM,MAAM,SAAS,GAAG,QAAQ,GAAG,aAAa,GAAG,UAAU,CAAC;AAE9D,MAAM,WAAW,UAAU;IACvB,IAAI,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,aAAc,SAAQ,UAAU;IAC7C,IAAI,EAAE,kBAAkB,CAAC;CAC5B;AAED,eAAO,MAAM,4BAA4B,kGAGxC,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,QAAS,SAAQ,UAAU;IACxC,IAAI,EAAE,aAAa,GAAG,aAAa,CAAC;IAEpC,kBAAkB,CAAC,EAAE,iBAAiB,EAAE,CAAC;IACzC,CAAC,4BAA4B,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,CAAC;IAC9C,CAAC,4BAA4B,CAAC,OAAO,CAAC,CAAC,EAAE,OAAO,CAAC;CACpD;AAED,oBAAY,qBAAqB;IAC7B,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,KAAK,UAAU;IACf,MAAM,WAAW;IACjB,QAAQ,aAAa;IACrB,OAAO,YAAY;CACtB;AAED,MAAM,WAAW,iBAAiB;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,qBAAqB,GAAG,MAAM,CAAC;CAC1C;AAED;;GAEG;AAEH,MAAM,WAAW,YAAY;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,2BAA2B,CAAC,EAAE,MAAM,CAAC;CACxC;AAGD,oBAAY,SAAS;IACjB,uDAAuD;IACvD,KAAK,UAAU;IAEf,qDAAqD;IACrD,QAAQ,aAAa;CACxB;AAED;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACnC;;OAEG;IACH,WAAW,EAAE,MAAM,CAAC;IACpB;;OAEG;IACH,UAAU,EAAE,MAAM,CAAC;CACtB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js deleted file mode 100644 index f0aed8e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js +++ /dev/null @@ -1,52 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SSOAction = exports.IdentityProviderBrand = exports.DELEGATED_OIDC_COMPATIBILITY = void 0; -var _NamespacedValue = require("../NamespacedValue"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const DELEGATED_OIDC_COMPATIBILITY = new _NamespacedValue.UnstableValue("delegated_oidc_compatibility", "org.matrix.msc3824.delegated_oidc_compatibility"); - -/** - * Representation of SSO flow as per https://spec.matrix.org/v1.3/client-server-api/#client-login-via-sso - */ -exports.DELEGATED_OIDC_COMPATIBILITY = DELEGATED_OIDC_COMPATIBILITY; -let IdentityProviderBrand; -exports.IdentityProviderBrand = IdentityProviderBrand; -(function (IdentityProviderBrand) { - IdentityProviderBrand["Gitlab"] = "gitlab"; - IdentityProviderBrand["Github"] = "github"; - IdentityProviderBrand["Apple"] = "apple"; - IdentityProviderBrand["Google"] = "google"; - IdentityProviderBrand["Facebook"] = "facebook"; - IdentityProviderBrand["Twitter"] = "twitter"; -})(IdentityProviderBrand || (exports.IdentityProviderBrand = IdentityProviderBrand = {})); -/* eslint-enable camelcase */ -let SSOAction; -/** - * The result of a successful [MSC3882](https://github.com/matrix-org/matrix-spec-proposals/pull/3882) - * `m.login.token` issuance request. - * Note that this is UNSTABLE and subject to breaking changes without notice. - */ -exports.SSOAction = SSOAction; -(function (SSOAction) { - SSOAction["LOGIN"] = "login"; - SSOAction["REGISTER"] = "register"; -})(SSOAction || (exports.SSOAction = SSOAction = {})); -//# sourceMappingURL=auth.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js.map deleted file mode 100644 index ae209b4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/auth.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"auth.js","names":["_NamespacedValue","require","DELEGATED_OIDC_COMPATIBILITY","UnstableValue","exports","IdentityProviderBrand","SSOAction"],"sources":["../../src/@types/auth.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { UnstableValue } from \"../NamespacedValue\";\n\n// disable lint because these are wire responses\n/* eslint-disable camelcase */\n\n/**\n * Represents a response to the CSAPI `/refresh` endpoint.\n */\nexport interface IRefreshTokenResponse {\n access_token: string;\n expires_in_ms: number;\n refresh_token: string;\n}\n\n/* eslint-enable camelcase */\n\n/**\n * Response to GET login flows as per https://spec.matrix.org/v1.3/client-server-api/#get_matrixclientv3login\n */\nexport interface ILoginFlowsResponse {\n flows: LoginFlow[];\n}\n\nexport type LoginFlow = ISSOFlow | IPasswordFlow | ILoginFlow;\n\nexport interface ILoginFlow {\n type: string;\n}\n\nexport interface IPasswordFlow extends ILoginFlow {\n type: \"m.login.password\";\n}\n\nexport const DELEGATED_OIDC_COMPATIBILITY = new UnstableValue(\n \"delegated_oidc_compatibility\",\n \"org.matrix.msc3824.delegated_oidc_compatibility\",\n);\n\n/**\n * Representation of SSO flow as per https://spec.matrix.org/v1.3/client-server-api/#client-login-via-sso\n */\nexport interface ISSOFlow extends ILoginFlow {\n type: \"m.login.sso\" | \"m.login.cas\";\n // eslint-disable-next-line camelcase\n identity_providers?: IIdentityProvider[];\n [DELEGATED_OIDC_COMPATIBILITY.name]?: boolean;\n [DELEGATED_OIDC_COMPATIBILITY.altName]?: boolean;\n}\n\nexport enum IdentityProviderBrand {\n Gitlab = \"gitlab\",\n Github = \"github\",\n Apple = \"apple\",\n Google = \"google\",\n Facebook = \"facebook\",\n Twitter = \"twitter\",\n}\n\nexport interface IIdentityProvider {\n id: string;\n name: string;\n icon?: string;\n brand?: IdentityProviderBrand | string;\n}\n\n/**\n * Parameters to login request as per https://spec.matrix.org/v1.3/client-server-api/#login\n */\n/* eslint-disable camelcase */\nexport interface ILoginParams {\n identifier?: object;\n password?: string;\n token?: string;\n device_id?: string;\n initial_device_display_name?: string;\n}\n/* eslint-enable camelcase */\n\nexport enum SSOAction {\n /** The user intends to login to an existing account */\n LOGIN = \"login\",\n\n /** The user intends to register for a new account */\n REGISTER = \"register\",\n}\n\n/**\n * The result of a successful [MSC3882](https://github.com/matrix-org/matrix-spec-proposals/pull/3882)\n * `m.login.token` issuance request.\n * Note that this is UNSTABLE and subject to breaking changes without notice.\n */\nexport interface LoginTokenPostResponse {\n /**\n * The token to use with `m.login.token` to authenticate.\n */\n login_token: string;\n /**\n * Expiration in seconds.\n */\n expires_in: number;\n}\n"],"mappings":";;;;;;AAgBA,IAAAA,gBAAA,GAAAC,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAmCO,MAAMC,4BAA4B,GAAG,IAAIC,8BAAa,CACzD,8BAA8B,EAC9B,iDAAiD,CACpD;;AAED;AACA;AACA;AAFAC,OAAA,CAAAF,4BAAA,GAAAA,4BAAA;AAAA,IAWYG,qBAAqB;AAAAD,OAAA,CAAAC,qBAAA,GAAAA,qBAAA;AAAA,WAArBA,qBAAqB;EAArBA,qBAAqB;EAArBA,qBAAqB;EAArBA,qBAAqB;EAArBA,qBAAqB;EAArBA,qBAAqB;EAArBA,qBAAqB;AAAA,GAArBA,qBAAqB,KAAAD,OAAA,CAAAC,qBAAA,GAArBA,qBAAqB;AA2BjC;AAAA,IAEYC,SAAS;AAQrB;AACA;AACA;AACA;AACA;AAJAF,OAAA,CAAAE,SAAA,GAAAA,SAAA;AAAA,WARYA,SAAS;EAATA,SAAS;EAATA,SAAS;AAAA,GAATA,SAAS,KAAAF,OAAA,CAAAE,SAAA,GAATA,SAAS"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts deleted file mode 100644 index 5b9dc42..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts +++ /dev/null @@ -1,106 +0,0 @@ -import { RelatesToRelationship, REFERENCE_RELATION } from "./extensible_events"; -import { UnstableValue } from "../NamespacedValue"; -import { MAssetEvent, MLocationEvent, MTimestampEvent } from "./location"; -/** - * Beacon info and beacon event types as described in MSC3672 - * https://github.com/matrix-org/matrix-spec-proposals/pull/3672 - */ -/** - * Beacon info events are state events. - * We have two requirements for these events: - * 1. they can only be written by their owner - * 2. a user can have an arbitrary number of beacon_info events - * - * 1. is achieved by setting the state_key to the owners mxid. - * Event keys in room state are a combination of `type` + `state_key`. - * To achieve an arbitrary number of only owner-writable state events - * we introduce a variable suffix to the event type - * - * @example - * ``` - * { - * "type": "m.beacon_info.@matthew:matrix.org.1", - * "state_key": "@matthew:matrix.org", - * "content": { - * "m.beacon_info": { - * "description": "The Matthew Tracker", - * "timeout": 86400000, - * }, - * // more content as described below - * } - * }, - * { - * "type": "m.beacon_info.@matthew:matrix.org.2", - * "state_key": "@matthew:matrix.org", - * "content": { - * "m.beacon_info": { - * "description": "Another different Matthew tracker", - * "timeout": 400000, - * }, - * // more content as described below - * } - * } - * ``` - */ -/** - * Non-variable type for m.beacon_info event content - */ -export declare const M_BEACON_INFO: UnstableValue<"m.beacon_info", "org.matrix.msc3672.beacon_info">; -export declare const M_BEACON: UnstableValue<"m.beacon", "org.matrix.msc3672.beacon">; -export type MBeaconInfoContent = { - description?: string; - timeout: number; - live?: boolean; -}; -/** - * m.beacon_info Event example from the spec - * https://github.com/matrix-org/matrix-spec-proposals/pull/3672 - * @example - * ``` - * { - * "type": "m.beacon_info", - * "state_key": "@matthew:matrix.org", - * "content": { - * "m.beacon_info": { - * "description": "The Matthew Tracker", // same as an `m.location` description - * "timeout": 86400000, // how long from the last event until we consider the beacon inactive in milliseconds - * }, - * "m.ts": 1436829458432, // creation timestamp of the beacon on the client - * "m.asset": { - * "type": "m.self" // the type of asset being tracked as per MSC3488 - * } - * } - * } - * ``` - */ -/** - * m.beacon_info.* event content - */ -export type MBeaconInfoEventContent = MBeaconInfoContent & MTimestampEvent & MAssetEvent; -/** - * m.beacon event example - * https://github.com/matrix-org/matrix-spec-proposals/pull/3672 - * @example - * ``` - * { - * "type": "m.beacon", - * "sender": "@matthew:matrix.org", - * "content": { - * "m.relates_to": { // from MSC2674: https://github.com/matrix-org/matrix-doc/pull/2674 - * "rel_type": "m.reference", // from MSC3267: https://github.com/matrix-org/matrix-doc/pull/3267 - * "event_id": "$beacon_info" - * }, - * "m.location": { - * "uri": "geo:51.5008,0.1247;u=35", - * "description": "Arbitrary beacon information" - * }, - * "m.ts": 1636829458432, - * } - * } - * ``` - */ -/** - * Content of an m.beacon event - */ -export type MBeaconEventContent = MLocationEvent & MTimestampEvent & RelatesToRelationship; -//# sourceMappingURL=beacon.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts.map deleted file mode 100644 index 57c2c27..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"beacon.d.ts","sourceRoot":"","sources":["../../src/@types/beacon.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAE1E;;;GAGG;AAEH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AAEH;;GAEG;AACH,eAAO,MAAM,aAAa,kEAAuE,CAAC;AAClG,eAAO,MAAM,QAAQ,wDAA6D,CAAC;AAEnF,MAAM,MAAM,kBAAkB,GAAG;IAC7B,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,OAAO,EAAE,MAAM,CAAC;IAGhB,IAAI,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;GAoBG;AAEH;;GAEG;AACH,MAAM,MAAM,uBAAuB,GAAG,kBAAkB,GAEpD,eAAe,GAEf,WAAW,CAAC;AAEhB;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH;;GAEG;AACH,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAE5C,eAAe,GAEf,qBAAqB,CAAC,OAAO,kBAAkB,CAAC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js deleted file mode 100644 index 5255817..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js +++ /dev/null @@ -1,74 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.M_BEACON_INFO = exports.M_BEACON = void 0; -var _NamespacedValue = require("../NamespacedValue"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Beacon info and beacon event types as described in MSC3672 - * https://github.com/matrix-org/matrix-spec-proposals/pull/3672 - */ - -/** - * Beacon info events are state events. - * We have two requirements for these events: - * 1. they can only be written by their owner - * 2. a user can have an arbitrary number of beacon_info events - * - * 1. is achieved by setting the state_key to the owners mxid. - * Event keys in room state are a combination of `type` + `state_key`. - * To achieve an arbitrary number of only owner-writable state events - * we introduce a variable suffix to the event type - * - * @example - * ``` - * { - * "type": "m.beacon_info.@matthew:matrix.org.1", - * "state_key": "@matthew:matrix.org", - * "content": { - * "m.beacon_info": { - * "description": "The Matthew Tracker", - * "timeout": 86400000, - * }, - * // more content as described below - * } - * }, - * { - * "type": "m.beacon_info.@matthew:matrix.org.2", - * "state_key": "@matthew:matrix.org", - * "content": { - * "m.beacon_info": { - * "description": "Another different Matthew tracker", - * "timeout": 400000, - * }, - * // more content as described below - * } - * } - * ``` - */ - -/** - * Non-variable type for m.beacon_info event content - */ -const M_BEACON_INFO = new _NamespacedValue.UnstableValue("m.beacon_info", "org.matrix.msc3672.beacon_info"); -exports.M_BEACON_INFO = M_BEACON_INFO; -const M_BEACON = new _NamespacedValue.UnstableValue("m.beacon", "org.matrix.msc3672.beacon"); -exports.M_BEACON = M_BEACON; -//# sourceMappingURL=beacon.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js.map deleted file mode 100644 index 403cbe0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/beacon.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"beacon.js","names":["_NamespacedValue","require","M_BEACON_INFO","UnstableValue","exports","M_BEACON"],"sources":["../../src/@types/beacon.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { RelatesToRelationship, REFERENCE_RELATION } from \"./extensible_events\";\nimport { UnstableValue } from \"../NamespacedValue\";\nimport { MAssetEvent, MLocationEvent, MTimestampEvent } from \"./location\";\n\n/**\n * Beacon info and beacon event types as described in MSC3672\n * https://github.com/matrix-org/matrix-spec-proposals/pull/3672\n */\n\n/**\n * Beacon info events are state events.\n * We have two requirements for these events:\n * 1. they can only be written by their owner\n * 2. a user can have an arbitrary number of beacon_info events\n *\n * 1. is achieved by setting the state_key to the owners mxid.\n * Event keys in room state are a combination of `type` + `state_key`.\n * To achieve an arbitrary number of only owner-writable state events\n * we introduce a variable suffix to the event type\n *\n * @example\n * ```\n * {\n * \"type\": \"m.beacon_info.@matthew:matrix.org.1\",\n * \"state_key\": \"@matthew:matrix.org\",\n * \"content\": {\n * \"m.beacon_info\": {\n * \"description\": \"The Matthew Tracker\",\n * \"timeout\": 86400000,\n * },\n * // more content as described below\n * }\n * },\n * {\n * \"type\": \"m.beacon_info.@matthew:matrix.org.2\",\n * \"state_key\": \"@matthew:matrix.org\",\n * \"content\": {\n * \"m.beacon_info\": {\n * \"description\": \"Another different Matthew tracker\",\n * \"timeout\": 400000,\n * },\n * // more content as described below\n * }\n * }\n * ```\n */\n\n/**\n * Non-variable type for m.beacon_info event content\n */\nexport const M_BEACON_INFO = new UnstableValue(\"m.beacon_info\", \"org.matrix.msc3672.beacon_info\");\nexport const M_BEACON = new UnstableValue(\"m.beacon\", \"org.matrix.msc3672.beacon\");\n\nexport type MBeaconInfoContent = {\n description?: string;\n // how long from the last event until we consider the beacon inactive in milliseconds\n timeout: number;\n // true when this is a live location beacon\n // https://github.com/matrix-org/matrix-spec-proposals/pull/3672\n live?: boolean;\n};\n\n/**\n * m.beacon_info Event example from the spec\n * https://github.com/matrix-org/matrix-spec-proposals/pull/3672\n * @example\n * ```\n * {\n * \"type\": \"m.beacon_info\",\n * \"state_key\": \"@matthew:matrix.org\",\n * \"content\": {\n * \"m.beacon_info\": {\n * \"description\": \"The Matthew Tracker\", // same as an `m.location` description\n * \"timeout\": 86400000, // how long from the last event until we consider the beacon inactive in milliseconds\n * },\n * \"m.ts\": 1436829458432, // creation timestamp of the beacon on the client\n * \"m.asset\": {\n * \"type\": \"m.self\" // the type of asset being tracked as per MSC3488\n * }\n * }\n * }\n * ```\n */\n\n/**\n * m.beacon_info.* event content\n */\nexport type MBeaconInfoEventContent = MBeaconInfoContent &\n // creation timestamp of the beacon on the client\n MTimestampEvent &\n // the type of asset being tracked as per MSC3488\n MAssetEvent;\n\n/**\n * m.beacon event example\n * https://github.com/matrix-org/matrix-spec-proposals/pull/3672\n * @example\n * ```\n * {\n * \"type\": \"m.beacon\",\n * \"sender\": \"@matthew:matrix.org\",\n * \"content\": {\n * \"m.relates_to\": { // from MSC2674: https://github.com/matrix-org/matrix-doc/pull/2674\n * \"rel_type\": \"m.reference\", // from MSC3267: https://github.com/matrix-org/matrix-doc/pull/3267\n * \"event_id\": \"$beacon_info\"\n * },\n * \"m.location\": {\n * \"uri\": \"geo:51.5008,0.1247;u=35\",\n * \"description\": \"Arbitrary beacon information\"\n * },\n * \"m.ts\": 1636829458432,\n * }\n * }\n * ```\n */\n\n/**\n * Content of an m.beacon event\n */\nexport type MBeaconEventContent = MLocationEvent &\n // timestamp when location was taken\n MTimestampEvent &\n // relates to a beacon_info event\n RelatesToRelationship;\n"],"mappings":";;;;;;AAiBA,IAAAA,gBAAA,GAAAC,OAAA;AAjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAMA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACO,MAAMC,aAAa,GAAG,IAAIC,8BAAa,CAAC,eAAe,EAAE,gCAAgC,CAAC;AAACC,OAAA,CAAAF,aAAA,GAAAA,aAAA;AAC3F,MAAMG,QAAQ,GAAG,IAAIF,8BAAa,CAAC,UAAU,EAAE,2BAA2B,CAAC;AAACC,OAAA,CAAAC,QAAA,GAAAA,QAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts deleted file mode 100644 index f9055bb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts +++ /dev/null @@ -1,75 +0,0 @@ -import type { IClearEvent } from "../models/event"; -import type { ISignatures } from "./signed"; -export type OlmGroupSessionExtraData = { - untrusted?: boolean; - sharedHistory?: boolean; -}; -/** - * The result of a (successful) call to {@link Crypto.decryptEvent} - */ -export interface IEventDecryptionResult { - /** - * The plaintext payload for the event (typically containing type and content fields). - */ - clearEvent: IClearEvent; - /** - * List of curve25519 keys involved in telling us about the senderCurve25519Key and claimedEd25519Key. - * See {@link MatrixEvent#getForwardingCurve25519KeyChain}. - */ - forwardingCurve25519KeyChain?: string[]; - /** - * Key owned by the sender of this event. See {@link MatrixEvent#getSenderKey}. - */ - senderCurve25519Key?: string; - /** - * ed25519 key claimed by the sender of this event. See {@link MatrixEvent#getClaimedEd25519Key}. - */ - claimedEd25519Key?: string; - untrusted?: boolean; - /** - * The sender doesn't authorize the unverified devices to decrypt his messages - */ - encryptedDisabledForUnverifiedDevices?: boolean; -} -interface Extensible { - [key: string]: any; -} -/** The result of a call to {@link MatrixClient.exportRoomKeys} */ -export interface IMegolmSessionData extends Extensible { - /** Sender's Curve25519 device key */ - sender_key: string; - /** Devices which forwarded this session to us (normally empty). */ - forwarding_curve25519_key_chain: string[]; - /** Other keys the sender claims. */ - sender_claimed_keys: Record; - /** Room this session is used in */ - room_id: string; - /** Unique id for the session */ - session_id: string; - /** Base64'ed key data */ - session_key: string; - algorithm?: string; - untrusted?: boolean; -} -/** the type of the `device_keys` parameter on `/_matrix/client/v3/keys/upload` - * - * @see https://spec.matrix.org/v1.5/client-server-api/#post_matrixclientv3keysupload - */ -export interface IDeviceKeys { - algorithms: Array; - device_id: string; - user_id: string; - keys: Record; - signatures?: ISignatures; -} -/** the type of the `one_time_keys` and `fallback_keys` parameters on `/_matrix/client/v3/keys/upload` - * - * @see https://spec.matrix.org/v1.5/client-server-api/#post_matrixclientv3keysupload - */ -export interface IOneTimeKey { - key: string; - fallback?: boolean; - signatures?: ISignatures; -} -export {}; -//# sourceMappingURL=crypto.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts.map deleted file mode 100644 index b2fa3ea..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"crypto.d.ts","sourceRoot":"","sources":["../../src/@types/crypto.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAE5C,MAAM,MAAM,wBAAwB,GAAG;IACnC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,aAAa,CAAC,EAAE,OAAO,CAAC;CAC3B,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACnC;;OAEG;IACH,UAAU,EAAE,WAAW,CAAC;IACxB;;;OAGG;IACH,4BAA4B,CAAC,EAAE,MAAM,EAAE,CAAC;IACxC;;OAEG;IACH,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B;;OAEG;IACH,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB;;OAEG;IACH,qCAAqC,CAAC,EAAE,OAAO,CAAC;CACnD;AAED,UAAU,UAAU;IAChB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACtB;AAID,kEAAkE;AAClE,MAAM,WAAW,kBAAmB,SAAQ,UAAU;IAClD,qCAAqC;IACrC,UAAU,EAAE,MAAM,CAAC;IACnB,mEAAmE;IACnE,+BAA+B,EAAE,MAAM,EAAE,CAAC;IAC1C,oCAAoC;IACpC,mBAAmB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC5C,mCAAmC;IACnC,OAAO,EAAE,MAAM,CAAC;IAChB,gCAAgC;IAChC,UAAU,EAAE,MAAM,CAAC;IACnB,yBAAyB;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;CACvB;AAID;;;GAGG;AACH,MAAM,WAAW,WAAW;IACxB,UAAU,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,UAAU,CAAC,EAAE,WAAW,CAAC;CAC5B;AAED;;;GAGG;AACH,MAAM,WAAW,WAAW;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,WAAW,CAAC;CAC5B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js deleted file mode 100644 index fbfcf4f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=crypto.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js.map deleted file mode 100644 index 8003ea2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/crypto.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"crypto.js","names":[],"sources":["../../src/@types/crypto.ts"],"sourcesContent":["/*\nCopyright 2022-2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport type { IClearEvent } from \"../models/event\";\nimport type { ISignatures } from \"./signed\";\n\nexport type OlmGroupSessionExtraData = {\n untrusted?: boolean;\n sharedHistory?: boolean;\n};\n\n/**\n * The result of a (successful) call to {@link Crypto.decryptEvent}\n */\nexport interface IEventDecryptionResult {\n /**\n * The plaintext payload for the event (typically containing type and content fields).\n */\n clearEvent: IClearEvent;\n /**\n * List of curve25519 keys involved in telling us about the senderCurve25519Key and claimedEd25519Key.\n * See {@link MatrixEvent#getForwardingCurve25519KeyChain}.\n */\n forwardingCurve25519KeyChain?: string[];\n /**\n * Key owned by the sender of this event. See {@link MatrixEvent#getSenderKey}.\n */\n senderCurve25519Key?: string;\n /**\n * ed25519 key claimed by the sender of this event. See {@link MatrixEvent#getClaimedEd25519Key}.\n */\n claimedEd25519Key?: string;\n untrusted?: boolean;\n /**\n * The sender doesn't authorize the unverified devices to decrypt his messages\n */\n encryptedDisabledForUnverifiedDevices?: boolean;\n}\n\ninterface Extensible {\n [key: string]: any;\n}\n\n/* eslint-disable camelcase */\n\n/** The result of a call to {@link MatrixClient.exportRoomKeys} */\nexport interface IMegolmSessionData extends Extensible {\n /** Sender's Curve25519 device key */\n sender_key: string;\n /** Devices which forwarded this session to us (normally empty). */\n forwarding_curve25519_key_chain: string[];\n /** Other keys the sender claims. */\n sender_claimed_keys: Record;\n /** Room this session is used in */\n room_id: string;\n /** Unique id for the session */\n session_id: string;\n /** Base64'ed key data */\n session_key: string;\n algorithm?: string;\n untrusted?: boolean;\n}\n\n/* eslint-enable camelcase */\n\n/** the type of the `device_keys` parameter on `/_matrix/client/v3/keys/upload`\n *\n * @see https://spec.matrix.org/v1.5/client-server-api/#post_matrixclientv3keysupload\n */\nexport interface IDeviceKeys {\n algorithms: Array;\n device_id: string; // eslint-disable-line camelcase\n user_id: string; // eslint-disable-line camelcase\n keys: Record;\n signatures?: ISignatures;\n}\n\n/** the type of the `one_time_keys` and `fallback_keys` parameters on `/_matrix/client/v3/keys/upload`\n *\n * @see https://spec.matrix.org/v1.5/client-server-api/#post_matrixclientv3keysupload\n */\nexport interface IOneTimeKey {\n key: string;\n fallback?: boolean;\n signatures?: ISignatures;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts deleted file mode 100644 index 89e6b3c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts +++ /dev/null @@ -1,194 +0,0 @@ -import { UnstableValue } from "../NamespacedValue"; -export declare enum EventType { - RoomCanonicalAlias = "m.room.canonical_alias", - RoomCreate = "m.room.create", - RoomJoinRules = "m.room.join_rules", - RoomMember = "m.room.member", - RoomThirdPartyInvite = "m.room.third_party_invite", - RoomPowerLevels = "m.room.power_levels", - RoomName = "m.room.name", - RoomTopic = "m.room.topic", - RoomAvatar = "m.room.avatar", - RoomPinnedEvents = "m.room.pinned_events", - RoomEncryption = "m.room.encryption", - RoomHistoryVisibility = "m.room.history_visibility", - RoomGuestAccess = "m.room.guest_access", - RoomServerAcl = "m.room.server_acl", - RoomTombstone = "m.room.tombstone", - RoomPredecessor = "org.matrix.msc3946.room_predecessor", - SpaceChild = "m.space.child", - SpaceParent = "m.space.parent", - RoomRedaction = "m.room.redaction", - RoomMessage = "m.room.message", - RoomMessageEncrypted = "m.room.encrypted", - Sticker = "m.sticker", - CallInvite = "m.call.invite", - CallCandidates = "m.call.candidates", - CallAnswer = "m.call.answer", - CallHangup = "m.call.hangup", - CallReject = "m.call.reject", - CallSelectAnswer = "m.call.select_answer", - CallNegotiate = "m.call.negotiate", - CallSDPStreamMetadataChanged = "m.call.sdp_stream_metadata_changed", - CallSDPStreamMetadataChangedPrefix = "org.matrix.call.sdp_stream_metadata_changed", - CallReplaces = "m.call.replaces", - CallAssertedIdentity = "m.call.asserted_identity", - CallAssertedIdentityPrefix = "org.matrix.call.asserted_identity", - KeyVerificationRequest = "m.key.verification.request", - KeyVerificationStart = "m.key.verification.start", - KeyVerificationCancel = "m.key.verification.cancel", - KeyVerificationMac = "m.key.verification.mac", - KeyVerificationDone = "m.key.verification.done", - KeyVerificationKey = "m.key.verification.key", - KeyVerificationAccept = "m.key.verification.accept", - KeyVerificationReady = "m.key.verification.ready", - RoomMessageFeedback = "m.room.message.feedback", - Reaction = "m.reaction", - PollStart = "org.matrix.msc3381.poll.start", - Typing = "m.typing", - Receipt = "m.receipt", - Presence = "m.presence", - FullyRead = "m.fully_read", - Tag = "m.tag", - SpaceOrder = "org.matrix.msc3230.space_order", - PushRules = "m.push_rules", - Direct = "m.direct", - IgnoredUserList = "m.ignored_user_list", - RoomKey = "m.room_key", - RoomKeyRequest = "m.room_key_request", - ForwardedRoomKey = "m.forwarded_room_key", - Dummy = "m.dummy", - GroupCallPrefix = "org.matrix.msc3401.call", - GroupCallMemberPrefix = "org.matrix.msc3401.call.member" -} -export declare enum RelationType { - Annotation = "m.annotation", - Replace = "m.replace", - Reference = "m.reference", - Thread = "m.thread" -} -export declare enum MsgType { - Text = "m.text", - Emote = "m.emote", - Notice = "m.notice", - Image = "m.image", - File = "m.file", - Audio = "m.audio", - Location = "m.location", - Video = "m.video", - KeyVerificationRequest = "m.key.verification.request" -} -export declare const RoomCreateTypeField = "type"; -export declare enum RoomType { - Space = "m.space", - UnstableCall = "org.matrix.msc3417.call", - ElementVideo = "io.element.video" -} -export declare const ToDeviceMessageId = "org.matrix.msgid"; -/** - * Identifier for an [MSC3088](https://github.com/matrix-org/matrix-doc/pull/3088) - * room purpose. Note that this reference is UNSTABLE and subject to breaking changes, - * including its eventual removal. - */ -export declare const UNSTABLE_MSC3088_PURPOSE: UnstableValue<"m.room.purpose", "org.matrix.msc3088.purpose">; -/** - * Enabled flag for an [MSC3088](https://github.com/matrix-org/matrix-doc/pull/3088) - * room purpose. Note that this reference is UNSTABLE and subject to breaking changes, - * including its eventual removal. - */ -export declare const UNSTABLE_MSC3088_ENABLED: UnstableValue<"m.enabled", "org.matrix.msc3088.enabled">; -/** - * Subtype for an [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room. - * Note that this reference is UNSTABLE and subject to breaking changes, including its - * eventual removal. - */ -export declare const UNSTABLE_MSC3089_TREE_SUBTYPE: UnstableValue<"m.data_tree", "org.matrix.msc3089.data_tree">; -/** - * Leaf type for an event in a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room. - * Note that this reference is UNSTABLE and subject to breaking changes, including its - * eventual removal. - */ -export declare const UNSTABLE_MSC3089_LEAF: UnstableValue<"m.leaf", "org.matrix.msc3089.leaf">; -/** - * Branch (Leaf Reference) type for the index approach in a - * [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room. Note that this reference is - * UNSTABLE and subject to breaking changes, including its eventual removal. - */ -export declare const UNSTABLE_MSC3089_BRANCH: UnstableValue<"m.branch", "org.matrix.msc3089.branch">; -/** - * Marker event type to point back at imported historical content in a room. See - * [MSC2716](https://github.com/matrix-org/matrix-spec-proposals/pull/2716). - * Note that this reference is UNSTABLE and subject to breaking changes, - * including its eventual removal. - */ -export declare const UNSTABLE_MSC2716_MARKER: UnstableValue<"m.room.marker", "org.matrix.msc2716.marker">; -/** - * Name of the "with_relations" request property for relation based redactions. - * {@link https://github.com/matrix-org/matrix-spec-proposals/pull/3912} - */ -export declare const MSC3912_RELATION_BASED_REDACTIONS_PROP: UnstableValue<"with_relations", "org.matrix.msc3912.with_relations">; -/** - * Functional members type for declaring a purpose of room members (e.g. helpful bots). - * Note that this reference is UNSTABLE and subject to breaking changes, including its - * eventual removal. - * - * Schema (TypeScript): - * ``` - * { - * service_members?: string[] - * } - * ``` - * - * @example - * ``` - * { - * "service_members": [ - * "@helperbot:localhost", - * "@reminderbot:alice.tdl" - * ] - * } - * ``` - */ -export declare const UNSTABLE_ELEMENT_FUNCTIONAL_USERS: UnstableValue<"io.element.functional_members", "io.element.functional_members">; -/** - * A type of message that affects visibility of a message, - * as per https://github.com/matrix-org/matrix-doc/pull/3531 - * - * @experimental - */ -export declare const EVENT_VISIBILITY_CHANGE_TYPE: UnstableValue<"m.visibility", "org.matrix.msc3531.visibility">; -/** - * https://github.com/matrix-org/matrix-doc/pull/3881 - * - * @experimental - */ -export declare const PUSHER_ENABLED: UnstableValue<"enabled", "org.matrix.msc3881.enabled">; -/** - * https://github.com/matrix-org/matrix-doc/pull/3881 - * - * @experimental - */ -export declare const PUSHER_DEVICE_ID: UnstableValue<"device_id", "org.matrix.msc3881.device_id">; -/** - * https://github.com/matrix-org/matrix-doc/pull/3890 - * - * @experimental - */ -export declare const LOCAL_NOTIFICATION_SETTINGS_PREFIX: UnstableValue<"m.local_notification_settings", "org.matrix.msc3890.local_notification_settings">; -export interface IEncryptedFile { - url: string; - mimetype?: string; - key: { - alg: string; - key_ops: string[]; - kty: string; - k: string; - ext: boolean; - }; - iv: string; - hashes: { - [alg: string]: string; - }; - v: string; -} -//# sourceMappingURL=event.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts.map deleted file mode 100644 index eb1d49b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event.d.ts","sourceRoot":"","sources":["../../src/@types/event.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js deleted file mode 100644 index 5ce77c7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js +++ /dev/null @@ -1,233 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UNSTABLE_MSC3089_TREE_SUBTYPE = exports.UNSTABLE_MSC3089_LEAF = exports.UNSTABLE_MSC3089_BRANCH = exports.UNSTABLE_MSC3088_PURPOSE = exports.UNSTABLE_MSC3088_ENABLED = exports.UNSTABLE_MSC2716_MARKER = exports.UNSTABLE_ELEMENT_FUNCTIONAL_USERS = exports.ToDeviceMessageId = exports.RoomType = exports.RoomCreateTypeField = exports.RelationType = exports.PUSHER_ENABLED = exports.PUSHER_DEVICE_ID = exports.MsgType = exports.MSC3912_RELATION_BASED_REDACTIONS_PROP = exports.LOCAL_NOTIFICATION_SETTINGS_PREFIX = exports.EventType = exports.EVENT_VISIBILITY_CHANGE_TYPE = void 0; -var _NamespacedValue = require("../NamespacedValue"); -/* -Copyright 2020 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let EventType; -exports.EventType = EventType; -(function (EventType) { - EventType["RoomCanonicalAlias"] = "m.room.canonical_alias"; - EventType["RoomCreate"] = "m.room.create"; - EventType["RoomJoinRules"] = "m.room.join_rules"; - EventType["RoomMember"] = "m.room.member"; - EventType["RoomThirdPartyInvite"] = "m.room.third_party_invite"; - EventType["RoomPowerLevels"] = "m.room.power_levels"; - EventType["RoomName"] = "m.room.name"; - EventType["RoomTopic"] = "m.room.topic"; - EventType["RoomAvatar"] = "m.room.avatar"; - EventType["RoomPinnedEvents"] = "m.room.pinned_events"; - EventType["RoomEncryption"] = "m.room.encryption"; - EventType["RoomHistoryVisibility"] = "m.room.history_visibility"; - EventType["RoomGuestAccess"] = "m.room.guest_access"; - EventType["RoomServerAcl"] = "m.room.server_acl"; - EventType["RoomTombstone"] = "m.room.tombstone"; - EventType["RoomPredecessor"] = "org.matrix.msc3946.room_predecessor"; - EventType["SpaceChild"] = "m.space.child"; - EventType["SpaceParent"] = "m.space.parent"; - EventType["RoomRedaction"] = "m.room.redaction"; - EventType["RoomMessage"] = "m.room.message"; - EventType["RoomMessageEncrypted"] = "m.room.encrypted"; - EventType["Sticker"] = "m.sticker"; - EventType["CallInvite"] = "m.call.invite"; - EventType["CallCandidates"] = "m.call.candidates"; - EventType["CallAnswer"] = "m.call.answer"; - EventType["CallHangup"] = "m.call.hangup"; - EventType["CallReject"] = "m.call.reject"; - EventType["CallSelectAnswer"] = "m.call.select_answer"; - EventType["CallNegotiate"] = "m.call.negotiate"; - EventType["CallSDPStreamMetadataChanged"] = "m.call.sdp_stream_metadata_changed"; - EventType["CallSDPStreamMetadataChangedPrefix"] = "org.matrix.call.sdp_stream_metadata_changed"; - EventType["CallReplaces"] = "m.call.replaces"; - EventType["CallAssertedIdentity"] = "m.call.asserted_identity"; - EventType["CallAssertedIdentityPrefix"] = "org.matrix.call.asserted_identity"; - EventType["KeyVerificationRequest"] = "m.key.verification.request"; - EventType["KeyVerificationStart"] = "m.key.verification.start"; - EventType["KeyVerificationCancel"] = "m.key.verification.cancel"; - EventType["KeyVerificationMac"] = "m.key.verification.mac"; - EventType["KeyVerificationDone"] = "m.key.verification.done"; - EventType["KeyVerificationKey"] = "m.key.verification.key"; - EventType["KeyVerificationAccept"] = "m.key.verification.accept"; - EventType["KeyVerificationReady"] = "m.key.verification.ready"; - EventType["RoomMessageFeedback"] = "m.room.message.feedback"; - EventType["Reaction"] = "m.reaction"; - EventType["PollStart"] = "org.matrix.msc3381.poll.start"; - EventType["Typing"] = "m.typing"; - EventType["Receipt"] = "m.receipt"; - EventType["Presence"] = "m.presence"; - EventType["FullyRead"] = "m.fully_read"; - EventType["Tag"] = "m.tag"; - EventType["SpaceOrder"] = "org.matrix.msc3230.space_order"; - EventType["PushRules"] = "m.push_rules"; - EventType["Direct"] = "m.direct"; - EventType["IgnoredUserList"] = "m.ignored_user_list"; - EventType["RoomKey"] = "m.room_key"; - EventType["RoomKeyRequest"] = "m.room_key_request"; - EventType["ForwardedRoomKey"] = "m.forwarded_room_key"; - EventType["Dummy"] = "m.dummy"; - EventType["GroupCallPrefix"] = "org.matrix.msc3401.call"; - EventType["GroupCallMemberPrefix"] = "org.matrix.msc3401.call.member"; -})(EventType || (exports.EventType = EventType = {})); -let RelationType; -exports.RelationType = RelationType; -(function (RelationType) { - RelationType["Annotation"] = "m.annotation"; - RelationType["Replace"] = "m.replace"; - RelationType["Reference"] = "m.reference"; - RelationType["Thread"] = "m.thread"; -})(RelationType || (exports.RelationType = RelationType = {})); -let MsgType; -exports.MsgType = MsgType; -(function (MsgType) { - MsgType["Text"] = "m.text"; - MsgType["Emote"] = "m.emote"; - MsgType["Notice"] = "m.notice"; - MsgType["Image"] = "m.image"; - MsgType["File"] = "m.file"; - MsgType["Audio"] = "m.audio"; - MsgType["Location"] = "m.location"; - MsgType["Video"] = "m.video"; - MsgType["KeyVerificationRequest"] = "m.key.verification.request"; -})(MsgType || (exports.MsgType = MsgType = {})); -const RoomCreateTypeField = "type"; -exports.RoomCreateTypeField = RoomCreateTypeField; -let RoomType; -exports.RoomType = RoomType; -(function (RoomType) { - RoomType["Space"] = "m.space"; - RoomType["UnstableCall"] = "org.matrix.msc3417.call"; - RoomType["ElementVideo"] = "io.element.video"; -})(RoomType || (exports.RoomType = RoomType = {})); -const ToDeviceMessageId = "org.matrix.msgid"; - -/** - * Identifier for an [MSC3088](https://github.com/matrix-org/matrix-doc/pull/3088) - * room purpose. Note that this reference is UNSTABLE and subject to breaking changes, - * including its eventual removal. - */ -exports.ToDeviceMessageId = ToDeviceMessageId; -const UNSTABLE_MSC3088_PURPOSE = new _NamespacedValue.UnstableValue("m.room.purpose", "org.matrix.msc3088.purpose"); - -/** - * Enabled flag for an [MSC3088](https://github.com/matrix-org/matrix-doc/pull/3088) - * room purpose. Note that this reference is UNSTABLE and subject to breaking changes, - * including its eventual removal. - */ -exports.UNSTABLE_MSC3088_PURPOSE = UNSTABLE_MSC3088_PURPOSE; -const UNSTABLE_MSC3088_ENABLED = new _NamespacedValue.UnstableValue("m.enabled", "org.matrix.msc3088.enabled"); - -/** - * Subtype for an [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room. - * Note that this reference is UNSTABLE and subject to breaking changes, including its - * eventual removal. - */ -exports.UNSTABLE_MSC3088_ENABLED = UNSTABLE_MSC3088_ENABLED; -const UNSTABLE_MSC3089_TREE_SUBTYPE = new _NamespacedValue.UnstableValue("m.data_tree", "org.matrix.msc3089.data_tree"); - -/** - * Leaf type for an event in a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room. - * Note that this reference is UNSTABLE and subject to breaking changes, including its - * eventual removal. - */ -exports.UNSTABLE_MSC3089_TREE_SUBTYPE = UNSTABLE_MSC3089_TREE_SUBTYPE; -const UNSTABLE_MSC3089_LEAF = new _NamespacedValue.UnstableValue("m.leaf", "org.matrix.msc3089.leaf"); - -/** - * Branch (Leaf Reference) type for the index approach in a - * [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room. Note that this reference is - * UNSTABLE and subject to breaking changes, including its eventual removal. - */ -exports.UNSTABLE_MSC3089_LEAF = UNSTABLE_MSC3089_LEAF; -const UNSTABLE_MSC3089_BRANCH = new _NamespacedValue.UnstableValue("m.branch", "org.matrix.msc3089.branch"); - -/** - * Marker event type to point back at imported historical content in a room. See - * [MSC2716](https://github.com/matrix-org/matrix-spec-proposals/pull/2716). - * Note that this reference is UNSTABLE and subject to breaking changes, - * including its eventual removal. - */ -exports.UNSTABLE_MSC3089_BRANCH = UNSTABLE_MSC3089_BRANCH; -const UNSTABLE_MSC2716_MARKER = new _NamespacedValue.UnstableValue("m.room.marker", "org.matrix.msc2716.marker"); - -/** - * Name of the "with_relations" request property for relation based redactions. - * {@link https://github.com/matrix-org/matrix-spec-proposals/pull/3912} - */ -exports.UNSTABLE_MSC2716_MARKER = UNSTABLE_MSC2716_MARKER; -const MSC3912_RELATION_BASED_REDACTIONS_PROP = new _NamespacedValue.UnstableValue("with_relations", "org.matrix.msc3912.with_relations"); - -/** - * Functional members type for declaring a purpose of room members (e.g. helpful bots). - * Note that this reference is UNSTABLE and subject to breaking changes, including its - * eventual removal. - * - * Schema (TypeScript): - * ``` - * { - * service_members?: string[] - * } - * ``` - * - * @example - * ``` - * { - * "service_members": [ - * "@helperbot:localhost", - * "@reminderbot:alice.tdl" - * ] - * } - * ``` - */ -exports.MSC3912_RELATION_BASED_REDACTIONS_PROP = MSC3912_RELATION_BASED_REDACTIONS_PROP; -const UNSTABLE_ELEMENT_FUNCTIONAL_USERS = new _NamespacedValue.UnstableValue("io.element.functional_members", "io.element.functional_members"); - -/** - * A type of message that affects visibility of a message, - * as per https://github.com/matrix-org/matrix-doc/pull/3531 - * - * @experimental - */ -exports.UNSTABLE_ELEMENT_FUNCTIONAL_USERS = UNSTABLE_ELEMENT_FUNCTIONAL_USERS; -const EVENT_VISIBILITY_CHANGE_TYPE = new _NamespacedValue.UnstableValue("m.visibility", "org.matrix.msc3531.visibility"); - -/** - * https://github.com/matrix-org/matrix-doc/pull/3881 - * - * @experimental - */ -exports.EVENT_VISIBILITY_CHANGE_TYPE = EVENT_VISIBILITY_CHANGE_TYPE; -const PUSHER_ENABLED = new _NamespacedValue.UnstableValue("enabled", "org.matrix.msc3881.enabled"); - -/** - * https://github.com/matrix-org/matrix-doc/pull/3881 - * - * @experimental - */ -exports.PUSHER_ENABLED = PUSHER_ENABLED; -const PUSHER_DEVICE_ID = new _NamespacedValue.UnstableValue("device_id", "org.matrix.msc3881.device_id"); - -/** - * https://github.com/matrix-org/matrix-doc/pull/3890 - * - * @experimental - */ -exports.PUSHER_DEVICE_ID = PUSHER_DEVICE_ID; -const LOCAL_NOTIFICATION_SETTINGS_PREFIX = new _NamespacedValue.UnstableValue("m.local_notification_settings", "org.matrix.msc3890.local_notification_settings"); -exports.LOCAL_NOTIFICATION_SETTINGS_PREFIX = LOCAL_NOTIFICATION_SETTINGS_PREFIX; -//# sourceMappingURL=event.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js.map deleted file mode 100644 index c3ab902..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/event.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event.js","names":["_NamespacedValue","require","EventType","exports","RelationType","MsgType","RoomCreateTypeField","RoomType","ToDeviceMessageId","UNSTABLE_MSC3088_PURPOSE","UnstableValue","UNSTABLE_MSC3088_ENABLED","UNSTABLE_MSC3089_TREE_SUBTYPE","UNSTABLE_MSC3089_LEAF","UNSTABLE_MSC3089_BRANCH","UNSTABLE_MSC2716_MARKER","MSC3912_RELATION_BASED_REDACTIONS_PROP","UNSTABLE_ELEMENT_FUNCTIONAL_USERS","EVENT_VISIBILITY_CHANGE_TYPE","PUSHER_ENABLED","PUSHER_DEVICE_ID","LOCAL_NOTIFICATION_SETTINGS_PREFIX"],"sources":["../../src/@types/event.ts"],"sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { UnstableValue } from \"../NamespacedValue\";\n\nexport enum EventType {\n // Room state events\n RoomCanonicalAlias = \"m.room.canonical_alias\",\n RoomCreate = \"m.room.create\",\n RoomJoinRules = \"m.room.join_rules\",\n RoomMember = \"m.room.member\",\n RoomThirdPartyInvite = \"m.room.third_party_invite\",\n RoomPowerLevels = \"m.room.power_levels\",\n RoomName = \"m.room.name\",\n RoomTopic = \"m.room.topic\",\n RoomAvatar = \"m.room.avatar\",\n RoomPinnedEvents = \"m.room.pinned_events\",\n RoomEncryption = \"m.room.encryption\",\n RoomHistoryVisibility = \"m.room.history_visibility\",\n RoomGuestAccess = \"m.room.guest_access\",\n RoomServerAcl = \"m.room.server_acl\",\n RoomTombstone = \"m.room.tombstone\",\n RoomPredecessor = \"org.matrix.msc3946.room_predecessor\",\n\n SpaceChild = \"m.space.child\",\n SpaceParent = \"m.space.parent\",\n\n // Room timeline events\n RoomRedaction = \"m.room.redaction\",\n RoomMessage = \"m.room.message\",\n RoomMessageEncrypted = \"m.room.encrypted\",\n Sticker = \"m.sticker\",\n CallInvite = \"m.call.invite\",\n CallCandidates = \"m.call.candidates\",\n CallAnswer = \"m.call.answer\",\n CallHangup = \"m.call.hangup\",\n CallReject = \"m.call.reject\",\n CallSelectAnswer = \"m.call.select_answer\",\n CallNegotiate = \"m.call.negotiate\",\n CallSDPStreamMetadataChanged = \"m.call.sdp_stream_metadata_changed\",\n CallSDPStreamMetadataChangedPrefix = \"org.matrix.call.sdp_stream_metadata_changed\",\n CallReplaces = \"m.call.replaces\",\n CallAssertedIdentity = \"m.call.asserted_identity\",\n CallAssertedIdentityPrefix = \"org.matrix.call.asserted_identity\",\n KeyVerificationRequest = \"m.key.verification.request\",\n KeyVerificationStart = \"m.key.verification.start\",\n KeyVerificationCancel = \"m.key.verification.cancel\",\n KeyVerificationMac = \"m.key.verification.mac\",\n KeyVerificationDone = \"m.key.verification.done\",\n KeyVerificationKey = \"m.key.verification.key\",\n KeyVerificationAccept = \"m.key.verification.accept\",\n // Not used directly - see READY_TYPE in VerificationRequest.\n KeyVerificationReady = \"m.key.verification.ready\",\n // use of this is discouraged https://matrix.org/docs/spec/client_server/r0.6.1#m-room-message-feedback\n RoomMessageFeedback = \"m.room.message.feedback\",\n Reaction = \"m.reaction\",\n PollStart = \"org.matrix.msc3381.poll.start\",\n\n // Room ephemeral events\n Typing = \"m.typing\",\n Receipt = \"m.receipt\",\n Presence = \"m.presence\",\n\n // Room account_data events\n FullyRead = \"m.fully_read\",\n Tag = \"m.tag\",\n SpaceOrder = \"org.matrix.msc3230.space_order\", // MSC3230\n\n // User account_data events\n PushRules = \"m.push_rules\",\n Direct = \"m.direct\",\n IgnoredUserList = \"m.ignored_user_list\",\n\n // to_device events\n RoomKey = \"m.room_key\",\n RoomKeyRequest = \"m.room_key_request\",\n ForwardedRoomKey = \"m.forwarded_room_key\",\n Dummy = \"m.dummy\",\n\n // Group call events\n GroupCallPrefix = \"org.matrix.msc3401.call\",\n GroupCallMemberPrefix = \"org.matrix.msc3401.call.member\",\n}\n\nexport enum RelationType {\n Annotation = \"m.annotation\",\n Replace = \"m.replace\",\n Reference = \"m.reference\",\n Thread = \"m.thread\",\n}\n\nexport enum MsgType {\n Text = \"m.text\",\n Emote = \"m.emote\",\n Notice = \"m.notice\",\n Image = \"m.image\",\n File = \"m.file\",\n Audio = \"m.audio\",\n Location = \"m.location\",\n Video = \"m.video\",\n KeyVerificationRequest = \"m.key.verification.request\",\n}\n\nexport const RoomCreateTypeField = \"type\";\n\nexport enum RoomType {\n Space = \"m.space\",\n UnstableCall = \"org.matrix.msc3417.call\",\n ElementVideo = \"io.element.video\",\n}\n\nexport const ToDeviceMessageId = \"org.matrix.msgid\";\n\n/**\n * Identifier for an [MSC3088](https://github.com/matrix-org/matrix-doc/pull/3088)\n * room purpose. Note that this reference is UNSTABLE and subject to breaking changes,\n * including its eventual removal.\n */\nexport const UNSTABLE_MSC3088_PURPOSE = new UnstableValue(\"m.room.purpose\", \"org.matrix.msc3088.purpose\");\n\n/**\n * Enabled flag for an [MSC3088](https://github.com/matrix-org/matrix-doc/pull/3088)\n * room purpose. Note that this reference is UNSTABLE and subject to breaking changes,\n * including its eventual removal.\n */\nexport const UNSTABLE_MSC3088_ENABLED = new UnstableValue(\"m.enabled\", \"org.matrix.msc3088.enabled\");\n\n/**\n * Subtype for an [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room.\n * Note that this reference is UNSTABLE and subject to breaking changes, including its\n * eventual removal.\n */\nexport const UNSTABLE_MSC3089_TREE_SUBTYPE = new UnstableValue(\"m.data_tree\", \"org.matrix.msc3089.data_tree\");\n\n/**\n * Leaf type for an event in a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room.\n * Note that this reference is UNSTABLE and subject to breaking changes, including its\n * eventual removal.\n */\nexport const UNSTABLE_MSC3089_LEAF = new UnstableValue(\"m.leaf\", \"org.matrix.msc3089.leaf\");\n\n/**\n * Branch (Leaf Reference) type for the index approach in a\n * [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) space-room. Note that this reference is\n * UNSTABLE and subject to breaking changes, including its eventual removal.\n */\nexport const UNSTABLE_MSC3089_BRANCH = new UnstableValue(\"m.branch\", \"org.matrix.msc3089.branch\");\n\n/**\n * Marker event type to point back at imported historical content in a room. See\n * [MSC2716](https://github.com/matrix-org/matrix-spec-proposals/pull/2716).\n * Note that this reference is UNSTABLE and subject to breaking changes,\n * including its eventual removal.\n */\nexport const UNSTABLE_MSC2716_MARKER = new UnstableValue(\"m.room.marker\", \"org.matrix.msc2716.marker\");\n\n/**\n * Name of the \"with_relations\" request property for relation based redactions.\n * {@link https://github.com/matrix-org/matrix-spec-proposals/pull/3912}\n */\nexport const MSC3912_RELATION_BASED_REDACTIONS_PROP = new UnstableValue(\n \"with_relations\",\n \"org.matrix.msc3912.with_relations\",\n);\n\n/**\n * Functional members type for declaring a purpose of room members (e.g. helpful bots).\n * Note that this reference is UNSTABLE and subject to breaking changes, including its\n * eventual removal.\n *\n * Schema (TypeScript):\n * ```\n * {\n * service_members?: string[]\n * }\n * ```\n *\n * @example\n * ```\n * {\n * \"service_members\": [\n * \"@helperbot:localhost\",\n * \"@reminderbot:alice.tdl\"\n * ]\n * }\n * ```\n */\nexport const UNSTABLE_ELEMENT_FUNCTIONAL_USERS = new UnstableValue(\n \"io.element.functional_members\",\n \"io.element.functional_members\",\n);\n\n/**\n * A type of message that affects visibility of a message,\n * as per https://github.com/matrix-org/matrix-doc/pull/3531\n *\n * @experimental\n */\nexport const EVENT_VISIBILITY_CHANGE_TYPE = new UnstableValue(\"m.visibility\", \"org.matrix.msc3531.visibility\");\n\n/**\n * https://github.com/matrix-org/matrix-doc/pull/3881\n *\n * @experimental\n */\nexport const PUSHER_ENABLED = new UnstableValue(\"enabled\", \"org.matrix.msc3881.enabled\");\n\n/**\n * https://github.com/matrix-org/matrix-doc/pull/3881\n *\n * @experimental\n */\nexport const PUSHER_DEVICE_ID = new UnstableValue(\"device_id\", \"org.matrix.msc3881.device_id\");\n\n/**\n * https://github.com/matrix-org/matrix-doc/pull/3890\n *\n * @experimental\n */\nexport const LOCAL_NOTIFICATION_SETTINGS_PREFIX = new UnstableValue(\n \"m.local_notification_settings\",\n \"org.matrix.msc3890.local_notification_settings\",\n);\n\nexport interface IEncryptedFile {\n url: string;\n mimetype?: string;\n key: {\n alg: string;\n key_ops: string[]; // eslint-disable-line camelcase\n kty: string;\n k: string;\n ext: boolean;\n };\n iv: string;\n hashes: { [alg: string]: string };\n v: string;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts deleted file mode 100644 index dd92a5e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts +++ /dev/null @@ -1,98 +0,0 @@ -import { EitherAnd, NamespacedValue, Optional, UnstableValue } from "matrix-events-sdk"; -/** - * Represents the stable and unstable values of a given namespace. - */ -export type TSNamespace = N extends NamespacedValue ? TSNamespaceValue | TSNamespaceValue : never; -/** - * Represents a namespaced value, if the value is a string. Used to extract provided types - * from a TSNamespace (in cases where only stable *or* unstable is provided). - */ -export type TSNamespaceValue = V extends string ? V : never; -/** - * Creates a type which is V when T is `never`, otherwise T. - */ -export type DefaultNever = [T] extends [never] ? V : T; -/** - * The namespaced value for m.message - */ -export declare const M_MESSAGE: UnstableValue<"m.message", "org.matrix.msc1767.message">; -/** - * An m.message event rendering - */ -export interface IMessageRendering { - body: string; - mimetype?: string; -} -/** - * The content for an m.message event - */ -export type ExtensibleMessageEventContent = EitherAnd<{ - [M_MESSAGE.name]: IMessageRendering[]; -}, { - [M_MESSAGE.altName]: IMessageRendering[]; -}>; -/** - * The namespaced value for m.text - */ -export declare const M_TEXT: UnstableValue<"m.text", "org.matrix.msc1767.text">; -/** - * The content for an m.text event - */ -export type TextEventContent = EitherAnd<{ - [M_TEXT.name]: string; -}, { - [M_TEXT.altName]: string; -}>; -/** - * The namespaced value for m.html - */ -export declare const M_HTML: UnstableValue<"m.html", "org.matrix.msc1767.html">; -/** - * The content for an m.html event - */ -export type HtmlEventContent = EitherAnd<{ - [M_HTML.name]: string; -}, { - [M_HTML.altName]: string; -}>; -/** - * The content for an m.message, m.text, or m.html event - */ -export type ExtensibleAnyMessageEventContent = ExtensibleMessageEventContent | TextEventContent | HtmlEventContent; -/** - * The namespaced value for an m.reference relation - */ -export declare const REFERENCE_RELATION: NamespacedValue<"m.reference", string>; -/** - * Represents any relation type - */ -export type AnyRelation = TSNamespace | string; -/** - * An m.relates_to relationship - */ -export type RelatesToRelationship = { - "m.relates_to": { - rel_type: [R] extends [never] ? AnyRelation : TSNamespace; - event_id: string; - } & DefaultNever; -}; -/** - * Partial types for a Matrix Event. - */ -export interface IPartialEvent { - type: string; - content: TContent; -} -/** - * Represents a potentially namespaced event type. - */ -export type ExtensibleEventType = NamespacedValue | string; -/** - * Determines if two event types are the same, including namespaces. - * @param given - The given event type. This will be compared - * against the expected type. - * @param expected - The expected event type. - * @returns True if the given type matches the expected type. - */ -export declare function isEventTypeSame(given: Optional, expected: Optional): boolean; -//# sourceMappingURL=extensible_events.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts.map deleted file mode 100644 index 2d49cd2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"extensible_events.d.ts","sourceRoot":"","sources":["../../src/@types/extensible_events.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAMxF;;GAEG;AACH,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,eAAe,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC,GAClE,gBAAgB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC,CAAC,GACzC,KAAK,CAAC;AAEZ;;;GAGG;AACH,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC;AAE/D;;GAEG;AAEH,MAAM,MAAM,YAAY,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AAE7D;;GAEG;AACH,eAAO,MAAM,SAAS,0DAA+D,CAAC;AAEtF;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,MAAM,6BAA6B,GAAG,SAAS,CACjD;IAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,iBAAiB,EAAE,CAAA;CAAE,EACzC;IAAE,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,iBAAiB,EAAE,CAAA;CAAE,CAC/C,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,MAAM,oDAAyD,CAAC;AAE7E;;GAEG;AACH,MAAM,MAAM,gBAAgB,GAAG,SAAS,CAAC;IAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,EAAE;IAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAElG;;GAEG;AACH,eAAO,MAAM,MAAM,oDAAyD,CAAC;AAE7E;;GAEG;AACH,MAAM,MAAM,gBAAgB,GAAG,SAAS,CAAC;IAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,EAAE;IAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAElG;;GAEG;AACH,MAAM,MAAM,gCAAgC,GAAG,6BAA6B,GAAG,gBAAgB,GAAG,gBAAgB,CAAC;AAEnH;;GAEG;AACH,eAAO,MAAM,kBAAkB,wCAAqC,CAAC;AAErE;;GAEG;AACH,MAAM,MAAM,WAAW,GAAG,WAAW,CAAC,OAAO,kBAAkB,CAAC,GAAG,MAAM,CAAC;AAE1E;;GAEG;AACH,MAAM,MAAM,qBAAqB,CAAC,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,KAAK,IAAI;IACtD,cAAc,EAAE;QAEZ,QAAQ,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,WAAW,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;QAC7D,QAAQ,EAAE,MAAM,CAAC;KACpB,GAAG,YAAY,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;CAC3B,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,aAAa,CAAC,QAAQ;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,QAAQ,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,MAAM,mBAAmB,GAAG,eAAe,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,MAAM,CAAC;AAE3E;;;;;;GAMG;AACH,wBAAgB,eAAe,CAC3B,KAAK,EAAE,QAAQ,CAAC,mBAAmB,CAAC,EACpC,QAAQ,EAAE,QAAQ,CAAC,mBAAmB,CAAC,GACxC,OAAO,CAmBT"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js deleted file mode 100644 index ccc41b5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js +++ /dev/null @@ -1,86 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.REFERENCE_RELATION = exports.M_TEXT = exports.M_MESSAGE = exports.M_HTML = void 0; -exports.isEventTypeSame = isEventTypeSame; -var _matrixEventsSdk = require("matrix-events-sdk"); -var _utilities = require("../extensible_events_v1/utilities"); -/* -Copyright 2021 - 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * The namespaced value for m.message - */ -const M_MESSAGE = new _matrixEventsSdk.UnstableValue("m.message", "org.matrix.msc1767.message"); - -/** - * An m.message event rendering - */ -exports.M_MESSAGE = M_MESSAGE; -/** - * The namespaced value for m.text - */ -const M_TEXT = new _matrixEventsSdk.UnstableValue("m.text", "org.matrix.msc1767.text"); - -/** - * The content for an m.text event - */ -exports.M_TEXT = M_TEXT; -/** - * The namespaced value for m.html - */ -const M_HTML = new _matrixEventsSdk.UnstableValue("m.html", "org.matrix.msc1767.html"); - -/** - * The content for an m.html event - */ -exports.M_HTML = M_HTML; -/** - * The namespaced value for an m.reference relation - */ -const REFERENCE_RELATION = new _matrixEventsSdk.NamespacedValue("m.reference"); - -/** - * Represents any relation type - */ -exports.REFERENCE_RELATION = REFERENCE_RELATION; -/** - * Determines if two event types are the same, including namespaces. - * @param given - The given event type. This will be compared - * against the expected type. - * @param expected - The expected event type. - * @returns True if the given type matches the expected type. - */ -function isEventTypeSame(given, expected) { - if (typeof given === "string") { - if (typeof expected === "string") { - return expected === given; - } else { - return expected.matches(given); - } - } else { - if (typeof expected === "string") { - return given.matches(expected); - } else { - const expectedNs = expected; - const givenNs = given; - return expectedNs.matches(givenNs.name) || (0, _utilities.isProvided)(givenNs.altName) && expectedNs.matches(givenNs.altName); - } - } -} -//# sourceMappingURL=extensible_events.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js.map deleted file mode 100644 index 4d1b39b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/extensible_events.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"extensible_events.js","names":["_matrixEventsSdk","require","_utilities","M_MESSAGE","UnstableValue","exports","M_TEXT","M_HTML","REFERENCE_RELATION","NamespacedValue","isEventTypeSame","given","expected","matches","expectedNs","givenNs","name","isProvided","altName"],"sources":["../../src/@types/extensible_events.ts"],"sourcesContent":["/*\nCopyright 2021 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EitherAnd, NamespacedValue, Optional, UnstableValue } from \"matrix-events-sdk\";\n\nimport { isProvided } from \"../extensible_events_v1/utilities\";\n\n// Types and utilities for MSC1767: Extensible events (version 1) in Matrix\n\n/**\n * Represents the stable and unstable values of a given namespace.\n */\nexport type TSNamespace = N extends NamespacedValue\n ? TSNamespaceValue | TSNamespaceValue\n : never;\n\n/**\n * Represents a namespaced value, if the value is a string. Used to extract provided types\n * from a TSNamespace (in cases where only stable *or* unstable is provided).\n */\nexport type TSNamespaceValue = V extends string ? V : never;\n\n/**\n * Creates a type which is V when T is `never`, otherwise T.\n */\n// See https://github.com/microsoft/TypeScript/issues/23182#issuecomment-379091887 for details on the array syntax.\nexport type DefaultNever = [T] extends [never] ? V : T;\n\n/**\n * The namespaced value for m.message\n */\nexport const M_MESSAGE = new UnstableValue(\"m.message\", \"org.matrix.msc1767.message\");\n\n/**\n * An m.message event rendering\n */\nexport interface IMessageRendering {\n body: string;\n mimetype?: string;\n}\n\n/**\n * The content for an m.message event\n */\nexport type ExtensibleMessageEventContent = EitherAnd<\n { [M_MESSAGE.name]: IMessageRendering[] },\n { [M_MESSAGE.altName]: IMessageRendering[] }\n>;\n\n/**\n * The namespaced value for m.text\n */\nexport const M_TEXT = new UnstableValue(\"m.text\", \"org.matrix.msc1767.text\");\n\n/**\n * The content for an m.text event\n */\nexport type TextEventContent = EitherAnd<{ [M_TEXT.name]: string }, { [M_TEXT.altName]: string }>;\n\n/**\n * The namespaced value for m.html\n */\nexport const M_HTML = new UnstableValue(\"m.html\", \"org.matrix.msc1767.html\");\n\n/**\n * The content for an m.html event\n */\nexport type HtmlEventContent = EitherAnd<{ [M_HTML.name]: string }, { [M_HTML.altName]: string }>;\n\n/**\n * The content for an m.message, m.text, or m.html event\n */\nexport type ExtensibleAnyMessageEventContent = ExtensibleMessageEventContent | TextEventContent | HtmlEventContent;\n\n/**\n * The namespaced value for an m.reference relation\n */\nexport const REFERENCE_RELATION = new NamespacedValue(\"m.reference\");\n\n/**\n * Represents any relation type\n */\nexport type AnyRelation = TSNamespace | string;\n\n/**\n * An m.relates_to relationship\n */\nexport type RelatesToRelationship = {\n \"m.relates_to\": {\n // See https://github.com/microsoft/TypeScript/issues/23182#issuecomment-379091887 for array syntax\n rel_type: [R] extends [never] ? AnyRelation : TSNamespace;\n event_id: string;\n } & DefaultNever;\n};\n\n/**\n * Partial types for a Matrix Event.\n */\nexport interface IPartialEvent {\n type: string;\n content: TContent;\n}\n\n/**\n * Represents a potentially namespaced event type.\n */\nexport type ExtensibleEventType = NamespacedValue | string;\n\n/**\n * Determines if two event types are the same, including namespaces.\n * @param given - The given event type. This will be compared\n * against the expected type.\n * @param expected - The expected event type.\n * @returns True if the given type matches the expected type.\n */\nexport function isEventTypeSame(\n given: Optional,\n expected: Optional,\n): boolean {\n if (typeof given === \"string\") {\n if (typeof expected === \"string\") {\n return expected === given;\n } else {\n return (expected as NamespacedValue).matches(given as string);\n }\n } else {\n if (typeof expected === \"string\") {\n return (given as NamespacedValue).matches(expected as string);\n } else {\n const expectedNs = expected as NamespacedValue;\n const givenNs = given as NamespacedValue;\n return (\n expectedNs.matches(givenNs.name) ||\n (isProvided(givenNs.altName) && expectedNs.matches(givenNs.altName!))\n );\n }\n }\n}\n"],"mappings":";;;;;;;AAgBA,IAAAA,gBAAA,GAAAC,OAAA;AAEA,IAAAC,UAAA,GAAAD,OAAA;AAlBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA2BA;AACA;AACA;AACO,MAAME,SAAS,GAAG,IAAIC,8BAAa,CAAC,WAAW,EAAE,4BAA4B,CAAC;;AAErF;AACA;AACA;AAFAC,OAAA,CAAAF,SAAA,GAAAA,SAAA;AAgBA;AACA;AACA;AACO,MAAMG,MAAM,GAAG,IAAIF,8BAAa,CAAC,QAAQ,EAAE,yBAAyB,CAAC;;AAE5E;AACA;AACA;AAFAC,OAAA,CAAAC,MAAA,GAAAA,MAAA;AAKA;AACA;AACA;AACO,MAAMC,MAAM,GAAG,IAAIH,8BAAa,CAAC,QAAQ,EAAE,yBAAyB,CAAC;;AAE5E;AACA;AACA;AAFAC,OAAA,CAAAE,MAAA,GAAAA,MAAA;AAUA;AACA;AACA;AACO,MAAMC,kBAAkB,GAAG,IAAIC,gCAAe,CAAC,aAAa,CAAC;;AAEpE;AACA;AACA;AAFAJ,OAAA,CAAAG,kBAAA,GAAAA,kBAAA;AA6BA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASE,eAAeA,CAC3BC,KAAoC,EACpCC,QAAuC,EAChC;EACP,IAAI,OAAOD,KAAK,KAAK,QAAQ,EAAE;IAC3B,IAAI,OAAOC,QAAQ,KAAK,QAAQ,EAAE;MAC9B,OAAOA,QAAQ,KAAKD,KAAK;IAC7B,CAAC,MAAM;MACH,OAAQC,QAAQ,CAAqCC,OAAO,CAACF,KAAK,CAAW;IACjF;EACJ,CAAC,MAAM;IACH,IAAI,OAAOC,QAAQ,KAAK,QAAQ,EAAE;MAC9B,OAAQD,KAAK,CAAqCE,OAAO,CAACD,QAAQ,CAAW;IACjF,CAAC,MAAM;MACH,MAAME,UAAU,GAAGF,QAA2C;MAC9D,MAAMG,OAAO,GAAGJ,KAAwC;MACxD,OACIG,UAAU,CAACD,OAAO,CAACE,OAAO,CAACC,IAAI,CAAC,IAC/B,IAAAC,qBAAU,EAACF,OAAO,CAACG,OAAO,CAAC,IAAIJ,UAAU,CAACD,OAAO,CAACE,OAAO,CAACG,OAAO,CAAG;IAE7E;EACJ;AACJ"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js deleted file mode 100644 index ff52ed9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js +++ /dev/null @@ -1,7 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -require("@matrix-org/olm"); -//# sourceMappingURL=global.d.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js.map deleted file mode 100644 index b1efaed..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/global.d.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"global.d.js","names":["require"],"sources":["../../src/@types/global.d.ts"],"sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n// this is needed to tell TS about global.Olm\nimport \"@matrix-org/olm\";\n\nexport {};\n\ndeclare global {\n // use `number` as the return type in all cases for global.set{Interval,Timeout},\n // so we don't accidentally use the methods on NodeJS.Timeout - they only exist in a subset of environments.\n // The overload for clear{Interval,Timeout} is resolved as expected.\n // We use `ReturnType` in the code to be agnostic of if this definition gets loaded.\n function setInterval(handler: TimerHandler, timeout: number, ...arguments: any[]): number;\n function setTimeout(handler: TimerHandler, timeout: number, ...arguments: any[]): number;\n\n namespace NodeJS {\n interface Global {\n localStorage: Storage;\n // marker variable used to detect both the browser & node entrypoints being used at once\n __js_sdk_entrypoint: unknown;\n }\n }\n\n interface Window {\n webkitAudioContext: typeof AudioContext;\n }\n\n interface Crypto {\n webkitSubtle?: Window[\"crypto\"][\"subtle\"];\n }\n\n interface MediaDevices {\n // This is experimental and types don't know about it yet\n // https://github.com/microsoft/TypeScript/issues/33232\n getDisplayMedia(constraints: MediaStreamConstraints | DesktopCapturerConstraints): Promise;\n getUserMedia(constraints: MediaStreamConstraints | DesktopCapturerConstraints): Promise;\n }\n\n interface DesktopCapturerConstraints {\n audio:\n | boolean\n | {\n mandatory: {\n chromeMediaSource: string;\n chromeMediaSourceId: string;\n };\n };\n video:\n | boolean\n | {\n mandatory: {\n chromeMediaSource: string;\n chromeMediaSourceId: string;\n };\n };\n }\n\n interface DummyInterfaceWeShouldntBeUsingThis {}\n\n interface Navigator {\n // We check for the webkit-prefixed getUserMedia to detect if we're\n // on webkit: we should check if we still need to do this\n webkitGetUserMedia: DummyInterfaceWeShouldntBeUsingThis;\n }\n\n export interface ISettledFulfilled {\n status: \"fulfilled\";\n value: T;\n }\n export interface ISettledRejected {\n status: \"rejected\";\n reason: any;\n }\n\n interface PromiseConstructor {\n allSettled(promises: Promise[]): Promise | ISettledRejected>>;\n }\n\n interface RTCRtpTransceiver {\n // This has been removed from TS\n // (https://github.com/microsoft/TypeScript-DOM-lib-generator/issues/1029),\n // but we still need this for MatrixCall::getRidOfRTXCodecs()\n setCodecPreferences(codecs: RTCRtpCodecCapability[]): void;\n }\n}\n"],"mappings":";;;;;AAiBAA,OAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts deleted file mode 100644 index 21d082c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -export interface LocalNotificationSettings { - is_silenced: boolean; -} -//# sourceMappingURL=local_notifications.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts.map deleted file mode 100644 index 9d7a78d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"local_notifications.d.ts","sourceRoot":"","sources":["../../src/@types/local_notifications.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,yBAAyB;IACtC,WAAW,EAAE,OAAO,CAAC;CACxB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js deleted file mode 100644 index 62a64a1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=local_notifications.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js.map deleted file mode 100644 index 462cf0d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/local_notifications.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"local_notifications.js","names":[],"sources":["../../src/@types/local_notifications.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport interface LocalNotificationSettings {\n is_silenced: boolean;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts deleted file mode 100644 index 3455144..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts +++ /dev/null @@ -1,60 +0,0 @@ -import { EitherAnd } from "matrix-events-sdk"; -import { UnstableValue } from "../NamespacedValue"; -import { M_TEXT } from "./extensible_events"; -export declare enum LocationAssetType { - Self = "m.self", - Pin = "m.pin" -} -export declare const M_ASSET: UnstableValue<"m.asset", "org.matrix.msc3488.asset">; -export type MAssetContent = { - type: LocationAssetType; -}; -/** - * The event definition for an m.asset event (in content) - */ -export type MAssetEvent = EitherAnd<{ - [M_ASSET.name]: MAssetContent; -}, { - [M_ASSET.altName]: MAssetContent; -}>; -export declare const M_TIMESTAMP: UnstableValue<"m.ts", "org.matrix.msc3488.ts">; -/** - * The event definition for an m.ts event (in content) - */ -export type MTimestampEvent = EitherAnd<{ - [M_TIMESTAMP.name]: number; -}, { - [M_TIMESTAMP.altName]: number; -}>; -export declare const M_LOCATION: UnstableValue<"m.location", "org.matrix.msc3488.location">; -export type MLocationContent = { - uri: string; - description?: string | null; -}; -export type MLocationEvent = EitherAnd<{ - [M_LOCATION.name]: MLocationContent; -}, { - [M_LOCATION.altName]: MLocationContent; -}>; -export type MTextEvent = EitherAnd<{ - [M_TEXT.name]: string; -}, { - [M_TEXT.altName]: string; -}>; -type OptionalTimestampEvent = MTimestampEvent | undefined; -/** - * The content for an m.location event - */ -export type MLocationEventContent = MLocationEvent & MAssetEvent & MTextEvent & OptionalTimestampEvent; -export type LegacyLocationEventContent = { - body: string; - msgtype: string; - geo_uri: string; -}; -/** - * Possible content for location events as sent over the wire - */ -export type LocationEventWireContent = Partial; -export type ILocationContent = MLocationEventContent & LegacyLocationEventContent; -export {}; -//# sourceMappingURL=location.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts.map deleted file mode 100644 index 4c0d3bc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"location.d.ts","sourceRoot":"","sources":["../../src/@types/location.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAE7C,oBAAY,iBAAiB;IACzB,IAAI,WAAW;IACf,GAAG,UAAU;CAChB;AAED,eAAO,MAAM,OAAO,sDAA2D,CAAC;AAChF,MAAM,MAAM,aAAa,GAAG;IAAE,IAAI,EAAE,iBAAiB,CAAA;CAAE,CAAC;AACxD;;GAEG;AACH,MAAM,MAAM,WAAW,GAAG,SAAS,CAAC;IAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,aAAa,CAAA;CAAE,EAAE;IAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,aAAa,CAAA;CAAE,CAAC,CAAC;AAE7G,eAAO,MAAM,WAAW,gDAAqD,CAAC;AAC9E;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG,SAAS,CAAC;IAAE,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,EAAE;IAAE,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAE3G,eAAO,MAAM,UAAU,4DAAiE,CAAC;AAEzF,MAAM,MAAM,gBAAgB,GAAG;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,SAAS,CAClC;IAAE,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,gBAAgB,CAAA;CAAE,EACvC;IAAE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,gBAAgB,CAAA;CAAE,CAC7C,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,SAAS,CAAC;IAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,EAAE;IAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAsB5F,KAAK,sBAAsB,GAAG,eAAe,GAAG,SAAS,CAAC;AAC1D;;GAEG;AACH,MAAM,MAAM,qBAAqB,GAAG,cAAc,GAAG,WAAW,GAAG,UAAU,GAAG,sBAAsB,CAAC;AAEvG,MAAM,MAAM,0BAA0B,GAAG;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,wBAAwB,GAAG,OAAO,CAAC,0BAA0B,GAAG,qBAAqB,CAAC,CAAC;AAEnG,MAAM,MAAM,gBAAgB,GAAG,qBAAqB,GAAG,0BAA0B,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js deleted file mode 100644 index 5b7fdb8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js +++ /dev/null @@ -1,40 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.M_TIMESTAMP = exports.M_LOCATION = exports.M_ASSET = exports.LocationAssetType = void 0; -var _NamespacedValue = require("../NamespacedValue"); -var _extensible_events = require("./extensible_events"); -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -// Types for MSC3488 - m.location: Extending events with location data -let LocationAssetType; -exports.LocationAssetType = LocationAssetType; -(function (LocationAssetType) { - LocationAssetType["Self"] = "m.self"; - LocationAssetType["Pin"] = "m.pin"; -})(LocationAssetType || (exports.LocationAssetType = LocationAssetType = {})); -const M_ASSET = new _NamespacedValue.UnstableValue("m.asset", "org.matrix.msc3488.asset"); -exports.M_ASSET = M_ASSET; -const M_TIMESTAMP = new _NamespacedValue.UnstableValue("m.ts", "org.matrix.msc3488.ts"); -/** - * The event definition for an m.ts event (in content) - */ -exports.M_TIMESTAMP = M_TIMESTAMP; -const M_LOCATION = new _NamespacedValue.UnstableValue("m.location", "org.matrix.msc3488.location"); -exports.M_LOCATION = M_LOCATION; -//# sourceMappingURL=location.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js.map deleted file mode 100644 index 18d8453..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/location.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"location.js","names":["_NamespacedValue","require","_extensible_events","LocationAssetType","exports","M_ASSET","UnstableValue","M_TIMESTAMP","M_LOCATION"],"sources":["../../src/@types/location.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n// Types for MSC3488 - m.location: Extending events with location data\nimport { EitherAnd } from \"matrix-events-sdk\";\n\nimport { UnstableValue } from \"../NamespacedValue\";\nimport { M_TEXT } from \"./extensible_events\";\n\nexport enum LocationAssetType {\n Self = \"m.self\",\n Pin = \"m.pin\",\n}\n\nexport const M_ASSET = new UnstableValue(\"m.asset\", \"org.matrix.msc3488.asset\");\nexport type MAssetContent = { type: LocationAssetType };\n/**\n * The event definition for an m.asset event (in content)\n */\nexport type MAssetEvent = EitherAnd<{ [M_ASSET.name]: MAssetContent }, { [M_ASSET.altName]: MAssetContent }>;\n\nexport const M_TIMESTAMP = new UnstableValue(\"m.ts\", \"org.matrix.msc3488.ts\");\n/**\n * The event definition for an m.ts event (in content)\n */\nexport type MTimestampEvent = EitherAnd<{ [M_TIMESTAMP.name]: number }, { [M_TIMESTAMP.altName]: number }>;\n\nexport const M_LOCATION = new UnstableValue(\"m.location\", \"org.matrix.msc3488.location\");\n\nexport type MLocationContent = {\n uri: string;\n description?: string | null;\n};\n\nexport type MLocationEvent = EitherAnd<\n { [M_LOCATION.name]: MLocationContent },\n { [M_LOCATION.altName]: MLocationContent }\n>;\n\nexport type MTextEvent = EitherAnd<{ [M_TEXT.name]: string }, { [M_TEXT.altName]: string }>;\n\n/* From the spec at:\n * https://github.com/matrix-org/matrix-doc/blob/matthew/location/proposals/3488-location.md\n{\n \"type\": \"m.room.message\",\n \"content\": {\n \"body\": \"Matthew was at geo:51.5008,0.1247;u=35 as of Sat Nov 13 18:50:58 2021\",\n \"msgtype\": \"m.location\",\n \"geo_uri\": \"geo:51.5008,0.1247;u=35\",\n \"m.location\": {\n \"uri\": \"geo:51.5008,0.1247;u=35\",\n \"description\": \"Matthew's whereabouts\",\n },\n \"m.asset\": {\n \"type\": \"m.self\"\n },\n \"m.text\": \"Matthew was at geo:51.5008,0.1247;u=35 as of Sat Nov 13 18:50:58 2021\",\n \"m.ts\": 1636829458432,\n }\n}\n*/\ntype OptionalTimestampEvent = MTimestampEvent | undefined;\n/**\n * The content for an m.location event\n */\nexport type MLocationEventContent = MLocationEvent & MAssetEvent & MTextEvent & OptionalTimestampEvent;\n\nexport type LegacyLocationEventContent = {\n body: string;\n msgtype: string;\n geo_uri: string;\n};\n\n/**\n * Possible content for location events as sent over the wire\n */\nexport type LocationEventWireContent = Partial;\n\nexport type ILocationContent = MLocationEventContent & LegacyLocationEventContent;\n"],"mappings":";;;;;;AAmBA,IAAAA,gBAAA,GAAAC,OAAA;AACA,IAAAC,kBAAA,GAAAD,OAAA;AApBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA,IAMYE,iBAAiB;AAAAC,OAAA,CAAAD,iBAAA,GAAAA,iBAAA;AAAA,WAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;AAAA,GAAjBA,iBAAiB,KAAAC,OAAA,CAAAD,iBAAA,GAAjBA,iBAAiB;AAKtB,MAAME,OAAO,GAAG,IAAIC,8BAAa,CAAC,SAAS,EAAE,0BAA0B,CAAC;AAACF,OAAA,CAAAC,OAAA,GAAAA,OAAA;AAOzE,MAAME,WAAW,GAAG,IAAID,8BAAa,CAAC,MAAM,EAAE,uBAAuB,CAAC;AAC7E;AACA;AACA;AAFAF,OAAA,CAAAG,WAAA,GAAAA,WAAA;AAKO,MAAMC,UAAU,GAAG,IAAIF,8BAAa,CAAC,YAAY,EAAE,6BAA6B,CAAC;AAACF,OAAA,CAAAI,UAAA,GAAAA,UAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts deleted file mode 100644 index fc98e9b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts +++ /dev/null @@ -1,58 +0,0 @@ -export interface IImageInfo { - size?: number; - mimetype?: string; - thumbnail_info?: { - w?: number; - h?: number; - size?: number; - mimetype?: string; - }; - w?: number; - h?: number; -} -export declare enum Visibility { - Public = "public", - Private = "private" -} -export declare enum Preset { - PrivateChat = "private_chat", - TrustedPrivateChat = "trusted_private_chat", - PublicChat = "public_chat" -} -export type ResizeMethod = "crop" | "scale"; -export type IdServerUnbindResult = "no-support" | "success"; -export declare enum JoinRule { - Public = "public", - Invite = "invite", - /** - * @deprecated Reserved keyword. Should not be used. Not yet implemented. - */ - Private = "private", - Knock = "knock", - Restricted = "restricted" -} -export declare enum RestrictedAllowType { - RoomMembership = "m.room_membership" -} -export interface IJoinRuleEventContent { - join_rule: JoinRule; - allow?: { - type: RestrictedAllowType; - room_id: string; - }[]; -} -export declare enum GuestAccess { - CanJoin = "can_join", - Forbidden = "forbidden" -} -export declare enum HistoryVisibility { - Invited = "invited", - Joined = "joined", - Shared = "shared", - WorldReadable = "world_readable" -} -export interface IUsageLimit { - limit_type: "monthly_active_user" | "hs_disabled" | string; - admin_contact?: string; -} -//# sourceMappingURL=partials.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts.map deleted file mode 100644 index a4df429..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"partials.d.ts","sourceRoot":"","sources":["../../src/@types/partials.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,UAAU;IACvB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,cAAc,CAAC,EAAE;QAEb,CAAC,CAAC,EAAE,MAAM,CAAC;QACX,CAAC,CAAC,EAAE,MAAM,CAAC;QACX,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,QAAQ,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;IACF,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,CAAC,CAAC,EAAE,MAAM,CAAC;CACd;AAED,oBAAY,UAAU;IAClB,MAAM,WAAW;IACjB,OAAO,YAAY;CACtB;AAED,oBAAY,MAAM;IACd,WAAW,iBAAiB;IAC5B,kBAAkB,yBAAyB;IAC3C,UAAU,gBAAgB;CAC7B;AAED,MAAM,MAAM,YAAY,GAAG,MAAM,GAAG,OAAO,CAAC;AAE5C,MAAM,MAAM,oBAAoB,GAAG,YAAY,GAAG,SAAS,CAAC;AAG5D,oBAAY,QAAQ;IAChB,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB;;OAEG;IACH,OAAO,YAAY;IACnB,KAAK,UAAU;IACf,UAAU,eAAe;CAC5B;AAED,oBAAY,mBAAmB;IAC3B,cAAc,sBAAsB;CACvC;AAED,MAAM,WAAW,qBAAqB;IAClC,SAAS,EAAE,QAAQ,CAAC;IACpB,KAAK,CAAC,EAAE;QACJ,IAAI,EAAE,mBAAmB,CAAC;QAC1B,OAAO,EAAE,MAAM,CAAC;KACnB,EAAE,CAAC;CACP;AAED,oBAAY,WAAW;IACnB,OAAO,aAAa;IACpB,SAAS,cAAc;CAC1B;AAED,oBAAY,iBAAiB;IACzB,OAAO,YAAY;IACnB,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,aAAa,mBAAmB;CACnC;AAED,MAAM,WAAW,WAAW;IAIxB,UAAU,EAAE,qBAAqB,GAAG,aAAa,GAAG,MAAM,CAAC;IAE3D,aAAa,CAAC,EAAE,MAAM,CAAC;CAC1B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js deleted file mode 100644 index 1743e92..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js +++ /dev/null @@ -1,64 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.Visibility = exports.RestrictedAllowType = exports.Preset = exports.JoinRule = exports.HistoryVisibility = exports.GuestAccess = void 0; -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let Visibility; -exports.Visibility = Visibility; -(function (Visibility) { - Visibility["Public"] = "public"; - Visibility["Private"] = "private"; -})(Visibility || (exports.Visibility = Visibility = {})); -let Preset; -exports.Preset = Preset; -(function (Preset) { - Preset["PrivateChat"] = "private_chat"; - Preset["TrustedPrivateChat"] = "trusted_private_chat"; - Preset["PublicChat"] = "public_chat"; -})(Preset || (exports.Preset = Preset = {})); -// Knock and private are reserved keywords which are not yet implemented. -let JoinRule; -exports.JoinRule = JoinRule; -(function (JoinRule) { - JoinRule["Public"] = "public"; - JoinRule["Invite"] = "invite"; - JoinRule["Private"] = "private"; - JoinRule["Knock"] = "knock"; - JoinRule["Restricted"] = "restricted"; -})(JoinRule || (exports.JoinRule = JoinRule = {})); -let RestrictedAllowType; -exports.RestrictedAllowType = RestrictedAllowType; -(function (RestrictedAllowType) { - RestrictedAllowType["RoomMembership"] = "m.room_membership"; -})(RestrictedAllowType || (exports.RestrictedAllowType = RestrictedAllowType = {})); -let GuestAccess; -exports.GuestAccess = GuestAccess; -(function (GuestAccess) { - GuestAccess["CanJoin"] = "can_join"; - GuestAccess["Forbidden"] = "forbidden"; -})(GuestAccess || (exports.GuestAccess = GuestAccess = {})); -let HistoryVisibility; -exports.HistoryVisibility = HistoryVisibility; -(function (HistoryVisibility) { - HistoryVisibility["Invited"] = "invited"; - HistoryVisibility["Joined"] = "joined"; - HistoryVisibility["Shared"] = "shared"; - HistoryVisibility["WorldReadable"] = "world_readable"; -})(HistoryVisibility || (exports.HistoryVisibility = HistoryVisibility = {})); -//# sourceMappingURL=partials.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js.map deleted file mode 100644 index feff786..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/partials.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"partials.js","names":["Visibility","exports","Preset","JoinRule","RestrictedAllowType","GuestAccess","HistoryVisibility"],"sources":["../../src/@types/partials.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport interface IImageInfo {\n size?: number;\n mimetype?: string;\n thumbnail_info?: {\n // eslint-disable-line camelcase\n w?: number;\n h?: number;\n size?: number;\n mimetype?: string;\n };\n w?: number;\n h?: number;\n}\n\nexport enum Visibility {\n Public = \"public\",\n Private = \"private\",\n}\n\nexport enum Preset {\n PrivateChat = \"private_chat\",\n TrustedPrivateChat = \"trusted_private_chat\",\n PublicChat = \"public_chat\",\n}\n\nexport type ResizeMethod = \"crop\" | \"scale\";\n\nexport type IdServerUnbindResult = \"no-support\" | \"success\";\n\n// Knock and private are reserved keywords which are not yet implemented.\nexport enum JoinRule {\n Public = \"public\",\n Invite = \"invite\",\n /**\n * @deprecated Reserved keyword. Should not be used. Not yet implemented.\n */\n Private = \"private\",\n Knock = \"knock\",\n Restricted = \"restricted\",\n}\n\nexport enum RestrictedAllowType {\n RoomMembership = \"m.room_membership\",\n}\n\nexport interface IJoinRuleEventContent {\n join_rule: JoinRule; // eslint-disable-line camelcase\n allow?: {\n type: RestrictedAllowType;\n room_id: string; // eslint-disable-line camelcase\n }[];\n}\n\nexport enum GuestAccess {\n CanJoin = \"can_join\",\n Forbidden = \"forbidden\",\n}\n\nexport enum HistoryVisibility {\n Invited = \"invited\",\n Joined = \"joined\",\n Shared = \"shared\",\n WorldReadable = \"world_readable\",\n}\n\nexport interface IUsageLimit {\n // \"hs_disabled\" is NOT a specced string, but is used in Synapse\n // This is tracked over at https://github.com/matrix-org/synapse/issues/9237\n // eslint-disable-next-line camelcase\n limit_type: \"monthly_active_user\" | \"hs_disabled\" | string;\n // eslint-disable-next-line camelcase\n admin_contact?: string;\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IA8BYA,UAAU;AAAAC,OAAA,CAAAD,UAAA,GAAAA,UAAA;AAAA,WAAVA,UAAU;EAAVA,UAAU;EAAVA,UAAU;AAAA,GAAVA,UAAU,KAAAC,OAAA,CAAAD,UAAA,GAAVA,UAAU;AAAA,IAKVE,MAAM;AAAAD,OAAA,CAAAC,MAAA,GAAAA,MAAA;AAAA,WAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;AAAA,GAANA,MAAM,KAAAD,OAAA,CAAAC,MAAA,GAANA,MAAM;AAUlB;AAAA,IACYC,QAAQ;AAAAF,OAAA,CAAAE,QAAA,GAAAA,QAAA;AAAA,WAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;AAAA,GAARA,QAAQ,KAAAF,OAAA,CAAAE,QAAA,GAARA,QAAQ;AAAA,IAWRC,mBAAmB;AAAAH,OAAA,CAAAG,mBAAA,GAAAA,mBAAA;AAAA,WAAnBA,mBAAmB;EAAnBA,mBAAmB;AAAA,GAAnBA,mBAAmB,KAAAH,OAAA,CAAAG,mBAAA,GAAnBA,mBAAmB;AAAA,IAYnBC,WAAW;AAAAJ,OAAA,CAAAI,WAAA,GAAAA,WAAA;AAAA,WAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;AAAA,GAAXA,WAAW,KAAAJ,OAAA,CAAAI,WAAA,GAAXA,WAAW;AAAA,IAKXC,iBAAiB;AAAAL,OAAA,CAAAK,iBAAA,GAAAA,iBAAA;AAAA,WAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;AAAA,GAAjBA,iBAAiB,KAAAL,OAAA,CAAAK,iBAAA,GAAjBA,iBAAiB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts deleted file mode 100644 index d3aebc2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts +++ /dev/null @@ -1,88 +0,0 @@ -import { EitherAnd, UnstableValue } from "matrix-events-sdk"; -import { ExtensibleAnyMessageEventContent, REFERENCE_RELATION, RelatesToRelationship, TSNamespace } from "./extensible_events"; -/** - * Identifier for a disclosed poll. - */ -export declare const M_POLL_KIND_DISCLOSED: UnstableValue<"m.poll.disclosed", "org.matrix.msc3381.poll.disclosed">; -/** - * Identifier for an undisclosed poll. - */ -export declare const M_POLL_KIND_UNDISCLOSED: UnstableValue<"m.poll.undisclosed", "org.matrix.msc3381.poll.undisclosed">; -/** - * Any poll kind. - */ -export type PollKind = TSNamespace | TSNamespace | string; -/** - * Known poll kind namespaces. - */ -export type KnownPollKind = typeof M_POLL_KIND_DISCLOSED | typeof M_POLL_KIND_UNDISCLOSED; -/** - * The namespaced value for m.poll.start - */ -export declare const M_POLL_START: UnstableValue<"m.poll.start", "org.matrix.msc3381.poll.start">; -/** - * The m.poll.start type within event content - */ -export type PollStartSubtype = { - question: ExtensibleAnyMessageEventContent; - kind: PollKind; - max_selections?: number; - answers: PollAnswer[]; -}; -/** - * A poll answer. - */ -export type PollAnswer = ExtensibleAnyMessageEventContent & { - id: string; -}; -/** - * The event definition for an m.poll.start event (in content) - */ -export type PollStartEvent = EitherAnd<{ - [M_POLL_START.name]: PollStartSubtype; -}, { - [M_POLL_START.altName]: PollStartSubtype; -}>; -/** - * The content for an m.poll.start event - */ -export type PollStartEventContent = PollStartEvent & ExtensibleAnyMessageEventContent; -/** - * The namespaced value for m.poll.response - */ -export declare const M_POLL_RESPONSE: UnstableValue<"m.poll.response", "org.matrix.msc3381.poll.response">; -/** - * The m.poll.response type within event content - */ -export type PollResponseSubtype = { - answers: string[]; -}; -/** - * The event definition for an m.poll.response event (in content) - */ -export type PollResponseEvent = EitherAnd<{ - [M_POLL_RESPONSE.name]: PollResponseSubtype; -}, { - [M_POLL_RESPONSE.altName]: PollResponseSubtype; -}>; -/** - * The content for an m.poll.response event - */ -export type PollResponseEventContent = PollResponseEvent & RelatesToRelationship; -/** - * The namespaced value for m.poll.end - */ -export declare const M_POLL_END: UnstableValue<"m.poll.end", "org.matrix.msc3381.poll.end">; -/** - * The event definition for an m.poll.end event (in content) - */ -export type PollEndEvent = EitherAnd<{ - [M_POLL_END.name]: {}; -}, { - [M_POLL_END.altName]: {}; -}>; -/** - * The content for an m.poll.end event - */ -export type PollEndEventContent = PollEndEvent & RelatesToRelationship & ExtensibleAnyMessageEventContent; -//# sourceMappingURL=polls.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts.map deleted file mode 100644 index b7c1ac7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"polls.d.ts","sourceRoot":"","sources":["../../src/@types/polls.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAE7D,OAAO,EACH,gCAAgC,EAChC,kBAAkB,EAClB,qBAAqB,EACrB,WAAW,EACd,MAAM,qBAAqB,CAAC;AAE7B;;GAEG;AACH,eAAO,MAAM,qBAAqB,wEAA6E,CAAC;AAEhH;;GAEG;AACH,eAAO,MAAM,uBAAuB,4EAAiF,CAAC;AAEtH;;GAEG;AACH,MAAM,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,qBAAqB,CAAC,GAAG,WAAW,CAAC,OAAO,uBAAuB,CAAC,GAAG,MAAM,CAAC;AAExH;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,OAAO,qBAAqB,GAAG,OAAO,uBAAuB,CAAC;AAE1F;;GAEG;AACH,eAAO,MAAM,YAAY,gEAAqE,CAAC;AAE/F;;GAEG;AACH,MAAM,MAAM,gBAAgB,GAAG;IAC3B,QAAQ,EAAE,gCAAgC,CAAC;IAC3C,IAAI,EAAE,QAAQ,CAAC;IACf,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,EAAE,UAAU,EAAE,CAAC;CACzB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,gCAAgC,GAAG;IAAE,EAAE,EAAE,MAAM,CAAA;CAAE,CAAC;AAE3E;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,SAAS,CAClC;IAAE,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,gBAAgB,CAAA;CAAE,EACzC;IAAE,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,gBAAgB,CAAA;CAAE,CAC/C,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,qBAAqB,GAAG,cAAc,GAAG,gCAAgC,CAAC;AAEtF;;GAEG;AACH,eAAO,MAAM,eAAe,sEAA2E,CAAC;AAExG;;GAEG;AACH,MAAM,MAAM,mBAAmB,GAAG;IAC9B,OAAO,EAAE,MAAM,EAAE,CAAC;CACrB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,iBAAiB,GAAG,SAAS,CACrC;IAAE,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,mBAAmB,CAAA;CAAE,EAC/C;IAAE,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,mBAAmB,CAAA;CAAE,CACrD,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,wBAAwB,GAAG,iBAAiB,GAAG,qBAAqB,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAE5G;;GAEG;AACH,eAAO,MAAM,UAAU,4DAAiE,CAAC;AAEzF;;GAEG;AACH,MAAM,MAAM,YAAY,GAAG,SAAS,CAAC;IAAE,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,EAAE,CAAA;CAAE,EAAE;IAAE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,EAAE,CAAA;CAAE,CAAC,CAAC;AAE9F;;GAEG;AACH,MAAM,MAAM,mBAAmB,GAAG,YAAY,GAC1C,qBAAqB,CAAC,OAAO,kBAAkB,CAAC,GAChD,gCAAgC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js deleted file mode 100644 index 59c4c75..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js +++ /dev/null @@ -1,66 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.M_POLL_START = exports.M_POLL_RESPONSE = exports.M_POLL_KIND_UNDISCLOSED = exports.M_POLL_KIND_DISCLOSED = exports.M_POLL_END = void 0; -var _matrixEventsSdk = require("matrix-events-sdk"); -/* -Copyright 2022 - 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Identifier for a disclosed poll. - */ -const M_POLL_KIND_DISCLOSED = new _matrixEventsSdk.UnstableValue("m.poll.disclosed", "org.matrix.msc3381.poll.disclosed"); - -/** - * Identifier for an undisclosed poll. - */ -exports.M_POLL_KIND_DISCLOSED = M_POLL_KIND_DISCLOSED; -const M_POLL_KIND_UNDISCLOSED = new _matrixEventsSdk.UnstableValue("m.poll.undisclosed", "org.matrix.msc3381.poll.undisclosed"); - -/** - * Any poll kind. - */ -exports.M_POLL_KIND_UNDISCLOSED = M_POLL_KIND_UNDISCLOSED; -/** - * The namespaced value for m.poll.start - */ -const M_POLL_START = new _matrixEventsSdk.UnstableValue("m.poll.start", "org.matrix.msc3381.poll.start"); - -/** - * The m.poll.start type within event content - */ -exports.M_POLL_START = M_POLL_START; -/** - * The namespaced value for m.poll.response - */ -const M_POLL_RESPONSE = new _matrixEventsSdk.UnstableValue("m.poll.response", "org.matrix.msc3381.poll.response"); - -/** - * The m.poll.response type within event content - */ -exports.M_POLL_RESPONSE = M_POLL_RESPONSE; -/** - * The namespaced value for m.poll.end - */ -const M_POLL_END = new _matrixEventsSdk.UnstableValue("m.poll.end", "org.matrix.msc3381.poll.end"); - -/** - * The event definition for an m.poll.end event (in content) - */ -exports.M_POLL_END = M_POLL_END; -//# sourceMappingURL=polls.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js.map deleted file mode 100644 index 0cc80c2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/polls.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"polls.js","names":["_matrixEventsSdk","require","M_POLL_KIND_DISCLOSED","UnstableValue","exports","M_POLL_KIND_UNDISCLOSED","M_POLL_START","M_POLL_RESPONSE","M_POLL_END"],"sources":["../../src/@types/polls.ts"],"sourcesContent":["/*\nCopyright 2022 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EitherAnd, UnstableValue } from \"matrix-events-sdk\";\n\nimport {\n ExtensibleAnyMessageEventContent,\n REFERENCE_RELATION,\n RelatesToRelationship,\n TSNamespace,\n} from \"./extensible_events\";\n\n/**\n * Identifier for a disclosed poll.\n */\nexport const M_POLL_KIND_DISCLOSED = new UnstableValue(\"m.poll.disclosed\", \"org.matrix.msc3381.poll.disclosed\");\n\n/**\n * Identifier for an undisclosed poll.\n */\nexport const M_POLL_KIND_UNDISCLOSED = new UnstableValue(\"m.poll.undisclosed\", \"org.matrix.msc3381.poll.undisclosed\");\n\n/**\n * Any poll kind.\n */\nexport type PollKind = TSNamespace | TSNamespace | string;\n\n/**\n * Known poll kind namespaces.\n */\nexport type KnownPollKind = typeof M_POLL_KIND_DISCLOSED | typeof M_POLL_KIND_UNDISCLOSED;\n\n/**\n * The namespaced value for m.poll.start\n */\nexport const M_POLL_START = new UnstableValue(\"m.poll.start\", \"org.matrix.msc3381.poll.start\");\n\n/**\n * The m.poll.start type within event content\n */\nexport type PollStartSubtype = {\n question: ExtensibleAnyMessageEventContent;\n kind: PollKind;\n max_selections?: number; // default 1, always positive\n answers: PollAnswer[];\n};\n\n/**\n * A poll answer.\n */\nexport type PollAnswer = ExtensibleAnyMessageEventContent & { id: string };\n\n/**\n * The event definition for an m.poll.start event (in content)\n */\nexport type PollStartEvent = EitherAnd<\n { [M_POLL_START.name]: PollStartSubtype },\n { [M_POLL_START.altName]: PollStartSubtype }\n>;\n\n/**\n * The content for an m.poll.start event\n */\nexport type PollStartEventContent = PollStartEvent & ExtensibleAnyMessageEventContent;\n\n/**\n * The namespaced value for m.poll.response\n */\nexport const M_POLL_RESPONSE = new UnstableValue(\"m.poll.response\", \"org.matrix.msc3381.poll.response\");\n\n/**\n * The m.poll.response type within event content\n */\nexport type PollResponseSubtype = {\n answers: string[];\n};\n\n/**\n * The event definition for an m.poll.response event (in content)\n */\nexport type PollResponseEvent = EitherAnd<\n { [M_POLL_RESPONSE.name]: PollResponseSubtype },\n { [M_POLL_RESPONSE.altName]: PollResponseSubtype }\n>;\n\n/**\n * The content for an m.poll.response event\n */\nexport type PollResponseEventContent = PollResponseEvent & RelatesToRelationship;\n\n/**\n * The namespaced value for m.poll.end\n */\nexport const M_POLL_END = new UnstableValue(\"m.poll.end\", \"org.matrix.msc3381.poll.end\");\n\n/**\n * The event definition for an m.poll.end event (in content)\n */\nexport type PollEndEvent = EitherAnd<{ [M_POLL_END.name]: {} }, { [M_POLL_END.altName]: {} }>;\n\n/**\n * The content for an m.poll.end event\n */\nexport type PollEndEventContent = PollEndEvent &\n RelatesToRelationship &\n ExtensibleAnyMessageEventContent;\n"],"mappings":";;;;;;AAgBA,IAAAA,gBAAA,GAAAC,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAWA;AACA;AACA;AACO,MAAMC,qBAAqB,GAAG,IAAIC,8BAAa,CAAC,kBAAkB,EAAE,mCAAmC,CAAC;;AAE/G;AACA;AACA;AAFAC,OAAA,CAAAF,qBAAA,GAAAA,qBAAA;AAGO,MAAMG,uBAAuB,GAAG,IAAIF,8BAAa,CAAC,oBAAoB,EAAE,qCAAqC,CAAC;;AAErH;AACA;AACA;AAFAC,OAAA,CAAAC,uBAAA,GAAAA,uBAAA;AAUA;AACA;AACA;AACO,MAAMC,YAAY,GAAG,IAAIH,8BAAa,CAAC,cAAc,EAAE,+BAA+B,CAAC;;AAE9F;AACA;AACA;AAFAC,OAAA,CAAAE,YAAA,GAAAA,YAAA;AA4BA;AACA;AACA;AACO,MAAMC,eAAe,GAAG,IAAIJ,8BAAa,CAAC,iBAAiB,EAAE,kCAAkC,CAAC;;AAEvG;AACA;AACA;AAFAC,OAAA,CAAAG,eAAA,GAAAA,eAAA;AAoBA;AACA;AACA;AACO,MAAMC,UAAU,GAAG,IAAIL,8BAAa,CAAC,YAAY,EAAE,6BAA6B,CAAC;;AAExF;AACA;AACA;AAFAC,OAAA,CAAAI,UAAA,GAAAA,UAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts deleted file mode 100644 index dd023c0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts +++ /dev/null @@ -1,36 +0,0 @@ -export declare enum ReceiptType { - Read = "m.read", - FullyRead = "m.fully_read", - ReadPrivate = "m.read.private" -} -export declare const MAIN_ROOM_TIMELINE = "main"; -export interface Receipt { - ts: number; - thread_id?: string; -} -export interface WrappedReceipt { - eventId: string; - data: Receipt; -} -export interface CachedReceipt { - type: ReceiptType; - userId: string; - data: Receipt; -} -export type ReceiptCache = Map; -export interface ReceiptContent { - [eventId: string]: { - [key in ReceiptType | string]: { - [userId: string]: Receipt; - }; - }; -} -export type Receipts = Map>; -export type CachedReceiptStructure = { - eventId: string; - receiptType: string | ReceiptType; - userId: string; - receipt: Receipt; - synthetic: boolean; -}; -//# sourceMappingURL=read_receipts.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts.map deleted file mode 100644 index deb67eb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"read_receipts.d.ts","sourceRoot":"","sources":["../../src/@types/read_receipts.ts"],"names":[],"mappings":"AAgBA,oBAAY,WAAW;IACnB,IAAI,WAAW;IACf,SAAS,iBAAiB;IAC1B,WAAW,mBAAmB;CACjC;AAED,eAAO,MAAM,kBAAkB,SAAS,CAAC;AAEzC,MAAM,WAAW,OAAO;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,cAAc;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,aAAa;IAC1B,IAAI,EAAE,WAAW,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,MAAM,YAAY,GAAG,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC;AAExD,MAAM,WAAW,cAAc;IAC3B,CAAC,OAAO,EAAE,MAAM,GAAG;SACd,GAAG,IAAI,WAAW,GAAG,MAAM,GAAG;YAC3B,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC;SAC7B;KACJ,CAAC;CACL;AAID,MAAM,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,EAAE,SAAS,EAAE,cAAc,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AAEjH,MAAM,MAAM,sBAAsB,GAAG;IACjC,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,GAAG,WAAW,CAAC;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;CACtB,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js deleted file mode 100644 index 6f662cc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js +++ /dev/null @@ -1,31 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ReceiptType = exports.MAIN_ROOM_TIMELINE = void 0; -/* -Copyright 2022 Šimon Brandner - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let ReceiptType; -exports.ReceiptType = ReceiptType; -(function (ReceiptType) { - ReceiptType["Read"] = "m.read"; - ReceiptType["FullyRead"] = "m.fully_read"; - ReceiptType["ReadPrivate"] = "m.read.private"; -})(ReceiptType || (exports.ReceiptType = ReceiptType = {})); -const MAIN_ROOM_TIMELINE = "main"; -exports.MAIN_ROOM_TIMELINE = MAIN_ROOM_TIMELINE; -//# sourceMappingURL=read_receipts.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js.map deleted file mode 100644 index 1a37b48..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/read_receipts.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"read_receipts.js","names":["ReceiptType","exports","MAIN_ROOM_TIMELINE"],"sources":["../../src/@types/read_receipts.ts"],"sourcesContent":["/*\nCopyright 2022 Šimon Brandner \n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport enum ReceiptType {\n Read = \"m.read\",\n FullyRead = \"m.fully_read\",\n ReadPrivate = \"m.read.private\",\n}\n\nexport const MAIN_ROOM_TIMELINE = \"main\";\n\nexport interface Receipt {\n ts: number;\n thread_id?: string;\n}\n\nexport interface WrappedReceipt {\n eventId: string;\n data: Receipt;\n}\n\nexport interface CachedReceipt {\n type: ReceiptType;\n userId: string;\n data: Receipt;\n}\n\nexport type ReceiptCache = Map;\n\nexport interface ReceiptContent {\n [eventId: string]: {\n [key in ReceiptType | string]: {\n [userId: string]: Receipt;\n };\n };\n}\n\n// We will only hold a synthetic receipt if we do not have a real receipt or the synthetic is newer.\n// map: receipt type → user Id → receipt\nexport type Receipts = Map>;\n\nexport type CachedReceiptStructure = {\n eventId: string;\n receiptType: string | ReceiptType;\n userId: string;\n receipt: Receipt;\n synthetic: boolean;\n};\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAgBYA,WAAW;AAAAC,OAAA,CAAAD,WAAA,GAAAA,WAAA;AAAA,WAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;AAAA,GAAXA,WAAW,KAAAC,OAAA,CAAAD,WAAA,GAAXA,WAAW;AAMhB,MAAME,kBAAkB,GAAG,MAAM;AAACD,OAAA,CAAAC,kBAAA,GAAAA,kBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts deleted file mode 100644 index 340faae..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts +++ /dev/null @@ -1,184 +0,0 @@ -import { IContent, IEvent } from "../models/event"; -import { Preset, Visibility } from "./partials"; -import { IEventWithRoomId, SearchKey } from "./search"; -import { IRoomEventFilter } from "../filter"; -import { Direction } from "../models/event-timeline"; -import { PushRuleAction } from "./PushRules"; -import { IRoomEvent } from "../sync-accumulator"; -import { EventType, RelationType, RoomType } from "./event"; -export interface IJoinRoomOpts { - /** - * True to do a room initial sync on the resulting - * room. If false, the returned Room object will have no current state. - * Default: true. - */ - syncRoom?: boolean; - /** - * If the caller has a keypair 3pid invite, the signing URL is passed in this parameter. - */ - inviteSignUrl?: string; - /** - * The server names to try and join through in addition to those that are automatically chosen. - */ - viaServers?: string[]; -} -export interface IRedactOpts { - reason?: string; - /** - * Whether events related to the redacted event should be redacted. - * - * If specified, then any events which relate to the event being redacted with - * any of the relationship types listed will also be redacted. - * - * Raises an Error if the server does not support it. - * Check for server-side support before using this param with - * client.canSupport.get(Feature.RelationBasedRedactions). - * {@link https://github.com/matrix-org/matrix-spec-proposals/pull/3912} - */ - with_relations?: Array; -} -export interface ISendEventResponse { - event_id: string; -} -export interface IPresenceOpts { - presence: "online" | "offline" | "unavailable"; - status_msg?: string; -} -export interface IPaginateOpts { - backwards?: boolean; - limit?: number; -} -export interface IGuestAccessOpts { - /** - * True to allow guests to join this room. This - * implicitly gives guests write access. If false or not given, guests are - * explicitly forbidden from joining the room. - */ - allowJoin: boolean; - /** - * True to set history visibility to - * be world_readable. This gives guests read access *from this point forward*. - * If false or not given, history visibility is not modified. - */ - allowRead: boolean; -} -export interface ISearchOpts { - keys?: SearchKey[]; - query: string; -} -export interface IEventSearchOpts { - filter?: IRoomEventFilter; - term: string; -} -export interface IInvite3PID { - id_server: string; - id_access_token?: string; - medium: string; - address: string; -} -export interface ICreateRoomStateEvent { - type: string; - state_key?: string; - content: IContent; -} -export interface ICreateRoomOpts { - room_alias_name?: string; - visibility?: Visibility; - name?: string; - topic?: string; - preset?: Preset; - power_level_content_override?: { - ban?: number; - events?: Record; - events_default?: number; - invite?: number; - kick?: number; - notifications?: Record; - redact?: number; - state_default?: number; - users?: Record; - users_default?: number; - }; - creation_content?: object; - initial_state?: ICreateRoomStateEvent[]; - invite?: string[]; - invite_3pid?: IInvite3PID[]; - is_direct?: boolean; - room_version?: string; -} -export interface IRoomDirectoryOptions { - server?: string; - limit?: number; - since?: string; - filter?: { - generic_search_term?: string; - room_types?: Array; - }; - include_all_networks?: boolean; - third_party_instance_id?: string; -} -export interface IAddThreePidOnlyBody { - auth?: { - type: string; - session?: string; - }; - client_secret: string; - sid: string; -} -export interface IBindThreePidBody { - client_secret: string; - id_server: string; - id_access_token: string; - sid: string; -} -export interface IRelationsRequestOpts { - from?: string; - to?: string; - limit?: number; - dir?: Direction; -} -export interface IRelationsResponse { - chunk: IEvent[]; - next_batch?: string; - prev_batch?: string; -} -export interface IContextResponse { - end: string; - start: string; - state: IEventWithRoomId[]; - events_before: IEventWithRoomId[]; - events_after: IEventWithRoomId[]; - event: IEventWithRoomId; -} -export interface IEventsResponse { - chunk: IEventWithRoomId[]; - end: string; - start: string; -} -export interface INotification { - actions: PushRuleAction[]; - event: IRoomEvent; - profile_tag?: string; - read: boolean; - room_id: string; - ts: number; -} -export interface INotificationsResponse { - next_token: string; - notifications: INotification[]; -} -export interface IFilterResponse { - filter_id: string; -} -export interface ITagsResponse { - tags: { - [tagId: string]: { - order: number; - }; - }; -} -export interface IStatusResponse extends IPresenceOpts { - currently_active?: boolean; - last_active_ago?: number; -} -//# sourceMappingURL=requests.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts.map deleted file mode 100644 index 09dc328..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"requests.d.ts","sourceRoot":"","sources":["../../src/@types/requests.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js deleted file mode 100644 index f1ffcdd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=requests.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js.map deleted file mode 100644 index 4222a82..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/requests.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"requests.js","names":[],"sources":["../../src/@types/requests.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IContent, IEvent } from \"../models/event\";\nimport { Preset, Visibility } from \"./partials\";\nimport { IEventWithRoomId, SearchKey } from \"./search\";\nimport { IRoomEventFilter } from \"../filter\";\nimport { Direction } from \"../models/event-timeline\";\nimport { PushRuleAction } from \"./PushRules\";\nimport { IRoomEvent } from \"../sync-accumulator\";\nimport { EventType, RelationType, RoomType } from \"./event\";\n\n// allow camelcase as these are things that go onto the wire\n/* eslint-disable camelcase */\n\nexport interface IJoinRoomOpts {\n /**\n * True to do a room initial sync on the resulting\n * room. If false, the returned Room object will have no current state.\n * Default: true.\n */\n syncRoom?: boolean;\n\n /**\n * If the caller has a keypair 3pid invite, the signing URL is passed in this parameter.\n */\n inviteSignUrl?: string;\n\n /**\n * The server names to try and join through in addition to those that are automatically chosen.\n */\n viaServers?: string[];\n}\n\nexport interface IRedactOpts {\n reason?: string;\n /**\n * Whether events related to the redacted event should be redacted.\n *\n * If specified, then any events which relate to the event being redacted with\n * any of the relationship types listed will also be redacted.\n *\n * Raises an Error if the server does not support it.\n * Check for server-side support before using this param with\n * client.canSupport.get(Feature.RelationBasedRedactions).\n * {@link https://github.com/matrix-org/matrix-spec-proposals/pull/3912}\n */\n with_relations?: Array;\n}\n\nexport interface ISendEventResponse {\n event_id: string;\n}\n\nexport interface IPresenceOpts {\n // One of \"online\", \"offline\" or \"unavailable\"\n presence: \"online\" | \"offline\" | \"unavailable\";\n // The status message to attach.\n status_msg?: string;\n}\n\nexport interface IPaginateOpts {\n // true to fill backwards, false to go forwards\n backwards?: boolean;\n // number of events to request\n limit?: number;\n}\n\nexport interface IGuestAccessOpts {\n /**\n * True to allow guests to join this room. This\n * implicitly gives guests write access. If false or not given, guests are\n * explicitly forbidden from joining the room.\n */\n allowJoin: boolean;\n /**\n * True to set history visibility to\n * be world_readable. This gives guests read access *from this point forward*.\n * If false or not given, history visibility is not modified.\n */\n allowRead: boolean;\n}\n\nexport interface ISearchOpts {\n keys?: SearchKey[];\n query: string;\n}\n\nexport interface IEventSearchOpts {\n // a JSON filter object to pass in the request\n filter?: IRoomEventFilter;\n // the term to search for\n term: string;\n}\n\nexport interface IInvite3PID {\n id_server: string;\n id_access_token?: string; // this gets injected by the js-sdk\n medium: string;\n address: string;\n}\n\nexport interface ICreateRoomStateEvent {\n type: string;\n state_key?: string; // defaults to an empty string\n content: IContent;\n}\n\nexport interface ICreateRoomOpts {\n // The alias localpart to assign to this room.\n room_alias_name?: string;\n // Either 'public' or 'private'.\n visibility?: Visibility;\n // The name to give this room.\n name?: string;\n // The topic to give this room.\n topic?: string;\n preset?: Preset;\n power_level_content_override?: {\n ban?: number;\n events?: Record;\n events_default?: number;\n invite?: number;\n kick?: number;\n notifications?: Record;\n redact?: number;\n state_default?: number;\n users?: Record;\n users_default?: number;\n };\n creation_content?: object;\n initial_state?: ICreateRoomStateEvent[];\n // A list of user IDs to invite to this room.\n invite?: string[];\n invite_3pid?: IInvite3PID[];\n is_direct?: boolean;\n room_version?: string;\n}\n\nexport interface IRoomDirectoryOptions {\n server?: string;\n limit?: number;\n since?: string;\n\n // Filter parameters\n filter?: {\n // String to search for\n generic_search_term?: string;\n room_types?: Array;\n };\n include_all_networks?: boolean;\n third_party_instance_id?: string;\n}\n\nexport interface IAddThreePidOnlyBody {\n auth?: {\n type: string;\n session?: string;\n };\n client_secret: string;\n sid: string;\n}\n\nexport interface IBindThreePidBody {\n client_secret: string;\n id_server: string;\n id_access_token: string;\n sid: string;\n}\n\nexport interface IRelationsRequestOpts {\n from?: string;\n to?: string;\n limit?: number;\n dir?: Direction;\n}\n\nexport interface IRelationsResponse {\n chunk: IEvent[];\n next_batch?: string;\n prev_batch?: string;\n}\n\nexport interface IContextResponse {\n end: string;\n start: string;\n state: IEventWithRoomId[];\n events_before: IEventWithRoomId[];\n events_after: IEventWithRoomId[];\n event: IEventWithRoomId;\n}\n\nexport interface IEventsResponse {\n chunk: IEventWithRoomId[];\n end: string;\n start: string;\n}\n\nexport interface INotification {\n actions: PushRuleAction[];\n event: IRoomEvent;\n profile_tag?: string;\n read: boolean;\n room_id: string;\n ts: number;\n}\n\nexport interface INotificationsResponse {\n next_token: string;\n notifications: INotification[];\n}\n\nexport interface IFilterResponse {\n filter_id: string;\n}\n\nexport interface ITagsResponse {\n tags: {\n [tagId: string]: {\n order: number;\n };\n };\n}\n\nexport interface IStatusResponse extends IPresenceOpts {\n currently_active?: boolean;\n last_active_ago?: number;\n}\n\n/* eslint-enable camelcase */\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts deleted file mode 100644 index 96bd090..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts +++ /dev/null @@ -1,90 +0,0 @@ -import { IRoomEvent, IStateEvent } from "../sync-accumulator"; -import { IRoomEventFilter } from "../filter"; -import { SearchResult } from "../models/search-result"; -export interface IEventWithRoomId extends IRoomEvent { - room_id: string; -} -export interface IStateEventWithRoomId extends IStateEvent { - room_id: string; -} -export interface IMatrixProfile { - avatar_url?: string; - displayname?: string; -} -export interface IResultContext { - events_before: IEventWithRoomId[]; - events_after: IEventWithRoomId[]; - profile_info: Record; - start?: string; - end?: string; -} -export interface ISearchResult { - rank: number; - result: IEventWithRoomId; - context: IResultContext; -} -declare enum GroupKey { - RoomId = "room_id", - Sender = "sender" -} -export interface IResultRoomEvents { - count: number; - highlights: string[]; - results: ISearchResult[]; - state?: { - [roomId: string]: IStateEventWithRoomId[]; - }; - groups?: { - [groupKey in GroupKey]: { - [value: string]: { - next_batch?: string; - order: number; - results: string[]; - }; - }; - }; - next_batch?: string; -} -interface IResultCategories { - room_events: IResultRoomEvents; -} -export type SearchKey = "content.body" | "content.name" | "content.topic"; -export declare enum SearchOrderBy { - Recent = "recent", - Rank = "rank" -} -export interface ISearchRequestBody { - search_categories: { - room_events: { - search_term: string; - keys?: SearchKey[]; - filter?: IRoomEventFilter; - order_by?: SearchOrderBy; - event_context?: { - before_limit?: number; - after_limit?: number; - include_profile?: boolean; - }; - include_state?: boolean; - groupings?: { - group_by: { - key: GroupKey; - }[]; - }; - }; - }; -} -export interface ISearchResponse { - search_categories: IResultCategories; -} -export interface ISearchResults { - _query?: ISearchRequestBody; - results: SearchResult[]; - highlights: string[]; - count?: number; - next_batch?: string; - pendingRequest?: Promise; - abortSignal?: AbortSignal; -} -export {}; -//# sourceMappingURL=search.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts.map deleted file mode 100644 index abfe161..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../src/@types/search.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js deleted file mode 100644 index cac4205..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js +++ /dev/null @@ -1,36 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SearchOrderBy = void 0; -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -// Types relating to the /search API -/* eslint-disable camelcase */ -var GroupKey; -(function (GroupKey) { - GroupKey["RoomId"] = "room_id"; - GroupKey["Sender"] = "sender"; -})(GroupKey || (GroupKey = {})); -let SearchOrderBy; -exports.SearchOrderBy = SearchOrderBy; -(function (SearchOrderBy) { - SearchOrderBy["Recent"] = "recent"; - SearchOrderBy["Rank"] = "rank"; -})(SearchOrderBy || (exports.SearchOrderBy = SearchOrderBy = {})); -/* eslint-enable camelcase */ -//# sourceMappingURL=search.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js.map deleted file mode 100644 index 19e33f4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/search.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"search.js","names":["GroupKey","SearchOrderBy","exports"],"sources":["../../src/@types/search.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n// Types relating to the /search API\n\nimport { IRoomEvent, IStateEvent } from \"../sync-accumulator\";\nimport { IRoomEventFilter } from \"../filter\";\nimport { SearchResult } from \"../models/search-result\";\n\n/* eslint-disable camelcase */\nexport interface IEventWithRoomId extends IRoomEvent {\n room_id: string;\n}\n\nexport interface IStateEventWithRoomId extends IStateEvent {\n room_id: string;\n}\n\nexport interface IMatrixProfile {\n avatar_url?: string;\n displayname?: string;\n}\n\nexport interface IResultContext {\n events_before: IEventWithRoomId[];\n events_after: IEventWithRoomId[];\n profile_info: Record;\n start?: string;\n end?: string;\n}\n\nexport interface ISearchResult {\n rank: number;\n result: IEventWithRoomId;\n context: IResultContext;\n}\n\nenum GroupKey {\n RoomId = \"room_id\",\n Sender = \"sender\",\n}\n\nexport interface IResultRoomEvents {\n count: number;\n highlights: string[];\n results: ISearchResult[];\n state?: { [roomId: string]: IStateEventWithRoomId[] };\n groups?: {\n [groupKey in GroupKey]: {\n [value: string]: {\n next_batch?: string;\n order: number;\n results: string[];\n };\n };\n };\n next_batch?: string;\n}\n\ninterface IResultCategories {\n room_events: IResultRoomEvents;\n}\n\nexport type SearchKey = \"content.body\" | \"content.name\" | \"content.topic\";\n\nexport enum SearchOrderBy {\n Recent = \"recent\",\n Rank = \"rank\",\n}\n\nexport interface ISearchRequestBody {\n search_categories: {\n room_events: {\n search_term: string;\n keys?: SearchKey[];\n filter?: IRoomEventFilter;\n order_by?: SearchOrderBy;\n event_context?: {\n before_limit?: number;\n after_limit?: number;\n include_profile?: boolean;\n };\n include_state?: boolean;\n groupings?: {\n group_by: {\n key: GroupKey;\n }[];\n };\n };\n };\n}\n\nexport interface ISearchResponse {\n search_categories: IResultCategories;\n}\n\nexport interface ISearchResults {\n _query?: ISearchRequestBody;\n results: SearchResult[];\n highlights: string[];\n count?: number;\n next_batch?: string;\n pendingRequest?: Promise;\n abortSignal?: AbortSignal;\n}\n/* eslint-enable camelcase */\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAMA;AAAA,IA4BKA,QAAQ;AAAA,WAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;AAAA,GAARA,QAAQ,KAARA,QAAQ;AAAA,IA4BDC,aAAa;AAAAC,OAAA,CAAAD,aAAA,GAAAA,aAAA;AAAA,WAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;AAAA,GAAbA,aAAa,KAAAC,OAAA,CAAAD,aAAA,GAAbA,aAAa;AAwCzB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts deleted file mode 100644 index 57b271e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -export interface ISignatures { - [entity: string]: { - [keyId: string]: string; - }; -} -export interface ISigned { - signatures?: ISignatures; -} -//# sourceMappingURL=signed.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts.map deleted file mode 100644 index 3e5677c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"signed.d.ts","sourceRoot":"","sources":["../../src/@types/signed.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,WAAW;IACxB,CAAC,MAAM,EAAE,MAAM,GAAG;QACd,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;KAC3B,CAAC;CACL;AAED,MAAM,WAAW,OAAO;IACpB,UAAU,CAAC,EAAE,WAAW,CAAC;CAC5B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js deleted file mode 100644 index 91a9aa5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=signed.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js.map deleted file mode 100644 index 6e49733..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/signed.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"signed.js","names":[],"sources":["../../src/@types/signed.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport interface ISignatures {\n [entity: string]: {\n [keyId: string]: string;\n };\n}\n\nexport interface ISigned {\n signatures?: ISignatures;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts deleted file mode 100644 index ba86e44..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts +++ /dev/null @@ -1,16 +0,0 @@ -import { IPublicRoomsChunkRoom } from "../client"; -import { RoomType } from "./event"; -import { IStrippedState } from "../sync-accumulator"; -export interface IHierarchyRelation extends IStrippedState { - origin_server_ts: number; - content: { - order?: string; - suggested?: boolean; - via?: string[]; - }; -} -export interface IHierarchyRoom extends IPublicRoomsChunkRoom { - room_type?: RoomType | string; - children_state: IHierarchyRelation[]; -} -//# sourceMappingURL=spaces.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts.map deleted file mode 100644 index 02e5a06..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"spaces.d.ts","sourceRoot":"","sources":["../../src/@types/spaces.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAKrD,MAAM,WAAW,kBAAmB,SAAQ,cAAc;IACtD,gBAAgB,EAAE,MAAM,CAAC;IACzB,OAAO,EAAE;QACL,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,OAAO,CAAC;QACpB,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;KAClB,CAAC;CACL;AAED,MAAM,WAAW,cAAe,SAAQ,qBAAqB;IACzD,SAAS,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAC;IAC9B,cAAc,EAAE,kBAAkB,EAAE,CAAC;CACxC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js deleted file mode 100644 index 8ecdd2b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=spaces.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js.map deleted file mode 100644 index 1063304..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/spaces.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"spaces.js","names":[],"sources":["../../src/@types/spaces.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IPublicRoomsChunkRoom } from \"../client\";\nimport { RoomType } from \"./event\";\nimport { IStrippedState } from \"../sync-accumulator\";\n\n// Types relating to Rooms of type `m.space` and related APIs\n\n/* eslint-disable camelcase */\nexport interface IHierarchyRelation extends IStrippedState {\n origin_server_ts: number;\n content: {\n order?: string;\n suggested?: boolean;\n via?: string[];\n };\n}\n\nexport interface IHierarchyRoom extends IPublicRoomsChunkRoom {\n room_type?: RoomType | string;\n children_state: IHierarchyRelation[];\n}\n/* eslint-enable camelcase */\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts deleted file mode 100644 index 37ad3d3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts +++ /dev/null @@ -1,19 +0,0 @@ -import { IdServerUnbindResult } from "./partials"; -export interface ISynapseAdminWhoisResponse { - user_id: string; - devices: { - [deviceId: string]: { - sessions: { - connections: { - ip: string; - last_seen: number; - user_agent: string; - }[]; - }[]; - }; - }; -} -export interface ISynapseAdminDeactivateResponse { - id_server_unbind_result: IdServerUnbindResult; -} -//# sourceMappingURL=synapse.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts.map deleted file mode 100644 index c484061..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"synapse.d.ts","sourceRoot":"","sources":["../../src/@types/synapse.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAKlD,MAAM,WAAW,0BAA0B;IACvC,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE;QACL,CAAC,QAAQ,EAAE,MAAM,GAAG;YAChB,QAAQ,EAAE;gBACN,WAAW,EAAE;oBACT,EAAE,EAAE,MAAM,CAAC;oBACX,SAAS,EAAE,MAAM,CAAC;oBAClB,UAAU,EAAE,MAAM,CAAC;iBACtB,EAAE,CAAC;aACP,EAAE,CAAC;SACP,CAAC;KACL,CAAC;CACL;AAED,MAAM,WAAW,+BAA+B;IAC5C,uBAAuB,EAAE,oBAAoB,CAAC;CACjD"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js deleted file mode 100644 index 3eea0ae..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=synapse.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js.map deleted file mode 100644 index 1035079..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/synapse.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"synapse.js","names":[],"sources":["../../src/@types/synapse.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IdServerUnbindResult } from \"./partials\";\n\n// Types relating to Synapse Admin APIs\n\n/* eslint-disable camelcase */\nexport interface ISynapseAdminWhoisResponse {\n user_id: string;\n devices: {\n [deviceId: string]: {\n sessions: {\n connections: {\n ip: string;\n last_seen: number; // millis since epoch\n user_agent: string;\n }[];\n }[];\n };\n };\n}\n\nexport interface ISynapseAdminDeactivateResponse {\n id_server_unbind_result: IdServerUnbindResult;\n}\n/* eslint-enable camelcase */\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts deleted file mode 100644 index 1debfef..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -import { ServerControlledNamespacedValue } from "../NamespacedValue"; -/** - * https://github.com/matrix-org/matrix-doc/pull/3773 - * - * @experimental - */ -export declare const UNREAD_THREAD_NOTIFICATIONS: ServerControlledNamespacedValue<"unread_thread_notifications", "org.matrix.msc3773.unread_thread_notifications">; -//# sourceMappingURL=sync.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts.map deleted file mode 100644 index 79b5bf5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../src/@types/sync.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,+BAA+B,EAAE,MAAM,oBAAoB,CAAC;AAErE;;;;GAIG;AACH,eAAO,MAAM,2BAA2B,kHAGvC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js deleted file mode 100644 index df6e6ff..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js +++ /dev/null @@ -1,31 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UNREAD_THREAD_NOTIFICATIONS = void 0; -var _NamespacedValue = require("../NamespacedValue"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * https://github.com/matrix-org/matrix-doc/pull/3773 - * - * @experimental - */ -const UNREAD_THREAD_NOTIFICATIONS = new _NamespacedValue.ServerControlledNamespacedValue("unread_thread_notifications", "org.matrix.msc3773.unread_thread_notifications"); -exports.UNREAD_THREAD_NOTIFICATIONS = UNREAD_THREAD_NOTIFICATIONS; -//# sourceMappingURL=sync.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js.map deleted file mode 100644 index 56a17e0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/sync.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sync.js","names":["_NamespacedValue","require","UNREAD_THREAD_NOTIFICATIONS","ServerControlledNamespacedValue","exports"],"sources":["../../src/@types/sync.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ServerControlledNamespacedValue } from \"../NamespacedValue\";\n\n/**\n * https://github.com/matrix-org/matrix-doc/pull/3773\n *\n * @experimental\n */\nexport const UNREAD_THREAD_NOTIFICATIONS = new ServerControlledNamespacedValue(\n \"unread_thread_notifications\",\n \"org.matrix.msc3773.unread_thread_notifications\",\n);\n"],"mappings":";;;;;;AAgBA,IAAAA,gBAAA,GAAAC,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIA;AACA;AACA;AACA;AACA;AACO,MAAMC,2BAA2B,GAAG,IAAIC,gDAA+B,CAC1E,6BAA6B,EAC7B,gDAAgD,CACnD;AAACC,OAAA,CAAAF,2BAAA,GAAAA,2BAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts deleted file mode 100644 index e9da35e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -export declare enum ThreepidMedium { - Email = "email", - Phone = "msisdn" -} -export interface IThreepid { - medium: ThreepidMedium; - address: string; - validated_at: number; - added_at: number; - bound?: boolean; -} -//# sourceMappingURL=threepids.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts.map deleted file mode 100644 index 00184f3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"threepids.d.ts","sourceRoot":"","sources":["../../src/@types/threepids.ts"],"names":[],"mappings":"AAgBA,oBAAY,cAAc;IACtB,KAAK,UAAU;IACf,KAAK,WAAW;CACnB;AAGD,MAAM,WAAW,SAAS;IACtB,MAAM,EAAE,cAAc,CAAC;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,OAAO,CAAC;CACnB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js deleted file mode 100644 index 28fe1b0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ThreepidMedium = void 0; -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let ThreepidMedium; // TODO: Are these types universal, or specific to just /account/3pid? -exports.ThreepidMedium = ThreepidMedium; -(function (ThreepidMedium) { - ThreepidMedium["Email"] = "email"; - ThreepidMedium["Phone"] = "msisdn"; -})(ThreepidMedium || (exports.ThreepidMedium = ThreepidMedium = {})); -//# sourceMappingURL=threepids.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js.map deleted file mode 100644 index 455c6f1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/threepids.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"threepids.js","names":["ThreepidMedium","exports"],"sources":["../../src/@types/threepids.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport enum ThreepidMedium {\n Email = \"email\",\n Phone = \"msisdn\",\n}\n\n// TODO: Are these types universal, or specific to just /account/3pid?\nexport interface IThreepid {\n medium: ThreepidMedium;\n address: string;\n validated_at: number; // eslint-disable-line camelcase\n added_at: number; // eslint-disable-line camelcase\n bound?: boolean;\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAgBYA,cAAc,EAK1B;AAAAC,OAAA,CAAAD,cAAA,GAAAA,cAAA;AAAA,WALYA,cAAc;EAAdA,cAAc;EAAdA,cAAc;AAAA,GAAdA,cAAc,KAAAC,OAAA,CAAAD,cAAA,GAAdA,cAAc"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts deleted file mode 100644 index cfa9d11..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts +++ /dev/null @@ -1,48 +0,0 @@ -import { EitherAnd } from "matrix-events-sdk"; -import { UnstableValue } from "../NamespacedValue"; -import { IMessageRendering } from "./extensible_events"; -/** - * Extensible topic event type based on MSC3765 - * https://github.com/matrix-org/matrix-spec-proposals/pull/3765 - * - * @example - * ``` - * { - * "type": "m.room.topic, - * "state_key": "", - * "content": { - * "topic": "All about **pizza**", - * "m.topic": [{ - * "body": "All about **pizza**", - * "mimetype": "text/plain", - * }, { - * "body": "All about pizza", - * "mimetype": "text/html", - * }], - * } - * } - * ``` - */ -/** - * The event type for an m.topic event (in content) - */ -export declare const M_TOPIC: UnstableValue<"m.topic", "org.matrix.msc3765.topic">; -/** - * The event content for an m.topic event (in content) - */ -export type MTopicContent = IMessageRendering[]; -/** - * The event definition for an m.topic event (in content) - */ -export type MTopicEvent = EitherAnd<{ - [M_TOPIC.name]: MTopicContent; -}, { - [M_TOPIC.altName]: MTopicContent; -}>; -/** - * The event content for an m.room.topic event - */ -export type MRoomTopicEventContent = { - topic: string; -} & MTopicEvent; -//# sourceMappingURL=topic.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts.map deleted file mode 100644 index 12b5eed..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"topic.d.ts","sourceRoot":"","sources":["../../src/@types/topic.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH;;GAEG;AACH,eAAO,MAAM,OAAO,sDAA2D,CAAC;AAEhF;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,iBAAiB,EAAE,CAAC;AAEhD;;GAEG;AACH,MAAM,MAAM,WAAW,GAAG,SAAS,CAAC;IAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,aAAa,CAAA;CAAE,EAAE;IAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,aAAa,CAAA;CAAE,CAAC,CAAC;AAE7G;;GAEG;AACH,MAAM,MAAM,sBAAsB,GAAG;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,GAAG,WAAW,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js deleted file mode 100644 index 56b83df..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js +++ /dev/null @@ -1,56 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.M_TOPIC = void 0; -var _NamespacedValue = require("../NamespacedValue"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Extensible topic event type based on MSC3765 - * https://github.com/matrix-org/matrix-spec-proposals/pull/3765 - * - * @example - * ``` - * { - * "type": "m.room.topic, - * "state_key": "", - * "content": { - * "topic": "All about **pizza**", - * "m.topic": [{ - * "body": "All about **pizza**", - * "mimetype": "text/plain", - * }, { - * "body": "All about pizza", - * "mimetype": "text/html", - * }], - * } - * } - * ``` - */ - -/** - * The event type for an m.topic event (in content) - */ -const M_TOPIC = new _NamespacedValue.UnstableValue("m.topic", "org.matrix.msc3765.topic"); - -/** - * The event content for an m.topic event (in content) - */ -exports.M_TOPIC = M_TOPIC; -//# sourceMappingURL=topic.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js.map deleted file mode 100644 index fb9873e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/topic.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"topic.js","names":["_NamespacedValue","require","M_TOPIC","UnstableValue","exports"],"sources":["../../src/@types/topic.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EitherAnd } from \"matrix-events-sdk\";\n\nimport { UnstableValue } from \"../NamespacedValue\";\nimport { IMessageRendering } from \"./extensible_events\";\n\n/**\n * Extensible topic event type based on MSC3765\n * https://github.com/matrix-org/matrix-spec-proposals/pull/3765\n *\n * @example\n * ```\n * {\n * \"type\": \"m.room.topic,\n * \"state_key\": \"\",\n * \"content\": {\n * \"topic\": \"All about **pizza**\",\n * \"m.topic\": [{\n * \"body\": \"All about **pizza**\",\n * \"mimetype\": \"text/plain\",\n * }, {\n * \"body\": \"All about pizza\",\n * \"mimetype\": \"text/html\",\n * }],\n * }\n * }\n * ```\n */\n\n/**\n * The event type for an m.topic event (in content)\n */\nexport const M_TOPIC = new UnstableValue(\"m.topic\", \"org.matrix.msc3765.topic\");\n\n/**\n * The event content for an m.topic event (in content)\n */\nexport type MTopicContent = IMessageRendering[];\n\n/**\n * The event definition for an m.topic event (in content)\n */\nexport type MTopicEvent = EitherAnd<{ [M_TOPIC.name]: MTopicContent }, { [M_TOPIC.altName]: MTopicContent }>;\n\n/**\n * The event content for an m.room.topic event\n */\nexport type MRoomTopicEventContent = { topic: string } & MTopicEvent;\n"],"mappings":";;;;;;AAkBA,IAAAA,gBAAA,GAAAC,OAAA;AAlBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACO,MAAMC,OAAO,GAAG,IAAIC,8BAAa,CAAC,SAAS,EAAE,0BAA0B,CAAC;;AAE/E;AACA;AACA;AAFAC,OAAA,CAAAF,OAAA,GAAAA,OAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts deleted file mode 100644 index 26d687e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import { IAuthData } from "../interactive-auth"; -/** - * Helper type to represent HTTP request body for a UIA enabled endpoint - */ -export type UIARequest = T & { - auth?: IAuthData; -}; -/** - * Helper type to represent HTTP response body for a UIA enabled endpoint - */ -export type UIAResponse = T | IAuthData; -//# sourceMappingURL=uia.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts.map deleted file mode 100644 index 2a0fb07..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"uia.d.ts","sourceRoot":"","sources":["../../src/@types/uia.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD;;GAEG;AACH,MAAM,MAAM,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG;IAC5B,IAAI,CAAC,EAAE,SAAS,CAAC;CACpB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js deleted file mode 100644 index e9e1da3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=uia.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js.map deleted file mode 100644 index 24cb166..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/@types/uia.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"uia.js","names":[],"sources":["../../src/@types/uia.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IAuthData } from \"../interactive-auth\";\n\n/**\n * Helper type to represent HTTP request body for a UIA enabled endpoint\n */\nexport type UIARequest = T & {\n auth?: IAuthData;\n};\n\n/**\n * Helper type to represent HTTP response body for a UIA enabled endpoint\n */\nexport type UIAResponse = T | IAuthData;\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts deleted file mode 100644 index 02703de..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts +++ /dev/null @@ -1,33 +0,0 @@ -import { Optional } from "matrix-events-sdk/lib/types"; -/** - * Represents a simple Matrix namespaced value. This will assume that if a stable prefix - * is provided that the stable prefix should be used when representing the identifier. - */ -export declare class NamespacedValue { - readonly stable?: S | null | undefined; - readonly unstable?: U | undefined; - constructor(stable: S, unstable: U); - constructor(stable: S, unstable?: U); - constructor(stable: null | undefined, unstable: U); - get name(): U | S; - get altName(): U | S | null | undefined; - get names(): (U | S)[]; - matches(val: string): boolean; - findIn(obj: any): Optional; - includedIn(arr: any[]): boolean; -} -export declare class ServerControlledNamespacedValue extends NamespacedValue { - private preferUnstable; - setPreferUnstable(preferUnstable: boolean): void; - get name(): U | S; -} -/** - * Represents a namespaced value which prioritizes the unstable value over the stable - * value. - */ -export declare class UnstableValue extends NamespacedValue { - constructor(stable: S, unstable: U); - get name(): U; - get altName(): S; -} -//# sourceMappingURL=NamespacedValue.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts.map deleted file mode 100644 index 782119d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"NamespacedValue.d.ts","sourceRoot":"","sources":["../src/NamespacedValue.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAEvD;;;GAGG;AACH,qBAAa,eAAe,CAAC,CAAC,SAAS,MAAM,EAAE,CAAC,SAAS,MAAM;aAMxB,MAAM,CAAC;aAA4B,QAAQ,CAAC;gBAH5D,MAAM,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC;gBACtB,MAAM,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC;gBACvB,MAAM,EAAE,IAAI,GAAG,SAAS,EAAE,QAAQ,EAAE,CAAC;IAOxD,IAAW,IAAI,IAAI,CAAC,GAAG,CAAC,CAKvB;IAED,IAAW,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,GAAG,SAAS,CAK7C;IAED,IAAW,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAK5B;IAEM,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAM7B,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAC;IAWhC,UAAU,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO;CAUzC;AAED,qBAAa,+BAA+B,CAAC,CAAC,SAAS,MAAM,EAAE,CAAC,SAAS,MAAM,CAAE,SAAQ,eAAe,CAAC,CAAC,EAAE,CAAC,CAAC;IAC1G,OAAO,CAAC,cAAc,CAAS;IAExB,iBAAiB,CAAC,cAAc,EAAE,OAAO,GAAG,IAAI;IAIvD,IAAW,IAAI,IAAI,CAAC,GAAG,CAAC,CAKvB;CACJ;AAED;;;GAGG;AACH,qBAAa,aAAa,CAAC,CAAC,SAAS,MAAM,EAAE,CAAC,SAAS,MAAM,CAAE,SAAQ,eAAe,CAAC,CAAC,EAAE,CAAC,CAAC;gBAErE,MAAM,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC;IAOzC,IAAW,IAAI,IAAI,CAAC,CAEnB;IAED,IAAW,OAAO,IAAI,CAAC,CAEtB;CACJ"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js deleted file mode 100644 index aa36c16..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js +++ /dev/null @@ -1,123 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UnstableValue = exports.ServerControlledNamespacedValue = exports.NamespacedValue = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2021 - 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Represents a simple Matrix namespaced value. This will assume that if a stable prefix - * is provided that the stable prefix should be used when representing the identifier. - */ -class NamespacedValue { - // Stable is optional, but one of the two parameters is required, hence the weird-looking types. - // Goal is to to have developers explicitly say there is no stable value (if applicable). - - constructor(stable, unstable) { - this.stable = stable; - this.unstable = unstable; - if (!this.unstable && !this.stable) { - throw new Error("One of stable or unstable values must be supplied"); - } - } - get name() { - if (this.stable) { - return this.stable; - } - return this.unstable; - } - get altName() { - if (!this.stable) { - return null; - } - return this.unstable; - } - get names() { - const names = [this.name]; - const altName = this.altName; - if (altName) names.push(altName); - return names; - } - matches(val) { - return this.name === val || this.altName === val; - } - - // this desperately wants https://github.com/microsoft/TypeScript/pull/26349 at the top level of the class - // so we can instantiate `NamespacedValue` as a default type for that namespace. - findIn(obj) { - let val = undefined; - if (this.name) { - val = obj === null || obj === void 0 ? void 0 : obj[this.name]; - } - if (!val && this.altName) { - val = obj === null || obj === void 0 ? void 0 : obj[this.altName]; - } - return val; - } - includedIn(arr) { - let included = false; - if (this.name) { - included = arr.includes(this.name); - } - if (!included && this.altName) { - included = arr.includes(this.altName); - } - return included; - } -} -exports.NamespacedValue = NamespacedValue; -class ServerControlledNamespacedValue extends NamespacedValue { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "preferUnstable", false); - } - setPreferUnstable(preferUnstable) { - this.preferUnstable = preferUnstable; - } - get name() { - if (this.stable && !this.preferUnstable) { - return this.stable; - } - return this.unstable; - } -} - -/** - * Represents a namespaced value which prioritizes the unstable value over the stable - * value. - */ -exports.ServerControlledNamespacedValue = ServerControlledNamespacedValue; -class UnstableValue extends NamespacedValue { - // Note: Constructor difference is that `unstable` is *required*. - constructor(stable, unstable) { - super(stable, unstable); - if (!this.unstable) { - throw new Error("Unstable value must be supplied"); - } - } - get name() { - return this.unstable; - } - get altName() { - return this.stable; - } -} -exports.UnstableValue = UnstableValue; -//# sourceMappingURL=NamespacedValue.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js.map deleted file mode 100644 index 1843c78..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/NamespacedValue.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"NamespacedValue.js","names":["NamespacedValue","constructor","stable","unstable","Error","name","altName","names","push","matches","val","findIn","obj","undefined","includedIn","arr","included","includes","exports","ServerControlledNamespacedValue","args","_defineProperty2","default","setPreferUnstable","preferUnstable","UnstableValue"],"sources":["../src/NamespacedValue.ts"],"sourcesContent":["/*\nCopyright 2021 - 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Optional } from \"matrix-events-sdk/lib/types\";\n\n/**\n * Represents a simple Matrix namespaced value. This will assume that if a stable prefix\n * is provided that the stable prefix should be used when representing the identifier.\n */\nexport class NamespacedValue {\n // Stable is optional, but one of the two parameters is required, hence the weird-looking types.\n // Goal is to to have developers explicitly say there is no stable value (if applicable).\n public constructor(stable: S, unstable: U);\n public constructor(stable: S, unstable?: U);\n public constructor(stable: null | undefined, unstable: U);\n public constructor(public readonly stable?: S | null, public readonly unstable?: U) {\n if (!this.unstable && !this.stable) {\n throw new Error(\"One of stable or unstable values must be supplied\");\n }\n }\n\n public get name(): U | S {\n if (this.stable) {\n return this.stable;\n }\n return this.unstable!;\n }\n\n public get altName(): U | S | null | undefined {\n if (!this.stable) {\n return null;\n }\n return this.unstable;\n }\n\n public get names(): (U | S)[] {\n const names = [this.name];\n const altName = this.altName;\n if (altName) names.push(altName);\n return names;\n }\n\n public matches(val: string): boolean {\n return this.name === val || this.altName === val;\n }\n\n // this desperately wants https://github.com/microsoft/TypeScript/pull/26349 at the top level of the class\n // so we can instantiate `NamespacedValue` as a default type for that namespace.\n public findIn(obj: any): Optional {\n let val: T | undefined = undefined;\n if (this.name) {\n val = obj?.[this.name];\n }\n if (!val && this.altName) {\n val = obj?.[this.altName];\n }\n return val;\n }\n\n public includedIn(arr: any[]): boolean {\n let included = false;\n if (this.name) {\n included = arr.includes(this.name);\n }\n if (!included && this.altName) {\n included = arr.includes(this.altName);\n }\n return included;\n }\n}\n\nexport class ServerControlledNamespacedValue extends NamespacedValue {\n private preferUnstable = false;\n\n public setPreferUnstable(preferUnstable: boolean): void {\n this.preferUnstable = preferUnstable;\n }\n\n public get name(): U | S {\n if (this.stable && !this.preferUnstable) {\n return this.stable;\n }\n return this.unstable!;\n }\n}\n\n/**\n * Represents a namespaced value which prioritizes the unstable value over the stable\n * value.\n */\nexport class UnstableValue extends NamespacedValue {\n // Note: Constructor difference is that `unstable` is *required*.\n public constructor(stable: S, unstable: U) {\n super(stable, unstable);\n if (!this.unstable) {\n throw new Error(\"Unstable value must be supplied\");\n }\n }\n\n public get name(): U {\n return this.unstable!;\n }\n\n public get altName(): S {\n return this.stable!;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts deleted file mode 100644 index bed9f5a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts +++ /dev/null @@ -1,16 +0,0 @@ -/// -import { EventEmitter } from "events"; -import { ListenerMap, TypedEventEmitter } from "./models/typed-event-emitter"; -export declare class ReEmitter { - private readonly target; - constructor(target: EventEmitter); - private reEmitters; - reEmit(source: EventEmitter, eventNames: string[]): void; - stopReEmitting(source: EventEmitter, eventNames: string[]): void; -} -export declare class TypedReEmitter> extends ReEmitter { - constructor(target: TypedEventEmitter); - reEmit(source: TypedEventEmitter, eventNames: T[]): void; - stopReEmitting(source: TypedEventEmitter, eventNames: T[]): void; -} -//# sourceMappingURL=ReEmitter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts.map deleted file mode 100644 index 9b957a5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ReEmitter.d.ts","sourceRoot":"","sources":["../src/ReEmitter.ts"],"names":[],"mappings":";AAmBA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAE9E,qBAAa,SAAS;IACC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,YAAY;IAGxD,OAAO,CAAC,UAAU,CAAkE;IAE7E,MAAM,CAAC,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI;IA8BxD,cAAc,CAAC,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI;CAW1E;AAED,qBAAa,cAAc,CAAC,MAAM,SAAS,MAAM,EAAE,SAAS,SAAS,WAAW,CAAC,MAAM,CAAC,CAAE,SAAQ,SAAS;gBACpF,MAAM,EAAE,iBAAiB,CAAC,MAAM,EAAE,SAAS,CAAC;IAIxD,MAAM,CAAC,eAAe,SAAS,MAAM,EAAE,CAAC,SAAS,MAAM,GAAG,eAAe,EAC5E,MAAM,EAAE,iBAAiB,CAAC,eAAe,EAAE,GAAG,CAAC,EAC/C,UAAU,EAAE,CAAC,EAAE,GAChB,IAAI;IAIA,cAAc,CAAC,eAAe,SAAS,MAAM,EAAE,CAAC,SAAS,MAAM,GAAG,eAAe,EACpF,MAAM,EAAE,iBAAiB,CAAC,eAAe,EAAE,GAAG,CAAC,EAC/C,UAAU,EAAE,CAAC,EAAE,GAChB,IAAI;CAGV"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js deleted file mode 100644 index 8122797..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js +++ /dev/null @@ -1,89 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TypedReEmitter = exports.ReEmitter = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2015, 2016 OpenMarket Ltd -Copyright 2017 Vector Creations Ltd -Copyright 2017 New Vector Ltd - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// eslint-disable-next-line no-restricted-imports - -class ReEmitter { - constructor(target) { - this.target = target; - (0, _defineProperty2.default)(this, "reEmitters", new Map()); - } - - // Map from emitter to event name to re-emitter - - reEmit(source, eventNames) { - let reEmittersByEvent = this.reEmitters.get(source); - if (!reEmittersByEvent) { - reEmittersByEvent = new Map(); - this.reEmitters.set(source, reEmittersByEvent); - } - for (const eventName of eventNames) { - // We include the source as the last argument for event handlers which may need it, - // such as read receipt listeners on the client class which won't have the context - // of the room. - const forSource = (...args) => { - // EventEmitter special cases 'error' to make the emit function throw if no - // handler is attached, which sort of makes sense for making sure that something - // handles an error, but for re-emitting, there could be a listener on the original - // source object so the test doesn't really work. We *could* try to replicate the - // same logic and throw if there is no listener on either the source or the target, - // but this behaviour is fairly undesireable for us anyway: the main place we throw - // 'error' events is for calls, where error events are usually emitted some time - // later by a different part of the code where 'emit' throwing because the app hasn't - // added an error handler isn't terribly helpful. (A better fix in retrospect may - // have been to just avoid using the event name 'error', but backwards compat...) - if (eventName === "error" && this.target.listenerCount("error") === 0) return; - this.target.emit(eventName, ...args, source); - }; - source.on(eventName, forSource); - reEmittersByEvent.set(eventName, forSource); - } - } - stopReEmitting(source, eventNames) { - const reEmittersByEvent = this.reEmitters.get(source); - if (!reEmittersByEvent) return; // We were never re-emitting these events in the first place - - for (const eventName of eventNames) { - source.off(eventName, reEmittersByEvent.get(eventName)); - reEmittersByEvent.delete(eventName); - } - if (reEmittersByEvent.size === 0) this.reEmitters.delete(source); - } -} -exports.ReEmitter = ReEmitter; -class TypedReEmitter extends ReEmitter { - constructor(target) { - super(target); - } - reEmit(source, eventNames) { - super.reEmit(source, eventNames); - } - stopReEmitting(source, eventNames) { - super.stopReEmitting(source, eventNames); - } -} -exports.TypedReEmitter = TypedReEmitter; -//# sourceMappingURL=ReEmitter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js.map deleted file mode 100644 index 0b63215..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ReEmitter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ReEmitter.js","names":["ReEmitter","constructor","target","_defineProperty2","default","Map","reEmit","source","eventNames","reEmittersByEvent","reEmitters","get","set","eventName","forSource","args","listenerCount","emit","on","stopReEmitting","off","delete","size","exports","TypedReEmitter"],"sources":["../src/ReEmitter.ts"],"sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\nCopyright 2017 Vector Creations Ltd\nCopyright 2017 New Vector Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n// eslint-disable-next-line no-restricted-imports\nimport { EventEmitter } from \"events\";\n\nimport { ListenerMap, TypedEventEmitter } from \"./models/typed-event-emitter\";\n\nexport class ReEmitter {\n public constructor(private readonly target: EventEmitter) {}\n\n // Map from emitter to event name to re-emitter\n private reEmitters = new Map void>>();\n\n public reEmit(source: EventEmitter, eventNames: string[]): void {\n let reEmittersByEvent = this.reEmitters.get(source);\n if (!reEmittersByEvent) {\n reEmittersByEvent = new Map();\n this.reEmitters.set(source, reEmittersByEvent);\n }\n\n for (const eventName of eventNames) {\n // We include the source as the last argument for event handlers which may need it,\n // such as read receipt listeners on the client class which won't have the context\n // of the room.\n const forSource = (...args: any[]): void => {\n // EventEmitter special cases 'error' to make the emit function throw if no\n // handler is attached, which sort of makes sense for making sure that something\n // handles an error, but for re-emitting, there could be a listener on the original\n // source object so the test doesn't really work. We *could* try to replicate the\n // same logic and throw if there is no listener on either the source or the target,\n // but this behaviour is fairly undesireable for us anyway: the main place we throw\n // 'error' events is for calls, where error events are usually emitted some time\n // later by a different part of the code where 'emit' throwing because the app hasn't\n // added an error handler isn't terribly helpful. (A better fix in retrospect may\n // have been to just avoid using the event name 'error', but backwards compat...)\n if (eventName === \"error\" && this.target.listenerCount(\"error\") === 0) return;\n this.target.emit(eventName, ...args, source);\n };\n source.on(eventName, forSource);\n reEmittersByEvent.set(eventName, forSource);\n }\n }\n\n public stopReEmitting(source: EventEmitter, eventNames: string[]): void {\n const reEmittersByEvent = this.reEmitters.get(source);\n if (!reEmittersByEvent) return; // We were never re-emitting these events in the first place\n\n for (const eventName of eventNames) {\n source.off(eventName, reEmittersByEvent.get(eventName)!);\n reEmittersByEvent.delete(eventName);\n }\n\n if (reEmittersByEvent.size === 0) this.reEmitters.delete(source);\n }\n}\n\nexport class TypedReEmitter> extends ReEmitter {\n public constructor(target: TypedEventEmitter) {\n super(target);\n }\n\n public reEmit(\n source: TypedEventEmitter,\n eventNames: T[],\n ): void {\n super.reEmit(source, eventNames);\n }\n\n public stopReEmitting(\n source: TypedEventEmitter,\n eventNames: T[],\n ): void {\n super.stopReEmitting(source, eventNames);\n }\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAKO,MAAMA,SAAS,CAAC;EACZC,WAAWA,CAAkBC,MAAoB,EAAE;IAAA,KAAtBA,MAAoB,GAApBA,MAAoB;IAAA,IAAAC,gBAAA,CAAAC,OAAA,sBAGnC,IAAIC,GAAG,EAAuD;EAHxB;;EAE3D;;EAGOC,MAAMA,CAACC,MAAoB,EAAEC,UAAoB,EAAQ;IAC5D,IAAIC,iBAAiB,GAAG,IAAI,CAACC,UAAU,CAACC,GAAG,CAACJ,MAAM,CAAC;IACnD,IAAI,CAACE,iBAAiB,EAAE;MACpBA,iBAAiB,GAAG,IAAIJ,GAAG,EAAE;MAC7B,IAAI,CAACK,UAAU,CAACE,GAAG,CAACL,MAAM,EAAEE,iBAAiB,CAAC;IAClD;IAEA,KAAK,MAAMI,SAAS,IAAIL,UAAU,EAAE;MAChC;MACA;MACA;MACA,MAAMM,SAAS,GAAGA,CAAC,GAAGC,IAAW,KAAW;QACxC;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,IAAIF,SAAS,KAAK,OAAO,IAAI,IAAI,CAACX,MAAM,CAACc,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;QACvE,IAAI,CAACd,MAAM,CAACe,IAAI,CAACJ,SAAS,EAAE,GAAGE,IAAI,EAAER,MAAM,CAAC;MAChD,CAAC;MACDA,MAAM,CAACW,EAAE,CAACL,SAAS,EAAEC,SAAS,CAAC;MAC/BL,iBAAiB,CAACG,GAAG,CAACC,SAAS,EAAEC,SAAS,CAAC;IAC/C;EACJ;EAEOK,cAAcA,CAACZ,MAAoB,EAAEC,UAAoB,EAAQ;IACpE,MAAMC,iBAAiB,GAAG,IAAI,CAACC,UAAU,CAACC,GAAG,CAACJ,MAAM,CAAC;IACrD,IAAI,CAACE,iBAAiB,EAAE,OAAO,CAAC;;IAEhC,KAAK,MAAMI,SAAS,IAAIL,UAAU,EAAE;MAChCD,MAAM,CAACa,GAAG,CAACP,SAAS,EAAEJ,iBAAiB,CAACE,GAAG,CAACE,SAAS,CAAC,CAAE;MACxDJ,iBAAiB,CAACY,MAAM,CAACR,SAAS,CAAC;IACvC;IAEA,IAAIJ,iBAAiB,CAACa,IAAI,KAAK,CAAC,EAAE,IAAI,CAACZ,UAAU,CAACW,MAAM,CAACd,MAAM,CAAC;EACpE;AACJ;AAACgB,OAAA,CAAAvB,SAAA,GAAAA,SAAA;AAEM,MAAMwB,cAAc,SAAuExB,SAAS,CAAC;EACjGC,WAAWA,CAACC,MAA4C,EAAE;IAC7D,KAAK,CAACA,MAAM,CAAC;EACjB;EAEOI,MAAMA,CACTC,MAA+C,EAC/CC,UAAe,EACX;IACJ,KAAK,CAACF,MAAM,CAACC,MAAM,EAAEC,UAAU,CAAC;EACpC;EAEOW,cAAcA,CACjBZ,MAA+C,EAC/CC,UAAe,EACX;IACJ,KAAK,CAACW,cAAc,CAACZ,MAAM,EAAEC,UAAU,CAAC;EAC5C;AACJ;AAACe,OAAA,CAAAC,cAAA,GAAAA,cAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts deleted file mode 100644 index d90e95c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts +++ /dev/null @@ -1,28 +0,0 @@ -import { MatrixClient } from "./client"; -import { ToDeviceBatch } from "./models/ToDeviceMessage"; -/** - * Maintains a queue of outgoing to-device messages, sending them - * as soon as the homeserver is reachable. - */ -export declare class ToDeviceMessageQueue { - private client; - private sending; - private running; - private retryTimeout; - private retryAttempts; - constructor(client: MatrixClient); - start(): void; - stop(): void; - queueBatch(batch: ToDeviceBatch): Promise; - sendQueue: () => Promise; - /** - * Attempts to send a batch of to-device messages. - */ - private sendBatch; - /** - * Listen to sync state changes and automatically resend any pending events - * once syncing is resumed - */ - private onResumedSync; -} -//# sourceMappingURL=ToDeviceMessageQueue.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts.map deleted file mode 100644 index b046c21..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ToDeviceMessageQueue.d.ts","sourceRoot":"","sources":["../src/ToDeviceMessageQueue.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,YAAY,EAAe,MAAM,UAAU,CAAC;AAErD,OAAO,EAAwB,aAAa,EAA2C,MAAM,0BAA0B,CAAC;AAOxH;;;GAGG;AACH,qBAAa,oBAAoB;IAMV,OAAO,CAAC,MAAM;IALjC,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,OAAO,CAAQ;IACvB,OAAO,CAAC,YAAY,CAA8C;IAClE,OAAO,CAAC,aAAa,CAAK;gBAEC,MAAM,EAAE,YAAY;IAExC,KAAK,IAAI,IAAI;IAMb,IAAI,IAAI,IAAI;IAON,UAAU,CAAC,KAAK,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAsBrD,SAAS,QAAa,QAAQ,IAAI,CAAC,CA6CxC;IAEF;;OAEG;YACW,SAAS;IAavB;;;OAGG;IACH,OAAO,CAAC,aAAa,CAKnB;CACL"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js deleted file mode 100644 index 507e8f4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js +++ /dev/null @@ -1,136 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ToDeviceMessageQueue = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _event = require("./@types/event"); -var _logger = require("./logger"); -var _client = require("./client"); -var _scheduler = require("./scheduler"); -var _sync = require("./sync"); -var _utils = require("./utils"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const MAX_BATCH_SIZE = 20; - -/** - * Maintains a queue of outgoing to-device messages, sending them - * as soon as the homeserver is reachable. - */ -class ToDeviceMessageQueue { - constructor(client) { - this.client = client; - (0, _defineProperty2.default)(this, "sending", false); - (0, _defineProperty2.default)(this, "running", true); - (0, _defineProperty2.default)(this, "retryTimeout", null); - (0, _defineProperty2.default)(this, "retryAttempts", 0); - (0, _defineProperty2.default)(this, "sendQueue", async () => { - if (this.retryTimeout !== null) clearTimeout(this.retryTimeout); - this.retryTimeout = null; - if (this.sending || !this.running) return; - _logger.logger.debug("Attempting to send queued to-device messages"); - this.sending = true; - let headBatch; - try { - while (this.running) { - headBatch = await this.client.store.getOldestToDeviceBatch(); - if (headBatch === null) break; - await this.sendBatch(headBatch); - await this.client.store.removeToDeviceBatch(headBatch.id); - this.retryAttempts = 0; - } - - // Make sure we're still running after the async tasks: if not, stop. - if (!this.running) return; - _logger.logger.debug("All queued to-device messages sent"); - } catch (e) { - ++this.retryAttempts; - // eslint-disable-next-line @typescript-eslint/naming-convention - // eslint-disable-next-line new-cap - const retryDelay = _scheduler.MatrixScheduler.RETRY_BACKOFF_RATELIMIT(null, this.retryAttempts, e); - if (retryDelay === -1) { - // the scheduler function doesn't differentiate between fatal errors and just getting - // bored and giving up for now - if (Math.floor(e.httpStatus / 100) === 4) { - _logger.logger.error("Fatal error when sending to-device message - dropping to-device batch!", e); - await this.client.store.removeToDeviceBatch(headBatch.id); - } else { - _logger.logger.info("Automatic retry limit reached for to-device messages."); - } - return; - } - _logger.logger.info(`Failed to send batch of to-device messages. Will retry in ${retryDelay}ms`, e); - this.retryTimeout = setTimeout(this.sendQueue, retryDelay); - } finally { - this.sending = false; - } - }); - (0, _defineProperty2.default)(this, "onResumedSync", (state, oldState) => { - if (state === _sync.SyncState.Syncing && oldState !== _sync.SyncState.Syncing) { - _logger.logger.info(`Resuming queue after resumed sync`); - this.sendQueue(); - } - }); - } - start() { - this.running = true; - this.sendQueue(); - this.client.on(_client.ClientEvent.Sync, this.onResumedSync); - } - stop() { - this.running = false; - if (this.retryTimeout !== null) clearTimeout(this.retryTimeout); - this.retryTimeout = null; - this.client.removeListener(_client.ClientEvent.Sync, this.onResumedSync); - } - async queueBatch(batch) { - const batches = []; - for (let i = 0; i < batch.batch.length; i += MAX_BATCH_SIZE) { - const batchWithTxnId = { - eventType: batch.eventType, - batch: batch.batch.slice(i, i + MAX_BATCH_SIZE), - txnId: this.client.makeTxnId() - }; - batches.push(batchWithTxnId); - const msgmap = batchWithTxnId.batch.map(msg => `${msg.userId}/${msg.deviceId} (msgid ${msg.payload[_event.ToDeviceMessageId]})`); - _logger.logger.info(`Enqueuing batch of to-device messages. type=${batch.eventType} txnid=${batchWithTxnId.txnId}`, msgmap); - } - await this.client.store.saveToDeviceBatches(batches); - this.sendQueue(); - } - /** - * Attempts to send a batch of to-device messages. - */ - async sendBatch(batch) { - const contentMap = new _utils.MapWithDefault(() => new Map()); - for (const item of batch.batch) { - contentMap.getOrCreate(item.userId).set(item.deviceId, item.payload); - } - _logger.logger.info(`Sending batch of ${batch.batch.length} to-device messages with ID ${batch.id} and txnId ${batch.txnId}`); - await this.client.sendToDevice(batch.eventType, contentMap, batch.txnId); - } - - /** - * Listen to sync state changes and automatically resend any pending events - * once syncing is resumed - */ -} -exports.ToDeviceMessageQueue = ToDeviceMessageQueue; -//# sourceMappingURL=ToDeviceMessageQueue.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js.map deleted file mode 100644 index f3369e4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/ToDeviceMessageQueue.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ToDeviceMessageQueue.js","names":["_event","require","_logger","_client","_scheduler","_sync","_utils","MAX_BATCH_SIZE","ToDeviceMessageQueue","constructor","client","_defineProperty2","default","retryTimeout","clearTimeout","sending","running","logger","debug","headBatch","store","getOldestToDeviceBatch","sendBatch","removeToDeviceBatch","id","retryAttempts","e","retryDelay","MatrixScheduler","RETRY_BACKOFF_RATELIMIT","Math","floor","httpStatus","error","info","setTimeout","sendQueue","state","oldState","SyncState","Syncing","start","on","ClientEvent","Sync","onResumedSync","stop","removeListener","queueBatch","batch","batches","i","length","batchWithTxnId","eventType","slice","txnId","makeTxnId","push","msgmap","map","msg","userId","deviceId","payload","ToDeviceMessageId","saveToDeviceBatches","contentMap","MapWithDefault","Map","item","getOrCreate","set","sendToDevice","exports"],"sources":["../src/ToDeviceMessageQueue.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ToDeviceMessageId } from \"./@types/event\";\nimport { logger } from \"./logger\";\nimport { MatrixClient, ClientEvent } from \"./client\";\nimport { MatrixError } from \"./http-api\";\nimport { IndexedToDeviceBatch, ToDeviceBatch, ToDeviceBatchWithTxnId, ToDevicePayload } from \"./models/ToDeviceMessage\";\nimport { MatrixScheduler } from \"./scheduler\";\nimport { SyncState } from \"./sync\";\nimport { MapWithDefault } from \"./utils\";\n\nconst MAX_BATCH_SIZE = 20;\n\n/**\n * Maintains a queue of outgoing to-device messages, sending them\n * as soon as the homeserver is reachable.\n */\nexport class ToDeviceMessageQueue {\n private sending = false;\n private running = true;\n private retryTimeout: ReturnType | null = null;\n private retryAttempts = 0;\n\n public constructor(private client: MatrixClient) {}\n\n public start(): void {\n this.running = true;\n this.sendQueue();\n this.client.on(ClientEvent.Sync, this.onResumedSync);\n }\n\n public stop(): void {\n this.running = false;\n if (this.retryTimeout !== null) clearTimeout(this.retryTimeout);\n this.retryTimeout = null;\n this.client.removeListener(ClientEvent.Sync, this.onResumedSync);\n }\n\n public async queueBatch(batch: ToDeviceBatch): Promise {\n const batches: ToDeviceBatchWithTxnId[] = [];\n for (let i = 0; i < batch.batch.length; i += MAX_BATCH_SIZE) {\n const batchWithTxnId = {\n eventType: batch.eventType,\n batch: batch.batch.slice(i, i + MAX_BATCH_SIZE),\n txnId: this.client.makeTxnId(),\n };\n batches.push(batchWithTxnId);\n const msgmap = batchWithTxnId.batch.map(\n (msg) => `${msg.userId}/${msg.deviceId} (msgid ${msg.payload[ToDeviceMessageId]})`,\n );\n logger.info(\n `Enqueuing batch of to-device messages. type=${batch.eventType} txnid=${batchWithTxnId.txnId}`,\n msgmap,\n );\n }\n\n await this.client.store.saveToDeviceBatches(batches);\n this.sendQueue();\n }\n\n public sendQueue = async (): Promise => {\n if (this.retryTimeout !== null) clearTimeout(this.retryTimeout);\n this.retryTimeout = null;\n\n if (this.sending || !this.running) return;\n\n logger.debug(\"Attempting to send queued to-device messages\");\n\n this.sending = true;\n let headBatch: IndexedToDeviceBatch | null;\n try {\n while (this.running) {\n headBatch = await this.client.store.getOldestToDeviceBatch();\n if (headBatch === null) break;\n await this.sendBatch(headBatch);\n await this.client.store.removeToDeviceBatch(headBatch.id);\n this.retryAttempts = 0;\n }\n\n // Make sure we're still running after the async tasks: if not, stop.\n if (!this.running) return;\n\n logger.debug(\"All queued to-device messages sent\");\n } catch (e) {\n ++this.retryAttempts;\n // eslint-disable-next-line @typescript-eslint/naming-convention\n // eslint-disable-next-line new-cap\n const retryDelay = MatrixScheduler.RETRY_BACKOFF_RATELIMIT(null, this.retryAttempts, e);\n if (retryDelay === -1) {\n // the scheduler function doesn't differentiate between fatal errors and just getting\n // bored and giving up for now\n if (Math.floor((e).httpStatus! / 100) === 4) {\n logger.error(\"Fatal error when sending to-device message - dropping to-device batch!\", e);\n await this.client.store.removeToDeviceBatch(headBatch!.id);\n } else {\n logger.info(\"Automatic retry limit reached for to-device messages.\");\n }\n return;\n }\n\n logger.info(`Failed to send batch of to-device messages. Will retry in ${retryDelay}ms`, e);\n this.retryTimeout = setTimeout(this.sendQueue, retryDelay);\n } finally {\n this.sending = false;\n }\n };\n\n /**\n * Attempts to send a batch of to-device messages.\n */\n private async sendBatch(batch: IndexedToDeviceBatch): Promise {\n const contentMap: MapWithDefault> = new MapWithDefault(() => new Map());\n for (const item of batch.batch) {\n contentMap.getOrCreate(item.userId).set(item.deviceId, item.payload);\n }\n\n logger.info(\n `Sending batch of ${batch.batch.length} to-device messages with ID ${batch.id} and txnId ${batch.txnId}`,\n );\n\n await this.client.sendToDevice(batch.eventType, contentMap, batch.txnId);\n }\n\n /**\n * Listen to sync state changes and automatically resend any pending events\n * once syncing is resumed\n */\n private onResumedSync = (state: SyncState | null, oldState: SyncState | null): void => {\n if (state === SyncState.Syncing && oldState !== SyncState.Syncing) {\n logger.info(`Resuming queue after resumed sync`);\n this.sendQueue();\n }\n };\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts deleted file mode 100644 index 295bea1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts +++ /dev/null @@ -1,132 +0,0 @@ -import { IClientWellKnown, IWellKnownConfig } from "./client"; -export declare enum AutoDiscoveryAction { - SUCCESS = "SUCCESS", - IGNORE = "IGNORE", - PROMPT = "PROMPT", - FAIL_PROMPT = "FAIL_PROMPT", - FAIL_ERROR = "FAIL_ERROR" -} -declare enum AutoDiscoveryError { - Invalid = "Invalid homeserver discovery response", - GenericFailure = "Failed to get autodiscovery configuration from server", - InvalidHsBaseUrl = "Invalid base_url for m.homeserver", - InvalidHomeserver = "Homeserver URL does not appear to be a valid Matrix homeserver", - InvalidIsBaseUrl = "Invalid base_url for m.identity_server", - InvalidIdentityServer = "Identity server URL does not appear to be a valid identity server", - InvalidIs = "Invalid identity server discovery response", - MissingWellknown = "No .well-known JSON file found", - InvalidJson = "Invalid JSON" -} -interface WellKnownConfig extends Omit { - state: AutoDiscoveryAction; - error?: IWellKnownConfig["error"] | null; -} -export interface ClientConfig extends Omit { - "m.homeserver": WellKnownConfig; - "m.identity_server": WellKnownConfig; -} -/** - * Utilities for automatically discovery resources, such as homeservers - * for users to log in to. - */ -export declare class AutoDiscovery { - static readonly ERROR_INVALID = AutoDiscoveryError.Invalid; - static readonly ERROR_GENERIC_FAILURE = AutoDiscoveryError.GenericFailure; - static readonly ERROR_INVALID_HS_BASE_URL = AutoDiscoveryError.InvalidHsBaseUrl; - static readonly ERROR_INVALID_HOMESERVER = AutoDiscoveryError.InvalidHomeserver; - static readonly ERROR_INVALID_IS_BASE_URL = AutoDiscoveryError.InvalidIsBaseUrl; - static readonly ERROR_INVALID_IDENTITY_SERVER = AutoDiscoveryError.InvalidIdentityServer; - static readonly ERROR_INVALID_IS = AutoDiscoveryError.InvalidIs; - static readonly ERROR_MISSING_WELLKNOWN = AutoDiscoveryError.MissingWellknown; - static readonly ERROR_INVALID_JSON = AutoDiscoveryError.InvalidJson; - static readonly ALL_ERRORS: string[]; - /** - * The auto discovery failed. The client is expected to communicate - * the error to the user and refuse logging in. - */ - static readonly FAIL_ERROR = AutoDiscoveryAction.FAIL_ERROR; - /** - * The auto discovery failed, however the client may still recover - * from the problem. The client is recommended to that the same - * action it would for PROMPT while also warning the user about - * what went wrong. The client may also treat this the same as - * a FAIL_ERROR state. - */ - static readonly FAIL_PROMPT = AutoDiscoveryAction.FAIL_PROMPT; - /** - * The auto discovery didn't fail but did not find anything of - * interest. The client is expected to prompt the user for more - * information, or fail if it prefers. - */ - static readonly PROMPT = AutoDiscoveryAction.PROMPT; - /** - * The auto discovery was successful. - */ - static readonly SUCCESS = AutoDiscoveryAction.SUCCESS; - /** - * Validates and verifies client configuration information for purposes - * of logging in. Such information includes the homeserver URL - * and identity server URL the client would want. Additional details - * may also be included, and will be transparently brought into the - * response object unaltered. - * @param wellknown - The configuration object itself, as returned - * by the .well-known auto-discovery endpoint. - * @returns Promise which resolves to the verified - * configuration, which may include error states. Rejects on unexpected - * failure, not when verification fails. - */ - static fromDiscoveryConfig(wellknown: IClientWellKnown): Promise; - /** - * Attempts to automatically discover client configuration information - * prior to logging in. Such information includes the homeserver URL - * and identity server URL the client would want. Additional details - * may also be discovered, and will be transparently included in the - * response object unaltered. - * @param domain - The homeserver domain to perform discovery - * on. For example, "matrix.org". - * @returns Promise which resolves to the discovered - * configuration, which may include error states. Rejects on unexpected - * failure, not when discovery fails. - */ - static findClientConfig(domain: string): Promise; - /** - * Gets the raw discovery client configuration for the given domain name. - * Should only be used if there's no validation to be done on the resulting - * object, otherwise use findClientConfig(). - * @param domain - The domain to get the client config for. - * @returns Promise which resolves to the domain's client config. Can - * be an empty object. - */ - static getRawClientConfig(domain?: string): Promise; - /** - * Sanitizes a given URL to ensure it is either an HTTP or HTTP URL and - * is suitable for the requirements laid out by .well-known auto discovery. - * If valid, the URL will also be stripped of any trailing slashes. - * @param url - The potentially invalid URL to sanitize. - * @returns The sanitized URL or a falsey value if the URL is invalid. - * @internal - */ - private static sanitizeWellKnownUrl; - private static fetch; - private static fetchFn?; - static setFetchFn(fetchFn: typeof global.fetch): void; - /** - * Fetches a JSON object from a given URL, as expected by all .well-known - * related lookups. If the server gives a 404 then the `action` will be - * IGNORE. If the server returns something that isn't JSON, the `action` - * will be FAIL_PROMPT. For any other failure the `action` will be FAIL_PROMPT. - * - * The returned object will be a result of the call in object form with - * the following properties: - * raw: The JSON object returned by the server. - * action: One of SUCCESS, IGNORE, or FAIL_PROMPT. - * reason: Relatively human-readable description of what went wrong. - * error: The actual Error, if one exists. - * @param url - The URL to fetch a JSON object from. - * @returns Promise which resolves to the returned state. - * @internal - */ - private static fetchWellKnownObject; -} -export {}; -//# sourceMappingURL=autodiscovery.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts.map deleted file mode 100644 index 363a437..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"autodiscovery.d.ts","sourceRoot":"","sources":["../src/autodiscovery.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAO9D,oBAAY,mBAAmB;IAC3B,OAAO,YAAY;IACnB,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,WAAW,gBAAgB;IAC3B,UAAU,eAAe;CAC5B;AAED,aAAK,kBAAkB;IACnB,OAAO,0CAA0C;IACjD,cAAc,0DAA0D;IACxE,gBAAgB,sCAAsC;IACtD,iBAAiB,mEAAmE;IACpF,gBAAgB,2CAA2C;IAC3D,qBAAqB,sEAAsE;IAC3F,SAAS,+CAA+C;IACxD,gBAAgB,mCAAmC;IACnD,WAAW,iBAAiB;CAC/B;AAED,UAAU,eAAgB,SAAQ,IAAI,CAAC,gBAAgB,EAAE,OAAO,CAAC;IAC7D,KAAK,EAAE,mBAAmB,CAAC;IAC3B,KAAK,CAAC,EAAE,gBAAgB,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC;CAC5C;AAED,MAAM,WAAW,YAAa,SAAQ,IAAI,CAAC,gBAAgB,EAAE,cAAc,GAAG,mBAAmB,CAAC;IAC9F,cAAc,EAAE,eAAe,CAAC;IAChC,mBAAmB,EAAE,eAAe,CAAC;CACxC;AAED;;;GAGG;AACH,qBAAa,aAAa;IAMtB,gBAAuB,aAAa,8BAA8B;IAElE,gBAAuB,qBAAqB,qCAAqC;IAEjF,gBAAuB,yBAAyB,uCAAuC;IAEvF,gBAAuB,wBAAwB,wCAAwC;IAEvF,gBAAuB,yBAAyB,uCAAuC;IAEvF,gBAAuB,6BAA6B,4CAA4C;IAEhG,gBAAuB,gBAAgB,gCAAgC;IAEvE,gBAAuB,uBAAuB,uCAAuC;IAErF,gBAAuB,kBAAkB,kCAAkC;IAE3E,gBAAuB,UAAU,WAAmC;IAEpE;;;OAGG;IACH,gBAAuB,UAAU,kCAAkC;IAEnE;;;;;;OAMG;IACH,gBAAuB,WAAW,mCAAmC;IAErE;;;;OAIG;IACH,gBAAuB,MAAM,8BAA8B;IAE3D;;OAEG;IACH,gBAAuB,OAAO,+BAA+B;IAE7D;;;;;;;;;;;OAWG;WACiB,mBAAmB,CAAC,SAAS,EAAE,gBAAgB,GAAG,OAAO,CAAC,YAAY,CAAC;IA2I3F;;;;;;;;;;;OAWG;WACiB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IA0D3E;;;;;;;OAOG;WACiB,kBAAkB,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAUlF;;;;;;;OAOG;IACH,OAAO,CAAC,MAAM,CAAC,oBAAoB;IA2BnC,OAAO,CAAC,MAAM,CAAC,KAAK;IAOpB,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAsB;WAE/B,UAAU,CAAC,OAAO,EAAE,OAAO,MAAM,CAAC,KAAK,GAAG,IAAI;IAI5D;;;;;;;;;;;;;;;OAeG;mBACkB,oBAAoB;CAyD5C"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js deleted file mode 100644 index 076c8d0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js +++ /dev/null @@ -1,437 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.AutoDiscoveryAction = exports.AutoDiscovery = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("./logger"); -var _httpApi = require("./http-api"); -/* -Copyright 2018 New Vector Ltd -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -// Dev note: Auto discovery is part of the spec. -// See: https://matrix.org/docs/spec/client_server/r0.4.0.html#server-discovery -let AutoDiscoveryAction; -exports.AutoDiscoveryAction = AutoDiscoveryAction; -(function (AutoDiscoveryAction) { - AutoDiscoveryAction["SUCCESS"] = "SUCCESS"; - AutoDiscoveryAction["IGNORE"] = "IGNORE"; - AutoDiscoveryAction["PROMPT"] = "PROMPT"; - AutoDiscoveryAction["FAIL_PROMPT"] = "FAIL_PROMPT"; - AutoDiscoveryAction["FAIL_ERROR"] = "FAIL_ERROR"; -})(AutoDiscoveryAction || (exports.AutoDiscoveryAction = AutoDiscoveryAction = {})); -var AutoDiscoveryError; -(function (AutoDiscoveryError) { - AutoDiscoveryError["Invalid"] = "Invalid homeserver discovery response"; - AutoDiscoveryError["GenericFailure"] = "Failed to get autodiscovery configuration from server"; - AutoDiscoveryError["InvalidHsBaseUrl"] = "Invalid base_url for m.homeserver"; - AutoDiscoveryError["InvalidHomeserver"] = "Homeserver URL does not appear to be a valid Matrix homeserver"; - AutoDiscoveryError["InvalidIsBaseUrl"] = "Invalid base_url for m.identity_server"; - AutoDiscoveryError["InvalidIdentityServer"] = "Identity server URL does not appear to be a valid identity server"; - AutoDiscoveryError["InvalidIs"] = "Invalid identity server discovery response"; - AutoDiscoveryError["MissingWellknown"] = "No .well-known JSON file found"; - AutoDiscoveryError["InvalidJson"] = "Invalid JSON"; -})(AutoDiscoveryError || (AutoDiscoveryError = {})); -/** - * Utilities for automatically discovery resources, such as homeservers - * for users to log in to. - */ -class AutoDiscovery { - // Dev note: the constants defined here are related to but not - // exactly the same as those in the spec. This is to hopefully - // translate the meaning of the states in the spec, but also - // support our own if needed. - - /** - * The auto discovery failed. The client is expected to communicate - * the error to the user and refuse logging in. - */ - - /** - * The auto discovery failed, however the client may still recover - * from the problem. The client is recommended to that the same - * action it would for PROMPT while also warning the user about - * what went wrong. The client may also treat this the same as - * a FAIL_ERROR state. - */ - - /** - * The auto discovery didn't fail but did not find anything of - * interest. The client is expected to prompt the user for more - * information, or fail if it prefers. - */ - - /** - * The auto discovery was successful. - */ - - /** - * Validates and verifies client configuration information for purposes - * of logging in. Such information includes the homeserver URL - * and identity server URL the client would want. Additional details - * may also be included, and will be transparently brought into the - * response object unaltered. - * @param wellknown - The configuration object itself, as returned - * by the .well-known auto-discovery endpoint. - * @returns Promise which resolves to the verified - * configuration, which may include error states. Rejects on unexpected - * failure, not when verification fails. - */ - static async fromDiscoveryConfig(wellknown) { - var _hsVersions$raw; - // Step 1 is to get the config, which is provided to us here. - - // We default to an error state to make the first few checks easier to - // write. We'll update the properties of this object over the duration - // of this function. - const clientConfig = { - "m.homeserver": { - state: AutoDiscovery.FAIL_ERROR, - error: AutoDiscovery.ERROR_INVALID, - base_url: null - }, - "m.identity_server": { - // Technically, we don't have a problem with the identity server - // config at this point. - state: AutoDiscovery.PROMPT, - error: null, - base_url: null - } - }; - if (!wellknown || !wellknown["m.homeserver"]) { - _logger.logger.error("No m.homeserver key in config"); - clientConfig["m.homeserver"].state = AutoDiscovery.FAIL_PROMPT; - clientConfig["m.homeserver"].error = AutoDiscovery.ERROR_INVALID; - return Promise.resolve(clientConfig); - } - if (!wellknown["m.homeserver"]["base_url"]) { - _logger.logger.error("No m.homeserver base_url in config"); - clientConfig["m.homeserver"].state = AutoDiscovery.FAIL_PROMPT; - clientConfig["m.homeserver"].error = AutoDiscovery.ERROR_INVALID_HS_BASE_URL; - return Promise.resolve(clientConfig); - } - - // Step 2: Make sure the homeserver URL is valid *looking*. We'll make - // sure it points to a homeserver in Step 3. - const hsUrl = this.sanitizeWellKnownUrl(wellknown["m.homeserver"]["base_url"]); - if (!hsUrl) { - _logger.logger.error("Invalid base_url for m.homeserver"); - clientConfig["m.homeserver"].error = AutoDiscovery.ERROR_INVALID_HS_BASE_URL; - return Promise.resolve(clientConfig); - } - - // Step 3: Make sure the homeserver URL points to a homeserver. - const hsVersions = await this.fetchWellKnownObject(`${hsUrl}/_matrix/client/versions`); - if (!hsVersions || !((_hsVersions$raw = hsVersions.raw) !== null && _hsVersions$raw !== void 0 && _hsVersions$raw["versions"])) { - _logger.logger.error("Invalid /versions response"); - clientConfig["m.homeserver"].error = AutoDiscovery.ERROR_INVALID_HOMESERVER; - - // Supply the base_url to the caller because they may be ignoring liveliness - // errors, like this one. - clientConfig["m.homeserver"].base_url = hsUrl; - return Promise.resolve(clientConfig); - } - - // Step 4: Now that the homeserver looks valid, update our client config. - clientConfig["m.homeserver"] = { - state: AutoDiscovery.SUCCESS, - error: null, - base_url: hsUrl - }; - - // Step 5: Try to pull out the identity server configuration - let isUrl = ""; - if (wellknown["m.identity_server"]) { - // We prepare a failing identity server response to save lines later - // in this branch. - const failingClientConfig = { - "m.homeserver": clientConfig["m.homeserver"], - "m.identity_server": { - state: AutoDiscovery.FAIL_PROMPT, - error: AutoDiscovery.ERROR_INVALID_IS, - base_url: null - } - }; - - // Step 5a: Make sure the URL is valid *looking*. We'll make sure it - // points to an identity server in Step 5b. - isUrl = this.sanitizeWellKnownUrl(wellknown["m.identity_server"]["base_url"]); - if (!isUrl) { - _logger.logger.error("Invalid base_url for m.identity_server"); - failingClientConfig["m.identity_server"].error = AutoDiscovery.ERROR_INVALID_IS_BASE_URL; - return Promise.resolve(failingClientConfig); - } - - // Step 5b: Verify there is an identity server listening on the provided - // URL. - const isResponse = await this.fetchWellKnownObject(`${isUrl}/_matrix/identity/v2`); - if (!(isResponse !== null && isResponse !== void 0 && isResponse.raw) || isResponse.action !== AutoDiscoveryAction.SUCCESS) { - _logger.logger.error("Invalid /v2 response"); - failingClientConfig["m.identity_server"].error = AutoDiscovery.ERROR_INVALID_IDENTITY_SERVER; - - // Supply the base_url to the caller because they may be ignoring - // liveliness errors, like this one. - failingClientConfig["m.identity_server"].base_url = isUrl; - return Promise.resolve(failingClientConfig); - } - } - - // Step 6: Now that the identity server is valid, or never existed, - // populate the IS section. - if (isUrl && isUrl.toString().length > 0) { - clientConfig["m.identity_server"] = { - state: AutoDiscovery.SUCCESS, - error: null, - base_url: isUrl - }; - } - - // Step 7: Copy any other keys directly into the clientConfig. This is for - // things like custom configuration of services. - Object.keys(wellknown).forEach(k => { - if (k === "m.homeserver" || k === "m.identity_server") { - // Only copy selected parts of the config to avoid overwriting - // properties computed by the validation logic above. - const notProps = ["error", "state", "base_url"]; - for (const prop of Object.keys(wellknown[k])) { - if (notProps.includes(prop)) continue; - // @ts-ignore - ts gets unhappy as we're mixing types here - clientConfig[k][prop] = wellknown[k][prop]; - } - } else { - // Just copy the whole thing over otherwise - clientConfig[k] = wellknown[k]; - } - }); - - // Step 8: Give the config to the caller (finally) - return Promise.resolve(clientConfig); - } - - /** - * Attempts to automatically discover client configuration information - * prior to logging in. Such information includes the homeserver URL - * and identity server URL the client would want. Additional details - * may also be discovered, and will be transparently included in the - * response object unaltered. - * @param domain - The homeserver domain to perform discovery - * on. For example, "matrix.org". - * @returns Promise which resolves to the discovered - * configuration, which may include error states. Rejects on unexpected - * failure, not when discovery fails. - */ - static async findClientConfig(domain) { - if (!domain || typeof domain !== "string" || domain.length === 0) { - throw new Error("'domain' must be a string of non-zero length"); - } - - // We use a .well-known lookup for all cases. According to the spec, we - // can do other discovery mechanisms if we want such as custom lookups - // however we won't bother with that here (mostly because the spec only - // supports .well-known right now). - // - // By using .well-known, we need to ensure we at least pull out a URL - // for the homeserver. We don't really need an identity server configuration - // but will return one anyways (with state PROMPT) to make development - // easier for clients. If we can't get a homeserver URL, all bets are - // off on the rest of the config and we'll assume it is invalid too. - - // We default to an error state to make the first few checks easier to - // write. We'll update the properties of this object over the duration - // of this function. - const clientConfig = { - "m.homeserver": { - state: AutoDiscovery.FAIL_ERROR, - error: AutoDiscovery.ERROR_INVALID, - base_url: null - }, - "m.identity_server": { - // Technically, we don't have a problem with the identity server - // config at this point. - state: AutoDiscovery.PROMPT, - error: null, - base_url: null - } - }; - - // Step 1: Actually request the .well-known JSON file and make sure it - // at least has a homeserver definition. - const wellknown = await this.fetchWellKnownObject(`https://${domain}/.well-known/matrix/client`); - if (!wellknown || wellknown.action !== AutoDiscoveryAction.SUCCESS) { - _logger.logger.error("No response or error when parsing .well-known"); - if (wellknown.reason) _logger.logger.error(wellknown.reason); - if (wellknown.action === AutoDiscoveryAction.IGNORE) { - clientConfig["m.homeserver"] = { - state: AutoDiscovery.PROMPT, - error: null, - base_url: null - }; - } else { - // this can only ever be FAIL_PROMPT at this point. - clientConfig["m.homeserver"].state = AutoDiscovery.FAIL_PROMPT; - clientConfig["m.homeserver"].error = AutoDiscovery.ERROR_INVALID; - } - return Promise.resolve(clientConfig); - } - - // Step 2: Validate and parse the config - return AutoDiscovery.fromDiscoveryConfig(wellknown.raw); - } - - /** - * Gets the raw discovery client configuration for the given domain name. - * Should only be used if there's no validation to be done on the resulting - * object, otherwise use findClientConfig(). - * @param domain - The domain to get the client config for. - * @returns Promise which resolves to the domain's client config. Can - * be an empty object. - */ - static async getRawClientConfig(domain) { - if (!domain || typeof domain !== "string" || domain.length === 0) { - throw new Error("'domain' must be a string of non-zero length"); - } - const response = await this.fetchWellKnownObject(`https://${domain}/.well-known/matrix/client`); - if (!response) return {}; - return response.raw || {}; - } - - /** - * Sanitizes a given URL to ensure it is either an HTTP or HTTP URL and - * is suitable for the requirements laid out by .well-known auto discovery. - * If valid, the URL will also be stripped of any trailing slashes. - * @param url - The potentially invalid URL to sanitize. - * @returns The sanitized URL or a falsey value if the URL is invalid. - * @internal - */ - static sanitizeWellKnownUrl(url) { - if (!url) return false; - try { - var _parsed; - let parsed; - try { - parsed = new URL(url); - } catch (e) { - _logger.logger.error("Could not parse url", e); - } - if (!((_parsed = parsed) !== null && _parsed !== void 0 && _parsed.hostname)) return false; - if (parsed.protocol !== "http:" && parsed.protocol !== "https:") return false; - const port = parsed.port ? `:${parsed.port}` : ""; - const path = parsed.pathname ? parsed.pathname : ""; - let saferUrl = `${parsed.protocol}//${parsed.hostname}${port}${path}`; - if (saferUrl.endsWith("/")) { - saferUrl = saferUrl.substring(0, saferUrl.length - 1); - } - return saferUrl; - } catch (e) { - _logger.logger.error(e); - return false; - } - } - static fetch(resource, options) { - if (this.fetchFn) { - return this.fetchFn(resource, options); - } - return global.fetch(resource, options); - } - static setFetchFn(fetchFn) { - AutoDiscovery.fetchFn = fetchFn; - } - - /** - * Fetches a JSON object from a given URL, as expected by all .well-known - * related lookups. If the server gives a 404 then the `action` will be - * IGNORE. If the server returns something that isn't JSON, the `action` - * will be FAIL_PROMPT. For any other failure the `action` will be FAIL_PROMPT. - * - * The returned object will be a result of the call in object form with - * the following properties: - * raw: The JSON object returned by the server. - * action: One of SUCCESS, IGNORE, or FAIL_PROMPT. - * reason: Relatively human-readable description of what went wrong. - * error: The actual Error, if one exists. - * @param url - The URL to fetch a JSON object from. - * @returns Promise which resolves to the returned state. - * @internal - */ - static async fetchWellKnownObject(url) { - let response; - try { - response = await AutoDiscovery.fetch(url, { - method: _httpApi.Method.Get, - signal: (0, _httpApi.timeoutSignal)(5000) - }); - if (response.status === 404) { - return { - raw: {}, - action: AutoDiscoveryAction.IGNORE, - reason: AutoDiscovery.ERROR_MISSING_WELLKNOWN - }; - } - if (!response.ok) { - return { - raw: {}, - action: AutoDiscoveryAction.FAIL_PROMPT, - reason: "General failure" - }; - } - } catch (err) { - const error = err; - let reason = ""; - if (typeof error === "object") { - reason = error === null || error === void 0 ? void 0 : error.message; - } - return { - error, - raw: {}, - action: AutoDiscoveryAction.FAIL_PROMPT, - reason: reason || "General failure" - }; - } - try { - return { - raw: await response.json(), - action: AutoDiscoveryAction.SUCCESS - }; - } catch (err) { - const error = err; - return { - error, - raw: {}, - action: AutoDiscoveryAction.FAIL_PROMPT, - reason: (error === null || error === void 0 ? void 0 : error.name) === "SyntaxError" ? AutoDiscovery.ERROR_INVALID_JSON : AutoDiscovery.ERROR_INVALID - }; - } - } -} -exports.AutoDiscovery = AutoDiscovery; -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_INVALID", AutoDiscoveryError.Invalid); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_GENERIC_FAILURE", AutoDiscoveryError.GenericFailure); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_INVALID_HS_BASE_URL", AutoDiscoveryError.InvalidHsBaseUrl); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_INVALID_HOMESERVER", AutoDiscoveryError.InvalidHomeserver); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_INVALID_IS_BASE_URL", AutoDiscoveryError.InvalidIsBaseUrl); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_INVALID_IDENTITY_SERVER", AutoDiscoveryError.InvalidIdentityServer); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_INVALID_IS", AutoDiscoveryError.InvalidIs); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_MISSING_WELLKNOWN", AutoDiscoveryError.MissingWellknown); -(0, _defineProperty2.default)(AutoDiscovery, "ERROR_INVALID_JSON", AutoDiscoveryError.InvalidJson); -(0, _defineProperty2.default)(AutoDiscovery, "ALL_ERRORS", Object.keys(AutoDiscoveryError)); -(0, _defineProperty2.default)(AutoDiscovery, "FAIL_ERROR", AutoDiscoveryAction.FAIL_ERROR); -(0, _defineProperty2.default)(AutoDiscovery, "FAIL_PROMPT", AutoDiscoveryAction.FAIL_PROMPT); -(0, _defineProperty2.default)(AutoDiscovery, "PROMPT", AutoDiscoveryAction.PROMPT); -(0, _defineProperty2.default)(AutoDiscovery, "SUCCESS", AutoDiscoveryAction.SUCCESS); -(0, _defineProperty2.default)(AutoDiscovery, "fetchFn", void 0); -//# sourceMappingURL=autodiscovery.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js.map deleted file mode 100644 index 061d864..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/autodiscovery.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"autodiscovery.js","names":["_logger","require","_httpApi","AutoDiscoveryAction","exports","AutoDiscoveryError","AutoDiscovery","fromDiscoveryConfig","wellknown","_hsVersions$raw","clientConfig","state","FAIL_ERROR","error","ERROR_INVALID","base_url","PROMPT","logger","FAIL_PROMPT","Promise","resolve","ERROR_INVALID_HS_BASE_URL","hsUrl","sanitizeWellKnownUrl","hsVersions","fetchWellKnownObject","raw","ERROR_INVALID_HOMESERVER","SUCCESS","isUrl","failingClientConfig","ERROR_INVALID_IS","ERROR_INVALID_IS_BASE_URL","isResponse","action","ERROR_INVALID_IDENTITY_SERVER","toString","length","Object","keys","forEach","k","notProps","prop","includes","findClientConfig","domain","Error","reason","IGNORE","getRawClientConfig","response","url","_parsed","parsed","URL","e","hostname","protocol","port","path","pathname","saferUrl","endsWith","substring","fetch","resource","options","fetchFn","global","setFetchFn","method","Method","Get","signal","timeoutSignal","status","ERROR_MISSING_WELLKNOWN","ok","err","message","json","name","ERROR_INVALID_JSON","_defineProperty2","default","Invalid","GenericFailure","InvalidHsBaseUrl","InvalidHomeserver","InvalidIsBaseUrl","InvalidIdentityServer","InvalidIs","MissingWellknown","InvalidJson"],"sources":["../src/autodiscovery.ts"],"sourcesContent":["/*\nCopyright 2018 New Vector Ltd\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IClientWellKnown, IWellKnownConfig } from \"./client\";\nimport { logger } from \"./logger\";\nimport { MatrixError, Method, timeoutSignal } from \"./http-api\";\n\n// Dev note: Auto discovery is part of the spec.\n// See: https://matrix.org/docs/spec/client_server/r0.4.0.html#server-discovery\n\nexport enum AutoDiscoveryAction {\n SUCCESS = \"SUCCESS\",\n IGNORE = \"IGNORE\",\n PROMPT = \"PROMPT\",\n FAIL_PROMPT = \"FAIL_PROMPT\",\n FAIL_ERROR = \"FAIL_ERROR\",\n}\n\nenum AutoDiscoveryError {\n Invalid = \"Invalid homeserver discovery response\",\n GenericFailure = \"Failed to get autodiscovery configuration from server\",\n InvalidHsBaseUrl = \"Invalid base_url for m.homeserver\",\n InvalidHomeserver = \"Homeserver URL does not appear to be a valid Matrix homeserver\",\n InvalidIsBaseUrl = \"Invalid base_url for m.identity_server\",\n InvalidIdentityServer = \"Identity server URL does not appear to be a valid identity server\",\n InvalidIs = \"Invalid identity server discovery response\",\n MissingWellknown = \"No .well-known JSON file found\",\n InvalidJson = \"Invalid JSON\",\n}\n\ninterface WellKnownConfig extends Omit {\n state: AutoDiscoveryAction;\n error?: IWellKnownConfig[\"error\"] | null;\n}\n\nexport interface ClientConfig extends Omit {\n \"m.homeserver\": WellKnownConfig;\n \"m.identity_server\": WellKnownConfig;\n}\n\n/**\n * Utilities for automatically discovery resources, such as homeservers\n * for users to log in to.\n */\nexport class AutoDiscovery {\n // Dev note: the constants defined here are related to but not\n // exactly the same as those in the spec. This is to hopefully\n // translate the meaning of the states in the spec, but also\n // support our own if needed.\n\n public static readonly ERROR_INVALID = AutoDiscoveryError.Invalid;\n\n public static readonly ERROR_GENERIC_FAILURE = AutoDiscoveryError.GenericFailure;\n\n public static readonly ERROR_INVALID_HS_BASE_URL = AutoDiscoveryError.InvalidHsBaseUrl;\n\n public static readonly ERROR_INVALID_HOMESERVER = AutoDiscoveryError.InvalidHomeserver;\n\n public static readonly ERROR_INVALID_IS_BASE_URL = AutoDiscoveryError.InvalidIsBaseUrl;\n\n public static readonly ERROR_INVALID_IDENTITY_SERVER = AutoDiscoveryError.InvalidIdentityServer;\n\n public static readonly ERROR_INVALID_IS = AutoDiscoveryError.InvalidIs;\n\n public static readonly ERROR_MISSING_WELLKNOWN = AutoDiscoveryError.MissingWellknown;\n\n public static readonly ERROR_INVALID_JSON = AutoDiscoveryError.InvalidJson;\n\n public static readonly ALL_ERRORS = Object.keys(AutoDiscoveryError);\n\n /**\n * The auto discovery failed. The client is expected to communicate\n * the error to the user and refuse logging in.\n */\n public static readonly FAIL_ERROR = AutoDiscoveryAction.FAIL_ERROR;\n\n /**\n * The auto discovery failed, however the client may still recover\n * from the problem. The client is recommended to that the same\n * action it would for PROMPT while also warning the user about\n * what went wrong. The client may also treat this the same as\n * a FAIL_ERROR state.\n */\n public static readonly FAIL_PROMPT = AutoDiscoveryAction.FAIL_PROMPT;\n\n /**\n * The auto discovery didn't fail but did not find anything of\n * interest. The client is expected to prompt the user for more\n * information, or fail if it prefers.\n */\n public static readonly PROMPT = AutoDiscoveryAction.PROMPT;\n\n /**\n * The auto discovery was successful.\n */\n public static readonly SUCCESS = AutoDiscoveryAction.SUCCESS;\n\n /**\n * Validates and verifies client configuration information for purposes\n * of logging in. Such information includes the homeserver URL\n * and identity server URL the client would want. Additional details\n * may also be included, and will be transparently brought into the\n * response object unaltered.\n * @param wellknown - The configuration object itself, as returned\n * by the .well-known auto-discovery endpoint.\n * @returns Promise which resolves to the verified\n * configuration, which may include error states. Rejects on unexpected\n * failure, not when verification fails.\n */\n public static async fromDiscoveryConfig(wellknown: IClientWellKnown): Promise {\n // Step 1 is to get the config, which is provided to us here.\n\n // We default to an error state to make the first few checks easier to\n // write. We'll update the properties of this object over the duration\n // of this function.\n const clientConfig: ClientConfig = {\n \"m.homeserver\": {\n state: AutoDiscovery.FAIL_ERROR,\n error: AutoDiscovery.ERROR_INVALID,\n base_url: null,\n },\n \"m.identity_server\": {\n // Technically, we don't have a problem with the identity server\n // config at this point.\n state: AutoDiscovery.PROMPT,\n error: null,\n base_url: null,\n },\n };\n\n if (!wellknown || !wellknown[\"m.homeserver\"]) {\n logger.error(\"No m.homeserver key in config\");\n\n clientConfig[\"m.homeserver\"].state = AutoDiscovery.FAIL_PROMPT;\n clientConfig[\"m.homeserver\"].error = AutoDiscovery.ERROR_INVALID;\n\n return Promise.resolve(clientConfig);\n }\n\n if (!wellknown[\"m.homeserver\"][\"base_url\"]) {\n logger.error(\"No m.homeserver base_url in config\");\n\n clientConfig[\"m.homeserver\"].state = AutoDiscovery.FAIL_PROMPT;\n clientConfig[\"m.homeserver\"].error = AutoDiscovery.ERROR_INVALID_HS_BASE_URL;\n\n return Promise.resolve(clientConfig);\n }\n\n // Step 2: Make sure the homeserver URL is valid *looking*. We'll make\n // sure it points to a homeserver in Step 3.\n const hsUrl = this.sanitizeWellKnownUrl(wellknown[\"m.homeserver\"][\"base_url\"]);\n if (!hsUrl) {\n logger.error(\"Invalid base_url for m.homeserver\");\n clientConfig[\"m.homeserver\"].error = AutoDiscovery.ERROR_INVALID_HS_BASE_URL;\n return Promise.resolve(clientConfig);\n }\n\n // Step 3: Make sure the homeserver URL points to a homeserver.\n const hsVersions = await this.fetchWellKnownObject(`${hsUrl}/_matrix/client/versions`);\n if (!hsVersions || !hsVersions.raw?.[\"versions\"]) {\n logger.error(\"Invalid /versions response\");\n clientConfig[\"m.homeserver\"].error = AutoDiscovery.ERROR_INVALID_HOMESERVER;\n\n // Supply the base_url to the caller because they may be ignoring liveliness\n // errors, like this one.\n clientConfig[\"m.homeserver\"].base_url = hsUrl;\n\n return Promise.resolve(clientConfig);\n }\n\n // Step 4: Now that the homeserver looks valid, update our client config.\n clientConfig[\"m.homeserver\"] = {\n state: AutoDiscovery.SUCCESS,\n error: null,\n base_url: hsUrl,\n };\n\n // Step 5: Try to pull out the identity server configuration\n let isUrl: string | boolean = \"\";\n if (wellknown[\"m.identity_server\"]) {\n // We prepare a failing identity server response to save lines later\n // in this branch.\n const failingClientConfig: ClientConfig = {\n \"m.homeserver\": clientConfig[\"m.homeserver\"],\n \"m.identity_server\": {\n state: AutoDiscovery.FAIL_PROMPT,\n error: AutoDiscovery.ERROR_INVALID_IS,\n base_url: null,\n },\n };\n\n // Step 5a: Make sure the URL is valid *looking*. We'll make sure it\n // points to an identity server in Step 5b.\n isUrl = this.sanitizeWellKnownUrl(wellknown[\"m.identity_server\"][\"base_url\"]);\n if (!isUrl) {\n logger.error(\"Invalid base_url for m.identity_server\");\n failingClientConfig[\"m.identity_server\"].error = AutoDiscovery.ERROR_INVALID_IS_BASE_URL;\n return Promise.resolve(failingClientConfig);\n }\n\n // Step 5b: Verify there is an identity server listening on the provided\n // URL.\n const isResponse = await this.fetchWellKnownObject(`${isUrl}/_matrix/identity/v2`);\n if (!isResponse?.raw || isResponse.action !== AutoDiscoveryAction.SUCCESS) {\n logger.error(\"Invalid /v2 response\");\n failingClientConfig[\"m.identity_server\"].error = AutoDiscovery.ERROR_INVALID_IDENTITY_SERVER;\n\n // Supply the base_url to the caller because they may be ignoring\n // liveliness errors, like this one.\n failingClientConfig[\"m.identity_server\"].base_url = isUrl;\n\n return Promise.resolve(failingClientConfig);\n }\n }\n\n // Step 6: Now that the identity server is valid, or never existed,\n // populate the IS section.\n if (isUrl && isUrl.toString().length > 0) {\n clientConfig[\"m.identity_server\"] = {\n state: AutoDiscovery.SUCCESS,\n error: null,\n base_url: isUrl,\n };\n }\n\n // Step 7: Copy any other keys directly into the clientConfig. This is for\n // things like custom configuration of services.\n Object.keys(wellknown).forEach((k: keyof IClientWellKnown) => {\n if (k === \"m.homeserver\" || k === \"m.identity_server\") {\n // Only copy selected parts of the config to avoid overwriting\n // properties computed by the validation logic above.\n const notProps = [\"error\", \"state\", \"base_url\"];\n for (const prop of Object.keys(wellknown[k]!)) {\n if (notProps.includes(prop)) continue;\n type Prop = Exclude;\n // @ts-ignore - ts gets unhappy as we're mixing types here\n clientConfig[k][prop as Prop] = wellknown[k]![prop as Prop];\n }\n } else {\n // Just copy the whole thing over otherwise\n clientConfig[k] = wellknown[k];\n }\n });\n\n // Step 8: Give the config to the caller (finally)\n return Promise.resolve(clientConfig);\n }\n\n /**\n * Attempts to automatically discover client configuration information\n * prior to logging in. Such information includes the homeserver URL\n * and identity server URL the client would want. Additional details\n * may also be discovered, and will be transparently included in the\n * response object unaltered.\n * @param domain - The homeserver domain to perform discovery\n * on. For example, \"matrix.org\".\n * @returns Promise which resolves to the discovered\n * configuration, which may include error states. Rejects on unexpected\n * failure, not when discovery fails.\n */\n public static async findClientConfig(domain: string): Promise {\n if (!domain || typeof domain !== \"string\" || domain.length === 0) {\n throw new Error(\"'domain' must be a string of non-zero length\");\n }\n\n // We use a .well-known lookup for all cases. According to the spec, we\n // can do other discovery mechanisms if we want such as custom lookups\n // however we won't bother with that here (mostly because the spec only\n // supports .well-known right now).\n //\n // By using .well-known, we need to ensure we at least pull out a URL\n // for the homeserver. We don't really need an identity server configuration\n // but will return one anyways (with state PROMPT) to make development\n // easier for clients. If we can't get a homeserver URL, all bets are\n // off on the rest of the config and we'll assume it is invalid too.\n\n // We default to an error state to make the first few checks easier to\n // write. We'll update the properties of this object over the duration\n // of this function.\n const clientConfig: ClientConfig = {\n \"m.homeserver\": {\n state: AutoDiscovery.FAIL_ERROR,\n error: AutoDiscovery.ERROR_INVALID,\n base_url: null,\n },\n \"m.identity_server\": {\n // Technically, we don't have a problem with the identity server\n // config at this point.\n state: AutoDiscovery.PROMPT,\n error: null,\n base_url: null,\n },\n };\n\n // Step 1: Actually request the .well-known JSON file and make sure it\n // at least has a homeserver definition.\n const wellknown = await this.fetchWellKnownObject(`https://${domain}/.well-known/matrix/client`);\n if (!wellknown || wellknown.action !== AutoDiscoveryAction.SUCCESS) {\n logger.error(\"No response or error when parsing .well-known\");\n if (wellknown.reason) logger.error(wellknown.reason);\n if (wellknown.action === AutoDiscoveryAction.IGNORE) {\n clientConfig[\"m.homeserver\"] = {\n state: AutoDiscovery.PROMPT,\n error: null,\n base_url: null,\n };\n } else {\n // this can only ever be FAIL_PROMPT at this point.\n clientConfig[\"m.homeserver\"].state = AutoDiscovery.FAIL_PROMPT;\n clientConfig[\"m.homeserver\"].error = AutoDiscovery.ERROR_INVALID;\n }\n return Promise.resolve(clientConfig);\n }\n\n // Step 2: Validate and parse the config\n return AutoDiscovery.fromDiscoveryConfig(wellknown.raw!);\n }\n\n /**\n * Gets the raw discovery client configuration for the given domain name.\n * Should only be used if there's no validation to be done on the resulting\n * object, otherwise use findClientConfig().\n * @param domain - The domain to get the client config for.\n * @returns Promise which resolves to the domain's client config. Can\n * be an empty object.\n */\n public static async getRawClientConfig(domain?: string): Promise {\n if (!domain || typeof domain !== \"string\" || domain.length === 0) {\n throw new Error(\"'domain' must be a string of non-zero length\");\n }\n\n const response = await this.fetchWellKnownObject(`https://${domain}/.well-known/matrix/client`);\n if (!response) return {};\n return response.raw || {};\n }\n\n /**\n * Sanitizes a given URL to ensure it is either an HTTP or HTTP URL and\n * is suitable for the requirements laid out by .well-known auto discovery.\n * If valid, the URL will also be stripped of any trailing slashes.\n * @param url - The potentially invalid URL to sanitize.\n * @returns The sanitized URL or a falsey value if the URL is invalid.\n * @internal\n */\n private static sanitizeWellKnownUrl(url?: string | null): string | false {\n if (!url) return false;\n\n try {\n let parsed: URL | undefined;\n try {\n parsed = new URL(url);\n } catch (e) {\n logger.error(\"Could not parse url\", e);\n }\n\n if (!parsed?.hostname) return false;\n if (parsed.protocol !== \"http:\" && parsed.protocol !== \"https:\") return false;\n\n const port = parsed.port ? `:${parsed.port}` : \"\";\n const path = parsed.pathname ? parsed.pathname : \"\";\n let saferUrl = `${parsed.protocol}//${parsed.hostname}${port}${path}`;\n if (saferUrl.endsWith(\"/\")) {\n saferUrl = saferUrl.substring(0, saferUrl.length - 1);\n }\n return saferUrl;\n } catch (e) {\n logger.error(e);\n return false;\n }\n }\n\n private static fetch(resource: URL | string, options?: RequestInit): ReturnType {\n if (this.fetchFn) {\n return this.fetchFn(resource, options);\n }\n return global.fetch(resource, options);\n }\n\n private static fetchFn?: typeof global.fetch;\n\n public static setFetchFn(fetchFn: typeof global.fetch): void {\n AutoDiscovery.fetchFn = fetchFn;\n }\n\n /**\n * Fetches a JSON object from a given URL, as expected by all .well-known\n * related lookups. If the server gives a 404 then the `action` will be\n * IGNORE. If the server returns something that isn't JSON, the `action`\n * will be FAIL_PROMPT. For any other failure the `action` will be FAIL_PROMPT.\n *\n * The returned object will be a result of the call in object form with\n * the following properties:\n * raw: The JSON object returned by the server.\n * action: One of SUCCESS, IGNORE, or FAIL_PROMPT.\n * reason: Relatively human-readable description of what went wrong.\n * error: The actual Error, if one exists.\n * @param url - The URL to fetch a JSON object from.\n * @returns Promise which resolves to the returned state.\n * @internal\n */\n private static async fetchWellKnownObject(url: string): Promise {\n let response: Response;\n\n try {\n response = await AutoDiscovery.fetch(url, {\n method: Method.Get,\n signal: timeoutSignal(5000),\n });\n\n if (response.status === 404) {\n return {\n raw: {},\n action: AutoDiscoveryAction.IGNORE,\n reason: AutoDiscovery.ERROR_MISSING_WELLKNOWN,\n };\n }\n\n if (!response.ok) {\n return {\n raw: {},\n action: AutoDiscoveryAction.FAIL_PROMPT,\n reason: \"General failure\",\n };\n }\n } catch (err) {\n const error = err as AutoDiscoveryError | string | undefined;\n let reason = \"\";\n if (typeof error === \"object\") {\n reason = (error)?.message;\n }\n\n return {\n error,\n raw: {},\n action: AutoDiscoveryAction.FAIL_PROMPT,\n reason: reason || \"General failure\",\n };\n }\n\n try {\n return {\n raw: await response.json(),\n action: AutoDiscoveryAction.SUCCESS,\n };\n } catch (err) {\n const error = err as Error;\n return {\n error,\n raw: {},\n action: AutoDiscoveryAction.FAIL_PROMPT,\n reason:\n (error as MatrixError)?.name === \"SyntaxError\"\n ? AutoDiscovery.ERROR_INVALID_JSON\n : AutoDiscovery.ERROR_INVALID,\n };\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts deleted file mode 100644 index d87e53f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import * as matrixcs from "./matrix"; -type BrowserMatrix = typeof matrixcs; -declare global { - var __js_sdk_entrypoint: boolean; - var matrixcs: BrowserMatrix; -} -export * from "./matrix"; -export default matrixcs; -//# sourceMappingURL=browser-index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts.map deleted file mode 100644 index 91c15f7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"browser-index.d.ts","sourceRoot":"","sources":["../src/browser-index.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,QAAQ,MAAM,UAAU,CAAC;AAErC,KAAK,aAAa,GAAG,OAAO,QAAQ,CAAC;AACrC,OAAO,CAAC,MAAM,CAAC;IAEX,IAAI,mBAAmB,EAAE,OAAO,CAAC;IACjC,IAAI,QAAQ,EAAE,aAAa,CAAC;CAE/B;AAoBD,cAAc,UAAU,CAAC;AACzB,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js deleted file mode 100644 index 25c7826..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js +++ /dev/null @@ -1,59 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -var _exportNames = {}; -exports.default = void 0; -var matrixcs = _interopRequireWildcard(require("./matrix")); -Object.keys(matrixcs).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === matrixcs[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return matrixcs[key]; - } - }); -}); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -if (global.__js_sdk_entrypoint) { - throw new Error("Multiple matrix-js-sdk entrypoints detected!"); -} -global.__js_sdk_entrypoint = true; - -// just *accessing* indexedDB throws an exception in firefox with indexeddb disabled. -let indexedDB; -try { - indexedDB = global.indexedDB; -} catch (e) {} - -// if our browser (appears to) support indexeddb, use an indexeddb crypto store. -if (indexedDB) { - matrixcs.setCryptoStoreFactory(() => new matrixcs.IndexedDBCryptoStore(indexedDB, "matrix-js-sdk:crypto")); -} - -// We export 3 things to make browserify happy as well as downstream projects. -// It's awkward, but required. -var _default = matrixcs; // keep export for browserify package deps -exports.default = _default; -global.matrixcs = matrixcs; -//# sourceMappingURL=browser-index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js.map deleted file mode 100644 index a14b56f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/browser-index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"browser-index.js","names":["matrixcs","_interopRequireWildcard","require","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","newObj","hasPropertyDescriptor","getOwnPropertyDescriptor","desc","set","global","__js_sdk_entrypoint","Error","indexedDB","e","setCryptoStoreFactory","IndexedDBCryptoStore","_default"],"sources":["../src/browser-index.ts"],"sourcesContent":["/*\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as matrixcs from \"./matrix\";\n\ntype BrowserMatrix = typeof matrixcs;\ndeclare global {\n /* eslint-disable no-var, camelcase */\n var __js_sdk_entrypoint: boolean;\n var matrixcs: BrowserMatrix;\n /* eslint-enable no-var */\n}\n\nif (global.__js_sdk_entrypoint) {\n throw new Error(\"Multiple matrix-js-sdk entrypoints detected!\");\n}\nglobal.__js_sdk_entrypoint = true;\n\n// just *accessing* indexedDB throws an exception in firefox with indexeddb disabled.\nlet indexedDB: IDBFactory | undefined;\ntry {\n indexedDB = global.indexedDB;\n} catch (e) {}\n\n// if our browser (appears to) support indexeddb, use an indexeddb crypto store.\nif (indexedDB) {\n matrixcs.setCryptoStoreFactory(() => new matrixcs.IndexedDBCryptoStore(indexedDB!, \"matrix-js-sdk:crypto\"));\n}\n\n// We export 3 things to make browserify happy as well as downstream projects.\n// It's awkward, but required.\nexport * from \"./matrix\";\nexport default matrixcs; // keep export for browserify package deps\nglobal.matrixcs = matrixcs;\n"],"mappings":";;;;;;;AAgBA,IAAAA,QAAA,GAAAC,uBAAA,CAAAC,OAAA;AA4BAC,MAAA,CAAAC,IAAA,CAAAJ,QAAA,EAAAK,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAN,QAAA,CAAAM,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAd,QAAA,CAAAM,GAAA;IAAA;EAAA;AAAA;AAAyB,SAAAS,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAf,wBAAAmB,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAT,GAAA,CAAAM,GAAA,SAAAK,MAAA,WAAAC,qBAAA,GAAAvB,MAAA,CAAAS,cAAA,IAAAT,MAAA,CAAAwB,wBAAA,WAAArB,GAAA,IAAAc,GAAA,QAAAd,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAW,GAAA,EAAAd,GAAA,SAAAsB,IAAA,GAAAF,qBAAA,GAAAvB,MAAA,CAAAwB,wBAAA,CAAAP,GAAA,EAAAd,GAAA,cAAAsB,IAAA,KAAAA,IAAA,CAAAd,GAAA,IAAAc,IAAA,CAAAC,GAAA,KAAA1B,MAAA,CAAAS,cAAA,CAAAa,MAAA,EAAAnB,GAAA,EAAAsB,IAAA,YAAAH,MAAA,CAAAnB,GAAA,IAAAc,GAAA,CAAAd,GAAA,SAAAmB,MAAA,CAAAH,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAM,GAAA,CAAAT,GAAA,EAAAK,MAAA,YAAAA,MAAA;AA5CzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAYA,IAAIK,MAAM,CAACC,mBAAmB,EAAE;EAC5B,MAAM,IAAIC,KAAK,CAAC,8CAA8C,CAAC;AACnE;AACAF,MAAM,CAACC,mBAAmB,GAAG,IAAI;;AAEjC;AACA,IAAIE,SAAiC;AACrC,IAAI;EACAA,SAAS,GAAGH,MAAM,CAACG,SAAS;AAChC,CAAC,CAAC,OAAOC,CAAC,EAAE,CAAC;;AAEb;AACA,IAAID,SAAS,EAAE;EACXjC,QAAQ,CAACmC,qBAAqB,CAAC,MAAM,IAAInC,QAAQ,CAACoC,oBAAoB,CAACH,SAAS,EAAG,sBAAsB,CAAC,CAAC;AAC/G;;AAEA;AACA;AAAA,IAAAI,QAAA,GAEerC,QAAQ,EAAE;AAAAW,OAAA,CAAAW,OAAA,GAAAe,QAAA;AACzBP,MAAM,CAAC9B,QAAQ,GAAGA,QAAQ"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts deleted file mode 100644 index ff85bc3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts +++ /dev/null @@ -1,3822 +0,0 @@ -/** - * This is an internal module. See {@link MatrixClient} for the public class. - */ -import { Optional } from "matrix-events-sdk"; -import type { IDeviceKeys, IMegolmSessionData, IOneTimeKey } from "./@types/crypto"; -import { ISyncStateData, SyncApi, SyncApiOptions, SyncState } from "./sync"; -import { EventStatus, IContent, IDecryptOptions, IEvent, MatrixEvent, MatrixEventEvent, MatrixEventHandlerMap } from "./models/event"; -import { CallEvent, CallEventHandlerMap, MatrixCall } from "./webrtc/call"; -import { Filter, IFilterDefinition } from "./filter"; -import { CallEventHandlerEvent, CallEventHandler, CallEventHandlerEventHandlerMap } from "./webrtc/callEventHandler"; -import { GroupCallEventHandlerEvent, GroupCallEventHandlerEventHandlerMap } from "./webrtc/groupCallEventHandler"; -import { Direction, EventTimeline } from "./models/event-timeline"; -import { IActionsObject, PushProcessor } from "./pushprocessor"; -import { AutoDiscoveryAction } from "./autodiscovery"; -import { IExportedDevice as IExportedOlmDevice } from "./crypto/OlmDevice"; -import { IOlmDevice } from "./crypto/algorithms/megolm"; -import { TypedReEmitter } from "./ReEmitter"; -import { IRoomEncryption, RoomList } from "./crypto/RoomList"; -import { SERVICE_TYPES } from "./service-types"; -import { HttpApiEvent, HttpApiEventHandlerMap, Upload, UploadOpts, MatrixError, MatrixHttpApi, IHttpOpts, FileType, UploadResponse, IRequestOpts } from "./http-api"; -import { Crypto, CryptoEvent, CryptoEventHandlerMap, ICryptoCallbacks, IBootstrapCrossSigningOpts, ICheckOwnCrossSigningTrustOpts, VerificationMethod } from "./crypto"; -import { DeviceInfo } from "./crypto/deviceinfo"; -import { User, UserEvent, UserEventHandlerMap } from "./models/user"; -import { IDehydratedDevice, IDehydratedDeviceKeyInfo } from "./crypto/dehydration"; -import { IKeyBackupInfo, IKeyBackupPrepareOpts, IKeyBackupRestoreOpts, IKeyBackupRestoreResult } from "./crypto/keybackup"; -import { IIdentityServerProvider } from "./@types/IIdentityServerProvider"; -import { MatrixScheduler } from "./scheduler"; -import { BeaconEvent, BeaconEventHandlerMap } from "./models/beacon"; -import { IAuthData, IAuthDict } from "./interactive-auth"; -import { IMinimalEvent, IRoomEvent, IStateEvent } from "./sync-accumulator"; -import { CrossSigningKey, IAddSecretStorageKeyOpts, ICreateSecretStorageOpts, IEncryptedEventInfo, IImportRoomKeysOpts, IRecoveryKey } from "./crypto/api"; -import { EventTimelineSet } from "./models/event-timeline-set"; -import { VerificationRequest } from "./crypto/verification/request/VerificationRequest"; -import { VerificationBase as Verification } from "./crypto/verification/Base"; -import { CrossSigningInfo, DeviceTrustLevel, ICacheCallbacks, UserTrustLevel } from "./crypto/CrossSigning"; -import { Room, RoomEvent, RoomEventHandlerMap, RoomNameState } from "./models/room"; -import { RoomMemberEvent, RoomMemberEventHandlerMap } from "./models/room-member"; -import { RoomStateEvent, RoomStateEventHandlerMap } from "./models/room-state"; -import { IAddThreePidOnlyBody, IBindThreePidBody, ICreateRoomOpts, IEventSearchOpts, IGuestAccessOpts, IJoinRoomOpts, IPaginateOpts, IPresenceOpts, IRedactOpts, IRelationsRequestOpts, IRelationsResponse, IRoomDirectoryOptions, ISearchOpts, ISendEventResponse, ITagsResponse, IStatusResponse } from "./@types/requests"; -import { EventType, RelationType, RoomType } from "./@types/event"; -import { IdServerUnbindResult, IImageInfo, Preset, Visibility } from "./@types/partials"; -import { EventMapper, MapperOpts } from "./event-mapper"; -import { IKeyBackup, IKeyBackupCheck, IPreparedKeyBackupVersion, TrustInfo } from "./crypto/backup"; -import { MSC3089TreeSpace } from "./models/MSC3089TreeSpace"; -import { ISignatures } from "./@types/signed"; -import { IStore } from "./store"; -import { ISecretRequest } from "./crypto/SecretStorage"; -import { IEventWithRoomId, ISearchRequestBody, ISearchResponse, ISearchResults, IStateEventWithRoomId } from "./@types/search"; -import { ISynapseAdminDeactivateResponse, ISynapseAdminWhoisResponse } from "./@types/synapse"; -import { IHierarchyRoom } from "./@types/spaces"; -import { IPusher, IPusherRequest, IPushRule, IPushRules, PushRuleAction, PushRuleKind, RuleId } from "./@types/PushRules"; -import { IThreepid } from "./@types/threepids"; -import { CryptoStore, OutgoingRoomKeyRequest } from "./crypto/store/base"; -import { GroupCall, IGroupCallDataChannelOptions, GroupCallIntent, GroupCallType } from "./webrtc/groupCall"; -import { MediaHandler } from "./webrtc/mediaHandler"; -import { GroupCallEventHandler } from "./webrtc/groupCallEventHandler"; -import { LoginTokenPostResponse, ILoginFlowsResponse, IRefreshTokenResponse, SSOAction } from "./@types/auth"; -import { TypedEventEmitter } from "./models/typed-event-emitter"; -import { ReceiptType } from "./@types/read_receipts"; -import { MSC3575SlidingSyncRequest, MSC3575SlidingSyncResponse, SlidingSync } from "./sliding-sync"; -import { SlidingSyncSdk } from "./sliding-sync-sdk"; -import { FeatureSupport, ThreadFilterType } from "./models/thread"; -import { MBeaconInfoEventContent } from "./@types/beacon"; -import { UnstableValue } from "./NamespacedValue"; -import { ToDeviceBatch } from "./models/ToDeviceMessage"; -import { IgnoredInvites } from "./models/invites-ignorer"; -import { UIAResponse } from "./@types/uia"; -import { LocalNotificationSettings } from "./@types/local_notifications"; -import { Feature, ServerSupport } from "./feature"; -import { CryptoApi } from "./crypto-api"; -import { DeviceInfoMap } from "./crypto/DeviceList"; -import { SecretStorageKeyDescription } from "./secret-storage"; -export type Store = IStore; -export type ResetTimelineCallback = (roomId: string) => boolean; -export declare const CRYPTO_ENABLED: boolean; -export declare const UNSTABLE_MSC3852_LAST_SEEN_UA: UnstableValue<"last_seen_user_agent", "org.matrix.msc3852.last_seen_user_agent">; -interface IExportedDevice { - olmDevice: IExportedOlmDevice; - userId: string; - deviceId: string; -} -export interface IKeysUploadResponse { - one_time_key_counts: { - [algorithm: string]: number; - }; -} -export interface ICreateClientOpts { - baseUrl: string; - idBaseUrl?: string; - /** - * The data store used for sync data from the homeserver. If not specified, - * this client will not store any HTTP responses. The `createClient` helper - * will create a default store if needed. - */ - store?: Store; - /** - * A store to be used for end-to-end crypto session data. If not specified, - * end-to-end crypto will be disabled. The `createClient` helper will create - * a default store if needed. Calls the factory supplied to - * {@link setCryptoStoreFactory} if unspecified; or if no factory has been - * specified, uses a default implementation (indexeddb in the browser, - * in-memory otherwise). - */ - cryptoStore?: CryptoStore; - /** - * The scheduler to use. If not - * specified, this client will not retry requests on failure. This client - * will supply its own processing function to - * {@link MatrixScheduler#setProcessFunction}. - */ - scheduler?: MatrixScheduler; - /** - * The function to invoke for HTTP requests. - * Most supported environments have a global `fetch` registered to which this will fall back. - */ - fetchFn?: typeof global.fetch; - userId?: string; - /** - * A unique identifier for this device; used for tracking things like crypto - * keys and access tokens. If not specified, end-to-end encryption will be - * disabled. - */ - deviceId?: string; - accessToken?: string; - /** - * Identity server provider to retrieve the user's access token when accessing - * the identity server. See also https://github.com/vector-im/element-web/issues/10615 - * which seeks to replace the previous approach of manual access tokens params - * with this callback throughout the SDK. - */ - identityServer?: IIdentityServerProvider; - /** - * The default maximum amount of - * time to wait before timing out HTTP requests. If not specified, there is no timeout. - */ - localTimeoutMs?: number; - /** - * Set to true to use - * Authorization header instead of query param to send the access token to the server. - * - * Default false. - */ - useAuthorizationHeader?: boolean; - /** - * Set to true to enable - * improved timeline support, see {@link MatrixClient#getEventTimeline}. - * It is disabled by default for compatibility with older clients - in particular to - * maintain support for back-paginating the live timeline after a '/sync' - * result with a gap. - */ - timelineSupport?: boolean; - /** - * Extra query parameters to append - * to all requests with this client. Useful for application services which require - * `?user_id=`. - */ - queryParams?: Record; - /** - * Device data exported with - * "exportDevice" method that must be imported to recreate this device. - * Should only be useful for devices with end-to-end crypto enabled. - * If provided, deviceId and userId should **NOT** be provided at the top - * level (they are present in the exported data). - */ - deviceToImport?: IExportedDevice; - /** - * Key used to pickle olm objects or other sensitive data. - */ - pickleKey?: string; - verificationMethods?: Array; - /** - * Whether relaying calls through a TURN server should be forced. Default false. - */ - forceTURN?: boolean; - /** - * Up to this many ICE candidates will be gathered when an incoming call arrives. - * Gathering does not send data to the caller, but will communicate with the configured TURN - * server. Default 0. - */ - iceCandidatePoolSize?: number; - /** - * True to advertise support for call transfers to other parties on Matrix calls. Default false. - */ - supportsCallTransfer?: boolean; - /** - * Whether to allow a fallback ICE server should be used for negotiating a - * WebRTC connection if the homeserver doesn't provide any servers. Defaults to false. - */ - fallbackICEServerAllowed?: boolean; - /** - * If true, to-device signalling for group calls will be encrypted - * with Olm. Default: true. - */ - useE2eForGroupCall?: boolean; - cryptoCallbacks?: ICryptoCallbacks; - /** - * Method to generate room names for empty rooms and rooms names based on membership. - * Defaults to a built-in English handler with basic pluralisation. - */ - roomNameGenerator?: (roomId: string, state: RoomNameState) => string | null; - /** - * If true, participant can join group call without video and audio this has to be allowed. By default, a local - * media stream is needed to establish a group call. - * Default: false. - */ - isVoipWithNoMediaAllowed?: boolean; -} -export interface IMatrixClientCreateOpts extends ICreateClientOpts { - /** - * Whether to allow sending messages to encrypted rooms when encryption - * is not available internally within this SDK. This is useful if you are using an external - * E2E proxy, for example. Defaults to false. - */ - usingExternalCrypto?: boolean; -} -export declare enum PendingEventOrdering { - Chronological = "chronological", - Detached = "detached" -} -export interface IStartClientOpts { - /** - * The event `limit=` to apply to initial sync. Default: 8. - */ - initialSyncLimit?: number; - /** - * True to put `archived=true on the /initialSync` request. Default: false. - */ - includeArchivedRooms?: boolean; - /** - * True to do /profile requests on every invite event if the displayname/avatar_url is not known for this user ID. Default: false. - */ - resolveInvitesToProfiles?: boolean; - /** - * Controls where pending messages appear in a room's timeline. If "chronological", messages will - * appear in the timeline when the call to `sendEvent` was made. If "detached", - * pending messages will appear in a separate list, accessbile via {@link Room#getPendingEvents}. - * Default: "chronological". - */ - pendingEventOrdering?: PendingEventOrdering; - /** - * The number of milliseconds to wait on /sync. Default: 30000 (30 seconds). - */ - pollTimeout?: number; - /** - * The filter to apply to /sync calls. - */ - filter?: Filter; - /** - * True to perform syncing without automatically updating presence. - */ - disablePresence?: boolean; - /** - * True to not load all membership events during initial sync but fetch them when needed by calling - * `loadOutOfBandMembers` This will override the filter option at this moment. - */ - lazyLoadMembers?: boolean; - /** - * The number of seconds between polls to /.well-known/matrix/client, undefined to disable. - * This should be in the order of hours. Default: undefined. - */ - clientWellKnownPollPeriod?: number; - /** - * @deprecated use `threadSupport` instead - */ - experimentalThreadSupport?: boolean; - /** - * Will organises events in threaded conversations when - * a thread relation is encountered - */ - threadSupport?: boolean; - /** - * @experimental - */ - slidingSync?: SlidingSync; - /** - * @experimental - */ - intentionalMentions?: boolean; -} -export interface IStoredClientOpts extends IStartClientOpts { -} -export declare enum RoomVersionStability { - Stable = "stable", - Unstable = "unstable" -} -export interface IRoomVersionsCapability { - default: string; - available: Record; -} -export interface ICapability { - enabled: boolean; -} -export interface IChangePasswordCapability extends ICapability { -} -export interface IThreadsCapability extends ICapability { -} -interface ICapabilities { - [key: string]: any; - "m.change_password"?: IChangePasswordCapability; - "m.room_versions"?: IRoomVersionsCapability; - "io.element.thread"?: IThreadsCapability; -} -export interface ICrossSigningKey { - keys: { - [algorithm: string]: string; - }; - signatures?: ISignatures; - usage: string[]; - user_id: string; -} -declare enum CrossSigningKeyType { - MasterKey = "master_key", - SelfSigningKey = "self_signing_key", - UserSigningKey = "user_signing_key" -} -export type CrossSigningKeys = Record; -export type SendToDeviceContentMap = Map>>; -export interface ISignedKey { - keys: Record; - signatures: ISignatures; - user_id: string; - algorithms: string[]; - device_id: string; -} -export type KeySignatures = Record>; -export interface IUploadKeySignaturesResponse { - failures: Record>; -} -export interface IPreviewUrlResponse { - [key: string]: undefined | string | number; - "og:title": string; - "og:type": string; - "og:url": string; - "og:image"?: string; - "og:image:type"?: string; - "og:image:height"?: number; - "og:image:width"?: number; - "og:description"?: string; - "matrix:image:size"?: number; -} -export interface ITurnServerResponse { - uris: string[]; - username: string; - password: string; - ttl: number; -} -export interface ITurnServer { - urls: string[]; - username: string; - credential: string; -} -export interface IServerVersions { - versions: string[]; - unstable_features: Record; -} -export declare const M_AUTHENTICATION: UnstableValue<"m.authentication", "org.matrix.msc2965.authentication">; -export interface IClientWellKnown { - [key: string]: any; - "m.homeserver"?: IWellKnownConfig; - "m.identity_server"?: IWellKnownConfig; - [M_AUTHENTICATION.name]?: IDelegatedAuthConfig; -} -export interface IWellKnownConfig { - raw?: IClientWellKnown; - action?: AutoDiscoveryAction; - reason?: string; - error?: Error | string; - base_url?: string | null; - server_name?: string; -} -export interface IDelegatedAuthConfig { - /** The OIDC Provider/issuer the client should use */ - issuer: string; - /** The optional URL of the web UI where the user can manage their account */ - account?: string; -} -interface IMediaConfig { - [key: string]: any; - "m.upload.size"?: number; -} -interface ITagMetadata { - [key: string]: any; - order: number; -} -interface IMessagesResponse { - start?: string; - end?: string; - chunk: IRoomEvent[]; - state?: IStateEvent[]; -} -export interface IRequestTokenResponse { - sid: string; - submit_url?: string; -} -export interface IRequestMsisdnTokenResponse extends IRequestTokenResponse { - msisdn: string; - success: boolean; - intl_fmt: string; -} -export interface IUploadKeysRequest { - "device_keys"?: Required; - "one_time_keys"?: Record; - "org.matrix.msc2732.fallback_keys"?: Record; -} -export interface IQueryKeysRequest { - device_keys: { - [userId: string]: string[]; - }; - timeout?: number; - token?: string; -} -export interface IClaimKeysRequest { - one_time_keys: { - [userId: string]: { - [deviceId: string]: string; - }; - }; - timeout?: number; -} -export interface IOpenIDToken { - access_token: string; - token_type: "Bearer" | string; - matrix_server_name: string; - expires_in: number; -} -interface IRoomInitialSyncResponse { - room_id: string; - membership: "invite" | "join" | "leave" | "ban"; - messages?: { - start?: string; - end?: string; - chunk: IEventWithRoomId[]; - }; - state?: IStateEventWithRoomId[]; - visibility: Visibility; - account_data?: IMinimalEvent[]; - presence: Partial; -} -interface IJoinedRoomsResponse { - joined_rooms: string[]; -} -interface IJoinedMembersResponse { - joined: { - [userId: string]: { - display_name: string; - avatar_url: string; - }; - }; -} -export interface IRegisterRequestParams { - auth?: IAuthData; - username?: string; - password?: string; - refresh_token?: boolean; - guest_access_token?: string; - x_show_msisdn?: boolean; - bind_msisdn?: boolean; - bind_email?: boolean; - inhibit_login?: boolean; - initial_device_display_name?: string; -} -export interface IPublicRoomsChunkRoom { - room_id: string; - name?: string; - avatar_url?: string; - topic?: string; - canonical_alias?: string; - aliases?: string[]; - world_readable: boolean; - guest_can_join: boolean; - num_joined_members: number; - room_type?: RoomType | string; -} -interface IPublicRoomsResponse { - chunk: IPublicRoomsChunkRoom[]; - next_batch?: string; - prev_batch?: string; - total_room_count_estimate?: number; -} -interface IUserDirectoryResponse { - results: { - user_id: string; - display_name?: string; - avatar_url?: string; - }[]; - limited: boolean; -} -export interface IMyDevice { - "device_id": string; - "display_name"?: string; - "last_seen_ip"?: string; - "last_seen_ts"?: number; - "last_seen_user_agent"?: string; - "org.matrix.msc3852.last_seen_user_agent"?: string; -} -export interface Keys { - keys: { - [keyId: string]: string; - }; - usage: string[]; - user_id: string; -} -export interface SigningKeys extends Keys { - signatures: ISignatures; -} -export interface DeviceKeys { - [deviceId: string]: IDeviceKeys & { - unsigned?: { - device_display_name: string; - }; - }; -} -export interface IDownloadKeyResult { - failures: { - [serverName: string]: object; - }; - device_keys: { - [userId: string]: DeviceKeys; - }; - master_keys?: { - [userId: string]: Keys; - }; - self_signing_keys?: { - [userId: string]: SigningKeys; - }; - user_signing_keys?: { - [userId: string]: SigningKeys; - }; -} -export interface IClaimOTKsResult { - failures: { - [serverName: string]: object; - }; - one_time_keys: { - [userId: string]: { - [deviceId: string]: { - [keyId: string]: { - key: string; - signatures: ISignatures; - }; - }; - }; - }; -} -export interface IFieldType { - regexp: string; - placeholder: string; -} -export interface IInstance { - desc: string; - icon?: string; - fields: object; - network_id: string; - instance_id: string; -} -export interface IProtocol { - user_fields: string[]; - location_fields: string[]; - icon: string; - field_types: Record; - instances: IInstance[]; -} -interface IThirdPartyLocation { - alias: string; - protocol: string; - fields: object; -} -interface IThirdPartyUser { - userid: string; - protocol: string; - fields: object; -} -interface IRoomSummary extends Omit { - room_type?: RoomType; - membership?: string; - is_encrypted: boolean; -} -interface IRoomHierarchy { - rooms: IHierarchyRoom[]; - next_batch?: string; -} -export interface TimestampToEventResponse { - event_id: string; - origin_server_ts: string; -} -interface IWhoamiResponse { - user_id: string; - device_id?: string; -} -export declare enum ClientEvent { - Sync = "sync", - Event = "event", - ToDeviceEvent = "toDeviceEvent", - AccountData = "accountData", - Room = "Room", - DeleteRoom = "deleteRoom", - SyncUnexpectedError = "sync.unexpectedError", - ClientWellKnown = "WellKnown.client", - ReceivedVoipEvent = "received_voip_event", - UndecryptableToDeviceEvent = "toDeviceEvent.undecryptable", - TurnServers = "turnServers", - TurnServersError = "turnServers.error" -} -type RoomEvents = RoomEvent.Name | RoomEvent.Redaction | RoomEvent.RedactionCancelled | RoomEvent.Receipt | RoomEvent.Tags | RoomEvent.LocalEchoUpdated | RoomEvent.HistoryImportedWithinTimeline | RoomEvent.AccountData | RoomEvent.MyMembership | RoomEvent.Timeline | RoomEvent.TimelineReset; -type RoomStateEvents = RoomStateEvent.Events | RoomStateEvent.Members | RoomStateEvent.NewMember | RoomStateEvent.Update | RoomStateEvent.Marker; -type CryptoEvents = CryptoEvent.KeySignatureUploadFailure | CryptoEvent.KeyBackupStatus | CryptoEvent.KeyBackupFailed | CryptoEvent.KeyBackupSessionsRemaining | CryptoEvent.RoomKeyRequest | CryptoEvent.RoomKeyRequestCancellation | CryptoEvent.VerificationRequest | CryptoEvent.DeviceVerificationChanged | CryptoEvent.UserTrustStatusChanged | CryptoEvent.KeysChanged | CryptoEvent.Warning | CryptoEvent.DevicesUpdated | CryptoEvent.WillUpdateDevices; -type MatrixEventEvents = MatrixEventEvent.Decrypted | MatrixEventEvent.Replaced | MatrixEventEvent.VisibilityChange; -type RoomMemberEvents = RoomMemberEvent.Name | RoomMemberEvent.Typing | RoomMemberEvent.PowerLevel | RoomMemberEvent.Membership; -type UserEvents = UserEvent.AvatarUrl | UserEvent.DisplayName | UserEvent.Presence | UserEvent.CurrentlyActive | UserEvent.LastPresenceTs; -export type EmittedEvents = ClientEvent | RoomEvents | RoomStateEvents | CryptoEvents | MatrixEventEvents | RoomMemberEvents | UserEvents | CallEvent | CallEventHandlerEvent.Incoming | GroupCallEventHandlerEvent.Incoming | GroupCallEventHandlerEvent.Outgoing | GroupCallEventHandlerEvent.Ended | GroupCallEventHandlerEvent.Participants | HttpApiEvent.SessionLoggedOut | HttpApiEvent.NoConsent | BeaconEvent; -export type ClientEventHandlerMap = { - /** - * Fires whenever the SDK's syncing state is updated. The state can be one of: - *
    - * - *
  • PREPARED: The client has synced with the server at least once and is - * ready for methods to be called on it. This will be immediately followed by - * a state of SYNCING. This is the equivalent of "syncComplete" in the - * previous API.
  • - * - *
  • CATCHUP: The client has detected the connection to the server might be - * available again and will now try to do a sync again. As this sync might take - * a long time (depending how long ago was last synced, and general server - * performance) the client is put in this mode so the UI can reflect trying - * to catch up with the server after losing connection.
  • - * - *
  • SYNCING : The client is currently polling for new events from the server. - * This will be called after processing latest events from a sync.
  • - * - *
  • ERROR : The client has had a problem syncing with the server. If this is - * called before PREPARED then there was a problem performing the initial - * sync. If this is called after PREPARED then there was a problem polling - * the server for updates. This may be called multiple times even if the state is - * already ERROR. This is the equivalent of "syncError" in the previous - * API.
  • - * - *
  • RECONNECTING: The sync connection has dropped, but not (yet) in a way that - * should be considered erroneous. - *
  • - * - *
  • STOPPED: The client has stopped syncing with server due to stopClient - * being called. - *
  • - *
- * State transition diagram: - * ``` - * +---->STOPPED - * | - * +----->PREPARED -------> SYNCING <--+ - * | ^ | ^ | - * | CATCHUP ----------+ | | | - * | ^ V | | - * null ------+ | +------- RECONNECTING | - * | V V | - * +------->ERROR ---------------------+ - * - * NB: 'null' will never be emitted by this event. - * - * ``` - * Transitions: - *
    - * - *
  • `null -> PREPARED` : Occurs when the initial sync is completed - * first time. This involves setting up filters and obtaining push rules. - * - *
  • `null -> ERROR` : Occurs when the initial sync failed first time. - * - *
  • `ERROR -> PREPARED` : Occurs when the initial sync succeeds - * after previously failing. - * - *
  • `PREPARED -> SYNCING` : Occurs immediately after transitioning - * to PREPARED. Starts listening for live updates rather than catching up. - * - *
  • `SYNCING -> RECONNECTING` : Occurs when the live update fails. - * - *
  • `RECONNECTING -> RECONNECTING` : Can occur if the update calls - * continue to fail, but the keepalive calls (to /versions) succeed. - * - *
  • `RECONNECTING -> ERROR` : Occurs when the keepalive call also fails - * - *
  • `ERROR -> SYNCING` : Occurs when the client has performed a - * live update after having previously failed. - * - *
  • `ERROR -> ERROR` : Occurs when the client has failed to keepalive - * for a second time or more.
  • - * - *
  • `SYNCING -> SYNCING` : Occurs when the client has performed a live - * update. This is called after processing.
  • - * - *
  • `* -> STOPPED` : Occurs once the client has stopped syncing or - * trying to sync after stopClient has been called.
  • - *
- * - * @param state - An enum representing the syncing state. One of "PREPARED", - * "SYNCING", "ERROR", "STOPPED". - * - * @param prevState - An enum representing the previous syncing state. - * One of "PREPARED", "SYNCING", "ERROR", "STOPPED" or null. - * - * @param data - Data about this transition. - * - * @example - * ``` - * matrixClient.on("sync", function(state, prevState, data) { - * switch (state) { - * case "ERROR": - * // update UI to say "Connection Lost" - * break; - * case "SYNCING": - * // update UI to remove any "Connection Lost" message - * break; - * case "PREPARED": - * // the client instance is ready to be queried. - * var rooms = matrixClient.getRooms(); - * break; - * } - * }); - * ``` - */ - [ClientEvent.Sync]: (state: SyncState, lastState: SyncState | null, data?: ISyncStateData) => void; - /** - * Fires whenever the SDK receives a new event. - *

- * This is only fired for live events received via /sync - it is not fired for - * events received over context, search, or pagination APIs. - * - * @param event - The matrix event which caused this event to fire. - * @example - * ``` - * matrixClient.on("event", function(event){ - * var sender = event.getSender(); - * }); - * ``` - */ - [ClientEvent.Event]: (event: MatrixEvent) => void; - /** - * Fires whenever the SDK receives a new to-device event. - * @param event - The matrix event which caused this event to fire. - * @example - * ``` - * matrixClient.on("toDeviceEvent", function(event){ - * var sender = event.getSender(); - * }); - * ``` - */ - [ClientEvent.ToDeviceEvent]: (event: MatrixEvent) => void; - /** - * Fires if a to-device event is received that cannot be decrypted. - * Encrypted to-device events will (generally) use plain Olm encryption, - * in which case decryption failures are fatal: the event will never be - * decryptable, unlike Megolm encrypted events where the key may simply - * arrive later. - * - * An undecryptable to-device event is therefore likley to indicate problems. - * - * @param event - The undecyptable to-device event - */ - [ClientEvent.UndecryptableToDeviceEvent]: (event: MatrixEvent) => void; - /** - * Fires whenever new user-scoped account_data is added. - * @param event - The event describing the account_data just added - * @param event - The previous account data, if known. - * @example - * ``` - * matrixClient.on("accountData", function(event, oldEvent){ - * myAccountData[event.type] = event.content; - * }); - * ``` - */ - [ClientEvent.AccountData]: (event: MatrixEvent, lastEvent?: MatrixEvent) => void; - /** - * Fires whenever a new Room is added. This will fire when you are invited to a - * room, as well as when you join a room. This event is experimental and - * may change. - * @param room - The newly created, fully populated room. - * @example - * ``` - * matrixClient.on("Room", function(room){ - * var roomId = room.roomId; - * }); - * ``` - */ - [ClientEvent.Room]: (room: Room) => void; - /** - * Fires whenever a Room is removed. This will fire when you forget a room. - * This event is experimental and may change. - * @param roomId - The deleted room ID. - * @example - * ``` - * matrixClient.on("deleteRoom", function(roomId){ - * // update UI from getRooms() - * }); - * ``` - */ - [ClientEvent.DeleteRoom]: (roomId: string) => void; - [ClientEvent.SyncUnexpectedError]: (error: Error) => void; - /** - * Fires when the client .well-known info is fetched. - * - * @param data - The JSON object returned by the server - */ - [ClientEvent.ClientWellKnown]: (data: IClientWellKnown) => void; - [ClientEvent.ReceivedVoipEvent]: (event: MatrixEvent) => void; - [ClientEvent.TurnServers]: (servers: ITurnServer[]) => void; - [ClientEvent.TurnServersError]: (error: Error, fatal: boolean) => void; -} & RoomEventHandlerMap & RoomStateEventHandlerMap & CryptoEventHandlerMap & MatrixEventHandlerMap & RoomMemberEventHandlerMap & UserEventHandlerMap & CallEventHandlerEventHandlerMap & GroupCallEventHandlerEventHandlerMap & CallEventHandlerMap & HttpApiEventHandlerMap & BeaconEventHandlerMap; -/** - * Represents a Matrix Client. Only directly construct this if you want to use - * custom modules. Normally, {@link createClient} should be used - * as it specifies 'sensible' defaults for these modules. - */ -export declare class MatrixClient extends TypedEventEmitter { - static readonly RESTORE_BACKUP_ERROR_BAD_KEY = "RESTORE_BACKUP_ERROR_BAD_KEY"; - reEmitter: TypedReEmitter; - olmVersion: [number, number, number] | null; - usingExternalCrypto: boolean; - store: Store; - deviceId: string | null; - credentials: { - userId: string | null; - }; - pickleKey?: string; - scheduler?: MatrixScheduler; - clientRunning: boolean; - timelineSupport: boolean; - urlPreviewCache: { - [key: string]: Promise; - }; - identityServer?: IIdentityServerProvider; - http: MatrixHttpApi; - /** - * The libolm crypto implementation, if it is in use. - * - * @deprecated This should not be used. Instead, use the methods exposed directly on this class or - * (where they are available) via {@link getCrypto}. - */ - crypto?: Crypto; - private cryptoBackend?; - cryptoCallbacks: ICryptoCallbacks; - callEventHandler?: CallEventHandler; - groupCallEventHandler?: GroupCallEventHandler; - supportsCallTransfer: boolean; - forceTURN: boolean; - iceCandidatePoolSize: number; - idBaseUrl?: string; - baseUrl: string; - readonly isVoipWithNoMediaAllowed: boolean; - protected canSupportVoip: boolean; - protected peekSync: SyncApi | null; - protected isGuestAccount: boolean; - protected ongoingScrollbacks: { - [roomId: string]: { - promise?: Promise; - errorTs?: number; - }; - }; - protected notifTimelineSet: EventTimelineSet | null; - protected cryptoStore?: CryptoStore; - protected verificationMethods?: VerificationMethod[]; - protected fallbackICEServerAllowed: boolean; - protected roomList: RoomList; - protected syncApi?: SlidingSyncSdk | SyncApi; - roomNameGenerator?: ICreateClientOpts["roomNameGenerator"]; - pushRules?: IPushRules; - protected syncLeftRoomsPromise?: Promise; - protected syncedLeftRooms: boolean; - protected clientOpts?: IStoredClientOpts; - protected clientWellKnownIntervalID?: ReturnType; - protected canResetTimelineCallback?: ResetTimelineCallback; - canSupport: Map; - protected pushProcessor: PushProcessor; - protected serverVersionsPromise?: Promise; - cachedCapabilities?: { - capabilities: ICapabilities; - expiration: number; - }; - protected clientWellKnown?: IClientWellKnown; - protected clientWellKnownPromise?: Promise; - protected turnServers: ITurnServer[]; - protected turnServersExpiry: number; - protected checkTurnServersIntervalID?: ReturnType; - protected exportedOlmDeviceToImport?: IExportedOlmDevice; - protected txnCtr: number; - protected mediaHandler: MediaHandler; - protected sessionId: string; - protected pendingEventEncryption: Map>; - private useE2eForGroupCall; - private toDeviceMessageQueue; - readonly ignoredInvites: IgnoredInvites; - constructor(opts: IMatrixClientCreateOpts); - /** - * High level helper method to begin syncing and poll for new events. To listen for these - * events, add a listener for {@link ClientEvent.Event} - * via {@link MatrixClient#on}. Alternatively, listen for specific - * state change events. - * @param opts - Options to apply when syncing. - */ - startClient(opts?: IStartClientOpts): Promise; - /** - * Construct a SyncApiOptions for this client, suitable for passing into the SyncApi constructor - */ - protected buildSyncApiOptions(): SyncApiOptions; - /** - * High level helper method to stop the client from polling and allow a - * clean shutdown. - */ - stopClient(): void; - /** - * Try to rehydrate a device if available. The client must have been - * initialized with a `cryptoCallback.getDehydrationKey` option, and this - * function must be called before initCrypto and startClient are called. - * - * @returns Promise which resolves to undefined if a device could not be dehydrated, or - * to the new device ID if the dehydration was successful. - * @returns Rejects: with an error response. - */ - rehydrateDevice(): Promise; - /** - * Get the current dehydrated device, if any - * @returns A promise of an object containing the dehydrated device - */ - getDehydratedDevice(): Promise; - /** - * Set the dehydration key. This will also periodically dehydrate devices to - * the server. - * - * @param key - the dehydration key - * @param keyInfo - Information about the key. Primarily for - * information about how to generate the key from a passphrase. - * @param deviceDisplayName - The device display name for the - * dehydrated device. - * @returns A promise that resolves when the dehydrated device is stored. - */ - setDehydrationKey(key: Uint8Array, keyInfo: IDehydratedDeviceKeyInfo, deviceDisplayName?: string): Promise; - /** - * Creates a new dehydrated device (without queuing periodic dehydration) - * @param key - the dehydration key - * @param keyInfo - Information about the key. Primarily for - * information about how to generate the key from a passphrase. - * @param deviceDisplayName - The device display name for the - * dehydrated device. - * @returns the device id of the newly created dehydrated device - */ - createDehydratedDevice(key: Uint8Array, keyInfo: IDehydratedDeviceKeyInfo, deviceDisplayName?: string): Promise; - exportDevice(): Promise; - /** - * Clear any data out of the persistent stores used by the client. - * - * @returns Promise which resolves when the stores have been cleared. - */ - clearStores(): Promise; - /** - * Get the user-id of the logged-in user - * - * @returns MXID for the logged-in user, or null if not logged in - */ - getUserId(): string | null; - /** - * Get the user-id of the logged-in user - * - * @returns MXID for the logged-in user - * @throws Error if not logged in - */ - getSafeUserId(): string; - /** - * Get the domain for this client's MXID - * @returns Domain of this MXID - */ - getDomain(): string | null; - /** - * Get the local part of the current user ID e.g. "foo" in "\@foo:bar". - * @returns The user ID localpart or null. - */ - getUserIdLocalpart(): string | null; - /** - * Get the device ID of this client - * @returns device ID - */ - getDeviceId(): string | null; - /** - * Get the session ID of this client - * @returns session ID - */ - getSessionId(): string; - /** - * Check if the runtime environment supports VoIP calling. - * @returns True if VoIP is supported. - */ - supportsVoip(): boolean; - /** - * @returns - */ - getMediaHandler(): MediaHandler; - /** - * Set whether VoIP calls are forced to use only TURN - * candidates. This is the same as the forceTURN option - * when creating the client. - * @param force - True to force use of TURN servers - */ - setForceTURN(force: boolean): void; - /** - * Set whether to advertise transfer support to other parties on Matrix calls. - * @param support - True to advertise the 'm.call.transferee' capability - */ - setSupportsCallTransfer(support: boolean): void; - /** - * Returns true if to-device signalling for group calls will be encrypted with Olm. - * If false, it will be sent unencrypted. - * @returns boolean Whether group call signalling will be encrypted - */ - getUseE2eForGroupCall(): boolean; - /** - * Creates a new call. - * The place*Call methods on the returned call can be used to actually place a call - * - * @param roomId - The room the call is to be placed in. - * @returns the call or null if the browser doesn't support calling. - */ - createCall(roomId: string): MatrixCall | null; - /** - * Creates a new group call and sends the associated state event - * to alert other members that the room now has a group call. - * - * @param roomId - The room the call is to be placed in. - */ - createGroupCall(roomId: string, type: GroupCallType, isPtt: boolean, intent: GroupCallIntent, dataChannelsEnabled?: boolean, dataChannelOptions?: IGroupCallDataChannelOptions): Promise; - /** - * Wait until an initial state for the given room has been processed by the - * client and the client is aware of any ongoing group calls. Awaiting on - * the promise returned by this method before calling getGroupCallForRoom() - * avoids races where getGroupCallForRoom is called before the state for that - * room has been processed. It does not, however, fix other races, eg. two - * clients both creating a group call at the same time. - * @param roomId - The room ID to wait for - * @returns A promise that resolves once existing group calls in the room - * have been processed. - */ - waitUntilRoomReadyForGroupCalls(roomId: string): Promise; - /** - * Get an existing group call for the provided room. - * @returns The group call or null if it doesn't already exist. - */ - getGroupCallForRoom(roomId: string): GroupCall | null; - /** - * Get the current sync state. - * @returns the sync state, which may be null. - * @see MatrixClient#event:"sync" - */ - getSyncState(): SyncState | null; - /** - * Returns the additional data object associated with - * the current sync state, or null if there is no - * such data. - * Sync errors, if available, are put in the 'error' key of - * this object. - */ - getSyncStateData(): ISyncStateData | null; - /** - * Whether the initial sync has completed. - * @returns True if at least one sync has happened. - */ - isInitialSyncComplete(): boolean; - /** - * Return whether the client is configured for a guest account. - * @returns True if this is a guest access_token (or no token is supplied). - */ - isGuest(): boolean; - /** - * Set whether this client is a guest account. This method is experimental - * and may change without warning. - * @param guest - True if this is a guest account. - */ - setGuest(guest: boolean): void; - /** - * Return the provided scheduler, if any. - * @returns The scheduler or undefined - */ - getScheduler(): MatrixScheduler | undefined; - /** - * Retry a backed off syncing request immediately. This should only be used when - * the user explicitly attempts to retry their lost connection. - * Will also retry any outbound to-device messages currently in the queue to be sent - * (retries of regular outgoing events are handled separately, per-event). - * @returns True if this resulted in a request being retried. - */ - retryImmediately(): boolean; - /** - * Return the global notification EventTimelineSet, if any - * - * @returns the globl notification EventTimelineSet - */ - getNotifTimelineSet(): EventTimelineSet | null; - /** - * Set the global notification EventTimelineSet - * - */ - setNotifTimelineSet(set: EventTimelineSet): void; - /** - * Gets the capabilities of the homeserver. Always returns an object of - * capability keys and their options, which may be empty. - * @param fresh - True to ignore any cached values. - * @returns Promise which resolves to the capabilities of the homeserver - * @returns Rejects: with an error response. - */ - getCapabilities(fresh?: boolean): Promise; - /** - * Initialise support for end-to-end encryption in this client, using libolm. - * - * You should call this method after creating the matrixclient, but *before* - * calling `startClient`, if you want to support end-to-end encryption. - * - * It will return a Promise which will resolve when the crypto layer has been - * successfully initialised. - */ - initCrypto(): Promise; - /** - * Initialise support for end-to-end encryption in this client, using the rust matrix-sdk-crypto. - * - * An alternative to {@link initCrypto}. - * - * *WARNING*: this API is very experimental, should not be used in production, and may change without notice! - * Eventually it will be deprecated and `initCrypto` will do the same thing. - * - * @experimental - * - * @returns a Promise which will resolve when the crypto layer has been - * successfully initialised. - */ - initRustCrypto(): Promise; - /** - * Access the crypto API for this client. - * - * If end-to-end encryption has been enabled for this client (via {@link initCrypto} or {@link initRustCrypto}), - * returns an object giving access to the crypto API. Otherwise, returns `undefined`. - */ - getCrypto(): CryptoApi | undefined; - /** - * Is end-to-end crypto enabled for this client. - * @returns True if end-to-end is enabled. - * @deprecated prefer {@link getCrypto} - */ - isCryptoEnabled(): boolean; - /** - * Get the Ed25519 key for this device - * - * @returns base64-encoded ed25519 key. Null if crypto is - * disabled. - */ - getDeviceEd25519Key(): string | null; - /** - * Get the Curve25519 key for this device - * - * @returns base64-encoded curve25519 key. Null if crypto is - * disabled. - */ - getDeviceCurve25519Key(): string | null; - /** - * @deprecated Does nothing. - */ - uploadKeys(): Promise; - /** - * Download the keys for a list of users and stores the keys in the session - * store. - * @param userIds - The users to fetch. - * @param forceDownload - Always download the keys even if cached. - * - * @returns A promise which resolves to a map userId-\>deviceId-\>{@link DeviceInfo} - */ - downloadKeys(userIds: string[], forceDownload?: boolean): Promise; - /** - * Get the stored device keys for a user id - * - * @param userId - the user to list keys for. - * - * @returns list of devices - */ - getStoredDevicesForUser(userId: string): DeviceInfo[]; - /** - * Get the stored device key for a user id and device id - * - * @param userId - the user to list keys for. - * @param deviceId - unique identifier for the device - * - * @returns device or null - */ - getStoredDevice(userId: string, deviceId: string): DeviceInfo | null; - /** - * Mark the given device as verified - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param verified - whether to mark the device as verified. defaults - * to 'true'. - * - * @returns - * - * @remarks - * Fires {@link CryptoEvent#DeviceVerificationChanged} - */ - setDeviceVerified(userId: string, deviceId: string, verified?: boolean): Promise; - /** - * Mark the given device as blocked/unblocked - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param blocked - whether to mark the device as blocked. defaults - * to 'true'. - * - * @returns - * - * @remarks - * Fires {@link CryptoEvent.DeviceVerificationChanged} - */ - setDeviceBlocked(userId: string, deviceId: string, blocked?: boolean): Promise; - /** - * Mark the given device as known/unknown - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param known - whether to mark the device as known. defaults - * to 'true'. - * - * @returns - * - * @remarks - * Fires {@link CryptoEvent#DeviceVerificationChanged} - */ - setDeviceKnown(userId: string, deviceId: string, known?: boolean): Promise; - private setDeviceVerification; - /** - * Request a key verification from another user, using a DM. - * - * @param userId - the user to request verification with - * @param roomId - the room to use for verification - * - * @returns resolves to a VerificationRequest - * when the request has been sent to the other party. - */ - requestVerificationDM(userId: string, roomId: string): Promise; - /** - * Finds a DM verification request that is already in progress for the given room id - * - * @param roomId - the room to use for verification - * - * @returns the VerificationRequest that is in progress, if any - */ - findVerificationRequestDMInProgress(roomId: string): VerificationRequest | undefined; - /** - * Returns all to-device verification requests that are already in progress for the given user id - * - * @param userId - the ID of the user to query - * - * @returns the VerificationRequests that are in progress - */ - getVerificationRequestsToDeviceInProgress(userId: string): VerificationRequest[]; - /** - * Request a key verification from another user. - * - * @param userId - the user to request verification with - * @param devices - array of device IDs to send requests to. Defaults to - * all devices owned by the user - * - * @returns resolves to a VerificationRequest - * when the request has been sent to the other party. - */ - requestVerification(userId: string, devices?: string[]): Promise; - /** - * Begin a key verification. - * - * @param method - the verification method to use - * @param userId - the user to verify keys with - * @param deviceId - the device to verify - * - * @returns a verification object - * @deprecated Use `requestVerification` instead. - */ - beginKeyVerification(method: string, userId: string, deviceId: string): Verification; - checkSecretStorageKey(key: Uint8Array, info: SecretStorageKeyDescription): Promise; - /** - * Set the global override for whether the client should ever send encrypted - * messages to unverified devices. This provides the default for rooms which - * do not specify a value. - * - * @param value - whether to blacklist all unverified devices by default - * - * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}: - * - * ```javascript - * client.getCrypto().globalBlacklistUnverifiedDevices = value; - * ``` - */ - setGlobalBlacklistUnverifiedDevices(value: boolean): boolean; - /** - * @returns whether to blacklist all unverified devices by default - * - * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}: - * - * ```javascript - * value = client.getCrypto().globalBlacklistUnverifiedDevices; - * ``` - */ - getGlobalBlacklistUnverifiedDevices(): boolean; - /** - * Set whether sendMessage in a room with unknown and unverified devices - * should throw an error and not send them message. This has 'Global' for - * symmetry with setGlobalBlacklistUnverifiedDevices but there is currently - * no room-level equivalent for this setting. - * - * This API is currently UNSTABLE and may change or be removed without notice. - * - * @param value - whether error on unknown devices - * - * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}: - * - * ```ts - * client.getCrypto().globalBlacklistUnverifiedDevices = value; - * ``` - */ - setGlobalErrorOnUnknownDevices(value: boolean): void; - /** - * @returns whether to error on unknown devices - * - * This API is currently UNSTABLE and may change or be removed without notice. - */ - getGlobalErrorOnUnknownDevices(): boolean; - /** - * Get the user's cross-signing key ID. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param type - The type of key to get the ID of. One of - * "master", "self_signing", or "user_signing". Defaults to "master". - * - * @returns the key ID - */ - getCrossSigningId(type?: CrossSigningKey | string): string | null; - /** - * Get the cross signing information for a given user. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param userId - the user ID to get the cross-signing info for. - * - * @returns the cross signing information for the user. - */ - getStoredCrossSigningForUser(userId: string): CrossSigningInfo | null; - /** - * Check whether a given user is trusted. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param userId - The ID of the user to check. - */ - checkUserTrust(userId: string): UserTrustLevel; - /** - * Check whether a given device is trusted. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param userId - The ID of the user whose devices is to be checked. - * @param deviceId - The ID of the device to check - */ - checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel; - /** - * Check whether one of our own devices is cross-signed by our - * user's stored keys, regardless of whether we trust those keys yet. - * - * @param deviceId - The ID of the device to check - * - * @returns true if the device is cross-signed - */ - checkIfOwnDeviceCrossSigned(deviceId: string): boolean; - /** - * Check the copy of our cross-signing key that we have in the device list and - * see if we can get the private key. If so, mark it as trusted. - * @param opts - ICheckOwnCrossSigningTrustOpts object - */ - checkOwnCrossSigningTrust(opts?: ICheckOwnCrossSigningTrustOpts): Promise; - /** - * Checks that a given cross-signing private key matches a given public key. - * This can be used by the getCrossSigningKey callback to verify that the - * private key it is about to supply is the one that was requested. - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkCrossSigningPrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean; - legacyDeviceVerification(userId: string, deviceId: string, method: VerificationMethod): Promise; - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * @param room - the room the event is in - * - * @deprecated Prefer {@link CryptoApi.prepareToEncrypt | `CryptoApi.prepareToEncrypt`}: - * - * ```javascript - * client.getCrypto().prepareToEncrypt(room); - * ``` - */ - prepareToEncrypt(room: Room): void; - /** - * Checks if the user has previously published cross-signing keys - * - * This means downloading the devicelist for the user and checking if the list includes - * the cross-signing pseudo-device. - * - * @deprecated Prefer {@link CryptoApi.userHasCrossSigningKeys | `CryptoApi.userHasCrossSigningKeys`}: - * - * ```javascript - * result = client.getCrypto().userHasCrossSigningKeys(); - * ``` - */ - userHasCrossSigningKeys(): Promise; - /** - * Checks whether cross signing: - * - is enabled on this account and trusted by this device - * - has private keys either cached locally or stored in secret storage - * - * If this function returns false, bootstrapCrossSigning() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapCrossSigning() completes successfully, this function should - * return true. - * @returns True if cross-signing is ready to be used on this device - */ - isCrossSigningReady(): Promise; - /** - * Bootstrap cross-signing by creating keys if needed. If everything is already - * set up, then no changes are made, so this is safe to run to ensure - * cross-signing is ready for use. - * - * This function: - * - creates new cross-signing keys if they are not found locally cached nor in - * secret storage (if it has been setup) - * - * The cross-signing API is currently UNSTABLE and may change without notice. - */ - bootstrapCrossSigning(opts: IBootstrapCrossSigningOpts): Promise; - /** - * Whether to trust a others users signatures of their devices. - * If false, devices will only be considered 'verified' if we have - * verified that device individually (effectively disabling cross-signing). - * - * Default: true - * - * @returns True if trusting cross-signed devices - */ - getCryptoTrustCrossSignedDevices(): boolean; - /** - * See getCryptoTrustCrossSignedDevices - * - * @param val - True to trust cross-signed devices - */ - setCryptoTrustCrossSignedDevices(val: boolean): void; - /** - * Counts the number of end to end session keys that are waiting to be backed up - * @returns Promise which resolves to the number of sessions requiring backup - */ - countSessionsNeedingBackup(): Promise; - /** - * Get information about the encryption of an event - * - * @param event - event to be checked - * @returns The event information. - */ - getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo; - /** - * Create a recovery key from a user-supplied passphrase. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param password - Passphrase string that can be entered by the user - * when restoring the backup as an alternative to entering the recovery key. - * Optional. - * @returns Object with public key metadata, encoded private - * recovery key which should be disposed of after displaying to the user, - * and raw private key to avoid round tripping if needed. - */ - createRecoveryKeyFromPassphrase(password?: string): Promise; - /** - * Checks whether secret storage: - * - is enabled on this account - * - is storing cross-signing private keys - * - is storing session backup key (if enabled) - * - * If this function returns false, bootstrapSecretStorage() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapSecretStorage() completes successfully, this function should - * return true. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @returns True if secret storage is ready to be used on this device - */ - isSecretStorageReady(): Promise; - /** - * Bootstrap Secure Secret Storage if needed by creating a default key. If everything is - * already set up, then no changes are made, so this is safe to run to ensure secret - * storage is ready for use. - * - * This function - * - creates a new Secure Secret Storage key if no default key exists - * - if a key backup exists, it is migrated to store the key in the Secret - * Storage - * - creates a backup if none exists, and one is requested - * - migrates Secure Secret Storage to use the latest algorithm, if an outdated - * algorithm is found - * - */ - bootstrapSecretStorage(opts: ICreateSecretStorageOpts): Promise; - /** - * Add a key for encrypting secrets. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param algorithm - the algorithm used by the key - * @param opts - the options for the algorithm. The properties used - * depend on the algorithm given. - * @param keyName - the name of the key. If not given, a random name will be generated. - * - * @returns An object with: - * keyId: the ID of the key - * keyInfo: details about the key (iv, mac, passphrase) - */ - addSecretStorageKey(algorithm: string, opts: IAddSecretStorageKeyOpts, keyName?: string): Promise<{ - keyId: string; - keyInfo: SecretStorageKeyDescription; - }>; - /** - * Check whether we have a key with a given ID. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param keyId - The ID of the key to check - * for. Defaults to the default key ID if not provided. - * @returns Whether we have the key. - */ - hasSecretStorageKey(keyId?: string): Promise; - /** - * Store an encrypted secret on the server. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - The name of the secret - * @param secret - The secret contents. - * @param keys - The IDs of the keys to use to encrypt the secret or null/undefined - * to use the default (will throw if no default key is set). - */ - storeSecret(name: string, secret: string, keys?: string[]): Promise; - /** - * Get a secret from storage. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - the name of the secret - * - * @returns the contents of the secret - */ - getSecret(name: string): Promise; - /** - * Check if a secret is stored on the server. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - the name of the secret - * @returns map of key name to key info the secret is encrypted - * with, or null if it is not present or not encrypted with a trusted - * key - */ - isSecretStored(name: string): Promise | null>; - /** - * Request a secret from another device. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - the name of the secret to request - * @param devices - the devices to request the secret from - * - * @returns the secret request object - */ - requestSecret(name: string, devices: string[]): ISecretRequest; - /** - * Get the current default key ID for encrypting secrets. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @returns The default key ID or null if no default key ID is set - */ - getDefaultSecretStorageKeyId(): Promise; - /** - * Set the current default key ID for encrypting secrets. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param keyId - The new default key ID - */ - setDefaultSecretStorageKeyId(keyId: string): Promise; - /** - * Checks that a given secret storage private key matches a given public key. - * This can be used by the getSecretStorageKey callback to verify that the - * private key it is about to supply is the one that was requested. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkSecretStoragePrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean; - /** - * Get e2e information on the device that sent an event - * - * @param event - event to be checked - */ - getEventSenderDeviceInfo(event: MatrixEvent): Promise; - /** - * Check if the sender of an event is verified - * - * @param event - event to be checked - * - * @returns true if the sender of this event has been verified using - * {@link MatrixClient#setDeviceVerified}. - */ - isEventSenderVerified(event: MatrixEvent): Promise; - /** - * Get outgoing room key request for this event if there is one. - * @param event - The event to check for - * - * @returns A room key request, or null if there is none - */ - getOutgoingRoomKeyRequest(event: MatrixEvent): Promise; - /** - * Cancel a room key request for this event if one is ongoing and resend the - * request. - * @param event - event of which to cancel and resend the room - * key request. - * @returns A promise that will resolve when the key request is queued - */ - cancelAndResendEventRoomKeyRequest(event: MatrixEvent): Promise; - /** - * Enable end-to-end encryption for a room. This does not modify room state. - * Any messages sent before the returned promise resolves will be sent unencrypted. - * @param roomId - The room ID to enable encryption in. - * @param config - The encryption config for the room. - * @returns A promise that will resolve when encryption is set up. - */ - setRoomEncryption(roomId: string, config: IRoomEncryption): Promise; - /** - * Whether encryption is enabled for a room. - * @param roomId - the room id to query. - * @returns whether encryption is enabled. - */ - isRoomEncrypted(roomId: string): boolean; - /** - * Encrypts and sends a given object via Olm to-device messages to a given - * set of devices. - * - * @param userDeviceMap - mapping from userId to deviceInfo - * - * @param payload - fields to include in the encrypted payload - * - * @returns Promise which - * resolves once the message has been encrypted and sent to the given - * userDeviceMap, and returns the `{ contentMap, deviceInfoByDeviceId }` - * of the successfully sent messages. - */ - encryptAndSendToDevices(userDeviceInfoArr: IOlmDevice[], payload: object): Promise; - /** - * Forces the current outbound group session to be discarded such - * that another one will be created next time an event is sent. - * - * @param roomId - The ID of the room to discard the session for - * - * @deprecated Prefer {@link CryptoApi.forceDiscardSession | `CryptoApi.forceDiscardSession`}: - * - */ - forceDiscardSession(roomId: string): void; - /** - * Get a list containing all of the room keys - * - * This should be encrypted before returning it to the user. - * - * @returns a promise which resolves to a list of session export objects - * - * @deprecated Prefer {@link CryptoApi.exportRoomKeys | `CryptoApi.exportRoomKeys`}: - * - * ```javascript - * sessionData = await client.getCrypto().exportRoomKeys(); - * ``` - */ - exportRoomKeys(): Promise; - /** - * Import a list of room keys previously exported by exportRoomKeys - * - * @param keys - a list of session export objects - * - * @returns a promise which resolves when the keys have been imported - */ - importRoomKeys(keys: IMegolmSessionData[], opts?: IImportRoomKeysOpts): Promise; - /** - * Force a re-check of the local key backup status against - * what's on the server. - * - * @returns Object with backup info (as returned by - * getKeyBackupVersion) in backupInfo and - * trust information (as returned by isKeyBackupTrusted) - * in trustInfo. - */ - checkKeyBackup(): Promise; - /** - * Get information about the current key backup. - * @returns Information object from API or null - */ - getKeyBackupVersion(): Promise; - /** - * @param info - key backup info dict from getKeyBackupVersion() - */ - isKeyBackupTrusted(info: IKeyBackupInfo): Promise; - /** - * @returns true if the client is configured to back up keys to - * the server, otherwise false. If we haven't completed a successful check - * of key backup status yet, returns null. - */ - getKeyBackupEnabled(): boolean | null; - /** - * Enable backing up of keys, using data previously returned from - * getKeyBackupVersion. - * - * @param info - Backup information object as returned by getKeyBackupVersion - * @returns Promise which resolves when complete. - */ - enableKeyBackup(info: IKeyBackupInfo): Promise; - /** - * Disable backing up of keys. - */ - disableKeyBackup(): void; - /** - * Set up the data required to create a new backup version. The backup version - * will not be created and enabled until createKeyBackupVersion is called. - * - * @param password - Passphrase string that can be entered by the user - * when restoring the backup as an alternative to entering the recovery key. - * Optional. - * - * @returns Object that can be passed to createKeyBackupVersion and - * additionally has a 'recovery_key' member with the user-facing recovery key string. - */ - prepareKeyBackupVersion(password?: string | Uint8Array | null, opts?: IKeyBackupPrepareOpts): Promise>; - /** - * Check whether the key backup private key is stored in secret storage. - * @returns map of key name to key info the secret is - * encrypted with, or null if it is not present or not encrypted with a - * trusted key - */ - isKeyBackupKeyStored(): Promise | null>; - /** - * Create a new key backup version and enable it, using the information return - * from prepareKeyBackupVersion. - * - * @param info - Info object from prepareKeyBackupVersion - * @returns Object with 'version' param indicating the version created - */ - createKeyBackupVersion(info: IKeyBackupInfo): Promise; - deleteKeyBackupVersion(version: string): Promise; - private makeKeyBackupPath; - /** - * Back up session keys to the homeserver. - * @param roomId - ID of the room that the keys are for Optional. - * @param sessionId - ID of the session that the keys are for Optional. - * @param version - backup version Optional. - * @param data - Object keys to send - * @returns a promise that will resolve when the keys - * are uploaded - */ - sendKeyBackup(roomId: undefined, sessionId: undefined, version: string | undefined, data: IKeyBackup): Promise; - sendKeyBackup(roomId: string, sessionId: undefined, version: string | undefined, data: IKeyBackup): Promise; - sendKeyBackup(roomId: string, sessionId: string, version: string | undefined, data: IKeyBackup): Promise; - /** - * Marks all group sessions as needing to be backed up and schedules them to - * upload in the background as soon as possible. - */ - scheduleAllGroupSessionsForBackup(): Promise; - /** - * Marks all group sessions as needing to be backed up without scheduling - * them to upload in the background. - * @returns Promise which resolves to the number of sessions requiring a backup. - */ - flagAllGroupSessionsForBackup(): Promise; - isValidRecoveryKey(recoveryKey: string): boolean; - /** - * Get the raw key for a key backup from the password - * Used when migrating key backups into SSSS - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param password - Passphrase - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @returns key backup key - */ - keyBackupKeyFromPassword(password: string, backupInfo: IKeyBackupInfo): Promise; - /** - * Get the raw key for a key backup from the recovery key - * Used when migrating key backups into SSSS - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param recoveryKey - The recovery key - * @returns key backup key - */ - keyBackupKeyFromRecoveryKey(recoveryKey: string): Uint8Array; - /** - * Restore from an existing key backup via a passphrase. - * - * @param password - Passphrase - * @param targetRoomId - Room ID to target a specific room. - * Restores all rooms if omitted. - * @param targetSessionId - Session ID to target a specific session. - * Restores all sessions if omitted. - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @param opts - Optional params such as callbacks - * @returns Status of restoration with `total` and `imported` - * key counts. - */ - restoreKeyBackupWithPassword(password: string, targetRoomId: undefined, targetSessionId: undefined, backupInfo: IKeyBackupInfo, opts: IKeyBackupRestoreOpts): Promise; - restoreKeyBackupWithPassword(password: string, targetRoomId: string, targetSessionId: undefined, backupInfo: IKeyBackupInfo, opts: IKeyBackupRestoreOpts): Promise; - restoreKeyBackupWithPassword(password: string, targetRoomId: string, targetSessionId: string, backupInfo: IKeyBackupInfo, opts: IKeyBackupRestoreOpts): Promise; - /** - * Restore from an existing key backup via a private key stored in secret - * storage. - * - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @param targetRoomId - Room ID to target a specific room. - * Restores all rooms if omitted. - * @param targetSessionId - Session ID to target a specific session. - * Restores all sessions if omitted. - * @param opts - Optional params such as callbacks - * @returns Status of restoration with `total` and `imported` - * key counts. - */ - restoreKeyBackupWithSecretStorage(backupInfo: IKeyBackupInfo, targetRoomId?: string, targetSessionId?: string, opts?: IKeyBackupRestoreOpts): Promise; - /** - * Restore from an existing key backup via an encoded recovery key. - * - * @param recoveryKey - Encoded recovery key - * @param targetRoomId - Room ID to target a specific room. - * Restores all rooms if omitted. - * @param targetSessionId - Session ID to target a specific session. - * Restores all sessions if omitted. - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @param opts - Optional params such as callbacks - - * @returns Status of restoration with `total` and `imported` - * key counts. - */ - restoreKeyBackupWithRecoveryKey(recoveryKey: string, targetRoomId: undefined, targetSessionId: undefined, backupInfo: IKeyBackupInfo, opts?: IKeyBackupRestoreOpts): Promise; - restoreKeyBackupWithRecoveryKey(recoveryKey: string, targetRoomId: string, targetSessionId: undefined, backupInfo: IKeyBackupInfo, opts?: IKeyBackupRestoreOpts): Promise; - restoreKeyBackupWithRecoveryKey(recoveryKey: string, targetRoomId: string, targetSessionId: string, backupInfo: IKeyBackupInfo, opts?: IKeyBackupRestoreOpts): Promise; - restoreKeyBackupWithCache(targetRoomId: undefined, targetSessionId: undefined, backupInfo: IKeyBackupInfo, opts?: IKeyBackupRestoreOpts): Promise; - restoreKeyBackupWithCache(targetRoomId: string, targetSessionId: undefined, backupInfo: IKeyBackupInfo, opts?: IKeyBackupRestoreOpts): Promise; - restoreKeyBackupWithCache(targetRoomId: string, targetSessionId: string, backupInfo: IKeyBackupInfo, opts?: IKeyBackupRestoreOpts): Promise; - private restoreKeyBackup; - deleteKeysFromBackup(roomId: undefined, sessionId: undefined, version?: string): Promise; - deleteKeysFromBackup(roomId: string, sessionId: undefined, version?: string): Promise; - deleteKeysFromBackup(roomId: string, sessionId: string, version?: string): Promise; - /** - * Share shared-history decryption keys with the given users. - * - * @param roomId - the room for which keys should be shared. - * @param userIds - a list of users to share with. The keys will be sent to - * all of the user's current devices. - */ - sendSharedHistoryKeys(roomId: string, userIds: string[]): Promise; - /** - * Get the config for the media repository. - * @returns Promise which resolves with an object containing the config. - */ - getMediaConfig(): Promise; - /** - * Get the room for the given room ID. - * This function will return a valid room for any room for which a Room event - * has been emitted. Note in particular that other events, eg. RoomState.members - * will be emitted for a room before this function will return the given room. - * @param roomId - The room ID - * @returns The Room or null if it doesn't exist or there is no data store. - */ - getRoom(roomId: string | undefined): Room | null; - /** - * Retrieve all known rooms. - * @returns A list of rooms, or an empty list if there is no data store. - */ - getRooms(): Room[]; - /** - * Retrieve all rooms that should be displayed to the user - * This is essentially getRooms() with some rooms filtered out, eg. old versions - * of rooms that have been replaced or (in future) other rooms that have been - * marked at the protocol level as not to be displayed to the user. - * - * @param msc3946ProcessDynamicPredecessor - if true, look for an - * m.room.predecessor state event and - * use it if found (MSC3946). - * @returns A list of rooms, or an empty list if there is no data store. - */ - getVisibleRooms(msc3946ProcessDynamicPredecessor?: boolean): Room[]; - /** - * Retrieve a user. - * @param userId - The user ID to retrieve. - * @returns A user or null if there is no data store or the user does - * not exist. - */ - getUser(userId: string): User | null; - /** - * Retrieve all known users. - * @returns A list of users, or an empty list if there is no data store. - */ - getUsers(): User[]; - /** - * Set account data event for the current user. - * It will retry the request up to 5 times. - * @param eventType - The event type - * @param content - the contents object for the event - * @returns Promise which resolves: an empty object - * @returns Rejects: with an error response. - */ - setAccountData(eventType: EventType | string, content: IContent): Promise<{}>; - /** - * Get account data event of given type for the current user. - * @param eventType - The event type - * @returns The contents of the given account data event - */ - getAccountData(eventType: string): MatrixEvent | undefined; - /** - * Get account data event of given type for the current user. This variant - * gets account data directly from the homeserver if the local store is not - * ready, which can be useful very early in startup before the initial sync. - * @param eventType - The event type - * @returns Promise which resolves: The contents of the given account data event. - * @returns Rejects: with an error response. - */ - getAccountDataFromServer(eventType: string): Promise; - deleteAccountData(eventType: string): Promise; - /** - * Gets the users that are ignored by this client - * @returns The array of users that are ignored (empty if none) - */ - getIgnoredUsers(): string[]; - /** - * Sets the users that the current user should ignore. - * @param userIds - the user IDs to ignore - * @returns Promise which resolves: an empty object - * @returns Rejects: with an error response. - */ - setIgnoredUsers(userIds: string[]): Promise<{}>; - /** - * Gets whether or not a specific user is being ignored by this client. - * @param userId - the user ID to check - * @returns true if the user is ignored, false otherwise - */ - isUserIgnored(userId: string): boolean; - /** - * Join a room. If you have already joined the room, this will no-op. - * @param roomIdOrAlias - The room ID or room alias to join. - * @param opts - Options when joining the room. - * @returns Promise which resolves: Room object. - * @returns Rejects: with an error response. - */ - joinRoom(roomIdOrAlias: string, opts?: IJoinRoomOpts): Promise; - /** - * Resend an event. Will also retry any to-device messages waiting to be sent. - * @param event - The event to resend. - * @param room - Optional. The room the event is in. Will update the - * timeline entry if provided. - * @returns Promise which resolves: to an ISendEventResponse object - * @returns Rejects: with an error response. - */ - resendEvent(event: MatrixEvent, room: Room): Promise; - /** - * Cancel a queued or unsent event. - * - * @param event - Event to cancel - * @throws Error if the event is not in QUEUED, NOT_SENT or ENCRYPTING state - */ - cancelPendingEvent(event: MatrixEvent): void; - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - setRoomName(roomId: string, name: string): Promise; - /** - * @param htmlTopic - Optional. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - setRoomTopic(roomId: string, topic: string, htmlTopic?: string): Promise; - /** - * @returns Promise which resolves: to an object keyed by tagId with objects containing a numeric order field. - * @returns Rejects: with an error response. - */ - getRoomTags(roomId: string): Promise; - /** - * @param tagName - name of room tag to be set - * @param metadata - associated with that tag to be stored - * @returns Promise which resolves: to an empty object - * @returns Rejects: with an error response. - */ - setRoomTag(roomId: string, tagName: string, metadata: ITagMetadata): Promise<{}>; - /** - * @param tagName - name of room tag to be removed - * @returns Promise which resolves: to an empty object - * @returns Rejects: with an error response. - */ - deleteRoomTag(roomId: string, tagName: string): Promise<{}>; - /** - * @param eventType - event type to be set - * @param content - event content - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setRoomAccountData(roomId: string, eventType: string, content: Record): Promise<{}>; - /** - * Set a power level to one or multiple users. - * @returns Promise which resolves: to an ISendEventResponse object - * @returns Rejects: with an error response. - */ - setPowerLevel(roomId: string, userId: string | string[], powerLevel: number | undefined, event: MatrixEvent | null): Promise; - /** - * Create an m.beacon_info event - * @returns - */ - unstable_createLiveBeacon(roomId: Room["roomId"], beaconInfoContent: MBeaconInfoEventContent): Promise; - /** - * Upsert a live beacon event - * using a specific m.beacon_info.* event variable type - * @param roomId - string - * @returns - */ - unstable_setLiveBeacon(roomId: string, beaconInfoContent: MBeaconInfoEventContent): Promise; - sendEvent(roomId: string, eventType: string, content: IContent, txnId?: string): Promise; - sendEvent(roomId: string, threadId: string | null, eventType: string, content: IContent, txnId?: string): Promise; - /** - * @param eventObject - An object with the partial structure of an event, to which event_id, user_id, room_id and origin_server_ts will be added. - * @param txnId - Optional. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - private sendCompleteEvent; - /** - * encrypts the event if necessary; adds the event to the queue, or sends it; marks the event as sent/unsent - * @returns returns a promise which resolves with the result of the send request - */ - protected encryptAndSendEvent(room: Room | null, event: MatrixEvent): Promise; - private encryptEventIfNeeded; - /** - * Returns the eventType that should be used taking encryption into account - * for a given eventType. - * @param roomId - the room for the events `eventType` relates to - * @param eventType - the event type - * @returns the event type taking encryption into account - */ - private getEncryptedIfNeededEventType; - protected updatePendingEventStatus(room: Room | null, event: MatrixEvent, newStatus: EventStatus): void; - private sendEventHttpRequest; - /** - * @param txnId - transaction id. One will be made up if not supplied. - * @param opts - Options to pass on, may contain `reason` and `with_relations` (MSC3912) - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - * @throws Error if called with `with_relations` (MSC3912) but the server does not support it. - * Callers should check whether the server supports MSC3912 via `MatrixClient.canSupport`. - */ - redactEvent(roomId: string, eventId: string, txnId?: string | undefined, opts?: IRedactOpts): Promise; - redactEvent(roomId: string, threadId: string | null, eventId: string, txnId?: string | undefined, opts?: IRedactOpts): Promise; - /** - * @param txnId - Optional. - * @returns Promise which resolves: to an ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendMessage(roomId: string, content: IContent, txnId?: string): Promise; - sendMessage(roomId: string, threadId: string | null, content: IContent, txnId?: string): Promise; - /** - * @param txnId - Optional. - * @returns - * @returns Rejects: with an error response. - */ - sendTextMessage(roomId: string, body: string, txnId?: string): Promise; - sendTextMessage(roomId: string, threadId: string | null, body: string, txnId?: string): Promise; - /** - * @param txnId - Optional. - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendNotice(roomId: string, body: string, txnId?: string): Promise; - sendNotice(roomId: string, threadId: string | null, body: string, txnId?: string): Promise; - /** - * @param txnId - Optional. - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendEmoteMessage(roomId: string, body: string, txnId?: string): Promise; - sendEmoteMessage(roomId: string, threadId: string | null, body: string, txnId?: string): Promise; - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendImageMessage(roomId: string, url: string, info?: IImageInfo, text?: string): Promise; - sendImageMessage(roomId: string, threadId: string | null, url: string, info?: IImageInfo, text?: string): Promise; - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendStickerMessage(roomId: string, url: string, info?: IImageInfo, text?: string): Promise; - sendStickerMessage(roomId: string, threadId: string | null, url: string, info?: IImageInfo, text?: string): Promise; - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendHtmlMessage(roomId: string, body: string, htmlBody: string): Promise; - sendHtmlMessage(roomId: string, threadId: string | null, body: string, htmlBody: string): Promise; - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendHtmlNotice(roomId: string, body: string, htmlBody: string): Promise; - sendHtmlNotice(roomId: string, threadId: string | null, body: string, htmlBody: string): Promise; - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - sendHtmlEmote(roomId: string, body: string, htmlBody: string): Promise; - sendHtmlEmote(roomId: string, threadId: string | null, body: string, htmlBody: string): Promise; - /** - * Send a receipt. - * @param event - The event being acknowledged - * @param receiptType - The kind of receipt e.g. "m.read". Other than - * ReceiptType.Read are experimental! - * @param body - Additional content to send alongside the receipt. - * @param unthreaded - An unthreaded receipt will clear room+thread notifications - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - sendReceipt(event: MatrixEvent, receiptType: ReceiptType, body: any, unthreaded?: boolean): Promise<{}>; - /** - * Send a read receipt. - * @param event - The event that has been read. - * @param receiptType - other than ReceiptType.Read are experimental! Optional. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - sendReadReceipt(event: MatrixEvent | null, receiptType?: ReceiptType, unthreaded?: boolean): Promise<{} | undefined>; - /** - * Set a marker to indicate the point in a room before which the user has read every - * event. This can be retrieved from room account data (the event type is `m.fully_read`) - * and displayed as a horizontal line in the timeline that is visually distinct to the - * position of the user's own read receipt. - * @param roomId - ID of the room that has been read - * @param rmEventId - ID of the event that has been read - * @param rrEvent - the event tracked by the read receipt. This is here for - * convenience because the RR and the RM are commonly updated at the same time as each - * other. The local echo of this receipt will be done if set. Optional. - * @param rpEvent - the m.read.private read receipt event for when we don't - * want other users to see the read receipts. This is experimental. Optional. - * @returns Promise which resolves: the empty object, `{}`. - */ - setRoomReadMarkers(roomId: string, rmEventId: string, rrEvent?: MatrixEvent, rpEvent?: MatrixEvent): Promise<{}>; - /** - * Get a preview of the given URL as of (roughly) the given point in time, - * described as an object with OpenGraph keys and associated values. - * Attributes may be synthesized where actual OG metadata is lacking. - * Caches results to prevent hammering the server. - * @param url - The URL to get preview data for - * @param ts - The preferred point in time that the preview should - * describe (ms since epoch). The preview returned will either be the most - * recent one preceding this timestamp if available, or failing that the next - * most recent available preview. - * @returns Promise which resolves: Object of OG metadata. - * @returns Rejects: with an error response. - * May return synthesized attributes if the URL lacked OG meta. - */ - getUrlPreview(url: string, ts: number): Promise; - /** - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - sendTyping(roomId: string, isTyping: boolean, timeoutMs: number): Promise<{}>; - /** - * Determines the history of room upgrades for a given room, as far as the - * client can see. Returns an array of Rooms where the first entry is the - * oldest and the last entry is the newest (likely current) room. If the - * provided room is not found, this returns an empty list. This works in - * both directions, looking for older and newer rooms of the given room. - * @param roomId - The room ID to search from - * @param verifyLinks - If true, the function will only return rooms - * which can be proven to be linked. For example, rooms which have a create - * event pointing to an old room which the client is not aware of or doesn't - * have a matching tombstone would not be returned. - * @param msc3946ProcessDynamicPredecessor - if true, look for - * m.room.predecessor state events as well as create events, and prefer - * predecessor events where they exist (MSC3946). - * @returns An array of rooms representing the upgrade - * history. - */ - getRoomUpgradeHistory(roomId: string, verifyLinks?: boolean, msc3946ProcessDynamicPredecessor?: boolean): Room[]; - private findPredecessorRooms; - private findSuccessorRooms; - /** - * @param reason - Optional. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - invite(roomId: string, userId: string, reason?: string): Promise<{}>; - /** - * Invite a user to a room based on their email address. - * @param roomId - The room to invite the user to. - * @param email - The email address to invite. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - inviteByEmail(roomId: string, email: string): Promise<{}>; - /** - * Invite a user to a room based on a third-party identifier. - * @param roomId - The room to invite the user to. - * @param medium - The medium to invite the user e.g. "email". - * @param address - The address for the specified medium. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - inviteByThreePid(roomId: string, medium: string, address: string): Promise<{}>; - /** - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - leave(roomId: string): Promise<{}>; - /** - * Leaves all rooms in the chain of room upgrades based on the given room. By - * default, this will leave all the previous and upgraded rooms, including the - * given room. To only leave the given room and any previous rooms, keeping the - * upgraded (modern) rooms untouched supply `false` to `includeFuture`. - * @param roomId - The room ID to start leaving at - * @param includeFuture - If true, the whole chain (past and future) of - * upgraded rooms will be left. - * @returns Promise which resolves when completed with an object keyed - * by room ID and value of the error encountered when leaving or null. - */ - leaveRoomChain(roomId: string, includeFuture?: boolean): Promise<{ - [roomId: string]: Error | MatrixError | null; - }>; - /** - * @param reason - Optional. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - ban(roomId: string, userId: string, reason?: string): Promise<{}>; - /** - * @param deleteRoom - True to delete the room from the store on success. - * Default: true. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - forget(roomId: string, deleteRoom?: boolean): Promise<{}>; - /** - * @returns Promise which resolves: Object (currently empty) - * @returns Rejects: with an error response. - */ - unban(roomId: string, userId: string): Promise<{}>; - /** - * @param reason - Optional. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - kick(roomId: string, userId: string, reason?: string): Promise<{}>; - private membershipChange; - /** - * Obtain a dict of actions which should be performed for this event according - * to the push rules for this user. Caches the dict on the event. - * @param event - The event to get push actions for. - * @param forceRecalculate - forces to recalculate actions for an event - * Useful when an event just got decrypted - * @returns A dict of actions to perform. - */ - getPushActionsForEvent(event: MatrixEvent, forceRecalculate?: boolean): IActionsObject | null; - /** - * @param info - The kind of info to set (e.g. 'avatar_url') - * @param data - The JSON object to set. - * @returns - * @returns Rejects: with an error response. - */ - setProfileInfo(info: "avatar_url", data: { - avatar_url: string; - }): Promise<{}>; - setProfileInfo(info: "displayname", data: { - displayname: string; - }): Promise<{}>; - /** - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - setDisplayName(name: string): Promise<{}>; - /** - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - setAvatarUrl(url: string): Promise<{}>; - /** - * Turn an MXC URL into an HTTP one. This method is experimental and - * may change. - * @param mxcUrl - The MXC URL - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDirectLinks - If true, return any non-mxc URLs - * directly. Fetching such URLs will leak information about the user to - * anyone they share a room with. If false, will return null for such URLs. - * @returns the avatar URL or null. - */ - mxcUrlToHttp(mxcUrl: string, width?: number, height?: number, resizeMethod?: string, allowDirectLinks?: boolean): string | null; - /** - * @param opts - Options to apply - * @returns Promise which resolves - * @returns Rejects: with an error response. - * @throws If 'presence' isn't a valid presence enum value. - */ - setPresence(opts: IPresenceOpts): Promise; - /** - * @param userId - The user to get presence for - * @returns Promise which resolves: The presence state for this user. - * @returns Rejects: with an error response. - */ - getPresence(userId: string): Promise; - /** - * Retrieve older messages from the given room and put them in the timeline. - * - * If this is called multiple times whilst a request is ongoing, the same - * Promise will be returned. If there was a problem requesting scrollback, there - * will be a small delay before another request can be made (to prevent tight-looping - * when there is no connection). - * - * @param room - The room to get older messages in. - * @param limit - Optional. The maximum number of previous events to - * pull in. Default: 30. - * @returns Promise which resolves: Room. If you are at the beginning - * of the timeline, `Room.oldState.paginationToken` will be - * `null`. - * @returns Rejects: with an error response. - */ - scrollback(room: Room, limit?: number): Promise; - getEventMapper(options?: MapperOpts): EventMapper; - /** - * Get an EventTimeline for the given event - * - *

If the EventTimelineSet object already has the given event in its store, the - * corresponding timeline will be returned. Otherwise, a /context request is - * made, and used to construct an EventTimeline. - * If the event does not belong to this EventTimelineSet then undefined will be returned. - * - * @param timelineSet - The timelineSet to look for the event in, must be bound to a room - * @param eventId - The ID of the event to look for - * - * @returns Promise which resolves: - * {@link EventTimeline} including the given event - */ - getEventTimeline(timelineSet: EventTimelineSet, eventId: string): Promise>; - getThreadTimeline(timelineSet: EventTimelineSet, eventId: string): Promise; - /** - * Get an EventTimeline for the latest events in the room. This will just - * call `/messages` to get the latest message in the room, then use - * `client.getEventTimeline(...)` to construct a new timeline from it. - * - * @param timelineSet - The timelineSet to find or add the timeline to - * - * @returns Promise which resolves: - * {@link EventTimeline} timeline with the latest events in the room - */ - getLatestTimeline(timelineSet: EventTimelineSet): Promise>; - /** - * Makes a request to /messages with the appropriate lazy loading filter set. - * XXX: if we do get rid of scrollback (as it's not used at the moment), - * we could inline this method again in paginateEventTimeline as that would - * then be the only call-site - * @param limit - the maximum amount of events the retrieve - * @param dir - 'f' or 'b' - * @param timelineFilter - the timeline filter to pass - */ - createMessagesRequest(roomId: string, fromToken: string | null, limit: number | undefined, dir: Direction, timelineFilter?: Filter): Promise; - /** - * Makes a request to /messages with the appropriate lazy loading filter set. - * XXX: if we do get rid of scrollback (as it's not used at the moment), - * we could inline this method again in paginateEventTimeline as that would - * then be the only call-site - * @param limit - the maximum amount of events the retrieve - * @param dir - 'f' or 'b' - * @param timelineFilter - the timeline filter to pass - */ - createThreadListMessagesRequest(roomId: string, fromToken: string | null, limit?: number, dir?: Direction, threadListType?: ThreadFilterType | null, timelineFilter?: Filter): Promise; - /** - * Take an EventTimeline, and back/forward-fill results. - * - * @param eventTimeline - timeline object to be updated - * - * @returns Promise which resolves to a boolean: false if there are no - * events and we reached either end of the timeline; else true. - */ - paginateEventTimeline(eventTimeline: EventTimeline, opts: IPaginateOpts): Promise; - /** - * Reset the notifTimelineSet entirely, paginating in some historical notifs as - * a starting point for subsequent pagination. - */ - resetNotifTimelineSet(): void; - /** - * Peek into a room and receive updates about the room. This only works if the - * history visibility for the room is world_readable. - * @param roomId - The room to attempt to peek into. - * @returns Promise which resolves: Room object - * @returns Rejects: with an error response. - */ - peekInRoom(roomId: string): Promise; - /** - * Stop any ongoing room peeking. - */ - stopPeeking(): void; - /** - * Set r/w flags for guest access in a room. - * @param roomId - The room to configure guest access in. - * @param opts - Options - * @returns Promise which resolves - * @returns Rejects: with an error response. - */ - setGuestAccess(roomId: string, opts: IGuestAccessOpts): Promise; - /** - * Requests an email verification token for the purposes of registration. - * This API requests a token from the homeserver. - * The doesServerRequireIdServerParam() method can be used to determine if - * the server requires the id_server parameter to be provided. - * - * Parameters and return value are as for requestEmailToken - - * @param email - As requestEmailToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestRegisterEmailToken(email: string, clientSecret: string, sendAttempt: number, nextLink?: string): Promise; - /** - * Requests a text message verification token for the purposes of registration. - * This API requests a token from the homeserver. - * The doesServerRequireIdServerParam() method can be used to determine if - * the server requires the id_server parameter to be provided. - * - * @param phoneCountry - The ISO 3166-1 alpha-2 code for the country in which - * phoneNumber should be parsed relative to. - * @param phoneNumber - The phone number, in national or international format - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestRegisterMsisdnToken(phoneCountry: string, phoneNumber: string, clientSecret: string, sendAttempt: number, nextLink?: string): Promise; - /** - * Requests an email verification token for the purposes of adding a - * third party identifier to an account. - * This API requests a token from the homeserver. - * The doesServerRequireIdServerParam() method can be used to determine if - * the server requires the id_server parameter to be provided. - * If an account with the given email address already exists and is - * associated with an account other than the one the user is authed as, - * it will either send an email to the address informing them of this - * or return M_THREEPID_IN_USE (which one is up to the homeserver). - * - * @param email - As requestEmailToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestAdd3pidEmailToken(email: string, clientSecret: string, sendAttempt: number, nextLink?: string): Promise; - /** - * Requests a text message verification token for the purposes of adding a - * third party identifier to an account. - * This API proxies the identity server /validate/email/requestToken API, - * adding specific behaviour for the addition of phone numbers to an - * account, as requestAdd3pidEmailToken. - * - * @param phoneCountry - As requestRegisterMsisdnToken - * @param phoneNumber - As requestRegisterMsisdnToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestAdd3pidMsisdnToken(phoneCountry: string, phoneNumber: string, clientSecret: string, sendAttempt: number, nextLink?: string): Promise; - /** - * Requests an email verification token for the purposes of resetting - * the password on an account. - * This API proxies the identity server /validate/email/requestToken API, - * adding specific behaviour for the password resetting. Specifically, - * if no account with the given email address exists, it may either - * return M_THREEPID_NOT_FOUND or send an email - * to the address informing them of this (which one is up to the homeserver). - * - * requestEmailToken calls the equivalent API directly on the identity server, - * therefore bypassing the password reset specific logic. - * - * @param email - As requestEmailToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestPasswordEmailToken(email: string, clientSecret: string, sendAttempt: number, nextLink?: string): Promise; - /** - * Requests a text message verification token for the purposes of resetting - * the password on an account. - * This API proxies the identity server /validate/email/requestToken API, - * adding specific behaviour for the password resetting, as requestPasswordEmailToken. - * - * @param phoneCountry - As requestRegisterMsisdnToken - * @param phoneNumber - As requestRegisterMsisdnToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestPasswordMsisdnToken(phoneCountry: string, phoneNumber: string, clientSecret: string, sendAttempt: number, nextLink: string): Promise; - /** - * Internal utility function for requesting validation tokens from usage-specific - * requestToken endpoints. - * - * @param endpoint - The endpoint to send the request to - * @param params - Parameters for the POST request - * @returns Promise which resolves: As requestEmailToken - */ - private requestTokenFromEndpoint; - /** - * Get the room-kind push rule associated with a room. - * @param scope - "global" or device-specific. - * @param roomId - the id of the room. - * @returns the rule or undefined. - */ - getRoomPushRule(scope: "global" | "device", roomId: string): IPushRule | undefined; - /** - * Set a room-kind muting push rule in a room. - * The operation also updates MatrixClient.pushRules at the end. - * @param scope - "global" or device-specific. - * @param roomId - the id of the room. - * @param mute - the mute state. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - setRoomMutePushRule(scope: "global" | "device", roomId: string, mute: boolean): Promise | undefined; - searchMessageText(opts: ISearchOpts): Promise; - /** - * Perform a server-side search for room events. - * - * The returned promise resolves to an object containing the fields: - * - * * count: estimate of the number of results - * * next_batch: token for back-pagination; if undefined, there are no more results - * * highlights: a list of words to highlight from the stemming algorithm - * * results: a list of results - * - * Each entry in the results list is a SearchResult. - * - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - searchRoomEvents(opts: IEventSearchOpts): Promise; - /** - * Take a result from an earlier searchRoomEvents call, and backfill results. - * - * @param searchResults - the results object to be updated - * @returns Promise which resolves: updated result object - * @returns Rejects: with an error response. - */ - backPaginateRoomEventsSearch(searchResults: T): Promise; - /** - * helper for searchRoomEvents and backPaginateRoomEventsSearch. Processes the - * response from the API call and updates the searchResults - * - * @returns searchResults - * @internal - */ - processRoomEventsSearch(searchResults: T, response: ISearchResponse): T; - /** - * Populate the store with rooms the user has left. - * @returns Promise which resolves: TODO - Resolved when the rooms have - * been added to the data store. - * @returns Rejects: with an error response. - */ - syncLeftRooms(): Promise; - /** - * Create a new filter. - * @param content - The HTTP body for the request - * @returns Promise which resolves to a Filter object. - * @returns Rejects: with an error response. - */ - createFilter(content: IFilterDefinition): Promise; - /** - * Retrieve a filter. - * @param userId - The user ID of the filter owner - * @param filterId - The filter ID to retrieve - * @param allowCached - True to allow cached filters to be returned. - * Default: True. - * @returns Promise which resolves: a Filter object - * @returns Rejects: with an error response. - */ - getFilter(userId: string, filterId: string, allowCached: boolean): Promise; - /** - * @returns Filter ID - */ - getOrCreateFilter(filterName: string, filter: Filter): Promise; - /** - * Gets a bearer token from the homeserver that the user can - * present to a third party in order to prove their ownership - * of the Matrix account they are logged into. - * @returns Promise which resolves: Token object - * @returns Rejects: with an error response. - */ - getOpenIdToken(): Promise; - private startCallEventHandler; - /** - * Once the client has been initialised, we want to clear notifications we - * know for a fact should be here. - * This issue should also be addressed on synapse's side and is tracked as part - * of https://github.com/matrix-org/synapse/issues/14837 - * - * We consider a room or a thread as fully read if the current user has sent - * the last event in the live timeline of that context and if the read receipt - * we have on record matches. - */ - private fixupRoomNotifications; - /** - * @returns Promise which resolves: ITurnServerResponse object - * @returns Rejects: with an error response. - */ - turnServer(): Promise; - /** - * Get the TURN servers for this homeserver. - * @returns The servers or an empty list. - */ - getTurnServers(): ITurnServer[]; - /** - * Get the unix timestamp (in milliseconds) at which the current - * TURN credentials (from getTurnServers) expire - * @returns The expiry timestamp in milliseconds - */ - getTurnServersExpiry(): number; - get pollingTurnServers(): boolean; - checkTurnServers(): Promise; - /** - * Set whether to allow a fallback ICE server should be used for negotiating a - * WebRTC connection if the homeserver doesn't provide any servers. Defaults to - * false. - * - */ - setFallbackICEServerAllowed(allow: boolean): void; - /** - * Get whether to allow a fallback ICE server should be used for negotiating a - * WebRTC connection if the homeserver doesn't provide any servers. Defaults to - * false. - * - * @returns - */ - isFallbackICEServerAllowed(): boolean; - /** - * Determines if the current user is an administrator of the Synapse homeserver. - * Returns false if untrue or the homeserver does not appear to be a Synapse - * homeserver. This function is implementation specific and may change - * as a result. - * @returns true if the user appears to be a Synapse administrator. - */ - isSynapseAdministrator(): Promise; - /** - * Performs a whois lookup on a user using Synapse's administrator API. - * This function is implementation specific and may change as a - * result. - * @param userId - the User ID to look up. - * @returns the whois response - see Synapse docs for information. - */ - whoisSynapseUser(userId: string): Promise; - /** - * Deactivates a user using Synapse's administrator API. This - * function is implementation specific and may change as a result. - * @param userId - the User ID to deactivate. - * @returns the deactivate response - see Synapse docs for information. - */ - deactivateSynapseUser(userId: string): Promise; - private fetchClientWellKnown; - getClientWellKnown(): IClientWellKnown | undefined; - waitForClientWellKnown(): Promise; - /** - * store client options with boolean/string/numeric values - * to know in the next session what flags the sync data was - * created with (e.g. lazy loading) - * @param opts - the complete set of client options - * @returns for store operation - */ - storeClientOptions(): Promise; - /** - * Gets a set of room IDs in common with another user - * @param userId - The userId to check. - * @returns Promise which resolves to a set of rooms - * @returns Rejects: with an error response. - */ - _unstable_getSharedRooms(userId: string): Promise; - /** - * Get the API versions supported by the server, along with any - * unstable APIs it supports - * @returns The server /versions response - */ - getVersions(): Promise; - /** - * Check if a particular spec version is supported by the server. - * @param version - The spec version (such as "r0.5.0") to check for. - * @returns Whether it is supported - */ - isVersionSupported(version: string): Promise; - /** - * Query the server to see if it supports members lazy loading - * @returns true if server supports lazy loading - */ - doesServerSupportLazyLoading(): Promise; - /** - * Query the server to see if the `id_server` parameter is required - * when registering with an 3pid, adding a 3pid or resetting password. - * @returns true if id_server parameter is required - */ - doesServerRequireIdServerParam(): Promise; - /** - * Query the server to see if the `id_access_token` parameter can be safely - * passed to the homeserver. Some homeservers may trigger errors if they are not - * prepared for the new parameter. - * @returns true if id_access_token can be sent - */ - doesServerAcceptIdentityAccessToken(): Promise; - /** - * Query the server to see if it supports separate 3PID add and bind functions. - * This affects the sequence of API calls clients should use for these operations, - * so it's helpful to be able to check for support. - * @returns true if separate functions are supported - */ - doesServerSupportSeparateAddAndBind(): Promise; - /** - * Query the server to see if it lists support for an unstable feature - * in the /versions response - * @param feature - the feature name - * @returns true if the feature is supported - */ - doesServerSupportUnstableFeature(feature: string): Promise; - /** - * Query the server to see if it is forcing encryption to be enabled for - * a given room preset, based on the /versions response. - * @param presetName - The name of the preset to check. - * @returns true if the server is forcing encryption - * for the preset. - */ - doesServerForceEncryptionForPreset(presetName: Preset): Promise; - doesServerSupportThread(): Promise<{ - threads: FeatureSupport; - list: FeatureSupport; - fwdPagination: FeatureSupport; - }>; - /** - * Query the server to see if it supports the MSC2457 `logout_devices` parameter when setting password - * @returns true if server supports the `logout_devices` parameter - */ - doesServerSupportLogoutDevices(): Promise; - /** - * Get if lazy loading members is being used. - * @returns Whether or not members are lazy loaded by this client - */ - hasLazyLoadMembersEnabled(): boolean; - /** - * Set a function which is called when /sync returns a 'limited' response. - * It is called with a room ID and returns a boolean. It should return 'true' if the SDK - * can SAFELY remove events from this room. It may not be safe to remove events if there - * are other references to the timelines for this room, e.g because the client is - * actively viewing events in this room. - * Default: returns false. - * @param cb - The callback which will be invoked. - */ - setCanResetTimelineCallback(cb: ResetTimelineCallback): void; - /** - * Get the callback set via `setCanResetTimelineCallback`. - * @returns The callback or null - */ - getCanResetTimelineCallback(): ResetTimelineCallback | undefined; - /** - * Returns relations for a given event. Handles encryption transparently, - * with the caveat that the amount of events returned might be 0, even though you get a nextBatch. - * When the returned promise resolves, all messages should have finished trying to decrypt. - * @param roomId - the room of the event - * @param eventId - the id of the event - * @param relationType - the rel_type of the relations requested - * @param eventType - the event type of the relations requested - * @param opts - options with optional values for the request. - * @returns an object with `events` as `MatrixEvent[]` and optionally `nextBatch` if more relations are available. - */ - relations(roomId: string, eventId: string, relationType?: RelationType | string | null, eventType?: EventType | string | null, opts?: IRelationsRequestOpts): Promise<{ - originalEvent?: MatrixEvent | null; - events: MatrixEvent[]; - nextBatch?: string | null; - prevBatch?: string | null; - }>; - /** - * The app may wish to see if we have a key cached without - * triggering a user interaction. - */ - getCrossSigningCacheCallbacks(): ICacheCallbacks | undefined; - /** - * Generates a random string suitable for use as a client secret. This - * method is experimental and may change. - * @returns A new client secret - */ - generateClientSecret(): string; - /** - * Attempts to decrypt an event - * @param event - The event to decrypt - * @returns A decryption promise - */ - decryptEventIfNeeded(event: MatrixEvent, options?: IDecryptOptions): Promise; - private termsUrlForService; - /** - * Get the Homeserver URL of this client - * @returns Homeserver URL of this client - */ - getHomeserverUrl(): string; - /** - * Get the identity server URL of this client - * @param stripProto - whether or not to strip the protocol from the URL - * @returns Identity server URL of this client - */ - getIdentityServerUrl(stripProto?: boolean): string | undefined; - /** - * Set the identity server URL of this client - * @param url - New identity server URL - */ - setIdentityServerUrl(url: string): void; - /** - * Get the access token associated with this account. - * @returns The access_token or null - */ - getAccessToken(): string | null; - /** - * Set the access token associated with this account. - * @param token - The new access token. - */ - setAccessToken(token: string): void; - /** - * @returns true if there is a valid access_token for this client. - */ - isLoggedIn(): boolean; - /** - * Make up a new transaction id - * - * @returns a new, unique, transaction id - */ - makeTxnId(): string; - /** - * Check whether a username is available prior to registration. An error response - * indicates an invalid/unavailable username. - * @param username - The username to check the availability of. - * @returns Promise which resolves: to boolean of whether the username is available. - */ - isUsernameAvailable(username: string): Promise; - /** - * @param bindThreepids - Set key 'email' to true to bind any email - * threepid uses during registration in the identity server. Set 'msisdn' to - * true to bind msisdn. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - register(username: string, password: string, sessionId: string | null, auth: { - session?: string; - type: string; - }, bindThreepids?: boolean | null | { - email?: boolean; - msisdn?: boolean; - }, guestAccessToken?: string, inhibitLogin?: boolean): Promise; - /** - * Register a guest account. - * This method returns the auth info needed to create a new authenticated client, - * Remember to call `setGuest(true)` on the (guest-)authenticated client, e.g: - * ```javascript - * const tmpClient = await sdk.createClient(MATRIX_INSTANCE); - * const { user_id, device_id, access_token } = tmpClient.registerGuest(); - * const client = createClient({ - * baseUrl: MATRIX_INSTANCE, - * accessToken: access_token, - * userId: user_id, - * deviceId: device_id, - * }) - * client.setGuest(true); - * ``` - * - * @param body - JSON HTTP body to provide. - * @returns Promise which resolves: JSON object that contains: - * `{ user_id, device_id, access_token, home_server }` - * @returns Rejects: with an error response. - */ - registerGuest({ body }?: { - body?: any; - }): Promise; - /** - * @param data - parameters for registration request - * @param kind - type of user to register. may be "guest" - * @returns Promise which resolves: to the /register response - * @returns Rejects: with an error response. - */ - registerRequest(data: IRegisterRequestParams, kind?: string): Promise; - /** - * Refreshes an access token using a provided refresh token. The refresh token - * must be valid for the current access token known to the client instance. - * - * Note that this function will not cause a logout if the token is deemed - * unknown by the server - the caller is responsible for managing logout - * actions on error. - * @param refreshToken - The refresh token. - * @returns Promise which resolves to the new token. - * @returns Rejects with an error response. - */ - refreshToken(refreshToken: string): Promise; - /** - * @returns Promise which resolves to the available login flows - * @returns Rejects: with an error response. - */ - loginFlows(): Promise; - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - login(loginType: string, data: any): Promise; - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - loginWithPassword(user: string, password: string): Promise; - /** - * @param relayState - URL Callback after SAML2 Authentication - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - loginWithSAML2(relayState: string): Promise; - /** - * @param redirectUrl - The URL to redirect to after the HS - * authenticates with CAS. - * @returns The HS URL to hit to begin the CAS login process. - */ - getCasLoginUrl(redirectUrl: string): string; - /** - * @param redirectUrl - The URL to redirect to after the HS - * authenticates with the SSO. - * @param loginType - The type of SSO login we are doing (sso or cas). - * Defaults to 'sso'. - * @param idpId - The ID of the Identity Provider being targeted, optional. - * @param action - the SSO flow to indicate to the IdP, optional. - * @returns The HS URL to hit to begin the SSO login process. - */ - getSsoLoginUrl(redirectUrl: string, loginType?: string, idpId?: string, action?: SSOAction): string; - /** - * @param token - Login token previously received from homeserver - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - loginWithToken(token: string): Promise; - /** - * Logs out the current session. - * Obviously, further calls that require authorisation should fail after this - * method is called. The state of the MatrixClient object is not affected: - * it is up to the caller to either reset or destroy the MatrixClient after - * this method succeeds. - * @param stopClient - whether to stop the client before calling /logout to prevent invalid token errors. - * @returns Promise which resolves: On success, the empty object `{}` - */ - logout(stopClient?: boolean): Promise<{}>; - /** - * Deactivates the logged-in account. - * Obviously, further calls that require authorisation should fail after this - * method is called. The state of the MatrixClient object is not affected: - * it is up to the caller to either reset or destroy the MatrixClient after - * this method succeeds. - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @param erase - Optional. If set, send as `erase` attribute in the - * JSON request body, indicating whether the account should be erased. Defaults - * to false. - * @returns Promise which resolves: On success, the empty object - */ - deactivateAccount(auth?: any, erase?: boolean): Promise<{}>; - /** - * Make a request for an `m.login.token` to be issued as per - * [MSC3882](https://github.com/matrix-org/matrix-spec-proposals/pull/3882). - * The server may require User-Interactive auth. - * Note that this is UNSTABLE and subject to breaking changes without notice. - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @returns Promise which resolves: On success, the token response - * or UIA auth data. - */ - requestLoginToken(auth?: IAuthData): Promise>; - /** - * Get the fallback URL to use for unknown interactive-auth stages. - * - * @param loginType - the type of stage being attempted - * @param authSessionId - the auth session ID provided by the homeserver - * - * @returns HS URL to hit to for the fallback interface - */ - getFallbackAuthUrl(loginType: string, authSessionId: string): string; - /** - * Create a new room. - * @param options - a list of options to pass to the /createRoom API. - * @returns Promise which resolves: `{room_id: {string}}` - * @returns Rejects: with an error response. - */ - createRoom(options: ICreateRoomOpts): Promise<{ - room_id: string; - }>; - /** - * Fetches relations for a given event - * @param roomId - the room of the event - * @param eventId - the id of the event - * @param relationType - the rel_type of the relations requested - * @param eventType - the event type of the relations requested - * @param opts - options with optional values for the request. - * @returns the response, with chunk, prev_batch and, next_batch. - */ - fetchRelations(roomId: string, eventId: string, relationType?: RelationType | string | null, eventType?: EventType | string | null, opts?: IRelationsRequestOpts): Promise; - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - roomState(roomId: string): Promise; - /** - * Get an event in a room by its event id. - * - * @returns Promise which resolves to an object containing the event. - * @returns Rejects: with an error response. - */ - fetchRoomEvent(roomId: string, eventId: string): Promise>; - /** - * @param includeMembership - the membership type to include in the response - * @param excludeMembership - the membership type to exclude from the response - * @param atEventId - the id of the event for which moment in the timeline the members should be returned for - * @returns Promise which resolves: dictionary of userid to profile information - * @returns Rejects: with an error response. - */ - members(roomId: string, includeMembership?: string, excludeMembership?: string, atEventId?: string): Promise<{ - [userId: string]: IStateEventWithRoomId[]; - }>; - /** - * Upgrades a room to a new protocol version - * @param newVersion - The target version to upgrade to - * @returns Promise which resolves: Object with key 'replacement_room' - * @returns Rejects: with an error response. - */ - upgradeRoom(roomId: string, newVersion: string): Promise<{ - replacement_room: string; - }>; - /** - * Retrieve a state event. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - getStateEvent(roomId: string, eventType: string, stateKey: string): Promise>; - /** - * @param opts - Options for the request function. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - sendStateEvent(roomId: string, eventType: string, content: any, stateKey?: string, opts?: IRequestOpts): Promise; - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - roomInitialSync(roomId: string, limit: number): Promise; - /** - * Set a marker to indicate the point in a room before which the user has read every - * event. This can be retrieved from room account data (the event type is `m.fully_read`) - * and displayed as a horizontal line in the timeline that is visually distinct to the - * position of the user's own read receipt. - * @param roomId - ID of the room that has been read - * @param rmEventId - ID of the event that has been read - * @param rrEventId - ID of the event tracked by the read receipt. This is here - * for convenience because the RR and the RM are commonly updated at the same time as - * each other. Optional. - * @param rpEventId - rpEvent the m.read.private read receipt event for when we - * don't want other users to see the read receipts. This is experimental. Optional. - * @returns Promise which resolves: the empty object, `{}`. - */ - setRoomReadMarkersHttpRequest(roomId: string, rmEventId: string, rrEventId?: string, rpEventId?: string): Promise<{}>; - /** - * @returns Promise which resolves: A list of the user's current rooms - * @returns Rejects: with an error response. - */ - getJoinedRooms(): Promise; - /** - * Retrieve membership info. for a room. - * @param roomId - ID of the room to get membership for - * @returns Promise which resolves: A list of currently joined users - * and their profile data. - * @returns Rejects: with an error response. - */ - getJoinedRoomMembers(roomId: string): Promise; - /** - * @param options - Options for this request - * @param server - The remote server to query for the room list. - * Optional. If unspecified, get the local home - * server's public room list. - * @param limit - Maximum number of entries to return - * @param since - Token to paginate from - * @returns Promise which resolves: IPublicRoomsResponse - * @returns Rejects: with an error response. - */ - publicRooms({ server, limit, since, ...options }?: IRoomDirectoryOptions): Promise; - /** - * Create an alias to room ID mapping. - * @param alias - The room alias to create. - * @param roomId - The room ID to link the alias to. - * @returns Promise which resolves: an empty object `{}` - * @returns Rejects: with an error response. - */ - createAlias(alias: string, roomId: string): Promise<{}>; - /** - * Delete an alias to room ID mapping. This alias must be on your local server, - * and you must have sufficient access to do this operation. - * @param alias - The room alias to delete. - * @returns Promise which resolves: an empty object `{}`. - * @returns Rejects: with an error response. - */ - deleteAlias(alias: string): Promise<{}>; - /** - * Gets the local aliases for the room. Note: this includes all local aliases, unlike the - * curated list from the m.room.canonical_alias state event. - * @param roomId - The room ID to get local aliases for. - * @returns Promise which resolves: an object with an `aliases` property, containing an array of local aliases - * @returns Rejects: with an error response. - */ - getLocalAliases(roomId: string): Promise<{ - aliases: string[]; - }>; - /** - * Get room info for the given alias. - * @param alias - The room alias to resolve. - * @returns Promise which resolves: Object with room_id and servers. - * @returns Rejects: with an error response. - */ - getRoomIdForAlias(alias: string): Promise<{ - room_id: string; - servers: string[]; - }>; - /** - * @returns Promise which resolves: Object with room_id and servers. - * @returns Rejects: with an error response. - */ - resolveRoomAlias(roomAlias: string): Promise<{ - room_id: string; - servers: string[]; - }>; - /** - * Get the visibility of a room in the current HS's room directory - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - getRoomDirectoryVisibility(roomId: string): Promise<{ - visibility: Visibility; - }>; - /** - * Set the visbility of a room in the current HS's room directory - * @param visibility - "public" to make the room visible - * in the public directory, or "private" to make - * it invisible. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setRoomDirectoryVisibility(roomId: string, visibility: Visibility): Promise<{}>; - /** - * Set the visbility of a room bridged to a 3rd party network in - * the current HS's room directory. - * @param networkId - the network ID of the 3rd party - * instance under which this room is published under. - * @param visibility - "public" to make the room visible - * in the public directory, or "private" to make - * it invisible. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - setRoomDirectoryVisibilityAppService(networkId: string, roomId: string, visibility: "public" | "private"): Promise; - /** - * Query the user directory with a term matching user IDs, display names and domains. - * @param term - the term with which to search. - * @param limit - the maximum number of results to return. The server will - * apply a limit if unspecified. - * @returns Promise which resolves: an array of results. - */ - searchUserDirectory({ term, limit }: { - term: string; - limit?: number; - }): Promise; - /** - * Upload a file to the media repository on the homeserver. - * - * @param file - The object to upload. On a browser, something that - * can be sent to XMLHttpRequest.send (typically a File). Under node.js, - * a a Buffer, String or ReadStream. - * - * @param opts - options object - * - * @returns Promise which resolves to response object, as - * determined by this.opts.onlyData, opts.rawResponse, and - * opts.onlyContentUri. Rejects with an error (usually a MatrixError). - */ - uploadContent(file: FileType, opts?: UploadOpts): Promise; - /** - * Cancel a file upload in progress - * @param upload - The object returned from uploadContent - * @returns true if canceled, otherwise false - */ - cancelUpload(upload: Promise): boolean; - /** - * Get a list of all file uploads in progress - * @returns Array of objects representing current uploads. - * Currently in progress is element 0. Keys: - * - promise: The promise associated with the upload - * - loaded: Number of bytes uploaded - * - total: Total number of bytes to upload - */ - getCurrentUploads(): Upload[]; - /** - * @param info - The kind of info to retrieve (e.g. 'displayname', - * 'avatar_url'). - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - getProfileInfo(userId: string, info?: string): Promise<{ - avatar_url?: string; - displayname?: string; - }>; - /** - * @returns Promise which resolves to a list of the user's threepids. - * @returns Rejects: with an error response. - */ - getThreePids(): Promise<{ - threepids: IThreepid[]; - }>; - /** - * Add a 3PID to your homeserver account and optionally bind it to an identity - * server as well. An identity server is required as part of the `creds` object. - * - * This API is deprecated, and you should instead use `addThreePidOnly` - * for homeservers that support it. - * - * @returns Promise which resolves: on success - * @returns Rejects: with an error response. - */ - addThreePid(creds: any, bind: boolean): Promise; - /** - * Add a 3PID to your homeserver account. This API does not use an identity - * server, as the homeserver is expected to handle 3PID ownership validation. - * - * You can check whether a homeserver supports this API via - * `doesServerSupportSeparateAddAndBind`. - * - * @param data - A object with 3PID validation data from having called - * `account/3pid//requestToken` on the homeserver. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - addThreePidOnly(data: IAddThreePidOnlyBody): Promise<{}>; - /** - * Bind a 3PID for discovery onto an identity server via the homeserver. The - * identity server handles 3PID ownership validation and the homeserver records - * the new binding to track where all 3PIDs for the account are bound. - * - * You can check whether a homeserver supports this API via - * `doesServerSupportSeparateAddAndBind`. - * - * @param data - A object with 3PID validation data from having called - * `validate//requestToken` on the identity server. It should also - * contain `id_server` and `id_access_token` fields as well. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - bindThreePid(data: IBindThreePidBody): Promise<{}>; - /** - * Unbind a 3PID for discovery on an identity server via the homeserver. The - * homeserver removes its record of the binding to keep an updated record of - * where all 3PIDs for the account are bound. - * - * @param medium - The threepid medium (eg. 'email') - * @param address - The threepid address (eg. 'bob\@example.com') - * this must be as returned by getThreePids. - * @returns Promise which resolves: on success - * @returns Rejects: with an error response. - */ - unbindThreePid(medium: string, address: string): Promise<{ - id_server_unbind_result: IdServerUnbindResult; - }>; - /** - * @param medium - The threepid medium (eg. 'email') - * @param address - The threepid address (eg. 'bob\@example.com') - * this must be as returned by getThreePids. - * @returns Promise which resolves: The server response on success - * (generally the empty JSON object) - * @returns Rejects: with an error response. - */ - deleteThreePid(medium: string, address: string): Promise<{ - id_server_unbind_result: IdServerUnbindResult; - }>; - /** - * Make a request to change your password. - * @param newPassword - The new desired password. - * @param logoutDevices - Should all sessions be logged out after the password change. Defaults to true. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setPassword(authDict: IAuthDict, newPassword: string, logoutDevices?: boolean): Promise<{}>; - /** - * Gets all devices recorded for the logged-in user - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - getDevices(): Promise<{ - devices: IMyDevice[]; - }>; - /** - * Gets specific device details for the logged-in user - * @param deviceId - device to query - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - getDevice(deviceId: string): Promise; - /** - * Update the given device - * - * @param deviceId - device to update - * @param body - body of request - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setDeviceDetails(deviceId: string, body: { - display_name: string; - }): Promise<{}>; - /** - * Delete the given device - * - * @param deviceId - device to delete - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - deleteDevice(deviceId: string, auth?: IAuthDict): Promise; - /** - * Delete multiple device - * - * @param devices - IDs of the devices to delete - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - deleteMultipleDevices(devices: string[], auth?: IAuthDict): Promise; - /** - * Gets all pushers registered for the logged-in user - * - * @returns Promise which resolves: Array of objects representing pushers - * @returns Rejects: with an error response. - */ - getPushers(): Promise<{ - pushers: IPusher[]; - }>; - /** - * Adds a new pusher or updates an existing pusher - * - * @param pusher - Object representing a pusher - * @returns Promise which resolves: Empty json object on success - * @returns Rejects: with an error response. - */ - setPusher(pusher: IPusherRequest): Promise<{}>; - /** - * Persists local notification settings - * @returns Promise which resolves: an empty object - * @returns Rejects: with an error response. - */ - setLocalNotificationSettings(deviceId: string, notificationSettings: LocalNotificationSettings): Promise<{}>; - /** - * Get the push rules for the account from the server. - * @returns Promise which resolves to the push rules. - * @returns Rejects: with an error response. - */ - getPushRules(): Promise; - /** - * Update the push rules for the account. This should be called whenever - * updated push rules are available. - */ - setPushRules(rules: IPushRules): void; - /** - * @returns Promise which resolves: an empty object `{}` - * @returns Rejects: with an error response. - */ - addPushRule(scope: string, kind: PushRuleKind, ruleId: Exclude, body: Pick): Promise<{}>; - /** - * @returns Promise which resolves: an empty object `{}` - * @returns Rejects: with an error response. - */ - deletePushRule(scope: string, kind: PushRuleKind, ruleId: Exclude): Promise<{}>; - /** - * Enable or disable a push notification rule. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setPushRuleEnabled(scope: string, kind: PushRuleKind, ruleId: RuleId | string, enabled: boolean): Promise<{}>; - /** - * Set the actions for a push notification rule. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setPushRuleActions(scope: string, kind: PushRuleKind, ruleId: RuleId | string, actions: PushRuleAction[]): Promise<{}>; - /** - * Perform a server-side search. - * @param next_batch - the batch token to pass in the query string - * @param body - the JSON object to pass to the request body. - * @param abortSignal - optional signal used to cancel the http request. - * @returns Promise which resolves to the search response object. - * @returns Rejects: with an error response. - */ - search({ body, next_batch: nextBatch }: { - body: ISearchRequestBody; - next_batch?: string; - }, abortSignal?: AbortSignal): Promise; - /** - * Upload keys - * - * @param content - body of upload request - * - * @param opts - this method no longer takes any opts, - * used to take opts.device_id but this was not removed from the spec as a redundant parameter - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - uploadKeysRequest(content: IUploadKeysRequest, opts?: void): Promise; - uploadKeySignatures(content: KeySignatures): Promise; - /** - * Download device keys - * - * @param userIds - list of users to get keys for - * - * @param token - sync token to pass in the query request, to help - * the HS give the most recent results - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - downloadKeysForUsers(userIds: string[], { token }?: { - token?: string; - }): Promise; - /** - * Claim one-time keys - * - * @param devices - a list of [userId, deviceId] pairs - * - * @param keyAlgorithm - desired key type - * - * @param timeout - the time (in milliseconds) to wait for keys from remote - * servers - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - claimOneTimeKeys(devices: [string, string][], keyAlgorithm?: string, timeout?: number): Promise; - /** - * Ask the server for a list of users who have changed their device lists - * between a pair of sync tokens - * - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - getKeyChanges(oldToken: string, newToken: string): Promise<{ - changed: string[]; - left: string[]; - }>; - uploadDeviceSigningKeys(auth?: IAuthData, keys?: CrossSigningKeys): Promise<{}>; - /** - * Register with an identity server using the OpenID token from the user's - * Homeserver, which can be retrieved via - * {@link MatrixClient#getOpenIdToken}. - * - * Note that the `/account/register` endpoint (as well as IS authentication in - * general) was added as part of the v2 API version. - * - * @returns Promise which resolves: with object containing an Identity - * Server access token. - * @returns Rejects: with an error response. - */ - registerWithIdentityServer(hsOpenIdToken: IOpenIDToken): Promise<{ - access_token: string; - token: string; - }>; - /** - * Requests an email verification token directly from an identity server. - * - * This API is used as part of binding an email for discovery on an identity - * server. The validation data that results should be passed to the - * `bindThreePid` method to complete the binding process. - * - * @param email - The email address to request a token for - * @param clientSecret - A secret binary string generated by the client. - * It is recommended this be around 16 ASCII characters. - * @param sendAttempt - If an identity server sees a duplicate request - * with the same sendAttempt, it will not send another email. - * To request another email to be sent, use a larger value for - * the sendAttempt param as was used in the previous request. - * @param nextLink - Optional If specified, the client will be redirected - * to this link after validation. - * @param identityAccessToken - The `access_token` field of the identity - * server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - * @throws Error if no identity server is set - */ - requestEmailToken(email: string, clientSecret: string, sendAttempt: number, nextLink?: string, identityAccessToken?: string): Promise; - /** - * Requests a MSISDN verification token directly from an identity server. - * - * This API is used as part of binding a MSISDN for discovery on an identity - * server. The validation data that results should be passed to the - * `bindThreePid` method to complete the binding process. - * - * @param phoneCountry - The ISO 3166-1 alpha-2 code for the country in - * which phoneNumber should be parsed relative to. - * @param phoneNumber - The phone number, in national or international - * format - * @param clientSecret - A secret binary string generated by the client. - * It is recommended this be around 16 ASCII characters. - * @param sendAttempt - If an identity server sees a duplicate request - * with the same sendAttempt, it will not send another SMS. - * To request another SMS to be sent, use a larger value for - * the sendAttempt param as was used in the previous request. - * @param nextLink - Optional If specified, the client will be redirected - * to this link after validation. - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves to an object with a sid string - * @returns Rejects: with an error response. - * @throws Error if no identity server is set - */ - requestMsisdnToken(phoneCountry: string, phoneNumber: string, clientSecret: string, sendAttempt: number, nextLink?: string, identityAccessToken?: string): Promise; - /** - * Submits a MSISDN token to the identity server - * - * This is used when submitting the code sent by SMS to a phone number. - * The identity server has an equivalent API for email but the js-sdk does - * not expose this, since email is normally validated by the user clicking - * a link rather than entering a code. - * - * @param sid - The sid given in the response to requestToken - * @param clientSecret - A secret binary string generated by the client. - * This must be the same value submitted in the requestToken call. - * @param msisdnToken - The MSISDN token, as enetered by the user. - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: Object, currently with no parameters. - * @returns Rejects: with an error response. - * @throws Error if No identity server is set - */ - submitMsisdnToken(sid: string, clientSecret: string, msisdnToken: string, identityAccessToken: string): Promise; - /** - * Submits a MSISDN token to an arbitrary URL. - * - * This is used when submitting the code sent by SMS to a phone number in the - * newer 3PID flow where the homeserver validates 3PID ownership (as part of - * `requestAdd3pidMsisdnToken`). The homeserver response may include a - * `submit_url` to specify where the token should be sent, and this helper can - * be used to pass the token to this URL. - * - * @param url - The URL to submit the token to - * @param sid - The sid given in the response to requestToken - * @param clientSecret - A secret binary string generated by the client. - * This must be the same value submitted in the requestToken call. - * @param msisdnToken - The MSISDN token, as enetered by the user. - * - * @returns Promise which resolves: Object, currently with no parameters. - * @returns Rejects: with an error response. - */ - submitMsisdnTokenOtherUrl(url: string, sid: string, clientSecret: string, msisdnToken: string): Promise; - /** - * Gets the V2 hashing information from the identity server. Primarily useful for - * lookups. - * @param identityAccessToken - The access token for the identity server. - * @returns The hashing information for the identity server. - */ - getIdentityHashDetails(identityAccessToken: string): Promise; - /** - * Performs a hashed lookup of addresses against the identity server. This is - * only supported on identity servers which have at least the version 2 API. - * @param addressPairs - An array of 2 element arrays. - * The first element of each pair is the address, the second is the 3PID medium. - * Eg: `["email@example.org", "email"]` - * @param identityAccessToken - The access token for the identity server. - * @returns A collection of address mappings to - * found MXIDs. Results where no user could be found will not be listed. - */ - identityHashedLookup(addressPairs: [string, string][], identityAccessToken: string): Promise<{ - address: string; - mxid: string; - }[]>; - /** - * Looks up the public Matrix ID mapping for a given 3rd party - * identifier from the identity server - * - * @param medium - The medium of the threepid, eg. 'email' - * @param address - The textual address of the threepid - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: A threepid mapping - * object or the empty object if no mapping - * exists - * @returns Rejects: with an error response. - */ - lookupThreePid(medium: string, address: string, identityAccessToken: string): Promise; - /** - * Looks up the public Matrix ID mappings for multiple 3PIDs. - * - * @param query - Array of arrays containing - * [medium, address] - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: Lookup results from IS. - * @returns Rejects: with an error response. - */ - bulkLookupThreePids(query: [string, string][], identityAccessToken: string): Promise; - /** - * Get account info from the identity server. This is useful as a neutral check - * to verify that other APIs are likely to approve access by testing that the - * token is valid, terms have been agreed, etc. - * - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: an object with account info. - * @returns Rejects: with an error response. - */ - getIdentityAccount(identityAccessToken: string): Promise; - /** - * Send an event to a specific list of devices. - * This is a low-level API that simply wraps the HTTP API - * call to send to-device messages. We recommend using - * queueToDevice() which is a higher level API. - * - * @param eventType - type of event to send - * content to send. Map from user_id to device_id to content object. - * @param txnId - transaction id. One will be made up if not - * supplied. - * @returns Promise which resolves: to an empty object `{}` - */ - sendToDevice(eventType: string, contentMap: SendToDeviceContentMap, txnId?: string): Promise<{}>; - /** - * Sends events directly to specific devices using Matrix's to-device - * messaging system. The batch will be split up into appropriately sized - * batches for sending and stored in the store so they can be retried - * later if they fail to send. Retries will happen automatically. - * @param batch - The to-device messages to send - */ - queueToDevice(batch: ToDeviceBatch): Promise; - /** - * Get the third party protocols that can be reached using - * this HS - * @returns Promise which resolves to the result object - */ - getThirdpartyProtocols(): Promise<{ - [protocol: string]: IProtocol; - }>; - /** - * Get information on how a specific place on a third party protocol - * may be reached. - * @param protocol - The protocol given in getThirdpartyProtocols() - * @param params - Protocol-specific parameters, as given in the - * response to getThirdpartyProtocols() - * @returns Promise which resolves to the result object - */ - getThirdpartyLocation(protocol: string, params: { - searchFields?: string[]; - }): Promise; - /** - * Get information on how a specific user on a third party protocol - * may be reached. - * @param protocol - The protocol given in getThirdpartyProtocols() - * @param params - Protocol-specific parameters, as given in the - * response to getThirdpartyProtocols() - * @returns Promise which resolves to the result object - */ - getThirdpartyUser(protocol: string, params: any): Promise; - getTerms(serviceType: SERVICE_TYPES, baseUrl: string): Promise; - agreeToTerms(serviceType: SERVICE_TYPES, baseUrl: string, accessToken: string, termsUrls: string[]): Promise<{}>; - /** - * Reports an event as inappropriate to the server, which may then notify the appropriate people. - * @param roomId - The room in which the event being reported is located. - * @param eventId - The event to report. - * @param score - The score to rate this content as where -100 is most offensive and 0 is inoffensive. - * @param reason - The reason the content is being reported. May be blank. - * @returns Promise which resolves to an empty object if successful - */ - reportEvent(roomId: string, eventId: string, score: number, reason: string): Promise<{}>; - /** - * Fetches or paginates a room hierarchy as defined by MSC2946. - * Falls back gracefully to sourcing its data from `getSpaceSummary` if this API is not yet supported by the server. - * @param roomId - The ID of the space-room to use as the root of the summary. - * @param limit - The maximum number of rooms to return per page. - * @param maxDepth - The maximum depth in the tree from the root room to return. - * @param suggestedOnly - Whether to only return rooms with suggested=true. - * @param fromToken - The opaque token to paginate a previous request. - * @returns the response, with next_batch & rooms fields. - */ - getRoomHierarchy(roomId: string, limit?: number, maxDepth?: number, suggestedOnly?: boolean, fromToken?: string): Promise; - /** - * Creates a new file tree space with the given name. The client will pick - * defaults for how it expects to be able to support the remaining API offered - * by the returned class. - * - * Note that this is UNSTABLE and may have breaking changes without notice. - * @param name - The name of the tree space. - * @returns Promise which resolves to the created space. - */ - unstableCreateFileTree(name: string): Promise; - /** - * Gets a reference to a tree space, if the room ID given is a tree space. If the room - * does not appear to be a tree space then null is returned. - * - * Note that this is UNSTABLE and may have breaking changes without notice. - * @param roomId - The room ID to get a tree space reference for. - * @returns The tree space, or null if not a tree space. - */ - unstableGetFileTreeSpace(roomId: string): MSC3089TreeSpace | null; - /** - * Perform a single MSC3575 sliding sync request. - * @param req - The request to make. - * @param proxyBaseUrl - The base URL for the sliding sync proxy. - * @param abortSignal - Optional signal to abort request mid-flight. - * @returns The sliding sync response, or a standard error. - * @throws on non 2xx status codes with an object with a field "httpStatus":number. - */ - slidingSync(req: MSC3575SlidingSyncRequest, proxyBaseUrl?: string, abortSignal?: AbortSignal): Promise; - /** - * @deprecated use supportsThreads() instead - */ - supportsExperimentalThreads(): boolean; - /** - * A helper to determine thread support - * @returns a boolean to determine if threads are enabled - */ - supportsThreads(): boolean; - /** - * A helper to determine intentional mentions support - * @returns a boolean to determine if intentional mentions are enabled - * @experimental - */ - supportsIntentionalMentions(): boolean; - /** - * Fetches the summary of a room as defined by an initial version of MSC3266 and implemented in Synapse - * Proposed at https://github.com/matrix-org/matrix-doc/pull/3266 - * @param roomIdOrAlias - The ID or alias of the room to get the summary of. - * @param via - The list of servers which know about the room if only an ID was provided. - */ - getRoomSummary(roomIdOrAlias: string, via?: string[]): Promise; - /** - * Processes a list of threaded events and adds them to their respective timelines - * @param room - the room the adds the threaded events - * @param threadedEvents - an array of the threaded events - * @param toStartOfTimeline - the direction in which we want to add the events - */ - processThreadEvents(room: Room, threadedEvents: MatrixEvent[], toStartOfTimeline: boolean): void; - /** - * Processes a list of thread roots and creates a thread model - * @param room - the room to create the threads in - * @param threadedEvents - an array of thread roots - * @param toStartOfTimeline - the direction - */ - processThreadRoots(room: Room, threadedEvents: MatrixEvent[], toStartOfTimeline: boolean): void; - processBeaconEvents(room?: Room, events?: MatrixEvent[]): void; - /** - * Calls aggregation functions for event types that are aggregated - * Polls and location beacons - * @param room - room the events belong to - * @param events - timeline events to be processed - * @returns - */ - processAggregatedTimelineEvents(room?: Room, events?: MatrixEvent[]): void; - /** - * Fetches information about the user for the configured access token. - */ - whoami(): Promise; - /** - * Find the event_id closest to the given timestamp in the given direction. - * @returns Resolves: A promise of an object containing the event_id and - * origin_server_ts of the closest event to the timestamp in the given direction - * @returns Rejects: when the request fails (module:http-api.MatrixError) - */ - timestampToEvent(roomId: string, timestamp: number, dir: Direction): Promise; -} -/** - * recalculates an accurate notifications count on event decryption. - * Servers do not have enough knowledge about encrypted events to calculate an - * accurate notification_count - */ -export declare function fixNotificationCountOnDecryption(cli: MatrixClient, event: MatrixEvent): void; -export {}; -//# sourceMappingURL=client.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts.map deleted file mode 100644 index a95aae2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js deleted file mode 100644 index 410d2ff..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js +++ /dev/null @@ -1,7616 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UNSTABLE_MSC3852_LAST_SEEN_UA = exports.RoomVersionStability = exports.PendingEventOrdering = exports.MatrixClient = exports.M_AUTHENTICATION = exports.ClientEvent = exports.CRYPTO_ENABLED = void 0; -exports.fixNotificationCountOnDecryption = fixNotificationCountOnDecryption; -var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _sync = require("./sync"); -var _event = require("./models/event"); -var _stub = require("./store/stub"); -var _call = require("./webrtc/call"); -var _filter = require("./filter"); -var _callEventHandler = require("./webrtc/callEventHandler"); -var utils = _interopRequireWildcard(require("./utils")); -var _eventTimeline = require("./models/event-timeline"); -var _pushprocessor = require("./pushprocessor"); -var _autodiscovery = require("./autodiscovery"); -var olmlib = _interopRequireWildcard(require("./crypto/olmlib")); -var _ReEmitter = require("./ReEmitter"); -var _RoomList = require("./crypto/RoomList"); -var _logger = require("./logger"); -var _serviceTypes = require("./service-types"); -var _httpApi = require("./http-api"); -var _crypto = require("./crypto"); -var _recoverykey = require("./crypto/recoverykey"); -var _key_passphrase = require("./crypto/key_passphrase"); -var _user = require("./models/user"); -var _contentRepo = require("./content-repo"); -var _searchResult = require("./models/search-result"); -var _dehydration = require("./crypto/dehydration"); -var _api = require("./crypto/api"); -var ContentHelpers = _interopRequireWildcard(require("./content-helpers")); -var _room = require("./models/room"); -var _roomMember = require("./models/room-member"); -var _event2 = require("./@types/event"); -var _partials = require("./@types/partials"); -var _eventMapper = require("./event-mapper"); -var _randomstring = require("./randomstring"); -var _backup = require("./crypto/backup"); -var _MSC3089TreeSpace = require("./models/MSC3089TreeSpace"); -var _search = require("./@types/search"); -var _PushRules = require("./@types/PushRules"); -var _groupCall = require("./webrtc/groupCall"); -var _mediaHandler = require("./webrtc/mediaHandler"); -var _groupCallEventHandler = require("./webrtc/groupCallEventHandler"); -var _typedEventEmitter = require("./models/typed-event-emitter"); -var _read_receipts = require("./@types/read_receipts"); -var _slidingSyncSdk = require("./sliding-sync-sdk"); -var _thread = require("./models/thread"); -var _beacon = require("./@types/beacon"); -var _NamespacedValue = require("./NamespacedValue"); -var _ToDeviceMessageQueue = require("./ToDeviceMessageQueue"); -var _invitesIgnorer = require("./models/invites-ignorer"); -var _feature = require("./feature"); -var _constants = require("./rust-crypto/constants"); -const _excluded = ["server", "limit", "since"]; -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -const SCROLLBACK_DELAY_MS = 3000; -const CRYPTO_ENABLED = (0, _crypto.isCryptoAvailable)(); -exports.CRYPTO_ENABLED = CRYPTO_ENABLED; -const CAPABILITIES_CACHE_MS = 21600000; // 6 hours - an arbitrary value -const TURN_CHECK_INTERVAL = 10 * 60 * 1000; // poll for turn credentials every 10 minutes - -const UNSTABLE_MSC3852_LAST_SEEN_UA = new _NamespacedValue.UnstableValue("last_seen_user_agent", "org.matrix.msc3852.last_seen_user_agent"); -exports.UNSTABLE_MSC3852_LAST_SEEN_UA = UNSTABLE_MSC3852_LAST_SEEN_UA; -let PendingEventOrdering; -exports.PendingEventOrdering = PendingEventOrdering; -(function (PendingEventOrdering) { - PendingEventOrdering["Chronological"] = "chronological"; - PendingEventOrdering["Detached"] = "detached"; -})(PendingEventOrdering || (exports.PendingEventOrdering = PendingEventOrdering = {})); -let RoomVersionStability; -exports.RoomVersionStability = RoomVersionStability; -(function (RoomVersionStability) { - RoomVersionStability["Stable"] = "stable"; - RoomVersionStability["Unstable"] = "unstable"; -})(RoomVersionStability || (exports.RoomVersionStability = RoomVersionStability = {})); -var CrossSigningKeyType; -(function (CrossSigningKeyType) { - CrossSigningKeyType["MasterKey"] = "master_key"; - CrossSigningKeyType["SelfSigningKey"] = "self_signing_key"; - CrossSigningKeyType["UserSigningKey"] = "user_signing_key"; -})(CrossSigningKeyType || (CrossSigningKeyType = {})); -const M_AUTHENTICATION = new _NamespacedValue.UnstableValue("m.authentication", "org.matrix.msc2965.authentication"); -exports.M_AUTHENTICATION = M_AUTHENTICATION; -/* eslint-enable camelcase */ - -// We're using this constant for methods overloading and inspect whether a variable -// contains an eventId or not. This was required to ensure backwards compatibility -// of methods for threads -// Probably not the most graceful solution but does a good enough job for now -const EVENT_ID_PREFIX = "$"; -let ClientEvent; -exports.ClientEvent = ClientEvent; -(function (ClientEvent) { - ClientEvent["Sync"] = "sync"; - ClientEvent["Event"] = "event"; - ClientEvent["ToDeviceEvent"] = "toDeviceEvent"; - ClientEvent["AccountData"] = "accountData"; - ClientEvent["Room"] = "Room"; - ClientEvent["DeleteRoom"] = "deleteRoom"; - ClientEvent["SyncUnexpectedError"] = "sync.unexpectedError"; - ClientEvent["ClientWellKnown"] = "WellKnown.client"; - ClientEvent["ReceivedVoipEvent"] = "received_voip_event"; - ClientEvent["UndecryptableToDeviceEvent"] = "toDeviceEvent.undecryptable"; - ClientEvent["TurnServers"] = "turnServers"; - ClientEvent["TurnServersError"] = "turnServers.error"; -})(ClientEvent || (exports.ClientEvent = ClientEvent = {})); -const SSO_ACTION_PARAM = new _NamespacedValue.UnstableValue("action", "org.matrix.msc3824.action"); - -/** - * Represents a Matrix Client. Only directly construct this if you want to use - * custom modules. Normally, {@link createClient} should be used - * as it specifies 'sensible' defaults for these modules. - */ -class MatrixClient extends _typedEventEmitter.TypedEventEmitter { - // populated after initCrypto - - // XXX: Intended private, used in code. - - /** - * The libolm crypto implementation, if it is in use. - * - * @deprecated This should not be used. Instead, use the methods exposed directly on this class or - * (where they are available) via {@link getCrypto}. - */ - // XXX: Intended private, used in code. Being replaced by cryptoBackend - - // one of crypto or rustCrypto - // XXX: Intended private, used in code. - // XXX: Intended private, used in code. - - // XXX: Intended private, used in code. - // XXX: Intended private, used in code. - // XXX: Intended private, used in code. - - // Note: these are all `protected` to let downstream consumers make mistakes if they want to. - // We don't technically support this usage, but have reasons to do this. - - // The pushprocessor caches useful things, so keep one and re-use it - - // Promise to a response of the server's /versions response - // TODO: This should expire: https://github.com/matrix-org/matrix-js-sdk/issues/1020 - - // A manager for determining which invites should be ignored. - - constructor(opts) { - var _opts$usingExternalCr; - super(); - (0, _defineProperty2.default)(this, "reEmitter", new _ReEmitter.TypedReEmitter(this)); - (0, _defineProperty2.default)(this, "olmVersion", null); - (0, _defineProperty2.default)(this, "usingExternalCrypto", false); - (0, _defineProperty2.default)(this, "store", void 0); - (0, _defineProperty2.default)(this, "deviceId", void 0); - (0, _defineProperty2.default)(this, "credentials", void 0); - (0, _defineProperty2.default)(this, "pickleKey", void 0); - (0, _defineProperty2.default)(this, "scheduler", void 0); - (0, _defineProperty2.default)(this, "clientRunning", false); - (0, _defineProperty2.default)(this, "timelineSupport", false); - (0, _defineProperty2.default)(this, "urlPreviewCache", {}); - (0, _defineProperty2.default)(this, "identityServer", void 0); - (0, _defineProperty2.default)(this, "http", void 0); - (0, _defineProperty2.default)(this, "crypto", void 0); - (0, _defineProperty2.default)(this, "cryptoBackend", void 0); - (0, _defineProperty2.default)(this, "cryptoCallbacks", void 0); - (0, _defineProperty2.default)(this, "callEventHandler", void 0); - (0, _defineProperty2.default)(this, "groupCallEventHandler", void 0); - (0, _defineProperty2.default)(this, "supportsCallTransfer", false); - (0, _defineProperty2.default)(this, "forceTURN", false); - (0, _defineProperty2.default)(this, "iceCandidatePoolSize", 0); - (0, _defineProperty2.default)(this, "idBaseUrl", void 0); - (0, _defineProperty2.default)(this, "baseUrl", void 0); - (0, _defineProperty2.default)(this, "isVoipWithNoMediaAllowed", void 0); - (0, _defineProperty2.default)(this, "canSupportVoip", false); - (0, _defineProperty2.default)(this, "peekSync", null); - (0, _defineProperty2.default)(this, "isGuestAccount", false); - (0, _defineProperty2.default)(this, "ongoingScrollbacks", {}); - (0, _defineProperty2.default)(this, "notifTimelineSet", null); - (0, _defineProperty2.default)(this, "cryptoStore", void 0); - (0, _defineProperty2.default)(this, "verificationMethods", void 0); - (0, _defineProperty2.default)(this, "fallbackICEServerAllowed", false); - (0, _defineProperty2.default)(this, "roomList", void 0); - (0, _defineProperty2.default)(this, "syncApi", void 0); - (0, _defineProperty2.default)(this, "roomNameGenerator", void 0); - (0, _defineProperty2.default)(this, "pushRules", void 0); - (0, _defineProperty2.default)(this, "syncLeftRoomsPromise", void 0); - (0, _defineProperty2.default)(this, "syncedLeftRooms", false); - (0, _defineProperty2.default)(this, "clientOpts", void 0); - (0, _defineProperty2.default)(this, "clientWellKnownIntervalID", void 0); - (0, _defineProperty2.default)(this, "canResetTimelineCallback", void 0); - (0, _defineProperty2.default)(this, "canSupport", new Map()); - (0, _defineProperty2.default)(this, "pushProcessor", new _pushprocessor.PushProcessor(this)); - (0, _defineProperty2.default)(this, "serverVersionsPromise", void 0); - (0, _defineProperty2.default)(this, "cachedCapabilities", void 0); - (0, _defineProperty2.default)(this, "clientWellKnown", void 0); - (0, _defineProperty2.default)(this, "clientWellKnownPromise", void 0); - (0, _defineProperty2.default)(this, "turnServers", []); - (0, _defineProperty2.default)(this, "turnServersExpiry", 0); - (0, _defineProperty2.default)(this, "checkTurnServersIntervalID", void 0); - (0, _defineProperty2.default)(this, "exportedOlmDeviceToImport", void 0); - (0, _defineProperty2.default)(this, "txnCtr", 0); - (0, _defineProperty2.default)(this, "mediaHandler", new _mediaHandler.MediaHandler(this)); - (0, _defineProperty2.default)(this, "sessionId", void 0); - (0, _defineProperty2.default)(this, "pendingEventEncryption", new Map()); - (0, _defineProperty2.default)(this, "useE2eForGroupCall", true); - (0, _defineProperty2.default)(this, "toDeviceMessageQueue", void 0); - (0, _defineProperty2.default)(this, "ignoredInvites", void 0); - (0, _defineProperty2.default)(this, "startCallEventHandler", () => { - if (this.isInitialSyncComplete()) { - this.callEventHandler.start(); - this.groupCallEventHandler.start(); - this.off(ClientEvent.Sync, this.startCallEventHandler); - } - }); - (0, _defineProperty2.default)(this, "fixupRoomNotifications", () => { - if (this.isInitialSyncComplete()) { - var _this$getRooms; - const unreadRooms = ((_this$getRooms = this.getRooms()) !== null && _this$getRooms !== void 0 ? _this$getRooms : []).filter(room => { - return room.getUnreadNotificationCount(_room.NotificationCountType.Total) > 0; - }); - for (const room of unreadRooms) { - const currentUserId = this.getSafeUserId(); - room.fixupNotifications(currentUserId); - } - this.off(ClientEvent.Sync, this.fixupRoomNotifications); - } - }); - opts.baseUrl = utils.ensureNoTrailingSlash(opts.baseUrl); - opts.idBaseUrl = utils.ensureNoTrailingSlash(opts.idBaseUrl); - this.baseUrl = opts.baseUrl; - this.idBaseUrl = opts.idBaseUrl; - this.identityServer = opts.identityServer; - this.usingExternalCrypto = (_opts$usingExternalCr = opts.usingExternalCrypto) !== null && _opts$usingExternalCr !== void 0 ? _opts$usingExternalCr : false; - this.store = opts.store || new _stub.StubStore(); - this.deviceId = opts.deviceId || null; - this.sessionId = (0, _randomstring.randomString)(10); - const userId = opts.userId || null; - this.credentials = { - userId - }; - this.http = new _httpApi.MatrixHttpApi(this, { - fetchFn: opts.fetchFn, - baseUrl: opts.baseUrl, - idBaseUrl: opts.idBaseUrl, - accessToken: opts.accessToken, - prefix: _httpApi.ClientPrefix.R0, - onlyData: true, - extraParams: opts.queryParams, - localTimeoutMs: opts.localTimeoutMs, - useAuthorizationHeader: opts.useAuthorizationHeader - }); - if (opts.deviceToImport) { - if (this.deviceId) { - _logger.logger.warn("not importing device because device ID is provided to " + "constructor independently of exported data"); - } else if (this.credentials.userId) { - _logger.logger.warn("not importing device because user ID is provided to " + "constructor independently of exported data"); - } else if (!opts.deviceToImport.deviceId) { - _logger.logger.warn("not importing device because no device ID in exported data"); - } else { - this.deviceId = opts.deviceToImport.deviceId; - this.credentials.userId = opts.deviceToImport.userId; - // will be used during async initialization of the crypto - this.exportedOlmDeviceToImport = opts.deviceToImport.olmDevice; - } - } else if (opts.pickleKey) { - this.pickleKey = opts.pickleKey; - } - this.scheduler = opts.scheduler; - if (this.scheduler) { - this.scheduler.setProcessFunction(async eventToSend => { - const room = this.getRoom(eventToSend.getRoomId()); - if (eventToSend.status !== _event.EventStatus.SENDING) { - this.updatePendingEventStatus(room, eventToSend, _event.EventStatus.SENDING); - } - const res = await this.sendEventHttpRequest(eventToSend); - if (room) { - // ensure we update pending event before the next scheduler run so that any listeners to event id - // updates on the synchronous event emitter get a chance to run first. - room.updatePendingEvent(eventToSend, _event.EventStatus.SENT, res.event_id); - } - return res; - }); - } - if ((0, _call.supportsMatrixCall)()) { - this.callEventHandler = new _callEventHandler.CallEventHandler(this); - this.groupCallEventHandler = new _groupCallEventHandler.GroupCallEventHandler(this); - this.canSupportVoip = true; - // Start listening for calls after the initial sync is done - // We do not need to backfill the call event buffer - // with encrypted events that might never get decrypted - this.on(ClientEvent.Sync, this.startCallEventHandler); - } - this.on(ClientEvent.Sync, this.fixupRoomNotifications); - this.timelineSupport = Boolean(opts.timelineSupport); - this.cryptoStore = opts.cryptoStore; - this.verificationMethods = opts.verificationMethods; - this.cryptoCallbacks = opts.cryptoCallbacks || {}; - this.forceTURN = opts.forceTURN || false; - this.iceCandidatePoolSize = opts.iceCandidatePoolSize === undefined ? 0 : opts.iceCandidatePoolSize; - this.supportsCallTransfer = opts.supportsCallTransfer || false; - this.fallbackICEServerAllowed = opts.fallbackICEServerAllowed || false; - this.isVoipWithNoMediaAllowed = opts.isVoipWithNoMediaAllowed || false; - if (opts.useE2eForGroupCall !== undefined) this.useE2eForGroupCall = opts.useE2eForGroupCall; - - // List of which rooms have encryption enabled: separate from crypto because - // we still want to know which rooms are encrypted even if crypto is disabled: - // we don't want to start sending unencrypted events to them. - this.roomList = new _RoomList.RoomList(this.cryptoStore); - this.roomNameGenerator = opts.roomNameGenerator; - this.toDeviceMessageQueue = new _ToDeviceMessageQueue.ToDeviceMessageQueue(this); - - // The SDK doesn't really provide a clean way for events to recalculate the push - // actions for themselves, so we have to kinda help them out when they are encrypted. - // We do this so that push rules are correctly executed on events in their decrypted - // state, such as highlights when the user's name is mentioned. - this.on(_event.MatrixEventEvent.Decrypted, event => { - fixNotificationCountOnDecryption(this, event); - }); - - // Like above, we have to listen for read receipts from ourselves in order to - // correctly handle notification counts on encrypted rooms. - // This fixes https://github.com/vector-im/element-web/issues/9421 - this.on(_room.RoomEvent.Receipt, (event, room) => { - if (room && this.isRoomEncrypted(room.roomId)) { - // Figure out if we've read something or if it's just informational - const content = event.getContent(); - const isSelf = Object.keys(content).filter(eid => { - for (const [key, value] of Object.entries(content[eid])) { - if (!utils.isSupportedReceiptType(key)) continue; - if (!value) continue; - if (Object.keys(value).includes(this.getUserId())) return true; - } - return false; - }).length > 0; - if (!isSelf) return; - - // Work backwards to determine how many events are unread. We also set - // a limit for how back we'll look to avoid spinning CPU for too long. - // If we hit the limit, we assume the count is unchanged. - const maxHistory = 20; - const events = room.getLiveTimeline().getEvents(); - let highlightCount = 0; - for (let i = events.length - 1; i >= 0; i--) { - var _pushActions$tweaks; - if (i === events.length - maxHistory) return; // limit reached - - const event = events[i]; - if (room.hasUserReadEvent(this.getUserId(), event.getId())) { - // If the user has read the event, then the counting is done. - break; - } - const pushActions = this.getPushActionsForEvent(event); - highlightCount += pushActions !== null && pushActions !== void 0 && (_pushActions$tweaks = pushActions.tweaks) !== null && _pushActions$tweaks !== void 0 && _pushActions$tweaks.highlight ? 1 : 0; - } - - // Note: we don't need to handle 'total' notifications because the counts - // will come from the server. - room.setUnreadNotificationCount(_room.NotificationCountType.Highlight, highlightCount); - } - }); - this.ignoredInvites = new _invitesIgnorer.IgnoredInvites(this); - } - - /** - * High level helper method to begin syncing and poll for new events. To listen for these - * events, add a listener for {@link ClientEvent.Event} - * via {@link MatrixClient#on}. Alternatively, listen for specific - * state change events. - * @param opts - Options to apply when syncing. - */ - async startClient(opts) { - var _opts; - if (this.clientRunning) { - // client is already running. - return; - } - this.clientRunning = true; - // backwards compat for when 'opts' was 'historyLen'. - if (typeof opts === "number") { - opts = { - initialSyncLimit: opts - }; - } - - // Create our own user object artificially (instead of waiting for sync) - // so it's always available, even if the user is not in any rooms etc. - const userId = this.getUserId(); - if (userId) { - this.store.storeUser(new _user.User(userId)); - } - - // periodically poll for turn servers if we support voip - if (this.canSupportVoip) { - this.checkTurnServersIntervalID = setInterval(() => { - this.checkTurnServers(); - }, TURN_CHECK_INTERVAL); - // noinspection ES6MissingAwait - this.checkTurnServers(); - } - if (this.syncApi) { - // This shouldn't happen since we thought the client was not running - _logger.logger.error("Still have sync object whilst not running: stopping old one"); - this.syncApi.stop(); - } - try { - await this.getVersions(); - - // This should be done with `canSupport` - // TODO: https://github.com/vector-im/element-web/issues/23643 - const { - threads, - list, - fwdPagination - } = await this.doesServerSupportThread(); - _thread.Thread.setServerSideSupport(threads); - _thread.Thread.setServerSideListSupport(list); - _thread.Thread.setServerSideFwdPaginationSupport(fwdPagination); - } catch (e) { - _logger.logger.error("Can't fetch server versions, continuing to initialise sync, this will be retried later", e); - } - this.clientOpts = (_opts = opts) !== null && _opts !== void 0 ? _opts : {}; - if (this.clientOpts.slidingSync) { - this.syncApi = new _slidingSyncSdk.SlidingSyncSdk(this.clientOpts.slidingSync, this, this.clientOpts, this.buildSyncApiOptions()); - } else { - this.syncApi = new _sync.SyncApi(this, this.clientOpts, this.buildSyncApiOptions()); - } - if (this.clientOpts.hasOwnProperty("experimentalThreadSupport")) { - _logger.logger.warn("`experimentalThreadSupport` has been deprecated, use `threadSupport` instead"); - } - - // If `threadSupport` is omitted and the deprecated `experimentalThreadSupport` has been passed - // We should fallback to that value for backwards compatibility purposes - if (!this.clientOpts.hasOwnProperty("threadSupport") && this.clientOpts.hasOwnProperty("experimentalThreadSupport")) { - this.clientOpts.threadSupport = this.clientOpts.experimentalThreadSupport; - } - this.syncApi.sync(); - if (this.clientOpts.clientWellKnownPollPeriod !== undefined) { - this.clientWellKnownIntervalID = setInterval(() => { - this.fetchClientWellKnown(); - }, 1000 * this.clientOpts.clientWellKnownPollPeriod); - this.fetchClientWellKnown(); - } - this.toDeviceMessageQueue.start(); - } - - /** - * Construct a SyncApiOptions for this client, suitable for passing into the SyncApi constructor - */ - buildSyncApiOptions() { - return { - crypto: this.crypto, - cryptoCallbacks: this.cryptoBackend, - canResetEntireTimeline: roomId => { - if (!this.canResetTimelineCallback) { - return false; - } - return this.canResetTimelineCallback(roomId); - } - }; - } - - /** - * High level helper method to stop the client from polling and allow a - * clean shutdown. - */ - stopClient() { - var _this$cryptoBackend, _this$syncApi, _this$peekSync, _this$callEventHandle, _this$groupCallEventH; - (_this$cryptoBackend = this.cryptoBackend) === null || _this$cryptoBackend === void 0 ? void 0 : _this$cryptoBackend.stop(); // crypto might have been initialised even if the client wasn't fully started - - if (!this.clientRunning) return; // already stopped - - _logger.logger.log("stopping MatrixClient"); - this.clientRunning = false; - (_this$syncApi = this.syncApi) === null || _this$syncApi === void 0 ? void 0 : _this$syncApi.stop(); - this.syncApi = undefined; - (_this$peekSync = this.peekSync) === null || _this$peekSync === void 0 ? void 0 : _this$peekSync.stopPeeking(); - (_this$callEventHandle = this.callEventHandler) === null || _this$callEventHandle === void 0 ? void 0 : _this$callEventHandle.stop(); - (_this$groupCallEventH = this.groupCallEventHandler) === null || _this$groupCallEventH === void 0 ? void 0 : _this$groupCallEventH.stop(); - this.callEventHandler = undefined; - this.groupCallEventHandler = undefined; - global.clearInterval(this.checkTurnServersIntervalID); - this.checkTurnServersIntervalID = undefined; - if (this.clientWellKnownIntervalID !== undefined) { - global.clearInterval(this.clientWellKnownIntervalID); - } - this.toDeviceMessageQueue.stop(); - } - - /** - * Try to rehydrate a device if available. The client must have been - * initialized with a `cryptoCallback.getDehydrationKey` option, and this - * function must be called before initCrypto and startClient are called. - * - * @returns Promise which resolves to undefined if a device could not be dehydrated, or - * to the new device ID if the dehydration was successful. - * @returns Rejects: with an error response. - */ - async rehydrateDevice() { - if (this.crypto) { - throw new Error("Cannot rehydrate device after crypto is initialized"); - } - if (!this.cryptoCallbacks.getDehydrationKey) { - return; - } - const getDeviceResult = await this.getDehydratedDevice(); - if (!getDeviceResult) { - return; - } - if (!getDeviceResult.device_data || !getDeviceResult.device_id) { - _logger.logger.info("no dehydrated device found"); - return; - } - const account = new global.Olm.Account(); - try { - const deviceData = getDeviceResult.device_data; - if (deviceData.algorithm !== _dehydration.DEHYDRATION_ALGORITHM) { - _logger.logger.warn("Wrong algorithm for dehydrated device"); - return; - } - _logger.logger.log("unpickling dehydrated device"); - const key = await this.cryptoCallbacks.getDehydrationKey(deviceData, k => { - // copy the key so that it doesn't get clobbered - account.unpickle(new Uint8Array(k), deviceData.account); - }); - account.unpickle(key, deviceData.account); - _logger.logger.log("unpickled device"); - const rehydrateResult = await this.http.authedRequest(_httpApi.Method.Post, "/dehydrated_device/claim", undefined, { - device_id: getDeviceResult.device_id - }, { - prefix: "/_matrix/client/unstable/org.matrix.msc2697.v2" - }); - if (rehydrateResult.success) { - this.deviceId = getDeviceResult.device_id; - _logger.logger.info("using dehydrated device"); - const pickleKey = this.pickleKey || "DEFAULT_KEY"; - this.exportedOlmDeviceToImport = { - pickledAccount: account.pickle(pickleKey), - sessions: [], - pickleKey: pickleKey - }; - account.free(); - return this.deviceId; - } else { - account.free(); - _logger.logger.info("not using dehydrated device"); - return; - } - } catch (e) { - account.free(); - _logger.logger.warn("could not unpickle", e); - } - } - - /** - * Get the current dehydrated device, if any - * @returns A promise of an object containing the dehydrated device - */ - async getDehydratedDevice() { - try { - return await this.http.authedRequest(_httpApi.Method.Get, "/dehydrated_device", undefined, undefined, { - prefix: "/_matrix/client/unstable/org.matrix.msc2697.v2" - }); - } catch (e) { - _logger.logger.info("could not get dehydrated device", e); - return; - } - } - - /** - * Set the dehydration key. This will also periodically dehydrate devices to - * the server. - * - * @param key - the dehydration key - * @param keyInfo - Information about the key. Primarily for - * information about how to generate the key from a passphrase. - * @param deviceDisplayName - The device display name for the - * dehydrated device. - * @returns A promise that resolves when the dehydrated device is stored. - */ - async setDehydrationKey(key, keyInfo, deviceDisplayName) { - if (!this.crypto) { - _logger.logger.warn("not dehydrating device if crypto is not enabled"); - return; - } - return this.crypto.dehydrationManager.setKeyAndQueueDehydration(key, keyInfo, deviceDisplayName); - } - - /** - * Creates a new dehydrated device (without queuing periodic dehydration) - * @param key - the dehydration key - * @param keyInfo - Information about the key. Primarily for - * information about how to generate the key from a passphrase. - * @param deviceDisplayName - The device display name for the - * dehydrated device. - * @returns the device id of the newly created dehydrated device - */ - async createDehydratedDevice(key, keyInfo, deviceDisplayName) { - if (!this.crypto) { - _logger.logger.warn("not dehydrating device if crypto is not enabled"); - return; - } - await this.crypto.dehydrationManager.setKey(key, keyInfo, deviceDisplayName); - return this.crypto.dehydrationManager.dehydrateDevice(); - } - async exportDevice() { - if (!this.crypto) { - _logger.logger.warn("not exporting device if crypto is not enabled"); - return; - } - return { - userId: this.credentials.userId, - deviceId: this.deviceId, - // XXX: Private member access. - olmDevice: await this.crypto.olmDevice.export() - }; - } - - /** - * Clear any data out of the persistent stores used by the client. - * - * @returns Promise which resolves when the stores have been cleared. - */ - clearStores() { - if (this.clientRunning) { - throw new Error("Cannot clear stores while client is running"); - } - const promises = []; - promises.push(this.store.deleteAllData()); - if (this.cryptoStore) { - promises.push(this.cryptoStore.deleteAllData()); - } - - // delete the stores used by the rust matrix-sdk-crypto, in case they were used - const deleteRustSdkStore = async () => { - let indexedDB; - try { - indexedDB = global.indexedDB; - } catch (e) { - // No indexeddb support - return; - } - for (const dbname of [`${_constants.RUST_SDK_STORE_PREFIX}::matrix-sdk-crypto`, `${_constants.RUST_SDK_STORE_PREFIX}::matrix-sdk-crypto-meta`]) { - const prom = new Promise((resolve, reject) => { - _logger.logger.info(`Removing IndexedDB instance ${dbname}`); - const req = indexedDB.deleteDatabase(dbname); - req.onsuccess = _ => { - _logger.logger.info(`Removed IndexedDB instance ${dbname}`); - resolve(0); - }; - req.onerror = e => { - // In private browsing, Firefox has a global.indexedDB, but attempts to delete an indexeddb - // (even a non-existent one) fail with "DOMException: A mutation operation was attempted on a - // database that did not allow mutations." - // - // it seems like the only thing we can really do is ignore the error. - _logger.logger.warn(`Failed to remove IndexedDB instance ${dbname}:`, e); - resolve(0); - }; - req.onblocked = e => { - _logger.logger.info(`cannot yet remove IndexedDB instance ${dbname}`); - }; - }); - await prom; - } - }; - promises.push(deleteRustSdkStore()); - return Promise.all(promises).then(); // .then to fix types - } - - /** - * Get the user-id of the logged-in user - * - * @returns MXID for the logged-in user, or null if not logged in - */ - getUserId() { - if (this.credentials && this.credentials.userId) { - return this.credentials.userId; - } - return null; - } - - /** - * Get the user-id of the logged-in user - * - * @returns MXID for the logged-in user - * @throws Error if not logged in - */ - getSafeUserId() { - const userId = this.getUserId(); - if (!userId) { - throw new Error("Expected logged in user but found none."); - } - return userId; - } - - /** - * Get the domain for this client's MXID - * @returns Domain of this MXID - */ - getDomain() { - if (this.credentials && this.credentials.userId) { - return this.credentials.userId.replace(/^.*?:/, ""); - } - return null; - } - - /** - * Get the local part of the current user ID e.g. "foo" in "\@foo:bar". - * @returns The user ID localpart or null. - */ - getUserIdLocalpart() { - if (this.credentials && this.credentials.userId) { - return this.credentials.userId.split(":")[0].substring(1); - } - return null; - } - - /** - * Get the device ID of this client - * @returns device ID - */ - getDeviceId() { - return this.deviceId; - } - - /** - * Get the session ID of this client - * @returns session ID - */ - getSessionId() { - return this.sessionId; - } - - /** - * Check if the runtime environment supports VoIP calling. - * @returns True if VoIP is supported. - */ - supportsVoip() { - return this.canSupportVoip; - } - - /** - * @returns - */ - getMediaHandler() { - return this.mediaHandler; - } - - /** - * Set whether VoIP calls are forced to use only TURN - * candidates. This is the same as the forceTURN option - * when creating the client. - * @param force - True to force use of TURN servers - */ - setForceTURN(force) { - this.forceTURN = force; - } - - /** - * Set whether to advertise transfer support to other parties on Matrix calls. - * @param support - True to advertise the 'm.call.transferee' capability - */ - setSupportsCallTransfer(support) { - this.supportsCallTransfer = support; - } - - /** - * Returns true if to-device signalling for group calls will be encrypted with Olm. - * If false, it will be sent unencrypted. - * @returns boolean Whether group call signalling will be encrypted - */ - getUseE2eForGroupCall() { - return this.useE2eForGroupCall; - } - - /** - * Creates a new call. - * The place*Call methods on the returned call can be used to actually place a call - * - * @param roomId - The room the call is to be placed in. - * @returns the call or null if the browser doesn't support calling. - */ - createCall(roomId) { - return (0, _call.createNewMatrixCall)(this, roomId); - } - - /** - * Creates a new group call and sends the associated state event - * to alert other members that the room now has a group call. - * - * @param roomId - The room the call is to be placed in. - */ - async createGroupCall(roomId, type, isPtt, intent, dataChannelsEnabled, dataChannelOptions) { - if (this.getGroupCallForRoom(roomId)) { - throw new Error(`${roomId} already has an existing group call`); - } - const room = this.getRoom(roomId); - if (!room) { - throw new Error(`Cannot find room ${roomId}`); - } - - // Because without Media section a WebRTC connection is not possible, so need a RTCDataChannel to set up a - // no media WebRTC connection anyway. - return new _groupCall.GroupCall(this, room, type, isPtt, intent, undefined, dataChannelsEnabled || this.isVoipWithNoMediaAllowed, dataChannelOptions, this.isVoipWithNoMediaAllowed).create(); - } - - /** - * Wait until an initial state for the given room has been processed by the - * client and the client is aware of any ongoing group calls. Awaiting on - * the promise returned by this method before calling getGroupCallForRoom() - * avoids races where getGroupCallForRoom is called before the state for that - * room has been processed. It does not, however, fix other races, eg. two - * clients both creating a group call at the same time. - * @param roomId - The room ID to wait for - * @returns A promise that resolves once existing group calls in the room - * have been processed. - */ - waitUntilRoomReadyForGroupCalls(roomId) { - return this.groupCallEventHandler.waitUntilRoomReadyForGroupCalls(roomId); - } - - /** - * Get an existing group call for the provided room. - * @returns The group call or null if it doesn't already exist. - */ - getGroupCallForRoom(roomId) { - return this.groupCallEventHandler.groupCalls.get(roomId) || null; - } - - /** - * Get the current sync state. - * @returns the sync state, which may be null. - * @see MatrixClient#event:"sync" - */ - getSyncState() { - var _this$syncApi$getSync, _this$syncApi2; - return (_this$syncApi$getSync = (_this$syncApi2 = this.syncApi) === null || _this$syncApi2 === void 0 ? void 0 : _this$syncApi2.getSyncState()) !== null && _this$syncApi$getSync !== void 0 ? _this$syncApi$getSync : null; - } - - /** - * Returns the additional data object associated with - * the current sync state, or null if there is no - * such data. - * Sync errors, if available, are put in the 'error' key of - * this object. - */ - getSyncStateData() { - if (!this.syncApi) { - return null; - } - return this.syncApi.getSyncStateData(); - } - - /** - * Whether the initial sync has completed. - * @returns True if at least one sync has happened. - */ - isInitialSyncComplete() { - const state = this.getSyncState(); - if (!state) { - return false; - } - return state === _sync.SyncState.Prepared || state === _sync.SyncState.Syncing; - } - - /** - * Return whether the client is configured for a guest account. - * @returns True if this is a guest access_token (or no token is supplied). - */ - isGuest() { - return this.isGuestAccount; - } - - /** - * Set whether this client is a guest account. This method is experimental - * and may change without warning. - * @param guest - True if this is a guest account. - */ - setGuest(guest) { - // EXPERIMENTAL: - // If the token is a macaroon, it should be encoded in it that it is a 'guest' - // access token, which means that the SDK can determine this entirely without - // the dev manually flipping this flag. - this.isGuestAccount = guest; - } - - /** - * Return the provided scheduler, if any. - * @returns The scheduler or undefined - */ - getScheduler() { - return this.scheduler; - } - - /** - * Retry a backed off syncing request immediately. This should only be used when - * the user explicitly attempts to retry their lost connection. - * Will also retry any outbound to-device messages currently in the queue to be sent - * (retries of regular outgoing events are handled separately, per-event). - * @returns True if this resulted in a request being retried. - */ - retryImmediately() { - var _this$syncApi$retryIm, _this$syncApi3; - // don't await for this promise: we just want to kick it off - this.toDeviceMessageQueue.sendQueue(); - return (_this$syncApi$retryIm = (_this$syncApi3 = this.syncApi) === null || _this$syncApi3 === void 0 ? void 0 : _this$syncApi3.retryImmediately()) !== null && _this$syncApi$retryIm !== void 0 ? _this$syncApi$retryIm : false; - } - - /** - * Return the global notification EventTimelineSet, if any - * - * @returns the globl notification EventTimelineSet - */ - getNotifTimelineSet() { - return this.notifTimelineSet; - } - - /** - * Set the global notification EventTimelineSet - * - */ - setNotifTimelineSet(set) { - this.notifTimelineSet = set; - } - - /** - * Gets the capabilities of the homeserver. Always returns an object of - * capability keys and their options, which may be empty. - * @param fresh - True to ignore any cached values. - * @returns Promise which resolves to the capabilities of the homeserver - * @returns Rejects: with an error response. - */ - getCapabilities(fresh = false) { - const now = new Date().getTime(); - if (this.cachedCapabilities && !fresh) { - if (now < this.cachedCapabilities.expiration) { - _logger.logger.log("Returning cached capabilities"); - return Promise.resolve(this.cachedCapabilities.capabilities); - } - } - return this.http.authedRequest(_httpApi.Method.Get, "/capabilities").catch(e => { - // We swallow errors because we need a default object anyhow - _logger.logger.error(e); - return {}; - }).then((r = {}) => { - const capabilities = r["capabilities"] || {}; - - // If the capabilities missed the cache, cache it for a shorter amount - // of time to try and refresh them later. - const cacheMs = Object.keys(capabilities).length ? CAPABILITIES_CACHE_MS : 60000 + Math.random() * 5000; - this.cachedCapabilities = { - capabilities, - expiration: now + cacheMs - }; - _logger.logger.log("Caching capabilities: ", capabilities); - return capabilities; - }); - } - - /** - * Initialise support for end-to-end encryption in this client, using libolm. - * - * You should call this method after creating the matrixclient, but *before* - * calling `startClient`, if you want to support end-to-end encryption. - * - * It will return a Promise which will resolve when the crypto layer has been - * successfully initialised. - */ - async initCrypto() { - if (!(0, _crypto.isCryptoAvailable)()) { - throw new Error(`End-to-end encryption not supported in this js-sdk build: did ` + `you remember to load the olm library?`); - } - if (this.cryptoBackend) { - _logger.logger.warn("Attempt to re-initialise e2e encryption on MatrixClient"); - return; - } - if (!this.cryptoStore) { - // the cryptostore is provided by sdk.createClient, so this shouldn't happen - throw new Error(`Cannot enable encryption: no cryptoStore provided`); - } - _logger.logger.log("Crypto: Starting up crypto store..."); - await this.cryptoStore.startup(); - - // initialise the list of encrypted rooms (whether or not crypto is enabled) - _logger.logger.log("Crypto: initialising roomlist..."); - await this.roomList.init(); - const userId = this.getUserId(); - if (userId === null) { - throw new Error(`Cannot enable encryption on MatrixClient with unknown userId: ` + `ensure userId is passed in createClient().`); - } - if (this.deviceId === null) { - throw new Error(`Cannot enable encryption on MatrixClient with unknown deviceId: ` + `ensure deviceId is passed in createClient().`); - } - const crypto = new _crypto.Crypto(this, userId, this.deviceId, this.store, this.cryptoStore, this.roomList, this.verificationMethods); - this.reEmitter.reEmit(crypto, [_crypto.CryptoEvent.KeyBackupFailed, _crypto.CryptoEvent.KeyBackupSessionsRemaining, _crypto.CryptoEvent.RoomKeyRequest, _crypto.CryptoEvent.RoomKeyRequestCancellation, _crypto.CryptoEvent.Warning, _crypto.CryptoEvent.DevicesUpdated, _crypto.CryptoEvent.WillUpdateDevices, _crypto.CryptoEvent.DeviceVerificationChanged, _crypto.CryptoEvent.UserTrustStatusChanged, _crypto.CryptoEvent.KeysChanged]); - _logger.logger.log("Crypto: initialising crypto object..."); - await crypto.init({ - exportedOlmDevice: this.exportedOlmDeviceToImport, - pickleKey: this.pickleKey - }); - delete this.exportedOlmDeviceToImport; - this.olmVersion = _crypto.Crypto.getOlmVersion(); - - // if crypto initialisation was successful, tell it to attach its event handlers. - crypto.registerEventHandlers(this); - this.cryptoBackend = this.crypto = crypto; - - // upload our keys in the background - this.crypto.uploadDeviceKeys().catch(e => { - // TODO: throwing away this error is a really bad idea. - _logger.logger.error("Error uploading device keys", e); - }); - } - - /** - * Initialise support for end-to-end encryption in this client, using the rust matrix-sdk-crypto. - * - * An alternative to {@link initCrypto}. - * - * *WARNING*: this API is very experimental, should not be used in production, and may change without notice! - * Eventually it will be deprecated and `initCrypto` will do the same thing. - * - * @experimental - * - * @returns a Promise which will resolve when the crypto layer has been - * successfully initialised. - */ - async initRustCrypto() { - if (this.cryptoBackend) { - _logger.logger.warn("Attempt to re-initialise e2e encryption on MatrixClient"); - return; - } - const userId = this.getUserId(); - if (userId === null) { - throw new Error(`Cannot enable encryption on MatrixClient with unknown userId: ` + `ensure userId is passed in createClient().`); - } - const deviceId = this.getDeviceId(); - if (deviceId === null) { - throw new Error(`Cannot enable encryption on MatrixClient with unknown deviceId: ` + `ensure deviceId is passed in createClient().`); - } - - // importing rust-crypto will download the webassembly, so we delay it until we know it will be - // needed. - const RustCrypto = await Promise.resolve().then(() => _interopRequireWildcard(require("./rust-crypto"))); - const rustCrypto = await RustCrypto.initRustCrypto(this.http, userId, deviceId); - this.cryptoBackend = rustCrypto; - - // attach the event listeners needed by RustCrypto - this.on(_roomMember.RoomMemberEvent.Membership, rustCrypto.onRoomMembership.bind(rustCrypto)); - } - - /** - * Access the crypto API for this client. - * - * If end-to-end encryption has been enabled for this client (via {@link initCrypto} or {@link initRustCrypto}), - * returns an object giving access to the crypto API. Otherwise, returns `undefined`. - */ - getCrypto() { - return this.cryptoBackend; - } - - /** - * Is end-to-end crypto enabled for this client. - * @returns True if end-to-end is enabled. - * @deprecated prefer {@link getCrypto} - */ - isCryptoEnabled() { - return !!this.cryptoBackend; - } - - /** - * Get the Ed25519 key for this device - * - * @returns base64-encoded ed25519 key. Null if crypto is - * disabled. - */ - getDeviceEd25519Key() { - var _this$crypto$getDevic, _this$crypto; - return (_this$crypto$getDevic = (_this$crypto = this.crypto) === null || _this$crypto === void 0 ? void 0 : _this$crypto.getDeviceEd25519Key()) !== null && _this$crypto$getDevic !== void 0 ? _this$crypto$getDevic : null; - } - - /** - * Get the Curve25519 key for this device - * - * @returns base64-encoded curve25519 key. Null if crypto is - * disabled. - */ - getDeviceCurve25519Key() { - var _this$crypto$getDevic2, _this$crypto2; - return (_this$crypto$getDevic2 = (_this$crypto2 = this.crypto) === null || _this$crypto2 === void 0 ? void 0 : _this$crypto2.getDeviceCurve25519Key()) !== null && _this$crypto$getDevic2 !== void 0 ? _this$crypto$getDevic2 : null; - } - - /** - * @deprecated Does nothing. - */ - async uploadKeys() { - _logger.logger.warn("MatrixClient.uploadKeys is deprecated"); - } - - /** - * Download the keys for a list of users and stores the keys in the session - * store. - * @param userIds - The users to fetch. - * @param forceDownload - Always download the keys even if cached. - * - * @returns A promise which resolves to a map userId-\>deviceId-\>{@link DeviceInfo} - */ - downloadKeys(userIds, forceDownload) { - if (!this.crypto) { - return Promise.reject(new Error("End-to-end encryption disabled")); - } - return this.crypto.downloadKeys(userIds, forceDownload); - } - - /** - * Get the stored device keys for a user id - * - * @param userId - the user to list keys for. - * - * @returns list of devices - */ - getStoredDevicesForUser(userId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getStoredDevicesForUser(userId) || []; - } - - /** - * Get the stored device key for a user id and device id - * - * @param userId - the user to list keys for. - * @param deviceId - unique identifier for the device - * - * @returns device or null - */ - getStoredDevice(userId, deviceId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getStoredDevice(userId, deviceId) || null; - } - - /** - * Mark the given device as verified - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param verified - whether to mark the device as verified. defaults - * to 'true'. - * - * @returns - * - * @remarks - * Fires {@link CryptoEvent#DeviceVerificationChanged} - */ - setDeviceVerified(userId, deviceId, verified = true) { - const prom = this.setDeviceVerification(userId, deviceId, verified, null, null); - - // if one of the user's own devices is being marked as verified / unverified, - // check the key backup status, since whether or not we use this depends on - // whether it has a signature from a verified device - if (userId == this.credentials.userId) { - this.checkKeyBackup(); - } - return prom; - } - - /** - * Mark the given device as blocked/unblocked - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param blocked - whether to mark the device as blocked. defaults - * to 'true'. - * - * @returns - * - * @remarks - * Fires {@link CryptoEvent.DeviceVerificationChanged} - */ - setDeviceBlocked(userId, deviceId, blocked = true) { - return this.setDeviceVerification(userId, deviceId, null, blocked, null); - } - - /** - * Mark the given device as known/unknown - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param known - whether to mark the device as known. defaults - * to 'true'. - * - * @returns - * - * @remarks - * Fires {@link CryptoEvent#DeviceVerificationChanged} - */ - setDeviceKnown(userId, deviceId, known = true) { - return this.setDeviceVerification(userId, deviceId, null, null, known); - } - async setDeviceVerification(userId, deviceId, verified, blocked, known) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - await this.crypto.setDeviceVerification(userId, deviceId, verified, blocked, known); - } - - /** - * Request a key verification from another user, using a DM. - * - * @param userId - the user to request verification with - * @param roomId - the room to use for verification - * - * @returns resolves to a VerificationRequest - * when the request has been sent to the other party. - */ - requestVerificationDM(userId, roomId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.requestVerificationDM(userId, roomId); - } - - /** - * Finds a DM verification request that is already in progress for the given room id - * - * @param roomId - the room to use for verification - * - * @returns the VerificationRequest that is in progress, if any - */ - findVerificationRequestDMInProgress(roomId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.findVerificationRequestDMInProgress(roomId); - } - - /** - * Returns all to-device verification requests that are already in progress for the given user id - * - * @param userId - the ID of the user to query - * - * @returns the VerificationRequests that are in progress - */ - getVerificationRequestsToDeviceInProgress(userId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getVerificationRequestsToDeviceInProgress(userId); - } - - /** - * Request a key verification from another user. - * - * @param userId - the user to request verification with - * @param devices - array of device IDs to send requests to. Defaults to - * all devices owned by the user - * - * @returns resolves to a VerificationRequest - * when the request has been sent to the other party. - */ - requestVerification(userId, devices) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.requestVerification(userId, devices); - } - - /** - * Begin a key verification. - * - * @param method - the verification method to use - * @param userId - the user to verify keys with - * @param deviceId - the device to verify - * - * @returns a verification object - * @deprecated Use `requestVerification` instead. - */ - beginKeyVerification(method, userId, deviceId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.beginKeyVerification(method, userId, deviceId); - } - checkSecretStorageKey(key, info) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.checkSecretStorageKey(key, info); - } - - /** - * Set the global override for whether the client should ever send encrypted - * messages to unverified devices. This provides the default for rooms which - * do not specify a value. - * - * @param value - whether to blacklist all unverified devices by default - * - * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}: - * - * ```javascript - * client.getCrypto().globalBlacklistUnverifiedDevices = value; - * ``` - */ - setGlobalBlacklistUnverifiedDevices(value) { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - this.cryptoBackend.globalBlacklistUnverifiedDevices = value; - return value; - } - - /** - * @returns whether to blacklist all unverified devices by default - * - * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}: - * - * ```javascript - * value = client.getCrypto().globalBlacklistUnverifiedDevices; - * ``` - */ - getGlobalBlacklistUnverifiedDevices() { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - return this.cryptoBackend.globalBlacklistUnverifiedDevices; - } - - /** - * Set whether sendMessage in a room with unknown and unverified devices - * should throw an error and not send them message. This has 'Global' for - * symmetry with setGlobalBlacklistUnverifiedDevices but there is currently - * no room-level equivalent for this setting. - * - * This API is currently UNSTABLE and may change or be removed without notice. - * - * @param value - whether error on unknown devices - * - * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}: - * - * ```ts - * client.getCrypto().globalBlacklistUnverifiedDevices = value; - * ``` - */ - setGlobalErrorOnUnknownDevices(value) { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - this.cryptoBackend.globalErrorOnUnknownDevices = value; - } - - /** - * @returns whether to error on unknown devices - * - * This API is currently UNSTABLE and may change or be removed without notice. - */ - getGlobalErrorOnUnknownDevices() { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - return this.cryptoBackend.globalErrorOnUnknownDevices; - } - - /** - * Get the user's cross-signing key ID. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param type - The type of key to get the ID of. One of - * "master", "self_signing", or "user_signing". Defaults to "master". - * - * @returns the key ID - */ - getCrossSigningId(type = _api.CrossSigningKey.Master) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getCrossSigningId(type); - } - - /** - * Get the cross signing information for a given user. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param userId - the user ID to get the cross-signing info for. - * - * @returns the cross signing information for the user. - */ - getStoredCrossSigningForUser(userId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getStoredCrossSigningForUser(userId); - } - - /** - * Check whether a given user is trusted. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param userId - The ID of the user to check. - */ - checkUserTrust(userId) { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - return this.cryptoBackend.checkUserTrust(userId); - } - - /** - * Check whether a given device is trusted. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param userId - The ID of the user whose devices is to be checked. - * @param deviceId - The ID of the device to check - */ - checkDeviceTrust(userId, deviceId) { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - return this.cryptoBackend.checkDeviceTrust(userId, deviceId); - } - - /** - * Check whether one of our own devices is cross-signed by our - * user's stored keys, regardless of whether we trust those keys yet. - * - * @param deviceId - The ID of the device to check - * - * @returns true if the device is cross-signed - */ - checkIfOwnDeviceCrossSigned(deviceId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.checkIfOwnDeviceCrossSigned(deviceId); - } - - /** - * Check the copy of our cross-signing key that we have in the device list and - * see if we can get the private key. If so, mark it as trusted. - * @param opts - ICheckOwnCrossSigningTrustOpts object - */ - checkOwnCrossSigningTrust(opts) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.checkOwnCrossSigningTrust(opts); - } - - /** - * Checks that a given cross-signing private key matches a given public key. - * This can be used by the getCrossSigningKey callback to verify that the - * private key it is about to supply is the one that was requested. - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkCrossSigningPrivateKey(privateKey, expectedPublicKey) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.checkCrossSigningPrivateKey(privateKey, expectedPublicKey); - } - - // deprecated: use requestVerification instead - legacyDeviceVerification(userId, deviceId, method) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.legacyDeviceVerification(userId, deviceId, method); - } - - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * @param room - the room the event is in - * - * @deprecated Prefer {@link CryptoApi.prepareToEncrypt | `CryptoApi.prepareToEncrypt`}: - * - * ```javascript - * client.getCrypto().prepareToEncrypt(room); - * ``` - */ - prepareToEncrypt(room) { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - this.cryptoBackend.prepareToEncrypt(room); - } - - /** - * Checks if the user has previously published cross-signing keys - * - * This means downloading the devicelist for the user and checking if the list includes - * the cross-signing pseudo-device. - * - * @deprecated Prefer {@link CryptoApi.userHasCrossSigningKeys | `CryptoApi.userHasCrossSigningKeys`}: - * - * ```javascript - * result = client.getCrypto().userHasCrossSigningKeys(); - * ``` - */ - userHasCrossSigningKeys() { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - return this.cryptoBackend.userHasCrossSigningKeys(); - } - - /** - * Checks whether cross signing: - * - is enabled on this account and trusted by this device - * - has private keys either cached locally or stored in secret storage - * - * If this function returns false, bootstrapCrossSigning() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapCrossSigning() completes successfully, this function should - * return true. - * @returns True if cross-signing is ready to be used on this device - */ - isCrossSigningReady() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.isCrossSigningReady(); - } - - /** - * Bootstrap cross-signing by creating keys if needed. If everything is already - * set up, then no changes are made, so this is safe to run to ensure - * cross-signing is ready for use. - * - * This function: - * - creates new cross-signing keys if they are not found locally cached nor in - * secret storage (if it has been setup) - * - * The cross-signing API is currently UNSTABLE and may change without notice. - */ - bootstrapCrossSigning(opts) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.bootstrapCrossSigning(opts); - } - - /** - * Whether to trust a others users signatures of their devices. - * If false, devices will only be considered 'verified' if we have - * verified that device individually (effectively disabling cross-signing). - * - * Default: true - * - * @returns True if trusting cross-signed devices - */ - getCryptoTrustCrossSignedDevices() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getCryptoTrustCrossSignedDevices(); - } - - /** - * See getCryptoTrustCrossSignedDevices - * - * @param val - True to trust cross-signed devices - */ - setCryptoTrustCrossSignedDevices(val) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - this.crypto.setCryptoTrustCrossSignedDevices(val); - } - - /** - * Counts the number of end to end session keys that are waiting to be backed up - * @returns Promise which resolves to the number of sessions requiring backup - */ - countSessionsNeedingBackup() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.countSessionsNeedingBackup(); - } - - /** - * Get information about the encryption of an event - * - * @param event - event to be checked - * @returns The event information. - */ - getEventEncryptionInfo(event) { - if (!this.cryptoBackend) { - throw new Error("End-to-end encryption disabled"); - } - return this.cryptoBackend.getEventEncryptionInfo(event); - } - - /** - * Create a recovery key from a user-supplied passphrase. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param password - Passphrase string that can be entered by the user - * when restoring the backup as an alternative to entering the recovery key. - * Optional. - * @returns Object with public key metadata, encoded private - * recovery key which should be disposed of after displaying to the user, - * and raw private key to avoid round tripping if needed. - */ - createRecoveryKeyFromPassphrase(password) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.createRecoveryKeyFromPassphrase(password); - } - - /** - * Checks whether secret storage: - * - is enabled on this account - * - is storing cross-signing private keys - * - is storing session backup key (if enabled) - * - * If this function returns false, bootstrapSecretStorage() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapSecretStorage() completes successfully, this function should - * return true. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @returns True if secret storage is ready to be used on this device - */ - isSecretStorageReady() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.isSecretStorageReady(); - } - - /** - * Bootstrap Secure Secret Storage if needed by creating a default key. If everything is - * already set up, then no changes are made, so this is safe to run to ensure secret - * storage is ready for use. - * - * This function - * - creates a new Secure Secret Storage key if no default key exists - * - if a key backup exists, it is migrated to store the key in the Secret - * Storage - * - creates a backup if none exists, and one is requested - * - migrates Secure Secret Storage to use the latest algorithm, if an outdated - * algorithm is found - * - */ - bootstrapSecretStorage(opts) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.bootstrapSecretStorage(opts); - } - - /** - * Add a key for encrypting secrets. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param algorithm - the algorithm used by the key - * @param opts - the options for the algorithm. The properties used - * depend on the algorithm given. - * @param keyName - the name of the key. If not given, a random name will be generated. - * - * @returns An object with: - * keyId: the ID of the key - * keyInfo: details about the key (iv, mac, passphrase) - */ - addSecretStorageKey(algorithm, opts, keyName) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.addSecretStorageKey(algorithm, opts, keyName); - } - - /** - * Check whether we have a key with a given ID. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param keyId - The ID of the key to check - * for. Defaults to the default key ID if not provided. - * @returns Whether we have the key. - */ - hasSecretStorageKey(keyId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.hasSecretStorageKey(keyId); - } - - /** - * Store an encrypted secret on the server. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - The name of the secret - * @param secret - The secret contents. - * @param keys - The IDs of the keys to use to encrypt the secret or null/undefined - * to use the default (will throw if no default key is set). - */ - storeSecret(name, secret, keys) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.storeSecret(name, secret, keys); - } - - /** - * Get a secret from storage. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - the name of the secret - * - * @returns the contents of the secret - */ - getSecret(name) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getSecret(name); - } - - /** - * Check if a secret is stored on the server. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - the name of the secret - * @returns map of key name to key info the secret is encrypted - * with, or null if it is not present or not encrypted with a trusted - * key - */ - isSecretStored(name) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.isSecretStored(name); - } - - /** - * Request a secret from another device. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param name - the name of the secret to request - * @param devices - the devices to request the secret from - * - * @returns the secret request object - */ - requestSecret(name, devices) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.requestSecret(name, devices); - } - - /** - * Get the current default key ID for encrypting secrets. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @returns The default key ID or null if no default key ID is set - */ - getDefaultSecretStorageKeyId() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.getDefaultSecretStorageKeyId(); - } - - /** - * Set the current default key ID for encrypting secrets. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param keyId - The new default key ID - */ - setDefaultSecretStorageKeyId(keyId) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.setDefaultSecretStorageKeyId(keyId); - } - - /** - * Checks that a given secret storage private key matches a given public key. - * This can be used by the getSecretStorageKey callback to verify that the - * private key it is about to supply is the one that was requested. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkSecretStoragePrivateKey(privateKey, expectedPublicKey) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.checkSecretStoragePrivateKey(privateKey, expectedPublicKey); - } - - /** - * Get e2e information on the device that sent an event - * - * @param event - event to be checked - */ - async getEventSenderDeviceInfo(event) { - if (!this.crypto) { - return null; - } - return this.crypto.getEventSenderDeviceInfo(event); - } - - /** - * Check if the sender of an event is verified - * - * @param event - event to be checked - * - * @returns true if the sender of this event has been verified using - * {@link MatrixClient#setDeviceVerified}. - */ - async isEventSenderVerified(event) { - const device = await this.getEventSenderDeviceInfo(event); - if (!device) { - return false; - } - return device.isVerified(); - } - - /** - * Get outgoing room key request for this event if there is one. - * @param event - The event to check for - * - * @returns A room key request, or null if there is none - */ - getOutgoingRoomKeyRequest(event) { - if (!this.crypto) { - throw new Error("End-to-End encryption disabled"); - } - const wireContent = event.getWireContent(); - const requestBody = { - session_id: wireContent.session_id, - sender_key: wireContent.sender_key, - algorithm: wireContent.algorithm, - room_id: event.getRoomId() - }; - if (!requestBody.session_id || !requestBody.sender_key || !requestBody.algorithm || !requestBody.room_id) { - return Promise.resolve(null); - } - return this.crypto.cryptoStore.getOutgoingRoomKeyRequest(requestBody); - } - - /** - * Cancel a room key request for this event if one is ongoing and resend the - * request. - * @param event - event of which to cancel and resend the room - * key request. - * @returns A promise that will resolve when the key request is queued - */ - cancelAndResendEventRoomKeyRequest(event) { - if (!this.crypto) { - throw new Error("End-to-End encryption disabled"); - } - return event.cancelAndResendKeyRequest(this.crypto, this.getUserId()); - } - - /** - * Enable end-to-end encryption for a room. This does not modify room state. - * Any messages sent before the returned promise resolves will be sent unencrypted. - * @param roomId - The room ID to enable encryption in. - * @param config - The encryption config for the room. - * @returns A promise that will resolve when encryption is set up. - */ - setRoomEncryption(roomId, config) { - if (!this.crypto) { - throw new Error("End-to-End encryption disabled"); - } - return this.crypto.setRoomEncryption(roomId, config); - } - - /** - * Whether encryption is enabled for a room. - * @param roomId - the room id to query. - * @returns whether encryption is enabled. - */ - isRoomEncrypted(roomId) { - const room = this.getRoom(roomId); - if (!room) { - // we don't know about this room, so can't determine if it should be - // encrypted. Let's assume not. - return false; - } - - // if there is an 'm.room.encryption' event in this room, it should be - // encrypted (independently of whether we actually support encryption) - const ev = room.currentState.getStateEvents(_event2.EventType.RoomEncryption, ""); - if (ev) { - return true; - } - - // we don't have an m.room.encrypted event, but that might be because - // the server is hiding it from us. Check the store to see if it was - // previously encrypted. - return this.roomList.isRoomEncrypted(roomId); - } - - /** - * Encrypts and sends a given object via Olm to-device messages to a given - * set of devices. - * - * @param userDeviceMap - mapping from userId to deviceInfo - * - * @param payload - fields to include in the encrypted payload - * - * @returns Promise which - * resolves once the message has been encrypted and sent to the given - * userDeviceMap, and returns the `{ contentMap, deviceInfoByDeviceId }` - * of the successfully sent messages. - */ - encryptAndSendToDevices(userDeviceInfoArr, payload) { - if (!this.crypto) { - throw new Error("End-to-End encryption disabled"); - } - return this.crypto.encryptAndSendToDevices(userDeviceInfoArr, payload); - } - - /** - * Forces the current outbound group session to be discarded such - * that another one will be created next time an event is sent. - * - * @param roomId - The ID of the room to discard the session for - * - * @deprecated Prefer {@link CryptoApi.forceDiscardSession | `CryptoApi.forceDiscardSession`}: - * - */ - forceDiscardSession(roomId) { - if (!this.cryptoBackend) { - throw new Error("End-to-End encryption disabled"); - } - this.cryptoBackend.forceDiscardSession(roomId); - } - - /** - * Get a list containing all of the room keys - * - * This should be encrypted before returning it to the user. - * - * @returns a promise which resolves to a list of session export objects - * - * @deprecated Prefer {@link CryptoApi.exportRoomKeys | `CryptoApi.exportRoomKeys`}: - * - * ```javascript - * sessionData = await client.getCrypto().exportRoomKeys(); - * ``` - */ - exportRoomKeys() { - if (!this.cryptoBackend) { - return Promise.reject(new Error("End-to-end encryption disabled")); - } - return this.cryptoBackend.exportRoomKeys(); - } - - /** - * Import a list of room keys previously exported by exportRoomKeys - * - * @param keys - a list of session export objects - * - * @returns a promise which resolves when the keys have been imported - */ - importRoomKeys(keys, opts) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.importRoomKeys(keys, opts); - } - - /** - * Force a re-check of the local key backup status against - * what's on the server. - * - * @returns Object with backup info (as returned by - * getKeyBackupVersion) in backupInfo and - * trust information (as returned by isKeyBackupTrusted) - * in trustInfo. - */ - checkKeyBackup() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.backupManager.checkKeyBackup(); - } - - /** - * Get information about the current key backup. - * @returns Information object from API or null - */ - async getKeyBackupVersion() { - let res; - try { - res = await this.http.authedRequest(_httpApi.Method.Get, "/room_keys/version", undefined, undefined, { - prefix: _httpApi.ClientPrefix.V3 - }); - } catch (e) { - if (e.errcode === "M_NOT_FOUND") { - return null; - } else { - throw e; - } - } - _backup.BackupManager.checkBackupVersion(res); - return res; - } - - /** - * @param info - key backup info dict from getKeyBackupVersion() - */ - isKeyBackupTrusted(info) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.backupManager.isKeyBackupTrusted(info); - } - - /** - * @returns true if the client is configured to back up keys to - * the server, otherwise false. If we haven't completed a successful check - * of key backup status yet, returns null. - */ - getKeyBackupEnabled() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.backupManager.getKeyBackupEnabled(); - } - - /** - * Enable backing up of keys, using data previously returned from - * getKeyBackupVersion. - * - * @param info - Backup information object as returned by getKeyBackupVersion - * @returns Promise which resolves when complete. - */ - enableKeyBackup(info) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.backupManager.enableKeyBackup(info); - } - - /** - * Disable backing up of keys. - */ - disableKeyBackup() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - this.crypto.backupManager.disableKeyBackup(); - } - - /** - * Set up the data required to create a new backup version. The backup version - * will not be created and enabled until createKeyBackupVersion is called. - * - * @param password - Passphrase string that can be entered by the user - * when restoring the backup as an alternative to entering the recovery key. - * Optional. - * - * @returns Object that can be passed to createKeyBackupVersion and - * additionally has a 'recovery_key' member with the user-facing recovery key string. - */ - async prepareKeyBackupVersion(password, opts = { - secureSecretStorage: false - }) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - - // eslint-disable-next-line camelcase - const { - algorithm, - auth_data, - recovery_key, - privateKey - } = await this.crypto.backupManager.prepareKeyBackupVersion(password); - if (opts.secureSecretStorage) { - await this.storeSecret("m.megolm_backup.v1", (0, olmlib.encodeBase64)(privateKey)); - _logger.logger.info("Key backup private key stored in secret storage"); - } - return { - algorithm, - /* eslint-disable camelcase */ - auth_data, - recovery_key - /* eslint-enable camelcase */ - }; - } - - /** - * Check whether the key backup private key is stored in secret storage. - * @returns map of key name to key info the secret is - * encrypted with, or null if it is not present or not encrypted with a - * trusted key - */ - isKeyBackupKeyStored() { - return Promise.resolve(this.isSecretStored("m.megolm_backup.v1")); - } - - /** - * Create a new key backup version and enable it, using the information return - * from prepareKeyBackupVersion. - * - * @param info - Info object from prepareKeyBackupVersion - * @returns Object with 'version' param indicating the version created - */ - async createKeyBackupVersion(info) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - await this.crypto.backupManager.createKeyBackupVersion(info); - const data = { - algorithm: info.algorithm, - auth_data: info.auth_data - }; - - // Sign the backup auth data with the device key for backwards compat with - // older devices with cross-signing. This can probably go away very soon in - // favour of just signing with the cross-singing master key. - // XXX: Private member access - await this.crypto.signObject(data.auth_data); - if (this.cryptoCallbacks.getCrossSigningKey && - // XXX: Private member access - this.crypto.crossSigningInfo.getId()) { - // now also sign the auth data with the cross-signing master key - // we check for the callback explicitly here because we still want to be able - // to create an un-cross-signed key backup if there is a cross-signing key but - // no callback supplied. - // XXX: Private member access - await this.crypto.crossSigningInfo.signObject(data.auth_data, "master"); - } - const res = await this.http.authedRequest(_httpApi.Method.Post, "/room_keys/version", undefined, data, { - prefix: _httpApi.ClientPrefix.V3 - }); - - // We could assume everything's okay and enable directly, but this ensures - // we run the same signature verification that will be used for future - // sessions. - await this.checkKeyBackup(); - if (!this.getKeyBackupEnabled()) { - _logger.logger.error("Key backup not usable even though we just created it"); - } - return res; - } - async deleteKeyBackupVersion(version) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - - // If we're currently backing up to this backup... stop. - // (We start using it automatically in createKeyBackupVersion - // so this is symmetrical). - if (this.crypto.backupManager.version) { - this.crypto.backupManager.disableKeyBackup(); - } - const path = utils.encodeUri("/room_keys/version/$version", { - $version: version - }); - await this.http.authedRequest(_httpApi.Method.Delete, path, undefined, undefined, { - prefix: _httpApi.ClientPrefix.V3 - }); - } - makeKeyBackupPath(roomId, sessionId, version) { - let path; - if (sessionId !== undefined) { - path = utils.encodeUri("/room_keys/keys/$roomId/$sessionId", { - $roomId: roomId, - $sessionId: sessionId - }); - } else if (roomId !== undefined) { - path = utils.encodeUri("/room_keys/keys/$roomId", { - $roomId: roomId - }); - } else { - path = "/room_keys/keys"; - } - const queryData = version === undefined ? undefined : { - version - }; - return { - path, - queryData - }; - } - - /** - * Back up session keys to the homeserver. - * @param roomId - ID of the room that the keys are for Optional. - * @param sessionId - ID of the session that the keys are for Optional. - * @param version - backup version Optional. - * @param data - Object keys to send - * @returns a promise that will resolve when the keys - * are uploaded - */ - - async sendKeyBackup(roomId, sessionId, version, data) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - const path = this.makeKeyBackupPath(roomId, sessionId, version); - await this.http.authedRequest(_httpApi.Method.Put, path.path, path.queryData, data, { - prefix: _httpApi.ClientPrefix.V3 - }); - } - - /** - * Marks all group sessions as needing to be backed up and schedules them to - * upload in the background as soon as possible. - */ - async scheduleAllGroupSessionsForBackup() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - await this.crypto.backupManager.scheduleAllGroupSessionsForBackup(); - } - - /** - * Marks all group sessions as needing to be backed up without scheduling - * them to upload in the background. - * @returns Promise which resolves to the number of sessions requiring a backup. - */ - flagAllGroupSessionsForBackup() { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - return this.crypto.backupManager.flagAllGroupSessionsForBackup(); - } - isValidRecoveryKey(recoveryKey) { - try { - (0, _recoverykey.decodeRecoveryKey)(recoveryKey); - return true; - } catch (e) { - return false; - } - } - - /** - * Get the raw key for a key backup from the password - * Used when migrating key backups into SSSS - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param password - Passphrase - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @returns key backup key - */ - keyBackupKeyFromPassword(password, backupInfo) { - return (0, _key_passphrase.keyFromAuthData)(backupInfo.auth_data, password); - } - - /** - * Get the raw key for a key backup from the recovery key - * Used when migrating key backups into SSSS - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param recoveryKey - The recovery key - * @returns key backup key - */ - keyBackupKeyFromRecoveryKey(recoveryKey) { - return (0, _recoverykey.decodeRecoveryKey)(recoveryKey); - } - - /** - * Restore from an existing key backup via a passphrase. - * - * @param password - Passphrase - * @param targetRoomId - Room ID to target a specific room. - * Restores all rooms if omitted. - * @param targetSessionId - Session ID to target a specific session. - * Restores all sessions if omitted. - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @param opts - Optional params such as callbacks - * @returns Status of restoration with `total` and `imported` - * key counts. - */ - - async restoreKeyBackupWithPassword(password, targetRoomId, targetSessionId, backupInfo, opts) { - const privKey = await (0, _key_passphrase.keyFromAuthData)(backupInfo.auth_data, password); - return this.restoreKeyBackup(privKey, targetRoomId, targetSessionId, backupInfo, opts); - } - - /** - * Restore from an existing key backup via a private key stored in secret - * storage. - * - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @param targetRoomId - Room ID to target a specific room. - * Restores all rooms if omitted. - * @param targetSessionId - Session ID to target a specific session. - * Restores all sessions if omitted. - * @param opts - Optional params such as callbacks - * @returns Status of restoration with `total` and `imported` - * key counts. - */ - async restoreKeyBackupWithSecretStorage(backupInfo, targetRoomId, targetSessionId, opts) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - const storedKey = await this.getSecret("m.megolm_backup.v1"); - - // ensure that the key is in the right format. If not, fix the key and - // store the fixed version - const fixedKey = (0, _crypto.fixBackupKey)(storedKey); - if (fixedKey) { - const keys = await this.crypto.getSecretStorageKey(); - await this.storeSecret("m.megolm_backup.v1", fixedKey, [keys[0]]); - } - const privKey = (0, olmlib.decodeBase64)(fixedKey || storedKey); - return this.restoreKeyBackup(privKey, targetRoomId, targetSessionId, backupInfo, opts); - } - - /** - * Restore from an existing key backup via an encoded recovery key. - * - * @param recoveryKey - Encoded recovery key - * @param targetRoomId - Room ID to target a specific room. - * Restores all rooms if omitted. - * @param targetSessionId - Session ID to target a specific session. - * Restores all sessions if omitted. - * @param backupInfo - Backup metadata from `checkKeyBackup` - * @param opts - Optional params such as callbacks - * @returns Status of restoration with `total` and `imported` - * key counts. - */ - - restoreKeyBackupWithRecoveryKey(recoveryKey, targetRoomId, targetSessionId, backupInfo, opts) { - const privKey = (0, _recoverykey.decodeRecoveryKey)(recoveryKey); - return this.restoreKeyBackup(privKey, targetRoomId, targetSessionId, backupInfo, opts); - } - async restoreKeyBackupWithCache(targetRoomId, targetSessionId, backupInfo, opts) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - const privKey = await this.crypto.getSessionBackupPrivateKey(); - if (!privKey) { - throw new Error("Couldn't get key"); - } - return this.restoreKeyBackup(privKey, targetRoomId, targetSessionId, backupInfo, opts); - } - async restoreKeyBackup(privKey, targetRoomId, targetSessionId, backupInfo, opts) { - const cacheCompleteCallback = opts === null || opts === void 0 ? void 0 : opts.cacheCompleteCallback; - const progressCallback = opts === null || opts === void 0 ? void 0 : opts.progressCallback; - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - let totalKeyCount = 0; - let keys = []; - const path = this.makeKeyBackupPath(targetRoomId, targetSessionId, backupInfo.version); - const algorithm = await _backup.BackupManager.makeAlgorithm(backupInfo, async () => { - return privKey; - }); - const untrusted = algorithm.untrusted; - try { - // If the pubkey computed from the private data we've been given - // doesn't match the one in the auth_data, the user has entered - // a different recovery key / the wrong passphrase. - if (!(await algorithm.keyMatches(privKey))) { - return Promise.reject(new _httpApi.MatrixError({ - errcode: MatrixClient.RESTORE_BACKUP_ERROR_BAD_KEY - })); - } - - // Cache the key, if possible. - // This is async. - this.crypto.storeSessionBackupPrivateKey(privKey).catch(e => { - _logger.logger.warn("Error caching session backup key:", e); - }).then(cacheCompleteCallback); - if (progressCallback) { - progressCallback({ - stage: "fetch" - }); - } - const res = await this.http.authedRequest(_httpApi.Method.Get, path.path, path.queryData, undefined, { - prefix: _httpApi.ClientPrefix.V3 - }); - if (res.rooms) { - const rooms = res.rooms; - for (const [roomId, roomData] of Object.entries(rooms)) { - if (!roomData.sessions) continue; - totalKeyCount += Object.keys(roomData.sessions).length; - const roomKeys = await algorithm.decryptSessions(roomData.sessions); - for (const k of roomKeys) { - k.room_id = roomId; - keys.push(k); - } - } - } else if (res.sessions) { - const sessions = res.sessions; - totalKeyCount = Object.keys(sessions).length; - keys = await algorithm.decryptSessions(sessions); - for (const k of keys) { - k.room_id = targetRoomId; - } - } else { - totalKeyCount = 1; - try { - const [key] = await algorithm.decryptSessions({ - [targetSessionId]: res - }); - key.room_id = targetRoomId; - key.session_id = targetSessionId; - keys.push(key); - } catch (e) { - _logger.logger.log("Failed to decrypt megolm session from backup", e); - } - } - } finally { - algorithm.free(); - } - await this.importRoomKeys(keys, { - progressCallback, - untrusted, - source: "backup" - }); - await this.checkKeyBackup(); - return { - total: totalKeyCount, - imported: keys.length - }; - } - async deleteKeysFromBackup(roomId, sessionId, version) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - const path = this.makeKeyBackupPath(roomId, sessionId, version); - await this.http.authedRequest(_httpApi.Method.Delete, path.path, path.queryData, undefined, { - prefix: _httpApi.ClientPrefix.V3 - }); - } - - /** - * Share shared-history decryption keys with the given users. - * - * @param roomId - the room for which keys should be shared. - * @param userIds - a list of users to share with. The keys will be sent to - * all of the user's current devices. - */ - async sendSharedHistoryKeys(roomId, userIds) { - if (!this.crypto) { - throw new Error("End-to-end encryption disabled"); - } - const roomEncryption = this.roomList.getRoomEncryption(roomId); - if (!roomEncryption) { - // unknown room, or unencrypted room - _logger.logger.error("Unknown room. Not sharing decryption keys"); - return; - } - const deviceInfos = await this.crypto.downloadKeys(userIds); - const devicesByUser = new Map(); - for (const [userId, devices] of deviceInfos) { - devicesByUser.set(userId, Array.from(devices.values())); - } - - // XXX: Private member access - const alg = this.crypto.getRoomDecryptor(roomId, roomEncryption.algorithm); - if (alg.sendSharedHistoryInboundSessions) { - await alg.sendSharedHistoryInboundSessions(devicesByUser); - } else { - _logger.logger.warn("Algorithm does not support sharing previous keys", roomEncryption.algorithm); - } - } - - /** - * Get the config for the media repository. - * @returns Promise which resolves with an object containing the config. - */ - getMediaConfig() { - return this.http.authedRequest(_httpApi.Method.Get, "/config", undefined, undefined, { - prefix: _httpApi.MediaPrefix.R0 - }); - } - - /** - * Get the room for the given room ID. - * This function will return a valid room for any room for which a Room event - * has been emitted. Note in particular that other events, eg. RoomState.members - * will be emitted for a room before this function will return the given room. - * @param roomId - The room ID - * @returns The Room or null if it doesn't exist or there is no data store. - */ - getRoom(roomId) { - if (!roomId) { - return null; - } - return this.store.getRoom(roomId); - } - - /** - * Retrieve all known rooms. - * @returns A list of rooms, or an empty list if there is no data store. - */ - getRooms() { - return this.store.getRooms(); - } - - /** - * Retrieve all rooms that should be displayed to the user - * This is essentially getRooms() with some rooms filtered out, eg. old versions - * of rooms that have been replaced or (in future) other rooms that have been - * marked at the protocol level as not to be displayed to the user. - * - * @param msc3946ProcessDynamicPredecessor - if true, look for an - * m.room.predecessor state event and - * use it if found (MSC3946). - * @returns A list of rooms, or an empty list if there is no data store. - */ - getVisibleRooms(msc3946ProcessDynamicPredecessor = false) { - const allRooms = this.store.getRooms(); - const replacedRooms = new Set(); - for (const r of allRooms) { - var _r$findPredecessor; - const predecessor = (_r$findPredecessor = r.findPredecessor(msc3946ProcessDynamicPredecessor)) === null || _r$findPredecessor === void 0 ? void 0 : _r$findPredecessor.roomId; - if (predecessor) { - replacedRooms.add(predecessor); - } - } - return allRooms.filter(r => { - const tombstone = r.currentState.getStateEvents(_event2.EventType.RoomTombstone, ""); - if (tombstone && replacedRooms.has(r.roomId)) { - return false; - } - return true; - }); - } - - /** - * Retrieve a user. - * @param userId - The user ID to retrieve. - * @returns A user or null if there is no data store or the user does - * not exist. - */ - getUser(userId) { - return this.store.getUser(userId); - } - - /** - * Retrieve all known users. - * @returns A list of users, or an empty list if there is no data store. - */ - getUsers() { - return this.store.getUsers(); - } - - /** - * Set account data event for the current user. - * It will retry the request up to 5 times. - * @param eventType - The event type - * @param content - the contents object for the event - * @returns Promise which resolves: an empty object - * @returns Rejects: with an error response. - */ - setAccountData(eventType, content) { - const path = utils.encodeUri("/user/$userId/account_data/$type", { - $userId: this.credentials.userId, - $type: eventType - }); - return (0, _httpApi.retryNetworkOperation)(5, () => { - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, content); - }); - } - - /** - * Get account data event of given type for the current user. - * @param eventType - The event type - * @returns The contents of the given account data event - */ - getAccountData(eventType) { - return this.store.getAccountData(eventType); - } - - /** - * Get account data event of given type for the current user. This variant - * gets account data directly from the homeserver if the local store is not - * ready, which can be useful very early in startup before the initial sync. - * @param eventType - The event type - * @returns Promise which resolves: The contents of the given account data event. - * @returns Rejects: with an error response. - */ - async getAccountDataFromServer(eventType) { - if (this.isInitialSyncComplete()) { - const event = this.store.getAccountData(eventType); - if (!event) { - return null; - } - // The network version below returns just the content, so this branch - // does the same to match. - return event.getContent(); - } - const path = utils.encodeUri("/user/$userId/account_data/$type", { - $userId: this.credentials.userId, - $type: eventType - }); - try { - return await this.http.authedRequest(_httpApi.Method.Get, path); - } catch (e) { - var _data; - if (((_data = e.data) === null || _data === void 0 ? void 0 : _data.errcode) === "M_NOT_FOUND") { - return null; - } - throw e; - } - } - async deleteAccountData(eventType) { - const msc3391DeleteAccountDataServerSupport = this.canSupport.get(_feature.Feature.AccountDataDeletion); - // if deletion is not supported overwrite with empty content - if (msc3391DeleteAccountDataServerSupport === _feature.ServerSupport.Unsupported) { - await this.setAccountData(eventType, {}); - return; - } - const path = utils.encodeUri("/user/$userId/account_data/$type", { - $userId: this.getSafeUserId(), - $type: eventType - }); - const options = msc3391DeleteAccountDataServerSupport === _feature.ServerSupport.Unstable ? { - prefix: "/_matrix/client/unstable/org.matrix.msc3391" - } : undefined; - return await this.http.authedRequest(_httpApi.Method.Delete, path, undefined, undefined, options); - } - - /** - * Gets the users that are ignored by this client - * @returns The array of users that are ignored (empty if none) - */ - getIgnoredUsers() { - const event = this.getAccountData("m.ignored_user_list"); - if (!event || !event.getContent() || !event.getContent()["ignored_users"]) return []; - return Object.keys(event.getContent()["ignored_users"]); - } - - /** - * Sets the users that the current user should ignore. - * @param userIds - the user IDs to ignore - * @returns Promise which resolves: an empty object - * @returns Rejects: with an error response. - */ - setIgnoredUsers(userIds) { - const content = { - ignored_users: {} - }; - userIds.forEach(u => { - content.ignored_users[u] = {}; - }); - return this.setAccountData("m.ignored_user_list", content); - } - - /** - * Gets whether or not a specific user is being ignored by this client. - * @param userId - the user ID to check - * @returns true if the user is ignored, false otherwise - */ - isUserIgnored(userId) { - return this.getIgnoredUsers().includes(userId); - } - - /** - * Join a room. If you have already joined the room, this will no-op. - * @param roomIdOrAlias - The room ID or room alias to join. - * @param opts - Options when joining the room. - * @returns Promise which resolves: Room object. - * @returns Rejects: with an error response. - */ - async joinRoom(roomIdOrAlias, opts = {}) { - if (opts.syncRoom === undefined) { - opts.syncRoom = true; - } - const room = this.getRoom(roomIdOrAlias); - if (room !== null && room !== void 0 && room.hasMembershipState(this.credentials.userId, "join")) { - return Promise.resolve(room); - } - let signPromise = Promise.resolve(); - if (opts.inviteSignUrl) { - const url = new URL(opts.inviteSignUrl); - url.searchParams.set("mxid", this.credentials.userId); - signPromise = this.http.requestOtherUrl(_httpApi.Method.Post, url); - } - const queryString = {}; - if (opts.viaServers) { - queryString["server_name"] = opts.viaServers; - } - try { - const data = {}; - const signedInviteObj = await signPromise; - if (signedInviteObj) { - data.third_party_signed = signedInviteObj; - } - const path = utils.encodeUri("/join/$roomid", { - $roomid: roomIdOrAlias - }); - const res = await this.http.authedRequest(_httpApi.Method.Post, path, queryString, data); - const roomId = res.room_id; - const syncApi = new _sync.SyncApi(this, this.clientOpts, this.buildSyncApiOptions()); - const room = syncApi.createRoom(roomId); - if (opts.syncRoom) { - // v2 will do this for us - // return syncApi.syncRoom(room); - } - return room; - } catch (e) { - throw e; // rethrow for reject - } - } - - /** - * Resend an event. Will also retry any to-device messages waiting to be sent. - * @param event - The event to resend. - * @param room - Optional. The room the event is in. Will update the - * timeline entry if provided. - * @returns Promise which resolves: to an ISendEventResponse object - * @returns Rejects: with an error response. - */ - resendEvent(event, room) { - // also kick the to-device queue to retry - this.toDeviceMessageQueue.sendQueue(); - this.updatePendingEventStatus(room, event, _event.EventStatus.SENDING); - return this.encryptAndSendEvent(room, event); - } - - /** - * Cancel a queued or unsent event. - * - * @param event - Event to cancel - * @throws Error if the event is not in QUEUED, NOT_SENT or ENCRYPTING state - */ - cancelPendingEvent(event) { - if (![_event.EventStatus.QUEUED, _event.EventStatus.NOT_SENT, _event.EventStatus.ENCRYPTING].includes(event.status)) { - throw new Error("cannot cancel an event with status " + event.status); - } - - // if the event is currently being encrypted then - if (event.status === _event.EventStatus.ENCRYPTING) { - this.pendingEventEncryption.delete(event.getId()); - } else if (this.scheduler && event.status === _event.EventStatus.QUEUED) { - // tell the scheduler to forget about it, if it's queued - this.scheduler.removeEventFromQueue(event); - } - - // then tell the room about the change of state, which will remove it - // from the room's list of pending events. - const room = this.getRoom(event.getRoomId()); - this.updatePendingEventStatus(room, event, _event.EventStatus.CANCELLED); - } - - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - setRoomName(roomId, name) { - return this.sendStateEvent(roomId, _event2.EventType.RoomName, { - name: name - }); - } - - /** - * @param htmlTopic - Optional. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - setRoomTopic(roomId, topic, htmlTopic) { - const content = ContentHelpers.makeTopicContent(topic, htmlTopic); - return this.sendStateEvent(roomId, _event2.EventType.RoomTopic, content); - } - - /** - * @returns Promise which resolves: to an object keyed by tagId with objects containing a numeric order field. - * @returns Rejects: with an error response. - */ - getRoomTags(roomId) { - const path = utils.encodeUri("/user/$userId/rooms/$roomId/tags", { - $userId: this.credentials.userId, - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * @param tagName - name of room tag to be set - * @param metadata - associated with that tag to be stored - * @returns Promise which resolves: to an empty object - * @returns Rejects: with an error response. - */ - setRoomTag(roomId, tagName, metadata) { - const path = utils.encodeUri("/user/$userId/rooms/$roomId/tags/$tag", { - $userId: this.credentials.userId, - $roomId: roomId, - $tag: tagName - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, metadata); - } - - /** - * @param tagName - name of room tag to be removed - * @returns Promise which resolves: to an empty object - * @returns Rejects: with an error response. - */ - deleteRoomTag(roomId, tagName) { - const path = utils.encodeUri("/user/$userId/rooms/$roomId/tags/$tag", { - $userId: this.credentials.userId, - $roomId: roomId, - $tag: tagName - }); - return this.http.authedRequest(_httpApi.Method.Delete, path); - } - - /** - * @param eventType - event type to be set - * @param content - event content - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setRoomAccountData(roomId, eventType, content) { - const path = utils.encodeUri("/user/$userId/rooms/$roomId/account_data/$type", { - $userId: this.credentials.userId, - $roomId: roomId, - $type: eventType - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, content); - } - - /** - * Set a power level to one or multiple users. - * @returns Promise which resolves: to an ISendEventResponse object - * @returns Rejects: with an error response. - */ - setPowerLevel(roomId, userId, powerLevel, event) { - let content = { - users: {} - }; - if ((event === null || event === void 0 ? void 0 : event.getType()) === _event2.EventType.RoomPowerLevels) { - // take a copy of the content to ensure we don't corrupt - // existing client state with a failed power level change - content = utils.deepCopy(event.getContent()); - } - const users = Array.isArray(userId) ? userId : [userId]; - for (const user of users) { - if (powerLevel == null) { - delete content.users[user]; - } else { - content.users[user] = powerLevel; - } - } - const path = utils.encodeUri("/rooms/$roomId/state/m.room.power_levels", { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, content); - } - - /** - * Create an m.beacon_info event - * @returns - */ - // eslint-disable-next-line @typescript-eslint/naming-convention - async unstable_createLiveBeacon(roomId, beaconInfoContent) { - return this.unstable_setLiveBeacon(roomId, beaconInfoContent); - } - - /** - * Upsert a live beacon event - * using a specific m.beacon_info.* event variable type - * @param roomId - string - * @returns - */ - // eslint-disable-next-line @typescript-eslint/naming-convention - async unstable_setLiveBeacon(roomId, beaconInfoContent) { - return this.sendStateEvent(roomId, _beacon.M_BEACON_INFO.name, beaconInfoContent, this.getUserId()); - } - sendEvent(roomId, threadIdOrEventType, eventTypeOrContent, contentOrTxnId, txnIdOrVoid) { - var _mRelates_to; - let threadId; - let eventType; - let content; - let txnId; - if (!(threadIdOrEventType !== null && threadIdOrEventType !== void 0 && threadIdOrEventType.startsWith(EVENT_ID_PREFIX)) && threadIdOrEventType !== null) { - txnId = contentOrTxnId; - content = eventTypeOrContent; - eventType = threadIdOrEventType; - threadId = null; - } else { - txnId = txnIdOrVoid; - content = contentOrTxnId; - eventType = eventTypeOrContent; - threadId = threadIdOrEventType; - } - - // If we expect that an event is part of a thread but is missing the relation - // we need to add it manually, as well as the reply fallback - if (threadId && !((_mRelates_to = content["m.relates_to"]) !== null && _mRelates_to !== void 0 && _mRelates_to.rel_type)) { - var _mRelates_to2, _this$getRoom; - const isReply = !!((_mRelates_to2 = content["m.relates_to"]) !== null && _mRelates_to2 !== void 0 && _mRelates_to2["m.in_reply_to"]); - content["m.relates_to"] = _objectSpread(_objectSpread({}, content["m.relates_to"]), {}, { - rel_type: _thread.THREAD_RELATION_TYPE.name, - event_id: threadId, - // Set is_falling_back to true unless this is actually intended to be a reply - is_falling_back: !isReply - }); - const thread = (_this$getRoom = this.getRoom(roomId)) === null || _this$getRoom === void 0 ? void 0 : _this$getRoom.getThread(threadId); - if (thread && !isReply) { - var _thread$lastReply$get, _thread$lastReply; - content["m.relates_to"]["m.in_reply_to"] = { - event_id: (_thread$lastReply$get = (_thread$lastReply = thread.lastReply(ev => { - return ev.isRelation(_thread.THREAD_RELATION_TYPE.name) && !ev.status; - })) === null || _thread$lastReply === void 0 ? void 0 : _thread$lastReply.getId()) !== null && _thread$lastReply$get !== void 0 ? _thread$lastReply$get : threadId - }; - } - } - return this.sendCompleteEvent(roomId, threadId, { - type: eventType, - content - }, txnId); - } - - /** - * @param eventObject - An object with the partial structure of an event, to which event_id, user_id, room_id and origin_server_ts will be added. - * @param txnId - Optional. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - sendCompleteEvent(roomId, threadId, eventObject, txnId) { - if (!txnId) { - txnId = this.makeTxnId(); - } - - // We always construct a MatrixEvent when sending because the store and scheduler use them. - // We'll extract the params back out if it turns out the client has no scheduler or store. - const localEvent = new _event.MatrixEvent(Object.assign(eventObject, { - event_id: "~" + roomId + ":" + txnId, - user_id: this.credentials.userId, - sender: this.credentials.userId, - room_id: roomId, - origin_server_ts: new Date().getTime() - })); - const room = this.getRoom(roomId); - const thread = threadId ? room === null || room === void 0 ? void 0 : room.getThread(threadId) : undefined; - if (thread) { - localEvent.setThread(thread); - } - - // set up re-emitter for this new event - this is normally the job of EventMapper but we don't use it here - this.reEmitter.reEmit(localEvent, [_event.MatrixEventEvent.Replaced, _event.MatrixEventEvent.VisibilityChange]); - room === null || room === void 0 ? void 0 : room.reEmitter.reEmit(localEvent, [_event.MatrixEventEvent.BeforeRedaction]); - - // if this is a relation or redaction of an event - // that hasn't been sent yet (e.g. with a local id starting with a ~) - // then listen for the remote echo of that event so that by the time - // this event does get sent, we have the correct event_id - const targetId = localEvent.getAssociatedId(); - if (targetId !== null && targetId !== void 0 && targetId.startsWith("~")) { - const target = room === null || room === void 0 ? void 0 : room.getPendingEvents().find(e => e.getId() === targetId); - target === null || target === void 0 ? void 0 : target.once(_event.MatrixEventEvent.LocalEventIdReplaced, () => { - localEvent.updateAssociatedId(target.getId()); - }); - } - const type = localEvent.getType(); - _logger.logger.log(`sendEvent of type ${type} in ${roomId} with txnId ${txnId}`); - localEvent.setTxnId(txnId); - localEvent.setStatus(_event.EventStatus.SENDING); - - // add this event immediately to the local store as 'sending'. - room === null || room === void 0 ? void 0 : room.addPendingEvent(localEvent, txnId); - - // addPendingEvent can change the state to NOT_SENT if it believes - // that there's other events that have failed. We won't bother to - // try sending the event if the state has changed as such. - if (localEvent.status === _event.EventStatus.NOT_SENT) { - return Promise.reject(new Error("Event blocked by other events not yet sent")); - } - return this.encryptAndSendEvent(room, localEvent); - } - - /** - * encrypts the event if necessary; adds the event to the queue, or sends it; marks the event as sent/unsent - * @returns returns a promise which resolves with the result of the send request - */ - encryptAndSendEvent(room, event) { - let cancelled = false; - // Add an extra Promise.resolve() to turn synchronous exceptions into promise rejections, - // so that we can handle synchronous and asynchronous exceptions with the - // same code path. - return Promise.resolve().then(() => { - const encryptionPromise = this.encryptEventIfNeeded(event, room !== null && room !== void 0 ? room : undefined); - if (!encryptionPromise) return null; // doesn't need encryption - - this.pendingEventEncryption.set(event.getId(), encryptionPromise); - this.updatePendingEventStatus(room, event, _event.EventStatus.ENCRYPTING); - return encryptionPromise.then(() => { - if (!this.pendingEventEncryption.has(event.getId())) { - // cancelled via MatrixClient::cancelPendingEvent - cancelled = true; - return; - } - this.updatePendingEventStatus(room, event, _event.EventStatus.SENDING); - }); - }).then(() => { - if (cancelled) return {}; - let promise = null; - if (this.scheduler) { - // if this returns a promise then the scheduler has control now and will - // resolve/reject when it is done. Internally, the scheduler will invoke - // processFn which is set to this._sendEventHttpRequest so the same code - // path is executed regardless. - promise = this.scheduler.queueEvent(event); - if (promise && this.scheduler.getQueueForEvent(event).length > 1) { - // event is processed FIFO so if the length is 2 or more we know - // this event is stuck behind an earlier event. - this.updatePendingEventStatus(room, event, _event.EventStatus.QUEUED); - } - } - if (!promise) { - promise = this.sendEventHttpRequest(event); - if (room) { - promise = promise.then(res => { - room.updatePendingEvent(event, _event.EventStatus.SENT, res["event_id"]); - return res; - }); - } - } - return promise; - }).catch(err => { - _logger.logger.error("Error sending event", err.stack || err); - try { - // set the error on the event before we update the status: - // updating the status emits the event, so the state should be - // consistent at that point. - event.error = err; - this.updatePendingEventStatus(room, event, _event.EventStatus.NOT_SENT); - } catch (e) { - _logger.logger.error("Exception in error handler!", e.stack || err); - } - if (err instanceof _httpApi.MatrixError) { - err.event = event; - } - throw err; - }); - } - encryptEventIfNeeded(event, room) { - if (event.isEncrypted()) { - // this event has already been encrypted; this happens if the - // encryption step succeeded, but the send step failed on the first - // attempt. - return null; - } - if (event.isRedaction()) { - // Redactions do not support encryption in the spec at this time, - // whilst it mostly worked in some clients, it wasn't compliant. - return null; - } - if (!room || !this.isRoomEncrypted(event.getRoomId())) { - return null; - } - if (!this.cryptoBackend && this.usingExternalCrypto) { - // The client has opted to allow sending messages to encrypted - // rooms even if the room is encrypted, and we haven't setup - // crypto. This is useful for users of matrix-org/pantalaimon - return null; - } - if (event.getType() === _event2.EventType.Reaction) { - // For reactions, there is a very little gained by encrypting the entire - // event, as relation data is already kept in the clear. Event - // encryption for a reaction effectively only obscures the event type, - // but the purpose is still obvious from the relation data, so nothing - // is really gained. It also causes quite a few problems, such as: - // * triggers notifications via default push rules - // * prevents server-side bundling for reactions - // The reaction key / content / emoji value does warrant encrypting, but - // this will be handled separately by encrypting just this value. - // See https://github.com/matrix-org/matrix-doc/pull/1849#pullrequestreview-248763642 - return null; - } - if (!this.cryptoBackend) { - throw new Error("This room is configured to use encryption, but your client does not support encryption."); - } - return this.cryptoBackend.encryptEvent(event, room); - } - - /** - * Returns the eventType that should be used taking encryption into account - * for a given eventType. - * @param roomId - the room for the events `eventType` relates to - * @param eventType - the event type - * @returns the event type taking encryption into account - */ - getEncryptedIfNeededEventType(roomId, eventType) { - if (eventType === _event2.EventType.Reaction) return eventType; - return this.isRoomEncrypted(roomId) ? _event2.EventType.RoomMessageEncrypted : eventType; - } - updatePendingEventStatus(room, event, newStatus) { - if (room) { - room.updatePendingEvent(event, newStatus); - } else { - event.setStatus(newStatus); - } - } - sendEventHttpRequest(event) { - let txnId = event.getTxnId(); - if (!txnId) { - txnId = this.makeTxnId(); - event.setTxnId(txnId); - } - const pathParams = { - $roomId: event.getRoomId(), - $eventType: event.getWireType(), - $stateKey: event.getStateKey(), - $txnId: txnId - }; - let path; - if (event.isState()) { - let pathTemplate = "/rooms/$roomId/state/$eventType"; - if (event.getStateKey() && event.getStateKey().length > 0) { - pathTemplate = "/rooms/$roomId/state/$eventType/$stateKey"; - } - path = utils.encodeUri(pathTemplate, pathParams); - } else if (event.isRedaction()) { - const pathTemplate = `/rooms/$roomId/redact/$redactsEventId/$txnId`; - path = utils.encodeUri(pathTemplate, _objectSpread({ - $redactsEventId: event.event.redacts - }, pathParams)); - } else { - path = utils.encodeUri("/rooms/$roomId/send/$eventType/$txnId", pathParams); - } - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, event.getWireContent()).then(res => { - _logger.logger.log(`Event sent to ${event.getRoomId()} with event id ${res.event_id}`); - return res; - }); - } - - /** - * @param txnId - transaction id. One will be made up if not supplied. - * @param opts - Options to pass on, may contain `reason` and `with_relations` (MSC3912) - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - * @throws Error if called with `with_relations` (MSC3912) but the server does not support it. - * Callers should check whether the server supports MSC3912 via `MatrixClient.canSupport`. - */ - - redactEvent(roomId, threadId, eventId, txnId, opts) { - var _eventId, _opts2, _opts3, _opts4, _opts5; - if (!((_eventId = eventId) !== null && _eventId !== void 0 && _eventId.startsWith(EVENT_ID_PREFIX))) { - opts = txnId; - txnId = eventId; - eventId = threadId; - threadId = null; - } - const reason = (_opts2 = opts) === null || _opts2 === void 0 ? void 0 : _opts2.reason; - if ((_opts3 = opts) !== null && _opts3 !== void 0 && _opts3.with_relations && this.canSupport.get(_feature.Feature.RelationBasedRedactions) === _feature.ServerSupport.Unsupported) { - throw new Error("Server does not support relation based redactions " + `roomId ${roomId} eventId ${eventId} txnId: ${txnId} threadId ${threadId}`); - } - const withRelations = (_opts4 = opts) !== null && _opts4 !== void 0 && _opts4.with_relations ? { - [this.canSupport.get(_feature.Feature.RelationBasedRedactions) === _feature.ServerSupport.Stable ? _event2.MSC3912_RELATION_BASED_REDACTIONS_PROP.stable : _event2.MSC3912_RELATION_BASED_REDACTIONS_PROP.unstable]: (_opts5 = opts) === null || _opts5 === void 0 ? void 0 : _opts5.with_relations - } : {}; - return this.sendCompleteEvent(roomId, threadId, { - type: _event2.EventType.RoomRedaction, - content: _objectSpread(_objectSpread({}, withRelations), {}, { - reason - }), - redacts: eventId - }, txnId); - } - - /** - * @param txnId - Optional. - * @returns Promise which resolves: to an ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendMessage(roomId, threadId, content, txnId) { - if (typeof threadId !== "string" && threadId !== null) { - txnId = content; - content = threadId; - threadId = null; - } - const eventType = _event2.EventType.RoomMessage; - const sendContent = content; - return this.sendEvent(roomId, threadId, eventType, sendContent, txnId); - } - - /** - * @param txnId - Optional. - * @returns - * @returns Rejects: with an error response. - */ - - sendTextMessage(roomId, threadId, body, txnId) { - var _threadId; - if (!((_threadId = threadId) !== null && _threadId !== void 0 && _threadId.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - txnId = body; - body = threadId; - threadId = null; - } - const content = ContentHelpers.makeTextMessage(body); - return this.sendMessage(roomId, threadId, content, txnId); - } - - /** - * @param txnId - Optional. - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendNotice(roomId, threadId, body, txnId) { - var _threadId2; - if (!((_threadId2 = threadId) !== null && _threadId2 !== void 0 && _threadId2.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - txnId = body; - body = threadId; - threadId = null; - } - const content = ContentHelpers.makeNotice(body); - return this.sendMessage(roomId, threadId, content, txnId); - } - - /** - * @param txnId - Optional. - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendEmoteMessage(roomId, threadId, body, txnId) { - var _threadId3; - if (!((_threadId3 = threadId) !== null && _threadId3 !== void 0 && _threadId3.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - txnId = body; - body = threadId; - threadId = null; - } - const content = ContentHelpers.makeEmoteMessage(body); - return this.sendMessage(roomId, threadId, content, txnId); - } - - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendImageMessage(roomId, threadId, url, info, text = "Image") { - var _threadId4; - if (!((_threadId4 = threadId) !== null && _threadId4 !== void 0 && _threadId4.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - text = info || "Image"; - info = url; - url = threadId; - threadId = null; - } - const content = { - msgtype: _event2.MsgType.Image, - url: url, - info: info, - body: text - }; - return this.sendMessage(roomId, threadId, content); - } - - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendStickerMessage(roomId, threadId, url, info, text = "Sticker") { - var _threadId5; - if (!((_threadId5 = threadId) !== null && _threadId5 !== void 0 && _threadId5.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - text = info || "Sticker"; - info = url; - url = threadId; - threadId = null; - } - const content = { - url: url, - info: info, - body: text - }; - return this.sendEvent(roomId, threadId, _event2.EventType.Sticker, content); - } - - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendHtmlMessage(roomId, threadId, body, htmlBody) { - var _threadId6; - if (!((_threadId6 = threadId) !== null && _threadId6 !== void 0 && _threadId6.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - htmlBody = body; - body = threadId; - threadId = null; - } - const content = ContentHelpers.makeHtmlMessage(body, htmlBody); - return this.sendMessage(roomId, threadId, content); - } - - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendHtmlNotice(roomId, threadId, body, htmlBody) { - var _threadId7; - if (!((_threadId7 = threadId) !== null && _threadId7 !== void 0 && _threadId7.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - htmlBody = body; - body = threadId; - threadId = null; - } - const content = ContentHelpers.makeHtmlNotice(body, htmlBody); - return this.sendMessage(roomId, threadId, content); - } - - /** - * @returns Promise which resolves: to a ISendEventResponse object - * @returns Rejects: with an error response. - */ - - sendHtmlEmote(roomId, threadId, body, htmlBody) { - var _threadId8; - if (!((_threadId8 = threadId) !== null && _threadId8 !== void 0 && _threadId8.startsWith(EVENT_ID_PREFIX)) && threadId !== null) { - htmlBody = body; - body = threadId; - threadId = null; - } - const content = ContentHelpers.makeHtmlEmote(body, htmlBody); - return this.sendMessage(roomId, threadId, content); - } - - /** - * Send a receipt. - * @param event - The event being acknowledged - * @param receiptType - The kind of receipt e.g. "m.read". Other than - * ReceiptType.Read are experimental! - * @param body - Additional content to send alongside the receipt. - * @param unthreaded - An unthreaded receipt will clear room+thread notifications - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - async sendReceipt(event, receiptType, body, unthreaded = false) { - if (this.isGuest()) { - return Promise.resolve({}); // guests cannot send receipts so don't bother. - } - - const path = utils.encodeUri("/rooms/$roomId/receipt/$receiptType/$eventId", { - $roomId: event.getRoomId(), - $receiptType: receiptType, - $eventId: event.getId() - }); - if (!unthreaded) { - const isThread = !!event.threadRootId; - body = _objectSpread(_objectSpread({}, body), {}, { - thread_id: isThread ? event.threadRootId : _read_receipts.MAIN_ROOM_TIMELINE - }); - } - const promise = this.http.authedRequest(_httpApi.Method.Post, path, undefined, body || {}); - const room = this.getRoom(event.getRoomId()); - if (room && this.credentials.userId) { - room.addLocalEchoReceipt(this.credentials.userId, event, receiptType); - } - return promise; - } - - /** - * Send a read receipt. - * @param event - The event that has been read. - * @param receiptType - other than ReceiptType.Read are experimental! Optional. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - async sendReadReceipt(event, receiptType = _read_receipts.ReceiptType.Read, unthreaded = false) { - if (!event) return; - const eventId = event.getId(); - const room = this.getRoom(event.getRoomId()); - if (room !== null && room !== void 0 && room.hasPendingEvent(eventId)) { - throw new Error(`Cannot set read receipt to a pending event (${eventId})`); - } - return this.sendReceipt(event, receiptType, {}, unthreaded); - } - - /** - * Set a marker to indicate the point in a room before which the user has read every - * event. This can be retrieved from room account data (the event type is `m.fully_read`) - * and displayed as a horizontal line in the timeline that is visually distinct to the - * position of the user's own read receipt. - * @param roomId - ID of the room that has been read - * @param rmEventId - ID of the event that has been read - * @param rrEvent - the event tracked by the read receipt. This is here for - * convenience because the RR and the RM are commonly updated at the same time as each - * other. The local echo of this receipt will be done if set. Optional. - * @param rpEvent - the m.read.private read receipt event for when we don't - * want other users to see the read receipts. This is experimental. Optional. - * @returns Promise which resolves: the empty object, `{}`. - */ - async setRoomReadMarkers(roomId, rmEventId, rrEvent, rpEvent) { - const room = this.getRoom(roomId); - if (room && room.hasPendingEvent(rmEventId)) { - throw new Error(`Cannot set read marker to a pending event (${rmEventId})`); - } - - // Add the optional RR update, do local echo like `sendReceipt` - let rrEventId; - if (rrEvent) { - rrEventId = rrEvent.getId(); - if (room !== null && room !== void 0 && room.hasPendingEvent(rrEventId)) { - throw new Error(`Cannot set read receipt to a pending event (${rrEventId})`); - } - room === null || room === void 0 ? void 0 : room.addLocalEchoReceipt(this.credentials.userId, rrEvent, _read_receipts.ReceiptType.Read); - } - - // Add the optional private RR update, do local echo like `sendReceipt` - let rpEventId; - if (rpEvent) { - rpEventId = rpEvent.getId(); - if (room !== null && room !== void 0 && room.hasPendingEvent(rpEventId)) { - throw new Error(`Cannot set read receipt to a pending event (${rpEventId})`); - } - room === null || room === void 0 ? void 0 : room.addLocalEchoReceipt(this.credentials.userId, rpEvent, _read_receipts.ReceiptType.ReadPrivate); - } - return await this.setRoomReadMarkersHttpRequest(roomId, rmEventId, rrEventId, rpEventId); - } - - /** - * Get a preview of the given URL as of (roughly) the given point in time, - * described as an object with OpenGraph keys and associated values. - * Attributes may be synthesized where actual OG metadata is lacking. - * Caches results to prevent hammering the server. - * @param url - The URL to get preview data for - * @param ts - The preferred point in time that the preview should - * describe (ms since epoch). The preview returned will either be the most - * recent one preceding this timestamp if available, or failing that the next - * most recent available preview. - * @returns Promise which resolves: Object of OG metadata. - * @returns Rejects: with an error response. - * May return synthesized attributes if the URL lacked OG meta. - */ - getUrlPreview(url, ts) { - // bucket the timestamp to the nearest minute to prevent excessive spam to the server - // Surely 60-second accuracy is enough for anyone. - ts = Math.floor(ts / 60000) * 60000; - const parsed = new URL(url); - parsed.hash = ""; // strip the hash as it won't affect the preview - url = parsed.toString(); - const key = ts + "_" + url; - - // If there's already a request in flight (or we've handled it), return that instead. - const cachedPreview = this.urlPreviewCache[key]; - if (cachedPreview) { - return cachedPreview; - } - const resp = this.http.authedRequest(_httpApi.Method.Get, "/preview_url", { - url, - ts: ts.toString() - }, undefined, { - prefix: _httpApi.MediaPrefix.R0 - }); - // TODO: Expire the URL preview cache sometimes - this.urlPreviewCache[key] = resp; - return resp; - } - - /** - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - sendTyping(roomId, isTyping, timeoutMs) { - if (this.isGuest()) { - return Promise.resolve({}); // guests cannot send typing notifications so don't bother. - } - - const path = utils.encodeUri("/rooms/$roomId/typing/$userId", { - $roomId: roomId, - $userId: this.getUserId() - }); - const data = { - typing: isTyping - }; - if (isTyping) { - data.timeout = timeoutMs ? timeoutMs : 20000; - } - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, data); - } - - /** - * Determines the history of room upgrades for a given room, as far as the - * client can see. Returns an array of Rooms where the first entry is the - * oldest and the last entry is the newest (likely current) room. If the - * provided room is not found, this returns an empty list. This works in - * both directions, looking for older and newer rooms of the given room. - * @param roomId - The room ID to search from - * @param verifyLinks - If true, the function will only return rooms - * which can be proven to be linked. For example, rooms which have a create - * event pointing to an old room which the client is not aware of or doesn't - * have a matching tombstone would not be returned. - * @param msc3946ProcessDynamicPredecessor - if true, look for - * m.room.predecessor state events as well as create events, and prefer - * predecessor events where they exist (MSC3946). - * @returns An array of rooms representing the upgrade - * history. - */ - getRoomUpgradeHistory(roomId, verifyLinks = false, msc3946ProcessDynamicPredecessor = false) { - const currentRoom = this.getRoom(roomId); - if (!currentRoom) return []; - const before = this.findPredecessorRooms(currentRoom, verifyLinks, msc3946ProcessDynamicPredecessor); - const after = this.findSuccessorRooms(currentRoom, verifyLinks, msc3946ProcessDynamicPredecessor); - return [...before, currentRoom, ...after]; - } - findPredecessorRooms(room, verifyLinks, msc3946ProcessDynamicPredecessor) { - var _room$findPredecessor; - const ret = []; - - // Work backwards from newer to older rooms - let predecessorRoomId = (_room$findPredecessor = room.findPredecessor(msc3946ProcessDynamicPredecessor)) === null || _room$findPredecessor === void 0 ? void 0 : _room$findPredecessor.roomId; - while (predecessorRoomId !== null) { - var _room$findPredecessor2; - const predecessorRoom = this.getRoom(predecessorRoomId); - if (predecessorRoom === null) { - break; - } - if (verifyLinks) { - const tombstone = predecessorRoom.currentState.getStateEvents(_event2.EventType.RoomTombstone, ""); - if (!tombstone || tombstone.getContent()["replacement_room"] !== room.roomId) { - break; - } - } - - // Insert at the front because we're working backwards from the currentRoom - ret.splice(0, 0, predecessorRoom); - room = predecessorRoom; - predecessorRoomId = (_room$findPredecessor2 = room.findPredecessor(msc3946ProcessDynamicPredecessor)) === null || _room$findPredecessor2 === void 0 ? void 0 : _room$findPredecessor2.roomId; - } - return ret; - } - findSuccessorRooms(room, verifyLinks, msc3946ProcessDynamicPredecessor) { - const ret = []; - - // Work forwards, looking at tombstone events - let tombstoneEvent = room.currentState.getStateEvents(_event2.EventType.RoomTombstone, ""); - while (tombstoneEvent) { - const successorRoom = this.getRoom(tombstoneEvent.getContent()["replacement_room"]); - if (!successorRoom) break; // end of the chain - if (successorRoom.roomId === room.roomId) break; // Tombstone is referencing its own room - - if (verifyLinks) { - var _successorRoom$findPr; - const predecessorRoomId = (_successorRoom$findPr = successorRoom.findPredecessor(msc3946ProcessDynamicPredecessor)) === null || _successorRoom$findPr === void 0 ? void 0 : _successorRoom$findPr.roomId; - if (!predecessorRoomId || predecessorRoomId !== room.roomId) { - break; - } - } - - // Push to the end because we're looking forwards - ret.push(successorRoom); - const roomIds = new Set(ret.map(ref => ref.roomId)); - if (roomIds.size < ret.length) { - // The last room added to the list introduced a previous roomId - // To avoid recursion, return the last rooms - 1 - return ret.slice(0, ret.length - 1); - } - - // Set the current room to the reference room so we know where we're at - room = successorRoom; - tombstoneEvent = room.currentState.getStateEvents(_event2.EventType.RoomTombstone, ""); - } - return ret; - } - - /** - * @param reason - Optional. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - invite(roomId, userId, reason) { - return this.membershipChange(roomId, userId, "invite", reason); - } - - /** - * Invite a user to a room based on their email address. - * @param roomId - The room to invite the user to. - * @param email - The email address to invite. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - inviteByEmail(roomId, email) { - return this.inviteByThreePid(roomId, "email", email); - } - - /** - * Invite a user to a room based on a third-party identifier. - * @param roomId - The room to invite the user to. - * @param medium - The medium to invite the user e.g. "email". - * @param address - The address for the specified medium. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - async inviteByThreePid(roomId, medium, address) { - var _this$identityServer; - const path = utils.encodeUri("/rooms/$roomId/invite", { - $roomId: roomId - }); - const identityServerUrl = this.getIdentityServerUrl(true); - if (!identityServerUrl) { - return Promise.reject(new _httpApi.MatrixError({ - error: "No supplied identity server URL", - errcode: "ORG.MATRIX.JSSDK_MISSING_PARAM" - })); - } - const params = { - id_server: identityServerUrl, - medium: medium, - address: address - }; - if ((_this$identityServer = this.identityServer) !== null && _this$identityServer !== void 0 && _this$identityServer.getAccessToken && (await this.doesServerAcceptIdentityAccessToken())) { - const identityAccessToken = await this.identityServer.getAccessToken(); - if (identityAccessToken) { - params["id_access_token"] = identityAccessToken; - } - } - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, params); - } - - /** - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - leave(roomId) { - return this.membershipChange(roomId, undefined, "leave"); - } - - /** - * Leaves all rooms in the chain of room upgrades based on the given room. By - * default, this will leave all the previous and upgraded rooms, including the - * given room. To only leave the given room and any previous rooms, keeping the - * upgraded (modern) rooms untouched supply `false` to `includeFuture`. - * @param roomId - The room ID to start leaving at - * @param includeFuture - If true, the whole chain (past and future) of - * upgraded rooms will be left. - * @returns Promise which resolves when completed with an object keyed - * by room ID and value of the error encountered when leaving or null. - */ - leaveRoomChain(roomId, includeFuture = true) { - const upgradeHistory = this.getRoomUpgradeHistory(roomId); - let eligibleToLeave = upgradeHistory; - if (!includeFuture) { - eligibleToLeave = []; - for (const room of upgradeHistory) { - eligibleToLeave.push(room); - if (room.roomId === roomId) { - break; - } - } - } - const populationResults = {}; - const promises = []; - const doLeave = roomId => { - return this.leave(roomId).then(() => { - delete populationResults[roomId]; - }).catch(err => { - // suppress error - populationResults[roomId] = err; - }); - }; - for (const room of eligibleToLeave) { - promises.push(doLeave(room.roomId)); - } - return Promise.all(promises).then(() => populationResults); - } - - /** - * @param reason - Optional. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - ban(roomId, userId, reason) { - return this.membershipChange(roomId, userId, "ban", reason); - } - - /** - * @param deleteRoom - True to delete the room from the store on success. - * Default: true. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - forget(roomId, deleteRoom = true) { - const promise = this.membershipChange(roomId, undefined, "forget"); - if (!deleteRoom) { - return promise; - } - return promise.then(response => { - this.store.removeRoom(roomId); - this.emit(ClientEvent.DeleteRoom, roomId); - return response; - }); - } - - /** - * @returns Promise which resolves: Object (currently empty) - * @returns Rejects: with an error response. - */ - unban(roomId, userId) { - // unbanning != set their state to leave: this used to be - // the case, but was then changed so that leaving was always - // a revoking of privilege, otherwise two people racing to - // kick / ban someone could end up banning and then un-banning - // them. - const path = utils.encodeUri("/rooms/$roomId/unban", { - $roomId: roomId - }); - const data = { - user_id: userId - }; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, data); - } - - /** - * @param reason - Optional. - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - kick(roomId, userId, reason) { - const path = utils.encodeUri("/rooms/$roomId/kick", { - $roomId: roomId - }); - const data = { - user_id: userId, - reason: reason - }; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, data); - } - membershipChange(roomId, userId, membership, reason) { - // API returns an empty object - const path = utils.encodeUri("/rooms/$room_id/$membership", { - $room_id: roomId, - $membership: membership - }); - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, { - user_id: userId, - // may be undefined e.g. on leave - reason: reason - }); - } - - /** - * Obtain a dict of actions which should be performed for this event according - * to the push rules for this user. Caches the dict on the event. - * @param event - The event to get push actions for. - * @param forceRecalculate - forces to recalculate actions for an event - * Useful when an event just got decrypted - * @returns A dict of actions to perform. - */ - getPushActionsForEvent(event, forceRecalculate = false) { - if (!event.getPushActions() || forceRecalculate) { - event.setPushActions(this.pushProcessor.actionsForEvent(event)); - } - return event.getPushActions(); - } - - /** - * @param info - The kind of info to set (e.g. 'avatar_url') - * @param data - The JSON object to set. - * @returns - * @returns Rejects: with an error response. - */ - // eslint-disable-next-line camelcase - - setProfileInfo(info, data) { - const path = utils.encodeUri("/profile/$userId/$info", { - $userId: this.credentials.userId, - $info: info - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, data); - } - - /** - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - async setDisplayName(name) { - const prom = await this.setProfileInfo("displayname", { - displayname: name - }); - // XXX: synthesise a profile update for ourselves because Synapse is broken and won't - const user = this.getUser(this.getUserId()); - if (user) { - user.displayName = name; - user.emit(_user.UserEvent.DisplayName, user.events.presence, user); - } - return prom; - } - - /** - * @returns Promise which resolves: `{}` an empty object. - * @returns Rejects: with an error response. - */ - async setAvatarUrl(url) { - const prom = await this.setProfileInfo("avatar_url", { - avatar_url: url - }); - // XXX: synthesise a profile update for ourselves because Synapse is broken and won't - const user = this.getUser(this.getUserId()); - if (user) { - user.avatarUrl = url; - user.emit(_user.UserEvent.AvatarUrl, user.events.presence, user); - } - return prom; - } - - /** - * Turn an MXC URL into an HTTP one. This method is experimental and - * may change. - * @param mxcUrl - The MXC URL - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDirectLinks - If true, return any non-mxc URLs - * directly. Fetching such URLs will leak information about the user to - * anyone they share a room with. If false, will return null for such URLs. - * @returns the avatar URL or null. - */ - mxcUrlToHttp(mxcUrl, width, height, resizeMethod, allowDirectLinks) { - return (0, _contentRepo.getHttpUriForMxc)(this.baseUrl, mxcUrl, width, height, resizeMethod, allowDirectLinks); - } - - /** - * @param opts - Options to apply - * @returns Promise which resolves - * @returns Rejects: with an error response. - * @throws If 'presence' isn't a valid presence enum value. - */ - async setPresence(opts) { - const path = utils.encodeUri("/presence/$userId/status", { - $userId: this.credentials.userId - }); - const validStates = ["offline", "online", "unavailable"]; - if (validStates.indexOf(opts.presence) === -1) { - throw new Error("Bad presence value: " + opts.presence); - } - await this.http.authedRequest(_httpApi.Method.Put, path, undefined, opts); - } - - /** - * @param userId - The user to get presence for - * @returns Promise which resolves: The presence state for this user. - * @returns Rejects: with an error response. - */ - getPresence(userId) { - const path = utils.encodeUri("/presence/$userId/status", { - $userId: userId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * Retrieve older messages from the given room and put them in the timeline. - * - * If this is called multiple times whilst a request is ongoing, the same - * Promise will be returned. If there was a problem requesting scrollback, there - * will be a small delay before another request can be made (to prevent tight-looping - * when there is no connection). - * - * @param room - The room to get older messages in. - * @param limit - Optional. The maximum number of previous events to - * pull in. Default: 30. - * @returns Promise which resolves: Room. If you are at the beginning - * of the timeline, `Room.oldState.paginationToken` will be - * `null`. - * @returns Rejects: with an error response. - */ - scrollback(room, limit = 30) { - let timeToWaitMs = 0; - let info = this.ongoingScrollbacks[room.roomId] || {}; - if (info.promise) { - return info.promise; - } else if (info.errorTs) { - const timeWaitedMs = Date.now() - info.errorTs; - timeToWaitMs = Math.max(SCROLLBACK_DELAY_MS - timeWaitedMs, 0); - } - if (room.oldState.paginationToken === null) { - return Promise.resolve(room); // already at the start. - } - // attempt to grab more events from the store first - const numAdded = this.store.scrollback(room, limit).length; - if (numAdded === limit) { - // store contained everything we needed. - return Promise.resolve(room); - } - // reduce the required number of events appropriately - limit = limit - numAdded; - const promise = new Promise((resolve, reject) => { - // wait for a time before doing this request - // (which may be 0 in order not to special case the code paths) - (0, utils.sleep)(timeToWaitMs).then(() => { - return this.createMessagesRequest(room.roomId, room.oldState.paginationToken, limit, _eventTimeline.Direction.Backward); - }).then(res => { - var _res$end, _res$end2; - const matrixEvents = res.chunk.map(this.getEventMapper()); - if (res.state) { - const stateEvents = res.state.map(this.getEventMapper()); - room.currentState.setUnknownStateEvents(stateEvents); - } - const [timelineEvents, threadedEvents] = room.partitionThreadedEvents(matrixEvents); - this.processAggregatedTimelineEvents(room, timelineEvents); - room.addEventsToTimeline(timelineEvents, true, room.getLiveTimeline()); - this.processThreadEvents(room, threadedEvents, true); - room.oldState.paginationToken = (_res$end = res.end) !== null && _res$end !== void 0 ? _res$end : null; - if (res.chunk.length === 0) { - room.oldState.paginationToken = null; - } - this.store.storeEvents(room, matrixEvents, (_res$end2 = res.end) !== null && _res$end2 !== void 0 ? _res$end2 : null, true); - delete this.ongoingScrollbacks[room.roomId]; - resolve(room); - }).catch(err => { - this.ongoingScrollbacks[room.roomId] = { - errorTs: Date.now() - }; - reject(err); - }); - }); - info = { - promise - }; - this.ongoingScrollbacks[room.roomId] = info; - return promise; - } - getEventMapper(options) { - return (0, _eventMapper.eventMapperFor)(this, options || {}); - } - - /** - * Get an EventTimeline for the given event - * - *

If the EventTimelineSet object already has the given event in its store, the - * corresponding timeline will be returned. Otherwise, a /context request is - * made, and used to construct an EventTimeline. - * If the event does not belong to this EventTimelineSet then undefined will be returned. - * - * @param timelineSet - The timelineSet to look for the event in, must be bound to a room - * @param eventId - The ID of the event to look for - * - * @returns Promise which resolves: - * {@link EventTimeline} including the given event - */ - async getEventTimeline(timelineSet, eventId) { - var _this$clientOpts, _ref, _timelineSet$getTimel, _timelineSet$room$fin; - // don't allow any timeline support unless it's been enabled. - if (!this.timelineSupport) { - throw new Error("timeline support is disabled. Set the 'timelineSupport'" + " parameter to true when creating MatrixClient to enable it."); - } - if (!(timelineSet !== null && timelineSet !== void 0 && timelineSet.room)) { - throw new Error("getEventTimeline only supports room timelines"); - } - if (timelineSet.getTimelineForEvent(eventId)) { - return timelineSet.getTimelineForEvent(eventId); - } - if (timelineSet.thread && this.supportsThreads()) { - return this.getThreadTimeline(timelineSet, eventId); - } - const path = utils.encodeUri("/rooms/$roomId/context/$eventId", { - $roomId: timelineSet.room.roomId, - $eventId: eventId - }); - let params = undefined; - if ((_this$clientOpts = this.clientOpts) !== null && _this$clientOpts !== void 0 && _this$clientOpts.lazyLoadMembers) { - params = { - filter: JSON.stringify(_filter.Filter.LAZY_LOADING_MESSAGES_FILTER) - }; - } - - // TODO: we should implement a backoff (as per scrollback()) to deal more nicely with HTTP errors. - const res = await this.http.authedRequest(_httpApi.Method.Get, path, params); - if (!res.event) { - throw new Error("'event' not in '/context' result - homeserver too old?"); - } - - // by the time the request completes, the event might have ended up in the timeline. - if (timelineSet.getTimelineForEvent(eventId)) { - return timelineSet.getTimelineForEvent(eventId); - } - const mapper = this.getEventMapper(); - const event = mapper(res.event); - if (event.isRelation(_thread.THREAD_RELATION_TYPE.name)) { - _logger.logger.warn("Tried loading a regular timeline at the position of a thread event"); - return undefined; - } - const events = [ - // Order events from most recent to oldest (reverse-chronological). - // We start with the last event, since that's the point at which we have known state. - // events_after is already backwards; events_before is forwards. - ...res.events_after.reverse().map(mapper), event, ...res.events_before.map(mapper)]; - - // Here we handle non-thread timelines only, but still process any thread events to populate thread summaries. - let timeline = timelineSet.getTimelineForEvent(events[0].getId()); - if (timeline) { - timeline.getState(_eventTimeline.EventTimeline.BACKWARDS).setUnknownStateEvents(res.state.map(mapper)); - } else { - timeline = timelineSet.addTimeline(); - timeline.initialiseState(res.state.map(mapper)); - timeline.getState(_eventTimeline.EventTimeline.FORWARDS).paginationToken = res.end; - } - const [timelineEvents, threadedEvents] = timelineSet.room.partitionThreadedEvents(events); - timelineSet.addEventsToTimeline(timelineEvents, true, timeline, res.start); - // The target event is not in a thread but process the contextual events, so we can show any threads around it. - this.processThreadEvents(timelineSet.room, threadedEvents, true); - this.processAggregatedTimelineEvents(timelineSet.room, timelineEvents); - - // There is no guarantee that the event ended up in "timeline" (we might have switched to a neighbouring - // timeline) - so check the room's index again. On the other hand, there's no guarantee the event ended up - // anywhere, if it was later redacted, so we just return the timeline we first thought of. - return (_ref = (_timelineSet$getTimel = timelineSet.getTimelineForEvent(eventId)) !== null && _timelineSet$getTimel !== void 0 ? _timelineSet$getTimel : (_timelineSet$room$fin = timelineSet.room.findThreadForEvent(event)) === null || _timelineSet$room$fin === void 0 ? void 0 : _timelineSet$room$fin.liveTimeline) !== null && _ref !== void 0 ? _ref : - // for Threads degraded support - timeline; - } - async getThreadTimeline(timelineSet, eventId) { - var _this$clientOpts2; - if (!this.supportsThreads()) { - throw new Error("could not get thread timeline: no client support"); - } - if (!timelineSet.room) { - throw new Error("could not get thread timeline: not a room timeline"); - } - if (!timelineSet.thread) { - throw new Error("could not get thread timeline: not a thread timeline"); - } - const path = utils.encodeUri("/rooms/$roomId/context/$eventId", { - $roomId: timelineSet.room.roomId, - $eventId: eventId - }); - const params = { - limit: "0" - }; - if ((_this$clientOpts2 = this.clientOpts) !== null && _this$clientOpts2 !== void 0 && _this$clientOpts2.lazyLoadMembers) { - params.filter = JSON.stringify(_filter.Filter.LAZY_LOADING_MESSAGES_FILTER); - } - - // TODO: we should implement a backoff (as per scrollback()) to deal more nicely with HTTP errors. - const res = await this.http.authedRequest(_httpApi.Method.Get, path, params); - const mapper = this.getEventMapper(); - const event = mapper(res.event); - if (!timelineSet.canContain(event)) { - return undefined; - } - if (_thread.Thread.hasServerSideSupport) { - if (_thread.Thread.hasServerSideFwdPaginationSupport) { - var _resOlder$next_batch, _resNewer$next_batch, _timelineSet$getTimel2; - if (!timelineSet.thread) { - throw new Error("could not get thread timeline: not a thread timeline"); - } - const thread = timelineSet.thread; - const resOlder = await this.fetchRelations(timelineSet.room.roomId, thread.id, _thread.THREAD_RELATION_TYPE.name, null, { - dir: _eventTimeline.Direction.Backward, - from: res.start - }); - const resNewer = await this.fetchRelations(timelineSet.room.roomId, thread.id, _thread.THREAD_RELATION_TYPE.name, null, { - dir: _eventTimeline.Direction.Forward, - from: res.end - }); - const events = [ - // Order events from most recent to oldest (reverse-chronological). - // We start with the last event, since that's the point at which we have known state. - // events_after is already backwards; events_before is forwards. - ...resNewer.chunk.reverse().map(mapper), event, ...resOlder.chunk.map(mapper)]; - for (const event of events) { - var _timelineSet$thread; - await ((_timelineSet$thread = timelineSet.thread) === null || _timelineSet$thread === void 0 ? void 0 : _timelineSet$thread.processEvent(event)); - } - - // Here we handle non-thread timelines only, but still process any thread events to populate thread summaries. - let timeline = timelineSet.getTimelineForEvent(event.getId()); - if (timeline) { - timeline.getState(_eventTimeline.EventTimeline.BACKWARDS).setUnknownStateEvents(res.state.map(mapper)); - } else { - timeline = timelineSet.addTimeline(); - timeline.initialiseState(res.state.map(mapper)); - } - timelineSet.addEventsToTimeline(events, true, timeline, resNewer.next_batch); - if (!resOlder.next_batch) { - const originalEvent = await this.fetchRoomEvent(timelineSet.room.roomId, thread.id); - timelineSet.addEventsToTimeline([mapper(originalEvent)], true, timeline, null); - } - timeline.setPaginationToken((_resOlder$next_batch = resOlder.next_batch) !== null && _resOlder$next_batch !== void 0 ? _resOlder$next_batch : null, _eventTimeline.Direction.Backward); - timeline.setPaginationToken((_resNewer$next_batch = resNewer.next_batch) !== null && _resNewer$next_batch !== void 0 ? _resNewer$next_batch : null, _eventTimeline.Direction.Forward); - this.processAggregatedTimelineEvents(timelineSet.room, events); - - // There is no guarantee that the event ended up in "timeline" (we might have switched to a neighbouring - // timeline) - so check the room's index again. On the other hand, there's no guarantee the event ended up - // anywhere, if it was later redacted, so we just return the timeline we first thought of. - return (_timelineSet$getTimel2 = timelineSet.getTimelineForEvent(eventId)) !== null && _timelineSet$getTimel2 !== void 0 ? _timelineSet$getTimel2 : timeline; - } else { - var _resOlder$next_batch2; - // Where the event is a thread reply (not a root) and running in MSC-enabled mode the Thread timeline only - // functions contiguously, so we have to jump through some hoops to get our target event in it. - // XXX: workaround for https://github.com/vector-im/element-meta/issues/150 - - const thread = timelineSet.thread; - const resOlder = await this.fetchRelations(timelineSet.room.roomId, thread.id, _thread.THREAD_RELATION_TYPE.name, null, { - dir: _eventTimeline.Direction.Backward, - from: res.start - }); - const eventsNewer = []; - let nextBatch = res.end; - while (nextBatch) { - var _resNewer$next_batch2; - const resNewer = await this.fetchRelations(timelineSet.room.roomId, thread.id, _thread.THREAD_RELATION_TYPE.name, null, { - dir: _eventTimeline.Direction.Forward, - from: nextBatch - }); - nextBatch = (_resNewer$next_batch2 = resNewer.next_batch) !== null && _resNewer$next_batch2 !== void 0 ? _resNewer$next_batch2 : null; - eventsNewer.push(...resNewer.chunk); - } - const events = [ - // Order events from most recent to oldest (reverse-chronological). - // We start with the last event, since that's the point at which we have known state. - // events_after is already backwards; events_before is forwards. - ...eventsNewer.reverse().map(mapper), event, ...resOlder.chunk.map(mapper)]; - for (const event of events) { - var _timelineSet$thread2; - await ((_timelineSet$thread2 = timelineSet.thread) === null || _timelineSet$thread2 === void 0 ? void 0 : _timelineSet$thread2.processEvent(event)); - } - - // Here we handle non-thread timelines only, but still process any thread events to populate thread - // summaries. - const timeline = timelineSet.getLiveTimeline(); - timeline.getState(_eventTimeline.EventTimeline.BACKWARDS).setUnknownStateEvents(res.state.map(mapper)); - timelineSet.addEventsToTimeline(events, true, timeline, null); - if (!resOlder.next_batch) { - const originalEvent = await this.fetchRoomEvent(timelineSet.room.roomId, thread.id); - timelineSet.addEventsToTimeline([mapper(originalEvent)], true, timeline, null); - } - timeline.setPaginationToken((_resOlder$next_batch2 = resOlder.next_batch) !== null && _resOlder$next_batch2 !== void 0 ? _resOlder$next_batch2 : null, _eventTimeline.Direction.Backward); - timeline.setPaginationToken(null, _eventTimeline.Direction.Forward); - this.processAggregatedTimelineEvents(timelineSet.room, events); - return timeline; - } - } - } - - /** - * Get an EventTimeline for the latest events in the room. This will just - * call `/messages` to get the latest message in the room, then use - * `client.getEventTimeline(...)` to construct a new timeline from it. - * - * @param timelineSet - The timelineSet to find or add the timeline to - * - * @returns Promise which resolves: - * {@link EventTimeline} timeline with the latest events in the room - */ - async getLatestTimeline(timelineSet) { - // don't allow any timeline support unless it's been enabled. - if (!this.timelineSupport) { - throw new Error("timeline support is disabled. Set the 'timelineSupport'" + " parameter to true when creating MatrixClient to enable it."); - } - if (!timelineSet.room) { - throw new Error("getLatestTimeline only supports room timelines"); - } - let event; - if (timelineSet.threadListType !== null) { - var _res$chunk; - const res = await this.createThreadListMessagesRequest(timelineSet.room.roomId, null, 1, _eventTimeline.Direction.Backward, timelineSet.threadListType, timelineSet.getFilter()); - event = (_res$chunk = res.chunk) === null || _res$chunk === void 0 ? void 0 : _res$chunk[0]; - } else if (timelineSet.thread && _thread.Thread.hasServerSideSupport) { - var _res$chunk2; - const res = await this.fetchRelations(timelineSet.room.roomId, timelineSet.thread.id, _thread.THREAD_RELATION_TYPE.name, null, { - dir: _eventTimeline.Direction.Backward, - limit: 1 - }); - event = (_res$chunk2 = res.chunk) === null || _res$chunk2 === void 0 ? void 0 : _res$chunk2[0]; - } else { - var _this$clientOpts3, _res$chunk3; - const messagesPath = utils.encodeUri("/rooms/$roomId/messages", { - $roomId: timelineSet.room.roomId - }); - const params = { - dir: "b" - }; - if ((_this$clientOpts3 = this.clientOpts) !== null && _this$clientOpts3 !== void 0 && _this$clientOpts3.lazyLoadMembers) { - params.filter = JSON.stringify(_filter.Filter.LAZY_LOADING_MESSAGES_FILTER); - } - const res = await this.http.authedRequest(_httpApi.Method.Get, messagesPath, params); - event = (_res$chunk3 = res.chunk) === null || _res$chunk3 === void 0 ? void 0 : _res$chunk3[0]; - } - if (!event) { - throw new Error("No message returned when trying to construct getLatestTimeline"); - } - return this.getEventTimeline(timelineSet, event.event_id); - } - - /** - * Makes a request to /messages with the appropriate lazy loading filter set. - * XXX: if we do get rid of scrollback (as it's not used at the moment), - * we could inline this method again in paginateEventTimeline as that would - * then be the only call-site - * @param limit - the maximum amount of events the retrieve - * @param dir - 'f' or 'b' - * @param timelineFilter - the timeline filter to pass - */ - // XXX: Intended private, used in code. - createMessagesRequest(roomId, fromToken, limit = 30, dir, timelineFilter) { - var _this$clientOpts4; - const path = utils.encodeUri("/rooms/$roomId/messages", { - $roomId: roomId - }); - const params = { - limit: limit.toString(), - dir: dir - }; - if (fromToken) { - params.from = fromToken; - } - let filter = null; - if ((_this$clientOpts4 = this.clientOpts) !== null && _this$clientOpts4 !== void 0 && _this$clientOpts4.lazyLoadMembers) { - // create a shallow copy of LAZY_LOADING_MESSAGES_FILTER, - // so the timelineFilter doesn't get written into it below - filter = Object.assign({}, _filter.Filter.LAZY_LOADING_MESSAGES_FILTER); - } - if (timelineFilter) { - var _timelineFilter$getRo; - // XXX: it's horrific that /messages' filter parameter doesn't match - // /sync's one - see https://matrix.org/jira/browse/SPEC-451 - filter = filter || {}; - Object.assign(filter, (_timelineFilter$getRo = timelineFilter.getRoomTimelineFilterComponent()) === null || _timelineFilter$getRo === void 0 ? void 0 : _timelineFilter$getRo.toJSON()); - } - if (filter) { - params.filter = JSON.stringify(filter); - } - return this.http.authedRequest(_httpApi.Method.Get, path, params); - } - - /** - * Makes a request to /messages with the appropriate lazy loading filter set. - * XXX: if we do get rid of scrollback (as it's not used at the moment), - * we could inline this method again in paginateEventTimeline as that would - * then be the only call-site - * @param limit - the maximum amount of events the retrieve - * @param dir - 'f' or 'b' - * @param timelineFilter - the timeline filter to pass - */ - // XXX: Intended private, used by room.fetchRoomThreads - createThreadListMessagesRequest(roomId, fromToken, limit = 30, dir = _eventTimeline.Direction.Backward, threadListType = _thread.ThreadFilterType.All, timelineFilter) { - var _this$clientOpts5; - const path = utils.encodeUri("/rooms/$roomId/threads", { - $roomId: roomId - }); - const params = { - limit: limit.toString(), - dir: dir, - include: (0, _thread.threadFilterTypeToFilter)(threadListType) - }; - if (fromToken) { - params.from = fromToken; - } - let filter = {}; - if ((_this$clientOpts5 = this.clientOpts) !== null && _this$clientOpts5 !== void 0 && _this$clientOpts5.lazyLoadMembers) { - // create a shallow copy of LAZY_LOADING_MESSAGES_FILTER, - // so the timelineFilter doesn't get written into it below - filter = _objectSpread({}, _filter.Filter.LAZY_LOADING_MESSAGES_FILTER); - } - if (timelineFilter) { - var _timelineFilter$getRo2; - // XXX: it's horrific that /messages' filter parameter doesn't match - // /sync's one - see https://matrix.org/jira/browse/SPEC-451 - filter = _objectSpread(_objectSpread({}, filter), (_timelineFilter$getRo2 = timelineFilter.getRoomTimelineFilterComponent()) === null || _timelineFilter$getRo2 === void 0 ? void 0 : _timelineFilter$getRo2.toJSON()); - } - if (Object.keys(filter).length) { - params.filter = JSON.stringify(filter); - } - const opts = { - prefix: _thread.Thread.hasServerSideListSupport === _thread.FeatureSupport.Stable ? "/_matrix/client/v1" : "/_matrix/client/unstable/org.matrix.msc3856" - }; - return this.http.authedRequest(_httpApi.Method.Get, path, params, undefined, opts).then(res => { - var _res$chunk4; - return _objectSpread(_objectSpread({}, res), {}, { - chunk: (_res$chunk4 = res.chunk) === null || _res$chunk4 === void 0 ? void 0 : _res$chunk4.reverse(), - start: res.prev_batch, - end: res.next_batch - }); - }); - } - - /** - * Take an EventTimeline, and back/forward-fill results. - * - * @param eventTimeline - timeline object to be updated - * - * @returns Promise which resolves to a boolean: false if there are no - * events and we reached either end of the timeline; else true. - */ - paginateEventTimeline(eventTimeline, opts) { - const isNotifTimeline = eventTimeline.getTimelineSet() === this.notifTimelineSet; - const room = this.getRoom(eventTimeline.getRoomId()); - const threadListType = eventTimeline.getTimelineSet().threadListType; - const thread = eventTimeline.getTimelineSet().thread; - - // TODO: we should implement a backoff (as per scrollback()) to deal more - // nicely with HTTP errors. - opts = opts || {}; - const backwards = opts.backwards || false; - if (isNotifTimeline) { - if (!backwards) { - throw new Error("paginateNotifTimeline can only paginate backwards"); - } - } - const dir = backwards ? _eventTimeline.EventTimeline.BACKWARDS : _eventTimeline.EventTimeline.FORWARDS; - const token = eventTimeline.getPaginationToken(dir); - const pendingRequest = eventTimeline.paginationRequests[dir]; - if (pendingRequest) { - // already a request in progress - return the existing promise - return pendingRequest; - } - let path; - let params; - let promise; - if (isNotifTimeline) { - var _opts$limit; - path = "/notifications"; - params = { - limit: ((_opts$limit = opts.limit) !== null && _opts$limit !== void 0 ? _opts$limit : 30).toString(), - only: "highlight" - }; - if (token && token !== "end") { - params.from = token; - } - promise = this.http.authedRequest(_httpApi.Method.Get, path, params).then(async res => { - const token = res.next_token; - const matrixEvents = []; - res.notifications = res.notifications.filter(utils.noUnsafeEventProps); - for (let i = 0; i < res.notifications.length; i++) { - const notification = res.notifications[i]; - const event = this.getEventMapper()(notification.event); - event.setPushActions(_pushprocessor.PushProcessor.actionListToActionsObject(notification.actions)); - event.event.room_id = notification.room_id; // XXX: gutwrenching - matrixEvents[i] = event; - } - - // No need to partition events for threads here, everything lives - // in the notification timeline set - const timelineSet = eventTimeline.getTimelineSet(); - timelineSet.addEventsToTimeline(matrixEvents, backwards, eventTimeline, token); - this.processAggregatedTimelineEvents(timelineSet.room, matrixEvents); - - // if we've hit the end of the timeline, we need to stop trying to - // paginate. We need to keep the 'forwards' token though, to make sure - // we can recover from gappy syncs. - if (backwards && !res.next_token) { - eventTimeline.setPaginationToken(null, dir); - } - return Boolean(res.next_token); - }).finally(() => { - eventTimeline.paginationRequests[dir] = null; - }); - eventTimeline.paginationRequests[dir] = promise; - } else if (threadListType !== null) { - if (!room) { - throw new Error("Unknown room " + eventTimeline.getRoomId()); - } - if (!_thread.Thread.hasServerSideFwdPaginationSupport && dir === _eventTimeline.Direction.Forward) { - throw new Error("Cannot paginate threads forwards without server-side support for MSC 3715"); - } - promise = this.createThreadListMessagesRequest(eventTimeline.getRoomId(), token, opts.limit, dir, threadListType, eventTimeline.getFilter()).then(res => { - if (res.state) { - const roomState = eventTimeline.getState(dir); - const stateEvents = res.state.filter(utils.noUnsafeEventProps).map(this.getEventMapper()); - roomState.setUnknownStateEvents(stateEvents); - } - const token = res.end; - const matrixEvents = res.chunk.filter(utils.noUnsafeEventProps).map(this.getEventMapper()); - const timelineSet = eventTimeline.getTimelineSet(); - timelineSet.addEventsToTimeline(matrixEvents, backwards, eventTimeline, token); - this.processAggregatedTimelineEvents(room, matrixEvents); - this.processThreadRoots(room, matrixEvents, backwards); - - // if we've hit the end of the timeline, we need to stop trying to - // paginate. We need to keep the 'forwards' token though, to make sure - // we can recover from gappy syncs. - if (backwards && res.end == res.start) { - eventTimeline.setPaginationToken(null, dir); - } - return res.end !== res.start; - }).finally(() => { - eventTimeline.paginationRequests[dir] = null; - }); - eventTimeline.paginationRequests[dir] = promise; - } else if (thread) { - var _eventTimeline$getRoo, _eventTimeline$getRoo2; - const room = this.getRoom((_eventTimeline$getRoo = eventTimeline.getRoomId()) !== null && _eventTimeline$getRoo !== void 0 ? _eventTimeline$getRoo : undefined); - if (!room) { - throw new Error("Unknown room " + eventTimeline.getRoomId()); - } - promise = this.fetchRelations((_eventTimeline$getRoo2 = eventTimeline.getRoomId()) !== null && _eventTimeline$getRoo2 !== void 0 ? _eventTimeline$getRoo2 : "", thread.id, _thread.THREAD_RELATION_TYPE.name, null, { - dir, - limit: opts.limit, - from: token !== null && token !== void 0 ? token : undefined - }).then(async res => { - const mapper = this.getEventMapper(); - const matrixEvents = res.chunk.filter(utils.noUnsafeEventProps).map(mapper); - - // Process latest events first - for (const event of matrixEvents.slice().reverse()) { - await (thread === null || thread === void 0 ? void 0 : thread.processEvent(event)); - const sender = event.getSender(); - if (!backwards || (thread === null || thread === void 0 ? void 0 : thread.getEventReadUpTo(sender)) === null) { - room.addLocalEchoReceipt(sender, event, _read_receipts.ReceiptType.Read); - } - } - const newToken = res.next_batch; - const timelineSet = eventTimeline.getTimelineSet(); - timelineSet.addEventsToTimeline(matrixEvents, backwards, eventTimeline, newToken !== null && newToken !== void 0 ? newToken : null); - if (!newToken && backwards) { - var _eventTimeline$getRoo3; - const originalEvent = await this.fetchRoomEvent((_eventTimeline$getRoo3 = eventTimeline.getRoomId()) !== null && _eventTimeline$getRoo3 !== void 0 ? _eventTimeline$getRoo3 : "", thread.id); - timelineSet.addEventsToTimeline([mapper(originalEvent)], true, eventTimeline, null); - } - this.processAggregatedTimelineEvents(timelineSet.room, matrixEvents); - - // if we've hit the end of the timeline, we need to stop trying to - // paginate. We need to keep the 'forwards' token though, to make sure - // we can recover from gappy syncs. - if (backwards && !newToken) { - eventTimeline.setPaginationToken(null, dir); - } - return Boolean(newToken); - }).finally(() => { - eventTimeline.paginationRequests[dir] = null; - }); - eventTimeline.paginationRequests[dir] = promise; - } else { - if (!room) { - throw new Error("Unknown room " + eventTimeline.getRoomId()); - } - promise = this.createMessagesRequest(eventTimeline.getRoomId(), token, opts.limit, dir, eventTimeline.getFilter()).then(res => { - if (res.state) { - const roomState = eventTimeline.getState(dir); - const stateEvents = res.state.filter(utils.noUnsafeEventProps).map(this.getEventMapper()); - roomState.setUnknownStateEvents(stateEvents); - } - const token = res.end; - const matrixEvents = res.chunk.filter(utils.noUnsafeEventProps).map(this.getEventMapper()); - const timelineSet = eventTimeline.getTimelineSet(); - const [timelineEvents] = room.partitionThreadedEvents(matrixEvents); - timelineSet.addEventsToTimeline(timelineEvents, backwards, eventTimeline, token); - this.processAggregatedTimelineEvents(room, timelineEvents); - this.processThreadRoots(room, timelineEvents.filter(it => it.getServerAggregatedRelation(_thread.THREAD_RELATION_TYPE.name)), false); - const atEnd = res.end === undefined || res.end === res.start; - - // if we've hit the end of the timeline, we need to stop trying to - // paginate. We need to keep the 'forwards' token though, to make sure - // we can recover from gappy syncs. - if (backwards && atEnd) { - eventTimeline.setPaginationToken(null, dir); - } - return !atEnd; - }).finally(() => { - eventTimeline.paginationRequests[dir] = null; - }); - eventTimeline.paginationRequests[dir] = promise; - } - return promise; - } - - /** - * Reset the notifTimelineSet entirely, paginating in some historical notifs as - * a starting point for subsequent pagination. - */ - resetNotifTimelineSet() { - if (!this.notifTimelineSet) { - return; - } - - // FIXME: This thing is a total hack, and results in duplicate events being - // added to the timeline both from /sync and /notifications, and lots of - // slow and wasteful processing and pagination. The correct solution is to - // extend /messages or /search or something to filter on notifications. - - // use the fictitious token 'end'. in practice we would ideally give it - // the oldest backwards pagination token from /sync, but /sync doesn't - // know about /notifications, so we have no choice but to start paginating - // from the current point in time. This may well overlap with historical - // notifs which are then inserted into the timeline by /sync responses. - this.notifTimelineSet.resetLiveTimeline("end"); - - // we could try to paginate a single event at this point in order to get - // a more valid pagination token, but it just ends up with an out of order - // timeline. given what a mess this is and given we're going to have duplicate - // events anyway, just leave it with the dummy token for now. - /* - this.paginateNotifTimeline(this._notifTimelineSet.getLiveTimeline(), { - backwards: true, - limit: 1 - }); - */ - } - - /** - * Peek into a room and receive updates about the room. This only works if the - * history visibility for the room is world_readable. - * @param roomId - The room to attempt to peek into. - * @returns Promise which resolves: Room object - * @returns Rejects: with an error response. - */ - peekInRoom(roomId) { - var _this$peekSync2; - (_this$peekSync2 = this.peekSync) === null || _this$peekSync2 === void 0 ? void 0 : _this$peekSync2.stopPeeking(); - this.peekSync = new _sync.SyncApi(this, this.clientOpts, this.buildSyncApiOptions()); - return this.peekSync.peek(roomId); - } - - /** - * Stop any ongoing room peeking. - */ - stopPeeking() { - if (this.peekSync) { - this.peekSync.stopPeeking(); - this.peekSync = null; - } - } - - /** - * Set r/w flags for guest access in a room. - * @param roomId - The room to configure guest access in. - * @param opts - Options - * @returns Promise which resolves - * @returns Rejects: with an error response. - */ - setGuestAccess(roomId, opts) { - const writePromise = this.sendStateEvent(roomId, _event2.EventType.RoomGuestAccess, { - guest_access: opts.allowJoin ? "can_join" : "forbidden" - }, ""); - let readPromise = Promise.resolve(undefined); - if (opts.allowRead) { - readPromise = this.sendStateEvent(roomId, _event2.EventType.RoomHistoryVisibility, { - history_visibility: "world_readable" - }, ""); - } - return Promise.all([readPromise, writePromise]).then(); // .then() to hide results for contract - } - - /** - * Requests an email verification token for the purposes of registration. - * This API requests a token from the homeserver. - * The doesServerRequireIdServerParam() method can be used to determine if - * the server requires the id_server parameter to be provided. - * - * Parameters and return value are as for requestEmailToken - * @param email - As requestEmailToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestRegisterEmailToken(email, clientSecret, sendAttempt, nextLink) { - return this.requestTokenFromEndpoint("/register/email/requestToken", { - email: email, - client_secret: clientSecret, - send_attempt: sendAttempt, - next_link: nextLink - }); - } - - /** - * Requests a text message verification token for the purposes of registration. - * This API requests a token from the homeserver. - * The doesServerRequireIdServerParam() method can be used to determine if - * the server requires the id_server parameter to be provided. - * - * @param phoneCountry - The ISO 3166-1 alpha-2 code for the country in which - * phoneNumber should be parsed relative to. - * @param phoneNumber - The phone number, in national or international format - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestRegisterMsisdnToken(phoneCountry, phoneNumber, clientSecret, sendAttempt, nextLink) { - return this.requestTokenFromEndpoint("/register/msisdn/requestToken", { - country: phoneCountry, - phone_number: phoneNumber, - client_secret: clientSecret, - send_attempt: sendAttempt, - next_link: nextLink - }); - } - - /** - * Requests an email verification token for the purposes of adding a - * third party identifier to an account. - * This API requests a token from the homeserver. - * The doesServerRequireIdServerParam() method can be used to determine if - * the server requires the id_server parameter to be provided. - * If an account with the given email address already exists and is - * associated with an account other than the one the user is authed as, - * it will either send an email to the address informing them of this - * or return M_THREEPID_IN_USE (which one is up to the homeserver). - * - * @param email - As requestEmailToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestAdd3pidEmailToken(email, clientSecret, sendAttempt, nextLink) { - return this.requestTokenFromEndpoint("/account/3pid/email/requestToken", { - email: email, - client_secret: clientSecret, - send_attempt: sendAttempt, - next_link: nextLink - }); - } - - /** - * Requests a text message verification token for the purposes of adding a - * third party identifier to an account. - * This API proxies the identity server /validate/email/requestToken API, - * adding specific behaviour for the addition of phone numbers to an - * account, as requestAdd3pidEmailToken. - * - * @param phoneCountry - As requestRegisterMsisdnToken - * @param phoneNumber - As requestRegisterMsisdnToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestAdd3pidMsisdnToken(phoneCountry, phoneNumber, clientSecret, sendAttempt, nextLink) { - return this.requestTokenFromEndpoint("/account/3pid/msisdn/requestToken", { - country: phoneCountry, - phone_number: phoneNumber, - client_secret: clientSecret, - send_attempt: sendAttempt, - next_link: nextLink - }); - } - - /** - * Requests an email verification token for the purposes of resetting - * the password on an account. - * This API proxies the identity server /validate/email/requestToken API, - * adding specific behaviour for the password resetting. Specifically, - * if no account with the given email address exists, it may either - * return M_THREEPID_NOT_FOUND or send an email - * to the address informing them of this (which one is up to the homeserver). - * - * requestEmailToken calls the equivalent API directly on the identity server, - * therefore bypassing the password reset specific logic. - * - * @param email - As requestEmailToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestPasswordEmailToken(email, clientSecret, sendAttempt, nextLink) { - return this.requestTokenFromEndpoint("/account/password/email/requestToken", { - email: email, - client_secret: clientSecret, - send_attempt: sendAttempt, - next_link: nextLink - }); - } - - /** - * Requests a text message verification token for the purposes of resetting - * the password on an account. - * This API proxies the identity server /validate/email/requestToken API, - * adding specific behaviour for the password resetting, as requestPasswordEmailToken. - * - * @param phoneCountry - As requestRegisterMsisdnToken - * @param phoneNumber - As requestRegisterMsisdnToken - * @param clientSecret - As requestEmailToken - * @param sendAttempt - As requestEmailToken - * @param nextLink - As requestEmailToken - * @returns Promise which resolves: As requestEmailToken - */ - requestPasswordMsisdnToken(phoneCountry, phoneNumber, clientSecret, sendAttempt, nextLink) { - return this.requestTokenFromEndpoint("/account/password/msisdn/requestToken", { - country: phoneCountry, - phone_number: phoneNumber, - client_secret: clientSecret, - send_attempt: sendAttempt, - next_link: nextLink - }); - } - - /** - * Internal utility function for requesting validation tokens from usage-specific - * requestToken endpoints. - * - * @param endpoint - The endpoint to send the request to - * @param params - Parameters for the POST request - * @returns Promise which resolves: As requestEmailToken - */ - async requestTokenFromEndpoint(endpoint, params) { - const postParams = Object.assign({}, params); - - // If the HS supports separate add and bind, then requestToken endpoints - // don't need an IS as they are all validated by the HS directly. - if (!(await this.doesServerSupportSeparateAddAndBind()) && this.idBaseUrl) { - var _this$identityServer2; - const idServerUrl = new URL(this.idBaseUrl); - postParams.id_server = idServerUrl.host; - if ((_this$identityServer2 = this.identityServer) !== null && _this$identityServer2 !== void 0 && _this$identityServer2.getAccessToken && (await this.doesServerAcceptIdentityAccessToken())) { - const identityAccessToken = await this.identityServer.getAccessToken(); - if (identityAccessToken) { - postParams.id_access_token = identityAccessToken; - } - } - } - return this.http.request(_httpApi.Method.Post, endpoint, undefined, postParams); - } - - /** - * Get the room-kind push rule associated with a room. - * @param scope - "global" or device-specific. - * @param roomId - the id of the room. - * @returns the rule or undefined. - */ - getRoomPushRule(scope, roomId) { - // There can be only room-kind push rule per room - // and its id is the room id. - if (this.pushRules) { - var _this$pushRules$scope, _this$pushRules$scope2; - return (_this$pushRules$scope = this.pushRules[scope]) === null || _this$pushRules$scope === void 0 ? void 0 : (_this$pushRules$scope2 = _this$pushRules$scope.room) === null || _this$pushRules$scope2 === void 0 ? void 0 : _this$pushRules$scope2.find(rule => rule.rule_id === roomId); - } else { - throw new Error("SyncApi.sync() must be done before accessing to push rules."); - } - } - - /** - * Set a room-kind muting push rule in a room. - * The operation also updates MatrixClient.pushRules at the end. - * @param scope - "global" or device-specific. - * @param roomId - the id of the room. - * @param mute - the mute state. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - setRoomMutePushRule(scope, roomId, mute) { - let promise; - let hasDontNotifyRule = false; - - // Get the existing room-kind push rule if any - const roomPushRule = this.getRoomPushRule(scope, roomId); - if (roomPushRule !== null && roomPushRule !== void 0 && roomPushRule.actions.includes(_PushRules.PushRuleActionName.DontNotify)) { - hasDontNotifyRule = true; - } - if (!mute) { - // Remove the rule only if it is a muting rule - if (hasDontNotifyRule) { - promise = this.deletePushRule(scope, _PushRules.PushRuleKind.RoomSpecific, roomPushRule.rule_id); - } - } else { - if (!roomPushRule) { - promise = this.addPushRule(scope, _PushRules.PushRuleKind.RoomSpecific, roomId, { - actions: [_PushRules.PushRuleActionName.DontNotify] - }); - } else if (!hasDontNotifyRule) { - // Remove the existing one before setting the mute push rule - // This is a workaround to SYN-590 (Push rule update fails) - const deferred = utils.defer(); - this.deletePushRule(scope, _PushRules.PushRuleKind.RoomSpecific, roomPushRule.rule_id).then(() => { - this.addPushRule(scope, _PushRules.PushRuleKind.RoomSpecific, roomId, { - actions: [_PushRules.PushRuleActionName.DontNotify] - }).then(() => { - deferred.resolve(); - }).catch(err => { - deferred.reject(err); - }); - }).catch(err => { - deferred.reject(err); - }); - promise = deferred.promise; - } - } - if (promise) { - return new Promise((resolve, reject) => { - // Update this.pushRules when the operation completes - promise.then(() => { - this.getPushRules().then(result => { - this.pushRules = result; - resolve(); - }).catch(err => { - reject(err); - }); - }).catch(err => { - // Update it even if the previous operation fails. This can help the - // app to recover when push settings has been modified from another client - this.getPushRules().then(result => { - this.pushRules = result; - reject(err); - }).catch(err2 => { - reject(err); - }); - }); - }); - } - } - searchMessageText(opts) { - const roomEvents = { - search_term: opts.query - }; - if ("keys" in opts) { - roomEvents.keys = opts.keys; - } - return this.search({ - body: { - search_categories: { - room_events: roomEvents - } - } - }); - } - - /** - * Perform a server-side search for room events. - * - * The returned promise resolves to an object containing the fields: - * - * * count: estimate of the number of results - * * next_batch: token for back-pagination; if undefined, there are no more results - * * highlights: a list of words to highlight from the stemming algorithm - * * results: a list of results - * - * Each entry in the results list is a SearchResult. - * - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - searchRoomEvents(opts) { - // TODO: support search groups - - const body = { - search_categories: { - room_events: { - search_term: opts.term, - filter: opts.filter, - order_by: _search.SearchOrderBy.Recent, - event_context: { - before_limit: 1, - after_limit: 1, - include_profile: true - } - } - } - }; - const searchResults = { - _query: body, - results: [], - highlights: [] - }; - return this.search({ - body: body - }).then(res => this.processRoomEventsSearch(searchResults, res)); - } - - /** - * Take a result from an earlier searchRoomEvents call, and backfill results. - * - * @param searchResults - the results object to be updated - * @returns Promise which resolves: updated result object - * @returns Rejects: with an error response. - */ - backPaginateRoomEventsSearch(searchResults) { - // TODO: we should implement a backoff (as per scrollback()) to deal more - // nicely with HTTP errors. - - if (!searchResults.next_batch) { - return Promise.reject(new Error("Cannot backpaginate event search any further")); - } - if (searchResults.pendingRequest) { - // already a request in progress - return the existing promise - return searchResults.pendingRequest; - } - const searchOpts = { - body: searchResults._query, - next_batch: searchResults.next_batch - }; - const promise = this.search(searchOpts, searchResults.abortSignal).then(res => this.processRoomEventsSearch(searchResults, res)).finally(() => { - searchResults.pendingRequest = undefined; - }); - searchResults.pendingRequest = promise; - return promise; - } - - /** - * helper for searchRoomEvents and backPaginateRoomEventsSearch. Processes the - * response from the API call and updates the searchResults - * - * @returns searchResults - * @internal - */ - // XXX: Intended private, used in code - processRoomEventsSearch(searchResults, response) { - var _roomEvents$results$l, _roomEvents$results; - const roomEvents = response.search_categories.room_events; - searchResults.count = roomEvents.count; - searchResults.next_batch = roomEvents.next_batch; - - // combine the highlight list with our existing list; - const highlights = new Set(roomEvents.highlights); - searchResults.highlights.forEach(hl => { - highlights.add(hl); - }); - - // turn it back into a list. - searchResults.highlights = Array.from(highlights); - const mapper = this.getEventMapper(); - - // append the new results to our existing results - const resultsLength = (_roomEvents$results$l = (_roomEvents$results = roomEvents.results) === null || _roomEvents$results === void 0 ? void 0 : _roomEvents$results.length) !== null && _roomEvents$results$l !== void 0 ? _roomEvents$results$l : 0; - for (let i = 0; i < resultsLength; i++) { - const sr = _searchResult.SearchResult.fromJson(roomEvents.results[i], mapper); - const room = this.getRoom(sr.context.getEvent().getRoomId()); - if (room) { - // Copy over a known event sender if we can - for (const ev of sr.context.getTimeline()) { - const sender = room.getMember(ev.getSender()); - if (!ev.sender && sender) ev.sender = sender; - } - } - searchResults.results.push(sr); - } - return searchResults; - } - - /** - * Populate the store with rooms the user has left. - * @returns Promise which resolves: TODO - Resolved when the rooms have - * been added to the data store. - * @returns Rejects: with an error response. - */ - syncLeftRooms() { - // Guard against multiple calls whilst ongoing and multiple calls post success - if (this.syncedLeftRooms) { - return Promise.resolve([]); // don't call syncRooms again if it succeeded. - } - - if (this.syncLeftRoomsPromise) { - return this.syncLeftRoomsPromise; // return the ongoing request - } - - const syncApi = new _sync.SyncApi(this, this.clientOpts, this.buildSyncApiOptions()); - this.syncLeftRoomsPromise = syncApi.syncLeftRooms(); - - // cleanup locks - this.syncLeftRoomsPromise.then(() => { - _logger.logger.log("Marking success of sync left room request"); - this.syncedLeftRooms = true; // flip the bit on success - }).finally(() => { - this.syncLeftRoomsPromise = undefined; // cleanup ongoing request state - }); - - return this.syncLeftRoomsPromise; - } - - /** - * Create a new filter. - * @param content - The HTTP body for the request - * @returns Promise which resolves to a Filter object. - * @returns Rejects: with an error response. - */ - createFilter(content) { - const path = utils.encodeUri("/user/$userId/filter", { - $userId: this.credentials.userId - }); - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, content).then(response => { - // persist the filter - const filter = _filter.Filter.fromJson(this.credentials.userId, response.filter_id, content); - this.store.storeFilter(filter); - return filter; - }); - } - - /** - * Retrieve a filter. - * @param userId - The user ID of the filter owner - * @param filterId - The filter ID to retrieve - * @param allowCached - True to allow cached filters to be returned. - * Default: True. - * @returns Promise which resolves: a Filter object - * @returns Rejects: with an error response. - */ - getFilter(userId, filterId, allowCached) { - if (allowCached) { - const filter = this.store.getFilter(userId, filterId); - if (filter) { - return Promise.resolve(filter); - } - } - const path = utils.encodeUri("/user/$userId/filter/$filterId", { - $userId: userId, - $filterId: filterId - }); - return this.http.authedRequest(_httpApi.Method.Get, path).then(response => { - // persist the filter - const filter = _filter.Filter.fromJson(userId, filterId, response); - this.store.storeFilter(filter); - return filter; - }); - } - - /** - * @returns Filter ID - */ - async getOrCreateFilter(filterName, filter) { - const filterId = this.store.getFilterIdByName(filterName); - let existingId; - if (filterId) { - // check that the existing filter matches our expectations - try { - const existingFilter = await this.getFilter(this.credentials.userId, filterId, true); - if (existingFilter) { - const oldDef = existingFilter.getDefinition(); - const newDef = filter.getDefinition(); - if (utils.deepCompare(oldDef, newDef)) { - // super, just use that. - // debuglog("Using existing filter ID %s: %s", filterId, - // JSON.stringify(oldDef)); - existingId = filterId; - } - } - } catch (error) { - // Synapse currently returns the following when the filter cannot be found: - // { - // errcode: "M_UNKNOWN", - // name: "M_UNKNOWN", - // message: "No row found", - // } - if (error.errcode !== "M_UNKNOWN" && error.errcode !== "M_NOT_FOUND") { - throw error; - } - } - // if the filter doesn't exist anymore on the server, remove from store - if (!existingId) { - this.store.setFilterIdByName(filterName, undefined); - } - } - if (existingId) { - return existingId; - } - - // create a new filter - const createdFilter = await this.createFilter(filter.getDefinition()); - this.store.setFilterIdByName(filterName, createdFilter.filterId); - return createdFilter.filterId; - } - - /** - * Gets a bearer token from the homeserver that the user can - * present to a third party in order to prove their ownership - * of the Matrix account they are logged into. - * @returns Promise which resolves: Token object - * @returns Rejects: with an error response. - */ - getOpenIdToken() { - const path = utils.encodeUri("/user/$userId/openid/request_token", { - $userId: this.credentials.userId - }); - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, {}); - } - /** - * @returns Promise which resolves: ITurnServerResponse object - * @returns Rejects: with an error response. - */ - turnServer() { - return this.http.authedRequest(_httpApi.Method.Get, "/voip/turnServer"); - } - - /** - * Get the TURN servers for this homeserver. - * @returns The servers or an empty list. - */ - getTurnServers() { - return this.turnServers || []; - } - - /** - * Get the unix timestamp (in milliseconds) at which the current - * TURN credentials (from getTurnServers) expire - * @returns The expiry timestamp in milliseconds - */ - getTurnServersExpiry() { - return this.turnServersExpiry; - } - get pollingTurnServers() { - return this.checkTurnServersIntervalID !== undefined; - } - - // XXX: Intended private, used in code. - async checkTurnServers() { - if (!this.canSupportVoip) { - return; - } - let credentialsGood = false; - const remainingTime = this.turnServersExpiry - Date.now(); - if (remainingTime > TURN_CHECK_INTERVAL) { - _logger.logger.debug("TURN creds are valid for another " + remainingTime + " ms: not fetching new ones."); - credentialsGood = true; - } else { - _logger.logger.debug("Fetching new TURN credentials"); - try { - const res = await this.turnServer(); - if (res.uris) { - _logger.logger.log("Got TURN URIs: " + res.uris + " refresh in " + res.ttl + " secs"); - // map the response to a format that can be fed to RTCPeerConnection - const servers = { - urls: res.uris, - username: res.username, - credential: res.password - }; - this.turnServers = [servers]; - // The TTL is in seconds but we work in ms - this.turnServersExpiry = Date.now() + res.ttl * 1000; - credentialsGood = true; - this.emit(ClientEvent.TurnServers, this.turnServers); - } - } catch (err) { - _logger.logger.error("Failed to get TURN URIs", err); - if (err.httpStatus === 403) { - // We got a 403, so there's no point in looping forever. - _logger.logger.info("TURN access unavailable for this account: stopping credentials checks"); - if (this.checkTurnServersIntervalID !== null) global.clearInterval(this.checkTurnServersIntervalID); - this.checkTurnServersIntervalID = undefined; - this.emit(ClientEvent.TurnServersError, err, true); // fatal - } else { - // otherwise, if we failed for whatever reason, try again the next time we're called. - this.emit(ClientEvent.TurnServersError, err, false); // non-fatal - } - } - } - - return credentialsGood; - } - - /** - * Set whether to allow a fallback ICE server should be used for negotiating a - * WebRTC connection if the homeserver doesn't provide any servers. Defaults to - * false. - * - */ - setFallbackICEServerAllowed(allow) { - this.fallbackICEServerAllowed = allow; - } - - /** - * Get whether to allow a fallback ICE server should be used for negotiating a - * WebRTC connection if the homeserver doesn't provide any servers. Defaults to - * false. - * - * @returns - */ - isFallbackICEServerAllowed() { - return this.fallbackICEServerAllowed; - } - - /** - * Determines if the current user is an administrator of the Synapse homeserver. - * Returns false if untrue or the homeserver does not appear to be a Synapse - * homeserver. This function is implementation specific and may change - * as a result. - * @returns true if the user appears to be a Synapse administrator. - */ - isSynapseAdministrator() { - const path = utils.encodeUri("/_synapse/admin/v1/users/$userId/admin", { - $userId: this.getUserId() - }); - return this.http.authedRequest(_httpApi.Method.Get, path, undefined, undefined, { - prefix: "" - }).then(r => r.admin); // pull out the specific boolean we want - } - - /** - * Performs a whois lookup on a user using Synapse's administrator API. - * This function is implementation specific and may change as a - * result. - * @param userId - the User ID to look up. - * @returns the whois response - see Synapse docs for information. - */ - whoisSynapseUser(userId) { - const path = utils.encodeUri("/_synapse/admin/v1/whois/$userId", { - $userId: userId - }); - return this.http.authedRequest(_httpApi.Method.Get, path, undefined, undefined, { - prefix: "" - }); - } - - /** - * Deactivates a user using Synapse's administrator API. This - * function is implementation specific and may change as a result. - * @param userId - the User ID to deactivate. - * @returns the deactivate response - see Synapse docs for information. - */ - deactivateSynapseUser(userId) { - const path = utils.encodeUri("/_synapse/admin/v1/deactivate/$userId", { - $userId: userId - }); - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, undefined, { - prefix: "" - }); - } - async fetchClientWellKnown() { - var _this$getDomain; - // `getRawClientConfig` does not throw or reject on network errors, instead - // it absorbs errors and returns `{}`. - this.clientWellKnownPromise = _autodiscovery.AutoDiscovery.getRawClientConfig((_this$getDomain = this.getDomain()) !== null && _this$getDomain !== void 0 ? _this$getDomain : undefined); - this.clientWellKnown = await this.clientWellKnownPromise; - this.emit(ClientEvent.ClientWellKnown, this.clientWellKnown); - } - getClientWellKnown() { - return this.clientWellKnown; - } - waitForClientWellKnown() { - if (!this.clientRunning) { - throw new Error("Client is not running"); - } - return this.clientWellKnownPromise; - } - - /** - * store client options with boolean/string/numeric values - * to know in the next session what flags the sync data was - * created with (e.g. lazy loading) - * @param opts - the complete set of client options - * @returns for store operation - */ - storeClientOptions() { - // XXX: Intended private, used in code - const primTypes = ["boolean", "string", "number"]; - const serializableOpts = Object.entries(this.clientOpts).filter(([key, value]) => { - return primTypes.includes(typeof value); - }).reduce((obj, [key, value]) => { - obj[key] = value; - return obj; - }, {}); - return this.store.storeClientOptions(serializableOpts); - } - - /** - * Gets a set of room IDs in common with another user - * @param userId - The userId to check. - * @returns Promise which resolves to a set of rooms - * @returns Rejects: with an error response. - */ - // eslint-disable-next-line - async _unstable_getSharedRooms(userId) { - const sharedRoomsSupport = await this.doesServerSupportUnstableFeature("uk.half-shot.msc2666"); - const mutualRoomsSupport = await this.doesServerSupportUnstableFeature("uk.half-shot.msc2666.mutual_rooms"); - if (!sharedRoomsSupport && !mutualRoomsSupport) { - throw Error("Server does not support mutual_rooms API"); - } - const path = utils.encodeUri(`/uk.half-shot.msc2666/user/${mutualRoomsSupport ? "mutual_rooms" : "shared_rooms"}/$userId`, { - $userId: userId - }); - const res = await this.http.authedRequest(_httpApi.Method.Get, path, undefined, undefined, { - prefix: _httpApi.ClientPrefix.Unstable - }); - return res.joined; - } - - /** - * Get the API versions supported by the server, along with any - * unstable APIs it supports - * @returns The server /versions response - */ - async getVersions() { - if (this.serverVersionsPromise) { - return this.serverVersionsPromise; - } - this.serverVersionsPromise = this.http.request(_httpApi.Method.Get, "/_matrix/client/versions", undefined, - // queryParams - undefined, - // data - { - prefix: "" - }).catch(e => { - // Need to unset this if it fails, otherwise we'll never retry - this.serverVersionsPromise = undefined; - // but rethrow the exception to anything that was waiting - throw e; - }); - const serverVersions = await this.serverVersionsPromise; - this.canSupport = await (0, _feature.buildFeatureSupportMap)(serverVersions); - return this.serverVersionsPromise; - } - - /** - * Check if a particular spec version is supported by the server. - * @param version - The spec version (such as "r0.5.0") to check for. - * @returns Whether it is supported - */ - async isVersionSupported(version) { - const { - versions - } = await this.getVersions(); - return versions && versions.includes(version); - } - - /** - * Query the server to see if it supports members lazy loading - * @returns true if server supports lazy loading - */ - async doesServerSupportLazyLoading() { - const response = await this.getVersions(); - if (!response) return false; - const versions = response["versions"]; - const unstableFeatures = response["unstable_features"]; - return versions && versions.includes("r0.5.0") || unstableFeatures && unstableFeatures["m.lazy_load_members"]; - } - - /** - * Query the server to see if the `id_server` parameter is required - * when registering with an 3pid, adding a 3pid or resetting password. - * @returns true if id_server parameter is required - */ - async doesServerRequireIdServerParam() { - const response = await this.getVersions(); - if (!response) return true; - const versions = response["versions"]; - - // Supporting r0.6.0 is the same as having the flag set to false - if (versions && versions.includes("r0.6.0")) { - return false; - } - const unstableFeatures = response["unstable_features"]; - if (!unstableFeatures) return true; - if (unstableFeatures["m.require_identity_server"] === undefined) { - return true; - } else { - return unstableFeatures["m.require_identity_server"]; - } - } - - /** - * Query the server to see if the `id_access_token` parameter can be safely - * passed to the homeserver. Some homeservers may trigger errors if they are not - * prepared for the new parameter. - * @returns true if id_access_token can be sent - */ - async doesServerAcceptIdentityAccessToken() { - const response = await this.getVersions(); - if (!response) return false; - const versions = response["versions"]; - const unstableFeatures = response["unstable_features"]; - return versions && versions.includes("r0.6.0") || unstableFeatures && unstableFeatures["m.id_access_token"]; - } - - /** - * Query the server to see if it supports separate 3PID add and bind functions. - * This affects the sequence of API calls clients should use for these operations, - * so it's helpful to be able to check for support. - * @returns true if separate functions are supported - */ - async doesServerSupportSeparateAddAndBind() { - const response = await this.getVersions(); - if (!response) return false; - const versions = response["versions"]; - const unstableFeatures = response["unstable_features"]; - return (versions === null || versions === void 0 ? void 0 : versions.includes("r0.6.0")) || (unstableFeatures === null || unstableFeatures === void 0 ? void 0 : unstableFeatures["m.separate_add_and_bind"]); - } - - /** - * Query the server to see if it lists support for an unstable feature - * in the /versions response - * @param feature - the feature name - * @returns true if the feature is supported - */ - async doesServerSupportUnstableFeature(feature) { - const response = await this.getVersions(); - if (!response) return false; - const unstableFeatures = response["unstable_features"]; - return unstableFeatures && !!unstableFeatures[feature]; - } - - /** - * Query the server to see if it is forcing encryption to be enabled for - * a given room preset, based on the /versions response. - * @param presetName - The name of the preset to check. - * @returns true if the server is forcing encryption - * for the preset. - */ - async doesServerForceEncryptionForPreset(presetName) { - const response = await this.getVersions(); - if (!response) return false; - const unstableFeatures = response["unstable_features"]; - - // The preset name in the versions response will be without the _chat suffix. - const versionsPresetName = presetName.includes("_chat") ? presetName.substring(0, presetName.indexOf("_chat")) : presetName; - return unstableFeatures && !!unstableFeatures[`io.element.e2ee_forced.${versionsPresetName}`]; - } - async doesServerSupportThread() { - if (await this.isVersionSupported("v1.4")) { - return { - threads: _thread.FeatureSupport.Stable, - list: _thread.FeatureSupport.Stable, - fwdPagination: _thread.FeatureSupport.Stable - }; - } - try { - const [threadUnstable, threadStable, listUnstable, listStable, fwdPaginationUnstable, fwdPaginationStable] = await Promise.all([this.doesServerSupportUnstableFeature("org.matrix.msc3440"), this.doesServerSupportUnstableFeature("org.matrix.msc3440.stable"), this.doesServerSupportUnstableFeature("org.matrix.msc3856"), this.doesServerSupportUnstableFeature("org.matrix.msc3856.stable"), this.doesServerSupportUnstableFeature("org.matrix.msc3715"), this.doesServerSupportUnstableFeature("org.matrix.msc3715.stable")]); - return { - threads: (0, _thread.determineFeatureSupport)(threadStable, threadUnstable), - list: (0, _thread.determineFeatureSupport)(listStable, listUnstable), - fwdPagination: (0, _thread.determineFeatureSupport)(fwdPaginationStable, fwdPaginationUnstable) - }; - } catch (e) { - return { - threads: _thread.FeatureSupport.None, - list: _thread.FeatureSupport.None, - fwdPagination: _thread.FeatureSupport.None - }; - } - } - - /** - * Query the server to see if it supports the MSC2457 `logout_devices` parameter when setting password - * @returns true if server supports the `logout_devices` parameter - */ - doesServerSupportLogoutDevices() { - return this.isVersionSupported("r0.6.1"); - } - - /** - * Get if lazy loading members is being used. - * @returns Whether or not members are lazy loaded by this client - */ - hasLazyLoadMembersEnabled() { - var _this$clientOpts6; - return !!((_this$clientOpts6 = this.clientOpts) !== null && _this$clientOpts6 !== void 0 && _this$clientOpts6.lazyLoadMembers); - } - - /** - * Set a function which is called when /sync returns a 'limited' response. - * It is called with a room ID and returns a boolean. It should return 'true' if the SDK - * can SAFELY remove events from this room. It may not be safe to remove events if there - * are other references to the timelines for this room, e.g because the client is - * actively viewing events in this room. - * Default: returns false. - * @param cb - The callback which will be invoked. - */ - setCanResetTimelineCallback(cb) { - this.canResetTimelineCallback = cb; - } - - /** - * Get the callback set via `setCanResetTimelineCallback`. - * @returns The callback or null - */ - getCanResetTimelineCallback() { - return this.canResetTimelineCallback; - } - - /** - * Returns relations for a given event. Handles encryption transparently, - * with the caveat that the amount of events returned might be 0, even though you get a nextBatch. - * When the returned promise resolves, all messages should have finished trying to decrypt. - * @param roomId - the room of the event - * @param eventId - the id of the event - * @param relationType - the rel_type of the relations requested - * @param eventType - the event type of the relations requested - * @param opts - options with optional values for the request. - * @returns an object with `events` as `MatrixEvent[]` and optionally `nextBatch` if more relations are available. - */ - async relations(roomId, eventId, relationType, eventType, opts = { - dir: _eventTimeline.Direction.Backward - }) { - var _result$next_batch, _result$prev_batch; - const fetchedEventType = eventType ? this.getEncryptedIfNeededEventType(roomId, eventType) : null; - const [eventResult, result] = await Promise.all([this.fetchRoomEvent(roomId, eventId), this.fetchRelations(roomId, eventId, relationType, fetchedEventType, opts)]); - const mapper = this.getEventMapper(); - const originalEvent = eventResult ? mapper(eventResult) : undefined; - let events = result.chunk.map(mapper); - if (fetchedEventType === _event2.EventType.RoomMessageEncrypted) { - const allEvents = originalEvent ? events.concat(originalEvent) : events; - await Promise.all(allEvents.map(e => this.decryptEventIfNeeded(e))); - if (eventType !== null) { - events = events.filter(e => e.getType() === eventType); - } - } - if (originalEvent && relationType === _event2.RelationType.Replace) { - events = events.filter(e => e.getSender() === originalEvent.getSender()); - } - return { - originalEvent: originalEvent !== null && originalEvent !== void 0 ? originalEvent : null, - events, - nextBatch: (_result$next_batch = result.next_batch) !== null && _result$next_batch !== void 0 ? _result$next_batch : null, - prevBatch: (_result$prev_batch = result.prev_batch) !== null && _result$prev_batch !== void 0 ? _result$prev_batch : null - }; - } - - /** - * The app may wish to see if we have a key cached without - * triggering a user interaction. - */ - getCrossSigningCacheCallbacks() { - var _this$crypto3; - // XXX: Private member access - return (_this$crypto3 = this.crypto) === null || _this$crypto3 === void 0 ? void 0 : _this$crypto3.crossSigningInfo.getCacheCallbacks(); - } - - /** - * Generates a random string suitable for use as a client secret. This - * method is experimental and may change. - * @returns A new client secret - */ - generateClientSecret() { - return (0, _randomstring.randomString)(32); - } - - /** - * Attempts to decrypt an event - * @param event - The event to decrypt - * @returns A decryption promise - */ - decryptEventIfNeeded(event, options) { - if (event.shouldAttemptDecryption() && this.isCryptoEnabled()) { - event.attemptDecryption(this.cryptoBackend, options); - } - if (event.isBeingDecrypted()) { - return event.getDecryptionPromise(); - } else { - return Promise.resolve(); - } - } - termsUrlForService(serviceType, baseUrl) { - switch (serviceType) { - case _serviceTypes.SERVICE_TYPES.IS: - return this.http.getUrl("/terms", undefined, _httpApi.IdentityPrefix.V2, baseUrl); - case _serviceTypes.SERVICE_TYPES.IM: - return this.http.getUrl("/terms", undefined, "/_matrix/integrations/v1", baseUrl); - default: - throw new Error("Unsupported service type"); - } - } - - /** - * Get the Homeserver URL of this client - * @returns Homeserver URL of this client - */ - getHomeserverUrl() { - return this.baseUrl; - } - - /** - * Get the identity server URL of this client - * @param stripProto - whether or not to strip the protocol from the URL - * @returns Identity server URL of this client - */ - getIdentityServerUrl(stripProto = false) { - var _this$idBaseUrl, _this$idBaseUrl2; - if (stripProto && ((_this$idBaseUrl = this.idBaseUrl) !== null && _this$idBaseUrl !== void 0 && _this$idBaseUrl.startsWith("http://") || (_this$idBaseUrl2 = this.idBaseUrl) !== null && _this$idBaseUrl2 !== void 0 && _this$idBaseUrl2.startsWith("https://"))) { - return this.idBaseUrl.split("://")[1]; - } - return this.idBaseUrl; - } - - /** - * Set the identity server URL of this client - * @param url - New identity server URL - */ - setIdentityServerUrl(url) { - this.idBaseUrl = utils.ensureNoTrailingSlash(url); - this.http.setIdBaseUrl(this.idBaseUrl); - } - - /** - * Get the access token associated with this account. - * @returns The access_token or null - */ - getAccessToken() { - return this.http.opts.accessToken || null; - } - - /** - * Set the access token associated with this account. - * @param token - The new access token. - */ - setAccessToken(token) { - this.http.opts.accessToken = token; - } - - /** - * @returns true if there is a valid access_token for this client. - */ - isLoggedIn() { - return this.http.opts.accessToken !== undefined; - } - - /** - * Make up a new transaction id - * - * @returns a new, unique, transaction id - */ - makeTxnId() { - return "m" + new Date().getTime() + "." + this.txnCtr++; - } - - /** - * Check whether a username is available prior to registration. An error response - * indicates an invalid/unavailable username. - * @param username - The username to check the availability of. - * @returns Promise which resolves: to boolean of whether the username is available. - */ - isUsernameAvailable(username) { - return this.http.authedRequest(_httpApi.Method.Get, "/register/available", { - username - }).then(response => { - return response.available; - }).catch(response => { - if (response.errcode === "M_USER_IN_USE") { - return false; - } - return Promise.reject(response); - }); - } - - /** - * @param bindThreepids - Set key 'email' to true to bind any email - * threepid uses during registration in the identity server. Set 'msisdn' to - * true to bind msisdn. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - register(username, password, sessionId, auth, bindThreepids, guestAccessToken, inhibitLogin) { - // backwards compat - if (bindThreepids === true) { - bindThreepids = { - email: true - }; - } else if (bindThreepids === null || bindThreepids === undefined || bindThreepids === false) { - bindThreepids = {}; - } - if (sessionId) { - auth.session = sessionId; - } - const params = { - auth: auth, - refresh_token: true // always ask for a refresh token - does nothing if unsupported - }; - - if (username !== undefined && username !== null) { - params.username = username; - } - if (password !== undefined && password !== null) { - params.password = password; - } - if (bindThreepids.email) { - params.bind_email = true; - } - if (bindThreepids.msisdn) { - params.bind_msisdn = true; - } - if (guestAccessToken !== undefined && guestAccessToken !== null) { - params.guest_access_token = guestAccessToken; - } - if (inhibitLogin !== undefined && inhibitLogin !== null) { - params.inhibit_login = inhibitLogin; - } - // Temporary parameter added to make the register endpoint advertise - // msisdn flows. This exists because there are clients that break - // when given stages they don't recognise. This parameter will cease - // to be necessary once these old clients are gone. - // Only send it if we send any params at all (the password param is - // mandatory, so if we send any params, we'll send the password param) - if (password !== undefined && password !== null) { - params.x_show_msisdn = true; - } - return this.registerRequest(params); - } - - /** - * Register a guest account. - * This method returns the auth info needed to create a new authenticated client, - * Remember to call `setGuest(true)` on the (guest-)authenticated client, e.g: - * ```javascript - * const tmpClient = await sdk.createClient(MATRIX_INSTANCE); - * const { user_id, device_id, access_token } = tmpClient.registerGuest(); - * const client = createClient({ - * baseUrl: MATRIX_INSTANCE, - * accessToken: access_token, - * userId: user_id, - * deviceId: device_id, - * }) - * client.setGuest(true); - * ``` - * - * @param body - JSON HTTP body to provide. - * @returns Promise which resolves: JSON object that contains: - * `{ user_id, device_id, access_token, home_server }` - * @returns Rejects: with an error response. - */ - registerGuest({ - body - } = {}) { - // TODO: Types - return this.registerRequest(body || {}, "guest"); - } - - /** - * @param data - parameters for registration request - * @param kind - type of user to register. may be "guest" - * @returns Promise which resolves: to the /register response - * @returns Rejects: with an error response. - */ - registerRequest(data, kind) { - const params = {}; - if (kind) { - params.kind = kind; - } - return this.http.request(_httpApi.Method.Post, "/register", params, data); - } - - /** - * Refreshes an access token using a provided refresh token. The refresh token - * must be valid for the current access token known to the client instance. - * - * Note that this function will not cause a logout if the token is deemed - * unknown by the server - the caller is responsible for managing logout - * actions on error. - * @param refreshToken - The refresh token. - * @returns Promise which resolves to the new token. - * @returns Rejects with an error response. - */ - refreshToken(refreshToken) { - return this.http.authedRequest(_httpApi.Method.Post, "/refresh", undefined, { - refresh_token: refreshToken - }, { - prefix: _httpApi.ClientPrefix.V1, - inhibitLogoutEmit: true // we don't want to cause logout loops - }); - } - - /** - * @returns Promise which resolves to the available login flows - * @returns Rejects: with an error response. - */ - loginFlows() { - return this.http.request(_httpApi.Method.Get, "/login"); - } - - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - login(loginType, data) { - // TODO: Types - const loginData = { - type: loginType - }; - - // merge data into loginData - Object.assign(loginData, data); - return this.http.authedRequest(_httpApi.Method.Post, "/login", undefined, loginData).then(response => { - if (response.access_token && response.user_id) { - this.http.opts.accessToken = response.access_token; - this.credentials = { - userId: response.user_id - }; - } - return response; - }); - } - - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - loginWithPassword(user, password) { - // TODO: Types - return this.login("m.login.password", { - user: user, - password: password - }); - } - - /** - * @param relayState - URL Callback after SAML2 Authentication - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - loginWithSAML2(relayState) { - // TODO: Types - return this.login("m.login.saml2", { - relay_state: relayState - }); - } - - /** - * @param redirectUrl - The URL to redirect to after the HS - * authenticates with CAS. - * @returns The HS URL to hit to begin the CAS login process. - */ - getCasLoginUrl(redirectUrl) { - return this.getSsoLoginUrl(redirectUrl, "cas"); - } - - /** - * @param redirectUrl - The URL to redirect to after the HS - * authenticates with the SSO. - * @param loginType - The type of SSO login we are doing (sso or cas). - * Defaults to 'sso'. - * @param idpId - The ID of the Identity Provider being targeted, optional. - * @param action - the SSO flow to indicate to the IdP, optional. - * @returns The HS URL to hit to begin the SSO login process. - */ - getSsoLoginUrl(redirectUrl, loginType = "sso", idpId, action) { - let url = "/login/" + loginType + "/redirect"; - if (idpId) { - url += "/" + idpId; - } - const params = { - redirectUrl, - [SSO_ACTION_PARAM.unstable]: action - }; - return this.http.getUrl(url, params, _httpApi.ClientPrefix.R0).href; - } - - /** - * @param token - Login token previously received from homeserver - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - loginWithToken(token) { - // TODO: Types - return this.login("m.login.token", { - token: token - }); - } - - /** - * Logs out the current session. - * Obviously, further calls that require authorisation should fail after this - * method is called. The state of the MatrixClient object is not affected: - * it is up to the caller to either reset or destroy the MatrixClient after - * this method succeeds. - * @param stopClient - whether to stop the client before calling /logout to prevent invalid token errors. - * @returns Promise which resolves: On success, the empty object `{}` - */ - async logout(stopClient = false) { - var _this$crypto4, _this$crypto4$backupM; - if ((_this$crypto4 = this.crypto) !== null && _this$crypto4 !== void 0 && (_this$crypto4$backupM = _this$crypto4.backupManager) !== null && _this$crypto4$backupM !== void 0 && _this$crypto4$backupM.getKeyBackupEnabled()) { - try { - while ((await this.crypto.backupManager.backupPendingKeys(200)) > 0); - } catch (err) { - _logger.logger.error("Key backup request failed when logging out. Some keys may be missing from backup", err); - } - } - if (stopClient) { - this.stopClient(); - this.http.abort(); - } - return this.http.authedRequest(_httpApi.Method.Post, "/logout"); - } - - /** - * Deactivates the logged-in account. - * Obviously, further calls that require authorisation should fail after this - * method is called. The state of the MatrixClient object is not affected: - * it is up to the caller to either reset or destroy the MatrixClient after - * this method succeeds. - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @param erase - Optional. If set, send as `erase` attribute in the - * JSON request body, indicating whether the account should be erased. Defaults - * to false. - * @returns Promise which resolves: On success, the empty object - */ - deactivateAccount(auth, erase) { - const body = {}; - if (auth) { - body.auth = auth; - } - if (erase !== undefined) { - body.erase = erase; - } - return this.http.authedRequest(_httpApi.Method.Post, "/account/deactivate", undefined, body); - } - - /** - * Make a request for an `m.login.token` to be issued as per - * [MSC3882](https://github.com/matrix-org/matrix-spec-proposals/pull/3882). - * The server may require User-Interactive auth. - * Note that this is UNSTABLE and subject to breaking changes without notice. - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @returns Promise which resolves: On success, the token response - * or UIA auth data. - */ - requestLoginToken(auth) { - const body = { - auth - }; - return this.http.authedRequest(_httpApi.Method.Post, "/org.matrix.msc3882/login/token", undefined, - // no query params - body, { - prefix: _httpApi.ClientPrefix.Unstable - }); - } - - /** - * Get the fallback URL to use for unknown interactive-auth stages. - * - * @param loginType - the type of stage being attempted - * @param authSessionId - the auth session ID provided by the homeserver - * - * @returns HS URL to hit to for the fallback interface - */ - getFallbackAuthUrl(loginType, authSessionId) { - const path = utils.encodeUri("/auth/$loginType/fallback/web", { - $loginType: loginType - }); - return this.http.getUrl(path, { - session: authSessionId - }, _httpApi.ClientPrefix.R0).href; - } - - /** - * Create a new room. - * @param options - a list of options to pass to the /createRoom API. - * @returns Promise which resolves: `{room_id: {string}}` - * @returns Rejects: with an error response. - */ - async createRoom(options) { - var _this$identityServer3; - // eslint-disable-line camelcase - // some valid options include: room_alias_name, visibility, invite - - // inject the id_access_token if inviting 3rd party addresses - const invitesNeedingToken = (options.invite_3pid || []).filter(i => !i.id_access_token); - if (invitesNeedingToken.length > 0 && (_this$identityServer3 = this.identityServer) !== null && _this$identityServer3 !== void 0 && _this$identityServer3.getAccessToken && (await this.doesServerAcceptIdentityAccessToken())) { - const identityAccessToken = await this.identityServer.getAccessToken(); - if (identityAccessToken) { - for (const invite of invitesNeedingToken) { - invite.id_access_token = identityAccessToken; - } - } - } - return this.http.authedRequest(_httpApi.Method.Post, "/createRoom", undefined, options); - } - - /** - * Fetches relations for a given event - * @param roomId - the room of the event - * @param eventId - the id of the event - * @param relationType - the rel_type of the relations requested - * @param eventType - the event type of the relations requested - * @param opts - options with optional values for the request. - * @returns the response, with chunk, prev_batch and, next_batch. - */ - fetchRelations(roomId, eventId, relationType, eventType, opts = { - dir: _eventTimeline.Direction.Backward - }) { - let params = opts; - if (_thread.Thread.hasServerSideFwdPaginationSupport === _thread.FeatureSupport.Experimental) { - params = (0, utils.replaceParam)("dir", "org.matrix.msc3715.dir", params); - } - const queryString = utils.encodeParams(params); - let templatedUrl = "/rooms/$roomId/relations/$eventId"; - if (relationType !== null) { - templatedUrl += "/$relationType"; - if (eventType !== null) { - templatedUrl += "/$eventType"; - } - } else if (eventType !== null) { - _logger.logger.warn(`eventType: ${eventType} ignored when fetching - relations as relationType is null`); - eventType = null; - } - const path = utils.encodeUri(templatedUrl + "?" + queryString, { - $roomId: roomId, - $eventId: eventId, - $relationType: relationType, - $eventType: eventType - }); - return this.http.authedRequest(_httpApi.Method.Get, path, undefined, undefined, { - prefix: _httpApi.ClientPrefix.V1 - }); - } - - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - roomState(roomId) { - const path = utils.encodeUri("/rooms/$roomId/state", { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * Get an event in a room by its event id. - * - * @returns Promise which resolves to an object containing the event. - * @returns Rejects: with an error response. - */ - fetchRoomEvent(roomId, eventId) { - const path = utils.encodeUri("/rooms/$roomId/event/$eventId", { - $roomId: roomId, - $eventId: eventId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * @param includeMembership - the membership type to include in the response - * @param excludeMembership - the membership type to exclude from the response - * @param atEventId - the id of the event for which moment in the timeline the members should be returned for - * @returns Promise which resolves: dictionary of userid to profile information - * @returns Rejects: with an error response. - */ - members(roomId, includeMembership, excludeMembership, atEventId) { - const queryParams = {}; - if (includeMembership) { - queryParams.membership = includeMembership; - } - if (excludeMembership) { - queryParams.not_membership = excludeMembership; - } - if (atEventId) { - queryParams.at = atEventId; - } - const queryString = utils.encodeParams(queryParams); - const path = utils.encodeUri("/rooms/$roomId/members?" + queryString, { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * Upgrades a room to a new protocol version - * @param newVersion - The target version to upgrade to - * @returns Promise which resolves: Object with key 'replacement_room' - * @returns Rejects: with an error response. - */ - upgradeRoom(roomId, newVersion) { - // eslint-disable-line camelcase - const path = utils.encodeUri("/rooms/$roomId/upgrade", { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, { - new_version: newVersion - }); - } - - /** - * Retrieve a state event. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - getStateEvent(roomId, eventType, stateKey) { - const pathParams = { - $roomId: roomId, - $eventType: eventType, - $stateKey: stateKey - }; - let path = utils.encodeUri("/rooms/$roomId/state/$eventType", pathParams); - if (stateKey !== undefined) { - path = utils.encodeUri(path + "/$stateKey", pathParams); - } - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * @param opts - Options for the request function. - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - sendStateEvent(roomId, eventType, content, stateKey = "", opts = {}) { - const pathParams = { - $roomId: roomId, - $eventType: eventType, - $stateKey: stateKey - }; - let path = utils.encodeUri("/rooms/$roomId/state/$eventType", pathParams); - if (stateKey !== undefined) { - path = utils.encodeUri(path + "/$stateKey", pathParams); - } - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, content, opts); - } - - /** - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - roomInitialSync(roomId, limit) { - var _limit$toString; - const path = utils.encodeUri("/rooms/$roomId/initialSync", { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Get, path, { - limit: (_limit$toString = limit === null || limit === void 0 ? void 0 : limit.toString()) !== null && _limit$toString !== void 0 ? _limit$toString : "30" - }); - } - - /** - * Set a marker to indicate the point in a room before which the user has read every - * event. This can be retrieved from room account data (the event type is `m.fully_read`) - * and displayed as a horizontal line in the timeline that is visually distinct to the - * position of the user's own read receipt. - * @param roomId - ID of the room that has been read - * @param rmEventId - ID of the event that has been read - * @param rrEventId - ID of the event tracked by the read receipt. This is here - * for convenience because the RR and the RM are commonly updated at the same time as - * each other. Optional. - * @param rpEventId - rpEvent the m.read.private read receipt event for when we - * don't want other users to see the read receipts. This is experimental. Optional. - * @returns Promise which resolves: the empty object, `{}`. - */ - async setRoomReadMarkersHttpRequest(roomId, rmEventId, rrEventId, rpEventId) { - const path = utils.encodeUri("/rooms/$roomId/read_markers", { - $roomId: roomId - }); - const content = { - [_read_receipts.ReceiptType.FullyRead]: rmEventId, - [_read_receipts.ReceiptType.Read]: rrEventId - }; - if ((await this.doesServerSupportUnstableFeature("org.matrix.msc2285.stable")) || (await this.isVersionSupported("v1.4"))) { - content[_read_receipts.ReceiptType.ReadPrivate] = rpEventId; - } - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, content); - } - - /** - * @returns Promise which resolves: A list of the user's current rooms - * @returns Rejects: with an error response. - */ - getJoinedRooms() { - const path = utils.encodeUri("/joined_rooms", {}); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * Retrieve membership info. for a room. - * @param roomId - ID of the room to get membership for - * @returns Promise which resolves: A list of currently joined users - * and their profile data. - * @returns Rejects: with an error response. - */ - getJoinedRoomMembers(roomId) { - const path = utils.encodeUri("/rooms/$roomId/joined_members", { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * @param options - Options for this request - * @param server - The remote server to query for the room list. - * Optional. If unspecified, get the local home - * server's public room list. - * @param limit - Maximum number of entries to return - * @param since - Token to paginate from - * @returns Promise which resolves: IPublicRoomsResponse - * @returns Rejects: with an error response. - */ - publicRooms(_ref2 = {}) { - let { - server, - limit, - since - } = _ref2, - options = (0, _objectWithoutProperties2.default)(_ref2, _excluded); - const queryParams = { - server, - limit, - since - }; - if (Object.keys(options).length === 0) { - return this.http.authedRequest(_httpApi.Method.Get, "/publicRooms", queryParams); - } else { - return this.http.authedRequest(_httpApi.Method.Post, "/publicRooms", queryParams, options); - } - } - - /** - * Create an alias to room ID mapping. - * @param alias - The room alias to create. - * @param roomId - The room ID to link the alias to. - * @returns Promise which resolves: an empty object `{}` - * @returns Rejects: with an error response. - */ - createAlias(alias, roomId) { - const path = utils.encodeUri("/directory/room/$alias", { - $alias: alias - }); - const data = { - room_id: roomId - }; - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, data); - } - - /** - * Delete an alias to room ID mapping. This alias must be on your local server, - * and you must have sufficient access to do this operation. - * @param alias - The room alias to delete. - * @returns Promise which resolves: an empty object `{}`. - * @returns Rejects: with an error response. - */ - deleteAlias(alias) { - const path = utils.encodeUri("/directory/room/$alias", { - $alias: alias - }); - return this.http.authedRequest(_httpApi.Method.Delete, path); - } - - /** - * Gets the local aliases for the room. Note: this includes all local aliases, unlike the - * curated list from the m.room.canonical_alias state event. - * @param roomId - The room ID to get local aliases for. - * @returns Promise which resolves: an object with an `aliases` property, containing an array of local aliases - * @returns Rejects: with an error response. - */ - getLocalAliases(roomId) { - const path = utils.encodeUri("/rooms/$roomId/aliases", { - $roomId: roomId - }); - const prefix = _httpApi.ClientPrefix.V3; - return this.http.authedRequest(_httpApi.Method.Get, path, undefined, undefined, { - prefix - }); - } - - /** - * Get room info for the given alias. - * @param alias - The room alias to resolve. - * @returns Promise which resolves: Object with room_id and servers. - * @returns Rejects: with an error response. - */ - getRoomIdForAlias(alias) { - // eslint-disable-line camelcase - // TODO: deprecate this or resolveRoomAlias - const path = utils.encodeUri("/directory/room/$alias", { - $alias: alias - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * @returns Promise which resolves: Object with room_id and servers. - * @returns Rejects: with an error response. - */ - // eslint-disable-next-line camelcase - resolveRoomAlias(roomAlias) { - // TODO: deprecate this or getRoomIdForAlias - const path = utils.encodeUri("/directory/room/$alias", { - $alias: roomAlias - }); - return this.http.request(_httpApi.Method.Get, path); - } - - /** - * Get the visibility of a room in the current HS's room directory - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - getRoomDirectoryVisibility(roomId) { - const path = utils.encodeUri("/directory/list/room/$roomId", { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * Set the visbility of a room in the current HS's room directory - * @param visibility - "public" to make the room visible - * in the public directory, or "private" to make - * it invisible. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setRoomDirectoryVisibility(roomId, visibility) { - const path = utils.encodeUri("/directory/list/room/$roomId", { - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, { - visibility - }); - } - - /** - * Set the visbility of a room bridged to a 3rd party network in - * the current HS's room directory. - * @param networkId - the network ID of the 3rd party - * instance under which this room is published under. - * @param visibility - "public" to make the room visible - * in the public directory, or "private" to make - * it invisible. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - setRoomDirectoryVisibilityAppService(networkId, roomId, visibility) { - // TODO: Types - const path = utils.encodeUri("/directory/list/appservice/$networkId/$roomId", { - $networkId: networkId, - $roomId: roomId - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, { - visibility: visibility - }); - } - - /** - * Query the user directory with a term matching user IDs, display names and domains. - * @param term - the term with which to search. - * @param limit - the maximum number of results to return. The server will - * apply a limit if unspecified. - * @returns Promise which resolves: an array of results. - */ - searchUserDirectory({ - term, - limit - }) { - const body = { - search_term: term - }; - if (limit !== undefined) { - body.limit = limit; - } - return this.http.authedRequest(_httpApi.Method.Post, "/user_directory/search", undefined, body); - } - - /** - * Upload a file to the media repository on the homeserver. - * - * @param file - The object to upload. On a browser, something that - * can be sent to XMLHttpRequest.send (typically a File). Under node.js, - * a a Buffer, String or ReadStream. - * - * @param opts - options object - * - * @returns Promise which resolves to response object, as - * determined by this.opts.onlyData, opts.rawResponse, and - * opts.onlyContentUri. Rejects with an error (usually a MatrixError). - */ - uploadContent(file, opts) { - return this.http.uploadContent(file, opts); - } - - /** - * Cancel a file upload in progress - * @param upload - The object returned from uploadContent - * @returns true if canceled, otherwise false - */ - cancelUpload(upload) { - return this.http.cancelUpload(upload); - } - - /** - * Get a list of all file uploads in progress - * @returns Array of objects representing current uploads. - * Currently in progress is element 0. Keys: - * - promise: The promise associated with the upload - * - loaded: Number of bytes uploaded - * - total: Total number of bytes to upload - */ - getCurrentUploads() { - return this.http.getCurrentUploads(); - } - - /** - * @param info - The kind of info to retrieve (e.g. 'displayname', - * 'avatar_url'). - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - */ - getProfileInfo(userId, info - // eslint-disable-next-line camelcase - ) { - const path = info ? utils.encodeUri("/profile/$userId/$info", { - $userId: userId, - $info: info - }) : utils.encodeUri("/profile/$userId", { - $userId: userId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * @returns Promise which resolves to a list of the user's threepids. - * @returns Rejects: with an error response. - */ - getThreePids() { - return this.http.authedRequest(_httpApi.Method.Get, "/account/3pid"); - } - - /** - * Add a 3PID to your homeserver account and optionally bind it to an identity - * server as well. An identity server is required as part of the `creds` object. - * - * This API is deprecated, and you should instead use `addThreePidOnly` - * for homeservers that support it. - * - * @returns Promise which resolves: on success - * @returns Rejects: with an error response. - */ - addThreePid(creds, bind) { - // TODO: Types - const path = "/account/3pid"; - const data = { - threePidCreds: creds, - bind: bind - }; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, data); - } - - /** - * Add a 3PID to your homeserver account. This API does not use an identity - * server, as the homeserver is expected to handle 3PID ownership validation. - * - * You can check whether a homeserver supports this API via - * `doesServerSupportSeparateAddAndBind`. - * - * @param data - A object with 3PID validation data from having called - * `account/3pid//requestToken` on the homeserver. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - async addThreePidOnly(data) { - const path = "/account/3pid/add"; - const prefix = (await this.isVersionSupported("r0.6.0")) ? _httpApi.ClientPrefix.R0 : _httpApi.ClientPrefix.Unstable; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, data, { - prefix - }); - } - - /** - * Bind a 3PID for discovery onto an identity server via the homeserver. The - * identity server handles 3PID ownership validation and the homeserver records - * the new binding to track where all 3PIDs for the account are bound. - * - * You can check whether a homeserver supports this API via - * `doesServerSupportSeparateAddAndBind`. - * - * @param data - A object with 3PID validation data from having called - * `validate//requestToken` on the identity server. It should also - * contain `id_server` and `id_access_token` fields as well. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - async bindThreePid(data) { - const path = "/account/3pid/bind"; - const prefix = (await this.isVersionSupported("r0.6.0")) ? _httpApi.ClientPrefix.R0 : _httpApi.ClientPrefix.Unstable; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, data, { - prefix - }); - } - - /** - * Unbind a 3PID for discovery on an identity server via the homeserver. The - * homeserver removes its record of the binding to keep an updated record of - * where all 3PIDs for the account are bound. - * - * @param medium - The threepid medium (eg. 'email') - * @param address - The threepid address (eg. 'bob\@example.com') - * this must be as returned by getThreePids. - * @returns Promise which resolves: on success - * @returns Rejects: with an error response. - */ - async unbindThreePid(medium, address - // eslint-disable-next-line camelcase - ) { - const path = "/account/3pid/unbind"; - const data = { - medium, - address, - id_server: this.getIdentityServerUrl(true) - }; - const prefix = (await this.isVersionSupported("r0.6.0")) ? _httpApi.ClientPrefix.R0 : _httpApi.ClientPrefix.Unstable; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, data, { - prefix - }); - } - - /** - * @param medium - The threepid medium (eg. 'email') - * @param address - The threepid address (eg. 'bob\@example.com') - * this must be as returned by getThreePids. - * @returns Promise which resolves: The server response on success - * (generally the empty JSON object) - * @returns Rejects: with an error response. - */ - deleteThreePid(medium, address - // eslint-disable-next-line camelcase - ) { - const path = "/account/3pid/delete"; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, { - medium, - address - }); - } - - /** - * Make a request to change your password. - * @param newPassword - The new desired password. - * @param logoutDevices - Should all sessions be logged out after the password change. Defaults to true. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setPassword(authDict, newPassword, logoutDevices) { - const path = "/account/password"; - const data = { - auth: authDict, - new_password: newPassword, - logout_devices: logoutDevices - }; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, data); - } - - /** - * Gets all devices recorded for the logged-in user - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - getDevices() { - return this.http.authedRequest(_httpApi.Method.Get, "/devices"); - } - - /** - * Gets specific device details for the logged-in user - * @param deviceId - device to query - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - getDevice(deviceId) { - const path = utils.encodeUri("/devices/$device_id", { - $device_id: deviceId - }); - return this.http.authedRequest(_httpApi.Method.Get, path); - } - - /** - * Update the given device - * - * @param deviceId - device to update - * @param body - body of request - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - // eslint-disable-next-line camelcase - setDeviceDetails(deviceId, body) { - const path = utils.encodeUri("/devices/$device_id", { - $device_id: deviceId - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, body); - } - - /** - * Delete the given device - * - * @param deviceId - device to delete - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - deleteDevice(deviceId, auth) { - const path = utils.encodeUri("/devices/$device_id", { - $device_id: deviceId - }); - const body = {}; - if (auth) { - body.auth = auth; - } - return this.http.authedRequest(_httpApi.Method.Delete, path, undefined, body); - } - - /** - * Delete multiple device - * - * @param devices - IDs of the devices to delete - * @param auth - Optional. Auth data to supply for User-Interactive auth. - * @returns Promise which resolves: result object - * @returns Rejects: with an error response. - */ - deleteMultipleDevices(devices, auth) { - const body = { - devices - }; - if (auth) { - body.auth = auth; - } - const path = "/delete_devices"; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, body); - } - - /** - * Gets all pushers registered for the logged-in user - * - * @returns Promise which resolves: Array of objects representing pushers - * @returns Rejects: with an error response. - */ - async getPushers() { - const response = await this.http.authedRequest(_httpApi.Method.Get, "/pushers"); - - // Migration path for clients that connect to a homeserver that does not support - // MSC3881 yet, see https://github.com/matrix-org/matrix-spec-proposals/blob/kerry/remote-push-toggle/proposals/3881-remote-push-notification-toggling.md#migration - if (!(await this.doesServerSupportUnstableFeature("org.matrix.msc3881"))) { - response.pushers = response.pushers.map(pusher => { - if (!pusher.hasOwnProperty(_event2.PUSHER_ENABLED.name)) { - pusher[_event2.PUSHER_ENABLED.name] = true; - } - return pusher; - }); - } - return response; - } - - /** - * Adds a new pusher or updates an existing pusher - * - * @param pusher - Object representing a pusher - * @returns Promise which resolves: Empty json object on success - * @returns Rejects: with an error response. - */ - setPusher(pusher) { - const path = "/pushers/set"; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, pusher); - } - - /** - * Persists local notification settings - * @returns Promise which resolves: an empty object - * @returns Rejects: with an error response. - */ - setLocalNotificationSettings(deviceId, notificationSettings) { - const key = `${_event2.LOCAL_NOTIFICATION_SETTINGS_PREFIX.name}.${deviceId}`; - return this.setAccountData(key, notificationSettings); - } - - /** - * Get the push rules for the account from the server. - * @returns Promise which resolves to the push rules. - * @returns Rejects: with an error response. - */ - getPushRules() { - return this.http.authedRequest(_httpApi.Method.Get, "/pushrules/").then(rules => { - this.setPushRules(rules); - return this.pushRules; - }); - } - - /** - * Update the push rules for the account. This should be called whenever - * updated push rules are available. - */ - setPushRules(rules) { - // Fix-up defaults, if applicable. - this.pushRules = _pushprocessor.PushProcessor.rewriteDefaultRules(rules, this.getUserId()); - // Pre-calculate any necessary caches. - this.pushProcessor.updateCachedPushRuleKeys(this.pushRules); - } - - /** - * @returns Promise which resolves: an empty object `{}` - * @returns Rejects: with an error response. - */ - addPushRule(scope, kind, ruleId, body) { - // NB. Scope not uri encoded because devices need the '/' - const path = utils.encodeUri("/pushrules/" + scope + "/$kind/$ruleId", { - $kind: kind, - $ruleId: ruleId - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, body); - } - - /** - * @returns Promise which resolves: an empty object `{}` - * @returns Rejects: with an error response. - */ - deletePushRule(scope, kind, ruleId) { - // NB. Scope not uri encoded because devices need the '/' - const path = utils.encodeUri("/pushrules/" + scope + "/$kind/$ruleId", { - $kind: kind, - $ruleId: ruleId - }); - return this.http.authedRequest(_httpApi.Method.Delete, path); - } - - /** - * Enable or disable a push notification rule. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setPushRuleEnabled(scope, kind, ruleId, enabled) { - const path = utils.encodeUri("/pushrules/" + scope + "/$kind/$ruleId/enabled", { - $kind: kind, - $ruleId: ruleId - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, { - enabled: enabled - }); - } - - /** - * Set the actions for a push notification rule. - * @returns Promise which resolves: to an empty object `{}` - * @returns Rejects: with an error response. - */ - setPushRuleActions(scope, kind, ruleId, actions) { - const path = utils.encodeUri("/pushrules/" + scope + "/$kind/$ruleId/actions", { - $kind: kind, - $ruleId: ruleId - }); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, { - actions: actions - }); - } - - /** - * Perform a server-side search. - * @param next_batch - the batch token to pass in the query string - * @param body - the JSON object to pass to the request body. - * @param abortSignal - optional signal used to cancel the http request. - * @returns Promise which resolves to the search response object. - * @returns Rejects: with an error response. - */ - search({ - body, - next_batch: nextBatch - }, abortSignal) { - const queryParams = {}; - if (nextBatch) { - queryParams.next_batch = nextBatch; - } - return this.http.authedRequest(_httpApi.Method.Post, "/search", queryParams, body, { - abortSignal - }); - } - - /** - * Upload keys - * - * @param content - body of upload request - * - * @param opts - this method no longer takes any opts, - * used to take opts.device_id but this was not removed from the spec as a redundant parameter - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - uploadKeysRequest(content, opts) { - return this.http.authedRequest(_httpApi.Method.Post, "/keys/upload", undefined, content); - } - uploadKeySignatures(content) { - return this.http.authedRequest(_httpApi.Method.Post, "/keys/signatures/upload", undefined, content, { - prefix: _httpApi.ClientPrefix.V3 - }); - } - - /** - * Download device keys - * - * @param userIds - list of users to get keys for - * - * @param token - sync token to pass in the query request, to help - * the HS give the most recent results - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - downloadKeysForUsers(userIds, { - token - } = {}) { - const content = { - device_keys: {} - }; - if (token !== undefined) { - content.token = token; - } - userIds.forEach(u => { - content.device_keys[u] = []; - }); - return this.http.authedRequest(_httpApi.Method.Post, "/keys/query", undefined, content); - } - - /** - * Claim one-time keys - * - * @param devices - a list of [userId, deviceId] pairs - * - * @param keyAlgorithm - desired key type - * - * @param timeout - the time (in milliseconds) to wait for keys from remote - * servers - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - claimOneTimeKeys(devices, keyAlgorithm = "signed_curve25519", timeout) { - const queries = {}; - if (keyAlgorithm === undefined) { - keyAlgorithm = "signed_curve25519"; - } - for (const [userId, deviceId] of devices) { - const query = queries[userId] || {}; - queries[userId] = query; - query[deviceId] = keyAlgorithm; - } - const content = { - one_time_keys: queries - }; - if (timeout) { - content.timeout = timeout; - } - const path = "/keys/claim"; - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, content); - } - - /** - * Ask the server for a list of users who have changed their device lists - * between a pair of sync tokens - * - * - * @returns Promise which resolves: result object. Rejects: with - * an error response ({@link MatrixError}). - */ - getKeyChanges(oldToken, newToken) { - const qps = { - from: oldToken, - to: newToken - }; - return this.http.authedRequest(_httpApi.Method.Get, "/keys/changes", qps); - } - uploadDeviceSigningKeys(auth, keys) { - // API returns empty object - const data = Object.assign({}, keys); - if (auth) Object.assign(data, { - auth - }); - return this.http.authedRequest(_httpApi.Method.Post, "/keys/device_signing/upload", undefined, data, { - prefix: _httpApi.ClientPrefix.Unstable - }); - } - - /** - * Register with an identity server using the OpenID token from the user's - * Homeserver, which can be retrieved via - * {@link MatrixClient#getOpenIdToken}. - * - * Note that the `/account/register` endpoint (as well as IS authentication in - * general) was added as part of the v2 API version. - * - * @returns Promise which resolves: with object containing an Identity - * Server access token. - * @returns Rejects: with an error response. - */ - registerWithIdentityServer(hsOpenIdToken) { - if (!this.idBaseUrl) { - throw new Error("No identity server base URL set"); - } - const uri = this.http.getUrl("/account/register", undefined, _httpApi.IdentityPrefix.V2, this.idBaseUrl); - return this.http.requestOtherUrl(_httpApi.Method.Post, uri, hsOpenIdToken); - } - - /** - * Requests an email verification token directly from an identity server. - * - * This API is used as part of binding an email for discovery on an identity - * server. The validation data that results should be passed to the - * `bindThreePid` method to complete the binding process. - * - * @param email - The email address to request a token for - * @param clientSecret - A secret binary string generated by the client. - * It is recommended this be around 16 ASCII characters. - * @param sendAttempt - If an identity server sees a duplicate request - * with the same sendAttempt, it will not send another email. - * To request another email to be sent, use a larger value for - * the sendAttempt param as was used in the previous request. - * @param nextLink - Optional If specified, the client will be redirected - * to this link after validation. - * @param identityAccessToken - The `access_token` field of the identity - * server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: TODO - * @returns Rejects: with an error response. - * @throws Error if no identity server is set - */ - requestEmailToken(email, clientSecret, sendAttempt, nextLink, identityAccessToken) { - const params = { - client_secret: clientSecret, - email: email, - send_attempt: sendAttempt === null || sendAttempt === void 0 ? void 0 : sendAttempt.toString() - }; - if (nextLink) { - params.next_link = nextLink; - } - return this.http.idServerRequest(_httpApi.Method.Post, "/validate/email/requestToken", params, _httpApi.IdentityPrefix.V2, identityAccessToken); - } - - /** - * Requests a MSISDN verification token directly from an identity server. - * - * This API is used as part of binding a MSISDN for discovery on an identity - * server. The validation data that results should be passed to the - * `bindThreePid` method to complete the binding process. - * - * @param phoneCountry - The ISO 3166-1 alpha-2 code for the country in - * which phoneNumber should be parsed relative to. - * @param phoneNumber - The phone number, in national or international - * format - * @param clientSecret - A secret binary string generated by the client. - * It is recommended this be around 16 ASCII characters. - * @param sendAttempt - If an identity server sees a duplicate request - * with the same sendAttempt, it will not send another SMS. - * To request another SMS to be sent, use a larger value for - * the sendAttempt param as was used in the previous request. - * @param nextLink - Optional If specified, the client will be redirected - * to this link after validation. - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves to an object with a sid string - * @returns Rejects: with an error response. - * @throws Error if no identity server is set - */ - requestMsisdnToken(phoneCountry, phoneNumber, clientSecret, sendAttempt, nextLink, identityAccessToken) { - const params = { - client_secret: clientSecret, - country: phoneCountry, - phone_number: phoneNumber, - send_attempt: sendAttempt === null || sendAttempt === void 0 ? void 0 : sendAttempt.toString() - }; - if (nextLink) { - params.next_link = nextLink; - } - return this.http.idServerRequest(_httpApi.Method.Post, "/validate/msisdn/requestToken", params, _httpApi.IdentityPrefix.V2, identityAccessToken); - } - - /** - * Submits a MSISDN token to the identity server - * - * This is used when submitting the code sent by SMS to a phone number. - * The identity server has an equivalent API for email but the js-sdk does - * not expose this, since email is normally validated by the user clicking - * a link rather than entering a code. - * - * @param sid - The sid given in the response to requestToken - * @param clientSecret - A secret binary string generated by the client. - * This must be the same value submitted in the requestToken call. - * @param msisdnToken - The MSISDN token, as enetered by the user. - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: Object, currently with no parameters. - * @returns Rejects: with an error response. - * @throws Error if No identity server is set - */ - submitMsisdnToken(sid, clientSecret, msisdnToken, identityAccessToken) { - // TODO: Types - const params = { - sid: sid, - client_secret: clientSecret, - token: msisdnToken - }; - return this.http.idServerRequest(_httpApi.Method.Post, "/validate/msisdn/submitToken", params, _httpApi.IdentityPrefix.V2, identityAccessToken); - } - - /** - * Submits a MSISDN token to an arbitrary URL. - * - * This is used when submitting the code sent by SMS to a phone number in the - * newer 3PID flow where the homeserver validates 3PID ownership (as part of - * `requestAdd3pidMsisdnToken`). The homeserver response may include a - * `submit_url` to specify where the token should be sent, and this helper can - * be used to pass the token to this URL. - * - * @param url - The URL to submit the token to - * @param sid - The sid given in the response to requestToken - * @param clientSecret - A secret binary string generated by the client. - * This must be the same value submitted in the requestToken call. - * @param msisdnToken - The MSISDN token, as enetered by the user. - * - * @returns Promise which resolves: Object, currently with no parameters. - * @returns Rejects: with an error response. - */ - submitMsisdnTokenOtherUrl(url, sid, clientSecret, msisdnToken) { - // TODO: Types - const params = { - sid: sid, - client_secret: clientSecret, - token: msisdnToken - }; - return this.http.requestOtherUrl(_httpApi.Method.Post, url, params); - } - - /** - * Gets the V2 hashing information from the identity server. Primarily useful for - * lookups. - * @param identityAccessToken - The access token for the identity server. - * @returns The hashing information for the identity server. - */ - getIdentityHashDetails(identityAccessToken) { - // TODO: Types - return this.http.idServerRequest(_httpApi.Method.Get, "/hash_details", undefined, _httpApi.IdentityPrefix.V2, identityAccessToken); - } - - /** - * Performs a hashed lookup of addresses against the identity server. This is - * only supported on identity servers which have at least the version 2 API. - * @param addressPairs - An array of 2 element arrays. - * The first element of each pair is the address, the second is the 3PID medium. - * Eg: `["email@example.org", "email"]` - * @param identityAccessToken - The access token for the identity server. - * @returns A collection of address mappings to - * found MXIDs. Results where no user could be found will not be listed. - */ - async identityHashedLookup(addressPairs, identityAccessToken) { - const params = { - // addresses: ["email@example.org", "10005550000"], - // algorithm: "sha256", - // pepper: "abc123" - }; - - // Get hash information first before trying to do a lookup - const hashes = await this.getIdentityHashDetails(identityAccessToken); - if (!hashes || !hashes["lookup_pepper"] || !hashes["algorithms"]) { - throw new Error("Unsupported identity server: bad response"); - } - params["pepper"] = hashes["lookup_pepper"]; - const localMapping = { - // hashed identifier => plain text address - // For use in this function's return format - }; - - // When picking an algorithm, we pick the hashed over no hashes - if (hashes["algorithms"].includes("sha256")) { - // Abuse the olm hashing - const olmutil = new global.Olm.Utility(); - params["addresses"] = addressPairs.map(p => { - const addr = p[0].toLowerCase(); // lowercase to get consistent hashes - const med = p[1].toLowerCase(); - const hashed = olmutil.sha256(`${addr} ${med} ${params["pepper"]}`).replace(/\+/g, "-").replace(/\//g, "_"); // URL-safe base64 - // Map the hash to a known (case-sensitive) address. We use the case - // sensitive version because the caller might be expecting that. - localMapping[hashed] = p[0]; - return hashed; - }); - params["algorithm"] = "sha256"; - } else if (hashes["algorithms"].includes("none")) { - params["addresses"] = addressPairs.map(p => { - const addr = p[0].toLowerCase(); // lowercase to get consistent hashes - const med = p[1].toLowerCase(); - const unhashed = `${addr} ${med}`; - // Map the unhashed values to a known (case-sensitive) address. We use - // the case-sensitive version because the caller might be expecting that. - localMapping[unhashed] = p[0]; - return unhashed; - }); - params["algorithm"] = "none"; - } else { - throw new Error("Unsupported identity server: unknown hash algorithm"); - } - const response = await this.http.idServerRequest(_httpApi.Method.Post, "/lookup", params, _httpApi.IdentityPrefix.V2, identityAccessToken); - if (!(response !== null && response !== void 0 && response["mappings"])) return []; // no results - - const foundAddresses = []; - for (const hashed of Object.keys(response["mappings"])) { - const mxid = response["mappings"][hashed]; - const plainAddress = localMapping[hashed]; - if (!plainAddress) { - throw new Error("Identity server returned more results than expected"); - } - foundAddresses.push({ - address: plainAddress, - mxid - }); - } - return foundAddresses; - } - - /** - * Looks up the public Matrix ID mapping for a given 3rd party - * identifier from the identity server - * - * @param medium - The medium of the threepid, eg. 'email' - * @param address - The textual address of the threepid - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: A threepid mapping - * object or the empty object if no mapping - * exists - * @returns Rejects: with an error response. - */ - async lookupThreePid(medium, address, identityAccessToken) { - // TODO: Types - // Note: we're using the V2 API by calling this function, but our - // function contract requires a V1 response. We therefore have to - // convert it manually. - const response = await this.identityHashedLookup([[address, medium]], identityAccessToken); - const result = response.find(p => p.address === address); - if (!result) { - return {}; - } - const mapping = { - address, - medium, - mxid: result.mxid - - // We can't reasonably fill these parameters: - // not_before - // not_after - // ts - // signatures - }; - - return mapping; - } - - /** - * Looks up the public Matrix ID mappings for multiple 3PIDs. - * - * @param query - Array of arrays containing - * [medium, address] - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: Lookup results from IS. - * @returns Rejects: with an error response. - */ - async bulkLookupThreePids(query, identityAccessToken) { - // TODO: Types - // Note: we're using the V2 API by calling this function, but our - // function contract requires a V1 response. We therefore have to - // convert it manually. - const response = await this.identityHashedLookup( - // We have to reverse the query order to get [address, medium] pairs - query.map(p => [p[1], p[0]]), identityAccessToken); - const v1results = []; - for (const mapping of response) { - const originalQuery = query.find(p => p[1] === mapping.address); - if (!originalQuery) { - throw new Error("Identity sever returned unexpected results"); - } - v1results.push([originalQuery[0], - // medium - mapping.address, mapping.mxid]); - } - return { - threepids: v1results - }; - } - - /** - * Get account info from the identity server. This is useful as a neutral check - * to verify that other APIs are likely to approve access by testing that the - * token is valid, terms have been agreed, etc. - * - * @param identityAccessToken - The `access_token` field of the Identity - * Server `/account/register` response (see {@link registerWithIdentityServer}). - * - * @returns Promise which resolves: an object with account info. - * @returns Rejects: with an error response. - */ - getIdentityAccount(identityAccessToken) { - // TODO: Types - return this.http.idServerRequest(_httpApi.Method.Get, "/account", undefined, _httpApi.IdentityPrefix.V2, identityAccessToken); - } - - /** - * Send an event to a specific list of devices. - * This is a low-level API that simply wraps the HTTP API - * call to send to-device messages. We recommend using - * queueToDevice() which is a higher level API. - * - * @param eventType - type of event to send - * content to send. Map from user_id to device_id to content object. - * @param txnId - transaction id. One will be made up if not - * supplied. - * @returns Promise which resolves: to an empty object `{}` - */ - sendToDevice(eventType, contentMap, txnId) { - const path = utils.encodeUri("/sendToDevice/$eventType/$txnId", { - $eventType: eventType, - $txnId: txnId ? txnId : this.makeTxnId() - }); - const body = { - messages: utils.recursiveMapToObject(contentMap) - }; - const targets = new Map(); - for (const [userId, deviceMessages] of contentMap) { - targets.set(userId, Array.from(deviceMessages.keys())); - } - _logger.logger.log(`PUT ${path}`, targets); - return this.http.authedRequest(_httpApi.Method.Put, path, undefined, body); - } - - /** - * Sends events directly to specific devices using Matrix's to-device - * messaging system. The batch will be split up into appropriately sized - * batches for sending and stored in the store so they can be retried - * later if they fail to send. Retries will happen automatically. - * @param batch - The to-device messages to send - */ - queueToDevice(batch) { - return this.toDeviceMessageQueue.queueBatch(batch); - } - - /** - * Get the third party protocols that can be reached using - * this HS - * @returns Promise which resolves to the result object - */ - getThirdpartyProtocols() { - return this.http.authedRequest(_httpApi.Method.Get, "/thirdparty/protocols").then(response => { - // sanity check - if (!response || typeof response !== "object") { - throw new Error(`/thirdparty/protocols did not return an object: ${response}`); - } - return response; - }); - } - - /** - * Get information on how a specific place on a third party protocol - * may be reached. - * @param protocol - The protocol given in getThirdpartyProtocols() - * @param params - Protocol-specific parameters, as given in the - * response to getThirdpartyProtocols() - * @returns Promise which resolves to the result object - */ - getThirdpartyLocation(protocol, params) { - const path = utils.encodeUri("/thirdparty/location/$protocol", { - $protocol: protocol - }); - return this.http.authedRequest(_httpApi.Method.Get, path, params); - } - - /** - * Get information on how a specific user on a third party protocol - * may be reached. - * @param protocol - The protocol given in getThirdpartyProtocols() - * @param params - Protocol-specific parameters, as given in the - * response to getThirdpartyProtocols() - * @returns Promise which resolves to the result object - */ - getThirdpartyUser(protocol, params) { - // TODO: Types - const path = utils.encodeUri("/thirdparty/user/$protocol", { - $protocol: protocol - }); - return this.http.authedRequest(_httpApi.Method.Get, path, params); - } - getTerms(serviceType, baseUrl) { - // TODO: Types - const url = this.termsUrlForService(serviceType, baseUrl); - return this.http.requestOtherUrl(_httpApi.Method.Get, url); - } - agreeToTerms(serviceType, baseUrl, accessToken, termsUrls) { - const url = this.termsUrlForService(serviceType, baseUrl); - const headers = { - Authorization: "Bearer " + accessToken - }; - return this.http.requestOtherUrl(_httpApi.Method.Post, url, { - user_accepts: termsUrls - }, { - headers - }); - } - - /** - * Reports an event as inappropriate to the server, which may then notify the appropriate people. - * @param roomId - The room in which the event being reported is located. - * @param eventId - The event to report. - * @param score - The score to rate this content as where -100 is most offensive and 0 is inoffensive. - * @param reason - The reason the content is being reported. May be blank. - * @returns Promise which resolves to an empty object if successful - */ - reportEvent(roomId, eventId, score, reason) { - const path = utils.encodeUri("/rooms/$roomId/report/$eventId", { - $roomId: roomId, - $eventId: eventId - }); - return this.http.authedRequest(_httpApi.Method.Post, path, undefined, { - score, - reason - }); - } - - /** - * Fetches or paginates a room hierarchy as defined by MSC2946. - * Falls back gracefully to sourcing its data from `getSpaceSummary` if this API is not yet supported by the server. - * @param roomId - The ID of the space-room to use as the root of the summary. - * @param limit - The maximum number of rooms to return per page. - * @param maxDepth - The maximum depth in the tree from the root room to return. - * @param suggestedOnly - Whether to only return rooms with suggested=true. - * @param fromToken - The opaque token to paginate a previous request. - * @returns the response, with next_batch & rooms fields. - */ - getRoomHierarchy(roomId, limit, maxDepth, suggestedOnly = false, fromToken) { - const path = utils.encodeUri("/rooms/$roomId/hierarchy", { - $roomId: roomId - }); - const queryParams = { - suggested_only: String(suggestedOnly), - max_depth: maxDepth === null || maxDepth === void 0 ? void 0 : maxDepth.toString(), - from: fromToken, - limit: limit === null || limit === void 0 ? void 0 : limit.toString() - }; - return this.http.authedRequest(_httpApi.Method.Get, path, queryParams, undefined, { - prefix: _httpApi.ClientPrefix.V1 - }).catch(e => { - if (e.errcode === "M_UNRECOGNIZED") { - // fall back to the prefixed hierarchy API. - return this.http.authedRequest(_httpApi.Method.Get, path, queryParams, undefined, { - prefix: "/_matrix/client/unstable/org.matrix.msc2946" - }); - } - throw e; - }); - } - - /** - * Creates a new file tree space with the given name. The client will pick - * defaults for how it expects to be able to support the remaining API offered - * by the returned class. - * - * Note that this is UNSTABLE and may have breaking changes without notice. - * @param name - The name of the tree space. - * @returns Promise which resolves to the created space. - */ - async unstableCreateFileTree(name) { - const { - room_id: roomId - } = await this.createRoom({ - name: name, - preset: _partials.Preset.PrivateChat, - power_level_content_override: _objectSpread(_objectSpread({}, _MSC3089TreeSpace.DEFAULT_TREE_POWER_LEVELS_TEMPLATE), {}, { - users: { - [this.getUserId()]: 100 - } - }), - creation_content: { - [_event2.RoomCreateTypeField]: _event2.RoomType.Space - }, - initial_state: [{ - type: _event2.UNSTABLE_MSC3088_PURPOSE.name, - state_key: _event2.UNSTABLE_MSC3089_TREE_SUBTYPE.name, - content: { - [_event2.UNSTABLE_MSC3088_ENABLED.name]: true - } - }, { - type: _event2.EventType.RoomEncryption, - state_key: "", - content: { - algorithm: olmlib.MEGOLM_ALGORITHM - } - }] - }); - return new _MSC3089TreeSpace.MSC3089TreeSpace(this, roomId); - } - - /** - * Gets a reference to a tree space, if the room ID given is a tree space. If the room - * does not appear to be a tree space then null is returned. - * - * Note that this is UNSTABLE and may have breaking changes without notice. - * @param roomId - The room ID to get a tree space reference for. - * @returns The tree space, or null if not a tree space. - */ - unstableGetFileTreeSpace(roomId) { - var _purposeEvent$getCont, _createEvent$getConte; - const room = this.getRoom(roomId); - if ((room === null || room === void 0 ? void 0 : room.getMyMembership()) !== "join") return null; - const createEvent = room.currentState.getStateEvents(_event2.EventType.RoomCreate, ""); - const purposeEvent = room.currentState.getStateEvents(_event2.UNSTABLE_MSC3088_PURPOSE.name, _event2.UNSTABLE_MSC3089_TREE_SUBTYPE.name); - if (!createEvent) throw new Error("Expected single room create event"); - if (!(purposeEvent !== null && purposeEvent !== void 0 && (_purposeEvent$getCont = purposeEvent.getContent()) !== null && _purposeEvent$getCont !== void 0 && _purposeEvent$getCont[_event2.UNSTABLE_MSC3088_ENABLED.name])) return null; - if (((_createEvent$getConte = createEvent.getContent()) === null || _createEvent$getConte === void 0 ? void 0 : _createEvent$getConte[_event2.RoomCreateTypeField]) !== _event2.RoomType.Space) return null; - return new _MSC3089TreeSpace.MSC3089TreeSpace(this, roomId); - } - - /** - * Perform a single MSC3575 sliding sync request. - * @param req - The request to make. - * @param proxyBaseUrl - The base URL for the sliding sync proxy. - * @param abortSignal - Optional signal to abort request mid-flight. - * @returns The sliding sync response, or a standard error. - * @throws on non 2xx status codes with an object with a field "httpStatus":number. - */ - slidingSync(req, proxyBaseUrl, abortSignal) { - const qps = {}; - if (req.pos) { - qps.pos = req.pos; - delete req.pos; - } - if (req.timeout) { - qps.timeout = req.timeout; - delete req.timeout; - } - const clientTimeout = req.clientTimeout; - delete req.clientTimeout; - return this.http.authedRequest(_httpApi.Method.Post, "/sync", qps, req, { - prefix: "/_matrix/client/unstable/org.matrix.msc3575", - baseUrl: proxyBaseUrl, - localTimeoutMs: clientTimeout, - abortSignal - }); - } - - /** - * @deprecated use supportsThreads() instead - */ - supportsExperimentalThreads() { - var _this$clientOpts7; - _logger.logger.warn(`supportsExperimentalThreads() is deprecated, use supportThreads() instead`); - return ((_this$clientOpts7 = this.clientOpts) === null || _this$clientOpts7 === void 0 ? void 0 : _this$clientOpts7.experimentalThreadSupport) || false; - } - - /** - * A helper to determine thread support - * @returns a boolean to determine if threads are enabled - */ - supportsThreads() { - var _this$clientOpts8; - return ((_this$clientOpts8 = this.clientOpts) === null || _this$clientOpts8 === void 0 ? void 0 : _this$clientOpts8.threadSupport) || false; - } - - /** - * A helper to determine intentional mentions support - * @returns a boolean to determine if intentional mentions are enabled - * @experimental - */ - supportsIntentionalMentions() { - var _this$clientOpts9; - return ((_this$clientOpts9 = this.clientOpts) === null || _this$clientOpts9 === void 0 ? void 0 : _this$clientOpts9.intentionalMentions) || false; - } - - /** - * Fetches the summary of a room as defined by an initial version of MSC3266 and implemented in Synapse - * Proposed at https://github.com/matrix-org/matrix-doc/pull/3266 - * @param roomIdOrAlias - The ID or alias of the room to get the summary of. - * @param via - The list of servers which know about the room if only an ID was provided. - */ - async getRoomSummary(roomIdOrAlias, via) { - const path = utils.encodeUri("/rooms/$roomid/summary", { - $roomid: roomIdOrAlias - }); - return this.http.authedRequest(_httpApi.Method.Get, path, { - via - }, undefined, { - prefix: "/_matrix/client/unstable/im.nheko.summary" - }); - } - - /** - * Processes a list of threaded events and adds them to their respective timelines - * @param room - the room the adds the threaded events - * @param threadedEvents - an array of the threaded events - * @param toStartOfTimeline - the direction in which we want to add the events - */ - processThreadEvents(room, threadedEvents, toStartOfTimeline) { - room.processThreadedEvents(threadedEvents, toStartOfTimeline); - } - - /** - * Processes a list of thread roots and creates a thread model - * @param room - the room to create the threads in - * @param threadedEvents - an array of thread roots - * @param toStartOfTimeline - the direction - */ - processThreadRoots(room, threadedEvents, toStartOfTimeline) { - room.processThreadRoots(threadedEvents, toStartOfTimeline); - } - processBeaconEvents(room, events) { - this.processAggregatedTimelineEvents(room, events); - } - - /** - * Calls aggregation functions for event types that are aggregated - * Polls and location beacons - * @param room - room the events belong to - * @param events - timeline events to be processed - * @returns - */ - processAggregatedTimelineEvents(room, events) { - if (!(events !== null && events !== void 0 && events.length)) return; - if (!room) return; - room.currentState.processBeaconEvents(events, this); - room.processPollEvents(events); - } - - /** - * Fetches information about the user for the configured access token. - */ - async whoami() { - return this.http.authedRequest(_httpApi.Method.Get, "/account/whoami"); - } - - /** - * Find the event_id closest to the given timestamp in the given direction. - * @returns Resolves: A promise of an object containing the event_id and - * origin_server_ts of the closest event to the timestamp in the given direction - * @returns Rejects: when the request fails (module:http-api.MatrixError) - */ - async timestampToEvent(roomId, timestamp, dir) { - const path = utils.encodeUri("/rooms/$roomId/timestamp_to_event", { - $roomId: roomId - }); - const queryParams = { - ts: timestamp.toString(), - dir: dir - }; - try { - return await this.http.authedRequest(_httpApi.Method.Get, path, queryParams, undefined, { - prefix: _httpApi.ClientPrefix.V1 - }); - } catch (err) { - // Fallback to the prefixed unstable endpoint. Since the stable endpoint is - // new, we should also try the unstable endpoint before giving up. We can - // remove this fallback request in a year (remove after 2023-11-28). - if (err.errcode === "M_UNRECOGNIZED" && ( - // XXX: The 400 status code check should be removed in the future - // when Synapse is compliant with MSC3743. - err.httpStatus === 400 || - // This the correct standard status code for an unsupported - // endpoint according to MSC3743. Not Found and Method Not Allowed - // both indicate that this endpoint+verb combination is - // not supported. - err.httpStatus === 404 || err.httpStatus === 405)) { - return await this.http.authedRequest(_httpApi.Method.Get, path, queryParams, undefined, { - prefix: "/_matrix/client/unstable/org.matrix.msc3030" - }); - } - throw err; - } - } -} - -/** - * recalculates an accurate notifications count on event decryption. - * Servers do not have enough knowledge about encrypted events to calculate an - * accurate notification_count - */ -exports.MatrixClient = MatrixClient; -(0, _defineProperty2.default)(MatrixClient, "RESTORE_BACKUP_ERROR_BAD_KEY", "RESTORE_BACKUP_ERROR_BAD_KEY"); -function fixNotificationCountOnDecryption(cli, event) { - var _oldActions$tweaks, _actions$tweaks; - const ourUserId = cli.getUserId(); - const eventId = event.getId(); - const room = cli.getRoom(event.getRoomId()); - if (!room || !ourUserId || !eventId) return; - const oldActions = event.getPushActions(); - const actions = cli.getPushActionsForEvent(event, true); - const isThreadEvent = !!event.threadRootId && !event.isThreadRoot; - const currentHighlightCount = room.getUnreadCountForEventContext(_room.NotificationCountType.Highlight, event); - - // Ensure the unread counts are kept up to date if the event is encrypted - // We also want to make sure that the notification count goes up if we already - // have encrypted events to avoid other code from resetting 'highlight' to zero. - const oldHighlight = !!(oldActions !== null && oldActions !== void 0 && (_oldActions$tweaks = oldActions.tweaks) !== null && _oldActions$tweaks !== void 0 && _oldActions$tweaks.highlight); - const newHighlight = !!(actions !== null && actions !== void 0 && (_actions$tweaks = actions.tweaks) !== null && _actions$tweaks !== void 0 && _actions$tweaks.highlight); - let hasReadEvent; - if (isThreadEvent) { - const thread = room.getThread(event.threadRootId); - hasReadEvent = thread ? thread.hasUserReadEvent(ourUserId, eventId) : - // If the thread object does not exist in the room yet, we don't - // want to calculate notification for this event yet. We have not - // restored the read receipts yet and can't accurately calculate - // notifications at this stage. - // - // This issue can likely go away when MSC3874 is implemented - true; - } else { - hasReadEvent = room.hasUserReadEvent(ourUserId, eventId); - } - if (hasReadEvent) { - // If the event has been read, ignore it. - return; - } - if (oldHighlight !== newHighlight || currentHighlightCount > 0) { - // TODO: Handle mentions received while the client is offline - // See also https://github.com/vector-im/element-web/issues/9069 - let newCount = currentHighlightCount; - if (newHighlight && !oldHighlight) newCount++; - if (!newHighlight && oldHighlight) newCount--; - if (isThreadEvent) { - room.setThreadUnreadNotificationCount(event.threadRootId, _room.NotificationCountType.Highlight, newCount); - } else { - room.setUnreadNotificationCount(_room.NotificationCountType.Highlight, newCount); - } - } - - // Total count is used to typically increment a room notification counter, but not loudly highlight it. - const currentTotalCount = room.getUnreadCountForEventContext(_room.NotificationCountType.Total, event); - - // `notify` is used in practice for incrementing the total count - const newNotify = !!(actions !== null && actions !== void 0 && actions.notify); - - // The room total count is NEVER incremented by the server for encrypted rooms. We basically ignore - // the server here as it's always going to tell us to increment for encrypted events. - if (newNotify) { - if (isThreadEvent) { - room.setThreadUnreadNotificationCount(event.threadRootId, _room.NotificationCountType.Total, currentTotalCount + 1); - } else { - room.setUnreadNotificationCount(_room.NotificationCountType.Total, currentTotalCount + 1); - } - } -} -//# sourceMappingURL=client.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js.map deleted file mode 100644 index aa66fbf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/client.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"client.js","names":["_sync","require","_event","_stub","_call","_filter","_callEventHandler","utils","_interopRequireWildcard","_eventTimeline","_pushprocessor","_autodiscovery","olmlib","_ReEmitter","_RoomList","_logger","_serviceTypes","_httpApi","_crypto","_recoverykey","_key_passphrase","_user","_contentRepo","_searchResult","_dehydration","_api","ContentHelpers","_room","_roomMember","_event2","_partials","_eventMapper","_randomstring","_backup","_MSC3089TreeSpace","_search","_PushRules","_groupCall","_mediaHandler","_groupCallEventHandler","_typedEventEmitter","_read_receipts","_slidingSyncSdk","_thread","_beacon","_NamespacedValue","_ToDeviceMessageQueue","_invitesIgnorer","_feature","_constants","_excluded","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","cache","has","get","newObj","hasPropertyDescriptor","prototype","hasOwnProperty","call","desc","set","SCROLLBACK_DELAY_MS","CRYPTO_ENABLED","isCryptoAvailable","exports","CAPABILITIES_CACHE_MS","TURN_CHECK_INTERVAL","UNSTABLE_MSC3852_LAST_SEEN_UA","UnstableValue","PendingEventOrdering","RoomVersionStability","CrossSigningKeyType","M_AUTHENTICATION","EVENT_ID_PREFIX","ClientEvent","SSO_ACTION_PARAM","MatrixClient","TypedEventEmitter","constructor","opts","_opts$usingExternalCr","TypedReEmitter","Map","PushProcessor","MediaHandler","isInitialSyncComplete","callEventHandler","start","groupCallEventHandler","off","Sync","startCallEventHandler","_this$getRooms","unreadRooms","getRooms","room","getUnreadNotificationCount","NotificationCountType","Total","currentUserId","getSafeUserId","fixupNotifications","fixupRoomNotifications","baseUrl","ensureNoTrailingSlash","idBaseUrl","identityServer","usingExternalCrypto","store","StubStore","deviceId","sessionId","randomString","userId","credentials","http","MatrixHttpApi","fetchFn","accessToken","prefix","ClientPrefix","R0","onlyData","extraParams","queryParams","localTimeoutMs","useAuthorizationHeader","deviceToImport","logger","warn","exportedOlmDeviceToImport","olmDevice","pickleKey","scheduler","setProcessFunction","eventToSend","getRoom","getRoomId","status","EventStatus","SENDING","updatePendingEventStatus","res","sendEventHttpRequest","updatePendingEvent","SENT","event_id","supportsMatrixCall","CallEventHandler","GroupCallEventHandler","canSupportVoip","on","timelineSupport","Boolean","cryptoStore","verificationMethods","cryptoCallbacks","forceTURN","iceCandidatePoolSize","undefined","supportsCallTransfer","fallbackICEServerAllowed","isVoipWithNoMediaAllowed","useE2eForGroupCall","roomList","RoomList","roomNameGenerator","toDeviceMessageQueue","ToDeviceMessageQueue","MatrixEventEvent","Decrypted","event","fixNotificationCountOnDecryption","RoomEvent","Receipt","isRoomEncrypted","roomId","content","getContent","isSelf","eid","value","entries","isSupportedReceiptType","includes","getUserId","maxHistory","events","getLiveTimeline","getEvents","highlightCount","_pushActions$tweaks","hasUserReadEvent","getId","pushActions","getPushActionsForEvent","tweaks","highlight","setUnreadNotificationCount","Highlight","ignoredInvites","IgnoredInvites","startClient","_opts","clientRunning","initialSyncLimit","storeUser","User","checkTurnServersIntervalID","setInterval","checkTurnServers","syncApi","error","stop","getVersions","threads","list","fwdPagination","doesServerSupportThread","Thread","setServerSideSupport","setServerSideListSupport","setServerSideFwdPaginationSupport","e","clientOpts","slidingSync","SlidingSyncSdk","buildSyncApiOptions","SyncApi","threadSupport","experimentalThreadSupport","sync","clientWellKnownPollPeriod","clientWellKnownIntervalID","fetchClientWellKnown","crypto","cryptoBackend","canResetEntireTimeline","canResetTimelineCallback","stopClient","_this$cryptoBackend","_this$syncApi","_this$peekSync","_this$callEventHandle","_this$groupCallEventH","log","peekSync","stopPeeking","global","clearInterval","rehydrateDevice","Error","getDehydrationKey","getDeviceResult","getDehydratedDevice","device_data","device_id","info","account","Olm","Account","deviceData","algorithm","DEHYDRATION_ALGORITHM","k","unpickle","Uint8Array","rehydrateResult","authedRequest","Method","Post","success","pickledAccount","pickle","sessions","free","Get","setDehydrationKey","keyInfo","deviceDisplayName","dehydrationManager","setKeyAndQueueDehydration","createDehydratedDevice","setKey","dehydrateDevice","exportDevice","export","clearStores","promises","deleteAllData","deleteRustSdkStore","indexedDB","dbname","RUST_SDK_STORE_PREFIX","prom","Promise","resolve","reject","req","deleteDatabase","onsuccess","_","onerror","onblocked","all","then","getDomain","replace","getUserIdLocalpart","split","substring","getDeviceId","getSessionId","supportsVoip","getMediaHandler","mediaHandler","setForceTURN","force","setSupportsCallTransfer","support","getUseE2eForGroupCall","createCall","createNewMatrixCall","createGroupCall","type","isPtt","intent","dataChannelsEnabled","dataChannelOptions","getGroupCallForRoom","GroupCall","create","waitUntilRoomReadyForGroupCalls","groupCalls","getSyncState","_this$syncApi$getSync","_this$syncApi2","getSyncStateData","state","SyncState","Prepared","Syncing","isGuest","isGuestAccount","setGuest","guest","getScheduler","retryImmediately","_this$syncApi$retryIm","_this$syncApi3","sendQueue","getNotifTimelineSet","notifTimelineSet","setNotifTimelineSet","getCapabilities","fresh","now","Date","getTime","cachedCapabilities","expiration","capabilities","catch","r","cacheMs","Math","random","initCrypto","startup","init","Crypto","reEmitter","reEmit","CryptoEvent","KeyBackupFailed","KeyBackupSessionsRemaining","RoomKeyRequest","RoomKeyRequestCancellation","Warning","DevicesUpdated","WillUpdateDevices","DeviceVerificationChanged","UserTrustStatusChanged","KeysChanged","exportedOlmDevice","olmVersion","getOlmVersion","registerEventHandlers","uploadDeviceKeys","initRustCrypto","RustCrypto","rustCrypto","RoomMemberEvent","Membership","onRoomMembership","bind","getCrypto","isCryptoEnabled","getDeviceEd25519Key","_this$crypto$getDevic","_this$crypto","getDeviceCurve25519Key","_this$crypto$getDevic2","_this$crypto2","uploadKeys","downloadKeys","userIds","forceDownload","getStoredDevicesForUser","getStoredDevice","setDeviceVerified","verified","setDeviceVerification","checkKeyBackup","setDeviceBlocked","blocked","setDeviceKnown","known","requestVerificationDM","findVerificationRequestDMInProgress","getVerificationRequestsToDeviceInProgress","requestVerification","devices","beginKeyVerification","method","checkSecretStorageKey","setGlobalBlacklistUnverifiedDevices","globalBlacklistUnverifiedDevices","getGlobalBlacklistUnverifiedDevices","setGlobalErrorOnUnknownDevices","globalErrorOnUnknownDevices","getGlobalErrorOnUnknownDevices","getCrossSigningId","CrossSigningKey","Master","getStoredCrossSigningForUser","checkUserTrust","checkDeviceTrust","checkIfOwnDeviceCrossSigned","checkOwnCrossSigningTrust","checkCrossSigningPrivateKey","privateKey","expectedPublicKey","legacyDeviceVerification","prepareToEncrypt","userHasCrossSigningKeys","isCrossSigningReady","bootstrapCrossSigning","getCryptoTrustCrossSignedDevices","setCryptoTrustCrossSignedDevices","val","countSessionsNeedingBackup","getEventEncryptionInfo","createRecoveryKeyFromPassphrase","password","isSecretStorageReady","bootstrapSecretStorage","addSecretStorageKey","keyName","hasSecretStorageKey","keyId","storeSecret","name","secret","getSecret","isSecretStored","requestSecret","getDefaultSecretStorageKeyId","setDefaultSecretStorageKeyId","checkSecretStoragePrivateKey","getEventSenderDeviceInfo","isEventSenderVerified","device","isVerified","getOutgoingRoomKeyRequest","wireContent","getWireContent","requestBody","session_id","sender_key","room_id","cancelAndResendEventRoomKeyRequest","cancelAndResendKeyRequest","setRoomEncryption","config","ev","currentState","getStateEvents","EventType","RoomEncryption","encryptAndSendToDevices","userDeviceInfoArr","payload","forceDiscardSession","exportRoomKeys","importRoomKeys","backupManager","getKeyBackupVersion","V3","errcode","BackupManager","checkBackupVersion","isKeyBackupTrusted","getKeyBackupEnabled","enableKeyBackup","disableKeyBackup","prepareKeyBackupVersion","secureSecretStorage","auth_data","recovery_key","encodeBase64","isKeyBackupKeyStored","createKeyBackupVersion","data","signObject","getCrossSigningKey","crossSigningInfo","deleteKeyBackupVersion","version","path","encodeUri","$version","Delete","makeKeyBackupPath","$roomId","$sessionId","queryData","sendKeyBackup","Put","scheduleAllGroupSessionsForBackup","flagAllGroupSessionsForBackup","isValidRecoveryKey","recoveryKey","decodeRecoveryKey","keyBackupKeyFromPassword","backupInfo","keyFromAuthData","keyBackupKeyFromRecoveryKey","restoreKeyBackupWithPassword","targetRoomId","targetSessionId","privKey","restoreKeyBackup","restoreKeyBackupWithSecretStorage","storedKey","fixedKey","fixBackupKey","getSecretStorageKey","decodeBase64","restoreKeyBackupWithRecoveryKey","restoreKeyBackupWithCache","getSessionBackupPrivateKey","cacheCompleteCallback","progressCallback","totalKeyCount","makeAlgorithm","untrusted","keyMatches","MatrixError","RESTORE_BACKUP_ERROR_BAD_KEY","storeSessionBackupPrivateKey","stage","rooms","roomData","roomKeys","decryptSessions","total","imported","deleteKeysFromBackup","sendSharedHistoryKeys","roomEncryption","getRoomEncryption","deviceInfos","devicesByUser","Array","from","values","alg","getRoomDecryptor","sendSharedHistoryInboundSessions","getMediaConfig","MediaPrefix","getVisibleRooms","msc3946ProcessDynamicPredecessor","allRooms","replacedRooms","Set","_r$findPredecessor","predecessor","findPredecessor","add","tombstone","RoomTombstone","getUser","getUsers","setAccountData","eventType","$userId","$type","retryNetworkOperation","getAccountData","getAccountDataFromServer","_data","deleteAccountData","msc3391DeleteAccountDataServerSupport","canSupport","Feature","AccountDataDeletion","ServerSupport","Unsupported","options","Unstable","getIgnoredUsers","setIgnoredUsers","ignored_users","u","isUserIgnored","joinRoom","roomIdOrAlias","syncRoom","hasMembershipState","signPromise","inviteSignUrl","url","URL","searchParams","requestOtherUrl","queryString","viaServers","signedInviteObj","third_party_signed","$roomid","createRoom","resendEvent","encryptAndSendEvent","cancelPendingEvent","QUEUED","NOT_SENT","ENCRYPTING","pendingEventEncryption","delete","removeEventFromQueue","CANCELLED","setRoomName","sendStateEvent","RoomName","setRoomTopic","topic","htmlTopic","makeTopicContent","RoomTopic","getRoomTags","setRoomTag","tagName","metadata","$tag","deleteRoomTag","setRoomAccountData","setPowerLevel","powerLevel","users","getType","RoomPowerLevels","deepCopy","isArray","user","unstable_createLiveBeacon","beaconInfoContent","unstable_setLiveBeacon","M_BEACON_INFO","sendEvent","threadIdOrEventType","eventTypeOrContent","contentOrTxnId","txnIdOrVoid","_mRelates_to","threadId","txnId","startsWith","rel_type","_mRelates_to2","_this$getRoom","isReply","THREAD_RELATION_TYPE","is_falling_back","thread","getThread","_thread$lastReply$get","_thread$lastReply","lastReply","isRelation","sendCompleteEvent","eventObject","makeTxnId","localEvent","MatrixEvent","assign","user_id","sender","origin_server_ts","setThread","Replaced","VisibilityChange","BeforeRedaction","targetId","getAssociatedId","getPendingEvents","find","once","LocalEventIdReplaced","updateAssociatedId","setTxnId","setStatus","addPendingEvent","cancelled","encryptionPromise","encryptEventIfNeeded","promise","queueEvent","getQueueForEvent","err","stack","isEncrypted","isRedaction","Reaction","encryptEvent","getEncryptedIfNeededEventType","RoomMessageEncrypted","newStatus","getTxnId","pathParams","$eventType","getWireType","$stateKey","getStateKey","$txnId","isState","pathTemplate","$redactsEventId","redacts","redactEvent","eventId","_eventId","_opts2","_opts3","_opts4","_opts5","reason","with_relations","RelationBasedRedactions","withRelations","Stable","MSC3912_RELATION_BASED_REDACTIONS_PROP","stable","unstable","RoomRedaction","sendMessage","RoomMessage","sendContent","sendTextMessage","body","_threadId","makeTextMessage","sendNotice","_threadId2","makeNotice","sendEmoteMessage","_threadId3","makeEmoteMessage","sendImageMessage","text","_threadId4","msgtype","MsgType","Image","sendStickerMessage","_threadId5","Sticker","sendHtmlMessage","htmlBody","_threadId6","makeHtmlMessage","sendHtmlNotice","_threadId7","makeHtmlNotice","sendHtmlEmote","_threadId8","makeHtmlEmote","sendReceipt","receiptType","unthreaded","$receiptType","$eventId","isThread","threadRootId","thread_id","MAIN_ROOM_TIMELINE","addLocalEchoReceipt","sendReadReceipt","ReceiptType","Read","hasPendingEvent","setRoomReadMarkers","rmEventId","rrEvent","rpEvent","rrEventId","rpEventId","ReadPrivate","setRoomReadMarkersHttpRequest","getUrlPreview","ts","floor","parsed","hash","toString","cachedPreview","urlPreviewCache","resp","sendTyping","isTyping","timeoutMs","typing","timeout","getRoomUpgradeHistory","verifyLinks","currentRoom","before","findPredecessorRooms","after","findSuccessorRooms","_room$findPredecessor","ret","predecessorRoomId","_room$findPredecessor2","predecessorRoom","splice","tombstoneEvent","successorRoom","_successorRoom$findPr","roomIds","map","ref","size","slice","invite","membershipChange","inviteByEmail","email","inviteByThreePid","medium","address","_this$identityServer","identityServerUrl","getIdentityServerUrl","params","id_server","getAccessToken","doesServerAcceptIdentityAccessToken","identityAccessToken","leave","leaveRoomChain","includeFuture","upgradeHistory","eligibleToLeave","populationResults","doLeave","ban","forget","deleteRoom","response","removeRoom","emit","DeleteRoom","unban","kick","membership","$room_id","$membership","forceRecalculate","getPushActions","setPushActions","pushProcessor","actionsForEvent","setProfileInfo","$info","setDisplayName","displayname","displayName","UserEvent","DisplayName","presence","setAvatarUrl","avatar_url","avatarUrl","AvatarUrl","mxcUrlToHttp","mxcUrl","width","height","resizeMethod","allowDirectLinks","getHttpUriForMxc","setPresence","validStates","indexOf","getPresence","scrollback","limit","timeToWaitMs","ongoingScrollbacks","errorTs","timeWaitedMs","max","oldState","paginationToken","numAdded","sleep","createMessagesRequest","Direction","Backward","_res$end","_res$end2","matrixEvents","chunk","getEventMapper","stateEvents","setUnknownStateEvents","timelineEvents","threadedEvents","partitionThreadedEvents","processAggregatedTimelineEvents","addEventsToTimeline","processThreadEvents","end","storeEvents","eventMapperFor","getEventTimeline","timelineSet","_this$clientOpts","_ref","_timelineSet$getTimel","_timelineSet$room$fin","getTimelineForEvent","supportsThreads","getThreadTimeline","lazyLoadMembers","JSON","stringify","Filter","LAZY_LOADING_MESSAGES_FILTER","mapper","events_after","reverse","events_before","timeline","getState","EventTimeline","BACKWARDS","addTimeline","initialiseState","FORWARDS","findThreadForEvent","liveTimeline","_this$clientOpts2","canContain","hasServerSideSupport","hasServerSideFwdPaginationSupport","_resOlder$next_batch","_resNewer$next_batch","_timelineSet$getTimel2","resOlder","fetchRelations","id","dir","resNewer","Forward","_timelineSet$thread","processEvent","next_batch","originalEvent","fetchRoomEvent","setPaginationToken","_resOlder$next_batch2","eventsNewer","nextBatch","_resNewer$next_batch2","_timelineSet$thread2","getLatestTimeline","threadListType","_res$chunk","createThreadListMessagesRequest","getFilter","_res$chunk2","_this$clientOpts3","_res$chunk3","messagesPath","fromToken","timelineFilter","_this$clientOpts4","_timelineFilter$getRo","getRoomTimelineFilterComponent","toJSON","ThreadFilterType","All","_this$clientOpts5","include","threadFilterTypeToFilter","_timelineFilter$getRo2","hasServerSideListSupport","FeatureSupport","_res$chunk4","prev_batch","paginateEventTimeline","eventTimeline","isNotifTimeline","getTimelineSet","backwards","token","getPaginationToken","pendingRequest","paginationRequests","_opts$limit","only","next_token","notifications","noUnsafeEventProps","notification","actionListToActionsObject","actions","finally","roomState","processThreadRoots","_eventTimeline$getRoo","_eventTimeline$getRoo2","getSender","getEventReadUpTo","newToken","_eventTimeline$getRoo3","it","getServerAggregatedRelation","atEnd","resetNotifTimelineSet","resetLiveTimeline","peekInRoom","_this$peekSync2","peek","setGuestAccess","writePromise","RoomGuestAccess","guest_access","allowJoin","readPromise","allowRead","RoomHistoryVisibility","history_visibility","requestRegisterEmailToken","clientSecret","sendAttempt","nextLink","requestTokenFromEndpoint","client_secret","send_attempt","next_link","requestRegisterMsisdnToken","phoneCountry","phoneNumber","country","phone_number","requestAdd3pidEmailToken","requestAdd3pidMsisdnToken","requestPasswordEmailToken","requestPasswordMsisdnToken","endpoint","postParams","doesServerSupportSeparateAddAndBind","_this$identityServer2","idServerUrl","host","id_access_token","request","getRoomPushRule","scope","pushRules","_this$pushRules$scope","_this$pushRules$scope2","rule","rule_id","setRoomMutePushRule","mute","hasDontNotifyRule","roomPushRule","PushRuleActionName","DontNotify","deletePushRule","PushRuleKind","RoomSpecific","addPushRule","deferred","defer","getPushRules","result","err2","searchMessageText","roomEvents","search_term","query","search","search_categories","room_events","searchRoomEvents","term","order_by","SearchOrderBy","Recent","event_context","before_limit","after_limit","include_profile","searchResults","_query","results","highlights","processRoomEventsSearch","backPaginateRoomEventsSearch","searchOpts","abortSignal","_roomEvents$results$l","_roomEvents$results","count","hl","resultsLength","sr","SearchResult","fromJson","context","getEvent","getTimeline","getMember","syncLeftRooms","syncedLeftRooms","syncLeftRoomsPromise","createFilter","filter_id","storeFilter","filterId","allowCached","$filterId","getOrCreateFilter","filterName","getFilterIdByName","existingId","existingFilter","oldDef","getDefinition","newDef","deepCompare","setFilterIdByName","createdFilter","getOpenIdToken","turnServer","getTurnServers","turnServers","getTurnServersExpiry","turnServersExpiry","pollingTurnServers","credentialsGood","remainingTime","debug","uris","ttl","servers","urls","username","credential","TurnServers","httpStatus","TurnServersError","setFallbackICEServerAllowed","allow","isFallbackICEServerAllowed","isSynapseAdministrator","admin","whoisSynapseUser","deactivateSynapseUser","_this$getDomain","clientWellKnownPromise","AutoDiscovery","getRawClientConfig","clientWellKnown","ClientWellKnown","getClientWellKnown","waitForClientWellKnown","storeClientOptions","primTypes","serializableOpts","reduce","_unstable_getSharedRooms","sharedRoomsSupport","doesServerSupportUnstableFeature","mutualRoomsSupport","joined","serverVersionsPromise","serverVersions","buildFeatureSupportMap","isVersionSupported","versions","doesServerSupportLazyLoading","unstableFeatures","doesServerRequireIdServerParam","feature","doesServerForceEncryptionForPreset","presetName","versionsPresetName","threadUnstable","threadStable","listUnstable","listStable","fwdPaginationUnstable","fwdPaginationStable","determineFeatureSupport","None","doesServerSupportLogoutDevices","hasLazyLoadMembersEnabled","_this$clientOpts6","setCanResetTimelineCallback","cb","getCanResetTimelineCallback","relations","relationType","_result$next_batch","_result$prev_batch","fetchedEventType","eventResult","allEvents","concat","decryptEventIfNeeded","RelationType","Replace","prevBatch","getCrossSigningCacheCallbacks","_this$crypto3","getCacheCallbacks","generateClientSecret","shouldAttemptDecryption","attemptDecryption","isBeingDecrypted","getDecryptionPromise","termsUrlForService","serviceType","SERVICE_TYPES","IS","getUrl","IdentityPrefix","V2","IM","getHomeserverUrl","stripProto","_this$idBaseUrl","_this$idBaseUrl2","setIdentityServerUrl","setIdBaseUrl","setAccessToken","isLoggedIn","txnCtr","isUsernameAvailable","available","register","auth","bindThreepids","guestAccessToken","inhibitLogin","session","refresh_token","bind_email","msisdn","bind_msisdn","guest_access_token","inhibit_login","x_show_msisdn","registerRequest","registerGuest","kind","refreshToken","V1","inhibitLogoutEmit","loginFlows","login","loginType","loginData","access_token","loginWithPassword","loginWithSAML2","relayState","relay_state","getCasLoginUrl","redirectUrl","getSsoLoginUrl","idpId","action","href","loginWithToken","logout","_this$crypto4","_this$crypto4$backupM","backupPendingKeys","abort","deactivateAccount","erase","requestLoginToken","getFallbackAuthUrl","authSessionId","$loginType","_this$identityServer3","invitesNeedingToken","invite_3pid","Experimental","replaceParam","encodeParams","templatedUrl","$relationType","members","includeMembership","excludeMembership","atEventId","not_membership","at","upgradeRoom","newVersion","new_version","getStateEvent","stateKey","roomInitialSync","_limit$toString","FullyRead","getJoinedRooms","getJoinedRoomMembers","publicRooms","_ref2","server","since","_objectWithoutProperties2","createAlias","alias","$alias","deleteAlias","getLocalAliases","getRoomIdForAlias","resolveRoomAlias","roomAlias","getRoomDirectoryVisibility","setRoomDirectoryVisibility","visibility","setRoomDirectoryVisibilityAppService","networkId","$networkId","searchUserDirectory","uploadContent","file","cancelUpload","upload","getCurrentUploads","getProfileInfo","getThreePids","addThreePid","creds","threePidCreds","addThreePidOnly","bindThreePid","unbindThreePid","deleteThreePid","setPassword","authDict","newPassword","logoutDevices","new_password","logout_devices","getDevices","getDevice","$device_id","setDeviceDetails","deleteDevice","deleteMultipleDevices","getPushers","pushers","pusher","PUSHER_ENABLED","setPusher","setLocalNotificationSettings","notificationSettings","LOCAL_NOTIFICATION_SETTINGS_PREFIX","rules","setPushRules","rewriteDefaultRules","updateCachedPushRuleKeys","ruleId","$kind","$ruleId","setPushRuleEnabled","enabled","setPushRuleActions","uploadKeysRequest","uploadKeySignatures","downloadKeysForUsers","device_keys","claimOneTimeKeys","keyAlgorithm","queries","one_time_keys","getKeyChanges","oldToken","qps","to","uploadDeviceSigningKeys","registerWithIdentityServer","hsOpenIdToken","uri","requestEmailToken","idServerRequest","requestMsisdnToken","submitMsisdnToken","sid","msisdnToken","submitMsisdnTokenOtherUrl","getIdentityHashDetails","identityHashedLookup","addressPairs","hashes","localMapping","olmutil","Utility","p","addr","toLowerCase","med","hashed","sha256","unhashed","foundAddresses","mxid","plainAddress","lookupThreePid","mapping","bulkLookupThreePids","v1results","originalQuery","threepids","getIdentityAccount","sendToDevice","contentMap","messages","recursiveMapToObject","targets","deviceMessages","queueToDevice","batch","queueBatch","getThirdpartyProtocols","getThirdpartyLocation","protocol","$protocol","getThirdpartyUser","getTerms","agreeToTerms","termsUrls","headers","Authorization","user_accepts","reportEvent","score","getRoomHierarchy","maxDepth","suggestedOnly","suggested_only","String","max_depth","unstableCreateFileTree","preset","Preset","PrivateChat","power_level_content_override","DEFAULT_TREE_POWER_LEVELS_TEMPLATE","creation_content","RoomCreateTypeField","RoomType","Space","initial_state","UNSTABLE_MSC3088_PURPOSE","state_key","UNSTABLE_MSC3089_TREE_SUBTYPE","UNSTABLE_MSC3088_ENABLED","MEGOLM_ALGORITHM","MSC3089TreeSpace","unstableGetFileTreeSpace","_purposeEvent$getCont","_createEvent$getConte","getMyMembership","createEvent","RoomCreate","purposeEvent","proxyBaseUrl","pos","clientTimeout","supportsExperimentalThreads","_this$clientOpts7","_this$clientOpts8","supportsIntentionalMentions","_this$clientOpts9","intentionalMentions","getRoomSummary","via","toStartOfTimeline","processThreadedEvents","processBeaconEvents","processPollEvents","whoami","timestampToEvent","timestamp","cli","_oldActions$tweaks","_actions$tweaks","ourUserId","oldActions","isThreadEvent","isThreadRoot","currentHighlightCount","getUnreadCountForEventContext","oldHighlight","newHighlight","hasReadEvent","newCount","setThreadUnreadNotificationCount","currentTotalCount","newNotify","notify"],"sources":["../src/client.ts"],"sourcesContent":["/*\nCopyright 2015-2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module. See {@link MatrixClient} for the public class.\n */\n\nimport { Optional } from \"matrix-events-sdk\";\n\nimport type { IDeviceKeys, IMegolmSessionData, IOneTimeKey } from \"./@types/crypto\";\nimport { ISyncStateData, SyncApi, SyncApiOptions, SyncState } from \"./sync\";\nimport {\n EventStatus,\n IContent,\n IDecryptOptions,\n IEvent,\n MatrixEvent,\n MatrixEventEvent,\n MatrixEventHandlerMap,\n} from \"./models/event\";\nimport { StubStore } from \"./store/stub\";\nimport { CallEvent, CallEventHandlerMap, createNewMatrixCall, MatrixCall, supportsMatrixCall } from \"./webrtc/call\";\nimport { Filter, IFilterDefinition, IRoomEventFilter } from \"./filter\";\nimport { CallEventHandlerEvent, CallEventHandler, CallEventHandlerEventHandlerMap } from \"./webrtc/callEventHandler\";\nimport { GroupCallEventHandlerEvent, GroupCallEventHandlerEventHandlerMap } from \"./webrtc/groupCallEventHandler\";\nimport * as utils from \"./utils\";\nimport { replaceParam, QueryDict, sleep, noUnsafeEventProps } from \"./utils\";\nimport { Direction, EventTimeline } from \"./models/event-timeline\";\nimport { IActionsObject, PushProcessor } from \"./pushprocessor\";\nimport { AutoDiscovery, AutoDiscoveryAction } from \"./autodiscovery\";\nimport * as olmlib from \"./crypto/olmlib\";\nimport { decodeBase64, encodeBase64 } from \"./crypto/olmlib\";\nimport { IExportedDevice as IExportedOlmDevice } from \"./crypto/OlmDevice\";\nimport { IOlmDevice } from \"./crypto/algorithms/megolm\";\nimport { TypedReEmitter } from \"./ReEmitter\";\nimport { IRoomEncryption, RoomList } from \"./crypto/RoomList\";\nimport { logger } from \"./logger\";\nimport { SERVICE_TYPES } from \"./service-types\";\nimport {\n HttpApiEvent,\n HttpApiEventHandlerMap,\n Upload,\n UploadOpts,\n MatrixError,\n MatrixHttpApi,\n Method,\n retryNetworkOperation,\n ClientPrefix,\n MediaPrefix,\n IdentityPrefix,\n IHttpOpts,\n FileType,\n UploadResponse,\n HTTPError,\n IRequestOpts,\n} from \"./http-api\";\nimport {\n Crypto,\n CryptoEvent,\n CryptoEventHandlerMap,\n fixBackupKey,\n ICryptoCallbacks,\n IBootstrapCrossSigningOpts,\n ICheckOwnCrossSigningTrustOpts,\n isCryptoAvailable,\n VerificationMethod,\n IRoomKeyRequestBody,\n} from \"./crypto\";\nimport { DeviceInfo } from \"./crypto/deviceinfo\";\nimport { decodeRecoveryKey } from \"./crypto/recoverykey\";\nimport { keyFromAuthData } from \"./crypto/key_passphrase\";\nimport { User, UserEvent, UserEventHandlerMap } from \"./models/user\";\nimport { getHttpUriForMxc } from \"./content-repo\";\nimport { SearchResult } from \"./models/search-result\";\nimport { DEHYDRATION_ALGORITHM, IDehydratedDevice, IDehydratedDeviceKeyInfo } from \"./crypto/dehydration\";\nimport {\n IKeyBackupInfo,\n IKeyBackupPrepareOpts,\n IKeyBackupRestoreOpts,\n IKeyBackupRestoreResult,\n IKeyBackupRoomSessions,\n IKeyBackupSession,\n} from \"./crypto/keybackup\";\nimport { IIdentityServerProvider } from \"./@types/IIdentityServerProvider\";\nimport { MatrixScheduler } from \"./scheduler\";\nimport { BeaconEvent, BeaconEventHandlerMap } from \"./models/beacon\";\nimport { IAuthData, IAuthDict } from \"./interactive-auth\";\nimport { IMinimalEvent, IRoomEvent, IStateEvent } from \"./sync-accumulator\";\nimport {\n CrossSigningKey,\n IAddSecretStorageKeyOpts,\n ICreateSecretStorageOpts,\n IEncryptedEventInfo,\n IImportRoomKeysOpts,\n IRecoveryKey,\n} from \"./crypto/api\";\nimport { EventTimelineSet } from \"./models/event-timeline-set\";\nimport { VerificationRequest } from \"./crypto/verification/request/VerificationRequest\";\nimport { VerificationBase as Verification } from \"./crypto/verification/Base\";\nimport * as ContentHelpers from \"./content-helpers\";\nimport { CrossSigningInfo, DeviceTrustLevel, ICacheCallbacks, UserTrustLevel } from \"./crypto/CrossSigning\";\nimport { Room, NotificationCountType, RoomEvent, RoomEventHandlerMap, RoomNameState } from \"./models/room\";\nimport { RoomMemberEvent, RoomMemberEventHandlerMap } from \"./models/room-member\";\nimport { RoomStateEvent, RoomStateEventHandlerMap } from \"./models/room-state\";\nimport {\n IAddThreePidOnlyBody,\n IBindThreePidBody,\n IContextResponse,\n ICreateRoomOpts,\n IEventSearchOpts,\n IGuestAccessOpts,\n IJoinRoomOpts,\n IPaginateOpts,\n IPresenceOpts,\n IRedactOpts,\n IRelationsRequestOpts,\n IRelationsResponse,\n IRoomDirectoryOptions,\n ISearchOpts,\n ISendEventResponse,\n INotificationsResponse,\n IFilterResponse,\n ITagsResponse,\n IStatusResponse,\n} from \"./@types/requests\";\nimport {\n EventType,\n LOCAL_NOTIFICATION_SETTINGS_PREFIX,\n MsgType,\n PUSHER_ENABLED,\n RelationType,\n RoomCreateTypeField,\n RoomType,\n UNSTABLE_MSC3088_ENABLED,\n UNSTABLE_MSC3088_PURPOSE,\n UNSTABLE_MSC3089_TREE_SUBTYPE,\n MSC3912_RELATION_BASED_REDACTIONS_PROP,\n} from \"./@types/event\";\nimport { IdServerUnbindResult, IImageInfo, Preset, Visibility } from \"./@types/partials\";\nimport { EventMapper, eventMapperFor, MapperOpts } from \"./event-mapper\";\nimport { randomString } from \"./randomstring\";\nimport { BackupManager, IKeyBackup, IKeyBackupCheck, IPreparedKeyBackupVersion, TrustInfo } from \"./crypto/backup\";\nimport { DEFAULT_TREE_POWER_LEVELS_TEMPLATE, MSC3089TreeSpace } from \"./models/MSC3089TreeSpace\";\nimport { ISignatures } from \"./@types/signed\";\nimport { IStore } from \"./store\";\nimport { ISecretRequest } from \"./crypto/SecretStorage\";\nimport {\n IEventWithRoomId,\n ISearchRequestBody,\n ISearchResponse,\n ISearchResults,\n IStateEventWithRoomId,\n SearchOrderBy,\n} from \"./@types/search\";\nimport { ISynapseAdminDeactivateResponse, ISynapseAdminWhoisResponse } from \"./@types/synapse\";\nimport { IHierarchyRoom } from \"./@types/spaces\";\nimport {\n IPusher,\n IPusherRequest,\n IPushRule,\n IPushRules,\n PushRuleAction,\n PushRuleActionName,\n PushRuleKind,\n RuleId,\n} from \"./@types/PushRules\";\nimport { IThreepid } from \"./@types/threepids\";\nimport { CryptoStore, OutgoingRoomKeyRequest } from \"./crypto/store/base\";\nimport { GroupCall, IGroupCallDataChannelOptions, GroupCallIntent, GroupCallType } from \"./webrtc/groupCall\";\nimport { MediaHandler } from \"./webrtc/mediaHandler\";\nimport { GroupCallEventHandler } from \"./webrtc/groupCallEventHandler\";\nimport { LoginTokenPostResponse, ILoginFlowsResponse, IRefreshTokenResponse, SSOAction } from \"./@types/auth\";\nimport { TypedEventEmitter } from \"./models/typed-event-emitter\";\nimport { MAIN_ROOM_TIMELINE, ReceiptType } from \"./@types/read_receipts\";\nimport { MSC3575SlidingSyncRequest, MSC3575SlidingSyncResponse, SlidingSync } from \"./sliding-sync\";\nimport { SlidingSyncSdk } from \"./sliding-sync-sdk\";\nimport {\n FeatureSupport,\n Thread,\n THREAD_RELATION_TYPE,\n determineFeatureSupport,\n ThreadFilterType,\n threadFilterTypeToFilter,\n} from \"./models/thread\";\nimport { MBeaconInfoEventContent, M_BEACON_INFO } from \"./@types/beacon\";\nimport { UnstableValue } from \"./NamespacedValue\";\nimport { ToDeviceMessageQueue } from \"./ToDeviceMessageQueue\";\nimport { ToDeviceBatch } from \"./models/ToDeviceMessage\";\nimport { IgnoredInvites } from \"./models/invites-ignorer\";\nimport { UIARequest, UIAResponse } from \"./@types/uia\";\nimport { LocalNotificationSettings } from \"./@types/local_notifications\";\nimport { buildFeatureSupportMap, Feature, ServerSupport } from \"./feature\";\nimport { CryptoBackend } from \"./common-crypto/CryptoBackend\";\nimport { RUST_SDK_STORE_PREFIX } from \"./rust-crypto/constants\";\nimport { CryptoApi } from \"./crypto-api\";\nimport { DeviceInfoMap } from \"./crypto/DeviceList\";\nimport { SecretStorageKeyDescription } from \"./secret-storage\";\n\nexport type Store = IStore;\n\nexport type ResetTimelineCallback = (roomId: string) => boolean;\n\nconst SCROLLBACK_DELAY_MS = 3000;\nexport const CRYPTO_ENABLED: boolean = isCryptoAvailable();\nconst CAPABILITIES_CACHE_MS = 21600000; // 6 hours - an arbitrary value\nconst TURN_CHECK_INTERVAL = 10 * 60 * 1000; // poll for turn credentials every 10 minutes\n\nexport const UNSTABLE_MSC3852_LAST_SEEN_UA = new UnstableValue(\n \"last_seen_user_agent\",\n \"org.matrix.msc3852.last_seen_user_agent\",\n);\n\ninterface IExportedDevice {\n olmDevice: IExportedOlmDevice;\n userId: string;\n deviceId: string;\n}\n\nexport interface IKeysUploadResponse {\n one_time_key_counts: {\n // eslint-disable-line camelcase\n [algorithm: string]: number;\n };\n}\n\nexport interface ICreateClientOpts {\n baseUrl: string;\n\n idBaseUrl?: string;\n\n /**\n * The data store used for sync data from the homeserver. If not specified,\n * this client will not store any HTTP responses. The `createClient` helper\n * will create a default store if needed.\n */\n store?: Store;\n\n /**\n * A store to be used for end-to-end crypto session data. If not specified,\n * end-to-end crypto will be disabled. The `createClient` helper will create\n * a default store if needed. Calls the factory supplied to\n * {@link setCryptoStoreFactory} if unspecified; or if no factory has been\n * specified, uses a default implementation (indexeddb in the browser,\n * in-memory otherwise).\n */\n cryptoStore?: CryptoStore;\n\n /**\n * The scheduler to use. If not\n * specified, this client will not retry requests on failure. This client\n * will supply its own processing function to\n * {@link MatrixScheduler#setProcessFunction}.\n */\n scheduler?: MatrixScheduler;\n\n /**\n * The function to invoke for HTTP requests.\n * Most supported environments have a global `fetch` registered to which this will fall back.\n */\n fetchFn?: typeof global.fetch;\n\n userId?: string;\n\n /**\n * A unique identifier for this device; used for tracking things like crypto\n * keys and access tokens. If not specified, end-to-end encryption will be\n * disabled.\n */\n deviceId?: string;\n\n accessToken?: string;\n\n /**\n * Identity server provider to retrieve the user's access token when accessing\n * the identity server. See also https://github.com/vector-im/element-web/issues/10615\n * which seeks to replace the previous approach of manual access tokens params\n * with this callback throughout the SDK.\n */\n identityServer?: IIdentityServerProvider;\n\n /**\n * The default maximum amount of\n * time to wait before timing out HTTP requests. If not specified, there is no timeout.\n */\n localTimeoutMs?: number;\n\n /**\n * Set to true to use\n * Authorization header instead of query param to send the access token to the server.\n *\n * Default false.\n */\n useAuthorizationHeader?: boolean;\n\n /**\n * Set to true to enable\n * improved timeline support, see {@link MatrixClient#getEventTimeline}.\n * It is disabled by default for compatibility with older clients - in particular to\n * maintain support for back-paginating the live timeline after a '/sync'\n * result with a gap.\n */\n timelineSupport?: boolean;\n\n /**\n * Extra query parameters to append\n * to all requests with this client. Useful for application services which require\n * `?user_id=`.\n */\n queryParams?: Record;\n\n /**\n * Device data exported with\n * \"exportDevice\" method that must be imported to recreate this device.\n * Should only be useful for devices with end-to-end crypto enabled.\n * If provided, deviceId and userId should **NOT** be provided at the top\n * level (they are present in the exported data).\n */\n deviceToImport?: IExportedDevice;\n\n /**\n * Key used to pickle olm objects or other sensitive data.\n */\n pickleKey?: string;\n\n verificationMethods?: Array;\n\n /**\n * Whether relaying calls through a TURN server should be forced. Default false.\n */\n forceTURN?: boolean;\n\n /**\n * Up to this many ICE candidates will be gathered when an incoming call arrives.\n * Gathering does not send data to the caller, but will communicate with the configured TURN\n * server. Default 0.\n */\n iceCandidatePoolSize?: number;\n\n /**\n * True to advertise support for call transfers to other parties on Matrix calls. Default false.\n */\n supportsCallTransfer?: boolean;\n\n /**\n * Whether to allow a fallback ICE server should be used for negotiating a\n * WebRTC connection if the homeserver doesn't provide any servers. Defaults to false.\n */\n fallbackICEServerAllowed?: boolean;\n\n /**\n * If true, to-device signalling for group calls will be encrypted\n * with Olm. Default: true.\n */\n useE2eForGroupCall?: boolean;\n\n cryptoCallbacks?: ICryptoCallbacks;\n\n /**\n * Method to generate room names for empty rooms and rooms names based on membership.\n * Defaults to a built-in English handler with basic pluralisation.\n */\n roomNameGenerator?: (roomId: string, state: RoomNameState) => string | null;\n\n /**\n * If true, participant can join group call without video and audio this has to be allowed. By default, a local\n * media stream is needed to establish a group call.\n * Default: false.\n */\n isVoipWithNoMediaAllowed?: boolean;\n}\n\nexport interface IMatrixClientCreateOpts extends ICreateClientOpts {\n /**\n * Whether to allow sending messages to encrypted rooms when encryption\n * is not available internally within this SDK. This is useful if you are using an external\n * E2E proxy, for example. Defaults to false.\n */\n usingExternalCrypto?: boolean;\n}\n\nexport enum PendingEventOrdering {\n Chronological = \"chronological\",\n Detached = \"detached\",\n}\n\nexport interface IStartClientOpts {\n /**\n * The event `limit=` to apply to initial sync. Default: 8.\n */\n initialSyncLimit?: number;\n\n /**\n * True to put `archived=true on the /initialSync` request. Default: false.\n */\n includeArchivedRooms?: boolean;\n\n /**\n * True to do /profile requests on every invite event if the displayname/avatar_url is not known for this user ID. Default: false.\n */\n resolveInvitesToProfiles?: boolean;\n\n /**\n * Controls where pending messages appear in a room's timeline. If \"chronological\", messages will\n * appear in the timeline when the call to `sendEvent` was made. If \"detached\",\n * pending messages will appear in a separate list, accessbile via {@link Room#getPendingEvents}.\n * Default: \"chronological\".\n */\n pendingEventOrdering?: PendingEventOrdering;\n\n /**\n * The number of milliseconds to wait on /sync. Default: 30000 (30 seconds).\n */\n pollTimeout?: number;\n\n /**\n * The filter to apply to /sync calls.\n */\n filter?: Filter;\n\n /**\n * True to perform syncing without automatically updating presence.\n */\n disablePresence?: boolean;\n\n /**\n * True to not load all membership events during initial sync but fetch them when needed by calling\n * `loadOutOfBandMembers` This will override the filter option at this moment.\n */\n lazyLoadMembers?: boolean;\n\n /**\n * The number of seconds between polls to /.well-known/matrix/client, undefined to disable.\n * This should be in the order of hours. Default: undefined.\n */\n clientWellKnownPollPeriod?: number;\n\n /**\n * @deprecated use `threadSupport` instead\n */\n experimentalThreadSupport?: boolean;\n\n /**\n * Will organises events in threaded conversations when\n * a thread relation is encountered\n */\n threadSupport?: boolean;\n\n /**\n * @experimental\n */\n slidingSync?: SlidingSync;\n\n /**\n * @experimental\n */\n intentionalMentions?: boolean;\n}\n\nexport interface IStoredClientOpts extends IStartClientOpts {}\n\nexport enum RoomVersionStability {\n Stable = \"stable\",\n Unstable = \"unstable\",\n}\n\nexport interface IRoomVersionsCapability {\n default: string;\n available: Record;\n}\n\nexport interface ICapability {\n enabled: boolean;\n}\n\nexport interface IChangePasswordCapability extends ICapability {}\n\nexport interface IThreadsCapability extends ICapability {}\n\ninterface ICapabilities {\n [key: string]: any;\n \"m.change_password\"?: IChangePasswordCapability;\n \"m.room_versions\"?: IRoomVersionsCapability;\n \"io.element.thread\"?: IThreadsCapability;\n}\n\n/* eslint-disable camelcase */\nexport interface ICrossSigningKey {\n keys: { [algorithm: string]: string };\n signatures?: ISignatures;\n usage: string[];\n user_id: string;\n}\n\nenum CrossSigningKeyType {\n MasterKey = \"master_key\",\n SelfSigningKey = \"self_signing_key\",\n UserSigningKey = \"user_signing_key\",\n}\n\nexport type CrossSigningKeys = Record;\n\nexport type SendToDeviceContentMap = Map>>;\n\nexport interface ISignedKey {\n keys: Record;\n signatures: ISignatures;\n user_id: string;\n algorithms: string[];\n device_id: string;\n}\n\nexport type KeySignatures = Record>;\nexport interface IUploadKeySignaturesResponse {\n failures: Record<\n string,\n Record<\n string,\n {\n errcode: string;\n error: string;\n }\n >\n >;\n}\n\nexport interface IPreviewUrlResponse {\n [key: string]: undefined | string | number;\n \"og:title\": string;\n \"og:type\": string;\n \"og:url\": string;\n \"og:image\"?: string;\n \"og:image:type\"?: string;\n \"og:image:height\"?: number;\n \"og:image:width\"?: number;\n \"og:description\"?: string;\n \"matrix:image:size\"?: number;\n}\n\nexport interface ITurnServerResponse {\n uris: string[];\n username: string;\n password: string;\n ttl: number;\n}\n\nexport interface ITurnServer {\n urls: string[];\n username: string;\n credential: string;\n}\n\nexport interface IServerVersions {\n versions: string[];\n unstable_features: Record;\n}\n\nexport const M_AUTHENTICATION = new UnstableValue(\"m.authentication\", \"org.matrix.msc2965.authentication\");\n\nexport interface IClientWellKnown {\n [key: string]: any;\n \"m.homeserver\"?: IWellKnownConfig;\n \"m.identity_server\"?: IWellKnownConfig;\n [M_AUTHENTICATION.name]?: IDelegatedAuthConfig; // MSC2965\n}\n\nexport interface IWellKnownConfig {\n raw?: IClientWellKnown;\n action?: AutoDiscoveryAction;\n reason?: string;\n error?: Error | string;\n // eslint-disable-next-line\n base_url?: string | null;\n // XXX: this is undocumented\n server_name?: string;\n}\n\nexport interface IDelegatedAuthConfig {\n // MSC2965\n /** The OIDC Provider/issuer the client should use */\n issuer: string;\n /** The optional URL of the web UI where the user can manage their account */\n account?: string;\n}\n\ninterface IKeyBackupPath {\n path: string;\n queryData?: {\n version: string;\n };\n}\n\ninterface IMediaConfig {\n [key: string]: any; // extensible\n \"m.upload.size\"?: number;\n}\n\ninterface IThirdPartySigned {\n sender: string;\n mxid: string;\n token: string;\n signatures: ISignatures;\n}\n\ninterface IJoinRequestBody {\n third_party_signed?: IThirdPartySigned;\n}\n\ninterface ITagMetadata {\n [key: string]: any;\n order: number;\n}\n\ninterface IMessagesResponse {\n start?: string;\n end?: string;\n chunk: IRoomEvent[];\n state?: IStateEvent[];\n}\n\ninterface IThreadedMessagesResponse {\n prev_batch: string;\n next_batch: string;\n chunk: IRoomEvent[];\n state: IStateEvent[];\n}\n\nexport interface IRequestTokenResponse {\n sid: string;\n submit_url?: string;\n}\n\nexport interface IRequestMsisdnTokenResponse extends IRequestTokenResponse {\n msisdn: string;\n success: boolean;\n intl_fmt: string;\n}\n\nexport interface IUploadKeysRequest {\n \"device_keys\"?: Required;\n \"one_time_keys\"?: Record;\n \"org.matrix.msc2732.fallback_keys\"?: Record;\n}\n\nexport interface IQueryKeysRequest {\n device_keys: { [userId: string]: string[] };\n timeout?: number;\n token?: string;\n}\n\nexport interface IClaimKeysRequest {\n one_time_keys: { [userId: string]: { [deviceId: string]: string } };\n timeout?: number;\n}\n\nexport interface IOpenIDToken {\n access_token: string;\n token_type: \"Bearer\" | string;\n matrix_server_name: string;\n expires_in: number;\n}\n\ninterface IRoomInitialSyncResponse {\n room_id: string;\n membership: \"invite\" | \"join\" | \"leave\" | \"ban\";\n messages?: {\n start?: string;\n end?: string;\n chunk: IEventWithRoomId[];\n };\n state?: IStateEventWithRoomId[];\n visibility: Visibility;\n account_data?: IMinimalEvent[];\n presence: Partial; // legacy and undocumented, api is deprecated so this won't get attention\n}\n\ninterface IJoinedRoomsResponse {\n joined_rooms: string[];\n}\n\ninterface IJoinedMembersResponse {\n joined: {\n [userId: string]: {\n display_name: string;\n avatar_url: string;\n };\n };\n}\n\nexport interface IRegisterRequestParams {\n auth?: IAuthData;\n username?: string;\n password?: string;\n refresh_token?: boolean;\n guest_access_token?: string;\n x_show_msisdn?: boolean;\n bind_msisdn?: boolean;\n bind_email?: boolean;\n inhibit_login?: boolean;\n initial_device_display_name?: string;\n}\n\nexport interface IPublicRoomsChunkRoom {\n room_id: string;\n name?: string;\n avatar_url?: string;\n topic?: string;\n canonical_alias?: string;\n aliases?: string[];\n world_readable: boolean;\n guest_can_join: boolean;\n num_joined_members: number;\n room_type?: RoomType | string; // Added by MSC3827\n}\n\ninterface IPublicRoomsResponse {\n chunk: IPublicRoomsChunkRoom[];\n next_batch?: string;\n prev_batch?: string;\n total_room_count_estimate?: number;\n}\n\ninterface IUserDirectoryResponse {\n results: {\n user_id: string;\n display_name?: string;\n avatar_url?: string;\n }[];\n limited: boolean;\n}\n\nexport interface IMyDevice {\n \"device_id\": string;\n \"display_name\"?: string;\n \"last_seen_ip\"?: string;\n \"last_seen_ts\"?: number;\n // UNSTABLE_MSC3852_LAST_SEEN_UA\n \"last_seen_user_agent\"?: string;\n \"org.matrix.msc3852.last_seen_user_agent\"?: string;\n}\n\nexport interface Keys {\n keys: { [keyId: string]: string };\n usage: string[];\n user_id: string;\n}\n\nexport interface SigningKeys extends Keys {\n signatures: ISignatures;\n}\n\nexport interface DeviceKeys {\n [deviceId: string]: IDeviceKeys & {\n unsigned?: {\n device_display_name: string;\n };\n };\n}\n\nexport interface IDownloadKeyResult {\n failures: { [serverName: string]: object };\n device_keys: { [userId: string]: DeviceKeys };\n // the following three fields were added in 1.1\n master_keys?: { [userId: string]: Keys };\n self_signing_keys?: { [userId: string]: SigningKeys };\n user_signing_keys?: { [userId: string]: SigningKeys };\n}\n\nexport interface IClaimOTKsResult {\n failures: { [serverName: string]: object };\n one_time_keys: {\n [userId: string]: {\n [deviceId: string]: {\n [keyId: string]: {\n key: string;\n signatures: ISignatures;\n };\n };\n };\n };\n}\n\nexport interface IFieldType {\n regexp: string;\n placeholder: string;\n}\n\nexport interface IInstance {\n desc: string;\n icon?: string;\n fields: object;\n network_id: string;\n // XXX: this is undocumented but we rely on it: https://github.com/matrix-org/matrix-doc/issues/3203\n instance_id: string;\n}\n\nexport interface IProtocol {\n user_fields: string[];\n location_fields: string[];\n icon: string;\n field_types: Record;\n instances: IInstance[];\n}\n\ninterface IThirdPartyLocation {\n alias: string;\n protocol: string;\n fields: object;\n}\n\ninterface IThirdPartyUser {\n userid: string;\n protocol: string;\n fields: object;\n}\n\ninterface IRoomSummary extends Omit {\n room_type?: RoomType;\n membership?: string;\n is_encrypted: boolean;\n}\n\ninterface IRoomKeysResponse {\n sessions: IKeyBackupRoomSessions;\n}\n\ninterface IRoomsKeysResponse {\n rooms: Record;\n}\n\ninterface IRoomHierarchy {\n rooms: IHierarchyRoom[];\n next_batch?: string;\n}\n\nexport interface TimestampToEventResponse {\n event_id: string;\n origin_server_ts: string;\n}\n\ninterface IWhoamiResponse {\n user_id: string;\n device_id?: string;\n}\n/* eslint-enable camelcase */\n\n// We're using this constant for methods overloading and inspect whether a variable\n// contains an eventId or not. This was required to ensure backwards compatibility\n// of methods for threads\n// Probably not the most graceful solution but does a good enough job for now\nconst EVENT_ID_PREFIX = \"$\";\n\nexport enum ClientEvent {\n Sync = \"sync\",\n Event = \"event\",\n ToDeviceEvent = \"toDeviceEvent\",\n AccountData = \"accountData\",\n Room = \"Room\",\n DeleteRoom = \"deleteRoom\",\n SyncUnexpectedError = \"sync.unexpectedError\",\n ClientWellKnown = \"WellKnown.client\",\n ReceivedVoipEvent = \"received_voip_event\",\n UndecryptableToDeviceEvent = \"toDeviceEvent.undecryptable\",\n TurnServers = \"turnServers\",\n TurnServersError = \"turnServers.error\",\n}\n\ntype RoomEvents =\n | RoomEvent.Name\n | RoomEvent.Redaction\n | RoomEvent.RedactionCancelled\n | RoomEvent.Receipt\n | RoomEvent.Tags\n | RoomEvent.LocalEchoUpdated\n | RoomEvent.HistoryImportedWithinTimeline\n | RoomEvent.AccountData\n | RoomEvent.MyMembership\n | RoomEvent.Timeline\n | RoomEvent.TimelineReset;\n\ntype RoomStateEvents =\n | RoomStateEvent.Events\n | RoomStateEvent.Members\n | RoomStateEvent.NewMember\n | RoomStateEvent.Update\n | RoomStateEvent.Marker;\n\ntype CryptoEvents =\n | CryptoEvent.KeySignatureUploadFailure\n | CryptoEvent.KeyBackupStatus\n | CryptoEvent.KeyBackupFailed\n | CryptoEvent.KeyBackupSessionsRemaining\n | CryptoEvent.RoomKeyRequest\n | CryptoEvent.RoomKeyRequestCancellation\n | CryptoEvent.VerificationRequest\n | CryptoEvent.DeviceVerificationChanged\n | CryptoEvent.UserTrustStatusChanged\n | CryptoEvent.KeysChanged\n | CryptoEvent.Warning\n | CryptoEvent.DevicesUpdated\n | CryptoEvent.WillUpdateDevices;\n\ntype MatrixEventEvents = MatrixEventEvent.Decrypted | MatrixEventEvent.Replaced | MatrixEventEvent.VisibilityChange;\n\ntype RoomMemberEvents =\n | RoomMemberEvent.Name\n | RoomMemberEvent.Typing\n | RoomMemberEvent.PowerLevel\n | RoomMemberEvent.Membership;\n\ntype UserEvents =\n | UserEvent.AvatarUrl\n | UserEvent.DisplayName\n | UserEvent.Presence\n | UserEvent.CurrentlyActive\n | UserEvent.LastPresenceTs;\n\nexport type EmittedEvents =\n | ClientEvent\n | RoomEvents\n | RoomStateEvents\n | CryptoEvents\n | MatrixEventEvents\n | RoomMemberEvents\n | UserEvents\n | CallEvent // re-emitted by call.ts using Object.values\n | CallEventHandlerEvent.Incoming\n | GroupCallEventHandlerEvent.Incoming\n | GroupCallEventHandlerEvent.Outgoing\n | GroupCallEventHandlerEvent.Ended\n | GroupCallEventHandlerEvent.Participants\n | HttpApiEvent.SessionLoggedOut\n | HttpApiEvent.NoConsent\n | BeaconEvent;\n\nexport type ClientEventHandlerMap = {\n /**\n * Fires whenever the SDK's syncing state is updated. The state can be one of:\n *

    \n *\n *
  • PREPARED: The client has synced with the server at least once and is\n * ready for methods to be called on it. This will be immediately followed by\n * a state of SYNCING. This is the equivalent of \"syncComplete\" in the\n * previous API.
  • \n *\n *
  • CATCHUP: The client has detected the connection to the server might be\n * available again and will now try to do a sync again. As this sync might take\n * a long time (depending how long ago was last synced, and general server\n * performance) the client is put in this mode so the UI can reflect trying\n * to catch up with the server after losing connection.
  • \n *\n *
  • SYNCING : The client is currently polling for new events from the server.\n * This will be called after processing latest events from a sync.
  • \n *\n *
  • ERROR : The client has had a problem syncing with the server. If this is\n * called before PREPARED then there was a problem performing the initial\n * sync. If this is called after PREPARED then there was a problem polling\n * the server for updates. This may be called multiple times even if the state is\n * already ERROR. This is the equivalent of \"syncError\" in the previous\n * API.
  • \n *\n *
  • RECONNECTING: The sync connection has dropped, but not (yet) in a way that\n * should be considered erroneous.\n *
  • \n *\n *
  • STOPPED: The client has stopped syncing with server due to stopClient\n * being called.\n *
  • \n *
\n * State transition diagram:\n * ```\n * +---->STOPPED\n * |\n * +----->PREPARED -------> SYNCING <--+\n * | ^ | ^ |\n * | CATCHUP ----------+ | | |\n * | ^ V | |\n * null ------+ | +------- RECONNECTING |\n * | V V |\n * +------->ERROR ---------------------+\n *\n * NB: 'null' will never be emitted by this event.\n *\n * ```\n * Transitions:\n *
    \n *\n *
  • `null -> PREPARED` : Occurs when the initial sync is completed\n * first time. This involves setting up filters and obtaining push rules.\n *\n *
  • `null -> ERROR` : Occurs when the initial sync failed first time.\n *\n *
  • `ERROR -> PREPARED` : Occurs when the initial sync succeeds\n * after previously failing.\n *\n *
  • `PREPARED -> SYNCING` : Occurs immediately after transitioning\n * to PREPARED. Starts listening for live updates rather than catching up.\n *\n *
  • `SYNCING -> RECONNECTING` : Occurs when the live update fails.\n *\n *
  • `RECONNECTING -> RECONNECTING` : Can occur if the update calls\n * continue to fail, but the keepalive calls (to /versions) succeed.\n *\n *
  • `RECONNECTING -> ERROR` : Occurs when the keepalive call also fails\n *\n *
  • `ERROR -> SYNCING` : Occurs when the client has performed a\n * live update after having previously failed.\n *\n *
  • `ERROR -> ERROR` : Occurs when the client has failed to keepalive\n * for a second time or more.
  • \n *\n *
  • `SYNCING -> SYNCING` : Occurs when the client has performed a live\n * update. This is called after processing.
  • \n *\n *
  • `* -> STOPPED` : Occurs once the client has stopped syncing or\n * trying to sync after stopClient has been called.
  • \n *
\n *\n * @param state - An enum representing the syncing state. One of \"PREPARED\",\n * \"SYNCING\", \"ERROR\", \"STOPPED\".\n *\n * @param prevState - An enum representing the previous syncing state.\n * One of \"PREPARED\", \"SYNCING\", \"ERROR\", \"STOPPED\" or null.\n *\n * @param data - Data about this transition.\n *\n * @example\n * ```\n * matrixClient.on(\"sync\", function(state, prevState, data) {\n * switch (state) {\n * case \"ERROR\":\n * // update UI to say \"Connection Lost\"\n * break;\n * case \"SYNCING\":\n * // update UI to remove any \"Connection Lost\" message\n * break;\n * case \"PREPARED\":\n * // the client instance is ready to be queried.\n * var rooms = matrixClient.getRooms();\n * break;\n * }\n * });\n * ```\n */\n [ClientEvent.Sync]: (state: SyncState, lastState: SyncState | null, data?: ISyncStateData) => void;\n /**\n * Fires whenever the SDK receives a new event.\n *

\n * This is only fired for live events received via /sync - it is not fired for\n * events received over context, search, or pagination APIs.\n *\n * @param event - The matrix event which caused this event to fire.\n * @example\n * ```\n * matrixClient.on(\"event\", function(event){\n * var sender = event.getSender();\n * });\n * ```\n */\n [ClientEvent.Event]: (event: MatrixEvent) => void;\n /**\n * Fires whenever the SDK receives a new to-device event.\n * @param event - The matrix event which caused this event to fire.\n * @example\n * ```\n * matrixClient.on(\"toDeviceEvent\", function(event){\n * var sender = event.getSender();\n * });\n * ```\n */\n [ClientEvent.ToDeviceEvent]: (event: MatrixEvent) => void;\n /**\n * Fires if a to-device event is received that cannot be decrypted.\n * Encrypted to-device events will (generally) use plain Olm encryption,\n * in which case decryption failures are fatal: the event will never be\n * decryptable, unlike Megolm encrypted events where the key may simply\n * arrive later.\n *\n * An undecryptable to-device event is therefore likley to indicate problems.\n *\n * @param event - The undecyptable to-device event\n */\n [ClientEvent.UndecryptableToDeviceEvent]: (event: MatrixEvent) => void;\n /**\n * Fires whenever new user-scoped account_data is added.\n * @param event - The event describing the account_data just added\n * @param event - The previous account data, if known.\n * @example\n * ```\n * matrixClient.on(\"accountData\", function(event, oldEvent){\n * myAccountData[event.type] = event.content;\n * });\n * ```\n */\n [ClientEvent.AccountData]: (event: MatrixEvent, lastEvent?: MatrixEvent) => void;\n /**\n * Fires whenever a new Room is added. This will fire when you are invited to a\n * room, as well as when you join a room. This event is experimental and\n * may change.\n * @param room - The newly created, fully populated room.\n * @example\n * ```\n * matrixClient.on(\"Room\", function(room){\n * var roomId = room.roomId;\n * });\n * ```\n */\n [ClientEvent.Room]: (room: Room) => void;\n /**\n * Fires whenever a Room is removed. This will fire when you forget a room.\n * This event is experimental and may change.\n * @param roomId - The deleted room ID.\n * @example\n * ```\n * matrixClient.on(\"deleteRoom\", function(roomId){\n * // update UI from getRooms()\n * });\n * ```\n */\n [ClientEvent.DeleteRoom]: (roomId: string) => void;\n [ClientEvent.SyncUnexpectedError]: (error: Error) => void;\n /**\n * Fires when the client .well-known info is fetched.\n *\n * @param data - The JSON object returned by the server\n */\n [ClientEvent.ClientWellKnown]: (data: IClientWellKnown) => void;\n [ClientEvent.ReceivedVoipEvent]: (event: MatrixEvent) => void;\n [ClientEvent.TurnServers]: (servers: ITurnServer[]) => void;\n [ClientEvent.TurnServersError]: (error: Error, fatal: boolean) => void;\n} & RoomEventHandlerMap &\n RoomStateEventHandlerMap &\n CryptoEventHandlerMap &\n MatrixEventHandlerMap &\n RoomMemberEventHandlerMap &\n UserEventHandlerMap &\n CallEventHandlerEventHandlerMap &\n GroupCallEventHandlerEventHandlerMap &\n CallEventHandlerMap &\n HttpApiEventHandlerMap &\n BeaconEventHandlerMap;\n\nconst SSO_ACTION_PARAM = new UnstableValue(\"action\", \"org.matrix.msc3824.action\");\n\n/**\n * Represents a Matrix Client. Only directly construct this if you want to use\n * custom modules. Normally, {@link createClient} should be used\n * as it specifies 'sensible' defaults for these modules.\n */\nexport class MatrixClient extends TypedEventEmitter {\n public static readonly RESTORE_BACKUP_ERROR_BAD_KEY = \"RESTORE_BACKUP_ERROR_BAD_KEY\";\n\n public reEmitter = new TypedReEmitter(this);\n public olmVersion: [number, number, number] | null = null; // populated after initCrypto\n public usingExternalCrypto = false;\n public store: Store;\n public deviceId: string | null;\n public credentials: { userId: string | null };\n public pickleKey?: string;\n public scheduler?: MatrixScheduler;\n public clientRunning = false;\n public timelineSupport = false;\n public urlPreviewCache: { [key: string]: Promise } = {};\n public identityServer?: IIdentityServerProvider;\n public http: MatrixHttpApi; // XXX: Intended private, used in code.\n\n /**\n * The libolm crypto implementation, if it is in use.\n *\n * @deprecated This should not be used. Instead, use the methods exposed directly on this class or\n * (where they are available) via {@link getCrypto}.\n */\n public crypto?: Crypto; // XXX: Intended private, used in code. Being replaced by cryptoBackend\n\n private cryptoBackend?: CryptoBackend; // one of crypto or rustCrypto\n public cryptoCallbacks: ICryptoCallbacks; // XXX: Intended private, used in code.\n public callEventHandler?: CallEventHandler; // XXX: Intended private, used in code.\n public groupCallEventHandler?: GroupCallEventHandler;\n public supportsCallTransfer = false; // XXX: Intended private, used in code.\n public forceTURN = false; // XXX: Intended private, used in code.\n public iceCandidatePoolSize = 0; // XXX: Intended private, used in code.\n public idBaseUrl?: string;\n public baseUrl: string;\n public readonly isVoipWithNoMediaAllowed;\n\n // Note: these are all `protected` to let downstream consumers make mistakes if they want to.\n // We don't technically support this usage, but have reasons to do this.\n\n protected canSupportVoip = false;\n protected peekSync: SyncApi | null = null;\n protected isGuestAccount = false;\n protected ongoingScrollbacks: { [roomId: string]: { promise?: Promise; errorTs?: number } } = {};\n protected notifTimelineSet: EventTimelineSet | null = null;\n protected cryptoStore?: CryptoStore;\n protected verificationMethods?: VerificationMethod[];\n protected fallbackICEServerAllowed = false;\n protected roomList: RoomList;\n protected syncApi?: SlidingSyncSdk | SyncApi;\n public roomNameGenerator?: ICreateClientOpts[\"roomNameGenerator\"];\n public pushRules?: IPushRules;\n protected syncLeftRoomsPromise?: Promise;\n protected syncedLeftRooms = false;\n protected clientOpts?: IStoredClientOpts;\n protected clientWellKnownIntervalID?: ReturnType;\n protected canResetTimelineCallback?: ResetTimelineCallback;\n\n public canSupport = new Map();\n\n // The pushprocessor caches useful things, so keep one and re-use it\n protected pushProcessor = new PushProcessor(this);\n\n // Promise to a response of the server's /versions response\n // TODO: This should expire: https://github.com/matrix-org/matrix-js-sdk/issues/1020\n protected serverVersionsPromise?: Promise;\n\n public cachedCapabilities?: {\n capabilities: ICapabilities;\n expiration: number;\n };\n protected clientWellKnown?: IClientWellKnown;\n protected clientWellKnownPromise?: Promise;\n protected turnServers: ITurnServer[] = [];\n protected turnServersExpiry = 0;\n protected checkTurnServersIntervalID?: ReturnType;\n protected exportedOlmDeviceToImport?: IExportedOlmDevice;\n protected txnCtr = 0;\n protected mediaHandler = new MediaHandler(this);\n protected sessionId: string;\n protected pendingEventEncryption = new Map>();\n\n private useE2eForGroupCall = true;\n private toDeviceMessageQueue: ToDeviceMessageQueue;\n\n // A manager for determining which invites should be ignored.\n public readonly ignoredInvites: IgnoredInvites;\n\n public constructor(opts: IMatrixClientCreateOpts) {\n super();\n\n opts.baseUrl = utils.ensureNoTrailingSlash(opts.baseUrl);\n opts.idBaseUrl = utils.ensureNoTrailingSlash(opts.idBaseUrl);\n\n this.baseUrl = opts.baseUrl;\n this.idBaseUrl = opts.idBaseUrl;\n this.identityServer = opts.identityServer;\n\n this.usingExternalCrypto = opts.usingExternalCrypto ?? false;\n this.store = opts.store || new StubStore();\n this.deviceId = opts.deviceId || null;\n this.sessionId = randomString(10);\n\n const userId = opts.userId || null;\n this.credentials = { userId };\n\n this.http = new MatrixHttpApi(this as ConstructorParameters[0], {\n fetchFn: opts.fetchFn,\n baseUrl: opts.baseUrl,\n idBaseUrl: opts.idBaseUrl,\n accessToken: opts.accessToken,\n prefix: ClientPrefix.R0,\n onlyData: true,\n extraParams: opts.queryParams,\n localTimeoutMs: opts.localTimeoutMs,\n useAuthorizationHeader: opts.useAuthorizationHeader,\n });\n\n if (opts.deviceToImport) {\n if (this.deviceId) {\n logger.warn(\n \"not importing device because device ID is provided to \" +\n \"constructor independently of exported data\",\n );\n } else if (this.credentials.userId) {\n logger.warn(\n \"not importing device because user ID is provided to \" +\n \"constructor independently of exported data\",\n );\n } else if (!opts.deviceToImport.deviceId) {\n logger.warn(\"not importing device because no device ID in exported data\");\n } else {\n this.deviceId = opts.deviceToImport.deviceId;\n this.credentials.userId = opts.deviceToImport.userId;\n // will be used during async initialization of the crypto\n this.exportedOlmDeviceToImport = opts.deviceToImport.olmDevice;\n }\n } else if (opts.pickleKey) {\n this.pickleKey = opts.pickleKey;\n }\n\n this.scheduler = opts.scheduler;\n if (this.scheduler) {\n this.scheduler.setProcessFunction(async (eventToSend: MatrixEvent) => {\n const room = this.getRoom(eventToSend.getRoomId());\n if (eventToSend.status !== EventStatus.SENDING) {\n this.updatePendingEventStatus(room, eventToSend, EventStatus.SENDING);\n }\n const res = await this.sendEventHttpRequest(eventToSend);\n if (room) {\n // ensure we update pending event before the next scheduler run so that any listeners to event id\n // updates on the synchronous event emitter get a chance to run first.\n room.updatePendingEvent(eventToSend, EventStatus.SENT, res.event_id);\n }\n return res;\n });\n }\n\n if (supportsMatrixCall()) {\n this.callEventHandler = new CallEventHandler(this);\n this.groupCallEventHandler = new GroupCallEventHandler(this);\n this.canSupportVoip = true;\n // Start listening for calls after the initial sync is done\n // We do not need to backfill the call event buffer\n // with encrypted events that might never get decrypted\n this.on(ClientEvent.Sync, this.startCallEventHandler);\n }\n\n this.on(ClientEvent.Sync, this.fixupRoomNotifications);\n\n this.timelineSupport = Boolean(opts.timelineSupport);\n\n this.cryptoStore = opts.cryptoStore;\n this.verificationMethods = opts.verificationMethods;\n this.cryptoCallbacks = opts.cryptoCallbacks || {};\n\n this.forceTURN = opts.forceTURN || false;\n this.iceCandidatePoolSize = opts.iceCandidatePoolSize === undefined ? 0 : opts.iceCandidatePoolSize;\n this.supportsCallTransfer = opts.supportsCallTransfer || false;\n this.fallbackICEServerAllowed = opts.fallbackICEServerAllowed || false;\n this.isVoipWithNoMediaAllowed = opts.isVoipWithNoMediaAllowed || false;\n\n if (opts.useE2eForGroupCall !== undefined) this.useE2eForGroupCall = opts.useE2eForGroupCall;\n\n // List of which rooms have encryption enabled: separate from crypto because\n // we still want to know which rooms are encrypted even if crypto is disabled:\n // we don't want to start sending unencrypted events to them.\n this.roomList = new RoomList(this.cryptoStore);\n this.roomNameGenerator = opts.roomNameGenerator;\n\n this.toDeviceMessageQueue = new ToDeviceMessageQueue(this);\n\n // The SDK doesn't really provide a clean way for events to recalculate the push\n // actions for themselves, so we have to kinda help them out when they are encrypted.\n // We do this so that push rules are correctly executed on events in their decrypted\n // state, such as highlights when the user's name is mentioned.\n this.on(MatrixEventEvent.Decrypted, (event) => {\n fixNotificationCountOnDecryption(this, event);\n });\n\n // Like above, we have to listen for read receipts from ourselves in order to\n // correctly handle notification counts on encrypted rooms.\n // This fixes https://github.com/vector-im/element-web/issues/9421\n this.on(RoomEvent.Receipt, (event, room) => {\n if (room && this.isRoomEncrypted(room.roomId)) {\n // Figure out if we've read something or if it's just informational\n const content = event.getContent();\n const isSelf =\n Object.keys(content).filter((eid) => {\n for (const [key, value] of Object.entries(content[eid])) {\n if (!utils.isSupportedReceiptType(key)) continue;\n if (!value) continue;\n\n if (Object.keys(value).includes(this.getUserId()!)) return true;\n }\n\n return false;\n }).length > 0;\n\n if (!isSelf) return;\n\n // Work backwards to determine how many events are unread. We also set\n // a limit for how back we'll look to avoid spinning CPU for too long.\n // If we hit the limit, we assume the count is unchanged.\n const maxHistory = 20;\n const events = room.getLiveTimeline().getEvents();\n\n let highlightCount = 0;\n\n for (let i = events.length - 1; i >= 0; i--) {\n if (i === events.length - maxHistory) return; // limit reached\n\n const event = events[i];\n\n if (room.hasUserReadEvent(this.getUserId()!, event.getId()!)) {\n // If the user has read the event, then the counting is done.\n break;\n }\n\n const pushActions = this.getPushActionsForEvent(event);\n highlightCount += pushActions?.tweaks?.highlight ? 1 : 0;\n }\n\n // Note: we don't need to handle 'total' notifications because the counts\n // will come from the server.\n room.setUnreadNotificationCount(NotificationCountType.Highlight, highlightCount);\n }\n });\n\n this.ignoredInvites = new IgnoredInvites(this);\n }\n\n /**\n * High level helper method to begin syncing and poll for new events. To listen for these\n * events, add a listener for {@link ClientEvent.Event}\n * via {@link MatrixClient#on}. Alternatively, listen for specific\n * state change events.\n * @param opts - Options to apply when syncing.\n */\n public async startClient(opts?: IStartClientOpts): Promise {\n if (this.clientRunning) {\n // client is already running.\n return;\n }\n this.clientRunning = true;\n // backwards compat for when 'opts' was 'historyLen'.\n if (typeof opts === \"number\") {\n opts = {\n initialSyncLimit: opts,\n };\n }\n\n // Create our own user object artificially (instead of waiting for sync)\n // so it's always available, even if the user is not in any rooms etc.\n const userId = this.getUserId();\n if (userId) {\n this.store.storeUser(new User(userId));\n }\n\n // periodically poll for turn servers if we support voip\n if (this.canSupportVoip) {\n this.checkTurnServersIntervalID = setInterval(() => {\n this.checkTurnServers();\n }, TURN_CHECK_INTERVAL);\n // noinspection ES6MissingAwait\n this.checkTurnServers();\n }\n\n if (this.syncApi) {\n // This shouldn't happen since we thought the client was not running\n logger.error(\"Still have sync object whilst not running: stopping old one\");\n this.syncApi.stop();\n }\n\n try {\n await this.getVersions();\n\n // This should be done with `canSupport`\n // TODO: https://github.com/vector-im/element-web/issues/23643\n const { threads, list, fwdPagination } = await this.doesServerSupportThread();\n Thread.setServerSideSupport(threads);\n Thread.setServerSideListSupport(list);\n Thread.setServerSideFwdPaginationSupport(fwdPagination);\n } catch (e) {\n logger.error(\"Can't fetch server versions, continuing to initialise sync, this will be retried later\", e);\n }\n\n this.clientOpts = opts ?? {};\n if (this.clientOpts.slidingSync) {\n this.syncApi = new SlidingSyncSdk(\n this.clientOpts.slidingSync,\n this,\n this.clientOpts,\n this.buildSyncApiOptions(),\n );\n } else {\n this.syncApi = new SyncApi(this, this.clientOpts, this.buildSyncApiOptions());\n }\n\n if (this.clientOpts.hasOwnProperty(\"experimentalThreadSupport\")) {\n logger.warn(\"`experimentalThreadSupport` has been deprecated, use `threadSupport` instead\");\n }\n\n // If `threadSupport` is omitted and the deprecated `experimentalThreadSupport` has been passed\n // We should fallback to that value for backwards compatibility purposes\n if (\n !this.clientOpts.hasOwnProperty(\"threadSupport\") &&\n this.clientOpts.hasOwnProperty(\"experimentalThreadSupport\")\n ) {\n this.clientOpts.threadSupport = this.clientOpts.experimentalThreadSupport;\n }\n\n this.syncApi.sync();\n\n if (this.clientOpts.clientWellKnownPollPeriod !== undefined) {\n this.clientWellKnownIntervalID = setInterval(() => {\n this.fetchClientWellKnown();\n }, 1000 * this.clientOpts.clientWellKnownPollPeriod);\n this.fetchClientWellKnown();\n }\n\n this.toDeviceMessageQueue.start();\n }\n\n /**\n * Construct a SyncApiOptions for this client, suitable for passing into the SyncApi constructor\n */\n protected buildSyncApiOptions(): SyncApiOptions {\n return {\n crypto: this.crypto,\n cryptoCallbacks: this.cryptoBackend,\n canResetEntireTimeline: (roomId: string): boolean => {\n if (!this.canResetTimelineCallback) {\n return false;\n }\n return this.canResetTimelineCallback(roomId);\n },\n };\n }\n\n /**\n * High level helper method to stop the client from polling and allow a\n * clean shutdown.\n */\n public stopClient(): void {\n this.cryptoBackend?.stop(); // crypto might have been initialised even if the client wasn't fully started\n\n if (!this.clientRunning) return; // already stopped\n\n logger.log(\"stopping MatrixClient\");\n\n this.clientRunning = false;\n\n this.syncApi?.stop();\n this.syncApi = undefined;\n\n this.peekSync?.stopPeeking();\n\n this.callEventHandler?.stop();\n this.groupCallEventHandler?.stop();\n this.callEventHandler = undefined;\n this.groupCallEventHandler = undefined;\n\n global.clearInterval(this.checkTurnServersIntervalID);\n this.checkTurnServersIntervalID = undefined;\n\n if (this.clientWellKnownIntervalID !== undefined) {\n global.clearInterval(this.clientWellKnownIntervalID);\n }\n\n this.toDeviceMessageQueue.stop();\n }\n\n /**\n * Try to rehydrate a device if available. The client must have been\n * initialized with a `cryptoCallback.getDehydrationKey` option, and this\n * function must be called before initCrypto and startClient are called.\n *\n * @returns Promise which resolves to undefined if a device could not be dehydrated, or\n * to the new device ID if the dehydration was successful.\n * @returns Rejects: with an error response.\n */\n public async rehydrateDevice(): Promise {\n if (this.crypto) {\n throw new Error(\"Cannot rehydrate device after crypto is initialized\");\n }\n\n if (!this.cryptoCallbacks.getDehydrationKey) {\n return;\n }\n\n const getDeviceResult = await this.getDehydratedDevice();\n if (!getDeviceResult) {\n return;\n }\n\n if (!getDeviceResult.device_data || !getDeviceResult.device_id) {\n logger.info(\"no dehydrated device found\");\n return;\n }\n\n const account = new global.Olm.Account();\n try {\n const deviceData = getDeviceResult.device_data;\n if (deviceData.algorithm !== DEHYDRATION_ALGORITHM) {\n logger.warn(\"Wrong algorithm for dehydrated device\");\n return;\n }\n logger.log(\"unpickling dehydrated device\");\n const key = await this.cryptoCallbacks.getDehydrationKey(deviceData, (k) => {\n // copy the key so that it doesn't get clobbered\n account.unpickle(new Uint8Array(k), deviceData.account);\n });\n account.unpickle(key, deviceData.account);\n logger.log(\"unpickled device\");\n\n const rehydrateResult = await this.http.authedRequest<{ success: boolean }>(\n Method.Post,\n \"/dehydrated_device/claim\",\n undefined,\n {\n device_id: getDeviceResult.device_id,\n },\n {\n prefix: \"/_matrix/client/unstable/org.matrix.msc2697.v2\",\n },\n );\n\n if (rehydrateResult.success) {\n this.deviceId = getDeviceResult.device_id;\n logger.info(\"using dehydrated device\");\n const pickleKey = this.pickleKey || \"DEFAULT_KEY\";\n this.exportedOlmDeviceToImport = {\n pickledAccount: account.pickle(pickleKey),\n sessions: [],\n pickleKey: pickleKey,\n };\n account.free();\n return this.deviceId;\n } else {\n account.free();\n logger.info(\"not using dehydrated device\");\n return;\n }\n } catch (e) {\n account.free();\n logger.warn(\"could not unpickle\", e);\n }\n }\n\n /**\n * Get the current dehydrated device, if any\n * @returns A promise of an object containing the dehydrated device\n */\n public async getDehydratedDevice(): Promise {\n try {\n return await this.http.authedRequest(\n Method.Get,\n \"/dehydrated_device\",\n undefined,\n undefined,\n {\n prefix: \"/_matrix/client/unstable/org.matrix.msc2697.v2\",\n },\n );\n } catch (e) {\n logger.info(\"could not get dehydrated device\", e);\n return;\n }\n }\n\n /**\n * Set the dehydration key. This will also periodically dehydrate devices to\n * the server.\n *\n * @param key - the dehydration key\n * @param keyInfo - Information about the key. Primarily for\n * information about how to generate the key from a passphrase.\n * @param deviceDisplayName - The device display name for the\n * dehydrated device.\n * @returns A promise that resolves when the dehydrated device is stored.\n */\n public async setDehydrationKey(\n key: Uint8Array,\n keyInfo: IDehydratedDeviceKeyInfo,\n deviceDisplayName?: string,\n ): Promise {\n if (!this.crypto) {\n logger.warn(\"not dehydrating device if crypto is not enabled\");\n return;\n }\n return this.crypto.dehydrationManager.setKeyAndQueueDehydration(key, keyInfo, deviceDisplayName);\n }\n\n /**\n * Creates a new dehydrated device (without queuing periodic dehydration)\n * @param key - the dehydration key\n * @param keyInfo - Information about the key. Primarily for\n * information about how to generate the key from a passphrase.\n * @param deviceDisplayName - The device display name for the\n * dehydrated device.\n * @returns the device id of the newly created dehydrated device\n */\n public async createDehydratedDevice(\n key: Uint8Array,\n keyInfo: IDehydratedDeviceKeyInfo,\n deviceDisplayName?: string,\n ): Promise {\n if (!this.crypto) {\n logger.warn(\"not dehydrating device if crypto is not enabled\");\n return;\n }\n await this.crypto.dehydrationManager.setKey(key, keyInfo, deviceDisplayName);\n return this.crypto.dehydrationManager.dehydrateDevice();\n }\n\n public async exportDevice(): Promise {\n if (!this.crypto) {\n logger.warn(\"not exporting device if crypto is not enabled\");\n return;\n }\n return {\n userId: this.credentials.userId!,\n deviceId: this.deviceId!,\n // XXX: Private member access.\n olmDevice: await this.crypto.olmDevice.export(),\n };\n }\n\n /**\n * Clear any data out of the persistent stores used by the client.\n *\n * @returns Promise which resolves when the stores have been cleared.\n */\n public clearStores(): Promise {\n if (this.clientRunning) {\n throw new Error(\"Cannot clear stores while client is running\");\n }\n\n const promises: Promise[] = [];\n\n promises.push(this.store.deleteAllData());\n if (this.cryptoStore) {\n promises.push(this.cryptoStore.deleteAllData());\n }\n\n // delete the stores used by the rust matrix-sdk-crypto, in case they were used\n const deleteRustSdkStore = async (): Promise => {\n let indexedDB: IDBFactory;\n try {\n indexedDB = global.indexedDB;\n } catch (e) {\n // No indexeddb support\n return;\n }\n for (const dbname of [\n `${RUST_SDK_STORE_PREFIX}::matrix-sdk-crypto`,\n `${RUST_SDK_STORE_PREFIX}::matrix-sdk-crypto-meta`,\n ]) {\n const prom = new Promise((resolve, reject) => {\n logger.info(`Removing IndexedDB instance ${dbname}`);\n const req = indexedDB.deleteDatabase(dbname);\n req.onsuccess = (_): void => {\n logger.info(`Removed IndexedDB instance ${dbname}`);\n resolve(0);\n };\n req.onerror = (e): void => {\n // In private browsing, Firefox has a global.indexedDB, but attempts to delete an indexeddb\n // (even a non-existent one) fail with \"DOMException: A mutation operation was attempted on a\n // database that did not allow mutations.\"\n //\n // it seems like the only thing we can really do is ignore the error.\n logger.warn(`Failed to remove IndexedDB instance ${dbname}:`, e);\n resolve(0);\n };\n req.onblocked = (e): void => {\n logger.info(`cannot yet remove IndexedDB instance ${dbname}`);\n };\n });\n await prom;\n }\n };\n promises.push(deleteRustSdkStore());\n\n return Promise.all(promises).then(); // .then to fix types\n }\n\n /**\n * Get the user-id of the logged-in user\n *\n * @returns MXID for the logged-in user, or null if not logged in\n */\n public getUserId(): string | null {\n if (this.credentials && this.credentials.userId) {\n return this.credentials.userId;\n }\n return null;\n }\n\n /**\n * Get the user-id of the logged-in user\n *\n * @returns MXID for the logged-in user\n * @throws Error if not logged in\n */\n public getSafeUserId(): string {\n const userId = this.getUserId();\n if (!userId) {\n throw new Error(\"Expected logged in user but found none.\");\n }\n return userId;\n }\n\n /**\n * Get the domain for this client's MXID\n * @returns Domain of this MXID\n */\n public getDomain(): string | null {\n if (this.credentials && this.credentials.userId) {\n return this.credentials.userId.replace(/^.*?:/, \"\");\n }\n return null;\n }\n\n /**\n * Get the local part of the current user ID e.g. \"foo\" in \"\\@foo:bar\".\n * @returns The user ID localpart or null.\n */\n public getUserIdLocalpart(): string | null {\n if (this.credentials && this.credentials.userId) {\n return this.credentials.userId.split(\":\")[0].substring(1);\n }\n return null;\n }\n\n /**\n * Get the device ID of this client\n * @returns device ID\n */\n public getDeviceId(): string | null {\n return this.deviceId;\n }\n\n /**\n * Get the session ID of this client\n * @returns session ID\n */\n public getSessionId(): string {\n return this.sessionId;\n }\n\n /**\n * Check if the runtime environment supports VoIP calling.\n * @returns True if VoIP is supported.\n */\n public supportsVoip(): boolean {\n return this.canSupportVoip;\n }\n\n /**\n * @returns\n */\n public getMediaHandler(): MediaHandler {\n return this.mediaHandler;\n }\n\n /**\n * Set whether VoIP calls are forced to use only TURN\n * candidates. This is the same as the forceTURN option\n * when creating the client.\n * @param force - True to force use of TURN servers\n */\n public setForceTURN(force: boolean): void {\n this.forceTURN = force;\n }\n\n /**\n * Set whether to advertise transfer support to other parties on Matrix calls.\n * @param support - True to advertise the 'm.call.transferee' capability\n */\n public setSupportsCallTransfer(support: boolean): void {\n this.supportsCallTransfer = support;\n }\n\n /**\n * Returns true if to-device signalling for group calls will be encrypted with Olm.\n * If false, it will be sent unencrypted.\n * @returns boolean Whether group call signalling will be encrypted\n */\n public getUseE2eForGroupCall(): boolean {\n return this.useE2eForGroupCall;\n }\n\n /**\n * Creates a new call.\n * The place*Call methods on the returned call can be used to actually place a call\n *\n * @param roomId - The room the call is to be placed in.\n * @returns the call or null if the browser doesn't support calling.\n */\n public createCall(roomId: string): MatrixCall | null {\n return createNewMatrixCall(this, roomId);\n }\n\n /**\n * Creates a new group call and sends the associated state event\n * to alert other members that the room now has a group call.\n *\n * @param roomId - The room the call is to be placed in.\n */\n public async createGroupCall(\n roomId: string,\n type: GroupCallType,\n isPtt: boolean,\n intent: GroupCallIntent,\n dataChannelsEnabled?: boolean,\n dataChannelOptions?: IGroupCallDataChannelOptions,\n ): Promise {\n if (this.getGroupCallForRoom(roomId)) {\n throw new Error(`${roomId} already has an existing group call`);\n }\n\n const room = this.getRoom(roomId);\n\n if (!room) {\n throw new Error(`Cannot find room ${roomId}`);\n }\n\n // Because without Media section a WebRTC connection is not possible, so need a RTCDataChannel to set up a\n // no media WebRTC connection anyway.\n return new GroupCall(\n this,\n room,\n type,\n isPtt,\n intent,\n undefined,\n dataChannelsEnabled || this.isVoipWithNoMediaAllowed,\n dataChannelOptions,\n this.isVoipWithNoMediaAllowed,\n ).create();\n }\n\n /**\n * Wait until an initial state for the given room has been processed by the\n * client and the client is aware of any ongoing group calls. Awaiting on\n * the promise returned by this method before calling getGroupCallForRoom()\n * avoids races where getGroupCallForRoom is called before the state for that\n * room has been processed. It does not, however, fix other races, eg. two\n * clients both creating a group call at the same time.\n * @param roomId - The room ID to wait for\n * @returns A promise that resolves once existing group calls in the room\n * have been processed.\n */\n public waitUntilRoomReadyForGroupCalls(roomId: string): Promise {\n return this.groupCallEventHandler!.waitUntilRoomReadyForGroupCalls(roomId);\n }\n\n /**\n * Get an existing group call for the provided room.\n * @returns The group call or null if it doesn't already exist.\n */\n public getGroupCallForRoom(roomId: string): GroupCall | null {\n return this.groupCallEventHandler!.groupCalls.get(roomId) || null;\n }\n\n /**\n * Get the current sync state.\n * @returns the sync state, which may be null.\n * @see MatrixClient#event:\"sync\"\n */\n public getSyncState(): SyncState | null {\n return this.syncApi?.getSyncState() ?? null;\n }\n\n /**\n * Returns the additional data object associated with\n * the current sync state, or null if there is no\n * such data.\n * Sync errors, if available, are put in the 'error' key of\n * this object.\n */\n public getSyncStateData(): ISyncStateData | null {\n if (!this.syncApi) {\n return null;\n }\n return this.syncApi.getSyncStateData();\n }\n\n /**\n * Whether the initial sync has completed.\n * @returns True if at least one sync has happened.\n */\n public isInitialSyncComplete(): boolean {\n const state = this.getSyncState();\n if (!state) {\n return false;\n }\n return state === SyncState.Prepared || state === SyncState.Syncing;\n }\n\n /**\n * Return whether the client is configured for a guest account.\n * @returns True if this is a guest access_token (or no token is supplied).\n */\n public isGuest(): boolean {\n return this.isGuestAccount;\n }\n\n /**\n * Set whether this client is a guest account. This method is experimental\n * and may change without warning.\n * @param guest - True if this is a guest account.\n */\n public setGuest(guest: boolean): void {\n // EXPERIMENTAL:\n // If the token is a macaroon, it should be encoded in it that it is a 'guest'\n // access token, which means that the SDK can determine this entirely without\n // the dev manually flipping this flag.\n this.isGuestAccount = guest;\n }\n\n /**\n * Return the provided scheduler, if any.\n * @returns The scheduler or undefined\n */\n public getScheduler(): MatrixScheduler | undefined {\n return this.scheduler;\n }\n\n /**\n * Retry a backed off syncing request immediately. This should only be used when\n * the user explicitly attempts to retry their lost connection.\n * Will also retry any outbound to-device messages currently in the queue to be sent\n * (retries of regular outgoing events are handled separately, per-event).\n * @returns True if this resulted in a request being retried.\n */\n public retryImmediately(): boolean {\n // don't await for this promise: we just want to kick it off\n this.toDeviceMessageQueue.sendQueue();\n return this.syncApi?.retryImmediately() ?? false;\n }\n\n /**\n * Return the global notification EventTimelineSet, if any\n *\n * @returns the globl notification EventTimelineSet\n */\n public getNotifTimelineSet(): EventTimelineSet | null {\n return this.notifTimelineSet;\n }\n\n /**\n * Set the global notification EventTimelineSet\n *\n */\n public setNotifTimelineSet(set: EventTimelineSet): void {\n this.notifTimelineSet = set;\n }\n\n /**\n * Gets the capabilities of the homeserver. Always returns an object of\n * capability keys and their options, which may be empty.\n * @param fresh - True to ignore any cached values.\n * @returns Promise which resolves to the capabilities of the homeserver\n * @returns Rejects: with an error response.\n */\n public getCapabilities(fresh = false): Promise {\n const now = new Date().getTime();\n\n if (this.cachedCapabilities && !fresh) {\n if (now < this.cachedCapabilities.expiration) {\n logger.log(\"Returning cached capabilities\");\n return Promise.resolve(this.cachedCapabilities.capabilities);\n }\n }\n\n type Response = {\n capabilities?: ICapabilities;\n };\n return this.http\n .authedRequest(Method.Get, \"/capabilities\")\n .catch((e: Error): Response => {\n // We swallow errors because we need a default object anyhow\n logger.error(e);\n return {};\n })\n .then((r = {}) => {\n const capabilities = r[\"capabilities\"] || {};\n\n // If the capabilities missed the cache, cache it for a shorter amount\n // of time to try and refresh them later.\n const cacheMs = Object.keys(capabilities).length ? CAPABILITIES_CACHE_MS : 60000 + Math.random() * 5000;\n\n this.cachedCapabilities = {\n capabilities,\n expiration: now + cacheMs,\n };\n\n logger.log(\"Caching capabilities: \", capabilities);\n return capabilities;\n });\n }\n\n /**\n * Initialise support for end-to-end encryption in this client, using libolm.\n *\n * You should call this method after creating the matrixclient, but *before*\n * calling `startClient`, if you want to support end-to-end encryption.\n *\n * It will return a Promise which will resolve when the crypto layer has been\n * successfully initialised.\n */\n public async initCrypto(): Promise {\n if (!isCryptoAvailable()) {\n throw new Error(\n `End-to-end encryption not supported in this js-sdk build: did ` +\n `you remember to load the olm library?`,\n );\n }\n\n if (this.cryptoBackend) {\n logger.warn(\"Attempt to re-initialise e2e encryption on MatrixClient\");\n return;\n }\n\n if (!this.cryptoStore) {\n // the cryptostore is provided by sdk.createClient, so this shouldn't happen\n throw new Error(`Cannot enable encryption: no cryptoStore provided`);\n }\n\n logger.log(\"Crypto: Starting up crypto store...\");\n await this.cryptoStore.startup();\n\n // initialise the list of encrypted rooms (whether or not crypto is enabled)\n logger.log(\"Crypto: initialising roomlist...\");\n await this.roomList.init();\n\n const userId = this.getUserId();\n if (userId === null) {\n throw new Error(\n `Cannot enable encryption on MatrixClient with unknown userId: ` +\n `ensure userId is passed in createClient().`,\n );\n }\n if (this.deviceId === null) {\n throw new Error(\n `Cannot enable encryption on MatrixClient with unknown deviceId: ` +\n `ensure deviceId is passed in createClient().`,\n );\n }\n\n const crypto = new Crypto(\n this,\n userId,\n this.deviceId,\n this.store,\n this.cryptoStore,\n this.roomList,\n this.verificationMethods!,\n );\n\n this.reEmitter.reEmit(crypto, [\n CryptoEvent.KeyBackupFailed,\n CryptoEvent.KeyBackupSessionsRemaining,\n CryptoEvent.RoomKeyRequest,\n CryptoEvent.RoomKeyRequestCancellation,\n CryptoEvent.Warning,\n CryptoEvent.DevicesUpdated,\n CryptoEvent.WillUpdateDevices,\n CryptoEvent.DeviceVerificationChanged,\n CryptoEvent.UserTrustStatusChanged,\n CryptoEvent.KeysChanged,\n ]);\n\n logger.log(\"Crypto: initialising crypto object...\");\n await crypto.init({\n exportedOlmDevice: this.exportedOlmDeviceToImport,\n pickleKey: this.pickleKey,\n });\n delete this.exportedOlmDeviceToImport;\n\n this.olmVersion = Crypto.getOlmVersion();\n\n // if crypto initialisation was successful, tell it to attach its event handlers.\n crypto.registerEventHandlers(this as Parameters[0]);\n this.cryptoBackend = this.crypto = crypto;\n\n // upload our keys in the background\n this.crypto.uploadDeviceKeys().catch((e) => {\n // TODO: throwing away this error is a really bad idea.\n logger.error(\"Error uploading device keys\", e);\n });\n }\n\n /**\n * Initialise support for end-to-end encryption in this client, using the rust matrix-sdk-crypto.\n *\n * An alternative to {@link initCrypto}.\n *\n * *WARNING*: this API is very experimental, should not be used in production, and may change without notice!\n * Eventually it will be deprecated and `initCrypto` will do the same thing.\n *\n * @experimental\n *\n * @returns a Promise which will resolve when the crypto layer has been\n * successfully initialised.\n */\n public async initRustCrypto(): Promise {\n if (this.cryptoBackend) {\n logger.warn(\"Attempt to re-initialise e2e encryption on MatrixClient\");\n return;\n }\n\n const userId = this.getUserId();\n if (userId === null) {\n throw new Error(\n `Cannot enable encryption on MatrixClient with unknown userId: ` +\n `ensure userId is passed in createClient().`,\n );\n }\n const deviceId = this.getDeviceId();\n if (deviceId === null) {\n throw new Error(\n `Cannot enable encryption on MatrixClient with unknown deviceId: ` +\n `ensure deviceId is passed in createClient().`,\n );\n }\n\n // importing rust-crypto will download the webassembly, so we delay it until we know it will be\n // needed.\n const RustCrypto = await import(\"./rust-crypto\");\n const rustCrypto = await RustCrypto.initRustCrypto(this.http, userId, deviceId);\n this.cryptoBackend = rustCrypto;\n\n // attach the event listeners needed by RustCrypto\n this.on(RoomMemberEvent.Membership, rustCrypto.onRoomMembership.bind(rustCrypto));\n }\n\n /**\n * Access the crypto API for this client.\n *\n * If end-to-end encryption has been enabled for this client (via {@link initCrypto} or {@link initRustCrypto}),\n * returns an object giving access to the crypto API. Otherwise, returns `undefined`.\n */\n public getCrypto(): CryptoApi | undefined {\n return this.cryptoBackend;\n }\n\n /**\n * Is end-to-end crypto enabled for this client.\n * @returns True if end-to-end is enabled.\n * @deprecated prefer {@link getCrypto}\n */\n public isCryptoEnabled(): boolean {\n return !!this.cryptoBackend;\n }\n\n /**\n * Get the Ed25519 key for this device\n *\n * @returns base64-encoded ed25519 key. Null if crypto is\n * disabled.\n */\n public getDeviceEd25519Key(): string | null {\n return this.crypto?.getDeviceEd25519Key() ?? null;\n }\n\n /**\n * Get the Curve25519 key for this device\n *\n * @returns base64-encoded curve25519 key. Null if crypto is\n * disabled.\n */\n public getDeviceCurve25519Key(): string | null {\n return this.crypto?.getDeviceCurve25519Key() ?? null;\n }\n\n /**\n * @deprecated Does nothing.\n */\n public async uploadKeys(): Promise {\n logger.warn(\"MatrixClient.uploadKeys is deprecated\");\n }\n\n /**\n * Download the keys for a list of users and stores the keys in the session\n * store.\n * @param userIds - The users to fetch.\n * @param forceDownload - Always download the keys even if cached.\n *\n * @returns A promise which resolves to a map userId-\\>deviceId-\\>{@link DeviceInfo}\n */\n public downloadKeys(userIds: string[], forceDownload?: boolean): Promise {\n if (!this.crypto) {\n return Promise.reject(new Error(\"End-to-end encryption disabled\"));\n }\n return this.crypto.downloadKeys(userIds, forceDownload);\n }\n\n /**\n * Get the stored device keys for a user id\n *\n * @param userId - the user to list keys for.\n *\n * @returns list of devices\n */\n public getStoredDevicesForUser(userId: string): DeviceInfo[] {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getStoredDevicesForUser(userId) || [];\n }\n\n /**\n * Get the stored device key for a user id and device id\n *\n * @param userId - the user to list keys for.\n * @param deviceId - unique identifier for the device\n *\n * @returns device or null\n */\n public getStoredDevice(userId: string, deviceId: string): DeviceInfo | null {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getStoredDevice(userId, deviceId) || null;\n }\n\n /**\n * Mark the given device as verified\n *\n * @param userId - owner of the device\n * @param deviceId - unique identifier for the device or user's\n * cross-signing public key ID.\n *\n * @param verified - whether to mark the device as verified. defaults\n * to 'true'.\n *\n * @returns\n *\n * @remarks\n * Fires {@link CryptoEvent#DeviceVerificationChanged}\n */\n public setDeviceVerified(userId: string, deviceId: string, verified = true): Promise {\n const prom = this.setDeviceVerification(userId, deviceId, verified, null, null);\n\n // if one of the user's own devices is being marked as verified / unverified,\n // check the key backup status, since whether or not we use this depends on\n // whether it has a signature from a verified device\n if (userId == this.credentials.userId) {\n this.checkKeyBackup();\n }\n return prom;\n }\n\n /**\n * Mark the given device as blocked/unblocked\n *\n * @param userId - owner of the device\n * @param deviceId - unique identifier for the device or user's\n * cross-signing public key ID.\n *\n * @param blocked - whether to mark the device as blocked. defaults\n * to 'true'.\n *\n * @returns\n *\n * @remarks\n * Fires {@link CryptoEvent.DeviceVerificationChanged}\n */\n public setDeviceBlocked(userId: string, deviceId: string, blocked = true): Promise {\n return this.setDeviceVerification(userId, deviceId, null, blocked, null);\n }\n\n /**\n * Mark the given device as known/unknown\n *\n * @param userId - owner of the device\n * @param deviceId - unique identifier for the device or user's\n * cross-signing public key ID.\n *\n * @param known - whether to mark the device as known. defaults\n * to 'true'.\n *\n * @returns\n *\n * @remarks\n * Fires {@link CryptoEvent#DeviceVerificationChanged}\n */\n public setDeviceKnown(userId: string, deviceId: string, known = true): Promise {\n return this.setDeviceVerification(userId, deviceId, null, null, known);\n }\n\n private async setDeviceVerification(\n userId: string,\n deviceId: string,\n verified?: boolean | null,\n blocked?: boolean | null,\n known?: boolean | null,\n ): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n await this.crypto.setDeviceVerification(userId, deviceId, verified, blocked, known);\n }\n\n /**\n * Request a key verification from another user, using a DM.\n *\n * @param userId - the user to request verification with\n * @param roomId - the room to use for verification\n *\n * @returns resolves to a VerificationRequest\n * when the request has been sent to the other party.\n */\n public requestVerificationDM(userId: string, roomId: string): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.requestVerificationDM(userId, roomId);\n }\n\n /**\n * Finds a DM verification request that is already in progress for the given room id\n *\n * @param roomId - the room to use for verification\n *\n * @returns the VerificationRequest that is in progress, if any\n */\n public findVerificationRequestDMInProgress(roomId: string): VerificationRequest | undefined {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.findVerificationRequestDMInProgress(roomId);\n }\n\n /**\n * Returns all to-device verification requests that are already in progress for the given user id\n *\n * @param userId - the ID of the user to query\n *\n * @returns the VerificationRequests that are in progress\n */\n public getVerificationRequestsToDeviceInProgress(userId: string): VerificationRequest[] {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getVerificationRequestsToDeviceInProgress(userId);\n }\n\n /**\n * Request a key verification from another user.\n *\n * @param userId - the user to request verification with\n * @param devices - array of device IDs to send requests to. Defaults to\n * all devices owned by the user\n *\n * @returns resolves to a VerificationRequest\n * when the request has been sent to the other party.\n */\n public requestVerification(userId: string, devices?: string[]): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.requestVerification(userId, devices);\n }\n\n /**\n * Begin a key verification.\n *\n * @param method - the verification method to use\n * @param userId - the user to verify keys with\n * @param deviceId - the device to verify\n *\n * @returns a verification object\n * @deprecated Use `requestVerification` instead.\n */\n public beginKeyVerification(method: string, userId: string, deviceId: string): Verification {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.beginKeyVerification(method, userId, deviceId);\n }\n\n public checkSecretStorageKey(key: Uint8Array, info: SecretStorageKeyDescription): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.checkSecretStorageKey(key, info);\n }\n\n /**\n * Set the global override for whether the client should ever send encrypted\n * messages to unverified devices. This provides the default for rooms which\n * do not specify a value.\n *\n * @param value - whether to blacklist all unverified devices by default\n *\n * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}:\n *\n * ```javascript\n * client.getCrypto().globalBlacklistUnverifiedDevices = value;\n * ```\n */\n public setGlobalBlacklistUnverifiedDevices(value: boolean): boolean {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n this.cryptoBackend.globalBlacklistUnverifiedDevices = value;\n return value;\n }\n\n /**\n * @returns whether to blacklist all unverified devices by default\n *\n * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}:\n *\n * ```javascript\n * value = client.getCrypto().globalBlacklistUnverifiedDevices;\n * ```\n */\n public getGlobalBlacklistUnverifiedDevices(): boolean {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.cryptoBackend.globalBlacklistUnverifiedDevices;\n }\n\n /**\n * Set whether sendMessage in a room with unknown and unverified devices\n * should throw an error and not send them message. This has 'Global' for\n * symmetry with setGlobalBlacklistUnverifiedDevices but there is currently\n * no room-level equivalent for this setting.\n *\n * This API is currently UNSTABLE and may change or be removed without notice.\n *\n * @param value - whether error on unknown devices\n *\n * @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}:\n *\n * ```ts\n * client.getCrypto().globalBlacklistUnverifiedDevices = value;\n * ```\n */\n public setGlobalErrorOnUnknownDevices(value: boolean): void {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n this.cryptoBackend.globalErrorOnUnknownDevices = value;\n }\n\n /**\n * @returns whether to error on unknown devices\n *\n * This API is currently UNSTABLE and may change or be removed without notice.\n */\n public getGlobalErrorOnUnknownDevices(): boolean {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.cryptoBackend.globalErrorOnUnknownDevices;\n }\n\n /**\n * Get the user's cross-signing key ID.\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @param type - The type of key to get the ID of. One of\n * \"master\", \"self_signing\", or \"user_signing\". Defaults to \"master\".\n *\n * @returns the key ID\n */\n public getCrossSigningId(type: CrossSigningKey | string = CrossSigningKey.Master): string | null {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getCrossSigningId(type);\n }\n\n /**\n * Get the cross signing information for a given user.\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @param userId - the user ID to get the cross-signing info for.\n *\n * @returns the cross signing information for the user.\n */\n public getStoredCrossSigningForUser(userId: string): CrossSigningInfo | null {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getStoredCrossSigningForUser(userId);\n }\n\n /**\n * Check whether a given user is trusted.\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @param userId - The ID of the user to check.\n */\n public checkUserTrust(userId: string): UserTrustLevel {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.cryptoBackend.checkUserTrust(userId);\n }\n\n /**\n * Check whether a given device is trusted.\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @param userId - The ID of the user whose devices is to be checked.\n * @param deviceId - The ID of the device to check\n */\n public checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.cryptoBackend.checkDeviceTrust(userId, deviceId);\n }\n\n /**\n * Check whether one of our own devices is cross-signed by our\n * user's stored keys, regardless of whether we trust those keys yet.\n *\n * @param deviceId - The ID of the device to check\n *\n * @returns true if the device is cross-signed\n */\n public checkIfOwnDeviceCrossSigned(deviceId: string): boolean {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.checkIfOwnDeviceCrossSigned(deviceId);\n }\n\n /**\n * Check the copy of our cross-signing key that we have in the device list and\n * see if we can get the private key. If so, mark it as trusted.\n * @param opts - ICheckOwnCrossSigningTrustOpts object\n */\n public checkOwnCrossSigningTrust(opts?: ICheckOwnCrossSigningTrustOpts): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.checkOwnCrossSigningTrust(opts);\n }\n\n /**\n * Checks that a given cross-signing private key matches a given public key.\n * This can be used by the getCrossSigningKey callback to verify that the\n * private key it is about to supply is the one that was requested.\n * @param privateKey - The private key\n * @param expectedPublicKey - The public key\n * @returns true if the key matches, otherwise false\n */\n public checkCrossSigningPrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.checkCrossSigningPrivateKey(privateKey, expectedPublicKey);\n }\n\n // deprecated: use requestVerification instead\n public legacyDeviceVerification(\n userId: string,\n deviceId: string,\n method: VerificationMethod,\n ): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.legacyDeviceVerification(userId, deviceId, method);\n }\n\n /**\n * Perform any background tasks that can be done before a message is ready to\n * send, in order to speed up sending of the message.\n * @param room - the room the event is in\n *\n * @deprecated Prefer {@link CryptoApi.prepareToEncrypt | `CryptoApi.prepareToEncrypt`}:\n *\n * ```javascript\n * client.getCrypto().prepareToEncrypt(room);\n * ```\n */\n public prepareToEncrypt(room: Room): void {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n this.cryptoBackend.prepareToEncrypt(room);\n }\n\n /**\n * Checks if the user has previously published cross-signing keys\n *\n * This means downloading the devicelist for the user and checking if the list includes\n * the cross-signing pseudo-device.\n *\n * @deprecated Prefer {@link CryptoApi.userHasCrossSigningKeys | `CryptoApi.userHasCrossSigningKeys`}:\n *\n * ```javascript\n * result = client.getCrypto().userHasCrossSigningKeys();\n * ```\n */\n public userHasCrossSigningKeys(): Promise {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.cryptoBackend.userHasCrossSigningKeys();\n }\n\n /**\n * Checks whether cross signing:\n * - is enabled on this account and trusted by this device\n * - has private keys either cached locally or stored in secret storage\n *\n * If this function returns false, bootstrapCrossSigning() can be used\n * to fix things such that it returns true. That is to say, after\n * bootstrapCrossSigning() completes successfully, this function should\n * return true.\n * @returns True if cross-signing is ready to be used on this device\n */\n public isCrossSigningReady(): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.isCrossSigningReady();\n }\n\n /**\n * Bootstrap cross-signing by creating keys if needed. If everything is already\n * set up, then no changes are made, so this is safe to run to ensure\n * cross-signing is ready for use.\n *\n * This function:\n * - creates new cross-signing keys if they are not found locally cached nor in\n * secret storage (if it has been setup)\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n */\n public bootstrapCrossSigning(opts: IBootstrapCrossSigningOpts): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.bootstrapCrossSigning(opts);\n }\n\n /**\n * Whether to trust a others users signatures of their devices.\n * If false, devices will only be considered 'verified' if we have\n * verified that device individually (effectively disabling cross-signing).\n *\n * Default: true\n *\n * @returns True if trusting cross-signed devices\n */\n public getCryptoTrustCrossSignedDevices(): boolean {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getCryptoTrustCrossSignedDevices();\n }\n\n /**\n * See getCryptoTrustCrossSignedDevices\n *\n * @param val - True to trust cross-signed devices\n */\n public setCryptoTrustCrossSignedDevices(val: boolean): void {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n this.crypto.setCryptoTrustCrossSignedDevices(val);\n }\n\n /**\n * Counts the number of end to end session keys that are waiting to be backed up\n * @returns Promise which resolves to the number of sessions requiring backup\n */\n public countSessionsNeedingBackup(): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.countSessionsNeedingBackup();\n }\n\n /**\n * Get information about the encryption of an event\n *\n * @param event - event to be checked\n * @returns The event information.\n */\n public getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.cryptoBackend.getEventEncryptionInfo(event);\n }\n\n /**\n * Create a recovery key from a user-supplied passphrase.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param password - Passphrase string that can be entered by the user\n * when restoring the backup as an alternative to entering the recovery key.\n * Optional.\n * @returns Object with public key metadata, encoded private\n * recovery key which should be disposed of after displaying to the user,\n * and raw private key to avoid round tripping if needed.\n */\n public createRecoveryKeyFromPassphrase(password?: string): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.createRecoveryKeyFromPassphrase(password);\n }\n\n /**\n * Checks whether secret storage:\n * - is enabled on this account\n * - is storing cross-signing private keys\n * - is storing session backup key (if enabled)\n *\n * If this function returns false, bootstrapSecretStorage() can be used\n * to fix things such that it returns true. That is to say, after\n * bootstrapSecretStorage() completes successfully, this function should\n * return true.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @returns True if secret storage is ready to be used on this device\n */\n public isSecretStorageReady(): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.isSecretStorageReady();\n }\n\n /**\n * Bootstrap Secure Secret Storage if needed by creating a default key. If everything is\n * already set up, then no changes are made, so this is safe to run to ensure secret\n * storage is ready for use.\n *\n * This function\n * - creates a new Secure Secret Storage key if no default key exists\n * - if a key backup exists, it is migrated to store the key in the Secret\n * Storage\n * - creates a backup if none exists, and one is requested\n * - migrates Secure Secret Storage to use the latest algorithm, if an outdated\n * algorithm is found\n *\n */\n public bootstrapSecretStorage(opts: ICreateSecretStorageOpts): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.bootstrapSecretStorage(opts);\n }\n\n /**\n * Add a key for encrypting secrets.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param algorithm - the algorithm used by the key\n * @param opts - the options for the algorithm. The properties used\n * depend on the algorithm given.\n * @param keyName - the name of the key. If not given, a random name will be generated.\n *\n * @returns An object with:\n * keyId: the ID of the key\n * keyInfo: details about the key (iv, mac, passphrase)\n */\n public addSecretStorageKey(\n algorithm: string,\n opts: IAddSecretStorageKeyOpts,\n keyName?: string,\n ): Promise<{ keyId: string; keyInfo: SecretStorageKeyDescription }> {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.addSecretStorageKey(algorithm, opts, keyName);\n }\n\n /**\n * Check whether we have a key with a given ID.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param keyId - The ID of the key to check\n * for. Defaults to the default key ID if not provided.\n * @returns Whether we have the key.\n */\n public hasSecretStorageKey(keyId?: string): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.hasSecretStorageKey(keyId);\n }\n\n /**\n * Store an encrypted secret on the server.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param name - The name of the secret\n * @param secret - The secret contents.\n * @param keys - The IDs of the keys to use to encrypt the secret or null/undefined\n * to use the default (will throw if no default key is set).\n */\n public storeSecret(name: string, secret: string, keys?: string[]): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.storeSecret(name, secret, keys);\n }\n\n /**\n * Get a secret from storage.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param name - the name of the secret\n *\n * @returns the contents of the secret\n */\n public getSecret(name: string): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getSecret(name);\n }\n\n /**\n * Check if a secret is stored on the server.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param name - the name of the secret\n * @returns map of key name to key info the secret is encrypted\n * with, or null if it is not present or not encrypted with a trusted\n * key\n */\n public isSecretStored(name: string): Promise | null> {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.isSecretStored(name);\n }\n\n /**\n * Request a secret from another device.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param name - the name of the secret to request\n * @param devices - the devices to request the secret from\n *\n * @returns the secret request object\n */\n public requestSecret(name: string, devices: string[]): ISecretRequest {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.requestSecret(name, devices);\n }\n\n /**\n * Get the current default key ID for encrypting secrets.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @returns The default key ID or null if no default key ID is set\n */\n public getDefaultSecretStorageKeyId(): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.getDefaultSecretStorageKeyId();\n }\n\n /**\n * Set the current default key ID for encrypting secrets.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param keyId - The new default key ID\n */\n public setDefaultSecretStorageKeyId(keyId: string): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.setDefaultSecretStorageKeyId(keyId);\n }\n\n /**\n * Checks that a given secret storage private key matches a given public key.\n * This can be used by the getSecretStorageKey callback to verify that the\n * private key it is about to supply is the one that was requested.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param privateKey - The private key\n * @param expectedPublicKey - The public key\n * @returns true if the key matches, otherwise false\n */\n public checkSecretStoragePrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.checkSecretStoragePrivateKey(privateKey, expectedPublicKey);\n }\n\n /**\n * Get e2e information on the device that sent an event\n *\n * @param event - event to be checked\n */\n public async getEventSenderDeviceInfo(event: MatrixEvent): Promise {\n if (!this.crypto) {\n return null;\n }\n return this.crypto.getEventSenderDeviceInfo(event);\n }\n\n /**\n * Check if the sender of an event is verified\n *\n * @param event - event to be checked\n *\n * @returns true if the sender of this event has been verified using\n * {@link MatrixClient#setDeviceVerified}.\n */\n public async isEventSenderVerified(event: MatrixEvent): Promise {\n const device = await this.getEventSenderDeviceInfo(event);\n if (!device) {\n return false;\n }\n return device.isVerified();\n }\n\n /**\n * Get outgoing room key request for this event if there is one.\n * @param event - The event to check for\n *\n * @returns A room key request, or null if there is none\n */\n public getOutgoingRoomKeyRequest(event: MatrixEvent): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-End encryption disabled\");\n }\n const wireContent = event.getWireContent();\n const requestBody: IRoomKeyRequestBody = {\n session_id: wireContent.session_id,\n sender_key: wireContent.sender_key,\n algorithm: wireContent.algorithm,\n room_id: event.getRoomId()!,\n };\n if (!requestBody.session_id || !requestBody.sender_key || !requestBody.algorithm || !requestBody.room_id) {\n return Promise.resolve(null);\n }\n return this.crypto.cryptoStore.getOutgoingRoomKeyRequest(requestBody);\n }\n\n /**\n * Cancel a room key request for this event if one is ongoing and resend the\n * request.\n * @param event - event of which to cancel and resend the room\n * key request.\n * @returns A promise that will resolve when the key request is queued\n */\n public cancelAndResendEventRoomKeyRequest(event: MatrixEvent): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-End encryption disabled\");\n }\n return event.cancelAndResendKeyRequest(this.crypto, this.getUserId()!);\n }\n\n /**\n * Enable end-to-end encryption for a room. This does not modify room state.\n * Any messages sent before the returned promise resolves will be sent unencrypted.\n * @param roomId - The room ID to enable encryption in.\n * @param config - The encryption config for the room.\n * @returns A promise that will resolve when encryption is set up.\n */\n public setRoomEncryption(roomId: string, config: IRoomEncryption): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-End encryption disabled\");\n }\n return this.crypto.setRoomEncryption(roomId, config);\n }\n\n /**\n * Whether encryption is enabled for a room.\n * @param roomId - the room id to query.\n * @returns whether encryption is enabled.\n */\n public isRoomEncrypted(roomId: string): boolean {\n const room = this.getRoom(roomId);\n if (!room) {\n // we don't know about this room, so can't determine if it should be\n // encrypted. Let's assume not.\n return false;\n }\n\n // if there is an 'm.room.encryption' event in this room, it should be\n // encrypted (independently of whether we actually support encryption)\n const ev = room.currentState.getStateEvents(EventType.RoomEncryption, \"\");\n if (ev) {\n return true;\n }\n\n // we don't have an m.room.encrypted event, but that might be because\n // the server is hiding it from us. Check the store to see if it was\n // previously encrypted.\n return this.roomList.isRoomEncrypted(roomId);\n }\n\n /**\n * Encrypts and sends a given object via Olm to-device messages to a given\n * set of devices.\n *\n * @param userDeviceMap - mapping from userId to deviceInfo\n *\n * @param payload - fields to include in the encrypted payload\n *\n * @returns Promise which\n * resolves once the message has been encrypted and sent to the given\n * userDeviceMap, and returns the `{ contentMap, deviceInfoByDeviceId }`\n * of the successfully sent messages.\n */\n public encryptAndSendToDevices(userDeviceInfoArr: IOlmDevice[], payload: object): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-End encryption disabled\");\n }\n return this.crypto.encryptAndSendToDevices(userDeviceInfoArr, payload);\n }\n\n /**\n * Forces the current outbound group session to be discarded such\n * that another one will be created next time an event is sent.\n *\n * @param roomId - The ID of the room to discard the session for\n *\n * @deprecated Prefer {@link CryptoApi.forceDiscardSession | `CryptoApi.forceDiscardSession`}:\n *\n */\n public forceDiscardSession(roomId: string): void {\n if (!this.cryptoBackend) {\n throw new Error(\"End-to-End encryption disabled\");\n }\n this.cryptoBackend.forceDiscardSession(roomId);\n }\n\n /**\n * Get a list containing all of the room keys\n *\n * This should be encrypted before returning it to the user.\n *\n * @returns a promise which resolves to a list of session export objects\n *\n * @deprecated Prefer {@link CryptoApi.exportRoomKeys | `CryptoApi.exportRoomKeys`}:\n *\n * ```javascript\n * sessionData = await client.getCrypto().exportRoomKeys();\n * ```\n */\n public exportRoomKeys(): Promise {\n if (!this.cryptoBackend) {\n return Promise.reject(new Error(\"End-to-end encryption disabled\"));\n }\n return this.cryptoBackend.exportRoomKeys();\n }\n\n /**\n * Import a list of room keys previously exported by exportRoomKeys\n *\n * @param keys - a list of session export objects\n *\n * @returns a promise which resolves when the keys have been imported\n */\n public importRoomKeys(keys: IMegolmSessionData[], opts?: IImportRoomKeysOpts): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.importRoomKeys(keys, opts);\n }\n\n /**\n * Force a re-check of the local key backup status against\n * what's on the server.\n *\n * @returns Object with backup info (as returned by\n * getKeyBackupVersion) in backupInfo and\n * trust information (as returned by isKeyBackupTrusted)\n * in trustInfo.\n */\n public checkKeyBackup(): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.backupManager.checkKeyBackup();\n }\n\n /**\n * Get information about the current key backup.\n * @returns Information object from API or null\n */\n public async getKeyBackupVersion(): Promise {\n let res: IKeyBackupInfo;\n try {\n res = await this.http.authedRequest(\n Method.Get,\n \"/room_keys/version\",\n undefined,\n undefined,\n { prefix: ClientPrefix.V3 },\n );\n } catch (e) {\n if ((e).errcode === \"M_NOT_FOUND\") {\n return null;\n } else {\n throw e;\n }\n }\n BackupManager.checkBackupVersion(res);\n return res;\n }\n\n /**\n * @param info - key backup info dict from getKeyBackupVersion()\n */\n public isKeyBackupTrusted(info: IKeyBackupInfo): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.backupManager.isKeyBackupTrusted(info);\n }\n\n /**\n * @returns true if the client is configured to back up keys to\n * the server, otherwise false. If we haven't completed a successful check\n * of key backup status yet, returns null.\n */\n public getKeyBackupEnabled(): boolean | null {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n return this.crypto.backupManager.getKeyBackupEnabled();\n }\n\n /**\n * Enable backing up of keys, using data previously returned from\n * getKeyBackupVersion.\n *\n * @param info - Backup information object as returned by getKeyBackupVersion\n * @returns Promise which resolves when complete.\n */\n public enableKeyBackup(info: IKeyBackupInfo): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n return this.crypto.backupManager.enableKeyBackup(info);\n }\n\n /**\n * Disable backing up of keys.\n */\n public disableKeyBackup(): void {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n this.crypto.backupManager.disableKeyBackup();\n }\n\n /**\n * Set up the data required to create a new backup version. The backup version\n * will not be created and enabled until createKeyBackupVersion is called.\n *\n * @param password - Passphrase string that can be entered by the user\n * when restoring the backup as an alternative to entering the recovery key.\n * Optional.\n *\n * @returns Object that can be passed to createKeyBackupVersion and\n * additionally has a 'recovery_key' member with the user-facing recovery key string.\n */\n public async prepareKeyBackupVersion(\n password?: string | Uint8Array | null,\n opts: IKeyBackupPrepareOpts = { secureSecretStorage: false },\n ): Promise> {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n // eslint-disable-next-line camelcase\n const { algorithm, auth_data, recovery_key, privateKey } =\n await this.crypto.backupManager.prepareKeyBackupVersion(password);\n\n if (opts.secureSecretStorage) {\n await this.storeSecret(\"m.megolm_backup.v1\", encodeBase64(privateKey));\n logger.info(\"Key backup private key stored in secret storage\");\n }\n\n return {\n algorithm,\n /* eslint-disable camelcase */\n auth_data,\n recovery_key,\n /* eslint-enable camelcase */\n };\n }\n\n /**\n * Check whether the key backup private key is stored in secret storage.\n * @returns map of key name to key info the secret is\n * encrypted with, or null if it is not present or not encrypted with a\n * trusted key\n */\n public isKeyBackupKeyStored(): Promise | null> {\n return Promise.resolve(this.isSecretStored(\"m.megolm_backup.v1\"));\n }\n\n /**\n * Create a new key backup version and enable it, using the information return\n * from prepareKeyBackupVersion.\n *\n * @param info - Info object from prepareKeyBackupVersion\n * @returns Object with 'version' param indicating the version created\n */\n public async createKeyBackupVersion(info: IKeyBackupInfo): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n await this.crypto.backupManager.createKeyBackupVersion(info);\n\n const data = {\n algorithm: info.algorithm,\n auth_data: info.auth_data,\n };\n\n // Sign the backup auth data with the device key for backwards compat with\n // older devices with cross-signing. This can probably go away very soon in\n // favour of just signing with the cross-singing master key.\n // XXX: Private member access\n await this.crypto.signObject(data.auth_data);\n\n if (\n this.cryptoCallbacks.getCrossSigningKey &&\n // XXX: Private member access\n this.crypto.crossSigningInfo.getId()\n ) {\n // now also sign the auth data with the cross-signing master key\n // we check for the callback explicitly here because we still want to be able\n // to create an un-cross-signed key backup if there is a cross-signing key but\n // no callback supplied.\n // XXX: Private member access\n await this.crypto.crossSigningInfo.signObject(data.auth_data, \"master\");\n }\n\n const res = await this.http.authedRequest(Method.Post, \"/room_keys/version\", undefined, data, {\n prefix: ClientPrefix.V3,\n });\n\n // We could assume everything's okay and enable directly, but this ensures\n // we run the same signature verification that will be used for future\n // sessions.\n await this.checkKeyBackup();\n if (!this.getKeyBackupEnabled()) {\n logger.error(\"Key backup not usable even though we just created it\");\n }\n\n return res;\n }\n\n public async deleteKeyBackupVersion(version: string): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n // If we're currently backing up to this backup... stop.\n // (We start using it automatically in createKeyBackupVersion\n // so this is symmetrical).\n if (this.crypto.backupManager.version) {\n this.crypto.backupManager.disableKeyBackup();\n }\n\n const path = utils.encodeUri(\"/room_keys/version/$version\", {\n $version: version,\n });\n\n await this.http.authedRequest(Method.Delete, path, undefined, undefined, { prefix: ClientPrefix.V3 });\n }\n\n private makeKeyBackupPath(roomId: undefined, sessionId: undefined, version?: string): IKeyBackupPath;\n private makeKeyBackupPath(roomId: string, sessionId: undefined, version?: string): IKeyBackupPath;\n private makeKeyBackupPath(roomId: string, sessionId: string, version?: string): IKeyBackupPath;\n private makeKeyBackupPath(roomId?: string, sessionId?: string, version?: string): IKeyBackupPath {\n let path: string;\n if (sessionId !== undefined) {\n path = utils.encodeUri(\"/room_keys/keys/$roomId/$sessionId\", {\n $roomId: roomId!,\n $sessionId: sessionId,\n });\n } else if (roomId !== undefined) {\n path = utils.encodeUri(\"/room_keys/keys/$roomId\", {\n $roomId: roomId,\n });\n } else {\n path = \"/room_keys/keys\";\n }\n const queryData = version === undefined ? undefined : { version };\n return { path, queryData };\n }\n\n /**\n * Back up session keys to the homeserver.\n * @param roomId - ID of the room that the keys are for Optional.\n * @param sessionId - ID of the session that the keys are for Optional.\n * @param version - backup version Optional.\n * @param data - Object keys to send\n * @returns a promise that will resolve when the keys\n * are uploaded\n */\n public sendKeyBackup(\n roomId: undefined,\n sessionId: undefined,\n version: string | undefined,\n data: IKeyBackup,\n ): Promise;\n public sendKeyBackup(\n roomId: string,\n sessionId: undefined,\n version: string | undefined,\n data: IKeyBackup,\n ): Promise;\n public sendKeyBackup(\n roomId: string,\n sessionId: string,\n version: string | undefined,\n data: IKeyBackup,\n ): Promise;\n public async sendKeyBackup(\n roomId: string | undefined,\n sessionId: string | undefined,\n version: string | undefined,\n data: IKeyBackup,\n ): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n const path = this.makeKeyBackupPath(roomId!, sessionId!, version);\n await this.http.authedRequest(Method.Put, path.path, path.queryData, data, { prefix: ClientPrefix.V3 });\n }\n\n /**\n * Marks all group sessions as needing to be backed up and schedules them to\n * upload in the background as soon as possible.\n */\n public async scheduleAllGroupSessionsForBackup(): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n await this.crypto.backupManager.scheduleAllGroupSessionsForBackup();\n }\n\n /**\n * Marks all group sessions as needing to be backed up without scheduling\n * them to upload in the background.\n * @returns Promise which resolves to the number of sessions requiring a backup.\n */\n public flagAllGroupSessionsForBackup(): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n return this.crypto.backupManager.flagAllGroupSessionsForBackup();\n }\n\n public isValidRecoveryKey(recoveryKey: string): boolean {\n try {\n decodeRecoveryKey(recoveryKey);\n return true;\n } catch (e) {\n return false;\n }\n }\n\n /**\n * Get the raw key for a key backup from the password\n * Used when migrating key backups into SSSS\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @param password - Passphrase\n * @param backupInfo - Backup metadata from `checkKeyBackup`\n * @returns key backup key\n */\n public keyBackupKeyFromPassword(password: string, backupInfo: IKeyBackupInfo): Promise {\n return keyFromAuthData(backupInfo.auth_data, password);\n }\n\n /**\n * Get the raw key for a key backup from the recovery key\n * Used when migrating key backups into SSSS\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @param recoveryKey - The recovery key\n * @returns key backup key\n */\n public keyBackupKeyFromRecoveryKey(recoveryKey: string): Uint8Array {\n return decodeRecoveryKey(recoveryKey);\n }\n\n /**\n * Restore from an existing key backup via a passphrase.\n *\n * @param password - Passphrase\n * @param targetRoomId - Room ID to target a specific room.\n * Restores all rooms if omitted.\n * @param targetSessionId - Session ID to target a specific session.\n * Restores all sessions if omitted.\n * @param backupInfo - Backup metadata from `checkKeyBackup`\n * @param opts - Optional params such as callbacks\n * @returns Status of restoration with `total` and `imported`\n * key counts.\n */\n public async restoreKeyBackupWithPassword(\n password: string,\n targetRoomId: undefined,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts: IKeyBackupRestoreOpts,\n ): Promise;\n public async restoreKeyBackupWithPassword(\n password: string,\n targetRoomId: string,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts: IKeyBackupRestoreOpts,\n ): Promise;\n public async restoreKeyBackupWithPassword(\n password: string,\n targetRoomId: string,\n targetSessionId: string,\n backupInfo: IKeyBackupInfo,\n opts: IKeyBackupRestoreOpts,\n ): Promise;\n public async restoreKeyBackupWithPassword(\n password: string,\n targetRoomId: string | undefined,\n targetSessionId: string | undefined,\n backupInfo: IKeyBackupInfo,\n opts: IKeyBackupRestoreOpts,\n ): Promise {\n const privKey = await keyFromAuthData(backupInfo.auth_data, password);\n return this.restoreKeyBackup(privKey, targetRoomId!, targetSessionId!, backupInfo, opts);\n }\n\n /**\n * Restore from an existing key backup via a private key stored in secret\n * storage.\n *\n * @param backupInfo - Backup metadata from `checkKeyBackup`\n * @param targetRoomId - Room ID to target a specific room.\n * Restores all rooms if omitted.\n * @param targetSessionId - Session ID to target a specific session.\n * Restores all sessions if omitted.\n * @param opts - Optional params such as callbacks\n * @returns Status of restoration with `total` and `imported`\n * key counts.\n */\n public async restoreKeyBackupWithSecretStorage(\n backupInfo: IKeyBackupInfo,\n targetRoomId?: string,\n targetSessionId?: string,\n opts?: IKeyBackupRestoreOpts,\n ): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n const storedKey = await this.getSecret(\"m.megolm_backup.v1\");\n\n // ensure that the key is in the right format. If not, fix the key and\n // store the fixed version\n const fixedKey = fixBackupKey(storedKey);\n if (fixedKey) {\n const keys = await this.crypto.getSecretStorageKey();\n await this.storeSecret(\"m.megolm_backup.v1\", fixedKey, [keys![0]]);\n }\n\n const privKey = decodeBase64(fixedKey || storedKey!);\n return this.restoreKeyBackup(privKey, targetRoomId!, targetSessionId!, backupInfo, opts);\n }\n\n /**\n * Restore from an existing key backup via an encoded recovery key.\n *\n * @param recoveryKey - Encoded recovery key\n * @param targetRoomId - Room ID to target a specific room.\n * Restores all rooms if omitted.\n * @param targetSessionId - Session ID to target a specific session.\n * Restores all sessions if omitted.\n * @param backupInfo - Backup metadata from `checkKeyBackup`\n * @param opts - Optional params such as callbacks\n\n * @returns Status of restoration with `total` and `imported`\n * key counts.\n */\n public restoreKeyBackupWithRecoveryKey(\n recoveryKey: string,\n targetRoomId: undefined,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n public restoreKeyBackupWithRecoveryKey(\n recoveryKey: string,\n targetRoomId: string,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n public restoreKeyBackupWithRecoveryKey(\n recoveryKey: string,\n targetRoomId: string,\n targetSessionId: string,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n public restoreKeyBackupWithRecoveryKey(\n recoveryKey: string,\n targetRoomId: string | undefined,\n targetSessionId: string | undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise {\n const privKey = decodeRecoveryKey(recoveryKey);\n return this.restoreKeyBackup(privKey, targetRoomId!, targetSessionId!, backupInfo, opts);\n }\n\n public async restoreKeyBackupWithCache(\n targetRoomId: undefined,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n public async restoreKeyBackupWithCache(\n targetRoomId: string,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n public async restoreKeyBackupWithCache(\n targetRoomId: string,\n targetSessionId: string,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n public async restoreKeyBackupWithCache(\n targetRoomId: string | undefined,\n targetSessionId: string | undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n const privKey = await this.crypto.getSessionBackupPrivateKey();\n if (!privKey) {\n throw new Error(\"Couldn't get key\");\n }\n return this.restoreKeyBackup(privKey, targetRoomId!, targetSessionId!, backupInfo, opts);\n }\n\n private async restoreKeyBackup(\n privKey: ArrayLike,\n targetRoomId: undefined,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n private async restoreKeyBackup(\n privKey: ArrayLike,\n targetRoomId: string,\n targetSessionId: undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n private async restoreKeyBackup(\n privKey: ArrayLike,\n targetRoomId: string,\n targetSessionId: string,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise;\n private async restoreKeyBackup(\n privKey: ArrayLike,\n targetRoomId: string | undefined,\n targetSessionId: string | undefined,\n backupInfo: IKeyBackupInfo,\n opts?: IKeyBackupRestoreOpts,\n ): Promise {\n const cacheCompleteCallback = opts?.cacheCompleteCallback;\n const progressCallback = opts?.progressCallback;\n\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n let totalKeyCount = 0;\n let keys: IMegolmSessionData[] = [];\n\n const path = this.makeKeyBackupPath(targetRoomId!, targetSessionId!, backupInfo.version);\n\n const algorithm = await BackupManager.makeAlgorithm(backupInfo, async () => {\n return privKey;\n });\n\n const untrusted = algorithm.untrusted;\n\n try {\n // If the pubkey computed from the private data we've been given\n // doesn't match the one in the auth_data, the user has entered\n // a different recovery key / the wrong passphrase.\n if (!(await algorithm.keyMatches(privKey))) {\n return Promise.reject(new MatrixError({ errcode: MatrixClient.RESTORE_BACKUP_ERROR_BAD_KEY }));\n }\n\n // Cache the key, if possible.\n // This is async.\n this.crypto\n .storeSessionBackupPrivateKey(privKey)\n .catch((e) => {\n logger.warn(\"Error caching session backup key:\", e);\n })\n .then(cacheCompleteCallback);\n\n if (progressCallback) {\n progressCallback({\n stage: \"fetch\",\n });\n }\n\n const res = await this.http.authedRequest(\n Method.Get,\n path.path,\n path.queryData,\n undefined,\n { prefix: ClientPrefix.V3 },\n );\n\n if ((res as IRoomsKeysResponse).rooms) {\n const rooms = (res as IRoomsKeysResponse).rooms;\n for (const [roomId, roomData] of Object.entries(rooms)) {\n if (!roomData.sessions) continue;\n\n totalKeyCount += Object.keys(roomData.sessions).length;\n const roomKeys = await algorithm.decryptSessions(roomData.sessions);\n for (const k of roomKeys) {\n k.room_id = roomId;\n keys.push(k);\n }\n }\n } else if ((res as IRoomKeysResponse).sessions) {\n const sessions = (res as IRoomKeysResponse).sessions;\n totalKeyCount = Object.keys(sessions).length;\n keys = await algorithm.decryptSessions(sessions);\n for (const k of keys) {\n k.room_id = targetRoomId!;\n }\n } else {\n totalKeyCount = 1;\n try {\n const [key] = await algorithm.decryptSessions({\n [targetSessionId!]: res as IKeyBackupSession,\n });\n key.room_id = targetRoomId!;\n key.session_id = targetSessionId!;\n keys.push(key);\n } catch (e) {\n logger.log(\"Failed to decrypt megolm session from backup\", e);\n }\n }\n } finally {\n algorithm.free();\n }\n\n await this.importRoomKeys(keys, {\n progressCallback,\n untrusted,\n source: \"backup\",\n });\n\n await this.checkKeyBackup();\n\n return { total: totalKeyCount, imported: keys.length };\n }\n\n public deleteKeysFromBackup(roomId: undefined, sessionId: undefined, version?: string): Promise;\n public deleteKeysFromBackup(roomId: string, sessionId: undefined, version?: string): Promise;\n public deleteKeysFromBackup(roomId: string, sessionId: string, version?: string): Promise;\n public async deleteKeysFromBackup(roomId?: string, sessionId?: string, version?: string): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n const path = this.makeKeyBackupPath(roomId!, sessionId!, version);\n await this.http.authedRequest(Method.Delete, path.path, path.queryData, undefined, { prefix: ClientPrefix.V3 });\n }\n\n /**\n * Share shared-history decryption keys with the given users.\n *\n * @param roomId - the room for which keys should be shared.\n * @param userIds - a list of users to share with. The keys will be sent to\n * all of the user's current devices.\n */\n public async sendSharedHistoryKeys(roomId: string, userIds: string[]): Promise {\n if (!this.crypto) {\n throw new Error(\"End-to-end encryption disabled\");\n }\n\n const roomEncryption = this.roomList.getRoomEncryption(roomId);\n if (!roomEncryption) {\n // unknown room, or unencrypted room\n logger.error(\"Unknown room. Not sharing decryption keys\");\n return;\n }\n\n const deviceInfos = await this.crypto.downloadKeys(userIds);\n const devicesByUser: Map = new Map();\n for (const [userId, devices] of deviceInfos) {\n devicesByUser.set(userId, Array.from(devices.values()));\n }\n\n // XXX: Private member access\n const alg = this.crypto.getRoomDecryptor(roomId, roomEncryption.algorithm);\n if (alg.sendSharedHistoryInboundSessions) {\n await alg.sendSharedHistoryInboundSessions(devicesByUser);\n } else {\n logger.warn(\"Algorithm does not support sharing previous keys\", roomEncryption.algorithm);\n }\n }\n\n /**\n * Get the config for the media repository.\n * @returns Promise which resolves with an object containing the config.\n */\n public getMediaConfig(): Promise {\n return this.http.authedRequest(Method.Get, \"/config\", undefined, undefined, {\n prefix: MediaPrefix.R0,\n });\n }\n\n /**\n * Get the room for the given room ID.\n * This function will return a valid room for any room for which a Room event\n * has been emitted. Note in particular that other events, eg. RoomState.members\n * will be emitted for a room before this function will return the given room.\n * @param roomId - The room ID\n * @returns The Room or null if it doesn't exist or there is no data store.\n */\n public getRoom(roomId: string | undefined): Room | null {\n if (!roomId) {\n return null;\n }\n return this.store.getRoom(roomId);\n }\n\n /**\n * Retrieve all known rooms.\n * @returns A list of rooms, or an empty list if there is no data store.\n */\n public getRooms(): Room[] {\n return this.store.getRooms();\n }\n\n /**\n * Retrieve all rooms that should be displayed to the user\n * This is essentially getRooms() with some rooms filtered out, eg. old versions\n * of rooms that have been replaced or (in future) other rooms that have been\n * marked at the protocol level as not to be displayed to the user.\n *\n * @param msc3946ProcessDynamicPredecessor - if true, look for an\n * m.room.predecessor state event and\n * use it if found (MSC3946).\n * @returns A list of rooms, or an empty list if there is no data store.\n */\n public getVisibleRooms(msc3946ProcessDynamicPredecessor = false): Room[] {\n const allRooms = this.store.getRooms();\n\n const replacedRooms = new Set();\n for (const r of allRooms) {\n const predecessor = r.findPredecessor(msc3946ProcessDynamicPredecessor)?.roomId;\n if (predecessor) {\n replacedRooms.add(predecessor);\n }\n }\n\n return allRooms.filter((r) => {\n const tombstone = r.currentState.getStateEvents(EventType.RoomTombstone, \"\");\n if (tombstone && replacedRooms.has(r.roomId)) {\n return false;\n }\n return true;\n });\n }\n\n /**\n * Retrieve a user.\n * @param userId - The user ID to retrieve.\n * @returns A user or null if there is no data store or the user does\n * not exist.\n */\n public getUser(userId: string): User | null {\n return this.store.getUser(userId);\n }\n\n /**\n * Retrieve all known users.\n * @returns A list of users, or an empty list if there is no data store.\n */\n public getUsers(): User[] {\n return this.store.getUsers();\n }\n\n /**\n * Set account data event for the current user.\n * It will retry the request up to 5 times.\n * @param eventType - The event type\n * @param content - the contents object for the event\n * @returns Promise which resolves: an empty object\n * @returns Rejects: with an error response.\n */\n public setAccountData(eventType: EventType | string, content: IContent): Promise<{}> {\n const path = utils.encodeUri(\"/user/$userId/account_data/$type\", {\n $userId: this.credentials.userId!,\n $type: eventType,\n });\n return retryNetworkOperation(5, () => {\n return this.http.authedRequest(Method.Put, path, undefined, content);\n });\n }\n\n /**\n * Get account data event of given type for the current user.\n * @param eventType - The event type\n * @returns The contents of the given account data event\n */\n public getAccountData(eventType: string): MatrixEvent | undefined {\n return this.store.getAccountData(eventType);\n }\n\n /**\n * Get account data event of given type for the current user. This variant\n * gets account data directly from the homeserver if the local store is not\n * ready, which can be useful very early in startup before the initial sync.\n * @param eventType - The event type\n * @returns Promise which resolves: The contents of the given account data event.\n * @returns Rejects: with an error response.\n */\n public async getAccountDataFromServer(eventType: string): Promise {\n if (this.isInitialSyncComplete()) {\n const event = this.store.getAccountData(eventType);\n if (!event) {\n return null;\n }\n // The network version below returns just the content, so this branch\n // does the same to match.\n return event.getContent();\n }\n const path = utils.encodeUri(\"/user/$userId/account_data/$type\", {\n $userId: this.credentials.userId!,\n $type: eventType,\n });\n try {\n return await this.http.authedRequest(Method.Get, path);\n } catch (e) {\n if ((e).data?.errcode === \"M_NOT_FOUND\") {\n return null;\n }\n throw e;\n }\n }\n\n public async deleteAccountData(eventType: string): Promise {\n const msc3391DeleteAccountDataServerSupport = this.canSupport.get(Feature.AccountDataDeletion);\n // if deletion is not supported overwrite with empty content\n if (msc3391DeleteAccountDataServerSupport === ServerSupport.Unsupported) {\n await this.setAccountData(eventType, {});\n return;\n }\n const path = utils.encodeUri(\"/user/$userId/account_data/$type\", {\n $userId: this.getSafeUserId(),\n $type: eventType,\n });\n const options =\n msc3391DeleteAccountDataServerSupport === ServerSupport.Unstable\n ? { prefix: \"/_matrix/client/unstable/org.matrix.msc3391\" }\n : undefined;\n return await this.http.authedRequest(Method.Delete, path, undefined, undefined, options);\n }\n\n /**\n * Gets the users that are ignored by this client\n * @returns The array of users that are ignored (empty if none)\n */\n public getIgnoredUsers(): string[] {\n const event = this.getAccountData(\"m.ignored_user_list\");\n if (!event || !event.getContent() || !event.getContent()[\"ignored_users\"]) return [];\n return Object.keys(event.getContent()[\"ignored_users\"]);\n }\n\n /**\n * Sets the users that the current user should ignore.\n * @param userIds - the user IDs to ignore\n * @returns Promise which resolves: an empty object\n * @returns Rejects: with an error response.\n */\n public setIgnoredUsers(userIds: string[]): Promise<{}> {\n const content = { ignored_users: {} as Record };\n userIds.forEach((u) => {\n content.ignored_users[u] = {};\n });\n return this.setAccountData(\"m.ignored_user_list\", content);\n }\n\n /**\n * Gets whether or not a specific user is being ignored by this client.\n * @param userId - the user ID to check\n * @returns true if the user is ignored, false otherwise\n */\n public isUserIgnored(userId: string): boolean {\n return this.getIgnoredUsers().includes(userId);\n }\n\n /**\n * Join a room. If you have already joined the room, this will no-op.\n * @param roomIdOrAlias - The room ID or room alias to join.\n * @param opts - Options when joining the room.\n * @returns Promise which resolves: Room object.\n * @returns Rejects: with an error response.\n */\n public async joinRoom(roomIdOrAlias: string, opts: IJoinRoomOpts = {}): Promise {\n if (opts.syncRoom === undefined) {\n opts.syncRoom = true;\n }\n\n const room = this.getRoom(roomIdOrAlias);\n if (room?.hasMembershipState(this.credentials.userId!, \"join\")) {\n return Promise.resolve(room);\n }\n\n let signPromise: Promise = Promise.resolve();\n\n if (opts.inviteSignUrl) {\n const url = new URL(opts.inviteSignUrl);\n url.searchParams.set(\"mxid\", this.credentials.userId!);\n signPromise = this.http.requestOtherUrl(Method.Post, url);\n }\n\n const queryString: Record = {};\n if (opts.viaServers) {\n queryString[\"server_name\"] = opts.viaServers;\n }\n\n try {\n const data: IJoinRequestBody = {};\n const signedInviteObj = await signPromise;\n if (signedInviteObj) {\n data.third_party_signed = signedInviteObj;\n }\n\n const path = utils.encodeUri(\"/join/$roomid\", { $roomid: roomIdOrAlias });\n const res = await this.http.authedRequest<{ room_id: string }>(Method.Post, path, queryString, data);\n\n const roomId = res.room_id;\n const syncApi = new SyncApi(this, this.clientOpts, this.buildSyncApiOptions());\n const room = syncApi.createRoom(roomId);\n if (opts.syncRoom) {\n // v2 will do this for us\n // return syncApi.syncRoom(room);\n }\n return room;\n } catch (e) {\n throw e; // rethrow for reject\n }\n }\n\n /**\n * Resend an event. Will also retry any to-device messages waiting to be sent.\n * @param event - The event to resend.\n * @param room - Optional. The room the event is in. Will update the\n * timeline entry if provided.\n * @returns Promise which resolves: to an ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public resendEvent(event: MatrixEvent, room: Room): Promise {\n // also kick the to-device queue to retry\n this.toDeviceMessageQueue.sendQueue();\n\n this.updatePendingEventStatus(room, event, EventStatus.SENDING);\n return this.encryptAndSendEvent(room, event);\n }\n\n /**\n * Cancel a queued or unsent event.\n *\n * @param event - Event to cancel\n * @throws Error if the event is not in QUEUED, NOT_SENT or ENCRYPTING state\n */\n public cancelPendingEvent(event: MatrixEvent): void {\n if (![EventStatus.QUEUED, EventStatus.NOT_SENT, EventStatus.ENCRYPTING].includes(event.status!)) {\n throw new Error(\"cannot cancel an event with status \" + event.status);\n }\n\n // if the event is currently being encrypted then\n if (event.status === EventStatus.ENCRYPTING) {\n this.pendingEventEncryption.delete(event.getId()!);\n } else if (this.scheduler && event.status === EventStatus.QUEUED) {\n // tell the scheduler to forget about it, if it's queued\n this.scheduler.removeEventFromQueue(event);\n }\n\n // then tell the room about the change of state, which will remove it\n // from the room's list of pending events.\n const room = this.getRoom(event.getRoomId());\n this.updatePendingEventStatus(room, event, EventStatus.CANCELLED);\n }\n\n /**\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public setRoomName(roomId: string, name: string): Promise {\n return this.sendStateEvent(roomId, EventType.RoomName, { name: name });\n }\n\n /**\n * @param htmlTopic - Optional.\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public setRoomTopic(roomId: string, topic: string, htmlTopic?: string): Promise {\n const content = ContentHelpers.makeTopicContent(topic, htmlTopic);\n return this.sendStateEvent(roomId, EventType.RoomTopic, content);\n }\n\n /**\n * @returns Promise which resolves: to an object keyed by tagId with objects containing a numeric order field.\n * @returns Rejects: with an error response.\n */\n public getRoomTags(roomId: string): Promise {\n const path = utils.encodeUri(\"/user/$userId/rooms/$roomId/tags\", {\n $userId: this.credentials.userId!,\n $roomId: roomId,\n });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * @param tagName - name of room tag to be set\n * @param metadata - associated with that tag to be stored\n * @returns Promise which resolves: to an empty object\n * @returns Rejects: with an error response.\n */\n public setRoomTag(roomId: string, tagName: string, metadata: ITagMetadata): Promise<{}> {\n const path = utils.encodeUri(\"/user/$userId/rooms/$roomId/tags/$tag\", {\n $userId: this.credentials.userId!,\n $roomId: roomId,\n $tag: tagName,\n });\n return this.http.authedRequest(Method.Put, path, undefined, metadata);\n }\n\n /**\n * @param tagName - name of room tag to be removed\n * @returns Promise which resolves: to an empty object\n * @returns Rejects: with an error response.\n */\n public deleteRoomTag(roomId: string, tagName: string): Promise<{}> {\n const path = utils.encodeUri(\"/user/$userId/rooms/$roomId/tags/$tag\", {\n $userId: this.credentials.userId!,\n $roomId: roomId,\n $tag: tagName,\n });\n return this.http.authedRequest(Method.Delete, path);\n }\n\n /**\n * @param eventType - event type to be set\n * @param content - event content\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public setRoomAccountData(roomId: string, eventType: string, content: Record): Promise<{}> {\n const path = utils.encodeUri(\"/user/$userId/rooms/$roomId/account_data/$type\", {\n $userId: this.credentials.userId!,\n $roomId: roomId,\n $type: eventType,\n });\n return this.http.authedRequest(Method.Put, path, undefined, content);\n }\n\n /**\n * Set a power level to one or multiple users.\n * @returns Promise which resolves: to an ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public setPowerLevel(\n roomId: string,\n userId: string | string[],\n powerLevel: number | undefined,\n event: MatrixEvent | null,\n ): Promise {\n let content = {\n users: {} as Record,\n };\n if (event?.getType() === EventType.RoomPowerLevels) {\n // take a copy of the content to ensure we don't corrupt\n // existing client state with a failed power level change\n content = utils.deepCopy(event.getContent());\n }\n\n const users = Array.isArray(userId) ? userId : [userId];\n for (const user of users) {\n if (powerLevel == null) {\n delete content.users[user];\n } else {\n content.users[user] = powerLevel;\n }\n }\n\n const path = utils.encodeUri(\"/rooms/$roomId/state/m.room.power_levels\", {\n $roomId: roomId,\n });\n return this.http.authedRequest(Method.Put, path, undefined, content);\n }\n\n /**\n * Create an m.beacon_info event\n * @returns\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n public async unstable_createLiveBeacon(\n roomId: Room[\"roomId\"],\n beaconInfoContent: MBeaconInfoEventContent,\n ): Promise {\n return this.unstable_setLiveBeacon(roomId, beaconInfoContent);\n }\n\n /**\n * Upsert a live beacon event\n * using a specific m.beacon_info.* event variable type\n * @param roomId - string\n * @returns\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n public async unstable_setLiveBeacon(\n roomId: string,\n beaconInfoContent: MBeaconInfoEventContent,\n ): Promise {\n return this.sendStateEvent(roomId, M_BEACON_INFO.name, beaconInfoContent, this.getUserId()!);\n }\n\n public sendEvent(roomId: string, eventType: string, content: IContent, txnId?: string): Promise;\n public sendEvent(\n roomId: string,\n threadId: string | null,\n eventType: string,\n content: IContent,\n txnId?: string,\n ): Promise;\n public sendEvent(\n roomId: string,\n threadIdOrEventType: string | null,\n eventTypeOrContent: string | IContent,\n contentOrTxnId?: IContent | string,\n txnIdOrVoid?: string,\n ): Promise {\n let threadId: string | null;\n let eventType: string;\n let content: IContent;\n let txnId: string | undefined;\n if (!threadIdOrEventType?.startsWith(EVENT_ID_PREFIX) && threadIdOrEventType !== null) {\n txnId = contentOrTxnId as string;\n content = eventTypeOrContent as IContent;\n eventType = threadIdOrEventType;\n threadId = null;\n } else {\n txnId = txnIdOrVoid;\n content = contentOrTxnId as IContent;\n eventType = eventTypeOrContent as string;\n threadId = threadIdOrEventType;\n }\n\n // If we expect that an event is part of a thread but is missing the relation\n // we need to add it manually, as well as the reply fallback\n if (threadId && !content![\"m.relates_to\"]?.rel_type) {\n const isReply = !!content![\"m.relates_to\"]?.[\"m.in_reply_to\"];\n content![\"m.relates_to\"] = {\n ...content![\"m.relates_to\"],\n rel_type: THREAD_RELATION_TYPE.name,\n event_id: threadId,\n // Set is_falling_back to true unless this is actually intended to be a reply\n is_falling_back: !isReply,\n };\n const thread = this.getRoom(roomId)?.getThread(threadId);\n if (thread && !isReply) {\n content![\"m.relates_to\"][\"m.in_reply_to\"] = {\n event_id:\n thread\n .lastReply((ev: MatrixEvent) => {\n return ev.isRelation(THREAD_RELATION_TYPE.name) && !ev.status;\n })\n ?.getId() ?? threadId,\n };\n }\n }\n\n return this.sendCompleteEvent(roomId, threadId, { type: eventType, content }, txnId);\n }\n\n /**\n * @param eventObject - An object with the partial structure of an event, to which event_id, user_id, room_id and origin_server_ts will be added.\n * @param txnId - Optional.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n private sendCompleteEvent(\n roomId: string,\n threadId: string | null,\n eventObject: any,\n txnId?: string,\n ): Promise {\n if (!txnId) {\n txnId = this.makeTxnId();\n }\n\n // We always construct a MatrixEvent when sending because the store and scheduler use them.\n // We'll extract the params back out if it turns out the client has no scheduler or store.\n const localEvent = new MatrixEvent(\n Object.assign(eventObject, {\n event_id: \"~\" + roomId + \":\" + txnId,\n user_id: this.credentials.userId,\n sender: this.credentials.userId,\n room_id: roomId,\n origin_server_ts: new Date().getTime(),\n }),\n );\n\n const room = this.getRoom(roomId);\n const thread = threadId ? room?.getThread(threadId) : undefined;\n if (thread) {\n localEvent.setThread(thread);\n }\n\n // set up re-emitter for this new event - this is normally the job of EventMapper but we don't use it here\n this.reEmitter.reEmit(localEvent, [MatrixEventEvent.Replaced, MatrixEventEvent.VisibilityChange]);\n room?.reEmitter.reEmit(localEvent, [MatrixEventEvent.BeforeRedaction]);\n\n // if this is a relation or redaction of an event\n // that hasn't been sent yet (e.g. with a local id starting with a ~)\n // then listen for the remote echo of that event so that by the time\n // this event does get sent, we have the correct event_id\n const targetId = localEvent.getAssociatedId();\n if (targetId?.startsWith(\"~\")) {\n const target = room?.getPendingEvents().find((e) => e.getId() === targetId);\n target?.once(MatrixEventEvent.LocalEventIdReplaced, () => {\n localEvent.updateAssociatedId(target.getId()!);\n });\n }\n\n const type = localEvent.getType();\n logger.log(`sendEvent of type ${type} in ${roomId} with txnId ${txnId}`);\n\n localEvent.setTxnId(txnId);\n localEvent.setStatus(EventStatus.SENDING);\n\n // add this event immediately to the local store as 'sending'.\n room?.addPendingEvent(localEvent, txnId);\n\n // addPendingEvent can change the state to NOT_SENT if it believes\n // that there's other events that have failed. We won't bother to\n // try sending the event if the state has changed as such.\n if (localEvent.status === EventStatus.NOT_SENT) {\n return Promise.reject(new Error(\"Event blocked by other events not yet sent\"));\n }\n\n return this.encryptAndSendEvent(room, localEvent);\n }\n\n /**\n * encrypts the event if necessary; adds the event to the queue, or sends it; marks the event as sent/unsent\n * @returns returns a promise which resolves with the result of the send request\n */\n protected encryptAndSendEvent(room: Room | null, event: MatrixEvent): Promise {\n let cancelled = false;\n // Add an extra Promise.resolve() to turn synchronous exceptions into promise rejections,\n // so that we can handle synchronous and asynchronous exceptions with the\n // same code path.\n return Promise.resolve()\n .then(() => {\n const encryptionPromise = this.encryptEventIfNeeded(event, room ?? undefined);\n if (!encryptionPromise) return null; // doesn't need encryption\n\n this.pendingEventEncryption.set(event.getId()!, encryptionPromise);\n this.updatePendingEventStatus(room, event, EventStatus.ENCRYPTING);\n return encryptionPromise.then(() => {\n if (!this.pendingEventEncryption.has(event.getId()!)) {\n // cancelled via MatrixClient::cancelPendingEvent\n cancelled = true;\n return;\n }\n this.updatePendingEventStatus(room, event, EventStatus.SENDING);\n });\n })\n .then(() => {\n if (cancelled) return {} as ISendEventResponse;\n let promise: Promise | null = null;\n if (this.scheduler) {\n // if this returns a promise then the scheduler has control now and will\n // resolve/reject when it is done. Internally, the scheduler will invoke\n // processFn which is set to this._sendEventHttpRequest so the same code\n // path is executed regardless.\n promise = this.scheduler.queueEvent(event);\n if (promise && this.scheduler.getQueueForEvent(event)!.length > 1) {\n // event is processed FIFO so if the length is 2 or more we know\n // this event is stuck behind an earlier event.\n this.updatePendingEventStatus(room, event, EventStatus.QUEUED);\n }\n }\n\n if (!promise) {\n promise = this.sendEventHttpRequest(event);\n if (room) {\n promise = promise.then((res) => {\n room.updatePendingEvent(event, EventStatus.SENT, res[\"event_id\"]);\n return res;\n });\n }\n }\n\n return promise;\n })\n .catch((err) => {\n logger.error(\"Error sending event\", err.stack || err);\n try {\n // set the error on the event before we update the status:\n // updating the status emits the event, so the state should be\n // consistent at that point.\n event.error = err;\n this.updatePendingEventStatus(room, event, EventStatus.NOT_SENT);\n } catch (e) {\n logger.error(\"Exception in error handler!\", (e).stack || err);\n }\n if (err instanceof MatrixError) {\n err.event = event;\n }\n throw err;\n });\n }\n\n private encryptEventIfNeeded(event: MatrixEvent, room?: Room): Promise | null {\n if (event.isEncrypted()) {\n // this event has already been encrypted; this happens if the\n // encryption step succeeded, but the send step failed on the first\n // attempt.\n return null;\n }\n\n if (event.isRedaction()) {\n // Redactions do not support encryption in the spec at this time,\n // whilst it mostly worked in some clients, it wasn't compliant.\n return null;\n }\n\n if (!room || !this.isRoomEncrypted(event.getRoomId()!)) {\n return null;\n }\n\n if (!this.cryptoBackend && this.usingExternalCrypto) {\n // The client has opted to allow sending messages to encrypted\n // rooms even if the room is encrypted, and we haven't setup\n // crypto. This is useful for users of matrix-org/pantalaimon\n return null;\n }\n\n if (event.getType() === EventType.Reaction) {\n // For reactions, there is a very little gained by encrypting the entire\n // event, as relation data is already kept in the clear. Event\n // encryption for a reaction effectively only obscures the event type,\n // but the purpose is still obvious from the relation data, so nothing\n // is really gained. It also causes quite a few problems, such as:\n // * triggers notifications via default push rules\n // * prevents server-side bundling for reactions\n // The reaction key / content / emoji value does warrant encrypting, but\n // this will be handled separately by encrypting just this value.\n // See https://github.com/matrix-org/matrix-doc/pull/1849#pullrequestreview-248763642\n return null;\n }\n\n if (!this.cryptoBackend) {\n throw new Error(\"This room is configured to use encryption, but your client does not support encryption.\");\n }\n\n return this.cryptoBackend.encryptEvent(event, room);\n }\n\n /**\n * Returns the eventType that should be used taking encryption into account\n * for a given eventType.\n * @param roomId - the room for the events `eventType` relates to\n * @param eventType - the event type\n * @returns the event type taking encryption into account\n */\n private getEncryptedIfNeededEventType(\n roomId: string,\n eventType?: EventType | string | null,\n ): EventType | string | null | undefined {\n if (eventType === EventType.Reaction) return eventType;\n return this.isRoomEncrypted(roomId) ? EventType.RoomMessageEncrypted : eventType;\n }\n\n protected updatePendingEventStatus(room: Room | null, event: MatrixEvent, newStatus: EventStatus): void {\n if (room) {\n room.updatePendingEvent(event, newStatus);\n } else {\n event.setStatus(newStatus);\n }\n }\n\n private sendEventHttpRequest(event: MatrixEvent): Promise {\n let txnId = event.getTxnId();\n if (!txnId) {\n txnId = this.makeTxnId();\n event.setTxnId(txnId);\n }\n\n const pathParams = {\n $roomId: event.getRoomId()!,\n $eventType: event.getWireType(),\n $stateKey: event.getStateKey()!,\n $txnId: txnId,\n };\n\n let path: string;\n\n if (event.isState()) {\n let pathTemplate = \"/rooms/$roomId/state/$eventType\";\n if (event.getStateKey() && event.getStateKey()!.length > 0) {\n pathTemplate = \"/rooms/$roomId/state/$eventType/$stateKey\";\n }\n path = utils.encodeUri(pathTemplate, pathParams);\n } else if (event.isRedaction()) {\n const pathTemplate = `/rooms/$roomId/redact/$redactsEventId/$txnId`;\n path = utils.encodeUri(pathTemplate, {\n $redactsEventId: event.event.redacts!,\n ...pathParams,\n });\n } else {\n path = utils.encodeUri(\"/rooms/$roomId/send/$eventType/$txnId\", pathParams);\n }\n\n return this.http\n .authedRequest(Method.Put, path, undefined, event.getWireContent())\n .then((res) => {\n logger.log(`Event sent to ${event.getRoomId()} with event id ${res.event_id}`);\n return res;\n });\n }\n\n /**\n * @param txnId - transaction id. One will be made up if not supplied.\n * @param opts - Options to pass on, may contain `reason` and `with_relations` (MSC3912)\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n * @throws Error if called with `with_relations` (MSC3912) but the server does not support it.\n * Callers should check whether the server supports MSC3912 via `MatrixClient.canSupport`.\n */\n public redactEvent(\n roomId: string,\n eventId: string,\n txnId?: string | undefined,\n opts?: IRedactOpts,\n ): Promise;\n public redactEvent(\n roomId: string,\n threadId: string | null,\n eventId: string,\n txnId?: string | undefined,\n opts?: IRedactOpts,\n ): Promise;\n public redactEvent(\n roomId: string,\n threadId: string | null,\n eventId?: string,\n txnId?: string | IRedactOpts,\n opts?: IRedactOpts,\n ): Promise {\n if (!eventId?.startsWith(EVENT_ID_PREFIX)) {\n opts = txnId as IRedactOpts;\n txnId = eventId;\n eventId = threadId!;\n threadId = null;\n }\n const reason = opts?.reason;\n\n if (\n opts?.with_relations &&\n this.canSupport.get(Feature.RelationBasedRedactions) === ServerSupport.Unsupported\n ) {\n throw new Error(\n \"Server does not support relation based redactions \" +\n `roomId ${roomId} eventId ${eventId} txnId: ${txnId} threadId ${threadId}`,\n );\n }\n\n const withRelations = opts?.with_relations\n ? {\n [this.canSupport.get(Feature.RelationBasedRedactions) === ServerSupport.Stable\n ? MSC3912_RELATION_BASED_REDACTIONS_PROP.stable!\n : MSC3912_RELATION_BASED_REDACTIONS_PROP.unstable!]: opts?.with_relations,\n }\n : {};\n\n return this.sendCompleteEvent(\n roomId,\n threadId,\n {\n type: EventType.RoomRedaction,\n content: {\n ...withRelations,\n reason,\n },\n redacts: eventId,\n },\n txnId as string,\n );\n }\n\n /**\n * @param txnId - Optional.\n * @returns Promise which resolves: to an ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendMessage(roomId: string, content: IContent, txnId?: string): Promise;\n public sendMessage(\n roomId: string,\n threadId: string | null,\n content: IContent,\n txnId?: string,\n ): Promise;\n public sendMessage(\n roomId: string,\n threadId: string | null | IContent,\n content?: IContent | string,\n txnId?: string,\n ): Promise {\n if (typeof threadId !== \"string\" && threadId !== null) {\n txnId = content as string;\n content = threadId as IContent;\n threadId = null;\n }\n\n const eventType: string = EventType.RoomMessage;\n const sendContent: IContent = content as IContent;\n\n return this.sendEvent(roomId, threadId as string | null, eventType, sendContent, txnId);\n }\n\n /**\n * @param txnId - Optional.\n * @returns\n * @returns Rejects: with an error response.\n */\n public sendTextMessage(roomId: string, body: string, txnId?: string): Promise;\n public sendTextMessage(\n roomId: string,\n threadId: string | null,\n body: string,\n txnId?: string,\n ): Promise;\n public sendTextMessage(\n roomId: string,\n threadId: string | null,\n body: string,\n txnId?: string,\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n txnId = body;\n body = threadId;\n threadId = null;\n }\n const content = ContentHelpers.makeTextMessage(body);\n return this.sendMessage(roomId, threadId, content, txnId);\n }\n\n /**\n * @param txnId - Optional.\n * @returns Promise which resolves: to a ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendNotice(roomId: string, body: string, txnId?: string): Promise;\n public sendNotice(\n roomId: string,\n threadId: string | null,\n body: string,\n txnId?: string,\n ): Promise;\n public sendNotice(\n roomId: string,\n threadId: string | null,\n body: string,\n txnId?: string,\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n txnId = body;\n body = threadId;\n threadId = null;\n }\n const content = ContentHelpers.makeNotice(body);\n return this.sendMessage(roomId, threadId, content, txnId);\n }\n\n /**\n * @param txnId - Optional.\n * @returns Promise which resolves: to a ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendEmoteMessage(roomId: string, body: string, txnId?: string): Promise;\n public sendEmoteMessage(\n roomId: string,\n threadId: string | null,\n body: string,\n txnId?: string,\n ): Promise;\n public sendEmoteMessage(\n roomId: string,\n threadId: string | null,\n body: string,\n txnId?: string,\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n txnId = body;\n body = threadId;\n threadId = null;\n }\n const content = ContentHelpers.makeEmoteMessage(body);\n return this.sendMessage(roomId, threadId, content, txnId);\n }\n\n /**\n * @returns Promise which resolves: to a ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendImageMessage(roomId: string, url: string, info?: IImageInfo, text?: string): Promise;\n public sendImageMessage(\n roomId: string,\n threadId: string | null,\n url: string,\n info?: IImageInfo,\n text?: string,\n ): Promise;\n public sendImageMessage(\n roomId: string,\n threadId: string | null,\n url?: string | IImageInfo,\n info?: IImageInfo | string,\n text = \"Image\",\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n text = (info as string) || \"Image\";\n info = url as IImageInfo;\n url = threadId as string;\n threadId = null;\n }\n const content = {\n msgtype: MsgType.Image,\n url: url,\n info: info,\n body: text,\n };\n return this.sendMessage(roomId, threadId, content);\n }\n\n /**\n * @returns Promise which resolves: to a ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendStickerMessage(\n roomId: string,\n url: string,\n info?: IImageInfo,\n text?: string,\n ): Promise;\n public sendStickerMessage(\n roomId: string,\n threadId: string | null,\n url: string,\n info?: IImageInfo,\n text?: string,\n ): Promise;\n public sendStickerMessage(\n roomId: string,\n threadId: string | null,\n url?: string | IImageInfo,\n info?: IImageInfo | string,\n text = \"Sticker\",\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n text = (info as string) || \"Sticker\";\n info = url as IImageInfo;\n url = threadId as string;\n threadId = null;\n }\n const content = {\n url: url,\n info: info,\n body: text,\n };\n\n return this.sendEvent(roomId, threadId, EventType.Sticker, content);\n }\n\n /**\n * @returns Promise which resolves: to a ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendHtmlMessage(roomId: string, body: string, htmlBody: string): Promise;\n public sendHtmlMessage(\n roomId: string,\n threadId: string | null,\n body: string,\n htmlBody: string,\n ): Promise;\n public sendHtmlMessage(\n roomId: string,\n threadId: string | null,\n body: string,\n htmlBody?: string,\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n htmlBody = body as string;\n body = threadId;\n threadId = null;\n }\n const content = ContentHelpers.makeHtmlMessage(body, htmlBody!);\n return this.sendMessage(roomId, threadId, content);\n }\n\n /**\n * @returns Promise which resolves: to a ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendHtmlNotice(roomId: string, body: string, htmlBody: string): Promise;\n public sendHtmlNotice(\n roomId: string,\n threadId: string | null,\n body: string,\n htmlBody: string,\n ): Promise;\n public sendHtmlNotice(\n roomId: string,\n threadId: string | null,\n body: string,\n htmlBody?: string,\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n htmlBody = body as string;\n body = threadId;\n threadId = null;\n }\n const content = ContentHelpers.makeHtmlNotice(body, htmlBody!);\n return this.sendMessage(roomId, threadId, content);\n }\n\n /**\n * @returns Promise which resolves: to a ISendEventResponse object\n * @returns Rejects: with an error response.\n */\n public sendHtmlEmote(roomId: string, body: string, htmlBody: string): Promise;\n public sendHtmlEmote(\n roomId: string,\n threadId: string | null,\n body: string,\n htmlBody: string,\n ): Promise;\n public sendHtmlEmote(\n roomId: string,\n threadId: string | null,\n body: string,\n htmlBody?: string,\n ): Promise {\n if (!threadId?.startsWith(EVENT_ID_PREFIX) && threadId !== null) {\n htmlBody = body as string;\n body = threadId;\n threadId = null;\n }\n const content = ContentHelpers.makeHtmlEmote(body, htmlBody!);\n return this.sendMessage(roomId, threadId, content);\n }\n\n /**\n * Send a receipt.\n * @param event - The event being acknowledged\n * @param receiptType - The kind of receipt e.g. \"m.read\". Other than\n * ReceiptType.Read are experimental!\n * @param body - Additional content to send alongside the receipt.\n * @param unthreaded - An unthreaded receipt will clear room+thread notifications\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public async sendReceipt(event: MatrixEvent, receiptType: ReceiptType, body: any, unthreaded = false): Promise<{}> {\n if (this.isGuest()) {\n return Promise.resolve({}); // guests cannot send receipts so don't bother.\n }\n\n const path = utils.encodeUri(\"/rooms/$roomId/receipt/$receiptType/$eventId\", {\n $roomId: event.getRoomId()!,\n $receiptType: receiptType,\n $eventId: event.getId()!,\n });\n\n if (!unthreaded) {\n const isThread = !!event.threadRootId;\n body = {\n ...body,\n thread_id: isThread ? event.threadRootId : MAIN_ROOM_TIMELINE,\n };\n }\n\n const promise = this.http.authedRequest<{}>(Method.Post, path, undefined, body || {});\n\n const room = this.getRoom(event.getRoomId());\n if (room && this.credentials.userId) {\n room.addLocalEchoReceipt(this.credentials.userId, event, receiptType);\n }\n return promise;\n }\n\n /**\n * Send a read receipt.\n * @param event - The event that has been read.\n * @param receiptType - other than ReceiptType.Read are experimental! Optional.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public async sendReadReceipt(\n event: MatrixEvent | null,\n receiptType = ReceiptType.Read,\n unthreaded = false,\n ): Promise<{} | undefined> {\n if (!event) return;\n const eventId = event.getId()!;\n const room = this.getRoom(event.getRoomId());\n if (room?.hasPendingEvent(eventId)) {\n throw new Error(`Cannot set read receipt to a pending event (${eventId})`);\n }\n\n return this.sendReceipt(event, receiptType, {}, unthreaded);\n }\n\n /**\n * Set a marker to indicate the point in a room before which the user has read every\n * event. This can be retrieved from room account data (the event type is `m.fully_read`)\n * and displayed as a horizontal line in the timeline that is visually distinct to the\n * position of the user's own read receipt.\n * @param roomId - ID of the room that has been read\n * @param rmEventId - ID of the event that has been read\n * @param rrEvent - the event tracked by the read receipt. This is here for\n * convenience because the RR and the RM are commonly updated at the same time as each\n * other. The local echo of this receipt will be done if set. Optional.\n * @param rpEvent - the m.read.private read receipt event for when we don't\n * want other users to see the read receipts. This is experimental. Optional.\n * @returns Promise which resolves: the empty object, `{}`.\n */\n public async setRoomReadMarkers(\n roomId: string,\n rmEventId: string,\n rrEvent?: MatrixEvent,\n rpEvent?: MatrixEvent,\n ): Promise<{}> {\n const room = this.getRoom(roomId);\n if (room && room.hasPendingEvent(rmEventId)) {\n throw new Error(`Cannot set read marker to a pending event (${rmEventId})`);\n }\n\n // Add the optional RR update, do local echo like `sendReceipt`\n let rrEventId: string | undefined;\n if (rrEvent) {\n rrEventId = rrEvent.getId()!;\n if (room?.hasPendingEvent(rrEventId)) {\n throw new Error(`Cannot set read receipt to a pending event (${rrEventId})`);\n }\n room?.addLocalEchoReceipt(this.credentials.userId!, rrEvent, ReceiptType.Read);\n }\n\n // Add the optional private RR update, do local echo like `sendReceipt`\n let rpEventId: string | undefined;\n if (rpEvent) {\n rpEventId = rpEvent.getId()!;\n if (room?.hasPendingEvent(rpEventId)) {\n throw new Error(`Cannot set read receipt to a pending event (${rpEventId})`);\n }\n room?.addLocalEchoReceipt(this.credentials.userId!, rpEvent, ReceiptType.ReadPrivate);\n }\n\n return await this.setRoomReadMarkersHttpRequest(roomId, rmEventId, rrEventId, rpEventId);\n }\n\n /**\n * Get a preview of the given URL as of (roughly) the given point in time,\n * described as an object with OpenGraph keys and associated values.\n * Attributes may be synthesized where actual OG metadata is lacking.\n * Caches results to prevent hammering the server.\n * @param url - The URL to get preview data for\n * @param ts - The preferred point in time that the preview should\n * describe (ms since epoch). The preview returned will either be the most\n * recent one preceding this timestamp if available, or failing that the next\n * most recent available preview.\n * @returns Promise which resolves: Object of OG metadata.\n * @returns Rejects: with an error response.\n * May return synthesized attributes if the URL lacked OG meta.\n */\n public getUrlPreview(url: string, ts: number): Promise {\n // bucket the timestamp to the nearest minute to prevent excessive spam to the server\n // Surely 60-second accuracy is enough for anyone.\n ts = Math.floor(ts / 60000) * 60000;\n\n const parsed = new URL(url);\n parsed.hash = \"\"; // strip the hash as it won't affect the preview\n url = parsed.toString();\n\n const key = ts + \"_\" + url;\n\n // If there's already a request in flight (or we've handled it), return that instead.\n const cachedPreview = this.urlPreviewCache[key];\n if (cachedPreview) {\n return cachedPreview;\n }\n\n const resp = this.http.authedRequest(\n Method.Get,\n \"/preview_url\",\n {\n url,\n ts: ts.toString(),\n },\n undefined,\n {\n prefix: MediaPrefix.R0,\n },\n );\n // TODO: Expire the URL preview cache sometimes\n this.urlPreviewCache[key] = resp;\n return resp;\n }\n\n /**\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public sendTyping(roomId: string, isTyping: boolean, timeoutMs: number): Promise<{}> {\n if (this.isGuest()) {\n return Promise.resolve({}); // guests cannot send typing notifications so don't bother.\n }\n\n const path = utils.encodeUri(\"/rooms/$roomId/typing/$userId\", {\n $roomId: roomId,\n $userId: this.getUserId()!,\n });\n const data: any = {\n typing: isTyping,\n };\n if (isTyping) {\n data.timeout = timeoutMs ? timeoutMs : 20000;\n }\n return this.http.authedRequest(Method.Put, path, undefined, data);\n }\n\n /**\n * Determines the history of room upgrades for a given room, as far as the\n * client can see. Returns an array of Rooms where the first entry is the\n * oldest and the last entry is the newest (likely current) room. If the\n * provided room is not found, this returns an empty list. This works in\n * both directions, looking for older and newer rooms of the given room.\n * @param roomId - The room ID to search from\n * @param verifyLinks - If true, the function will only return rooms\n * which can be proven to be linked. For example, rooms which have a create\n * event pointing to an old room which the client is not aware of or doesn't\n * have a matching tombstone would not be returned.\n * @param msc3946ProcessDynamicPredecessor - if true, look for\n * m.room.predecessor state events as well as create events, and prefer\n * predecessor events where they exist (MSC3946).\n * @returns An array of rooms representing the upgrade\n * history.\n */\n public getRoomUpgradeHistory(\n roomId: string,\n verifyLinks = false,\n msc3946ProcessDynamicPredecessor = false,\n ): Room[] {\n const currentRoom = this.getRoom(roomId);\n if (!currentRoom) return [];\n\n const before = this.findPredecessorRooms(currentRoom, verifyLinks, msc3946ProcessDynamicPredecessor);\n const after = this.findSuccessorRooms(currentRoom, verifyLinks, msc3946ProcessDynamicPredecessor);\n\n return [...before, currentRoom, ...after];\n }\n\n private findPredecessorRooms(room: Room, verifyLinks: boolean, msc3946ProcessDynamicPredecessor: boolean): Room[] {\n const ret: Room[] = [];\n\n // Work backwards from newer to older rooms\n let predecessorRoomId = room.findPredecessor(msc3946ProcessDynamicPredecessor)?.roomId;\n while (predecessorRoomId !== null) {\n const predecessorRoom = this.getRoom(predecessorRoomId);\n if (predecessorRoom === null) {\n break;\n }\n if (verifyLinks) {\n const tombstone = predecessorRoom.currentState.getStateEvents(EventType.RoomTombstone, \"\");\n if (!tombstone || tombstone.getContent()[\"replacement_room\"] !== room.roomId) {\n break;\n }\n }\n\n // Insert at the front because we're working backwards from the currentRoom\n ret.splice(0, 0, predecessorRoom);\n\n room = predecessorRoom;\n predecessorRoomId = room.findPredecessor(msc3946ProcessDynamicPredecessor)?.roomId;\n }\n return ret;\n }\n\n private findSuccessorRooms(room: Room, verifyLinks: boolean, msc3946ProcessDynamicPredecessor: boolean): Room[] {\n const ret: Room[] = [];\n\n // Work forwards, looking at tombstone events\n let tombstoneEvent = room.currentState.getStateEvents(EventType.RoomTombstone, \"\");\n while (tombstoneEvent) {\n const successorRoom = this.getRoom(tombstoneEvent.getContent()[\"replacement_room\"]);\n if (!successorRoom) break; // end of the chain\n if (successorRoom.roomId === room.roomId) break; // Tombstone is referencing its own room\n\n if (verifyLinks) {\n const predecessorRoomId = successorRoom.findPredecessor(msc3946ProcessDynamicPredecessor)?.roomId;\n if (!predecessorRoomId || predecessorRoomId !== room.roomId) {\n break;\n }\n }\n\n // Push to the end because we're looking forwards\n ret.push(successorRoom);\n const roomIds = new Set(ret.map((ref) => ref.roomId));\n if (roomIds.size < ret.length) {\n // The last room added to the list introduced a previous roomId\n // To avoid recursion, return the last rooms - 1\n return ret.slice(0, ret.length - 1);\n }\n\n // Set the current room to the reference room so we know where we're at\n room = successorRoom;\n tombstoneEvent = room.currentState.getStateEvents(EventType.RoomTombstone, \"\");\n }\n return ret;\n }\n\n /**\n * @param reason - Optional.\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public invite(roomId: string, userId: string, reason?: string): Promise<{}> {\n return this.membershipChange(roomId, userId, \"invite\", reason);\n }\n\n /**\n * Invite a user to a room based on their email address.\n * @param roomId - The room to invite the user to.\n * @param email - The email address to invite.\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public inviteByEmail(roomId: string, email: string): Promise<{}> {\n return this.inviteByThreePid(roomId, \"email\", email);\n }\n\n /**\n * Invite a user to a room based on a third-party identifier.\n * @param roomId - The room to invite the user to.\n * @param medium - The medium to invite the user e.g. \"email\".\n * @param address - The address for the specified medium.\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public async inviteByThreePid(roomId: string, medium: string, address: string): Promise<{}> {\n const path = utils.encodeUri(\"/rooms/$roomId/invite\", { $roomId: roomId });\n\n const identityServerUrl = this.getIdentityServerUrl(true);\n if (!identityServerUrl) {\n return Promise.reject(\n new MatrixError({\n error: \"No supplied identity server URL\",\n errcode: \"ORG.MATRIX.JSSDK_MISSING_PARAM\",\n }),\n );\n }\n const params: Record = {\n id_server: identityServerUrl,\n medium: medium,\n address: address,\n };\n\n if (this.identityServer?.getAccessToken && (await this.doesServerAcceptIdentityAccessToken())) {\n const identityAccessToken = await this.identityServer.getAccessToken();\n if (identityAccessToken) {\n params[\"id_access_token\"] = identityAccessToken;\n }\n }\n\n return this.http.authedRequest(Method.Post, path, undefined, params);\n }\n\n /**\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public leave(roomId: string): Promise<{}> {\n return this.membershipChange(roomId, undefined, \"leave\");\n }\n\n /**\n * Leaves all rooms in the chain of room upgrades based on the given room. By\n * default, this will leave all the previous and upgraded rooms, including the\n * given room. To only leave the given room and any previous rooms, keeping the\n * upgraded (modern) rooms untouched supply `false` to `includeFuture`.\n * @param roomId - The room ID to start leaving at\n * @param includeFuture - If true, the whole chain (past and future) of\n * upgraded rooms will be left.\n * @returns Promise which resolves when completed with an object keyed\n * by room ID and value of the error encountered when leaving or null.\n */\n public leaveRoomChain(\n roomId: string,\n includeFuture = true,\n ): Promise<{ [roomId: string]: Error | MatrixError | null }> {\n const upgradeHistory = this.getRoomUpgradeHistory(roomId);\n\n let eligibleToLeave = upgradeHistory;\n if (!includeFuture) {\n eligibleToLeave = [];\n for (const room of upgradeHistory) {\n eligibleToLeave.push(room);\n if (room.roomId === roomId) {\n break;\n }\n }\n }\n\n const populationResults: { [roomId: string]: Error } = {};\n const promises: Promise[] = [];\n\n const doLeave = (roomId: string): Promise => {\n return this.leave(roomId)\n .then(() => {\n delete populationResults[roomId];\n })\n .catch((err) => {\n // suppress error\n populationResults[roomId] = err;\n });\n };\n\n for (const room of eligibleToLeave) {\n promises.push(doLeave(room.roomId));\n }\n\n return Promise.all(promises).then(() => populationResults);\n }\n\n /**\n * @param reason - Optional.\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public ban(roomId: string, userId: string, reason?: string): Promise<{}> {\n return this.membershipChange(roomId, userId, \"ban\", reason);\n }\n\n /**\n * @param deleteRoom - True to delete the room from the store on success.\n * Default: true.\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public forget(roomId: string, deleteRoom = true): Promise<{}> {\n const promise = this.membershipChange(roomId, undefined, \"forget\");\n if (!deleteRoom) {\n return promise;\n }\n return promise.then((response) => {\n this.store.removeRoom(roomId);\n this.emit(ClientEvent.DeleteRoom, roomId);\n return response;\n });\n }\n\n /**\n * @returns Promise which resolves: Object (currently empty)\n * @returns Rejects: with an error response.\n */\n public unban(roomId: string, userId: string): Promise<{}> {\n // unbanning != set their state to leave: this used to be\n // the case, but was then changed so that leaving was always\n // a revoking of privilege, otherwise two people racing to\n // kick / ban someone could end up banning and then un-banning\n // them.\n const path = utils.encodeUri(\"/rooms/$roomId/unban\", {\n $roomId: roomId,\n });\n const data = {\n user_id: userId,\n };\n return this.http.authedRequest(Method.Post, path, undefined, data);\n }\n\n /**\n * @param reason - Optional.\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public kick(roomId: string, userId: string, reason?: string): Promise<{}> {\n const path = utils.encodeUri(\"/rooms/$roomId/kick\", {\n $roomId: roomId,\n });\n const data = {\n user_id: userId,\n reason: reason,\n };\n return this.http.authedRequest(Method.Post, path, undefined, data);\n }\n\n private membershipChange(\n roomId: string,\n userId: string | undefined,\n membership: string,\n reason?: string,\n ): Promise<{}> {\n // API returns an empty object\n const path = utils.encodeUri(\"/rooms/$room_id/$membership\", {\n $room_id: roomId,\n $membership: membership,\n });\n return this.http.authedRequest(Method.Post, path, undefined, {\n user_id: userId, // may be undefined e.g. on leave\n reason: reason,\n });\n }\n\n /**\n * Obtain a dict of actions which should be performed for this event according\n * to the push rules for this user. Caches the dict on the event.\n * @param event - The event to get push actions for.\n * @param forceRecalculate - forces to recalculate actions for an event\n * Useful when an event just got decrypted\n * @returns A dict of actions to perform.\n */\n public getPushActionsForEvent(event: MatrixEvent, forceRecalculate = false): IActionsObject | null {\n if (!event.getPushActions() || forceRecalculate) {\n event.setPushActions(this.pushProcessor.actionsForEvent(event));\n }\n return event.getPushActions();\n }\n\n /**\n * @param info - The kind of info to set (e.g. 'avatar_url')\n * @param data - The JSON object to set.\n * @returns\n * @returns Rejects: with an error response.\n */\n // eslint-disable-next-line camelcase\n public setProfileInfo(info: \"avatar_url\", data: { avatar_url: string }): Promise<{}>;\n public setProfileInfo(info: \"displayname\", data: { displayname: string }): Promise<{}>;\n public setProfileInfo(info: \"avatar_url\" | \"displayname\", data: object): Promise<{}> {\n const path = utils.encodeUri(\"/profile/$userId/$info\", {\n $userId: this.credentials.userId!,\n $info: info,\n });\n return this.http.authedRequest(Method.Put, path, undefined, data);\n }\n\n /**\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public async setDisplayName(name: string): Promise<{}> {\n const prom = await this.setProfileInfo(\"displayname\", { displayname: name });\n // XXX: synthesise a profile update for ourselves because Synapse is broken and won't\n const user = this.getUser(this.getUserId()!);\n if (user) {\n user.displayName = name;\n user.emit(UserEvent.DisplayName, user.events.presence, user);\n }\n return prom;\n }\n\n /**\n * @returns Promise which resolves: `{}` an empty object.\n * @returns Rejects: with an error response.\n */\n public async setAvatarUrl(url: string): Promise<{}> {\n const prom = await this.setProfileInfo(\"avatar_url\", { avatar_url: url });\n // XXX: synthesise a profile update for ourselves because Synapse is broken and won't\n const user = this.getUser(this.getUserId()!);\n if (user) {\n user.avatarUrl = url;\n user.emit(UserEvent.AvatarUrl, user.events.presence, user);\n }\n return prom;\n }\n\n /**\n * Turn an MXC URL into an HTTP one. This method is experimental and\n * may change.\n * @param mxcUrl - The MXC URL\n * @param width - The desired width of the thumbnail.\n * @param height - The desired height of the thumbnail.\n * @param resizeMethod - The thumbnail resize method to use, either\n * \"crop\" or \"scale\".\n * @param allowDirectLinks - If true, return any non-mxc URLs\n * directly. Fetching such URLs will leak information about the user to\n * anyone they share a room with. If false, will return null for such URLs.\n * @returns the avatar URL or null.\n */\n public mxcUrlToHttp(\n mxcUrl: string,\n width?: number,\n height?: number,\n resizeMethod?: string,\n allowDirectLinks?: boolean,\n ): string | null {\n return getHttpUriForMxc(this.baseUrl, mxcUrl, width, height, resizeMethod, allowDirectLinks);\n }\n\n /**\n * @param opts - Options to apply\n * @returns Promise which resolves\n * @returns Rejects: with an error response.\n * @throws If 'presence' isn't a valid presence enum value.\n */\n public async setPresence(opts: IPresenceOpts): Promise {\n const path = utils.encodeUri(\"/presence/$userId/status\", {\n $userId: this.credentials.userId!,\n });\n\n const validStates = [\"offline\", \"online\", \"unavailable\"];\n if (validStates.indexOf(opts.presence) === -1) {\n throw new Error(\"Bad presence value: \" + opts.presence);\n }\n await this.http.authedRequest(Method.Put, path, undefined, opts);\n }\n\n /**\n * @param userId - The user to get presence for\n * @returns Promise which resolves: The presence state for this user.\n * @returns Rejects: with an error response.\n */\n public getPresence(userId: string): Promise {\n const path = utils.encodeUri(\"/presence/$userId/status\", {\n $userId: userId,\n });\n\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * Retrieve older messages from the given room and put them in the timeline.\n *\n * If this is called multiple times whilst a request is ongoing, the same\n * Promise will be returned. If there was a problem requesting scrollback, there\n * will be a small delay before another request can be made (to prevent tight-looping\n * when there is no connection).\n *\n * @param room - The room to get older messages in.\n * @param limit - Optional. The maximum number of previous events to\n * pull in. Default: 30.\n * @returns Promise which resolves: Room. If you are at the beginning\n * of the timeline, `Room.oldState.paginationToken` will be\n * `null`.\n * @returns Rejects: with an error response.\n */\n public scrollback(room: Room, limit = 30): Promise {\n let timeToWaitMs = 0;\n\n let info = this.ongoingScrollbacks[room.roomId] || {};\n if (info.promise) {\n return info.promise;\n } else if (info.errorTs) {\n const timeWaitedMs = Date.now() - info.errorTs;\n timeToWaitMs = Math.max(SCROLLBACK_DELAY_MS - timeWaitedMs, 0);\n }\n\n if (room.oldState.paginationToken === null) {\n return Promise.resolve(room); // already at the start.\n }\n // attempt to grab more events from the store first\n const numAdded = this.store.scrollback(room, limit).length;\n if (numAdded === limit) {\n // store contained everything we needed.\n return Promise.resolve(room);\n }\n // reduce the required number of events appropriately\n limit = limit - numAdded;\n\n const promise = new Promise((resolve, reject) => {\n // wait for a time before doing this request\n // (which may be 0 in order not to special case the code paths)\n sleep(timeToWaitMs)\n .then(() => {\n return this.createMessagesRequest(\n room.roomId,\n room.oldState.paginationToken,\n limit,\n Direction.Backward,\n );\n })\n .then((res: IMessagesResponse) => {\n const matrixEvents = res.chunk.map(this.getEventMapper());\n if (res.state) {\n const stateEvents = res.state.map(this.getEventMapper());\n room.currentState.setUnknownStateEvents(stateEvents);\n }\n\n const [timelineEvents, threadedEvents] = room.partitionThreadedEvents(matrixEvents);\n\n this.processAggregatedTimelineEvents(room, timelineEvents);\n room.addEventsToTimeline(timelineEvents, true, room.getLiveTimeline());\n this.processThreadEvents(room, threadedEvents, true);\n\n room.oldState.paginationToken = res.end ?? null;\n if (res.chunk.length === 0) {\n room.oldState.paginationToken = null;\n }\n this.store.storeEvents(room, matrixEvents, res.end ?? null, true);\n delete this.ongoingScrollbacks[room.roomId];\n resolve(room);\n })\n .catch((err) => {\n this.ongoingScrollbacks[room.roomId] = {\n errorTs: Date.now(),\n };\n reject(err);\n });\n });\n\n info = { promise };\n\n this.ongoingScrollbacks[room.roomId] = info;\n return promise;\n }\n\n public getEventMapper(options?: MapperOpts): EventMapper {\n return eventMapperFor(this, options || {});\n }\n\n /**\n * Get an EventTimeline for the given event\n *\n *

If the EventTimelineSet object already has the given event in its store, the\n * corresponding timeline will be returned. Otherwise, a /context request is\n * made, and used to construct an EventTimeline.\n * If the event does not belong to this EventTimelineSet then undefined will be returned.\n *\n * @param timelineSet - The timelineSet to look for the event in, must be bound to a room\n * @param eventId - The ID of the event to look for\n *\n * @returns Promise which resolves:\n * {@link EventTimeline} including the given event\n */\n public async getEventTimeline(timelineSet: EventTimelineSet, eventId: string): Promise> {\n // don't allow any timeline support unless it's been enabled.\n if (!this.timelineSupport) {\n throw new Error(\n \"timeline support is disabled. Set the 'timelineSupport'\" +\n \" parameter to true when creating MatrixClient to enable it.\",\n );\n }\n\n if (!timelineSet?.room) {\n throw new Error(\"getEventTimeline only supports room timelines\");\n }\n\n if (timelineSet.getTimelineForEvent(eventId)) {\n return timelineSet.getTimelineForEvent(eventId);\n }\n\n if (timelineSet.thread && this.supportsThreads()) {\n return this.getThreadTimeline(timelineSet, eventId);\n }\n\n const path = utils.encodeUri(\"/rooms/$roomId/context/$eventId\", {\n $roomId: timelineSet.room.roomId,\n $eventId: eventId,\n });\n\n let params: Record | undefined = undefined;\n if (this.clientOpts?.lazyLoadMembers) {\n params = { filter: JSON.stringify(Filter.LAZY_LOADING_MESSAGES_FILTER) };\n }\n\n // TODO: we should implement a backoff (as per scrollback()) to deal more nicely with HTTP errors.\n const res = await this.http.authedRequest(Method.Get, path, params);\n if (!res.event) {\n throw new Error(\"'event' not in '/context' result - homeserver too old?\");\n }\n\n // by the time the request completes, the event might have ended up in the timeline.\n if (timelineSet.getTimelineForEvent(eventId)) {\n return timelineSet.getTimelineForEvent(eventId);\n }\n\n const mapper = this.getEventMapper();\n const event = mapper(res.event);\n if (event.isRelation(THREAD_RELATION_TYPE.name)) {\n logger.warn(\"Tried loading a regular timeline at the position of a thread event\");\n return undefined;\n }\n const events = [\n // Order events from most recent to oldest (reverse-chronological).\n // We start with the last event, since that's the point at which we have known state.\n // events_after is already backwards; events_before is forwards.\n ...res.events_after.reverse().map(mapper),\n event,\n ...res.events_before.map(mapper),\n ];\n\n // Here we handle non-thread timelines only, but still process any thread events to populate thread summaries.\n let timeline = timelineSet.getTimelineForEvent(events[0].getId());\n if (timeline) {\n timeline.getState(EventTimeline.BACKWARDS)!.setUnknownStateEvents(res.state.map(mapper));\n } else {\n timeline = timelineSet.addTimeline();\n timeline.initialiseState(res.state.map(mapper));\n timeline.getState(EventTimeline.FORWARDS)!.paginationToken = res.end;\n }\n\n const [timelineEvents, threadedEvents] = timelineSet.room.partitionThreadedEvents(events);\n timelineSet.addEventsToTimeline(timelineEvents, true, timeline, res.start);\n // The target event is not in a thread but process the contextual events, so we can show any threads around it.\n this.processThreadEvents(timelineSet.room, threadedEvents, true);\n this.processAggregatedTimelineEvents(timelineSet.room, timelineEvents);\n\n // There is no guarantee that the event ended up in \"timeline\" (we might have switched to a neighbouring\n // timeline) - so check the room's index again. On the other hand, there's no guarantee the event ended up\n // anywhere, if it was later redacted, so we just return the timeline we first thought of.\n return (\n timelineSet.getTimelineForEvent(eventId) ??\n timelineSet.room.findThreadForEvent(event)?.liveTimeline ?? // for Threads degraded support\n timeline\n );\n }\n\n public async getThreadTimeline(timelineSet: EventTimelineSet, eventId: string): Promise {\n if (!this.supportsThreads()) {\n throw new Error(\"could not get thread timeline: no client support\");\n }\n\n if (!timelineSet.room) {\n throw new Error(\"could not get thread timeline: not a room timeline\");\n }\n\n if (!timelineSet.thread) {\n throw new Error(\"could not get thread timeline: not a thread timeline\");\n }\n\n const path = utils.encodeUri(\"/rooms/$roomId/context/$eventId\", {\n $roomId: timelineSet.room.roomId,\n $eventId: eventId,\n });\n\n const params: Record = {\n limit: \"0\",\n };\n if (this.clientOpts?.lazyLoadMembers) {\n params.filter = JSON.stringify(Filter.LAZY_LOADING_MESSAGES_FILTER);\n }\n\n // TODO: we should implement a backoff (as per scrollback()) to deal more nicely with HTTP errors.\n const res = await this.http.authedRequest(Method.Get, path, params);\n const mapper = this.getEventMapper();\n const event = mapper(res.event);\n\n if (!timelineSet.canContain(event)) {\n return undefined;\n }\n\n if (Thread.hasServerSideSupport) {\n if (Thread.hasServerSideFwdPaginationSupport) {\n if (!timelineSet.thread) {\n throw new Error(\"could not get thread timeline: not a thread timeline\");\n }\n\n const thread = timelineSet.thread;\n const resOlder: IRelationsResponse = await this.fetchRelations(\n timelineSet.room.roomId,\n thread.id,\n THREAD_RELATION_TYPE.name,\n null,\n { dir: Direction.Backward, from: res.start },\n );\n const resNewer: IRelationsResponse = await this.fetchRelations(\n timelineSet.room.roomId,\n thread.id,\n THREAD_RELATION_TYPE.name,\n null,\n { dir: Direction.Forward, from: res.end },\n );\n const events = [\n // Order events from most recent to oldest (reverse-chronological).\n // We start with the last event, since that's the point at which we have known state.\n // events_after is already backwards; events_before is forwards.\n ...resNewer.chunk.reverse().map(mapper),\n event,\n ...resOlder.chunk.map(mapper),\n ];\n for (const event of events) {\n await timelineSet.thread?.processEvent(event);\n }\n\n // Here we handle non-thread timelines only, but still process any thread events to populate thread summaries.\n let timeline = timelineSet.getTimelineForEvent(event.getId());\n if (timeline) {\n timeline.getState(EventTimeline.BACKWARDS)!.setUnknownStateEvents(res.state.map(mapper));\n } else {\n timeline = timelineSet.addTimeline();\n timeline.initialiseState(res.state.map(mapper));\n }\n\n timelineSet.addEventsToTimeline(events, true, timeline, resNewer.next_batch);\n if (!resOlder.next_batch) {\n const originalEvent = await this.fetchRoomEvent(timelineSet.room.roomId, thread.id);\n timelineSet.addEventsToTimeline([mapper(originalEvent)], true, timeline, null);\n }\n timeline.setPaginationToken(resOlder.next_batch ?? null, Direction.Backward);\n timeline.setPaginationToken(resNewer.next_batch ?? null, Direction.Forward);\n this.processAggregatedTimelineEvents(timelineSet.room, events);\n\n // There is no guarantee that the event ended up in \"timeline\" (we might have switched to a neighbouring\n // timeline) - so check the room's index again. On the other hand, there's no guarantee the event ended up\n // anywhere, if it was later redacted, so we just return the timeline we first thought of.\n return timelineSet.getTimelineForEvent(eventId) ?? timeline;\n } else {\n // Where the event is a thread reply (not a root) and running in MSC-enabled mode the Thread timeline only\n // functions contiguously, so we have to jump through some hoops to get our target event in it.\n // XXX: workaround for https://github.com/vector-im/element-meta/issues/150\n\n const thread = timelineSet.thread;\n\n const resOlder = await this.fetchRelations(\n timelineSet.room.roomId,\n thread.id,\n THREAD_RELATION_TYPE.name,\n null,\n { dir: Direction.Backward, from: res.start },\n );\n const eventsNewer: IEvent[] = [];\n let nextBatch: Optional = res.end;\n while (nextBatch) {\n const resNewer: IRelationsResponse = await this.fetchRelations(\n timelineSet.room.roomId,\n thread.id,\n THREAD_RELATION_TYPE.name,\n null,\n { dir: Direction.Forward, from: nextBatch },\n );\n nextBatch = resNewer.next_batch ?? null;\n eventsNewer.push(...resNewer.chunk);\n }\n const events = [\n // Order events from most recent to oldest (reverse-chronological).\n // We start with the last event, since that's the point at which we have known state.\n // events_after is already backwards; events_before is forwards.\n ...eventsNewer.reverse().map(mapper),\n event,\n ...resOlder.chunk.map(mapper),\n ];\n for (const event of events) {\n await timelineSet.thread?.processEvent(event);\n }\n\n // Here we handle non-thread timelines only, but still process any thread events to populate thread\n // summaries.\n const timeline = timelineSet.getLiveTimeline();\n timeline.getState(EventTimeline.BACKWARDS)!.setUnknownStateEvents(res.state.map(mapper));\n\n timelineSet.addEventsToTimeline(events, true, timeline, null);\n if (!resOlder.next_batch) {\n const originalEvent = await this.fetchRoomEvent(timelineSet.room.roomId, thread.id);\n timelineSet.addEventsToTimeline([mapper(originalEvent)], true, timeline, null);\n }\n timeline.setPaginationToken(resOlder.next_batch ?? null, Direction.Backward);\n timeline.setPaginationToken(null, Direction.Forward);\n this.processAggregatedTimelineEvents(timelineSet.room, events);\n\n return timeline;\n }\n }\n }\n\n /**\n * Get an EventTimeline for the latest events in the room. This will just\n * call `/messages` to get the latest message in the room, then use\n * `client.getEventTimeline(...)` to construct a new timeline from it.\n *\n * @param timelineSet - The timelineSet to find or add the timeline to\n *\n * @returns Promise which resolves:\n * {@link EventTimeline} timeline with the latest events in the room\n */\n public async getLatestTimeline(timelineSet: EventTimelineSet): Promise> {\n // don't allow any timeline support unless it's been enabled.\n if (!this.timelineSupport) {\n throw new Error(\n \"timeline support is disabled. Set the 'timelineSupport'\" +\n \" parameter to true when creating MatrixClient to enable it.\",\n );\n }\n\n if (!timelineSet.room) {\n throw new Error(\"getLatestTimeline only supports room timelines\");\n }\n\n let event;\n if (timelineSet.threadListType !== null) {\n const res = await this.createThreadListMessagesRequest(\n timelineSet.room.roomId,\n null,\n 1,\n Direction.Backward,\n timelineSet.threadListType,\n timelineSet.getFilter(),\n );\n event = res.chunk?.[0];\n } else if (timelineSet.thread && Thread.hasServerSideSupport) {\n const res = await this.fetchRelations(\n timelineSet.room.roomId,\n timelineSet.thread.id,\n THREAD_RELATION_TYPE.name,\n null,\n { dir: Direction.Backward, limit: 1 },\n );\n event = res.chunk?.[0];\n } else {\n const messagesPath = utils.encodeUri(\"/rooms/$roomId/messages\", {\n $roomId: timelineSet.room.roomId,\n });\n\n const params: Record = {\n dir: \"b\",\n };\n if (this.clientOpts?.lazyLoadMembers) {\n params.filter = JSON.stringify(Filter.LAZY_LOADING_MESSAGES_FILTER);\n }\n\n const res = await this.http.authedRequest(Method.Get, messagesPath, params);\n event = res.chunk?.[0];\n }\n if (!event) {\n throw new Error(\"No message returned when trying to construct getLatestTimeline\");\n }\n\n return this.getEventTimeline(timelineSet, event.event_id);\n }\n\n /**\n * Makes a request to /messages with the appropriate lazy loading filter set.\n * XXX: if we do get rid of scrollback (as it's not used at the moment),\n * we could inline this method again in paginateEventTimeline as that would\n * then be the only call-site\n * @param limit - the maximum amount of events the retrieve\n * @param dir - 'f' or 'b'\n * @param timelineFilter - the timeline filter to pass\n */\n // XXX: Intended private, used in code.\n public createMessagesRequest(\n roomId: string,\n fromToken: string | null,\n limit = 30,\n dir: Direction,\n timelineFilter?: Filter,\n ): Promise {\n const path = utils.encodeUri(\"/rooms/$roomId/messages\", { $roomId: roomId });\n\n const params: Record = {\n limit: limit.toString(),\n dir: dir,\n };\n\n if (fromToken) {\n params.from = fromToken;\n }\n\n let filter: IRoomEventFilter | null = null;\n if (this.clientOpts?.lazyLoadMembers) {\n // create a shallow copy of LAZY_LOADING_MESSAGES_FILTER,\n // so the timelineFilter doesn't get written into it below\n filter = Object.assign({}, Filter.LAZY_LOADING_MESSAGES_FILTER);\n }\n if (timelineFilter) {\n // XXX: it's horrific that /messages' filter parameter doesn't match\n // /sync's one - see https://matrix.org/jira/browse/SPEC-451\n filter = filter || {};\n Object.assign(filter, timelineFilter.getRoomTimelineFilterComponent()?.toJSON());\n }\n if (filter) {\n params.filter = JSON.stringify(filter);\n }\n return this.http.authedRequest(Method.Get, path, params);\n }\n\n /**\n * Makes a request to /messages with the appropriate lazy loading filter set.\n * XXX: if we do get rid of scrollback (as it's not used at the moment),\n * we could inline this method again in paginateEventTimeline as that would\n * then be the only call-site\n * @param limit - the maximum amount of events the retrieve\n * @param dir - 'f' or 'b'\n * @param timelineFilter - the timeline filter to pass\n */\n // XXX: Intended private, used by room.fetchRoomThreads\n public createThreadListMessagesRequest(\n roomId: string,\n fromToken: string | null,\n limit = 30,\n dir = Direction.Backward,\n threadListType: ThreadFilterType | null = ThreadFilterType.All,\n timelineFilter?: Filter,\n ): Promise {\n const path = utils.encodeUri(\"/rooms/$roomId/threads\", { $roomId: roomId });\n\n const params: Record = {\n limit: limit.toString(),\n dir: dir,\n include: threadFilterTypeToFilter(threadListType),\n };\n\n if (fromToken) {\n params.from = fromToken;\n }\n\n let filter: IRoomEventFilter = {};\n if (this.clientOpts?.lazyLoadMembers) {\n // create a shallow copy of LAZY_LOADING_MESSAGES_FILTER,\n // so the timelineFilter doesn't get written into it below\n filter = {\n ...Filter.LAZY_LOADING_MESSAGES_FILTER,\n };\n }\n if (timelineFilter) {\n // XXX: it's horrific that /messages' filter parameter doesn't match\n // /sync's one - see https://matrix.org/jira/browse/SPEC-451\n filter = {\n ...filter,\n ...timelineFilter.getRoomTimelineFilterComponent()?.toJSON(),\n };\n }\n if (Object.keys(filter).length) {\n params.filter = JSON.stringify(filter);\n }\n\n const opts = {\n prefix:\n Thread.hasServerSideListSupport === FeatureSupport.Stable\n ? \"/_matrix/client/v1\"\n : \"/_matrix/client/unstable/org.matrix.msc3856\",\n };\n\n return this.http\n .authedRequest(Method.Get, path, params, undefined, opts)\n .then((res) => ({\n ...res,\n chunk: res.chunk?.reverse(),\n start: res.prev_batch,\n end: res.next_batch,\n }));\n }\n\n /**\n * Take an EventTimeline, and back/forward-fill results.\n *\n * @param eventTimeline - timeline object to be updated\n *\n * @returns Promise which resolves to a boolean: false if there are no\n * events and we reached either end of the timeline; else true.\n */\n public paginateEventTimeline(eventTimeline: EventTimeline, opts: IPaginateOpts): Promise {\n const isNotifTimeline = eventTimeline.getTimelineSet() === this.notifTimelineSet;\n const room = this.getRoom(eventTimeline.getRoomId()!);\n const threadListType = eventTimeline.getTimelineSet().threadListType;\n const thread = eventTimeline.getTimelineSet().thread;\n\n // TODO: we should implement a backoff (as per scrollback()) to deal more\n // nicely with HTTP errors.\n opts = opts || {};\n const backwards = opts.backwards || false;\n\n if (isNotifTimeline) {\n if (!backwards) {\n throw new Error(\"paginateNotifTimeline can only paginate backwards\");\n }\n }\n\n const dir = backwards ? EventTimeline.BACKWARDS : EventTimeline.FORWARDS;\n\n const token = eventTimeline.getPaginationToken(dir);\n const pendingRequest = eventTimeline.paginationRequests[dir];\n\n if (pendingRequest) {\n // already a request in progress - return the existing promise\n return pendingRequest;\n }\n\n let path: string;\n let params: Record;\n let promise: Promise;\n\n if (isNotifTimeline) {\n path = \"/notifications\";\n params = {\n limit: (opts.limit ?? 30).toString(),\n only: \"highlight\",\n };\n\n if (token && token !== \"end\") {\n params.from = token;\n }\n\n promise = this.http\n .authedRequest(Method.Get, path, params)\n .then(async (res) => {\n const token = res.next_token;\n const matrixEvents: MatrixEvent[] = [];\n\n res.notifications = res.notifications.filter(noUnsafeEventProps);\n\n for (let i = 0; i < res.notifications.length; i++) {\n const notification = res.notifications[i];\n const event = this.getEventMapper()(notification.event);\n event.setPushActions(PushProcessor.actionListToActionsObject(notification.actions));\n event.event.room_id = notification.room_id; // XXX: gutwrenching\n matrixEvents[i] = event;\n }\n\n // No need to partition events for threads here, everything lives\n // in the notification timeline set\n const timelineSet = eventTimeline.getTimelineSet();\n timelineSet.addEventsToTimeline(matrixEvents, backwards, eventTimeline, token);\n this.processAggregatedTimelineEvents(timelineSet.room, matrixEvents);\n\n // if we've hit the end of the timeline, we need to stop trying to\n // paginate. We need to keep the 'forwards' token though, to make sure\n // we can recover from gappy syncs.\n if (backwards && !res.next_token) {\n eventTimeline.setPaginationToken(null, dir);\n }\n return Boolean(res.next_token);\n })\n .finally(() => {\n eventTimeline.paginationRequests[dir] = null;\n });\n eventTimeline.paginationRequests[dir] = promise;\n } else if (threadListType !== null) {\n if (!room) {\n throw new Error(\"Unknown room \" + eventTimeline.getRoomId());\n }\n\n if (!Thread.hasServerSideFwdPaginationSupport && dir === Direction.Forward) {\n throw new Error(\"Cannot paginate threads forwards without server-side support for MSC 3715\");\n }\n\n promise = this.createThreadListMessagesRequest(\n eventTimeline.getRoomId()!,\n token,\n opts.limit,\n dir,\n threadListType,\n eventTimeline.getFilter(),\n )\n .then((res) => {\n if (res.state) {\n const roomState = eventTimeline.getState(dir)!;\n const stateEvents = res.state.filter(noUnsafeEventProps).map(this.getEventMapper());\n roomState.setUnknownStateEvents(stateEvents);\n }\n const token = res.end;\n const matrixEvents = res.chunk.filter(noUnsafeEventProps).map(this.getEventMapper());\n\n const timelineSet = eventTimeline.getTimelineSet();\n timelineSet.addEventsToTimeline(matrixEvents, backwards, eventTimeline, token);\n this.processAggregatedTimelineEvents(room, matrixEvents);\n this.processThreadRoots(room, matrixEvents, backwards);\n\n // if we've hit the end of the timeline, we need to stop trying to\n // paginate. We need to keep the 'forwards' token though, to make sure\n // we can recover from gappy syncs.\n if (backwards && res.end == res.start) {\n eventTimeline.setPaginationToken(null, dir);\n }\n return res.end !== res.start;\n })\n .finally(() => {\n eventTimeline.paginationRequests[dir] = null;\n });\n eventTimeline.paginationRequests[dir] = promise;\n } else if (thread) {\n const room = this.getRoom(eventTimeline.getRoomId() ?? undefined);\n if (!room) {\n throw new Error(\"Unknown room \" + eventTimeline.getRoomId());\n }\n\n promise = this.fetchRelations(eventTimeline.getRoomId() ?? \"\", thread.id, THREAD_RELATION_TYPE.name, null, {\n dir,\n limit: opts.limit,\n from: token ?? undefined,\n })\n .then(async (res) => {\n const mapper = this.getEventMapper();\n const matrixEvents = res.chunk.filter(noUnsafeEventProps).map(mapper);\n\n // Process latest events first\n for (const event of matrixEvents.slice().reverse()) {\n await thread?.processEvent(event);\n const sender = event.getSender()!;\n if (!backwards || thread?.getEventReadUpTo(sender) === null) {\n room.addLocalEchoReceipt(sender, event, ReceiptType.Read);\n }\n }\n\n const newToken = res.next_batch;\n\n const timelineSet = eventTimeline.getTimelineSet();\n timelineSet.addEventsToTimeline(matrixEvents, backwards, eventTimeline, newToken ?? null);\n if (!newToken && backwards) {\n const originalEvent = await this.fetchRoomEvent(eventTimeline.getRoomId() ?? \"\", thread.id);\n timelineSet.addEventsToTimeline([mapper(originalEvent)], true, eventTimeline, null);\n }\n this.processAggregatedTimelineEvents(timelineSet.room, matrixEvents);\n\n // if we've hit the end of the timeline, we need to stop trying to\n // paginate. We need to keep the 'forwards' token though, to make sure\n // we can recover from gappy syncs.\n if (backwards && !newToken) {\n eventTimeline.setPaginationToken(null, dir);\n }\n return Boolean(newToken);\n })\n .finally(() => {\n eventTimeline.paginationRequests[dir] = null;\n });\n eventTimeline.paginationRequests[dir] = promise;\n } else {\n if (!room) {\n throw new Error(\"Unknown room \" + eventTimeline.getRoomId());\n }\n\n promise = this.createMessagesRequest(\n eventTimeline.getRoomId()!,\n token,\n opts.limit,\n dir,\n eventTimeline.getFilter(),\n )\n .then((res) => {\n if (res.state) {\n const roomState = eventTimeline.getState(dir)!;\n const stateEvents = res.state.filter(noUnsafeEventProps).map(this.getEventMapper());\n roomState.setUnknownStateEvents(stateEvents);\n }\n const token = res.end;\n const matrixEvents = res.chunk.filter(noUnsafeEventProps).map(this.getEventMapper());\n\n const timelineSet = eventTimeline.getTimelineSet();\n const [timelineEvents] = room.partitionThreadedEvents(matrixEvents);\n timelineSet.addEventsToTimeline(timelineEvents, backwards, eventTimeline, token);\n this.processAggregatedTimelineEvents(room, timelineEvents);\n this.processThreadRoots(\n room,\n timelineEvents.filter((it) => it.getServerAggregatedRelation(THREAD_RELATION_TYPE.name)),\n false,\n );\n\n const atEnd = res.end === undefined || res.end === res.start;\n\n // if we've hit the end of the timeline, we need to stop trying to\n // paginate. We need to keep the 'forwards' token though, to make sure\n // we can recover from gappy syncs.\n if (backwards && atEnd) {\n eventTimeline.setPaginationToken(null, dir);\n }\n return !atEnd;\n })\n .finally(() => {\n eventTimeline.paginationRequests[dir] = null;\n });\n eventTimeline.paginationRequests[dir] = promise;\n }\n\n return promise;\n }\n\n /**\n * Reset the notifTimelineSet entirely, paginating in some historical notifs as\n * a starting point for subsequent pagination.\n */\n public resetNotifTimelineSet(): void {\n if (!this.notifTimelineSet) {\n return;\n }\n\n // FIXME: This thing is a total hack, and results in duplicate events being\n // added to the timeline both from /sync and /notifications, and lots of\n // slow and wasteful processing and pagination. The correct solution is to\n // extend /messages or /search or something to filter on notifications.\n\n // use the fictitious token 'end'. in practice we would ideally give it\n // the oldest backwards pagination token from /sync, but /sync doesn't\n // know about /notifications, so we have no choice but to start paginating\n // from the current point in time. This may well overlap with historical\n // notifs which are then inserted into the timeline by /sync responses.\n this.notifTimelineSet.resetLiveTimeline(\"end\");\n\n // we could try to paginate a single event at this point in order to get\n // a more valid pagination token, but it just ends up with an out of order\n // timeline. given what a mess this is and given we're going to have duplicate\n // events anyway, just leave it with the dummy token for now.\n /*\n this.paginateNotifTimeline(this._notifTimelineSet.getLiveTimeline(), {\n backwards: true,\n limit: 1\n });\n */\n }\n\n /**\n * Peek into a room and receive updates about the room. This only works if the\n * history visibility for the room is world_readable.\n * @param roomId - The room to attempt to peek into.\n * @returns Promise which resolves: Room object\n * @returns Rejects: with an error response.\n */\n public peekInRoom(roomId: string): Promise {\n this.peekSync?.stopPeeking();\n this.peekSync = new SyncApi(this, this.clientOpts, this.buildSyncApiOptions());\n return this.peekSync.peek(roomId);\n }\n\n /**\n * Stop any ongoing room peeking.\n */\n public stopPeeking(): void {\n if (this.peekSync) {\n this.peekSync.stopPeeking();\n this.peekSync = null;\n }\n }\n\n /**\n * Set r/w flags for guest access in a room.\n * @param roomId - The room to configure guest access in.\n * @param opts - Options\n * @returns Promise which resolves\n * @returns Rejects: with an error response.\n */\n public setGuestAccess(roomId: string, opts: IGuestAccessOpts): Promise {\n const writePromise = this.sendStateEvent(\n roomId,\n EventType.RoomGuestAccess,\n {\n guest_access: opts.allowJoin ? \"can_join\" : \"forbidden\",\n },\n \"\",\n );\n\n let readPromise: Promise = Promise.resolve(undefined);\n if (opts.allowRead) {\n readPromise = this.sendStateEvent(\n roomId,\n EventType.RoomHistoryVisibility,\n {\n history_visibility: \"world_readable\",\n },\n \"\",\n );\n }\n\n return Promise.all([readPromise, writePromise]).then(); // .then() to hide results for contract\n }\n\n /**\n * Requests an email verification token for the purposes of registration.\n * This API requests a token from the homeserver.\n * The doesServerRequireIdServerParam() method can be used to determine if\n * the server requires the id_server parameter to be provided.\n *\n * Parameters and return value are as for requestEmailToken\n\n * @param email - As requestEmailToken\n * @param clientSecret - As requestEmailToken\n * @param sendAttempt - As requestEmailToken\n * @param nextLink - As requestEmailToken\n * @returns Promise which resolves: As requestEmailToken\n */\n public requestRegisterEmailToken(\n email: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink?: string,\n ): Promise {\n return this.requestTokenFromEndpoint(\"/register/email/requestToken\", {\n email: email,\n client_secret: clientSecret,\n send_attempt: sendAttempt,\n next_link: nextLink,\n });\n }\n\n /**\n * Requests a text message verification token for the purposes of registration.\n * This API requests a token from the homeserver.\n * The doesServerRequireIdServerParam() method can be used to determine if\n * the server requires the id_server parameter to be provided.\n *\n * @param phoneCountry - The ISO 3166-1 alpha-2 code for the country in which\n * phoneNumber should be parsed relative to.\n * @param phoneNumber - The phone number, in national or international format\n * @param clientSecret - As requestEmailToken\n * @param sendAttempt - As requestEmailToken\n * @param nextLink - As requestEmailToken\n * @returns Promise which resolves: As requestEmailToken\n */\n public requestRegisterMsisdnToken(\n phoneCountry: string,\n phoneNumber: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink?: string,\n ): Promise {\n return this.requestTokenFromEndpoint(\"/register/msisdn/requestToken\", {\n country: phoneCountry,\n phone_number: phoneNumber,\n client_secret: clientSecret,\n send_attempt: sendAttempt,\n next_link: nextLink,\n });\n }\n\n /**\n * Requests an email verification token for the purposes of adding a\n * third party identifier to an account.\n * This API requests a token from the homeserver.\n * The doesServerRequireIdServerParam() method can be used to determine if\n * the server requires the id_server parameter to be provided.\n * If an account with the given email address already exists and is\n * associated with an account other than the one the user is authed as,\n * it will either send an email to the address informing them of this\n * or return M_THREEPID_IN_USE (which one is up to the homeserver).\n *\n * @param email - As requestEmailToken\n * @param clientSecret - As requestEmailToken\n * @param sendAttempt - As requestEmailToken\n * @param nextLink - As requestEmailToken\n * @returns Promise which resolves: As requestEmailToken\n */\n public requestAdd3pidEmailToken(\n email: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink?: string,\n ): Promise {\n return this.requestTokenFromEndpoint(\"/account/3pid/email/requestToken\", {\n email: email,\n client_secret: clientSecret,\n send_attempt: sendAttempt,\n next_link: nextLink,\n });\n }\n\n /**\n * Requests a text message verification token for the purposes of adding a\n * third party identifier to an account.\n * This API proxies the identity server /validate/email/requestToken API,\n * adding specific behaviour for the addition of phone numbers to an\n * account, as requestAdd3pidEmailToken.\n *\n * @param phoneCountry - As requestRegisterMsisdnToken\n * @param phoneNumber - As requestRegisterMsisdnToken\n * @param clientSecret - As requestEmailToken\n * @param sendAttempt - As requestEmailToken\n * @param nextLink - As requestEmailToken\n * @returns Promise which resolves: As requestEmailToken\n */\n public requestAdd3pidMsisdnToken(\n phoneCountry: string,\n phoneNumber: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink?: string,\n ): Promise {\n return this.requestTokenFromEndpoint(\"/account/3pid/msisdn/requestToken\", {\n country: phoneCountry,\n phone_number: phoneNumber,\n client_secret: clientSecret,\n send_attempt: sendAttempt,\n next_link: nextLink,\n });\n }\n\n /**\n * Requests an email verification token for the purposes of resetting\n * the password on an account.\n * This API proxies the identity server /validate/email/requestToken API,\n * adding specific behaviour for the password resetting. Specifically,\n * if no account with the given email address exists, it may either\n * return M_THREEPID_NOT_FOUND or send an email\n * to the address informing them of this (which one is up to the homeserver).\n *\n * requestEmailToken calls the equivalent API directly on the identity server,\n * therefore bypassing the password reset specific logic.\n *\n * @param email - As requestEmailToken\n * @param clientSecret - As requestEmailToken\n * @param sendAttempt - As requestEmailToken\n * @param nextLink - As requestEmailToken\n * @returns Promise which resolves: As requestEmailToken\n */\n public requestPasswordEmailToken(\n email: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink?: string,\n ): Promise {\n return this.requestTokenFromEndpoint(\"/account/password/email/requestToken\", {\n email: email,\n client_secret: clientSecret,\n send_attempt: sendAttempt,\n next_link: nextLink,\n });\n }\n\n /**\n * Requests a text message verification token for the purposes of resetting\n * the password on an account.\n * This API proxies the identity server /validate/email/requestToken API,\n * adding specific behaviour for the password resetting, as requestPasswordEmailToken.\n *\n * @param phoneCountry - As requestRegisterMsisdnToken\n * @param phoneNumber - As requestRegisterMsisdnToken\n * @param clientSecret - As requestEmailToken\n * @param sendAttempt - As requestEmailToken\n * @param nextLink - As requestEmailToken\n * @returns Promise which resolves: As requestEmailToken\n */\n public requestPasswordMsisdnToken(\n phoneCountry: string,\n phoneNumber: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink: string,\n ): Promise {\n return this.requestTokenFromEndpoint(\"/account/password/msisdn/requestToken\", {\n country: phoneCountry,\n phone_number: phoneNumber,\n client_secret: clientSecret,\n send_attempt: sendAttempt,\n next_link: nextLink,\n });\n }\n\n /**\n * Internal utility function for requesting validation tokens from usage-specific\n * requestToken endpoints.\n *\n * @param endpoint - The endpoint to send the request to\n * @param params - Parameters for the POST request\n * @returns Promise which resolves: As requestEmailToken\n */\n private async requestTokenFromEndpoint(\n endpoint: string,\n params: Record,\n ): Promise {\n const postParams = Object.assign({}, params);\n\n // If the HS supports separate add and bind, then requestToken endpoints\n // don't need an IS as they are all validated by the HS directly.\n if (!(await this.doesServerSupportSeparateAddAndBind()) && this.idBaseUrl) {\n const idServerUrl = new URL(this.idBaseUrl);\n postParams.id_server = idServerUrl.host;\n\n if (this.identityServer?.getAccessToken && (await this.doesServerAcceptIdentityAccessToken())) {\n const identityAccessToken = await this.identityServer.getAccessToken();\n if (identityAccessToken) {\n postParams.id_access_token = identityAccessToken;\n }\n }\n }\n\n return this.http.request(Method.Post, endpoint, undefined, postParams);\n }\n\n /**\n * Get the room-kind push rule associated with a room.\n * @param scope - \"global\" or device-specific.\n * @param roomId - the id of the room.\n * @returns the rule or undefined.\n */\n public getRoomPushRule(scope: \"global\" | \"device\", roomId: string): IPushRule | undefined {\n // There can be only room-kind push rule per room\n // and its id is the room id.\n if (this.pushRules) {\n return this.pushRules[scope]?.room?.find((rule) => rule.rule_id === roomId);\n } else {\n throw new Error(\"SyncApi.sync() must be done before accessing to push rules.\");\n }\n }\n\n /**\n * Set a room-kind muting push rule in a room.\n * The operation also updates MatrixClient.pushRules at the end.\n * @param scope - \"global\" or device-specific.\n * @param roomId - the id of the room.\n * @param mute - the mute state.\n * @returns Promise which resolves: result object\n * @returns Rejects: with an error response.\n */\n public setRoomMutePushRule(scope: \"global\" | \"device\", roomId: string, mute: boolean): Promise | undefined {\n let promise: Promise | undefined;\n let hasDontNotifyRule = false;\n\n // Get the existing room-kind push rule if any\n const roomPushRule = this.getRoomPushRule(scope, roomId);\n if (roomPushRule?.actions.includes(PushRuleActionName.DontNotify)) {\n hasDontNotifyRule = true;\n }\n\n if (!mute) {\n // Remove the rule only if it is a muting rule\n if (hasDontNotifyRule) {\n promise = this.deletePushRule(scope, PushRuleKind.RoomSpecific, roomPushRule!.rule_id);\n }\n } else {\n if (!roomPushRule) {\n promise = this.addPushRule(scope, PushRuleKind.RoomSpecific, roomId, {\n actions: [PushRuleActionName.DontNotify],\n });\n } else if (!hasDontNotifyRule) {\n // Remove the existing one before setting the mute push rule\n // This is a workaround to SYN-590 (Push rule update fails)\n const deferred = utils.defer();\n this.deletePushRule(scope, PushRuleKind.RoomSpecific, roomPushRule.rule_id)\n .then(() => {\n this.addPushRule(scope, PushRuleKind.RoomSpecific, roomId, {\n actions: [PushRuleActionName.DontNotify],\n })\n .then(() => {\n deferred.resolve();\n })\n .catch((err) => {\n deferred.reject(err);\n });\n })\n .catch((err) => {\n deferred.reject(err);\n });\n\n promise = deferred.promise;\n }\n }\n\n if (promise) {\n return new Promise((resolve, reject) => {\n // Update this.pushRules when the operation completes\n promise!\n .then(() => {\n this.getPushRules()\n .then((result) => {\n this.pushRules = result;\n resolve();\n })\n .catch((err) => {\n reject(err);\n });\n })\n .catch((err: Error) => {\n // Update it even if the previous operation fails. This can help the\n // app to recover when push settings has been modified from another client\n this.getPushRules()\n .then((result) => {\n this.pushRules = result;\n reject(err);\n })\n .catch((err2) => {\n reject(err);\n });\n });\n });\n }\n }\n\n public searchMessageText(opts: ISearchOpts): Promise {\n const roomEvents: ISearchRequestBody[\"search_categories\"][\"room_events\"] = {\n search_term: opts.query,\n };\n\n if (\"keys\" in opts) {\n roomEvents.keys = opts.keys;\n }\n\n return this.search({\n body: {\n search_categories: {\n room_events: roomEvents,\n },\n },\n });\n }\n\n /**\n * Perform a server-side search for room events.\n *\n * The returned promise resolves to an object containing the fields:\n *\n * * count: estimate of the number of results\n * * next_batch: token for back-pagination; if undefined, there are no more results\n * * highlights: a list of words to highlight from the stemming algorithm\n * * results: a list of results\n *\n * Each entry in the results list is a SearchResult.\n *\n * @returns Promise which resolves: result object\n * @returns Rejects: with an error response.\n */\n public searchRoomEvents(opts: IEventSearchOpts): Promise {\n // TODO: support search groups\n\n const body = {\n search_categories: {\n room_events: {\n search_term: opts.term,\n filter: opts.filter,\n order_by: SearchOrderBy.Recent,\n event_context: {\n before_limit: 1,\n after_limit: 1,\n include_profile: true,\n },\n },\n },\n };\n\n const searchResults: ISearchResults = {\n _query: body,\n results: [],\n highlights: [],\n };\n\n return this.search({ body: body }).then((res) => this.processRoomEventsSearch(searchResults, res));\n }\n\n /**\n * Take a result from an earlier searchRoomEvents call, and backfill results.\n *\n * @param searchResults - the results object to be updated\n * @returns Promise which resolves: updated result object\n * @returns Rejects: with an error response.\n */\n public backPaginateRoomEventsSearch(searchResults: T): Promise {\n // TODO: we should implement a backoff (as per scrollback()) to deal more\n // nicely with HTTP errors.\n\n if (!searchResults.next_batch) {\n return Promise.reject(new Error(\"Cannot backpaginate event search any further\"));\n }\n\n if (searchResults.pendingRequest) {\n // already a request in progress - return the existing promise\n return searchResults.pendingRequest as Promise;\n }\n\n const searchOpts = {\n body: searchResults._query!,\n next_batch: searchResults.next_batch,\n };\n\n const promise = this.search(searchOpts, searchResults.abortSignal)\n .then((res) => this.processRoomEventsSearch(searchResults, res))\n .finally(() => {\n searchResults.pendingRequest = undefined;\n });\n searchResults.pendingRequest = promise;\n\n return promise;\n }\n\n /**\n * helper for searchRoomEvents and backPaginateRoomEventsSearch. Processes the\n * response from the API call and updates the searchResults\n *\n * @returns searchResults\n * @internal\n */\n // XXX: Intended private, used in code\n public processRoomEventsSearch(searchResults: T, response: ISearchResponse): T {\n const roomEvents = response.search_categories.room_events;\n\n searchResults.count = roomEvents.count;\n searchResults.next_batch = roomEvents.next_batch;\n\n // combine the highlight list with our existing list;\n const highlights = new Set(roomEvents.highlights);\n searchResults.highlights.forEach((hl) => {\n highlights.add(hl);\n });\n\n // turn it back into a list.\n searchResults.highlights = Array.from(highlights);\n\n const mapper = this.getEventMapper();\n\n // append the new results to our existing results\n const resultsLength = roomEvents.results?.length ?? 0;\n for (let i = 0; i < resultsLength; i++) {\n const sr = SearchResult.fromJson(roomEvents.results[i], mapper);\n const room = this.getRoom(sr.context.getEvent().getRoomId());\n if (room) {\n // Copy over a known event sender if we can\n for (const ev of sr.context.getTimeline()) {\n const sender = room.getMember(ev.getSender()!);\n if (!ev.sender && sender) ev.sender = sender;\n }\n }\n searchResults.results.push(sr);\n }\n return searchResults;\n }\n\n /**\n * Populate the store with rooms the user has left.\n * @returns Promise which resolves: TODO - Resolved when the rooms have\n * been added to the data store.\n * @returns Rejects: with an error response.\n */\n public syncLeftRooms(): Promise {\n // Guard against multiple calls whilst ongoing and multiple calls post success\n if (this.syncedLeftRooms) {\n return Promise.resolve([]); // don't call syncRooms again if it succeeded.\n }\n if (this.syncLeftRoomsPromise) {\n return this.syncLeftRoomsPromise; // return the ongoing request\n }\n const syncApi = new SyncApi(this, this.clientOpts, this.buildSyncApiOptions());\n this.syncLeftRoomsPromise = syncApi.syncLeftRooms();\n\n // cleanup locks\n this.syncLeftRoomsPromise\n .then(() => {\n logger.log(\"Marking success of sync left room request\");\n this.syncedLeftRooms = true; // flip the bit on success\n })\n .finally(() => {\n this.syncLeftRoomsPromise = undefined; // cleanup ongoing request state\n });\n\n return this.syncLeftRoomsPromise;\n }\n\n /**\n * Create a new filter.\n * @param content - The HTTP body for the request\n * @returns Promise which resolves to a Filter object.\n * @returns Rejects: with an error response.\n */\n public createFilter(content: IFilterDefinition): Promise {\n const path = utils.encodeUri(\"/user/$userId/filter\", {\n $userId: this.credentials.userId!,\n });\n return this.http.authedRequest(Method.Post, path, undefined, content).then((response) => {\n // persist the filter\n const filter = Filter.fromJson(this.credentials.userId, response.filter_id, content);\n this.store.storeFilter(filter);\n return filter;\n });\n }\n\n /**\n * Retrieve a filter.\n * @param userId - The user ID of the filter owner\n * @param filterId - The filter ID to retrieve\n * @param allowCached - True to allow cached filters to be returned.\n * Default: True.\n * @returns Promise which resolves: a Filter object\n * @returns Rejects: with an error response.\n */\n public getFilter(userId: string, filterId: string, allowCached: boolean): Promise {\n if (allowCached) {\n const filter = this.store.getFilter(userId, filterId);\n if (filter) {\n return Promise.resolve(filter);\n }\n }\n\n const path = utils.encodeUri(\"/user/$userId/filter/$filterId\", {\n $userId: userId,\n $filterId: filterId,\n });\n\n return this.http.authedRequest(Method.Get, path).then((response) => {\n // persist the filter\n const filter = Filter.fromJson(userId, filterId, response);\n this.store.storeFilter(filter);\n return filter;\n });\n }\n\n /**\n * @returns Filter ID\n */\n public async getOrCreateFilter(filterName: string, filter: Filter): Promise {\n const filterId = this.store.getFilterIdByName(filterName);\n let existingId: string | undefined;\n\n if (filterId) {\n // check that the existing filter matches our expectations\n try {\n const existingFilter = await this.getFilter(this.credentials.userId!, filterId, true);\n if (existingFilter) {\n const oldDef = existingFilter.getDefinition();\n const newDef = filter.getDefinition();\n\n if (utils.deepCompare(oldDef, newDef)) {\n // super, just use that.\n // debuglog(\"Using existing filter ID %s: %s\", filterId,\n // JSON.stringify(oldDef));\n existingId = filterId;\n }\n }\n } catch (error) {\n // Synapse currently returns the following when the filter cannot be found:\n // {\n // errcode: \"M_UNKNOWN\",\n // name: \"M_UNKNOWN\",\n // message: \"No row found\",\n // }\n if ((error).errcode !== \"M_UNKNOWN\" && (error).errcode !== \"M_NOT_FOUND\") {\n throw error;\n }\n }\n // if the filter doesn't exist anymore on the server, remove from store\n if (!existingId) {\n this.store.setFilterIdByName(filterName, undefined);\n }\n }\n\n if (existingId) {\n return existingId;\n }\n\n // create a new filter\n const createdFilter = await this.createFilter(filter.getDefinition());\n\n this.store.setFilterIdByName(filterName, createdFilter.filterId);\n return createdFilter.filterId!;\n }\n\n /**\n * Gets a bearer token from the homeserver that the user can\n * present to a third party in order to prove their ownership\n * of the Matrix account they are logged into.\n * @returns Promise which resolves: Token object\n * @returns Rejects: with an error response.\n */\n public getOpenIdToken(): Promise {\n const path = utils.encodeUri(\"/user/$userId/openid/request_token\", {\n $userId: this.credentials.userId!,\n });\n\n return this.http.authedRequest(Method.Post, path, undefined, {});\n }\n\n private startCallEventHandler = (): void => {\n if (this.isInitialSyncComplete()) {\n this.callEventHandler!.start();\n this.groupCallEventHandler!.start();\n this.off(ClientEvent.Sync, this.startCallEventHandler);\n }\n };\n\n /**\n * Once the client has been initialised, we want to clear notifications we\n * know for a fact should be here.\n * This issue should also be addressed on synapse's side and is tracked as part\n * of https://github.com/matrix-org/synapse/issues/14837\n *\n * We consider a room or a thread as fully read if the current user has sent\n * the last event in the live timeline of that context and if the read receipt\n * we have on record matches.\n */\n private fixupRoomNotifications = (): void => {\n if (this.isInitialSyncComplete()) {\n const unreadRooms = (this.getRooms() ?? []).filter((room) => {\n return room.getUnreadNotificationCount(NotificationCountType.Total) > 0;\n });\n\n for (const room of unreadRooms) {\n const currentUserId = this.getSafeUserId();\n room.fixupNotifications(currentUserId);\n }\n\n this.off(ClientEvent.Sync, this.fixupRoomNotifications);\n }\n };\n\n /**\n * @returns Promise which resolves: ITurnServerResponse object\n * @returns Rejects: with an error response.\n */\n public turnServer(): Promise {\n return this.http.authedRequest(Method.Get, \"/voip/turnServer\");\n }\n\n /**\n * Get the TURN servers for this homeserver.\n * @returns The servers or an empty list.\n */\n public getTurnServers(): ITurnServer[] {\n return this.turnServers || [];\n }\n\n /**\n * Get the unix timestamp (in milliseconds) at which the current\n * TURN credentials (from getTurnServers) expire\n * @returns The expiry timestamp in milliseconds\n */\n public getTurnServersExpiry(): number {\n return this.turnServersExpiry;\n }\n\n public get pollingTurnServers(): boolean {\n return this.checkTurnServersIntervalID !== undefined;\n }\n\n // XXX: Intended private, used in code.\n public async checkTurnServers(): Promise {\n if (!this.canSupportVoip) {\n return;\n }\n\n let credentialsGood = false;\n const remainingTime = this.turnServersExpiry - Date.now();\n if (remainingTime > TURN_CHECK_INTERVAL) {\n logger.debug(\"TURN creds are valid for another \" + remainingTime + \" ms: not fetching new ones.\");\n credentialsGood = true;\n } else {\n logger.debug(\"Fetching new TURN credentials\");\n try {\n const res = await this.turnServer();\n if (res.uris) {\n logger.log(\"Got TURN URIs: \" + res.uris + \" refresh in \" + res.ttl + \" secs\");\n // map the response to a format that can be fed to RTCPeerConnection\n const servers: ITurnServer = {\n urls: res.uris,\n username: res.username,\n credential: res.password,\n };\n this.turnServers = [servers];\n // The TTL is in seconds but we work in ms\n this.turnServersExpiry = Date.now() + res.ttl * 1000;\n credentialsGood = true;\n this.emit(ClientEvent.TurnServers, this.turnServers);\n }\n } catch (err) {\n logger.error(\"Failed to get TURN URIs\", err);\n if ((err).httpStatus === 403) {\n // We got a 403, so there's no point in looping forever.\n logger.info(\"TURN access unavailable for this account: stopping credentials checks\");\n if (this.checkTurnServersIntervalID !== null) global.clearInterval(this.checkTurnServersIntervalID);\n this.checkTurnServersIntervalID = undefined;\n this.emit(ClientEvent.TurnServersError, err, true); // fatal\n } else {\n // otherwise, if we failed for whatever reason, try again the next time we're called.\n this.emit(ClientEvent.TurnServersError, err, false); // non-fatal\n }\n }\n }\n\n return credentialsGood;\n }\n\n /**\n * Set whether to allow a fallback ICE server should be used for negotiating a\n * WebRTC connection if the homeserver doesn't provide any servers. Defaults to\n * false.\n *\n */\n public setFallbackICEServerAllowed(allow: boolean): void {\n this.fallbackICEServerAllowed = allow;\n }\n\n /**\n * Get whether to allow a fallback ICE server should be used for negotiating a\n * WebRTC connection if the homeserver doesn't provide any servers. Defaults to\n * false.\n *\n * @returns\n */\n public isFallbackICEServerAllowed(): boolean {\n return this.fallbackICEServerAllowed;\n }\n\n /**\n * Determines if the current user is an administrator of the Synapse homeserver.\n * Returns false if untrue or the homeserver does not appear to be a Synapse\n * homeserver. This function is implementation specific and may change\n * as a result.\n * @returns true if the user appears to be a Synapse administrator.\n */\n public isSynapseAdministrator(): Promise {\n const path = utils.encodeUri(\"/_synapse/admin/v1/users/$userId/admin\", { $userId: this.getUserId()! });\n return this.http\n .authedRequest<{ admin: boolean }>(Method.Get, path, undefined, undefined, { prefix: \"\" })\n .then((r) => r.admin); // pull out the specific boolean we want\n }\n\n /**\n * Performs a whois lookup on a user using Synapse's administrator API.\n * This function is implementation specific and may change as a\n * result.\n * @param userId - the User ID to look up.\n * @returns the whois response - see Synapse docs for information.\n */\n public whoisSynapseUser(userId: string): Promise {\n const path = utils.encodeUri(\"/_synapse/admin/v1/whois/$userId\", { $userId: userId });\n return this.http.authedRequest(Method.Get, path, undefined, undefined, { prefix: \"\" });\n }\n\n /**\n * Deactivates a user using Synapse's administrator API. This\n * function is implementation specific and may change as a result.\n * @param userId - the User ID to deactivate.\n * @returns the deactivate response - see Synapse docs for information.\n */\n public deactivateSynapseUser(userId: string): Promise {\n const path = utils.encodeUri(\"/_synapse/admin/v1/deactivate/$userId\", { $userId: userId });\n return this.http.authedRequest(Method.Post, path, undefined, undefined, { prefix: \"\" });\n }\n\n private async fetchClientWellKnown(): Promise {\n // `getRawClientConfig` does not throw or reject on network errors, instead\n // it absorbs errors and returns `{}`.\n this.clientWellKnownPromise = AutoDiscovery.getRawClientConfig(this.getDomain() ?? undefined);\n this.clientWellKnown = await this.clientWellKnownPromise;\n this.emit(ClientEvent.ClientWellKnown, this.clientWellKnown);\n }\n\n public getClientWellKnown(): IClientWellKnown | undefined {\n return this.clientWellKnown;\n }\n\n public waitForClientWellKnown(): Promise {\n if (!this.clientRunning) {\n throw new Error(\"Client is not running\");\n }\n return this.clientWellKnownPromise!;\n }\n\n /**\n * store client options with boolean/string/numeric values\n * to know in the next session what flags the sync data was\n * created with (e.g. lazy loading)\n * @param opts - the complete set of client options\n * @returns for store operation\n */\n public storeClientOptions(): Promise {\n // XXX: Intended private, used in code\n const primTypes = [\"boolean\", \"string\", \"number\"];\n const serializableOpts = Object.entries(this.clientOpts!)\n .filter(([key, value]) => {\n return primTypes.includes(typeof value);\n })\n .reduce>((obj, [key, value]) => {\n obj[key] = value;\n return obj;\n }, {});\n return this.store.storeClientOptions(serializableOpts);\n }\n\n /**\n * Gets a set of room IDs in common with another user\n * @param userId - The userId to check.\n * @returns Promise which resolves to a set of rooms\n * @returns Rejects: with an error response.\n */\n // eslint-disable-next-line\n public async _unstable_getSharedRooms(userId: string): Promise {\n const sharedRoomsSupport = await this.doesServerSupportUnstableFeature(\"uk.half-shot.msc2666\");\n const mutualRoomsSupport = await this.doesServerSupportUnstableFeature(\"uk.half-shot.msc2666.mutual_rooms\");\n\n if (!sharedRoomsSupport && !mutualRoomsSupport) {\n throw Error(\"Server does not support mutual_rooms API\");\n }\n\n const path = utils.encodeUri(\n `/uk.half-shot.msc2666/user/${mutualRoomsSupport ? \"mutual_rooms\" : \"shared_rooms\"}/$userId`,\n { $userId: userId },\n );\n\n const res = await this.http.authedRequest<{ joined: string[] }>(Method.Get, path, undefined, undefined, {\n prefix: ClientPrefix.Unstable,\n });\n return res.joined;\n }\n\n /**\n * Get the API versions supported by the server, along with any\n * unstable APIs it supports\n * @returns The server /versions response\n */\n public async getVersions(): Promise {\n if (this.serverVersionsPromise) {\n return this.serverVersionsPromise;\n }\n\n this.serverVersionsPromise = this.http\n .request(\n Method.Get,\n \"/_matrix/client/versions\",\n undefined, // queryParams\n undefined, // data\n {\n prefix: \"\",\n },\n )\n .catch((e) => {\n // Need to unset this if it fails, otherwise we'll never retry\n this.serverVersionsPromise = undefined;\n // but rethrow the exception to anything that was waiting\n throw e;\n });\n\n const serverVersions = await this.serverVersionsPromise;\n this.canSupport = await buildFeatureSupportMap(serverVersions);\n\n return this.serverVersionsPromise;\n }\n\n /**\n * Check if a particular spec version is supported by the server.\n * @param version - The spec version (such as \"r0.5.0\") to check for.\n * @returns Whether it is supported\n */\n public async isVersionSupported(version: string): Promise {\n const { versions } = await this.getVersions();\n return versions && versions.includes(version);\n }\n\n /**\n * Query the server to see if it supports members lazy loading\n * @returns true if server supports lazy loading\n */\n public async doesServerSupportLazyLoading(): Promise {\n const response = await this.getVersions();\n if (!response) return false;\n\n const versions = response[\"versions\"];\n const unstableFeatures = response[\"unstable_features\"];\n\n return (\n (versions && versions.includes(\"r0.5.0\")) || (unstableFeatures && unstableFeatures[\"m.lazy_load_members\"])\n );\n }\n\n /**\n * Query the server to see if the `id_server` parameter is required\n * when registering with an 3pid, adding a 3pid or resetting password.\n * @returns true if id_server parameter is required\n */\n public async doesServerRequireIdServerParam(): Promise {\n const response = await this.getVersions();\n if (!response) return true;\n\n const versions = response[\"versions\"];\n\n // Supporting r0.6.0 is the same as having the flag set to false\n if (versions && versions.includes(\"r0.6.0\")) {\n return false;\n }\n\n const unstableFeatures = response[\"unstable_features\"];\n if (!unstableFeatures) return true;\n if (unstableFeatures[\"m.require_identity_server\"] === undefined) {\n return true;\n } else {\n return unstableFeatures[\"m.require_identity_server\"];\n }\n }\n\n /**\n * Query the server to see if the `id_access_token` parameter can be safely\n * passed to the homeserver. Some homeservers may trigger errors if they are not\n * prepared for the new parameter.\n * @returns true if id_access_token can be sent\n */\n public async doesServerAcceptIdentityAccessToken(): Promise {\n const response = await this.getVersions();\n if (!response) return false;\n\n const versions = response[\"versions\"];\n const unstableFeatures = response[\"unstable_features\"];\n return (versions && versions.includes(\"r0.6.0\")) || (unstableFeatures && unstableFeatures[\"m.id_access_token\"]);\n }\n\n /**\n * Query the server to see if it supports separate 3PID add and bind functions.\n * This affects the sequence of API calls clients should use for these operations,\n * so it's helpful to be able to check for support.\n * @returns true if separate functions are supported\n */\n public async doesServerSupportSeparateAddAndBind(): Promise {\n const response = await this.getVersions();\n if (!response) return false;\n\n const versions = response[\"versions\"];\n const unstableFeatures = response[\"unstable_features\"];\n\n return versions?.includes(\"r0.6.0\") || unstableFeatures?.[\"m.separate_add_and_bind\"];\n }\n\n /**\n * Query the server to see if it lists support for an unstable feature\n * in the /versions response\n * @param feature - the feature name\n * @returns true if the feature is supported\n */\n public async doesServerSupportUnstableFeature(feature: string): Promise {\n const response = await this.getVersions();\n if (!response) return false;\n const unstableFeatures = response[\"unstable_features\"];\n return unstableFeatures && !!unstableFeatures[feature];\n }\n\n /**\n * Query the server to see if it is forcing encryption to be enabled for\n * a given room preset, based on the /versions response.\n * @param presetName - The name of the preset to check.\n * @returns true if the server is forcing encryption\n * for the preset.\n */\n public async doesServerForceEncryptionForPreset(presetName: Preset): Promise {\n const response = await this.getVersions();\n if (!response) return false;\n const unstableFeatures = response[\"unstable_features\"];\n\n // The preset name in the versions response will be without the _chat suffix.\n const versionsPresetName = presetName.includes(\"_chat\")\n ? presetName.substring(0, presetName.indexOf(\"_chat\"))\n : presetName;\n\n return unstableFeatures && !!unstableFeatures[`io.element.e2ee_forced.${versionsPresetName}`];\n }\n\n public async doesServerSupportThread(): Promise<{\n threads: FeatureSupport;\n list: FeatureSupport;\n fwdPagination: FeatureSupport;\n }> {\n if (await this.isVersionSupported(\"v1.4\")) {\n return {\n threads: FeatureSupport.Stable,\n list: FeatureSupport.Stable,\n fwdPagination: FeatureSupport.Stable,\n };\n }\n\n try {\n const [threadUnstable, threadStable, listUnstable, listStable, fwdPaginationUnstable, fwdPaginationStable] =\n await Promise.all([\n this.doesServerSupportUnstableFeature(\"org.matrix.msc3440\"),\n this.doesServerSupportUnstableFeature(\"org.matrix.msc3440.stable\"),\n this.doesServerSupportUnstableFeature(\"org.matrix.msc3856\"),\n this.doesServerSupportUnstableFeature(\"org.matrix.msc3856.stable\"),\n this.doesServerSupportUnstableFeature(\"org.matrix.msc3715\"),\n this.doesServerSupportUnstableFeature(\"org.matrix.msc3715.stable\"),\n ]);\n\n return {\n threads: determineFeatureSupport(threadStable, threadUnstable),\n list: determineFeatureSupport(listStable, listUnstable),\n fwdPagination: determineFeatureSupport(fwdPaginationStable, fwdPaginationUnstable),\n };\n } catch (e) {\n return {\n threads: FeatureSupport.None,\n list: FeatureSupport.None,\n fwdPagination: FeatureSupport.None,\n };\n }\n }\n\n /**\n * Query the server to see if it supports the MSC2457 `logout_devices` parameter when setting password\n * @returns true if server supports the `logout_devices` parameter\n */\n public doesServerSupportLogoutDevices(): Promise {\n return this.isVersionSupported(\"r0.6.1\");\n }\n\n /**\n * Get if lazy loading members is being used.\n * @returns Whether or not members are lazy loaded by this client\n */\n public hasLazyLoadMembersEnabled(): boolean {\n return !!this.clientOpts?.lazyLoadMembers;\n }\n\n /**\n * Set a function which is called when /sync returns a 'limited' response.\n * It is called with a room ID and returns a boolean. It should return 'true' if the SDK\n * can SAFELY remove events from this room. It may not be safe to remove events if there\n * are other references to the timelines for this room, e.g because the client is\n * actively viewing events in this room.\n * Default: returns false.\n * @param cb - The callback which will be invoked.\n */\n public setCanResetTimelineCallback(cb: ResetTimelineCallback): void {\n this.canResetTimelineCallback = cb;\n }\n\n /**\n * Get the callback set via `setCanResetTimelineCallback`.\n * @returns The callback or null\n */\n public getCanResetTimelineCallback(): ResetTimelineCallback | undefined {\n return this.canResetTimelineCallback;\n }\n\n /**\n * Returns relations for a given event. Handles encryption transparently,\n * with the caveat that the amount of events returned might be 0, even though you get a nextBatch.\n * When the returned promise resolves, all messages should have finished trying to decrypt.\n * @param roomId - the room of the event\n * @param eventId - the id of the event\n * @param relationType - the rel_type of the relations requested\n * @param eventType - the event type of the relations requested\n * @param opts - options with optional values for the request.\n * @returns an object with `events` as `MatrixEvent[]` and optionally `nextBatch` if more relations are available.\n */\n public async relations(\n roomId: string,\n eventId: string,\n relationType?: RelationType | string | null,\n eventType?: EventType | string | null,\n opts: IRelationsRequestOpts = { dir: Direction.Backward },\n ): Promise<{\n originalEvent?: MatrixEvent | null;\n events: MatrixEvent[];\n nextBatch?: string | null;\n prevBatch?: string | null;\n }> {\n const fetchedEventType = eventType ? this.getEncryptedIfNeededEventType(roomId, eventType) : null;\n const [eventResult, result] = await Promise.all([\n this.fetchRoomEvent(roomId, eventId),\n this.fetchRelations(roomId, eventId, relationType, fetchedEventType, opts),\n ]);\n const mapper = this.getEventMapper();\n\n const originalEvent = eventResult ? mapper(eventResult) : undefined;\n let events = result.chunk.map(mapper);\n\n if (fetchedEventType === EventType.RoomMessageEncrypted) {\n const allEvents = originalEvent ? events.concat(originalEvent) : events;\n await Promise.all(allEvents.map((e) => this.decryptEventIfNeeded(e)));\n if (eventType !== null) {\n events = events.filter((e) => e.getType() === eventType);\n }\n }\n\n if (originalEvent && relationType === RelationType.Replace) {\n events = events.filter((e) => e.getSender() === originalEvent.getSender());\n }\n return {\n originalEvent: originalEvent ?? null,\n events,\n nextBatch: result.next_batch ?? null,\n prevBatch: result.prev_batch ?? null,\n };\n }\n\n /**\n * The app may wish to see if we have a key cached without\n * triggering a user interaction.\n */\n public getCrossSigningCacheCallbacks(): ICacheCallbacks | undefined {\n // XXX: Private member access\n return this.crypto?.crossSigningInfo.getCacheCallbacks();\n }\n\n /**\n * Generates a random string suitable for use as a client secret. This\n * method is experimental and may change.\n * @returns A new client secret\n */\n public generateClientSecret(): string {\n return randomString(32);\n }\n\n /**\n * Attempts to decrypt an event\n * @param event - The event to decrypt\n * @returns A decryption promise\n */\n public decryptEventIfNeeded(event: MatrixEvent, options?: IDecryptOptions): Promise {\n if (event.shouldAttemptDecryption() && this.isCryptoEnabled()) {\n event.attemptDecryption(this.cryptoBackend!, options);\n }\n\n if (event.isBeingDecrypted()) {\n return event.getDecryptionPromise()!;\n } else {\n return Promise.resolve();\n }\n }\n\n private termsUrlForService(serviceType: SERVICE_TYPES, baseUrl: string): URL {\n switch (serviceType) {\n case SERVICE_TYPES.IS:\n return this.http.getUrl(\"/terms\", undefined, IdentityPrefix.V2, baseUrl);\n case SERVICE_TYPES.IM:\n return this.http.getUrl(\"/terms\", undefined, \"/_matrix/integrations/v1\", baseUrl);\n default:\n throw new Error(\"Unsupported service type\");\n }\n }\n\n /**\n * Get the Homeserver URL of this client\n * @returns Homeserver URL of this client\n */\n public getHomeserverUrl(): string {\n return this.baseUrl;\n }\n\n /**\n * Get the identity server URL of this client\n * @param stripProto - whether or not to strip the protocol from the URL\n * @returns Identity server URL of this client\n */\n public getIdentityServerUrl(stripProto = false): string | undefined {\n if (stripProto && (this.idBaseUrl?.startsWith(\"http://\") || this.idBaseUrl?.startsWith(\"https://\"))) {\n return this.idBaseUrl.split(\"://\")[1];\n }\n return this.idBaseUrl;\n }\n\n /**\n * Set the identity server URL of this client\n * @param url - New identity server URL\n */\n public setIdentityServerUrl(url: string): void {\n this.idBaseUrl = utils.ensureNoTrailingSlash(url);\n this.http.setIdBaseUrl(this.idBaseUrl);\n }\n\n /**\n * Get the access token associated with this account.\n * @returns The access_token or null\n */\n public getAccessToken(): string | null {\n return this.http.opts.accessToken || null;\n }\n\n /**\n * Set the access token associated with this account.\n * @param token - The new access token.\n */\n public setAccessToken(token: string): void {\n this.http.opts.accessToken = token;\n }\n\n /**\n * @returns true if there is a valid access_token for this client.\n */\n public isLoggedIn(): boolean {\n return this.http.opts.accessToken !== undefined;\n }\n\n /**\n * Make up a new transaction id\n *\n * @returns a new, unique, transaction id\n */\n public makeTxnId(): string {\n return \"m\" + new Date().getTime() + \".\" + this.txnCtr++;\n }\n\n /**\n * Check whether a username is available prior to registration. An error response\n * indicates an invalid/unavailable username.\n * @param username - The username to check the availability of.\n * @returns Promise which resolves: to boolean of whether the username is available.\n */\n public isUsernameAvailable(username: string): Promise {\n return this.http\n .authedRequest<{ available: true }>(Method.Get, \"/register/available\", { username })\n .then((response) => {\n return response.available;\n })\n .catch((response) => {\n if (response.errcode === \"M_USER_IN_USE\") {\n return false;\n }\n return Promise.reject(response);\n });\n }\n\n /**\n * @param bindThreepids - Set key 'email' to true to bind any email\n * threepid uses during registration in the identity server. Set 'msisdn' to\n * true to bind msisdn.\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public register(\n username: string,\n password: string,\n sessionId: string | null,\n auth: { session?: string; type: string },\n bindThreepids?: boolean | null | { email?: boolean; msisdn?: boolean },\n guestAccessToken?: string,\n inhibitLogin?: boolean,\n ): Promise {\n // backwards compat\n if (bindThreepids === true) {\n bindThreepids = { email: true };\n } else if (bindThreepids === null || bindThreepids === undefined || bindThreepids === false) {\n bindThreepids = {};\n }\n if (sessionId) {\n auth.session = sessionId;\n }\n\n const params: IRegisterRequestParams = {\n auth: auth,\n refresh_token: true, // always ask for a refresh token - does nothing if unsupported\n };\n if (username !== undefined && username !== null) {\n params.username = username;\n }\n if (password !== undefined && password !== null) {\n params.password = password;\n }\n if (bindThreepids.email) {\n params.bind_email = true;\n }\n if (bindThreepids.msisdn) {\n params.bind_msisdn = true;\n }\n if (guestAccessToken !== undefined && guestAccessToken !== null) {\n params.guest_access_token = guestAccessToken;\n }\n if (inhibitLogin !== undefined && inhibitLogin !== null) {\n params.inhibit_login = inhibitLogin;\n }\n // Temporary parameter added to make the register endpoint advertise\n // msisdn flows. This exists because there are clients that break\n // when given stages they don't recognise. This parameter will cease\n // to be necessary once these old clients are gone.\n // Only send it if we send any params at all (the password param is\n // mandatory, so if we send any params, we'll send the password param)\n if (password !== undefined && password !== null) {\n params.x_show_msisdn = true;\n }\n\n return this.registerRequest(params);\n }\n\n /**\n * Register a guest account.\n * This method returns the auth info needed to create a new authenticated client,\n * Remember to call `setGuest(true)` on the (guest-)authenticated client, e.g:\n * ```javascript\n * const tmpClient = await sdk.createClient(MATRIX_INSTANCE);\n * const { user_id, device_id, access_token } = tmpClient.registerGuest();\n * const client = createClient({\n * baseUrl: MATRIX_INSTANCE,\n * accessToken: access_token,\n * userId: user_id,\n * deviceId: device_id,\n * })\n * client.setGuest(true);\n * ```\n *\n * @param body - JSON HTTP body to provide.\n * @returns Promise which resolves: JSON object that contains:\n * `{ user_id, device_id, access_token, home_server }`\n * @returns Rejects: with an error response.\n */\n public registerGuest({ body }: { body?: any } = {}): Promise {\n // TODO: Types\n return this.registerRequest(body || {}, \"guest\");\n }\n\n /**\n * @param data - parameters for registration request\n * @param kind - type of user to register. may be \"guest\"\n * @returns Promise which resolves: to the /register response\n * @returns Rejects: with an error response.\n */\n public registerRequest(data: IRegisterRequestParams, kind?: string): Promise {\n const params: { kind?: string } = {};\n if (kind) {\n params.kind = kind;\n }\n\n return this.http.request(Method.Post, \"/register\", params, data);\n }\n\n /**\n * Refreshes an access token using a provided refresh token. The refresh token\n * must be valid for the current access token known to the client instance.\n *\n * Note that this function will not cause a logout if the token is deemed\n * unknown by the server - the caller is responsible for managing logout\n * actions on error.\n * @param refreshToken - The refresh token.\n * @returns Promise which resolves to the new token.\n * @returns Rejects with an error response.\n */\n public refreshToken(refreshToken: string): Promise {\n return this.http.authedRequest(\n Method.Post,\n \"/refresh\",\n undefined,\n { refresh_token: refreshToken },\n {\n prefix: ClientPrefix.V1,\n inhibitLogoutEmit: true, // we don't want to cause logout loops\n },\n );\n }\n\n /**\n * @returns Promise which resolves to the available login flows\n * @returns Rejects: with an error response.\n */\n public loginFlows(): Promise {\n return this.http.request(Method.Get, \"/login\");\n }\n\n /**\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public login(loginType: string, data: any): Promise {\n // TODO: Types\n const loginData = {\n type: loginType,\n };\n\n // merge data into loginData\n Object.assign(loginData, data);\n\n return this.http\n .authedRequest<{\n access_token?: string;\n user_id?: string;\n }>(Method.Post, \"/login\", undefined, loginData)\n .then((response) => {\n if (response.access_token && response.user_id) {\n this.http.opts.accessToken = response.access_token;\n this.credentials = {\n userId: response.user_id,\n };\n }\n return response;\n });\n }\n\n /**\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public loginWithPassword(user: string, password: string): Promise {\n // TODO: Types\n return this.login(\"m.login.password\", {\n user: user,\n password: password,\n });\n }\n\n /**\n * @param relayState - URL Callback after SAML2 Authentication\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public loginWithSAML2(relayState: string): Promise {\n // TODO: Types\n return this.login(\"m.login.saml2\", {\n relay_state: relayState,\n });\n }\n\n /**\n * @param redirectUrl - The URL to redirect to after the HS\n * authenticates with CAS.\n * @returns The HS URL to hit to begin the CAS login process.\n */\n public getCasLoginUrl(redirectUrl: string): string {\n return this.getSsoLoginUrl(redirectUrl, \"cas\");\n }\n\n /**\n * @param redirectUrl - The URL to redirect to after the HS\n * authenticates with the SSO.\n * @param loginType - The type of SSO login we are doing (sso or cas).\n * Defaults to 'sso'.\n * @param idpId - The ID of the Identity Provider being targeted, optional.\n * @param action - the SSO flow to indicate to the IdP, optional.\n * @returns The HS URL to hit to begin the SSO login process.\n */\n public getSsoLoginUrl(redirectUrl: string, loginType = \"sso\", idpId?: string, action?: SSOAction): string {\n let url = \"/login/\" + loginType + \"/redirect\";\n if (idpId) {\n url += \"/\" + idpId;\n }\n\n const params = {\n redirectUrl,\n [SSO_ACTION_PARAM.unstable!]: action,\n };\n\n return this.http.getUrl(url, params, ClientPrefix.R0).href;\n }\n\n /**\n * @param token - Login token previously received from homeserver\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public loginWithToken(token: string): Promise {\n // TODO: Types\n return this.login(\"m.login.token\", {\n token: token,\n });\n }\n\n /**\n * Logs out the current session.\n * Obviously, further calls that require authorisation should fail after this\n * method is called. The state of the MatrixClient object is not affected:\n * it is up to the caller to either reset or destroy the MatrixClient after\n * this method succeeds.\n * @param stopClient - whether to stop the client before calling /logout to prevent invalid token errors.\n * @returns Promise which resolves: On success, the empty object `{}`\n */\n public async logout(stopClient = false): Promise<{}> {\n if (this.crypto?.backupManager?.getKeyBackupEnabled()) {\n try {\n while ((await this.crypto.backupManager.backupPendingKeys(200)) > 0);\n } catch (err) {\n logger.error(\"Key backup request failed when logging out. Some keys may be missing from backup\", err);\n }\n }\n\n if (stopClient) {\n this.stopClient();\n this.http.abort();\n }\n\n return this.http.authedRequest(Method.Post, \"/logout\");\n }\n\n /**\n * Deactivates the logged-in account.\n * Obviously, further calls that require authorisation should fail after this\n * method is called. The state of the MatrixClient object is not affected:\n * it is up to the caller to either reset or destroy the MatrixClient after\n * this method succeeds.\n * @param auth - Optional. Auth data to supply for User-Interactive auth.\n * @param erase - Optional. If set, send as `erase` attribute in the\n * JSON request body, indicating whether the account should be erased. Defaults\n * to false.\n * @returns Promise which resolves: On success, the empty object\n */\n public deactivateAccount(auth?: any, erase?: boolean): Promise<{}> {\n const body: any = {};\n if (auth) {\n body.auth = auth;\n }\n if (erase !== undefined) {\n body.erase = erase;\n }\n\n return this.http.authedRequest(Method.Post, \"/account/deactivate\", undefined, body);\n }\n\n /**\n * Make a request for an `m.login.token` to be issued as per\n * [MSC3882](https://github.com/matrix-org/matrix-spec-proposals/pull/3882).\n * The server may require User-Interactive auth.\n * Note that this is UNSTABLE and subject to breaking changes without notice.\n * @param auth - Optional. Auth data to supply for User-Interactive auth.\n * @returns Promise which resolves: On success, the token response\n * or UIA auth data.\n */\n public requestLoginToken(auth?: IAuthData): Promise> {\n const body: UIARequest<{}> = { auth };\n return this.http.authedRequest(\n Method.Post,\n \"/org.matrix.msc3882/login/token\",\n undefined, // no query params\n body,\n { prefix: ClientPrefix.Unstable },\n );\n }\n\n /**\n * Get the fallback URL to use for unknown interactive-auth stages.\n *\n * @param loginType - the type of stage being attempted\n * @param authSessionId - the auth session ID provided by the homeserver\n *\n * @returns HS URL to hit to for the fallback interface\n */\n public getFallbackAuthUrl(loginType: string, authSessionId: string): string {\n const path = utils.encodeUri(\"/auth/$loginType/fallback/web\", {\n $loginType: loginType,\n });\n\n return this.http.getUrl(\n path,\n {\n session: authSessionId,\n },\n ClientPrefix.R0,\n ).href;\n }\n\n /**\n * Create a new room.\n * @param options - a list of options to pass to the /createRoom API.\n * @returns Promise which resolves: `{room_id: {string}}`\n * @returns Rejects: with an error response.\n */\n public async createRoom(options: ICreateRoomOpts): Promise<{ room_id: string }> {\n // eslint-disable-line camelcase\n // some valid options include: room_alias_name, visibility, invite\n\n // inject the id_access_token if inviting 3rd party addresses\n const invitesNeedingToken = (options.invite_3pid || []).filter((i) => !i.id_access_token);\n if (\n invitesNeedingToken.length > 0 &&\n this.identityServer?.getAccessToken &&\n (await this.doesServerAcceptIdentityAccessToken())\n ) {\n const identityAccessToken = await this.identityServer.getAccessToken();\n if (identityAccessToken) {\n for (const invite of invitesNeedingToken) {\n invite.id_access_token = identityAccessToken;\n }\n }\n }\n\n return this.http.authedRequest(Method.Post, \"/createRoom\", undefined, options);\n }\n\n /**\n * Fetches relations for a given event\n * @param roomId - the room of the event\n * @param eventId - the id of the event\n * @param relationType - the rel_type of the relations requested\n * @param eventType - the event type of the relations requested\n * @param opts - options with optional values for the request.\n * @returns the response, with chunk, prev_batch and, next_batch.\n */\n public fetchRelations(\n roomId: string,\n eventId: string,\n relationType?: RelationType | string | null,\n eventType?: EventType | string | null,\n opts: IRelationsRequestOpts = { dir: Direction.Backward },\n ): Promise {\n let params = opts as QueryDict;\n if (Thread.hasServerSideFwdPaginationSupport === FeatureSupport.Experimental) {\n params = replaceParam(\"dir\", \"org.matrix.msc3715.dir\", params);\n }\n const queryString = utils.encodeParams(params);\n\n let templatedUrl = \"/rooms/$roomId/relations/$eventId\";\n if (relationType !== null) {\n templatedUrl += \"/$relationType\";\n if (eventType !== null) {\n templatedUrl += \"/$eventType\";\n }\n } else if (eventType !== null) {\n logger.warn(`eventType: ${eventType} ignored when fetching\n relations as relationType is null`);\n eventType = null;\n }\n\n const path = utils.encodeUri(templatedUrl + \"?\" + queryString, {\n $roomId: roomId,\n $eventId: eventId,\n $relationType: relationType!,\n $eventType: eventType!,\n });\n return this.http.authedRequest(Method.Get, path, undefined, undefined, {\n prefix: ClientPrefix.V1,\n });\n }\n\n /**\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public roomState(roomId: string): Promise {\n const path = utils.encodeUri(\"/rooms/$roomId/state\", { $roomId: roomId });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * Get an event in a room by its event id.\n *\n * @returns Promise which resolves to an object containing the event.\n * @returns Rejects: with an error response.\n */\n public fetchRoomEvent(roomId: string, eventId: string): Promise> {\n const path = utils.encodeUri(\"/rooms/$roomId/event/$eventId\", {\n $roomId: roomId,\n $eventId: eventId,\n });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * @param includeMembership - the membership type to include in the response\n * @param excludeMembership - the membership type to exclude from the response\n * @param atEventId - the id of the event for which moment in the timeline the members should be returned for\n * @returns Promise which resolves: dictionary of userid to profile information\n * @returns Rejects: with an error response.\n */\n public members(\n roomId: string,\n includeMembership?: string,\n excludeMembership?: string,\n atEventId?: string,\n ): Promise<{ [userId: string]: IStateEventWithRoomId[] }> {\n const queryParams: Record = {};\n if (includeMembership) {\n queryParams.membership = includeMembership;\n }\n if (excludeMembership) {\n queryParams.not_membership = excludeMembership;\n }\n if (atEventId) {\n queryParams.at = atEventId;\n }\n\n const queryString = utils.encodeParams(queryParams);\n\n const path = utils.encodeUri(\"/rooms/$roomId/members?\" + queryString, { $roomId: roomId });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * Upgrades a room to a new protocol version\n * @param newVersion - The target version to upgrade to\n * @returns Promise which resolves: Object with key 'replacement_room'\n * @returns Rejects: with an error response.\n */\n public upgradeRoom(roomId: string, newVersion: string): Promise<{ replacement_room: string }> {\n // eslint-disable-line camelcase\n const path = utils.encodeUri(\"/rooms/$roomId/upgrade\", { $roomId: roomId });\n return this.http.authedRequest(Method.Post, path, undefined, { new_version: newVersion });\n }\n\n /**\n * Retrieve a state event.\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public getStateEvent(roomId: string, eventType: string, stateKey: string): Promise> {\n const pathParams = {\n $roomId: roomId,\n $eventType: eventType,\n $stateKey: stateKey,\n };\n let path = utils.encodeUri(\"/rooms/$roomId/state/$eventType\", pathParams);\n if (stateKey !== undefined) {\n path = utils.encodeUri(path + \"/$stateKey\", pathParams);\n }\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * @param opts - Options for the request function.\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public sendStateEvent(\n roomId: string,\n eventType: string,\n content: any,\n stateKey = \"\",\n opts: IRequestOpts = {},\n ): Promise {\n const pathParams = {\n $roomId: roomId,\n $eventType: eventType,\n $stateKey: stateKey,\n };\n let path = utils.encodeUri(\"/rooms/$roomId/state/$eventType\", pathParams);\n if (stateKey !== undefined) {\n path = utils.encodeUri(path + \"/$stateKey\", pathParams);\n }\n return this.http.authedRequest(Method.Put, path, undefined, content, opts);\n }\n\n /**\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public roomInitialSync(roomId: string, limit: number): Promise {\n const path = utils.encodeUri(\"/rooms/$roomId/initialSync\", { $roomId: roomId });\n\n return this.http.authedRequest(Method.Get, path, { limit: limit?.toString() ?? \"30\" });\n }\n\n /**\n * Set a marker to indicate the point in a room before which the user has read every\n * event. This can be retrieved from room account data (the event type is `m.fully_read`)\n * and displayed as a horizontal line in the timeline that is visually distinct to the\n * position of the user's own read receipt.\n * @param roomId - ID of the room that has been read\n * @param rmEventId - ID of the event that has been read\n * @param rrEventId - ID of the event tracked by the read receipt. This is here\n * for convenience because the RR and the RM are commonly updated at the same time as\n * each other. Optional.\n * @param rpEventId - rpEvent the m.read.private read receipt event for when we\n * don't want other users to see the read receipts. This is experimental. Optional.\n * @returns Promise which resolves: the empty object, `{}`.\n */\n public async setRoomReadMarkersHttpRequest(\n roomId: string,\n rmEventId: string,\n rrEventId?: string,\n rpEventId?: string,\n ): Promise<{}> {\n const path = utils.encodeUri(\"/rooms/$roomId/read_markers\", {\n $roomId: roomId,\n });\n\n const content: IContent = {\n [ReceiptType.FullyRead]: rmEventId,\n [ReceiptType.Read]: rrEventId,\n };\n\n if (\n (await this.doesServerSupportUnstableFeature(\"org.matrix.msc2285.stable\")) ||\n (await this.isVersionSupported(\"v1.4\"))\n ) {\n content[ReceiptType.ReadPrivate] = rpEventId;\n }\n\n return this.http.authedRequest(Method.Post, path, undefined, content);\n }\n\n /**\n * @returns Promise which resolves: A list of the user's current rooms\n * @returns Rejects: with an error response.\n */\n public getJoinedRooms(): Promise {\n const path = utils.encodeUri(\"/joined_rooms\", {});\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * Retrieve membership info. for a room.\n * @param roomId - ID of the room to get membership for\n * @returns Promise which resolves: A list of currently joined users\n * and their profile data.\n * @returns Rejects: with an error response.\n */\n public getJoinedRoomMembers(roomId: string): Promise {\n const path = utils.encodeUri(\"/rooms/$roomId/joined_members\", {\n $roomId: roomId,\n });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * @param options - Options for this request\n * @param server - The remote server to query for the room list.\n * Optional. If unspecified, get the local home\n * server's public room list.\n * @param limit - Maximum number of entries to return\n * @param since - Token to paginate from\n * @returns Promise which resolves: IPublicRoomsResponse\n * @returns Rejects: with an error response.\n */\n public publicRooms({\n server,\n limit,\n since,\n ...options\n }: IRoomDirectoryOptions = {}): Promise {\n const queryParams: QueryDict = { server, limit, since };\n if (Object.keys(options).length === 0) {\n return this.http.authedRequest(Method.Get, \"/publicRooms\", queryParams);\n } else {\n return this.http.authedRequest(Method.Post, \"/publicRooms\", queryParams, options);\n }\n }\n\n /**\n * Create an alias to room ID mapping.\n * @param alias - The room alias to create.\n * @param roomId - The room ID to link the alias to.\n * @returns Promise which resolves: an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public createAlias(alias: string, roomId: string): Promise<{}> {\n const path = utils.encodeUri(\"/directory/room/$alias\", {\n $alias: alias,\n });\n const data = {\n room_id: roomId,\n };\n return this.http.authedRequest(Method.Put, path, undefined, data);\n }\n\n /**\n * Delete an alias to room ID mapping. This alias must be on your local server,\n * and you must have sufficient access to do this operation.\n * @param alias - The room alias to delete.\n * @returns Promise which resolves: an empty object `{}`.\n * @returns Rejects: with an error response.\n */\n public deleteAlias(alias: string): Promise<{}> {\n const path = utils.encodeUri(\"/directory/room/$alias\", {\n $alias: alias,\n });\n return this.http.authedRequest(Method.Delete, path);\n }\n\n /**\n * Gets the local aliases for the room. Note: this includes all local aliases, unlike the\n * curated list from the m.room.canonical_alias state event.\n * @param roomId - The room ID to get local aliases for.\n * @returns Promise which resolves: an object with an `aliases` property, containing an array of local aliases\n * @returns Rejects: with an error response.\n */\n public getLocalAliases(roomId: string): Promise<{ aliases: string[] }> {\n const path = utils.encodeUri(\"/rooms/$roomId/aliases\", { $roomId: roomId });\n const prefix = ClientPrefix.V3;\n return this.http.authedRequest(Method.Get, path, undefined, undefined, { prefix });\n }\n\n /**\n * Get room info for the given alias.\n * @param alias - The room alias to resolve.\n * @returns Promise which resolves: Object with room_id and servers.\n * @returns Rejects: with an error response.\n */\n public getRoomIdForAlias(alias: string): Promise<{ room_id: string; servers: string[] }> {\n // eslint-disable-line camelcase\n // TODO: deprecate this or resolveRoomAlias\n const path = utils.encodeUri(\"/directory/room/$alias\", {\n $alias: alias,\n });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * @returns Promise which resolves: Object with room_id and servers.\n * @returns Rejects: with an error response.\n */\n // eslint-disable-next-line camelcase\n public resolveRoomAlias(roomAlias: string): Promise<{ room_id: string; servers: string[] }> {\n // TODO: deprecate this or getRoomIdForAlias\n const path = utils.encodeUri(\"/directory/room/$alias\", { $alias: roomAlias });\n return this.http.request(Method.Get, path);\n }\n\n /**\n * Get the visibility of a room in the current HS's room directory\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public getRoomDirectoryVisibility(roomId: string): Promise<{ visibility: Visibility }> {\n const path = utils.encodeUri(\"/directory/list/room/$roomId\", {\n $roomId: roomId,\n });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * Set the visbility of a room in the current HS's room directory\n * @param visibility - \"public\" to make the room visible\n * in the public directory, or \"private\" to make\n * it invisible.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public setRoomDirectoryVisibility(roomId: string, visibility: Visibility): Promise<{}> {\n const path = utils.encodeUri(\"/directory/list/room/$roomId\", {\n $roomId: roomId,\n });\n return this.http.authedRequest(Method.Put, path, undefined, { visibility });\n }\n\n /**\n * Set the visbility of a room bridged to a 3rd party network in\n * the current HS's room directory.\n * @param networkId - the network ID of the 3rd party\n * instance under which this room is published under.\n * @param visibility - \"public\" to make the room visible\n * in the public directory, or \"private\" to make\n * it invisible.\n * @returns Promise which resolves: result object\n * @returns Rejects: with an error response.\n */\n public setRoomDirectoryVisibilityAppService(\n networkId: string,\n roomId: string,\n visibility: \"public\" | \"private\",\n ): Promise {\n // TODO: Types\n const path = utils.encodeUri(\"/directory/list/appservice/$networkId/$roomId\", {\n $networkId: networkId,\n $roomId: roomId,\n });\n return this.http.authedRequest(Method.Put, path, undefined, { visibility: visibility });\n }\n\n /**\n * Query the user directory with a term matching user IDs, display names and domains.\n * @param term - the term with which to search.\n * @param limit - the maximum number of results to return. The server will\n * apply a limit if unspecified.\n * @returns Promise which resolves: an array of results.\n */\n public searchUserDirectory({ term, limit }: { term: string; limit?: number }): Promise {\n const body: any = {\n search_term: term,\n };\n\n if (limit !== undefined) {\n body.limit = limit;\n }\n\n return this.http.authedRequest(Method.Post, \"/user_directory/search\", undefined, body);\n }\n\n /**\n * Upload a file to the media repository on the homeserver.\n *\n * @param file - The object to upload. On a browser, something that\n * can be sent to XMLHttpRequest.send (typically a File). Under node.js,\n * a a Buffer, String or ReadStream.\n *\n * @param opts - options object\n *\n * @returns Promise which resolves to response object, as\n * determined by this.opts.onlyData, opts.rawResponse, and\n * opts.onlyContentUri. Rejects with an error (usually a MatrixError).\n */\n public uploadContent(file: FileType, opts?: UploadOpts): Promise {\n return this.http.uploadContent(file, opts);\n }\n\n /**\n * Cancel a file upload in progress\n * @param upload - The object returned from uploadContent\n * @returns true if canceled, otherwise false\n */\n public cancelUpload(upload: Promise): boolean {\n return this.http.cancelUpload(upload);\n }\n\n /**\n * Get a list of all file uploads in progress\n * @returns Array of objects representing current uploads.\n * Currently in progress is element 0. Keys:\n * - promise: The promise associated with the upload\n * - loaded: Number of bytes uploaded\n * - total: Total number of bytes to upload\n */\n public getCurrentUploads(): Upload[] {\n return this.http.getCurrentUploads();\n }\n\n /**\n * @param info - The kind of info to retrieve (e.g. 'displayname',\n * 'avatar_url').\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n */\n public getProfileInfo(\n userId: string,\n info?: string,\n // eslint-disable-next-line camelcase\n ): Promise<{ avatar_url?: string; displayname?: string }> {\n const path = info\n ? utils.encodeUri(\"/profile/$userId/$info\", { $userId: userId, $info: info })\n : utils.encodeUri(\"/profile/$userId\", { $userId: userId });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * @returns Promise which resolves to a list of the user's threepids.\n * @returns Rejects: with an error response.\n */\n public getThreePids(): Promise<{ threepids: IThreepid[] }> {\n return this.http.authedRequest(Method.Get, \"/account/3pid\");\n }\n\n /**\n * Add a 3PID to your homeserver account and optionally bind it to an identity\n * server as well. An identity server is required as part of the `creds` object.\n *\n * This API is deprecated, and you should instead use `addThreePidOnly`\n * for homeservers that support it.\n *\n * @returns Promise which resolves: on success\n * @returns Rejects: with an error response.\n */\n public addThreePid(creds: any, bind: boolean): Promise {\n // TODO: Types\n const path = \"/account/3pid\";\n const data = {\n threePidCreds: creds,\n bind: bind,\n };\n return this.http.authedRequest(Method.Post, path, undefined, data);\n }\n\n /**\n * Add a 3PID to your homeserver account. This API does not use an identity\n * server, as the homeserver is expected to handle 3PID ownership validation.\n *\n * You can check whether a homeserver supports this API via\n * `doesServerSupportSeparateAddAndBind`.\n *\n * @param data - A object with 3PID validation data from having called\n * `account/3pid//requestToken` on the homeserver.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public async addThreePidOnly(data: IAddThreePidOnlyBody): Promise<{}> {\n const path = \"/account/3pid/add\";\n const prefix = (await this.isVersionSupported(\"r0.6.0\")) ? ClientPrefix.R0 : ClientPrefix.Unstable;\n return this.http.authedRequest(Method.Post, path, undefined, data, { prefix });\n }\n\n /**\n * Bind a 3PID for discovery onto an identity server via the homeserver. The\n * identity server handles 3PID ownership validation and the homeserver records\n * the new binding to track where all 3PIDs for the account are bound.\n *\n * You can check whether a homeserver supports this API via\n * `doesServerSupportSeparateAddAndBind`.\n *\n * @param data - A object with 3PID validation data from having called\n * `validate//requestToken` on the identity server. It should also\n * contain `id_server` and `id_access_token` fields as well.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public async bindThreePid(data: IBindThreePidBody): Promise<{}> {\n const path = \"/account/3pid/bind\";\n const prefix = (await this.isVersionSupported(\"r0.6.0\")) ? ClientPrefix.R0 : ClientPrefix.Unstable;\n return this.http.authedRequest(Method.Post, path, undefined, data, { prefix });\n }\n\n /**\n * Unbind a 3PID for discovery on an identity server via the homeserver. The\n * homeserver removes its record of the binding to keep an updated record of\n * where all 3PIDs for the account are bound.\n *\n * @param medium - The threepid medium (eg. 'email')\n * @param address - The threepid address (eg. 'bob\\@example.com')\n * this must be as returned by getThreePids.\n * @returns Promise which resolves: on success\n * @returns Rejects: with an error response.\n */\n public async unbindThreePid(\n medium: string,\n address: string,\n // eslint-disable-next-line camelcase\n ): Promise<{ id_server_unbind_result: IdServerUnbindResult }> {\n const path = \"/account/3pid/unbind\";\n const data = {\n medium,\n address,\n id_server: this.getIdentityServerUrl(true),\n };\n const prefix = (await this.isVersionSupported(\"r0.6.0\")) ? ClientPrefix.R0 : ClientPrefix.Unstable;\n return this.http.authedRequest(Method.Post, path, undefined, data, { prefix });\n }\n\n /**\n * @param medium - The threepid medium (eg. 'email')\n * @param address - The threepid address (eg. 'bob\\@example.com')\n * this must be as returned by getThreePids.\n * @returns Promise which resolves: The server response on success\n * (generally the empty JSON object)\n * @returns Rejects: with an error response.\n */\n public deleteThreePid(\n medium: string,\n address: string,\n // eslint-disable-next-line camelcase\n ): Promise<{ id_server_unbind_result: IdServerUnbindResult }> {\n const path = \"/account/3pid/delete\";\n return this.http.authedRequest(Method.Post, path, undefined, { medium, address });\n }\n\n /**\n * Make a request to change your password.\n * @param newPassword - The new desired password.\n * @param logoutDevices - Should all sessions be logged out after the password change. Defaults to true.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public setPassword(authDict: IAuthDict, newPassword: string, logoutDevices?: boolean): Promise<{}> {\n const path = \"/account/password\";\n const data = {\n auth: authDict,\n new_password: newPassword,\n logout_devices: logoutDevices,\n };\n\n return this.http.authedRequest<{}>(Method.Post, path, undefined, data);\n }\n\n /**\n * Gets all devices recorded for the logged-in user\n * @returns Promise which resolves: result object\n * @returns Rejects: with an error response.\n */\n public getDevices(): Promise<{ devices: IMyDevice[] }> {\n return this.http.authedRequest(Method.Get, \"/devices\");\n }\n\n /**\n * Gets specific device details for the logged-in user\n * @param deviceId - device to query\n * @returns Promise which resolves: result object\n * @returns Rejects: with an error response.\n */\n public getDevice(deviceId: string): Promise {\n const path = utils.encodeUri(\"/devices/$device_id\", {\n $device_id: deviceId,\n });\n return this.http.authedRequest(Method.Get, path);\n }\n\n /**\n * Update the given device\n *\n * @param deviceId - device to update\n * @param body - body of request\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n // eslint-disable-next-line camelcase\n public setDeviceDetails(deviceId: string, body: { display_name: string }): Promise<{}> {\n const path = utils.encodeUri(\"/devices/$device_id\", {\n $device_id: deviceId,\n });\n\n return this.http.authedRequest(Method.Put, path, undefined, body);\n }\n\n /**\n * Delete the given device\n *\n * @param deviceId - device to delete\n * @param auth - Optional. Auth data to supply for User-Interactive auth.\n * @returns Promise which resolves: result object\n * @returns Rejects: with an error response.\n */\n public deleteDevice(deviceId: string, auth?: IAuthDict): Promise {\n const path = utils.encodeUri(\"/devices/$device_id\", {\n $device_id: deviceId,\n });\n\n const body: any = {};\n\n if (auth) {\n body.auth = auth;\n }\n\n return this.http.authedRequest(Method.Delete, path, undefined, body);\n }\n\n /**\n * Delete multiple device\n *\n * @param devices - IDs of the devices to delete\n * @param auth - Optional. Auth data to supply for User-Interactive auth.\n * @returns Promise which resolves: result object\n * @returns Rejects: with an error response.\n */\n public deleteMultipleDevices(devices: string[], auth?: IAuthDict): Promise {\n const body: any = { devices };\n\n if (auth) {\n body.auth = auth;\n }\n\n const path = \"/delete_devices\";\n return this.http.authedRequest(Method.Post, path, undefined, body);\n }\n\n /**\n * Gets all pushers registered for the logged-in user\n *\n * @returns Promise which resolves: Array of objects representing pushers\n * @returns Rejects: with an error response.\n */\n public async getPushers(): Promise<{ pushers: IPusher[] }> {\n const response = await this.http.authedRequest<{ pushers: IPusher[] }>(Method.Get, \"/pushers\");\n\n // Migration path for clients that connect to a homeserver that does not support\n // MSC3881 yet, see https://github.com/matrix-org/matrix-spec-proposals/blob/kerry/remote-push-toggle/proposals/3881-remote-push-notification-toggling.md#migration\n if (!(await this.doesServerSupportUnstableFeature(\"org.matrix.msc3881\"))) {\n response.pushers = response.pushers.map((pusher) => {\n if (!pusher.hasOwnProperty(PUSHER_ENABLED.name)) {\n pusher[PUSHER_ENABLED.name] = true;\n }\n return pusher;\n });\n }\n\n return response;\n }\n\n /**\n * Adds a new pusher or updates an existing pusher\n *\n * @param pusher - Object representing a pusher\n * @returns Promise which resolves: Empty json object on success\n * @returns Rejects: with an error response.\n */\n public setPusher(pusher: IPusherRequest): Promise<{}> {\n const path = \"/pushers/set\";\n return this.http.authedRequest(Method.Post, path, undefined, pusher);\n }\n\n /**\n * Persists local notification settings\n * @returns Promise which resolves: an empty object\n * @returns Rejects: with an error response.\n */\n public setLocalNotificationSettings(\n deviceId: string,\n notificationSettings: LocalNotificationSettings,\n ): Promise<{}> {\n const key = `${LOCAL_NOTIFICATION_SETTINGS_PREFIX.name}.${deviceId}`;\n return this.setAccountData(key, notificationSettings);\n }\n\n /**\n * Get the push rules for the account from the server.\n * @returns Promise which resolves to the push rules.\n * @returns Rejects: with an error response.\n */\n public getPushRules(): Promise {\n return this.http.authedRequest(Method.Get, \"/pushrules/\").then((rules: IPushRules) => {\n this.setPushRules(rules);\n return this.pushRules!;\n });\n }\n\n /**\n * Update the push rules for the account. This should be called whenever\n * updated push rules are available.\n */\n public setPushRules(rules: IPushRules): void {\n // Fix-up defaults, if applicable.\n this.pushRules = PushProcessor.rewriteDefaultRules(rules, this.getUserId()!);\n // Pre-calculate any necessary caches.\n this.pushProcessor.updateCachedPushRuleKeys(this.pushRules);\n }\n\n /**\n * @returns Promise which resolves: an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public addPushRule(\n scope: string,\n kind: PushRuleKind,\n ruleId: Exclude,\n body: Pick,\n ): Promise<{}> {\n // NB. Scope not uri encoded because devices need the '/'\n const path = utils.encodeUri(\"/pushrules/\" + scope + \"/$kind/$ruleId\", {\n $kind: kind,\n $ruleId: ruleId,\n });\n return this.http.authedRequest(Method.Put, path, undefined, body);\n }\n\n /**\n * @returns Promise which resolves: an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public deletePushRule(scope: string, kind: PushRuleKind, ruleId: Exclude): Promise<{}> {\n // NB. Scope not uri encoded because devices need the '/'\n const path = utils.encodeUri(\"/pushrules/\" + scope + \"/$kind/$ruleId\", {\n $kind: kind,\n $ruleId: ruleId,\n });\n return this.http.authedRequest(Method.Delete, path);\n }\n\n /**\n * Enable or disable a push notification rule.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public setPushRuleEnabled(\n scope: string,\n kind: PushRuleKind,\n ruleId: RuleId | string,\n enabled: boolean,\n ): Promise<{}> {\n const path = utils.encodeUri(\"/pushrules/\" + scope + \"/$kind/$ruleId/enabled\", {\n $kind: kind,\n $ruleId: ruleId,\n });\n return this.http.authedRequest(Method.Put, path, undefined, { enabled: enabled });\n }\n\n /**\n * Set the actions for a push notification rule.\n * @returns Promise which resolves: to an empty object `{}`\n * @returns Rejects: with an error response.\n */\n public setPushRuleActions(\n scope: string,\n kind: PushRuleKind,\n ruleId: RuleId | string,\n actions: PushRuleAction[],\n ): Promise<{}> {\n const path = utils.encodeUri(\"/pushrules/\" + scope + \"/$kind/$ruleId/actions\", {\n $kind: kind,\n $ruleId: ruleId,\n });\n return this.http.authedRequest(Method.Put, path, undefined, { actions: actions });\n }\n\n /**\n * Perform a server-side search.\n * @param next_batch - the batch token to pass in the query string\n * @param body - the JSON object to pass to the request body.\n * @param abortSignal - optional signal used to cancel the http request.\n * @returns Promise which resolves to the search response object.\n * @returns Rejects: with an error response.\n */\n public search(\n { body, next_batch: nextBatch }: { body: ISearchRequestBody; next_batch?: string },\n abortSignal?: AbortSignal,\n ): Promise {\n const queryParams: any = {};\n if (nextBatch) {\n queryParams.next_batch = nextBatch;\n }\n return this.http.authedRequest(Method.Post, \"/search\", queryParams, body, { abortSignal });\n }\n\n /**\n * Upload keys\n *\n * @param content - body of upload request\n *\n * @param opts - this method no longer takes any opts,\n * used to take opts.device_id but this was not removed from the spec as a redundant parameter\n *\n * @returns Promise which resolves: result object. Rejects: with\n * an error response ({@link MatrixError}).\n */\n public uploadKeysRequest(content: IUploadKeysRequest, opts?: void): Promise {\n return this.http.authedRequest(Method.Post, \"/keys/upload\", undefined, content);\n }\n\n public uploadKeySignatures(content: KeySignatures): Promise {\n return this.http.authedRequest(Method.Post, \"/keys/signatures/upload\", undefined, content, {\n prefix: ClientPrefix.V3,\n });\n }\n\n /**\n * Download device keys\n *\n * @param userIds - list of users to get keys for\n *\n * @param token - sync token to pass in the query request, to help\n * the HS give the most recent results\n *\n * @returns Promise which resolves: result object. Rejects: with\n * an error response ({@link MatrixError}).\n */\n public downloadKeysForUsers(userIds: string[], { token }: { token?: string } = {}): Promise {\n const content: IQueryKeysRequest = {\n device_keys: {},\n };\n if (token !== undefined) {\n content.token = token;\n }\n userIds.forEach((u) => {\n content.device_keys[u] = [];\n });\n\n return this.http.authedRequest(Method.Post, \"/keys/query\", undefined, content);\n }\n\n /**\n * Claim one-time keys\n *\n * @param devices - a list of [userId, deviceId] pairs\n *\n * @param keyAlgorithm - desired key type\n *\n * @param timeout - the time (in milliseconds) to wait for keys from remote\n * servers\n *\n * @returns Promise which resolves: result object. Rejects: with\n * an error response ({@link MatrixError}).\n */\n public claimOneTimeKeys(\n devices: [string, string][],\n keyAlgorithm = \"signed_curve25519\",\n timeout?: number,\n ): Promise {\n const queries: Record> = {};\n\n if (keyAlgorithm === undefined) {\n keyAlgorithm = \"signed_curve25519\";\n }\n\n for (const [userId, deviceId] of devices) {\n const query = queries[userId] || {};\n queries[userId] = query;\n query[deviceId] = keyAlgorithm;\n }\n const content: IClaimKeysRequest = { one_time_keys: queries };\n if (timeout) {\n content.timeout = timeout;\n }\n const path = \"/keys/claim\";\n return this.http.authedRequest(Method.Post, path, undefined, content);\n }\n\n /**\n * Ask the server for a list of users who have changed their device lists\n * between a pair of sync tokens\n *\n *\n * @returns Promise which resolves: result object. Rejects: with\n * an error response ({@link MatrixError}).\n */\n public getKeyChanges(oldToken: string, newToken: string): Promise<{ changed: string[]; left: string[] }> {\n const qps = {\n from: oldToken,\n to: newToken,\n };\n\n return this.http.authedRequest(Method.Get, \"/keys/changes\", qps);\n }\n\n public uploadDeviceSigningKeys(auth?: IAuthData, keys?: CrossSigningKeys): Promise<{}> {\n // API returns empty object\n const data = Object.assign({}, keys);\n if (auth) Object.assign(data, { auth });\n return this.http.authedRequest(Method.Post, \"/keys/device_signing/upload\", undefined, data, {\n prefix: ClientPrefix.Unstable,\n });\n }\n\n /**\n * Register with an identity server using the OpenID token from the user's\n * Homeserver, which can be retrieved via\n * {@link MatrixClient#getOpenIdToken}.\n *\n * Note that the `/account/register` endpoint (as well as IS authentication in\n * general) was added as part of the v2 API version.\n *\n * @returns Promise which resolves: with object containing an Identity\n * Server access token.\n * @returns Rejects: with an error response.\n */\n public registerWithIdentityServer(hsOpenIdToken: IOpenIDToken): Promise<{\n access_token: string;\n token: string;\n }> {\n if (!this.idBaseUrl) {\n throw new Error(\"No identity server base URL set\");\n }\n\n const uri = this.http.getUrl(\"/account/register\", undefined, IdentityPrefix.V2, this.idBaseUrl);\n return this.http.requestOtherUrl(Method.Post, uri, hsOpenIdToken);\n }\n\n /**\n * Requests an email verification token directly from an identity server.\n *\n * This API is used as part of binding an email for discovery on an identity\n * server. The validation data that results should be passed to the\n * `bindThreePid` method to complete the binding process.\n *\n * @param email - The email address to request a token for\n * @param clientSecret - A secret binary string generated by the client.\n * It is recommended this be around 16 ASCII characters.\n * @param sendAttempt - If an identity server sees a duplicate request\n * with the same sendAttempt, it will not send another email.\n * To request another email to be sent, use a larger value for\n * the sendAttempt param as was used in the previous request.\n * @param nextLink - Optional If specified, the client will be redirected\n * to this link after validation.\n * @param identityAccessToken - The `access_token` field of the identity\n * server `/account/register` response (see {@link registerWithIdentityServer}).\n *\n * @returns Promise which resolves: TODO\n * @returns Rejects: with an error response.\n * @throws Error if no identity server is set\n */\n public requestEmailToken(\n email: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink?: string,\n identityAccessToken?: string,\n ): Promise {\n const params: Record = {\n client_secret: clientSecret,\n email: email,\n send_attempt: sendAttempt?.toString(),\n };\n if (nextLink) {\n params.next_link = nextLink;\n }\n\n return this.http.idServerRequest(\n Method.Post,\n \"/validate/email/requestToken\",\n params,\n IdentityPrefix.V2,\n identityAccessToken,\n );\n }\n\n /**\n * Requests a MSISDN verification token directly from an identity server.\n *\n * This API is used as part of binding a MSISDN for discovery on an identity\n * server. The validation data that results should be passed to the\n * `bindThreePid` method to complete the binding process.\n *\n * @param phoneCountry - The ISO 3166-1 alpha-2 code for the country in\n * which phoneNumber should be parsed relative to.\n * @param phoneNumber - The phone number, in national or international\n * format\n * @param clientSecret - A secret binary string generated by the client.\n * It is recommended this be around 16 ASCII characters.\n * @param sendAttempt - If an identity server sees a duplicate request\n * with the same sendAttempt, it will not send another SMS.\n * To request another SMS to be sent, use a larger value for\n * the sendAttempt param as was used in the previous request.\n * @param nextLink - Optional If specified, the client will be redirected\n * to this link after validation.\n * @param identityAccessToken - The `access_token` field of the Identity\n * Server `/account/register` response (see {@link registerWithIdentityServer}).\n *\n * @returns Promise which resolves to an object with a sid string\n * @returns Rejects: with an error response.\n * @throws Error if no identity server is set\n */\n public requestMsisdnToken(\n phoneCountry: string,\n phoneNumber: string,\n clientSecret: string,\n sendAttempt: number,\n nextLink?: string,\n identityAccessToken?: string,\n ): Promise {\n const params: Record = {\n client_secret: clientSecret,\n country: phoneCountry,\n phone_number: phoneNumber,\n send_attempt: sendAttempt?.toString(),\n };\n if (nextLink) {\n params.next_link = nextLink;\n }\n\n return this.http.idServerRequest(\n Method.Post,\n \"/validate/msisdn/requestToken\",\n params,\n IdentityPrefix.V2,\n identityAccessToken,\n );\n }\n\n /**\n * Submits a MSISDN token to the identity server\n *\n * This is used when submitting the code sent by SMS to a phone number.\n * The identity server has an equivalent API for email but the js-sdk does\n * not expose this, since email is normally validated by the user clicking\n * a link rather than entering a code.\n *\n * @param sid - The sid given in the response to requestToken\n * @param clientSecret - A secret binary string generated by the client.\n * This must be the same value submitted in the requestToken call.\n * @param msisdnToken - The MSISDN token, as enetered by the user.\n * @param identityAccessToken - The `access_token` field of the Identity\n * Server `/account/register` response (see {@link registerWithIdentityServer}).\n *\n * @returns Promise which resolves: Object, currently with no parameters.\n * @returns Rejects: with an error response.\n * @throws Error if No identity server is set\n */\n public submitMsisdnToken(\n sid: string,\n clientSecret: string,\n msisdnToken: string,\n identityAccessToken: string,\n ): Promise {\n // TODO: Types\n const params = {\n sid: sid,\n client_secret: clientSecret,\n token: msisdnToken,\n };\n\n return this.http.idServerRequest(\n Method.Post,\n \"/validate/msisdn/submitToken\",\n params,\n IdentityPrefix.V2,\n identityAccessToken,\n );\n }\n\n /**\n * Submits a MSISDN token to an arbitrary URL.\n *\n * This is used when submitting the code sent by SMS to a phone number in the\n * newer 3PID flow where the homeserver validates 3PID ownership (as part of\n * `requestAdd3pidMsisdnToken`). The homeserver response may include a\n * `submit_url` to specify where the token should be sent, and this helper can\n * be used to pass the token to this URL.\n *\n * @param url - The URL to submit the token to\n * @param sid - The sid given in the response to requestToken\n * @param clientSecret - A secret binary string generated by the client.\n * This must be the same value submitted in the requestToken call.\n * @param msisdnToken - The MSISDN token, as enetered by the user.\n *\n * @returns Promise which resolves: Object, currently with no parameters.\n * @returns Rejects: with an error response.\n */\n public submitMsisdnTokenOtherUrl(\n url: string,\n sid: string,\n clientSecret: string,\n msisdnToken: string,\n ): Promise {\n // TODO: Types\n const params = {\n sid: sid,\n client_secret: clientSecret,\n token: msisdnToken,\n };\n return this.http.requestOtherUrl(Method.Post, url, params);\n }\n\n /**\n * Gets the V2 hashing information from the identity server. Primarily useful for\n * lookups.\n * @param identityAccessToken - The access token for the identity server.\n * @returns The hashing information for the identity server.\n */\n public getIdentityHashDetails(identityAccessToken: string): Promise {\n // TODO: Types\n return this.http.idServerRequest(\n Method.Get,\n \"/hash_details\",\n undefined,\n IdentityPrefix.V2,\n identityAccessToken,\n );\n }\n\n /**\n * Performs a hashed lookup of addresses against the identity server. This is\n * only supported on identity servers which have at least the version 2 API.\n * @param addressPairs - An array of 2 element arrays.\n * The first element of each pair is the address, the second is the 3PID medium.\n * Eg: `[\"email@example.org\", \"email\"]`\n * @param identityAccessToken - The access token for the identity server.\n * @returns A collection of address mappings to\n * found MXIDs. Results where no user could be found will not be listed.\n */\n public async identityHashedLookup(\n addressPairs: [string, string][],\n identityAccessToken: string,\n ): Promise<{ address: string; mxid: string }[]> {\n const params: Record = {\n // addresses: [\"email@example.org\", \"10005550000\"],\n // algorithm: \"sha256\",\n // pepper: \"abc123\"\n };\n\n // Get hash information first before trying to do a lookup\n const hashes = await this.getIdentityHashDetails(identityAccessToken);\n if (!hashes || !hashes[\"lookup_pepper\"] || !hashes[\"algorithms\"]) {\n throw new Error(\"Unsupported identity server: bad response\");\n }\n\n params[\"pepper\"] = hashes[\"lookup_pepper\"];\n\n const localMapping: Record = {\n // hashed identifier => plain text address\n // For use in this function's return format\n };\n\n // When picking an algorithm, we pick the hashed over no hashes\n if (hashes[\"algorithms\"].includes(\"sha256\")) {\n // Abuse the olm hashing\n const olmutil = new global.Olm.Utility();\n params[\"addresses\"] = addressPairs.map((p) => {\n const addr = p[0].toLowerCase(); // lowercase to get consistent hashes\n const med = p[1].toLowerCase();\n const hashed = olmutil\n .sha256(`${addr} ${med} ${params[\"pepper\"]}`)\n .replace(/\\+/g, \"-\")\n .replace(/\\//g, \"_\"); // URL-safe base64\n // Map the hash to a known (case-sensitive) address. We use the case\n // sensitive version because the caller might be expecting that.\n localMapping[hashed] = p[0];\n return hashed;\n });\n params[\"algorithm\"] = \"sha256\";\n } else if (hashes[\"algorithms\"].includes(\"none\")) {\n params[\"addresses\"] = addressPairs.map((p) => {\n const addr = p[0].toLowerCase(); // lowercase to get consistent hashes\n const med = p[1].toLowerCase();\n const unhashed = `${addr} ${med}`;\n // Map the unhashed values to a known (case-sensitive) address. We use\n // the case-sensitive version because the caller might be expecting that.\n localMapping[unhashed] = p[0];\n return unhashed;\n });\n params[\"algorithm\"] = \"none\";\n } else {\n throw new Error(\"Unsupported identity server: unknown hash algorithm\");\n }\n\n const response = await this.http.idServerRequest<{\n mappings: { [address: string]: string };\n }>(Method.Post, \"/lookup\", params, IdentityPrefix.V2, identityAccessToken);\n\n if (!response?.[\"mappings\"]) return []; // no results\n\n const foundAddresses: { address: string; mxid: string }[] = [];\n for (const hashed of Object.keys(response[\"mappings\"])) {\n const mxid = response[\"mappings\"][hashed];\n const plainAddress = localMapping[hashed];\n if (!plainAddress) {\n throw new Error(\"Identity server returned more results than expected\");\n }\n\n foundAddresses.push({ address: plainAddress, mxid });\n }\n return foundAddresses;\n }\n\n /**\n * Looks up the public Matrix ID mapping for a given 3rd party\n * identifier from the identity server\n *\n * @param medium - The medium of the threepid, eg. 'email'\n * @param address - The textual address of the threepid\n * @param identityAccessToken - The `access_token` field of the Identity\n * Server `/account/register` response (see {@link registerWithIdentityServer}).\n *\n * @returns Promise which resolves: A threepid mapping\n * object or the empty object if no mapping\n * exists\n * @returns Rejects: with an error response.\n */\n public async lookupThreePid(medium: string, address: string, identityAccessToken: string): Promise {\n // TODO: Types\n // Note: we're using the V2 API by calling this function, but our\n // function contract requires a V1 response. We therefore have to\n // convert it manually.\n const response = await this.identityHashedLookup([[address, medium]], identityAccessToken);\n const result = response.find((p) => p.address === address);\n if (!result) {\n return {};\n }\n\n const mapping = {\n address,\n medium,\n mxid: result.mxid,\n\n // We can't reasonably fill these parameters:\n // not_before\n // not_after\n // ts\n // signatures\n };\n\n return mapping;\n }\n\n /**\n * Looks up the public Matrix ID mappings for multiple 3PIDs.\n *\n * @param query - Array of arrays containing\n * [medium, address]\n * @param identityAccessToken - The `access_token` field of the Identity\n * Server `/account/register` response (see {@link registerWithIdentityServer}).\n *\n * @returns Promise which resolves: Lookup results from IS.\n * @returns Rejects: with an error response.\n */\n public async bulkLookupThreePids(query: [string, string][], identityAccessToken: string): Promise {\n // TODO: Types\n // Note: we're using the V2 API by calling this function, but our\n // function contract requires a V1 response. We therefore have to\n // convert it manually.\n const response = await this.identityHashedLookup(\n // We have to reverse the query order to get [address, medium] pairs\n query.map((p) => [p[1], p[0]]),\n identityAccessToken,\n );\n\n const v1results: [medium: string, address: string, mxid: string][] = [];\n for (const mapping of response) {\n const originalQuery = query.find((p) => p[1] === mapping.address);\n if (!originalQuery) {\n throw new Error(\"Identity sever returned unexpected results\");\n }\n\n v1results.push([\n originalQuery[0], // medium\n mapping.address,\n mapping.mxid,\n ]);\n }\n\n return { threepids: v1results };\n }\n\n /**\n * Get account info from the identity server. This is useful as a neutral check\n * to verify that other APIs are likely to approve access by testing that the\n * token is valid, terms have been agreed, etc.\n *\n * @param identityAccessToken - The `access_token` field of the Identity\n * Server `/account/register` response (see {@link registerWithIdentityServer}).\n *\n * @returns Promise which resolves: an object with account info.\n * @returns Rejects: with an error response.\n */\n public getIdentityAccount(identityAccessToken: string): Promise {\n // TODO: Types\n return this.http.idServerRequest(Method.Get, \"/account\", undefined, IdentityPrefix.V2, identityAccessToken);\n }\n\n /**\n * Send an event to a specific list of devices.\n * This is a low-level API that simply wraps the HTTP API\n * call to send to-device messages. We recommend using\n * queueToDevice() which is a higher level API.\n *\n * @param eventType - type of event to send\n * content to send. Map from user_id to device_id to content object.\n * @param txnId - transaction id. One will be made up if not\n * supplied.\n * @returns Promise which resolves: to an empty object `{}`\n */\n public sendToDevice(eventType: string, contentMap: SendToDeviceContentMap, txnId?: string): Promise<{}> {\n const path = utils.encodeUri(\"/sendToDevice/$eventType/$txnId\", {\n $eventType: eventType,\n $txnId: txnId ? txnId : this.makeTxnId(),\n });\n\n const body = {\n messages: utils.recursiveMapToObject(contentMap),\n };\n\n const targets = new Map();\n\n for (const [userId, deviceMessages] of contentMap) {\n targets.set(userId, Array.from(deviceMessages.keys()));\n }\n\n logger.log(`PUT ${path}`, targets);\n\n return this.http.authedRequest(Method.Put, path, undefined, body);\n }\n\n /**\n * Sends events directly to specific devices using Matrix's to-device\n * messaging system. The batch will be split up into appropriately sized\n * batches for sending and stored in the store so they can be retried\n * later if they fail to send. Retries will happen automatically.\n * @param batch - The to-device messages to send\n */\n public queueToDevice(batch: ToDeviceBatch): Promise {\n return this.toDeviceMessageQueue.queueBatch(batch);\n }\n\n /**\n * Get the third party protocols that can be reached using\n * this HS\n * @returns Promise which resolves to the result object\n */\n public getThirdpartyProtocols(): Promise<{ [protocol: string]: IProtocol }> {\n return this.http\n .authedRequest>(Method.Get, \"/thirdparty/protocols\")\n .then((response) => {\n // sanity check\n if (!response || typeof response !== \"object\") {\n throw new Error(`/thirdparty/protocols did not return an object: ${response}`);\n }\n return response;\n });\n }\n\n /**\n * Get information on how a specific place on a third party protocol\n * may be reached.\n * @param protocol - The protocol given in getThirdpartyProtocols()\n * @param params - Protocol-specific parameters, as given in the\n * response to getThirdpartyProtocols()\n * @returns Promise which resolves to the result object\n */\n public getThirdpartyLocation(\n protocol: string,\n params: { searchFields?: string[] },\n ): Promise {\n const path = utils.encodeUri(\"/thirdparty/location/$protocol\", {\n $protocol: protocol,\n });\n\n return this.http.authedRequest(Method.Get, path, params);\n }\n\n /**\n * Get information on how a specific user on a third party protocol\n * may be reached.\n * @param protocol - The protocol given in getThirdpartyProtocols()\n * @param params - Protocol-specific parameters, as given in the\n * response to getThirdpartyProtocols()\n * @returns Promise which resolves to the result object\n */\n public getThirdpartyUser(protocol: string, params: any): Promise {\n // TODO: Types\n const path = utils.encodeUri(\"/thirdparty/user/$protocol\", {\n $protocol: protocol,\n });\n\n return this.http.authedRequest(Method.Get, path, params);\n }\n\n public getTerms(serviceType: SERVICE_TYPES, baseUrl: string): Promise {\n // TODO: Types\n const url = this.termsUrlForService(serviceType, baseUrl);\n return this.http.requestOtherUrl(Method.Get, url);\n }\n\n public agreeToTerms(\n serviceType: SERVICE_TYPES,\n baseUrl: string,\n accessToken: string,\n termsUrls: string[],\n ): Promise<{}> {\n const url = this.termsUrlForService(serviceType, baseUrl);\n const headers = {\n Authorization: \"Bearer \" + accessToken,\n };\n return this.http.requestOtherUrl(\n Method.Post,\n url,\n {\n user_accepts: termsUrls,\n },\n { headers },\n );\n }\n\n /**\n * Reports an event as inappropriate to the server, which may then notify the appropriate people.\n * @param roomId - The room in which the event being reported is located.\n * @param eventId - The event to report.\n * @param score - The score to rate this content as where -100 is most offensive and 0 is inoffensive.\n * @param reason - The reason the content is being reported. May be blank.\n * @returns Promise which resolves to an empty object if successful\n */\n public reportEvent(roomId: string, eventId: string, score: number, reason: string): Promise<{}> {\n const path = utils.encodeUri(\"/rooms/$roomId/report/$eventId\", {\n $roomId: roomId,\n $eventId: eventId,\n });\n\n return this.http.authedRequest(Method.Post, path, undefined, { score, reason });\n }\n\n /**\n * Fetches or paginates a room hierarchy as defined by MSC2946.\n * Falls back gracefully to sourcing its data from `getSpaceSummary` if this API is not yet supported by the server.\n * @param roomId - The ID of the space-room to use as the root of the summary.\n * @param limit - The maximum number of rooms to return per page.\n * @param maxDepth - The maximum depth in the tree from the root room to return.\n * @param suggestedOnly - Whether to only return rooms with suggested=true.\n * @param fromToken - The opaque token to paginate a previous request.\n * @returns the response, with next_batch & rooms fields.\n */\n public getRoomHierarchy(\n roomId: string,\n limit?: number,\n maxDepth?: number,\n suggestedOnly = false,\n fromToken?: string,\n ): Promise {\n const path = utils.encodeUri(\"/rooms/$roomId/hierarchy\", {\n $roomId: roomId,\n });\n\n const queryParams: QueryDict = {\n suggested_only: String(suggestedOnly),\n max_depth: maxDepth?.toString(),\n from: fromToken,\n limit: limit?.toString(),\n };\n\n return this.http\n .authedRequest(Method.Get, path, queryParams, undefined, {\n prefix: ClientPrefix.V1,\n })\n .catch((e) => {\n if (e.errcode === \"M_UNRECOGNIZED\") {\n // fall back to the prefixed hierarchy API.\n return this.http.authedRequest(Method.Get, path, queryParams, undefined, {\n prefix: \"/_matrix/client/unstable/org.matrix.msc2946\",\n });\n }\n\n throw e;\n });\n }\n\n /**\n * Creates a new file tree space with the given name. The client will pick\n * defaults for how it expects to be able to support the remaining API offered\n * by the returned class.\n *\n * Note that this is UNSTABLE and may have breaking changes without notice.\n * @param name - The name of the tree space.\n * @returns Promise which resolves to the created space.\n */\n public async unstableCreateFileTree(name: string): Promise {\n const { room_id: roomId } = await this.createRoom({\n name: name,\n preset: Preset.PrivateChat,\n power_level_content_override: {\n ...DEFAULT_TREE_POWER_LEVELS_TEMPLATE,\n users: {\n [this.getUserId()!]: 100,\n },\n },\n creation_content: {\n [RoomCreateTypeField]: RoomType.Space,\n },\n initial_state: [\n {\n type: UNSTABLE_MSC3088_PURPOSE.name,\n state_key: UNSTABLE_MSC3089_TREE_SUBTYPE.name,\n content: {\n [UNSTABLE_MSC3088_ENABLED.name]: true,\n },\n },\n {\n type: EventType.RoomEncryption,\n state_key: \"\",\n content: {\n algorithm: olmlib.MEGOLM_ALGORITHM,\n },\n },\n ],\n });\n return new MSC3089TreeSpace(this, roomId);\n }\n\n /**\n * Gets a reference to a tree space, if the room ID given is a tree space. If the room\n * does not appear to be a tree space then null is returned.\n *\n * Note that this is UNSTABLE and may have breaking changes without notice.\n * @param roomId - The room ID to get a tree space reference for.\n * @returns The tree space, or null if not a tree space.\n */\n public unstableGetFileTreeSpace(roomId: string): MSC3089TreeSpace | null {\n const room = this.getRoom(roomId);\n if (room?.getMyMembership() !== \"join\") return null;\n\n const createEvent = room.currentState.getStateEvents(EventType.RoomCreate, \"\");\n const purposeEvent = room.currentState.getStateEvents(\n UNSTABLE_MSC3088_PURPOSE.name,\n UNSTABLE_MSC3089_TREE_SUBTYPE.name,\n );\n\n if (!createEvent) throw new Error(\"Expected single room create event\");\n\n if (!purposeEvent?.getContent()?.[UNSTABLE_MSC3088_ENABLED.name]) return null;\n if (createEvent.getContent()?.[RoomCreateTypeField] !== RoomType.Space) return null;\n\n return new MSC3089TreeSpace(this, roomId);\n }\n\n /**\n * Perform a single MSC3575 sliding sync request.\n * @param req - The request to make.\n * @param proxyBaseUrl - The base URL for the sliding sync proxy.\n * @param abortSignal - Optional signal to abort request mid-flight.\n * @returns The sliding sync response, or a standard error.\n * @throws on non 2xx status codes with an object with a field \"httpStatus\":number.\n */\n public slidingSync(\n req: MSC3575SlidingSyncRequest,\n proxyBaseUrl?: string,\n abortSignal?: AbortSignal,\n ): Promise {\n const qps: Record = {};\n if (req.pos) {\n qps.pos = req.pos;\n delete req.pos;\n }\n if (req.timeout) {\n qps.timeout = req.timeout;\n delete req.timeout;\n }\n const clientTimeout = req.clientTimeout;\n delete req.clientTimeout;\n return this.http.authedRequest(Method.Post, \"/sync\", qps, req, {\n prefix: \"/_matrix/client/unstable/org.matrix.msc3575\",\n baseUrl: proxyBaseUrl,\n localTimeoutMs: clientTimeout,\n abortSignal,\n });\n }\n\n /**\n * @deprecated use supportsThreads() instead\n */\n public supportsExperimentalThreads(): boolean {\n logger.warn(`supportsExperimentalThreads() is deprecated, use supportThreads() instead`);\n return this.clientOpts?.experimentalThreadSupport || false;\n }\n\n /**\n * A helper to determine thread support\n * @returns a boolean to determine if threads are enabled\n */\n public supportsThreads(): boolean {\n return this.clientOpts?.threadSupport || false;\n }\n\n /**\n * A helper to determine intentional mentions support\n * @returns a boolean to determine if intentional mentions are enabled\n * @experimental\n */\n public supportsIntentionalMentions(): boolean {\n return this.clientOpts?.intentionalMentions || false;\n }\n\n /**\n * Fetches the summary of a room as defined by an initial version of MSC3266 and implemented in Synapse\n * Proposed at https://github.com/matrix-org/matrix-doc/pull/3266\n * @param roomIdOrAlias - The ID or alias of the room to get the summary of.\n * @param via - The list of servers which know about the room if only an ID was provided.\n */\n public async getRoomSummary(roomIdOrAlias: string, via?: string[]): Promise {\n const path = utils.encodeUri(\"/rooms/$roomid/summary\", { $roomid: roomIdOrAlias });\n return this.http.authedRequest(Method.Get, path, { via }, undefined, {\n prefix: \"/_matrix/client/unstable/im.nheko.summary\",\n });\n }\n\n /**\n * Processes a list of threaded events and adds them to their respective timelines\n * @param room - the room the adds the threaded events\n * @param threadedEvents - an array of the threaded events\n * @param toStartOfTimeline - the direction in which we want to add the events\n */\n public processThreadEvents(room: Room, threadedEvents: MatrixEvent[], toStartOfTimeline: boolean): void {\n room.processThreadedEvents(threadedEvents, toStartOfTimeline);\n }\n\n /**\n * Processes a list of thread roots and creates a thread model\n * @param room - the room to create the threads in\n * @param threadedEvents - an array of thread roots\n * @param toStartOfTimeline - the direction\n */\n public processThreadRoots(room: Room, threadedEvents: MatrixEvent[], toStartOfTimeline: boolean): void {\n room.processThreadRoots(threadedEvents, toStartOfTimeline);\n }\n\n public processBeaconEvents(room?: Room, events?: MatrixEvent[]): void {\n this.processAggregatedTimelineEvents(room, events);\n }\n\n /**\n * Calls aggregation functions for event types that are aggregated\n * Polls and location beacons\n * @param room - room the events belong to\n * @param events - timeline events to be processed\n * @returns\n */\n public processAggregatedTimelineEvents(room?: Room, events?: MatrixEvent[]): void {\n if (!events?.length) return;\n if (!room) return;\n\n room.currentState.processBeaconEvents(events, this);\n room.processPollEvents(events);\n }\n\n /**\n * Fetches information about the user for the configured access token.\n */\n public async whoami(): Promise {\n return this.http.authedRequest(Method.Get, \"/account/whoami\");\n }\n\n /**\n * Find the event_id closest to the given timestamp in the given direction.\n * @returns Resolves: A promise of an object containing the event_id and\n * origin_server_ts of the closest event to the timestamp in the given direction\n * @returns Rejects: when the request fails (module:http-api.MatrixError)\n */\n public async timestampToEvent(\n roomId: string,\n timestamp: number,\n dir: Direction,\n ): Promise {\n const path = utils.encodeUri(\"/rooms/$roomId/timestamp_to_event\", {\n $roomId: roomId,\n });\n const queryParams = {\n ts: timestamp.toString(),\n dir: dir,\n };\n\n try {\n return await this.http.authedRequest(Method.Get, path, queryParams, undefined, {\n prefix: ClientPrefix.V1,\n });\n } catch (err) {\n // Fallback to the prefixed unstable endpoint. Since the stable endpoint is\n // new, we should also try the unstable endpoint before giving up. We can\n // remove this fallback request in a year (remove after 2023-11-28).\n if (\n (err).errcode === \"M_UNRECOGNIZED\" &&\n // XXX: The 400 status code check should be removed in the future\n // when Synapse is compliant with MSC3743.\n ((err).httpStatus === 400 ||\n // This the correct standard status code for an unsupported\n // endpoint according to MSC3743. Not Found and Method Not Allowed\n // both indicate that this endpoint+verb combination is\n // not supported.\n (err).httpStatus === 404 ||\n (err).httpStatus === 405)\n ) {\n return await this.http.authedRequest(Method.Get, path, queryParams, undefined, {\n prefix: \"/_matrix/client/unstable/org.matrix.msc3030\",\n });\n }\n\n throw err;\n }\n }\n}\n\n/**\n * recalculates an accurate notifications count on event decryption.\n * Servers do not have enough knowledge about encrypted events to calculate an\n * accurate notification_count\n */\nexport function fixNotificationCountOnDecryption(cli: MatrixClient, event: MatrixEvent): void {\n const ourUserId = cli.getUserId();\n const eventId = event.getId();\n\n const room = cli.getRoom(event.getRoomId());\n if (!room || !ourUserId || !eventId) return;\n\n const oldActions = event.getPushActions();\n const actions = cli.getPushActionsForEvent(event, true);\n\n const isThreadEvent = !!event.threadRootId && !event.isThreadRoot;\n\n const currentHighlightCount = room.getUnreadCountForEventContext(NotificationCountType.Highlight, event);\n\n // Ensure the unread counts are kept up to date if the event is encrypted\n // We also want to make sure that the notification count goes up if we already\n // have encrypted events to avoid other code from resetting 'highlight' to zero.\n const oldHighlight = !!oldActions?.tweaks?.highlight;\n const newHighlight = !!actions?.tweaks?.highlight;\n\n let hasReadEvent;\n if (isThreadEvent) {\n const thread = room.getThread(event.threadRootId);\n hasReadEvent = thread\n ? thread.hasUserReadEvent(ourUserId, eventId)\n : // If the thread object does not exist in the room yet, we don't\n // want to calculate notification for this event yet. We have not\n // restored the read receipts yet and can't accurately calculate\n // notifications at this stage.\n //\n // This issue can likely go away when MSC3874 is implemented\n true;\n } else {\n hasReadEvent = room.hasUserReadEvent(ourUserId, eventId);\n }\n\n if (hasReadEvent) {\n // If the event has been read, ignore it.\n return;\n }\n\n if (oldHighlight !== newHighlight || currentHighlightCount > 0) {\n // TODO: Handle mentions received while the client is offline\n // See also https://github.com/vector-im/element-web/issues/9069\n let newCount = currentHighlightCount;\n if (newHighlight && !oldHighlight) newCount++;\n if (!newHighlight && oldHighlight) newCount--;\n\n if (isThreadEvent) {\n room.setThreadUnreadNotificationCount(event.threadRootId, NotificationCountType.Highlight, newCount);\n } else {\n room.setUnreadNotificationCount(NotificationCountType.Highlight, newCount);\n }\n }\n\n // Total count is used to typically increment a room notification counter, but not loudly highlight it.\n const currentTotalCount = room.getUnreadCountForEventContext(NotificationCountType.Total, event);\n\n // `notify` is used in practice for incrementing the total count\n const newNotify = !!actions?.notify;\n\n // The room total count is NEVER incremented by the server for encrypted rooms. We basically ignore\n // the server here as it's always going to tell us to increment for encrypted events.\n if (newNotify) {\n if (isThreadEvent) {\n room.setThreadUnreadNotificationCount(\n event.threadRootId,\n NotificationCountType.Total,\n currentTotalCount + 1,\n );\n } else {\n room.setUnreadNotificationCount(NotificationCountType.Total, currentTotalCount + 1);\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts deleted file mode 100644 index adfff15..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts +++ /dev/null @@ -1,141 +0,0 @@ -import type { IToDeviceEvent } from "../sync-accumulator"; -import { MatrixEvent } from "../models/event"; -import { Room } from "../models/room"; -import { CryptoApi } from "../crypto-api"; -import { DeviceTrustLevel, UserTrustLevel } from "../crypto/CrossSigning"; -import { IEncryptedEventInfo } from "../crypto/api"; -import { IEventDecryptionResult } from "../@types/crypto"; -/** - * Common interface for the crypto implementations - */ -export interface CryptoBackend extends SyncCryptoCallbacks, CryptoApi { - /** - * Whether sendMessage in a room with unknown and unverified devices - * should throw an error and not send the message. This has 'Global' for - * symmetry with setGlobalBlacklistUnverifiedDevices but there is currently - * no room-level equivalent for this setting. - * - * @remarks this is here, rather than in `CryptoApi`, because I don't think we're - * going to support it in the rust crypto implementation. - */ - globalErrorOnUnknownDevices: boolean; - /** - * Shut down any background processes related to crypto - */ - stop(): void; - /** - * Get the verification level for a given user - * - * TODO: define this better - * - * @param userId - user to be checked - */ - checkUserTrust(userId: string): UserTrustLevel; - /** - * Get the verification level for a given device - * - * TODO: define this better - * - * @param userId - user to be checked - * @param deviceId - device to be checked - */ - checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel; - /** - * Encrypt an event according to the configuration of the room. - * - * @param event - event to be sent - * - * @param room - destination room. - * - * @returns Promise which resolves when the event has been - * encrypted, or null if nothing was needed - */ - encryptEvent(event: MatrixEvent, room: Room): Promise; - /** - * Decrypt a received event - * - * @returns a promise which resolves once we have finished decrypting. - * Rejects with an error if there is a problem decrypting the event. - */ - decryptEvent(event: MatrixEvent): Promise; - /** - * Get information about the encryption of an event - * - * @param event - event to be checked - */ - getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo; -} -/** The methods which crypto implementations should expose to the Sync api */ -export interface SyncCryptoCallbacks { - /** - * Called by the /sync loop whenever there are incoming to-device messages. - * - * The implementation may preprocess the received messages (eg, decrypt them) and return an - * updated list of messages for dispatch to the rest of the system. - * - * Note that, unlike {@link ClientEvent.ToDeviceEvent} events, this is called on the raw to-device - * messages, rather than the results of any decryption attempts. - * - * @param events - the received to-device messages - * @returns A list of preprocessed to-device messages. - */ - preprocessToDeviceMessages(events: IToDeviceEvent[]): Promise; - /** - * Called by the /sync loop whenever there are incoming to-device messages. - * - * The implementation may preprocess the received messages (eg, decrypt them) and return an - * updated list of messages for dispatch to the rest of the system. - * - * Note that, unlike {@link ClientEvent.ToDeviceEvent} events, this is called on the raw to-device - * messages, rather than the results of any decryption attempts. - * - * @param oneTimeKeysCounts - the received one time key counts - * @returns A list of preprocessed to-device messages. - */ - preprocessOneTimeKeyCounts(oneTimeKeysCounts: Map): Promise; - /** - * Called by the /sync loop whenever there are incoming to-device messages. - * - * The implementation may preprocess the received messages (eg, decrypt them) and return an - * updated list of messages for dispatch to the rest of the system. - * - * Note that, unlike {@link ClientEvent.ToDeviceEvent} events, this is called on the raw to-device - * messages, rather than the results of any decryption attempts. - * - * @param unusedFallbackKeys - the received unused fallback keys - * @returns A list of preprocessed to-device messages. - */ - preprocessUnusedFallbackKeys(unusedFallbackKeys: Set): Promise; - /** - * Called by the /sync loop whenever an m.room.encryption event is received. - * - * This is called before RoomStateEvents are emitted for any of the events in the /sync - * response (even if the other events technically happened first). This works around a problem - * if the client uses a RoomStateEvent (typically a membership event) as a trigger to send a message - * in a new room (or one where encryption has been newly enabled): that would otherwise leave the - * crypto layer confused because it expects crypto to be set up, but it has not yet been. - * - * @param room - in which the event was received - * @param event - encryption event to be processed - */ - onCryptoEvent(room: Room, event: MatrixEvent): Promise; - /** - * Called by the /sync loop after each /sync response is processed. - * - * Used to complete batch processing, or to initiate background processes - * - * @param syncState - information about the completed sync. - */ - onSyncCompleted(syncState: OnSyncCompletedData): void; -} -export interface OnSyncCompletedData { - /** - * The 'next_batch' result from /sync, which will become the 'since' token for the next call to /sync. - */ - nextSyncToken?: string; - /** - * True if we are working our way through a backlog of events after connecting. - */ - catchingUp?: boolean; -} -//# sourceMappingURL=CryptoBackend.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts.map deleted file mode 100644 index 85416cf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"CryptoBackend.d.ts","sourceRoot":"","sources":["../../src/common-crypto/CryptoBackend.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAC;AAE1D;;GAEG;AACH,MAAM,WAAW,aAAc,SAAQ,mBAAmB,EAAE,SAAS;IACjE;;;;;;;;OAQG;IACH,2BAA2B,EAAE,OAAO,CAAC;IAErC;;OAEG;IACH,IAAI,IAAI,IAAI,CAAC;IAEb;;;;;;OAMG;IACH,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,CAAC;IAE/C;;;;;;;OAOG;IACH,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,gBAAgB,CAAC;IAErE;;;;;;;;;OASG;IACH,YAAY,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE5D;;;;;OAKG;IACH,YAAY,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC;IAElE;;;;OAIG;IACH,sBAAsB,CAAC,KAAK,EAAE,WAAW,GAAG,mBAAmB,CAAC;CACnE;AAED,6EAA6E;AAC7E,MAAM,WAAW,mBAAmB;IAChC;;;;;;;;;;;OAWG;IACH,0BAA0B,CAAC,MAAM,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,CAAC;IAEhF;;;;;;;;;;;OAWG;IACH,0BAA0B,CAAC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAElF;;;;;;;;;;;OAWG;IACH,4BAA4B,CAAC,kBAAkB,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE7E;;;;;;;;;;;OAWG;IACH,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE7D;;;;;;OAMG;IACH,eAAe,CAAC,SAAS,EAAE,mBAAmB,GAAG,IAAI,CAAC;CACzD;AAED,MAAM,WAAW,mBAAmB;IAChC;;OAEG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB;;OAEG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACxB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js deleted file mode 100644 index 628411d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=CryptoBackend.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js.map deleted file mode 100644 index 06cee66..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/common-crypto/CryptoBackend.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"CryptoBackend.js","names":[],"sources":["../../src/common-crypto/CryptoBackend.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport type { IToDeviceEvent } from \"../sync-accumulator\";\nimport { MatrixEvent } from \"../models/event\";\nimport { Room } from \"../models/room\";\nimport { CryptoApi } from \"../crypto-api\";\nimport { DeviceTrustLevel, UserTrustLevel } from \"../crypto/CrossSigning\";\nimport { IEncryptedEventInfo } from \"../crypto/api\";\nimport { IEventDecryptionResult } from \"../@types/crypto\";\n\n/**\n * Common interface for the crypto implementations\n */\nexport interface CryptoBackend extends SyncCryptoCallbacks, CryptoApi {\n /**\n * Whether sendMessage in a room with unknown and unverified devices\n * should throw an error and not send the message. This has 'Global' for\n * symmetry with setGlobalBlacklistUnverifiedDevices but there is currently\n * no room-level equivalent for this setting.\n *\n * @remarks this is here, rather than in `CryptoApi`, because I don't think we're\n * going to support it in the rust crypto implementation.\n */\n globalErrorOnUnknownDevices: boolean;\n\n /**\n * Shut down any background processes related to crypto\n */\n stop(): void;\n\n /**\n * Get the verification level for a given user\n *\n * TODO: define this better\n *\n * @param userId - user to be checked\n */\n checkUserTrust(userId: string): UserTrustLevel;\n\n /**\n * Get the verification level for a given device\n *\n * TODO: define this better\n *\n * @param userId - user to be checked\n * @param deviceId - device to be checked\n */\n checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel;\n\n /**\n * Encrypt an event according to the configuration of the room.\n *\n * @param event - event to be sent\n *\n * @param room - destination room.\n *\n * @returns Promise which resolves when the event has been\n * encrypted, or null if nothing was needed\n */\n encryptEvent(event: MatrixEvent, room: Room): Promise;\n\n /**\n * Decrypt a received event\n *\n * @returns a promise which resolves once we have finished decrypting.\n * Rejects with an error if there is a problem decrypting the event.\n */\n decryptEvent(event: MatrixEvent): Promise;\n\n /**\n * Get information about the encryption of an event\n *\n * @param event - event to be checked\n */\n getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo;\n}\n\n/** The methods which crypto implementations should expose to the Sync api */\nexport interface SyncCryptoCallbacks {\n /**\n * Called by the /sync loop whenever there are incoming to-device messages.\n *\n * The implementation may preprocess the received messages (eg, decrypt them) and return an\n * updated list of messages for dispatch to the rest of the system.\n *\n * Note that, unlike {@link ClientEvent.ToDeviceEvent} events, this is called on the raw to-device\n * messages, rather than the results of any decryption attempts.\n *\n * @param events - the received to-device messages\n * @returns A list of preprocessed to-device messages.\n */\n preprocessToDeviceMessages(events: IToDeviceEvent[]): Promise;\n\n /**\n * Called by the /sync loop whenever there are incoming to-device messages.\n *\n * The implementation may preprocess the received messages (eg, decrypt them) and return an\n * updated list of messages for dispatch to the rest of the system.\n *\n * Note that, unlike {@link ClientEvent.ToDeviceEvent} events, this is called on the raw to-device\n * messages, rather than the results of any decryption attempts.\n *\n * @param oneTimeKeysCounts - the received one time key counts\n * @returns A list of preprocessed to-device messages.\n */\n preprocessOneTimeKeyCounts(oneTimeKeysCounts: Map): Promise;\n\n /**\n * Called by the /sync loop whenever there are incoming to-device messages.\n *\n * The implementation may preprocess the received messages (eg, decrypt them) and return an\n * updated list of messages for dispatch to the rest of the system.\n *\n * Note that, unlike {@link ClientEvent.ToDeviceEvent} events, this is called on the raw to-device\n * messages, rather than the results of any decryption attempts.\n *\n * @param unusedFallbackKeys - the received unused fallback keys\n * @returns A list of preprocessed to-device messages.\n */\n preprocessUnusedFallbackKeys(unusedFallbackKeys: Set): Promise;\n\n /**\n * Called by the /sync loop whenever an m.room.encryption event is received.\n *\n * This is called before RoomStateEvents are emitted for any of the events in the /sync\n * response (even if the other events technically happened first). This works around a problem\n * if the client uses a RoomStateEvent (typically a membership event) as a trigger to send a message\n * in a new room (or one where encryption has been newly enabled): that would otherwise leave the\n * crypto layer confused because it expects crypto to be set up, but it has not yet been.\n *\n * @param room - in which the event was received\n * @param event - encryption event to be processed\n */\n onCryptoEvent(room: Room, event: MatrixEvent): Promise;\n\n /**\n * Called by the /sync loop after each /sync response is processed.\n *\n * Used to complete batch processing, or to initiate background processes\n *\n * @param syncState - information about the completed sync.\n */\n onSyncCompleted(syncState: OnSyncCompletedData): void;\n}\n\nexport interface OnSyncCompletedData {\n /**\n * The 'next_batch' result from /sync, which will become the 'since' token for the next call to /sync.\n */\n nextSyncToken?: string;\n\n /**\n * True if we are working our way through a backlog of events after connecting.\n */\n catchingUp?: boolean;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts deleted file mode 100644 index f7b23ff..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts +++ /dev/null @@ -1,90 +0,0 @@ -import { MBeaconEventContent, MBeaconInfoContent, MBeaconInfoEventContent } from "./@types/beacon"; -import { LocationAssetType, LocationEventWireContent, MLocationEventContent, MLocationContent, LegacyLocationEventContent } from "./@types/location"; -import { MRoomTopicEventContent } from "./@types/topic"; -import { IContent } from "./models/event"; -/** - * Generates the content for a HTML Message event - * @param body - the plaintext body of the message - * @param htmlBody - the HTML representation of the message - * @returns - */ -export declare function makeHtmlMessage(body: string, htmlBody: string): IContent; -/** - * Generates the content for a HTML Notice event - * @param body - the plaintext body of the notice - * @param htmlBody - the HTML representation of the notice - * @returns - */ -export declare function makeHtmlNotice(body: string, htmlBody: string): IContent; -/** - * Generates the content for a HTML Emote event - * @param body - the plaintext body of the emote - * @param htmlBody - the HTML representation of the emote - * @returns - */ -export declare function makeHtmlEmote(body: string, htmlBody: string): IContent; -/** - * Generates the content for a Plaintext Message event - * @param body - the plaintext body of the emote - * @returns - */ -export declare function makeTextMessage(body: string): IContent; -/** - * Generates the content for a Plaintext Notice event - * @param body - the plaintext body of the notice - * @returns - */ -export declare function makeNotice(body: string): IContent; -/** - * Generates the content for a Plaintext Emote event - * @param body - the plaintext body of the emote - * @returns - */ -export declare function makeEmoteMessage(body: string): IContent; -/** Location content helpers */ -export declare const getTextForLocationEvent: (uri: string | undefined, assetType: LocationAssetType, timestamp?: number, description?: string | null) => string; -/** - * Generates the content for a Location event - * @param uri - a geo:// uri for the location - * @param timestamp - the timestamp when the location was correct (milliseconds since the UNIX epoch) - * @param description - the (optional) label for this location on the map - * @param assetType - the (optional) asset type of this location e.g. "m.self" - * @param text - optional. A text for the location - */ -export declare const makeLocationContent: (text?: string, uri?: string, timestamp?: number, description?: string | null, assetType?: LocationAssetType) => LegacyLocationEventContent & MLocationEventContent; -/** - * Parse location event content and transform to - * a backwards compatible modern m.location event format - */ -export declare const parseLocationEvent: (wireEventContent: LocationEventWireContent) => MLocationEventContent; -/** - * Topic event helpers - */ -export type MakeTopicContent = (topic: string, htmlTopic?: string) => MRoomTopicEventContent; -export declare const makeTopicContent: MakeTopicContent; -export type TopicState = { - text: string; - html?: string; -}; -export declare const parseTopicContent: (content: MRoomTopicEventContent) => TopicState; -/** - * Beacon event helpers - */ -export type MakeBeaconInfoContent = (timeout: number, isLive?: boolean, description?: string, assetType?: LocationAssetType, timestamp?: number) => MBeaconInfoEventContent; -export declare const makeBeaconInfoContent: MakeBeaconInfoContent; -export type BeaconInfoState = MBeaconInfoContent & { - assetType?: LocationAssetType; - timestamp?: number; -}; -/** - * Flatten beacon info event content - */ -export declare const parseBeaconInfoContent: (content: MBeaconInfoEventContent) => BeaconInfoState; -export type MakeBeaconContent = (uri: string, timestamp: number, beaconInfoEventId: string, description?: string) => MBeaconEventContent; -export declare const makeBeaconContent: MakeBeaconContent; -export type BeaconLocationState = Omit & { - uri?: string; - timestamp?: number; -}; -export declare const parseBeaconContent: (content: MBeaconEventContent) => BeaconLocationState; -//# sourceMappingURL=content-helpers.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts.map deleted file mode 100644 index 55f6f06..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"content-helpers.d.ts","sourceRoot":"","sources":["../src/content-helpers.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js deleted file mode 100644 index 73f1e86..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js +++ /dev/null @@ -1,256 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.makeBeaconInfoContent = exports.makeBeaconContent = exports.getTextForLocationEvent = void 0; -exports.makeEmoteMessage = makeEmoteMessage; -exports.makeHtmlEmote = makeHtmlEmote; -exports.makeHtmlMessage = makeHtmlMessage; -exports.makeHtmlNotice = makeHtmlNotice; -exports.makeLocationContent = void 0; -exports.makeNotice = makeNotice; -exports.makeTextMessage = makeTextMessage; -exports.parseTopicContent = exports.parseLocationEvent = exports.parseBeaconInfoContent = exports.parseBeaconContent = exports.makeTopicContent = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _event = require("./@types/event"); -var _extensible_events = require("./@types/extensible_events"); -var _utilities = require("./extensible_events_v1/utilities"); -var _location = require("./@types/location"); -var _topic = require("./@types/topic"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * Generates the content for a HTML Message event - * @param body - the plaintext body of the message - * @param htmlBody - the HTML representation of the message - * @returns - */ -function makeHtmlMessage(body, htmlBody) { - return { - msgtype: _event.MsgType.Text, - format: "org.matrix.custom.html", - body: body, - formatted_body: htmlBody - }; -} - -/** - * Generates the content for a HTML Notice event - * @param body - the plaintext body of the notice - * @param htmlBody - the HTML representation of the notice - * @returns - */ -function makeHtmlNotice(body, htmlBody) { - return { - msgtype: _event.MsgType.Notice, - format: "org.matrix.custom.html", - body: body, - formatted_body: htmlBody - }; -} - -/** - * Generates the content for a HTML Emote event - * @param body - the plaintext body of the emote - * @param htmlBody - the HTML representation of the emote - * @returns - */ -function makeHtmlEmote(body, htmlBody) { - return { - msgtype: _event.MsgType.Emote, - format: "org.matrix.custom.html", - body: body, - formatted_body: htmlBody - }; -} - -/** - * Generates the content for a Plaintext Message event - * @param body - the plaintext body of the emote - * @returns - */ -function makeTextMessage(body) { - return { - msgtype: _event.MsgType.Text, - body: body - }; -} - -/** - * Generates the content for a Plaintext Notice event - * @param body - the plaintext body of the notice - * @returns - */ -function makeNotice(body) { - return { - msgtype: _event.MsgType.Notice, - body: body - }; -} - -/** - * Generates the content for a Plaintext Emote event - * @param body - the plaintext body of the emote - * @returns - */ -function makeEmoteMessage(body) { - return { - msgtype: _event.MsgType.Emote, - body: body - }; -} - -/** Location content helpers */ - -const getTextForLocationEvent = (uri, assetType, timestamp, description) => { - const date = `at ${new Date(timestamp).toISOString()}`; - const assetName = assetType === _location.LocationAssetType.Self ? "User" : undefined; - const quotedDescription = description ? `"${description}"` : undefined; - return [assetName, "Location", quotedDescription, uri, date].filter(Boolean).join(" "); -}; - -/** - * Generates the content for a Location event - * @param uri - a geo:// uri for the location - * @param timestamp - the timestamp when the location was correct (milliseconds since the UNIX epoch) - * @param description - the (optional) label for this location on the map - * @param assetType - the (optional) asset type of this location e.g. "m.self" - * @param text - optional. A text for the location - */ -exports.getTextForLocationEvent = getTextForLocationEvent; -const makeLocationContent = (text, uri, timestamp, description, assetType) => { - const defaultedText = text !== null && text !== void 0 ? text : getTextForLocationEvent(uri, assetType || _location.LocationAssetType.Self, timestamp, description); - const timestampEvent = timestamp ? { - [_location.M_TIMESTAMP.name]: timestamp - } : {}; - return _objectSpread({ - msgtype: _event.MsgType.Location, - body: defaultedText, - geo_uri: uri, - [_location.M_LOCATION.name]: { - description, - uri - }, - [_location.M_ASSET.name]: { - type: assetType || _location.LocationAssetType.Self - }, - [_extensible_events.M_TEXT.name]: defaultedText - }, timestampEvent); -}; - -/** - * Parse location event content and transform to - * a backwards compatible modern m.location event format - */ -exports.makeLocationContent = makeLocationContent; -const parseLocationEvent = wireEventContent => { - var _location$uri, _asset$type; - const location = _location.M_LOCATION.findIn(wireEventContent); - const asset = _location.M_ASSET.findIn(wireEventContent); - const timestamp = _location.M_TIMESTAMP.findIn(wireEventContent); - const text = _extensible_events.M_TEXT.findIn(wireEventContent); - const geoUri = (_location$uri = location === null || location === void 0 ? void 0 : location.uri) !== null && _location$uri !== void 0 ? _location$uri : wireEventContent === null || wireEventContent === void 0 ? void 0 : wireEventContent.geo_uri; - const description = location === null || location === void 0 ? void 0 : location.description; - const assetType = (_asset$type = asset === null || asset === void 0 ? void 0 : asset.type) !== null && _asset$type !== void 0 ? _asset$type : _location.LocationAssetType.Self; - const fallbackText = text !== null && text !== void 0 ? text : wireEventContent.body; - return makeLocationContent(fallbackText, geoUri, timestamp !== null && timestamp !== void 0 ? timestamp : undefined, description, assetType); -}; - -/** - * Topic event helpers - */ -exports.parseLocationEvent = parseLocationEvent; -const makeTopicContent = (topic, htmlTopic) => { - const renderings = [{ - body: topic, - mimetype: "text/plain" - }]; - if ((0, _utilities.isProvided)(htmlTopic)) { - renderings.push({ - body: htmlTopic, - mimetype: "text/html" - }); - } - return { - topic, - [_topic.M_TOPIC.name]: renderings - }; -}; -exports.makeTopicContent = makeTopicContent; -const parseTopicContent = content => { - var _mtopic$find$body, _mtopic$find, _mtopic$find2; - const mtopic = _topic.M_TOPIC.findIn(content); - if (!Array.isArray(mtopic)) { - return { - text: content.topic - }; - } - const text = (_mtopic$find$body = mtopic === null || mtopic === void 0 ? void 0 : (_mtopic$find = mtopic.find(r => !(0, _utilities.isProvided)(r.mimetype) || r.mimetype === "text/plain")) === null || _mtopic$find === void 0 ? void 0 : _mtopic$find.body) !== null && _mtopic$find$body !== void 0 ? _mtopic$find$body : content.topic; - const html = mtopic === null || mtopic === void 0 ? void 0 : (_mtopic$find2 = mtopic.find(r => r.mimetype === "text/html")) === null || _mtopic$find2 === void 0 ? void 0 : _mtopic$find2.body; - return { - text, - html - }; -}; - -/** - * Beacon event helpers - */ -exports.parseTopicContent = parseTopicContent; -const makeBeaconInfoContent = (timeout, isLive, description, assetType, timestamp) => ({ - description, - timeout, - live: isLive, - [_location.M_TIMESTAMP.name]: timestamp || Date.now(), - [_location.M_ASSET.name]: { - type: assetType !== null && assetType !== void 0 ? assetType : _location.LocationAssetType.Self - } -}); -exports.makeBeaconInfoContent = makeBeaconInfoContent; -/** - * Flatten beacon info event content - */ -const parseBeaconInfoContent = content => { - var _M_TIMESTAMP$findIn; - const { - description, - timeout, - live - } = content; - const timestamp = (_M_TIMESTAMP$findIn = _location.M_TIMESTAMP.findIn(content)) !== null && _M_TIMESTAMP$findIn !== void 0 ? _M_TIMESTAMP$findIn : undefined; - const asset = _location.M_ASSET.findIn(content); - return { - description, - timeout, - live, - assetType: asset === null || asset === void 0 ? void 0 : asset.type, - timestamp - }; -}; -exports.parseBeaconInfoContent = parseBeaconInfoContent; -const makeBeaconContent = (uri, timestamp, beaconInfoEventId, description) => ({ - [_location.M_LOCATION.name]: { - description, - uri - }, - [_location.M_TIMESTAMP.name]: timestamp, - "m.relates_to": { - rel_type: _extensible_events.REFERENCE_RELATION.name, - event_id: beaconInfoEventId - } -}); -exports.makeBeaconContent = makeBeaconContent; -const parseBeaconContent = content => { - var _M_TIMESTAMP$findIn2; - const location = _location.M_LOCATION.findIn(content); - const timestamp = (_M_TIMESTAMP$findIn2 = _location.M_TIMESTAMP.findIn(content)) !== null && _M_TIMESTAMP$findIn2 !== void 0 ? _M_TIMESTAMP$findIn2 : undefined; - return { - description: location === null || location === void 0 ? void 0 : location.description, - uri: location === null || location === void 0 ? void 0 : location.uri, - timestamp - }; -}; -exports.parseBeaconContent = parseBeaconContent; -//# sourceMappingURL=content-helpers.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js.map deleted file mode 100644 index b50087a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-helpers.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"content-helpers.js","names":["_event","require","_extensible_events","_utilities","_location","_topic","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","makeHtmlMessage","body","htmlBody","msgtype","MsgType","Text","format","formatted_body","makeHtmlNotice","Notice","makeHtmlEmote","Emote","makeTextMessage","makeNotice","makeEmoteMessage","getTextForLocationEvent","uri","assetType","timestamp","description","date","Date","toISOString","assetName","LocationAssetType","Self","undefined","quotedDescription","Boolean","join","exports","makeLocationContent","text","defaultedText","timestampEvent","M_TIMESTAMP","name","Location","geo_uri","M_LOCATION","M_ASSET","type","M_TEXT","parseLocationEvent","wireEventContent","_location$uri","_asset$type","location","findIn","asset","geoUri","fallbackText","makeTopicContent","topic","htmlTopic","renderings","mimetype","isProvided","M_TOPIC","parseTopicContent","content","_mtopic$find$body","_mtopic$find","_mtopic$find2","mtopic","Array","isArray","find","r","html","makeBeaconInfoContent","timeout","isLive","live","now","parseBeaconInfoContent","_M_TIMESTAMP$findIn","makeBeaconContent","beaconInfoEventId","rel_type","REFERENCE_RELATION","event_id","parseBeaconContent","_M_TIMESTAMP$findIn2"],"sources":["../src/content-helpers.ts"],"sourcesContent":["/*\nCopyright 2018 - 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MBeaconEventContent, MBeaconInfoContent, MBeaconInfoEventContent } from \"./@types/beacon\";\nimport { MsgType } from \"./@types/event\";\nimport { M_TEXT, REFERENCE_RELATION } from \"./@types/extensible_events\";\nimport { isProvided } from \"./extensible_events_v1/utilities\";\nimport {\n M_ASSET,\n LocationAssetType,\n M_LOCATION,\n M_TIMESTAMP,\n LocationEventWireContent,\n MLocationEventContent,\n MLocationContent,\n MAssetContent,\n LegacyLocationEventContent,\n} from \"./@types/location\";\nimport { MRoomTopicEventContent, MTopicContent, M_TOPIC } from \"./@types/topic\";\nimport { IContent } from \"./models/event\";\n\n/**\n * Generates the content for a HTML Message event\n * @param body - the plaintext body of the message\n * @param htmlBody - the HTML representation of the message\n * @returns\n */\nexport function makeHtmlMessage(body: string, htmlBody: string): IContent {\n return {\n msgtype: MsgType.Text,\n format: \"org.matrix.custom.html\",\n body: body,\n formatted_body: htmlBody,\n };\n}\n\n/**\n * Generates the content for a HTML Notice event\n * @param body - the plaintext body of the notice\n * @param htmlBody - the HTML representation of the notice\n * @returns\n */\nexport function makeHtmlNotice(body: string, htmlBody: string): IContent {\n return {\n msgtype: MsgType.Notice,\n format: \"org.matrix.custom.html\",\n body: body,\n formatted_body: htmlBody,\n };\n}\n\n/**\n * Generates the content for a HTML Emote event\n * @param body - the plaintext body of the emote\n * @param htmlBody - the HTML representation of the emote\n * @returns\n */\nexport function makeHtmlEmote(body: string, htmlBody: string): IContent {\n return {\n msgtype: MsgType.Emote,\n format: \"org.matrix.custom.html\",\n body: body,\n formatted_body: htmlBody,\n };\n}\n\n/**\n * Generates the content for a Plaintext Message event\n * @param body - the plaintext body of the emote\n * @returns\n */\nexport function makeTextMessage(body: string): IContent {\n return {\n msgtype: MsgType.Text,\n body: body,\n };\n}\n\n/**\n * Generates the content for a Plaintext Notice event\n * @param body - the plaintext body of the notice\n * @returns\n */\nexport function makeNotice(body: string): IContent {\n return {\n msgtype: MsgType.Notice,\n body: body,\n };\n}\n\n/**\n * Generates the content for a Plaintext Emote event\n * @param body - the plaintext body of the emote\n * @returns\n */\nexport function makeEmoteMessage(body: string): IContent {\n return {\n msgtype: MsgType.Emote,\n body: body,\n };\n}\n\n/** Location content helpers */\n\nexport const getTextForLocationEvent = (\n uri: string | undefined,\n assetType: LocationAssetType,\n timestamp?: number,\n description?: string | null,\n): string => {\n const date = `at ${new Date(timestamp!).toISOString()}`;\n const assetName = assetType === LocationAssetType.Self ? \"User\" : undefined;\n const quotedDescription = description ? `\"${description}\"` : undefined;\n\n return [assetName, \"Location\", quotedDescription, uri, date].filter(Boolean).join(\" \");\n};\n\n/**\n * Generates the content for a Location event\n * @param uri - a geo:// uri for the location\n * @param timestamp - the timestamp when the location was correct (milliseconds since the UNIX epoch)\n * @param description - the (optional) label for this location on the map\n * @param assetType - the (optional) asset type of this location e.g. \"m.self\"\n * @param text - optional. A text for the location\n */\nexport const makeLocationContent = (\n // this is first but optional\n // to avoid a breaking change\n text?: string,\n uri?: string,\n timestamp?: number,\n description?: string | null,\n assetType?: LocationAssetType,\n): LegacyLocationEventContent & MLocationEventContent => {\n const defaultedText =\n text ?? getTextForLocationEvent(uri, assetType || LocationAssetType.Self, timestamp, description);\n const timestampEvent = timestamp ? { [M_TIMESTAMP.name]: timestamp } : {};\n return {\n msgtype: MsgType.Location,\n body: defaultedText,\n geo_uri: uri,\n [M_LOCATION.name]: {\n description,\n uri,\n },\n [M_ASSET.name]: {\n type: assetType || LocationAssetType.Self,\n },\n [M_TEXT.name]: defaultedText,\n ...timestampEvent,\n } as LegacyLocationEventContent & MLocationEventContent;\n};\n\n/**\n * Parse location event content and transform to\n * a backwards compatible modern m.location event format\n */\nexport const parseLocationEvent = (wireEventContent: LocationEventWireContent): MLocationEventContent => {\n const location = M_LOCATION.findIn(wireEventContent);\n const asset = M_ASSET.findIn(wireEventContent);\n const timestamp = M_TIMESTAMP.findIn(wireEventContent);\n const text = M_TEXT.findIn(wireEventContent);\n\n const geoUri = location?.uri ?? wireEventContent?.geo_uri;\n const description = location?.description;\n const assetType = asset?.type ?? LocationAssetType.Self;\n const fallbackText = text ?? wireEventContent.body;\n\n return makeLocationContent(fallbackText, geoUri, timestamp ?? undefined, description, assetType);\n};\n\n/**\n * Topic event helpers\n */\nexport type MakeTopicContent = (topic: string, htmlTopic?: string) => MRoomTopicEventContent;\n\nexport const makeTopicContent: MakeTopicContent = (topic, htmlTopic) => {\n const renderings = [{ body: topic, mimetype: \"text/plain\" }];\n if (isProvided(htmlTopic)) {\n renderings.push({ body: htmlTopic!, mimetype: \"text/html\" });\n }\n return { topic, [M_TOPIC.name]: renderings };\n};\n\nexport type TopicState = {\n text: string;\n html?: string;\n};\n\nexport const parseTopicContent = (content: MRoomTopicEventContent): TopicState => {\n const mtopic = M_TOPIC.findIn(content);\n if (!Array.isArray(mtopic)) {\n return { text: content.topic };\n }\n const text = mtopic?.find((r) => !isProvided(r.mimetype) || r.mimetype === \"text/plain\")?.body ?? content.topic;\n const html = mtopic?.find((r) => r.mimetype === \"text/html\")?.body;\n return { text, html };\n};\n\n/**\n * Beacon event helpers\n */\nexport type MakeBeaconInfoContent = (\n timeout: number,\n isLive?: boolean,\n description?: string,\n assetType?: LocationAssetType,\n timestamp?: number,\n) => MBeaconInfoEventContent;\n\nexport const makeBeaconInfoContent: MakeBeaconInfoContent = (timeout, isLive, description, assetType, timestamp) => ({\n description,\n timeout,\n live: isLive,\n [M_TIMESTAMP.name]: timestamp || Date.now(),\n [M_ASSET.name]: {\n type: assetType ?? LocationAssetType.Self,\n },\n});\n\nexport type BeaconInfoState = MBeaconInfoContent & {\n assetType?: LocationAssetType;\n timestamp?: number;\n};\n/**\n * Flatten beacon info event content\n */\nexport const parseBeaconInfoContent = (content: MBeaconInfoEventContent): BeaconInfoState => {\n const { description, timeout, live } = content;\n const timestamp = M_TIMESTAMP.findIn(content) ?? undefined;\n const asset = M_ASSET.findIn(content);\n\n return {\n description,\n timeout,\n live,\n assetType: asset?.type,\n timestamp,\n };\n};\n\nexport type MakeBeaconContent = (\n uri: string,\n timestamp: number,\n beaconInfoEventId: string,\n description?: string,\n) => MBeaconEventContent;\n\nexport const makeBeaconContent: MakeBeaconContent = (uri, timestamp, beaconInfoEventId, description) => ({\n [M_LOCATION.name]: {\n description,\n uri,\n },\n [M_TIMESTAMP.name]: timestamp,\n \"m.relates_to\": {\n rel_type: REFERENCE_RELATION.name,\n event_id: beaconInfoEventId,\n },\n});\n\nexport type BeaconLocationState = Omit & {\n uri?: string; // override from MLocationContent to allow optionals\n timestamp?: number;\n};\n\nexport const parseBeaconContent = (content: MBeaconEventContent): BeaconLocationState => {\n const location = M_LOCATION.findIn(content);\n const timestamp = M_TIMESTAMP.findIn(content) ?? undefined;\n\n return {\n description: location?.description,\n uri: location?.uri,\n timestamp,\n };\n};\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts deleted file mode 100644 index 3906bf4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts +++ /dev/null @@ -1,16 +0,0 @@ -/** - * Get the HTTP URL for an MXC URI. - * @param baseUrl - The base homeserver url which has a content repo. - * @param mxc - The mxc:// URI. - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDirectLinks - If true, return any non-mxc URLs - * directly. Fetching such URLs will leak information about the user to - * anyone they share a room with. If false, will return the emptry string - * for such URLs. - * @returns The complete URL to the content. - */ -export declare function getHttpUriForMxc(baseUrl: string, mxc?: string, width?: number, height?: number, resizeMethod?: string, allowDirectLinks?: boolean): string; -//# sourceMappingURL=content-repo.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts.map deleted file mode 100644 index 5573b03..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"content-repo.d.ts","sourceRoot":"","sources":["../src/content-repo.ts"],"names":[],"mappings":"AAkBA;;;;;;;;;;;;;GAaG;AACH,wBAAgB,gBAAgB,CAC5B,OAAO,EAAE,MAAM,EACf,GAAG,CAAC,EAAE,MAAM,EACZ,KAAK,CAAC,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,MAAM,EACf,YAAY,CAAC,EAAE,MAAM,EACrB,gBAAgB,UAAQ,GACzB,MAAM,CAuCR"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js deleted file mode 100644 index 613b90f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js +++ /dev/null @@ -1,77 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.getHttpUriForMxc = getHttpUriForMxc; -var utils = _interopRequireWildcard(require("./utils")); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Get the HTTP URL for an MXC URI. - * @param baseUrl - The base homeserver url which has a content repo. - * @param mxc - The mxc:// URI. - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDirectLinks - If true, return any non-mxc URLs - * directly. Fetching such URLs will leak information about the user to - * anyone they share a room with. If false, will return the emptry string - * for such URLs. - * @returns The complete URL to the content. - */ -function getHttpUriForMxc(baseUrl, mxc, width, height, resizeMethod, allowDirectLinks = false) { - if (typeof mxc !== "string" || !mxc) { - return ""; - } - if (mxc.indexOf("mxc://") !== 0) { - if (allowDirectLinks) { - return mxc; - } else { - return ""; - } - } - let serverAndMediaId = mxc.slice(6); // strips mxc:// - let prefix = "/_matrix/media/r0/download/"; - const params = {}; - if (width) { - params["width"] = Math.round(width).toString(); - } - if (height) { - params["height"] = Math.round(height).toString(); - } - if (resizeMethod) { - params["method"] = resizeMethod; - } - if (Object.keys(params).length > 0) { - // these are thumbnailing params so they probably want the - // thumbnailing API... - prefix = "/_matrix/media/r0/thumbnail/"; - } - const fragmentOffset = serverAndMediaId.indexOf("#"); - let fragment = ""; - if (fragmentOffset >= 0) { - fragment = serverAndMediaId.slice(fragmentOffset); - serverAndMediaId = serverAndMediaId.slice(0, fragmentOffset); - } - const urlParams = Object.keys(params).length === 0 ? "" : "?" + utils.encodeParams(params); - return baseUrl + prefix + serverAndMediaId + urlParams + fragment; -} -//# sourceMappingURL=content-repo.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js.map deleted file mode 100644 index 19aaff9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/content-repo.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"content-repo.js","names":["utils","_interopRequireWildcard","require","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","getHttpUriForMxc","baseUrl","mxc","width","height","resizeMethod","allowDirectLinks","indexOf","serverAndMediaId","slice","prefix","params","Math","round","toString","keys","length","fragmentOffset","fragment","urlParams","encodeParams"],"sources":["../src/content-repo.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as utils from \"./utils\";\n\n/**\n * Get the HTTP URL for an MXC URI.\n * @param baseUrl - The base homeserver url which has a content repo.\n * @param mxc - The mxc:// URI.\n * @param width - The desired width of the thumbnail.\n * @param height - The desired height of the thumbnail.\n * @param resizeMethod - The thumbnail resize method to use, either\n * \"crop\" or \"scale\".\n * @param allowDirectLinks - If true, return any non-mxc URLs\n * directly. Fetching such URLs will leak information about the user to\n * anyone they share a room with. If false, will return the emptry string\n * for such URLs.\n * @returns The complete URL to the content.\n */\nexport function getHttpUriForMxc(\n baseUrl: string,\n mxc?: string,\n width?: number,\n height?: number,\n resizeMethod?: string,\n allowDirectLinks = false,\n): string {\n if (typeof mxc !== \"string\" || !mxc) {\n return \"\";\n }\n if (mxc.indexOf(\"mxc://\") !== 0) {\n if (allowDirectLinks) {\n return mxc;\n } else {\n return \"\";\n }\n }\n let serverAndMediaId = mxc.slice(6); // strips mxc://\n let prefix = \"/_matrix/media/r0/download/\";\n const params: Record = {};\n\n if (width) {\n params[\"width\"] = Math.round(width).toString();\n }\n if (height) {\n params[\"height\"] = Math.round(height).toString();\n }\n if (resizeMethod) {\n params[\"method\"] = resizeMethod;\n }\n if (Object.keys(params).length > 0) {\n // these are thumbnailing params so they probably want the\n // thumbnailing API...\n prefix = \"/_matrix/media/r0/thumbnail/\";\n }\n\n const fragmentOffset = serverAndMediaId.indexOf(\"#\");\n let fragment = \"\";\n if (fragmentOffset >= 0) {\n fragment = serverAndMediaId.slice(fragmentOffset);\n serverAndMediaId = serverAndMediaId.slice(0, fragmentOffset);\n }\n\n const urlParams = Object.keys(params).length === 0 ? \"\" : \"?\" + utils.encodeParams(params);\n return baseUrl + prefix + serverAndMediaId + urlParams + fragment;\n}\n"],"mappings":";;;;;;AAgBA,IAAAA,KAAA,GAAAC,uBAAA,CAAAC,OAAA;AAAiC,SAAAC,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAH,wBAAAO,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAE,GAAA,CAAAL,GAAA,SAAAM,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAX,GAAA,QAAAW,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAd,GAAA,EAAAW,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAV,GAAA,EAAAW,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAX,GAAA,CAAAW,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAhB,GAAA,EAAAM,MAAA,YAAAA,MAAA;AAhBjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASW,gBAAgBA,CAC5BC,OAAe,EACfC,GAAY,EACZC,KAAc,EACdC,MAAe,EACfC,YAAqB,EACrBC,gBAAgB,GAAG,KAAK,EAClB;EACN,IAAI,OAAOJ,GAAG,KAAK,QAAQ,IAAI,CAACA,GAAG,EAAE;IACjC,OAAO,EAAE;EACb;EACA,IAAIA,GAAG,CAACK,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;IAC7B,IAAID,gBAAgB,EAAE;MAClB,OAAOJ,GAAG;IACd,CAAC,MAAM;MACH,OAAO,EAAE;IACb;EACJ;EACA,IAAIM,gBAAgB,GAAGN,GAAG,CAACO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;EACrC,IAAIC,MAAM,GAAG,6BAA6B;EAC1C,MAAMC,MAA8B,GAAG,CAAC,CAAC;EAEzC,IAAIR,KAAK,EAAE;IACPQ,MAAM,CAAC,OAAO,CAAC,GAAGC,IAAI,CAACC,KAAK,CAACV,KAAK,CAAC,CAACW,QAAQ,EAAE;EAClD;EACA,IAAIV,MAAM,EAAE;IACRO,MAAM,CAAC,QAAQ,CAAC,GAAGC,IAAI,CAACC,KAAK,CAACT,MAAM,CAAC,CAACU,QAAQ,EAAE;EACpD;EACA,IAAIT,YAAY,EAAE;IACdM,MAAM,CAAC,QAAQ,CAAC,GAAGN,YAAY;EACnC;EACA,IAAId,MAAM,CAACwB,IAAI,CAACJ,MAAM,CAAC,CAACK,MAAM,GAAG,CAAC,EAAE;IAChC;IACA;IACAN,MAAM,GAAG,8BAA8B;EAC3C;EAEA,MAAMO,cAAc,GAAGT,gBAAgB,CAACD,OAAO,CAAC,GAAG,CAAC;EACpD,IAAIW,QAAQ,GAAG,EAAE;EACjB,IAAID,cAAc,IAAI,CAAC,EAAE;IACrBC,QAAQ,GAAGV,gBAAgB,CAACC,KAAK,CAACQ,cAAc,CAAC;IACjDT,gBAAgB,GAAGA,gBAAgB,CAACC,KAAK,CAAC,CAAC,EAAEQ,cAAc,CAAC;EAChE;EAEA,MAAME,SAAS,GAAG5B,MAAM,CAACwB,IAAI,CAACJ,MAAM,CAAC,CAACK,MAAM,KAAK,CAAC,GAAG,EAAE,GAAG,GAAG,GAAGzC,KAAK,CAAC6C,YAAY,CAACT,MAAM,CAAC;EAC1F,OAAOV,OAAO,GAAGS,MAAM,GAAGF,gBAAgB,GAAGW,SAAS,GAAGD,QAAQ;AACrE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts deleted file mode 100644 index 4822827..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts +++ /dev/null @@ -1,55 +0,0 @@ -import type { IMegolmSessionData } from "./@types/crypto"; -import { Room } from "./models/room"; -/** - * Public interface to the cryptography parts of the js-sdk - * - * @remarks Currently, this is a work-in-progress. In time, more methods will be added here. - */ -export interface CryptoApi { - /** - * Global override for whether the client should ever send encrypted - * messages to unverified devices. This provides the default for rooms which - * do not specify a value. - * - * If true, all unverified devices will be blacklisted by default - */ - globalBlacklistUnverifiedDevices: boolean; - /** - * Checks if the user has previously published cross-signing keys - * - * This means downloading the devicelist for the user and checking if the list includes - * the cross-signing pseudo-device. - * - * @returns true if the user has previously published cross-signing keys - */ - userHasCrossSigningKeys(): Promise; - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * - * @param room - the room the event is in - */ - prepareToEncrypt(room: Room): void; - /** - * Discard any existing megolm session for the given room. - * - * This will ensure that a new session is created on the next call to {@link prepareToEncrypt}, - * or the next time a message is sent. - * - * This should not normally be necessary: it should only be used as a debugging tool if there has been a - * problem with encryption. - * - * @param roomId - the room to discard sessions for - */ - forceDiscardSession(roomId: string): Promise; - /** - * Get a list containing all of the room keys - * - * This should be encrypted before returning it to the user. - * - * @returns a promise which resolves to a list of - * session export objects - */ - exportRoomKeys(): Promise; -} -//# sourceMappingURL=crypto-api.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts.map deleted file mode 100644 index c94de49..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"crypto-api.d.ts","sourceRoot":"","sources":["../src/crypto-api.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAErC;;;;GAIG;AACH,MAAM,WAAW,SAAS;IACtB;;;;;;OAMG;IACH,gCAAgC,EAAE,OAAO,CAAC;IAE1C;;;;;;;OAOG;IACH,uBAAuB,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAE5C;;;;;OAKG;IACH,gBAAgB,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,CAAC;IAEnC;;;;;;;;;;OAUG;IACH,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEnD;;;;;;;OAOG;IACH,cAAc,IAAI,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAAC;CACnD"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js deleted file mode 100644 index 2b800b4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=crypto-api.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js.map deleted file mode 100644 index 098c8b7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto-api.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"crypto-api.js","names":[],"sources":["../src/crypto-api.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport type { IMegolmSessionData } from \"./@types/crypto\";\nimport { Room } from \"./models/room\";\n\n/**\n * Public interface to the cryptography parts of the js-sdk\n *\n * @remarks Currently, this is a work-in-progress. In time, more methods will be added here.\n */\nexport interface CryptoApi {\n /**\n * Global override for whether the client should ever send encrypted\n * messages to unverified devices. This provides the default for rooms which\n * do not specify a value.\n *\n * If true, all unverified devices will be blacklisted by default\n */\n globalBlacklistUnverifiedDevices: boolean;\n\n /**\n * Checks if the user has previously published cross-signing keys\n *\n * This means downloading the devicelist for the user and checking if the list includes\n * the cross-signing pseudo-device.\n *\n * @returns true if the user has previously published cross-signing keys\n */\n userHasCrossSigningKeys(): Promise;\n\n /**\n * Perform any background tasks that can be done before a message is ready to\n * send, in order to speed up sending of the message.\n *\n * @param room - the room the event is in\n */\n prepareToEncrypt(room: Room): void;\n\n /**\n * Discard any existing megolm session for the given room.\n *\n * This will ensure that a new session is created on the next call to {@link prepareToEncrypt},\n * or the next time a message is sent.\n *\n * This should not normally be necessary: it should only be used as a debugging tool if there has been a\n * problem with encryption.\n *\n * @param roomId - the room to discard sessions for\n */\n forceDiscardSession(roomId: string): Promise;\n\n /**\n * Get a list containing all of the room keys\n *\n * This should be encrypted before returning it to the user.\n *\n * @returns a promise which resolves to a list of\n * session export objects\n */\n exportRoomKeys(): Promise;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts deleted file mode 100644 index d9d17d9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts +++ /dev/null @@ -1,214 +0,0 @@ -/** - * Cross signing methods - */ -import { PkSigning } from "@matrix-org/olm"; -import { DeviceInfo } from "./deviceinfo"; -import { SecretStorage } from "./SecretStorage"; -import { ICrossSigningKey, ISignedKey, MatrixClient } from "../client"; -import { OlmDevice } from "./OlmDevice"; -import { ICryptoCallbacks } from "."; -import { ISignatures } from "../@types/signed"; -import { CryptoStore } from "./store/base"; -export interface ICacheCallbacks { - getCrossSigningKeyCache?(type: string, expectedPublicKey?: string): Promise; - storeCrossSigningKeyCache?(type: string, key?: Uint8Array): Promise; -} -export interface ICrossSigningInfo { - keys: Record; - firstUse: boolean; - crossSigningVerifiedBefore: boolean; -} -export declare class CrossSigningInfo { - readonly userId: string; - private callbacks; - private cacheCallbacks; - keys: Record; - firstUse: boolean; - private crossSigningVerifiedBefore; - /** - * Information about a user's cross-signing keys - * - * @param userId - the user that the information is about - * @param callbacks - Callbacks used to interact with the app - * Requires getCrossSigningKey and saveCrossSigningKeys - * @param cacheCallbacks - Callbacks used to interact with the cache - */ - constructor(userId: string, callbacks?: ICryptoCallbacks, cacheCallbacks?: ICacheCallbacks); - static fromStorage(obj: ICrossSigningInfo, userId: string): CrossSigningInfo; - toStorage(): ICrossSigningInfo; - /** - * Calls the app callback to ask for a private key - * - * @param type - The key type ("master", "self_signing", or "user_signing") - * @param expectedPubkey - The matching public key or undefined to use - * the stored public key for the given key type. - * @returns An array with [ public key, Olm.PkSigning ] - */ - getCrossSigningKey(type: string, expectedPubkey?: string): Promise<[string, PkSigning]>; - /** - * Check whether the private keys exist in secret storage. - * XXX: This could be static, be we often seem to have an instance when we - * want to know this anyway... - * - * @param secretStorage - The secret store using account data - * @returns map of key name to key info the secret is encrypted - * with, or null if it is not present or not encrypted with a trusted - * key - */ - isStoredInSecretStorage(secretStorage: SecretStorage): Promise | null>; - /** - * Store private keys in secret storage for use by other devices. This is - * typically called in conjunction with the creation of new cross-signing - * keys. - * - * @param keys - The keys to store - * @param secretStorage - The secret store using account data - */ - static storeInSecretStorage(keys: Map, secretStorage: SecretStorage): Promise; - /** - * Get private keys from secret storage created by some other device. This - * also passes the private keys to the app-specific callback. - * - * @param type - The type of key to get. One of "master", - * "self_signing", or "user_signing". - * @param secretStorage - The secret store using account data - * @returns The private key - */ - static getFromSecretStorage(type: string, secretStorage: SecretStorage): Promise; - /** - * Check whether the private keys exist in the local key cache. - * - * @param type - The type of key to get. One of "master", - * "self_signing", or "user_signing". Optional, will check all by default. - * @returns True if all keys are stored in the local cache. - */ - isStoredInKeyCache(type?: string): Promise; - /** - * Get cross-signing private keys from the local cache. - * - * @returns A map from key type (string) to private key (Uint8Array) - */ - getCrossSigningKeysFromCache(): Promise>; - /** - * Get the ID used to identify the user. This can also be used to test for - * the existence of a given key type. - * - * @param type - The type of key to get the ID of. One of "master", - * "self_signing", or "user_signing". Defaults to "master". - * - * @returns the ID - */ - getId(type?: string): string | null; - /** - * Create new cross-signing keys for the given key types. The public keys - * will be held in this class, while the private keys are passed off to the - * `saveCrossSigningKeys` application callback. - * - * @param level - The key types to reset - */ - resetKeys(level?: CrossSigningLevel): Promise; - /** - * unsets the keys, used when another session has reset the keys, to disable cross-signing - */ - clearKeys(): void; - setKeys(keys: Record): void; - updateCrossSigningVerifiedBefore(isCrossSigningVerified: boolean): void; - signObject(data: T, type: string): Promise; - signUser(key: CrossSigningInfo): Promise; - signDevice(userId: string, device: DeviceInfo): Promise; - /** - * Check whether a given user is trusted. - * - * @param userCrossSigning - Cross signing info for user - * - * @returns - */ - checkUserTrust(userCrossSigning: CrossSigningInfo): UserTrustLevel; - /** - * Check whether a given device is trusted. - * - * @param userCrossSigning - Cross signing info for user - * @param device - The device to check - * @param localTrust - Whether the device is trusted locally - * @param trustCrossSignedDevices - Whether we trust cross signed devices - * - * @returns - */ - checkDeviceTrust(userCrossSigning: CrossSigningInfo, device: DeviceInfo, localTrust: boolean, trustCrossSignedDevices: boolean): DeviceTrustLevel; - /** - * @returns Cache callbacks - */ - getCacheCallbacks(): ICacheCallbacks; -} -export declare enum CrossSigningLevel { - MASTER = 4, - USER_SIGNING = 2, - SELF_SIGNING = 1 -} -/** - * Represents the ways in which we trust a user - */ -export declare class UserTrustLevel { - private readonly crossSigningVerified; - private readonly crossSigningVerifiedBefore; - private readonly tofu; - constructor(crossSigningVerified: boolean, crossSigningVerifiedBefore: boolean, tofu: boolean); - /** - * @returns true if this user is verified via any means - */ - isVerified(): boolean; - /** - * @returns true if this user is verified via cross signing - */ - isCrossSigningVerified(): boolean; - /** - * @returns true if we ever verified this user before (at least for - * the history of verifications observed by this device). - */ - wasCrossSigningVerified(): boolean; - /** - * @returns true if this user's key is trusted on first use - */ - isTofu(): boolean; -} -/** - * Represents the ways in which we trust a device - */ -export declare class DeviceTrustLevel { - readonly crossSigningVerified: boolean; - readonly tofu: boolean; - private readonly localVerified; - private readonly trustCrossSignedDevices; - constructor(crossSigningVerified: boolean, tofu: boolean, localVerified: boolean, trustCrossSignedDevices: boolean); - static fromUserTrustLevel(userTrustLevel: UserTrustLevel, localVerified: boolean, trustCrossSignedDevices: boolean): DeviceTrustLevel; - /** - * @returns true if this device is verified via any means - */ - isVerified(): boolean; - /** - * @returns true if this device is verified via cross signing - */ - isCrossSigningVerified(): boolean; - /** - * @returns true if this device is verified locally - */ - isLocallyVerified(): boolean; - /** - * @returns true if this device is trusted from a user's key - * that is trusted on first use - */ - isTofu(): boolean; -} -export declare function createCryptoStoreCacheCallbacks(store: CryptoStore, olmDevice: OlmDevice): ICacheCallbacks; -export type KeysDuringVerification = [[string, PkSigning], [string, PkSigning], [string, PkSigning], void]; -/** - * Request cross-signing keys from another device during verification. - * - * @param baseApis - base Matrix API interface - * @param userId - The user ID being verified - * @param deviceId - The device ID being verified - */ -export declare function requestKeysDuringVerification(baseApis: MatrixClient, userId: string, deviceId: string): Promise; -//# sourceMappingURL=CrossSigning.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts.map deleted file mode 100644 index 9656a5f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"CrossSigning.d.ts","sourceRoot":"","sources":["../../src/crypto/CrossSigning.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js deleted file mode 100644 index 21d9f90..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js +++ /dev/null @@ -1,711 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UserTrustLevel = exports.DeviceTrustLevel = exports.CrossSigningLevel = exports.CrossSigningInfo = void 0; -exports.createCryptoStoreCacheCallbacks = createCryptoStoreCacheCallbacks; -exports.requestKeysDuringVerification = requestKeysDuringVerification; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _olmlib = require("./olmlib"); -var _logger = require("../logger"); -var _indexeddbCryptoStore = require("../crypto/store/indexeddb-crypto-store"); -var _aes = require("./aes"); -/* -Copyright 2019 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Cross signing methods - */ - -const KEY_REQUEST_TIMEOUT_MS = 1000 * 60; -function publicKeyFromKeyInfo(keyInfo) { - // `keys` is an object with { [`ed25519:${pubKey}`]: pubKey } - // We assume only a single key, and we want the bare form without type - // prefix, so we select the values. - return Object.values(keyInfo.keys)[0]; -} -class CrossSigningInfo { - // This tracks whether we've ever verified this user with any identity. - // When you verify a user, any devices online at the time that receive - // the verifying signature via the homeserver will latch this to true - // and can use it in the future to detect cases where the user has - // become unverified later for any reason. - - /** - * Information about a user's cross-signing keys - * - * @param userId - the user that the information is about - * @param callbacks - Callbacks used to interact with the app - * Requires getCrossSigningKey and saveCrossSigningKeys - * @param cacheCallbacks - Callbacks used to interact with the cache - */ - constructor(userId, callbacks = {}, cacheCallbacks = {}) { - this.userId = userId; - this.callbacks = callbacks; - this.cacheCallbacks = cacheCallbacks; - (0, _defineProperty2.default)(this, "keys", {}); - (0, _defineProperty2.default)(this, "firstUse", true); - (0, _defineProperty2.default)(this, "crossSigningVerifiedBefore", false); - } - static fromStorage(obj, userId) { - const res = new CrossSigningInfo(userId); - for (const prop in obj) { - if (obj.hasOwnProperty(prop)) { - // @ts-ignore - ts doesn't like this and nor should we - res[prop] = obj[prop]; - } - } - return res; - } - toStorage() { - return { - keys: this.keys, - firstUse: this.firstUse, - crossSigningVerifiedBefore: this.crossSigningVerifiedBefore - }; - } - - /** - * Calls the app callback to ask for a private key - * - * @param type - The key type ("master", "self_signing", or "user_signing") - * @param expectedPubkey - The matching public key or undefined to use - * the stored public key for the given key type. - * @returns An array with [ public key, Olm.PkSigning ] - */ - async getCrossSigningKey(type, expectedPubkey) { - const shouldCache = ["master", "self_signing", "user_signing"].indexOf(type) >= 0; - if (!this.callbacks.getCrossSigningKey) { - throw new Error("No getCrossSigningKey callback supplied"); - } - if (expectedPubkey === undefined) { - expectedPubkey = this.getId(type); - } - function validateKey(key) { - if (!key) return; - const signing = new global.Olm.PkSigning(); - const gotPubkey = signing.init_with_seed(key); - if (gotPubkey === expectedPubkey) { - return [gotPubkey, signing]; - } - signing.free(); - } - let privkey = null; - if (this.cacheCallbacks.getCrossSigningKeyCache && shouldCache) { - privkey = await this.cacheCallbacks.getCrossSigningKeyCache(type, expectedPubkey); - } - const cacheresult = validateKey(privkey); - if (cacheresult) { - return cacheresult; - } - privkey = await this.callbacks.getCrossSigningKey(type, expectedPubkey); - const result = validateKey(privkey); - if (result) { - if (this.cacheCallbacks.storeCrossSigningKeyCache && shouldCache) { - await this.cacheCallbacks.storeCrossSigningKeyCache(type, privkey); - } - return result; - } - - /* No keysource even returned a key */ - if (!privkey) { - throw new Error("getCrossSigningKey callback for " + type + " returned falsey"); - } - - /* We got some keys from the keysource, but none of them were valid */ - throw new Error("Key type " + type + " from getCrossSigningKey callback did not match"); - } - - /** - * Check whether the private keys exist in secret storage. - * XXX: This could be static, be we often seem to have an instance when we - * want to know this anyway... - * - * @param secretStorage - The secret store using account data - * @returns map of key name to key info the secret is encrypted - * with, or null if it is not present or not encrypted with a trusted - * key - */ - async isStoredInSecretStorage(secretStorage) { - // check what SSSS keys have encrypted the master key (if any) - const stored = (await secretStorage.isStored("m.cross_signing.master")) || {}; - // then check which of those SSSS keys have also encrypted the SSK and USK - function intersect(s) { - for (const k of Object.keys(stored)) { - if (!s[k]) { - delete stored[k]; - } - } - } - for (const type of ["self_signing", "user_signing"]) { - intersect((await secretStorage.isStored(`m.cross_signing.${type}`)) || {}); - } - return Object.keys(stored).length ? stored : null; - } - - /** - * Store private keys in secret storage for use by other devices. This is - * typically called in conjunction with the creation of new cross-signing - * keys. - * - * @param keys - The keys to store - * @param secretStorage - The secret store using account data - */ - static async storeInSecretStorage(keys, secretStorage) { - for (const [type, privateKey] of keys) { - const encodedKey = (0, _olmlib.encodeBase64)(privateKey); - await secretStorage.store(`m.cross_signing.${type}`, encodedKey); - } - } - - /** - * Get private keys from secret storage created by some other device. This - * also passes the private keys to the app-specific callback. - * - * @param type - The type of key to get. One of "master", - * "self_signing", or "user_signing". - * @param secretStorage - The secret store using account data - * @returns The private key - */ - static async getFromSecretStorage(type, secretStorage) { - const encodedKey = await secretStorage.get(`m.cross_signing.${type}`); - if (!encodedKey) { - return null; - } - return (0, _olmlib.decodeBase64)(encodedKey); - } - - /** - * Check whether the private keys exist in the local key cache. - * - * @param type - The type of key to get. One of "master", - * "self_signing", or "user_signing". Optional, will check all by default. - * @returns True if all keys are stored in the local cache. - */ - async isStoredInKeyCache(type) { - const cacheCallbacks = this.cacheCallbacks; - if (!cacheCallbacks) return false; - const types = type ? [type] : ["master", "self_signing", "user_signing"]; - for (const t of types) { - var _cacheCallbacks$getCr; - if (!(await ((_cacheCallbacks$getCr = cacheCallbacks.getCrossSigningKeyCache) === null || _cacheCallbacks$getCr === void 0 ? void 0 : _cacheCallbacks$getCr.call(cacheCallbacks, t)))) { - return false; - } - } - return true; - } - - /** - * Get cross-signing private keys from the local cache. - * - * @returns A map from key type (string) to private key (Uint8Array) - */ - async getCrossSigningKeysFromCache() { - const keys = new Map(); - const cacheCallbacks = this.cacheCallbacks; - if (!cacheCallbacks) return keys; - for (const type of ["master", "self_signing", "user_signing"]) { - var _cacheCallbacks$getCr2; - const privKey = await ((_cacheCallbacks$getCr2 = cacheCallbacks.getCrossSigningKeyCache) === null || _cacheCallbacks$getCr2 === void 0 ? void 0 : _cacheCallbacks$getCr2.call(cacheCallbacks, type)); - if (!privKey) { - continue; - } - keys.set(type, privKey); - } - return keys; - } - - /** - * Get the ID used to identify the user. This can also be used to test for - * the existence of a given key type. - * - * @param type - The type of key to get the ID of. One of "master", - * "self_signing", or "user_signing". Defaults to "master". - * - * @returns the ID - */ - getId(type = "master") { - if (!this.keys[type]) return null; - const keyInfo = this.keys[type]; - return publicKeyFromKeyInfo(keyInfo); - } - - /** - * Create new cross-signing keys for the given key types. The public keys - * will be held in this class, while the private keys are passed off to the - * `saveCrossSigningKeys` application callback. - * - * @param level - The key types to reset - */ - async resetKeys(level) { - if (!this.callbacks.saveCrossSigningKeys) { - throw new Error("No saveCrossSigningKeys callback supplied"); - } - - // If we're resetting the master key, we reset all keys - if (level === undefined || level & CrossSigningLevel.MASTER || !this.keys.master) { - level = CrossSigningLevel.MASTER | CrossSigningLevel.USER_SIGNING | CrossSigningLevel.SELF_SIGNING; - } else if (level === 0) { - return; - } - const privateKeys = {}; - const keys = {}; - let masterSigning; - let masterPub; - try { - if (level & CrossSigningLevel.MASTER) { - masterSigning = new global.Olm.PkSigning(); - privateKeys.master = masterSigning.generate_seed(); - masterPub = masterSigning.init_with_seed(privateKeys.master); - keys.master = { - user_id: this.userId, - usage: ["master"], - keys: { - ["ed25519:" + masterPub]: masterPub - } - }; - } else { - [masterPub, masterSigning] = await this.getCrossSigningKey("master"); - } - if (level & CrossSigningLevel.SELF_SIGNING) { - const sskSigning = new global.Olm.PkSigning(); - try { - privateKeys.self_signing = sskSigning.generate_seed(); - const sskPub = sskSigning.init_with_seed(privateKeys.self_signing); - keys.self_signing = { - user_id: this.userId, - usage: ["self_signing"], - keys: { - ["ed25519:" + sskPub]: sskPub - } - }; - (0, _olmlib.pkSign)(keys.self_signing, masterSigning, this.userId, masterPub); - } finally { - sskSigning.free(); - } - } - if (level & CrossSigningLevel.USER_SIGNING) { - const uskSigning = new global.Olm.PkSigning(); - try { - privateKeys.user_signing = uskSigning.generate_seed(); - const uskPub = uskSigning.init_with_seed(privateKeys.user_signing); - keys.user_signing = { - user_id: this.userId, - usage: ["user_signing"], - keys: { - ["ed25519:" + uskPub]: uskPub - } - }; - (0, _olmlib.pkSign)(keys.user_signing, masterSigning, this.userId, masterPub); - } finally { - uskSigning.free(); - } - } - Object.assign(this.keys, keys); - this.callbacks.saveCrossSigningKeys(privateKeys); - } finally { - if (masterSigning) { - masterSigning.free(); - } - } - } - - /** - * unsets the keys, used when another session has reset the keys, to disable cross-signing - */ - clearKeys() { - this.keys = {}; - } - setKeys(keys) { - const signingKeys = {}; - if (keys.master) { - if (keys.master.user_id !== this.userId) { - const error = "Mismatched user ID " + keys.master.user_id + " in master key from " + this.userId; - _logger.logger.error(error); - throw new Error(error); - } - if (!this.keys.master) { - // this is the first key we've seen, so first-use is true - this.firstUse = true; - } else if (publicKeyFromKeyInfo(keys.master) !== this.getId()) { - // this is a different key, so first-use is false - this.firstUse = false; - } // otherwise, same key, so no change - signingKeys.master = keys.master; - } else if (this.keys.master) { - signingKeys.master = this.keys.master; - } else { - throw new Error("Tried to set cross-signing keys without a master key"); - } - const masterKey = publicKeyFromKeyInfo(signingKeys.master); - - // verify signatures - if (keys.user_signing) { - if (keys.user_signing.user_id !== this.userId) { - const error = "Mismatched user ID " + keys.master.user_id + " in user_signing key from " + this.userId; - _logger.logger.error(error); - throw new Error(error); - } - try { - (0, _olmlib.pkVerify)(keys.user_signing, masterKey, this.userId); - } catch (e) { - _logger.logger.error("invalid signature on user-signing key"); - // FIXME: what do we want to do here? - throw e; - } - } - if (keys.self_signing) { - if (keys.self_signing.user_id !== this.userId) { - const error = "Mismatched user ID " + keys.master.user_id + " in self_signing key from " + this.userId; - _logger.logger.error(error); - throw new Error(error); - } - try { - (0, _olmlib.pkVerify)(keys.self_signing, masterKey, this.userId); - } catch (e) { - _logger.logger.error("invalid signature on self-signing key"); - // FIXME: what do we want to do here? - throw e; - } - } - - // if everything checks out, then save the keys - if (keys.master) { - this.keys.master = keys.master; - // if the master key is set, then the old self-signing and user-signing keys are obsolete - delete this.keys["self_signing"]; - delete this.keys["user_signing"]; - } - if (keys.self_signing) { - this.keys.self_signing = keys.self_signing; - } - if (keys.user_signing) { - this.keys.user_signing = keys.user_signing; - } - } - updateCrossSigningVerifiedBefore(isCrossSigningVerified) { - // It is critical that this value latches forward from false to true but - // never back to false to avoid a downgrade attack. - if (!this.crossSigningVerifiedBefore && isCrossSigningVerified) { - this.crossSigningVerifiedBefore = true; - } - } - async signObject(data, type) { - if (!this.keys[type]) { - throw new Error("Attempted to sign with " + type + " key but no such key present"); - } - const [pubkey, signing] = await this.getCrossSigningKey(type); - try { - (0, _olmlib.pkSign)(data, signing, this.userId, pubkey); - return data; - } finally { - signing.free(); - } - } - async signUser(key) { - if (!this.keys.user_signing) { - _logger.logger.info("No user signing key: not signing user"); - return; - } - return this.signObject(key.keys.master, "user_signing"); - } - async signDevice(userId, device) { - if (userId !== this.userId) { - throw new Error(`Trying to sign ${userId}'s device; can only sign our own device`); - } - if (!this.keys.self_signing) { - _logger.logger.info("No self signing key: not signing device"); - return; - } - return this.signObject({ - algorithms: device.algorithms, - keys: device.keys, - device_id: device.deviceId, - user_id: userId - }, "self_signing"); - } - - /** - * Check whether a given user is trusted. - * - * @param userCrossSigning - Cross signing info for user - * - * @returns - */ - checkUserTrust(userCrossSigning) { - // if we're checking our own key, then it's trusted if the master key - // and self-signing key match - if (this.userId === userCrossSigning.userId && this.getId() && this.getId() === userCrossSigning.getId() && this.getId("self_signing") && this.getId("self_signing") === userCrossSigning.getId("self_signing")) { - return new UserTrustLevel(true, true, this.firstUse); - } - if (!this.keys.user_signing) { - // If there's no user signing key, they can't possibly be verified. - // They may be TOFU trusted though. - return new UserTrustLevel(false, false, userCrossSigning.firstUse); - } - let userTrusted; - const userMaster = userCrossSigning.keys.master; - const uskId = this.getId("user_signing"); - try { - (0, _olmlib.pkVerify)(userMaster, uskId, this.userId); - userTrusted = true; - } catch (e) { - userTrusted = false; - } - return new UserTrustLevel(userTrusted, userCrossSigning.crossSigningVerifiedBefore, userCrossSigning.firstUse); - } - - /** - * Check whether a given device is trusted. - * - * @param userCrossSigning - Cross signing info for user - * @param device - The device to check - * @param localTrust - Whether the device is trusted locally - * @param trustCrossSignedDevices - Whether we trust cross signed devices - * - * @returns - */ - checkDeviceTrust(userCrossSigning, device, localTrust, trustCrossSignedDevices) { - const userTrust = this.checkUserTrust(userCrossSigning); - const userSSK = userCrossSigning.keys.self_signing; - if (!userSSK) { - // if the user has no self-signing key then we cannot make any - // trust assertions about this device from cross-signing - return new DeviceTrustLevel(false, false, localTrust, trustCrossSignedDevices); - } - const deviceObj = deviceToObject(device, userCrossSigning.userId); - try { - // if we can verify the user's SSK from their master key... - (0, _olmlib.pkVerify)(userSSK, userCrossSigning.getId(), userCrossSigning.userId); - // ...and this device's key from their SSK... - (0, _olmlib.pkVerify)(deviceObj, publicKeyFromKeyInfo(userSSK), userCrossSigning.userId); - // ...then we trust this device as much as far as we trust the user - return DeviceTrustLevel.fromUserTrustLevel(userTrust, localTrust, trustCrossSignedDevices); - } catch (e) { - return new DeviceTrustLevel(false, false, localTrust, trustCrossSignedDevices); - } - } - - /** - * @returns Cache callbacks - */ - getCacheCallbacks() { - return this.cacheCallbacks; - } -} -exports.CrossSigningInfo = CrossSigningInfo; -function deviceToObject(device, userId) { - return { - algorithms: device.algorithms, - keys: device.keys, - device_id: device.deviceId, - user_id: userId, - signatures: device.signatures - }; -} -let CrossSigningLevel; -/** - * Represents the ways in which we trust a user - */ -exports.CrossSigningLevel = CrossSigningLevel; -(function (CrossSigningLevel) { - CrossSigningLevel[CrossSigningLevel["MASTER"] = 4] = "MASTER"; - CrossSigningLevel[CrossSigningLevel["USER_SIGNING"] = 2] = "USER_SIGNING"; - CrossSigningLevel[CrossSigningLevel["SELF_SIGNING"] = 1] = "SELF_SIGNING"; -})(CrossSigningLevel || (exports.CrossSigningLevel = CrossSigningLevel = {})); -class UserTrustLevel { - constructor(crossSigningVerified, crossSigningVerifiedBefore, tofu) { - this.crossSigningVerified = crossSigningVerified; - this.crossSigningVerifiedBefore = crossSigningVerifiedBefore; - this.tofu = tofu; - } - - /** - * @returns true if this user is verified via any means - */ - isVerified() { - return this.isCrossSigningVerified(); - } - - /** - * @returns true if this user is verified via cross signing - */ - isCrossSigningVerified() { - return this.crossSigningVerified; - } - - /** - * @returns true if we ever verified this user before (at least for - * the history of verifications observed by this device). - */ - wasCrossSigningVerified() { - return this.crossSigningVerifiedBefore; - } - - /** - * @returns true if this user's key is trusted on first use - */ - isTofu() { - return this.tofu; - } -} - -/** - * Represents the ways in which we trust a device - */ -exports.UserTrustLevel = UserTrustLevel; -class DeviceTrustLevel { - constructor(crossSigningVerified, tofu, localVerified, trustCrossSignedDevices) { - this.crossSigningVerified = crossSigningVerified; - this.tofu = tofu; - this.localVerified = localVerified; - this.trustCrossSignedDevices = trustCrossSignedDevices; - } - static fromUserTrustLevel(userTrustLevel, localVerified, trustCrossSignedDevices) { - return new DeviceTrustLevel(userTrustLevel.isCrossSigningVerified(), userTrustLevel.isTofu(), localVerified, trustCrossSignedDevices); - } - - /** - * @returns true if this device is verified via any means - */ - isVerified() { - return Boolean(this.isLocallyVerified() || this.trustCrossSignedDevices && this.isCrossSigningVerified()); - } - - /** - * @returns true if this device is verified via cross signing - */ - isCrossSigningVerified() { - return this.crossSigningVerified; - } - - /** - * @returns true if this device is verified locally - */ - isLocallyVerified() { - return this.localVerified; - } - - /** - * @returns true if this device is trusted from a user's key - * that is trusted on first use - */ - isTofu() { - return this.tofu; - } -} -exports.DeviceTrustLevel = DeviceTrustLevel; -function createCryptoStoreCacheCallbacks(store, olmDevice) { - return { - getCrossSigningKeyCache: async function (type, _expectedPublicKey) { - const key = await new Promise(resolve => { - return store.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - store.getSecretStorePrivateKey(txn, resolve, type); - }); - }); - if (key && key.ciphertext) { - const pickleKey = Buffer.from(olmDevice.pickleKey); - const decrypted = await (0, _aes.decryptAES)(key, pickleKey, type); - return (0, _olmlib.decodeBase64)(decrypted); - } else { - return key; - } - }, - storeCrossSigningKeyCache: async function (type, key) { - if (!(key instanceof Uint8Array)) { - throw new Error(`storeCrossSigningKeyCache expects Uint8Array, got ${key}`); - } - const pickleKey = Buffer.from(olmDevice.pickleKey); - const encryptedKey = await (0, _aes.encryptAES)((0, _olmlib.encodeBase64)(key), pickleKey, type); - return store.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - store.storeSecretStorePrivateKey(txn, type, encryptedKey); - }); - } - }; -} -/** - * Request cross-signing keys from another device during verification. - * - * @param baseApis - base Matrix API interface - * @param userId - The user ID being verified - * @param deviceId - The device ID being verified - */ -async function requestKeysDuringVerification(baseApis, userId, deviceId) { - // If this is a self-verification, ask the other party for keys - if (baseApis.getUserId() !== userId) { - return; - } - _logger.logger.log("Cross-signing: Self-verification done; requesting keys"); - // This happens asynchronously, and we're not concerned about waiting for - // it. We return here in order to test. - return new Promise((resolve, reject) => { - const client = baseApis; - const original = client.crypto.crossSigningInfo; - - // We already have all of the infrastructure we need to validate and - // cache cross-signing keys, so instead of replicating that, here we set - // up callbacks that request them from the other device and call - // CrossSigningInfo.getCrossSigningKey() to validate/cache - const crossSigning = new CrossSigningInfo(original.userId, { - getCrossSigningKey: async type => { - _logger.logger.debug("Cross-signing: requesting secret", type, deviceId); - const { - promise - } = client.requestSecret(`m.cross_signing.${type}`, [deviceId]); - const result = await promise; - const decoded = (0, _olmlib.decodeBase64)(result); - return Uint8Array.from(decoded); - } - }, original.getCacheCallbacks()); - crossSigning.keys = original.keys; - - // XXX: get all keys out if we get one key out - // https://github.com/vector-im/element-web/issues/12604 - // then change here to reject on the timeout - // Requests can be ignored, so don't wait around forever - const timeout = new Promise(resolve => { - setTimeout(resolve, KEY_REQUEST_TIMEOUT_MS, new Error("Timeout")); - }); - - // also request and cache the key backup key - const backupKeyPromise = (async () => { - const cachedKey = await client.crypto.getSessionBackupPrivateKey(); - if (!cachedKey) { - _logger.logger.info("No cached backup key found. Requesting..."); - const secretReq = client.requestSecret("m.megolm_backup.v1", [deviceId]); - const base64Key = await secretReq.promise; - _logger.logger.info("Got key backup key, decoding..."); - const decodedKey = (0, _olmlib.decodeBase64)(base64Key); - _logger.logger.info("Decoded backup key, storing..."); - await client.crypto.storeSessionBackupPrivateKey(Uint8Array.from(decodedKey)); - _logger.logger.info("Backup key stored. Starting backup restore..."); - const backupInfo = await client.getKeyBackupVersion(); - // no need to await for this - just let it go in the bg - client.restoreKeyBackupWithCache(undefined, undefined, backupInfo).then(() => { - _logger.logger.info("Backup restored."); - }); - } - })(); - - // We call getCrossSigningKey() for its side-effects - return Promise.race([Promise.all([crossSigning.getCrossSigningKey("master"), crossSigning.getCrossSigningKey("self_signing"), crossSigning.getCrossSigningKey("user_signing"), backupKeyPromise]), timeout]).then(resolve, reject); - }).catch(e => { - _logger.logger.warn("Cross-signing: failure while requesting keys:", e); - }); -} -//# sourceMappingURL=CrossSigning.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js.map deleted file mode 100644 index 8a07294..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/CrossSigning.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"CrossSigning.js","names":["_olmlib","require","_logger","_indexeddbCryptoStore","_aes","KEY_REQUEST_TIMEOUT_MS","publicKeyFromKeyInfo","keyInfo","Object","values","keys","CrossSigningInfo","constructor","userId","callbacks","cacheCallbacks","_defineProperty2","default","fromStorage","obj","res","prop","hasOwnProperty","toStorage","firstUse","crossSigningVerifiedBefore","getCrossSigningKey","type","expectedPubkey","shouldCache","indexOf","Error","undefined","getId","validateKey","key","signing","global","Olm","PkSigning","gotPubkey","init_with_seed","free","privkey","getCrossSigningKeyCache","cacheresult","result","storeCrossSigningKeyCache","isStoredInSecretStorage","secretStorage","stored","isStored","intersect","s","k","length","storeInSecretStorage","privateKey","encodedKey","encodeBase64","store","getFromSecretStorage","get","decodeBase64","isStoredInKeyCache","types","t","_cacheCallbacks$getCr","call","getCrossSigningKeysFromCache","Map","_cacheCallbacks$getCr2","privKey","set","resetKeys","level","saveCrossSigningKeys","CrossSigningLevel","MASTER","master","USER_SIGNING","SELF_SIGNING","privateKeys","masterSigning","masterPub","generate_seed","user_id","usage","sskSigning","self_signing","sskPub","pkSign","uskSigning","user_signing","uskPub","assign","clearKeys","setKeys","signingKeys","error","logger","masterKey","pkVerify","e","updateCrossSigningVerifiedBefore","isCrossSigningVerified","signObject","data","pubkey","signUser","info","signDevice","device","algorithms","device_id","deviceId","checkUserTrust","userCrossSigning","UserTrustLevel","userTrusted","userMaster","uskId","checkDeviceTrust","localTrust","trustCrossSignedDevices","userTrust","userSSK","DeviceTrustLevel","deviceObj","deviceToObject","fromUserTrustLevel","getCacheCallbacks","exports","signatures","crossSigningVerified","tofu","isVerified","wasCrossSigningVerified","isTofu","localVerified","userTrustLevel","Boolean","isLocallyVerified","createCryptoStoreCacheCallbacks","olmDevice","_expectedPublicKey","Promise","resolve","doTxn","IndexedDBCryptoStore","STORE_ACCOUNT","txn","getSecretStorePrivateKey","ciphertext","pickleKey","Buffer","from","decrypted","decryptAES","Uint8Array","encryptedKey","encryptAES","storeSecretStorePrivateKey","requestKeysDuringVerification","baseApis","getUserId","log","reject","client","original","crypto","crossSigningInfo","crossSigning","debug","promise","requestSecret","decoded","timeout","setTimeout","backupKeyPromise","cachedKey","getSessionBackupPrivateKey","secretReq","base64Key","decodedKey","storeSessionBackupPrivateKey","backupInfo","getKeyBackupVersion","restoreKeyBackupWithCache","then","race","all","catch","warn"],"sources":["../../src/crypto/CrossSigning.ts"],"sourcesContent":["/*\nCopyright 2019 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Cross signing methods\n */\n\nimport { PkSigning } from \"@matrix-org/olm\";\n\nimport { decodeBase64, encodeBase64, IObject, pkSign, pkVerify } from \"./olmlib\";\nimport { logger } from \"../logger\";\nimport { IndexedDBCryptoStore } from \"../crypto/store/indexeddb-crypto-store\";\nimport { decryptAES, encryptAES } from \"./aes\";\nimport { DeviceInfo } from \"./deviceinfo\";\nimport { SecretStorage } from \"./SecretStorage\";\nimport { ICrossSigningKey, ISignedKey, MatrixClient } from \"../client\";\nimport { OlmDevice } from \"./OlmDevice\";\nimport { ICryptoCallbacks } from \".\";\nimport { ISignatures } from \"../@types/signed\";\nimport { CryptoStore, SecretStorePrivateKeys } from \"./store/base\";\nimport { SecretStorageKeyDescription } from \"../secret-storage\";\n\nconst KEY_REQUEST_TIMEOUT_MS = 1000 * 60;\n\nfunction publicKeyFromKeyInfo(keyInfo: ICrossSigningKey): string {\n // `keys` is an object with { [`ed25519:${pubKey}`]: pubKey }\n // We assume only a single key, and we want the bare form without type\n // prefix, so we select the values.\n return Object.values(keyInfo.keys)[0];\n}\n\nexport interface ICacheCallbacks {\n getCrossSigningKeyCache?(type: string, expectedPublicKey?: string): Promise;\n storeCrossSigningKeyCache?(type: string, key?: Uint8Array): Promise;\n}\n\nexport interface ICrossSigningInfo {\n keys: Record;\n firstUse: boolean;\n crossSigningVerifiedBefore: boolean;\n}\n\nexport class CrossSigningInfo {\n public keys: Record = {};\n public firstUse = true;\n // This tracks whether we've ever verified this user with any identity.\n // When you verify a user, any devices online at the time that receive\n // the verifying signature via the homeserver will latch this to true\n // and can use it in the future to detect cases where the user has\n // become unverified later for any reason.\n private crossSigningVerifiedBefore = false;\n\n /**\n * Information about a user's cross-signing keys\n *\n * @param userId - the user that the information is about\n * @param callbacks - Callbacks used to interact with the app\n * Requires getCrossSigningKey and saveCrossSigningKeys\n * @param cacheCallbacks - Callbacks used to interact with the cache\n */\n public constructor(\n public readonly userId: string,\n private callbacks: ICryptoCallbacks = {},\n private cacheCallbacks: ICacheCallbacks = {},\n ) {}\n\n public static fromStorage(obj: ICrossSigningInfo, userId: string): CrossSigningInfo {\n const res = new CrossSigningInfo(userId);\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n // @ts-ignore - ts doesn't like this and nor should we\n res[prop] = obj[prop];\n }\n }\n return res;\n }\n\n public toStorage(): ICrossSigningInfo {\n return {\n keys: this.keys,\n firstUse: this.firstUse,\n crossSigningVerifiedBefore: this.crossSigningVerifiedBefore,\n };\n }\n\n /**\n * Calls the app callback to ask for a private key\n *\n * @param type - The key type (\"master\", \"self_signing\", or \"user_signing\")\n * @param expectedPubkey - The matching public key or undefined to use\n * the stored public key for the given key type.\n * @returns An array with [ public key, Olm.PkSigning ]\n */\n public async getCrossSigningKey(type: string, expectedPubkey?: string): Promise<[string, PkSigning]> {\n const shouldCache = [\"master\", \"self_signing\", \"user_signing\"].indexOf(type) >= 0;\n\n if (!this.callbacks.getCrossSigningKey) {\n throw new Error(\"No getCrossSigningKey callback supplied\");\n }\n\n if (expectedPubkey === undefined) {\n expectedPubkey = this.getId(type)!;\n }\n\n function validateKey(key: Uint8Array | null): [string, PkSigning] | undefined {\n if (!key) return;\n const signing = new global.Olm.PkSigning();\n const gotPubkey = signing.init_with_seed(key);\n if (gotPubkey === expectedPubkey) {\n return [gotPubkey, signing];\n }\n signing.free();\n }\n\n let privkey: Uint8Array | null = null;\n if (this.cacheCallbacks.getCrossSigningKeyCache && shouldCache) {\n privkey = await this.cacheCallbacks.getCrossSigningKeyCache(type, expectedPubkey);\n }\n\n const cacheresult = validateKey(privkey);\n if (cacheresult) {\n return cacheresult;\n }\n\n privkey = await this.callbacks.getCrossSigningKey(type, expectedPubkey);\n const result = validateKey(privkey);\n if (result) {\n if (this.cacheCallbacks.storeCrossSigningKeyCache && shouldCache) {\n await this.cacheCallbacks.storeCrossSigningKeyCache(type, privkey!);\n }\n return result;\n }\n\n /* No keysource even returned a key */\n if (!privkey) {\n throw new Error(\"getCrossSigningKey callback for \" + type + \" returned falsey\");\n }\n\n /* We got some keys from the keysource, but none of them were valid */\n throw new Error(\"Key type \" + type + \" from getCrossSigningKey callback did not match\");\n }\n\n /**\n * Check whether the private keys exist in secret storage.\n * XXX: This could be static, be we often seem to have an instance when we\n * want to know this anyway...\n *\n * @param secretStorage - The secret store using account data\n * @returns map of key name to key info the secret is encrypted\n * with, or null if it is not present or not encrypted with a trusted\n * key\n */\n public async isStoredInSecretStorage(\n secretStorage: SecretStorage,\n ): Promise | null> {\n // check what SSSS keys have encrypted the master key (if any)\n const stored = (await secretStorage.isStored(\"m.cross_signing.master\")) || {};\n // then check which of those SSSS keys have also encrypted the SSK and USK\n function intersect(s: Record): void {\n for (const k of Object.keys(stored)) {\n if (!s[k]) {\n delete stored[k];\n }\n }\n }\n for (const type of [\"self_signing\", \"user_signing\"]) {\n intersect((await secretStorage.isStored(`m.cross_signing.${type}`)) || {});\n }\n return Object.keys(stored).length ? stored : null;\n }\n\n /**\n * Store private keys in secret storage for use by other devices. This is\n * typically called in conjunction with the creation of new cross-signing\n * keys.\n *\n * @param keys - The keys to store\n * @param secretStorage - The secret store using account data\n */\n public static async storeInSecretStorage(\n keys: Map,\n secretStorage: SecretStorage,\n ): Promise {\n for (const [type, privateKey] of keys) {\n const encodedKey = encodeBase64(privateKey);\n await secretStorage.store(`m.cross_signing.${type}`, encodedKey);\n }\n }\n\n /**\n * Get private keys from secret storage created by some other device. This\n * also passes the private keys to the app-specific callback.\n *\n * @param type - The type of key to get. One of \"master\",\n * \"self_signing\", or \"user_signing\".\n * @param secretStorage - The secret store using account data\n * @returns The private key\n */\n public static async getFromSecretStorage(type: string, secretStorage: SecretStorage): Promise {\n const encodedKey = await secretStorage.get(`m.cross_signing.${type}`);\n if (!encodedKey) {\n return null;\n }\n return decodeBase64(encodedKey);\n }\n\n /**\n * Check whether the private keys exist in the local key cache.\n *\n * @param type - The type of key to get. One of \"master\",\n * \"self_signing\", or \"user_signing\". Optional, will check all by default.\n * @returns True if all keys are stored in the local cache.\n */\n public async isStoredInKeyCache(type?: string): Promise {\n const cacheCallbacks = this.cacheCallbacks;\n if (!cacheCallbacks) return false;\n const types = type ? [type] : [\"master\", \"self_signing\", \"user_signing\"];\n for (const t of types) {\n if (!(await cacheCallbacks.getCrossSigningKeyCache?.(t))) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * Get cross-signing private keys from the local cache.\n *\n * @returns A map from key type (string) to private key (Uint8Array)\n */\n public async getCrossSigningKeysFromCache(): Promise> {\n const keys = new Map();\n const cacheCallbacks = this.cacheCallbacks;\n if (!cacheCallbacks) return keys;\n for (const type of [\"master\", \"self_signing\", \"user_signing\"]) {\n const privKey = await cacheCallbacks.getCrossSigningKeyCache?.(type);\n if (!privKey) {\n continue;\n }\n keys.set(type, privKey);\n }\n return keys;\n }\n\n /**\n * Get the ID used to identify the user. This can also be used to test for\n * the existence of a given key type.\n *\n * @param type - The type of key to get the ID of. One of \"master\",\n * \"self_signing\", or \"user_signing\". Defaults to \"master\".\n *\n * @returns the ID\n */\n public getId(type = \"master\"): string | null {\n if (!this.keys[type]) return null;\n const keyInfo = this.keys[type];\n return publicKeyFromKeyInfo(keyInfo);\n }\n\n /**\n * Create new cross-signing keys for the given key types. The public keys\n * will be held in this class, while the private keys are passed off to the\n * `saveCrossSigningKeys` application callback.\n *\n * @param level - The key types to reset\n */\n public async resetKeys(level?: CrossSigningLevel): Promise {\n if (!this.callbacks.saveCrossSigningKeys) {\n throw new Error(\"No saveCrossSigningKeys callback supplied\");\n }\n\n // If we're resetting the master key, we reset all keys\n if (level === undefined || level & CrossSigningLevel.MASTER || !this.keys.master) {\n level = CrossSigningLevel.MASTER | CrossSigningLevel.USER_SIGNING | CrossSigningLevel.SELF_SIGNING;\n } else if (level === (0 as CrossSigningLevel)) {\n return;\n }\n\n const privateKeys: Record = {};\n const keys: Record = {};\n let masterSigning;\n let masterPub;\n\n try {\n if (level & CrossSigningLevel.MASTER) {\n masterSigning = new global.Olm.PkSigning();\n privateKeys.master = masterSigning.generate_seed();\n masterPub = masterSigning.init_with_seed(privateKeys.master);\n keys.master = {\n user_id: this.userId,\n usage: [\"master\"],\n keys: {\n [\"ed25519:\" + masterPub]: masterPub,\n },\n };\n } else {\n [masterPub, masterSigning] = await this.getCrossSigningKey(\"master\");\n }\n\n if (level & CrossSigningLevel.SELF_SIGNING) {\n const sskSigning = new global.Olm.PkSigning();\n try {\n privateKeys.self_signing = sskSigning.generate_seed();\n const sskPub = sskSigning.init_with_seed(privateKeys.self_signing);\n keys.self_signing = {\n user_id: this.userId,\n usage: [\"self_signing\"],\n keys: {\n [\"ed25519:\" + sskPub]: sskPub,\n },\n };\n pkSign(keys.self_signing, masterSigning, this.userId, masterPub);\n } finally {\n sskSigning.free();\n }\n }\n\n if (level & CrossSigningLevel.USER_SIGNING) {\n const uskSigning = new global.Olm.PkSigning();\n try {\n privateKeys.user_signing = uskSigning.generate_seed();\n const uskPub = uskSigning.init_with_seed(privateKeys.user_signing);\n keys.user_signing = {\n user_id: this.userId,\n usage: [\"user_signing\"],\n keys: {\n [\"ed25519:\" + uskPub]: uskPub,\n },\n };\n pkSign(keys.user_signing, masterSigning, this.userId, masterPub);\n } finally {\n uskSigning.free();\n }\n }\n\n Object.assign(this.keys, keys);\n this.callbacks.saveCrossSigningKeys(privateKeys);\n } finally {\n if (masterSigning) {\n masterSigning.free();\n }\n }\n }\n\n /**\n * unsets the keys, used when another session has reset the keys, to disable cross-signing\n */\n public clearKeys(): void {\n this.keys = {};\n }\n\n public setKeys(keys: Record): void {\n const signingKeys: Record = {};\n if (keys.master) {\n if (keys.master.user_id !== this.userId) {\n const error = \"Mismatched user ID \" + keys.master.user_id + \" in master key from \" + this.userId;\n logger.error(error);\n throw new Error(error);\n }\n if (!this.keys.master) {\n // this is the first key we've seen, so first-use is true\n this.firstUse = true;\n } else if (publicKeyFromKeyInfo(keys.master) !== this.getId()) {\n // this is a different key, so first-use is false\n this.firstUse = false;\n } // otherwise, same key, so no change\n signingKeys.master = keys.master;\n } else if (this.keys.master) {\n signingKeys.master = this.keys.master;\n } else {\n throw new Error(\"Tried to set cross-signing keys without a master key\");\n }\n const masterKey = publicKeyFromKeyInfo(signingKeys.master);\n\n // verify signatures\n if (keys.user_signing) {\n if (keys.user_signing.user_id !== this.userId) {\n const error = \"Mismatched user ID \" + keys.master.user_id + \" in user_signing key from \" + this.userId;\n logger.error(error);\n throw new Error(error);\n }\n try {\n pkVerify(keys.user_signing, masterKey, this.userId);\n } catch (e) {\n logger.error(\"invalid signature on user-signing key\");\n // FIXME: what do we want to do here?\n throw e;\n }\n }\n if (keys.self_signing) {\n if (keys.self_signing.user_id !== this.userId) {\n const error = \"Mismatched user ID \" + keys.master.user_id + \" in self_signing key from \" + this.userId;\n logger.error(error);\n throw new Error(error);\n }\n try {\n pkVerify(keys.self_signing, masterKey, this.userId);\n } catch (e) {\n logger.error(\"invalid signature on self-signing key\");\n // FIXME: what do we want to do here?\n throw e;\n }\n }\n\n // if everything checks out, then save the keys\n if (keys.master) {\n this.keys.master = keys.master;\n // if the master key is set, then the old self-signing and user-signing keys are obsolete\n delete this.keys[\"self_signing\"];\n delete this.keys[\"user_signing\"];\n }\n if (keys.self_signing) {\n this.keys.self_signing = keys.self_signing;\n }\n if (keys.user_signing) {\n this.keys.user_signing = keys.user_signing;\n }\n }\n\n public updateCrossSigningVerifiedBefore(isCrossSigningVerified: boolean): void {\n // It is critical that this value latches forward from false to true but\n // never back to false to avoid a downgrade attack.\n if (!this.crossSigningVerifiedBefore && isCrossSigningVerified) {\n this.crossSigningVerifiedBefore = true;\n }\n }\n\n public async signObject(data: T, type: string): Promise {\n if (!this.keys[type]) {\n throw new Error(\"Attempted to sign with \" + type + \" key but no such key present\");\n }\n const [pubkey, signing] = await this.getCrossSigningKey(type);\n try {\n pkSign(data, signing, this.userId, pubkey);\n return data as T & { signatures: ISignatures };\n } finally {\n signing.free();\n }\n }\n\n public async signUser(key: CrossSigningInfo): Promise {\n if (!this.keys.user_signing) {\n logger.info(\"No user signing key: not signing user\");\n return;\n }\n return this.signObject(key.keys.master, \"user_signing\");\n }\n\n public async signDevice(userId: string, device: DeviceInfo): Promise {\n if (userId !== this.userId) {\n throw new Error(`Trying to sign ${userId}'s device; can only sign our own device`);\n }\n if (!this.keys.self_signing) {\n logger.info(\"No self signing key: not signing device\");\n return;\n }\n return this.signObject>(\n {\n algorithms: device.algorithms,\n keys: device.keys,\n device_id: device.deviceId,\n user_id: userId,\n },\n \"self_signing\",\n );\n }\n\n /**\n * Check whether a given user is trusted.\n *\n * @param userCrossSigning - Cross signing info for user\n *\n * @returns\n */\n public checkUserTrust(userCrossSigning: CrossSigningInfo): UserTrustLevel {\n // if we're checking our own key, then it's trusted if the master key\n // and self-signing key match\n if (\n this.userId === userCrossSigning.userId &&\n this.getId() &&\n this.getId() === userCrossSigning.getId() &&\n this.getId(\"self_signing\") &&\n this.getId(\"self_signing\") === userCrossSigning.getId(\"self_signing\")\n ) {\n return new UserTrustLevel(true, true, this.firstUse);\n }\n\n if (!this.keys.user_signing) {\n // If there's no user signing key, they can't possibly be verified.\n // They may be TOFU trusted though.\n return new UserTrustLevel(false, false, userCrossSigning.firstUse);\n }\n\n let userTrusted: boolean;\n const userMaster = userCrossSigning.keys.master;\n const uskId = this.getId(\"user_signing\")!;\n try {\n pkVerify(userMaster, uskId, this.userId);\n userTrusted = true;\n } catch (e) {\n userTrusted = false;\n }\n return new UserTrustLevel(userTrusted, userCrossSigning.crossSigningVerifiedBefore, userCrossSigning.firstUse);\n }\n\n /**\n * Check whether a given device is trusted.\n *\n * @param userCrossSigning - Cross signing info for user\n * @param device - The device to check\n * @param localTrust - Whether the device is trusted locally\n * @param trustCrossSignedDevices - Whether we trust cross signed devices\n *\n * @returns\n */\n public checkDeviceTrust(\n userCrossSigning: CrossSigningInfo,\n device: DeviceInfo,\n localTrust: boolean,\n trustCrossSignedDevices: boolean,\n ): DeviceTrustLevel {\n const userTrust = this.checkUserTrust(userCrossSigning);\n\n const userSSK = userCrossSigning.keys.self_signing;\n if (!userSSK) {\n // if the user has no self-signing key then we cannot make any\n // trust assertions about this device from cross-signing\n return new DeviceTrustLevel(false, false, localTrust, trustCrossSignedDevices);\n }\n\n const deviceObj = deviceToObject(device, userCrossSigning.userId);\n try {\n // if we can verify the user's SSK from their master key...\n pkVerify(userSSK, userCrossSigning.getId()!, userCrossSigning.userId);\n // ...and this device's key from their SSK...\n pkVerify(deviceObj, publicKeyFromKeyInfo(userSSK), userCrossSigning.userId);\n // ...then we trust this device as much as far as we trust the user\n return DeviceTrustLevel.fromUserTrustLevel(userTrust, localTrust, trustCrossSignedDevices);\n } catch (e) {\n return new DeviceTrustLevel(false, false, localTrust, trustCrossSignedDevices);\n }\n }\n\n /**\n * @returns Cache callbacks\n */\n public getCacheCallbacks(): ICacheCallbacks {\n return this.cacheCallbacks;\n }\n}\n\ninterface DeviceObject extends IObject {\n algorithms: string[];\n keys: Record;\n device_id: string;\n user_id: string;\n}\n\nfunction deviceToObject(device: DeviceInfo, userId: string): DeviceObject {\n return {\n algorithms: device.algorithms,\n keys: device.keys,\n device_id: device.deviceId,\n user_id: userId,\n signatures: device.signatures,\n };\n}\n\nexport enum CrossSigningLevel {\n MASTER = 4,\n USER_SIGNING = 2,\n SELF_SIGNING = 1,\n}\n\n/**\n * Represents the ways in which we trust a user\n */\nexport class UserTrustLevel {\n public constructor(\n private readonly crossSigningVerified: boolean,\n private readonly crossSigningVerifiedBefore: boolean,\n private readonly tofu: boolean,\n ) {}\n\n /**\n * @returns true if this user is verified via any means\n */\n public isVerified(): boolean {\n return this.isCrossSigningVerified();\n }\n\n /**\n * @returns true if this user is verified via cross signing\n */\n public isCrossSigningVerified(): boolean {\n return this.crossSigningVerified;\n }\n\n /**\n * @returns true if we ever verified this user before (at least for\n * the history of verifications observed by this device).\n */\n public wasCrossSigningVerified(): boolean {\n return this.crossSigningVerifiedBefore;\n }\n\n /**\n * @returns true if this user's key is trusted on first use\n */\n public isTofu(): boolean {\n return this.tofu;\n }\n}\n\n/**\n * Represents the ways in which we trust a device\n */\nexport class DeviceTrustLevel {\n public constructor(\n public readonly crossSigningVerified: boolean,\n public readonly tofu: boolean,\n private readonly localVerified: boolean,\n private readonly trustCrossSignedDevices: boolean,\n ) {}\n\n public static fromUserTrustLevel(\n userTrustLevel: UserTrustLevel,\n localVerified: boolean,\n trustCrossSignedDevices: boolean,\n ): DeviceTrustLevel {\n return new DeviceTrustLevel(\n userTrustLevel.isCrossSigningVerified(),\n userTrustLevel.isTofu(),\n localVerified,\n trustCrossSignedDevices,\n );\n }\n\n /**\n * @returns true if this device is verified via any means\n */\n public isVerified(): boolean {\n return Boolean(this.isLocallyVerified() || (this.trustCrossSignedDevices && this.isCrossSigningVerified()));\n }\n\n /**\n * @returns true if this device is verified via cross signing\n */\n public isCrossSigningVerified(): boolean {\n return this.crossSigningVerified;\n }\n\n /**\n * @returns true if this device is verified locally\n */\n public isLocallyVerified(): boolean {\n return this.localVerified;\n }\n\n /**\n * @returns true if this device is trusted from a user's key\n * that is trusted on first use\n */\n public isTofu(): boolean {\n return this.tofu;\n }\n}\n\nexport function createCryptoStoreCacheCallbacks(store: CryptoStore, olmDevice: OlmDevice): ICacheCallbacks {\n return {\n getCrossSigningKeyCache: async function (\n type: keyof SecretStorePrivateKeys,\n _expectedPublicKey: string,\n ): Promise {\n const key = await new Promise((resolve) => {\n return store.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n store.getSecretStorePrivateKey(txn, resolve, type);\n });\n });\n\n if (key && key.ciphertext) {\n const pickleKey = Buffer.from(olmDevice.pickleKey);\n const decrypted = await decryptAES(key, pickleKey, type);\n return decodeBase64(decrypted);\n } else {\n return key;\n }\n },\n storeCrossSigningKeyCache: async function (\n type: keyof SecretStorePrivateKeys,\n key?: Uint8Array,\n ): Promise {\n if (!(key instanceof Uint8Array)) {\n throw new Error(`storeCrossSigningKeyCache expects Uint8Array, got ${key}`);\n }\n const pickleKey = Buffer.from(olmDevice.pickleKey);\n const encryptedKey = await encryptAES(encodeBase64(key), pickleKey, type);\n return store.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n store.storeSecretStorePrivateKey(txn, type, encryptedKey);\n });\n },\n };\n}\n\nexport type KeysDuringVerification = [[string, PkSigning], [string, PkSigning], [string, PkSigning], void];\n\n/**\n * Request cross-signing keys from another device during verification.\n *\n * @param baseApis - base Matrix API interface\n * @param userId - The user ID being verified\n * @param deviceId - The device ID being verified\n */\nexport async function requestKeysDuringVerification(\n baseApis: MatrixClient,\n userId: string,\n deviceId: string,\n): Promise {\n // If this is a self-verification, ask the other party for keys\n if (baseApis.getUserId() !== userId) {\n return;\n }\n logger.log(\"Cross-signing: Self-verification done; requesting keys\");\n // This happens asynchronously, and we're not concerned about waiting for\n // it. We return here in order to test.\n return new Promise((resolve, reject) => {\n const client = baseApis;\n const original = client.crypto!.crossSigningInfo;\n\n // We already have all of the infrastructure we need to validate and\n // cache cross-signing keys, so instead of replicating that, here we set\n // up callbacks that request them from the other device and call\n // CrossSigningInfo.getCrossSigningKey() to validate/cache\n const crossSigning = new CrossSigningInfo(\n original.userId,\n {\n getCrossSigningKey: async (type): Promise => {\n logger.debug(\"Cross-signing: requesting secret\", type, deviceId);\n const { promise } = client.requestSecret(`m.cross_signing.${type}`, [deviceId]);\n const result = await promise;\n const decoded = decodeBase64(result);\n return Uint8Array.from(decoded);\n },\n },\n original.getCacheCallbacks(),\n );\n crossSigning.keys = original.keys;\n\n // XXX: get all keys out if we get one key out\n // https://github.com/vector-im/element-web/issues/12604\n // then change here to reject on the timeout\n // Requests can be ignored, so don't wait around forever\n const timeout = new Promise((resolve) => {\n setTimeout(resolve, KEY_REQUEST_TIMEOUT_MS, new Error(\"Timeout\"));\n });\n\n // also request and cache the key backup key\n const backupKeyPromise = (async (): Promise => {\n const cachedKey = await client.crypto!.getSessionBackupPrivateKey();\n if (!cachedKey) {\n logger.info(\"No cached backup key found. Requesting...\");\n const secretReq = client.requestSecret(\"m.megolm_backup.v1\", [deviceId]);\n const base64Key = await secretReq.promise;\n logger.info(\"Got key backup key, decoding...\");\n const decodedKey = decodeBase64(base64Key);\n logger.info(\"Decoded backup key, storing...\");\n await client.crypto!.storeSessionBackupPrivateKey(Uint8Array.from(decodedKey));\n logger.info(\"Backup key stored. Starting backup restore...\");\n const backupInfo = await client.getKeyBackupVersion();\n // no need to await for this - just let it go in the bg\n client.restoreKeyBackupWithCache(undefined, undefined, backupInfo!).then(() => {\n logger.info(\"Backup restored.\");\n });\n }\n })();\n\n // We call getCrossSigningKey() for its side-effects\n return Promise.race([\n Promise.all([\n crossSigning.getCrossSigningKey(\"master\"),\n crossSigning.getCrossSigningKey(\"self_signing\"),\n crossSigning.getCrossSigningKey(\"user_signing\"),\n backupKeyPromise,\n ]) as Promise,\n timeout,\n ]).then(resolve, reject);\n }).catch((e) => {\n logger.warn(\"Cross-signing: failure while requesting keys:\", e);\n });\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts deleted file mode 100644 index 6c124fa..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts +++ /dev/null @@ -1,216 +0,0 @@ -import { DeviceInfo, IDevice } from "./deviceinfo"; -import { CrossSigningInfo, ICrossSigningInfo } from "./CrossSigning"; -import { MatrixClient } from "../client"; -import { OlmDevice } from "./OlmDevice"; -import { CryptoStore } from "./store/base"; -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { CryptoEvent, CryptoEventHandlerMap } from "./index"; -export declare enum TrackingStatus { - NotTracked = 0, - PendingDownload = 1, - DownloadInProgress = 2, - UpToDate = 3 -} -export type DeviceInfoMap = Map>; -type EmittedEvents = CryptoEvent.WillUpdateDevices | CryptoEvent.DevicesUpdated | CryptoEvent.UserCrossSigningUpdated; -export declare class DeviceList extends TypedEventEmitter { - private readonly cryptoStore; - readonly keyDownloadChunkSize: number; - private devices; - crossSigningInfo: { - [userId: string]: ICrossSigningInfo; - }; - private userByIdentityKey; - private deviceTrackingStatus; - private syncToken; - private keyDownloadsInProgressByUser; - private dirty; - private savePromise; - private resolveSavePromise; - private savePromiseTime; - private saveTimer; - private hasFetched; - private readonly serialiser; - constructor(baseApis: MatrixClient, cryptoStore: CryptoStore, olmDevice: OlmDevice, keyDownloadChunkSize?: number); - /** - * Load the device tracking state from storage - */ - load(): Promise; - stop(): void; - /** - * Save the device tracking state to storage, if any changes are - * pending other than updating the sync token - * - * The actual save will be delayed by a short amount of time to - * aggregate multiple writes to the database. - * - * @param delay - Time in ms before which the save actually happens. - * By default, the save is delayed for a short period in order to batch - * multiple writes, but this behaviour can be disabled by passing 0. - * - * @returns true if the data was saved, false if - * it was not (eg. because no changes were pending). The promise - * will only resolve once the data is saved, so may take some time - * to resolve. - */ - saveIfDirty(delay?: number): Promise; - /** - * Gets the sync token last set with setSyncToken - * - * @returns The sync token - */ - getSyncToken(): string | null; - /** - * Sets the sync token that the app will pass as the 'since' to the /sync - * endpoint next time it syncs. - * The sync token must always be set after any changes made as a result of - * data in that sync since setting the sync token to a newer one will mean - * those changed will not be synced from the server if a new client starts - * up with that data. - * - * @param st - The sync token - */ - setSyncToken(st: string | null): void; - /** - * Ensures up to date keys for a list of users are stored in the session store, - * downloading and storing them if they're not (or if forceDownload is - * true). - * @param userIds - The users to fetch. - * @param forceDownload - Always download the keys even if cached. - * - * @returns A promise which resolves to a map userId-\>deviceId-\>{@link DeviceInfo}. - */ - downloadKeys(userIds: string[], forceDownload: boolean): Promise; - /** - * Get the stored device keys for a list of user ids - * - * @param userIds - the list of users to list keys for. - * - * @returns userId-\>deviceId-\>{@link DeviceInfo}. - */ - private getDevicesFromStore; - /** - * Returns a list of all user IDs the DeviceList knows about - * - * @returns All known user IDs - */ - getKnownUserIds(): string[]; - /** - * Get the stored device keys for a user id - * - * @param userId - the user to list keys for. - * - * @returns list of devices, or null if we haven't - * managed to get a list of devices for this user yet. - */ - getStoredDevicesForUser(userId: string): DeviceInfo[] | null; - /** - * Get the stored device data for a user, in raw object form - * - * @param userId - the user to get data for - * - * @returns `deviceId->{object}` devices, or undefined if - * there is no data for this user. - */ - getRawStoredDevicesForUser(userId: string): Record; - getStoredCrossSigningForUser(userId: string): CrossSigningInfo | null; - storeCrossSigningForUser(userId: string, info: ICrossSigningInfo): void; - /** - * Get the stored keys for a single device - * - * - * @returns device, or undefined - * if we don't know about this device - */ - getStoredDevice(userId: string, deviceId: string): DeviceInfo | undefined; - /** - * Get a user ID by one of their device's curve25519 identity key - * - * @param algorithm - encryption algorithm - * @param senderKey - curve25519 key to match - * - * @returns user ID - */ - getUserByIdentityKey(algorithm: string, senderKey: string): string | null; - /** - * Find a device by curve25519 identity key - * - * @param algorithm - encryption algorithm - * @param senderKey - curve25519 key to match - */ - getDeviceByIdentityKey(algorithm: string, senderKey: string): DeviceInfo | null; - /** - * Replaces the list of devices for a user with the given device list - * - * @param userId - The user ID - * @param devices - New device info for user - */ - storeDevicesForUser(userId: string, devices: Record): void; - /** - * flag the given user for device-list tracking, if they are not already. - * - * This will mean that a subsequent call to refreshOutdatedDeviceLists() - * will download the device list for the user, and that subsequent calls to - * invalidateUserDeviceList will trigger more updates. - * - */ - startTrackingDeviceList(userId: string): void; - /** - * Mark the given user as no longer being tracked for device-list updates. - * - * This won't affect any in-progress downloads, which will still go on to - * complete; it will just mean that we don't think that we have an up-to-date - * list for future calls to downloadKeys. - * - */ - stopTrackingDeviceList(userId: string): void; - /** - * Set all users we're currently tracking to untracked - * - * This will flag each user whose devices we are tracking as in need of an - * update. - */ - stopTrackingAllDeviceLists(): void; - /** - * Mark the cached device list for the given user outdated. - * - * If we are not tracking this user's devices, we'll do nothing. Otherwise - * we flag the user as needing an update. - * - * This doesn't actually set off an update, so that several users can be - * batched together. Call refreshOutdatedDeviceLists() for that. - * - */ - invalidateUserDeviceList(userId: string): void; - /** - * If we have users who have outdated device lists, start key downloads for them - * - * @returns which completes when the download completes; normally there - * is no need to wait for this (it's mostly for the unit tests). - */ - refreshOutdatedDeviceLists(): Promise; - /** - * Set the stored device data for a user, in raw object form - * Used only by internal class DeviceListUpdateSerialiser - * - * @param userId - the user to get data for - * - * @param devices - `deviceId->{object}` the new devices - */ - setRawStoredDevicesForUser(userId: string, devices: Record): void; - setRawStoredCrossSigningForUser(userId: string, info: ICrossSigningInfo): void; - /** - * Fire off download update requests for the given users, and update the - * device list tracking status for them, and the - * keyDownloadsInProgressByUser map for them. - * - * @param users - list of userIds - * - * @returns resolves when all the users listed have - * been updated. rejects if there was a problem updating any of the - * users. - */ - private doKeyDownload; -} -export {}; -//# sourceMappingURL=DeviceList.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts.map deleted file mode 100644 index 9c1e98e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"DeviceList.d.ts","sourceRoot":"","sources":["../../src/crypto/DeviceList.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js deleted file mode 100644 index bdf90a3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js +++ /dev/null @@ -1,877 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TrackingStatus = exports.DeviceList = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../logger"); -var _deviceinfo = require("./deviceinfo"); -var _CrossSigning = require("./CrossSigning"); -var olmlib = _interopRequireWildcard(require("./olmlib")); -var _indexeddbCryptoStore = require("./store/indexeddb-crypto-store"); -var _utils = require("../utils"); -var _typedEventEmitter = require("../models/typed-event-emitter"); -var _index = require("./index"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2017 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -/** - * Manages the list of other users' devices - */ -/* State transition diagram for DeviceList.deviceTrackingStatus - * - * | - * stopTrackingDeviceList V - * +---------------------> NOT_TRACKED - * | | - * +<--------------------+ | startTrackingDeviceList - * | | V - * | +-------------> PENDING_DOWNLOAD <--------------------+-+ - * | | ^ | | | - * | | restart download | | start download | | invalidateUserDeviceList - * | | client failed | | | | - * | | | V | | - * | +------------ DOWNLOAD_IN_PROGRESS -------------------+ | - * | | | | - * +<-------------------+ | download successful | - * ^ V | - * +----------------------- UP_TO_DATE ------------------------+ - */ -// constants for DeviceList.deviceTrackingStatus -let TrackingStatus; // user-Id → device-Id → DeviceInfo -exports.TrackingStatus = TrackingStatus; -(function (TrackingStatus) { - TrackingStatus[TrackingStatus["NotTracked"] = 0] = "NotTracked"; - TrackingStatus[TrackingStatus["PendingDownload"] = 1] = "PendingDownload"; - TrackingStatus[TrackingStatus["DownloadInProgress"] = 2] = "DownloadInProgress"; - TrackingStatus[TrackingStatus["UpToDate"] = 3] = "UpToDate"; -})(TrackingStatus || (exports.TrackingStatus = TrackingStatus = {})); -class DeviceList extends _typedEventEmitter.TypedEventEmitter { - // map of identity keys to the user who owns it - - // which users we are tracking device status for. - // loaded from storage in load() - - // The 'next_batch' sync token at the point the data was written, - // ie. a token representing the point immediately after the - // moment represented by the snapshot in the db. - - // Set whenever changes are made other than setting the sync token - - // Promise resolved when device data is saved - - // Function that resolves the save promise - - // The time the save is scheduled for - - // The timer used to delay the save - - // True if we have fetched data from the server or loaded a non-empty - // set of device data from the store - - constructor(baseApis, cryptoStore, olmDevice, - // Maximum number of user IDs per request to prevent server overload (#1619) - keyDownloadChunkSize = 250) { - super(); - this.cryptoStore = cryptoStore; - this.keyDownloadChunkSize = keyDownloadChunkSize; - (0, _defineProperty2.default)(this, "devices", {}); - (0, _defineProperty2.default)(this, "crossSigningInfo", {}); - (0, _defineProperty2.default)(this, "userByIdentityKey", {}); - (0, _defineProperty2.default)(this, "deviceTrackingStatus", {}); - (0, _defineProperty2.default)(this, "syncToken", null); - (0, _defineProperty2.default)(this, "keyDownloadsInProgressByUser", new Map()); - (0, _defineProperty2.default)(this, "dirty", false); - (0, _defineProperty2.default)(this, "savePromise", null); - (0, _defineProperty2.default)(this, "resolveSavePromise", null); - (0, _defineProperty2.default)(this, "savePromiseTime", null); - (0, _defineProperty2.default)(this, "saveTimer", null); - (0, _defineProperty2.default)(this, "hasFetched", null); - (0, _defineProperty2.default)(this, "serialiser", void 0); - this.serialiser = new DeviceListUpdateSerialiser(baseApis, olmDevice, this); - } - - /** - * Load the device tracking state from storage - */ - async load() { - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_DEVICE_DATA], txn => { - this.cryptoStore.getEndToEndDeviceData(txn, deviceData => { - var _deviceData$syncToken; - this.hasFetched = Boolean(deviceData && deviceData.devices); - this.devices = deviceData ? deviceData.devices : {}; - this.crossSigningInfo = deviceData ? deviceData.crossSigningInfo || {} : {}; - this.deviceTrackingStatus = deviceData ? deviceData.trackingStatus : {}; - this.syncToken = (_deviceData$syncToken = deviceData === null || deviceData === void 0 ? void 0 : deviceData.syncToken) !== null && _deviceData$syncToken !== void 0 ? _deviceData$syncToken : null; - this.userByIdentityKey = {}; - for (const user of Object.keys(this.devices)) { - const userDevices = this.devices[user]; - for (const device of Object.keys(userDevices)) { - const idKey = userDevices[device].keys["curve25519:" + device]; - if (idKey !== undefined) { - this.userByIdentityKey[idKey] = user; - } - } - } - }); - }); - for (const u of Object.keys(this.deviceTrackingStatus)) { - // if a download was in progress when we got shut down, it isn't any more. - if (this.deviceTrackingStatus[u] == TrackingStatus.DownloadInProgress) { - this.deviceTrackingStatus[u] = TrackingStatus.PendingDownload; - } - } - } - stop() { - if (this.saveTimer !== null) { - clearTimeout(this.saveTimer); - } - } - - /** - * Save the device tracking state to storage, if any changes are - * pending other than updating the sync token - * - * The actual save will be delayed by a short amount of time to - * aggregate multiple writes to the database. - * - * @param delay - Time in ms before which the save actually happens. - * By default, the save is delayed for a short period in order to batch - * multiple writes, but this behaviour can be disabled by passing 0. - * - * @returns true if the data was saved, false if - * it was not (eg. because no changes were pending). The promise - * will only resolve once the data is saved, so may take some time - * to resolve. - */ - async saveIfDirty(delay = 500) { - if (!this.dirty) return Promise.resolve(false); - // Delay saves for a bit so we can aggregate multiple saves that happen - // in quick succession (eg. when a whole room's devices are marked as known) - - const targetTime = Date.now() + delay; - if (this.savePromiseTime && targetTime < this.savePromiseTime) { - // There's a save scheduled but for after we would like: cancel - // it & schedule one for the time we want - clearTimeout(this.saveTimer); - this.saveTimer = null; - this.savePromiseTime = null; - // (but keep the save promise since whatever called save before - // will still want to know when the save is done) - } - - let savePromise = this.savePromise; - if (savePromise === null) { - savePromise = new Promise(resolve => { - this.resolveSavePromise = resolve; - }); - this.savePromise = savePromise; - } - if (this.saveTimer === null) { - const resolveSavePromise = this.resolveSavePromise; - this.savePromiseTime = targetTime; - this.saveTimer = setTimeout(() => { - _logger.logger.log("Saving device tracking data", this.syncToken); - - // null out savePromise now (after the delay but before the write), - // otherwise we could return the existing promise when the save has - // actually already happened. - this.savePromiseTime = null; - this.saveTimer = null; - this.savePromise = null; - this.resolveSavePromise = null; - this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_DEVICE_DATA], txn => { - var _this$syncToken; - this.cryptoStore.storeEndToEndDeviceData({ - devices: this.devices, - crossSigningInfo: this.crossSigningInfo, - trackingStatus: this.deviceTrackingStatus, - syncToken: (_this$syncToken = this.syncToken) !== null && _this$syncToken !== void 0 ? _this$syncToken : undefined - }, txn); - }).then(() => { - // The device list is considered dirty until the write completes. - this.dirty = false; - resolveSavePromise === null || resolveSavePromise === void 0 ? void 0 : resolveSavePromise(true); - }, err => { - _logger.logger.error("Failed to save device tracking data", this.syncToken); - _logger.logger.error(err); - }); - }, delay); - } - return savePromise; - } - - /** - * Gets the sync token last set with setSyncToken - * - * @returns The sync token - */ - getSyncToken() { - return this.syncToken; - } - - /** - * Sets the sync token that the app will pass as the 'since' to the /sync - * endpoint next time it syncs. - * The sync token must always be set after any changes made as a result of - * data in that sync since setting the sync token to a newer one will mean - * those changed will not be synced from the server if a new client starts - * up with that data. - * - * @param st - The sync token - */ - setSyncToken(st) { - this.syncToken = st; - } - - /** - * Ensures up to date keys for a list of users are stored in the session store, - * downloading and storing them if they're not (or if forceDownload is - * true). - * @param userIds - The users to fetch. - * @param forceDownload - Always download the keys even if cached. - * - * @returns A promise which resolves to a map userId-\>deviceId-\>{@link DeviceInfo}. - */ - downloadKeys(userIds, forceDownload) { - const usersToDownload = []; - const promises = []; - userIds.forEach(u => { - const trackingStatus = this.deviceTrackingStatus[u]; - if (this.keyDownloadsInProgressByUser.has(u)) { - // already a key download in progress/queued for this user; its results - // will be good enough for us. - _logger.logger.log(`downloadKeys: already have a download in progress for ` + `${u}: awaiting its result`); - promises.push(this.keyDownloadsInProgressByUser.get(u)); - } else if (forceDownload || trackingStatus != TrackingStatus.UpToDate) { - usersToDownload.push(u); - } - }); - if (usersToDownload.length != 0) { - _logger.logger.log("downloadKeys: downloading for", usersToDownload); - const downloadPromise = this.doKeyDownload(usersToDownload); - promises.push(downloadPromise); - } - if (promises.length === 0) { - _logger.logger.log("downloadKeys: already have all necessary keys"); - } - return Promise.all(promises).then(() => { - return this.getDevicesFromStore(userIds); - }); - } - - /** - * Get the stored device keys for a list of user ids - * - * @param userIds - the list of users to list keys for. - * - * @returns userId-\>deviceId-\>{@link DeviceInfo}. - */ - getDevicesFromStore(userIds) { - const stored = new Map(); - userIds.forEach(userId => { - var _this$getStoredDevice; - const deviceMap = new Map(); - (_this$getStoredDevice = this.getStoredDevicesForUser(userId)) === null || _this$getStoredDevice === void 0 ? void 0 : _this$getStoredDevice.forEach(function (device) { - deviceMap.set(device.deviceId, device); - }); - stored.set(userId, deviceMap); - }); - return stored; - } - - /** - * Returns a list of all user IDs the DeviceList knows about - * - * @returns All known user IDs - */ - getKnownUserIds() { - return Object.keys(this.devices); - } - - /** - * Get the stored device keys for a user id - * - * @param userId - the user to list keys for. - * - * @returns list of devices, or null if we haven't - * managed to get a list of devices for this user yet. - */ - getStoredDevicesForUser(userId) { - const devs = this.devices[userId]; - if (!devs) { - return null; - } - const res = []; - for (const deviceId in devs) { - if (devs.hasOwnProperty(deviceId)) { - res.push(_deviceinfo.DeviceInfo.fromStorage(devs[deviceId], deviceId)); - } - } - return res; - } - - /** - * Get the stored device data for a user, in raw object form - * - * @param userId - the user to get data for - * - * @returns `deviceId->{object}` devices, or undefined if - * there is no data for this user. - */ - getRawStoredDevicesForUser(userId) { - return this.devices[userId]; - } - getStoredCrossSigningForUser(userId) { - if (!this.crossSigningInfo[userId]) return null; - return _CrossSigning.CrossSigningInfo.fromStorage(this.crossSigningInfo[userId], userId); - } - storeCrossSigningForUser(userId, info) { - this.crossSigningInfo[userId] = info; - this.dirty = true; - } - - /** - * Get the stored keys for a single device - * - * - * @returns device, or undefined - * if we don't know about this device - */ - getStoredDevice(userId, deviceId) { - const devs = this.devices[userId]; - if (!(devs !== null && devs !== void 0 && devs[deviceId])) { - return undefined; - } - return _deviceinfo.DeviceInfo.fromStorage(devs[deviceId], deviceId); - } - - /** - * Get a user ID by one of their device's curve25519 identity key - * - * @param algorithm - encryption algorithm - * @param senderKey - curve25519 key to match - * - * @returns user ID - */ - getUserByIdentityKey(algorithm, senderKey) { - if (algorithm !== olmlib.OLM_ALGORITHM && algorithm !== olmlib.MEGOLM_ALGORITHM) { - // we only deal in olm keys - return null; - } - return this.userByIdentityKey[senderKey]; - } - - /** - * Find a device by curve25519 identity key - * - * @param algorithm - encryption algorithm - * @param senderKey - curve25519 key to match - */ - getDeviceByIdentityKey(algorithm, senderKey) { - const userId = this.getUserByIdentityKey(algorithm, senderKey); - if (!userId) { - return null; - } - const devices = this.devices[userId]; - if (!devices) { - return null; - } - for (const deviceId in devices) { - if (!devices.hasOwnProperty(deviceId)) { - continue; - } - const device = devices[deviceId]; - for (const keyId in device.keys) { - if (!device.keys.hasOwnProperty(keyId)) { - continue; - } - if (keyId.indexOf("curve25519:") !== 0) { - continue; - } - const deviceKey = device.keys[keyId]; - if (deviceKey == senderKey) { - return _deviceinfo.DeviceInfo.fromStorage(device, deviceId); - } - } - } - - // doesn't match a known device - return null; - } - - /** - * Replaces the list of devices for a user with the given device list - * - * @param userId - The user ID - * @param devices - New device info for user - */ - storeDevicesForUser(userId, devices) { - this.setRawStoredDevicesForUser(userId, devices); - this.dirty = true; - } - - /** - * flag the given user for device-list tracking, if they are not already. - * - * This will mean that a subsequent call to refreshOutdatedDeviceLists() - * will download the device list for the user, and that subsequent calls to - * invalidateUserDeviceList will trigger more updates. - * - */ - startTrackingDeviceList(userId) { - // sanity-check the userId. This is mostly paranoia, but if synapse - // can't parse the userId we give it as an mxid, it 500s the whole - // request and we can never update the device lists again (because - // the broken userId is always 'invalid' and always included in any - // refresh request). - // By checking it is at least a string, we can eliminate a class of - // silly errors. - if (typeof userId !== "string") { - throw new Error("userId must be a string; was " + userId); - } - if (!this.deviceTrackingStatus[userId]) { - _logger.logger.log("Now tracking device list for " + userId); - this.deviceTrackingStatus[userId] = TrackingStatus.PendingDownload; - // we don't yet persist the tracking status, since there may be a lot - // of calls; we save all data together once the sync is done - this.dirty = true; - } - } - - /** - * Mark the given user as no longer being tracked for device-list updates. - * - * This won't affect any in-progress downloads, which will still go on to - * complete; it will just mean that we don't think that we have an up-to-date - * list for future calls to downloadKeys. - * - */ - stopTrackingDeviceList(userId) { - if (this.deviceTrackingStatus[userId]) { - _logger.logger.log("No longer tracking device list for " + userId); - this.deviceTrackingStatus[userId] = TrackingStatus.NotTracked; - - // we don't yet persist the tracking status, since there may be a lot - // of calls; we save all data together once the sync is done - this.dirty = true; - } - } - - /** - * Set all users we're currently tracking to untracked - * - * This will flag each user whose devices we are tracking as in need of an - * update. - */ - stopTrackingAllDeviceLists() { - for (const userId of Object.keys(this.deviceTrackingStatus)) { - this.deviceTrackingStatus[userId] = TrackingStatus.NotTracked; - } - this.dirty = true; - } - - /** - * Mark the cached device list for the given user outdated. - * - * If we are not tracking this user's devices, we'll do nothing. Otherwise - * we flag the user as needing an update. - * - * This doesn't actually set off an update, so that several users can be - * batched together. Call refreshOutdatedDeviceLists() for that. - * - */ - invalidateUserDeviceList(userId) { - if (this.deviceTrackingStatus[userId]) { - _logger.logger.log("Marking device list outdated for", userId); - this.deviceTrackingStatus[userId] = TrackingStatus.PendingDownload; - - // we don't yet persist the tracking status, since there may be a lot - // of calls; we save all data together once the sync is done - this.dirty = true; - } - } - - /** - * If we have users who have outdated device lists, start key downloads for them - * - * @returns which completes when the download completes; normally there - * is no need to wait for this (it's mostly for the unit tests). - */ - refreshOutdatedDeviceLists() { - this.saveIfDirty(); - const usersToDownload = []; - for (const userId of Object.keys(this.deviceTrackingStatus)) { - const stat = this.deviceTrackingStatus[userId]; - if (stat == TrackingStatus.PendingDownload) { - usersToDownload.push(userId); - } - } - return this.doKeyDownload(usersToDownload); - } - - /** - * Set the stored device data for a user, in raw object form - * Used only by internal class DeviceListUpdateSerialiser - * - * @param userId - the user to get data for - * - * @param devices - `deviceId->{object}` the new devices - */ - setRawStoredDevicesForUser(userId, devices) { - // remove old devices from userByIdentityKey - if (this.devices[userId] !== undefined) { - for (const [deviceId, dev] of Object.entries(this.devices[userId])) { - const identityKey = dev.keys["curve25519:" + deviceId]; - delete this.userByIdentityKey[identityKey]; - } - } - this.devices[userId] = devices; - - // add new devices into userByIdentityKey - for (const [deviceId, dev] of Object.entries(devices)) { - const identityKey = dev.keys["curve25519:" + deviceId]; - this.userByIdentityKey[identityKey] = userId; - } - } - setRawStoredCrossSigningForUser(userId, info) { - this.crossSigningInfo[userId] = info; - } - - /** - * Fire off download update requests for the given users, and update the - * device list tracking status for them, and the - * keyDownloadsInProgressByUser map for them. - * - * @param users - list of userIds - * - * @returns resolves when all the users listed have - * been updated. rejects if there was a problem updating any of the - * users. - */ - doKeyDownload(users) { - if (users.length === 0) { - // nothing to do - return Promise.resolve(); - } - const prom = this.serialiser.updateDevicesForUsers(users, this.syncToken).then(() => { - finished(true); - }, e => { - _logger.logger.error("Error downloading keys for " + users + ":", e); - finished(false); - throw e; - }); - users.forEach(u => { - this.keyDownloadsInProgressByUser.set(u, prom); - const stat = this.deviceTrackingStatus[u]; - if (stat == TrackingStatus.PendingDownload) { - this.deviceTrackingStatus[u] = TrackingStatus.DownloadInProgress; - } - }); - const finished = success => { - this.emit(_index.CryptoEvent.WillUpdateDevices, users, !this.hasFetched); - users.forEach(u => { - this.dirty = true; - - // we may have queued up another download request for this user - // since we started this request. If that happens, we should - // ignore the completion of the first one. - if (this.keyDownloadsInProgressByUser.get(u) !== prom) { - _logger.logger.log("Another update in the queue for", u, "- not marking up-to-date"); - return; - } - this.keyDownloadsInProgressByUser.delete(u); - const stat = this.deviceTrackingStatus[u]; - if (stat == TrackingStatus.DownloadInProgress) { - if (success) { - // we didn't get any new invalidations since this download started: - // this user's device list is now up to date. - this.deviceTrackingStatus[u] = TrackingStatus.UpToDate; - _logger.logger.log("Device list for", u, "now up to date"); - } else { - this.deviceTrackingStatus[u] = TrackingStatus.PendingDownload; - } - } - }); - this.saveIfDirty(); - this.emit(_index.CryptoEvent.DevicesUpdated, users, !this.hasFetched); - this.hasFetched = true; - }; - return prom; - } -} - -/** - * Serialises updates to device lists - * - * Ensures that results from /keys/query are not overwritten if a second call - * completes *before* an earlier one. - * - * It currently does this by ensuring only one call to /keys/query happens at a - * time (and queuing other requests up). - */ -exports.DeviceList = DeviceList; -class DeviceListUpdateSerialiser { - // users which are queued for download - // userId -> true - - // deferred which is resolved when the queued users are downloaded. - // non-null indicates that we have users queued for download. - - // The sync token we send with the requests - - /* - * @param baseApis - Base API object - * @param olmDevice - The Olm Device - * @param deviceList - The device list object, the device list to be updated - */ - constructor(baseApis, olmDevice, deviceList) { - this.baseApis = baseApis; - this.olmDevice = olmDevice; - this.deviceList = deviceList; - (0, _defineProperty2.default)(this, "downloadInProgress", false); - (0, _defineProperty2.default)(this, "keyDownloadsQueuedByUser", {}); - (0, _defineProperty2.default)(this, "queuedQueryDeferred", void 0); - (0, _defineProperty2.default)(this, "syncToken", void 0); - } - - /** - * Make a key query request for the given users - * - * @param users - list of user ids - * - * @param syncToken - sync token to pass in the query request, to - * help the HS give the most recent results - * - * @returns resolves when all the users listed have - * been updated. rejects if there was a problem updating any of the - * users. - */ - updateDevicesForUsers(users, syncToken) { - users.forEach(u => { - this.keyDownloadsQueuedByUser[u] = true; - }); - if (!this.queuedQueryDeferred) { - this.queuedQueryDeferred = (0, _utils.defer)(); - } - - // We always take the new sync token and just use the latest one we've - // been given, since it just needs to be at least as recent as the - // sync response the device invalidation message arrived in - this.syncToken = syncToken; - if (this.downloadInProgress) { - // just queue up these users - _logger.logger.log("Queued key download for", users); - return this.queuedQueryDeferred.promise; - } - - // start a new download. - return this.doQueuedQueries(); - } - doQueuedQueries() { - if (this.downloadInProgress) { - throw new Error("DeviceListUpdateSerialiser.doQueuedQueries called with request active"); - } - const downloadUsers = Object.keys(this.keyDownloadsQueuedByUser); - this.keyDownloadsQueuedByUser = {}; - const deferred = this.queuedQueryDeferred; - this.queuedQueryDeferred = undefined; - _logger.logger.log("Starting key download for", downloadUsers); - this.downloadInProgress = true; - const opts = {}; - if (this.syncToken) { - opts.token = this.syncToken; - } - const factories = []; - for (let i = 0; i < downloadUsers.length; i += this.deviceList.keyDownloadChunkSize) { - const userSlice = downloadUsers.slice(i, i + this.deviceList.keyDownloadChunkSize); - factories.push(() => this.baseApis.downloadKeysForUsers(userSlice, opts)); - } - (0, _utils.chunkPromises)(factories, 3).then(async responses => { - const dk = Object.assign({}, ...responses.map(res => res.device_keys || {})); - const masterKeys = Object.assign({}, ...responses.map(res => res.master_keys || {})); - const ssks = Object.assign({}, ...responses.map(res => res.self_signing_keys || {})); - const usks = Object.assign({}, ...responses.map(res => res.user_signing_keys || {})); - - // yield to other things that want to execute in between users, to - // avoid wedging the CPU - // (https://github.com/vector-im/element-web/issues/3158) - // - // of course we ought to do this in a web worker or similar, but - // this serves as an easy solution for now. - for (const userId of downloadUsers) { - await (0, _utils.sleep)(5); - try { - await this.processQueryResponseForUser(userId, dk[userId], { - master: masterKeys === null || masterKeys === void 0 ? void 0 : masterKeys[userId], - self_signing: ssks === null || ssks === void 0 ? void 0 : ssks[userId], - user_signing: usks === null || usks === void 0 ? void 0 : usks[userId] - }); - } catch (e) { - // log the error but continue, so that one bad key - // doesn't kill the whole process - _logger.logger.error(`Error processing keys for ${userId}:`, e); - } - } - }).then(() => { - _logger.logger.log("Completed key download for " + downloadUsers); - this.downloadInProgress = false; - deferred === null || deferred === void 0 ? void 0 : deferred.resolve(); - - // if we have queued users, fire off another request. - if (this.queuedQueryDeferred) { - this.doQueuedQueries(); - } - }, e => { - _logger.logger.warn("Error downloading keys for " + downloadUsers + ":", e); - this.downloadInProgress = false; - deferred === null || deferred === void 0 ? void 0 : deferred.reject(e); - }); - return deferred.promise; - } - async processQueryResponseForUser(userId, dkResponse, crossSigningResponse) { - _logger.logger.log("got device keys for " + userId + ":", dkResponse); - _logger.logger.log("got cross-signing keys for " + userId + ":", crossSigningResponse); - { - // map from deviceid -> deviceinfo for this user - const userStore = {}; - const devs = this.deviceList.getRawStoredDevicesForUser(userId); - if (devs) { - Object.keys(devs).forEach(deviceId => { - const d = _deviceinfo.DeviceInfo.fromStorage(devs[deviceId], deviceId); - userStore[deviceId] = d; - }); - } - await updateStoredDeviceKeysForUser(this.olmDevice, userId, userStore, dkResponse || {}, this.baseApis.getUserId(), this.baseApis.deviceId); - - // put the updates into the object that will be returned as our results - const storage = {}; - Object.keys(userStore).forEach(deviceId => { - storage[deviceId] = userStore[deviceId].toStorage(); - }); - this.deviceList.setRawStoredDevicesForUser(userId, storage); - } - - // now do the same for the cross-signing keys - { - // FIXME: should we be ignoring empty cross-signing responses, or - // should we be dropping the keys? - if (crossSigningResponse && (crossSigningResponse.master || crossSigningResponse.self_signing || crossSigningResponse.user_signing)) { - const crossSigning = this.deviceList.getStoredCrossSigningForUser(userId) || new _CrossSigning.CrossSigningInfo(userId); - crossSigning.setKeys(crossSigningResponse); - this.deviceList.setRawStoredCrossSigningForUser(userId, crossSigning.toStorage()); - - // NB. Unlike most events in the js-sdk, this one is internal to the - // js-sdk and is not re-emitted - this.deviceList.emit(_index.CryptoEvent.UserCrossSigningUpdated, userId); - } - } - } -} -async function updateStoredDeviceKeysForUser(olmDevice, userId, userStore, userResult, localUserId, localDeviceId) { - let updated = false; - - // remove any devices in the store which aren't in the response - for (const deviceId in userStore) { - if (!userStore.hasOwnProperty(deviceId)) { - continue; - } - if (!(deviceId in userResult)) { - if (userId === localUserId && deviceId === localDeviceId) { - _logger.logger.warn(`Local device ${deviceId} missing from sync, skipping removal`); - continue; - } - _logger.logger.log("Device " + userId + ":" + deviceId + " has been removed"); - delete userStore[deviceId]; - updated = true; - } - } - for (const deviceId in userResult) { - if (!userResult.hasOwnProperty(deviceId)) { - continue; - } - const deviceResult = userResult[deviceId]; - - // check that the user_id and device_id in the response object are - // correct - if (deviceResult.user_id !== userId) { - _logger.logger.warn("Mismatched user_id " + deviceResult.user_id + " in keys from " + userId + ":" + deviceId); - continue; - } - if (deviceResult.device_id !== deviceId) { - _logger.logger.warn("Mismatched device_id " + deviceResult.device_id + " in keys from " + userId + ":" + deviceId); - continue; - } - if (await storeDeviceKeys(olmDevice, userStore, deviceResult)) { - updated = true; - } - } - return updated; -} - -/* - * Process a device in a /query response, and add it to the userStore - * - * returns (a promise for) true if a change was made, else false - */ -async function storeDeviceKeys(olmDevice, userStore, deviceResult) { - if (!deviceResult.keys) { - // no keys? - return false; - } - const deviceId = deviceResult.device_id; - const userId = deviceResult.user_id; - const signKeyId = "ed25519:" + deviceId; - const signKey = deviceResult.keys[signKeyId]; - if (!signKey) { - _logger.logger.warn("Device " + userId + ":" + deviceId + " has no ed25519 key"); - return false; - } - const unsigned = deviceResult.unsigned || {}; - const signatures = deviceResult.signatures || {}; - try { - await olmlib.verifySignature(olmDevice, deviceResult, userId, deviceId, signKey); - } catch (e) { - _logger.logger.warn("Unable to verify signature on device " + userId + ":" + deviceId + ":" + e); - return false; - } - - // DeviceInfo - let deviceStore; - if (deviceId in userStore) { - // already have this device. - deviceStore = userStore[deviceId]; - if (deviceStore.getFingerprint() != signKey) { - // this should only happen if the list has been MITMed; we are - // best off sticking with the original keys. - // - // Should we warn the user about it somehow? - _logger.logger.warn("Ed25519 key for device " + userId + ":" + deviceId + " has changed"); - return false; - } - } else { - userStore[deviceId] = deviceStore = new _deviceinfo.DeviceInfo(deviceId); - } - deviceStore.keys = deviceResult.keys || {}; - deviceStore.algorithms = deviceResult.algorithms || []; - deviceStore.unsigned = unsigned; - deviceStore.signatures = signatures; - return true; -} -//# sourceMappingURL=DeviceList.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js.map deleted file mode 100644 index 56c04c2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/DeviceList.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"DeviceList.js","names":["_logger","require","_deviceinfo","_CrossSigning","olmlib","_interopRequireWildcard","_indexeddbCryptoStore","_utils","_typedEventEmitter","_index","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","TrackingStatus","exports","DeviceList","TypedEventEmitter","constructor","baseApis","cryptoStore","olmDevice","keyDownloadChunkSize","_defineProperty2","Map","serialiser","DeviceListUpdateSerialiser","load","doTxn","IndexedDBCryptoStore","STORE_DEVICE_DATA","txn","getEndToEndDeviceData","deviceData","_deviceData$syncToken","hasFetched","Boolean","devices","crossSigningInfo","deviceTrackingStatus","trackingStatus","syncToken","userByIdentityKey","user","keys","userDevices","device","idKey","undefined","u","DownloadInProgress","PendingDownload","stop","saveTimer","clearTimeout","saveIfDirty","delay","dirty","Promise","resolve","targetTime","Date","now","savePromiseTime","savePromise","resolveSavePromise","setTimeout","logger","log","_this$syncToken","storeEndToEndDeviceData","then","err","error","getSyncToken","setSyncToken","st","downloadKeys","userIds","forceDownload","usersToDownload","promises","forEach","keyDownloadsInProgressByUser","push","UpToDate","length","downloadPromise","doKeyDownload","all","getDevicesFromStore","stored","userId","_this$getStoredDevice","deviceMap","getStoredDevicesForUser","deviceId","getKnownUserIds","devs","res","DeviceInfo","fromStorage","getRawStoredDevicesForUser","getStoredCrossSigningForUser","CrossSigningInfo","storeCrossSigningForUser","info","getStoredDevice","getUserByIdentityKey","algorithm","senderKey","OLM_ALGORITHM","MEGOLM_ALGORITHM","getDeviceByIdentityKey","keyId","indexOf","deviceKey","storeDevicesForUser","setRawStoredDevicesForUser","startTrackingDeviceList","Error","stopTrackingDeviceList","NotTracked","stopTrackingAllDeviceLists","invalidateUserDeviceList","refreshOutdatedDeviceLists","stat","dev","entries","identityKey","setRawStoredCrossSigningForUser","users","prom","updateDevicesForUsers","finished","e","success","emit","CryptoEvent","WillUpdateDevices","delete","DevicesUpdated","deviceList","keyDownloadsQueuedByUser","queuedQueryDeferred","defer","downloadInProgress","promise","doQueuedQueries","downloadUsers","deferred","opts","token","factories","i","userSlice","slice","downloadKeysForUsers","chunkPromises","responses","dk","assign","map","device_keys","masterKeys","master_keys","ssks","self_signing_keys","usks","user_signing_keys","sleep","processQueryResponseForUser","master","self_signing","user_signing","warn","reject","dkResponse","crossSigningResponse","userStore","d","updateStoredDeviceKeysForUser","getUserId","storage","toStorage","crossSigning","setKeys","UserCrossSigningUpdated","userResult","localUserId","localDeviceId","updated","deviceResult","user_id","device_id","storeDeviceKeys","signKeyId","signKey","unsigned","signatures","verifySignature","deviceStore","getFingerprint","algorithms"],"sources":["../../src/crypto/DeviceList.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Manages the list of other users' devices\n */\n\nimport { logger } from \"../logger\";\nimport { DeviceInfo, IDevice } from \"./deviceinfo\";\nimport { CrossSigningInfo, ICrossSigningInfo } from \"./CrossSigning\";\nimport * as olmlib from \"./olmlib\";\nimport { IndexedDBCryptoStore } from \"./store/indexeddb-crypto-store\";\nimport { chunkPromises, defer, IDeferred, sleep } from \"../utils\";\nimport { DeviceKeys, IDownloadKeyResult, Keys, MatrixClient, SigningKeys } from \"../client\";\nimport { OlmDevice } from \"./OlmDevice\";\nimport { CryptoStore } from \"./store/base\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { CryptoEvent, CryptoEventHandlerMap } from \"./index\";\n\n/* State transition diagram for DeviceList.deviceTrackingStatus\n *\n * |\n * stopTrackingDeviceList V\n * +---------------------> NOT_TRACKED\n * | |\n * +<--------------------+ | startTrackingDeviceList\n * | | V\n * | +-------------> PENDING_DOWNLOAD <--------------------+-+\n * | | ^ | | |\n * | | restart download | | start download | | invalidateUserDeviceList\n * | | client failed | | | |\n * | | | V | |\n * | +------------ DOWNLOAD_IN_PROGRESS -------------------+ |\n * | | | |\n * +<-------------------+ | download successful |\n * ^ V |\n * +----------------------- UP_TO_DATE ------------------------+\n */\n\n// constants for DeviceList.deviceTrackingStatus\nexport enum TrackingStatus {\n NotTracked,\n PendingDownload,\n DownloadInProgress,\n UpToDate,\n}\n\n// user-Id → device-Id → DeviceInfo\nexport type DeviceInfoMap = Map>;\n\ntype EmittedEvents = CryptoEvent.WillUpdateDevices | CryptoEvent.DevicesUpdated | CryptoEvent.UserCrossSigningUpdated;\n\nexport class DeviceList extends TypedEventEmitter {\n private devices: { [userId: string]: { [deviceId: string]: IDevice } } = {};\n\n public crossSigningInfo: { [userId: string]: ICrossSigningInfo } = {};\n\n // map of identity keys to the user who owns it\n private userByIdentityKey: Record = {};\n\n // which users we are tracking device status for.\n private deviceTrackingStatus: { [userId: string]: TrackingStatus } = {}; // loaded from storage in load()\n\n // The 'next_batch' sync token at the point the data was written,\n // ie. a token representing the point immediately after the\n // moment represented by the snapshot in the db.\n private syncToken: string | null = null;\n\n private keyDownloadsInProgressByUser = new Map>();\n\n // Set whenever changes are made other than setting the sync token\n private dirty = false;\n\n // Promise resolved when device data is saved\n private savePromise: Promise | null = null;\n // Function that resolves the save promise\n private resolveSavePromise: ((saved: boolean) => void) | null = null;\n // The time the save is scheduled for\n private savePromiseTime: number | null = null;\n // The timer used to delay the save\n private saveTimer: ReturnType | null = null;\n // True if we have fetched data from the server or loaded a non-empty\n // set of device data from the store\n private hasFetched: boolean | null = null;\n\n private readonly serialiser: DeviceListUpdateSerialiser;\n\n public constructor(\n baseApis: MatrixClient,\n private readonly cryptoStore: CryptoStore,\n olmDevice: OlmDevice,\n // Maximum number of user IDs per request to prevent server overload (#1619)\n public readonly keyDownloadChunkSize = 250,\n ) {\n super();\n\n this.serialiser = new DeviceListUpdateSerialiser(baseApis, olmDevice, this);\n }\n\n /**\n * Load the device tracking state from storage\n */\n public async load(): Promise {\n await this.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_DEVICE_DATA], (txn) => {\n this.cryptoStore.getEndToEndDeviceData(txn, (deviceData) => {\n this.hasFetched = Boolean(deviceData && deviceData.devices);\n this.devices = deviceData ? deviceData.devices : {};\n this.crossSigningInfo = deviceData ? deviceData.crossSigningInfo || {} : {};\n this.deviceTrackingStatus = deviceData ? deviceData.trackingStatus : {};\n this.syncToken = deviceData?.syncToken ?? null;\n this.userByIdentityKey = {};\n for (const user of Object.keys(this.devices)) {\n const userDevices = this.devices[user];\n for (const device of Object.keys(userDevices)) {\n const idKey = userDevices[device].keys[\"curve25519:\" + device];\n if (idKey !== undefined) {\n this.userByIdentityKey[idKey] = user;\n }\n }\n }\n });\n });\n\n for (const u of Object.keys(this.deviceTrackingStatus)) {\n // if a download was in progress when we got shut down, it isn't any more.\n if (this.deviceTrackingStatus[u] == TrackingStatus.DownloadInProgress) {\n this.deviceTrackingStatus[u] = TrackingStatus.PendingDownload;\n }\n }\n }\n\n public stop(): void {\n if (this.saveTimer !== null) {\n clearTimeout(this.saveTimer);\n }\n }\n\n /**\n * Save the device tracking state to storage, if any changes are\n * pending other than updating the sync token\n *\n * The actual save will be delayed by a short amount of time to\n * aggregate multiple writes to the database.\n *\n * @param delay - Time in ms before which the save actually happens.\n * By default, the save is delayed for a short period in order to batch\n * multiple writes, but this behaviour can be disabled by passing 0.\n *\n * @returns true if the data was saved, false if\n * it was not (eg. because no changes were pending). The promise\n * will only resolve once the data is saved, so may take some time\n * to resolve.\n */\n public async saveIfDirty(delay = 500): Promise {\n if (!this.dirty) return Promise.resolve(false);\n // Delay saves for a bit so we can aggregate multiple saves that happen\n // in quick succession (eg. when a whole room's devices are marked as known)\n\n const targetTime = Date.now() + delay;\n if (this.savePromiseTime && targetTime < this.savePromiseTime) {\n // There's a save scheduled but for after we would like: cancel\n // it & schedule one for the time we want\n clearTimeout(this.saveTimer!);\n this.saveTimer = null;\n this.savePromiseTime = null;\n // (but keep the save promise since whatever called save before\n // will still want to know when the save is done)\n }\n\n let savePromise = this.savePromise;\n if (savePromise === null) {\n savePromise = new Promise((resolve) => {\n this.resolveSavePromise = resolve;\n });\n this.savePromise = savePromise;\n }\n\n if (this.saveTimer === null) {\n const resolveSavePromise = this.resolveSavePromise;\n this.savePromiseTime = targetTime;\n this.saveTimer = setTimeout(() => {\n logger.log(\"Saving device tracking data\", this.syncToken);\n\n // null out savePromise now (after the delay but before the write),\n // otherwise we could return the existing promise when the save has\n // actually already happened.\n this.savePromiseTime = null;\n this.saveTimer = null;\n this.savePromise = null;\n this.resolveSavePromise = null;\n\n this.cryptoStore\n .doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_DEVICE_DATA], (txn) => {\n this.cryptoStore.storeEndToEndDeviceData(\n {\n devices: this.devices,\n crossSigningInfo: this.crossSigningInfo,\n trackingStatus: this.deviceTrackingStatus,\n syncToken: this.syncToken ?? undefined,\n },\n txn,\n );\n })\n .then(\n () => {\n // The device list is considered dirty until the write completes.\n this.dirty = false;\n resolveSavePromise?.(true);\n },\n (err) => {\n logger.error(\"Failed to save device tracking data\", this.syncToken);\n logger.error(err);\n },\n );\n }, delay);\n }\n\n return savePromise;\n }\n\n /**\n * Gets the sync token last set with setSyncToken\n *\n * @returns The sync token\n */\n public getSyncToken(): string | null {\n return this.syncToken;\n }\n\n /**\n * Sets the sync token that the app will pass as the 'since' to the /sync\n * endpoint next time it syncs.\n * The sync token must always be set after any changes made as a result of\n * data in that sync since setting the sync token to a newer one will mean\n * those changed will not be synced from the server if a new client starts\n * up with that data.\n *\n * @param st - The sync token\n */\n public setSyncToken(st: string | null): void {\n this.syncToken = st;\n }\n\n /**\n * Ensures up to date keys for a list of users are stored in the session store,\n * downloading and storing them if they're not (or if forceDownload is\n * true).\n * @param userIds - The users to fetch.\n * @param forceDownload - Always download the keys even if cached.\n *\n * @returns A promise which resolves to a map userId-\\>deviceId-\\>{@link DeviceInfo}.\n */\n public downloadKeys(userIds: string[], forceDownload: boolean): Promise {\n const usersToDownload: string[] = [];\n const promises: Promise[] = [];\n\n userIds.forEach((u) => {\n const trackingStatus = this.deviceTrackingStatus[u];\n if (this.keyDownloadsInProgressByUser.has(u)) {\n // already a key download in progress/queued for this user; its results\n // will be good enough for us.\n logger.log(`downloadKeys: already have a download in progress for ` + `${u}: awaiting its result`);\n promises.push(this.keyDownloadsInProgressByUser.get(u)!);\n } else if (forceDownload || trackingStatus != TrackingStatus.UpToDate) {\n usersToDownload.push(u);\n }\n });\n\n if (usersToDownload.length != 0) {\n logger.log(\"downloadKeys: downloading for\", usersToDownload);\n const downloadPromise = this.doKeyDownload(usersToDownload);\n promises.push(downloadPromise);\n }\n\n if (promises.length === 0) {\n logger.log(\"downloadKeys: already have all necessary keys\");\n }\n\n return Promise.all(promises).then(() => {\n return this.getDevicesFromStore(userIds);\n });\n }\n\n /**\n * Get the stored device keys for a list of user ids\n *\n * @param userIds - the list of users to list keys for.\n *\n * @returns userId-\\>deviceId-\\>{@link DeviceInfo}.\n */\n private getDevicesFromStore(userIds: string[]): DeviceInfoMap {\n const stored: DeviceInfoMap = new Map();\n userIds.forEach((userId) => {\n const deviceMap = new Map();\n this.getStoredDevicesForUser(userId)?.forEach(function (device) {\n deviceMap.set(device.deviceId, device);\n });\n stored.set(userId, deviceMap);\n });\n return stored;\n }\n\n /**\n * Returns a list of all user IDs the DeviceList knows about\n *\n * @returns All known user IDs\n */\n public getKnownUserIds(): string[] {\n return Object.keys(this.devices);\n }\n\n /**\n * Get the stored device keys for a user id\n *\n * @param userId - the user to list keys for.\n *\n * @returns list of devices, or null if we haven't\n * managed to get a list of devices for this user yet.\n */\n public getStoredDevicesForUser(userId: string): DeviceInfo[] | null {\n const devs = this.devices[userId];\n if (!devs) {\n return null;\n }\n const res: DeviceInfo[] = [];\n for (const deviceId in devs) {\n if (devs.hasOwnProperty(deviceId)) {\n res.push(DeviceInfo.fromStorage(devs[deviceId], deviceId));\n }\n }\n return res;\n }\n\n /**\n * Get the stored device data for a user, in raw object form\n *\n * @param userId - the user to get data for\n *\n * @returns `deviceId->{object}` devices, or undefined if\n * there is no data for this user.\n */\n public getRawStoredDevicesForUser(userId: string): Record {\n return this.devices[userId];\n }\n\n public getStoredCrossSigningForUser(userId: string): CrossSigningInfo | null {\n if (!this.crossSigningInfo[userId]) return null;\n\n return CrossSigningInfo.fromStorage(this.crossSigningInfo[userId], userId);\n }\n\n public storeCrossSigningForUser(userId: string, info: ICrossSigningInfo): void {\n this.crossSigningInfo[userId] = info;\n this.dirty = true;\n }\n\n /**\n * Get the stored keys for a single device\n *\n *\n * @returns device, or undefined\n * if we don't know about this device\n */\n public getStoredDevice(userId: string, deviceId: string): DeviceInfo | undefined {\n const devs = this.devices[userId];\n if (!devs?.[deviceId]) {\n return undefined;\n }\n return DeviceInfo.fromStorage(devs[deviceId], deviceId);\n }\n\n /**\n * Get a user ID by one of their device's curve25519 identity key\n *\n * @param algorithm - encryption algorithm\n * @param senderKey - curve25519 key to match\n *\n * @returns user ID\n */\n public getUserByIdentityKey(algorithm: string, senderKey: string): string | null {\n if (algorithm !== olmlib.OLM_ALGORITHM && algorithm !== olmlib.MEGOLM_ALGORITHM) {\n // we only deal in olm keys\n return null;\n }\n\n return this.userByIdentityKey[senderKey];\n }\n\n /**\n * Find a device by curve25519 identity key\n *\n * @param algorithm - encryption algorithm\n * @param senderKey - curve25519 key to match\n */\n public getDeviceByIdentityKey(algorithm: string, senderKey: string): DeviceInfo | null {\n const userId = this.getUserByIdentityKey(algorithm, senderKey);\n if (!userId) {\n return null;\n }\n\n const devices = this.devices[userId];\n if (!devices) {\n return null;\n }\n\n for (const deviceId in devices) {\n if (!devices.hasOwnProperty(deviceId)) {\n continue;\n }\n\n const device = devices[deviceId];\n for (const keyId in device.keys) {\n if (!device.keys.hasOwnProperty(keyId)) {\n continue;\n }\n if (keyId.indexOf(\"curve25519:\") !== 0) {\n continue;\n }\n const deviceKey = device.keys[keyId];\n if (deviceKey == senderKey) {\n return DeviceInfo.fromStorage(device, deviceId);\n }\n }\n }\n\n // doesn't match a known device\n return null;\n }\n\n /**\n * Replaces the list of devices for a user with the given device list\n *\n * @param userId - The user ID\n * @param devices - New device info for user\n */\n public storeDevicesForUser(userId: string, devices: Record): void {\n this.setRawStoredDevicesForUser(userId, devices);\n this.dirty = true;\n }\n\n /**\n * flag the given user for device-list tracking, if they are not already.\n *\n * This will mean that a subsequent call to refreshOutdatedDeviceLists()\n * will download the device list for the user, and that subsequent calls to\n * invalidateUserDeviceList will trigger more updates.\n *\n */\n public startTrackingDeviceList(userId: string): void {\n // sanity-check the userId. This is mostly paranoia, but if synapse\n // can't parse the userId we give it as an mxid, it 500s the whole\n // request and we can never update the device lists again (because\n // the broken userId is always 'invalid' and always included in any\n // refresh request).\n // By checking it is at least a string, we can eliminate a class of\n // silly errors.\n if (typeof userId !== \"string\") {\n throw new Error(\"userId must be a string; was \" + userId);\n }\n if (!this.deviceTrackingStatus[userId]) {\n logger.log(\"Now tracking device list for \" + userId);\n this.deviceTrackingStatus[userId] = TrackingStatus.PendingDownload;\n // we don't yet persist the tracking status, since there may be a lot\n // of calls; we save all data together once the sync is done\n this.dirty = true;\n }\n }\n\n /**\n * Mark the given user as no longer being tracked for device-list updates.\n *\n * This won't affect any in-progress downloads, which will still go on to\n * complete; it will just mean that we don't think that we have an up-to-date\n * list for future calls to downloadKeys.\n *\n */\n public stopTrackingDeviceList(userId: string): void {\n if (this.deviceTrackingStatus[userId]) {\n logger.log(\"No longer tracking device list for \" + userId);\n this.deviceTrackingStatus[userId] = TrackingStatus.NotTracked;\n\n // we don't yet persist the tracking status, since there may be a lot\n // of calls; we save all data together once the sync is done\n this.dirty = true;\n }\n }\n\n /**\n * Set all users we're currently tracking to untracked\n *\n * This will flag each user whose devices we are tracking as in need of an\n * update.\n */\n public stopTrackingAllDeviceLists(): void {\n for (const userId of Object.keys(this.deviceTrackingStatus)) {\n this.deviceTrackingStatus[userId] = TrackingStatus.NotTracked;\n }\n this.dirty = true;\n }\n\n /**\n * Mark the cached device list for the given user outdated.\n *\n * If we are not tracking this user's devices, we'll do nothing. Otherwise\n * we flag the user as needing an update.\n *\n * This doesn't actually set off an update, so that several users can be\n * batched together. Call refreshOutdatedDeviceLists() for that.\n *\n */\n public invalidateUserDeviceList(userId: string): void {\n if (this.deviceTrackingStatus[userId]) {\n logger.log(\"Marking device list outdated for\", userId);\n this.deviceTrackingStatus[userId] = TrackingStatus.PendingDownload;\n\n // we don't yet persist the tracking status, since there may be a lot\n // of calls; we save all data together once the sync is done\n this.dirty = true;\n }\n }\n\n /**\n * If we have users who have outdated device lists, start key downloads for them\n *\n * @returns which completes when the download completes; normally there\n * is no need to wait for this (it's mostly for the unit tests).\n */\n public refreshOutdatedDeviceLists(): Promise {\n this.saveIfDirty();\n\n const usersToDownload: string[] = [];\n for (const userId of Object.keys(this.deviceTrackingStatus)) {\n const stat = this.deviceTrackingStatus[userId];\n if (stat == TrackingStatus.PendingDownload) {\n usersToDownload.push(userId);\n }\n }\n\n return this.doKeyDownload(usersToDownload);\n }\n\n /**\n * Set the stored device data for a user, in raw object form\n * Used only by internal class DeviceListUpdateSerialiser\n *\n * @param userId - the user to get data for\n *\n * @param devices - `deviceId->{object}` the new devices\n */\n public setRawStoredDevicesForUser(userId: string, devices: Record): void {\n // remove old devices from userByIdentityKey\n if (this.devices[userId] !== undefined) {\n for (const [deviceId, dev] of Object.entries(this.devices[userId])) {\n const identityKey = dev.keys[\"curve25519:\" + deviceId];\n\n delete this.userByIdentityKey[identityKey];\n }\n }\n\n this.devices[userId] = devices;\n\n // add new devices into userByIdentityKey\n for (const [deviceId, dev] of Object.entries(devices)) {\n const identityKey = dev.keys[\"curve25519:\" + deviceId];\n\n this.userByIdentityKey[identityKey] = userId;\n }\n }\n\n public setRawStoredCrossSigningForUser(userId: string, info: ICrossSigningInfo): void {\n this.crossSigningInfo[userId] = info;\n }\n\n /**\n * Fire off download update requests for the given users, and update the\n * device list tracking status for them, and the\n * keyDownloadsInProgressByUser map for them.\n *\n * @param users - list of userIds\n *\n * @returns resolves when all the users listed have\n * been updated. rejects if there was a problem updating any of the\n * users.\n */\n private doKeyDownload(users: string[]): Promise {\n if (users.length === 0) {\n // nothing to do\n return Promise.resolve();\n }\n\n const prom = this.serialiser.updateDevicesForUsers(users, this.syncToken!).then(\n () => {\n finished(true);\n },\n (e) => {\n logger.error(\"Error downloading keys for \" + users + \":\", e);\n finished(false);\n throw e;\n },\n );\n\n users.forEach((u) => {\n this.keyDownloadsInProgressByUser.set(u, prom);\n const stat = this.deviceTrackingStatus[u];\n if (stat == TrackingStatus.PendingDownload) {\n this.deviceTrackingStatus[u] = TrackingStatus.DownloadInProgress;\n }\n });\n\n const finished = (success: boolean): void => {\n this.emit(CryptoEvent.WillUpdateDevices, users, !this.hasFetched);\n users.forEach((u) => {\n this.dirty = true;\n\n // we may have queued up another download request for this user\n // since we started this request. If that happens, we should\n // ignore the completion of the first one.\n if (this.keyDownloadsInProgressByUser.get(u) !== prom) {\n logger.log(\"Another update in the queue for\", u, \"- not marking up-to-date\");\n return;\n }\n this.keyDownloadsInProgressByUser.delete(u);\n const stat = this.deviceTrackingStatus[u];\n if (stat == TrackingStatus.DownloadInProgress) {\n if (success) {\n // we didn't get any new invalidations since this download started:\n // this user's device list is now up to date.\n this.deviceTrackingStatus[u] = TrackingStatus.UpToDate;\n logger.log(\"Device list for\", u, \"now up to date\");\n } else {\n this.deviceTrackingStatus[u] = TrackingStatus.PendingDownload;\n }\n }\n });\n this.saveIfDirty();\n this.emit(CryptoEvent.DevicesUpdated, users, !this.hasFetched);\n this.hasFetched = true;\n };\n\n return prom;\n }\n}\n\n/**\n * Serialises updates to device lists\n *\n * Ensures that results from /keys/query are not overwritten if a second call\n * completes *before* an earlier one.\n *\n * It currently does this by ensuring only one call to /keys/query happens at a\n * time (and queuing other requests up).\n */\nclass DeviceListUpdateSerialiser {\n private downloadInProgress = false;\n\n // users which are queued for download\n // userId -> true\n private keyDownloadsQueuedByUser: Record = {};\n\n // deferred which is resolved when the queued users are downloaded.\n // non-null indicates that we have users queued for download.\n private queuedQueryDeferred?: IDeferred;\n\n private syncToken?: string; // The sync token we send with the requests\n\n /*\n * @param baseApis - Base API object\n * @param olmDevice - The Olm Device\n * @param deviceList - The device list object, the device list to be updated\n */\n public constructor(\n private readonly baseApis: MatrixClient,\n private readonly olmDevice: OlmDevice,\n private readonly deviceList: DeviceList,\n ) {}\n\n /**\n * Make a key query request for the given users\n *\n * @param users - list of user ids\n *\n * @param syncToken - sync token to pass in the query request, to\n * help the HS give the most recent results\n *\n * @returns resolves when all the users listed have\n * been updated. rejects if there was a problem updating any of the\n * users.\n */\n public updateDevicesForUsers(users: string[], syncToken: string): Promise {\n users.forEach((u) => {\n this.keyDownloadsQueuedByUser[u] = true;\n });\n\n if (!this.queuedQueryDeferred) {\n this.queuedQueryDeferred = defer();\n }\n\n // We always take the new sync token and just use the latest one we've\n // been given, since it just needs to be at least as recent as the\n // sync response the device invalidation message arrived in\n this.syncToken = syncToken;\n\n if (this.downloadInProgress) {\n // just queue up these users\n logger.log(\"Queued key download for\", users);\n return this.queuedQueryDeferred.promise;\n }\n\n // start a new download.\n return this.doQueuedQueries();\n }\n\n private doQueuedQueries(): Promise {\n if (this.downloadInProgress) {\n throw new Error(\"DeviceListUpdateSerialiser.doQueuedQueries called with request active\");\n }\n\n const downloadUsers = Object.keys(this.keyDownloadsQueuedByUser);\n this.keyDownloadsQueuedByUser = {};\n const deferred = this.queuedQueryDeferred;\n this.queuedQueryDeferred = undefined;\n\n logger.log(\"Starting key download for\", downloadUsers);\n this.downloadInProgress = true;\n\n const opts: Parameters[1] = {};\n if (this.syncToken) {\n opts.token = this.syncToken;\n }\n\n const factories: Array<() => Promise> = [];\n for (let i = 0; i < downloadUsers.length; i += this.deviceList.keyDownloadChunkSize) {\n const userSlice = downloadUsers.slice(i, i + this.deviceList.keyDownloadChunkSize);\n factories.push(() => this.baseApis.downloadKeysForUsers(userSlice, opts));\n }\n\n chunkPromises(factories, 3)\n .then(async (responses: IDownloadKeyResult[]) => {\n const dk: IDownloadKeyResult[\"device_keys\"] = Object.assign(\n {},\n ...responses.map((res) => res.device_keys || {}),\n );\n const masterKeys: IDownloadKeyResult[\"master_keys\"] = Object.assign(\n {},\n ...responses.map((res) => res.master_keys || {}),\n );\n const ssks: IDownloadKeyResult[\"self_signing_keys\"] = Object.assign(\n {},\n ...responses.map((res) => res.self_signing_keys || {}),\n );\n const usks: IDownloadKeyResult[\"user_signing_keys\"] = Object.assign(\n {},\n ...responses.map((res) => res.user_signing_keys || {}),\n );\n\n // yield to other things that want to execute in between users, to\n // avoid wedging the CPU\n // (https://github.com/vector-im/element-web/issues/3158)\n //\n // of course we ought to do this in a web worker or similar, but\n // this serves as an easy solution for now.\n for (const userId of downloadUsers) {\n await sleep(5);\n try {\n await this.processQueryResponseForUser(userId, dk[userId], {\n master: masterKeys?.[userId],\n self_signing: ssks?.[userId],\n user_signing: usks?.[userId],\n });\n } catch (e) {\n // log the error but continue, so that one bad key\n // doesn't kill the whole process\n logger.error(`Error processing keys for ${userId}:`, e);\n }\n }\n })\n .then(\n () => {\n logger.log(\"Completed key download for \" + downloadUsers);\n\n this.downloadInProgress = false;\n deferred?.resolve();\n\n // if we have queued users, fire off another request.\n if (this.queuedQueryDeferred) {\n this.doQueuedQueries();\n }\n },\n (e) => {\n logger.warn(\"Error downloading keys for \" + downloadUsers + \":\", e);\n this.downloadInProgress = false;\n deferred?.reject(e);\n },\n );\n\n return deferred!.promise;\n }\n\n private async processQueryResponseForUser(\n userId: string,\n dkResponse: DeviceKeys,\n crossSigningResponse: {\n master?: Keys;\n self_signing?: SigningKeys;\n user_signing?: SigningKeys;\n },\n ): Promise {\n logger.log(\"got device keys for \" + userId + \":\", dkResponse);\n logger.log(\"got cross-signing keys for \" + userId + \":\", crossSigningResponse);\n\n {\n // map from deviceid -> deviceinfo for this user\n const userStore: Record = {};\n const devs = this.deviceList.getRawStoredDevicesForUser(userId);\n if (devs) {\n Object.keys(devs).forEach((deviceId) => {\n const d = DeviceInfo.fromStorage(devs[deviceId], deviceId);\n userStore[deviceId] = d;\n });\n }\n\n await updateStoredDeviceKeysForUser(\n this.olmDevice,\n userId,\n userStore,\n dkResponse || {},\n this.baseApis.getUserId()!,\n this.baseApis.deviceId!,\n );\n\n // put the updates into the object that will be returned as our results\n const storage: Record = {};\n Object.keys(userStore).forEach((deviceId) => {\n storage[deviceId] = userStore[deviceId].toStorage();\n });\n\n this.deviceList.setRawStoredDevicesForUser(userId, storage);\n }\n\n // now do the same for the cross-signing keys\n {\n // FIXME: should we be ignoring empty cross-signing responses, or\n // should we be dropping the keys?\n if (\n crossSigningResponse &&\n (crossSigningResponse.master || crossSigningResponse.self_signing || crossSigningResponse.user_signing)\n ) {\n const crossSigning =\n this.deviceList.getStoredCrossSigningForUser(userId) || new CrossSigningInfo(userId);\n\n crossSigning.setKeys(crossSigningResponse);\n\n this.deviceList.setRawStoredCrossSigningForUser(userId, crossSigning.toStorage());\n\n // NB. Unlike most events in the js-sdk, this one is internal to the\n // js-sdk and is not re-emitted\n this.deviceList.emit(CryptoEvent.UserCrossSigningUpdated, userId);\n }\n }\n }\n}\n\nasync function updateStoredDeviceKeysForUser(\n olmDevice: OlmDevice,\n userId: string,\n userStore: Record,\n userResult: IDownloadKeyResult[\"device_keys\"][\"user_id\"],\n localUserId: string,\n localDeviceId: string,\n): Promise {\n let updated = false;\n\n // remove any devices in the store which aren't in the response\n for (const deviceId in userStore) {\n if (!userStore.hasOwnProperty(deviceId)) {\n continue;\n }\n\n if (!(deviceId in userResult)) {\n if (userId === localUserId && deviceId === localDeviceId) {\n logger.warn(`Local device ${deviceId} missing from sync, skipping removal`);\n continue;\n }\n\n logger.log(\"Device \" + userId + \":\" + deviceId + \" has been removed\");\n delete userStore[deviceId];\n updated = true;\n }\n }\n\n for (const deviceId in userResult) {\n if (!userResult.hasOwnProperty(deviceId)) {\n continue;\n }\n\n const deviceResult = userResult[deviceId];\n\n // check that the user_id and device_id in the response object are\n // correct\n if (deviceResult.user_id !== userId) {\n logger.warn(\"Mismatched user_id \" + deviceResult.user_id + \" in keys from \" + userId + \":\" + deviceId);\n continue;\n }\n if (deviceResult.device_id !== deviceId) {\n logger.warn(\"Mismatched device_id \" + deviceResult.device_id + \" in keys from \" + userId + \":\" + deviceId);\n continue;\n }\n\n if (await storeDeviceKeys(olmDevice, userStore, deviceResult)) {\n updated = true;\n }\n }\n\n return updated;\n}\n\n/*\n * Process a device in a /query response, and add it to the userStore\n *\n * returns (a promise for) true if a change was made, else false\n */\nasync function storeDeviceKeys(\n olmDevice: OlmDevice,\n userStore: Record,\n deviceResult: IDownloadKeyResult[\"device_keys\"][\"user_id\"][\"device_id\"],\n): Promise {\n if (!deviceResult.keys) {\n // no keys?\n return false;\n }\n\n const deviceId = deviceResult.device_id;\n const userId = deviceResult.user_id;\n\n const signKeyId = \"ed25519:\" + deviceId;\n const signKey = deviceResult.keys[signKeyId];\n if (!signKey) {\n logger.warn(\"Device \" + userId + \":\" + deviceId + \" has no ed25519 key\");\n return false;\n }\n\n const unsigned = deviceResult.unsigned || {};\n const signatures = deviceResult.signatures || {};\n\n try {\n await olmlib.verifySignature(olmDevice, deviceResult, userId, deviceId, signKey);\n } catch (e) {\n logger.warn(\"Unable to verify signature on device \" + userId + \":\" + deviceId + \":\" + e);\n return false;\n }\n\n // DeviceInfo\n let deviceStore;\n\n if (deviceId in userStore) {\n // already have this device.\n deviceStore = userStore[deviceId];\n\n if (deviceStore.getFingerprint() != signKey) {\n // this should only happen if the list has been MITMed; we are\n // best off sticking with the original keys.\n //\n // Should we warn the user about it somehow?\n logger.warn(\"Ed25519 key for device \" + userId + \":\" + deviceId + \" has changed\");\n return false;\n }\n } else {\n userStore[deviceId] = deviceStore = new DeviceInfo(deviceId);\n }\n\n deviceStore.keys = deviceResult.keys || {};\n deviceStore.algorithms = deviceResult.algorithms || [];\n deviceStore.unsigned = unsigned;\n deviceStore.signatures = signatures;\n return true;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts deleted file mode 100644 index 30fd408..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts +++ /dev/null @@ -1,150 +0,0 @@ -import { IContent, MatrixEvent } from "../models/event"; -import { ICacheCallbacks } from "./CrossSigning"; -import { Crypto, ICryptoCallbacks, IBootstrapCrossSigningOpts } from "./index"; -import { ClientEvent, ClientEventHandlerMap, ICrossSigningKey, ISignedKey, KeySignatures } from "../client"; -import { IKeyBackupInfo } from "./keybackup"; -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { IAccountDataClient } from "./SecretStorage"; -import { SecretStorageKeyDescription } from "../secret-storage"; -interface ICrossSigningKeys { - authUpload: IBootstrapCrossSigningOpts["authUploadDeviceSigningKeys"]; - keys: Record<"master" | "self_signing" | "user_signing", ICrossSigningKey>; -} -/** - * Builds an EncryptionSetupOperation by calling any of the add.. methods. - * Once done, `buildOperation()` can be called which allows to apply to operation. - * - * This is used as a helper by Crypto to keep track of all the network requests - * and other side-effects of bootstrapping, so it can be applied in one go (and retried in the future) - * Also keeps track of all the private keys created during bootstrapping, so we don't need to prompt for them - * more than once. - */ -export declare class EncryptionSetupBuilder { - readonly accountDataClientAdapter: AccountDataClientAdapter; - readonly crossSigningCallbacks: CrossSigningCallbacks; - readonly ssssCryptoCallbacks: SSSSCryptoCallbacks; - private crossSigningKeys?; - private keySignatures?; - private keyBackupInfo?; - private sessionBackupPrivateKey?; - /** - * @param accountData - pre-existing account data, will only be read, not written. - * @param delegateCryptoCallbacks - crypto callbacks to delegate to if the key isn't in cache yet - */ - constructor(accountData: Map, delegateCryptoCallbacks?: ICryptoCallbacks); - /** - * Adds new cross-signing public keys - * - * @param authUpload - Function called to await an interactive auth - * flow when uploading device signing keys. - * Args: - * A function that makes the request requiring auth. Receives - * the auth data as an object. Can be called multiple times, first with - * an empty authDict, to obtain the flows. - * @param keys - the new keys - */ - addCrossSigningKeys(authUpload: ICrossSigningKeys["authUpload"], keys: ICrossSigningKeys["keys"]): void; - /** - * Adds the key backup info to be updated on the server - * - * Used either to create a new key backup, or add signatures - * from the new MSK. - * - * @param keyBackupInfo - as received from/sent to the server - */ - addSessionBackup(keyBackupInfo: IKeyBackupInfo): void; - /** - * Adds the session backup private key to be updated in the local cache - * - * Used after fixing the format of the key - * - */ - addSessionBackupPrivateKeyToCache(privateKey: Uint8Array): void; - /** - * Add signatures from a given user and device/x-sign key - * Used to sign the new cross-signing key with the device key - * - */ - addKeySignature(userId: string, deviceId: string, signature: ISignedKey): void; - setAccountData(type: string, content: object): Promise; - /** - * builds the operation containing all the parts that have been added to the builder - */ - buildOperation(): EncryptionSetupOperation; - /** - * Stores the created keys locally. - * - * This does not yet store the operation in a way that it can be restored, - * but that is the idea in the future. - */ - persist(crypto: Crypto): Promise; -} -/** - * Can be created from EncryptionSetupBuilder, or - * (in a follow-up PR, not implemented yet) restored from storage, to retry. - * - * It does not have knowledge of any private keys, unlike the builder. - */ -export declare class EncryptionSetupOperation { - private readonly accountData; - private readonly crossSigningKeys?; - private readonly keyBackupInfo?; - private readonly keySignatures?; - /** - */ - constructor(accountData: Map, crossSigningKeys?: ICrossSigningKeys | undefined, keyBackupInfo?: IKeyBackupInfo | undefined, keySignatures?: KeySignatures | undefined); - /** - * Runs the (remaining part of, in the future) operation by sending requests to the server. - */ - apply(crypto: Crypto): Promise; -} -/** - * Catches account data set by SecretStorage during bootstrapping by - * implementing the methods related to account data in MatrixClient - */ -declare class AccountDataClientAdapter extends TypedEventEmitter implements IAccountDataClient { - private readonly existingValues; - readonly values: Map; - /** - * @param existingValues - existing account data - */ - constructor(existingValues: Map); - /** - * @returns the content of the account data - */ - getAccountDataFromServer(type: string): Promise; - /** - * @returns the content of the account data - */ - getAccountData(type: string): IContent | null; - setAccountData(type: string, content: any): Promise<{}>; -} -/** - * Catches the private cross-signing keys set during bootstrapping - * by both cache callbacks (see createCryptoStoreCacheCallbacks) as non-cache callbacks. - * See CrossSigningInfo constructor - */ -declare class CrossSigningCallbacks implements ICryptoCallbacks, ICacheCallbacks { - readonly privateKeys: Map; - getCrossSigningKeyCache(type: string, expectedPublicKey: string): Promise; - storeCrossSigningKeyCache(type: string, key: Uint8Array): Promise; - getCrossSigningKey(type: string, expectedPubkey: string): Promise; - saveCrossSigningKeys(privateKeys: Record): void; -} -/** - * Catches the 4S private key set during bootstrapping by implementing - * the SecretStorage crypto callbacks - */ -declare class SSSSCryptoCallbacks { - private readonly delegateCryptoCallbacks?; - private readonly privateKeys; - constructor(delegateCryptoCallbacks?: ICryptoCallbacks | undefined); - getSecretStorageKey({ keys }: { - keys: Record; - }, name: string): Promise<[string, Uint8Array] | null>; - addPrivateKey(keyId: string, keyInfo: SecretStorageKeyDescription, privKey: Uint8Array): void; -} -export {}; -//# sourceMappingURL=EncryptionSetup.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts.map deleted file mode 100644 index b35bc8a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"EncryptionSetup.d.ts","sourceRoot":"","sources":["../../src/crypto/EncryptionSetup.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js deleted file mode 100644 index a0e98ca..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js +++ /dev/null @@ -1,350 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.EncryptionSetupOperation = exports.EncryptionSetupBuilder = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../logger"); -var _event = require("../models/event"); -var _CrossSigning = require("./CrossSigning"); -var _indexeddbCryptoStore = require("./store/indexeddb-crypto-store"); -var _httpApi = require("../http-api"); -var _client = require("../client"); -var _typedEventEmitter = require("../models/typed-event-emitter"); -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Builds an EncryptionSetupOperation by calling any of the add.. methods. - * Once done, `buildOperation()` can be called which allows to apply to operation. - * - * This is used as a helper by Crypto to keep track of all the network requests - * and other side-effects of bootstrapping, so it can be applied in one go (and retried in the future) - * Also keeps track of all the private keys created during bootstrapping, so we don't need to prompt for them - * more than once. - */ -class EncryptionSetupBuilder { - /** - * @param accountData - pre-existing account data, will only be read, not written. - * @param delegateCryptoCallbacks - crypto callbacks to delegate to if the key isn't in cache yet - */ - constructor(accountData, delegateCryptoCallbacks) { - (0, _defineProperty2.default)(this, "accountDataClientAdapter", void 0); - (0, _defineProperty2.default)(this, "crossSigningCallbacks", void 0); - (0, _defineProperty2.default)(this, "ssssCryptoCallbacks", void 0); - (0, _defineProperty2.default)(this, "crossSigningKeys", void 0); - (0, _defineProperty2.default)(this, "keySignatures", void 0); - (0, _defineProperty2.default)(this, "keyBackupInfo", void 0); - (0, _defineProperty2.default)(this, "sessionBackupPrivateKey", void 0); - this.accountDataClientAdapter = new AccountDataClientAdapter(accountData); - this.crossSigningCallbacks = new CrossSigningCallbacks(); - this.ssssCryptoCallbacks = new SSSSCryptoCallbacks(delegateCryptoCallbacks); - } - - /** - * Adds new cross-signing public keys - * - * @param authUpload - Function called to await an interactive auth - * flow when uploading device signing keys. - * Args: - * A function that makes the request requiring auth. Receives - * the auth data as an object. Can be called multiple times, first with - * an empty authDict, to obtain the flows. - * @param keys - the new keys - */ - addCrossSigningKeys(authUpload, keys) { - this.crossSigningKeys = { - authUpload, - keys - }; - } - - /** - * Adds the key backup info to be updated on the server - * - * Used either to create a new key backup, or add signatures - * from the new MSK. - * - * @param keyBackupInfo - as received from/sent to the server - */ - addSessionBackup(keyBackupInfo) { - this.keyBackupInfo = keyBackupInfo; - } - - /** - * Adds the session backup private key to be updated in the local cache - * - * Used after fixing the format of the key - * - */ - addSessionBackupPrivateKeyToCache(privateKey) { - this.sessionBackupPrivateKey = privateKey; - } - - /** - * Add signatures from a given user and device/x-sign key - * Used to sign the new cross-signing key with the device key - * - */ - addKeySignature(userId, deviceId, signature) { - if (!this.keySignatures) { - this.keySignatures = {}; - } - const userSignatures = this.keySignatures[userId] || {}; - this.keySignatures[userId] = userSignatures; - userSignatures[deviceId] = signature; - } - async setAccountData(type, content) { - await this.accountDataClientAdapter.setAccountData(type, content); - } - - /** - * builds the operation containing all the parts that have been added to the builder - */ - buildOperation() { - const accountData = this.accountDataClientAdapter.values; - return new EncryptionSetupOperation(accountData, this.crossSigningKeys, this.keyBackupInfo, this.keySignatures); - } - - /** - * Stores the created keys locally. - * - * This does not yet store the operation in a way that it can be restored, - * but that is the idea in the future. - */ - async persist(crypto) { - // store private keys in cache - if (this.crossSigningKeys) { - const cacheCallbacks = (0, _CrossSigning.createCryptoStoreCacheCallbacks)(crypto.cryptoStore, crypto.olmDevice); - for (const type of ["master", "self_signing", "user_signing"]) { - var _cacheCallbacks$store; - _logger.logger.log(`Cache ${type} cross-signing private key locally`); - const privateKey = this.crossSigningCallbacks.privateKeys.get(type); - await ((_cacheCallbacks$store = cacheCallbacks.storeCrossSigningKeyCache) === null || _cacheCallbacks$store === void 0 ? void 0 : _cacheCallbacks$store.call(cacheCallbacks, type, privateKey)); - } - // store own cross-sign pubkeys as trusted - await crypto.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - crypto.cryptoStore.storeCrossSigningKeys(txn, this.crossSigningKeys.keys); - }); - } - // store session backup key in cache - if (this.sessionBackupPrivateKey) { - await crypto.storeSessionBackupPrivateKey(this.sessionBackupPrivateKey); - } - } -} - -/** - * Can be created from EncryptionSetupBuilder, or - * (in a follow-up PR, not implemented yet) restored from storage, to retry. - * - * It does not have knowledge of any private keys, unlike the builder. - */ -exports.EncryptionSetupBuilder = EncryptionSetupBuilder; -class EncryptionSetupOperation { - /** - */ - constructor(accountData, crossSigningKeys, keyBackupInfo, keySignatures) { - this.accountData = accountData; - this.crossSigningKeys = crossSigningKeys; - this.keyBackupInfo = keyBackupInfo; - this.keySignatures = keySignatures; - } - - /** - * Runs the (remaining part of, in the future) operation by sending requests to the server. - */ - async apply(crypto) { - const baseApis = crypto.baseApis; - // upload cross-signing keys - if (this.crossSigningKeys) { - var _this$crossSigningKey, _this$crossSigningKey2; - const keys = {}; - for (const [name, key] of Object.entries(this.crossSigningKeys.keys)) { - keys[name + "_key"] = key; - } - - // We must only call `uploadDeviceSigningKeys` from inside this auth - // helper to ensure we properly handle auth errors. - await ((_this$crossSigningKey = (_this$crossSigningKey2 = this.crossSigningKeys).authUpload) === null || _this$crossSigningKey === void 0 ? void 0 : _this$crossSigningKey.call(_this$crossSigningKey2, authDict => { - return baseApis.uploadDeviceSigningKeys(authDict, keys); - })); - - // pass the new keys to the main instance of our own CrossSigningInfo. - crypto.crossSigningInfo.setKeys(this.crossSigningKeys.keys); - } - // set account data - if (this.accountData) { - for (const [type, content] of this.accountData) { - await baseApis.setAccountData(type, content); - } - } - // upload first cross-signing signatures with the new key - // (e.g. signing our own device) - if (this.keySignatures) { - await baseApis.uploadKeySignatures(this.keySignatures); - } - // need to create/update key backup info - if (this.keyBackupInfo) { - if (this.keyBackupInfo.version) { - // session backup signature - // The backup is trusted because the user provided the private key. - // Sign the backup with the cross signing key so the key backup can - // be trusted via cross-signing. - await baseApis.http.authedRequest(_httpApi.Method.Put, "/room_keys/version/" + this.keyBackupInfo.version, undefined, { - algorithm: this.keyBackupInfo.algorithm, - auth_data: this.keyBackupInfo.auth_data - }, { - prefix: _httpApi.ClientPrefix.V3 - }); - } else { - // add new key backup - await baseApis.http.authedRequest(_httpApi.Method.Post, "/room_keys/version", undefined, this.keyBackupInfo, { - prefix: _httpApi.ClientPrefix.V3 - }); - } - } - } -} - -/** - * Catches account data set by SecretStorage during bootstrapping by - * implementing the methods related to account data in MatrixClient - */ -exports.EncryptionSetupOperation = EncryptionSetupOperation; -class AccountDataClientAdapter extends _typedEventEmitter.TypedEventEmitter { - // - - /** - * @param existingValues - existing account data - */ - constructor(existingValues) { - super(); - this.existingValues = existingValues; - (0, _defineProperty2.default)(this, "values", new Map()); - } - - /** - * @returns the content of the account data - */ - getAccountDataFromServer(type) { - return Promise.resolve(this.getAccountData(type)); - } - - /** - * @returns the content of the account data - */ - getAccountData(type) { - const modifiedValue = this.values.get(type); - if (modifiedValue) { - return modifiedValue; - } - const existingValue = this.existingValues.get(type); - if (existingValue) { - return existingValue.getContent(); - } - return null; - } - setAccountData(type, content) { - const lastEvent = this.values.get(type); - this.values.set(type, content); - // ensure accountData is emitted on the next tick, - // as SecretStorage listens for it while calling this method - // and it seems to rely on this. - return Promise.resolve().then(() => { - const event = new _event.MatrixEvent({ - type, - content - }); - this.emit(_client.ClientEvent.AccountData, event, lastEvent); - return {}; - }); - } -} - -/** - * Catches the private cross-signing keys set during bootstrapping - * by both cache callbacks (see createCryptoStoreCacheCallbacks) as non-cache callbacks. - * See CrossSigningInfo constructor - */ -class CrossSigningCallbacks { - constructor() { - (0, _defineProperty2.default)(this, "privateKeys", new Map()); - } - // cache callbacks - getCrossSigningKeyCache(type, expectedPublicKey) { - return this.getCrossSigningKey(type, expectedPublicKey); - } - storeCrossSigningKeyCache(type, key) { - this.privateKeys.set(type, key); - return Promise.resolve(); - } - - // non-cache callbacks - getCrossSigningKey(type, expectedPubkey) { - var _this$privateKeys$get; - return Promise.resolve((_this$privateKeys$get = this.privateKeys.get(type)) !== null && _this$privateKeys$get !== void 0 ? _this$privateKeys$get : null); - } - saveCrossSigningKeys(privateKeys) { - for (const [type, privateKey] of Object.entries(privateKeys)) { - this.privateKeys.set(type, privateKey); - } - } -} - -/** - * Catches the 4S private key set during bootstrapping by implementing - * the SecretStorage crypto callbacks - */ -class SSSSCryptoCallbacks { - constructor(delegateCryptoCallbacks) { - this.delegateCryptoCallbacks = delegateCryptoCallbacks; - (0, _defineProperty2.default)(this, "privateKeys", new Map()); - } - async getSecretStorageKey({ - keys - }, name) { - var _this$delegateCryptoC; - for (const keyId of Object.keys(keys)) { - const privateKey = this.privateKeys.get(keyId); - if (privateKey) { - return [keyId, privateKey]; - } - } - // if we don't have the key cached yet, ask - // for it to the general crypto callbacks and cache it - if (this !== null && this !== void 0 && (_this$delegateCryptoC = this.delegateCryptoCallbacks) !== null && _this$delegateCryptoC !== void 0 && _this$delegateCryptoC.getSecretStorageKey) { - const result = await this.delegateCryptoCallbacks.getSecretStorageKey({ - keys - }, name); - if (result) { - const [keyId, privateKey] = result; - this.privateKeys.set(keyId, privateKey); - } - return result; - } - return null; - } - addPrivateKey(keyId, keyInfo, privKey) { - var _this$delegateCryptoC2, _this$delegateCryptoC3; - this.privateKeys.set(keyId, privKey); - // Also pass along to application to cache if it wishes - (_this$delegateCryptoC2 = this.delegateCryptoCallbacks) === null || _this$delegateCryptoC2 === void 0 ? void 0 : (_this$delegateCryptoC3 = _this$delegateCryptoC2.cacheSecretStorageKey) === null || _this$delegateCryptoC3 === void 0 ? void 0 : _this$delegateCryptoC3.call(_this$delegateCryptoC2, keyId, keyInfo, privKey); - } -} -//# sourceMappingURL=EncryptionSetup.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map deleted file mode 100644 index 9b80af9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"EncryptionSetup.js","names":["_logger","require","_event","_CrossSigning","_indexeddbCryptoStore","_httpApi","_client","_typedEventEmitter","EncryptionSetupBuilder","constructor","accountData","delegateCryptoCallbacks","_defineProperty2","default","accountDataClientAdapter","AccountDataClientAdapter","crossSigningCallbacks","CrossSigningCallbacks","ssssCryptoCallbacks","SSSSCryptoCallbacks","addCrossSigningKeys","authUpload","keys","crossSigningKeys","addSessionBackup","keyBackupInfo","addSessionBackupPrivateKeyToCache","privateKey","sessionBackupPrivateKey","addKeySignature","userId","deviceId","signature","keySignatures","userSignatures","setAccountData","type","content","buildOperation","values","EncryptionSetupOperation","persist","crypto","cacheCallbacks","createCryptoStoreCacheCallbacks","cryptoStore","olmDevice","_cacheCallbacks$store","logger","log","privateKeys","get","storeCrossSigningKeyCache","call","doTxn","IndexedDBCryptoStore","STORE_ACCOUNT","txn","storeCrossSigningKeys","storeSessionBackupPrivateKey","exports","apply","baseApis","_this$crossSigningKey","_this$crossSigningKey2","name","key","Object","entries","authDict","uploadDeviceSigningKeys","crossSigningInfo","setKeys","uploadKeySignatures","version","http","authedRequest","Method","Put","undefined","algorithm","auth_data","prefix","ClientPrefix","V3","Post","TypedEventEmitter","existingValues","Map","getAccountDataFromServer","Promise","resolve","getAccountData","modifiedValue","existingValue","getContent","lastEvent","set","then","event","MatrixEvent","emit","ClientEvent","AccountData","getCrossSigningKeyCache","expectedPublicKey","getCrossSigningKey","expectedPubkey","_this$privateKeys$get","saveCrossSigningKeys","getSecretStorageKey","_this$delegateCryptoC","keyId","result","addPrivateKey","keyInfo","privKey","_this$delegateCryptoC2","_this$delegateCryptoC3","cacheSecretStorageKey"],"sources":["../../src/crypto/EncryptionSetup.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../logger\";\nimport { IContent, MatrixEvent } from \"../models/event\";\nimport { createCryptoStoreCacheCallbacks, ICacheCallbacks } from \"./CrossSigning\";\nimport { IndexedDBCryptoStore } from \"./store/indexeddb-crypto-store\";\nimport { Method, ClientPrefix } from \"../http-api\";\nimport { Crypto, ICryptoCallbacks, IBootstrapCrossSigningOpts } from \"./index\";\nimport {\n ClientEvent,\n ClientEventHandlerMap,\n CrossSigningKeys,\n ICrossSigningKey,\n ISignedKey,\n KeySignatures,\n} from \"../client\";\nimport { IKeyBackupInfo } from \"./keybackup\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { IAccountDataClient } from \"./SecretStorage\";\nimport { SecretStorageKeyDescription } from \"../secret-storage\";\n\ninterface ICrossSigningKeys {\n authUpload: IBootstrapCrossSigningOpts[\"authUploadDeviceSigningKeys\"];\n keys: Record<\"master\" | \"self_signing\" | \"user_signing\", ICrossSigningKey>;\n}\n\n/**\n * Builds an EncryptionSetupOperation by calling any of the add.. methods.\n * Once done, `buildOperation()` can be called which allows to apply to operation.\n *\n * This is used as a helper by Crypto to keep track of all the network requests\n * and other side-effects of bootstrapping, so it can be applied in one go (and retried in the future)\n * Also keeps track of all the private keys created during bootstrapping, so we don't need to prompt for them\n * more than once.\n */\nexport class EncryptionSetupBuilder {\n public readonly accountDataClientAdapter: AccountDataClientAdapter;\n public readonly crossSigningCallbacks: CrossSigningCallbacks;\n public readonly ssssCryptoCallbacks: SSSSCryptoCallbacks;\n\n private crossSigningKeys?: ICrossSigningKeys;\n private keySignatures?: KeySignatures;\n private keyBackupInfo?: IKeyBackupInfo;\n private sessionBackupPrivateKey?: Uint8Array;\n\n /**\n * @param accountData - pre-existing account data, will only be read, not written.\n * @param delegateCryptoCallbacks - crypto callbacks to delegate to if the key isn't in cache yet\n */\n public constructor(accountData: Map, delegateCryptoCallbacks?: ICryptoCallbacks) {\n this.accountDataClientAdapter = new AccountDataClientAdapter(accountData);\n this.crossSigningCallbacks = new CrossSigningCallbacks();\n this.ssssCryptoCallbacks = new SSSSCryptoCallbacks(delegateCryptoCallbacks);\n }\n\n /**\n * Adds new cross-signing public keys\n *\n * @param authUpload - Function called to await an interactive auth\n * flow when uploading device signing keys.\n * Args:\n * A function that makes the request requiring auth. Receives\n * the auth data as an object. Can be called multiple times, first with\n * an empty authDict, to obtain the flows.\n * @param keys - the new keys\n */\n public addCrossSigningKeys(authUpload: ICrossSigningKeys[\"authUpload\"], keys: ICrossSigningKeys[\"keys\"]): void {\n this.crossSigningKeys = { authUpload, keys };\n }\n\n /**\n * Adds the key backup info to be updated on the server\n *\n * Used either to create a new key backup, or add signatures\n * from the new MSK.\n *\n * @param keyBackupInfo - as received from/sent to the server\n */\n public addSessionBackup(keyBackupInfo: IKeyBackupInfo): void {\n this.keyBackupInfo = keyBackupInfo;\n }\n\n /**\n * Adds the session backup private key to be updated in the local cache\n *\n * Used after fixing the format of the key\n *\n */\n public addSessionBackupPrivateKeyToCache(privateKey: Uint8Array): void {\n this.sessionBackupPrivateKey = privateKey;\n }\n\n /**\n * Add signatures from a given user and device/x-sign key\n * Used to sign the new cross-signing key with the device key\n *\n */\n public addKeySignature(userId: string, deviceId: string, signature: ISignedKey): void {\n if (!this.keySignatures) {\n this.keySignatures = {};\n }\n const userSignatures = this.keySignatures[userId] || {};\n this.keySignatures[userId] = userSignatures;\n userSignatures[deviceId] = signature;\n }\n\n public async setAccountData(type: string, content: object): Promise {\n await this.accountDataClientAdapter.setAccountData(type, content);\n }\n\n /**\n * builds the operation containing all the parts that have been added to the builder\n */\n public buildOperation(): EncryptionSetupOperation {\n const accountData = this.accountDataClientAdapter.values;\n return new EncryptionSetupOperation(accountData, this.crossSigningKeys, this.keyBackupInfo, this.keySignatures);\n }\n\n /**\n * Stores the created keys locally.\n *\n * This does not yet store the operation in a way that it can be restored,\n * but that is the idea in the future.\n */\n public async persist(crypto: Crypto): Promise {\n // store private keys in cache\n if (this.crossSigningKeys) {\n const cacheCallbacks = createCryptoStoreCacheCallbacks(crypto.cryptoStore, crypto.olmDevice);\n for (const type of [\"master\", \"self_signing\", \"user_signing\"]) {\n logger.log(`Cache ${type} cross-signing private key locally`);\n const privateKey = this.crossSigningCallbacks.privateKeys.get(type);\n await cacheCallbacks.storeCrossSigningKeyCache?.(type, privateKey);\n }\n // store own cross-sign pubkeys as trusted\n await crypto.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n crypto.cryptoStore.storeCrossSigningKeys(txn, this.crossSigningKeys!.keys);\n });\n }\n // store session backup key in cache\n if (this.sessionBackupPrivateKey) {\n await crypto.storeSessionBackupPrivateKey(this.sessionBackupPrivateKey);\n }\n }\n}\n\n/**\n * Can be created from EncryptionSetupBuilder, or\n * (in a follow-up PR, not implemented yet) restored from storage, to retry.\n *\n * It does not have knowledge of any private keys, unlike the builder.\n */\nexport class EncryptionSetupOperation {\n /**\n */\n public constructor(\n private readonly accountData: Map,\n private readonly crossSigningKeys?: ICrossSigningKeys,\n private readonly keyBackupInfo?: IKeyBackupInfo,\n private readonly keySignatures?: KeySignatures,\n ) {}\n\n /**\n * Runs the (remaining part of, in the future) operation by sending requests to the server.\n */\n public async apply(crypto: Crypto): Promise {\n const baseApis = crypto.baseApis;\n // upload cross-signing keys\n if (this.crossSigningKeys) {\n const keys: Partial = {};\n for (const [name, key] of Object.entries(this.crossSigningKeys.keys)) {\n keys[((name as keyof ICrossSigningKeys[\"keys\"]) + \"_key\") as keyof CrossSigningKeys] = key;\n }\n\n // We must only call `uploadDeviceSigningKeys` from inside this auth\n // helper to ensure we properly handle auth errors.\n await this.crossSigningKeys.authUpload?.((authDict) => {\n return baseApis.uploadDeviceSigningKeys(authDict, keys as CrossSigningKeys);\n });\n\n // pass the new keys to the main instance of our own CrossSigningInfo.\n crypto.crossSigningInfo.setKeys(this.crossSigningKeys.keys);\n }\n // set account data\n if (this.accountData) {\n for (const [type, content] of this.accountData) {\n await baseApis.setAccountData(type, content);\n }\n }\n // upload first cross-signing signatures with the new key\n // (e.g. signing our own device)\n if (this.keySignatures) {\n await baseApis.uploadKeySignatures(this.keySignatures);\n }\n // need to create/update key backup info\n if (this.keyBackupInfo) {\n if (this.keyBackupInfo.version) {\n // session backup signature\n // The backup is trusted because the user provided the private key.\n // Sign the backup with the cross signing key so the key backup can\n // be trusted via cross-signing.\n await baseApis.http.authedRequest(\n Method.Put,\n \"/room_keys/version/\" + this.keyBackupInfo.version,\n undefined,\n {\n algorithm: this.keyBackupInfo.algorithm,\n auth_data: this.keyBackupInfo.auth_data,\n },\n { prefix: ClientPrefix.V3 },\n );\n } else {\n // add new key backup\n await baseApis.http.authedRequest(Method.Post, \"/room_keys/version\", undefined, this.keyBackupInfo, {\n prefix: ClientPrefix.V3,\n });\n }\n }\n }\n}\n\n/**\n * Catches account data set by SecretStorage during bootstrapping by\n * implementing the methods related to account data in MatrixClient\n */\nclass AccountDataClientAdapter\n extends TypedEventEmitter\n implements IAccountDataClient\n{\n //\n public readonly values = new Map();\n\n /**\n * @param existingValues - existing account data\n */\n public constructor(private readonly existingValues: Map) {\n super();\n }\n\n /**\n * @returns the content of the account data\n */\n public getAccountDataFromServer(type: string): Promise {\n return Promise.resolve(this.getAccountData(type) as T);\n }\n\n /**\n * @returns the content of the account data\n */\n public getAccountData(type: string): IContent | null {\n const modifiedValue = this.values.get(type);\n if (modifiedValue) {\n return modifiedValue;\n }\n const existingValue = this.existingValues.get(type);\n if (existingValue) {\n return existingValue.getContent();\n }\n return null;\n }\n\n public setAccountData(type: string, content: any): Promise<{}> {\n const lastEvent = this.values.get(type);\n this.values.set(type, content);\n // ensure accountData is emitted on the next tick,\n // as SecretStorage listens for it while calling this method\n // and it seems to rely on this.\n return Promise.resolve().then(() => {\n const event = new MatrixEvent({ type, content });\n this.emit(ClientEvent.AccountData, event, lastEvent);\n return {};\n });\n }\n}\n\n/**\n * Catches the private cross-signing keys set during bootstrapping\n * by both cache callbacks (see createCryptoStoreCacheCallbacks) as non-cache callbacks.\n * See CrossSigningInfo constructor\n */\nclass CrossSigningCallbacks implements ICryptoCallbacks, ICacheCallbacks {\n public readonly privateKeys = new Map();\n\n // cache callbacks\n public getCrossSigningKeyCache(type: string, expectedPublicKey: string): Promise {\n return this.getCrossSigningKey(type, expectedPublicKey);\n }\n\n public storeCrossSigningKeyCache(type: string, key: Uint8Array): Promise {\n this.privateKeys.set(type, key);\n return Promise.resolve();\n }\n\n // non-cache callbacks\n public getCrossSigningKey(type: string, expectedPubkey: string): Promise {\n return Promise.resolve(this.privateKeys.get(type) ?? null);\n }\n\n public saveCrossSigningKeys(privateKeys: Record): void {\n for (const [type, privateKey] of Object.entries(privateKeys)) {\n this.privateKeys.set(type, privateKey);\n }\n }\n}\n\n/**\n * Catches the 4S private key set during bootstrapping by implementing\n * the SecretStorage crypto callbacks\n */\nclass SSSSCryptoCallbacks {\n private readonly privateKeys = new Map();\n\n public constructor(private readonly delegateCryptoCallbacks?: ICryptoCallbacks) {}\n\n public async getSecretStorageKey(\n { keys }: { keys: Record },\n name: string,\n ): Promise<[string, Uint8Array] | null> {\n for (const keyId of Object.keys(keys)) {\n const privateKey = this.privateKeys.get(keyId);\n if (privateKey) {\n return [keyId, privateKey];\n }\n }\n // if we don't have the key cached yet, ask\n // for it to the general crypto callbacks and cache it\n if (this?.delegateCryptoCallbacks?.getSecretStorageKey) {\n const result = await this.delegateCryptoCallbacks.getSecretStorageKey({ keys }, name);\n if (result) {\n const [keyId, privateKey] = result;\n this.privateKeys.set(keyId, privateKey);\n }\n return result;\n }\n return null;\n }\n\n public addPrivateKey(keyId: string, keyInfo: SecretStorageKeyDescription, privKey: Uint8Array): void {\n this.privateKeys.set(keyId, privKey);\n // Also pass along to application to cache if it wishes\n this.delegateCryptoCallbacks?.cacheSecretStorageKey?.(keyId, keyInfo, privKey);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts deleted file mode 100644 index 3b8bbe9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts +++ /dev/null @@ -1,454 +0,0 @@ -import { PrefixedLogger } from "../logger"; -import { CryptoStore, IProblem, ISessionInfo } from "./store/base"; -import { IOlmDevice, IOutboundGroupSessionKey } from "./algorithms/megolm"; -import { IMegolmSessionData, OlmGroupSessionExtraData } from "../@types/crypto"; -import { IMessage } from "./algorithms/olm"; -export declare class PayloadTooLargeError extends Error { - readonly data: { - errcode: string; - error: string; - }; -} -interface IInitOpts { - fromExportedDevice?: IExportedDevice; - pickleKey?: string; -} -/** data stored in the session store about an inbound group session */ -export interface InboundGroupSessionData { - room_id: string; - /** pickled Olm.InboundGroupSession */ - session: string; - keysClaimed: Record; - /** Devices involved in forwarding this session to us (normally empty). */ - forwardingCurve25519KeyChain: string[]; - /** whether this session is untrusted. */ - untrusted?: boolean; - /** whether this session exists during the room being set to shared history. */ - sharedHistory?: boolean; -} -export interface IDecryptedGroupMessage { - result: string; - keysClaimed: Record; - senderKey: string; - forwardingCurve25519KeyChain: string[]; - untrusted: boolean; -} -export interface IInboundSession { - payload: string; - session_id: string; -} -export interface IExportedDevice { - pickleKey: string; - pickledAccount: string; - sessions: ISessionInfo[]; -} -interface IInboundGroupSessionKey { - chain_index: number; - key: string; - forwarding_curve25519_key_chain: string[]; - sender_claimed_ed25519_key: string | null; - shared_history: boolean; - untrusted?: boolean; -} -type OneTimeKeys = { - curve25519: { - [keyId: string]: string; - }; -}; -/** - * Manages the olm cryptography functions. Each OlmDevice has a single - * OlmAccount and a number of OlmSessions. - * - * Accounts and sessions are kept pickled in the cryptoStore. - */ -export declare class OlmDevice { - private readonly cryptoStore; - pickleKey: string; - /** Curve25519 key for the account, unknown until we load the account from storage in init() */ - deviceCurve25519Key: string | null; - /** Ed25519 key for the account, unknown until we load the account from storage in init() */ - deviceEd25519Key: string | null; - private maxOneTimeKeys; - private outboundGroupSessionStore; - private inboundGroupSessionMessageIndexes; - sessionsInProgress: Record>; - olmPrekeyPromise: Promise; - constructor(cryptoStore: CryptoStore); - /** - * @returns The version of Olm. - */ - static getOlmVersion(): [number, number, number]; - /** - * Initialise the OlmAccount. This must be called before any other operations - * on the OlmDevice. - * - * Data from an exported Olm device can be provided - * in order to re-create this device. - * - * Attempts to load the OlmAccount from the crypto store, or creates one if none is - * found. - * - * Reads the device keys from the OlmAccount object. - * - * @param fromExportedDevice - (Optional) data from exported device - * that must be re-created. - * If present, opts.pickleKey is ignored - * (exported data already provides a pickle key) - * @param pickleKey - (Optional) pickle key to set instead of default one - */ - init({ pickleKey, fromExportedDevice }?: IInitOpts): Promise; - /** - * Populates the crypto store using data that was exported from an existing device. - * Note that for now only the “account” and “sessions” stores are populated; - * Other stores will be as with a new device. - * - * @param exportedData - Data exported from another device - * through the “export” method. - * @param account - an olm account to initialize - */ - private initialiseFromExportedDevice; - private initialiseAccount; - /** - * extract our OlmAccount from the crypto store and call the given function - * with the account object - * The `account` object is usable only within the callback passed to this - * function and will be freed as soon the callback returns. It is *not* - * usable for the rest of the lifetime of the transaction. - * This function requires a live transaction object from cryptoStore.doTxn() - * and therefore may only be called in a doTxn() callback. - * - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @internal - */ - private getAccount; - private storeAccount; - /** - * Export data for re-creating the Olm device later. - * TODO export data other than just account and (P2P) sessions. - * - * @returns The exported data - */ - export(): Promise; - /** - * extract an OlmSession from the session store and call the given function - * The session is usable only within the callback passed to this - * function and will be freed as soon the callback returns. It is *not* - * usable for the rest of the lifetime of the transaction. - * - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @internal - */ - private getSession; - /** - * Creates a session object from a session pickle and executes the given - * function with it. The session object is destroyed once the function - * returns. - * - * @internal - */ - private unpickleSession; - /** - * store our OlmSession in the session store - * - * @param sessionInfo - `{session: OlmSession, lastReceivedMessageTs: int}` - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @internal - */ - private saveSession; - /** - * get an OlmUtility and call the given function - * - * @returns result of func - * @internal - */ - private getUtility; - /** - * Signs a message with the ed25519 key for this account. - * - * @param message - message to be signed - * @returns base64-encoded signature - */ - sign(message: string): Promise; - /** - * Get the current (unused, unpublished) one-time keys for this account. - * - * @returns one time keys; an object with the single property - * curve25519, which is itself an object mapping key id to Curve25519 - * key. - */ - getOneTimeKeys(): Promise; - /** - * Get the maximum number of one-time keys we can store. - * - * @returns number of keys - */ - maxNumberOfOneTimeKeys(): number; - /** - * Marks all of the one-time keys as published. - */ - markKeysAsPublished(): Promise; - /** - * Generate some new one-time keys - * - * @param numKeys - number of keys to generate - * @returns Resolved once the account is saved back having generated the keys - */ - generateOneTimeKeys(numKeys: number): Promise; - /** - * Generate a new fallback keys - * - * @returns Resolved once the account is saved back having generated the key - */ - generateFallbackKey(): Promise; - getFallbackKey(): Promise>>; - forgetOldFallbackKey(): Promise; - /** - * Generate a new outbound session - * - * The new session will be stored in the cryptoStore. - * - * @param theirIdentityKey - remote user's Curve25519 identity key - * @param theirOneTimeKey - remote user's one-time Curve25519 key - * @returns sessionId for the outbound session. - */ - createOutboundSession(theirIdentityKey: string, theirOneTimeKey: string): Promise; - /** - * Generate a new inbound session, given an incoming message - * - * @param theirDeviceIdentityKey - remote user's Curve25519 identity key - * @param messageType - messageType field from the received message (must be 0) - * @param ciphertext - base64-encoded body from the received message - * - * @returns decrypted payload, and - * session id of new session - * - * @throws Error if the received message was not valid (for instance, it didn't use a valid one-time key). - */ - createInboundSession(theirDeviceIdentityKey: string, messageType: number, ciphertext: string): Promise; - /** - * Get a list of known session IDs for the given device - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @returns a list of known session ids for the device - */ - getSessionIdsForDevice(theirDeviceIdentityKey: string): Promise; - /** - * Get the right olm session id for encrypting messages to the given identity key - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param nowait - Don't wait for an in-progress session to complete. - * This should only be set to true of the calling function is the function - * that marked the session as being in-progress. - * @param log - A possibly customised log - * @returns session id, or null if no established session - */ - getSessionIdForDevice(theirDeviceIdentityKey: string, nowait?: boolean, log?: PrefixedLogger): Promise; - /** - * Get information on the active Olm sessions for a device. - *

- * Returns an array, with an entry for each active session. The first entry in - * the result will be the one used for outgoing messages. Each entry contains - * the keys 'hasReceivedMessage' (true if the session has received an incoming - * message and is therefore past the pre-key stage), and 'sessionId'. - * - * @param deviceIdentityKey - Curve25519 identity key for the device - * @param nowait - Don't wait for an in-progress session to complete. - * This should only be set to true of the calling function is the function - * that marked the session as being in-progress. - * @param log - A possibly customised log - */ - getSessionInfoForDevice(deviceIdentityKey: string, nowait?: boolean, log?: PrefixedLogger): Promise<{ - sessionId: string; - lastReceivedMessageTs: number; - hasReceivedMessage: boolean; - }[]>; - /** - * Encrypt an outgoing message using an existing session - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param sessionId - the id of the active session - * @param payloadString - payload to be encrypted and sent - * - * @returns ciphertext - */ - encryptMessage(theirDeviceIdentityKey: string, sessionId: string, payloadString: string): Promise; - /** - * Decrypt an incoming message using an existing session - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param sessionId - the id of the active session - * @param messageType - messageType field from the received message - * @param ciphertext - base64-encoded body from the received message - * - * @returns decrypted payload. - */ - decryptMessage(theirDeviceIdentityKey: string, sessionId: string, messageType: number, ciphertext: string): Promise; - /** - * Determine if an incoming messages is a prekey message matching an existing session - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param sessionId - the id of the active session - * @param messageType - messageType field from the received message - * @param ciphertext - base64-encoded body from the received message - * - * @returns true if the received message is a prekey message which matches - * the given session. - */ - matchesSession(theirDeviceIdentityKey: string, sessionId: string, messageType: number, ciphertext: string): Promise; - recordSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise; - sessionMayHaveProblems(deviceKey: string, timestamp: number): Promise; - filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise; - /** - * store an OutboundGroupSession in outboundGroupSessionStore - * - * @internal - */ - private saveOutboundGroupSession; - /** - * extract an OutboundGroupSession from outboundGroupSessionStore and call the - * given function - * - * @returns result of func - * @internal - */ - private getOutboundGroupSession; - /** - * Generate a new outbound group session - * - * @returns sessionId for the outbound session. - */ - createOutboundGroupSession(): string; - /** - * Encrypt an outgoing message with an outbound group session - * - * @param sessionId - the id of the outboundgroupsession - * @param payloadString - payload to be encrypted and sent - * - * @returns ciphertext - */ - encryptGroupMessage(sessionId: string, payloadString: string): string; - /** - * Get the session keys for an outbound group session - * - * @param sessionId - the id of the outbound group session - * - * @returns current chain index, and - * base64-encoded secret key. - */ - getOutboundGroupSessionKey(sessionId: string): IOutboundGroupSessionKey; - /** - * Unpickle a session from a sessionData object and invoke the given function. - * The session is valid only until func returns. - * - * @param sessionData - Object describing the session. - * @param func - Invoked with the unpickled session - * @returns result of func - */ - private unpickleInboundGroupSession; - /** - * extract an InboundGroupSession from the crypto store and call the given function - * - * @param roomId - The room ID to extract the session for, or null to fetch - * sessions for any room. - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @param func - function to call. - * - * @internal - */ - private getInboundGroupSession; - /** - * Add an inbound group session to the session store - * - * @param roomId - room in which this session will be used - * @param senderKey - base64-encoded curve25519 key of the sender - * @param forwardingCurve25519KeyChain - Devices involved in forwarding - * this session to us. - * @param sessionId - session identifier - * @param sessionKey - base64-encoded secret key - * @param keysClaimed - Other keys the sender claims. - * @param exportFormat - true if the megolm keys are in export format - * (ie, they lack an ed25519 signature) - * @param extraSessionData - any other data to be include with the session - */ - addInboundGroupSession(roomId: string, senderKey: string, forwardingCurve25519KeyChain: string[], sessionId: string, sessionKey: string, keysClaimed: Record, exportFormat: boolean, extraSessionData?: OlmGroupSessionExtraData): Promise; - /** - * Record in the data store why an inbound group session was withheld. - * - * @param roomId - room that the session belongs to - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param code - reason code - * @param reason - human-readable version of `code` - */ - addInboundGroupSessionWithheld(roomId: string, senderKey: string, sessionId: string, code: string, reason: string): Promise; - /** - * Decrypt a received message with an inbound group session - * - * @param roomId - room in which the message was received - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param body - base64-encoded body of the encrypted message - * @param eventId - ID of the event being decrypted - * @param timestamp - timestamp of the event being decrypted - * - * @returns null if the sessionId is unknown - */ - decryptGroupMessage(roomId: string, senderKey: string, sessionId: string, body: string, eventId: string, timestamp: number): Promise; - /** - * Determine if we have the keys for a given megolm session - * - * @param roomId - room in which the message was received - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * - * @returns true if we have the keys to this session - */ - hasInboundSessionKeys(roomId: string, senderKey: string, sessionId: string): Promise; - /** - * Extract the keys to a given megolm session, for sharing - * - * @param roomId - room in which the message was received - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param chainIndex - The chain index at which to export the session. - * If omitted, export at the first index we know about. - * - * @returns - * details of the session key. The key is a base64-encoded megolm key in - * export format. - * - * @throws Error If the given chain index could not be obtained from the known - * index (ie. the given chain index is before the first we have). - */ - getInboundGroupSessionKey(roomId: string, senderKey: string, sessionId: string, chainIndex?: number): Promise; - /** - * Export an inbound group session - * - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param sessionData - The session object from the store - * @returns exported session data - */ - exportInboundGroupSession(senderKey: string, sessionId: string, sessionData: InboundGroupSessionData): IMegolmSessionData; - getSharedHistoryInboundGroupSessions(roomId: string): Promise<[senderKey: string, sessionId: string][]>; - /** - * Verify an ed25519 signature. - * - * @param key - ed25519 key - * @param message - message which was signed - * @param signature - base64-encoded signature to be checked - * - * @throws Error if there is a problem with the verification. If the key was - * too small then the message will be "OLM.INVALID_BASE64". If the signature - * was invalid then the message will be "OLM.BAD_MESSAGE_MAC". - */ - verifySignature(key: string, message: string, signature: string): void; -} -export declare const WITHHELD_MESSAGES: Record; -export {}; -//# sourceMappingURL=OlmDevice.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts.map deleted file mode 100644 index 710db52..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"OlmDevice.d.ts","sourceRoot":"","sources":["../../src/crypto/OlmDevice.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js deleted file mode 100644 index adfbe01..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js +++ /dev/null @@ -1,1164 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.WITHHELD_MESSAGES = exports.PayloadTooLargeError = exports.OlmDevice = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../logger"); -var _indexeddbCryptoStore = require("./store/indexeddb-crypto-store"); -var algorithms = _interopRequireWildcard(require("./algorithms")); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// The maximum size of an event is 65K, and we base64 the content, so this is a -// reasonable approximation to the biggest plaintext we can encrypt. -const MAX_PLAINTEXT_LENGTH = 65536 * 3 / 4; -class PayloadTooLargeError extends Error { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "data", { - errcode: "M_TOO_LARGE", - error: "Payload too large for encrypted message" - }); - } -} -exports.PayloadTooLargeError = PayloadTooLargeError; -function checkPayloadLength(payloadString) { - if (payloadString === undefined) { - throw new Error("payloadString undefined"); - } - if (payloadString.length > MAX_PLAINTEXT_LENGTH) { - // might as well fail early here rather than letting the olm library throw - // a cryptic memory allocation error. - // - // Note that even if we manage to do the encryption, the message send may fail, - // because by the time we've wrapped the ciphertext in the event object, it may - // exceed 65K. But at least we won't just fail with "abort()" in that case. - throw new PayloadTooLargeError(`Message too long (${payloadString.length} bytes). ` + `The maximum for an encrypted message is ${MAX_PLAINTEXT_LENGTH} bytes.`); - } -} -/** - * Manages the olm cryptography functions. Each OlmDevice has a single - * OlmAccount and a number of OlmSessions. - * - * Accounts and sessions are kept pickled in the cryptoStore. - */ -class OlmDevice { - // set by consumers - - /** Curve25519 key for the account, unknown until we load the account from storage in init() */ - - /** Ed25519 key for the account, unknown until we load the account from storage in init() */ - - // we don't bother stashing outboundgroupsessions in the cryptoStore - - // instead we keep them here. - - // Store a set of decrypted message indexes for each group session. - // This partially mitigates a replay attack where a MITM resends a group - // message into the room. - // - // When we decrypt a message and the message index matches a previously - // decrypted message, one possible cause of that is that we are decrypting - // the same event, and may not indicate an actual replay attack. For - // example, this could happen if we receive events, forget about them, and - // then re-fetch them when we backfill. So we store the event ID and - // timestamp corresponding to each message index when we first decrypt it, - // and compare these against the event ID and timestamp every time we use - // that same index. If they match, then we're probably decrypting the same - // event and we don't consider it a replay attack. - // - // Keys are strings of form "||" - // Values are objects of the form "{id: , timestamp: }" - - // Keep track of sessions that we're starting, so that we don't start - // multiple sessions for the same device at the same time. - // set by consumers - - // Used by olm to serialise prekey message decryptions - // set by consumers - - constructor(cryptoStore) { - this.cryptoStore = cryptoStore; - (0, _defineProperty2.default)(this, "pickleKey", "DEFAULT_KEY"); - (0, _defineProperty2.default)(this, "deviceCurve25519Key", null); - (0, _defineProperty2.default)(this, "deviceEd25519Key", null); - (0, _defineProperty2.default)(this, "maxOneTimeKeys", null); - (0, _defineProperty2.default)(this, "outboundGroupSessionStore", {}); - (0, _defineProperty2.default)(this, "inboundGroupSessionMessageIndexes", {}); - (0, _defineProperty2.default)(this, "sessionsInProgress", {}); - (0, _defineProperty2.default)(this, "olmPrekeyPromise", Promise.resolve()); - } - - /** - * @returns The version of Olm. - */ - static getOlmVersion() { - return global.Olm.get_library_version(); - } - - /** - * Initialise the OlmAccount. This must be called before any other operations - * on the OlmDevice. - * - * Data from an exported Olm device can be provided - * in order to re-create this device. - * - * Attempts to load the OlmAccount from the crypto store, or creates one if none is - * found. - * - * Reads the device keys from the OlmAccount object. - * - * @param fromExportedDevice - (Optional) data from exported device - * that must be re-created. - * If present, opts.pickleKey is ignored - * (exported data already provides a pickle key) - * @param pickleKey - (Optional) pickle key to set instead of default one - */ - async init({ - pickleKey, - fromExportedDevice - } = {}) { - let e2eKeys; - const account = new global.Olm.Account(); - try { - if (fromExportedDevice) { - if (pickleKey) { - _logger.logger.warn("ignoring opts.pickleKey" + " because opts.fromExportedDevice is present."); - } - this.pickleKey = fromExportedDevice.pickleKey; - await this.initialiseFromExportedDevice(fromExportedDevice, account); - } else { - if (pickleKey) { - this.pickleKey = pickleKey; - } - await this.initialiseAccount(account); - } - e2eKeys = JSON.parse(account.identity_keys()); - this.maxOneTimeKeys = account.max_number_of_one_time_keys(); - } finally { - account.free(); - } - this.deviceCurve25519Key = e2eKeys.curve25519; - this.deviceEd25519Key = e2eKeys.ed25519; - } - - /** - * Populates the crypto store using data that was exported from an existing device. - * Note that for now only the “account” and “sessions” stores are populated; - * Other stores will be as with a new device. - * - * @param exportedData - Data exported from another device - * through the “export” method. - * @param account - an olm account to initialize - */ - async initialiseFromExportedDevice(exportedData, account) { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.cryptoStore.storeAccount(txn, exportedData.pickledAccount); - exportedData.sessions.forEach(session => { - const { - deviceKey, - sessionId - } = session; - const sessionInfo = { - session: session.session, - lastReceivedMessageTs: session.lastReceivedMessageTs - }; - this.cryptoStore.storeEndToEndSession(deviceKey, sessionId, sessionInfo, txn); - }); - }); - account.unpickle(this.pickleKey, exportedData.pickledAccount); - } - async initialiseAccount(account) { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.cryptoStore.getAccount(txn, pickledAccount => { - if (pickledAccount !== null) { - account.unpickle(this.pickleKey, pickledAccount); - } else { - account.create(); - pickledAccount = account.pickle(this.pickleKey); - this.cryptoStore.storeAccount(txn, pickledAccount); - } - }); - }); - } - - /** - * extract our OlmAccount from the crypto store and call the given function - * with the account object - * The `account` object is usable only within the callback passed to this - * function and will be freed as soon the callback returns. It is *not* - * usable for the rest of the lifetime of the transaction. - * This function requires a live transaction object from cryptoStore.doTxn() - * and therefore may only be called in a doTxn() callback. - * - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @internal - */ - getAccount(txn, func) { - this.cryptoStore.getAccount(txn, pickledAccount => { - const account = new global.Olm.Account(); - try { - account.unpickle(this.pickleKey, pickledAccount); - func(account); - } finally { - account.free(); - } - }); - } - - /* - * Saves an account to the crypto store. - * This function requires a live transaction object from cryptoStore.doTxn() - * and therefore may only be called in a doTxn() callback. - * - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @param Olm.Account object - * @internal - */ - storeAccount(txn, account) { - this.cryptoStore.storeAccount(txn, account.pickle(this.pickleKey)); - } - - /** - * Export data for re-creating the Olm device later. - * TODO export data other than just account and (P2P) sessions. - * - * @returns The exported data - */ - async export() { - const result = { - pickleKey: this.pickleKey - }; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.cryptoStore.getAccount(txn, pickledAccount => { - result.pickledAccount = pickledAccount; - }); - result.sessions = []; - // Note that the pickledSession object we get in the callback - // is not exactly the same thing you get in method _getSession - // see documentation of IndexedDBCryptoStore.getAllEndToEndSessions - this.cryptoStore.getAllEndToEndSessions(txn, pickledSession => { - result.sessions.push(pickledSession); - }); - }); - return result; - } - - /** - * extract an OlmSession from the session store and call the given function - * The session is usable only within the callback passed to this - * function and will be freed as soon the callback returns. It is *not* - * usable for the rest of the lifetime of the transaction. - * - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @internal - */ - getSession(deviceKey, sessionId, txn, func) { - this.cryptoStore.getEndToEndSession(deviceKey, sessionId, txn, sessionInfo => { - this.unpickleSession(sessionInfo, func); - }); - } - - /** - * Creates a session object from a session pickle and executes the given - * function with it. The session object is destroyed once the function - * returns. - * - * @internal - */ - unpickleSession(sessionInfo, func) { - const session = new global.Olm.Session(); - try { - session.unpickle(this.pickleKey, sessionInfo.session); - const unpickledSessInfo = Object.assign({}, sessionInfo, { - session - }); - func(unpickledSessInfo); - } finally { - session.free(); - } - } - - /** - * store our OlmSession in the session store - * - * @param sessionInfo - `{session: OlmSession, lastReceivedMessageTs: int}` - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @internal - */ - saveSession(deviceKey, sessionInfo, txn) { - const sessionId = sessionInfo.session.session_id(); - _logger.logger.debug(`Saving Olm session ${sessionId} with device ${deviceKey}: ${sessionInfo.session.describe()}`); - - // Why do we re-use the input object for this, overwriting the same key with a different - // type? Is it because we want to erase the unpickled session to enforce that it's no longer - // used? A comment would be great. - const pickledSessionInfo = Object.assign(sessionInfo, { - session: sessionInfo.session.pickle(this.pickleKey) - }); - this.cryptoStore.storeEndToEndSession(deviceKey, sessionId, pickledSessionInfo, txn); - } - - /** - * get an OlmUtility and call the given function - * - * @returns result of func - * @internal - */ - getUtility(func) { - const utility = new global.Olm.Utility(); - try { - return func(utility); - } finally { - utility.free(); - } - } - - /** - * Signs a message with the ed25519 key for this account. - * - * @param message - message to be signed - * @returns base64-encoded signature - */ - async sign(message) { - let result; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.getAccount(txn, account => { - result = account.sign(message); - }); - }); - return result; - } - - /** - * Get the current (unused, unpublished) one-time keys for this account. - * - * @returns one time keys; an object with the single property - * curve25519, which is itself an object mapping key id to Curve25519 - * key. - */ - async getOneTimeKeys() { - let result; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.getAccount(txn, account => { - result = JSON.parse(account.one_time_keys()); - }); - }); - return result; - } - - /** - * Get the maximum number of one-time keys we can store. - * - * @returns number of keys - */ - maxNumberOfOneTimeKeys() { - var _this$maxOneTimeKeys; - return (_this$maxOneTimeKeys = this.maxOneTimeKeys) !== null && _this$maxOneTimeKeys !== void 0 ? _this$maxOneTimeKeys : -1; - } - - /** - * Marks all of the one-time keys as published. - */ - async markKeysAsPublished() { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.getAccount(txn, account => { - account.mark_keys_as_published(); - this.storeAccount(txn, account); - }); - }); - } - - /** - * Generate some new one-time keys - * - * @param numKeys - number of keys to generate - * @returns Resolved once the account is saved back having generated the keys - */ - generateOneTimeKeys(numKeys) { - return this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.getAccount(txn, account => { - account.generate_one_time_keys(numKeys); - this.storeAccount(txn, account); - }); - }); - } - - /** - * Generate a new fallback keys - * - * @returns Resolved once the account is saved back having generated the key - */ - async generateFallbackKey() { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.getAccount(txn, account => { - account.generate_fallback_key(); - this.storeAccount(txn, account); - }); - }); - } - async getFallbackKey() { - let result; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.getAccount(txn, account => { - result = JSON.parse(account.unpublished_fallback_key()); - }); - }); - return result; - } - async forgetOldFallbackKey() { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.getAccount(txn, account => { - account.forget_old_fallback_key(); - this.storeAccount(txn, account); - }); - }); - } - - /** - * Generate a new outbound session - * - * The new session will be stored in the cryptoStore. - * - * @param theirIdentityKey - remote user's Curve25519 identity key - * @param theirOneTimeKey - remote user's one-time Curve25519 key - * @returns sessionId for the outbound session. - */ - async createOutboundSession(theirIdentityKey, theirOneTimeKey) { - let newSessionId; - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.getAccount(txn, account => { - const session = new global.Olm.Session(); - try { - session.create_outbound(account, theirIdentityKey, theirOneTimeKey); - newSessionId = session.session_id(); - this.storeAccount(txn, account); - const sessionInfo = { - session, - // Pretend we've received a message at this point, otherwise - // if we try to send a message to the device, it won't use - // this session - lastReceivedMessageTs: Date.now() - }; - this.saveSession(theirIdentityKey, sessionInfo, txn); - } finally { - session.free(); - } - }); - }, _logger.logger.withPrefix("[createOutboundSession]")); - return newSessionId; - } - - /** - * Generate a new inbound session, given an incoming message - * - * @param theirDeviceIdentityKey - remote user's Curve25519 identity key - * @param messageType - messageType field from the received message (must be 0) - * @param ciphertext - base64-encoded body from the received message - * - * @returns decrypted payload, and - * session id of new session - * - * @throws Error if the received message was not valid (for instance, it didn't use a valid one-time key). - */ - async createInboundSession(theirDeviceIdentityKey, messageType, ciphertext) { - if (messageType !== 0) { - throw new Error("Need messageType == 0 to create inbound session"); - } - let result; // eslint-disable-line camelcase - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.getAccount(txn, account => { - const session = new global.Olm.Session(); - try { - session.create_inbound_from(account, theirDeviceIdentityKey, ciphertext); - account.remove_one_time_keys(session); - this.storeAccount(txn, account); - const payloadString = session.decrypt(messageType, ciphertext); - const sessionInfo = { - session, - // this counts as a received message: set last received message time - // to now - lastReceivedMessageTs: Date.now() - }; - this.saveSession(theirDeviceIdentityKey, sessionInfo, txn); - result = { - payload: payloadString, - session_id: session.session_id() - }; - } finally { - session.free(); - } - }); - }, _logger.logger.withPrefix("[createInboundSession]")); - return result; - } - - /** - * Get a list of known session IDs for the given device - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @returns a list of known session ids for the device - */ - async getSessionIdsForDevice(theirDeviceIdentityKey) { - const log = _logger.logger.withPrefix("[getSessionIdsForDevice]"); - if (theirDeviceIdentityKey in this.sessionsInProgress) { - log.debug(`Waiting for Olm session for ${theirDeviceIdentityKey} to be created`); - try { - await this.sessionsInProgress[theirDeviceIdentityKey]; - } catch (e) { - // if the session failed to be created, just fall through and - // return an empty result - } - } - let sessionIds; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.cryptoStore.getEndToEndSessions(theirDeviceIdentityKey, txn, sessions => { - sessionIds = Object.keys(sessions); - }); - }, log); - return sessionIds; - } - - /** - * Get the right olm session id for encrypting messages to the given identity key - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param nowait - Don't wait for an in-progress session to complete. - * This should only be set to true of the calling function is the function - * that marked the session as being in-progress. - * @param log - A possibly customised log - * @returns session id, or null if no established session - */ - async getSessionIdForDevice(theirDeviceIdentityKey, nowait = false, log) { - const sessionInfos = await this.getSessionInfoForDevice(theirDeviceIdentityKey, nowait, log); - if (sessionInfos.length === 0) { - return null; - } - // Use the session that has most recently received a message - let idxOfBest = 0; - for (let i = 1; i < sessionInfos.length; i++) { - const thisSessInfo = sessionInfos[i]; - const thisLastReceived = thisSessInfo.lastReceivedMessageTs === undefined ? 0 : thisSessInfo.lastReceivedMessageTs; - const bestSessInfo = sessionInfos[idxOfBest]; - const bestLastReceived = bestSessInfo.lastReceivedMessageTs === undefined ? 0 : bestSessInfo.lastReceivedMessageTs; - if (thisLastReceived > bestLastReceived || thisLastReceived === bestLastReceived && thisSessInfo.sessionId < bestSessInfo.sessionId) { - idxOfBest = i; - } - } - return sessionInfos[idxOfBest].sessionId; - } - - /** - * Get information on the active Olm sessions for a device. - *

- * Returns an array, with an entry for each active session. The first entry in - * the result will be the one used for outgoing messages. Each entry contains - * the keys 'hasReceivedMessage' (true if the session has received an incoming - * message and is therefore past the pre-key stage), and 'sessionId'. - * - * @param deviceIdentityKey - Curve25519 identity key for the device - * @param nowait - Don't wait for an in-progress session to complete. - * This should only be set to true of the calling function is the function - * that marked the session as being in-progress. - * @param log - A possibly customised log - */ - async getSessionInfoForDevice(deviceIdentityKey, nowait = false, log = _logger.logger) { - log = log.withPrefix("[getSessionInfoForDevice]"); - if (deviceIdentityKey in this.sessionsInProgress && !nowait) { - log.debug(`Waiting for Olm session for ${deviceIdentityKey} to be created`); - try { - await this.sessionsInProgress[deviceIdentityKey]; - } catch (e) { - // if the session failed to be created, then just fall through and - // return an empty result - } - } - const info = []; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.cryptoStore.getEndToEndSessions(deviceIdentityKey, txn, sessions => { - const sessionIds = Object.keys(sessions).sort(); - for (const sessionId of sessionIds) { - this.unpickleSession(sessions[sessionId], sessInfo => { - info.push({ - lastReceivedMessageTs: sessInfo.lastReceivedMessageTs, - hasReceivedMessage: sessInfo.session.has_received_message(), - sessionId - }); - }); - } - }); - }, log); - return info; - } - - /** - * Encrypt an outgoing message using an existing session - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param sessionId - the id of the active session - * @param payloadString - payload to be encrypted and sent - * - * @returns ciphertext - */ - async encryptMessage(theirDeviceIdentityKey, sessionId, payloadString) { - checkPayloadLength(payloadString); - let res; - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.getSession(theirDeviceIdentityKey, sessionId, txn, sessionInfo => { - const sessionDesc = sessionInfo.session.describe(); - _logger.logger.log("encryptMessage: Olm Session ID " + sessionId + " to " + theirDeviceIdentityKey + ": " + sessionDesc); - res = sessionInfo.session.encrypt(payloadString); - this.saveSession(theirDeviceIdentityKey, sessionInfo, txn); - }); - }, _logger.logger.withPrefix("[encryptMessage]")); - return res; - } - - /** - * Decrypt an incoming message using an existing session - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param sessionId - the id of the active session - * @param messageType - messageType field from the received message - * @param ciphertext - base64-encoded body from the received message - * - * @returns decrypted payload. - */ - async decryptMessage(theirDeviceIdentityKey, sessionId, messageType, ciphertext) { - let payloadString; - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.getSession(theirDeviceIdentityKey, sessionId, txn, sessionInfo => { - const sessionDesc = sessionInfo.session.describe(); - _logger.logger.log("decryptMessage: Olm Session ID " + sessionId + " from " + theirDeviceIdentityKey + ": " + sessionDesc); - payloadString = sessionInfo.session.decrypt(messageType, ciphertext); - sessionInfo.lastReceivedMessageTs = Date.now(); - this.saveSession(theirDeviceIdentityKey, sessionInfo, txn); - }); - }, _logger.logger.withPrefix("[decryptMessage]")); - return payloadString; - } - - /** - * Determine if an incoming messages is a prekey message matching an existing session - * - * @param theirDeviceIdentityKey - Curve25519 identity key for the - * remote device - * @param sessionId - the id of the active session - * @param messageType - messageType field from the received message - * @param ciphertext - base64-encoded body from the received message - * - * @returns true if the received message is a prekey message which matches - * the given session. - */ - async matchesSession(theirDeviceIdentityKey, sessionId, messageType, ciphertext) { - if (messageType !== 0) { - return false; - } - let matches; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SESSIONS], txn => { - this.getSession(theirDeviceIdentityKey, sessionId, txn, sessionInfo => { - matches = sessionInfo.session.matches_inbound(ciphertext); - }); - }, _logger.logger.withPrefix("[matchesSession]")); - return matches; - } - async recordSessionProblem(deviceKey, type, fixed) { - _logger.logger.info(`Recording problem on olm session with ${deviceKey} of type ${type}. Recreating: ${fixed}`); - await this.cryptoStore.storeEndToEndSessionProblem(deviceKey, type, fixed); - } - sessionMayHaveProblems(deviceKey, timestamp) { - return this.cryptoStore.getEndToEndSessionProblem(deviceKey, timestamp); - } - filterOutNotifiedErrorDevices(devices) { - return this.cryptoStore.filterOutNotifiedErrorDevices(devices); - } - - // Outbound group session - // ====================== - - /** - * store an OutboundGroupSession in outboundGroupSessionStore - * - * @internal - */ - saveOutboundGroupSession(session) { - this.outboundGroupSessionStore[session.session_id()] = session.pickle(this.pickleKey); - } - - /** - * extract an OutboundGroupSession from outboundGroupSessionStore and call the - * given function - * - * @returns result of func - * @internal - */ - getOutboundGroupSession(sessionId, func) { - const pickled = this.outboundGroupSessionStore[sessionId]; - if (pickled === undefined) { - throw new Error("Unknown outbound group session " + sessionId); - } - const session = new global.Olm.OutboundGroupSession(); - try { - session.unpickle(this.pickleKey, pickled); - return func(session); - } finally { - session.free(); - } - } - - /** - * Generate a new outbound group session - * - * @returns sessionId for the outbound session. - */ - createOutboundGroupSession() { - const session = new global.Olm.OutboundGroupSession(); - try { - session.create(); - this.saveOutboundGroupSession(session); - return session.session_id(); - } finally { - session.free(); - } - } - - /** - * Encrypt an outgoing message with an outbound group session - * - * @param sessionId - the id of the outboundgroupsession - * @param payloadString - payload to be encrypted and sent - * - * @returns ciphertext - */ - encryptGroupMessage(sessionId, payloadString) { - _logger.logger.log(`encrypting msg with megolm session ${sessionId}`); - checkPayloadLength(payloadString); - return this.getOutboundGroupSession(sessionId, session => { - const res = session.encrypt(payloadString); - this.saveOutboundGroupSession(session); - return res; - }); - } - - /** - * Get the session keys for an outbound group session - * - * @param sessionId - the id of the outbound group session - * - * @returns current chain index, and - * base64-encoded secret key. - */ - getOutboundGroupSessionKey(sessionId) { - return this.getOutboundGroupSession(sessionId, function (session) { - return { - chain_index: session.message_index(), - key: session.session_key() - }; - }); - } - - // Inbound group session - // ===================== - - /** - * Unpickle a session from a sessionData object and invoke the given function. - * The session is valid only until func returns. - * - * @param sessionData - Object describing the session. - * @param func - Invoked with the unpickled session - * @returns result of func - */ - unpickleInboundGroupSession(sessionData, func) { - const session = new global.Olm.InboundGroupSession(); - try { - session.unpickle(this.pickleKey, sessionData.session); - return func(session); - } finally { - session.free(); - } - } - - /** - * extract an InboundGroupSession from the crypto store and call the given function - * - * @param roomId - The room ID to extract the session for, or null to fetch - * sessions for any room. - * @param txn - Opaque transaction object from cryptoStore.doTxn() - * @param func - function to call. - * - * @internal - */ - getInboundGroupSession(roomId, senderKey, sessionId, txn, func) { - this.cryptoStore.getEndToEndInboundGroupSession(senderKey, sessionId, txn, (sessionData, withheld) => { - if (sessionData === null) { - func(null, null, withheld); - return; - } - - // if we were given a room ID, check that the it matches the original one for the session. This stops - // the HS pretending a message was targeting a different room. - if (roomId !== null && roomId !== sessionData.room_id) { - throw new Error("Mismatched room_id for inbound group session (expected " + sessionData.room_id + ", was " + roomId + ")"); - } - this.unpickleInboundGroupSession(sessionData, session => { - func(session, sessionData, withheld); - }); - }); - } - - /** - * Add an inbound group session to the session store - * - * @param roomId - room in which this session will be used - * @param senderKey - base64-encoded curve25519 key of the sender - * @param forwardingCurve25519KeyChain - Devices involved in forwarding - * this session to us. - * @param sessionId - session identifier - * @param sessionKey - base64-encoded secret key - * @param keysClaimed - Other keys the sender claims. - * @param exportFormat - true if the megolm keys are in export format - * (ie, they lack an ed25519 signature) - * @param extraSessionData - any other data to be include with the session - */ - async addInboundGroupSession(roomId, senderKey, forwardingCurve25519KeyChain, sessionId, sessionKey, keysClaimed, exportFormat, extraSessionData = {}) { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS], txn => { - /* if we already have this session, consider updating it */ - this.getInboundGroupSession(roomId, senderKey, sessionId, txn, (existingSession, existingSessionData) => { - // new session. - const session = new global.Olm.InboundGroupSession(); - try { - if (exportFormat) { - session.import_session(sessionKey); - } else { - session.create(sessionKey); - } - if (sessionId != session.session_id()) { - throw new Error("Mismatched group session ID from senderKey: " + senderKey); - } - if (existingSession) { - _logger.logger.log(`Update for megolm session ${senderKey}|${sessionId}`); - if (existingSession.first_known_index() <= session.first_known_index()) { - if (!existingSessionData.untrusted || extraSessionData.untrusted) { - // existing session has less-than-or-equal index - // (i.e. can decrypt at least as much), and the - // new session's trust does not win over the old - // session's trust, so keep it - _logger.logger.log(`Keeping existing megolm session ${senderKey}|${sessionId}`); - return; - } - if (existingSession.first_known_index() < session.first_known_index()) { - // We want to upgrade the existing session's trust, - // but we can't just use the new session because we'll - // lose the lower index. Check that the sessions connect - // properly, and then manually set the existing session - // as trusted. - if (existingSession.export_session(session.first_known_index()) === session.export_session(session.first_known_index())) { - _logger.logger.info("Upgrading trust of existing megolm session " + `${senderKey}|${sessionId} based on newly-received trusted session`); - existingSessionData.untrusted = false; - this.cryptoStore.storeEndToEndInboundGroupSession(senderKey, sessionId, existingSessionData, txn); - } else { - _logger.logger.warn(`Newly-received megolm session ${senderKey}|$sessionId}` + " does not match existing session! Keeping existing session"); - } - return; - } - // If the sessions have the same index, go ahead and store the new trusted one. - } - } - - _logger.logger.info(`Storing megolm session ${senderKey}|${sessionId} with first index ` + session.first_known_index()); - const sessionData = Object.assign({}, extraSessionData, { - room_id: roomId, - session: session.pickle(this.pickleKey), - keysClaimed: keysClaimed, - forwardingCurve25519KeyChain: forwardingCurve25519KeyChain - }); - this.cryptoStore.storeEndToEndInboundGroupSession(senderKey, sessionId, sessionData, txn); - if (!existingSession && extraSessionData.sharedHistory) { - this.cryptoStore.addSharedHistoryInboundGroupSession(roomId, senderKey, sessionId, txn); - } - } finally { - session.free(); - } - }); - }, _logger.logger.withPrefix("[addInboundGroupSession]")); - } - - /** - * Record in the data store why an inbound group session was withheld. - * - * @param roomId - room that the session belongs to - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param code - reason code - * @param reason - human-readable version of `code` - */ - async addInboundGroupSessionWithheld(roomId, senderKey, sessionId, code, reason) { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD], txn => { - this.cryptoStore.storeEndToEndInboundGroupSessionWithheld(senderKey, sessionId, { - room_id: roomId, - code: code, - reason: reason - }, txn); - }); - } - - /** - * Decrypt a received message with an inbound group session - * - * @param roomId - room in which the message was received - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param body - base64-encoded body of the encrypted message - * @param eventId - ID of the event being decrypted - * @param timestamp - timestamp of the event being decrypted - * - * @returns null if the sessionId is unknown - */ - async decryptGroupMessage(roomId, senderKey, sessionId, body, eventId, timestamp) { - let result = null; - // when the localstorage crypto store is used as an indexeddb backend, - // exceptions thrown from within the inner function are not passed through - // to the top level, so we store exceptions in a variable and raise them at - // the end - let error; - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD], txn => { - this.getInboundGroupSession(roomId, senderKey, sessionId, txn, (session, sessionData, withheld) => { - if (session === null || sessionData === null) { - if (withheld) { - error = new algorithms.DecryptionError("MEGOLM_UNKNOWN_INBOUND_SESSION_ID", calculateWithheldMessage(withheld), { - session: senderKey + "|" + sessionId - }); - } - result = null; - return; - } - let res; - try { - res = session.decrypt(body); - } catch (e) { - if ((e === null || e === void 0 ? void 0 : e.message) === "OLM.UNKNOWN_MESSAGE_INDEX" && withheld) { - error = new algorithms.DecryptionError("MEGOLM_UNKNOWN_INBOUND_SESSION_ID", calculateWithheldMessage(withheld), { - session: senderKey + "|" + sessionId - }); - } else { - error = e; - } - return; - } - let plaintext = res.plaintext; - if (plaintext === undefined) { - // @ts-ignore - Compatibility for older olm versions. - plaintext = res; - } else { - // Check if we have seen this message index before to detect replay attacks. - // If the event ID and timestamp are specified, and the match the event ID - // and timestamp from the last time we used this message index, then we - // don't consider it a replay attack. - const messageIndexKey = senderKey + "|" + sessionId + "|" + res.message_index; - if (messageIndexKey in this.inboundGroupSessionMessageIndexes) { - const msgInfo = this.inboundGroupSessionMessageIndexes[messageIndexKey]; - if (msgInfo.id !== eventId || msgInfo.timestamp !== timestamp) { - error = new Error("Duplicate message index, possible replay attack: " + messageIndexKey); - return; - } - } - this.inboundGroupSessionMessageIndexes[messageIndexKey] = { - id: eventId, - timestamp: timestamp - }; - } - sessionData.session = session.pickle(this.pickleKey); - this.cryptoStore.storeEndToEndInboundGroupSession(senderKey, sessionId, sessionData, txn); - result = { - result: plaintext, - keysClaimed: sessionData.keysClaimed || {}, - senderKey: senderKey, - forwardingCurve25519KeyChain: sessionData.forwardingCurve25519KeyChain || [], - untrusted: !!sessionData.untrusted - }; - }); - }, _logger.logger.withPrefix("[decryptGroupMessage]")); - if (error) { - throw error; - } - return result; - } - - /** - * Determine if we have the keys for a given megolm session - * - * @param roomId - room in which the message was received - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * - * @returns true if we have the keys to this session - */ - async hasInboundSessionKeys(roomId, senderKey, sessionId) { - let result; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD], txn => { - this.cryptoStore.getEndToEndInboundGroupSession(senderKey, sessionId, txn, sessionData => { - if (sessionData === null) { - result = false; - return; - } - if (roomId !== sessionData.room_id) { - _logger.logger.warn(`requested keys for inbound group session ${senderKey}|` + `${sessionId}, with incorrect room_id ` + `(expected ${sessionData.room_id}, ` + `was ${roomId})`); - result = false; - } else { - result = true; - } - }); - }, _logger.logger.withPrefix("[hasInboundSessionKeys]")); - return result; - } - - /** - * Extract the keys to a given megolm session, for sharing - * - * @param roomId - room in which the message was received - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param chainIndex - The chain index at which to export the session. - * If omitted, export at the first index we know about. - * - * @returns - * details of the session key. The key is a base64-encoded megolm key in - * export format. - * - * @throws Error If the given chain index could not be obtained from the known - * index (ie. the given chain index is before the first we have). - */ - async getInboundGroupSessionKey(roomId, senderKey, sessionId, chainIndex) { - let result = null; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD], txn => { - this.getInboundGroupSession(roomId, senderKey, sessionId, txn, (session, sessionData) => { - if (session === null || sessionData === null) { - result = null; - return; - } - if (chainIndex === undefined) { - chainIndex = session.first_known_index(); - } - const exportedSession = session.export_session(chainIndex); - const claimedKeys = sessionData.keysClaimed || {}; - const senderEd25519Key = claimedKeys.ed25519 || null; - const forwardingKeyChain = sessionData.forwardingCurve25519KeyChain || []; - // older forwarded keys didn't set the "untrusted" - // property, but can be identified by having a - // non-empty forwarding key chain. These keys should - // be marked as untrusted since we don't know that they - // can be trusted - const untrusted = "untrusted" in sessionData ? sessionData.untrusted : forwardingKeyChain.length > 0; - result = { - chain_index: chainIndex, - key: exportedSession, - forwarding_curve25519_key_chain: forwardingKeyChain, - sender_claimed_ed25519_key: senderEd25519Key, - shared_history: sessionData.sharedHistory || false, - untrusted: untrusted - }; - }); - }, _logger.logger.withPrefix("[getInboundGroupSessionKey]")); - return result; - } - - /** - * Export an inbound group session - * - * @param senderKey - base64-encoded curve25519 key of the sender - * @param sessionId - session identifier - * @param sessionData - The session object from the store - * @returns exported session data - */ - exportInboundGroupSession(senderKey, sessionId, sessionData) { - return this.unpickleInboundGroupSession(sessionData, session => { - const messageIndex = session.first_known_index(); - return { - "sender_key": senderKey, - "sender_claimed_keys": sessionData.keysClaimed, - "room_id": sessionData.room_id, - "session_id": sessionId, - "session_key": session.export_session(messageIndex), - "forwarding_curve25519_key_chain": sessionData.forwardingCurve25519KeyChain || [], - "first_known_index": session.first_known_index(), - "org.matrix.msc3061.shared_history": sessionData.sharedHistory || false - }; - }); - } - async getSharedHistoryInboundGroupSessions(roomId) { - let result; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS], txn => { - result = this.cryptoStore.getSharedHistoryInboundGroupSessions(roomId, txn); - }, _logger.logger.withPrefix("[getSharedHistoryInboundGroupSessionsForRoom]")); - return result; - } - - // Utilities - // ========= - - /** - * Verify an ed25519 signature. - * - * @param key - ed25519 key - * @param message - message which was signed - * @param signature - base64-encoded signature to be checked - * - * @throws Error if there is a problem with the verification. If the key was - * too small then the message will be "OLM.INVALID_BASE64". If the signature - * was invalid then the message will be "OLM.BAD_MESSAGE_MAC". - */ - verifySignature(key, message, signature) { - this.getUtility(function (util) { - util.ed25519_verify(key, message, signature); - }); - } -} -exports.OlmDevice = OlmDevice; -const WITHHELD_MESSAGES = { - "m.unverified": "The sender has disabled encrypting to unverified devices.", - "m.blacklisted": "The sender has blocked you.", - "m.unauthorised": "You are not authorised to read the message.", - "m.no_olm": "Unable to establish a secure channel." -}; - -/** - * Calculate the message to use for the exception when a session key is withheld. - * - * @param withheld - An object that describes why the key was withheld. - * - * @returns the message - * - * @internal - */ -exports.WITHHELD_MESSAGES = WITHHELD_MESSAGES; -function calculateWithheldMessage(withheld) { - if (withheld.code && withheld.code in WITHHELD_MESSAGES) { - return WITHHELD_MESSAGES[withheld.code]; - } else if (withheld.reason) { - return withheld.reason; - } else { - return "decryption key withheld"; - } -} -//# sourceMappingURL=OlmDevice.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js.map deleted file mode 100644 index 2801abe..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OlmDevice.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"OlmDevice.js","names":["_logger","require","_indexeddbCryptoStore","algorithms","_interopRequireWildcard","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","MAX_PLAINTEXT_LENGTH","PayloadTooLargeError","Error","constructor","args","_defineProperty2","errcode","error","exports","checkPayloadLength","payloadString","undefined","length","OlmDevice","cryptoStore","Promise","resolve","getOlmVersion","global","Olm","get_library_version","init","pickleKey","fromExportedDevice","e2eKeys","account","Account","logger","warn","initialiseFromExportedDevice","initialiseAccount","JSON","parse","identity_keys","maxOneTimeKeys","max_number_of_one_time_keys","free","deviceCurve25519Key","curve25519","deviceEd25519Key","ed25519","exportedData","doTxn","IndexedDBCryptoStore","STORE_ACCOUNT","STORE_SESSIONS","txn","storeAccount","pickledAccount","sessions","forEach","session","deviceKey","sessionId","sessionInfo","lastReceivedMessageTs","storeEndToEndSession","unpickle","getAccount","create","pickle","func","export","result","getAllEndToEndSessions","pickledSession","push","getSession","getEndToEndSession","unpickleSession","Session","unpickledSessInfo","assign","saveSession","session_id","debug","describe","pickledSessionInfo","getUtility","utility","Utility","sign","message","getOneTimeKeys","one_time_keys","maxNumberOfOneTimeKeys","_this$maxOneTimeKeys","markKeysAsPublished","mark_keys_as_published","generateOneTimeKeys","numKeys","generate_one_time_keys","generateFallbackKey","generate_fallback_key","getFallbackKey","unpublished_fallback_key","forgetOldFallbackKey","forget_old_fallback_key","createOutboundSession","theirIdentityKey","theirOneTimeKey","newSessionId","create_outbound","Date","now","withPrefix","createInboundSession","theirDeviceIdentityKey","messageType","ciphertext","create_inbound_from","remove_one_time_keys","decrypt","payload","getSessionIdsForDevice","log","sessionsInProgress","e","sessionIds","getEndToEndSessions","keys","getSessionIdForDevice","nowait","sessionInfos","getSessionInfoForDevice","idxOfBest","i","thisSessInfo","thisLastReceived","bestSessInfo","bestLastReceived","deviceIdentityKey","info","sort","sessInfo","hasReceivedMessage","has_received_message","encryptMessage","res","sessionDesc","encrypt","decryptMessage","matchesSession","matches","matches_inbound","recordSessionProblem","type","fixed","storeEndToEndSessionProblem","sessionMayHaveProblems","timestamp","getEndToEndSessionProblem","filterOutNotifiedErrorDevices","devices","saveOutboundGroupSession","outboundGroupSessionStore","getOutboundGroupSession","pickled","OutboundGroupSession","createOutboundGroupSession","encryptGroupMessage","getOutboundGroupSessionKey","chain_index","message_index","session_key","unpickleInboundGroupSession","sessionData","InboundGroupSession","getInboundGroupSession","roomId","senderKey","getEndToEndInboundGroupSession","withheld","room_id","addInboundGroupSession","forwardingCurve25519KeyChain","sessionKey","keysClaimed","exportFormat","extraSessionData","STORE_INBOUND_GROUP_SESSIONS","STORE_INBOUND_GROUP_SESSIONS_WITHHELD","STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS","existingSession","existingSessionData","import_session","first_known_index","untrusted","export_session","storeEndToEndInboundGroupSession","sharedHistory","addSharedHistoryInboundGroupSession","addInboundGroupSessionWithheld","code","reason","storeEndToEndInboundGroupSessionWithheld","decryptGroupMessage","body","eventId","DecryptionError","calculateWithheldMessage","plaintext","messageIndexKey","inboundGroupSessionMessageIndexes","msgInfo","id","hasInboundSessionKeys","getInboundGroupSessionKey","chainIndex","exportedSession","claimedKeys","senderEd25519Key","forwardingKeyChain","forwarding_curve25519_key_chain","sender_claimed_ed25519_key","shared_history","exportInboundGroupSession","messageIndex","getSharedHistoryInboundGroupSessions","verifySignature","signature","util","ed25519_verify","WITHHELD_MESSAGES"],"sources":["../../src/crypto/OlmDevice.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Account, InboundGroupSession, OutboundGroupSession, Session, Utility } from \"@matrix-org/olm\";\n\nimport { logger, PrefixedLogger } from \"../logger\";\nimport { IndexedDBCryptoStore } from \"./store/indexeddb-crypto-store\";\nimport * as algorithms from \"./algorithms\";\nimport { CryptoStore, IProblem, ISessionInfo, IWithheld } from \"./store/base\";\nimport { IOlmDevice, IOutboundGroupSessionKey } from \"./algorithms/megolm\";\nimport { IMegolmSessionData, OlmGroupSessionExtraData } from \"../@types/crypto\";\nimport { IMessage } from \"./algorithms/olm\";\n\n// The maximum size of an event is 65K, and we base64 the content, so this is a\n// reasonable approximation to the biggest plaintext we can encrypt.\nconst MAX_PLAINTEXT_LENGTH = (65536 * 3) / 4;\n\nexport class PayloadTooLargeError extends Error {\n public readonly data = {\n errcode: \"M_TOO_LARGE\",\n error: \"Payload too large for encrypted message\",\n };\n}\n\nfunction checkPayloadLength(payloadString: string): void {\n if (payloadString === undefined) {\n throw new Error(\"payloadString undefined\");\n }\n\n if (payloadString.length > MAX_PLAINTEXT_LENGTH) {\n // might as well fail early here rather than letting the olm library throw\n // a cryptic memory allocation error.\n //\n // Note that even if we manage to do the encryption, the message send may fail,\n // because by the time we've wrapped the ciphertext in the event object, it may\n // exceed 65K. But at least we won't just fail with \"abort()\" in that case.\n throw new PayloadTooLargeError(\n `Message too long (${payloadString.length} bytes). ` +\n `The maximum for an encrypted message is ${MAX_PLAINTEXT_LENGTH} bytes.`,\n );\n }\n}\n\ninterface IInitOpts {\n fromExportedDevice?: IExportedDevice;\n pickleKey?: string;\n}\n\n/** data stored in the session store about an inbound group session */\nexport interface InboundGroupSessionData {\n room_id: string; // eslint-disable-line camelcase\n /** pickled Olm.InboundGroupSession */\n session: string;\n keysClaimed: Record;\n /** Devices involved in forwarding this session to us (normally empty). */\n forwardingCurve25519KeyChain: string[];\n /** whether this session is untrusted. */\n untrusted?: boolean;\n /** whether this session exists during the room being set to shared history. */\n sharedHistory?: boolean;\n}\n\nexport interface IDecryptedGroupMessage {\n result: string;\n keysClaimed: Record;\n senderKey: string;\n forwardingCurve25519KeyChain: string[];\n untrusted: boolean;\n}\n\nexport interface IInboundSession {\n payload: string;\n session_id: string;\n}\n\nexport interface IExportedDevice {\n pickleKey: string;\n pickledAccount: string;\n sessions: ISessionInfo[];\n}\n\ninterface IUnpickledSessionInfo extends Omit {\n session: Session;\n}\n\n/* eslint-disable camelcase */\ninterface IInboundGroupSessionKey {\n chain_index: number;\n key: string;\n forwarding_curve25519_key_chain: string[];\n sender_claimed_ed25519_key: string | null;\n shared_history: boolean;\n untrusted?: boolean;\n}\n/* eslint-enable camelcase */\n\ntype OneTimeKeys = { curve25519: { [keyId: string]: string } };\n\n/**\n * Manages the olm cryptography functions. Each OlmDevice has a single\n * OlmAccount and a number of OlmSessions.\n *\n * Accounts and sessions are kept pickled in the cryptoStore.\n */\nexport class OlmDevice {\n public pickleKey = \"DEFAULT_KEY\"; // set by consumers\n\n /** Curve25519 key for the account, unknown until we load the account from storage in init() */\n public deviceCurve25519Key: string | null = null;\n /** Ed25519 key for the account, unknown until we load the account from storage in init() */\n public deviceEd25519Key: string | null = null;\n private maxOneTimeKeys: number | null = null;\n\n // we don't bother stashing outboundgroupsessions in the cryptoStore -\n // instead we keep them here.\n private outboundGroupSessionStore: Record = {};\n\n // Store a set of decrypted message indexes for each group session.\n // This partially mitigates a replay attack where a MITM resends a group\n // message into the room.\n //\n // When we decrypt a message and the message index matches a previously\n // decrypted message, one possible cause of that is that we are decrypting\n // the same event, and may not indicate an actual replay attack. For\n // example, this could happen if we receive events, forget about them, and\n // then re-fetch them when we backfill. So we store the event ID and\n // timestamp corresponding to each message index when we first decrypt it,\n // and compare these against the event ID and timestamp every time we use\n // that same index. If they match, then we're probably decrypting the same\n // event and we don't consider it a replay attack.\n //\n // Keys are strings of form \"||\"\n // Values are objects of the form \"{id: , timestamp: }\"\n private inboundGroupSessionMessageIndexes: Record = {};\n\n // Keep track of sessions that we're starting, so that we don't start\n // multiple sessions for the same device at the same time.\n public sessionsInProgress: Record> = {}; // set by consumers\n\n // Used by olm to serialise prekey message decryptions\n public olmPrekeyPromise: Promise = Promise.resolve(); // set by consumers\n\n public constructor(private readonly cryptoStore: CryptoStore) {}\n\n /**\n * @returns The version of Olm.\n */\n public static getOlmVersion(): [number, number, number] {\n return global.Olm.get_library_version();\n }\n\n /**\n * Initialise the OlmAccount. This must be called before any other operations\n * on the OlmDevice.\n *\n * Data from an exported Olm device can be provided\n * in order to re-create this device.\n *\n * Attempts to load the OlmAccount from the crypto store, or creates one if none is\n * found.\n *\n * Reads the device keys from the OlmAccount object.\n *\n * @param fromExportedDevice - (Optional) data from exported device\n * that must be re-created.\n * If present, opts.pickleKey is ignored\n * (exported data already provides a pickle key)\n * @param pickleKey - (Optional) pickle key to set instead of default one\n */\n public async init({ pickleKey, fromExportedDevice }: IInitOpts = {}): Promise {\n let e2eKeys;\n const account = new global.Olm.Account();\n\n try {\n if (fromExportedDevice) {\n if (pickleKey) {\n logger.warn(\"ignoring opts.pickleKey\" + \" because opts.fromExportedDevice is present.\");\n }\n this.pickleKey = fromExportedDevice.pickleKey;\n await this.initialiseFromExportedDevice(fromExportedDevice, account);\n } else {\n if (pickleKey) {\n this.pickleKey = pickleKey;\n }\n await this.initialiseAccount(account);\n }\n e2eKeys = JSON.parse(account.identity_keys());\n\n this.maxOneTimeKeys = account.max_number_of_one_time_keys();\n } finally {\n account.free();\n }\n\n this.deviceCurve25519Key = e2eKeys.curve25519;\n this.deviceEd25519Key = e2eKeys.ed25519;\n }\n\n /**\n * Populates the crypto store using data that was exported from an existing device.\n * Note that for now only the “account” and “sessions” stores are populated;\n * Other stores will be as with a new device.\n *\n * @param exportedData - Data exported from another device\n * through the “export” method.\n * @param account - an olm account to initialize\n */\n private async initialiseFromExportedDevice(exportedData: IExportedDevice, account: Account): Promise {\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [IndexedDBCryptoStore.STORE_ACCOUNT, IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.cryptoStore.storeAccount(txn, exportedData.pickledAccount);\n exportedData.sessions.forEach((session) => {\n const { deviceKey, sessionId } = session;\n const sessionInfo = {\n session: session.session,\n lastReceivedMessageTs: session.lastReceivedMessageTs,\n };\n this.cryptoStore.storeEndToEndSession(deviceKey!, sessionId!, sessionInfo, txn);\n });\n },\n );\n account.unpickle(this.pickleKey, exportedData.pickledAccount);\n }\n\n private async initialiseAccount(account: Account): Promise {\n await this.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.cryptoStore.getAccount(txn, (pickledAccount) => {\n if (pickledAccount !== null) {\n account.unpickle(this.pickleKey, pickledAccount);\n } else {\n account.create();\n pickledAccount = account.pickle(this.pickleKey);\n this.cryptoStore.storeAccount(txn, pickledAccount);\n }\n });\n });\n }\n\n /**\n * extract our OlmAccount from the crypto store and call the given function\n * with the account object\n * The `account` object is usable only within the callback passed to this\n * function and will be freed as soon the callback returns. It is *not*\n * usable for the rest of the lifetime of the transaction.\n * This function requires a live transaction object from cryptoStore.doTxn()\n * and therefore may only be called in a doTxn() callback.\n *\n * @param txn - Opaque transaction object from cryptoStore.doTxn()\n * @internal\n */\n private getAccount(txn: unknown, func: (account: Account) => void): void {\n this.cryptoStore.getAccount(txn, (pickledAccount: string | null) => {\n const account = new global.Olm.Account();\n try {\n account.unpickle(this.pickleKey, pickledAccount!);\n func(account);\n } finally {\n account.free();\n }\n });\n }\n\n /*\n * Saves an account to the crypto store.\n * This function requires a live transaction object from cryptoStore.doTxn()\n * and therefore may only be called in a doTxn() callback.\n *\n * @param txn - Opaque transaction object from cryptoStore.doTxn()\n * @param Olm.Account object\n * @internal\n */\n private storeAccount(txn: unknown, account: Account): void {\n this.cryptoStore.storeAccount(txn, account.pickle(this.pickleKey));\n }\n\n /**\n * Export data for re-creating the Olm device later.\n * TODO export data other than just account and (P2P) sessions.\n *\n * @returns The exported data\n */\n public async export(): Promise {\n const result: Partial = {\n pickleKey: this.pickleKey,\n };\n\n await this.cryptoStore.doTxn(\n \"readonly\",\n [IndexedDBCryptoStore.STORE_ACCOUNT, IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.cryptoStore.getAccount(txn, (pickledAccount: string | null) => {\n result.pickledAccount = pickledAccount!;\n });\n result.sessions = [];\n // Note that the pickledSession object we get in the callback\n // is not exactly the same thing you get in method _getSession\n // see documentation of IndexedDBCryptoStore.getAllEndToEndSessions\n this.cryptoStore.getAllEndToEndSessions(txn, (pickledSession) => {\n result.sessions!.push(pickledSession!);\n });\n },\n );\n return result as IExportedDevice;\n }\n\n /**\n * extract an OlmSession from the session store and call the given function\n * The session is usable only within the callback passed to this\n * function and will be freed as soon the callback returns. It is *not*\n * usable for the rest of the lifetime of the transaction.\n *\n * @param txn - Opaque transaction object from cryptoStore.doTxn()\n * @internal\n */\n private getSession(\n deviceKey: string,\n sessionId: string,\n txn: unknown,\n func: (unpickledSessionInfo: IUnpickledSessionInfo) => void,\n ): void {\n this.cryptoStore.getEndToEndSession(deviceKey, sessionId, txn, (sessionInfo: ISessionInfo | null) => {\n this.unpickleSession(sessionInfo!, func);\n });\n }\n\n /**\n * Creates a session object from a session pickle and executes the given\n * function with it. The session object is destroyed once the function\n * returns.\n *\n * @internal\n */\n private unpickleSession(\n sessionInfo: ISessionInfo,\n func: (unpickledSessionInfo: IUnpickledSessionInfo) => void,\n ): void {\n const session = new global.Olm.Session();\n try {\n session.unpickle(this.pickleKey, sessionInfo.session!);\n const unpickledSessInfo: IUnpickledSessionInfo = Object.assign({}, sessionInfo, { session });\n\n func(unpickledSessInfo);\n } finally {\n session.free();\n }\n }\n\n /**\n * store our OlmSession in the session store\n *\n * @param sessionInfo - `{session: OlmSession, lastReceivedMessageTs: int}`\n * @param txn - Opaque transaction object from cryptoStore.doTxn()\n * @internal\n */\n private saveSession(deviceKey: string, sessionInfo: IUnpickledSessionInfo, txn: unknown): void {\n const sessionId = sessionInfo.session.session_id();\n logger.debug(`Saving Olm session ${sessionId} with device ${deviceKey}: ${sessionInfo.session.describe()}`);\n\n // Why do we re-use the input object for this, overwriting the same key with a different\n // type? Is it because we want to erase the unpickled session to enforce that it's no longer\n // used? A comment would be great.\n const pickledSessionInfo = Object.assign(sessionInfo, {\n session: sessionInfo.session.pickle(this.pickleKey),\n });\n this.cryptoStore.storeEndToEndSession(deviceKey, sessionId, pickledSessionInfo, txn);\n }\n\n /**\n * get an OlmUtility and call the given function\n *\n * @returns result of func\n * @internal\n */\n private getUtility(func: (utility: Utility) => T): T {\n const utility = new global.Olm.Utility();\n try {\n return func(utility);\n } finally {\n utility.free();\n }\n }\n\n /**\n * Signs a message with the ed25519 key for this account.\n *\n * @param message - message to be signed\n * @returns base64-encoded signature\n */\n public async sign(message: string): Promise {\n let result: string;\n await this.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.getAccount(txn, (account: Account) => {\n result = account.sign(message);\n });\n });\n return result!;\n }\n\n /**\n * Get the current (unused, unpublished) one-time keys for this account.\n *\n * @returns one time keys; an object with the single property\n * curve25519, which is itself an object mapping key id to Curve25519\n * key.\n */\n public async getOneTimeKeys(): Promise {\n let result: OneTimeKeys;\n await this.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.getAccount(txn, (account) => {\n result = JSON.parse(account.one_time_keys());\n });\n });\n\n return result!;\n }\n\n /**\n * Get the maximum number of one-time keys we can store.\n *\n * @returns number of keys\n */\n public maxNumberOfOneTimeKeys(): number {\n return this.maxOneTimeKeys ?? -1;\n }\n\n /**\n * Marks all of the one-time keys as published.\n */\n public async markKeysAsPublished(): Promise {\n await this.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.getAccount(txn, (account: Account) => {\n account.mark_keys_as_published();\n this.storeAccount(txn, account);\n });\n });\n }\n\n /**\n * Generate some new one-time keys\n *\n * @param numKeys - number of keys to generate\n * @returns Resolved once the account is saved back having generated the keys\n */\n public generateOneTimeKeys(numKeys: number): Promise {\n return this.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.getAccount(txn, (account) => {\n account.generate_one_time_keys(numKeys);\n this.storeAccount(txn, account);\n });\n });\n }\n\n /**\n * Generate a new fallback keys\n *\n * @returns Resolved once the account is saved back having generated the key\n */\n public async generateFallbackKey(): Promise {\n await this.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.getAccount(txn, (account) => {\n account.generate_fallback_key();\n this.storeAccount(txn, account);\n });\n });\n }\n\n public async getFallbackKey(): Promise>> {\n let result: Record>;\n await this.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.getAccount(txn, (account: Account) => {\n result = JSON.parse(account.unpublished_fallback_key());\n });\n });\n return result!;\n }\n\n public async forgetOldFallbackKey(): Promise {\n await this.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.getAccount(txn, (account: Account) => {\n account.forget_old_fallback_key();\n this.storeAccount(txn, account);\n });\n });\n }\n\n /**\n * Generate a new outbound session\n *\n * The new session will be stored in the cryptoStore.\n *\n * @param theirIdentityKey - remote user's Curve25519 identity key\n * @param theirOneTimeKey - remote user's one-time Curve25519 key\n * @returns sessionId for the outbound session.\n */\n public async createOutboundSession(theirIdentityKey: string, theirOneTimeKey: string): Promise {\n let newSessionId: string;\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [IndexedDBCryptoStore.STORE_ACCOUNT, IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.getAccount(txn, (account: Account) => {\n const session = new global.Olm.Session();\n try {\n session.create_outbound(account, theirIdentityKey, theirOneTimeKey);\n newSessionId = session.session_id();\n this.storeAccount(txn, account);\n const sessionInfo: IUnpickledSessionInfo = {\n session,\n // Pretend we've received a message at this point, otherwise\n // if we try to send a message to the device, it won't use\n // this session\n lastReceivedMessageTs: Date.now(),\n };\n this.saveSession(theirIdentityKey, sessionInfo, txn);\n } finally {\n session.free();\n }\n });\n },\n logger.withPrefix(\"[createOutboundSession]\"),\n );\n return newSessionId!;\n }\n\n /**\n * Generate a new inbound session, given an incoming message\n *\n * @param theirDeviceIdentityKey - remote user's Curve25519 identity key\n * @param messageType - messageType field from the received message (must be 0)\n * @param ciphertext - base64-encoded body from the received message\n *\n * @returns decrypted payload, and\n * session id of new session\n *\n * @throws Error if the received message was not valid (for instance, it didn't use a valid one-time key).\n */\n public async createInboundSession(\n theirDeviceIdentityKey: string,\n messageType: number,\n ciphertext: string,\n ): Promise {\n if (messageType !== 0) {\n throw new Error(\"Need messageType == 0 to create inbound session\");\n }\n\n let result: { payload: string; session_id: string }; // eslint-disable-line camelcase\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [IndexedDBCryptoStore.STORE_ACCOUNT, IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.getAccount(txn, (account: Account) => {\n const session = new global.Olm.Session();\n try {\n session.create_inbound_from(account, theirDeviceIdentityKey, ciphertext);\n account.remove_one_time_keys(session);\n this.storeAccount(txn, account);\n\n const payloadString = session.decrypt(messageType, ciphertext);\n\n const sessionInfo: IUnpickledSessionInfo = {\n session,\n // this counts as a received message: set last received message time\n // to now\n lastReceivedMessageTs: Date.now(),\n };\n this.saveSession(theirDeviceIdentityKey, sessionInfo, txn);\n\n result = {\n payload: payloadString,\n session_id: session.session_id(),\n };\n } finally {\n session.free();\n }\n });\n },\n logger.withPrefix(\"[createInboundSession]\"),\n );\n\n return result!;\n }\n\n /**\n * Get a list of known session IDs for the given device\n *\n * @param theirDeviceIdentityKey - Curve25519 identity key for the\n * remote device\n * @returns a list of known session ids for the device\n */\n public async getSessionIdsForDevice(theirDeviceIdentityKey: string): Promise {\n const log = logger.withPrefix(\"[getSessionIdsForDevice]\");\n\n if (theirDeviceIdentityKey in this.sessionsInProgress) {\n log.debug(`Waiting for Olm session for ${theirDeviceIdentityKey} to be created`);\n try {\n await this.sessionsInProgress[theirDeviceIdentityKey];\n } catch (e) {\n // if the session failed to be created, just fall through and\n // return an empty result\n }\n }\n let sessionIds: string[];\n await this.cryptoStore.doTxn(\n \"readonly\",\n [IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.cryptoStore.getEndToEndSessions(theirDeviceIdentityKey, txn, (sessions) => {\n sessionIds = Object.keys(sessions);\n });\n },\n log,\n );\n\n return sessionIds!;\n }\n\n /**\n * Get the right olm session id for encrypting messages to the given identity key\n *\n * @param theirDeviceIdentityKey - Curve25519 identity key for the\n * remote device\n * @param nowait - Don't wait for an in-progress session to complete.\n * This should only be set to true of the calling function is the function\n * that marked the session as being in-progress.\n * @param log - A possibly customised log\n * @returns session id, or null if no established session\n */\n public async getSessionIdForDevice(\n theirDeviceIdentityKey: string,\n nowait = false,\n log?: PrefixedLogger,\n ): Promise {\n const sessionInfos = await this.getSessionInfoForDevice(theirDeviceIdentityKey, nowait, log);\n\n if (sessionInfos.length === 0) {\n return null;\n }\n // Use the session that has most recently received a message\n let idxOfBest = 0;\n for (let i = 1; i < sessionInfos.length; i++) {\n const thisSessInfo = sessionInfos[i];\n const thisLastReceived =\n thisSessInfo.lastReceivedMessageTs === undefined ? 0 : thisSessInfo.lastReceivedMessageTs;\n\n const bestSessInfo = sessionInfos[idxOfBest];\n const bestLastReceived =\n bestSessInfo.lastReceivedMessageTs === undefined ? 0 : bestSessInfo.lastReceivedMessageTs;\n if (\n thisLastReceived > bestLastReceived ||\n (thisLastReceived === bestLastReceived && thisSessInfo.sessionId < bestSessInfo.sessionId)\n ) {\n idxOfBest = i;\n }\n }\n return sessionInfos[idxOfBest].sessionId;\n }\n\n /**\n * Get information on the active Olm sessions for a device.\n *

\n * Returns an array, with an entry for each active session. The first entry in\n * the result will be the one used for outgoing messages. Each entry contains\n * the keys 'hasReceivedMessage' (true if the session has received an incoming\n * message and is therefore past the pre-key stage), and 'sessionId'.\n *\n * @param deviceIdentityKey - Curve25519 identity key for the device\n * @param nowait - Don't wait for an in-progress session to complete.\n * This should only be set to true of the calling function is the function\n * that marked the session as being in-progress.\n * @param log - A possibly customised log\n */\n public async getSessionInfoForDevice(\n deviceIdentityKey: string,\n nowait = false,\n log = logger,\n ): Promise<{ sessionId: string; lastReceivedMessageTs: number; hasReceivedMessage: boolean }[]> {\n log = log.withPrefix(\"[getSessionInfoForDevice]\");\n\n if (deviceIdentityKey in this.sessionsInProgress && !nowait) {\n log.debug(`Waiting for Olm session for ${deviceIdentityKey} to be created`);\n try {\n await this.sessionsInProgress[deviceIdentityKey];\n } catch (e) {\n // if the session failed to be created, then just fall through and\n // return an empty result\n }\n }\n const info: {\n lastReceivedMessageTs: number;\n hasReceivedMessage: boolean;\n sessionId: string;\n }[] = [];\n\n await this.cryptoStore.doTxn(\n \"readonly\",\n [IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.cryptoStore.getEndToEndSessions(deviceIdentityKey, txn, (sessions) => {\n const sessionIds = Object.keys(sessions).sort();\n for (const sessionId of sessionIds) {\n this.unpickleSession(sessions[sessionId], (sessInfo: IUnpickledSessionInfo) => {\n info.push({\n lastReceivedMessageTs: sessInfo.lastReceivedMessageTs!,\n hasReceivedMessage: sessInfo.session.has_received_message(),\n sessionId,\n });\n });\n }\n });\n },\n log,\n );\n\n return info;\n }\n\n /**\n * Encrypt an outgoing message using an existing session\n *\n * @param theirDeviceIdentityKey - Curve25519 identity key for the\n * remote device\n * @param sessionId - the id of the active session\n * @param payloadString - payload to be encrypted and sent\n *\n * @returns ciphertext\n */\n public async encryptMessage(\n theirDeviceIdentityKey: string,\n sessionId: string,\n payloadString: string,\n ): Promise {\n checkPayloadLength(payloadString);\n\n let res: IMessage;\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.getSession(theirDeviceIdentityKey, sessionId, txn, (sessionInfo) => {\n const sessionDesc = sessionInfo.session.describe();\n logger.log(\n \"encryptMessage: Olm Session ID \" +\n sessionId +\n \" to \" +\n theirDeviceIdentityKey +\n \": \" +\n sessionDesc,\n );\n res = sessionInfo.session.encrypt(payloadString);\n this.saveSession(theirDeviceIdentityKey, sessionInfo, txn);\n });\n },\n logger.withPrefix(\"[encryptMessage]\"),\n );\n return res!;\n }\n\n /**\n * Decrypt an incoming message using an existing session\n *\n * @param theirDeviceIdentityKey - Curve25519 identity key for the\n * remote device\n * @param sessionId - the id of the active session\n * @param messageType - messageType field from the received message\n * @param ciphertext - base64-encoded body from the received message\n *\n * @returns decrypted payload.\n */\n public async decryptMessage(\n theirDeviceIdentityKey: string,\n sessionId: string,\n messageType: number,\n ciphertext: string,\n ): Promise {\n let payloadString: string;\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.getSession(theirDeviceIdentityKey, sessionId, txn, (sessionInfo: IUnpickledSessionInfo) => {\n const sessionDesc = sessionInfo.session.describe();\n logger.log(\n \"decryptMessage: Olm Session ID \" +\n sessionId +\n \" from \" +\n theirDeviceIdentityKey +\n \": \" +\n sessionDesc,\n );\n payloadString = sessionInfo.session.decrypt(messageType, ciphertext);\n sessionInfo.lastReceivedMessageTs = Date.now();\n this.saveSession(theirDeviceIdentityKey, sessionInfo, txn);\n });\n },\n logger.withPrefix(\"[decryptMessage]\"),\n );\n return payloadString!;\n }\n\n /**\n * Determine if an incoming messages is a prekey message matching an existing session\n *\n * @param theirDeviceIdentityKey - Curve25519 identity key for the\n * remote device\n * @param sessionId - the id of the active session\n * @param messageType - messageType field from the received message\n * @param ciphertext - base64-encoded body from the received message\n *\n * @returns true if the received message is a prekey message which matches\n * the given session.\n */\n public async matchesSession(\n theirDeviceIdentityKey: string,\n sessionId: string,\n messageType: number,\n ciphertext: string,\n ): Promise {\n if (messageType !== 0) {\n return false;\n }\n\n let matches: boolean;\n await this.cryptoStore.doTxn(\n \"readonly\",\n [IndexedDBCryptoStore.STORE_SESSIONS],\n (txn) => {\n this.getSession(theirDeviceIdentityKey, sessionId, txn, (sessionInfo) => {\n matches = sessionInfo.session.matches_inbound(ciphertext);\n });\n },\n logger.withPrefix(\"[matchesSession]\"),\n );\n return matches!;\n }\n\n public async recordSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise {\n logger.info(`Recording problem on olm session with ${deviceKey} of type ${type}. Recreating: ${fixed}`);\n await this.cryptoStore.storeEndToEndSessionProblem(deviceKey, type, fixed);\n }\n\n public sessionMayHaveProblems(deviceKey: string, timestamp: number): Promise {\n return this.cryptoStore.getEndToEndSessionProblem(deviceKey, timestamp);\n }\n\n public filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise {\n return this.cryptoStore.filterOutNotifiedErrorDevices(devices);\n }\n\n // Outbound group session\n // ======================\n\n /**\n * store an OutboundGroupSession in outboundGroupSessionStore\n *\n * @internal\n */\n private saveOutboundGroupSession(session: OutboundGroupSession): void {\n this.outboundGroupSessionStore[session.session_id()] = session.pickle(this.pickleKey);\n }\n\n /**\n * extract an OutboundGroupSession from outboundGroupSessionStore and call the\n * given function\n *\n * @returns result of func\n * @internal\n */\n private getOutboundGroupSession(sessionId: string, func: (session: OutboundGroupSession) => T): T {\n const pickled = this.outboundGroupSessionStore[sessionId];\n if (pickled === undefined) {\n throw new Error(\"Unknown outbound group session \" + sessionId);\n }\n\n const session = new global.Olm.OutboundGroupSession();\n try {\n session.unpickle(this.pickleKey, pickled);\n return func(session);\n } finally {\n session.free();\n }\n }\n\n /**\n * Generate a new outbound group session\n *\n * @returns sessionId for the outbound session.\n */\n public createOutboundGroupSession(): string {\n const session = new global.Olm.OutboundGroupSession();\n try {\n session.create();\n this.saveOutboundGroupSession(session);\n return session.session_id();\n } finally {\n session.free();\n }\n }\n\n /**\n * Encrypt an outgoing message with an outbound group session\n *\n * @param sessionId - the id of the outboundgroupsession\n * @param payloadString - payload to be encrypted and sent\n *\n * @returns ciphertext\n */\n public encryptGroupMessage(sessionId: string, payloadString: string): string {\n logger.log(`encrypting msg with megolm session ${sessionId}`);\n\n checkPayloadLength(payloadString);\n\n return this.getOutboundGroupSession(sessionId, (session: OutboundGroupSession) => {\n const res = session.encrypt(payloadString);\n this.saveOutboundGroupSession(session);\n return res;\n });\n }\n\n /**\n * Get the session keys for an outbound group session\n *\n * @param sessionId - the id of the outbound group session\n *\n * @returns current chain index, and\n * base64-encoded secret key.\n */\n public getOutboundGroupSessionKey(sessionId: string): IOutboundGroupSessionKey {\n return this.getOutboundGroupSession(sessionId, function (session: OutboundGroupSession) {\n return {\n chain_index: session.message_index(),\n key: session.session_key(),\n };\n });\n }\n\n // Inbound group session\n // =====================\n\n /**\n * Unpickle a session from a sessionData object and invoke the given function.\n * The session is valid only until func returns.\n *\n * @param sessionData - Object describing the session.\n * @param func - Invoked with the unpickled session\n * @returns result of func\n */\n private unpickleInboundGroupSession(\n sessionData: InboundGroupSessionData,\n func: (session: InboundGroupSession) => T,\n ): T {\n const session = new global.Olm.InboundGroupSession();\n try {\n session.unpickle(this.pickleKey, sessionData.session);\n return func(session);\n } finally {\n session.free();\n }\n }\n\n /**\n * extract an InboundGroupSession from the crypto store and call the given function\n *\n * @param roomId - The room ID to extract the session for, or null to fetch\n * sessions for any room.\n * @param txn - Opaque transaction object from cryptoStore.doTxn()\n * @param func - function to call.\n *\n * @internal\n */\n private getInboundGroupSession(\n roomId: string,\n senderKey: string,\n sessionId: string,\n txn: unknown,\n func: (\n session: InboundGroupSession | null,\n data: InboundGroupSessionData | null,\n withheld: IWithheld | null,\n ) => void,\n ): void {\n this.cryptoStore.getEndToEndInboundGroupSession(\n senderKey,\n sessionId,\n txn,\n (sessionData: InboundGroupSessionData | null, withheld: IWithheld | null) => {\n if (sessionData === null) {\n func(null, null, withheld);\n return;\n }\n\n // if we were given a room ID, check that the it matches the original one for the session. This stops\n // the HS pretending a message was targeting a different room.\n if (roomId !== null && roomId !== sessionData.room_id) {\n throw new Error(\n \"Mismatched room_id for inbound group session (expected \" +\n sessionData.room_id +\n \", was \" +\n roomId +\n \")\",\n );\n }\n\n this.unpickleInboundGroupSession(sessionData, (session: InboundGroupSession) => {\n func(session, sessionData, withheld);\n });\n },\n );\n }\n\n /**\n * Add an inbound group session to the session store\n *\n * @param roomId - room in which this session will be used\n * @param senderKey - base64-encoded curve25519 key of the sender\n * @param forwardingCurve25519KeyChain - Devices involved in forwarding\n * this session to us.\n * @param sessionId - session identifier\n * @param sessionKey - base64-encoded secret key\n * @param keysClaimed - Other keys the sender claims.\n * @param exportFormat - true if the megolm keys are in export format\n * (ie, they lack an ed25519 signature)\n * @param extraSessionData - any other data to be include with the session\n */\n public async addInboundGroupSession(\n roomId: string,\n senderKey: string,\n forwardingCurve25519KeyChain: string[],\n sessionId: string,\n sessionKey: string,\n keysClaimed: Record,\n exportFormat: boolean,\n extraSessionData: OlmGroupSessionExtraData = {},\n ): Promise {\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS,\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD,\n IndexedDBCryptoStore.STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS,\n ],\n (txn) => {\n /* if we already have this session, consider updating it */\n this.getInboundGroupSession(\n roomId,\n senderKey,\n sessionId,\n txn,\n (\n existingSession: InboundGroupSession | null,\n existingSessionData: InboundGroupSessionData | null,\n ) => {\n // new session.\n const session = new global.Olm.InboundGroupSession();\n try {\n if (exportFormat) {\n session.import_session(sessionKey);\n } else {\n session.create(sessionKey);\n }\n if (sessionId != session.session_id()) {\n throw new Error(\"Mismatched group session ID from senderKey: \" + senderKey);\n }\n\n if (existingSession) {\n logger.log(`Update for megolm session ${senderKey}|${sessionId}`);\n if (existingSession.first_known_index() <= session.first_known_index()) {\n if (!existingSessionData!.untrusted || extraSessionData.untrusted) {\n // existing session has less-than-or-equal index\n // (i.e. can decrypt at least as much), and the\n // new session's trust does not win over the old\n // session's trust, so keep it\n logger.log(`Keeping existing megolm session ${senderKey}|${sessionId}`);\n return;\n }\n if (existingSession.first_known_index() < session.first_known_index()) {\n // We want to upgrade the existing session's trust,\n // but we can't just use the new session because we'll\n // lose the lower index. Check that the sessions connect\n // properly, and then manually set the existing session\n // as trusted.\n if (\n existingSession.export_session(session.first_known_index()) ===\n session.export_session(session.first_known_index())\n ) {\n logger.info(\n \"Upgrading trust of existing megolm session \" +\n `${senderKey}|${sessionId} based on newly-received trusted session`,\n );\n existingSessionData!.untrusted = false;\n this.cryptoStore.storeEndToEndInboundGroupSession(\n senderKey,\n sessionId,\n existingSessionData!,\n txn,\n );\n } else {\n logger.warn(\n `Newly-received megolm session ${senderKey}|$sessionId}` +\n \" does not match existing session! Keeping existing session\",\n );\n }\n return;\n }\n // If the sessions have the same index, go ahead and store the new trusted one.\n }\n }\n\n logger.info(\n `Storing megolm session ${senderKey}|${sessionId} with first index ` +\n session.first_known_index(),\n );\n\n const sessionData = Object.assign({}, extraSessionData, {\n room_id: roomId,\n session: session.pickle(this.pickleKey),\n keysClaimed: keysClaimed,\n forwardingCurve25519KeyChain: forwardingCurve25519KeyChain,\n });\n\n this.cryptoStore.storeEndToEndInboundGroupSession(senderKey, sessionId, sessionData, txn);\n\n if (!existingSession && extraSessionData.sharedHistory) {\n this.cryptoStore.addSharedHistoryInboundGroupSession(roomId, senderKey, sessionId, txn);\n }\n } finally {\n session.free();\n }\n },\n );\n },\n logger.withPrefix(\"[addInboundGroupSession]\"),\n );\n }\n\n /**\n * Record in the data store why an inbound group session was withheld.\n *\n * @param roomId - room that the session belongs to\n * @param senderKey - base64-encoded curve25519 key of the sender\n * @param sessionId - session identifier\n * @param code - reason code\n * @param reason - human-readable version of `code`\n */\n public async addInboundGroupSessionWithheld(\n roomId: string,\n senderKey: string,\n sessionId: string,\n code: string,\n reason: string,\n ): Promise {\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD],\n (txn) => {\n this.cryptoStore.storeEndToEndInboundGroupSessionWithheld(\n senderKey,\n sessionId,\n {\n room_id: roomId,\n code: code,\n reason: reason,\n },\n txn,\n );\n },\n );\n }\n\n /**\n * Decrypt a received message with an inbound group session\n *\n * @param roomId - room in which the message was received\n * @param senderKey - base64-encoded curve25519 key of the sender\n * @param sessionId - session identifier\n * @param body - base64-encoded body of the encrypted message\n * @param eventId - ID of the event being decrypted\n * @param timestamp - timestamp of the event being decrypted\n *\n * @returns null if the sessionId is unknown\n */\n public async decryptGroupMessage(\n roomId: string,\n senderKey: string,\n sessionId: string,\n body: string,\n eventId: string,\n timestamp: number,\n ): Promise {\n let result: IDecryptedGroupMessage | null = null;\n // when the localstorage crypto store is used as an indexeddb backend,\n // exceptions thrown from within the inner function are not passed through\n // to the top level, so we store exceptions in a variable and raise them at\n // the end\n let error: Error;\n\n await this.cryptoStore.doTxn(\n \"readwrite\",\n [\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS,\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD,\n ],\n (txn) => {\n this.getInboundGroupSession(roomId, senderKey, sessionId, txn, (session, sessionData, withheld) => {\n if (session === null || sessionData === null) {\n if (withheld) {\n error = new algorithms.DecryptionError(\n \"MEGOLM_UNKNOWN_INBOUND_SESSION_ID\",\n calculateWithheldMessage(withheld),\n {\n session: senderKey + \"|\" + sessionId,\n },\n );\n }\n result = null;\n return;\n }\n let res: ReturnType;\n try {\n res = session.decrypt(body);\n } catch (e) {\n if ((e)?.message === \"OLM.UNKNOWN_MESSAGE_INDEX\" && withheld) {\n error = new algorithms.DecryptionError(\n \"MEGOLM_UNKNOWN_INBOUND_SESSION_ID\",\n calculateWithheldMessage(withheld),\n {\n session: senderKey + \"|\" + sessionId,\n },\n );\n } else {\n error = e;\n }\n return;\n }\n\n let plaintext: string = res.plaintext;\n if (plaintext === undefined) {\n // @ts-ignore - Compatibility for older olm versions.\n plaintext = res as string;\n } else {\n // Check if we have seen this message index before to detect replay attacks.\n // If the event ID and timestamp are specified, and the match the event ID\n // and timestamp from the last time we used this message index, then we\n // don't consider it a replay attack.\n const messageIndexKey = senderKey + \"|\" + sessionId + \"|\" + res.message_index;\n if (messageIndexKey in this.inboundGroupSessionMessageIndexes) {\n const msgInfo = this.inboundGroupSessionMessageIndexes[messageIndexKey];\n if (msgInfo.id !== eventId || msgInfo.timestamp !== timestamp) {\n error = new Error(\n \"Duplicate message index, possible replay attack: \" + messageIndexKey,\n );\n return;\n }\n }\n this.inboundGroupSessionMessageIndexes[messageIndexKey] = {\n id: eventId,\n timestamp: timestamp,\n };\n }\n\n sessionData.session = session.pickle(this.pickleKey);\n this.cryptoStore.storeEndToEndInboundGroupSession(senderKey, sessionId, sessionData, txn);\n result = {\n result: plaintext,\n keysClaimed: sessionData.keysClaimed || {},\n senderKey: senderKey,\n forwardingCurve25519KeyChain: sessionData.forwardingCurve25519KeyChain || [],\n untrusted: !!sessionData.untrusted,\n };\n });\n },\n logger.withPrefix(\"[decryptGroupMessage]\"),\n );\n\n if (error!) {\n throw error;\n }\n return result!;\n }\n\n /**\n * Determine if we have the keys for a given megolm session\n *\n * @param roomId - room in which the message was received\n * @param senderKey - base64-encoded curve25519 key of the sender\n * @param sessionId - session identifier\n *\n * @returns true if we have the keys to this session\n */\n public async hasInboundSessionKeys(roomId: string, senderKey: string, sessionId: string): Promise {\n let result: boolean;\n await this.cryptoStore.doTxn(\n \"readonly\",\n [\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS,\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD,\n ],\n (txn) => {\n this.cryptoStore.getEndToEndInboundGroupSession(senderKey, sessionId, txn, (sessionData) => {\n if (sessionData === null) {\n result = false;\n return;\n }\n\n if (roomId !== sessionData.room_id) {\n logger.warn(\n `requested keys for inbound group session ${senderKey}|` +\n `${sessionId}, with incorrect room_id ` +\n `(expected ${sessionData.room_id}, ` +\n `was ${roomId})`,\n );\n result = false;\n } else {\n result = true;\n }\n });\n },\n logger.withPrefix(\"[hasInboundSessionKeys]\"),\n );\n\n return result!;\n }\n\n /**\n * Extract the keys to a given megolm session, for sharing\n *\n * @param roomId - room in which the message was received\n * @param senderKey - base64-encoded curve25519 key of the sender\n * @param sessionId - session identifier\n * @param chainIndex - The chain index at which to export the session.\n * If omitted, export at the first index we know about.\n *\n * @returns\n * details of the session key. The key is a base64-encoded megolm key in\n * export format.\n *\n * @throws Error If the given chain index could not be obtained from the known\n * index (ie. the given chain index is before the first we have).\n */\n public async getInboundGroupSessionKey(\n roomId: string,\n senderKey: string,\n sessionId: string,\n chainIndex?: number,\n ): Promise {\n let result: IInboundGroupSessionKey | null = null;\n await this.cryptoStore.doTxn(\n \"readonly\",\n [\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS,\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD,\n ],\n (txn) => {\n this.getInboundGroupSession(roomId, senderKey, sessionId, txn, (session, sessionData) => {\n if (session === null || sessionData === null) {\n result = null;\n return;\n }\n\n if (chainIndex === undefined) {\n chainIndex = session.first_known_index();\n }\n\n const exportedSession = session.export_session(chainIndex);\n\n const claimedKeys = sessionData.keysClaimed || {};\n const senderEd25519Key = claimedKeys.ed25519 || null;\n\n const forwardingKeyChain = sessionData.forwardingCurve25519KeyChain || [];\n // older forwarded keys didn't set the \"untrusted\"\n // property, but can be identified by having a\n // non-empty forwarding key chain. These keys should\n // be marked as untrusted since we don't know that they\n // can be trusted\n const untrusted =\n \"untrusted\" in sessionData ? sessionData.untrusted : forwardingKeyChain.length > 0;\n\n result = {\n chain_index: chainIndex,\n key: exportedSession,\n forwarding_curve25519_key_chain: forwardingKeyChain,\n sender_claimed_ed25519_key: senderEd25519Key,\n shared_history: sessionData.sharedHistory || false,\n untrusted: untrusted,\n };\n });\n },\n logger.withPrefix(\"[getInboundGroupSessionKey]\"),\n );\n\n return result;\n }\n\n /**\n * Export an inbound group session\n *\n * @param senderKey - base64-encoded curve25519 key of the sender\n * @param sessionId - session identifier\n * @param sessionData - The session object from the store\n * @returns exported session data\n */\n public exportInboundGroupSession(\n senderKey: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n ): IMegolmSessionData {\n return this.unpickleInboundGroupSession(sessionData, (session) => {\n const messageIndex = session.first_known_index();\n\n return {\n \"sender_key\": senderKey,\n \"sender_claimed_keys\": sessionData.keysClaimed,\n \"room_id\": sessionData.room_id,\n \"session_id\": sessionId,\n \"session_key\": session.export_session(messageIndex),\n \"forwarding_curve25519_key_chain\": sessionData.forwardingCurve25519KeyChain || [],\n \"first_known_index\": session.first_known_index(),\n \"org.matrix.msc3061.shared_history\": sessionData.sharedHistory || false,\n } as IMegolmSessionData;\n });\n }\n\n public async getSharedHistoryInboundGroupSessions(\n roomId: string,\n ): Promise<[senderKey: string, sessionId: string][]> {\n let result: Promise<[senderKey: string, sessionId: string][]>;\n await this.cryptoStore.doTxn(\n \"readonly\",\n [IndexedDBCryptoStore.STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS],\n (txn) => {\n result = this.cryptoStore.getSharedHistoryInboundGroupSessions(roomId, txn);\n },\n logger.withPrefix(\"[getSharedHistoryInboundGroupSessionsForRoom]\"),\n );\n return result!;\n }\n\n // Utilities\n // =========\n\n /**\n * Verify an ed25519 signature.\n *\n * @param key - ed25519 key\n * @param message - message which was signed\n * @param signature - base64-encoded signature to be checked\n *\n * @throws Error if there is a problem with the verification. If the key was\n * too small then the message will be \"OLM.INVALID_BASE64\". If the signature\n * was invalid then the message will be \"OLM.BAD_MESSAGE_MAC\".\n */\n public verifySignature(key: string, message: string, signature: string): void {\n this.getUtility(function (util: Utility) {\n util.ed25519_verify(key, message, signature);\n });\n }\n}\n\nexport const WITHHELD_MESSAGES: Record = {\n \"m.unverified\": \"The sender has disabled encrypting to unverified devices.\",\n \"m.blacklisted\": \"The sender has blocked you.\",\n \"m.unauthorised\": \"You are not authorised to read the message.\",\n \"m.no_olm\": \"Unable to establish a secure channel.\",\n};\n\n/**\n * Calculate the message to use for the exception when a session key is withheld.\n *\n * @param withheld - An object that describes why the key was withheld.\n *\n * @returns the message\n *\n * @internal\n */\nfunction calculateWithheldMessage(withheld: IWithheld): string {\n if (withheld.code && withheld.code in WITHHELD_MESSAGES) {\n return WITHHELD_MESSAGES[withheld.code];\n } else if (withheld.reason) {\n return withheld.reason;\n } else {\n return \"decryption key withheld\";\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts deleted file mode 100644 index 6e5bf8c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts +++ /dev/null @@ -1,109 +0,0 @@ -import { MatrixClient } from "../client"; -import { IRoomKeyRequestBody, IRoomKeyRequestRecipient } from "./index"; -import { CryptoStore, OutgoingRoomKeyRequest } from "./store/base"; -/** - * possible states for a room key request - * - * The state machine looks like: - * ``` - * - * | (cancellation sent) - * | .-------------------------------------------------. - * | | | - * V V (cancellation requested) | - * UNSENT -----------------------------+ | - * | | | - * | | | - * | (send successful) | CANCELLATION_PENDING_AND_WILL_RESEND - * V | Λ - * SENT | | - * |-------------------------------- | --------------' - * | | (cancellation requested with intent - * | | to resend the original request) - * | | - * | (cancellation requested) | - * V | - * CANCELLATION_PENDING | - * | | - * | (cancellation sent) | - * V | - * (deleted) <---------------------------+ - * ``` - */ -export declare enum RoomKeyRequestState { - /** request not yet sent */ - Unsent = 0, - /** request sent, awaiting reply */ - Sent = 1, - /** reply received, cancellation not yet sent */ - CancellationPending = 2, - /** - * Cancellation not yet sent and will transition to UNSENT instead of - * being deleted once the cancellation has been sent. - */ - CancellationPendingAndWillResend = 3 -} -export declare class OutgoingRoomKeyRequestManager { - private readonly baseApis; - private readonly deviceId; - private readonly cryptoStore; - private sendOutgoingRoomKeyRequestsTimer?; - private sendOutgoingRoomKeyRequestsRunning; - private clientRunning; - constructor(baseApis: MatrixClient, deviceId: string, cryptoStore: CryptoStore); - /** - * Called when the client is stopped. Stops any running background processes. - */ - stop(): void; - /** - * Send any requests that have been queued - */ - sendQueuedRequests(): void; - /** - * Queue up a room key request, if we haven't already queued or sent one. - * - * The `requestBody` is compared (with a deep-equality check) against - * previous queued or sent requests and if it matches, no change is made. - * Otherwise, a request is added to the pending list, and a job is started - * in the background to send it. - * - * @param resend - whether to resend the key request if there is - * already one - * - * @returns resolves when the request has been added to the - * pending list (or we have established that a similar request already - * exists) - */ - queueRoomKeyRequest(requestBody: IRoomKeyRequestBody, recipients: IRoomKeyRequestRecipient[], resend?: boolean): Promise; - /** - * Cancel room key requests, if any match the given requestBody - * - * - * @returns resolves when the request has been updated in our - * pending list. - */ - cancelRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise; - /** - * Look for room key requests by target device and state - * - * @param userId - Target user ID - * @param deviceId - Target device ID - * - * @returns resolves to a list of all the {@link OutgoingRoomKeyRequest} - */ - getOutgoingSentRoomKeyRequest(userId: string, deviceId: string): Promise; - /** - * Find anything in `sent` state, and kick it around the loop again. - * This is intended for situations where something substantial has changed, and we - * don't really expect the other end to even care about the cancellation. - * For example, after initialization or self-verification. - * @returns An array of `queueRoomKeyRequest` outputs. - */ - cancelAndResendAllOutgoingRequests(): Promise; - private startTimer; - private sendOutgoingRoomKeyRequests; - private sendOutgoingRoomKeyRequest; - private sendOutgoingRoomKeyRequestCancellation; - private sendMessageToDevices; -} -//# sourceMappingURL=OutgoingRoomKeyRequestManager.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts.map deleted file mode 100644 index 19d0444..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"OutgoingRoomKeyRequestManager.d.ts","sourceRoot":"","sources":["../../src/crypto/OutgoingRoomKeyRequestManager.ts"],"names":[],"mappings":"AAmBA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,mBAAmB,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAenE;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,oBAAY,mBAAmB;IAC3B,2BAA2B;IAC3B,MAAM,IAAA;IACN,mCAAmC;IACnC,IAAI,IAAA;IACJ,gDAAgD;IAChD,mBAAmB,IAAA;IACnB;;;OAGG;IACH,gCAAgC,IAAA;CACnC;AAkBD,qBAAa,6BAA6B;IAYlC,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,WAAW;IAXhC,OAAO,CAAC,gCAAgC,CAAC,CAAgC;IAIzE,OAAO,CAAC,kCAAkC,CAAS;IAEnD,OAAO,CAAC,aAAa,CAAQ;gBAGR,QAAQ,EAAE,YAAY,EACtB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,WAAW;IAG7C;;OAEG;IACI,IAAI,IAAI,IAAI;IAMnB;;OAEG;IACI,kBAAkB,IAAI,IAAI;IAIjC;;;;;;;;;;;;;;OAcG;IACU,mBAAmB,CAC5B,WAAW,EAAE,mBAAmB,EAChC,UAAU,EAAE,wBAAwB,EAAE,EACtC,MAAM,UAAQ,GACf,OAAO,CAAC,IAAI,CAAC;IAqFhB;;;;;;OAMG;IACI,oBAAoB,CAAC,WAAW,EAAE,mBAAmB,GAAG,OAAO,CAAC,OAAO,CAAC;IAmE/E;;;;;;;OAOG;IACI,6BAA6B,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAIzG;;;;;;OAMG;IACU,kCAAkC,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IASlE,OAAO,CAAC,UAAU;YA+BJ,2BAA2B;IAuCzC,OAAO,CAAC,0BAA0B;IAuBlC,OAAO,CAAC,sCAAsC;IA+B9C,OAAO,CAAC,oBAAoB;CAgB/B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js deleted file mode 100644 index 2bd25ba..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js +++ /dev/null @@ -1,394 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomKeyRequestState = exports.OutgoingRoomKeyRequestManager = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _uuid = require("uuid"); -var _logger = require("../logger"); -var _event = require("../@types/event"); -var _utils = require("../utils"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * Internal module. Management of outgoing room key requests. - * - * See https://docs.google.com/document/d/1m4gQkcnJkxNuBmb5NoFCIadIY-DyqqNAS3lloE73BlQ - * for draft documentation on what we're supposed to be implementing here. - */ - -// delay between deciding we want some keys, and sending out the request, to -// allow for (a) it turning up anyway, (b) grouping requests together -const SEND_KEY_REQUESTS_DELAY_MS = 500; - -/** - * possible states for a room key request - * - * The state machine looks like: - * ``` - * - * | (cancellation sent) - * | .-------------------------------------------------. - * | | | - * V V (cancellation requested) | - * UNSENT -----------------------------+ | - * | | | - * | | | - * | (send successful) | CANCELLATION_PENDING_AND_WILL_RESEND - * V | Λ - * SENT | | - * |-------------------------------- | --------------' - * | | (cancellation requested with intent - * | | to resend the original request) - * | | - * | (cancellation requested) | - * V | - * CANCELLATION_PENDING | - * | | - * | (cancellation sent) | - * V | - * (deleted) <---------------------------+ - * ``` - */ -let RoomKeyRequestState; -exports.RoomKeyRequestState = RoomKeyRequestState; -(function (RoomKeyRequestState) { - RoomKeyRequestState[RoomKeyRequestState["Unsent"] = 0] = "Unsent"; - RoomKeyRequestState[RoomKeyRequestState["Sent"] = 1] = "Sent"; - RoomKeyRequestState[RoomKeyRequestState["CancellationPending"] = 2] = "CancellationPending"; - RoomKeyRequestState[RoomKeyRequestState["CancellationPendingAndWillResend"] = 3] = "CancellationPendingAndWillResend"; -})(RoomKeyRequestState || (exports.RoomKeyRequestState = RoomKeyRequestState = {})); -class OutgoingRoomKeyRequestManager { - // handle for the delayed call to sendOutgoingRoomKeyRequests. Non-null - // if the callback has been set, or if it is still running. - - // sanity check to ensure that we don't end up with two concurrent runs - // of sendOutgoingRoomKeyRequests - - constructor(baseApis, deviceId, cryptoStore) { - this.baseApis = baseApis; - this.deviceId = deviceId; - this.cryptoStore = cryptoStore; - (0, _defineProperty2.default)(this, "sendOutgoingRoomKeyRequestsTimer", void 0); - (0, _defineProperty2.default)(this, "sendOutgoingRoomKeyRequestsRunning", false); - (0, _defineProperty2.default)(this, "clientRunning", true); - } - - /** - * Called when the client is stopped. Stops any running background processes. - */ - stop() { - _logger.logger.log("stopping OutgoingRoomKeyRequestManager"); - // stop the timer on the next run - this.clientRunning = false; - } - - /** - * Send any requests that have been queued - */ - sendQueuedRequests() { - this.startTimer(); - } - - /** - * Queue up a room key request, if we haven't already queued or sent one. - * - * The `requestBody` is compared (with a deep-equality check) against - * previous queued or sent requests and if it matches, no change is made. - * Otherwise, a request is added to the pending list, and a job is started - * in the background to send it. - * - * @param resend - whether to resend the key request if there is - * already one - * - * @returns resolves when the request has been added to the - * pending list (or we have established that a similar request already - * exists) - */ - async queueRoomKeyRequest(requestBody, recipients, resend = false) { - const req = await this.cryptoStore.getOutgoingRoomKeyRequest(requestBody); - if (!req) { - await this.cryptoStore.getOrAddOutgoingRoomKeyRequest({ - requestBody: requestBody, - recipients: recipients, - requestId: this.baseApis.makeTxnId(), - state: RoomKeyRequestState.Unsent - }); - } else { - switch (req.state) { - case RoomKeyRequestState.CancellationPendingAndWillResend: - case RoomKeyRequestState.Unsent: - // nothing to do here, since we're going to send a request anyways - return; - case RoomKeyRequestState.CancellationPending: - { - // existing request is about to be cancelled. If we want to - // resend, then change the state so that it resends after - // cancelling. Otherwise, just cancel the cancellation. - const state = resend ? RoomKeyRequestState.CancellationPendingAndWillResend : RoomKeyRequestState.Sent; - await this.cryptoStore.updateOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.CancellationPending, { - state, - cancellationTxnId: this.baseApis.makeTxnId() - }); - break; - } - case RoomKeyRequestState.Sent: - { - // a request has already been sent. If we don't want to - // resend, then do nothing. If we do want to, then cancel the - // existing request and send a new one. - if (resend) { - const state = RoomKeyRequestState.CancellationPendingAndWillResend; - const updatedReq = await this.cryptoStore.updateOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.Sent, { - state, - cancellationTxnId: this.baseApis.makeTxnId(), - // need to use a new transaction ID so that - // the request gets sent - requestTxnId: this.baseApis.makeTxnId() - }); - if (!updatedReq) { - // updateOutgoingRoomKeyRequest couldn't find the request - // in state ROOM_KEY_REQUEST_STATES.SENT, so we must have - // raced with another tab to mark the request cancelled. - // Try again, to make sure the request is resent. - return this.queueRoomKeyRequest(requestBody, recipients, resend); - } - - // We don't want to wait for the timer, so we send it - // immediately. (We might actually end up racing with the timer, - // but that's ok: even if we make the request twice, we'll do it - // with the same transaction_id, so only one message will get - // sent). - // - // (We also don't want to wait for the response from the server - // here, as it will slow down processing of received keys if we - // do.) - try { - await this.sendOutgoingRoomKeyRequestCancellation(updatedReq, true); - } catch (e) { - _logger.logger.error("Error sending room key request cancellation;" + " will retry later.", e); - } - // The request has transitioned from - // CANCELLATION_PENDING_AND_WILL_RESEND to UNSENT. We - // still need to resend the request which is now UNSENT, so - // start the timer if it isn't already started. - } - - break; - } - default: - throw new Error("unhandled state: " + req.state); - } - } - } - - /** - * Cancel room key requests, if any match the given requestBody - * - * - * @returns resolves when the request has been updated in our - * pending list. - */ - cancelRoomKeyRequest(requestBody) { - return this.cryptoStore.getOutgoingRoomKeyRequest(requestBody).then(req => { - if (!req) { - // no request was made for this key - return; - } - switch (req.state) { - case RoomKeyRequestState.CancellationPending: - case RoomKeyRequestState.CancellationPendingAndWillResend: - // nothing to do here - return; - case RoomKeyRequestState.Unsent: - // just delete it - - // FIXME: ghahah we may have attempted to send it, and - // not yet got a successful response. So the server - // may have seen it, so we still need to send a cancellation - // in that case :/ - - _logger.logger.log("deleting unnecessary room key request for " + stringifyRequestBody(requestBody)); - return this.cryptoStore.deleteOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.Unsent); - case RoomKeyRequestState.Sent: - { - // send a cancellation. - return this.cryptoStore.updateOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.Sent, { - state: RoomKeyRequestState.CancellationPending, - cancellationTxnId: this.baseApis.makeTxnId() - }).then(updatedReq => { - if (!updatedReq) { - // updateOutgoingRoomKeyRequest couldn't find the - // request in state ROOM_KEY_REQUEST_STATES.SENT, - // so we must have raced with another tab to mark - // the request cancelled. There is no point in - // sending another cancellation since the other tab - // will do it. - _logger.logger.log("Tried to cancel room key request for " + stringifyRequestBody(requestBody) + " but it was already cancelled in another tab"); - return; - } - - // We don't want to wait for the timer, so we send it - // immediately. (We might actually end up racing with the timer, - // but that's ok: even if we make the request twice, we'll do it - // with the same transaction_id, so only one message will get - // sent). - // - // (We also don't want to wait for the response from the server - // here, as it will slow down processing of received keys if we - // do.) - this.sendOutgoingRoomKeyRequestCancellation(updatedReq).catch(e => { - _logger.logger.error("Error sending room key request cancellation;" + " will retry later.", e); - this.startTimer(); - }); - }); - } - default: - throw new Error("unhandled state: " + req.state); - } - }); - } - - /** - * Look for room key requests by target device and state - * - * @param userId - Target user ID - * @param deviceId - Target device ID - * - * @returns resolves to a list of all the {@link OutgoingRoomKeyRequest} - */ - getOutgoingSentRoomKeyRequest(userId, deviceId) { - return this.cryptoStore.getOutgoingRoomKeyRequestsByTarget(userId, deviceId, [RoomKeyRequestState.Sent]); - } - - /** - * Find anything in `sent` state, and kick it around the loop again. - * This is intended for situations where something substantial has changed, and we - * don't really expect the other end to even care about the cancellation. - * For example, after initialization or self-verification. - * @returns An array of `queueRoomKeyRequest` outputs. - */ - async cancelAndResendAllOutgoingRequests() { - const outgoings = await this.cryptoStore.getAllOutgoingRoomKeyRequestsByState(RoomKeyRequestState.Sent); - return Promise.all(outgoings.map(({ - requestBody, - recipients - }) => this.queueRoomKeyRequest(requestBody, recipients, true))); - } - - // start the background timer to send queued requests, if the timer isn't - // already running - startTimer() { - if (this.sendOutgoingRoomKeyRequestsTimer) { - return; - } - const startSendingOutgoingRoomKeyRequests = () => { - if (this.sendOutgoingRoomKeyRequestsRunning) { - throw new Error("RoomKeyRequestSend already in progress!"); - } - this.sendOutgoingRoomKeyRequestsRunning = true; - this.sendOutgoingRoomKeyRequests().finally(() => { - this.sendOutgoingRoomKeyRequestsRunning = false; - }).catch(e => { - // this should only happen if there is an indexeddb error, - // in which case we're a bit stuffed anyway. - _logger.logger.warn(`error in OutgoingRoomKeyRequestManager: ${e}`); - }); - }; - this.sendOutgoingRoomKeyRequestsTimer = setTimeout(startSendingOutgoingRoomKeyRequests, SEND_KEY_REQUESTS_DELAY_MS); - } - - // look for and send any queued requests. Runs itself recursively until - // there are no more requests, or there is an error (in which case, the - // timer will be restarted before the promise resolves). - async sendOutgoingRoomKeyRequests() { - if (!this.clientRunning) { - this.sendOutgoingRoomKeyRequestsTimer = undefined; - return; - } - const req = await this.cryptoStore.getOutgoingRoomKeyRequestByState([RoomKeyRequestState.CancellationPending, RoomKeyRequestState.CancellationPendingAndWillResend, RoomKeyRequestState.Unsent]); - if (!req) { - this.sendOutgoingRoomKeyRequestsTimer = undefined; - return; - } - try { - switch (req.state) { - case RoomKeyRequestState.Unsent: - await this.sendOutgoingRoomKeyRequest(req); - break; - case RoomKeyRequestState.CancellationPending: - await this.sendOutgoingRoomKeyRequestCancellation(req); - break; - case RoomKeyRequestState.CancellationPendingAndWillResend: - await this.sendOutgoingRoomKeyRequestCancellation(req, true); - break; - } - - // go around the loop again - return this.sendOutgoingRoomKeyRequests(); - } catch (e) { - _logger.logger.error("Error sending room key request; will retry later.", e); - this.sendOutgoingRoomKeyRequestsTimer = undefined; - } - } - - // given a RoomKeyRequest, send it and update the request record - sendOutgoingRoomKeyRequest(req) { - _logger.logger.log(`Requesting keys for ${stringifyRequestBody(req.requestBody)}` + ` from ${stringifyRecipientList(req.recipients)}` + `(id ${req.requestId})`); - const requestMessage = { - action: "request", - requesting_device_id: this.deviceId, - request_id: req.requestId, - body: req.requestBody - }; - return this.sendMessageToDevices(requestMessage, req.recipients, req.requestTxnId || req.requestId).then(() => { - return this.cryptoStore.updateOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.Unsent, { - state: RoomKeyRequestState.Sent - }); - }); - } - - // Given a RoomKeyRequest, cancel it and delete the request record unless - // andResend is set, in which case transition to UNSENT. - sendOutgoingRoomKeyRequestCancellation(req, andResend = false) { - _logger.logger.log(`Sending cancellation for key request for ` + `${stringifyRequestBody(req.requestBody)} to ` + `${stringifyRecipientList(req.recipients)} ` + `(cancellation id ${req.cancellationTxnId})`); - const requestMessage = { - action: "request_cancellation", - requesting_device_id: this.deviceId, - request_id: req.requestId - }; - return this.sendMessageToDevices(requestMessage, req.recipients, req.cancellationTxnId).then(() => { - if (andResend) { - // We want to resend, so transition to UNSENT - return this.cryptoStore.updateOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.CancellationPendingAndWillResend, { - state: RoomKeyRequestState.Unsent - }); - } - return this.cryptoStore.deleteOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.CancellationPending); - }); - } - - // send a RoomKeyRequest to a list of recipients - sendMessageToDevices(message, recipients, txnId) { - const contentMap = new _utils.MapWithDefault(() => new Map()); - for (const recip of recipients) { - const userDeviceMap = contentMap.getOrCreate(recip.userId); - userDeviceMap.set(recip.deviceId, _objectSpread(_objectSpread({}, message), {}, { - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - })); - } - return this.baseApis.sendToDevice(_event.EventType.RoomKeyRequest, contentMap, txnId); - } -} -exports.OutgoingRoomKeyRequestManager = OutgoingRoomKeyRequestManager; -function stringifyRequestBody(requestBody) { - // we assume that the request is for megolm keys, which are identified by - // room id and session id - return requestBody.room_id + " / " + requestBody.session_id; -} -function stringifyRecipientList(recipients) { - return `[${recipients.map(r => `${r.userId}:${r.deviceId}`).join(",")}]`; -} -//# sourceMappingURL=OutgoingRoomKeyRequestManager.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js.map deleted file mode 100644 index ef87212..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/OutgoingRoomKeyRequestManager.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"OutgoingRoomKeyRequestManager.js","names":["_uuid","require","_logger","_event","_utils","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","SEND_KEY_REQUESTS_DELAY_MS","RoomKeyRequestState","exports","OutgoingRoomKeyRequestManager","constructor","baseApis","deviceId","cryptoStore","stop","logger","log","clientRunning","sendQueuedRequests","startTimer","queueRoomKeyRequest","requestBody","recipients","resend","req","getOutgoingRoomKeyRequest","getOrAddOutgoingRoomKeyRequest","requestId","makeTxnId","state","Unsent","CancellationPendingAndWillResend","CancellationPending","Sent","updateOutgoingRoomKeyRequest","cancellationTxnId","updatedReq","requestTxnId","sendOutgoingRoomKeyRequestCancellation","e","error","Error","cancelRoomKeyRequest","then","stringifyRequestBody","deleteOutgoingRoomKeyRequest","catch","getOutgoingSentRoomKeyRequest","userId","getOutgoingRoomKeyRequestsByTarget","cancelAndResendAllOutgoingRequests","outgoings","getAllOutgoingRoomKeyRequestsByState","Promise","all","map","sendOutgoingRoomKeyRequestsTimer","startSendingOutgoingRoomKeyRequests","sendOutgoingRoomKeyRequestsRunning","sendOutgoingRoomKeyRequests","finally","warn","setTimeout","undefined","getOutgoingRoomKeyRequestByState","sendOutgoingRoomKeyRequest","stringifyRecipientList","requestMessage","action","requesting_device_id","request_id","body","sendMessageToDevices","andResend","message","txnId","contentMap","MapWithDefault","Map","recip","userDeviceMap","getOrCreate","set","ToDeviceMessageId","uuidv4","sendToDevice","EventType","RoomKeyRequest","room_id","session_id","r","join"],"sources":["../../src/crypto/OutgoingRoomKeyRequestManager.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { logger } from \"../logger\";\nimport { MatrixClient } from \"../client\";\nimport { IRoomKeyRequestBody, IRoomKeyRequestRecipient } from \"./index\";\nimport { CryptoStore, OutgoingRoomKeyRequest } from \"./store/base\";\nimport { EventType, ToDeviceMessageId } from \"../@types/event\";\nimport { MapWithDefault } from \"../utils\";\n\n/**\n * Internal module. Management of outgoing room key requests.\n *\n * See https://docs.google.com/document/d/1m4gQkcnJkxNuBmb5NoFCIadIY-DyqqNAS3lloE73BlQ\n * for draft documentation on what we're supposed to be implementing here.\n */\n\n// delay between deciding we want some keys, and sending out the request, to\n// allow for (a) it turning up anyway, (b) grouping requests together\nconst SEND_KEY_REQUESTS_DELAY_MS = 500;\n\n/**\n * possible states for a room key request\n *\n * The state machine looks like:\n * ```\n *\n * | (cancellation sent)\n * | .-------------------------------------------------.\n * | | |\n * V V (cancellation requested) |\n * UNSENT -----------------------------+ |\n * | | |\n * | | |\n * | (send successful) | CANCELLATION_PENDING_AND_WILL_RESEND\n * V | Λ\n * SENT | |\n * |-------------------------------- | --------------'\n * | | (cancellation requested with intent\n * | | to resend the original request)\n * | |\n * | (cancellation requested) |\n * V |\n * CANCELLATION_PENDING |\n * | |\n * | (cancellation sent) |\n * V |\n * (deleted) <---------------------------+\n * ```\n */\nexport enum RoomKeyRequestState {\n /** request not yet sent */\n Unsent,\n /** request sent, awaiting reply */\n Sent,\n /** reply received, cancellation not yet sent */\n CancellationPending,\n /**\n * Cancellation not yet sent and will transition to UNSENT instead of\n * being deleted once the cancellation has been sent.\n */\n CancellationPendingAndWillResend,\n}\n\ninterface RequestMessageBase {\n requesting_device_id: string;\n request_id: string;\n}\n\ninterface RequestMessageRequest extends RequestMessageBase {\n action: \"request\";\n body: IRoomKeyRequestBody;\n}\n\ninterface RequestMessageCancellation extends RequestMessageBase {\n action: \"request_cancellation\";\n}\n\ntype RequestMessage = RequestMessageRequest | RequestMessageCancellation;\n\nexport class OutgoingRoomKeyRequestManager {\n // handle for the delayed call to sendOutgoingRoomKeyRequests. Non-null\n // if the callback has been set, or if it is still running.\n private sendOutgoingRoomKeyRequestsTimer?: ReturnType;\n\n // sanity check to ensure that we don't end up with two concurrent runs\n // of sendOutgoingRoomKeyRequests\n private sendOutgoingRoomKeyRequestsRunning = false;\n\n private clientRunning = true;\n\n public constructor(\n private readonly baseApis: MatrixClient,\n private readonly deviceId: string,\n private readonly cryptoStore: CryptoStore,\n ) {}\n\n /**\n * Called when the client is stopped. Stops any running background processes.\n */\n public stop(): void {\n logger.log(\"stopping OutgoingRoomKeyRequestManager\");\n // stop the timer on the next run\n this.clientRunning = false;\n }\n\n /**\n * Send any requests that have been queued\n */\n public sendQueuedRequests(): void {\n this.startTimer();\n }\n\n /**\n * Queue up a room key request, if we haven't already queued or sent one.\n *\n * The `requestBody` is compared (with a deep-equality check) against\n * previous queued or sent requests and if it matches, no change is made.\n * Otherwise, a request is added to the pending list, and a job is started\n * in the background to send it.\n *\n * @param resend - whether to resend the key request if there is\n * already one\n *\n * @returns resolves when the request has been added to the\n * pending list (or we have established that a similar request already\n * exists)\n */\n public async queueRoomKeyRequest(\n requestBody: IRoomKeyRequestBody,\n recipients: IRoomKeyRequestRecipient[],\n resend = false,\n ): Promise {\n const req = await this.cryptoStore.getOutgoingRoomKeyRequest(requestBody);\n if (!req) {\n await this.cryptoStore.getOrAddOutgoingRoomKeyRequest({\n requestBody: requestBody,\n recipients: recipients,\n requestId: this.baseApis.makeTxnId(),\n state: RoomKeyRequestState.Unsent,\n });\n } else {\n switch (req.state) {\n case RoomKeyRequestState.CancellationPendingAndWillResend:\n case RoomKeyRequestState.Unsent:\n // nothing to do here, since we're going to send a request anyways\n return;\n\n case RoomKeyRequestState.CancellationPending: {\n // existing request is about to be cancelled. If we want to\n // resend, then change the state so that it resends after\n // cancelling. Otherwise, just cancel the cancellation.\n const state = resend\n ? RoomKeyRequestState.CancellationPendingAndWillResend\n : RoomKeyRequestState.Sent;\n await this.cryptoStore.updateOutgoingRoomKeyRequest(\n req.requestId,\n RoomKeyRequestState.CancellationPending,\n {\n state,\n cancellationTxnId: this.baseApis.makeTxnId(),\n },\n );\n break;\n }\n case RoomKeyRequestState.Sent: {\n // a request has already been sent. If we don't want to\n // resend, then do nothing. If we do want to, then cancel the\n // existing request and send a new one.\n if (resend) {\n const state = RoomKeyRequestState.CancellationPendingAndWillResend;\n const updatedReq = await this.cryptoStore.updateOutgoingRoomKeyRequest(\n req.requestId,\n RoomKeyRequestState.Sent,\n {\n state,\n cancellationTxnId: this.baseApis.makeTxnId(),\n // need to use a new transaction ID so that\n // the request gets sent\n requestTxnId: this.baseApis.makeTxnId(),\n },\n );\n if (!updatedReq) {\n // updateOutgoingRoomKeyRequest couldn't find the request\n // in state ROOM_KEY_REQUEST_STATES.SENT, so we must have\n // raced with another tab to mark the request cancelled.\n // Try again, to make sure the request is resent.\n return this.queueRoomKeyRequest(requestBody, recipients, resend);\n }\n\n // We don't want to wait for the timer, so we send it\n // immediately. (We might actually end up racing with the timer,\n // but that's ok: even if we make the request twice, we'll do it\n // with the same transaction_id, so only one message will get\n // sent).\n //\n // (We also don't want to wait for the response from the server\n // here, as it will slow down processing of received keys if we\n // do.)\n try {\n await this.sendOutgoingRoomKeyRequestCancellation(updatedReq, true);\n } catch (e) {\n logger.error(\"Error sending room key request cancellation;\" + \" will retry later.\", e);\n }\n // The request has transitioned from\n // CANCELLATION_PENDING_AND_WILL_RESEND to UNSENT. We\n // still need to resend the request which is now UNSENT, so\n // start the timer if it isn't already started.\n }\n break;\n }\n default:\n throw new Error(\"unhandled state: \" + req.state);\n }\n }\n }\n\n /**\n * Cancel room key requests, if any match the given requestBody\n *\n *\n * @returns resolves when the request has been updated in our\n * pending list.\n */\n public cancelRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise {\n return this.cryptoStore.getOutgoingRoomKeyRequest(requestBody).then((req): unknown => {\n if (!req) {\n // no request was made for this key\n return;\n }\n switch (req.state) {\n case RoomKeyRequestState.CancellationPending:\n case RoomKeyRequestState.CancellationPendingAndWillResend:\n // nothing to do here\n return;\n\n case RoomKeyRequestState.Unsent:\n // just delete it\n\n // FIXME: ghahah we may have attempted to send it, and\n // not yet got a successful response. So the server\n // may have seen it, so we still need to send a cancellation\n // in that case :/\n\n logger.log(\"deleting unnecessary room key request for \" + stringifyRequestBody(requestBody));\n return this.cryptoStore.deleteOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.Unsent);\n\n case RoomKeyRequestState.Sent: {\n // send a cancellation.\n return this.cryptoStore\n .updateOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.Sent, {\n state: RoomKeyRequestState.CancellationPending,\n cancellationTxnId: this.baseApis.makeTxnId(),\n })\n .then((updatedReq) => {\n if (!updatedReq) {\n // updateOutgoingRoomKeyRequest couldn't find the\n // request in state ROOM_KEY_REQUEST_STATES.SENT,\n // so we must have raced with another tab to mark\n // the request cancelled. There is no point in\n // sending another cancellation since the other tab\n // will do it.\n logger.log(\n \"Tried to cancel room key request for \" +\n stringifyRequestBody(requestBody) +\n \" but it was already cancelled in another tab\",\n );\n return;\n }\n\n // We don't want to wait for the timer, so we send it\n // immediately. (We might actually end up racing with the timer,\n // but that's ok: even if we make the request twice, we'll do it\n // with the same transaction_id, so only one message will get\n // sent).\n //\n // (We also don't want to wait for the response from the server\n // here, as it will slow down processing of received keys if we\n // do.)\n this.sendOutgoingRoomKeyRequestCancellation(updatedReq).catch((e) => {\n logger.error(\"Error sending room key request cancellation;\" + \" will retry later.\", e);\n this.startTimer();\n });\n });\n }\n default:\n throw new Error(\"unhandled state: \" + req.state);\n }\n });\n }\n\n /**\n * Look for room key requests by target device and state\n *\n * @param userId - Target user ID\n * @param deviceId - Target device ID\n *\n * @returns resolves to a list of all the {@link OutgoingRoomKeyRequest}\n */\n public getOutgoingSentRoomKeyRequest(userId: string, deviceId: string): Promise {\n return this.cryptoStore.getOutgoingRoomKeyRequestsByTarget(userId, deviceId, [RoomKeyRequestState.Sent]);\n }\n\n /**\n * Find anything in `sent` state, and kick it around the loop again.\n * This is intended for situations where something substantial has changed, and we\n * don't really expect the other end to even care about the cancellation.\n * For example, after initialization or self-verification.\n * @returns An array of `queueRoomKeyRequest` outputs.\n */\n public async cancelAndResendAllOutgoingRequests(): Promise {\n const outgoings = await this.cryptoStore.getAllOutgoingRoomKeyRequestsByState(RoomKeyRequestState.Sent);\n return Promise.all(\n outgoings.map(({ requestBody, recipients }) => this.queueRoomKeyRequest(requestBody, recipients, true)),\n );\n }\n\n // start the background timer to send queued requests, if the timer isn't\n // already running\n private startTimer(): void {\n if (this.sendOutgoingRoomKeyRequestsTimer) {\n return;\n }\n\n const startSendingOutgoingRoomKeyRequests = (): void => {\n if (this.sendOutgoingRoomKeyRequestsRunning) {\n throw new Error(\"RoomKeyRequestSend already in progress!\");\n }\n this.sendOutgoingRoomKeyRequestsRunning = true;\n\n this.sendOutgoingRoomKeyRequests()\n .finally(() => {\n this.sendOutgoingRoomKeyRequestsRunning = false;\n })\n .catch((e) => {\n // this should only happen if there is an indexeddb error,\n // in which case we're a bit stuffed anyway.\n logger.warn(`error in OutgoingRoomKeyRequestManager: ${e}`);\n });\n };\n\n this.sendOutgoingRoomKeyRequestsTimer = setTimeout(\n startSendingOutgoingRoomKeyRequests,\n SEND_KEY_REQUESTS_DELAY_MS,\n );\n }\n\n // look for and send any queued requests. Runs itself recursively until\n // there are no more requests, or there is an error (in which case, the\n // timer will be restarted before the promise resolves).\n private async sendOutgoingRoomKeyRequests(): Promise {\n if (!this.clientRunning) {\n this.sendOutgoingRoomKeyRequestsTimer = undefined;\n return;\n }\n\n const req = await this.cryptoStore.getOutgoingRoomKeyRequestByState([\n RoomKeyRequestState.CancellationPending,\n RoomKeyRequestState.CancellationPendingAndWillResend,\n RoomKeyRequestState.Unsent,\n ]);\n\n if (!req) {\n this.sendOutgoingRoomKeyRequestsTimer = undefined;\n return;\n }\n\n try {\n switch (req.state) {\n case RoomKeyRequestState.Unsent:\n await this.sendOutgoingRoomKeyRequest(req);\n break;\n case RoomKeyRequestState.CancellationPending:\n await this.sendOutgoingRoomKeyRequestCancellation(req);\n break;\n case RoomKeyRequestState.CancellationPendingAndWillResend:\n await this.sendOutgoingRoomKeyRequestCancellation(req, true);\n break;\n }\n\n // go around the loop again\n return this.sendOutgoingRoomKeyRequests();\n } catch (e) {\n logger.error(\"Error sending room key request; will retry later.\", e);\n this.sendOutgoingRoomKeyRequestsTimer = undefined;\n }\n }\n\n // given a RoomKeyRequest, send it and update the request record\n private sendOutgoingRoomKeyRequest(req: OutgoingRoomKeyRequest): Promise {\n logger.log(\n `Requesting keys for ${stringifyRequestBody(req.requestBody)}` +\n ` from ${stringifyRecipientList(req.recipients)}` +\n `(id ${req.requestId})`,\n );\n\n const requestMessage: RequestMessage = {\n action: \"request\",\n requesting_device_id: this.deviceId,\n request_id: req.requestId,\n body: req.requestBody,\n };\n\n return this.sendMessageToDevices(requestMessage, req.recipients, req.requestTxnId || req.requestId).then(() => {\n return this.cryptoStore.updateOutgoingRoomKeyRequest(req.requestId, RoomKeyRequestState.Unsent, {\n state: RoomKeyRequestState.Sent,\n });\n });\n }\n\n // Given a RoomKeyRequest, cancel it and delete the request record unless\n // andResend is set, in which case transition to UNSENT.\n private sendOutgoingRoomKeyRequestCancellation(req: OutgoingRoomKeyRequest, andResend = false): Promise {\n logger.log(\n `Sending cancellation for key request for ` +\n `${stringifyRequestBody(req.requestBody)} to ` +\n `${stringifyRecipientList(req.recipients)} ` +\n `(cancellation id ${req.cancellationTxnId})`,\n );\n\n const requestMessage: RequestMessage = {\n action: \"request_cancellation\",\n requesting_device_id: this.deviceId,\n request_id: req.requestId,\n };\n\n return this.sendMessageToDevices(requestMessage, req.recipients, req.cancellationTxnId).then(() => {\n if (andResend) {\n // We want to resend, so transition to UNSENT\n return this.cryptoStore.updateOutgoingRoomKeyRequest(\n req.requestId,\n RoomKeyRequestState.CancellationPendingAndWillResend,\n { state: RoomKeyRequestState.Unsent },\n );\n }\n return this.cryptoStore.deleteOutgoingRoomKeyRequest(\n req.requestId,\n RoomKeyRequestState.CancellationPending,\n );\n });\n }\n\n // send a RoomKeyRequest to a list of recipients\n private sendMessageToDevices(\n message: RequestMessage,\n recipients: IRoomKeyRequestRecipient[],\n txnId?: string,\n ): Promise<{}> {\n const contentMap = new MapWithDefault>>(() => new Map());\n for (const recip of recipients) {\n const userDeviceMap = contentMap.getOrCreate(recip.userId);\n userDeviceMap.set(recip.deviceId, {\n ...message,\n [ToDeviceMessageId]: uuidv4(),\n });\n }\n\n return this.baseApis.sendToDevice(EventType.RoomKeyRequest, contentMap, txnId);\n }\n}\n\nfunction stringifyRequestBody(requestBody: IRoomKeyRequestBody): string {\n // we assume that the request is for megolm keys, which are identified by\n // room id and session id\n return requestBody.room_id + \" / \" + requestBody.session_id;\n}\n\nfunction stringifyRecipientList(recipients: IRoomKeyRequestRecipient[]): string {\n return `[${recipients.map((r) => `${r.userId}:${r.deviceId}`).join(\",\")}]`;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts deleted file mode 100644 index f2cf687..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts +++ /dev/null @@ -1,19 +0,0 @@ -/** - * Manages the list of encrypted rooms - */ -import { CryptoStore } from "./store/base"; -export interface IRoomEncryption { - algorithm: string; - rotation_period_ms?: number; - rotation_period_msgs?: number; -} -export declare class RoomList { - private readonly cryptoStore?; - private roomEncryption; - constructor(cryptoStore?: CryptoStore | undefined); - init(): Promise; - getRoomEncryption(roomId: string): IRoomEncryption; - isRoomEncrypted(roomId: string): boolean; - setRoomEncryption(roomId: string, roomInfo: IRoomEncryption): Promise; -} -//# sourceMappingURL=RoomList.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts.map deleted file mode 100644 index c28854b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RoomList.d.ts","sourceRoot":"","sources":["../../src/crypto/RoomList.ts"],"names":[],"mappings":"AAgBA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAI3C,MAAM,WAAW,eAAe;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,oBAAoB,CAAC,EAAE,MAAM,CAAC;CACjC;AAGD,qBAAa,QAAQ;IAIE,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;IAFhD,OAAO,CAAC,cAAc,CAAuC;gBAEzB,WAAW,CAAC,yBAAa;IAEhD,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ3B,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,eAAe;IAIlD,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAIlC,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAS3F"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js deleted file mode 100644 index 8fbc993..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js +++ /dev/null @@ -1,63 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomList = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _indexeddbCryptoStore = require("./store/indexeddb-crypto-store"); -/* -Copyright 2018 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Manages the list of encrypted rooms - */ - -/* eslint-enable camelcase */ - -class RoomList { - // Object of roomId -> room e2e info object (body of the m.room.encryption event) - - constructor(cryptoStore) { - this.cryptoStore = cryptoStore; - (0, _defineProperty2.default)(this, "roomEncryption", {}); - } - async init() { - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ROOMS], txn => { - this.cryptoStore.getEndToEndRooms(txn, result => { - this.roomEncryption = result; - }); - }); - } - getRoomEncryption(roomId) { - return this.roomEncryption[roomId] || null; - } - isRoomEncrypted(roomId) { - return Boolean(this.getRoomEncryption(roomId)); - } - async setRoomEncryption(roomId, roomInfo) { - // important that this happens before calling into the store - // as it prevents the Crypto::setRoomEncryption from calling - // this twice for consecutive m.room.encryption events - this.roomEncryption[roomId] = roomInfo; - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ROOMS], txn => { - this.cryptoStore.storeEndToEndRoom(roomId, roomInfo, txn); - }); - } -} -exports.RoomList = RoomList; -//# sourceMappingURL=RoomList.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js.map deleted file mode 100644 index d8edb35..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/RoomList.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RoomList.js","names":["_indexeddbCryptoStore","require","RoomList","constructor","cryptoStore","_defineProperty2","default","init","doTxn","IndexedDBCryptoStore","STORE_ROOMS","txn","getEndToEndRooms","result","roomEncryption","getRoomEncryption","roomId","isRoomEncrypted","Boolean","setRoomEncryption","roomInfo","storeEndToEndRoom","exports"],"sources":["../../src/crypto/RoomList.ts"],"sourcesContent":["/*\nCopyright 2018 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Manages the list of encrypted rooms\n */\n\nimport { CryptoStore } from \"./store/base\";\nimport { IndexedDBCryptoStore } from \"./store/indexeddb-crypto-store\";\n\n/* eslint-disable camelcase */\nexport interface IRoomEncryption {\n algorithm: string;\n rotation_period_ms?: number;\n rotation_period_msgs?: number;\n}\n/* eslint-enable camelcase */\n\nexport class RoomList {\n // Object of roomId -> room e2e info object (body of the m.room.encryption event)\n private roomEncryption: Record = {};\n\n public constructor(private readonly cryptoStore?: CryptoStore) {}\n\n public async init(): Promise {\n await this.cryptoStore!.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ROOMS], (txn) => {\n this.cryptoStore!.getEndToEndRooms(txn, (result) => {\n this.roomEncryption = result;\n });\n });\n }\n\n public getRoomEncryption(roomId: string): IRoomEncryption {\n return this.roomEncryption[roomId] || null;\n }\n\n public isRoomEncrypted(roomId: string): boolean {\n return Boolean(this.getRoomEncryption(roomId));\n }\n\n public async setRoomEncryption(roomId: string, roomInfo: IRoomEncryption): Promise {\n // important that this happens before calling into the store\n // as it prevents the Crypto::setRoomEncryption from calling\n // this twice for consecutive m.room.encryption events\n this.roomEncryption[roomId] = roomInfo;\n await this.cryptoStore!.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ROOMS], (txn) => {\n this.cryptoStore!.storeEndToEndRoom(roomId, roomInfo, txn);\n });\n }\n}\n"],"mappings":";;;;;;;;AAqBA,IAAAA,qBAAA,GAAAC,OAAA;AArBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAWA;;AAEO,MAAMC,QAAQ,CAAC;EAClB;;EAGOC,WAAWA,CAAkBC,WAAyB,EAAE;IAAA,KAA3BA,WAAyB,GAAzBA,WAAyB;IAAA,IAAAC,gBAAA,CAAAC,OAAA,0BAFH,CAAC,CAAC;EAEI;EAEhE,MAAaC,IAAIA,CAAA,EAAkB;IAC/B,MAAM,IAAI,CAACH,WAAW,CAAEI,KAAK,CAAC,WAAW,EAAE,CAACC,0CAAoB,CAACC,WAAW,CAAC,EAAGC,GAAG,IAAK;MACpF,IAAI,CAACP,WAAW,CAAEQ,gBAAgB,CAACD,GAAG,EAAGE,MAAM,IAAK;QAChD,IAAI,CAACC,cAAc,GAAGD,MAAM;MAChC,CAAC,CAAC;IACN,CAAC,CAAC;EACN;EAEOE,iBAAiBA,CAACC,MAAc,EAAmB;IACtD,OAAO,IAAI,CAACF,cAAc,CAACE,MAAM,CAAC,IAAI,IAAI;EAC9C;EAEOC,eAAeA,CAACD,MAAc,EAAW;IAC5C,OAAOE,OAAO,CAAC,IAAI,CAACH,iBAAiB,CAACC,MAAM,CAAC,CAAC;EAClD;EAEA,MAAaG,iBAAiBA,CAACH,MAAc,EAAEI,QAAyB,EAAiB;IACrF;IACA;IACA;IACA,IAAI,CAACN,cAAc,CAACE,MAAM,CAAC,GAAGI,QAAQ;IACtC,MAAM,IAAI,CAAChB,WAAW,CAAEI,KAAK,CAAC,WAAW,EAAE,CAACC,0CAAoB,CAACC,WAAW,CAAC,EAAGC,GAAG,IAAK;MACpF,IAAI,CAACP,WAAW,CAAEiB,iBAAiB,CAACL,MAAM,EAAEI,QAAQ,EAAET,GAAG,CAAC;IAC9D,CAAC,CAAC;EACN;AACJ;AAACW,OAAA,CAAApB,QAAA,GAAAA,QAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts deleted file mode 100644 index 13729e2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts +++ /dev/null @@ -1,115 +0,0 @@ -import { ICryptoCallbacks } from "."; -import { IContent, MatrixEvent } from "../models/event"; -import { ClientEvent, ClientEventHandlerMap, MatrixClient } from "../client"; -import { IAddSecretStorageKeyOpts } from "./api"; -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { SecretStorageKeyDescription } from "../secret-storage"; -export declare const SECRET_STORAGE_ALGORITHM_V1_AES = "m.secret_storage.v1.aes-hmac-sha2"; -export type SecretStorageKeyTuple = [keyId: string, keyInfo: SecretStorageKeyDescription]; -export type SecretStorageKeyObject = { - keyId: string; - keyInfo: SecretStorageKeyDescription; -}; -export interface ISecretRequest { - requestId: string; - promise: Promise; - cancel: (reason: string) => void; -} -export interface IAccountDataClient extends TypedEventEmitter { - getAccountDataFromServer: (eventType: string) => Promise; - getAccountData: (eventType: string) => IContent | null; - setAccountData: (eventType: string, content: any) => Promise<{}>; -} -/** - * Implements Secure Secret Storage and Sharing (MSC1946) - */ -export declare class SecretStorage { - private readonly accountDataAdapter; - private readonly cryptoCallbacks; - private readonly baseApis; - private requests; - constructor(accountDataAdapter: IAccountDataClient, cryptoCallbacks: ICryptoCallbacks, baseApis: B); - getDefaultKeyId(): Promise; - setDefaultKeyId(keyId: string): Promise; - /** - * Add a key for encrypting secrets. - * - * @param algorithm - the algorithm used by the key. - * @param opts - the options for the algorithm. The properties used - * depend on the algorithm given. - * @param keyId - the ID of the key. If not given, a random - * ID will be generated. - * - * @returns An object with: - * keyId: the ID of the key - * keyInfo: details about the key (iv, mac, passphrase) - */ - addKey(algorithm: string, opts?: IAddSecretStorageKeyOpts, keyId?: string): Promise; - /** - * Get the key information for a given ID. - * - * @param keyId - The ID of the key to check - * for. Defaults to the default key ID if not provided. - * @returns If the key was found, the return value is an array of - * the form [keyId, keyInfo]. Otherwise, null is returned. - * XXX: why is this an array when addKey returns an object? - */ - getKey(keyId?: string | null): Promise; - /** - * Check whether we have a key with a given ID. - * - * @param keyId - The ID of the key to check - * for. Defaults to the default key ID if not provided. - * @returns Whether we have the key. - */ - hasKey(keyId?: string): Promise; - /** - * Check whether a key matches what we expect based on the key info - * - * @param key - the key to check - * @param info - the key info - * - * @returns whether or not the key matches - */ - checkKey(key: Uint8Array, info: SecretStorageKeyDescription): Promise; - /** - * Store an encrypted secret on the server - * - * @param name - The name of the secret - * @param secret - The secret contents. - * @param keys - The IDs of the keys to use to encrypt the secret - * or null/undefined to use the default key. - */ - store(name: string, secret: string, keys?: string[] | null): Promise; - /** - * Get a secret from storage. - * - * @param name - the name of the secret - * - * @returns the contents of the secret - */ - get(name: string): Promise; - /** - * Check if a secret is stored on the server. - * - * @param name - the name of the secret - * - * @returns map of key name to key info the secret is encrypted - * with, or null if it is not present or not encrypted with a trusted - * key - */ - isStored(name: string): Promise | null>; - /** - * Request a secret from another device - * - * @param name - the name of the secret to request - * @param devices - the devices to request the secret from - */ - request(this: SecretStorage, name: string, devices: string[]): ISecretRequest; - onRequestReceived(this: SecretStorage, event: MatrixEvent): Promise; - onSecretReceived(this: SecretStorage, event: MatrixEvent): void; - private getSecretStorageKey; -} -//# sourceMappingURL=SecretStorage.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts.map deleted file mode 100644 index b322252..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SecretStorage.d.ts","sourceRoot":"","sources":["../../src/crypto/SecretStorage.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js deleted file mode 100644 index 8e8d965..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js +++ /dev/null @@ -1,491 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SecretStorage = exports.SECRET_STORAGE_ALGORITHM_V1_AES = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _uuid = require("uuid"); -var _logger = require("../logger"); -var olmlib = _interopRequireWildcard(require("./olmlib")); -var _randomstring = require("../randomstring"); -var _aes = require("./aes"); -var _client = require("../client"); -var _utils = require("../utils"); -var _event = require("../@types/event"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2019 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const SECRET_STORAGE_ALGORITHM_V1_AES = "m.secret_storage.v1.aes-hmac-sha2"; - -// Some of the key functions use a tuple and some use an object... -exports.SECRET_STORAGE_ALGORITHM_V1_AES = SECRET_STORAGE_ALGORITHM_V1_AES; -/** - * Implements Secure Secret Storage and Sharing (MSC1946) - */ -class SecretStorage { - // In it's pure javascript days, this was relying on some proper Javascript-style - // type-abuse where sometimes we'd pass in a fake client object with just the account - // data methods implemented, which is all this class needs unless you use the secret - // sharing code, so it was fine. As a low-touch TypeScript migration, this now has - // an extra, optional param for a real matrix client, so you can not pass it as long - // as you don't request any secrets. - // A better solution would probably be to split this class up into secret storage and - // secret sharing which are really two separate things, even though they share an MSC. - constructor(accountDataAdapter, cryptoCallbacks, baseApis) { - this.accountDataAdapter = accountDataAdapter; - this.cryptoCallbacks = cryptoCallbacks; - this.baseApis = baseApis; - (0, _defineProperty2.default)(this, "requests", new Map()); - } - async getDefaultKeyId() { - const defaultKey = await this.accountDataAdapter.getAccountDataFromServer("m.secret_storage.default_key"); - if (!defaultKey) return null; - return defaultKey.key; - } - setDefaultKeyId(keyId) { - return new Promise((resolve, reject) => { - const listener = ev => { - if (ev.getType() === "m.secret_storage.default_key" && ev.getContent().key === keyId) { - this.accountDataAdapter.removeListener(_client.ClientEvent.AccountData, listener); - resolve(); - } - }; - this.accountDataAdapter.on(_client.ClientEvent.AccountData, listener); - this.accountDataAdapter.setAccountData("m.secret_storage.default_key", { - key: keyId - }).catch(e => { - this.accountDataAdapter.removeListener(_client.ClientEvent.AccountData, listener); - reject(e); - }); - }); - } - - /** - * Add a key for encrypting secrets. - * - * @param algorithm - the algorithm used by the key. - * @param opts - the options for the algorithm. The properties used - * depend on the algorithm given. - * @param keyId - the ID of the key. If not given, a random - * ID will be generated. - * - * @returns An object with: - * keyId: the ID of the key - * keyInfo: details about the key (iv, mac, passphrase) - */ - async addKey(algorithm, opts = {}, keyId) { - if (algorithm !== SECRET_STORAGE_ALGORITHM_V1_AES) { - throw new Error(`Unknown key algorithm ${algorithm}`); - } - const keyInfo = { - algorithm - }; - if (opts.name) { - keyInfo.name = opts.name; - } - if (opts.passphrase) { - keyInfo.passphrase = opts.passphrase; - } - if (opts.key) { - const { - iv, - mac - } = await (0, _aes.calculateKeyCheck)(opts.key); - keyInfo.iv = iv; - keyInfo.mac = mac; - } - if (!keyId) { - do { - keyId = (0, _randomstring.randomString)(32); - } while (await this.accountDataAdapter.getAccountDataFromServer(`m.secret_storage.key.${keyId}`)); - } - await this.accountDataAdapter.setAccountData(`m.secret_storage.key.${keyId}`, keyInfo); - return { - keyId, - keyInfo - }; - } - - /** - * Get the key information for a given ID. - * - * @param keyId - The ID of the key to check - * for. Defaults to the default key ID if not provided. - * @returns If the key was found, the return value is an array of - * the form [keyId, keyInfo]. Otherwise, null is returned. - * XXX: why is this an array when addKey returns an object? - */ - async getKey(keyId) { - if (!keyId) { - keyId = await this.getDefaultKeyId(); - } - if (!keyId) { - return null; - } - const keyInfo = await this.accountDataAdapter.getAccountDataFromServer("m.secret_storage.key." + keyId); - return keyInfo ? [keyId, keyInfo] : null; - } - - /** - * Check whether we have a key with a given ID. - * - * @param keyId - The ID of the key to check - * for. Defaults to the default key ID if not provided. - * @returns Whether we have the key. - */ - async hasKey(keyId) { - return Boolean(await this.getKey(keyId)); - } - - /** - * Check whether a key matches what we expect based on the key info - * - * @param key - the key to check - * @param info - the key info - * - * @returns whether or not the key matches - */ - async checkKey(key, info) { - if (info.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) { - if (info.mac) { - const { - mac - } = await (0, _aes.calculateKeyCheck)(key, info.iv); - return info.mac.replace(/=+$/g, "") === mac.replace(/=+$/g, ""); - } else { - // if we have no information, we have to assume the key is right - return true; - } - } else { - throw new Error("Unknown algorithm"); - } - } - - /** - * Store an encrypted secret on the server - * - * @param name - The name of the secret - * @param secret - The secret contents. - * @param keys - The IDs of the keys to use to encrypt the secret - * or null/undefined to use the default key. - */ - async store(name, secret, keys) { - const encrypted = {}; - if (!keys) { - const defaultKeyId = await this.getDefaultKeyId(); - if (!defaultKeyId) { - throw new Error("No keys specified and no default key present"); - } - keys = [defaultKeyId]; - } - if (keys.length === 0) { - throw new Error("Zero keys given to encrypt with!"); - } - for (const keyId of keys) { - // get key information from key storage - const keyInfo = await this.accountDataAdapter.getAccountDataFromServer("m.secret_storage.key." + keyId); - if (!keyInfo) { - throw new Error("Unknown key: " + keyId); - } - - // encrypt secret, based on the algorithm - if (keyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) { - const keys = { - [keyId]: keyInfo - }; - const [, encryption] = await this.getSecretStorageKey(keys, name); - encrypted[keyId] = await encryption.encrypt(secret); - } else { - _logger.logger.warn("unknown algorithm for secret storage key " + keyId + ": " + keyInfo.algorithm); - // do nothing if we don't understand the encryption algorithm - } - } - - // save encrypted secret - await this.accountDataAdapter.setAccountData(name, { - encrypted - }); - } - - /** - * Get a secret from storage. - * - * @param name - the name of the secret - * - * @returns the contents of the secret - */ - async get(name) { - const secretInfo = await this.accountDataAdapter.getAccountDataFromServer(name); - if (!secretInfo) { - return; - } - if (!secretInfo.encrypted) { - throw new Error("Content is not encrypted!"); - } - - // get possible keys to decrypt - const keys = {}; - for (const keyId of Object.keys(secretInfo.encrypted)) { - // get key information from key storage - const keyInfo = await this.accountDataAdapter.getAccountDataFromServer("m.secret_storage.key." + keyId); - const encInfo = secretInfo.encrypted[keyId]; - // only use keys we understand the encryption algorithm of - if (keyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) { - if (encInfo.iv && encInfo.ciphertext && encInfo.mac) { - keys[keyId] = keyInfo; - } - } - } - if (Object.keys(keys).length === 0) { - throw new Error(`Could not decrypt ${name} because none of ` + `the keys it is encrypted with are for a supported algorithm`); - } - - // fetch private key from app - const [keyId, decryption] = await this.getSecretStorageKey(keys, name); - const encInfo = secretInfo.encrypted[keyId]; - return decryption.decrypt(encInfo); - } - - /** - * Check if a secret is stored on the server. - * - * @param name - the name of the secret - * - * @returns map of key name to key info the secret is encrypted - * with, or null if it is not present or not encrypted with a trusted - * key - */ - async isStored(name) { - // check if secret exists - const secretInfo = await this.accountDataAdapter.getAccountDataFromServer(name); - if (!(secretInfo !== null && secretInfo !== void 0 && secretInfo.encrypted)) return null; - const ret = {}; - - // filter secret encryption keys with supported algorithm - for (const keyId of Object.keys(secretInfo.encrypted)) { - // get key information from key storage - const keyInfo = await this.accountDataAdapter.getAccountDataFromServer("m.secret_storage.key." + keyId); - if (!keyInfo) continue; - const encInfo = secretInfo.encrypted[keyId]; - - // only use keys we understand the encryption algorithm of - if (keyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) { - if (encInfo.iv && encInfo.ciphertext && encInfo.mac) { - ret[keyId] = keyInfo; - } - } - } - return Object.keys(ret).length ? ret : null; - } - - /** - * Request a secret from another device - * - * @param name - the name of the secret to request - * @param devices - the devices to request the secret from - */ - request(name, devices) { - const requestId = this.baseApis.makeTxnId(); - const deferred = (0, _utils.defer)(); - this.requests.set(requestId, { - name, - devices, - deferred - }); - const cancel = reason => { - // send cancellation event - const cancelData = { - action: "request_cancellation", - requesting_device_id: this.baseApis.deviceId, - request_id: requestId - }; - const toDevice = new Map(); - for (const device of devices) { - toDevice.set(device, cancelData); - } - this.baseApis.sendToDevice("m.secret.request", new Map([[this.baseApis.getUserId(), toDevice]])); - - // and reject the promise so that anyone waiting on it will be - // notified - deferred.reject(new Error(reason || "Cancelled")); - }; - - // send request to devices - const requestData = { - name, - action: "request", - requesting_device_id: this.baseApis.deviceId, - request_id: requestId, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - const toDevice = new Map(); - for (const device of devices) { - toDevice.set(device, requestData); - } - _logger.logger.info(`Request secret ${name} from ${devices}, id ${requestId}`); - this.baseApis.sendToDevice("m.secret.request", new Map([[this.baseApis.getUserId(), toDevice]])); - return { - requestId, - promise: deferred.promise, - cancel - }; - } - async onRequestReceived(event) { - const sender = event.getSender(); - const content = event.getContent(); - if (sender !== this.baseApis.getUserId() || !(content.name && content.action && content.requesting_device_id && content.request_id)) { - // ignore requests from anyone else, for now - return; - } - const deviceId = content.requesting_device_id; - // check if it's a cancel - if (content.action === "request_cancellation") { - /* - Looks like we intended to emit events when we got cancelations, but - we never put anything in the _incomingRequests object, and the request - itself doesn't use events anyway so if we were to wire up cancellations, - they probably ought to use the same callback interface. I'm leaving them - disabled for now while converting this file to typescript. - if (this._incomingRequests[deviceId] - && this._incomingRequests[deviceId][content.request_id]) { - logger.info( - "received request cancellation for secret (" + sender + - ", " + deviceId + ", " + content.request_id + ")", - ); - this.baseApis.emit("crypto.secrets.requestCancelled", { - user_id: sender, - device_id: deviceId, - request_id: content.request_id, - }); - } - */ - } else if (content.action === "request") { - if (deviceId === this.baseApis.deviceId) { - // no point in trying to send ourself the secret - return; - } - - // check if we have the secret - _logger.logger.info("received request for secret (" + sender + ", " + deviceId + ", " + content.request_id + ")"); - if (!this.cryptoCallbacks.onSecretRequested) { - return; - } - const secret = await this.cryptoCallbacks.onSecretRequested(sender, deviceId, content.request_id, content.name, this.baseApis.checkDeviceTrust(sender, deviceId)); - if (secret) { - _logger.logger.info(`Preparing ${content.name} secret for ${deviceId}`); - const payload = { - type: "m.secret.send", - content: { - request_id: content.request_id, - secret: secret - } - }; - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.baseApis.crypto.olmDevice.deviceCurve25519Key, - ciphertext: {}, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - await olmlib.ensureOlmSessionsForDevices(this.baseApis.crypto.olmDevice, this.baseApis, new Map([[sender, [this.baseApis.getStoredDevice(sender, deviceId)]]])); - await olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.baseApis.getUserId(), this.baseApis.deviceId, this.baseApis.crypto.olmDevice, sender, this.baseApis.getStoredDevice(sender, deviceId), payload); - const contentMap = new Map([[sender, new Map([[deviceId, encryptedContent]])]]); - _logger.logger.info(`Sending ${content.name} secret for ${deviceId}`); - this.baseApis.sendToDevice("m.room.encrypted", contentMap); - } else { - _logger.logger.info(`Request denied for ${content.name} secret for ${deviceId}`); - } - } - } - onSecretReceived(event) { - if (event.getSender() !== this.baseApis.getUserId()) { - // we shouldn't be receiving secrets from anyone else, so ignore - // because someone could be trying to send us bogus data - return; - } - if (!olmlib.isOlmEncrypted(event)) { - _logger.logger.error("secret event not properly encrypted"); - return; - } - const content = event.getContent(); - const senderKeyUser = this.baseApis.crypto.deviceList.getUserByIdentityKey(olmlib.OLM_ALGORITHM, event.getSenderKey() || ""); - if (senderKeyUser !== event.getSender()) { - _logger.logger.error("sending device does not belong to the user it claims to be from"); - return; - } - _logger.logger.log("got secret share for request", content.request_id); - const requestControl = this.requests.get(content.request_id); - if (requestControl) { - // make sure that the device that sent it is one of the devices that - // we requested from - const deviceInfo = this.baseApis.crypto.deviceList.getDeviceByIdentityKey(olmlib.OLM_ALGORITHM, event.getSenderKey()); - if (!deviceInfo) { - _logger.logger.log("secret share from unknown device with key", event.getSenderKey()); - return; - } - if (!requestControl.devices.includes(deviceInfo.deviceId)) { - _logger.logger.log("unsolicited secret share from device", deviceInfo.deviceId); - return; - } - // unsure that the sender is trusted. In theory, this check is - // unnecessary since we only accept secret shares from devices that - // we requested from, but it doesn't hurt. - const deviceTrust = this.baseApis.crypto.checkDeviceInfoTrust(event.getSender(), deviceInfo); - if (!deviceTrust.isVerified()) { - _logger.logger.log("secret share from unverified device"); - return; - } - _logger.logger.log(`Successfully received secret ${requestControl.name} ` + `from ${deviceInfo.deviceId}`); - requestControl.deferred.resolve(content.secret); - } - } - async getSecretStorageKey(keys, name) { - if (!this.cryptoCallbacks.getSecretStorageKey) { - throw new Error("No getSecretStorageKey callback supplied"); - } - const returned = await this.cryptoCallbacks.getSecretStorageKey({ - keys - }, name); - if (!returned) { - throw new Error("getSecretStorageKey callback returned falsey"); - } - if (returned.length < 2) { - throw new Error("getSecretStorageKey callback returned invalid data"); - } - const [keyId, privateKey] = returned; - if (!keys[keyId]) { - throw new Error("App returned unknown key from getSecretStorageKey!"); - } - if (keys[keyId].algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) { - const decryption = { - encrypt: function (secret) { - return (0, _aes.encryptAES)(secret, privateKey, name); - }, - decrypt: function (encInfo) { - return (0, _aes.decryptAES)(encInfo, privateKey, name); - } - }; - return [keyId, decryption]; - } else { - throw new Error("Unknown key type: " + keys[keyId].algorithm); - } - } -} -exports.SecretStorage = SecretStorage; -//# sourceMappingURL=SecretStorage.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js.map deleted file mode 100644 index 5852b67..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/SecretStorage.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SecretStorage.js","names":["_uuid","require","_logger","olmlib","_interopRequireWildcard","_randomstring","_aes","_client","_utils","_event","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","SECRET_STORAGE_ALGORITHM_V1_AES","exports","SecretStorage","constructor","accountDataAdapter","cryptoCallbacks","baseApis","_defineProperty2","Map","getDefaultKeyId","defaultKey","getAccountDataFromServer","setDefaultKeyId","keyId","Promise","resolve","reject","listener","ev","getType","getContent","removeListener","ClientEvent","AccountData","on","setAccountData","catch","e","addKey","algorithm","opts","Error","keyInfo","name","passphrase","iv","mac","calculateKeyCheck","randomString","getKey","hasKey","Boolean","checkKey","info","replace","store","secret","keys","encrypted","defaultKeyId","length","encryption","getSecretStorageKey","encrypt","logger","warn","secretInfo","encInfo","ciphertext","decryption","decrypt","isStored","ret","request","devices","requestId","makeTxnId","deferred","defer","requests","cancel","reason","cancelData","action","requesting_device_id","deviceId","request_id","toDevice","device","sendToDevice","getUserId","requestData","ToDeviceMessageId","uuidv4","promise","onRequestReceived","event","sender","getSender","content","onSecretRequested","checkDeviceTrust","payload","type","encryptedContent","OLM_ALGORITHM","sender_key","crypto","olmDevice","deviceCurve25519Key","ensureOlmSessionsForDevices","getStoredDevice","encryptMessageForDevice","contentMap","onSecretReceived","isOlmEncrypted","error","senderKeyUser","deviceList","getUserByIdentityKey","getSenderKey","log","requestControl","deviceInfo","getDeviceByIdentityKey","includes","deviceTrust","checkDeviceInfoTrust","isVerified","returned","privateKey","encryptAES","decryptAES"],"sources":["../../src/crypto/SecretStorage.ts"],"sourcesContent":["/*\nCopyright 2019 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { logger } from \"../logger\";\nimport * as olmlib from \"./olmlib\";\nimport { randomString } from \"../randomstring\";\nimport { calculateKeyCheck, decryptAES, encryptAES, IEncryptedPayload } from \"./aes\";\nimport { ICryptoCallbacks, IEncryptedContent } from \".\";\nimport { IContent, MatrixEvent } from \"../models/event\";\nimport { ClientEvent, ClientEventHandlerMap, MatrixClient } from \"../client\";\nimport { IAddSecretStorageKeyOpts } from \"./api\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { defer, IDeferred } from \"../utils\";\nimport { ToDeviceMessageId } from \"../@types/event\";\nimport { SecretStorageKeyDescription, SecretStorageKeyDescriptionAesV1 } from \"../secret-storage\";\n\nexport const SECRET_STORAGE_ALGORITHM_V1_AES = \"m.secret_storage.v1.aes-hmac-sha2\";\n\n// Some of the key functions use a tuple and some use an object...\nexport type SecretStorageKeyTuple = [keyId: string, keyInfo: SecretStorageKeyDescription];\nexport type SecretStorageKeyObject = { keyId: string; keyInfo: SecretStorageKeyDescription };\n\nexport interface ISecretRequest {\n requestId: string;\n promise: Promise;\n cancel: (reason: string) => void;\n}\n\nexport interface IAccountDataClient extends TypedEventEmitter {\n // Subset of MatrixClient (which also uses any for the event content)\n getAccountDataFromServer: (eventType: string) => Promise;\n getAccountData: (eventType: string) => IContent | null;\n setAccountData: (eventType: string, content: any) => Promise<{}>;\n}\n\ninterface ISecretRequestInternal {\n name: string;\n devices: string[];\n deferred: IDeferred;\n}\n\ninterface IDecryptors {\n encrypt: (plaintext: string) => Promise;\n decrypt: (ciphertext: IEncryptedPayload) => Promise;\n}\n\ninterface ISecretInfo {\n encrypted: {\n [keyId: string]: IEncryptedPayload;\n };\n}\n\n/**\n * Implements Secure Secret Storage and Sharing (MSC1946)\n */\nexport class SecretStorage {\n private requests = new Map();\n\n // In it's pure javascript days, this was relying on some proper Javascript-style\n // type-abuse where sometimes we'd pass in a fake client object with just the account\n // data methods implemented, which is all this class needs unless you use the secret\n // sharing code, so it was fine. As a low-touch TypeScript migration, this now has\n // an extra, optional param for a real matrix client, so you can not pass it as long\n // as you don't request any secrets.\n // A better solution would probably be to split this class up into secret storage and\n // secret sharing which are really two separate things, even though they share an MSC.\n public constructor(\n private readonly accountDataAdapter: IAccountDataClient,\n private readonly cryptoCallbacks: ICryptoCallbacks,\n private readonly baseApis: B,\n ) {}\n\n public async getDefaultKeyId(): Promise {\n const defaultKey = await this.accountDataAdapter.getAccountDataFromServer<{ key: string }>(\n \"m.secret_storage.default_key\",\n );\n if (!defaultKey) return null;\n return defaultKey.key;\n }\n\n public setDefaultKeyId(keyId: string): Promise {\n return new Promise((resolve, reject) => {\n const listener = (ev: MatrixEvent): void => {\n if (ev.getType() === \"m.secret_storage.default_key\" && ev.getContent().key === keyId) {\n this.accountDataAdapter.removeListener(ClientEvent.AccountData, listener);\n resolve();\n }\n };\n this.accountDataAdapter.on(ClientEvent.AccountData, listener);\n\n this.accountDataAdapter.setAccountData(\"m.secret_storage.default_key\", { key: keyId }).catch((e) => {\n this.accountDataAdapter.removeListener(ClientEvent.AccountData, listener);\n reject(e);\n });\n });\n }\n\n /**\n * Add a key for encrypting secrets.\n *\n * @param algorithm - the algorithm used by the key.\n * @param opts - the options for the algorithm. The properties used\n * depend on the algorithm given.\n * @param keyId - the ID of the key. If not given, a random\n * ID will be generated.\n *\n * @returns An object with:\n * keyId: the ID of the key\n * keyInfo: details about the key (iv, mac, passphrase)\n */\n public async addKey(\n algorithm: string,\n opts: IAddSecretStorageKeyOpts = {},\n keyId?: string,\n ): Promise {\n if (algorithm !== SECRET_STORAGE_ALGORITHM_V1_AES) {\n throw new Error(`Unknown key algorithm ${algorithm}`);\n }\n\n const keyInfo = { algorithm } as SecretStorageKeyDescriptionAesV1;\n\n if (opts.name) {\n keyInfo.name = opts.name;\n }\n\n if (opts.passphrase) {\n keyInfo.passphrase = opts.passphrase;\n }\n if (opts.key) {\n const { iv, mac } = await calculateKeyCheck(opts.key);\n keyInfo.iv = iv;\n keyInfo.mac = mac;\n }\n\n if (!keyId) {\n do {\n keyId = randomString(32);\n } while (\n await this.accountDataAdapter.getAccountDataFromServer(\n `m.secret_storage.key.${keyId}`,\n )\n );\n }\n\n await this.accountDataAdapter.setAccountData(`m.secret_storage.key.${keyId}`, keyInfo);\n\n return {\n keyId,\n keyInfo,\n };\n }\n\n /**\n * Get the key information for a given ID.\n *\n * @param keyId - The ID of the key to check\n * for. Defaults to the default key ID if not provided.\n * @returns If the key was found, the return value is an array of\n * the form [keyId, keyInfo]. Otherwise, null is returned.\n * XXX: why is this an array when addKey returns an object?\n */\n public async getKey(keyId?: string | null): Promise {\n if (!keyId) {\n keyId = await this.getDefaultKeyId();\n }\n if (!keyId) {\n return null;\n }\n\n const keyInfo = await this.accountDataAdapter.getAccountDataFromServer(\n \"m.secret_storage.key.\" + keyId,\n );\n return keyInfo ? [keyId, keyInfo] : null;\n }\n\n /**\n * Check whether we have a key with a given ID.\n *\n * @param keyId - The ID of the key to check\n * for. Defaults to the default key ID if not provided.\n * @returns Whether we have the key.\n */\n public async hasKey(keyId?: string): Promise {\n return Boolean(await this.getKey(keyId));\n }\n\n /**\n * Check whether a key matches what we expect based on the key info\n *\n * @param key - the key to check\n * @param info - the key info\n *\n * @returns whether or not the key matches\n */\n public async checkKey(key: Uint8Array, info: SecretStorageKeyDescription): Promise {\n if (info.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) {\n if (info.mac) {\n const { mac } = await calculateKeyCheck(key, info.iv);\n return info.mac.replace(/=+$/g, \"\") === mac.replace(/=+$/g, \"\");\n } else {\n // if we have no information, we have to assume the key is right\n return true;\n }\n } else {\n throw new Error(\"Unknown algorithm\");\n }\n }\n\n /**\n * Store an encrypted secret on the server\n *\n * @param name - The name of the secret\n * @param secret - The secret contents.\n * @param keys - The IDs of the keys to use to encrypt the secret\n * or null/undefined to use the default key.\n */\n public async store(name: string, secret: string, keys?: string[] | null): Promise {\n const encrypted: Record = {};\n\n if (!keys) {\n const defaultKeyId = await this.getDefaultKeyId();\n if (!defaultKeyId) {\n throw new Error(\"No keys specified and no default key present\");\n }\n keys = [defaultKeyId];\n }\n\n if (keys.length === 0) {\n throw new Error(\"Zero keys given to encrypt with!\");\n }\n\n for (const keyId of keys) {\n // get key information from key storage\n const keyInfo = await this.accountDataAdapter.getAccountDataFromServer(\n \"m.secret_storage.key.\" + keyId,\n );\n if (!keyInfo) {\n throw new Error(\"Unknown key: \" + keyId);\n }\n\n // encrypt secret, based on the algorithm\n if (keyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) {\n const keys = { [keyId]: keyInfo };\n const [, encryption] = await this.getSecretStorageKey(keys, name);\n encrypted[keyId] = await encryption.encrypt(secret);\n } else {\n logger.warn(\"unknown algorithm for secret storage key \" + keyId + \": \" + keyInfo.algorithm);\n // do nothing if we don't understand the encryption algorithm\n }\n }\n\n // save encrypted secret\n await this.accountDataAdapter.setAccountData(name, { encrypted });\n }\n\n /**\n * Get a secret from storage.\n *\n * @param name - the name of the secret\n *\n * @returns the contents of the secret\n */\n public async get(name: string): Promise {\n const secretInfo = await this.accountDataAdapter.getAccountDataFromServer(name);\n if (!secretInfo) {\n return;\n }\n if (!secretInfo.encrypted) {\n throw new Error(\"Content is not encrypted!\");\n }\n\n // get possible keys to decrypt\n const keys: Record = {};\n for (const keyId of Object.keys(secretInfo.encrypted)) {\n // get key information from key storage\n const keyInfo = await this.accountDataAdapter.getAccountDataFromServer(\n \"m.secret_storage.key.\" + keyId,\n );\n const encInfo = secretInfo.encrypted[keyId];\n // only use keys we understand the encryption algorithm of\n if (keyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) {\n if (encInfo.iv && encInfo.ciphertext && encInfo.mac) {\n keys[keyId] = keyInfo;\n }\n }\n }\n\n if (Object.keys(keys).length === 0) {\n throw new Error(\n `Could not decrypt ${name} because none of ` +\n `the keys it is encrypted with are for a supported algorithm`,\n );\n }\n\n // fetch private key from app\n const [keyId, decryption] = await this.getSecretStorageKey(keys, name);\n const encInfo = secretInfo.encrypted[keyId];\n\n return decryption.decrypt(encInfo);\n }\n\n /**\n * Check if a secret is stored on the server.\n *\n * @param name - the name of the secret\n *\n * @returns map of key name to key info the secret is encrypted\n * with, or null if it is not present or not encrypted with a trusted\n * key\n */\n public async isStored(name: string): Promise | null> {\n // check if secret exists\n const secretInfo = await this.accountDataAdapter.getAccountDataFromServer(name);\n if (!secretInfo?.encrypted) return null;\n\n const ret: Record = {};\n\n // filter secret encryption keys with supported algorithm\n for (const keyId of Object.keys(secretInfo.encrypted)) {\n // get key information from key storage\n const keyInfo = await this.accountDataAdapter.getAccountDataFromServer(\n \"m.secret_storage.key.\" + keyId,\n );\n if (!keyInfo) continue;\n const encInfo = secretInfo.encrypted[keyId];\n\n // only use keys we understand the encryption algorithm of\n if (keyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) {\n if (encInfo.iv && encInfo.ciphertext && encInfo.mac) {\n ret[keyId] = keyInfo;\n }\n }\n }\n return Object.keys(ret).length ? ret : null;\n }\n\n /**\n * Request a secret from another device\n *\n * @param name - the name of the secret to request\n * @param devices - the devices to request the secret from\n */\n public request(this: SecretStorage, name: string, devices: string[]): ISecretRequest {\n const requestId = this.baseApis.makeTxnId();\n\n const deferred = defer();\n this.requests.set(requestId, { name, devices, deferred });\n\n const cancel = (reason: string): void => {\n // send cancellation event\n const cancelData = {\n action: \"request_cancellation\",\n requesting_device_id: this.baseApis.deviceId,\n request_id: requestId,\n };\n const toDevice: Map = new Map();\n for (const device of devices) {\n toDevice.set(device, cancelData);\n }\n this.baseApis.sendToDevice(\"m.secret.request\", new Map([[this.baseApis.getUserId()!, toDevice]]));\n\n // and reject the promise so that anyone waiting on it will be\n // notified\n deferred.reject(new Error(reason || \"Cancelled\"));\n };\n\n // send request to devices\n const requestData = {\n name,\n action: \"request\",\n requesting_device_id: this.baseApis.deviceId,\n request_id: requestId,\n [ToDeviceMessageId]: uuidv4(),\n };\n const toDevice: Map = new Map();\n for (const device of devices) {\n toDevice.set(device, requestData);\n }\n logger.info(`Request secret ${name} from ${devices}, id ${requestId}`);\n this.baseApis.sendToDevice(\"m.secret.request\", new Map([[this.baseApis.getUserId()!, toDevice]]));\n\n return {\n requestId,\n promise: deferred.promise,\n cancel,\n };\n }\n\n public async onRequestReceived(this: SecretStorage, event: MatrixEvent): Promise {\n const sender = event.getSender();\n const content = event.getContent();\n if (\n sender !== this.baseApis.getUserId() ||\n !(content.name && content.action && content.requesting_device_id && content.request_id)\n ) {\n // ignore requests from anyone else, for now\n return;\n }\n const deviceId = content.requesting_device_id;\n // check if it's a cancel\n if (content.action === \"request_cancellation\") {\n /*\n Looks like we intended to emit events when we got cancelations, but\n we never put anything in the _incomingRequests object, and the request\n itself doesn't use events anyway so if we were to wire up cancellations,\n they probably ought to use the same callback interface. I'm leaving them\n disabled for now while converting this file to typescript.\n if (this._incomingRequests[deviceId]\n && this._incomingRequests[deviceId][content.request_id]) {\n logger.info(\n \"received request cancellation for secret (\" + sender +\n \", \" + deviceId + \", \" + content.request_id + \")\",\n );\n this.baseApis.emit(\"crypto.secrets.requestCancelled\", {\n user_id: sender,\n device_id: deviceId,\n request_id: content.request_id,\n });\n }\n */\n } else if (content.action === \"request\") {\n if (deviceId === this.baseApis.deviceId) {\n // no point in trying to send ourself the secret\n return;\n }\n\n // check if we have the secret\n logger.info(\"received request for secret (\" + sender + \", \" + deviceId + \", \" + content.request_id + \")\");\n if (!this.cryptoCallbacks.onSecretRequested) {\n return;\n }\n const secret = await this.cryptoCallbacks.onSecretRequested(\n sender,\n deviceId,\n content.request_id,\n content.name,\n this.baseApis.checkDeviceTrust(sender, deviceId),\n );\n if (secret) {\n logger.info(`Preparing ${content.name} secret for ${deviceId}`);\n const payload = {\n type: \"m.secret.send\",\n content: {\n request_id: content.request_id,\n secret: secret,\n },\n };\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.baseApis.crypto!.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n [ToDeviceMessageId]: uuidv4(),\n };\n await olmlib.ensureOlmSessionsForDevices(\n this.baseApis.crypto!.olmDevice,\n this.baseApis,\n new Map([[sender, [this.baseApis.getStoredDevice(sender, deviceId)!]]]),\n );\n await olmlib.encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.baseApis.getUserId()!,\n this.baseApis.deviceId!,\n this.baseApis.crypto!.olmDevice,\n sender,\n this.baseApis.getStoredDevice(sender, deviceId)!,\n payload,\n );\n const contentMap = new Map([[sender, new Map([[deviceId, encryptedContent]])]]);\n\n logger.info(`Sending ${content.name} secret for ${deviceId}`);\n this.baseApis.sendToDevice(\"m.room.encrypted\", contentMap);\n } else {\n logger.info(`Request denied for ${content.name} secret for ${deviceId}`);\n }\n }\n }\n\n public onSecretReceived(this: SecretStorage, event: MatrixEvent): void {\n if (event.getSender() !== this.baseApis.getUserId()) {\n // we shouldn't be receiving secrets from anyone else, so ignore\n // because someone could be trying to send us bogus data\n return;\n }\n\n if (!olmlib.isOlmEncrypted(event)) {\n logger.error(\"secret event not properly encrypted\");\n return;\n }\n\n const content = event.getContent();\n\n const senderKeyUser = this.baseApis.crypto!.deviceList.getUserByIdentityKey(\n olmlib.OLM_ALGORITHM,\n event.getSenderKey() || \"\",\n );\n if (senderKeyUser !== event.getSender()) {\n logger.error(\"sending device does not belong to the user it claims to be from\");\n return;\n }\n\n logger.log(\"got secret share for request\", content.request_id);\n const requestControl = this.requests.get(content.request_id);\n if (requestControl) {\n // make sure that the device that sent it is one of the devices that\n // we requested from\n const deviceInfo = this.baseApis.crypto!.deviceList.getDeviceByIdentityKey(\n olmlib.OLM_ALGORITHM,\n event.getSenderKey()!,\n );\n if (!deviceInfo) {\n logger.log(\"secret share from unknown device with key\", event.getSenderKey());\n return;\n }\n if (!requestControl.devices.includes(deviceInfo.deviceId)) {\n logger.log(\"unsolicited secret share from device\", deviceInfo.deviceId);\n return;\n }\n // unsure that the sender is trusted. In theory, this check is\n // unnecessary since we only accept secret shares from devices that\n // we requested from, but it doesn't hurt.\n const deviceTrust = this.baseApis.crypto!.checkDeviceInfoTrust(event.getSender()!, deviceInfo);\n if (!deviceTrust.isVerified()) {\n logger.log(\"secret share from unverified device\");\n return;\n }\n\n logger.log(`Successfully received secret ${requestControl.name} ` + `from ${deviceInfo.deviceId}`);\n requestControl.deferred.resolve(content.secret);\n }\n }\n\n private async getSecretStorageKey(\n keys: Record,\n name: string,\n ): Promise<[string, IDecryptors]> {\n if (!this.cryptoCallbacks.getSecretStorageKey) {\n throw new Error(\"No getSecretStorageKey callback supplied\");\n }\n\n const returned = await this.cryptoCallbacks.getSecretStorageKey({ keys }, name);\n\n if (!returned) {\n throw new Error(\"getSecretStorageKey callback returned falsey\");\n }\n if (returned.length < 2) {\n throw new Error(\"getSecretStorageKey callback returned invalid data\");\n }\n\n const [keyId, privateKey] = returned;\n if (!keys[keyId]) {\n throw new Error(\"App returned unknown key from getSecretStorageKey!\");\n }\n\n if (keys[keyId].algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) {\n const decryption = {\n encrypt: function (secret: string): Promise {\n return encryptAES(secret, privateKey, name);\n },\n decrypt: function (encInfo: IEncryptedPayload): Promise {\n return decryptAES(encInfo, privateKey, name);\n },\n };\n return [keyId, decryption];\n } else {\n throw new Error(\"Unknown key type: \" + keys[keyId].algorithm);\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts deleted file mode 100644 index 30ab08a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts +++ /dev/null @@ -1,35 +0,0 @@ -export interface IEncryptedPayload { - [key: string]: any; - /** the initialization vector in base64 */ - iv: string; - /** the ciphertext in base64 */ - ciphertext: string; - /** the HMAC in base64 */ - mac: string; -} -/** - * encrypt a string - * - * @param data - the plaintext to encrypt - * @param key - the encryption key to use - * @param name - the name of the secret - * @param ivStr - the initialization vector to use - */ -export declare function encryptAES(data: string, key: Uint8Array, name: string, ivStr?: string): Promise; -/** - * decrypt a string - * - * @param data - the encrypted data - * @param key - the encryption key to use - * @param name - the name of the secret - */ -export declare function decryptAES(data: IEncryptedPayload, key: Uint8Array, name: string): Promise; -/** Calculate the MAC for checking the key. - * - * @param key - the key to use - * @param iv - The initialization vector as a base64-encoded string. - * If omitted, a random initialization vector will be created. - * @returns An object that contains, `mac` and `iv` properties. - */ -export declare function calculateKeyCheck(key: Uint8Array, iv?: string): Promise; -//# sourceMappingURL=aes.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts.map deleted file mode 100644 index ed3d0b5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"aes.d.ts","sourceRoot":"","sources":["../../src/crypto/aes.ts"],"names":[],"mappings":"AAsBA,MAAM,WAAW,iBAAiB;IAC9B,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;IACnB,0CAA0C;IAC1C,EAAE,EAAE,MAAM,CAAC;IACX,+BAA+B;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,yBAAyB;IACzB,GAAG,EAAE,MAAM,CAAC;CACf;AAED;;;;;;;GAOG;AACH,wBAAsB,UAAU,CAC5B,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,UAAU,EACf,IAAI,EAAE,MAAM,EACZ,KAAK,CAAC,EAAE,MAAM,GACf,OAAO,CAAC,iBAAiB,CAAC,CAkC5B;AAED;;;;;;GAMG;AACH,wBAAsB,UAAU,CAAC,IAAI,EAAE,iBAAiB,EAAE,GAAG,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAoBxG;AAuCD;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAE1F"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js deleted file mode 100644 index 97181df..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js +++ /dev/null @@ -1,128 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.calculateKeyCheck = calculateKeyCheck; -exports.decryptAES = decryptAES; -exports.encryptAES = encryptAES; -var _olmlib = require("./olmlib"); -var _crypto = require("./crypto"); -/* -Copyright 2020 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// salt for HKDF, with 8 bytes of zeros -const zeroSalt = new Uint8Array(8); -/** - * encrypt a string - * - * @param data - the plaintext to encrypt - * @param key - the encryption key to use - * @param name - the name of the secret - * @param ivStr - the initialization vector to use - */ -async function encryptAES(data, key, name, ivStr) { - let iv; - if (ivStr) { - iv = (0, _olmlib.decodeBase64)(ivStr); - } else { - iv = new Uint8Array(16); - _crypto.crypto.getRandomValues(iv); - - // clear bit 63 of the IV to stop us hitting the 64-bit counter boundary - // (which would mean we wouldn't be able to decrypt on Android). The loss - // of a single bit of iv is a price we have to pay. - iv[8] &= 0x7f; - } - const [aesKey, hmacKey] = await deriveKeys(key, name); - const encodedData = new _crypto.TextEncoder().encode(data); - const ciphertext = await _crypto.subtleCrypto.encrypt({ - name: "AES-CTR", - counter: iv, - length: 64 - }, aesKey, encodedData); - const hmac = await _crypto.subtleCrypto.sign({ - name: "HMAC" - }, hmacKey, ciphertext); - return { - iv: (0, _olmlib.encodeBase64)(iv), - ciphertext: (0, _olmlib.encodeBase64)(ciphertext), - mac: (0, _olmlib.encodeBase64)(hmac) - }; -} - -/** - * decrypt a string - * - * @param data - the encrypted data - * @param key - the encryption key to use - * @param name - the name of the secret - */ -async function decryptAES(data, key, name) { - const [aesKey, hmacKey] = await deriveKeys(key, name); - const ciphertext = (0, _olmlib.decodeBase64)(data.ciphertext); - if (!(await _crypto.subtleCrypto.verify({ - name: "HMAC" - }, hmacKey, (0, _olmlib.decodeBase64)(data.mac), ciphertext))) { - throw new Error(`Error decrypting secret ${name}: bad MAC`); - } - const plaintext = await _crypto.subtleCrypto.decrypt({ - name: "AES-CTR", - counter: (0, _olmlib.decodeBase64)(data.iv), - length: 64 - }, aesKey, ciphertext); - return new TextDecoder().decode(new Uint8Array(plaintext)); -} -async function deriveKeys(key, name) { - const hkdfkey = await _crypto.subtleCrypto.importKey("raw", key, { - name: "HKDF" - }, false, ["deriveBits"]); - const keybits = await _crypto.subtleCrypto.deriveBits({ - name: "HKDF", - salt: zeroSalt, - // eslint-disable-next-line @typescript-eslint/ban-ts-comment - // @ts-ignore: https://github.com/microsoft/TypeScript-DOM-lib-generator/pull/879 - info: new _crypto.TextEncoder().encode(name), - hash: "SHA-256" - }, hkdfkey, 512); - const aesKey = keybits.slice(0, 32); - const hmacKey = keybits.slice(32); - const aesProm = _crypto.subtleCrypto.importKey("raw", aesKey, { - name: "AES-CTR" - }, false, ["encrypt", "decrypt"]); - const hmacProm = _crypto.subtleCrypto.importKey("raw", hmacKey, { - name: "HMAC", - hash: { - name: "SHA-256" - } - }, false, ["sign", "verify"]); - return Promise.all([aesProm, hmacProm]); -} - -// string of zeroes, for calculating the key check -const ZERO_STR = "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"; - -/** Calculate the MAC for checking the key. - * - * @param key - the key to use - * @param iv - The initialization vector as a base64-encoded string. - * If omitted, a random initialization vector will be created. - * @returns An object that contains, `mac` and `iv` properties. - */ -function calculateKeyCheck(key, iv) { - return encryptAES(ZERO_STR, key, "", iv); -} -//# sourceMappingURL=aes.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js.map deleted file mode 100644 index 3b8f88c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/aes.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"aes.js","names":["_olmlib","require","_crypto","zeroSalt","Uint8Array","encryptAES","data","key","name","ivStr","iv","decodeBase64","crypto","getRandomValues","aesKey","hmacKey","deriveKeys","encodedData","TextEncoder","encode","ciphertext","subtleCrypto","encrypt","counter","length","hmac","sign","encodeBase64","mac","decryptAES","verify","Error","plaintext","decrypt","TextDecoder","decode","hkdfkey","importKey","keybits","deriveBits","salt","info","hash","slice","aesProm","hmacProm","Promise","all","ZERO_STR","calculateKeyCheck"],"sources":["../../src/crypto/aes.ts"],"sourcesContent":["/*\nCopyright 2020 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { decodeBase64, encodeBase64 } from \"./olmlib\";\nimport { subtleCrypto, crypto, TextEncoder } from \"./crypto\";\n\n// salt for HKDF, with 8 bytes of zeros\nconst zeroSalt = new Uint8Array(8);\n\nexport interface IEncryptedPayload {\n [key: string]: any; // extensible\n /** the initialization vector in base64 */\n iv: string;\n /** the ciphertext in base64 */\n ciphertext: string;\n /** the HMAC in base64 */\n mac: string;\n}\n\n/**\n * encrypt a string\n *\n * @param data - the plaintext to encrypt\n * @param key - the encryption key to use\n * @param name - the name of the secret\n * @param ivStr - the initialization vector to use\n */\nexport async function encryptAES(\n data: string,\n key: Uint8Array,\n name: string,\n ivStr?: string,\n): Promise {\n let iv: Uint8Array;\n if (ivStr) {\n iv = decodeBase64(ivStr);\n } else {\n iv = new Uint8Array(16);\n crypto.getRandomValues(iv);\n\n // clear bit 63 of the IV to stop us hitting the 64-bit counter boundary\n // (which would mean we wouldn't be able to decrypt on Android). The loss\n // of a single bit of iv is a price we have to pay.\n iv[8] &= 0x7f;\n }\n\n const [aesKey, hmacKey] = await deriveKeys(key, name);\n const encodedData = new TextEncoder().encode(data);\n\n const ciphertext = await subtleCrypto.encrypt(\n {\n name: \"AES-CTR\",\n counter: iv,\n length: 64,\n },\n aesKey,\n encodedData,\n );\n\n const hmac = await subtleCrypto.sign({ name: \"HMAC\" }, hmacKey, ciphertext);\n\n return {\n iv: encodeBase64(iv),\n ciphertext: encodeBase64(ciphertext),\n mac: encodeBase64(hmac),\n };\n}\n\n/**\n * decrypt a string\n *\n * @param data - the encrypted data\n * @param key - the encryption key to use\n * @param name - the name of the secret\n */\nexport async function decryptAES(data: IEncryptedPayload, key: Uint8Array, name: string): Promise {\n const [aesKey, hmacKey] = await deriveKeys(key, name);\n\n const ciphertext = decodeBase64(data.ciphertext);\n\n if (!(await subtleCrypto.verify({ name: \"HMAC\" }, hmacKey, decodeBase64(data.mac), ciphertext))) {\n throw new Error(`Error decrypting secret ${name}: bad MAC`);\n }\n\n const plaintext = await subtleCrypto.decrypt(\n {\n name: \"AES-CTR\",\n counter: decodeBase64(data.iv),\n length: 64,\n },\n aesKey,\n ciphertext,\n );\n\n return new TextDecoder().decode(new Uint8Array(plaintext));\n}\n\nasync function deriveKeys(key: Uint8Array, name: string): Promise<[CryptoKey, CryptoKey]> {\n const hkdfkey = await subtleCrypto.importKey(\"raw\", key, { name: \"HKDF\" }, false, [\"deriveBits\"]);\n const keybits = await subtleCrypto.deriveBits(\n {\n name: \"HKDF\",\n salt: zeroSalt,\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore: https://github.com/microsoft/TypeScript-DOM-lib-generator/pull/879\n info: new TextEncoder().encode(name),\n hash: \"SHA-256\",\n },\n hkdfkey,\n 512,\n );\n\n const aesKey = keybits.slice(0, 32);\n const hmacKey = keybits.slice(32);\n\n const aesProm = subtleCrypto.importKey(\"raw\", aesKey, { name: \"AES-CTR\" }, false, [\"encrypt\", \"decrypt\"]);\n\n const hmacProm = subtleCrypto.importKey(\n \"raw\",\n hmacKey,\n {\n name: \"HMAC\",\n hash: { name: \"SHA-256\" },\n },\n false,\n [\"sign\", \"verify\"],\n );\n\n return Promise.all([aesProm, hmacProm]);\n}\n\n// string of zeroes, for calculating the key check\nconst ZERO_STR = \"\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\";\n\n/** Calculate the MAC for checking the key.\n *\n * @param key - the key to use\n * @param iv - The initialization vector as a base64-encoded string.\n * If omitted, a random initialization vector will be created.\n * @returns An object that contains, `mac` and `iv` properties.\n */\nexport function calculateKeyCheck(key: Uint8Array, iv?: string): Promise {\n return encryptAES(ZERO_STR, key, \"\", iv);\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts deleted file mode 100644 index adf2715..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts +++ /dev/null @@ -1,170 +0,0 @@ -/** - * Internal module. Defines the base classes of the encryption implementations - */ -import type { IMegolmSessionData } from "../../@types/crypto"; -import { MatrixClient } from "../../client"; -import { Room } from "../../models/room"; -import { OlmDevice } from "../OlmDevice"; -import { IContent, MatrixEvent, RoomMember } from "../../matrix"; -import { Crypto, IEncryptedContent, IEventDecryptionResult, IncomingRoomKeyRequest } from ".."; -import { DeviceInfo } from "../deviceinfo"; -import { IRoomEncryption } from "../RoomList"; -import { DeviceInfoMap } from "../DeviceList"; -/** - * Map of registered encryption algorithm classes. A map from string to {@link EncryptionAlgorithm} class - */ -export declare const ENCRYPTION_CLASSES: Map EncryptionAlgorithm>; -export type DecryptionClassParams

= Omit; -/** - * map of registered encryption algorithm classes. Map from string to {@link DecryptionAlgorithm} class - */ -export declare const DECRYPTION_CLASSES: Map DecryptionAlgorithm>; -export interface IParams { - /** The UserID for the local user */ - userId: string; - /** The identifier for this device. */ - deviceId: string; - /** crypto core */ - crypto: Crypto; - /** olm.js wrapper */ - olmDevice: OlmDevice; - /** base matrix api interface */ - baseApis: MatrixClient; - /** The ID of the room we will be sending to */ - roomId?: string; - /** The body of the m.room.encryption event */ - config: IRoomEncryption & object; -} -/** - * base type for encryption implementations - */ -export declare abstract class EncryptionAlgorithm { - protected readonly userId: string; - protected readonly deviceId: string; - protected readonly crypto: Crypto; - protected readonly olmDevice: OlmDevice; - protected readonly baseApis: MatrixClient; - protected readonly roomId?: string; - /** - * @param params - parameters - */ - constructor(params: IParams); - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * - * @param room - the room the event is in - */ - prepareToEncrypt(room: Room): void; - /** - * Encrypt a message event - * - * @public - * - * @param content - event content - * - * @returns Promise which resolves to the new event body - */ - abstract encryptMessage(room: Room, eventType: string, content: IContent): Promise; - /** - * Called when the membership of a member of the room changes. - * - * @param event - event causing the change - * @param member - user whose membership changed - * @param oldMembership - previous membership - * @public - */ - onRoomMembership(event: MatrixEvent, member: RoomMember, oldMembership?: string): void; - reshareKeyWithDevice?(senderKey: string, sessionId: string, userId: string, device: DeviceInfo): Promise; - forceDiscardSession?(): void; -} -/** - * base type for decryption implementations - */ -export declare abstract class DecryptionAlgorithm { - protected readonly userId: string; - protected readonly crypto: Crypto; - protected readonly olmDevice: OlmDevice; - protected readonly baseApis: MatrixClient; - protected readonly roomId?: string; - constructor(params: DecryptionClassParams); - /** - * Decrypt an event - * - * @param event - undecrypted event - * - * @returns promise which - * resolves once we have finished decrypting. Rejects with an - * `algorithms.DecryptionError` if there is a problem decrypting the event. - */ - abstract decryptEvent(event: MatrixEvent): Promise; - /** - * Handle a key event - * - * @param params - event key event - */ - onRoomKeyEvent(params: MatrixEvent): Promise; - /** - * Import a room key - * - * @param opts - object - */ - importRoomKey(session: IMegolmSessionData, opts: object): Promise; - /** - * Determine if we have the keys necessary to respond to a room key request - * - * @returns true if we have the keys and could (theoretically) share - * them; else false. - */ - hasKeysForKeyRequest(keyRequest: IncomingRoomKeyRequest): Promise; - /** - * Send the response to a room key request - * - */ - shareKeysWithDevice(keyRequest: IncomingRoomKeyRequest): void; - /** - * Retry decrypting all the events from a sender that haven't been - * decrypted yet. - * - * @param senderKey - the sender's key - */ - retryDecryptionFromSender(senderKey: string): Promise; - onRoomKeyWithheldEvent?(event: MatrixEvent): Promise; - sendSharedHistoryInboundSessions?(devicesByUser: Map): Promise; -} -/** - * Exception thrown when decryption fails - * - * @param msg - user-visible message describing the problem - * - * @param details - key/value pairs reported in the logs but not shown - * to the user. - */ -export declare class DecryptionError extends Error { - readonly code: string; - readonly detailedString: string; - constructor(code: string, msg: string, details?: Record); -} -export declare class UnknownDeviceError extends Error { - readonly devices: DeviceInfoMap; - event?: MatrixEvent | undefined; - /** - * Exception thrown specifically when we want to warn the user to consider - * the security of their conversation before continuing - * - * @param msg - message describing the problem - * @param devices - set of unknown devices per user we're warning about - */ - constructor(msg: string, devices: DeviceInfoMap, event?: MatrixEvent | undefined); -} -/** - * Registers an encryption/decryption class for a particular algorithm - * - * @param algorithm - algorithm tag to register for - * - * @param encryptor - {@link EncryptionAlgorithm} implementation - * - * @param decryptor - {@link DecryptionAlgorithm} implementation - */ -export declare function registerAlgorithm

(algorithm: string, encryptor: new (params: P) => EncryptionAlgorithm, decryptor: new (params: DecryptionClassParams

) => DecryptionAlgorithm): void; -//# sourceMappingURL=base.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts.map deleted file mode 100644 index c4c177a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../src/crypto/algorithms/base.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js deleted file mode 100644 index 9c5bd8f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js +++ /dev/null @@ -1,226 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UnknownDeviceError = exports.EncryptionAlgorithm = exports.ENCRYPTION_CLASSES = exports.DecryptionError = exports.DecryptionAlgorithm = exports.DECRYPTION_CLASSES = void 0; -exports.registerAlgorithm = registerAlgorithm; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Internal module. Defines the base classes of the encryption implementations - */ - -/** - * Map of registered encryption algorithm classes. A map from string to {@link EncryptionAlgorithm} class - */ -const ENCRYPTION_CLASSES = new Map(); -exports.ENCRYPTION_CLASSES = ENCRYPTION_CLASSES; -/** - * map of registered encryption algorithm classes. Map from string to {@link DecryptionAlgorithm} class - */ -const DECRYPTION_CLASSES = new Map(); -exports.DECRYPTION_CLASSES = DECRYPTION_CLASSES; -/** - * base type for encryption implementations - */ -class EncryptionAlgorithm { - /** - * @param params - parameters - */ - constructor(params) { - (0, _defineProperty2.default)(this, "userId", void 0); - (0, _defineProperty2.default)(this, "deviceId", void 0); - (0, _defineProperty2.default)(this, "crypto", void 0); - (0, _defineProperty2.default)(this, "olmDevice", void 0); - (0, _defineProperty2.default)(this, "baseApis", void 0); - (0, _defineProperty2.default)(this, "roomId", void 0); - this.userId = params.userId; - this.deviceId = params.deviceId; - this.crypto = params.crypto; - this.olmDevice = params.olmDevice; - this.baseApis = params.baseApis; - this.roomId = params.roomId; - } - - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * - * @param room - the room the event is in - */ - prepareToEncrypt(room) {} - - /** - * Encrypt a message event - * - * @public - * - * @param content - event content - * - * @returns Promise which resolves to the new event body - */ - - /** - * Called when the membership of a member of the room changes. - * - * @param event - event causing the change - * @param member - user whose membership changed - * @param oldMembership - previous membership - * @public - */ - onRoomMembership(event, member, oldMembership) {} -} - -/** - * base type for decryption implementations - */ -exports.EncryptionAlgorithm = EncryptionAlgorithm; -class DecryptionAlgorithm { - constructor(params) { - (0, _defineProperty2.default)(this, "userId", void 0); - (0, _defineProperty2.default)(this, "crypto", void 0); - (0, _defineProperty2.default)(this, "olmDevice", void 0); - (0, _defineProperty2.default)(this, "baseApis", void 0); - (0, _defineProperty2.default)(this, "roomId", void 0); - this.userId = params.userId; - this.crypto = params.crypto; - this.olmDevice = params.olmDevice; - this.baseApis = params.baseApis; - this.roomId = params.roomId; - } - - /** - * Decrypt an event - * - * @param event - undecrypted event - * - * @returns promise which - * resolves once we have finished decrypting. Rejects with an - * `algorithms.DecryptionError` if there is a problem decrypting the event. - */ - - /** - * Handle a key event - * - * @param params - event key event - */ - async onRoomKeyEvent(params) { - // ignore by default - } - - /** - * Import a room key - * - * @param opts - object - */ - async importRoomKey(session, opts) { - // ignore by default - } - - /** - * Determine if we have the keys necessary to respond to a room key request - * - * @returns true if we have the keys and could (theoretically) share - * them; else false. - */ - hasKeysForKeyRequest(keyRequest) { - return Promise.resolve(false); - } - - /** - * Send the response to a room key request - * - */ - shareKeysWithDevice(keyRequest) { - throw new Error("shareKeysWithDevice not supported for this DecryptionAlgorithm"); - } - - /** - * Retry decrypting all the events from a sender that haven't been - * decrypted yet. - * - * @param senderKey - the sender's key - */ - async retryDecryptionFromSender(senderKey) { - // ignore by default - return false; - } -} - -/** - * Exception thrown when decryption fails - * - * @param msg - user-visible message describing the problem - * - * @param details - key/value pairs reported in the logs but not shown - * to the user. - */ -exports.DecryptionAlgorithm = DecryptionAlgorithm; -class DecryptionError extends Error { - constructor(code, msg, details) { - super(msg); - this.code = code; - (0, _defineProperty2.default)(this, "detailedString", void 0); - this.code = code; - this.name = "DecryptionError"; - this.detailedString = detailedStringForDecryptionError(this, details); - } -} -exports.DecryptionError = DecryptionError; -function detailedStringForDecryptionError(err, details) { - let result = err.name + "[msg: " + err.message; - if (details) { - result += ", " + Object.keys(details).map(k => k + ": " + details[k]).join(", "); - } - result += "]"; - return result; -} -class UnknownDeviceError extends Error { - /** - * Exception thrown specifically when we want to warn the user to consider - * the security of their conversation before continuing - * - * @param msg - message describing the problem - * @param devices - set of unknown devices per user we're warning about - */ - constructor(msg, devices, event) { - super(msg); - this.devices = devices; - this.event = event; - this.name = "UnknownDeviceError"; - this.devices = devices; - } -} - -/** - * Registers an encryption/decryption class for a particular algorithm - * - * @param algorithm - algorithm tag to register for - * - * @param encryptor - {@link EncryptionAlgorithm} implementation - * - * @param decryptor - {@link DecryptionAlgorithm} implementation - */ -exports.UnknownDeviceError = UnknownDeviceError; -function registerAlgorithm(algorithm, encryptor, decryptor) { - ENCRYPTION_CLASSES.set(algorithm, encryptor); - DECRYPTION_CLASSES.set(algorithm, decryptor); -} -//# sourceMappingURL=base.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js.map deleted file mode 100644 index 3a4d930..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/base.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"base.js","names":["ENCRYPTION_CLASSES","Map","exports","DECRYPTION_CLASSES","EncryptionAlgorithm","constructor","params","_defineProperty2","default","userId","deviceId","crypto","olmDevice","baseApis","roomId","prepareToEncrypt","room","onRoomMembership","event","member","oldMembership","DecryptionAlgorithm","onRoomKeyEvent","importRoomKey","session","opts","hasKeysForKeyRequest","keyRequest","Promise","resolve","shareKeysWithDevice","Error","retryDecryptionFromSender","senderKey","DecryptionError","code","msg","details","name","detailedString","detailedStringForDecryptionError","err","result","message","Object","keys","map","k","join","UnknownDeviceError","devices","registerAlgorithm","algorithm","encryptor","decryptor","set"],"sources":["../../../src/crypto/algorithms/base.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Internal module. Defines the base classes of the encryption implementations\n */\n\nimport type { IMegolmSessionData } from \"../../@types/crypto\";\nimport { MatrixClient } from \"../../client\";\nimport { Room } from \"../../models/room\";\nimport { OlmDevice } from \"../OlmDevice\";\nimport { IContent, MatrixEvent, RoomMember } from \"../../matrix\";\nimport { Crypto, IEncryptedContent, IEventDecryptionResult, IncomingRoomKeyRequest } from \"..\";\nimport { DeviceInfo } from \"../deviceinfo\";\nimport { IRoomEncryption } from \"../RoomList\";\nimport { DeviceInfoMap } from \"../DeviceList\";\n\n/**\n * Map of registered encryption algorithm classes. A map from string to {@link EncryptionAlgorithm} class\n */\nexport const ENCRYPTION_CLASSES = new Map EncryptionAlgorithm>();\n\nexport type DecryptionClassParams

= Omit;\n\n/**\n * map of registered encryption algorithm classes. Map from string to {@link DecryptionAlgorithm} class\n */\nexport const DECRYPTION_CLASSES = new Map DecryptionAlgorithm>();\n\nexport interface IParams {\n /** The UserID for the local user */\n userId: string;\n /** The identifier for this device. */\n deviceId: string;\n /** crypto core */\n crypto: Crypto;\n /** olm.js wrapper */\n olmDevice: OlmDevice;\n /** base matrix api interface */\n baseApis: MatrixClient;\n /** The ID of the room we will be sending to */\n roomId?: string;\n /** The body of the m.room.encryption event */\n config: IRoomEncryption & object;\n}\n\n/**\n * base type for encryption implementations\n */\nexport abstract class EncryptionAlgorithm {\n protected readonly userId: string;\n protected readonly deviceId: string;\n protected readonly crypto: Crypto;\n protected readonly olmDevice: OlmDevice;\n protected readonly baseApis: MatrixClient;\n protected readonly roomId?: string;\n\n /**\n * @param params - parameters\n */\n public constructor(params: IParams) {\n this.userId = params.userId;\n this.deviceId = params.deviceId;\n this.crypto = params.crypto;\n this.olmDevice = params.olmDevice;\n this.baseApis = params.baseApis;\n this.roomId = params.roomId;\n }\n\n /**\n * Perform any background tasks that can be done before a message is ready to\n * send, in order to speed up sending of the message.\n *\n * @param room - the room the event is in\n */\n public prepareToEncrypt(room: Room): void {}\n\n /**\n * Encrypt a message event\n *\n * @public\n *\n * @param content - event content\n *\n * @returns Promise which resolves to the new event body\n */\n public abstract encryptMessage(room: Room, eventType: string, content: IContent): Promise;\n\n /**\n * Called when the membership of a member of the room changes.\n *\n * @param event - event causing the change\n * @param member - user whose membership changed\n * @param oldMembership - previous membership\n * @public\n */\n public onRoomMembership(event: MatrixEvent, member: RoomMember, oldMembership?: string): void {}\n\n public reshareKeyWithDevice?(\n senderKey: string,\n sessionId: string,\n userId: string,\n device: DeviceInfo,\n ): Promise;\n\n public forceDiscardSession?(): void;\n}\n\n/**\n * base type for decryption implementations\n */\nexport abstract class DecryptionAlgorithm {\n protected readonly userId: string;\n protected readonly crypto: Crypto;\n protected readonly olmDevice: OlmDevice;\n protected readonly baseApis: MatrixClient;\n protected readonly roomId?: string;\n\n public constructor(params: DecryptionClassParams) {\n this.userId = params.userId;\n this.crypto = params.crypto;\n this.olmDevice = params.olmDevice;\n this.baseApis = params.baseApis;\n this.roomId = params.roomId;\n }\n\n /**\n * Decrypt an event\n *\n * @param event - undecrypted event\n *\n * @returns promise which\n * resolves once we have finished decrypting. Rejects with an\n * `algorithms.DecryptionError` if there is a problem decrypting the event.\n */\n public abstract decryptEvent(event: MatrixEvent): Promise;\n\n /**\n * Handle a key event\n *\n * @param params - event key event\n */\n public async onRoomKeyEvent(params: MatrixEvent): Promise {\n // ignore by default\n }\n\n /**\n * Import a room key\n *\n * @param opts - object\n */\n public async importRoomKey(session: IMegolmSessionData, opts: object): Promise {\n // ignore by default\n }\n\n /**\n * Determine if we have the keys necessary to respond to a room key request\n *\n * @returns true if we have the keys and could (theoretically) share\n * them; else false.\n */\n public hasKeysForKeyRequest(keyRequest: IncomingRoomKeyRequest): Promise {\n return Promise.resolve(false);\n }\n\n /**\n * Send the response to a room key request\n *\n */\n public shareKeysWithDevice(keyRequest: IncomingRoomKeyRequest): void {\n throw new Error(\"shareKeysWithDevice not supported for this DecryptionAlgorithm\");\n }\n\n /**\n * Retry decrypting all the events from a sender that haven't been\n * decrypted yet.\n *\n * @param senderKey - the sender's key\n */\n public async retryDecryptionFromSender(senderKey: string): Promise {\n // ignore by default\n return false;\n }\n\n public onRoomKeyWithheldEvent?(event: MatrixEvent): Promise;\n public sendSharedHistoryInboundSessions?(devicesByUser: Map): Promise;\n}\n\n/**\n * Exception thrown when decryption fails\n *\n * @param msg - user-visible message describing the problem\n *\n * @param details - key/value pairs reported in the logs but not shown\n * to the user.\n */\nexport class DecryptionError extends Error {\n public readonly detailedString: string;\n\n public constructor(public readonly code: string, msg: string, details?: Record) {\n super(msg);\n this.code = code;\n this.name = \"DecryptionError\";\n this.detailedString = detailedStringForDecryptionError(this, details);\n }\n}\n\nfunction detailedStringForDecryptionError(err: DecryptionError, details?: Record): string {\n let result = err.name + \"[msg: \" + err.message;\n\n if (details) {\n result +=\n \", \" +\n Object.keys(details)\n .map((k) => k + \": \" + details[k])\n .join(\", \");\n }\n\n result += \"]\";\n\n return result;\n}\n\nexport class UnknownDeviceError extends Error {\n /**\n * Exception thrown specifically when we want to warn the user to consider\n * the security of their conversation before continuing\n *\n * @param msg - message describing the problem\n * @param devices - set of unknown devices per user we're warning about\n */\n public constructor(msg: string, public readonly devices: DeviceInfoMap, public event?: MatrixEvent) {\n super(msg);\n this.name = \"UnknownDeviceError\";\n this.devices = devices;\n }\n}\n\n/**\n * Registers an encryption/decryption class for a particular algorithm\n *\n * @param algorithm - algorithm tag to register for\n *\n * @param encryptor - {@link EncryptionAlgorithm} implementation\n *\n * @param decryptor - {@link DecryptionAlgorithm} implementation\n */\nexport function registerAlgorithm

(\n algorithm: string,\n encryptor: new (params: P) => EncryptionAlgorithm,\n decryptor: new (params: DecryptionClassParams

) => DecryptionAlgorithm,\n): void {\n ENCRYPTION_CLASSES.set(algorithm, encryptor as new (params: IParams) => EncryptionAlgorithm);\n DECRYPTION_CLASSES.set(algorithm, decryptor as new (params: DecryptionClassParams) => DecryptionAlgorithm);\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts deleted file mode 100644 index e380e5f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -import "./olm"; -import "./megolm"; -export * from "./base"; -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts.map deleted file mode 100644 index fe86a77..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/algorithms/index.ts"],"names":[],"mappings":"AAgBA,OAAO,OAAO,CAAC;AACf,OAAO,UAAU,CAAC;AAElB,cAAc,QAAQ,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js deleted file mode 100644 index 1b8540e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js +++ /dev/null @@ -1,19 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -require("./olm"); -require("./megolm"); -var _base = require("./base"); -Object.keys(_base).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _base[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _base[key]; - } - }); -}); -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js.map deleted file mode 100644 index 84ccb86..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["require","_base","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["../../../src/crypto/algorithms/index.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport \"./olm\";\nimport \"./megolm\";\n\nexport * from \"./base\";\n"],"mappings":";;;;;AAgBAA,OAAA;AACAA,OAAA;AAEA,IAAAC,KAAA,GAAAD,OAAA;AAAAE,MAAA,CAAAC,IAAA,CAAAF,KAAA,EAAAG,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAJ,KAAA,CAAAI,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAR,KAAA,CAAAI,GAAA;IAAA;EAAA;AAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts deleted file mode 100644 index cfc9abb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts +++ /dev/null @@ -1,385 +0,0 @@ -import type { IEventDecryptionResult, IMegolmSessionData } from "../../@types/crypto"; -import { DecryptionAlgorithm, DecryptionClassParams, EncryptionAlgorithm, IParams } from "./base"; -import { Room } from "../../models/room"; -import { DeviceInfo } from "../deviceinfo"; -import { IContent, MatrixEvent } from "../../models/event"; -import { IMegolmEncryptedContent, IncomingRoomKeyRequest } from "../index"; -export declare function isRoomSharedHistory(room: Room): boolean; -export interface IOlmDevice { - userId: string; - deviceInfo: T; -} -export interface IOutboundGroupSessionKey { - chain_index: number; - key: string; -} -/** - * Megolm encryption implementation - * - * @param params - parameters, as per {@link EncryptionAlgorithm} - */ -export declare class MegolmEncryption extends EncryptionAlgorithm { - private setupPromise; - private outboundSessions; - private readonly sessionRotationPeriodMsgs; - private readonly sessionRotationPeriodMs; - private encryptionPreparation?; - protected readonly roomId: string; - private readonly prefixedLogger; - constructor(params: IParams & Required>); - /** - * @internal - * - * @param devicesInRoom - The devices in this room, indexed by user ID - * @param blocked - The devices that are blocked, indexed by user ID - * @param singleOlmCreationPhase - Only perform one round of olm - * session creation - * - * This method updates the setupPromise field of the class by chaining a new - * call on top of the existing promise, and then catching and discarding any - * errors that might happen while setting up the outbound group session. This - * is done to ensure that `setupPromise` always resolves to `null` or the - * `OutboundSessionInfo`. - * - * Using `>>=` to represent the promise chaining operation, it does the - * following: - * - * ``` - * setupPromise = previousSetupPromise >>= setup >>= discardErrors - * ``` - * - * The initial value for the `setupPromise` is a promise that resolves to - * `null`. The forceDiscardSession() resets setupPromise to this initial - * promise. - * - * @returns Promise which resolves to the - * OutboundSessionInfo when setup is complete. - */ - private ensureOutboundSession; - private prepareSession; - private shareSession; - /** - * @internal - * - * - * @returns session - */ - private prepareNewSession; - /** - * Determines what devices in devicesByUser don't have an olm session as given - * in devicemap. - * - * @internal - * - * @param deviceMap - the devices that have olm sessions, as returned by - * olmlib.ensureOlmSessionsForDevices. - * @param devicesByUser - a map of user IDs to array of deviceInfo - * @param noOlmDevices - an array to fill with devices that don't have - * olm sessions - * - * @returns an array of devices that don't have olm sessions. If - * noOlmDevices is specified, then noOlmDevices will be returned. - */ - private getDevicesWithoutSessions; - /** - * Splits the user device map into multiple chunks to reduce the number of - * devices we encrypt to per API call. - * - * @internal - * - * @param devicesByUser - map from userid to list of devices - * - * @returns the blocked devices, split into chunks - */ - private splitDevices; - /** - * @internal - * - * - * @param chainIndex - current chain index - * - * @param userDeviceMap - mapping from userId to deviceInfo - * - * @param payload - fields to include in the encrypted payload - * - * @returns Promise which resolves once the key sharing - * for the given userDeviceMap is generated and has been sent. - */ - private encryptAndSendKeysToDevices; - /** - * @internal - * - * - * @param userDeviceMap - list of blocked devices to notify - * - * @param payload - fields to include in the notification payload - * - * @returns Promise which resolves once the notifications - * for the given userDeviceMap is generated and has been sent. - */ - private sendBlockedNotificationsToDevices; - /** - * Re-shares a megolm session key with devices if the key has already been - * sent to them. - * - * @param senderKey - The key of the originating device for the session - * @param sessionId - ID of the outbound session to share - * @param userId - ID of the user who owns the target device - * @param device - The target device - */ - reshareKeyWithDevice(senderKey: string, sessionId: string, userId: string, device: DeviceInfo): Promise; - /** - * @internal - * - * - * @param key - the session key as returned by - * OlmDevice.getOutboundGroupSessionKey - * - * @param payload - the base to-device message payload for sharing keys - * - * @param devicesByUser - map from userid to list of devices - * - * @param errorDevices - array that will be populated with the devices that we can't get an - * olm session for - * - * @param otkTimeout - The timeout in milliseconds when requesting - * one-time keys for establishing new olm sessions. - * - * @param failedServers - An array to fill with remote servers that - * failed to respond to one-time-key requests. - */ - private shareKeyWithDevices; - private shareKeyWithOlmSessions; - /** - * Notify devices that we weren't able to create olm sessions. - * - * - * - * @param failedDevices - the devices that we were unable to - * create olm sessions for, as returned by shareKeyWithDevices - */ - private notifyFailedOlmDevices; - /** - * Notify blocked devices that they have been blocked. - * - * - * @param devicesByUser - map from userid to device ID to blocked data - */ - private notifyBlockedDevices; - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * - * @param room - the room the event is in - * @returns A function that, when called, will stop the preparation - */ - prepareToEncrypt(room: Room): () => void; - /** - * @param content - plaintext event content - * - * @returns Promise which resolves to the new event body - */ - encryptMessage(room: Room, eventType: string, content: IContent): Promise; - private isVerificationEvent; - /** - * Forces the current outbound group session to be discarded such - * that another one will be created next time an event is sent. - * - * This should not normally be necessary. - */ - forceDiscardSession(): void; - /** - * Checks the devices we're about to send to and see if any are entirely - * unknown to the user. If so, warn the user, and mark them as known to - * give the user a chance to go verify them before re-sending this message. - * - * @param devicesInRoom - `userId -> {deviceId -> object}` - * devices we should shared the session with. - */ - private checkForUnknownDevices; - /** - * Remove unknown devices from a set of devices. The devicesInRoom parameter - * will be modified. - * - * @param devicesInRoom - `userId -> {deviceId -> object}` - * devices we should shared the session with. - */ - private removeUnknownDevices; - /** - * Get the list of unblocked devices for all users in the room - * - * @param forceDistributeToUnverified - if set to true will include the unverified devices - * even if setting is set to block them (useful for verification) - * @param isCancelled - will cause the procedure to abort early if and when it starts - * returning `true`. If omitted, cancellation won't happen. - * - * @returns Promise which resolves to `null`, or an array whose - * first element is a {@link DeviceInfoMap} indicating - * the devices that messages should be encrypted to, and whose second - * element is a map from userId to deviceId to data indicating the devices - * that are in the room but that have been blocked. - * If `isCancelled` is provided and returns `true` while processing, `null` - * will be returned. - * If `isCancelled` is not provided, the Promise will never resolve to `null`. - */ - private getDevicesInRoom; -} -/** - * Megolm decryption implementation - * - * @param params - parameters, as per {@link DecryptionAlgorithm} - */ -export declare class MegolmDecryption extends DecryptionAlgorithm { - private pendingEvents; - private olmlib; - protected readonly roomId: string; - private readonly prefixedLogger; - constructor(params: DecryptionClassParams>>); - /** - * returns a promise which resolves to a - * {@link EventDecryptionResult} once we have finished - * decrypting, or rejects with an `algorithms.DecryptionError` if there is a - * problem decrypting the event. - */ - decryptEvent(event: MatrixEvent): Promise; - private requestKeysForEvent; - /** - * Add an event to the list of those awaiting their session keys. - * - * @internal - * - */ - private addEventToPendingList; - /** - * Remove an event from the list of those awaiting their session keys. - * - * @internal - * - */ - private removeEventFromPendingList; - /** - * Parse a RoomKey out of an `m.room_key` event. - * - * @param event - the event containing the room key. - * - * @returns The `RoomKey` if it could be successfully parsed out of the - * event. - * - * @internal - * - */ - private roomKeyFromEvent; - /** - * Parse a RoomKey out of an `m.forwarded_room_key` event. - * - * @param event - the event containing the forwarded room key. - * - * @returns The `RoomKey` if it could be successfully parsed out of the - * event. - * - * @internal - * - */ - private forwardedRoomKeyFromEvent; - /** - * Determine if we should accept the forwarded room key that was found in the given - * event. - * - * @param event - An `m.forwarded_room_key` event. - * @param roomKey - The room key that was found in the event. - * - * @returns promise that will resolve to a boolean telling us if it's ok to - * accept the given forwarded room key. - * - * @internal - * - */ - private shouldAcceptForwardedKey; - /** - * Did we ever request the given room key from the event sender and its - * accompanying device. - * - * @param event - An `m.forwarded_room_key` event. - * @param roomKey - The room key that was found in the event. - * - * @internal - * - */ - private wasRoomKeyRequested; - private wasRoomKeyForwardedByInviter; - private wasRoomKeyForwardedAsHistory; - /** - * Check if a forwarded room key should be parked. - * - * A forwarded room key should be parked if it's a key for a room we're not - * in. We park the forwarded room key in case *this sender* invites us to - * that room later. - */ - private shouldParkForwardedKey; - /** - * Park the given room key to our store. - * - * @param event - An `m.forwarded_room_key` event. - * @param roomKey - The room key that was found in the event. - * - * @internal - * - */ - private parkForwardedKey; - /** - * Add the given room key to our store. - * - * @param roomKey - The room key that should be added to the store. - * - * @internal - * - */ - private addRoomKey; - /** - * Handle room keys that have been forwarded to us as an - * `m.forwarded_room_key` event. - * - * Forwarded room keys need special handling since we have no way of knowing - * who the original creator of the room key was. This naturally means that - * forwarded room keys are always untrusted and should only be accepted in - * some cases. - * - * @param event - An `m.forwarded_room_key` event. - * - * @internal - * - */ - private onForwardedRoomKey; - onRoomKeyEvent(event: MatrixEvent): Promise; - /** - * @param event - key event - */ - onRoomKeyWithheldEvent(event: MatrixEvent): Promise; - private onNoOlmWithheldEvent; - hasKeysForKeyRequest(keyRequest: IncomingRoomKeyRequest): Promise; - shareKeysWithDevice(keyRequest: IncomingRoomKeyRequest): void; - private buildKeyForwardingMessage; - /** - * @param untrusted - whether the key should be considered as untrusted - * @param source - where the key came from - */ - importRoomKey(session: IMegolmSessionData, { untrusted, source }?: { - untrusted?: boolean; - source?: string; - }): Promise; - /** - * Have another go at decrypting events after we receive a key. Resolves once - * decryption has been re-attempted on all events. - * - * @internal - * @param forceRedecryptIfUntrusted - whether messages that were already - * successfully decrypted using untrusted keys should be re-decrypted - * - * @returns whether all messages were successfully - * decrypted with trusted keys - */ - private retryDecryption; - retryDecryptionFromSender(senderKey: string): Promise; - sendSharedHistoryInboundSessions(devicesByUser: Map): Promise; -} -//# sourceMappingURL=megolm.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts.map deleted file mode 100644 index 5282d8b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"megolm.d.ts","sourceRoot":"","sources":["../../../src/crypto/algorithms/megolm.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js deleted file mode 100644 index 28b25ac..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js +++ /dev/null @@ -1,1682 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MegolmEncryption = exports.MegolmDecryption = void 0; -exports.isRoomSharedHistory = isRoomSharedHistory; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _uuid = require("uuid"); -var _logger = require("../../logger"); -var olmlib = _interopRequireWildcard(require("../olmlib")); -var _base = require("./base"); -var _OlmDevice = require("../OlmDevice"); -var _event = require("../../@types/event"); -var _OutgoingRoomKeyRequestManager = require("../OutgoingRoomKeyRequestManager"); -var _utils = require("../../utils"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -// determine whether the key can be shared with invitees -function isRoomSharedHistory(room) { - var _room$currentState, _visibilityEvent$getC; - const visibilityEvent = room === null || room === void 0 ? void 0 : (_room$currentState = room.currentState) === null || _room$currentState === void 0 ? void 0 : _room$currentState.getStateEvents("m.room.history_visibility", ""); - // NOTE: if the room visibility is unset, it would normally default to - // "world_readable". - // (https://spec.matrix.org/unstable/client-server-api/#server-behaviour-5) - // But we will be paranoid here, and treat it as a situation where the room - // is not shared-history - const visibility = visibilityEvent === null || visibilityEvent === void 0 ? void 0 : (_visibilityEvent$getC = visibilityEvent.getContent()) === null || _visibilityEvent$getC === void 0 ? void 0 : _visibilityEvent$getC.history_visibility; - return ["world_readable", "shared"].includes(visibility); -} -/** - * Tests whether an encrypted content has a ciphertext. - * Ciphertext can be a string or object depending on the content type {@link IEncryptedContent}. - * - * @param content - Encrypted content - * @returns true: has ciphertext, else false - */ -const hasCiphertext = content => { - return typeof content.ciphertext === "string" ? !!content.ciphertext.length : !!Object.keys(content.ciphertext).length; -}; - -/** The result of parsing the an `m.room_key` or `m.forwarded_room_key` to-device event */ - -/** - * @internal - */ -class OutboundSessionInfo { - /** number of times this session has been used */ - - /** when the session was created (ms since the epoch) */ - - /** devices with which we have shared the session key `userId -> {deviceId -> SharedWithData}` */ - - /** - * @param sharedHistory - whether the session can be freely shared with - * other group members, according to the room history visibility settings - */ - constructor(sessionId, sharedHistory = false) { - this.sessionId = sessionId; - this.sharedHistory = sharedHistory; - (0, _defineProperty2.default)(this, "useCount", 0); - (0, _defineProperty2.default)(this, "creationTime", void 0); - (0, _defineProperty2.default)(this, "sharedWithDevices", new _utils.MapWithDefault(() => new Map())); - (0, _defineProperty2.default)(this, "blockedDevicesNotified", new _utils.MapWithDefault(() => new Map())); - this.creationTime = new Date().getTime(); - } - - /** - * Check if it's time to rotate the session - */ - needsRotation(rotationPeriodMsgs, rotationPeriodMs) { - const sessionLifetime = new Date().getTime() - this.creationTime; - if (this.useCount >= rotationPeriodMsgs || sessionLifetime >= rotationPeriodMs) { - _logger.logger.log("Rotating megolm session after " + this.useCount + " messages, " + sessionLifetime + "ms"); - return true; - } - return false; - } - markSharedWithDevice(userId, deviceId, deviceKey, chainIndex) { - this.sharedWithDevices.getOrCreate(userId).set(deviceId, { - deviceKey, - messageIndex: chainIndex - }); - } - markNotifiedBlockedDevice(userId, deviceId) { - this.blockedDevicesNotified.getOrCreate(userId).set(deviceId, true); - } - - /** - * Determine if this session has been shared with devices which it shouldn't - * have been. - * - * @param devicesInRoom - `userId -> {deviceId -> object}` - * devices we should shared the session with. - * - * @returns true if we have shared the session with devices which aren't - * in devicesInRoom. - */ - sharedWithTooManyDevices(devicesInRoom) { - for (const [userId, devices] of this.sharedWithDevices) { - if (!devicesInRoom.has(userId)) { - _logger.logger.log("Starting new megolm session because we shared with " + userId); - return true; - } - for (const [deviceId] of devices) { - var _devicesInRoom$get; - if (!((_devicesInRoom$get = devicesInRoom.get(userId)) !== null && _devicesInRoom$get !== void 0 && _devicesInRoom$get.get(deviceId))) { - _logger.logger.log("Starting new megolm session because we shared with " + userId + ":" + deviceId); - return true; - } - } - } - return false; - } -} - -/** - * Megolm encryption implementation - * - * @param params - parameters, as per {@link EncryptionAlgorithm} - */ -class MegolmEncryption extends _base.EncryptionAlgorithm { - // the most recent attempt to set up a session. This is used to serialise - // the session setups, so that we have a race-free view of which session we - // are using, and which devices we have shared the keys with. It resolves - // with an OutboundSessionInfo (or undefined, for the first message in the - // room). - - // Map of outbound sessions by sessions ID. Used if we need a particular - // session (the session we're currently using to send is always obtained - // using setupPromise). - - constructor(params) { - var _params$config$rotati, _params$config, _params$config$rotati2, _params$config2; - super(params); - (0, _defineProperty2.default)(this, "setupPromise", Promise.resolve(null)); - (0, _defineProperty2.default)(this, "outboundSessions", {}); - (0, _defineProperty2.default)(this, "sessionRotationPeriodMsgs", void 0); - (0, _defineProperty2.default)(this, "sessionRotationPeriodMs", void 0); - (0, _defineProperty2.default)(this, "encryptionPreparation", void 0); - (0, _defineProperty2.default)(this, "roomId", void 0); - (0, _defineProperty2.default)(this, "prefixedLogger", void 0); - this.roomId = params.roomId; - this.prefixedLogger = _logger.logger.withPrefix(`[${this.roomId} encryption]`); - this.sessionRotationPeriodMsgs = (_params$config$rotati = (_params$config = params.config) === null || _params$config === void 0 ? void 0 : _params$config.rotation_period_msgs) !== null && _params$config$rotati !== void 0 ? _params$config$rotati : 100; - this.sessionRotationPeriodMs = (_params$config$rotati2 = (_params$config2 = params.config) === null || _params$config2 === void 0 ? void 0 : _params$config2.rotation_period_ms) !== null && _params$config$rotati2 !== void 0 ? _params$config$rotati2 : 7 * 24 * 3600 * 1000; - } - - /** - * @internal - * - * @param devicesInRoom - The devices in this room, indexed by user ID - * @param blocked - The devices that are blocked, indexed by user ID - * @param singleOlmCreationPhase - Only perform one round of olm - * session creation - * - * This method updates the setupPromise field of the class by chaining a new - * call on top of the existing promise, and then catching and discarding any - * errors that might happen while setting up the outbound group session. This - * is done to ensure that `setupPromise` always resolves to `null` or the - * `OutboundSessionInfo`. - * - * Using `>>=` to represent the promise chaining operation, it does the - * following: - * - * ``` - * setupPromise = previousSetupPromise >>= setup >>= discardErrors - * ``` - * - * The initial value for the `setupPromise` is a promise that resolves to - * `null`. The forceDiscardSession() resets setupPromise to this initial - * promise. - * - * @returns Promise which resolves to the - * OutboundSessionInfo when setup is complete. - */ - async ensureOutboundSession(room, devicesInRoom, blocked, singleOlmCreationPhase = false) { - // takes the previous OutboundSessionInfo, and considers whether to create - // a new one. Also shares the key with any (new) devices in the room. - // - // returns a promise which resolves once the keyshare is successful. - const setup = async oldSession => { - const sharedHistory = isRoomSharedHistory(room); - const session = await this.prepareSession(devicesInRoom, sharedHistory, oldSession); - await this.shareSession(devicesInRoom, sharedHistory, singleOlmCreationPhase, blocked, session); - return session; - }; - - // first wait for the previous share to complete - const fallible = this.setupPromise.then(setup); - - // Ensure any failures are logged for debugging and make sure that the - // promise chain remains unbroken - // - // setupPromise resolves to `null` or the `OutboundSessionInfo` whether - // or not the share succeeds - this.setupPromise = fallible.catch(e => { - this.prefixedLogger.error(`Failed to setup outbound session`, e); - return null; - }); - - // but we return a promise which only resolves if the share was successful. - return fallible; - } - async prepareSession(devicesInRoom, sharedHistory, session) { - var _session, _session2; - // history visibility changed - if (session && sharedHistory !== session.sharedHistory) { - session = null; - } - - // need to make a brand new session? - if ((_session = session) !== null && _session !== void 0 && _session.needsRotation(this.sessionRotationPeriodMsgs, this.sessionRotationPeriodMs)) { - this.prefixedLogger.log("Starting new megolm session because we need to rotate."); - session = null; - } - - // determine if we have shared with anyone we shouldn't have - if ((_session2 = session) !== null && _session2 !== void 0 && _session2.sharedWithTooManyDevices(devicesInRoom)) { - session = null; - } - if (!session) { - this.prefixedLogger.log("Starting new megolm session"); - session = await this.prepareNewSession(sharedHistory); - this.prefixedLogger.log(`Started new megolm session ${session.sessionId}`); - this.outboundSessions[session.sessionId] = session; - } - return session; - } - async shareSession(devicesInRoom, sharedHistory, singleOlmCreationPhase, blocked, session) { - // now check if we need to share with any devices - const shareMap = {}; - for (const [userId, userDevices] of devicesInRoom) { - for (const [deviceId, deviceInfo] of userDevices) { - var _session$sharedWithDe; - const key = deviceInfo.getIdentityKey(); - if (key == this.olmDevice.deviceCurve25519Key) { - // don't bother sending to ourself - continue; - } - if (!((_session$sharedWithDe = session.sharedWithDevices.get(userId)) !== null && _session$sharedWithDe !== void 0 && _session$sharedWithDe.get(deviceId))) { - shareMap[userId] = shareMap[userId] || []; - shareMap[userId].push(deviceInfo); - } - } - } - const key = this.olmDevice.getOutboundGroupSessionKey(session.sessionId); - const payload = { - type: "m.room_key", - content: { - "algorithm": olmlib.MEGOLM_ALGORITHM, - "room_id": this.roomId, - "session_id": session.sessionId, - "session_key": key.key, - "chain_index": key.chain_index, - "org.matrix.msc3061.shared_history": sharedHistory - } - }; - const [devicesWithoutSession, olmSessions] = await olmlib.getExistingOlmSessions(this.olmDevice, this.baseApis, shareMap); - await Promise.all([(async () => { - // share keys with devices that we already have a session for - const olmSessionList = Array.from(olmSessions.entries()).map(([userId, sessionsByUser]) => Array.from(sessionsByUser.entries()).map(([deviceId, session]) => `${userId}/${deviceId}: ${session.sessionId}`)).flat(1); - this.prefixedLogger.debug("Sharing keys with devices with existing Olm sessions:", olmSessionList); - await this.shareKeyWithOlmSessions(session, key, payload, olmSessions); - this.prefixedLogger.debug("Shared keys with existing Olm sessions"); - })(), (async () => { - const deviceList = Array.from(devicesWithoutSession.entries()).map(([userId, devicesByUser]) => devicesByUser.map(device => `${userId}/${device.deviceId}`)).flat(1); - this.prefixedLogger.debug("Sharing keys (start phase 1) with devices without existing Olm sessions:", deviceList); - const errorDevices = []; - - // meanwhile, establish olm sessions for devices that we don't - // already have a session for, and share keys with them. If - // we're doing two phases of olm session creation, use a - // shorter timeout when fetching one-time keys for the first - // phase. - const start = Date.now(); - const failedServers = []; - await this.shareKeyWithDevices(session, key, payload, devicesWithoutSession, errorDevices, singleOlmCreationPhase ? 10000 : 2000, failedServers); - this.prefixedLogger.debug("Shared keys (end phase 1) with devices without existing Olm sessions"); - if (!singleOlmCreationPhase && Date.now() - start < 10000) { - // perform the second phase of olm session creation if requested, - // and if the first phase didn't take too long - (async () => { - // Retry sending keys to devices that we were unable to establish - // an olm session for. This time, we use a longer timeout, but we - // do this in the background and don't block anything else while we - // do this. We only need to retry users from servers that didn't - // respond the first time. - const retryDevices = new _utils.MapWithDefault(() => []); - const failedServerMap = new Set(); - for (const server of failedServers) { - failedServerMap.add(server); - } - const failedDevices = []; - for (const { - userId, - deviceInfo - } of errorDevices) { - const userHS = userId.slice(userId.indexOf(":") + 1); - if (failedServerMap.has(userHS)) { - retryDevices.getOrCreate(userId).push(deviceInfo); - } else { - // if we aren't going to retry, then handle it - // as a failed device - failedDevices.push({ - userId, - deviceInfo - }); - } - } - const retryDeviceList = Array.from(retryDevices.entries()).map(([userId, devicesByUser]) => devicesByUser.map(device => `${userId}/${device.deviceId}`)).flat(1); - if (retryDeviceList.length > 0) { - this.prefixedLogger.debug("Sharing keys (start phase 2) with devices without existing Olm sessions:", retryDeviceList); - await this.shareKeyWithDevices(session, key, payload, retryDevices, failedDevices, 30000); - this.prefixedLogger.debug("Shared keys (end phase 2) with devices without existing Olm sessions"); - } - await this.notifyFailedOlmDevices(session, key, failedDevices); - })(); - } else { - await this.notifyFailedOlmDevices(session, key, errorDevices); - } - })(), (async () => { - this.prefixedLogger.debug(`There are ${blocked.size} blocked devices:`, Array.from(blocked.entries()).map(([userId, blockedByUser]) => Array.from(blockedByUser.entries()).map(([deviceId, _deviceInfo]) => `${userId}/${deviceId}`)).flat(1)); - - // also, notify newly blocked devices that they're blocked - const blockedMap = new _utils.MapWithDefault(() => new Map()); - let blockedCount = 0; - for (const [userId, userBlockedDevices] of blocked) { - for (const [deviceId, device] of userBlockedDevices) { - var _session$blockedDevic; - if (((_session$blockedDevic = session.blockedDevicesNotified.get(userId)) === null || _session$blockedDevic === void 0 ? void 0 : _session$blockedDevic.get(deviceId)) === undefined) { - blockedMap.getOrCreate(userId).set(deviceId, { - device - }); - blockedCount++; - } - } - } - if (blockedCount) { - this.prefixedLogger.debug(`Notifying ${blockedCount} newly blocked devices:`, Array.from(blockedMap.entries()).map(([userId, blockedByUser]) => Object.entries(blockedByUser).map(([deviceId, _deviceInfo]) => `${userId}/${deviceId}`)).flat(1)); - await this.notifyBlockedDevices(session, blockedMap); - this.prefixedLogger.debug(`Notified ${blockedCount} newly blocked devices`); - } - })()]); - } - - /** - * @internal - * - * - * @returns session - */ - async prepareNewSession(sharedHistory) { - const sessionId = this.olmDevice.createOutboundGroupSession(); - const key = this.olmDevice.getOutboundGroupSessionKey(sessionId); - await this.olmDevice.addInboundGroupSession(this.roomId, this.olmDevice.deviceCurve25519Key, [], sessionId, key.key, { - ed25519: this.olmDevice.deviceEd25519Key - }, false, { - sharedHistory - }); - - // don't wait for it to complete - this.crypto.backupManager.backupGroupSession(this.olmDevice.deviceCurve25519Key, sessionId); - return new OutboundSessionInfo(sessionId, sharedHistory); - } - - /** - * Determines what devices in devicesByUser don't have an olm session as given - * in devicemap. - * - * @internal - * - * @param deviceMap - the devices that have olm sessions, as returned by - * olmlib.ensureOlmSessionsForDevices. - * @param devicesByUser - a map of user IDs to array of deviceInfo - * @param noOlmDevices - an array to fill with devices that don't have - * olm sessions - * - * @returns an array of devices that don't have olm sessions. If - * noOlmDevices is specified, then noOlmDevices will be returned. - */ - getDevicesWithoutSessions(deviceMap, devicesByUser, noOlmDevices = []) { - for (const [userId, devicesToShareWith] of devicesByUser) { - const sessionResults = deviceMap.get(userId); - for (const deviceInfo of devicesToShareWith) { - const deviceId = deviceInfo.deviceId; - const sessionResult = sessionResults === null || sessionResults === void 0 ? void 0 : sessionResults.get(deviceId); - if (!(sessionResult !== null && sessionResult !== void 0 && sessionResult.sessionId)) { - // no session with this device, probably because there - // were no one-time keys. - - noOlmDevices.push({ - userId, - deviceInfo - }); - sessionResults === null || sessionResults === void 0 ? void 0 : sessionResults.delete(deviceId); - - // ensureOlmSessionsForUsers has already done the logging, - // so just skip it. - continue; - } - } - } - return noOlmDevices; - } - - /** - * Splits the user device map into multiple chunks to reduce the number of - * devices we encrypt to per API call. - * - * @internal - * - * @param devicesByUser - map from userid to list of devices - * - * @returns the blocked devices, split into chunks - */ - splitDevices(devicesByUser) { - const maxDevicesPerRequest = 20; - - // use an array where the slices of a content map gets stored - let currentSlice = []; - const mapSlices = [currentSlice]; - for (const [userId, userDevices] of devicesByUser) { - for (const deviceInfo of userDevices.values()) { - currentSlice.push({ - userId: userId, - deviceInfo: deviceInfo.device - }); - } - - // We do this in the per-user loop as we prefer that all messages to the - // same user end up in the same API call to make it easier for the - // server (e.g. only have to send one EDU if a remote user, etc). This - // does mean that if a user has many devices we may go over the desired - // limit, but its not a hard limit so that is fine. - if (currentSlice.length > maxDevicesPerRequest) { - // the current slice is filled up. Start inserting into the next slice - currentSlice = []; - mapSlices.push(currentSlice); - } - } - if (currentSlice.length === 0) { - mapSlices.pop(); - } - return mapSlices; - } - - /** - * @internal - * - * - * @param chainIndex - current chain index - * - * @param userDeviceMap - mapping from userId to deviceInfo - * - * @param payload - fields to include in the encrypted payload - * - * @returns Promise which resolves once the key sharing - * for the given userDeviceMap is generated and has been sent. - */ - encryptAndSendKeysToDevices(session, chainIndex, devices, payload) { - return this.crypto.encryptAndSendToDevices(devices, payload).then(() => { - // store that we successfully uploaded the keys of the current slice - for (const device of devices) { - session.markSharedWithDevice(device.userId, device.deviceInfo.deviceId, device.deviceInfo.getIdentityKey(), chainIndex); - } - }).catch(error => { - this.prefixedLogger.error("failed to encryptAndSendToDevices", error); - throw error; - }); - } - - /** - * @internal - * - * - * @param userDeviceMap - list of blocked devices to notify - * - * @param payload - fields to include in the notification payload - * - * @returns Promise which resolves once the notifications - * for the given userDeviceMap is generated and has been sent. - */ - async sendBlockedNotificationsToDevices(session, userDeviceMap, payload) { - const contentMap = new _utils.MapWithDefault(() => new Map()); - for (const val of userDeviceMap) { - const userId = val.userId; - const blockedInfo = val.deviceInfo; - const deviceInfo = blockedInfo.deviceInfo; - const deviceId = deviceInfo.deviceId; - const message = _objectSpread(_objectSpread({}, payload), {}, { - code: blockedInfo.code, - reason: blockedInfo.reason, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }); - if (message.code === "m.no_olm") { - delete message.room_id; - delete message.session_id; - } - contentMap.getOrCreate(userId).set(deviceId, message); - } - await this.baseApis.sendToDevice("m.room_key.withheld", contentMap); - - // record the fact that we notified these blocked devices - for (const [userId, userDeviceMap] of contentMap) { - for (const deviceId of userDeviceMap.keys()) { - session.markNotifiedBlockedDevice(userId, deviceId); - } - } - } - - /** - * Re-shares a megolm session key with devices if the key has already been - * sent to them. - * - * @param senderKey - The key of the originating device for the session - * @param sessionId - ID of the outbound session to share - * @param userId - ID of the user who owns the target device - * @param device - The target device - */ - async reshareKeyWithDevice(senderKey, sessionId, userId, device) { - var _obSessionInfo$shared; - const obSessionInfo = this.outboundSessions[sessionId]; - if (!obSessionInfo) { - this.prefixedLogger.debug(`megolm session ${senderKey}|${sessionId} not found: not re-sharing keys`); - return; - } - - // The chain index of the key we previously sent this device - if (!obSessionInfo.sharedWithDevices.has(userId)) { - this.prefixedLogger.debug(`megolm session ${senderKey}|${sessionId} never shared with user ${userId}`); - return; - } - const sessionSharedData = (_obSessionInfo$shared = obSessionInfo.sharedWithDevices.get(userId)) === null || _obSessionInfo$shared === void 0 ? void 0 : _obSessionInfo$shared.get(device.deviceId); - if (sessionSharedData === undefined) { - this.prefixedLogger.debug(`megolm session ${senderKey}|${sessionId} never shared with device ${userId}:${device.deviceId}`); - return; - } - if (sessionSharedData.deviceKey !== device.getIdentityKey()) { - this.prefixedLogger.warn(`Megolm session ${senderKey}|${sessionId} has been shared with device ${device.deviceId} but ` + `with identity key ${sessionSharedData.deviceKey}. Key is now ${device.getIdentityKey()}!`); - return; - } - - // get the key from the inbound session: the outbound one will already - // have been ratcheted to the next chain index. - const key = await this.olmDevice.getInboundGroupSessionKey(this.roomId, senderKey, sessionId, sessionSharedData.messageIndex); - if (!key) { - this.prefixedLogger.warn(`No inbound session key found for megolm session ${senderKey}|${sessionId}: not re-sharing keys`); - return; - } - await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, new Map([[userId, [device]]])); - const payload = { - type: "m.forwarded_room_key", - content: { - "algorithm": olmlib.MEGOLM_ALGORITHM, - "room_id": this.roomId, - "session_id": sessionId, - "session_key": key.key, - "chain_index": key.chain_index, - "sender_key": senderKey, - "sender_claimed_ed25519_key": key.sender_claimed_ed25519_key, - "forwarding_curve25519_key_chain": key.forwarding_curve25519_key_chain, - "org.matrix.msc3061.shared_history": key.shared_history || false - } - }; - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: {}, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - await olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.userId, this.deviceId, this.olmDevice, userId, device, payload); - await this.baseApis.sendToDevice("m.room.encrypted", new Map([[userId, new Map([[device.deviceId, encryptedContent]])]])); - this.prefixedLogger.debug(`Re-shared key for megolm session ${senderKey}|${sessionId} with ${userId}:${device.deviceId}`); - } - - /** - * @internal - * - * - * @param key - the session key as returned by - * OlmDevice.getOutboundGroupSessionKey - * - * @param payload - the base to-device message payload for sharing keys - * - * @param devicesByUser - map from userid to list of devices - * - * @param errorDevices - array that will be populated with the devices that we can't get an - * olm session for - * - * @param otkTimeout - The timeout in milliseconds when requesting - * one-time keys for establishing new olm sessions. - * - * @param failedServers - An array to fill with remote servers that - * failed to respond to one-time-key requests. - */ - async shareKeyWithDevices(session, key, payload, devicesByUser, errorDevices, otkTimeout, failedServers) { - const devicemap = await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, devicesByUser, false, otkTimeout, failedServers, this.prefixedLogger); - this.getDevicesWithoutSessions(devicemap, devicesByUser, errorDevices); - await this.shareKeyWithOlmSessions(session, key, payload, devicemap); - } - async shareKeyWithOlmSessions(session, key, payload, deviceMap) { - const userDeviceMaps = this.splitDevices(deviceMap); - for (let i = 0; i < userDeviceMaps.length; i++) { - const taskDetail = `megolm keys for ${session.sessionId} (slice ${i + 1}/${userDeviceMaps.length})`; - try { - this.prefixedLogger.debug(`Sharing ${taskDetail}`, userDeviceMaps[i].map(d => `${d.userId}/${d.deviceInfo.deviceId}`)); - await this.encryptAndSendKeysToDevices(session, key.chain_index, userDeviceMaps[i], payload); - this.prefixedLogger.debug(`Shared ${taskDetail}`); - } catch (e) { - this.prefixedLogger.error(`Failed to share ${taskDetail}`); - throw e; - } - } - } - - /** - * Notify devices that we weren't able to create olm sessions. - * - * - * - * @param failedDevices - the devices that we were unable to - * create olm sessions for, as returned by shareKeyWithDevices - */ - async notifyFailedOlmDevices(session, key, failedDevices) { - this.prefixedLogger.debug(`Notifying ${failedDevices.length} devices we failed to create Olm sessions`); - - // mark the devices that failed as "handled" because we don't want to try - // to claim a one-time-key for dead devices on every message. - for (const { - userId, - deviceInfo - } of failedDevices) { - const deviceId = deviceInfo.deviceId; - session.markSharedWithDevice(userId, deviceId, deviceInfo.getIdentityKey(), key.chain_index); - } - const unnotifiedFailedDevices = await this.olmDevice.filterOutNotifiedErrorDevices(failedDevices); - this.prefixedLogger.debug(`Need to notify ${unnotifiedFailedDevices.length} failed devices which haven't been notified before`); - const blockedMap = new _utils.MapWithDefault(() => new Map()); - for (const { - userId, - deviceInfo - } of unnotifiedFailedDevices) { - // we use a similar format to what - // olmlib.ensureOlmSessionsForDevices returns, so that - // we can use the same function to split - blockedMap.getOrCreate(userId).set(deviceInfo.deviceId, { - device: { - code: "m.no_olm", - reason: _OlmDevice.WITHHELD_MESSAGES["m.no_olm"], - deviceInfo - } - }); - } - - // send the notifications - await this.notifyBlockedDevices(session, blockedMap); - this.prefixedLogger.debug(`Notified ${unnotifiedFailedDevices.length} devices we failed to create Olm sessions`); - } - - /** - * Notify blocked devices that they have been blocked. - * - * - * @param devicesByUser - map from userid to device ID to blocked data - */ - async notifyBlockedDevices(session, devicesByUser) { - const payload = { - room_id: this.roomId, - session_id: session.sessionId, - algorithm: olmlib.MEGOLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key - }; - const userDeviceMaps = this.splitDevices(devicesByUser); - for (let i = 0; i < userDeviceMaps.length; i++) { - try { - await this.sendBlockedNotificationsToDevices(session, userDeviceMaps[i], payload); - this.prefixedLogger.log(`Completed blacklist notification for ${session.sessionId} ` + `(slice ${i + 1}/${userDeviceMaps.length})`); - } catch (e) { - this.prefixedLogger.log(`blacklist notification for ${session.sessionId} ` + `(slice ${i + 1}/${userDeviceMaps.length}) failed`); - throw e; - } - } - } - - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * - * @param room - the room the event is in - * @returns A function that, when called, will stop the preparation - */ - prepareToEncrypt(room) { - if (room.roomId !== this.roomId) { - throw new Error("MegolmEncryption.prepareToEncrypt called on unexpected room"); - } - if (this.encryptionPreparation != null) { - // We're already preparing something, so don't do anything else. - const elapsedTime = Date.now() - this.encryptionPreparation.startTime; - this.prefixedLogger.debug(`Already started preparing to encrypt for this room ${elapsedTime}ms ago, skipping`); - return this.encryptionPreparation.cancel; - } - this.prefixedLogger.debug("Preparing to encrypt events"); - let cancelled = false; - const isCancelled = () => cancelled; - this.encryptionPreparation = { - startTime: Date.now(), - promise: (async () => { - try { - // Attempt to enumerate the devices in room, and gracefully - // handle cancellation if it occurs. - const getDevicesResult = await this.getDevicesInRoom(room, false, isCancelled); - if (getDevicesResult === null) return; - const [devicesInRoom, blocked] = getDevicesResult; - if (this.crypto.globalErrorOnUnknownDevices) { - // Drop unknown devices for now. When the message gets sent, we'll - // throw an error, but we'll still be prepared to send to the known - // devices. - this.removeUnknownDevices(devicesInRoom); - } - this.prefixedLogger.debug("Ensuring outbound megolm session"); - await this.ensureOutboundSession(room, devicesInRoom, blocked, true); - this.prefixedLogger.debug("Ready to encrypt events"); - } catch (e) { - this.prefixedLogger.error("Failed to prepare to encrypt events", e); - } finally { - delete this.encryptionPreparation; - } - })(), - cancel: () => { - // The caller has indicated that the process should be cancelled, - // so tell the promise that we'd like to halt, and reset the preparation state. - cancelled = true; - delete this.encryptionPreparation; - } - }; - return this.encryptionPreparation.cancel; - } - - /** - * @param content - plaintext event content - * - * @returns Promise which resolves to the new event body - */ - async encryptMessage(room, eventType, content) { - this.prefixedLogger.log("Starting to encrypt event"); - if (this.encryptionPreparation != null) { - // If we started sending keys, wait for it to be done. - // FIXME: check if we need to cancel - // (https://github.com/matrix-org/matrix-js-sdk/issues/1255) - try { - await this.encryptionPreparation.promise; - } catch (e) { - // ignore any errors -- if the preparation failed, we'll just - // restart everything here - } - } - - /** - * When using in-room messages and the room has encryption enabled, - * clients should ensure that encryption does not hinder the verification. - */ - const forceDistributeToUnverified = this.isVerificationEvent(eventType, content); - const [devicesInRoom, blocked] = await this.getDevicesInRoom(room, forceDistributeToUnverified); - - // check if any of these devices are not yet known to the user. - // if so, warn the user so they can verify or ignore. - if (this.crypto.globalErrorOnUnknownDevices) { - this.checkForUnknownDevices(devicesInRoom); - } - const session = await this.ensureOutboundSession(room, devicesInRoom, blocked); - const payloadJson = { - room_id: this.roomId, - type: eventType, - content: content - }; - const ciphertext = this.olmDevice.encryptGroupMessage(session.sessionId, JSON.stringify(payloadJson)); - const encryptedContent = { - algorithm: olmlib.MEGOLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: ciphertext, - session_id: session.sessionId, - // Include our device ID so that recipients can send us a - // m.new_device message if they don't have our session key. - // XXX: Do we still need this now that m.new_device messages - // no longer exist since #483? - device_id: this.deviceId - }; - session.useCount++; - return encryptedContent; - } - isVerificationEvent(eventType, content) { - switch (eventType) { - case _event.EventType.KeyVerificationCancel: - case _event.EventType.KeyVerificationDone: - case _event.EventType.KeyVerificationMac: - case _event.EventType.KeyVerificationStart: - case _event.EventType.KeyVerificationKey: - case _event.EventType.KeyVerificationReady: - case _event.EventType.KeyVerificationAccept: - { - return true; - } - case _event.EventType.RoomMessage: - { - return content["msgtype"] === _event.MsgType.KeyVerificationRequest; - } - default: - { - return false; - } - } - } - - /** - * Forces the current outbound group session to be discarded such - * that another one will be created next time an event is sent. - * - * This should not normally be necessary. - */ - forceDiscardSession() { - this.setupPromise = this.setupPromise.then(() => null); - } - - /** - * Checks the devices we're about to send to and see if any are entirely - * unknown to the user. If so, warn the user, and mark them as known to - * give the user a chance to go verify them before re-sending this message. - * - * @param devicesInRoom - `userId -> {deviceId -> object}` - * devices we should shared the session with. - */ - checkForUnknownDevices(devicesInRoom) { - const unknownDevices = new _utils.MapWithDefault(() => new Map()); - for (const [userId, userDevices] of devicesInRoom) { - for (const [deviceId, device] of userDevices) { - if (device.isUnverified() && !device.isKnown()) { - unknownDevices.getOrCreate(userId).set(deviceId, device); - } - } - } - if (unknownDevices.size) { - // it'd be kind to pass unknownDevices up to the user in this error - throw new _base.UnknownDeviceError("This room contains unknown devices which have not been verified. " + "We strongly recommend you verify them before continuing.", unknownDevices); - } - } - - /** - * Remove unknown devices from a set of devices. The devicesInRoom parameter - * will be modified. - * - * @param devicesInRoom - `userId -> {deviceId -> object}` - * devices we should shared the session with. - */ - removeUnknownDevices(devicesInRoom) { - for (const [userId, userDevices] of devicesInRoom) { - for (const [deviceId, device] of userDevices) { - if (device.isUnverified() && !device.isKnown()) { - userDevices.delete(deviceId); - } - } - if (userDevices.size === 0) { - devicesInRoom.delete(userId); - } - } - } - - /** - * Get the list of unblocked devices for all users in the room - * - * @param forceDistributeToUnverified - if set to true will include the unverified devices - * even if setting is set to block them (useful for verification) - * @param isCancelled - will cause the procedure to abort early if and when it starts - * returning `true`. If omitted, cancellation won't happen. - * - * @returns Promise which resolves to `null`, or an array whose - * first element is a {@link DeviceInfoMap} indicating - * the devices that messages should be encrypted to, and whose second - * element is a map from userId to deviceId to data indicating the devices - * that are in the room but that have been blocked. - * If `isCancelled` is provided and returns `true` while processing, `null` - * will be returned. - * If `isCancelled` is not provided, the Promise will never resolve to `null`. - */ - - async getDevicesInRoom(room, forceDistributeToUnverified = false, isCancelled) { - const members = await room.getEncryptionTargetMembers(); - this.prefixedLogger.debug(`Encrypting for users (shouldEncryptForInvitedMembers: ${room.shouldEncryptForInvitedMembers()}):`, members.map(u => `${u.userId} (${u.membership})`)); - const roomMembers = members.map(function (u) { - return u.userId; - }); - - // The global value is treated as a default for when rooms don't specify a value. - let isBlacklisting = this.crypto.globalBlacklistUnverifiedDevices; - const isRoomBlacklisting = room.getBlacklistUnverifiedDevices(); - if (typeof isRoomBlacklisting === "boolean") { - isBlacklisting = isRoomBlacklisting; - } - - // We are happy to use a cached version here: we assume that if we already - // have a list of the user's devices, then we already share an e2e room - // with them, which means that they will have announced any new devices via - // device_lists in their /sync response. This cache should then be maintained - // using all the device_lists changes and left fields. - // See https://github.com/vector-im/element-web/issues/2305 for details. - const devices = await this.crypto.downloadKeys(roomMembers, false); - if ((isCancelled === null || isCancelled === void 0 ? void 0 : isCancelled()) === true) { - return null; - } - const blocked = new _utils.MapWithDefault(() => new Map()); - // remove any blocked devices - for (const [userId, userDevices] of devices) { - for (const [deviceId, userDevice] of userDevices) { - // Yield prior to checking each device so that we don't block - // updating/rendering for too long. - // See https://github.com/vector-im/element-web/issues/21612 - if (isCancelled !== undefined) await (0, _utils.immediate)(); - if ((isCancelled === null || isCancelled === void 0 ? void 0 : isCancelled()) === true) return null; - const deviceTrust = this.crypto.checkDeviceTrust(userId, deviceId); - if (userDevice.isBlocked() || !deviceTrust.isVerified() && isBlacklisting && !forceDistributeToUnverified) { - const blockedDevices = blocked.getOrCreate(userId); - const isBlocked = userDevice.isBlocked(); - blockedDevices.set(deviceId, { - code: isBlocked ? "m.blacklisted" : "m.unverified", - reason: _OlmDevice.WITHHELD_MESSAGES[isBlocked ? "m.blacklisted" : "m.unverified"], - deviceInfo: userDevice - }); - userDevices.delete(deviceId); - } - } - } - return [devices, blocked]; - } -} - -/** - * Megolm decryption implementation - * - * @param params - parameters, as per {@link DecryptionAlgorithm} - */ -exports.MegolmEncryption = MegolmEncryption; -class MegolmDecryption extends _base.DecryptionAlgorithm { - // events which we couldn't decrypt due to unknown sessions / - // indexes, or which we could only decrypt with untrusted keys: - // map from senderKey|sessionId to Set of MatrixEvents - - // this gets stubbed out by the unit tests. - - constructor(params) { - super(params); - (0, _defineProperty2.default)(this, "pendingEvents", new Map()); - (0, _defineProperty2.default)(this, "olmlib", olmlib); - (0, _defineProperty2.default)(this, "roomId", void 0); - (0, _defineProperty2.default)(this, "prefixedLogger", void 0); - this.roomId = params.roomId; - this.prefixedLogger = _logger.logger.withPrefix(`[${this.roomId} decryption]`); - } - - /** - * returns a promise which resolves to a - * {@link EventDecryptionResult} once we have finished - * decrypting, or rejects with an `algorithms.DecryptionError` if there is a - * problem decrypting the event. - */ - async decryptEvent(event) { - const content = event.getWireContent(); - if (!content.sender_key || !content.session_id || !content.ciphertext) { - throw new _base.DecryptionError("MEGOLM_MISSING_FIELDS", "Missing fields in input"); - } - - // we add the event to the pending list *before* we start decryption. - // - // then, if the key turns up while decryption is in progress (and - // decryption fails), we will schedule a retry. - // (fixes https://github.com/vector-im/element-web/issues/5001) - this.addEventToPendingList(event); - let res; - try { - res = await this.olmDevice.decryptGroupMessage(event.getRoomId(), content.sender_key, content.session_id, content.ciphertext, event.getId(), event.getTs()); - } catch (e) { - if (e.name === "DecryptionError") { - // re-throw decryption errors as-is - throw e; - } - let errorCode = "OLM_DECRYPT_GROUP_MESSAGE_ERROR"; - if ((e === null || e === void 0 ? void 0 : e.message) === "OLM.UNKNOWN_MESSAGE_INDEX") { - this.requestKeysForEvent(event); - errorCode = "OLM_UNKNOWN_MESSAGE_INDEX"; - } - throw new _base.DecryptionError(errorCode, e instanceof Error ? e.message : "Unknown Error: Error is undefined", { - session: content.sender_key + "|" + content.session_id - }); - } - if (res === null) { - // We've got a message for a session we don't have. - // try and get the missing key from the backup first - this.crypto.backupManager.queryKeyBackupRateLimited(event.getRoomId(), content.session_id).catch(() => {}); - - // (XXX: We might actually have received this key since we started - // decrypting, in which case we'll have scheduled a retry, and this - // request will be redundant. We could probably check to see if the - // event is still in the pending list; if not, a retry will have been - // scheduled, so we needn't send out the request here.) - this.requestKeysForEvent(event); - - // See if there was a problem with the olm session at the time the - // event was sent. Use a fuzz factor of 2 minutes. - const problem = await this.olmDevice.sessionMayHaveProblems(content.sender_key, event.getTs() - 120000); - if (problem) { - this.prefixedLogger.info(`When handling UISI from ${event.getSender()} (sender key ${content.sender_key}): ` + `recent session problem with that sender:`, problem); - let problemDescription = PROBLEM_DESCRIPTIONS[problem.type] || PROBLEM_DESCRIPTIONS.unknown; - if (problem.fixed) { - problemDescription += " Trying to create a new secure channel and re-requesting the keys."; - } - throw new _base.DecryptionError("MEGOLM_UNKNOWN_INBOUND_SESSION_ID", problemDescription, { - session: content.sender_key + "|" + content.session_id - }); - } - throw new _base.DecryptionError("MEGOLM_UNKNOWN_INBOUND_SESSION_ID", "The sender's device has not sent us the keys for this message.", { - session: content.sender_key + "|" + content.session_id - }); - } - - // Success. We can remove the event from the pending list, if - // that hasn't already happened. However, if the event was - // decrypted with an untrusted key, leave it on the pending - // list so it will be retried if we find a trusted key later. - if (!res.untrusted) { - this.removeEventFromPendingList(event); - } - const payload = JSON.parse(res.result); - - // belt-and-braces check that the room id matches that indicated by the HS - // (this is somewhat redundant, since the megolm session is scoped to the - // room, so neither the sender nor a MITM can lie about the room_id). - if (payload.room_id !== event.getRoomId()) { - throw new _base.DecryptionError("MEGOLM_BAD_ROOM", "Message intended for room " + payload.room_id); - } - return { - clearEvent: payload, - senderCurve25519Key: res.senderKey, - claimedEd25519Key: res.keysClaimed.ed25519, - forwardingCurve25519KeyChain: res.forwardingCurve25519KeyChain, - untrusted: res.untrusted - }; - } - requestKeysForEvent(event) { - const wireContent = event.getWireContent(); - const recipients = event.getKeyRequestRecipients(this.userId); - this.crypto.requestRoomKey({ - room_id: event.getRoomId(), - algorithm: wireContent.algorithm, - sender_key: wireContent.sender_key, - session_id: wireContent.session_id - }, recipients); - } - - /** - * Add an event to the list of those awaiting their session keys. - * - * @internal - * - */ - addEventToPendingList(event) { - var _senderPendingEvents$; - const content = event.getWireContent(); - const senderKey = content.sender_key; - const sessionId = content.session_id; - if (!this.pendingEvents.has(senderKey)) { - this.pendingEvents.set(senderKey, new Map()); - } - const senderPendingEvents = this.pendingEvents.get(senderKey); - if (!senderPendingEvents.has(sessionId)) { - senderPendingEvents.set(sessionId, new Set()); - } - (_senderPendingEvents$ = senderPendingEvents.get(sessionId)) === null || _senderPendingEvents$ === void 0 ? void 0 : _senderPendingEvents$.add(event); - } - - /** - * Remove an event from the list of those awaiting their session keys. - * - * @internal - * - */ - removeEventFromPendingList(event) { - const content = event.getWireContent(); - const senderKey = content.sender_key; - const sessionId = content.session_id; - const senderPendingEvents = this.pendingEvents.get(senderKey); - const pendingEvents = senderPendingEvents === null || senderPendingEvents === void 0 ? void 0 : senderPendingEvents.get(sessionId); - if (!pendingEvents) { - return; - } - pendingEvents.delete(event); - if (pendingEvents.size === 0) { - senderPendingEvents.delete(sessionId); - } - if (senderPendingEvents.size === 0) { - this.pendingEvents.delete(senderKey); - } - } - - /** - * Parse a RoomKey out of an `m.room_key` event. - * - * @param event - the event containing the room key. - * - * @returns The `RoomKey` if it could be successfully parsed out of the - * event. - * - * @internal - * - */ - roomKeyFromEvent(event) { - const senderKey = event.getSenderKey(); - const content = event.getContent(); - const extraSessionData = {}; - if (!content.room_id || !content.session_key || !content.session_id || !content.algorithm) { - this.prefixedLogger.error("key event is missing fields"); - return; - } - if (!olmlib.isOlmEncrypted(event)) { - this.prefixedLogger.error("key event not properly encrypted"); - return; - } - if (content["org.matrix.msc3061.shared_history"]) { - extraSessionData.sharedHistory = true; - } - const roomKey = { - senderKey: senderKey, - sessionId: content.session_id, - sessionKey: content.session_key, - extraSessionData, - exportFormat: false, - roomId: content.room_id, - algorithm: content.algorithm, - forwardingKeyChain: [], - keysClaimed: event.getKeysClaimed() - }; - return roomKey; - } - - /** - * Parse a RoomKey out of an `m.forwarded_room_key` event. - * - * @param event - the event containing the forwarded room key. - * - * @returns The `RoomKey` if it could be successfully parsed out of the - * event. - * - * @internal - * - */ - forwardedRoomKeyFromEvent(event) { - // the properties in m.forwarded_room_key are a superset of those in m.room_key, so - // start by parsing the m.room_key fields. - const roomKey = this.roomKeyFromEvent(event); - if (!roomKey) { - return; - } - const senderKey = event.getSenderKey(); - const content = event.getContent(); - const senderKeyUser = this.baseApis.crypto.deviceList.getUserByIdentityKey(olmlib.OLM_ALGORITHM, senderKey); - - // We received this to-device event from event.getSenderKey(), but the original - // creator of the room key is claimed in the content. - const claimedCurve25519Key = content.sender_key; - const claimedEd25519Key = content.sender_claimed_ed25519_key; - let forwardingKeyChain = Array.isArray(content.forwarding_curve25519_key_chain) ? content.forwarding_curve25519_key_chain : []; - - // copy content before we modify it - forwardingKeyChain = forwardingKeyChain.slice(); - forwardingKeyChain.push(senderKey); - - // Check if we have all the fields we need. - if (senderKeyUser !== event.getSender()) { - this.prefixedLogger.error("sending device does not belong to the user it claims to be from"); - return; - } - if (!claimedCurve25519Key) { - this.prefixedLogger.error("forwarded_room_key event is missing sender_key field"); - return; - } - if (!claimedEd25519Key) { - this.prefixedLogger.error(`forwarded_room_key_event is missing sender_claimed_ed25519_key field`); - return; - } - const keysClaimed = { - ed25519: claimedEd25519Key - }; - - // FIXME: We're reusing the same field to track both: - // - // 1. The Olm identity we've received this room key from. - // 2. The Olm identity deduced (in the trusted case) or claiming (in the - // untrusted case) to be the original creator of this room key. - // - // We now overwrite the value tracking usage 1 with the value tracking usage 2. - roomKey.senderKey = claimedCurve25519Key; - // Replace our keysClaimed as well. - roomKey.keysClaimed = keysClaimed; - roomKey.exportFormat = true; - roomKey.forwardingKeyChain = forwardingKeyChain; - // forwarded keys are always untrusted - roomKey.extraSessionData.untrusted = true; - return roomKey; - } - - /** - * Determine if we should accept the forwarded room key that was found in the given - * event. - * - * @param event - An `m.forwarded_room_key` event. - * @param roomKey - The room key that was found in the event. - * - * @returns promise that will resolve to a boolean telling us if it's ok to - * accept the given forwarded room key. - * - * @internal - * - */ - async shouldAcceptForwardedKey(event, roomKey) { - var _this$crypto$deviceLi; - const senderKey = event.getSenderKey(); - const sendingDevice = (_this$crypto$deviceLi = this.crypto.deviceList.getDeviceByIdentityKey(olmlib.OLM_ALGORITHM, senderKey)) !== null && _this$crypto$deviceLi !== void 0 ? _this$crypto$deviceLi : undefined; - const deviceTrust = this.crypto.checkDeviceInfoTrust(event.getSender(), sendingDevice); - - // Using the plaintext sender here is fine since we checked that the - // sender matches to the user id in the device keys when this event was - // originally decrypted. This can obviously only happen if the device - // keys have been downloaded, but if they haven't the - // `deviceTrust.isVerified()` flag would be false as well. - // - // It would still be far nicer if the `sendingDevice` had a user ID - // attached to it that went through signature checks. - const fromUs = event.getSender() === this.baseApis.getUserId(); - const keyFromOurVerifiedDevice = deviceTrust.isVerified() && fromUs; - const weRequested = await this.wasRoomKeyRequested(event, roomKey); - const fromInviter = this.wasRoomKeyForwardedByInviter(event, roomKey); - const sharedAsHistory = this.wasRoomKeyForwardedAsHistory(roomKey); - return weRequested && keyFromOurVerifiedDevice || fromInviter && sharedAsHistory; - } - - /** - * Did we ever request the given room key from the event sender and its - * accompanying device. - * - * @param event - An `m.forwarded_room_key` event. - * @param roomKey - The room key that was found in the event. - * - * @internal - * - */ - async wasRoomKeyRequested(event, roomKey) { - // We send the `m.room_key_request` out as a wildcard to-device request, - // otherwise we would have to duplicate the same content for each - // device. This is why we need to pass in "*" as the device id here. - const outgoingRequests = await this.crypto.cryptoStore.getOutgoingRoomKeyRequestsByTarget(event.getSender(), "*", [_OutgoingRoomKeyRequestManager.RoomKeyRequestState.Sent]); - return outgoingRequests.some(req => req.requestBody.room_id === roomKey.roomId && req.requestBody.session_id === roomKey.sessionId); - } - wasRoomKeyForwardedByInviter(event, roomKey) { - var _room$getMember, _memberEvent$getUnsig, _memberEvent$getPrevC; - // TODO: This is supposed to have a time limit. We should only accept - // such keys if we happen to receive them for a recently joined room. - const room = this.baseApis.getRoom(roomKey.roomId); - const senderKey = event.getSenderKey(); - if (!senderKey) { - return false; - } - const senderKeyUser = this.crypto.deviceList.getUserByIdentityKey(olmlib.OLM_ALGORITHM, senderKey); - if (!senderKeyUser) { - return false; - } - const memberEvent = room === null || room === void 0 ? void 0 : (_room$getMember = room.getMember(this.userId)) === null || _room$getMember === void 0 ? void 0 : _room$getMember.events.member; - const fromInviter = (memberEvent === null || memberEvent === void 0 ? void 0 : memberEvent.getSender()) === senderKeyUser || (memberEvent === null || memberEvent === void 0 ? void 0 : (_memberEvent$getUnsig = memberEvent.getUnsigned()) === null || _memberEvent$getUnsig === void 0 ? void 0 : _memberEvent$getUnsig.prev_sender) === senderKeyUser && (memberEvent === null || memberEvent === void 0 ? void 0 : (_memberEvent$getPrevC = memberEvent.getPrevContent()) === null || _memberEvent$getPrevC === void 0 ? void 0 : _memberEvent$getPrevC.membership) === "invite"; - if (room && fromInviter) { - return true; - } else { - return false; - } - } - wasRoomKeyForwardedAsHistory(roomKey) { - const room = this.baseApis.getRoom(roomKey.roomId); - - // If the key is not for a known room, then something fishy is going on, - // so we reject the key out of caution. In practice, this is a bit moot - // because we'll only accept shared_history forwarded by the inviter, and - // we won't know who was the inviter for an unknown room, so we'll reject - // it anyway. - if (room && roomKey.extraSessionData.sharedHistory) { - return true; - } else { - return false; - } - } - - /** - * Check if a forwarded room key should be parked. - * - * A forwarded room key should be parked if it's a key for a room we're not - * in. We park the forwarded room key in case *this sender* invites us to - * that room later. - */ - shouldParkForwardedKey(roomKey) { - const room = this.baseApis.getRoom(roomKey.roomId); - if (!room && roomKey.extraSessionData.sharedHistory) { - return true; - } else { - return false; - } - } - - /** - * Park the given room key to our store. - * - * @param event - An `m.forwarded_room_key` event. - * @param roomKey - The room key that was found in the event. - * - * @internal - * - */ - async parkForwardedKey(event, roomKey) { - const parkedData = { - senderId: event.getSender(), - senderKey: roomKey.senderKey, - sessionId: roomKey.sessionId, - sessionKey: roomKey.sessionKey, - keysClaimed: roomKey.keysClaimed, - forwardingCurve25519KeyChain: roomKey.forwardingKeyChain - }; - await this.crypto.cryptoStore.doTxn("readwrite", ["parked_shared_history"], txn => this.crypto.cryptoStore.addParkedSharedHistory(roomKey.roomId, parkedData, txn), _logger.logger.withPrefix("[addParkedSharedHistory]")); - } - - /** - * Add the given room key to our store. - * - * @param roomKey - The room key that should be added to the store. - * - * @internal - * - */ - async addRoomKey(roomKey) { - try { - await this.olmDevice.addInboundGroupSession(roomKey.roomId, roomKey.senderKey, roomKey.forwardingKeyChain, roomKey.sessionId, roomKey.sessionKey, roomKey.keysClaimed, roomKey.exportFormat, roomKey.extraSessionData); - - // have another go at decrypting events sent with this session. - if (await this.retryDecryption(roomKey.senderKey, roomKey.sessionId, !roomKey.extraSessionData.untrusted)) { - // cancel any outstanding room key requests for this session. - // Only do this if we managed to decrypt every message in the - // session, because if we didn't, we leave the other key - // requests in the hopes that someone sends us a key that - // includes an earlier index. - this.crypto.cancelRoomKeyRequest({ - algorithm: roomKey.algorithm, - room_id: roomKey.roomId, - session_id: roomKey.sessionId, - sender_key: roomKey.senderKey - }); - } - - // don't wait for the keys to be backed up for the server - await this.crypto.backupManager.backupGroupSession(roomKey.senderKey, roomKey.sessionId); - } catch (e) { - this.prefixedLogger.error(`Error handling m.room_key_event: ${e}`); - } - } - - /** - * Handle room keys that have been forwarded to us as an - * `m.forwarded_room_key` event. - * - * Forwarded room keys need special handling since we have no way of knowing - * who the original creator of the room key was. This naturally means that - * forwarded room keys are always untrusted and should only be accepted in - * some cases. - * - * @param event - An `m.forwarded_room_key` event. - * - * @internal - * - */ - async onForwardedRoomKey(event) { - const roomKey = this.forwardedRoomKeyFromEvent(event); - if (!roomKey) { - return; - } - if (await this.shouldAcceptForwardedKey(event, roomKey)) { - await this.addRoomKey(roomKey); - } else if (this.shouldParkForwardedKey(roomKey)) { - await this.parkForwardedKey(event, roomKey); - } - } - async onRoomKeyEvent(event) { - if (event.getType() == "m.forwarded_room_key") { - await this.onForwardedRoomKey(event); - } else { - const roomKey = this.roomKeyFromEvent(event); - if (!roomKey) { - return; - } - await this.addRoomKey(roomKey); - } - } - - /** - * @param event - key event - */ - async onRoomKeyWithheldEvent(event) { - const content = event.getContent(); - const senderKey = content.sender_key; - if (content.code === "m.no_olm") { - await this.onNoOlmWithheldEvent(event); - } else if (content.code === "m.unavailable") { - // this simply means that the other device didn't have the key, which isn't very useful information. Don't - // record it in the storage - } else { - await this.olmDevice.addInboundGroupSessionWithheld(content.room_id, senderKey, content.session_id, content.code, content.reason); - } - - // Having recorded the problem, retry decryption on any affected messages. - // It's unlikely we'll be able to decrypt sucessfully now, but this will - // update the error message. - // - if (content.session_id) { - await this.retryDecryption(senderKey, content.session_id); - } else { - // no_olm messages aren't specific to a given megolm session, so - // we trigger retrying decryption for all the messages from the sender's - // key, so that we can update the error message to indicate the olm - // session problem. - await this.retryDecryptionFromSender(senderKey); - } - } - async onNoOlmWithheldEvent(event) { - const content = event.getContent(); - const senderKey = content.sender_key; - const sender = event.getSender(); - this.prefixedLogger.warn(`${sender}:${senderKey} was unable to establish an olm session with us`); - // if the sender says that they haven't been able to establish an olm - // session, let's proactively establish one - - if (await this.olmDevice.getSessionIdForDevice(senderKey)) { - // a session has already been established, so we don't need to - // create a new one. - this.prefixedLogger.debug("New session already created. Not creating a new one."); - await this.olmDevice.recordSessionProblem(senderKey, "no_olm", true); - return; - } - let device = this.crypto.deviceList.getDeviceByIdentityKey(content.algorithm, senderKey); - if (!device) { - // if we don't know about the device, fetch the user's devices again - // and retry before giving up - await this.crypto.downloadKeys([sender], false); - device = this.crypto.deviceList.getDeviceByIdentityKey(content.algorithm, senderKey); - if (!device) { - this.prefixedLogger.info("Couldn't find device for identity key " + senderKey + ": not establishing session"); - await this.olmDevice.recordSessionProblem(senderKey, "no_olm", false); - return; - } - } - - // XXX: switch this to use encryptAndSendToDevices() rather than duplicating it? - - await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, new Map([[sender, [device]]]), false); - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: {}, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - await olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.userId, undefined, this.olmDevice, sender, device, { - type: "m.dummy" - }); - await this.olmDevice.recordSessionProblem(senderKey, "no_olm", true); - await this.baseApis.sendToDevice("m.room.encrypted", new Map([[sender, new Map([[device.deviceId, encryptedContent]])]])); - } - hasKeysForKeyRequest(keyRequest) { - const body = keyRequest.requestBody; - return this.olmDevice.hasInboundSessionKeys(body.room_id, body.sender_key, body.session_id - // TODO: ratchet index - ); - } - - shareKeysWithDevice(keyRequest) { - const userId = keyRequest.userId; - const deviceId = keyRequest.deviceId; - const deviceInfo = this.crypto.getStoredDevice(userId, deviceId); - const body = keyRequest.requestBody; - - // XXX: switch this to use encryptAndSendToDevices()? - - this.olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, new Map([[userId, [deviceInfo]]])).then(devicemap => { - var _devicemap$get; - const olmSessionResult = (_devicemap$get = devicemap.get(userId)) === null || _devicemap$get === void 0 ? void 0 : _devicemap$get.get(deviceId); - if (!(olmSessionResult !== null && olmSessionResult !== void 0 && olmSessionResult.sessionId)) { - // no session with this device, probably because there - // were no one-time keys. - // - // ensureOlmSessionsForUsers has already done the logging, - // so just skip it. - return null; - } - this.prefixedLogger.log("sharing keys for session " + body.sender_key + "|" + body.session_id + " with device " + userId + ":" + deviceId); - return this.buildKeyForwardingMessage(body.room_id, body.sender_key, body.session_id); - }).then(payload => { - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: {}, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - return this.olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.userId, undefined, this.olmDevice, userId, deviceInfo, payload).then(() => { - // TODO: retries - return this.baseApis.sendToDevice("m.room.encrypted", new Map([[userId, new Map([[deviceId, encryptedContent]])]])); - }); - }); - } - async buildKeyForwardingMessage(roomId, senderKey, sessionId) { - const key = await this.olmDevice.getInboundGroupSessionKey(roomId, senderKey, sessionId); - return { - type: "m.forwarded_room_key", - content: { - "algorithm": olmlib.MEGOLM_ALGORITHM, - "room_id": roomId, - "sender_key": senderKey, - "sender_claimed_ed25519_key": key.sender_claimed_ed25519_key, - "session_id": sessionId, - "session_key": key.key, - "chain_index": key.chain_index, - "forwarding_curve25519_key_chain": key.forwarding_curve25519_key_chain, - "org.matrix.msc3061.shared_history": key.shared_history || false - } - }; - } - - /** - * @param untrusted - whether the key should be considered as untrusted - * @param source - where the key came from - */ - importRoomKey(session, { - untrusted, - source - } = {}) { - const extraSessionData = {}; - if (untrusted || session.untrusted) { - extraSessionData.untrusted = true; - } - if (session["org.matrix.msc3061.shared_history"]) { - extraSessionData.sharedHistory = true; - } - return this.olmDevice.addInboundGroupSession(session.room_id, session.sender_key, session.forwarding_curve25519_key_chain, session.session_id, session.session_key, session.sender_claimed_keys, true, extraSessionData).then(() => { - if (source !== "backup") { - // don't wait for it to complete - this.crypto.backupManager.backupGroupSession(session.sender_key, session.session_id).catch(e => { - // This throws if the upload failed, but this is fine - // since it will have written it to the db and will retry. - this.prefixedLogger.log("Failed to back up megolm session", e); - }); - } - // have another go at decrypting events sent with this session. - this.retryDecryption(session.sender_key, session.session_id, !extraSessionData.untrusted); - }); - } - - /** - * Have another go at decrypting events after we receive a key. Resolves once - * decryption has been re-attempted on all events. - * - * @internal - * @param forceRedecryptIfUntrusted - whether messages that were already - * successfully decrypted using untrusted keys should be re-decrypted - * - * @returns whether all messages were successfully - * decrypted with trusted keys - */ - async retryDecryption(senderKey, sessionId, forceRedecryptIfUntrusted) { - var _this$pendingEvents$g; - const senderPendingEvents = this.pendingEvents.get(senderKey); - if (!senderPendingEvents) { - return true; - } - const pending = senderPendingEvents.get(sessionId); - if (!pending) { - return true; - } - const pendingList = [...pending]; - this.prefixedLogger.debug("Retrying decryption on events:", pendingList.map(e => `${e.getId()}`)); - await Promise.all(pendingList.map(async ev => { - try { - await ev.attemptDecryption(this.crypto, { - isRetry: true, - forceRedecryptIfUntrusted - }); - } catch (e) { - // don't die if something goes wrong - } - })); - - // If decrypted successfully with trusted keys, they'll have - // been removed from pendingEvents - return !((_this$pendingEvents$g = this.pendingEvents.get(senderKey)) !== null && _this$pendingEvents$g !== void 0 && _this$pendingEvents$g.has(sessionId)); - } - async retryDecryptionFromSender(senderKey) { - const senderPendingEvents = this.pendingEvents.get(senderKey); - if (!senderPendingEvents) { - return true; - } - this.pendingEvents.delete(senderKey); - await Promise.all([...senderPendingEvents].map(async ([_sessionId, pending]) => { - await Promise.all([...pending].map(async ev => { - try { - await ev.attemptDecryption(this.crypto); - } catch (e) { - // don't die if something goes wrong - } - })); - })); - return !this.pendingEvents.has(senderKey); - } - async sendSharedHistoryInboundSessions(devicesByUser) { - await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, devicesByUser); - const sharedHistorySessions = await this.olmDevice.getSharedHistoryInboundGroupSessions(this.roomId); - this.prefixedLogger.log(`Sharing history in with users ${Array.from(devicesByUser.keys())}`, sharedHistorySessions.map(([senderKey, sessionId]) => `${senderKey}|${sessionId}`)); - for (const [senderKey, sessionId] of sharedHistorySessions) { - const payload = await this.buildKeyForwardingMessage(this.roomId, senderKey, sessionId); - - // FIXME: use encryptAndSendToDevices() rather than duplicating it here. - const promises = []; - const contentMap = new Map(); - for (const [userId, devices] of devicesByUser) { - const deviceMessages = new Map(); - contentMap.set(userId, deviceMessages); - for (const deviceInfo of devices) { - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: {}, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - deviceMessages.set(deviceInfo.deviceId, encryptedContent); - promises.push(olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.userId, undefined, this.olmDevice, userId, deviceInfo, payload)); - } - } - await Promise.all(promises); - - // prune out any devices that encryptMessageForDevice could not encrypt for, - // in which case it will have just not added anything to the ciphertext object. - // There's no point sending messages to devices if we couldn't encrypt to them, - // since that's effectively a blank message. - for (const [userId, deviceMessages] of contentMap) { - for (const [deviceId, content] of deviceMessages) { - if (!hasCiphertext(content)) { - this.prefixedLogger.log("No ciphertext for device " + userId + ":" + deviceId + ": pruning"); - deviceMessages.delete(deviceId); - } - } - // No devices left for that user? Strip that too. - if (deviceMessages.size === 0) { - this.prefixedLogger.log("Pruned all devices for user " + userId); - contentMap.delete(userId); - } - } - - // Is there anything left? - if (contentMap.size === 0) { - this.prefixedLogger.log("No users left to send to: aborting"); - return; - } - await this.baseApis.sendToDevice("m.room.encrypted", contentMap); - } - } -} -exports.MegolmDecryption = MegolmDecryption; -const PROBLEM_DESCRIPTIONS = { - no_olm: "The sender was unable to establish a secure channel.", - unknown: "The secure channel with the sender was corrupted." -}; -(0, _base.registerAlgorithm)(olmlib.MEGOLM_ALGORITHM, MegolmEncryption, MegolmDecryption); -//# sourceMappingURL=megolm.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js.map deleted file mode 100644 index 27edd8b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/megolm.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"megolm.js","names":["_uuid","require","_logger","olmlib","_interopRequireWildcard","_base","_OlmDevice","_event","_OutgoingRoomKeyRequestManager","_utils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","isRoomSharedHistory","room","_room$currentState","_visibilityEvent$getC","visibilityEvent","currentState","getStateEvents","visibility","getContent","history_visibility","includes","hasCiphertext","content","ciphertext","OutboundSessionInfo","constructor","sessionId","sharedHistory","MapWithDefault","Map","creationTime","Date","getTime","needsRotation","rotationPeriodMsgs","rotationPeriodMs","sessionLifetime","useCount","logger","log","markSharedWithDevice","userId","deviceId","deviceKey","chainIndex","sharedWithDevices","getOrCreate","messageIndex","markNotifiedBlockedDevice","blockedDevicesNotified","sharedWithTooManyDevices","devicesInRoom","devices","_devicesInRoom$get","MegolmEncryption","EncryptionAlgorithm","params","_params$config$rotati","_params$config","_params$config$rotati2","_params$config2","Promise","resolve","roomId","prefixedLogger","withPrefix","sessionRotationPeriodMsgs","config","rotation_period_msgs","sessionRotationPeriodMs","rotation_period_ms","ensureOutboundSession","blocked","singleOlmCreationPhase","setup","oldSession","session","prepareSession","shareSession","fallible","setupPromise","then","catch","e","error","_session","_session2","prepareNewSession","outboundSessions","shareMap","userDevices","deviceInfo","_session$sharedWithDe","getIdentityKey","olmDevice","deviceCurve25519Key","getOutboundGroupSessionKey","payload","type","MEGOLM_ALGORITHM","chain_index","devicesWithoutSession","olmSessions","getExistingOlmSessions","baseApis","all","olmSessionList","Array","from","entries","map","sessionsByUser","flat","debug","shareKeyWithOlmSessions","deviceList","devicesByUser","device","errorDevices","start","now","failedServers","shareKeyWithDevices","retryDevices","failedServerMap","Set","server","add","failedDevices","userHS","slice","indexOf","retryDeviceList","notifyFailedOlmDevices","size","blockedByUser","_deviceInfo","blockedMap","blockedCount","userBlockedDevices","_session$blockedDevic","undefined","notifyBlockedDevices","createOutboundGroupSession","addInboundGroupSession","ed25519","deviceEd25519Key","crypto","backupManager","backupGroupSession","getDevicesWithoutSessions","deviceMap","noOlmDevices","devicesToShareWith","sessionResults","sessionResult","delete","splitDevices","maxDevicesPerRequest","currentSlice","mapSlices","values","pop","encryptAndSendKeysToDevices","encryptAndSendToDevices","sendBlockedNotificationsToDevices","userDeviceMap","contentMap","val","blockedInfo","message","code","reason","ToDeviceMessageId","uuidv4","room_id","session_id","sendToDevice","reshareKeyWithDevice","senderKey","_obSessionInfo$shared","obSessionInfo","sessionSharedData","warn","getInboundGroupSessionKey","ensureOlmSessionsForDevices","sender_claimed_ed25519_key","forwarding_curve25519_key_chain","shared_history","encryptedContent","algorithm","OLM_ALGORITHM","sender_key","encryptMessageForDevice","otkTimeout","devicemap","userDeviceMaps","taskDetail","d","unnotifiedFailedDevices","filterOutNotifiedErrorDevices","WITHHELD_MESSAGES","prepareToEncrypt","Error","encryptionPreparation","elapsedTime","startTime","cancel","cancelled","isCancelled","promise","getDevicesResult","getDevicesInRoom","globalErrorOnUnknownDevices","removeUnknownDevices","encryptMessage","eventType","forceDistributeToUnverified","isVerificationEvent","checkForUnknownDevices","payloadJson","encryptGroupMessage","JSON","stringify","device_id","EventType","KeyVerificationCancel","KeyVerificationDone","KeyVerificationMac","KeyVerificationStart","KeyVerificationKey","KeyVerificationReady","KeyVerificationAccept","RoomMessage","MsgType","KeyVerificationRequest","forceDiscardSession","unknownDevices","isUnverified","isKnown","UnknownDeviceError","members","getEncryptionTargetMembers","shouldEncryptForInvitedMembers","u","membership","roomMembers","isBlacklisting","globalBlacklistUnverifiedDevices","isRoomBlacklisting","getBlacklistUnverifiedDevices","downloadKeys","userDevice","immediate","deviceTrust","checkDeviceTrust","isBlocked","isVerified","blockedDevices","exports","MegolmDecryption","DecryptionAlgorithm","decryptEvent","event","getWireContent","DecryptionError","addEventToPendingList","res","decryptGroupMessage","getRoomId","getId","getTs","name","errorCode","requestKeysForEvent","queryKeyBackupRateLimited","problem","sessionMayHaveProblems","info","getSender","problemDescription","PROBLEM_DESCRIPTIONS","unknown","fixed","untrusted","removeEventFromPendingList","parse","result","clearEvent","senderCurve25519Key","claimedEd25519Key","keysClaimed","forwardingCurve25519KeyChain","wireContent","recipients","getKeyRequestRecipients","requestRoomKey","_senderPendingEvents$","pendingEvents","senderPendingEvents","roomKeyFromEvent","getSenderKey","extraSessionData","session_key","isOlmEncrypted","roomKey","sessionKey","exportFormat","forwardingKeyChain","getKeysClaimed","forwardedRoomKeyFromEvent","senderKeyUser","getUserByIdentityKey","claimedCurve25519Key","isArray","shouldAcceptForwardedKey","_this$crypto$deviceLi","sendingDevice","getDeviceByIdentityKey","checkDeviceInfoTrust","fromUs","getUserId","keyFromOurVerifiedDevice","weRequested","wasRoomKeyRequested","fromInviter","wasRoomKeyForwardedByInviter","sharedAsHistory","wasRoomKeyForwardedAsHistory","outgoingRequests","cryptoStore","getOutgoingRoomKeyRequestsByTarget","RoomKeyRequestState","Sent","some","req","requestBody","_room$getMember","_memberEvent$getUnsig","_memberEvent$getPrevC","getRoom","memberEvent","getMember","events","member","getUnsigned","prev_sender","getPrevContent","shouldParkForwardedKey","parkForwardedKey","parkedData","senderId","doTxn","txn","addParkedSharedHistory","addRoomKey","retryDecryption","cancelRoomKeyRequest","onForwardedRoomKey","onRoomKeyEvent","getType","onRoomKeyWithheldEvent","onNoOlmWithheldEvent","addInboundGroupSessionWithheld","retryDecryptionFromSender","sender","getSessionIdForDevice","recordSessionProblem","hasKeysForKeyRequest","keyRequest","body","hasInboundSessionKeys","shareKeysWithDevice","getStoredDevice","_devicemap$get","olmSessionResult","buildKeyForwardingMessage","importRoomKey","sender_claimed_keys","forceRedecryptIfUntrusted","_this$pendingEvents$g","pending","pendingList","ev","attemptDecryption","isRetry","_sessionId","sendSharedHistoryInboundSessions","sharedHistorySessions","getSharedHistoryInboundGroupSessions","promises","deviceMessages","no_olm","registerAlgorithm"],"sources":["../../../src/crypto/algorithms/megolm.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021, 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Defines m.olm encryption/decryption\n */\n\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport type { IEventDecryptionResult, IMegolmSessionData } from \"../../@types/crypto\";\nimport { logger, PrefixedLogger } from \"../../logger\";\nimport * as olmlib from \"../olmlib\";\nimport {\n DecryptionAlgorithm,\n DecryptionClassParams,\n DecryptionError,\n EncryptionAlgorithm,\n IParams,\n registerAlgorithm,\n UnknownDeviceError,\n} from \"./base\";\nimport { IDecryptedGroupMessage, WITHHELD_MESSAGES } from \"../OlmDevice\";\nimport { Room } from \"../../models/room\";\nimport { DeviceInfo } from \"../deviceinfo\";\nimport { IOlmSessionResult } from \"../olmlib\";\nimport { DeviceInfoMap } from \"../DeviceList\";\nimport { IContent, MatrixEvent } from \"../../models/event\";\nimport { EventType, MsgType, ToDeviceMessageId } from \"../../@types/event\";\nimport { IMegolmEncryptedContent, IncomingRoomKeyRequest, IEncryptedContent } from \"../index\";\nimport { RoomKeyRequestState } from \"../OutgoingRoomKeyRequestManager\";\nimport { OlmGroupSessionExtraData } from \"../../@types/crypto\";\nimport { MatrixError } from \"../../http-api\";\nimport { immediate, MapWithDefault } from \"../../utils\";\n\n// determine whether the key can be shared with invitees\nexport function isRoomSharedHistory(room: Room): boolean {\n const visibilityEvent = room?.currentState?.getStateEvents(\"m.room.history_visibility\", \"\");\n // NOTE: if the room visibility is unset, it would normally default to\n // \"world_readable\".\n // (https://spec.matrix.org/unstable/client-server-api/#server-behaviour-5)\n // But we will be paranoid here, and treat it as a situation where the room\n // is not shared-history\n const visibility = visibilityEvent?.getContent()?.history_visibility;\n return [\"world_readable\", \"shared\"].includes(visibility);\n}\n\ninterface IBlockedDevice {\n code: string;\n reason: string;\n deviceInfo: DeviceInfo;\n}\n\n// map user Id → device Id → IBlockedDevice\ntype BlockedMap = Map>;\n\nexport interface IOlmDevice {\n userId: string;\n deviceInfo: T;\n}\n\n/**\n * Tests whether an encrypted content has a ciphertext.\n * Ciphertext can be a string or object depending on the content type {@link IEncryptedContent}.\n *\n * @param content - Encrypted content\n * @returns true: has ciphertext, else false\n */\nconst hasCiphertext = (content: IEncryptedContent): boolean => {\n return typeof content.ciphertext === \"string\"\n ? !!content.ciphertext.length\n : !!Object.keys(content.ciphertext).length;\n};\n\n/** The result of parsing the an `m.room_key` or `m.forwarded_room_key` to-device event */\ninterface RoomKey {\n /**\n * The Curve25519 key of the megolm session creator.\n *\n * For `m.room_key`, this is also the sender of the `m.room_key` to-device event.\n * For `m.forwarded_room_key`, the two are different (and the key of the sender of the\n * `m.forwarded_room_key` event is included in `forwardingKeyChain`)\n */\n senderKey: string;\n sessionId: string;\n sessionKey: string;\n exportFormat: boolean;\n roomId: string;\n algorithm: string;\n /**\n * A list of the curve25519 keys of the users involved in forwarding this key, most recent last.\n * For `m.room_key` events, this is empty.\n */\n forwardingKeyChain: string[];\n keysClaimed: Partial>;\n extraSessionData: OlmGroupSessionExtraData;\n}\n\nexport interface IOutboundGroupSessionKey {\n chain_index: number;\n key: string;\n}\n\ninterface IMessage {\n type: string;\n content: {\n \"algorithm\": string;\n \"room_id\": string;\n \"sender_key\"?: string;\n \"sender_claimed_ed25519_key\"?: string;\n \"session_id\": string;\n \"session_key\": string;\n \"chain_index\": number;\n \"forwarding_curve25519_key_chain\"?: string[];\n \"org.matrix.msc3061.shared_history\": boolean;\n };\n}\n\ninterface IKeyForwardingMessage extends IMessage {\n type: \"m.forwarded_room_key\";\n}\n\ninterface IPayload extends Partial {\n code?: string;\n reason?: string;\n room_id?: string;\n session_id?: string;\n algorithm?: string;\n sender_key?: string;\n}\n\ninterface SharedWithData {\n // The identity key of the device we shared with\n deviceKey: string;\n // The message index of the ratchet we shared with that device\n messageIndex: number;\n}\n\n/**\n * @internal\n */\nclass OutboundSessionInfo {\n /** number of times this session has been used */\n public useCount = 0;\n /** when the session was created (ms since the epoch) */\n public creationTime: number;\n /** devices with which we have shared the session key `userId -> {deviceId -> SharedWithData}` */\n public sharedWithDevices: MapWithDefault> = new MapWithDefault(() => new Map());\n public blockedDevicesNotified: MapWithDefault> = new MapWithDefault(() => new Map());\n\n /**\n * @param sharedHistory - whether the session can be freely shared with\n * other group members, according to the room history visibility settings\n */\n public constructor(public readonly sessionId: string, public readonly sharedHistory = false) {\n this.creationTime = new Date().getTime();\n }\n\n /**\n * Check if it's time to rotate the session\n */\n public needsRotation(rotationPeriodMsgs: number, rotationPeriodMs: number): boolean {\n const sessionLifetime = new Date().getTime() - this.creationTime;\n\n if (this.useCount >= rotationPeriodMsgs || sessionLifetime >= rotationPeriodMs) {\n logger.log(\"Rotating megolm session after \" + this.useCount + \" messages, \" + sessionLifetime + \"ms\");\n return true;\n }\n\n return false;\n }\n\n public markSharedWithDevice(userId: string, deviceId: string, deviceKey: string, chainIndex: number): void {\n this.sharedWithDevices.getOrCreate(userId).set(deviceId, { deviceKey, messageIndex: chainIndex });\n }\n\n public markNotifiedBlockedDevice(userId: string, deviceId: string): void {\n this.blockedDevicesNotified.getOrCreate(userId).set(deviceId, true);\n }\n\n /**\n * Determine if this session has been shared with devices which it shouldn't\n * have been.\n *\n * @param devicesInRoom - `userId -> {deviceId -> object}`\n * devices we should shared the session with.\n *\n * @returns true if we have shared the session with devices which aren't\n * in devicesInRoom.\n */\n public sharedWithTooManyDevices(devicesInRoom: DeviceInfoMap): boolean {\n for (const [userId, devices] of this.sharedWithDevices) {\n if (!devicesInRoom.has(userId)) {\n logger.log(\"Starting new megolm session because we shared with \" + userId);\n return true;\n }\n\n for (const [deviceId] of devices) {\n if (!devicesInRoom.get(userId)?.get(deviceId)) {\n logger.log(\"Starting new megolm session because we shared with \" + userId + \":\" + deviceId);\n return true;\n }\n }\n }\n\n return false;\n }\n}\n\n/**\n * Megolm encryption implementation\n *\n * @param params - parameters, as per {@link EncryptionAlgorithm}\n */\nexport class MegolmEncryption extends EncryptionAlgorithm {\n // the most recent attempt to set up a session. This is used to serialise\n // the session setups, so that we have a race-free view of which session we\n // are using, and which devices we have shared the keys with. It resolves\n // with an OutboundSessionInfo (or undefined, for the first message in the\n // room).\n private setupPromise = Promise.resolve(null);\n\n // Map of outbound sessions by sessions ID. Used if we need a particular\n // session (the session we're currently using to send is always obtained\n // using setupPromise).\n private outboundSessions: Record = {};\n\n private readonly sessionRotationPeriodMsgs: number;\n private readonly sessionRotationPeriodMs: number;\n private encryptionPreparation?: {\n promise: Promise;\n startTime: number;\n cancel: () => void;\n };\n\n protected readonly roomId: string;\n private readonly prefixedLogger: PrefixedLogger;\n\n public constructor(params: IParams & Required>) {\n super(params);\n this.roomId = params.roomId;\n this.prefixedLogger = logger.withPrefix(`[${this.roomId} encryption]`);\n\n this.sessionRotationPeriodMsgs = params.config?.rotation_period_msgs ?? 100;\n this.sessionRotationPeriodMs = params.config?.rotation_period_ms ?? 7 * 24 * 3600 * 1000;\n }\n\n /**\n * @internal\n *\n * @param devicesInRoom - The devices in this room, indexed by user ID\n * @param blocked - The devices that are blocked, indexed by user ID\n * @param singleOlmCreationPhase - Only perform one round of olm\n * session creation\n *\n * This method updates the setupPromise field of the class by chaining a new\n * call on top of the existing promise, and then catching and discarding any\n * errors that might happen while setting up the outbound group session. This\n * is done to ensure that `setupPromise` always resolves to `null` or the\n * `OutboundSessionInfo`.\n *\n * Using `>>=` to represent the promise chaining operation, it does the\n * following:\n *\n * ```\n * setupPromise = previousSetupPromise >>= setup >>= discardErrors\n * ```\n *\n * The initial value for the `setupPromise` is a promise that resolves to\n * `null`. The forceDiscardSession() resets setupPromise to this initial\n * promise.\n *\n * @returns Promise which resolves to the\n * OutboundSessionInfo when setup is complete.\n */\n private async ensureOutboundSession(\n room: Room,\n devicesInRoom: DeviceInfoMap,\n blocked: BlockedMap,\n singleOlmCreationPhase = false,\n ): Promise {\n // takes the previous OutboundSessionInfo, and considers whether to create\n // a new one. Also shares the key with any (new) devices in the room.\n //\n // returns a promise which resolves once the keyshare is successful.\n const setup = async (oldSession: OutboundSessionInfo | null): Promise => {\n const sharedHistory = isRoomSharedHistory(room);\n const session = await this.prepareSession(devicesInRoom, sharedHistory, oldSession);\n\n await this.shareSession(devicesInRoom, sharedHistory, singleOlmCreationPhase, blocked, session);\n\n return session;\n };\n\n // first wait for the previous share to complete\n const fallible = this.setupPromise.then(setup);\n\n // Ensure any failures are logged for debugging and make sure that the\n // promise chain remains unbroken\n //\n // setupPromise resolves to `null` or the `OutboundSessionInfo` whether\n // or not the share succeeds\n this.setupPromise = fallible.catch((e) => {\n this.prefixedLogger.error(`Failed to setup outbound session`, e);\n return null;\n });\n\n // but we return a promise which only resolves if the share was successful.\n return fallible;\n }\n\n private async prepareSession(\n devicesInRoom: DeviceInfoMap,\n sharedHistory: boolean,\n session: OutboundSessionInfo | null,\n ): Promise {\n // history visibility changed\n if (session && sharedHistory !== session.sharedHistory) {\n session = null;\n }\n\n // need to make a brand new session?\n if (session?.needsRotation(this.sessionRotationPeriodMsgs, this.sessionRotationPeriodMs)) {\n this.prefixedLogger.log(\"Starting new megolm session because we need to rotate.\");\n session = null;\n }\n\n // determine if we have shared with anyone we shouldn't have\n if (session?.sharedWithTooManyDevices(devicesInRoom)) {\n session = null;\n }\n\n if (!session) {\n this.prefixedLogger.log(\"Starting new megolm session\");\n session = await this.prepareNewSession(sharedHistory);\n this.prefixedLogger.log(`Started new megolm session ${session.sessionId}`);\n this.outboundSessions[session.sessionId] = session;\n }\n\n return session;\n }\n\n private async shareSession(\n devicesInRoom: DeviceInfoMap,\n sharedHistory: boolean,\n singleOlmCreationPhase: boolean,\n blocked: BlockedMap,\n session: OutboundSessionInfo,\n ): Promise {\n // now check if we need to share with any devices\n const shareMap: Record = {};\n\n for (const [userId, userDevices] of devicesInRoom) {\n for (const [deviceId, deviceInfo] of userDevices) {\n const key = deviceInfo.getIdentityKey();\n if (key == this.olmDevice.deviceCurve25519Key) {\n // don't bother sending to ourself\n continue;\n }\n\n if (!session.sharedWithDevices.get(userId)?.get(deviceId)) {\n shareMap[userId] = shareMap[userId] || [];\n shareMap[userId].push(deviceInfo);\n }\n }\n }\n\n const key = this.olmDevice.getOutboundGroupSessionKey(session.sessionId);\n const payload: IPayload = {\n type: \"m.room_key\",\n content: {\n \"algorithm\": olmlib.MEGOLM_ALGORITHM,\n \"room_id\": this.roomId,\n \"session_id\": session.sessionId,\n \"session_key\": key.key,\n \"chain_index\": key.chain_index,\n \"org.matrix.msc3061.shared_history\": sharedHistory,\n },\n };\n const [devicesWithoutSession, olmSessions] = await olmlib.getExistingOlmSessions(\n this.olmDevice,\n this.baseApis,\n shareMap,\n );\n\n await Promise.all([\n (async (): Promise => {\n // share keys with devices that we already have a session for\n const olmSessionList = Array.from(olmSessions.entries())\n .map(([userId, sessionsByUser]) =>\n Array.from(sessionsByUser.entries()).map(\n ([deviceId, session]) => `${userId}/${deviceId}: ${session.sessionId}`,\n ),\n )\n .flat(1);\n this.prefixedLogger.debug(\"Sharing keys with devices with existing Olm sessions:\", olmSessionList);\n await this.shareKeyWithOlmSessions(session, key, payload, olmSessions);\n this.prefixedLogger.debug(\"Shared keys with existing Olm sessions\");\n })(),\n (async (): Promise => {\n const deviceList = Array.from(devicesWithoutSession.entries())\n .map(([userId, devicesByUser]) => devicesByUser.map((device) => `${userId}/${device.deviceId}`))\n .flat(1);\n this.prefixedLogger.debug(\n \"Sharing keys (start phase 1) with devices without existing Olm sessions:\",\n deviceList,\n );\n const errorDevices: IOlmDevice[] = [];\n\n // meanwhile, establish olm sessions for devices that we don't\n // already have a session for, and share keys with them. If\n // we're doing two phases of olm session creation, use a\n // shorter timeout when fetching one-time keys for the first\n // phase.\n const start = Date.now();\n const failedServers: string[] = [];\n await this.shareKeyWithDevices(\n session,\n key,\n payload,\n devicesWithoutSession,\n errorDevices,\n singleOlmCreationPhase ? 10000 : 2000,\n failedServers,\n );\n this.prefixedLogger.debug(\"Shared keys (end phase 1) with devices without existing Olm sessions\");\n\n if (!singleOlmCreationPhase && Date.now() - start < 10000) {\n // perform the second phase of olm session creation if requested,\n // and if the first phase didn't take too long\n (async (): Promise => {\n // Retry sending keys to devices that we were unable to establish\n // an olm session for. This time, we use a longer timeout, but we\n // do this in the background and don't block anything else while we\n // do this. We only need to retry users from servers that didn't\n // respond the first time.\n const retryDevices: MapWithDefault = new MapWithDefault(() => []);\n const failedServerMap = new Set();\n for (const server of failedServers) {\n failedServerMap.add(server);\n }\n const failedDevices: IOlmDevice[] = [];\n for (const { userId, deviceInfo } of errorDevices) {\n const userHS = userId.slice(userId.indexOf(\":\") + 1);\n if (failedServerMap.has(userHS)) {\n retryDevices.getOrCreate(userId).push(deviceInfo);\n } else {\n // if we aren't going to retry, then handle it\n // as a failed device\n failedDevices.push({ userId, deviceInfo });\n }\n }\n\n const retryDeviceList = Array.from(retryDevices.entries())\n .map(([userId, devicesByUser]) =>\n devicesByUser.map((device) => `${userId}/${device.deviceId}`),\n )\n .flat(1);\n\n if (retryDeviceList.length > 0) {\n this.prefixedLogger.debug(\n \"Sharing keys (start phase 2) with devices without existing Olm sessions:\",\n retryDeviceList,\n );\n await this.shareKeyWithDevices(session, key, payload, retryDevices, failedDevices, 30000);\n this.prefixedLogger.debug(\n \"Shared keys (end phase 2) with devices without existing Olm sessions\",\n );\n }\n\n await this.notifyFailedOlmDevices(session, key, failedDevices);\n })();\n } else {\n await this.notifyFailedOlmDevices(session, key, errorDevices);\n }\n })(),\n (async (): Promise => {\n this.prefixedLogger.debug(\n `There are ${blocked.size} blocked devices:`,\n Array.from(blocked.entries())\n .map(([userId, blockedByUser]) =>\n Array.from(blockedByUser.entries()).map(\n ([deviceId, _deviceInfo]) => `${userId}/${deviceId}`,\n ),\n )\n .flat(1),\n );\n\n // also, notify newly blocked devices that they're blocked\n const blockedMap: MapWithDefault> = new MapWithDefault(\n () => new Map(),\n );\n let blockedCount = 0;\n for (const [userId, userBlockedDevices] of blocked) {\n for (const [deviceId, device] of userBlockedDevices) {\n if (session.blockedDevicesNotified.get(userId)?.get(deviceId) === undefined) {\n blockedMap.getOrCreate(userId).set(deviceId, { device });\n blockedCount++;\n }\n }\n }\n\n if (blockedCount) {\n this.prefixedLogger.debug(\n `Notifying ${blockedCount} newly blocked devices:`,\n Array.from(blockedMap.entries())\n .map(([userId, blockedByUser]) =>\n Object.entries(blockedByUser).map(([deviceId, _deviceInfo]) => `${userId}/${deviceId}`),\n )\n .flat(1),\n );\n await this.notifyBlockedDevices(session, blockedMap);\n this.prefixedLogger.debug(`Notified ${blockedCount} newly blocked devices`);\n }\n })(),\n ]);\n }\n\n /**\n * @internal\n *\n *\n * @returns session\n */\n private async prepareNewSession(sharedHistory: boolean): Promise {\n const sessionId = this.olmDevice.createOutboundGroupSession();\n const key = this.olmDevice.getOutboundGroupSessionKey(sessionId);\n\n await this.olmDevice.addInboundGroupSession(\n this.roomId,\n this.olmDevice.deviceCurve25519Key!,\n [],\n sessionId,\n key.key,\n { ed25519: this.olmDevice.deviceEd25519Key! },\n false,\n { sharedHistory },\n );\n\n // don't wait for it to complete\n this.crypto.backupManager.backupGroupSession(this.olmDevice.deviceCurve25519Key!, sessionId);\n\n return new OutboundSessionInfo(sessionId, sharedHistory);\n }\n\n /**\n * Determines what devices in devicesByUser don't have an olm session as given\n * in devicemap.\n *\n * @internal\n *\n * @param deviceMap - the devices that have olm sessions, as returned by\n * olmlib.ensureOlmSessionsForDevices.\n * @param devicesByUser - a map of user IDs to array of deviceInfo\n * @param noOlmDevices - an array to fill with devices that don't have\n * olm sessions\n *\n * @returns an array of devices that don't have olm sessions. If\n * noOlmDevices is specified, then noOlmDevices will be returned.\n */\n private getDevicesWithoutSessions(\n deviceMap: Map>,\n devicesByUser: Map,\n noOlmDevices: IOlmDevice[] = [],\n ): IOlmDevice[] {\n for (const [userId, devicesToShareWith] of devicesByUser) {\n const sessionResults = deviceMap.get(userId);\n\n for (const deviceInfo of devicesToShareWith) {\n const deviceId = deviceInfo.deviceId;\n\n const sessionResult = sessionResults?.get(deviceId);\n if (!sessionResult?.sessionId) {\n // no session with this device, probably because there\n // were no one-time keys.\n\n noOlmDevices.push({ userId, deviceInfo });\n sessionResults?.delete(deviceId);\n\n // ensureOlmSessionsForUsers has already done the logging,\n // so just skip it.\n continue;\n }\n }\n }\n\n return noOlmDevices;\n }\n\n /**\n * Splits the user device map into multiple chunks to reduce the number of\n * devices we encrypt to per API call.\n *\n * @internal\n *\n * @param devicesByUser - map from userid to list of devices\n *\n * @returns the blocked devices, split into chunks\n */\n private splitDevices(\n devicesByUser: Map>,\n ): IOlmDevice[][] {\n const maxDevicesPerRequest = 20;\n\n // use an array where the slices of a content map gets stored\n let currentSlice: IOlmDevice[] = [];\n const mapSlices = [currentSlice];\n\n for (const [userId, userDevices] of devicesByUser) {\n for (const deviceInfo of userDevices.values()) {\n currentSlice.push({\n userId: userId,\n deviceInfo: deviceInfo.device,\n });\n }\n\n // We do this in the per-user loop as we prefer that all messages to the\n // same user end up in the same API call to make it easier for the\n // server (e.g. only have to send one EDU if a remote user, etc). This\n // does mean that if a user has many devices we may go over the desired\n // limit, but its not a hard limit so that is fine.\n if (currentSlice.length > maxDevicesPerRequest) {\n // the current slice is filled up. Start inserting into the next slice\n currentSlice = [];\n mapSlices.push(currentSlice);\n }\n }\n if (currentSlice.length === 0) {\n mapSlices.pop();\n }\n return mapSlices;\n }\n\n /**\n * @internal\n *\n *\n * @param chainIndex - current chain index\n *\n * @param userDeviceMap - mapping from userId to deviceInfo\n *\n * @param payload - fields to include in the encrypted payload\n *\n * @returns Promise which resolves once the key sharing\n * for the given userDeviceMap is generated and has been sent.\n */\n private encryptAndSendKeysToDevices(\n session: OutboundSessionInfo,\n chainIndex: number,\n devices: IOlmDevice[],\n payload: IPayload,\n ): Promise {\n return this.crypto\n .encryptAndSendToDevices(devices, payload)\n .then(() => {\n // store that we successfully uploaded the keys of the current slice\n for (const device of devices) {\n session.markSharedWithDevice(\n device.userId,\n device.deviceInfo.deviceId,\n device.deviceInfo.getIdentityKey(),\n chainIndex,\n );\n }\n })\n .catch((error) => {\n this.prefixedLogger.error(\"failed to encryptAndSendToDevices\", error);\n throw error;\n });\n }\n\n /**\n * @internal\n *\n *\n * @param userDeviceMap - list of blocked devices to notify\n *\n * @param payload - fields to include in the notification payload\n *\n * @returns Promise which resolves once the notifications\n * for the given userDeviceMap is generated and has been sent.\n */\n private async sendBlockedNotificationsToDevices(\n session: OutboundSessionInfo,\n userDeviceMap: IOlmDevice[],\n payload: IPayload,\n ): Promise {\n const contentMap: MapWithDefault> = new MapWithDefault(() => new Map());\n\n for (const val of userDeviceMap) {\n const userId = val.userId;\n const blockedInfo = val.deviceInfo;\n const deviceInfo = blockedInfo.deviceInfo;\n const deviceId = deviceInfo.deviceId;\n\n const message = {\n ...payload,\n code: blockedInfo.code,\n reason: blockedInfo.reason,\n [ToDeviceMessageId]: uuidv4(),\n };\n\n if (message.code === \"m.no_olm\") {\n delete message.room_id;\n delete message.session_id;\n }\n\n contentMap.getOrCreate(userId).set(deviceId, message);\n }\n\n await this.baseApis.sendToDevice(\"m.room_key.withheld\", contentMap);\n\n // record the fact that we notified these blocked devices\n for (const [userId, userDeviceMap] of contentMap) {\n for (const deviceId of userDeviceMap.keys()) {\n session.markNotifiedBlockedDevice(userId, deviceId);\n }\n }\n }\n\n /**\n * Re-shares a megolm session key with devices if the key has already been\n * sent to them.\n *\n * @param senderKey - The key of the originating device for the session\n * @param sessionId - ID of the outbound session to share\n * @param userId - ID of the user who owns the target device\n * @param device - The target device\n */\n public async reshareKeyWithDevice(\n senderKey: string,\n sessionId: string,\n userId: string,\n device: DeviceInfo,\n ): Promise {\n const obSessionInfo = this.outboundSessions[sessionId];\n if (!obSessionInfo) {\n this.prefixedLogger.debug(`megolm session ${senderKey}|${sessionId} not found: not re-sharing keys`);\n return;\n }\n\n // The chain index of the key we previously sent this device\n if (!obSessionInfo.sharedWithDevices.has(userId)) {\n this.prefixedLogger.debug(`megolm session ${senderKey}|${sessionId} never shared with user ${userId}`);\n return;\n }\n const sessionSharedData = obSessionInfo.sharedWithDevices.get(userId)?.get(device.deviceId);\n if (sessionSharedData === undefined) {\n this.prefixedLogger.debug(\n `megolm session ${senderKey}|${sessionId} never shared with device ${userId}:${device.deviceId}`,\n );\n return;\n }\n\n if (sessionSharedData.deviceKey !== device.getIdentityKey()) {\n this.prefixedLogger.warn(\n `Megolm session ${senderKey}|${sessionId} has been shared with device ${device.deviceId} but ` +\n `with identity key ${sessionSharedData.deviceKey}. Key is now ${device.getIdentityKey()}!`,\n );\n return;\n }\n\n // get the key from the inbound session: the outbound one will already\n // have been ratcheted to the next chain index.\n const key = await this.olmDevice.getInboundGroupSessionKey(\n this.roomId,\n senderKey,\n sessionId,\n sessionSharedData.messageIndex,\n );\n\n if (!key) {\n this.prefixedLogger.warn(\n `No inbound session key found for megolm session ${senderKey}|${sessionId}: not re-sharing keys`,\n );\n return;\n }\n\n await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, new Map([[userId, [device]]]));\n\n const payload = {\n type: \"m.forwarded_room_key\",\n content: {\n \"algorithm\": olmlib.MEGOLM_ALGORITHM,\n \"room_id\": this.roomId,\n \"session_id\": sessionId,\n \"session_key\": key.key,\n \"chain_index\": key.chain_index,\n \"sender_key\": senderKey,\n \"sender_claimed_ed25519_key\": key.sender_claimed_ed25519_key,\n \"forwarding_curve25519_key_chain\": key.forwarding_curve25519_key_chain,\n \"org.matrix.msc3061.shared_history\": key.shared_history || false,\n },\n };\n\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n [ToDeviceMessageId]: uuidv4(),\n };\n await olmlib.encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.userId,\n this.deviceId,\n this.olmDevice,\n userId,\n device,\n payload,\n );\n\n await this.baseApis.sendToDevice(\n \"m.room.encrypted\",\n new Map([[userId, new Map([[device.deviceId, encryptedContent]])]]),\n );\n this.prefixedLogger.debug(\n `Re-shared key for megolm session ${senderKey}|${sessionId} with ${userId}:${device.deviceId}`,\n );\n }\n\n /**\n * @internal\n *\n *\n * @param key - the session key as returned by\n * OlmDevice.getOutboundGroupSessionKey\n *\n * @param payload - the base to-device message payload for sharing keys\n *\n * @param devicesByUser - map from userid to list of devices\n *\n * @param errorDevices - array that will be populated with the devices that we can't get an\n * olm session for\n *\n * @param otkTimeout - The timeout in milliseconds when requesting\n * one-time keys for establishing new olm sessions.\n *\n * @param failedServers - An array to fill with remote servers that\n * failed to respond to one-time-key requests.\n */\n private async shareKeyWithDevices(\n session: OutboundSessionInfo,\n key: IOutboundGroupSessionKey,\n payload: IPayload,\n devicesByUser: Map,\n errorDevices: IOlmDevice[],\n otkTimeout: number,\n failedServers?: string[],\n ): Promise {\n const devicemap = await olmlib.ensureOlmSessionsForDevices(\n this.olmDevice,\n this.baseApis,\n devicesByUser,\n false,\n otkTimeout,\n failedServers,\n this.prefixedLogger,\n );\n this.getDevicesWithoutSessions(devicemap, devicesByUser, errorDevices);\n await this.shareKeyWithOlmSessions(session, key, payload, devicemap);\n }\n\n private async shareKeyWithOlmSessions(\n session: OutboundSessionInfo,\n key: IOutboundGroupSessionKey,\n payload: IPayload,\n deviceMap: Map>,\n ): Promise {\n const userDeviceMaps = this.splitDevices(deviceMap);\n\n for (let i = 0; i < userDeviceMaps.length; i++) {\n const taskDetail = `megolm keys for ${session.sessionId} (slice ${i + 1}/${userDeviceMaps.length})`;\n try {\n this.prefixedLogger.debug(\n `Sharing ${taskDetail}`,\n userDeviceMaps[i].map((d) => `${d.userId}/${d.deviceInfo.deviceId}`),\n );\n await this.encryptAndSendKeysToDevices(session, key.chain_index, userDeviceMaps[i], payload);\n this.prefixedLogger.debug(`Shared ${taskDetail}`);\n } catch (e) {\n this.prefixedLogger.error(`Failed to share ${taskDetail}`);\n throw e;\n }\n }\n }\n\n /**\n * Notify devices that we weren't able to create olm sessions.\n *\n *\n *\n * @param failedDevices - the devices that we were unable to\n * create olm sessions for, as returned by shareKeyWithDevices\n */\n private async notifyFailedOlmDevices(\n session: OutboundSessionInfo,\n key: IOutboundGroupSessionKey,\n failedDevices: IOlmDevice[],\n ): Promise {\n this.prefixedLogger.debug(`Notifying ${failedDevices.length} devices we failed to create Olm sessions`);\n\n // mark the devices that failed as \"handled\" because we don't want to try\n // to claim a one-time-key for dead devices on every message.\n for (const { userId, deviceInfo } of failedDevices) {\n const deviceId = deviceInfo.deviceId;\n\n session.markSharedWithDevice(userId, deviceId, deviceInfo.getIdentityKey(), key.chain_index);\n }\n\n const unnotifiedFailedDevices = await this.olmDevice.filterOutNotifiedErrorDevices(failedDevices);\n this.prefixedLogger.debug(\n `Need to notify ${unnotifiedFailedDevices.length} failed devices which haven't been notified before`,\n );\n const blockedMap: MapWithDefault> = new MapWithDefault(\n () => new Map(),\n );\n for (const { userId, deviceInfo } of unnotifiedFailedDevices) {\n // we use a similar format to what\n // olmlib.ensureOlmSessionsForDevices returns, so that\n // we can use the same function to split\n blockedMap.getOrCreate(userId).set(deviceInfo.deviceId, {\n device: {\n code: \"m.no_olm\",\n reason: WITHHELD_MESSAGES[\"m.no_olm\"],\n deviceInfo,\n },\n });\n }\n\n // send the notifications\n await this.notifyBlockedDevices(session, blockedMap);\n this.prefixedLogger.debug(\n `Notified ${unnotifiedFailedDevices.length} devices we failed to create Olm sessions`,\n );\n }\n\n /**\n * Notify blocked devices that they have been blocked.\n *\n *\n * @param devicesByUser - map from userid to device ID to blocked data\n */\n private async notifyBlockedDevices(\n session: OutboundSessionInfo,\n devicesByUser: Map>,\n ): Promise {\n const payload: IPayload = {\n room_id: this.roomId,\n session_id: session.sessionId,\n algorithm: olmlib.MEGOLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n };\n\n const userDeviceMaps = this.splitDevices(devicesByUser);\n\n for (let i = 0; i < userDeviceMaps.length; i++) {\n try {\n await this.sendBlockedNotificationsToDevices(session, userDeviceMaps[i], payload);\n this.prefixedLogger.log(\n `Completed blacklist notification for ${session.sessionId} ` +\n `(slice ${i + 1}/${userDeviceMaps.length})`,\n );\n } catch (e) {\n this.prefixedLogger.log(\n `blacklist notification for ${session.sessionId} ` +\n `(slice ${i + 1}/${userDeviceMaps.length}) failed`,\n );\n\n throw e;\n }\n }\n }\n\n /**\n * Perform any background tasks that can be done before a message is ready to\n * send, in order to speed up sending of the message.\n *\n * @param room - the room the event is in\n * @returns A function that, when called, will stop the preparation\n */\n public prepareToEncrypt(room: Room): () => void {\n if (room.roomId !== this.roomId) {\n throw new Error(\"MegolmEncryption.prepareToEncrypt called on unexpected room\");\n }\n\n if (this.encryptionPreparation != null) {\n // We're already preparing something, so don't do anything else.\n const elapsedTime = Date.now() - this.encryptionPreparation.startTime;\n this.prefixedLogger.debug(\n `Already started preparing to encrypt for this room ${elapsedTime}ms ago, skipping`,\n );\n return this.encryptionPreparation.cancel;\n }\n\n this.prefixedLogger.debug(\"Preparing to encrypt events\");\n\n let cancelled = false;\n const isCancelled = (): boolean => cancelled;\n\n this.encryptionPreparation = {\n startTime: Date.now(),\n promise: (async (): Promise => {\n try {\n // Attempt to enumerate the devices in room, and gracefully\n // handle cancellation if it occurs.\n const getDevicesResult = await this.getDevicesInRoom(room, false, isCancelled);\n if (getDevicesResult === null) return;\n const [devicesInRoom, blocked] = getDevicesResult;\n\n if (this.crypto.globalErrorOnUnknownDevices) {\n // Drop unknown devices for now. When the message gets sent, we'll\n // throw an error, but we'll still be prepared to send to the known\n // devices.\n this.removeUnknownDevices(devicesInRoom);\n }\n\n this.prefixedLogger.debug(\"Ensuring outbound megolm session\");\n await this.ensureOutboundSession(room, devicesInRoom, blocked, true);\n\n this.prefixedLogger.debug(\"Ready to encrypt events\");\n } catch (e) {\n this.prefixedLogger.error(\"Failed to prepare to encrypt events\", e);\n } finally {\n delete this.encryptionPreparation;\n }\n })(),\n\n cancel: (): void => {\n // The caller has indicated that the process should be cancelled,\n // so tell the promise that we'd like to halt, and reset the preparation state.\n cancelled = true;\n delete this.encryptionPreparation;\n },\n };\n\n return this.encryptionPreparation.cancel;\n }\n\n /**\n * @param content - plaintext event content\n *\n * @returns Promise which resolves to the new event body\n */\n public async encryptMessage(room: Room, eventType: string, content: IContent): Promise {\n this.prefixedLogger.log(\"Starting to encrypt event\");\n\n if (this.encryptionPreparation != null) {\n // If we started sending keys, wait for it to be done.\n // FIXME: check if we need to cancel\n // (https://github.com/matrix-org/matrix-js-sdk/issues/1255)\n try {\n await this.encryptionPreparation.promise;\n } catch (e) {\n // ignore any errors -- if the preparation failed, we'll just\n // restart everything here\n }\n }\n\n /**\n * When using in-room messages and the room has encryption enabled,\n * clients should ensure that encryption does not hinder the verification.\n */\n const forceDistributeToUnverified = this.isVerificationEvent(eventType, content);\n const [devicesInRoom, blocked] = await this.getDevicesInRoom(room, forceDistributeToUnverified);\n\n // check if any of these devices are not yet known to the user.\n // if so, warn the user so they can verify or ignore.\n if (this.crypto.globalErrorOnUnknownDevices) {\n this.checkForUnknownDevices(devicesInRoom);\n }\n\n const session = await this.ensureOutboundSession(room, devicesInRoom, blocked);\n const payloadJson = {\n room_id: this.roomId,\n type: eventType,\n content: content,\n };\n\n const ciphertext = this.olmDevice.encryptGroupMessage(session.sessionId, JSON.stringify(payloadJson));\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.MEGOLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: ciphertext,\n session_id: session.sessionId,\n // Include our device ID so that recipients can send us a\n // m.new_device message if they don't have our session key.\n // XXX: Do we still need this now that m.new_device messages\n // no longer exist since #483?\n device_id: this.deviceId,\n };\n\n session.useCount++;\n return encryptedContent;\n }\n\n private isVerificationEvent(eventType: string, content: IContent): boolean {\n switch (eventType) {\n case EventType.KeyVerificationCancel:\n case EventType.KeyVerificationDone:\n case EventType.KeyVerificationMac:\n case EventType.KeyVerificationStart:\n case EventType.KeyVerificationKey:\n case EventType.KeyVerificationReady:\n case EventType.KeyVerificationAccept: {\n return true;\n }\n case EventType.RoomMessage: {\n return content[\"msgtype\"] === MsgType.KeyVerificationRequest;\n }\n default: {\n return false;\n }\n }\n }\n\n /**\n * Forces the current outbound group session to be discarded such\n * that another one will be created next time an event is sent.\n *\n * This should not normally be necessary.\n */\n public forceDiscardSession(): void {\n this.setupPromise = this.setupPromise.then(() => null);\n }\n\n /**\n * Checks the devices we're about to send to and see if any are entirely\n * unknown to the user. If so, warn the user, and mark them as known to\n * give the user a chance to go verify them before re-sending this message.\n *\n * @param devicesInRoom - `userId -> {deviceId -> object}`\n * devices we should shared the session with.\n */\n private checkForUnknownDevices(devicesInRoom: DeviceInfoMap): void {\n const unknownDevices: MapWithDefault> = new MapWithDefault(() => new Map());\n\n for (const [userId, userDevices] of devicesInRoom) {\n for (const [deviceId, device] of userDevices) {\n if (device.isUnverified() && !device.isKnown()) {\n unknownDevices.getOrCreate(userId).set(deviceId, device);\n }\n }\n }\n\n if (unknownDevices.size) {\n // it'd be kind to pass unknownDevices up to the user in this error\n throw new UnknownDeviceError(\n \"This room contains unknown devices which have not been verified. \" +\n \"We strongly recommend you verify them before continuing.\",\n unknownDevices,\n );\n }\n }\n\n /**\n * Remove unknown devices from a set of devices. The devicesInRoom parameter\n * will be modified.\n *\n * @param devicesInRoom - `userId -> {deviceId -> object}`\n * devices we should shared the session with.\n */\n private removeUnknownDevices(devicesInRoom: DeviceInfoMap): void {\n for (const [userId, userDevices] of devicesInRoom) {\n for (const [deviceId, device] of userDevices) {\n if (device.isUnverified() && !device.isKnown()) {\n userDevices.delete(deviceId);\n }\n }\n\n if (userDevices.size === 0) {\n devicesInRoom.delete(userId);\n }\n }\n }\n\n /**\n * Get the list of unblocked devices for all users in the room\n *\n * @param forceDistributeToUnverified - if set to true will include the unverified devices\n * even if setting is set to block them (useful for verification)\n * @param isCancelled - will cause the procedure to abort early if and when it starts\n * returning `true`. If omitted, cancellation won't happen.\n *\n * @returns Promise which resolves to `null`, or an array whose\n * first element is a {@link DeviceInfoMap} indicating\n * the devices that messages should be encrypted to, and whose second\n * element is a map from userId to deviceId to data indicating the devices\n * that are in the room but that have been blocked.\n * If `isCancelled` is provided and returns `true` while processing, `null`\n * will be returned.\n * If `isCancelled` is not provided, the Promise will never resolve to `null`.\n */\n private async getDevicesInRoom(\n room: Room,\n forceDistributeToUnverified?: boolean,\n ): Promise<[DeviceInfoMap, BlockedMap]>;\n private async getDevicesInRoom(\n room: Room,\n forceDistributeToUnverified?: boolean,\n isCancelled?: () => boolean,\n ): Promise;\n private async getDevicesInRoom(\n room: Room,\n forceDistributeToUnverified = false,\n isCancelled?: () => boolean,\n ): Promise {\n const members = await room.getEncryptionTargetMembers();\n this.prefixedLogger.debug(\n `Encrypting for users (shouldEncryptForInvitedMembers: ${room.shouldEncryptForInvitedMembers()}):`,\n members.map((u) => `${u.userId} (${u.membership})`),\n );\n\n const roomMembers = members.map(function (u) {\n return u.userId;\n });\n\n // The global value is treated as a default for when rooms don't specify a value.\n let isBlacklisting = this.crypto.globalBlacklistUnverifiedDevices;\n const isRoomBlacklisting = room.getBlacklistUnverifiedDevices();\n if (typeof isRoomBlacklisting === \"boolean\") {\n isBlacklisting = isRoomBlacklisting;\n }\n\n // We are happy to use a cached version here: we assume that if we already\n // have a list of the user's devices, then we already share an e2e room\n // with them, which means that they will have announced any new devices via\n // device_lists in their /sync response. This cache should then be maintained\n // using all the device_lists changes and left fields.\n // See https://github.com/vector-im/element-web/issues/2305 for details.\n const devices = await this.crypto.downloadKeys(roomMembers, false);\n\n if (isCancelled?.() === true) {\n return null;\n }\n\n const blocked = new MapWithDefault>(() => new Map());\n // remove any blocked devices\n for (const [userId, userDevices] of devices) {\n for (const [deviceId, userDevice] of userDevices) {\n // Yield prior to checking each device so that we don't block\n // updating/rendering for too long.\n // See https://github.com/vector-im/element-web/issues/21612\n if (isCancelled !== undefined) await immediate();\n if (isCancelled?.() === true) return null;\n const deviceTrust = this.crypto.checkDeviceTrust(userId, deviceId);\n\n if (\n userDevice.isBlocked() ||\n (!deviceTrust.isVerified() && isBlacklisting && !forceDistributeToUnverified)\n ) {\n const blockedDevices = blocked.getOrCreate(userId);\n const isBlocked = userDevice.isBlocked();\n blockedDevices.set(deviceId, {\n code: isBlocked ? \"m.blacklisted\" : \"m.unverified\",\n reason: WITHHELD_MESSAGES[isBlocked ? \"m.blacklisted\" : \"m.unverified\"],\n deviceInfo: userDevice,\n });\n userDevices.delete(deviceId);\n }\n }\n }\n\n return [devices, blocked];\n }\n}\n\n/**\n * Megolm decryption implementation\n *\n * @param params - parameters, as per {@link DecryptionAlgorithm}\n */\nexport class MegolmDecryption extends DecryptionAlgorithm {\n // events which we couldn't decrypt due to unknown sessions /\n // indexes, or which we could only decrypt with untrusted keys:\n // map from senderKey|sessionId to Set of MatrixEvents\n private pendingEvents = new Map>>();\n\n // this gets stubbed out by the unit tests.\n private olmlib = olmlib;\n\n protected readonly roomId: string;\n private readonly prefixedLogger: PrefixedLogger;\n\n public constructor(params: DecryptionClassParams>>) {\n super(params);\n this.roomId = params.roomId;\n this.prefixedLogger = logger.withPrefix(`[${this.roomId} decryption]`);\n }\n\n /**\n * returns a promise which resolves to a\n * {@link EventDecryptionResult} once we have finished\n * decrypting, or rejects with an `algorithms.DecryptionError` if there is a\n * problem decrypting the event.\n */\n public async decryptEvent(event: MatrixEvent): Promise {\n const content = event.getWireContent();\n\n if (!content.sender_key || !content.session_id || !content.ciphertext) {\n throw new DecryptionError(\"MEGOLM_MISSING_FIELDS\", \"Missing fields in input\");\n }\n\n // we add the event to the pending list *before* we start decryption.\n //\n // then, if the key turns up while decryption is in progress (and\n // decryption fails), we will schedule a retry.\n // (fixes https://github.com/vector-im/element-web/issues/5001)\n this.addEventToPendingList(event);\n\n let res: IDecryptedGroupMessage | null;\n try {\n res = await this.olmDevice.decryptGroupMessage(\n event.getRoomId()!,\n content.sender_key,\n content.session_id,\n content.ciphertext,\n event.getId()!,\n event.getTs(),\n );\n } catch (e) {\n if ((e).name === \"DecryptionError\") {\n // re-throw decryption errors as-is\n throw e;\n }\n\n let errorCode = \"OLM_DECRYPT_GROUP_MESSAGE_ERROR\";\n\n if ((e)?.message === \"OLM.UNKNOWN_MESSAGE_INDEX\") {\n this.requestKeysForEvent(event);\n\n errorCode = \"OLM_UNKNOWN_MESSAGE_INDEX\";\n }\n\n throw new DecryptionError(errorCode, e instanceof Error ? e.message : \"Unknown Error: Error is undefined\", {\n session: content.sender_key + \"|\" + content.session_id,\n });\n }\n\n if (res === null) {\n // We've got a message for a session we don't have.\n // try and get the missing key from the backup first\n this.crypto.backupManager.queryKeyBackupRateLimited(event.getRoomId(), content.session_id).catch(() => {});\n\n // (XXX: We might actually have received this key since we started\n // decrypting, in which case we'll have scheduled a retry, and this\n // request will be redundant. We could probably check to see if the\n // event is still in the pending list; if not, a retry will have been\n // scheduled, so we needn't send out the request here.)\n this.requestKeysForEvent(event);\n\n // See if there was a problem with the olm session at the time the\n // event was sent. Use a fuzz factor of 2 minutes.\n const problem = await this.olmDevice.sessionMayHaveProblems(content.sender_key, event.getTs() - 120000);\n if (problem) {\n this.prefixedLogger.info(\n `When handling UISI from ${event.getSender()} (sender key ${content.sender_key}): ` +\n `recent session problem with that sender:`,\n problem,\n );\n let problemDescription = PROBLEM_DESCRIPTIONS[problem.type as \"no_olm\"] || PROBLEM_DESCRIPTIONS.unknown;\n if (problem.fixed) {\n problemDescription += \" Trying to create a new secure channel and re-requesting the keys.\";\n }\n throw new DecryptionError(\"MEGOLM_UNKNOWN_INBOUND_SESSION_ID\", problemDescription, {\n session: content.sender_key + \"|\" + content.session_id,\n });\n }\n\n throw new DecryptionError(\n \"MEGOLM_UNKNOWN_INBOUND_SESSION_ID\",\n \"The sender's device has not sent us the keys for this message.\",\n {\n session: content.sender_key + \"|\" + content.session_id,\n },\n );\n }\n\n // Success. We can remove the event from the pending list, if\n // that hasn't already happened. However, if the event was\n // decrypted with an untrusted key, leave it on the pending\n // list so it will be retried if we find a trusted key later.\n if (!res.untrusted) {\n this.removeEventFromPendingList(event);\n }\n\n const payload = JSON.parse(res.result);\n\n // belt-and-braces check that the room id matches that indicated by the HS\n // (this is somewhat redundant, since the megolm session is scoped to the\n // room, so neither the sender nor a MITM can lie about the room_id).\n if (payload.room_id !== event.getRoomId()) {\n throw new DecryptionError(\"MEGOLM_BAD_ROOM\", \"Message intended for room \" + payload.room_id);\n }\n\n return {\n clearEvent: payload,\n senderCurve25519Key: res.senderKey,\n claimedEd25519Key: res.keysClaimed.ed25519,\n forwardingCurve25519KeyChain: res.forwardingCurve25519KeyChain,\n untrusted: res.untrusted,\n };\n }\n\n private requestKeysForEvent(event: MatrixEvent): void {\n const wireContent = event.getWireContent();\n\n const recipients = event.getKeyRequestRecipients(this.userId);\n\n this.crypto.requestRoomKey(\n {\n room_id: event.getRoomId()!,\n algorithm: wireContent.algorithm,\n sender_key: wireContent.sender_key,\n session_id: wireContent.session_id,\n },\n recipients,\n );\n }\n\n /**\n * Add an event to the list of those awaiting their session keys.\n *\n * @internal\n *\n */\n private addEventToPendingList(event: MatrixEvent): void {\n const content = event.getWireContent();\n const senderKey = content.sender_key;\n const sessionId = content.session_id;\n if (!this.pendingEvents.has(senderKey)) {\n this.pendingEvents.set(senderKey, new Map>());\n }\n const senderPendingEvents = this.pendingEvents.get(senderKey)!;\n if (!senderPendingEvents.has(sessionId)) {\n senderPendingEvents.set(sessionId, new Set());\n }\n senderPendingEvents.get(sessionId)?.add(event);\n }\n\n /**\n * Remove an event from the list of those awaiting their session keys.\n *\n * @internal\n *\n */\n private removeEventFromPendingList(event: MatrixEvent): void {\n const content = event.getWireContent();\n const senderKey = content.sender_key;\n const sessionId = content.session_id;\n const senderPendingEvents = this.pendingEvents.get(senderKey);\n const pendingEvents = senderPendingEvents?.get(sessionId);\n if (!pendingEvents) {\n return;\n }\n\n pendingEvents.delete(event);\n if (pendingEvents.size === 0) {\n senderPendingEvents!.delete(sessionId);\n }\n if (senderPendingEvents!.size === 0) {\n this.pendingEvents.delete(senderKey);\n }\n }\n\n /**\n * Parse a RoomKey out of an `m.room_key` event.\n *\n * @param event - the event containing the room key.\n *\n * @returns The `RoomKey` if it could be successfully parsed out of the\n * event.\n *\n * @internal\n *\n */\n private roomKeyFromEvent(event: MatrixEvent): RoomKey | undefined {\n const senderKey = event.getSenderKey()!;\n const content = event.getContent>();\n const extraSessionData: OlmGroupSessionExtraData = {};\n\n if (!content.room_id || !content.session_key || !content.session_id || !content.algorithm) {\n this.prefixedLogger.error(\"key event is missing fields\");\n return;\n }\n\n if (!olmlib.isOlmEncrypted(event)) {\n this.prefixedLogger.error(\"key event not properly encrypted\");\n return;\n }\n\n if (content[\"org.matrix.msc3061.shared_history\"]) {\n extraSessionData.sharedHistory = true;\n }\n\n const roomKey: RoomKey = {\n senderKey: senderKey,\n sessionId: content.session_id,\n sessionKey: content.session_key,\n extraSessionData,\n exportFormat: false,\n roomId: content.room_id,\n algorithm: content.algorithm,\n forwardingKeyChain: [],\n keysClaimed: event.getKeysClaimed(),\n };\n\n return roomKey;\n }\n\n /**\n * Parse a RoomKey out of an `m.forwarded_room_key` event.\n *\n * @param event - the event containing the forwarded room key.\n *\n * @returns The `RoomKey` if it could be successfully parsed out of the\n * event.\n *\n * @internal\n *\n */\n private forwardedRoomKeyFromEvent(event: MatrixEvent): RoomKey | undefined {\n // the properties in m.forwarded_room_key are a superset of those in m.room_key, so\n // start by parsing the m.room_key fields.\n const roomKey = this.roomKeyFromEvent(event);\n\n if (!roomKey) {\n return;\n }\n\n const senderKey = event.getSenderKey()!;\n const content = event.getContent>();\n\n const senderKeyUser = this.baseApis.crypto!.deviceList.getUserByIdentityKey(olmlib.OLM_ALGORITHM, senderKey);\n\n // We received this to-device event from event.getSenderKey(), but the original\n // creator of the room key is claimed in the content.\n const claimedCurve25519Key = content.sender_key;\n const claimedEd25519Key = content.sender_claimed_ed25519_key;\n\n let forwardingKeyChain = Array.isArray(content.forwarding_curve25519_key_chain)\n ? content.forwarding_curve25519_key_chain\n : [];\n\n // copy content before we modify it\n forwardingKeyChain = forwardingKeyChain.slice();\n forwardingKeyChain.push(senderKey);\n\n // Check if we have all the fields we need.\n if (senderKeyUser !== event.getSender()) {\n this.prefixedLogger.error(\"sending device does not belong to the user it claims to be from\");\n return;\n }\n\n if (!claimedCurve25519Key) {\n this.prefixedLogger.error(\"forwarded_room_key event is missing sender_key field\");\n return;\n }\n\n if (!claimedEd25519Key) {\n this.prefixedLogger.error(`forwarded_room_key_event is missing sender_claimed_ed25519_key field`);\n return;\n }\n\n const keysClaimed = {\n ed25519: claimedEd25519Key,\n };\n\n // FIXME: We're reusing the same field to track both:\n //\n // 1. The Olm identity we've received this room key from.\n // 2. The Olm identity deduced (in the trusted case) or claiming (in the\n // untrusted case) to be the original creator of this room key.\n //\n // We now overwrite the value tracking usage 1 with the value tracking usage 2.\n roomKey.senderKey = claimedCurve25519Key;\n // Replace our keysClaimed as well.\n roomKey.keysClaimed = keysClaimed;\n roomKey.exportFormat = true;\n roomKey.forwardingKeyChain = forwardingKeyChain;\n // forwarded keys are always untrusted\n roomKey.extraSessionData.untrusted = true;\n\n return roomKey;\n }\n\n /**\n * Determine if we should accept the forwarded room key that was found in the given\n * event.\n *\n * @param event - An `m.forwarded_room_key` event.\n * @param roomKey - The room key that was found in the event.\n *\n * @returns promise that will resolve to a boolean telling us if it's ok to\n * accept the given forwarded room key.\n *\n * @internal\n *\n */\n private async shouldAcceptForwardedKey(event: MatrixEvent, roomKey: RoomKey): Promise {\n const senderKey = event.getSenderKey()!;\n\n const sendingDevice =\n this.crypto.deviceList.getDeviceByIdentityKey(olmlib.OLM_ALGORITHM, senderKey) ?? undefined;\n const deviceTrust = this.crypto.checkDeviceInfoTrust(event.getSender()!, sendingDevice);\n\n // Using the plaintext sender here is fine since we checked that the\n // sender matches to the user id in the device keys when this event was\n // originally decrypted. This can obviously only happen if the device\n // keys have been downloaded, but if they haven't the\n // `deviceTrust.isVerified()` flag would be false as well.\n //\n // It would still be far nicer if the `sendingDevice` had a user ID\n // attached to it that went through signature checks.\n const fromUs = event.getSender() === this.baseApis.getUserId();\n const keyFromOurVerifiedDevice = deviceTrust.isVerified() && fromUs;\n const weRequested = await this.wasRoomKeyRequested(event, roomKey);\n const fromInviter = this.wasRoomKeyForwardedByInviter(event, roomKey);\n const sharedAsHistory = this.wasRoomKeyForwardedAsHistory(roomKey);\n\n return (weRequested && keyFromOurVerifiedDevice) || (fromInviter && sharedAsHistory);\n }\n\n /**\n * Did we ever request the given room key from the event sender and its\n * accompanying device.\n *\n * @param event - An `m.forwarded_room_key` event.\n * @param roomKey - The room key that was found in the event.\n *\n * @internal\n *\n */\n private async wasRoomKeyRequested(event: MatrixEvent, roomKey: RoomKey): Promise {\n // We send the `m.room_key_request` out as a wildcard to-device request,\n // otherwise we would have to duplicate the same content for each\n // device. This is why we need to pass in \"*\" as the device id here.\n const outgoingRequests = await this.crypto.cryptoStore.getOutgoingRoomKeyRequestsByTarget(\n event.getSender()!,\n \"*\",\n [RoomKeyRequestState.Sent],\n );\n\n return outgoingRequests.some(\n (req) => req.requestBody.room_id === roomKey.roomId && req.requestBody.session_id === roomKey.sessionId,\n );\n }\n\n private wasRoomKeyForwardedByInviter(event: MatrixEvent, roomKey: RoomKey): boolean {\n // TODO: This is supposed to have a time limit. We should only accept\n // such keys if we happen to receive them for a recently joined room.\n const room = this.baseApis.getRoom(roomKey.roomId);\n const senderKey = event.getSenderKey();\n\n if (!senderKey) {\n return false;\n }\n\n const senderKeyUser = this.crypto.deviceList.getUserByIdentityKey(olmlib.OLM_ALGORITHM, senderKey);\n\n if (!senderKeyUser) {\n return false;\n }\n\n const memberEvent = room?.getMember(this.userId)?.events.member;\n const fromInviter =\n memberEvent?.getSender() === senderKeyUser ||\n (memberEvent?.getUnsigned()?.prev_sender === senderKeyUser &&\n memberEvent?.getPrevContent()?.membership === \"invite\");\n\n if (room && fromInviter) {\n return true;\n } else {\n return false;\n }\n }\n\n private wasRoomKeyForwardedAsHistory(roomKey: RoomKey): boolean {\n const room = this.baseApis.getRoom(roomKey.roomId);\n\n // If the key is not for a known room, then something fishy is going on,\n // so we reject the key out of caution. In practice, this is a bit moot\n // because we'll only accept shared_history forwarded by the inviter, and\n // we won't know who was the inviter for an unknown room, so we'll reject\n // it anyway.\n if (room && roomKey.extraSessionData.sharedHistory) {\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * Check if a forwarded room key should be parked.\n *\n * A forwarded room key should be parked if it's a key for a room we're not\n * in. We park the forwarded room key in case *this sender* invites us to\n * that room later.\n */\n private shouldParkForwardedKey(roomKey: RoomKey): boolean {\n const room = this.baseApis.getRoom(roomKey.roomId);\n\n if (!room && roomKey.extraSessionData.sharedHistory) {\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * Park the given room key to our store.\n *\n * @param event - An `m.forwarded_room_key` event.\n * @param roomKey - The room key that was found in the event.\n *\n * @internal\n *\n */\n private async parkForwardedKey(event: MatrixEvent, roomKey: RoomKey): Promise {\n const parkedData = {\n senderId: event.getSender()!,\n senderKey: roomKey.senderKey,\n sessionId: roomKey.sessionId,\n sessionKey: roomKey.sessionKey,\n keysClaimed: roomKey.keysClaimed,\n forwardingCurve25519KeyChain: roomKey.forwardingKeyChain,\n };\n await this.crypto.cryptoStore.doTxn(\n \"readwrite\",\n [\"parked_shared_history\"],\n (txn) => this.crypto.cryptoStore.addParkedSharedHistory(roomKey.roomId, parkedData, txn),\n logger.withPrefix(\"[addParkedSharedHistory]\"),\n );\n }\n\n /**\n * Add the given room key to our store.\n *\n * @param roomKey - The room key that should be added to the store.\n *\n * @internal\n *\n */\n private async addRoomKey(roomKey: RoomKey): Promise {\n try {\n await this.olmDevice.addInboundGroupSession(\n roomKey.roomId,\n roomKey.senderKey,\n roomKey.forwardingKeyChain,\n roomKey.sessionId,\n roomKey.sessionKey,\n roomKey.keysClaimed,\n roomKey.exportFormat,\n roomKey.extraSessionData,\n );\n\n // have another go at decrypting events sent with this session.\n if (await this.retryDecryption(roomKey.senderKey, roomKey.sessionId, !roomKey.extraSessionData.untrusted)) {\n // cancel any outstanding room key requests for this session.\n // Only do this if we managed to decrypt every message in the\n // session, because if we didn't, we leave the other key\n // requests in the hopes that someone sends us a key that\n // includes an earlier index.\n this.crypto.cancelRoomKeyRequest({\n algorithm: roomKey.algorithm,\n room_id: roomKey.roomId,\n session_id: roomKey.sessionId,\n sender_key: roomKey.senderKey,\n });\n }\n\n // don't wait for the keys to be backed up for the server\n await this.crypto.backupManager.backupGroupSession(roomKey.senderKey, roomKey.sessionId);\n } catch (e) {\n this.prefixedLogger.error(`Error handling m.room_key_event: ${e}`);\n }\n }\n\n /**\n * Handle room keys that have been forwarded to us as an\n * `m.forwarded_room_key` event.\n *\n * Forwarded room keys need special handling since we have no way of knowing\n * who the original creator of the room key was. This naturally means that\n * forwarded room keys are always untrusted and should only be accepted in\n * some cases.\n *\n * @param event - An `m.forwarded_room_key` event.\n *\n * @internal\n *\n */\n private async onForwardedRoomKey(event: MatrixEvent): Promise {\n const roomKey = this.forwardedRoomKeyFromEvent(event);\n\n if (!roomKey) {\n return;\n }\n\n if (await this.shouldAcceptForwardedKey(event, roomKey)) {\n await this.addRoomKey(roomKey);\n } else if (this.shouldParkForwardedKey(roomKey)) {\n await this.parkForwardedKey(event, roomKey);\n }\n }\n\n public async onRoomKeyEvent(event: MatrixEvent): Promise {\n if (event.getType() == \"m.forwarded_room_key\") {\n await this.onForwardedRoomKey(event);\n } else {\n const roomKey = this.roomKeyFromEvent(event);\n\n if (!roomKey) {\n return;\n }\n\n await this.addRoomKey(roomKey);\n }\n }\n\n /**\n * @param event - key event\n */\n public async onRoomKeyWithheldEvent(event: MatrixEvent): Promise {\n const content = event.getContent();\n const senderKey = content.sender_key;\n\n if (content.code === \"m.no_olm\") {\n await this.onNoOlmWithheldEvent(event);\n } else if (content.code === \"m.unavailable\") {\n // this simply means that the other device didn't have the key, which isn't very useful information. Don't\n // record it in the storage\n } else {\n await this.olmDevice.addInboundGroupSessionWithheld(\n content.room_id,\n senderKey,\n content.session_id,\n content.code,\n content.reason,\n );\n }\n\n // Having recorded the problem, retry decryption on any affected messages.\n // It's unlikely we'll be able to decrypt sucessfully now, but this will\n // update the error message.\n //\n if (content.session_id) {\n await this.retryDecryption(senderKey, content.session_id);\n } else {\n // no_olm messages aren't specific to a given megolm session, so\n // we trigger retrying decryption for all the messages from the sender's\n // key, so that we can update the error message to indicate the olm\n // session problem.\n await this.retryDecryptionFromSender(senderKey);\n }\n }\n\n private async onNoOlmWithheldEvent(event: MatrixEvent): Promise {\n const content = event.getContent();\n const senderKey = content.sender_key;\n const sender = event.getSender()!;\n this.prefixedLogger.warn(`${sender}:${senderKey} was unable to establish an olm session with us`);\n // if the sender says that they haven't been able to establish an olm\n // session, let's proactively establish one\n\n if (await this.olmDevice.getSessionIdForDevice(senderKey)) {\n // a session has already been established, so we don't need to\n // create a new one.\n this.prefixedLogger.debug(\"New session already created. Not creating a new one.\");\n await this.olmDevice.recordSessionProblem(senderKey, \"no_olm\", true);\n return;\n }\n let device = this.crypto.deviceList.getDeviceByIdentityKey(content.algorithm, senderKey);\n if (!device) {\n // if we don't know about the device, fetch the user's devices again\n // and retry before giving up\n await this.crypto.downloadKeys([sender], false);\n device = this.crypto.deviceList.getDeviceByIdentityKey(content.algorithm, senderKey);\n if (!device) {\n this.prefixedLogger.info(\n \"Couldn't find device for identity key \" + senderKey + \": not establishing session\",\n );\n await this.olmDevice.recordSessionProblem(senderKey, \"no_olm\", false);\n return;\n }\n }\n\n // XXX: switch this to use encryptAndSendToDevices() rather than duplicating it?\n\n await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, new Map([[sender, [device]]]), false);\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n [ToDeviceMessageId]: uuidv4(),\n };\n await olmlib.encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.userId,\n undefined,\n this.olmDevice,\n sender,\n device,\n { type: \"m.dummy\" },\n );\n\n await this.olmDevice.recordSessionProblem(senderKey, \"no_olm\", true);\n\n await this.baseApis.sendToDevice(\n \"m.room.encrypted\",\n new Map([[sender, new Map([[device.deviceId, encryptedContent]])]]),\n );\n }\n\n public hasKeysForKeyRequest(keyRequest: IncomingRoomKeyRequest): Promise {\n const body = keyRequest.requestBody;\n\n return this.olmDevice.hasInboundSessionKeys(\n body.room_id,\n body.sender_key,\n body.session_id,\n // TODO: ratchet index\n );\n }\n\n public shareKeysWithDevice(keyRequest: IncomingRoomKeyRequest): void {\n const userId = keyRequest.userId;\n const deviceId = keyRequest.deviceId;\n const deviceInfo = this.crypto.getStoredDevice(userId, deviceId)!;\n const body = keyRequest.requestBody;\n\n // XXX: switch this to use encryptAndSendToDevices()?\n\n this.olmlib\n .ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, new Map([[userId, [deviceInfo]]]))\n .then((devicemap) => {\n const olmSessionResult = devicemap.get(userId)?.get(deviceId);\n if (!olmSessionResult?.sessionId) {\n // no session with this device, probably because there\n // were no one-time keys.\n //\n // ensureOlmSessionsForUsers has already done the logging,\n // so just skip it.\n return null;\n }\n\n this.prefixedLogger.log(\n \"sharing keys for session \" +\n body.sender_key +\n \"|\" +\n body.session_id +\n \" with device \" +\n userId +\n \":\" +\n deviceId,\n );\n\n return this.buildKeyForwardingMessage(body.room_id, body.sender_key, body.session_id);\n })\n .then((payload) => {\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n [ToDeviceMessageId]: uuidv4(),\n };\n\n return this.olmlib\n .encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.userId,\n undefined,\n this.olmDevice,\n userId,\n deviceInfo,\n payload!,\n )\n .then(() => {\n // TODO: retries\n return this.baseApis.sendToDevice(\n \"m.room.encrypted\",\n new Map([[userId, new Map([[deviceId, encryptedContent]])]]),\n );\n });\n });\n }\n\n private async buildKeyForwardingMessage(\n roomId: string,\n senderKey: string,\n sessionId: string,\n ): Promise {\n const key = await this.olmDevice.getInboundGroupSessionKey(roomId, senderKey, sessionId);\n\n return {\n type: \"m.forwarded_room_key\",\n content: {\n \"algorithm\": olmlib.MEGOLM_ALGORITHM,\n \"room_id\": roomId,\n \"sender_key\": senderKey,\n \"sender_claimed_ed25519_key\": key!.sender_claimed_ed25519_key!,\n \"session_id\": sessionId,\n \"session_key\": key!.key,\n \"chain_index\": key!.chain_index,\n \"forwarding_curve25519_key_chain\": key!.forwarding_curve25519_key_chain,\n \"org.matrix.msc3061.shared_history\": key!.shared_history || false,\n },\n };\n }\n\n /**\n * @param untrusted - whether the key should be considered as untrusted\n * @param source - where the key came from\n */\n public importRoomKey(\n session: IMegolmSessionData,\n { untrusted, source }: { untrusted?: boolean; source?: string } = {},\n ): Promise {\n const extraSessionData: OlmGroupSessionExtraData = {};\n if (untrusted || session.untrusted) {\n extraSessionData.untrusted = true;\n }\n if (session[\"org.matrix.msc3061.shared_history\"]) {\n extraSessionData.sharedHistory = true;\n }\n return this.olmDevice\n .addInboundGroupSession(\n session.room_id,\n session.sender_key,\n session.forwarding_curve25519_key_chain,\n session.session_id,\n session.session_key,\n session.sender_claimed_keys,\n true,\n extraSessionData,\n )\n .then(() => {\n if (source !== \"backup\") {\n // don't wait for it to complete\n this.crypto.backupManager.backupGroupSession(session.sender_key, session.session_id).catch((e) => {\n // This throws if the upload failed, but this is fine\n // since it will have written it to the db and will retry.\n this.prefixedLogger.log(\"Failed to back up megolm session\", e);\n });\n }\n // have another go at decrypting events sent with this session.\n this.retryDecryption(session.sender_key, session.session_id, !extraSessionData.untrusted);\n });\n }\n\n /**\n * Have another go at decrypting events after we receive a key. Resolves once\n * decryption has been re-attempted on all events.\n *\n * @internal\n * @param forceRedecryptIfUntrusted - whether messages that were already\n * successfully decrypted using untrusted keys should be re-decrypted\n *\n * @returns whether all messages were successfully\n * decrypted with trusted keys\n */\n private async retryDecryption(\n senderKey: string,\n sessionId: string,\n forceRedecryptIfUntrusted?: boolean,\n ): Promise {\n const senderPendingEvents = this.pendingEvents.get(senderKey);\n if (!senderPendingEvents) {\n return true;\n }\n\n const pending = senderPendingEvents.get(sessionId);\n if (!pending) {\n return true;\n }\n\n const pendingList = [...pending];\n this.prefixedLogger.debug(\n \"Retrying decryption on events:\",\n pendingList.map((e) => `${e.getId()}`),\n );\n\n await Promise.all(\n pendingList.map(async (ev) => {\n try {\n await ev.attemptDecryption(this.crypto, { isRetry: true, forceRedecryptIfUntrusted });\n } catch (e) {\n // don't die if something goes wrong\n }\n }),\n );\n\n // If decrypted successfully with trusted keys, they'll have\n // been removed from pendingEvents\n return !this.pendingEvents.get(senderKey)?.has(sessionId);\n }\n\n public async retryDecryptionFromSender(senderKey: string): Promise {\n const senderPendingEvents = this.pendingEvents.get(senderKey);\n if (!senderPendingEvents) {\n return true;\n }\n\n this.pendingEvents.delete(senderKey);\n\n await Promise.all(\n [...senderPendingEvents].map(async ([_sessionId, pending]) => {\n await Promise.all(\n [...pending].map(async (ev) => {\n try {\n await ev.attemptDecryption(this.crypto);\n } catch (e) {\n // don't die if something goes wrong\n }\n }),\n );\n }),\n );\n\n return !this.pendingEvents.has(senderKey);\n }\n\n public async sendSharedHistoryInboundSessions(devicesByUser: Map): Promise {\n await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, devicesByUser);\n\n const sharedHistorySessions = await this.olmDevice.getSharedHistoryInboundGroupSessions(this.roomId);\n this.prefixedLogger.log(\n `Sharing history in with users ${Array.from(devicesByUser.keys())}`,\n sharedHistorySessions.map(([senderKey, sessionId]) => `${senderKey}|${sessionId}`),\n );\n for (const [senderKey, sessionId] of sharedHistorySessions) {\n const payload = await this.buildKeyForwardingMessage(this.roomId, senderKey, sessionId);\n\n // FIXME: use encryptAndSendToDevices() rather than duplicating it here.\n const promises: Promise[] = [];\n const contentMap: Map> = new Map();\n for (const [userId, devices] of devicesByUser) {\n const deviceMessages = new Map();\n contentMap.set(userId, deviceMessages);\n for (const deviceInfo of devices) {\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n [ToDeviceMessageId]: uuidv4(),\n };\n deviceMessages.set(deviceInfo.deviceId, encryptedContent);\n promises.push(\n olmlib.encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.userId,\n undefined,\n this.olmDevice,\n userId,\n deviceInfo,\n payload,\n ),\n );\n }\n }\n await Promise.all(promises);\n\n // prune out any devices that encryptMessageForDevice could not encrypt for,\n // in which case it will have just not added anything to the ciphertext object.\n // There's no point sending messages to devices if we couldn't encrypt to them,\n // since that's effectively a blank message.\n for (const [userId, deviceMessages] of contentMap) {\n for (const [deviceId, content] of deviceMessages) {\n if (!hasCiphertext(content)) {\n this.prefixedLogger.log(\"No ciphertext for device \" + userId + \":\" + deviceId + \": pruning\");\n deviceMessages.delete(deviceId);\n }\n }\n // No devices left for that user? Strip that too.\n if (deviceMessages.size === 0) {\n this.prefixedLogger.log(\"Pruned all devices for user \" + userId);\n contentMap.delete(userId);\n }\n }\n\n // Is there anything left?\n if (contentMap.size === 0) {\n this.prefixedLogger.log(\"No users left to send to: aborting\");\n return;\n }\n\n await this.baseApis.sendToDevice(\"m.room.encrypted\", contentMap);\n }\n }\n}\n\nconst PROBLEM_DESCRIPTIONS = {\n no_olm: \"The sender was unable to establish a secure channel.\",\n unknown: \"The secure channel with the sender was corrupted.\",\n};\n\nregisterAlgorithm(olmlib.MEGOLM_ALGORITHM, MegolmEncryption, MegolmDecryption);\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts deleted file mode 100644 index 827a070..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -export interface IMessage { - type: number; - body: string; -} -//# sourceMappingURL=olm.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts.map deleted file mode 100644 index 803f3d9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"olm.d.ts","sourceRoot":"","sources":["../../../src/crypto/algorithms/olm.ts"],"names":[],"mappings":"AAgCA,MAAM,WAAW,QAAQ;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CAChB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js deleted file mode 100644 index 3b1fb56..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js +++ /dev/null @@ -1,269 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../../logger"); -var olmlib = _interopRequireWildcard(require("../olmlib")); -var _deviceinfo = require("../deviceinfo"); -var _base = require("./base"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Defines m.olm encryption/decryption - */ - -const DeviceVerification = _deviceinfo.DeviceInfo.DeviceVerification; -/** - * Olm encryption implementation - * - * @param params - parameters, as per {@link EncryptionAlgorithm} - */ -class OlmEncryption extends _base.EncryptionAlgorithm { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "sessionPrepared", false); - (0, _defineProperty2.default)(this, "prepPromise", null); - } - /** - * @internal - * @param roomMembers - list of currently-joined users in the room - * @returns Promise which resolves when setup is complete - */ - ensureSession(roomMembers) { - if (this.prepPromise) { - // prep already in progress - return this.prepPromise; - } - if (this.sessionPrepared) { - // prep already done - return Promise.resolve(); - } - this.prepPromise = this.crypto.downloadKeys(roomMembers).then(() => { - return this.crypto.ensureOlmSessionsForUsers(roomMembers); - }).then(() => { - this.sessionPrepared = true; - }).finally(() => { - this.prepPromise = null; - }); - return this.prepPromise; - } - - /** - * @param content - plaintext event content - * - * @returns Promise which resolves to the new event body - */ - async encryptMessage(room, eventType, content) { - // pick the list of recipients based on the membership list. - // - // TODO: there is a race condition here! What if a new user turns up - // just as you are sending a secret message? - - const members = await room.getEncryptionTargetMembers(); - const users = members.map(function (u) { - return u.userId; - }); - await this.ensureSession(users); - const payloadFields = { - room_id: room.roomId, - type: eventType, - content: content - }; - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: {} - }; - const promises = []; - for (const userId of users) { - const devices = this.crypto.getStoredDevicesForUser(userId) || []; - for (const deviceInfo of devices) { - const key = deviceInfo.getIdentityKey(); - if (key == this.olmDevice.deviceCurve25519Key) { - // don't bother sending to ourself - continue; - } - if (deviceInfo.verified == DeviceVerification.BLOCKED) { - // don't bother setting up sessions with blocked users - continue; - } - promises.push(olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.userId, this.deviceId, this.olmDevice, userId, deviceInfo, payloadFields)); - } - } - return Promise.all(promises).then(() => encryptedContent); - } -} - -/** - * Olm decryption implementation - * - * @param params - parameters, as per {@link DecryptionAlgorithm} - */ -class OlmDecryption extends _base.DecryptionAlgorithm { - /** - * returns a promise which resolves to a - * {@link EventDecryptionResult} once we have finished - * decrypting. Rejects with an `algorithms.DecryptionError` if there is a - * problem decrypting the event. - */ - async decryptEvent(event) { - const content = event.getWireContent(); - const deviceKey = content.sender_key; - const ciphertext = content.ciphertext; - if (!ciphertext) { - throw new _base.DecryptionError("OLM_MISSING_CIPHERTEXT", "Missing ciphertext"); - } - if (!(this.olmDevice.deviceCurve25519Key in ciphertext)) { - throw new _base.DecryptionError("OLM_NOT_INCLUDED_IN_RECIPIENTS", "Not included in recipients"); - } - const message = ciphertext[this.olmDevice.deviceCurve25519Key]; - let payloadString; - try { - payloadString = await this.decryptMessage(deviceKey, message); - } catch (e) { - throw new _base.DecryptionError("OLM_BAD_ENCRYPTED_MESSAGE", "Bad Encrypted Message", { - sender: deviceKey, - err: e - }); - } - const payload = JSON.parse(payloadString); - - // check that we were the intended recipient, to avoid unknown-key attack - // https://github.com/vector-im/vector-web/issues/2483 - if (payload.recipient != this.userId) { - throw new _base.DecryptionError("OLM_BAD_RECIPIENT", "Message was intented for " + payload.recipient); - } - if (payload.recipient_keys.ed25519 != this.olmDevice.deviceEd25519Key) { - throw new _base.DecryptionError("OLM_BAD_RECIPIENT_KEY", "Message not intended for this device", { - intended: payload.recipient_keys.ed25519, - our_key: this.olmDevice.deviceEd25519Key - }); - } - - // check that the device that encrypted the event belongs to the user - // that the event claims it's from. We need to make sure that our - // device list is up-to-date. If the device is unknown, we can only - // assume that the device logged out. Some event handlers, such as - // secret sharing, may be more strict and reject events that come from - // unknown devices. - await this.crypto.deviceList.downloadKeys([event.getSender()], false); - const senderKeyUser = this.crypto.deviceList.getUserByIdentityKey(olmlib.OLM_ALGORITHM, deviceKey); - if (senderKeyUser !== event.getSender() && senderKeyUser != undefined) { - throw new _base.DecryptionError("OLM_BAD_SENDER", "Message claimed to be from " + event.getSender(), { - real_sender: senderKeyUser - }); - } - - // check that the original sender matches what the homeserver told us, to - // avoid people masquerading as others. - // (this check is also provided via the sender's embedded ed25519 key, - // which is checked elsewhere). - if (payload.sender != event.getSender()) { - throw new _base.DecryptionError("OLM_FORWARDED_MESSAGE", "Message forwarded from " + payload.sender, { - reported_sender: event.getSender() - }); - } - - // Olm events intended for a room have a room_id. - if (payload.room_id !== event.getRoomId()) { - throw new _base.DecryptionError("OLM_BAD_ROOM", "Message intended for room " + payload.room_id, { - reported_room: event.getRoomId() || "ROOM_ID_UNDEFINED" - }); - } - const claimedKeys = payload.keys || {}; - return { - clearEvent: payload, - senderCurve25519Key: deviceKey, - claimedEd25519Key: claimedKeys.ed25519 || null - }; - } - - /** - * Attempt to decrypt an Olm message - * - * @param theirDeviceIdentityKey - Curve25519 identity key of the sender - * @param message - message object, with 'type' and 'body' fields - * - * @returns payload, if decrypted successfully. - */ - decryptMessage(theirDeviceIdentityKey, message) { - // This is a wrapper that serialises decryptions of prekey messages, because - // otherwise we race between deciding we have no active sessions for the message - // and creating a new one, which we can only do once because it removes the OTK. - if (message.type !== 0) { - // not a prekey message: we can safely just try & decrypt it - return this.reallyDecryptMessage(theirDeviceIdentityKey, message); - } else { - const myPromise = this.olmDevice.olmPrekeyPromise.then(() => { - return this.reallyDecryptMessage(theirDeviceIdentityKey, message); - }); - // we want the error, but don't propagate it to the next decryption - this.olmDevice.olmPrekeyPromise = myPromise.catch(() => {}); - return myPromise; - } - } - async reallyDecryptMessage(theirDeviceIdentityKey, message) { - const sessionIds = await this.olmDevice.getSessionIdsForDevice(theirDeviceIdentityKey); - - // try each session in turn. - const decryptionErrors = {}; - for (const sessionId of sessionIds) { - try { - const payload = await this.olmDevice.decryptMessage(theirDeviceIdentityKey, sessionId, message.type, message.body); - _logger.logger.log("Decrypted Olm message from " + theirDeviceIdentityKey + " with session " + sessionId); - return payload; - } catch (e) { - const foundSession = await this.olmDevice.matchesSession(theirDeviceIdentityKey, sessionId, message.type, message.body); - if (foundSession) { - // decryption failed, but it was a prekey message matching this - // session, so it should have worked. - throw new Error("Error decrypting prekey message with existing session id " + sessionId + ": " + e.message); - } - - // otherwise it's probably a message for another session; carry on, but - // keep a record of the error - decryptionErrors[sessionId] = e.message; - } - } - if (message.type !== 0) { - // not a prekey message, so it should have matched an existing session, but it - // didn't work. - - if (sessionIds.length === 0) { - throw new Error("No existing sessions"); - } - throw new Error("Error decrypting non-prekey message with existing sessions: " + JSON.stringify(decryptionErrors)); - } - - // prekey message which doesn't match any existing sessions: make a new - // session. - - let res; - try { - res = await this.olmDevice.createInboundSession(theirDeviceIdentityKey, message.type, message.body); - } catch (e) { - decryptionErrors["(new)"] = e.message; - throw new Error("Error decrypting prekey message: " + JSON.stringify(decryptionErrors)); - } - _logger.logger.log("created new inbound Olm session ID " + res.session_id + " with " + theirDeviceIdentityKey); - return res.payload; - } -} -(0, _base.registerAlgorithm)(olmlib.OLM_ALGORITHM, OlmEncryption, OlmDecryption); -//# sourceMappingURL=olm.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js.map deleted file mode 100644 index a760ab6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/algorithms/olm.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"olm.js","names":["_logger","require","olmlib","_interopRequireWildcard","_deviceinfo","_base","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","DeviceVerification","DeviceInfo","OlmEncryption","EncryptionAlgorithm","constructor","args","_defineProperty2","ensureSession","roomMembers","prepPromise","sessionPrepared","Promise","resolve","crypto","downloadKeys","then","ensureOlmSessionsForUsers","finally","encryptMessage","room","eventType","content","members","getEncryptionTargetMembers","users","map","u","userId","payloadFields","room_id","roomId","type","encryptedContent","algorithm","OLM_ALGORITHM","sender_key","olmDevice","deviceCurve25519Key","ciphertext","promises","devices","getStoredDevicesForUser","deviceInfo","getIdentityKey","verified","BLOCKED","push","encryptMessageForDevice","deviceId","all","OlmDecryption","DecryptionAlgorithm","decryptEvent","event","getWireContent","deviceKey","DecryptionError","message","payloadString","decryptMessage","e","sender","err","payload","JSON","parse","recipient","recipient_keys","ed25519","deviceEd25519Key","intended","our_key","deviceList","getSender","senderKeyUser","getUserByIdentityKey","undefined","real_sender","reported_sender","getRoomId","reported_room","claimedKeys","keys","clearEvent","senderCurve25519Key","claimedEd25519Key","theirDeviceIdentityKey","reallyDecryptMessage","myPromise","olmPrekeyPromise","catch","sessionIds","getSessionIdsForDevice","decryptionErrors","sessionId","body","logger","log","foundSession","matchesSession","Error","length","stringify","res","createInboundSession","session_id","registerAlgorithm"],"sources":["../../../src/crypto/algorithms/olm.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Defines m.olm encryption/decryption\n */\n\nimport type { IEventDecryptionResult } from \"../../@types/crypto\";\nimport { logger } from \"../../logger\";\nimport * as olmlib from \"../olmlib\";\nimport { DeviceInfo } from \"../deviceinfo\";\nimport { DecryptionAlgorithm, DecryptionError, EncryptionAlgorithm, registerAlgorithm } from \"./base\";\nimport { Room } from \"../../models/room\";\nimport { IContent, MatrixEvent } from \"../../models/event\";\nimport { IEncryptedContent, IOlmEncryptedContent } from \"../index\";\nimport { IInboundSession } from \"../OlmDevice\";\n\nconst DeviceVerification = DeviceInfo.DeviceVerification;\n\nexport interface IMessage {\n type: number;\n body: string;\n}\n\n/**\n * Olm encryption implementation\n *\n * @param params - parameters, as per {@link EncryptionAlgorithm}\n */\nclass OlmEncryption extends EncryptionAlgorithm {\n private sessionPrepared = false;\n private prepPromise: Promise | null = null;\n\n /**\n * @internal\n\n * @param roomMembers - list of currently-joined users in the room\n * @returns Promise which resolves when setup is complete\n */\n private ensureSession(roomMembers: string[]): Promise {\n if (this.prepPromise) {\n // prep already in progress\n return this.prepPromise;\n }\n\n if (this.sessionPrepared) {\n // prep already done\n return Promise.resolve();\n }\n\n this.prepPromise = this.crypto\n .downloadKeys(roomMembers)\n .then(() => {\n return this.crypto.ensureOlmSessionsForUsers(roomMembers);\n })\n .then(() => {\n this.sessionPrepared = true;\n })\n .finally(() => {\n this.prepPromise = null;\n });\n\n return this.prepPromise;\n }\n\n /**\n * @param content - plaintext event content\n *\n * @returns Promise which resolves to the new event body\n */\n public async encryptMessage(room: Room, eventType: string, content: IContent): Promise {\n // pick the list of recipients based on the membership list.\n //\n // TODO: there is a race condition here! What if a new user turns up\n // just as you are sending a secret message?\n\n const members = await room.getEncryptionTargetMembers();\n\n const users = members.map(function (u) {\n return u.userId;\n });\n\n await this.ensureSession(users);\n\n const payloadFields = {\n room_id: room.roomId,\n type: eventType,\n content: content,\n };\n\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n };\n\n const promises: Promise[] = [];\n\n for (const userId of users) {\n const devices = this.crypto.getStoredDevicesForUser(userId) || [];\n\n for (const deviceInfo of devices) {\n const key = deviceInfo.getIdentityKey();\n if (key == this.olmDevice.deviceCurve25519Key) {\n // don't bother sending to ourself\n continue;\n }\n if (deviceInfo.verified == DeviceVerification.BLOCKED) {\n // don't bother setting up sessions with blocked users\n continue;\n }\n\n promises.push(\n olmlib.encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.userId,\n this.deviceId,\n this.olmDevice,\n userId,\n deviceInfo,\n payloadFields,\n ),\n );\n }\n }\n\n return Promise.all(promises).then(() => encryptedContent);\n }\n}\n\n/**\n * Olm decryption implementation\n *\n * @param params - parameters, as per {@link DecryptionAlgorithm}\n */\nclass OlmDecryption extends DecryptionAlgorithm {\n /**\n * returns a promise which resolves to a\n * {@link EventDecryptionResult} once we have finished\n * decrypting. Rejects with an `algorithms.DecryptionError` if there is a\n * problem decrypting the event.\n */\n public async decryptEvent(event: MatrixEvent): Promise {\n const content = event.getWireContent();\n const deviceKey = content.sender_key;\n const ciphertext = content.ciphertext;\n\n if (!ciphertext) {\n throw new DecryptionError(\"OLM_MISSING_CIPHERTEXT\", \"Missing ciphertext\");\n }\n\n if (!(this.olmDevice.deviceCurve25519Key! in ciphertext)) {\n throw new DecryptionError(\"OLM_NOT_INCLUDED_IN_RECIPIENTS\", \"Not included in recipients\");\n }\n const message = ciphertext[this.olmDevice.deviceCurve25519Key!];\n let payloadString: string;\n\n try {\n payloadString = await this.decryptMessage(deviceKey, message);\n } catch (e) {\n throw new DecryptionError(\"OLM_BAD_ENCRYPTED_MESSAGE\", \"Bad Encrypted Message\", {\n sender: deviceKey,\n err: e as Error,\n });\n }\n\n const payload = JSON.parse(payloadString);\n\n // check that we were the intended recipient, to avoid unknown-key attack\n // https://github.com/vector-im/vector-web/issues/2483\n if (payload.recipient != this.userId) {\n throw new DecryptionError(\"OLM_BAD_RECIPIENT\", \"Message was intented for \" + payload.recipient);\n }\n\n if (payload.recipient_keys.ed25519 != this.olmDevice.deviceEd25519Key) {\n throw new DecryptionError(\"OLM_BAD_RECIPIENT_KEY\", \"Message not intended for this device\", {\n intended: payload.recipient_keys.ed25519,\n our_key: this.olmDevice.deviceEd25519Key!,\n });\n }\n\n // check that the device that encrypted the event belongs to the user\n // that the event claims it's from. We need to make sure that our\n // device list is up-to-date. If the device is unknown, we can only\n // assume that the device logged out. Some event handlers, such as\n // secret sharing, may be more strict and reject events that come from\n // unknown devices.\n await this.crypto.deviceList.downloadKeys([event.getSender()!], false);\n const senderKeyUser = this.crypto.deviceList.getUserByIdentityKey(olmlib.OLM_ALGORITHM, deviceKey);\n if (senderKeyUser !== event.getSender() && senderKeyUser != undefined) {\n throw new DecryptionError(\"OLM_BAD_SENDER\", \"Message claimed to be from \" + event.getSender(), {\n real_sender: senderKeyUser,\n });\n }\n\n // check that the original sender matches what the homeserver told us, to\n // avoid people masquerading as others.\n // (this check is also provided via the sender's embedded ed25519 key,\n // which is checked elsewhere).\n if (payload.sender != event.getSender()) {\n throw new DecryptionError(\"OLM_FORWARDED_MESSAGE\", \"Message forwarded from \" + payload.sender, {\n reported_sender: event.getSender()!,\n });\n }\n\n // Olm events intended for a room have a room_id.\n if (payload.room_id !== event.getRoomId()) {\n throw new DecryptionError(\"OLM_BAD_ROOM\", \"Message intended for room \" + payload.room_id, {\n reported_room: event.getRoomId() || \"ROOM_ID_UNDEFINED\",\n });\n }\n\n const claimedKeys = payload.keys || {};\n\n return {\n clearEvent: payload,\n senderCurve25519Key: deviceKey,\n claimedEd25519Key: claimedKeys.ed25519 || null,\n };\n }\n\n /**\n * Attempt to decrypt an Olm message\n *\n * @param theirDeviceIdentityKey - Curve25519 identity key of the sender\n * @param message - message object, with 'type' and 'body' fields\n *\n * @returns payload, if decrypted successfully.\n */\n private decryptMessage(theirDeviceIdentityKey: string, message: IMessage): Promise {\n // This is a wrapper that serialises decryptions of prekey messages, because\n // otherwise we race between deciding we have no active sessions for the message\n // and creating a new one, which we can only do once because it removes the OTK.\n if (message.type !== 0) {\n // not a prekey message: we can safely just try & decrypt it\n return this.reallyDecryptMessage(theirDeviceIdentityKey, message);\n } else {\n const myPromise = this.olmDevice.olmPrekeyPromise.then(() => {\n return this.reallyDecryptMessage(theirDeviceIdentityKey, message);\n });\n // we want the error, but don't propagate it to the next decryption\n this.olmDevice.olmPrekeyPromise = myPromise.catch(() => {});\n return myPromise;\n }\n }\n\n private async reallyDecryptMessage(theirDeviceIdentityKey: string, message: IMessage): Promise {\n const sessionIds = await this.olmDevice.getSessionIdsForDevice(theirDeviceIdentityKey);\n\n // try each session in turn.\n const decryptionErrors: Record = {};\n for (const sessionId of sessionIds) {\n try {\n const payload = await this.olmDevice.decryptMessage(\n theirDeviceIdentityKey,\n sessionId,\n message.type,\n message.body,\n );\n logger.log(\"Decrypted Olm message from \" + theirDeviceIdentityKey + \" with session \" + sessionId);\n return payload;\n } catch (e) {\n const foundSession = await this.olmDevice.matchesSession(\n theirDeviceIdentityKey,\n sessionId,\n message.type,\n message.body,\n );\n\n if (foundSession) {\n // decryption failed, but it was a prekey message matching this\n // session, so it should have worked.\n throw new Error(\n \"Error decrypting prekey message with existing session id \" +\n sessionId +\n \": \" +\n (e).message,\n );\n }\n\n // otherwise it's probably a message for another session; carry on, but\n // keep a record of the error\n decryptionErrors[sessionId] = (e).message;\n }\n }\n\n if (message.type !== 0) {\n // not a prekey message, so it should have matched an existing session, but it\n // didn't work.\n\n if (sessionIds.length === 0) {\n throw new Error(\"No existing sessions\");\n }\n\n throw new Error(\n \"Error decrypting non-prekey message with existing sessions: \" + JSON.stringify(decryptionErrors),\n );\n }\n\n // prekey message which doesn't match any existing sessions: make a new\n // session.\n\n let res: IInboundSession;\n try {\n res = await this.olmDevice.createInboundSession(theirDeviceIdentityKey, message.type, message.body);\n } catch (e) {\n decryptionErrors[\"(new)\"] = (e).message;\n throw new Error(\"Error decrypting prekey message: \" + JSON.stringify(decryptionErrors));\n }\n\n logger.log(\"created new inbound Olm session ID \" + res.session_id + \" with \" + theirDeviceIdentityKey);\n return res.payload;\n }\n}\n\nregisterAlgorithm(olmlib.OLM_ALGORITHM, OlmEncryption, OlmDecryption);\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts deleted file mode 100644 index a01a697..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts +++ /dev/null @@ -1,89 +0,0 @@ -import { DeviceInfo } from "./deviceinfo"; -import { IKeyBackupInfo } from "./keybackup"; -import { PassphraseInfo } from "../secret-storage"; -export { PassphraseInfo as IPassphraseInfo, SecretStorageKeyDescription as ISecretStorageKeyInfo, } from "../secret-storage"; -export declare enum CrossSigningKey { - Master = "master", - SelfSigning = "self_signing", - UserSigning = "user_signing" -} -export interface IEncryptedEventInfo { - /** - * whether the event is encrypted (if not encrypted, some of the other properties may not be set) - */ - encrypted: boolean; - /** - * the sender's key - */ - senderKey: string; - /** - * the algorithm used to encrypt the event - */ - algorithm: string; - /** - * whether we can be sure that the owner of the senderKey sent the event - */ - authenticated: boolean; - /** - * the sender's device information, if available - */ - sender?: DeviceInfo; - /** - * if the event's ed25519 and curve25519 keys don't match (only meaningful if `sender` is set) - */ - mismatchedSender: boolean; -} -export interface IRecoveryKey { - keyInfo?: IAddSecretStorageKeyOpts; - privateKey: Uint8Array; - encodedPrivateKey?: string; -} -export interface ICreateSecretStorageOpts { - /** - * Function called to await a secret storage key creation flow. - * @returns Promise resolving to an object with public key metadata, encoded private - * recovery key which should be disposed of after displaying to the user, - * and raw private key to avoid round tripping if needed. - */ - createSecretStorageKey?: () => Promise; - /** - * The current key backup object. If passed, - * the passphrase and recovery key from this backup will be used. - */ - keyBackupInfo?: IKeyBackupInfo; - /** - * If true, a new key backup version will be - * created and the private key stored in the new SSSS store. Ignored if keyBackupInfo - * is supplied. - */ - setupNewKeyBackup?: boolean; - /** - * Reset even if keys already exist. - */ - setupNewSecretStorage?: boolean; - /** - * Function called to get the user's - * current key backup passphrase. Should return a promise that resolves with a Uint8Array - * containing the key, or rejects if the key cannot be obtained. - */ - getKeyBackupPassphrase?: () => Promise; -} -export interface IAddSecretStorageKeyOpts { - pubkey?: string; - passphrase?: PassphraseInfo; - name?: string; - key?: Uint8Array; -} -export interface IImportOpts { - stage: string; - successes: number; - failures: number; - total: number; -} -export interface IImportRoomKeysOpts { - /** called with an object that has a "stage" param */ - progressCallback?: (stage: IImportOpts) => void; - untrusted?: boolean; - source?: string; -} -//# sourceMappingURL=api.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts.map deleted file mode 100644 index ceeb45b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../src/crypto/api.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,OAAO,EACH,cAAc,IAAI,eAAe,EACjC,2BAA2B,IAAI,qBAAqB,GACvD,MAAM,mBAAmB,CAAC;AAI3B,oBAAY,eAAe;IACvB,MAAM,WAAW;IACjB,WAAW,iBAAiB;IAC5B,WAAW,iBAAiB;CAC/B;AAED,MAAM,WAAW,mBAAmB;IAChC;;OAEG;IACH,SAAS,EAAE,OAAO,CAAC;IAEnB;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAElB;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAElB;;OAEG;IACH,aAAa,EAAE,OAAO,CAAC;IAEvB;;OAEG;IACH,MAAM,CAAC,EAAE,UAAU,CAAC;IAEpB;;OAEG;IACH,gBAAgB,EAAE,OAAO,CAAC;CAC7B;AAED,MAAM,WAAW,YAAY;IACzB,OAAO,CAAC,EAAE,wBAAwB,CAAC;IACnC,UAAU,EAAE,UAAU,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED,MAAM,WAAW,wBAAwB;IACrC;;;;;OAKG;IACH,sBAAsB,CAAC,EAAE,MAAM,OAAO,CAAC,YAAY,CAAC,CAAC;IAErD;;;OAGG;IACH,aAAa,CAAC,EAAE,cAAc,CAAC;IAE/B;;;;OAIG;IACH,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAE5B;;OAEG;IACH,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAEhC;;;;OAIG;IACH,sBAAsB,CAAC,EAAE,MAAM,OAAO,CAAC,UAAU,CAAC,CAAC;CACtD;AAED,MAAM,WAAW,wBAAwB;IACrC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,cAAc,CAAC;IAC5B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,UAAU,CAAC;CACpB;AAED,MAAM,WAAW,WAAW;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,mBAAmB;IAChC,qDAAqD;IACrD,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,IAAI,CAAC;IAChD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;CACnB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js deleted file mode 100644 index ac3ef1e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js +++ /dev/null @@ -1,44 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.CrossSigningKey = void 0; -Object.defineProperty(exports, "IPassphraseInfo", { - enumerable: true, - get: function () { - return _secretStorage.PassphraseInfo; - } -}); -Object.defineProperty(exports, "ISecretStorageKeyInfo", { - enumerable: true, - get: function () { - return _secretStorage.SecretStorageKeyDescription; - } -}); -var _secretStorage = require("../secret-storage"); -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -/* re-exports for backwards compatibility. */ -// TODO: Merge this with crypto.js once converted -let CrossSigningKey; -exports.CrossSigningKey = CrossSigningKey; -(function (CrossSigningKey) { - CrossSigningKey["Master"] = "master"; - CrossSigningKey["SelfSigning"] = "self_signing"; - CrossSigningKey["UserSigning"] = "user_signing"; -})(CrossSigningKey || (exports.CrossSigningKey = CrossSigningKey = {})); -//# sourceMappingURL=api.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js.map deleted file mode 100644 index 810699f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/api.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"api.js","names":["_secretStorage","require","CrossSigningKey","exports"],"sources":["../../src/crypto/api.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { DeviceInfo } from \"./deviceinfo\";\nimport { IKeyBackupInfo } from \"./keybackup\";\nimport { PassphraseInfo } from \"../secret-storage\";\n\n/* re-exports for backwards compatibility. */\nexport {\n PassphraseInfo as IPassphraseInfo,\n SecretStorageKeyDescription as ISecretStorageKeyInfo,\n} from \"../secret-storage\";\n\n// TODO: Merge this with crypto.js once converted\n\nexport enum CrossSigningKey {\n Master = \"master\",\n SelfSigning = \"self_signing\",\n UserSigning = \"user_signing\",\n}\n\nexport interface IEncryptedEventInfo {\n /**\n * whether the event is encrypted (if not encrypted, some of the other properties may not be set)\n */\n encrypted: boolean;\n\n /**\n * the sender's key\n */\n senderKey: string;\n\n /**\n * the algorithm used to encrypt the event\n */\n algorithm: string;\n\n /**\n * whether we can be sure that the owner of the senderKey sent the event\n */\n authenticated: boolean;\n\n /**\n * the sender's device information, if available\n */\n sender?: DeviceInfo;\n\n /**\n * if the event's ed25519 and curve25519 keys don't match (only meaningful if `sender` is set)\n */\n mismatchedSender: boolean;\n}\n\nexport interface IRecoveryKey {\n keyInfo?: IAddSecretStorageKeyOpts;\n privateKey: Uint8Array;\n encodedPrivateKey?: string;\n}\n\nexport interface ICreateSecretStorageOpts {\n /**\n * Function called to await a secret storage key creation flow.\n * @returns Promise resolving to an object with public key metadata, encoded private\n * recovery key which should be disposed of after displaying to the user,\n * and raw private key to avoid round tripping if needed.\n */\n createSecretStorageKey?: () => Promise;\n\n /**\n * The current key backup object. If passed,\n * the passphrase and recovery key from this backup will be used.\n */\n keyBackupInfo?: IKeyBackupInfo;\n\n /**\n * If true, a new key backup version will be\n * created and the private key stored in the new SSSS store. Ignored if keyBackupInfo\n * is supplied.\n */\n setupNewKeyBackup?: boolean;\n\n /**\n * Reset even if keys already exist.\n */\n setupNewSecretStorage?: boolean;\n\n /**\n * Function called to get the user's\n * current key backup passphrase. Should return a promise that resolves with a Uint8Array\n * containing the key, or rejects if the key cannot be obtained.\n */\n getKeyBackupPassphrase?: () => Promise;\n}\n\nexport interface IAddSecretStorageKeyOpts {\n pubkey?: string;\n passphrase?: PassphraseInfo;\n name?: string;\n key?: Uint8Array;\n}\n\nexport interface IImportOpts {\n stage: string; // TODO: Enum\n successes: number;\n failures: number;\n total: number;\n}\n\nexport interface IImportRoomKeysOpts {\n /** called with an object that has a \"stage\" param */\n progressCallback?: (stage: IImportOpts) => void;\n untrusted?: boolean;\n source?: string; // TODO: Enum\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAqBA,IAAAA,cAAA,GAAAC,OAAA;AArBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AAMA;AAAA,IAEYC,eAAe;AAAAC,OAAA,CAAAD,eAAA,GAAAA,eAAA;AAAA,WAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;AAAA,GAAfA,eAAe,KAAAC,OAAA,CAAAD,eAAA,GAAfA,eAAe"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts deleted file mode 100644 index 143b2bb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts +++ /dev/null @@ -1,184 +0,0 @@ -/** - * Classes for dealing with key backup. - */ -import type { IMegolmSessionData } from "../@types/crypto"; -import { MatrixClient } from "../client"; -import { DeviceInfo } from "./deviceinfo"; -import { DeviceTrustLevel } from "./CrossSigning"; -import { IEncryptedPayload } from "./aes"; -import { Curve25519SessionData, IAes256AuthData, ICurve25519AuthData, IKeyBackupInfo, IKeyBackupSession } from "./keybackup"; -type AuthData = IKeyBackupInfo["auth_data"]; -type SigInfo = { - deviceId: string; - valid?: boolean | null; - device?: DeviceInfo | null; - crossSigningId?: boolean; - deviceTrust?: DeviceTrustLevel; -}; -export type TrustInfo = { - usable: boolean; - sigs: SigInfo[]; - trusted_locally?: boolean; -}; -export interface IKeyBackupCheck { - backupInfo?: IKeyBackupInfo; - trustInfo: TrustInfo; -} -export interface IPreparedKeyBackupVersion { - algorithm: string; - auth_data: AuthData; - recovery_key: string; - privateKey: Uint8Array; -} -/** A function used to get the secret key for a backup. - */ -type GetKey = () => Promise>; -interface BackupAlgorithmClass { - algorithmName: string; - init(authData: AuthData, getKey: GetKey): Promise; - prepare(key?: string | Uint8Array | null): Promise<[Uint8Array, AuthData]>; - checkBackupVersion(info: IKeyBackupInfo): void; -} -interface BackupAlgorithm { - untrusted: boolean; - encryptSession(data: Record): Promise; - decryptSessions(ciphertexts: Record): Promise; - authData: AuthData; - keyMatches(key: ArrayLike): Promise; - free(): void; -} -export interface IKeyBackup { - rooms: { - [roomId: string]: { - sessions: { - [sessionId: string]: IKeyBackupSession; - }; - }; - }; -} -/** - * Manages the key backup. - */ -export declare class BackupManager { - private readonly baseApis; - readonly getKey: GetKey; - private algorithm; - backupInfo: IKeyBackupInfo | undefined; - checkedForBackup: boolean; - private sendingBackups; - private sessionLastCheckAttemptedTime; - constructor(baseApis: MatrixClient, getKey: GetKey); - get version(): string | undefined; - /** - * Performs a quick check to ensure that the backup info looks sane. - * - * Throws an error if a problem is detected. - * - * @param info - the key backup info - */ - static checkBackupVersion(info: IKeyBackupInfo): void; - static makeAlgorithm(info: IKeyBackupInfo, getKey: GetKey): Promise; - enableKeyBackup(info: IKeyBackupInfo): Promise; - /** - * Disable backing up of keys. - */ - disableKeyBackup(): void; - getKeyBackupEnabled(): boolean | null; - prepareKeyBackupVersion(key?: string | Uint8Array | null, algorithm?: string | undefined): Promise; - createKeyBackupVersion(info: IKeyBackupInfo): Promise; - /** - * Check the server for an active key backup and - * if one is present and has a valid signature from - * one of the user's verified devices, start backing up - * to it. - */ - checkAndStart(): Promise; - /** - * Forces a re-check of the key backup and enables/disables it - * as appropriate. - * - * @returns Object with backup info (as returned by - * getKeyBackupVersion) in backupInfo and - * trust information (as returned by isKeyBackupTrusted) - * in trustInfo. - */ - checkKeyBackup(): Promise; - /** - * Attempts to retrieve a session from a key backup, if enough time - * has elapsed since the last check for this session id. - */ - queryKeyBackupRateLimited(targetRoomId: string | undefined, targetSessionId: string | undefined): Promise; - /** - * Check if the given backup info is trusted. - * - * @param backupInfo - key backup info dict from /room_keys/version - */ - isKeyBackupTrusted(backupInfo?: IKeyBackupInfo): Promise; - /** - * Schedules sending all keys waiting to be sent to the backup, if not already - * scheduled. Retries if necessary. - * - * @param maxDelay - Maximum delay to wait in ms. 0 means no delay. - */ - scheduleKeyBackupSend(maxDelay?: number): Promise; - /** - * Take some e2e keys waiting to be backed up and send them - * to the backup. - * - * @param limit - Maximum number of keys to back up - * @returns Number of sessions backed up - */ - backupPendingKeys(limit: number): Promise; - backupGroupSession(senderKey: string, sessionId: string): Promise; - /** - * Marks all group sessions as needing to be backed up and schedules them to - * upload in the background as soon as possible. - */ - scheduleAllGroupSessionsForBackup(): Promise; - /** - * Marks all group sessions as needing to be backed up without scheduling - * them to upload in the background. - * @returns Promise which resolves to the number of sessions now requiring a backup - * (which will be equal to the number of sessions in the store). - */ - flagAllGroupSessionsForBackup(): Promise; - /** - * Counts the number of end to end session keys that are waiting to be backed up - * @returns Promise which resolves to the number of sessions requiring backup - */ - countSessionsNeedingBackup(): Promise; -} -export declare class Curve25519 implements BackupAlgorithm { - authData: ICurve25519AuthData; - private publicKey; - private getKey; - static algorithmName: string; - constructor(authData: ICurve25519AuthData, publicKey: any, // FIXME: PkEncryption - getKey: () => Promise); - static init(authData: AuthData, getKey: () => Promise): Promise; - static prepare(key?: string | Uint8Array | null): Promise<[Uint8Array, AuthData]>; - static checkBackupVersion(info: IKeyBackupInfo): void; - get untrusted(): boolean; - encryptSession(data: Record): Promise; - decryptSessions(sessions: Record>): Promise; - keyMatches(key: Uint8Array): Promise; - free(): void; -} -export declare class Aes256 implements BackupAlgorithm { - readonly authData: IAes256AuthData; - private readonly key; - static algorithmName: "org.matrix.msc3270.v1.aes-hmac-sha2"; - constructor(authData: IAes256AuthData, key: Uint8Array); - static init(authData: IAes256AuthData, getKey: () => Promise): Promise; - static prepare(key?: string | Uint8Array | null): Promise<[Uint8Array, AuthData]>; - static checkBackupVersion(info: IKeyBackupInfo): void; - get untrusted(): boolean; - encryptSession(data: Record): Promise; - decryptSessions(sessions: Record>): Promise; - keyMatches(key: Uint8Array): Promise; - free(): void; -} -export declare const algorithmsByName: Record; -export declare const DefaultAlgorithm: BackupAlgorithmClass; -export {}; -//# sourceMappingURL=backup.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts.map deleted file mode 100644 index 5161b6e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"backup.d.ts","sourceRoot":"","sources":["../../src/crypto/backup.ts"],"names":[],"mappings":"AAgBA;;GAEG;AAEH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAGzC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAKlD,OAAO,EAA6C,iBAAiB,EAAE,MAAM,OAAO,CAAC;AACrF,OAAO,EACH,qBAAqB,EACrB,eAAe,EACf,mBAAmB,EACnB,cAAc,EACd,iBAAiB,EACpB,MAAM,aAAa,CAAC;AASrB,KAAK,QAAQ,GAAG,cAAc,CAAC,WAAW,CAAC,CAAC;AAE5C,KAAK,OAAO,GAAG;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IACvB,MAAM,CAAC,EAAE,UAAU,GAAG,IAAI,CAAC;IAC3B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,WAAW,CAAC,EAAE,gBAAgB,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG;IACpB,MAAM,EAAE,OAAO,CAAC;IAChB,IAAI,EAAE,OAAO,EAAE,CAAC;IAEhB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC7B,CAAC;AAEF,MAAM,WAAW,eAAe;IAC5B,UAAU,CAAC,EAAE,cAAc,CAAC;IAC5B,SAAS,EAAE,SAAS,CAAC;CACxB;AAGD,MAAM,WAAW,yBAAyB;IACtC,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,QAAQ,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,UAAU,CAAC;CAC1B;AAGD;GACG;AACH,KAAK,MAAM,GAAG,MAAM,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;AAE/C,UAAU,oBAAoB;IAC1B,aAAa,EAAE,MAAM,CAAC;IAEtB,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;IAGnE,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;IAE3E,kBAAkB,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,CAAC;CAClD;AAED,UAAU,eAAe;IACrB,SAAS,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,qBAAqB,GAAG,iBAAiB,CAAC,CAAC;IAC9F,eAAe,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAAC;IAC/F,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,CAAC,GAAG,EAAE,SAAS,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IACrD,IAAI,IAAI,IAAI,CAAC;CAChB;AAED,MAAM,WAAW,UAAU;IACvB,KAAK,EAAE;QACH,CAAC,MAAM,EAAE,MAAM,GAAG;YACd,QAAQ,EAAE;gBACN,CAAC,SAAS,EAAE,MAAM,GAAG,iBAAiB,CAAC;aAC1C,CAAC;SACL,CAAC;KACL,CAAC;CACL;AAED;;GAEG;AACH,qBAAa,aAAa;IAOH,OAAO,CAAC,QAAQ,CAAC,QAAQ;aAAgC,MAAM,EAAE,MAAM;IAN1F,OAAO,CAAC,SAAS,CAA8B;IACxC,UAAU,EAAE,cAAc,GAAG,SAAS,CAAC;IACvC,gBAAgB,EAAE,OAAO,CAAC;IACjC,OAAO,CAAC,cAAc,CAAU;IAChC,OAAO,CAAC,6BAA6B,CAA8B;gBAE/B,QAAQ,EAAE,YAAY,EAAkB,MAAM,EAAE,MAAM;IAK1F,IAAW,OAAO,IAAI,MAAM,GAAG,SAAS,CAEvC;IAED;;;;;;OAMG;WACW,kBAAkB,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;WAW9C,aAAa,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC;IAQ9E,eAAe,CAAC,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAejE;;OAEG;IACI,gBAAgB,IAAI,IAAI;IAWxB,mBAAmB,IAAI,OAAO,GAAG,IAAI;IAO/B,uBAAuB,CAChC,GAAG,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,EAChC,SAAS,CAAC,EAAE,MAAM,GAAG,SAAS,GAC/B,OAAO,CAAC,yBAAyB,CAAC;IAgBxB,sBAAsB,CAAC,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAIxE;;;;;OAKG;IACU,aAAa,IAAI,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;IAsD7D;;;;;;;;OAQG;IACU,cAAc,IAAI,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;IAK9D;;;OAGG;IACU,yBAAyB,CAClC,YAAY,EAAE,MAAM,GAAG,SAAS,EAChC,eAAe,EAAE,MAAM,GAAG,SAAS,GACpC,OAAO,CAAC,IAAI,CAAC;IAehB;;;;OAIG;IACU,kBAAkB,CAAC,UAAU,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,SAAS,CAAC;IA4GhF;;;;;OAKG;IACU,qBAAqB,CAAC,QAAQ,SAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAmDnE;;;;;;OAMG;IACU,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IA8CjD,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBpF;;;OAGG;IACU,iCAAiC,IAAI,OAAO,CAAC,IAAI,CAAC;IAO/D;;;;;OAKG;IACU,6BAA6B,IAAI,OAAO,CAAC,MAAM,CAAC;IAkB7D;;;OAGG;IACI,0BAA0B,IAAI,OAAO,CAAC,MAAM,CAAC;CAGvD;AAED,qBAAa,UAAW,YAAW,eAAe;IAInC,QAAQ,EAAE,mBAAmB;IACpC,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,MAAM;IALlB,OAAc,aAAa,SAA4C;gBAG5D,QAAQ,EAAE,mBAAmB,EAC5B,SAAS,EAAE,GAAG,EAAE,sBAAsB;IACtC,MAAM,EAAE,MAAM,OAAO,CAAC,UAAU,CAAC;WAGzB,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC;WAShF,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;WAuBhF,kBAAkB,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAM5D,IAAW,SAAS,IAAI,OAAO,CAE9B;IAEY,cAAc,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAQzE,eAAe,CACxB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,qBAAqB,CAAC,CAAC,GACnE,OAAO,CAAC,kBAAkB,EAAE,CAAC;IAiCnB,UAAU,CAAC,GAAG,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC;IAYnD,IAAI,IAAI,IAAI;CAGtB;AAaD,qBAAa,MAAO,YAAW,eAAe;aAGP,QAAQ,EAAE,eAAe;IAAE,OAAO,CAAC,QAAQ,CAAC,GAAG;IAFlF,OAAc,aAAa,wCAA8B;gBAEtB,QAAQ,EAAE,eAAe,EAAmB,GAAG,EAAE,UAAU;WAE1E,IAAI,CAAC,QAAQ,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;WAcnF,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;WAqBhF,kBAAkB,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAM5D,IAAW,SAAS,IAAI,OAAO,CAE9B;IAEM,cAAc,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAQ/D,eAAe,CACxB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,iBAAiB,CAAC,CAAC,GAC/D,OAAO,CAAC,kBAAkB,EAAE,CAAC;IAenB,UAAU,CAAC,GAAG,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC;IAUnD,IAAI,IAAI,IAAI;CAGtB;AAED,eAAO,MAAM,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE,oBAAoB,CAGjE,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,oBAAiC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js deleted file mode 100644 index ae42cce..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js +++ /dev/null @@ -1,654 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.algorithmsByName = exports.DefaultAlgorithm = exports.Curve25519 = exports.BackupManager = exports.Aes256 = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _client = require("../client"); -var _logger = require("../logger"); -var _olmlib = require("./olmlib"); -var _key_passphrase = require("./key_passphrase"); -var _utils = require("../utils"); -var _indexeddbCryptoStore = require("./store/indexeddb-crypto-store"); -var _recoverykey = require("./recoverykey"); -var _aes = require("./aes"); -var _NamespacedValue = require("../NamespacedValue"); -var _index = require("./index"); -var _crypto = require("./crypto"); -var _httpApi = require("../http-api"); -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Classes for dealing with key backup. - */ - -const KEY_BACKUP_KEYS_PER_REQUEST = 200; -const KEY_BACKUP_CHECK_RATE_LIMIT = 5000; // ms - -/** - * Manages the key backup. - */ -class BackupManager { - // The info dict from /room_keys/version - // Have we checked the server for a backup we can use? - // Are we currently sending backups? - // When did we last try to check the server for a given session id? - - constructor(baseApis, getKey) { - this.baseApis = baseApis; - this.getKey = getKey; - (0, _defineProperty2.default)(this, "algorithm", void 0); - (0, _defineProperty2.default)(this, "backupInfo", void 0); - (0, _defineProperty2.default)(this, "checkedForBackup", void 0); - (0, _defineProperty2.default)(this, "sendingBackups", void 0); - (0, _defineProperty2.default)(this, "sessionLastCheckAttemptedTime", {}); - this.checkedForBackup = false; - this.sendingBackups = false; - } - get version() { - return this.backupInfo && this.backupInfo.version; - } - - /** - * Performs a quick check to ensure that the backup info looks sane. - * - * Throws an error if a problem is detected. - * - * @param info - the key backup info - */ - static checkBackupVersion(info) { - const Algorithm = algorithmsByName[info.algorithm]; - if (!Algorithm) { - throw new Error("Unknown backup algorithm: " + info.algorithm); - } - if (typeof info.auth_data !== "object") { - throw new Error("Invalid backup data returned"); - } - return Algorithm.checkBackupVersion(info); - } - static makeAlgorithm(info, getKey) { - const Algorithm = algorithmsByName[info.algorithm]; - if (!Algorithm) { - throw new Error("Unknown backup algorithm"); - } - return Algorithm.init(info.auth_data, getKey); - } - async enableKeyBackup(info) { - this.backupInfo = info; - if (this.algorithm) { - this.algorithm.free(); - } - this.algorithm = await BackupManager.makeAlgorithm(info, this.getKey); - this.baseApis.emit(_index.CryptoEvent.KeyBackupStatus, true); - - // There may be keys left over from a partially completed backup, so - // schedule a send to check. - this.scheduleKeyBackupSend(); - } - - /** - * Disable backing up of keys. - */ - disableKeyBackup() { - if (this.algorithm) { - this.algorithm.free(); - } - this.algorithm = undefined; - this.backupInfo = undefined; - this.baseApis.emit(_index.CryptoEvent.KeyBackupStatus, false); - } - getKeyBackupEnabled() { - if (!this.checkedForBackup) { - return null; - } - return Boolean(this.algorithm); - } - async prepareKeyBackupVersion(key, algorithm) { - const Algorithm = algorithm ? algorithmsByName[algorithm] : DefaultAlgorithm; - if (!Algorithm) { - throw new Error("Unknown backup algorithm"); - } - const [privateKey, authData] = await Algorithm.prepare(key); - const recoveryKey = (0, _recoverykey.encodeRecoveryKey)(privateKey); - return { - algorithm: Algorithm.algorithmName, - auth_data: authData, - recovery_key: recoveryKey, - privateKey - }; - } - async createKeyBackupVersion(info) { - this.algorithm = await BackupManager.makeAlgorithm(info, this.getKey); - } - - /** - * Check the server for an active key backup and - * if one is present and has a valid signature from - * one of the user's verified devices, start backing up - * to it. - */ - async checkAndStart() { - _logger.logger.log("Checking key backup status..."); - if (this.baseApis.isGuest()) { - _logger.logger.log("Skipping key backup check since user is guest"); - this.checkedForBackup = true; - return null; - } - let backupInfo; - try { - var _await$this$baseApis$; - backupInfo = (_await$this$baseApis$ = await this.baseApis.getKeyBackupVersion()) !== null && _await$this$baseApis$ !== void 0 ? _await$this$baseApis$ : undefined; - } catch (e) { - _logger.logger.log("Error checking for active key backup", e); - if (e.httpStatus === 404) { - // 404 is returned when the key backup does not exist, so that - // counts as successfully checking. - this.checkedForBackup = true; - } - return null; - } - this.checkedForBackup = true; - const trustInfo = await this.isKeyBackupTrusted(backupInfo); - if (trustInfo.usable && !this.backupInfo) { - _logger.logger.log(`Found usable key backup v${backupInfo.version}: enabling key backups`); - await this.enableKeyBackup(backupInfo); - } else if (!trustInfo.usable && this.backupInfo) { - _logger.logger.log("No usable key backup: disabling key backup"); - this.disableKeyBackup(); - } else if (!trustInfo.usable && !this.backupInfo) { - _logger.logger.log("No usable key backup: not enabling key backup"); - } else if (trustInfo.usable && this.backupInfo) { - // may not be the same version: if not, we should switch - if (backupInfo.version !== this.backupInfo.version) { - _logger.logger.log(`On backup version ${this.backupInfo.version} but ` + `found version ${backupInfo.version}: switching.`); - this.disableKeyBackup(); - await this.enableKeyBackup(backupInfo); - // We're now using a new backup, so schedule all the keys we have to be - // uploaded to the new backup. This is a bit of a workaround to upload - // keys to a new backup in *most* cases, but it won't cover all cases - // because we don't remember what backup version we uploaded keys to: - // see https://github.com/vector-im/element-web/issues/14833 - await this.scheduleAllGroupSessionsForBackup(); - } else { - _logger.logger.log(`Backup version ${backupInfo.version} still current`); - } - } - return { - backupInfo, - trustInfo - }; - } - - /** - * Forces a re-check of the key backup and enables/disables it - * as appropriate. - * - * @returns Object with backup info (as returned by - * getKeyBackupVersion) in backupInfo and - * trust information (as returned by isKeyBackupTrusted) - * in trustInfo. - */ - async checkKeyBackup() { - this.checkedForBackup = false; - return this.checkAndStart(); - } - - /** - * Attempts to retrieve a session from a key backup, if enough time - * has elapsed since the last check for this session id. - */ - async queryKeyBackupRateLimited(targetRoomId, targetSessionId) { - if (!this.backupInfo) { - return; - } - const now = new Date().getTime(); - if (!this.sessionLastCheckAttemptedTime[targetSessionId] || now - this.sessionLastCheckAttemptedTime[targetSessionId] > KEY_BACKUP_CHECK_RATE_LIMIT) { - this.sessionLastCheckAttemptedTime[targetSessionId] = now; - await this.baseApis.restoreKeyBackupWithCache(targetRoomId, targetSessionId, this.backupInfo, {}); - } - } - - /** - * Check if the given backup info is trusted. - * - * @param backupInfo - key backup info dict from /room_keys/version - */ - async isKeyBackupTrusted(backupInfo) { - const ret = { - usable: false, - trusted_locally: false, - sigs: [] - }; - if (!backupInfo || !backupInfo.algorithm || !backupInfo.auth_data || !backupInfo.auth_data.signatures) { - _logger.logger.info("Key backup is absent or missing required data"); - return ret; - } - const userId = this.baseApis.getUserId(); - const privKey = await this.baseApis.crypto.getSessionBackupPrivateKey(); - if (privKey) { - let algorithm = null; - try { - algorithm = await BackupManager.makeAlgorithm(backupInfo, async () => privKey); - if (await algorithm.keyMatches(privKey)) { - _logger.logger.info("Backup is trusted locally"); - ret.trusted_locally = true; - } - } catch { - // do nothing -- if we have an error, then we don't mark it as - // locally trusted - } finally { - var _algorithm; - (_algorithm = algorithm) === null || _algorithm === void 0 ? void 0 : _algorithm.free(); - } - } - const mySigs = backupInfo.auth_data.signatures[userId] || {}; - for (const keyId of Object.keys(mySigs)) { - const keyIdParts = keyId.split(":"); - if (keyIdParts[0] !== "ed25519") { - _logger.logger.log("Ignoring unknown signature type: " + keyIdParts[0]); - continue; - } - // Could be a cross-signing master key, but just say this is the device - // ID for backwards compat - const sigInfo = { - deviceId: keyIdParts[1] - }; - - // first check to see if it's from our cross-signing key - const crossSigningId = this.baseApis.crypto.crossSigningInfo.getId(); - if (crossSigningId === sigInfo.deviceId) { - sigInfo.crossSigningId = true; - try { - await (0, _olmlib.verifySignature)(this.baseApis.crypto.olmDevice, backupInfo.auth_data, userId, sigInfo.deviceId, crossSigningId); - sigInfo.valid = true; - } catch (e) { - _logger.logger.warn("Bad signature from cross signing key " + crossSigningId, e); - sigInfo.valid = false; - } - ret.sigs.push(sigInfo); - continue; - } - - // Now look for a sig from a device - // At some point this can probably go away and we'll just support - // it being signed by the cross-signing master key - const device = this.baseApis.crypto.deviceList.getStoredDevice(userId, sigInfo.deviceId); - if (device) { - sigInfo.device = device; - sigInfo.deviceTrust = this.baseApis.checkDeviceTrust(userId, sigInfo.deviceId); - try { - await (0, _olmlib.verifySignature)(this.baseApis.crypto.olmDevice, backupInfo.auth_data, userId, device.deviceId, device.getFingerprint()); - sigInfo.valid = true; - } catch (e) { - _logger.logger.info("Bad signature from key ID " + keyId + " userID " + this.baseApis.getUserId() + " device ID " + device.deviceId + " fingerprint: " + device.getFingerprint(), backupInfo.auth_data, e); - sigInfo.valid = false; - } - } else { - sigInfo.valid = null; // Can't determine validity because we don't have the signing device - _logger.logger.info("Ignoring signature from unknown key " + keyId); - } - ret.sigs.push(sigInfo); - } - ret.usable = ret.sigs.some(s => { - var _s$deviceTrust; - return s.valid && (s.device && ((_s$deviceTrust = s.deviceTrust) === null || _s$deviceTrust === void 0 ? void 0 : _s$deviceTrust.isVerified()) || s.crossSigningId); - }); - return ret; - } - - /** - * Schedules sending all keys waiting to be sent to the backup, if not already - * scheduled. Retries if necessary. - * - * @param maxDelay - Maximum delay to wait in ms. 0 means no delay. - */ - async scheduleKeyBackupSend(maxDelay = 10000) { - if (this.sendingBackups) return; - this.sendingBackups = true; - try { - // wait between 0 and `maxDelay` seconds, to avoid backup - // requests from different clients hitting the server all at - // the same time when a new key is sent - const delay = Math.random() * maxDelay; - await (0, _utils.sleep)(delay); - let numFailures = 0; // number of consecutive failures - for (;;) { - if (!this.algorithm) { - return; - } - try { - const numBackedUp = await this.backupPendingKeys(KEY_BACKUP_KEYS_PER_REQUEST); - if (numBackedUp === 0) { - // no sessions left needing backup: we're done - return; - } - numFailures = 0; - } catch (err) { - numFailures++; - _logger.logger.log("Key backup request failed", err); - if (err.data) { - if (err.data.errcode == "M_NOT_FOUND" || err.data.errcode == "M_WRONG_ROOM_KEYS_VERSION") { - // Re-check key backup status on error, so we can be - // sure to present the current situation when asked. - await this.checkKeyBackup(); - // Backup version has changed or this backup version - // has been deleted - this.baseApis.crypto.emit(_index.CryptoEvent.KeyBackupFailed, err.data.errcode); - throw err; - } - } - } - if (numFailures) { - // exponential backoff if we have failures - await (0, _utils.sleep)(1000 * Math.pow(2, Math.min(numFailures - 1, 4))); - } - } - } finally { - this.sendingBackups = false; - } - } - - /** - * Take some e2e keys waiting to be backed up and send them - * to the backup. - * - * @param limit - Maximum number of keys to back up - * @returns Number of sessions backed up - */ - async backupPendingKeys(limit) { - const sessions = await this.baseApis.crypto.cryptoStore.getSessionsNeedingBackup(limit); - if (!sessions.length) { - return 0; - } - let remaining = await this.baseApis.crypto.cryptoStore.countSessionsNeedingBackup(); - this.baseApis.crypto.emit(_index.CryptoEvent.KeyBackupSessionsRemaining, remaining); - const rooms = {}; - for (const session of sessions) { - var _deviceList$getDevice; - const roomId = session.sessionData.room_id; - (0, _utils.safeSet)(rooms, roomId, rooms[roomId] || { - sessions: {} - }); - const sessionData = this.baseApis.crypto.olmDevice.exportInboundGroupSession(session.senderKey, session.sessionId, session.sessionData); - sessionData.algorithm = _olmlib.MEGOLM_ALGORITHM; - const forwardedCount = (sessionData.forwarding_curve25519_key_chain || []).length; - const userId = this.baseApis.crypto.deviceList.getUserByIdentityKey(_olmlib.MEGOLM_ALGORITHM, session.senderKey); - const device = (_deviceList$getDevice = this.baseApis.crypto.deviceList.getDeviceByIdentityKey(_olmlib.MEGOLM_ALGORITHM, session.senderKey)) !== null && _deviceList$getDevice !== void 0 ? _deviceList$getDevice : undefined; - const verified = this.baseApis.crypto.checkDeviceInfoTrust(userId, device).isVerified(); - (0, _utils.safeSet)(rooms[roomId]["sessions"], session.sessionId, { - first_message_index: sessionData.first_known_index, - forwarded_count: forwardedCount, - is_verified: verified, - session_data: await this.algorithm.encryptSession(sessionData) - }); - } - await this.baseApis.sendKeyBackup(undefined, undefined, this.backupInfo.version, { - rooms - }); - await this.baseApis.crypto.cryptoStore.unmarkSessionsNeedingBackup(sessions); - remaining = await this.baseApis.crypto.cryptoStore.countSessionsNeedingBackup(); - this.baseApis.crypto.emit(_index.CryptoEvent.KeyBackupSessionsRemaining, remaining); - return sessions.length; - } - async backupGroupSession(senderKey, sessionId) { - await this.baseApis.crypto.cryptoStore.markSessionsNeedingBackup([{ - senderKey: senderKey, - sessionId: sessionId - }]); - if (this.backupInfo) { - // don't wait for this to complete: it will delay so - // happens in the background - this.scheduleKeyBackupSend(); - } - // if this.backupInfo is not set, then the keys will be backed up when - // this.enableKeyBackup is called - } - - /** - * Marks all group sessions as needing to be backed up and schedules them to - * upload in the background as soon as possible. - */ - async scheduleAllGroupSessionsForBackup() { - await this.flagAllGroupSessionsForBackup(); - - // Schedule keys to upload in the background as soon as possible. - this.scheduleKeyBackupSend(0 /* maxDelay */); - } - - /** - * Marks all group sessions as needing to be backed up without scheduling - * them to upload in the background. - * @returns Promise which resolves to the number of sessions now requiring a backup - * (which will be equal to the number of sessions in the store). - */ - async flagAllGroupSessionsForBackup() { - await this.baseApis.crypto.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, _indexeddbCryptoStore.IndexedDBCryptoStore.STORE_BACKUP], txn => { - this.baseApis.crypto.cryptoStore.getAllEndToEndInboundGroupSessions(txn, session => { - if (session !== null) { - this.baseApis.crypto.cryptoStore.markSessionsNeedingBackup([session], txn); - } - }); - }); - const remaining = await this.baseApis.crypto.cryptoStore.countSessionsNeedingBackup(); - this.baseApis.emit(_index.CryptoEvent.KeyBackupSessionsRemaining, remaining); - return remaining; - } - - /** - * Counts the number of end to end session keys that are waiting to be backed up - * @returns Promise which resolves to the number of sessions requiring backup - */ - countSessionsNeedingBackup() { - return this.baseApis.crypto.cryptoStore.countSessionsNeedingBackup(); - } -} -exports.BackupManager = BackupManager; -class Curve25519 { - constructor(authData, publicKey, - // FIXME: PkEncryption - getKey) { - this.authData = authData; - this.publicKey = publicKey; - this.getKey = getKey; - } - static async init(authData, getKey) { - if (!authData || !("public_key" in authData)) { - throw new Error("auth_data missing required information"); - } - const publicKey = new global.Olm.PkEncryption(); - publicKey.set_recipient_key(authData.public_key); - return new Curve25519(authData, publicKey, getKey); - } - static async prepare(key) { - const decryption = new global.Olm.PkDecryption(); - try { - const authData = {}; - if (!key) { - authData.public_key = decryption.generate_key(); - } else if (key instanceof Uint8Array) { - authData.public_key = decryption.init_with_private_key(key); - } else { - const derivation = await (0, _key_passphrase.keyFromPassphrase)(key); - authData.private_key_salt = derivation.salt; - authData.private_key_iterations = derivation.iterations; - authData.public_key = decryption.init_with_private_key(derivation.key); - } - const publicKey = new global.Olm.PkEncryption(); - publicKey.set_recipient_key(authData.public_key); - return [decryption.get_private_key(), authData]; - } finally { - decryption.free(); - } - } - static checkBackupVersion(info) { - if (!("public_key" in info.auth_data)) { - throw new Error("Invalid backup data returned"); - } - } - get untrusted() { - return true; - } - async encryptSession(data) { - const plainText = Object.assign({}, data); - delete plainText.session_id; - delete plainText.room_id; - delete plainText.first_known_index; - return this.publicKey.encrypt(JSON.stringify(plainText)); - } - async decryptSessions(sessions) { - const privKey = await this.getKey(); - const decryption = new global.Olm.PkDecryption(); - try { - const backupPubKey = decryption.init_with_private_key(privKey); - if (backupPubKey !== this.authData.public_key) { - throw new _httpApi.MatrixError({ - errcode: _client.MatrixClient.RESTORE_BACKUP_ERROR_BAD_KEY - }); - } - const keys = []; - for (const [sessionId, sessionData] of Object.entries(sessions)) { - try { - const decrypted = JSON.parse(decryption.decrypt(sessionData.session_data.ephemeral, sessionData.session_data.mac, sessionData.session_data.ciphertext)); - decrypted.session_id = sessionId; - keys.push(decrypted); - } catch (e) { - _logger.logger.log("Failed to decrypt megolm session from backup", e, sessionData); - } - } - return keys; - } finally { - decryption.free(); - } - } - async keyMatches(key) { - const decryption = new global.Olm.PkDecryption(); - let pubKey; - try { - pubKey = decryption.init_with_private_key(key); - } finally { - decryption.free(); - } - return pubKey === this.authData.public_key; - } - free() { - this.publicKey.free(); - } -} -exports.Curve25519 = Curve25519; -(0, _defineProperty2.default)(Curve25519, "algorithmName", "m.megolm_backup.v1.curve25519-aes-sha2"); -function randomBytes(size) { - const buf = new Uint8Array(size); - _crypto.crypto.getRandomValues(buf); - return buf; -} -const UNSTABLE_MSC3270_NAME = new _NamespacedValue.UnstableValue("m.megolm_backup.v1.aes-hmac-sha2", "org.matrix.msc3270.v1.aes-hmac-sha2"); -class Aes256 { - constructor(authData, key) { - this.authData = authData; - this.key = key; - } - static async init(authData, getKey) { - if (!authData) { - throw new Error("auth_data missing"); - } - const key = await getKey(); - if (authData.mac) { - const { - mac - } = await (0, _aes.calculateKeyCheck)(key, authData.iv); - if (authData.mac.replace(/=+$/g, "") !== mac.replace(/=+/g, "")) { - throw new Error("Key does not match"); - } - } - return new Aes256(authData, key); - } - static async prepare(key) { - let outKey; - const authData = {}; - if (!key) { - outKey = randomBytes(32); - } else if (key instanceof Uint8Array) { - outKey = new Uint8Array(key); - } else { - const derivation = await (0, _key_passphrase.keyFromPassphrase)(key); - authData.private_key_salt = derivation.salt; - authData.private_key_iterations = derivation.iterations; - outKey = derivation.key; - } - const { - iv, - mac - } = await (0, _aes.calculateKeyCheck)(outKey); - authData.iv = iv; - authData.mac = mac; - return [outKey, authData]; - } - static checkBackupVersion(info) { - if (!("iv" in info.auth_data && "mac" in info.auth_data)) { - throw new Error("Invalid backup data returned"); - } - } - get untrusted() { - return false; - } - encryptSession(data) { - const plainText = Object.assign({}, data); - delete plainText.session_id; - delete plainText.room_id; - delete plainText.first_known_index; - return (0, _aes.encryptAES)(JSON.stringify(plainText), this.key, data.session_id); - } - async decryptSessions(sessions) { - const keys = []; - for (const [sessionId, sessionData] of Object.entries(sessions)) { - try { - const decrypted = JSON.parse(await (0, _aes.decryptAES)(sessionData.session_data, this.key, sessionId)); - decrypted.session_id = sessionId; - keys.push(decrypted); - } catch (e) { - _logger.logger.log("Failed to decrypt megolm session from backup", e, sessionData); - } - } - return keys; - } - async keyMatches(key) { - if (this.authData.mac) { - const { - mac - } = await (0, _aes.calculateKeyCheck)(key, this.authData.iv); - return this.authData.mac.replace(/=+$/g, "") === mac.replace(/=+/g, ""); - } else { - // if we have no information, we have to assume the key is right - return true; - } - } - free() { - this.key.fill(0); - } -} -exports.Aes256 = Aes256; -(0, _defineProperty2.default)(Aes256, "algorithmName", UNSTABLE_MSC3270_NAME.name); -const algorithmsByName = { - [Curve25519.algorithmName]: Curve25519, - [Aes256.algorithmName]: Aes256 -}; -exports.algorithmsByName = algorithmsByName; -const DefaultAlgorithm = Curve25519; -exports.DefaultAlgorithm = DefaultAlgorithm; -//# sourceMappingURL=backup.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js.map deleted file mode 100644 index 970eea4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/backup.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"backup.js","names":["_client","require","_logger","_olmlib","_key_passphrase","_utils","_indexeddbCryptoStore","_recoverykey","_aes","_NamespacedValue","_index","_crypto","_httpApi","KEY_BACKUP_KEYS_PER_REQUEST","KEY_BACKUP_CHECK_RATE_LIMIT","BackupManager","constructor","baseApis","getKey","_defineProperty2","default","checkedForBackup","sendingBackups","version","backupInfo","checkBackupVersion","info","Algorithm","algorithmsByName","algorithm","Error","auth_data","makeAlgorithm","init","enableKeyBackup","free","emit","CryptoEvent","KeyBackupStatus","scheduleKeyBackupSend","disableKeyBackup","undefined","getKeyBackupEnabled","Boolean","prepareKeyBackupVersion","key","DefaultAlgorithm","privateKey","authData","prepare","recoveryKey","encodeRecoveryKey","algorithmName","recovery_key","createKeyBackupVersion","checkAndStart","logger","log","isGuest","_await$this$baseApis$","getKeyBackupVersion","e","httpStatus","trustInfo","isKeyBackupTrusted","usable","scheduleAllGroupSessionsForBackup","checkKeyBackup","queryKeyBackupRateLimited","targetRoomId","targetSessionId","now","Date","getTime","sessionLastCheckAttemptedTime","restoreKeyBackupWithCache","ret","trusted_locally","sigs","signatures","userId","getUserId","privKey","crypto","getSessionBackupPrivateKey","keyMatches","_algorithm","mySigs","keyId","Object","keys","keyIdParts","split","sigInfo","deviceId","crossSigningId","crossSigningInfo","getId","verifySignature","olmDevice","valid","warn","push","device","deviceList","getStoredDevice","deviceTrust","checkDeviceTrust","getFingerprint","some","s","_s$deviceTrust","isVerified","maxDelay","delay","Math","random","sleep","numFailures","numBackedUp","backupPendingKeys","err","data","errcode","KeyBackupFailed","pow","min","limit","sessions","cryptoStore","getSessionsNeedingBackup","length","remaining","countSessionsNeedingBackup","KeyBackupSessionsRemaining","rooms","session","_deviceList$getDevice","roomId","sessionData","room_id","safeSet","exportInboundGroupSession","senderKey","sessionId","MEGOLM_ALGORITHM","forwardedCount","forwarding_curve25519_key_chain","getUserByIdentityKey","getDeviceByIdentityKey","verified","checkDeviceInfoTrust","first_message_index","first_known_index","forwarded_count","is_verified","session_data","encryptSession","sendKeyBackup","unmarkSessionsNeedingBackup","backupGroupSession","markSessionsNeedingBackup","flagAllGroupSessionsForBackup","doTxn","IndexedDBCryptoStore","STORE_INBOUND_GROUP_SESSIONS","STORE_BACKUP","txn","getAllEndToEndInboundGroupSessions","exports","Curve25519","publicKey","global","Olm","PkEncryption","set_recipient_key","public_key","decryption","PkDecryption","generate_key","Uint8Array","init_with_private_key","derivation","keyFromPassphrase","private_key_salt","salt","private_key_iterations","iterations","get_private_key","untrusted","plainText","assign","session_id","encrypt","JSON","stringify","decryptSessions","backupPubKey","MatrixError","MatrixClient","RESTORE_BACKUP_ERROR_BAD_KEY","entries","decrypted","parse","decrypt","ephemeral","mac","ciphertext","pubKey","randomBytes","size","buf","getRandomValues","UNSTABLE_MSC3270_NAME","UnstableValue","Aes256","calculateKeyCheck","iv","replace","outKey","encryptAES","decryptAES","fill","name"],"sources":["../../src/crypto/backup.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Classes for dealing with key backup.\n */\n\nimport type { IMegolmSessionData } from \"../@types/crypto\";\nimport { MatrixClient } from \"../client\";\nimport { logger } from \"../logger\";\nimport { MEGOLM_ALGORITHM, verifySignature } from \"./olmlib\";\nimport { DeviceInfo } from \"./deviceinfo\";\nimport { DeviceTrustLevel } from \"./CrossSigning\";\nimport { keyFromPassphrase } from \"./key_passphrase\";\nimport { safeSet, sleep } from \"../utils\";\nimport { IndexedDBCryptoStore } from \"./store/indexeddb-crypto-store\";\nimport { encodeRecoveryKey } from \"./recoverykey\";\nimport { calculateKeyCheck, decryptAES, encryptAES, IEncryptedPayload } from \"./aes\";\nimport {\n Curve25519SessionData,\n IAes256AuthData,\n ICurve25519AuthData,\n IKeyBackupInfo,\n IKeyBackupSession,\n} from \"./keybackup\";\nimport { UnstableValue } from \"../NamespacedValue\";\nimport { CryptoEvent } from \"./index\";\nimport { crypto } from \"./crypto\";\nimport { HTTPError, MatrixError } from \"../http-api\";\n\nconst KEY_BACKUP_KEYS_PER_REQUEST = 200;\nconst KEY_BACKUP_CHECK_RATE_LIMIT = 5000; // ms\n\ntype AuthData = IKeyBackupInfo[\"auth_data\"];\n\ntype SigInfo = {\n deviceId: string;\n valid?: boolean | null; // true: valid, false: invalid, null: cannot attempt validation\n device?: DeviceInfo | null;\n crossSigningId?: boolean;\n deviceTrust?: DeviceTrustLevel;\n};\n\nexport type TrustInfo = {\n usable: boolean; // is the backup trusted, true iff there is a sig that is valid & from a trusted device\n sigs: SigInfo[];\n // eslint-disable-next-line camelcase\n trusted_locally?: boolean;\n};\n\nexport interface IKeyBackupCheck {\n backupInfo?: IKeyBackupInfo;\n trustInfo: TrustInfo;\n}\n\n/* eslint-disable camelcase */\nexport interface IPreparedKeyBackupVersion {\n algorithm: string;\n auth_data: AuthData;\n recovery_key: string;\n privateKey: Uint8Array;\n}\n/* eslint-enable camelcase */\n\n/** A function used to get the secret key for a backup.\n */\ntype GetKey = () => Promise>;\n\ninterface BackupAlgorithmClass {\n algorithmName: string;\n // initialize from an existing backup\n init(authData: AuthData, getKey: GetKey): Promise;\n\n // prepare a brand new backup\n prepare(key?: string | Uint8Array | null): Promise<[Uint8Array, AuthData]>;\n\n checkBackupVersion(info: IKeyBackupInfo): void;\n}\n\ninterface BackupAlgorithm {\n untrusted: boolean;\n encryptSession(data: Record): Promise;\n decryptSessions(ciphertexts: Record): Promise;\n authData: AuthData;\n keyMatches(key: ArrayLike): Promise;\n free(): void;\n}\n\nexport interface IKeyBackup {\n rooms: {\n [roomId: string]: {\n sessions: {\n [sessionId: string]: IKeyBackupSession;\n };\n };\n };\n}\n\n/**\n * Manages the key backup.\n */\nexport class BackupManager {\n private algorithm: BackupAlgorithm | undefined;\n public backupInfo: IKeyBackupInfo | undefined; // The info dict from /room_keys/version\n public checkedForBackup: boolean; // Have we checked the server for a backup we can use?\n private sendingBackups: boolean; // Are we currently sending backups?\n private sessionLastCheckAttemptedTime: Record = {}; // When did we last try to check the server for a given session id?\n\n public constructor(private readonly baseApis: MatrixClient, public readonly getKey: GetKey) {\n this.checkedForBackup = false;\n this.sendingBackups = false;\n }\n\n public get version(): string | undefined {\n return this.backupInfo && this.backupInfo.version;\n }\n\n /**\n * Performs a quick check to ensure that the backup info looks sane.\n *\n * Throws an error if a problem is detected.\n *\n * @param info - the key backup info\n */\n public static checkBackupVersion(info: IKeyBackupInfo): void {\n const Algorithm = algorithmsByName[info.algorithm];\n if (!Algorithm) {\n throw new Error(\"Unknown backup algorithm: \" + info.algorithm);\n }\n if (typeof info.auth_data !== \"object\") {\n throw new Error(\"Invalid backup data returned\");\n }\n return Algorithm.checkBackupVersion(info);\n }\n\n public static makeAlgorithm(info: IKeyBackupInfo, getKey: GetKey): Promise {\n const Algorithm = algorithmsByName[info.algorithm];\n if (!Algorithm) {\n throw new Error(\"Unknown backup algorithm\");\n }\n return Algorithm.init(info.auth_data, getKey);\n }\n\n public async enableKeyBackup(info: IKeyBackupInfo): Promise {\n this.backupInfo = info;\n if (this.algorithm) {\n this.algorithm.free();\n }\n\n this.algorithm = await BackupManager.makeAlgorithm(info, this.getKey);\n\n this.baseApis.emit(CryptoEvent.KeyBackupStatus, true);\n\n // There may be keys left over from a partially completed backup, so\n // schedule a send to check.\n this.scheduleKeyBackupSend();\n }\n\n /**\n * Disable backing up of keys.\n */\n public disableKeyBackup(): void {\n if (this.algorithm) {\n this.algorithm.free();\n }\n this.algorithm = undefined;\n\n this.backupInfo = undefined;\n\n this.baseApis.emit(CryptoEvent.KeyBackupStatus, false);\n }\n\n public getKeyBackupEnabled(): boolean | null {\n if (!this.checkedForBackup) {\n return null;\n }\n return Boolean(this.algorithm);\n }\n\n public async prepareKeyBackupVersion(\n key?: string | Uint8Array | null,\n algorithm?: string | undefined,\n ): Promise {\n const Algorithm = algorithm ? algorithmsByName[algorithm] : DefaultAlgorithm;\n if (!Algorithm) {\n throw new Error(\"Unknown backup algorithm\");\n }\n\n const [privateKey, authData] = await Algorithm.prepare(key);\n const recoveryKey = encodeRecoveryKey(privateKey)!;\n return {\n algorithm: Algorithm.algorithmName,\n auth_data: authData,\n recovery_key: recoveryKey,\n privateKey,\n };\n }\n\n public async createKeyBackupVersion(info: IKeyBackupInfo): Promise {\n this.algorithm = await BackupManager.makeAlgorithm(info, this.getKey);\n }\n\n /**\n * Check the server for an active key backup and\n * if one is present and has a valid signature from\n * one of the user's verified devices, start backing up\n * to it.\n */\n public async checkAndStart(): Promise {\n logger.log(\"Checking key backup status...\");\n if (this.baseApis.isGuest()) {\n logger.log(\"Skipping key backup check since user is guest\");\n this.checkedForBackup = true;\n return null;\n }\n let backupInfo: IKeyBackupInfo | undefined;\n try {\n backupInfo = (await this.baseApis.getKeyBackupVersion()) ?? undefined;\n } catch (e) {\n logger.log(\"Error checking for active key backup\", e);\n if ((e).httpStatus === 404) {\n // 404 is returned when the key backup does not exist, so that\n // counts as successfully checking.\n this.checkedForBackup = true;\n }\n return null;\n }\n this.checkedForBackup = true;\n\n const trustInfo = await this.isKeyBackupTrusted(backupInfo);\n\n if (trustInfo.usable && !this.backupInfo) {\n logger.log(`Found usable key backup v${backupInfo!.version}: enabling key backups`);\n await this.enableKeyBackup(backupInfo!);\n } else if (!trustInfo.usable && this.backupInfo) {\n logger.log(\"No usable key backup: disabling key backup\");\n this.disableKeyBackup();\n } else if (!trustInfo.usable && !this.backupInfo) {\n logger.log(\"No usable key backup: not enabling key backup\");\n } else if (trustInfo.usable && this.backupInfo) {\n // may not be the same version: if not, we should switch\n if (backupInfo!.version !== this.backupInfo.version) {\n logger.log(\n `On backup version ${this.backupInfo.version} but ` +\n `found version ${backupInfo!.version}: switching.`,\n );\n this.disableKeyBackup();\n await this.enableKeyBackup(backupInfo!);\n // We're now using a new backup, so schedule all the keys we have to be\n // uploaded to the new backup. This is a bit of a workaround to upload\n // keys to a new backup in *most* cases, but it won't cover all cases\n // because we don't remember what backup version we uploaded keys to:\n // see https://github.com/vector-im/element-web/issues/14833\n await this.scheduleAllGroupSessionsForBackup();\n } else {\n logger.log(`Backup version ${backupInfo!.version} still current`);\n }\n }\n\n return { backupInfo, trustInfo };\n }\n\n /**\n * Forces a re-check of the key backup and enables/disables it\n * as appropriate.\n *\n * @returns Object with backup info (as returned by\n * getKeyBackupVersion) in backupInfo and\n * trust information (as returned by isKeyBackupTrusted)\n * in trustInfo.\n */\n public async checkKeyBackup(): Promise {\n this.checkedForBackup = false;\n return this.checkAndStart();\n }\n\n /**\n * Attempts to retrieve a session from a key backup, if enough time\n * has elapsed since the last check for this session id.\n */\n public async queryKeyBackupRateLimited(\n targetRoomId: string | undefined,\n targetSessionId: string | undefined,\n ): Promise {\n if (!this.backupInfo) {\n return;\n }\n\n const now = new Date().getTime();\n if (\n !this.sessionLastCheckAttemptedTime[targetSessionId!] ||\n now - this.sessionLastCheckAttemptedTime[targetSessionId!] > KEY_BACKUP_CHECK_RATE_LIMIT\n ) {\n this.sessionLastCheckAttemptedTime[targetSessionId!] = now;\n await this.baseApis.restoreKeyBackupWithCache(targetRoomId!, targetSessionId!, this.backupInfo, {});\n }\n }\n\n /**\n * Check if the given backup info is trusted.\n *\n * @param backupInfo - key backup info dict from /room_keys/version\n */\n public async isKeyBackupTrusted(backupInfo?: IKeyBackupInfo): Promise {\n const ret = {\n usable: false,\n trusted_locally: false,\n sigs: [] as SigInfo[],\n };\n\n if (!backupInfo || !backupInfo.algorithm || !backupInfo.auth_data || !backupInfo.auth_data.signatures) {\n logger.info(\"Key backup is absent or missing required data\");\n return ret;\n }\n\n const userId = this.baseApis.getUserId()!;\n const privKey = await this.baseApis.crypto!.getSessionBackupPrivateKey();\n if (privKey) {\n let algorithm: BackupAlgorithm | null = null;\n try {\n algorithm = await BackupManager.makeAlgorithm(backupInfo, async () => privKey);\n\n if (await algorithm.keyMatches(privKey)) {\n logger.info(\"Backup is trusted locally\");\n ret.trusted_locally = true;\n }\n } catch {\n // do nothing -- if we have an error, then we don't mark it as\n // locally trusted\n } finally {\n algorithm?.free();\n }\n }\n\n const mySigs = backupInfo.auth_data.signatures[userId] || {};\n\n for (const keyId of Object.keys(mySigs)) {\n const keyIdParts = keyId.split(\":\");\n if (keyIdParts[0] !== \"ed25519\") {\n logger.log(\"Ignoring unknown signature type: \" + keyIdParts[0]);\n continue;\n }\n // Could be a cross-signing master key, but just say this is the device\n // ID for backwards compat\n const sigInfo: SigInfo = { deviceId: keyIdParts[1] };\n\n // first check to see if it's from our cross-signing key\n const crossSigningId = this.baseApis.crypto!.crossSigningInfo.getId();\n if (crossSigningId === sigInfo.deviceId) {\n sigInfo.crossSigningId = true;\n try {\n await verifySignature(\n this.baseApis.crypto!.olmDevice,\n backupInfo.auth_data,\n userId,\n sigInfo.deviceId,\n crossSigningId,\n );\n sigInfo.valid = true;\n } catch (e) {\n logger.warn(\"Bad signature from cross signing key \" + crossSigningId, e);\n sigInfo.valid = false;\n }\n ret.sigs.push(sigInfo);\n continue;\n }\n\n // Now look for a sig from a device\n // At some point this can probably go away and we'll just support\n // it being signed by the cross-signing master key\n const device = this.baseApis.crypto!.deviceList.getStoredDevice(userId, sigInfo.deviceId);\n if (device) {\n sigInfo.device = device;\n sigInfo.deviceTrust = this.baseApis.checkDeviceTrust(userId, sigInfo.deviceId);\n try {\n await verifySignature(\n this.baseApis.crypto!.olmDevice,\n backupInfo.auth_data,\n userId,\n device.deviceId,\n device.getFingerprint(),\n );\n sigInfo.valid = true;\n } catch (e) {\n logger.info(\n \"Bad signature from key ID \" +\n keyId +\n \" userID \" +\n this.baseApis.getUserId() +\n \" device ID \" +\n device.deviceId +\n \" fingerprint: \" +\n device.getFingerprint(),\n backupInfo.auth_data,\n e,\n );\n sigInfo.valid = false;\n }\n } else {\n sigInfo.valid = null; // Can't determine validity because we don't have the signing device\n logger.info(\"Ignoring signature from unknown key \" + keyId);\n }\n ret.sigs.push(sigInfo);\n }\n\n ret.usable = ret.sigs.some((s) => {\n return s.valid && ((s.device && s.deviceTrust?.isVerified()) || s.crossSigningId);\n });\n return ret;\n }\n\n /**\n * Schedules sending all keys waiting to be sent to the backup, if not already\n * scheduled. Retries if necessary.\n *\n * @param maxDelay - Maximum delay to wait in ms. 0 means no delay.\n */\n public async scheduleKeyBackupSend(maxDelay = 10000): Promise {\n if (this.sendingBackups) return;\n\n this.sendingBackups = true;\n\n try {\n // wait between 0 and `maxDelay` seconds, to avoid backup\n // requests from different clients hitting the server all at\n // the same time when a new key is sent\n const delay = Math.random() * maxDelay;\n await sleep(delay);\n let numFailures = 0; // number of consecutive failures\n for (;;) {\n if (!this.algorithm) {\n return;\n }\n try {\n const numBackedUp = await this.backupPendingKeys(KEY_BACKUP_KEYS_PER_REQUEST);\n if (numBackedUp === 0) {\n // no sessions left needing backup: we're done\n return;\n }\n numFailures = 0;\n } catch (err) {\n numFailures++;\n logger.log(\"Key backup request failed\", err);\n if ((err).data) {\n if (\n (err).data.errcode == \"M_NOT_FOUND\" ||\n (err).data.errcode == \"M_WRONG_ROOM_KEYS_VERSION\"\n ) {\n // Re-check key backup status on error, so we can be\n // sure to present the current situation when asked.\n await this.checkKeyBackup();\n // Backup version has changed or this backup version\n // has been deleted\n this.baseApis.crypto!.emit(CryptoEvent.KeyBackupFailed, (err).data.errcode!);\n throw err;\n }\n }\n }\n if (numFailures) {\n // exponential backoff if we have failures\n await sleep(1000 * Math.pow(2, Math.min(numFailures - 1, 4)));\n }\n }\n } finally {\n this.sendingBackups = false;\n }\n }\n\n /**\n * Take some e2e keys waiting to be backed up and send them\n * to the backup.\n *\n * @param limit - Maximum number of keys to back up\n * @returns Number of sessions backed up\n */\n public async backupPendingKeys(limit: number): Promise {\n const sessions = await this.baseApis.crypto!.cryptoStore.getSessionsNeedingBackup(limit);\n if (!sessions.length) {\n return 0;\n }\n\n let remaining = await this.baseApis.crypto!.cryptoStore.countSessionsNeedingBackup();\n this.baseApis.crypto!.emit(CryptoEvent.KeyBackupSessionsRemaining, remaining);\n\n const rooms: IKeyBackup[\"rooms\"] = {};\n for (const session of sessions) {\n const roomId = session.sessionData!.room_id;\n safeSet(rooms, roomId, rooms[roomId] || { sessions: {} });\n\n const sessionData = this.baseApis.crypto!.olmDevice.exportInboundGroupSession(\n session.senderKey,\n session.sessionId,\n session.sessionData!,\n );\n sessionData.algorithm = MEGOLM_ALGORITHM;\n\n const forwardedCount = (sessionData.forwarding_curve25519_key_chain || []).length;\n\n const userId = this.baseApis.crypto!.deviceList.getUserByIdentityKey(MEGOLM_ALGORITHM, session.senderKey);\n const device =\n this.baseApis.crypto!.deviceList.getDeviceByIdentityKey(MEGOLM_ALGORITHM, session.senderKey) ??\n undefined;\n const verified = this.baseApis.crypto!.checkDeviceInfoTrust(userId!, device).isVerified();\n\n safeSet(rooms[roomId][\"sessions\"], session.sessionId, {\n first_message_index: sessionData.first_known_index,\n forwarded_count: forwardedCount,\n is_verified: verified,\n session_data: await this.algorithm!.encryptSession(sessionData),\n });\n }\n\n await this.baseApis.sendKeyBackup(undefined, undefined, this.backupInfo!.version, { rooms });\n\n await this.baseApis.crypto!.cryptoStore.unmarkSessionsNeedingBackup(sessions);\n remaining = await this.baseApis.crypto!.cryptoStore.countSessionsNeedingBackup();\n this.baseApis.crypto!.emit(CryptoEvent.KeyBackupSessionsRemaining, remaining);\n\n return sessions.length;\n }\n\n public async backupGroupSession(senderKey: string, sessionId: string): Promise {\n await this.baseApis.crypto!.cryptoStore.markSessionsNeedingBackup([\n {\n senderKey: senderKey,\n sessionId: sessionId,\n },\n ]);\n\n if (this.backupInfo) {\n // don't wait for this to complete: it will delay so\n // happens in the background\n this.scheduleKeyBackupSend();\n }\n // if this.backupInfo is not set, then the keys will be backed up when\n // this.enableKeyBackup is called\n }\n\n /**\n * Marks all group sessions as needing to be backed up and schedules them to\n * upload in the background as soon as possible.\n */\n public async scheduleAllGroupSessionsForBackup(): Promise {\n await this.flagAllGroupSessionsForBackup();\n\n // Schedule keys to upload in the background as soon as possible.\n this.scheduleKeyBackupSend(0 /* maxDelay */);\n }\n\n /**\n * Marks all group sessions as needing to be backed up without scheduling\n * them to upload in the background.\n * @returns Promise which resolves to the number of sessions now requiring a backup\n * (which will be equal to the number of sessions in the store).\n */\n public async flagAllGroupSessionsForBackup(): Promise {\n await this.baseApis.crypto!.cryptoStore.doTxn(\n \"readwrite\",\n [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, IndexedDBCryptoStore.STORE_BACKUP],\n (txn) => {\n this.baseApis.crypto!.cryptoStore.getAllEndToEndInboundGroupSessions(txn, (session) => {\n if (session !== null) {\n this.baseApis.crypto!.cryptoStore.markSessionsNeedingBackup([session], txn);\n }\n });\n },\n );\n\n const remaining = await this.baseApis.crypto!.cryptoStore.countSessionsNeedingBackup();\n this.baseApis.emit(CryptoEvent.KeyBackupSessionsRemaining, remaining);\n return remaining;\n }\n\n /**\n * Counts the number of end to end session keys that are waiting to be backed up\n * @returns Promise which resolves to the number of sessions requiring backup\n */\n public countSessionsNeedingBackup(): Promise {\n return this.baseApis.crypto!.cryptoStore.countSessionsNeedingBackup();\n }\n}\n\nexport class Curve25519 implements BackupAlgorithm {\n public static algorithmName = \"m.megolm_backup.v1.curve25519-aes-sha2\";\n\n public constructor(\n public authData: ICurve25519AuthData,\n private publicKey: any, // FIXME: PkEncryption\n private getKey: () => Promise,\n ) {}\n\n public static async init(authData: AuthData, getKey: () => Promise): Promise {\n if (!authData || !(\"public_key\" in authData)) {\n throw new Error(\"auth_data missing required information\");\n }\n const publicKey = new global.Olm.PkEncryption();\n publicKey.set_recipient_key(authData.public_key);\n return new Curve25519(authData as ICurve25519AuthData, publicKey, getKey);\n }\n\n public static async prepare(key?: string | Uint8Array | null): Promise<[Uint8Array, AuthData]> {\n const decryption = new global.Olm.PkDecryption();\n try {\n const authData: Partial = {};\n if (!key) {\n authData.public_key = decryption.generate_key();\n } else if (key instanceof Uint8Array) {\n authData.public_key = decryption.init_with_private_key(key);\n } else {\n const derivation = await keyFromPassphrase(key);\n authData.private_key_salt = derivation.salt;\n authData.private_key_iterations = derivation.iterations;\n authData.public_key = decryption.init_with_private_key(derivation.key);\n }\n const publicKey = new global.Olm.PkEncryption();\n publicKey.set_recipient_key(authData.public_key);\n\n return [decryption.get_private_key(), authData as AuthData];\n } finally {\n decryption.free();\n }\n }\n\n public static checkBackupVersion(info: IKeyBackupInfo): void {\n if (!(\"public_key\" in info.auth_data)) {\n throw new Error(\"Invalid backup data returned\");\n }\n }\n\n public get untrusted(): boolean {\n return true;\n }\n\n public async encryptSession(data: Record): Promise {\n const plainText: Record = Object.assign({}, data);\n delete plainText.session_id;\n delete plainText.room_id;\n delete plainText.first_known_index;\n return this.publicKey.encrypt(JSON.stringify(plainText));\n }\n\n public async decryptSessions(\n sessions: Record>,\n ): Promise {\n const privKey = await this.getKey();\n const decryption = new global.Olm.PkDecryption();\n try {\n const backupPubKey = decryption.init_with_private_key(privKey);\n\n if (backupPubKey !== this.authData.public_key) {\n throw new MatrixError({ errcode: MatrixClient.RESTORE_BACKUP_ERROR_BAD_KEY });\n }\n\n const keys: IMegolmSessionData[] = [];\n\n for (const [sessionId, sessionData] of Object.entries(sessions)) {\n try {\n const decrypted = JSON.parse(\n decryption.decrypt(\n sessionData.session_data.ephemeral,\n sessionData.session_data.mac,\n sessionData.session_data.ciphertext,\n ),\n );\n decrypted.session_id = sessionId;\n keys.push(decrypted);\n } catch (e) {\n logger.log(\"Failed to decrypt megolm session from backup\", e, sessionData);\n }\n }\n return keys;\n } finally {\n decryption.free();\n }\n }\n\n public async keyMatches(key: Uint8Array): Promise {\n const decryption = new global.Olm.PkDecryption();\n let pubKey: string;\n try {\n pubKey = decryption.init_with_private_key(key);\n } finally {\n decryption.free();\n }\n\n return pubKey === this.authData.public_key;\n }\n\n public free(): void {\n this.publicKey.free();\n }\n}\n\nfunction randomBytes(size: number): Uint8Array {\n const buf = new Uint8Array(size);\n crypto.getRandomValues(buf);\n return buf;\n}\n\nconst UNSTABLE_MSC3270_NAME = new UnstableValue(\n \"m.megolm_backup.v1.aes-hmac-sha2\",\n \"org.matrix.msc3270.v1.aes-hmac-sha2\",\n);\n\nexport class Aes256 implements BackupAlgorithm {\n public static algorithmName = UNSTABLE_MSC3270_NAME.name;\n\n public constructor(public readonly authData: IAes256AuthData, private readonly key: Uint8Array) {}\n\n public static async init(authData: IAes256AuthData, getKey: () => Promise): Promise {\n if (!authData) {\n throw new Error(\"auth_data missing\");\n }\n const key = await getKey();\n if (authData.mac) {\n const { mac } = await calculateKeyCheck(key, authData.iv);\n if (authData.mac.replace(/=+$/g, \"\") !== mac.replace(/=+/g, \"\")) {\n throw new Error(\"Key does not match\");\n }\n }\n return new Aes256(authData, key);\n }\n\n public static async prepare(key?: string | Uint8Array | null): Promise<[Uint8Array, AuthData]> {\n let outKey: Uint8Array;\n const authData: Partial = {};\n if (!key) {\n outKey = randomBytes(32);\n } else if (key instanceof Uint8Array) {\n outKey = new Uint8Array(key);\n } else {\n const derivation = await keyFromPassphrase(key);\n authData.private_key_salt = derivation.salt;\n authData.private_key_iterations = derivation.iterations;\n outKey = derivation.key;\n }\n\n const { iv, mac } = await calculateKeyCheck(outKey);\n authData.iv = iv;\n authData.mac = mac;\n\n return [outKey, authData as AuthData];\n }\n\n public static checkBackupVersion(info: IKeyBackupInfo): void {\n if (!(\"iv\" in info.auth_data && \"mac\" in info.auth_data)) {\n throw new Error(\"Invalid backup data returned\");\n }\n }\n\n public get untrusted(): boolean {\n return false;\n }\n\n public encryptSession(data: Record): Promise {\n const plainText: Record = Object.assign({}, data);\n delete plainText.session_id;\n delete plainText.room_id;\n delete plainText.first_known_index;\n return encryptAES(JSON.stringify(plainText), this.key, data.session_id);\n }\n\n public async decryptSessions(\n sessions: Record>,\n ): Promise {\n const keys: IMegolmSessionData[] = [];\n\n for (const [sessionId, sessionData] of Object.entries(sessions)) {\n try {\n const decrypted = JSON.parse(await decryptAES(sessionData.session_data, this.key, sessionId));\n decrypted.session_id = sessionId;\n keys.push(decrypted);\n } catch (e) {\n logger.log(\"Failed to decrypt megolm session from backup\", e, sessionData);\n }\n }\n return keys;\n }\n\n public async keyMatches(key: Uint8Array): Promise {\n if (this.authData.mac) {\n const { mac } = await calculateKeyCheck(key, this.authData.iv);\n return this.authData.mac.replace(/=+$/g, \"\") === mac.replace(/=+/g, \"\");\n } else {\n // if we have no information, we have to assume the key is right\n return true;\n }\n }\n\n public free(): void {\n this.key.fill(0);\n }\n}\n\nexport const algorithmsByName: Record = {\n [Curve25519.algorithmName]: Curve25519,\n [Aes256.algorithmName]: Aes256,\n};\n\nexport const DefaultAlgorithm: BackupAlgorithmClass = Curve25519;\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts deleted file mode 100644 index 8078b5f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -export declare let crypto: Crypto; -export declare let subtleCrypto: SubtleCrypto; -export declare let TextEncoder: { - new (): TextEncoder; - prototype: TextEncoder; -}; -export declare function setCrypto(_crypto: Crypto): void; -export declare function setTextEncoder(_TextEncoder: typeof TextEncoder): void; -//# sourceMappingURL=crypto.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts.map deleted file mode 100644 index c5a2d62..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"crypto.d.ts","sourceRoot":"","sources":["../../src/crypto/crypto.ts"],"names":[],"mappings":"AAkBA,eAAO,IAAI,MAAM,QAAwB,CAAC;AAC1C,eAAO,IAAI,YAAY,cAAuE,CAAC;AAC/F,eAAO,IAAI,WAAW;;;CAA6B,CAAC;AAsBpD,wBAAgB,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAG/C;AAED,wBAAgB,cAAc,CAAC,YAAY,EAAE,OAAO,WAAW,GAAG,IAAI,CAErE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js deleted file mode 100644 index a622f2e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js +++ /dev/null @@ -1,48 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.crypto = exports.TextEncoder = void 0; -exports.setCrypto = setCrypto; -exports.setTextEncoder = setTextEncoder; -exports.subtleCrypto = void 0; -var _logger = require("../logger"); -var _global$window, _global$window$crypto, _global$window2, _global$window2$crypt, _global$window3, _global$window3$crypt, _global$window4; -let crypto = (_global$window = global.window) === null || _global$window === void 0 ? void 0 : _global$window.crypto; -exports.crypto = crypto; -let subtleCrypto = (_global$window$crypto = (_global$window2 = global.window) === null || _global$window2 === void 0 ? void 0 : (_global$window2$crypt = _global$window2.crypto) === null || _global$window2$crypt === void 0 ? void 0 : _global$window2$crypt.subtle) !== null && _global$window$crypto !== void 0 ? _global$window$crypto : (_global$window3 = global.window) === null || _global$window3 === void 0 ? void 0 : (_global$window3$crypt = _global$window3.crypto) === null || _global$window3$crypt === void 0 ? void 0 : _global$window3$crypt.webkitSubtle; -exports.subtleCrypto = subtleCrypto; -let TextEncoder = (_global$window4 = global.window) === null || _global$window4 === void 0 ? void 0 : _global$window4.TextEncoder; - -/* eslint-disable @typescript-eslint/no-var-requires */ -exports.TextEncoder = TextEncoder; -if (!crypto) { - try { - exports.crypto = crypto = require("crypto").webcrypto; - } catch (e) { - _logger.logger.error("Failed to load webcrypto", e); - } -} -if (!subtleCrypto) { - var _crypto2; - exports.subtleCrypto = subtleCrypto = (_crypto2 = crypto) === null || _crypto2 === void 0 ? void 0 : _crypto2.subtle; -} -if (!TextEncoder) { - try { - exports.TextEncoder = TextEncoder = require("util").TextEncoder; - } catch (e) { - _logger.logger.error("Failed to load TextEncoder util", e); - } -} -/* eslint-enable @typescript-eslint/no-var-requires */ - -function setCrypto(_crypto) { - var _crypto$subtle; - exports.crypto = crypto = _crypto; - exports.subtleCrypto = subtleCrypto = (_crypto$subtle = _crypto.subtle) !== null && _crypto$subtle !== void 0 ? _crypto$subtle : _crypto.webkitSubtle; -} -function setTextEncoder(_TextEncoder) { - exports.TextEncoder = TextEncoder = _TextEncoder; -} -//# sourceMappingURL=crypto.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js.map deleted file mode 100644 index 8dc5b69..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/crypto.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"crypto.js","names":["_logger","require","_global$window","_global$window$crypto","_global$window2","_global$window2$crypt","_global$window3","_global$window3$crypt","_global$window4","crypto","global","window","exports","subtleCrypto","subtle","webkitSubtle","TextEncoder","webcrypto","e","logger","error","_crypto2","setCrypto","_crypto","_crypto$subtle","setTextEncoder","_TextEncoder"],"sources":["../../src/crypto/crypto.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../logger\";\n\nexport let crypto = global.window?.crypto;\nexport let subtleCrypto = global.window?.crypto?.subtle ?? global.window?.crypto?.webkitSubtle;\nexport let TextEncoder = global.window?.TextEncoder;\n\n/* eslint-disable @typescript-eslint/no-var-requires */\nif (!crypto) {\n try {\n crypto = require(\"crypto\").webcrypto;\n } catch (e) {\n logger.error(\"Failed to load webcrypto\", e);\n }\n}\nif (!subtleCrypto) {\n subtleCrypto = crypto?.subtle;\n}\nif (!TextEncoder) {\n try {\n TextEncoder = require(\"util\").TextEncoder;\n } catch (e) {\n logger.error(\"Failed to load TextEncoder util\", e);\n }\n}\n/* eslint-enable @typescript-eslint/no-var-requires */\n\nexport function setCrypto(_crypto: Crypto): void {\n crypto = _crypto;\n subtleCrypto = _crypto.subtle ?? _crypto.webkitSubtle;\n}\n\nexport function setTextEncoder(_TextEncoder: typeof TextEncoder): void {\n TextEncoder = _TextEncoder;\n}\n"],"mappings":";;;;;;;;;AAgBA,IAAAA,OAAA,GAAAC,OAAA;AAAmC,IAAAC,cAAA,EAAAC,qBAAA,EAAAC,eAAA,EAAAC,qBAAA,EAAAC,eAAA,EAAAC,qBAAA,EAAAC,eAAA;AAE5B,IAAIC,MAAM,IAAAP,cAAA,GAAGQ,MAAM,CAACC,MAAM,cAAAT,cAAA,uBAAbA,cAAA,CAAeO,MAAM;AAACG,OAAA,CAAAH,MAAA,GAAAA,MAAA;AACnC,IAAII,YAAY,IAAAV,qBAAA,IAAAC,eAAA,GAAGM,MAAM,CAACC,MAAM,cAAAP,eAAA,wBAAAC,qBAAA,GAAbD,eAAA,CAAeK,MAAM,cAAAJ,qBAAA,uBAArBA,qBAAA,CAAuBS,MAAM,cAAAX,qBAAA,cAAAA,qBAAA,IAAAG,eAAA,GAAII,MAAM,CAACC,MAAM,cAAAL,eAAA,wBAAAC,qBAAA,GAAbD,eAAA,CAAeG,MAAM,cAAAF,qBAAA,uBAArBA,qBAAA,CAAuBQ,YAAY;AAACH,OAAA,CAAAC,YAAA,GAAAA,YAAA;AACxF,IAAIG,WAAW,IAAAR,eAAA,GAAGE,MAAM,CAACC,MAAM,cAAAH,eAAA,uBAAbA,eAAA,CAAeQ,WAAW;;AAEnD;AAAAJ,OAAA,CAAAI,WAAA,GAAAA,WAAA;AACA,IAAI,CAACP,MAAM,EAAE;EACT,IAAI;IACAG,OAAA,CAAAH,MAAA,GAAAA,MAAM,GAAGR,OAAO,CAAC,QAAQ,CAAC,CAACgB,SAAS;EACxC,CAAC,CAAC,OAAOC,CAAC,EAAE;IACRC,cAAM,CAACC,KAAK,CAAC,0BAA0B,EAAEF,CAAC,CAAC;EAC/C;AACJ;AACA,IAAI,CAACL,YAAY,EAAE;EAAA,IAAAQ,QAAA;EACfT,OAAA,CAAAC,YAAA,GAAAA,YAAY,IAAAQ,QAAA,GAAGZ,MAAM,cAAAY,QAAA,uBAANA,QAAA,CAAQP,MAAM;AACjC;AACA,IAAI,CAACE,WAAW,EAAE;EACd,IAAI;IACAJ,OAAA,CAAAI,WAAA,GAAAA,WAAW,GAAGf,OAAO,CAAC,MAAM,CAAC,CAACe,WAAW;EAC7C,CAAC,CAAC,OAAOE,CAAC,EAAE;IACRC,cAAM,CAACC,KAAK,CAAC,iCAAiC,EAAEF,CAAC,CAAC;EACtD;AACJ;AACA;;AAEO,SAASI,SAASA,CAACC,OAAe,EAAQ;EAAA,IAAAC,cAAA;EAC7CZ,OAAA,CAAAH,MAAA,GAAAA,MAAM,GAAGc,OAAO;EAChBX,OAAA,CAAAC,YAAA,GAAAA,YAAY,IAAAW,cAAA,GAAGD,OAAO,CAACT,MAAM,cAAAU,cAAA,cAAAA,cAAA,GAAID,OAAO,CAACR,YAAY;AACzD;AAEO,SAASU,cAAcA,CAACC,YAAgC,EAAQ;EACnEd,OAAA,CAAAI,WAAA,GAAAA,WAAW,GAAGU,YAAY;AAC9B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts deleted file mode 100644 index 2087b6a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts +++ /dev/null @@ -1,34 +0,0 @@ -import { Crypto } from "./index"; -import { SecretStorageKeyDescription } from "../secret-storage"; -export interface IDehydratedDevice { - device_id: string; - device_data: SecretStorageKeyDescription & { - algorithm: string; - account: string; - }; -} -export interface IDehydratedDeviceKeyInfo { - passphrase?: string; -} -export declare const DEHYDRATION_ALGORITHM = "org.matrix.msc2697.v1.olm.libolm_pickle"; -export declare class DehydrationManager { - private readonly crypto; - private inProgress; - private timeoutId; - private key?; - private keyInfo?; - private deviceDisplayName?; - constructor(crypto: Crypto); - getDehydrationKeyFromCache(): Promise; - /** set the key, and queue periodic dehydration to the server in the background */ - setKeyAndQueueDehydration(key: Uint8Array, keyInfo?: { - [props: string]: any; - }, deviceDisplayName?: string): Promise; - setKey(key: Uint8Array, keyInfo?: { - [props: string]: any; - }, deviceDisplayName?: string): Promise; - /** returns the device id of the newly created dehydrated device */ - dehydrateDevice(): Promise; - stop(): void; -} -//# sourceMappingURL=dehydration.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts.map deleted file mode 100644 index 1908ae6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"dehydration.d.ts","sourceRoot":"","sources":["../../src/crypto/dehydration.ts"],"names":[],"mappings":"AAuBA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,2BAA2B,EAAE,MAAM,mBAAmB,CAAC;AAEhE,MAAM,WAAW,iBAAiB;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,2BAA2B,GAAG;QAEvC,SAAS,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC;KACnB,CAAC;CACL;AAED,MAAM,WAAW,wBAAwB;IACrC,UAAU,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,eAAO,MAAM,qBAAqB,4CAA4C,CAAC;AAI/E,qBAAa,kBAAkB;IAOR,OAAO,CAAC,QAAQ,CAAC,MAAM;IAN1C,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,SAAS,CAAM;IACvB,OAAO,CAAC,GAAG,CAAC,CAAa;IACzB,OAAO,CAAC,OAAO,CAAC,CAA2B;IAC3C,OAAO,CAAC,iBAAiB,CAAC,CAAS;gBAEC,MAAM,EAAE,MAAM;IAI3C,0BAA0B,IAAI,OAAO,CAAC,IAAI,CAAC;IAsBlD,kFAAkF;IACrE,yBAAyB,CAClC,GAAG,EAAE,UAAU,EACf,OAAO,GAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG,CAAA;KAAO,EACtC,iBAAiB,CAAC,EAAE,MAAM,GAC3B,OAAO,CAAC,IAAI,CAAC;IAQH,MAAM,CACf,GAAG,EAAE,UAAU,EACf,OAAO,GAAE;QAAE,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG,CAAA;KAAO,EACtC,iBAAiB,CAAC,EAAE,MAAM,GAC3B,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC;IAkC/B,mEAAmE;IACtD,eAAe,IAAI,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAuIpD,IAAI,IAAI,IAAI;CAMtB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js deleted file mode 100644 index 2a00aa7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js +++ /dev/null @@ -1,238 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.DehydrationManager = exports.DEHYDRATION_ALGORITHM = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _anotherJson = _interopRequireDefault(require("another-json")); -var _olmlib = require("./olmlib"); -var _indexeddbCryptoStore = require("../crypto/store/indexeddb-crypto-store"); -var _aes = require("./aes"); -var _logger = require("../logger"); -var _httpApi = require("../http-api"); -/* -Copyright 2020-2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const DEHYDRATION_ALGORITHM = "org.matrix.msc2697.v1.olm.libolm_pickle"; -exports.DEHYDRATION_ALGORITHM = DEHYDRATION_ALGORITHM; -const oneweek = 7 * 24 * 60 * 60 * 1000; -class DehydrationManager { - constructor(crypto) { - this.crypto = crypto; - (0, _defineProperty2.default)(this, "inProgress", false); - (0, _defineProperty2.default)(this, "timeoutId", void 0); - (0, _defineProperty2.default)(this, "key", void 0); - (0, _defineProperty2.default)(this, "keyInfo", void 0); - (0, _defineProperty2.default)(this, "deviceDisplayName", void 0); - this.getDehydrationKeyFromCache(); - } - getDehydrationKeyFromCache() { - return this.crypto.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.crypto.cryptoStore.getSecretStorePrivateKey(txn, async result => { - if (result) { - const { - key, - keyInfo, - deviceDisplayName, - time - } = result; - const pickleKey = Buffer.from(this.crypto.olmDevice.pickleKey); - const decrypted = await (0, _aes.decryptAES)(key, pickleKey, DEHYDRATION_ALGORITHM); - this.key = (0, _olmlib.decodeBase64)(decrypted); - this.keyInfo = keyInfo; - this.deviceDisplayName = deviceDisplayName; - const now = Date.now(); - const delay = Math.max(1, time + oneweek - now); - this.timeoutId = global.setTimeout(this.dehydrateDevice.bind(this), delay); - } - }, "dehydration"); - }); - } - - /** set the key, and queue periodic dehydration to the server in the background */ - async setKeyAndQueueDehydration(key, keyInfo = {}, deviceDisplayName) { - const matches = await this.setKey(key, keyInfo, deviceDisplayName); - if (!matches) { - // start dehydration in the background - this.dehydrateDevice(); - } - } - async setKey(key, keyInfo = {}, deviceDisplayName) { - if (!key) { - // unsetting the key -- cancel any pending dehydration task - if (this.timeoutId) { - global.clearTimeout(this.timeoutId); - this.timeoutId = undefined; - } - // clear storage - await this.crypto.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.crypto.cryptoStore.storeSecretStorePrivateKey(txn, "dehydration", null); - }); - this.key = undefined; - this.keyInfo = undefined; - return; - } - - // Check to see if it's the same key as before. If it's different, - // dehydrate a new device. If it's the same, we can keep the same - // device. (Assume that keyInfo and deviceDisplayName will be the - // same if the key is the same.) - let matches = !!this.key && key.length == this.key.length; - for (let i = 0; matches && i < key.length; i++) { - if (key[i] != this.key[i]) { - matches = false; - } - } - if (!matches) { - this.key = key; - this.keyInfo = keyInfo; - this.deviceDisplayName = deviceDisplayName; - } - return matches; - } - - /** returns the device id of the newly created dehydrated device */ - async dehydrateDevice() { - if (this.inProgress) { - _logger.logger.log("Dehydration already in progress -- not starting new dehydration"); - return; - } - this.inProgress = true; - if (this.timeoutId) { - global.clearTimeout(this.timeoutId); - this.timeoutId = undefined; - } - try { - const pickleKey = Buffer.from(this.crypto.olmDevice.pickleKey); - - // update the crypto store with the timestamp - const key = await (0, _aes.encryptAES)((0, _olmlib.encodeBase64)(this.key), pickleKey, DEHYDRATION_ALGORITHM); - await this.crypto.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.crypto.cryptoStore.storeSecretStorePrivateKey(txn, "dehydration", { - keyInfo: this.keyInfo, - key, - deviceDisplayName: this.deviceDisplayName, - time: Date.now() - }); - }); - _logger.logger.log("Attempting to dehydrate device"); - _logger.logger.log("Creating account"); - // create the account and all the necessary keys - const account = new global.Olm.Account(); - account.create(); - const e2eKeys = JSON.parse(account.identity_keys()); - const maxKeys = account.max_number_of_one_time_keys(); - // FIXME: generate in small batches? - account.generate_one_time_keys(maxKeys / 2); - account.generate_fallback_key(); - const otks = JSON.parse(account.one_time_keys()); - const fallbacks = JSON.parse(account.fallback_key()); - account.mark_keys_as_published(); - - // dehydrate the account and store it on the server - const pickledAccount = account.pickle(new Uint8Array(this.key)); - const deviceData = { - algorithm: DEHYDRATION_ALGORITHM, - account: pickledAccount - }; - if (this.keyInfo.passphrase) { - deviceData.passphrase = this.keyInfo.passphrase; - } - _logger.logger.log("Uploading account to server"); - // eslint-disable-next-line camelcase - const dehydrateResult = await this.crypto.baseApis.http.authedRequest(_httpApi.Method.Put, "/dehydrated_device", undefined, { - device_data: deviceData, - initial_device_display_name: this.deviceDisplayName - }, { - prefix: "/_matrix/client/unstable/org.matrix.msc2697.v2" - }); - - // send the keys to the server - const deviceId = dehydrateResult.device_id; - _logger.logger.log("Preparing device keys", deviceId); - const deviceKeys = { - algorithms: this.crypto.supportedAlgorithms, - device_id: deviceId, - user_id: this.crypto.userId, - keys: { - [`ed25519:${deviceId}`]: e2eKeys.ed25519, - [`curve25519:${deviceId}`]: e2eKeys.curve25519 - } - }; - const deviceSignature = account.sign(_anotherJson.default.stringify(deviceKeys)); - deviceKeys.signatures = { - [this.crypto.userId]: { - [`ed25519:${deviceId}`]: deviceSignature - } - }; - if (this.crypto.crossSigningInfo.getId("self_signing")) { - await this.crypto.crossSigningInfo.signObject(deviceKeys, "self_signing"); - } - _logger.logger.log("Preparing one-time keys"); - const oneTimeKeys = {}; - for (const [keyId, key] of Object.entries(otks.curve25519)) { - const k = { - key - }; - const signature = account.sign(_anotherJson.default.stringify(k)); - k.signatures = { - [this.crypto.userId]: { - [`ed25519:${deviceId}`]: signature - } - }; - oneTimeKeys[`signed_curve25519:${keyId}`] = k; - } - _logger.logger.log("Preparing fallback keys"); - const fallbackKeys = {}; - for (const [keyId, key] of Object.entries(fallbacks.curve25519)) { - const k = { - key, - fallback: true - }; - const signature = account.sign(_anotherJson.default.stringify(k)); - k.signatures = { - [this.crypto.userId]: { - [`ed25519:${deviceId}`]: signature - } - }; - fallbackKeys[`signed_curve25519:${keyId}`] = k; - } - _logger.logger.log("Uploading keys to server"); - await this.crypto.baseApis.http.authedRequest(_httpApi.Method.Post, "/keys/upload/" + encodeURI(deviceId), undefined, { - "device_keys": deviceKeys, - "one_time_keys": oneTimeKeys, - "org.matrix.msc2732.fallback_keys": fallbackKeys - }); - _logger.logger.log("Done dehydrating"); - - // dehydrate again in a week - this.timeoutId = global.setTimeout(this.dehydrateDevice.bind(this), oneweek); - return deviceId; - } finally { - this.inProgress = false; - } - } - stop() { - if (this.timeoutId) { - global.clearTimeout(this.timeoutId); - this.timeoutId = undefined; - } - } -} -exports.DehydrationManager = DehydrationManager; -//# sourceMappingURL=dehydration.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js.map deleted file mode 100644 index 385d71f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/dehydration.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"dehydration.js","names":["_anotherJson","_interopRequireDefault","require","_olmlib","_indexeddbCryptoStore","_aes","_logger","_httpApi","DEHYDRATION_ALGORITHM","exports","oneweek","DehydrationManager","constructor","crypto","_defineProperty2","default","getDehydrationKeyFromCache","cryptoStore","doTxn","IndexedDBCryptoStore","STORE_ACCOUNT","txn","getSecretStorePrivateKey","result","key","keyInfo","deviceDisplayName","time","pickleKey","Buffer","from","olmDevice","decrypted","decryptAES","decodeBase64","now","Date","delay","Math","max","timeoutId","global","setTimeout","dehydrateDevice","bind","setKeyAndQueueDehydration","matches","setKey","clearTimeout","undefined","storeSecretStorePrivateKey","length","i","inProgress","logger","log","encryptAES","encodeBase64","account","Olm","Account","create","e2eKeys","JSON","parse","identity_keys","maxKeys","max_number_of_one_time_keys","generate_one_time_keys","generate_fallback_key","otks","one_time_keys","fallbacks","fallback_key","mark_keys_as_published","pickledAccount","pickle","Uint8Array","deviceData","algorithm","passphrase","dehydrateResult","baseApis","http","authedRequest","Method","Put","device_data","initial_device_display_name","prefix","deviceId","device_id","deviceKeys","algorithms","supportedAlgorithms","user_id","userId","keys","ed25519","curve25519","deviceSignature","sign","anotherjson","stringify","signatures","crossSigningInfo","getId","signObject","oneTimeKeys","keyId","Object","entries","k","signature","fallbackKeys","fallback","Post","encodeURI","stop"],"sources":["../../src/crypto/dehydration.ts"],"sourcesContent":["/*\nCopyright 2020-2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport anotherjson from \"another-json\";\n\nimport type { IDeviceKeys, IOneTimeKey } from \"../@types/crypto\";\nimport { decodeBase64, encodeBase64 } from \"./olmlib\";\nimport { IndexedDBCryptoStore } from \"../crypto/store/indexeddb-crypto-store\";\nimport { decryptAES, encryptAES } from \"./aes\";\nimport { logger } from \"../logger\";\nimport { Crypto } from \"./index\";\nimport { Method } from \"../http-api\";\nimport { SecretStorageKeyDescription } from \"../secret-storage\";\n\nexport interface IDehydratedDevice {\n device_id: string; // eslint-disable-line camelcase\n device_data: SecretStorageKeyDescription & {\n // eslint-disable-line camelcase\n algorithm: string;\n account: string; // pickle\n };\n}\n\nexport interface IDehydratedDeviceKeyInfo {\n passphrase?: string;\n}\n\nexport const DEHYDRATION_ALGORITHM = \"org.matrix.msc2697.v1.olm.libolm_pickle\";\n\nconst oneweek = 7 * 24 * 60 * 60 * 1000;\n\nexport class DehydrationManager {\n private inProgress = false;\n private timeoutId: any;\n private key?: Uint8Array;\n private keyInfo?: { [props: string]: any };\n private deviceDisplayName?: string;\n\n public constructor(private readonly crypto: Crypto) {\n this.getDehydrationKeyFromCache();\n }\n\n public getDehydrationKeyFromCache(): Promise {\n return this.crypto.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.crypto.cryptoStore.getSecretStorePrivateKey(\n txn,\n async (result) => {\n if (result) {\n const { key, keyInfo, deviceDisplayName, time } = result;\n const pickleKey = Buffer.from(this.crypto.olmDevice.pickleKey);\n const decrypted = await decryptAES(key, pickleKey, DEHYDRATION_ALGORITHM);\n this.key = decodeBase64(decrypted);\n this.keyInfo = keyInfo;\n this.deviceDisplayName = deviceDisplayName;\n const now = Date.now();\n const delay = Math.max(1, time + oneweek - now);\n this.timeoutId = global.setTimeout(this.dehydrateDevice.bind(this), delay);\n }\n },\n \"dehydration\",\n );\n });\n }\n\n /** set the key, and queue periodic dehydration to the server in the background */\n public async setKeyAndQueueDehydration(\n key: Uint8Array,\n keyInfo: { [props: string]: any } = {},\n deviceDisplayName?: string,\n ): Promise {\n const matches = await this.setKey(key, keyInfo, deviceDisplayName);\n if (!matches) {\n // start dehydration in the background\n this.dehydrateDevice();\n }\n }\n\n public async setKey(\n key: Uint8Array,\n keyInfo: { [props: string]: any } = {},\n deviceDisplayName?: string,\n ): Promise {\n if (!key) {\n // unsetting the key -- cancel any pending dehydration task\n if (this.timeoutId) {\n global.clearTimeout(this.timeoutId);\n this.timeoutId = undefined;\n }\n // clear storage\n await this.crypto.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.crypto.cryptoStore.storeSecretStorePrivateKey(txn, \"dehydration\", null);\n });\n this.key = undefined;\n this.keyInfo = undefined;\n return;\n }\n\n // Check to see if it's the same key as before. If it's different,\n // dehydrate a new device. If it's the same, we can keep the same\n // device. (Assume that keyInfo and deviceDisplayName will be the\n // same if the key is the same.)\n let matches: boolean = !!this.key && key.length == this.key.length;\n for (let i = 0; matches && i < key.length; i++) {\n if (key[i] != this.key![i]) {\n matches = false;\n }\n }\n if (!matches) {\n this.key = key;\n this.keyInfo = keyInfo;\n this.deviceDisplayName = deviceDisplayName;\n }\n return matches;\n }\n\n /** returns the device id of the newly created dehydrated device */\n public async dehydrateDevice(): Promise {\n if (this.inProgress) {\n logger.log(\"Dehydration already in progress -- not starting new dehydration\");\n return;\n }\n this.inProgress = true;\n if (this.timeoutId) {\n global.clearTimeout(this.timeoutId);\n this.timeoutId = undefined;\n }\n try {\n const pickleKey = Buffer.from(this.crypto.olmDevice.pickleKey);\n\n // update the crypto store with the timestamp\n const key = await encryptAES(encodeBase64(this.key!), pickleKey, DEHYDRATION_ALGORITHM);\n await this.crypto.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.crypto.cryptoStore.storeSecretStorePrivateKey(txn, \"dehydration\", {\n keyInfo: this.keyInfo,\n key,\n deviceDisplayName: this.deviceDisplayName!,\n time: Date.now(),\n });\n });\n logger.log(\"Attempting to dehydrate device\");\n\n logger.log(\"Creating account\");\n // create the account and all the necessary keys\n const account = new global.Olm.Account();\n account.create();\n const e2eKeys = JSON.parse(account.identity_keys());\n\n const maxKeys = account.max_number_of_one_time_keys();\n // FIXME: generate in small batches?\n account.generate_one_time_keys(maxKeys / 2);\n account.generate_fallback_key();\n const otks: Record = JSON.parse(account.one_time_keys());\n const fallbacks: Record = JSON.parse(account.fallback_key());\n account.mark_keys_as_published();\n\n // dehydrate the account and store it on the server\n const pickledAccount = account.pickle(new Uint8Array(this.key!));\n\n const deviceData: { [props: string]: any } = {\n algorithm: DEHYDRATION_ALGORITHM,\n account: pickledAccount,\n };\n if (this.keyInfo!.passphrase) {\n deviceData.passphrase = this.keyInfo!.passphrase;\n }\n\n logger.log(\"Uploading account to server\");\n // eslint-disable-next-line camelcase\n const dehydrateResult = await this.crypto.baseApis.http.authedRequest<{ device_id: string }>(\n Method.Put,\n \"/dehydrated_device\",\n undefined,\n {\n device_data: deviceData,\n initial_device_display_name: this.deviceDisplayName,\n },\n {\n prefix: \"/_matrix/client/unstable/org.matrix.msc2697.v2\",\n },\n );\n\n // send the keys to the server\n const deviceId = dehydrateResult.device_id;\n logger.log(\"Preparing device keys\", deviceId);\n const deviceKeys: IDeviceKeys = {\n algorithms: this.crypto.supportedAlgorithms,\n device_id: deviceId,\n user_id: this.crypto.userId,\n keys: {\n [`ed25519:${deviceId}`]: e2eKeys.ed25519,\n [`curve25519:${deviceId}`]: e2eKeys.curve25519,\n },\n };\n const deviceSignature = account.sign(anotherjson.stringify(deviceKeys));\n deviceKeys.signatures = {\n [this.crypto.userId]: {\n [`ed25519:${deviceId}`]: deviceSignature,\n },\n };\n if (this.crypto.crossSigningInfo.getId(\"self_signing\")) {\n await this.crypto.crossSigningInfo.signObject(deviceKeys, \"self_signing\");\n }\n\n logger.log(\"Preparing one-time keys\");\n const oneTimeKeys: Record = {};\n for (const [keyId, key] of Object.entries(otks.curve25519)) {\n const k: IOneTimeKey = { key };\n const signature = account.sign(anotherjson.stringify(k));\n k.signatures = {\n [this.crypto.userId]: {\n [`ed25519:${deviceId}`]: signature,\n },\n };\n oneTimeKeys[`signed_curve25519:${keyId}`] = k;\n }\n\n logger.log(\"Preparing fallback keys\");\n const fallbackKeys: Record = {};\n for (const [keyId, key] of Object.entries(fallbacks.curve25519)) {\n const k: IOneTimeKey = { key, fallback: true };\n const signature = account.sign(anotherjson.stringify(k));\n k.signatures = {\n [this.crypto.userId]: {\n [`ed25519:${deviceId}`]: signature,\n },\n };\n fallbackKeys[`signed_curve25519:${keyId}`] = k;\n }\n\n logger.log(\"Uploading keys to server\");\n await this.crypto.baseApis.http.authedRequest(\n Method.Post,\n \"/keys/upload/\" + encodeURI(deviceId),\n undefined,\n {\n \"device_keys\": deviceKeys,\n \"one_time_keys\": oneTimeKeys,\n \"org.matrix.msc2732.fallback_keys\": fallbackKeys,\n },\n );\n logger.log(\"Done dehydrating\");\n\n // dehydrate again in a week\n this.timeoutId = global.setTimeout(this.dehydrateDevice.bind(this), oneweek);\n\n return deviceId;\n } finally {\n this.inProgress = false;\n }\n }\n\n public stop(): void {\n if (this.timeoutId) {\n global.clearTimeout(this.timeoutId);\n this.timeoutId = undefined;\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts deleted file mode 100644 index 2363761..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts +++ /dev/null @@ -1,102 +0,0 @@ -import { ISignatures } from "../@types/signed"; -export interface IDevice { - keys: Record; - algorithms: string[]; - verified: DeviceVerification; - known: boolean; - unsigned?: Record; - signatures?: ISignatures; -} -declare enum DeviceVerification { - Blocked = -1, - Unverified = 0, - Verified = 1 -} -/** - * Information about a user's device - */ -export declare class DeviceInfo { - readonly deviceId: string; - /** - * rehydrate a DeviceInfo from the session store - * - * @param obj - raw object from session store - * @param deviceId - id of the device - * - * @returns new DeviceInfo - */ - static fromStorage(obj: Partial, deviceId: string): DeviceInfo; - static DeviceVerification: { - VERIFIED: DeviceVerification; - UNVERIFIED: DeviceVerification; - BLOCKED: DeviceVerification; - }; - /** list of algorithms supported by this device */ - algorithms: string[]; - /** a map from `: -> ` */ - keys: Record; - /** whether the device has been verified/blocked by the user */ - verified: DeviceVerification; - /** - * whether the user knows of this device's existence - * (useful when warning the user that a user has added new devices) - */ - known: boolean; - /** additional data from the homeserver */ - unsigned: Record; - signatures: ISignatures; - /** - * @param deviceId - id of the device - */ - constructor(deviceId: string); - /** - * Prepare a DeviceInfo for JSON serialisation in the session store - * - * @returns deviceinfo with non-serialised members removed - */ - toStorage(): IDevice; - /** - * Get the fingerprint for this device (ie, the Ed25519 key) - * - * @returns base64-encoded fingerprint of this device - */ - getFingerprint(): string; - /** - * Get the identity key for this device (ie, the Curve25519 key) - * - * @returns base64-encoded identity key of this device - */ - getIdentityKey(): string; - /** - * Get the configured display name for this device, if any - * - * @returns displayname - */ - getDisplayName(): string | null; - /** - * Returns true if this device is blocked - * - * @returns true if blocked - */ - isBlocked(): boolean; - /** - * Returns true if this device is verified - * - * @returns true if verified - */ - isVerified(): boolean; - /** - * Returns true if this device is unverified - * - * @returns true if unverified - */ - isUnverified(): boolean; - /** - * Returns true if the user knows about this device's existence - * - * @returns true if known - */ - isKnown(): boolean; -} -export {}; -//# sourceMappingURL=deviceinfo.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts.map deleted file mode 100644 index 10a0011..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"deviceinfo.d.ts","sourceRoot":"","sources":["../../src/crypto/deviceinfo.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,MAAM,WAAW,OAAO;IACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,KAAK,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC/B,UAAU,CAAC,EAAE,WAAW,CAAC;CAC5B;AAED,aAAK,kBAAkB;IACnB,OAAO,KAAK;IACZ,UAAU,IAAI;IACd,QAAQ,IAAI;CACf;AAED;;GAEG;AACH,qBAAa,UAAU;aA4CgB,QAAQ,EAAE,MAAM;IA3CnD;;;;;;;OAOG;WACW,WAAW,CAAC,GAAG,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,MAAM,GAAG,UAAU;IAW9E,OAAc,kBAAkB;;;;MAI9B;IAEF,kDAAkD;IAC3C,UAAU,EAAE,MAAM,EAAE,CAAM;IACjC,2DAA2D;IACpD,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAM;IACzC,+DAA+D;IACxD,QAAQ,qBAAiC;IAChD;;;OAGG;IACI,KAAK,UAAS;IACrB,0CAA0C;IACnC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAM;IACnC,UAAU,EAAE,WAAW,CAAM;IAEpC;;OAEG;gBACgC,QAAQ,EAAE,MAAM;IAEnD;;;;OAIG;IACI,SAAS,IAAI,OAAO;IAW3B;;;;OAIG;IACI,cAAc,IAAI,MAAM;IAI/B;;;;OAIG;IACI,cAAc,IAAI,MAAM;IAI/B;;;;OAIG;IACI,cAAc,IAAI,MAAM,GAAG,IAAI;IAItC;;;;OAIG;IACI,SAAS,IAAI,OAAO;IAI3B;;;;OAIG;IACI,UAAU,IAAI,OAAO;IAI5B;;;;OAIG;IACI,YAAY,IAAI,OAAO;IAI9B;;;;OAIG;IACI,OAAO,IAAI,OAAO;CAG5B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js deleted file mode 100644 index 42dc409..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js +++ /dev/null @@ -1,150 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.DeviceInfo = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -var DeviceVerification; -/** - * Information about a user's device - */ -(function (DeviceVerification) { - DeviceVerification[DeviceVerification["Blocked"] = -1] = "Blocked"; - DeviceVerification[DeviceVerification["Unverified"] = 0] = "Unverified"; - DeviceVerification[DeviceVerification["Verified"] = 1] = "Verified"; -})(DeviceVerification || (DeviceVerification = {})); -class DeviceInfo { - /** - * rehydrate a DeviceInfo from the session store - * - * @param obj - raw object from session store - * @param deviceId - id of the device - * - * @returns new DeviceInfo - */ - static fromStorage(obj, deviceId) { - const res = new DeviceInfo(deviceId); - for (const prop in obj) { - if (obj.hasOwnProperty(prop)) { - // @ts-ignore - this is messy and typescript doesn't like it - res[prop] = obj[prop]; - } - } - return res; - } - /** - * @param deviceId - id of the device - */ - constructor(deviceId) { - this.deviceId = deviceId; - (0, _defineProperty2.default)(this, "algorithms", []); - (0, _defineProperty2.default)(this, "keys", {}); - (0, _defineProperty2.default)(this, "verified", DeviceVerification.Unverified); - (0, _defineProperty2.default)(this, "known", false); - (0, _defineProperty2.default)(this, "unsigned", {}); - (0, _defineProperty2.default)(this, "signatures", {}); - } - - /** - * Prepare a DeviceInfo for JSON serialisation in the session store - * - * @returns deviceinfo with non-serialised members removed - */ - toStorage() { - return { - algorithms: this.algorithms, - keys: this.keys, - verified: this.verified, - known: this.known, - unsigned: this.unsigned, - signatures: this.signatures - }; - } - - /** - * Get the fingerprint for this device (ie, the Ed25519 key) - * - * @returns base64-encoded fingerprint of this device - */ - getFingerprint() { - return this.keys["ed25519:" + this.deviceId]; - } - - /** - * Get the identity key for this device (ie, the Curve25519 key) - * - * @returns base64-encoded identity key of this device - */ - getIdentityKey() { - return this.keys["curve25519:" + this.deviceId]; - } - - /** - * Get the configured display name for this device, if any - * - * @returns displayname - */ - getDisplayName() { - return this.unsigned.device_display_name || null; - } - - /** - * Returns true if this device is blocked - * - * @returns true if blocked - */ - isBlocked() { - return this.verified == DeviceVerification.Blocked; - } - - /** - * Returns true if this device is verified - * - * @returns true if verified - */ - isVerified() { - return this.verified == DeviceVerification.Verified; - } - - /** - * Returns true if this device is unverified - * - * @returns true if unverified - */ - isUnverified() { - return this.verified == DeviceVerification.Unverified; - } - - /** - * Returns true if the user knows about this device's existence - * - * @returns true if known - */ - isKnown() { - return this.known === true; - } -} -exports.DeviceInfo = DeviceInfo; -(0, _defineProperty2.default)(DeviceInfo, "DeviceVerification", { - VERIFIED: DeviceVerification.Verified, - UNVERIFIED: DeviceVerification.Unverified, - BLOCKED: DeviceVerification.Blocked -}); -//# sourceMappingURL=deviceinfo.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js.map deleted file mode 100644 index 4ce37db..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/deviceinfo.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"deviceinfo.js","names":["DeviceVerification","DeviceInfo","fromStorage","obj","deviceId","res","prop","hasOwnProperty","constructor","_defineProperty2","default","Unverified","toStorage","algorithms","keys","verified","known","unsigned","signatures","getFingerprint","getIdentityKey","getDisplayName","device_display_name","isBlocked","Blocked","isVerified","Verified","isUnverified","isKnown","exports","VERIFIED","UNVERIFIED","BLOCKED"],"sources":["../../src/crypto/deviceinfo.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ISignatures } from \"../@types/signed\";\n\nexport interface IDevice {\n keys: Record;\n algorithms: string[];\n verified: DeviceVerification;\n known: boolean;\n unsigned?: Record;\n signatures?: ISignatures;\n}\n\nenum DeviceVerification {\n Blocked = -1,\n Unverified = 0,\n Verified = 1,\n}\n\n/**\n * Information about a user's device\n */\nexport class DeviceInfo {\n /**\n * rehydrate a DeviceInfo from the session store\n *\n * @param obj - raw object from session store\n * @param deviceId - id of the device\n *\n * @returns new DeviceInfo\n */\n public static fromStorage(obj: Partial, deviceId: string): DeviceInfo {\n const res = new DeviceInfo(deviceId);\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n // @ts-ignore - this is messy and typescript doesn't like it\n res[prop as keyof IDevice] = obj[prop as keyof IDevice];\n }\n }\n return res;\n }\n\n public static DeviceVerification = {\n VERIFIED: DeviceVerification.Verified,\n UNVERIFIED: DeviceVerification.Unverified,\n BLOCKED: DeviceVerification.Blocked,\n };\n\n /** list of algorithms supported by this device */\n public algorithms: string[] = [];\n /** a map from `: -> ` */\n public keys: Record = {};\n /** whether the device has been verified/blocked by the user */\n public verified = DeviceVerification.Unverified;\n /**\n * whether the user knows of this device's existence\n * (useful when warning the user that a user has added new devices)\n */\n public known = false;\n /** additional data from the homeserver */\n public unsigned: Record = {};\n public signatures: ISignatures = {};\n\n /**\n * @param deviceId - id of the device\n */\n public constructor(public readonly deviceId: string) {}\n\n /**\n * Prepare a DeviceInfo for JSON serialisation in the session store\n *\n * @returns deviceinfo with non-serialised members removed\n */\n public toStorage(): IDevice {\n return {\n algorithms: this.algorithms,\n keys: this.keys,\n verified: this.verified,\n known: this.known,\n unsigned: this.unsigned,\n signatures: this.signatures,\n };\n }\n\n /**\n * Get the fingerprint for this device (ie, the Ed25519 key)\n *\n * @returns base64-encoded fingerprint of this device\n */\n public getFingerprint(): string {\n return this.keys[\"ed25519:\" + this.deviceId];\n }\n\n /**\n * Get the identity key for this device (ie, the Curve25519 key)\n *\n * @returns base64-encoded identity key of this device\n */\n public getIdentityKey(): string {\n return this.keys[\"curve25519:\" + this.deviceId];\n }\n\n /**\n * Get the configured display name for this device, if any\n *\n * @returns displayname\n */\n public getDisplayName(): string | null {\n return this.unsigned.device_display_name || null;\n }\n\n /**\n * Returns true if this device is blocked\n *\n * @returns true if blocked\n */\n public isBlocked(): boolean {\n return this.verified == DeviceVerification.Blocked;\n }\n\n /**\n * Returns true if this device is verified\n *\n * @returns true if verified\n */\n public isVerified(): boolean {\n return this.verified == DeviceVerification.Verified;\n }\n\n /**\n * Returns true if this device is unverified\n *\n * @returns true if unverified\n */\n public isUnverified(): boolean {\n return this.verified == DeviceVerification.Unverified;\n }\n\n /**\n * Returns true if the user knows about this device's existence\n *\n * @returns true if known\n */\n public isKnown(): boolean {\n return this.known === true;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts deleted file mode 100644 index 8b0811d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts +++ /dev/null @@ -1,1083 +0,0 @@ -import type { IEventDecryptionResult, IMegolmSessionData } from "../@types/crypto"; -import { ToDeviceMessageId } from "../@types/event"; -import { IExportedDevice, OlmDevice } from "./OlmDevice"; -import { IOlmDevice } from "./algorithms/megolm"; -import * as olmlib from "./olmlib"; -import { DeviceInfoMap, DeviceList } from "./DeviceList"; -import { DeviceInfo } from "./deviceinfo"; -import type { DecryptionAlgorithm } from "./algorithms"; -import { CrossSigningInfo, DeviceTrustLevel, UserTrustLevel } from "./CrossSigning"; -import { ISecretRequest, SecretStorage, SecretStorageKeyObject, SecretStorageKeyTuple } from "./SecretStorage"; -import { IAddSecretStorageKeyOpts, ICreateSecretStorageOpts, IEncryptedEventInfo, IImportRoomKeysOpts, IRecoveryKey } from "./api"; -import { VerificationBase } from "./verification/Base"; -import { VerificationRequest } from "./verification/request/VerificationRequest"; -import { InRoomRequests } from "./verification/request/InRoomChannel"; -import { DehydrationManager } from "./dehydration"; -import { BackupManager } from "./backup"; -import { IStore } from "../store"; -import { Room, RoomEvent } from "../models/room"; -import { RoomMemberEvent } from "../models/room-member"; -import { MatrixEvent, MatrixEventEvent } from "../models/event"; -import { ClientEvent, IKeysUploadResponse, IUploadKeySignaturesResponse, MatrixClient } from "../client"; -import type { IRoomEncryption, RoomList } from "./RoomList"; -import { ISyncStateData } from "../sync"; -import { CryptoStore } from "./store/base"; -import { IVerificationChannel } from "./verification/request/Channel"; -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { ISyncResponse, IToDeviceEvent } from "../sync-accumulator"; -import { ISignatures } from "../@types/signed"; -import { IMessage } from "./algorithms/olm"; -import { CryptoBackend, OnSyncCompletedData } from "../common-crypto/CryptoBackend"; -import { SecretStorageKeyDescription } from "../secret-storage"; -/** - * verification method names - */ -export declare const verificationMethods: { - readonly RECIPROCATE_QR_CODE: string; - readonly SAS: string; -}; -export type VerificationMethod = keyof typeof verificationMethods | string; -export declare function isCryptoAvailable(): boolean; -interface IInitOpts { - exportedOlmDevice?: IExportedDevice; - pickleKey?: string; -} -export interface IBootstrapCrossSigningOpts { - /** Optional. Reset even if keys already exist. */ - setupNewCrossSigning?: boolean; - /** - * A function that makes the request requiring auth. Receives the auth data as an object. - * Can be called multiple times, first with an empty authDict, to obtain the flows. - */ - authUploadDeviceSigningKeys?(makeRequest: (authData: any) => Promise<{}>): Promise; -} -export interface ICryptoCallbacks { - getCrossSigningKey?: (keyType: string, pubKey: string) => Promise; - saveCrossSigningKeys?: (keys: Record) => void; - shouldUpgradeDeviceVerifications?: (users: Record) => Promise; - getSecretStorageKey?: (keys: { - keys: Record; - }, name: string) => Promise<[string, Uint8Array] | null>; - cacheSecretStorageKey?: (keyId: string, keyInfo: SecretStorageKeyDescription, key: Uint8Array) => void; - onSecretRequested?: (userId: string, deviceId: string, requestId: string, secretName: string, deviceTrust: DeviceTrustLevel) => Promise; - getDehydrationKey?: (keyInfo: SecretStorageKeyDescription, checkFunc: (key: Uint8Array) => void) => Promise; - getBackupKey?: () => Promise; -} -interface IRoomKey { - room_id: string; - algorithm: string; -} -/** - * The parameters of a room key request. The details of the request may - * vary with the crypto algorithm, but the management and storage layers for - * outgoing requests expect it to have 'room_id' and 'session_id' properties. - */ -export interface IRoomKeyRequestBody extends IRoomKey { - session_id: string; - sender_key: string; -} -export interface ICheckOwnCrossSigningTrustOpts { - allowPrivateKeyRequests?: boolean; -} -interface IUserOlmSession { - deviceIdKey: string; - sessions: { - sessionId: string; - hasReceivedMessage: boolean; - }[]; -} -export interface IRoomKeyRequestRecipient { - userId: string; - deviceId: string; -} -interface ISignableObject { - signatures?: ISignatures; - unsigned?: object; -} -export interface IRequestsMap { - getRequest(event: MatrixEvent): VerificationRequest | undefined; - getRequestByChannel(channel: IVerificationChannel): VerificationRequest | undefined; - setRequest(event: MatrixEvent, request: VerificationRequest): void; - setRequestByChannel(channel: IVerificationChannel, request: VerificationRequest): void; -} -export interface IOlmEncryptedContent { - algorithm: typeof olmlib.OLM_ALGORITHM; - sender_key: string; - ciphertext: Record; - [ToDeviceMessageId]?: string; -} -export interface IMegolmEncryptedContent { - algorithm: typeof olmlib.MEGOLM_ALGORITHM; - sender_key: string; - session_id: string; - device_id: string; - ciphertext: string; - [ToDeviceMessageId]?: string; -} -export type IEncryptedContent = IOlmEncryptedContent | IMegolmEncryptedContent; -export declare enum CryptoEvent { - DeviceVerificationChanged = "deviceVerificationChanged", - UserTrustStatusChanged = "userTrustStatusChanged", - UserCrossSigningUpdated = "userCrossSigningUpdated", - RoomKeyRequest = "crypto.roomKeyRequest", - RoomKeyRequestCancellation = "crypto.roomKeyRequestCancellation", - KeyBackupStatus = "crypto.keyBackupStatus", - KeyBackupFailed = "crypto.keyBackupFailed", - KeyBackupSessionsRemaining = "crypto.keyBackupSessionsRemaining", - KeySignatureUploadFailure = "crypto.keySignatureUploadFailure", - VerificationRequest = "crypto.verification.request", - Warning = "crypto.warning", - WillUpdateDevices = "crypto.willUpdateDevices", - DevicesUpdated = "crypto.devicesUpdated", - KeysChanged = "crossSigning.keysChanged" -} -export type CryptoEventHandlerMap = { - /** - * Fires when a device is marked as verified/unverified/blocked/unblocked by - * {@link MatrixClient#setDeviceVerified|MatrixClient.setDeviceVerified} or - * {@link MatrixClient#setDeviceBlocked|MatrixClient.setDeviceBlocked}. - * - * @param userId - the owner of the verified device - * @param deviceId - the id of the verified device - * @param deviceInfo - updated device information - */ - [CryptoEvent.DeviceVerificationChanged]: (userId: string, deviceId: string, device: DeviceInfo) => void; - /** - * Fires when the trust status of a user changes - * If userId is the userId of the logged-in user, this indicated a change - * in the trust status of the cross-signing data on the account. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * @experimental - * - * @param userId - the userId of the user in question - * @param trustLevel - The new trust level of the user - */ - [CryptoEvent.UserTrustStatusChanged]: (userId: string, trustLevel: UserTrustLevel) => void; - /** - * Fires when we receive a room key request - * - * @param req - request details - */ - [CryptoEvent.RoomKeyRequest]: (request: IncomingRoomKeyRequest) => void; - /** - * Fires when we receive a room key request cancellation - */ - [CryptoEvent.RoomKeyRequestCancellation]: (request: IncomingRoomKeyRequestCancellation) => void; - /** - * Fires whenever the status of e2e key backup changes, as returned by getKeyBackupEnabled() - * @param enabled - true if key backup has been enabled, otherwise false - * @example - * ``` - * matrixClient.on("crypto.keyBackupStatus", function(enabled){ - * if (enabled) { - * [...] - * } - * }); - * ``` - */ - [CryptoEvent.KeyBackupStatus]: (enabled: boolean) => void; - [CryptoEvent.KeyBackupFailed]: (errcode: string) => void; - [CryptoEvent.KeyBackupSessionsRemaining]: (remaining: number) => void; - [CryptoEvent.KeySignatureUploadFailure]: (failures: IUploadKeySignaturesResponse["failures"], source: "checkOwnCrossSigningTrust" | "afterCrossSigningLocalKeyChange" | "setDeviceVerification", upload: (opts: { - shouldEmit: boolean; - }) => Promise) => void; - /** - * Fires when a key verification is requested. - */ - [CryptoEvent.VerificationRequest]: (request: VerificationRequest) => void; - /** - * Fires when the app may wish to warn the user about something related - * the end-to-end crypto. - * - * @param type - One of the strings listed above - */ - [CryptoEvent.Warning]: (type: string) => void; - /** - * Fires when the user's cross-signing keys have changed or cross-signing - * has been enabled/disabled. The client can use getStoredCrossSigningForUser - * with the user ID of the logged in user to check if cross-signing is - * enabled on the account. If enabled, it can test whether the current key - * is trusted using with checkUserTrust with the user ID of the logged - * in user. The checkOwnCrossSigningTrust function may be used to reconcile - * the trust in the account key. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * @experimental - */ - [CryptoEvent.KeysChanged]: (data: {}) => void; - /** - * Fires whenever the stored devices for a user will be updated - * @param users - A list of user IDs that will be updated - * @param initialFetch - If true, the store is empty (apart - * from our own device) and is being seeded. - */ - [CryptoEvent.WillUpdateDevices]: (users: string[], initialFetch: boolean) => void; - /** - * Fires whenever the stored devices for a user have changed - * @param users - A list of user IDs that were updated - * @param initialFetch - If true, the store was empty (apart - * from our own device) and has been seeded. - */ - [CryptoEvent.DevicesUpdated]: (users: string[], initialFetch: boolean) => void; - [CryptoEvent.UserCrossSigningUpdated]: (userId: string) => void; -}; -export declare class Crypto extends TypedEventEmitter implements CryptoBackend { - readonly baseApis: MatrixClient; - readonly userId: string; - private readonly deviceId; - private readonly clientStore; - readonly cryptoStore: CryptoStore; - private readonly roomList; - /** - * @returns The version of Olm. - */ - static getOlmVersion(): [number, number, number]; - readonly backupManager: BackupManager; - readonly crossSigningInfo: CrossSigningInfo; - readonly olmDevice: OlmDevice; - readonly deviceList: DeviceList; - readonly dehydrationManager: DehydrationManager; - readonly secretStorage: SecretStorage; - private readonly reEmitter; - private readonly verificationMethods; - readonly supportedAlgorithms: string[]; - private readonly outgoingRoomKeyRequestManager; - private readonly toDeviceVerificationRequests; - readonly inRoomVerificationRequests: InRoomRequests; - private trustCrossSignedDevices; - private lastOneTimeKeyCheck; - private oneTimeKeyCheckInProgress; - private roomEncryptors; - private roomDecryptors; - private deviceKeys; - globalBlacklistUnverifiedDevices: boolean; - globalErrorOnUnknownDevices: boolean; - private receivedRoomKeyRequests; - private receivedRoomKeyRequestCancellations; - private processingRoomKeyRequests; - private lazyLoadMembers; - private roomDeviceTrackingState; - private lastNewSessionForced; - private sendKeyRequestsImmediately; - private oneTimeKeyCount?; - private needsNewFallback?; - private fallbackCleanup?; - /** - * Cryptography bits - * - * This module is internal to the js-sdk; the public API is via MatrixClient. - * - * @internal - * - * @param baseApis - base matrix api interface - * - * @param userId - The user ID for the local user - * - * @param deviceId - The identifier for this device. - * - * @param clientStore - the MatrixClient data store. - * - * @param cryptoStore - storage for the crypto layer. - * - * @param roomList - An initialised RoomList object - * - * @param verificationMethods - Array of verification methods to use. - * Each element can either be a string from MatrixClient.verificationMethods - * or a class that implements a verification method. - */ - constructor(baseApis: MatrixClient, userId: string, deviceId: string, clientStore: IStore, cryptoStore: CryptoStore, roomList: RoomList, verificationMethods: Array); - /** - * Initialise the crypto module so that it is ready for use - * - * Returns a promise which resolves once the crypto module is ready for use. - * - * @param exportedOlmDevice - (Optional) data from exported device - * that must be re-created. - */ - init({ exportedOlmDevice, pickleKey }?: IInitOpts): Promise; - /** - * Whether to trust a others users signatures of their devices. - * If false, devices will only be considered 'verified' if we have - * verified that device individually (effectively disabling cross-signing). - * - * Default: true - * - * @returns True if trusting cross-signed devices - */ - getCryptoTrustCrossSignedDevices(): boolean; - /** - * See getCryptoTrustCrossSignedDevices - - * This may be set before initCrypto() is called to ensure no races occur. - * - * @param val - True to trust cross-signed devices - */ - setCryptoTrustCrossSignedDevices(val: boolean): void; - /** - * Create a recovery key from a user-supplied passphrase. - * - * @param password - Passphrase string that can be entered by the user - * when restoring the backup as an alternative to entering the recovery key. - * Optional. - * @returns Object with public key metadata, encoded private - * recovery key which should be disposed of after displaying to the user, - * and raw private key to avoid round tripping if needed. - */ - createRecoveryKeyFromPassphrase(password?: string): Promise; - /** - * Checks if the user has previously published cross-signing keys - * - * This means downloading the devicelist for the user and checking if the list includes - * the cross-signing pseudo-device. - * - * @internal - */ - userHasCrossSigningKeys(): Promise; - /** - * Checks whether cross signing: - * - is enabled on this account and trusted by this device - * - has private keys either cached locally or stored in secret storage - * - * If this function returns false, bootstrapCrossSigning() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapCrossSigning() completes successfully, this function should - * return true. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @returns True if cross-signing is ready to be used on this device - */ - isCrossSigningReady(): Promise; - /** - * Checks whether secret storage: - * - is enabled on this account - * - is storing cross-signing private keys - * - is storing session backup key (if enabled) - * - * If this function returns false, bootstrapSecretStorage() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapSecretStorage() completes successfully, this function should - * return true. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @returns True if secret storage is ready to be used on this device - */ - isSecretStorageReady(): Promise; - /** - * Bootstrap cross-signing by creating keys if needed. If everything is already - * set up, then no changes are made, so this is safe to run to ensure - * cross-signing is ready for use. - * - * This function: - * - creates new cross-signing keys if they are not found locally cached nor in - * secret storage (if it has been setup) - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param authUploadDeviceSigningKeys - Function - * called to await an interactive auth flow when uploading device signing keys. - * @param setupNewCrossSigning - Optional. Reset even if keys - * already exist. - * Args: - * A function that makes the request requiring auth. Receives the - * auth data as an object. Can be called multiple times, first with an empty - * authDict, to obtain the flows. - */ - bootstrapCrossSigning({ authUploadDeviceSigningKeys, setupNewCrossSigning, }?: IBootstrapCrossSigningOpts): Promise; - /** - * Bootstrap Secure Secret Storage if needed by creating a default key. If everything is - * already set up, then no changes are made, so this is safe to run to ensure secret - * storage is ready for use. - * - * This function - * - creates a new Secure Secret Storage key if no default key exists - * - if a key backup exists, it is migrated to store the key in the Secret - * Storage - * - creates a backup if none exists, and one is requested - * - migrates Secure Secret Storage to use the latest algorithm, if an outdated - * algorithm is found - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param createSecretStorageKey - Optional. Function - * called to await a secret storage key creation flow. - * Returns a Promise which resolves to an object with public key metadata, encoded private - * recovery key which should be disposed of after displaying to the user, - * and raw private key to avoid round tripping if needed. - * @param keyBackupInfo - The current key backup object. If passed, - * the passphrase and recovery key from this backup will be used. - * @param setupNewKeyBackup - If true, a new key backup version will be - * created and the private key stored in the new SSSS store. Ignored if keyBackupInfo - * is supplied. - * @param setupNewSecretStorage - Optional. Reset even if keys already exist. - * @param getKeyBackupPassphrase - Optional. Function called to get the user's - * current key backup passphrase. Should return a promise that resolves with a Buffer - * containing the key, or rejects if the key cannot be obtained. - * Returns: - * A promise which resolves to key creation data for - * SecretStorage#addKey: an object with `passphrase` etc fields. - */ - bootstrapSecretStorage({ createSecretStorageKey, keyBackupInfo, setupNewKeyBackup, setupNewSecretStorage, getKeyBackupPassphrase, }?: ICreateSecretStorageOpts): Promise; - addSecretStorageKey(algorithm: string, opts: IAddSecretStorageKeyOpts, keyID?: string): Promise; - hasSecretStorageKey(keyID?: string): Promise; - getSecretStorageKey(keyID?: string): Promise; - storeSecret(name: string, secret: string, keys?: string[]): Promise; - getSecret(name: string): Promise; - isSecretStored(name: string): Promise | null>; - requestSecret(name: string, devices: string[]): ISecretRequest; - getDefaultSecretStorageKeyId(): Promise; - setDefaultSecretStorageKeyId(k: string): Promise; - checkSecretStorageKey(key: Uint8Array, info: SecretStorageKeyDescription): Promise; - /** - * Checks that a given secret storage private key matches a given public key. - * This can be used by the getSecretStorageKey callback to verify that the - * private key it is about to supply is the one that was requested. - * - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkSecretStoragePrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean; - /** - * Fetches the backup private key, if cached - * @returns the key, if any, or null - */ - getSessionBackupPrivateKey(): Promise; - /** - * Stores the session backup key to the cache - * @param key - the private key - * @returns a promise so you can catch failures - */ - storeSessionBackupPrivateKey(key: ArrayLike): Promise; - /** - * Checks that a given cross-signing private key matches a given public key. - * This can be used by the getCrossSigningKey callback to verify that the - * private key it is about to supply is the one that was requested. - * - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkCrossSigningPrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean; - /** - * Run various follow-up actions after cross-signing keys have changed locally - * (either by resetting the keys for the account or by getting them from secret - * storage), such as signing the current device, upgrading device - * verifications, etc. - */ - private afterCrossSigningLocalKeyChange; - /** - * Check if a user's cross-signing key is a candidate for upgrading from device - * verification. - * - * @param userId - the user whose cross-signing information is to be checked - * @param crossSigningInfo - the cross-signing information to check - */ - private checkForDeviceVerificationUpgrade; - /** - * Check if the cross-signing key is signed by a verified device. - * - * @param userId - the user ID whose key is being checked - * @param key - the key that is being checked - * @param devices - the user's devices. Should be a map from device ID - * to device info - */ - private checkForValidDeviceSignature; - /** - * Get the user's cross-signing key ID. - * - * @param type - The type of key to get the ID of. One of - * "master", "self_signing", or "user_signing". Defaults to "master". - * - * @returns the key ID - */ - getCrossSigningId(type: string): string | null; - /** - * Get the cross signing information for a given user. - * - * @param userId - the user ID to get the cross-signing info for. - * - * @returns the cross signing information for the user. - */ - getStoredCrossSigningForUser(userId: string): CrossSigningInfo | null; - /** - * Check whether a given user is trusted. - * - * @param userId - The ID of the user to check. - * - * @returns - */ - checkUserTrust(userId: string): UserTrustLevel; - /** - * Check whether a given device is trusted. - * - * @param userId - The ID of the user whose devices is to be checked. - * @param deviceId - The ID of the device to check - * - * @returns - */ - checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel; - /** - * Check whether a given deviceinfo is trusted. - * - * @param userId - The ID of the user whose devices is to be checked. - * @param device - The device info object to check - * - * @returns - */ - checkDeviceInfoTrust(userId: string, device?: DeviceInfo): DeviceTrustLevel; - /** - * Check whether one of our own devices is cross-signed by our - * user's stored keys, regardless of whether we trust those keys yet. - * - * @param deviceId - The ID of the device to check - * - * @returns true if the device is cross-signed - */ - checkIfOwnDeviceCrossSigned(deviceId: string): boolean; - private onDeviceListUserCrossSigningUpdated; - /** - * Check the copy of our cross-signing key that we have in the device list and - * see if we can get the private key. If so, mark it as trusted. - */ - checkOwnCrossSigningTrust({ allowPrivateKeyRequests, }?: ICheckOwnCrossSigningTrustOpts): Promise; - /** - * Store a set of keys as our own, trusted, cross-signing keys. - * - * @param keys - The new trusted set of keys - */ - private storeTrustedSelfKeys; - /** - * Check if the master key is signed by a verified device, and if so, prompt - * the application to mark it as verified. - * - * @param userId - the user ID whose key should be checked - */ - private checkDeviceVerifications; - /** - */ - enableLazyLoading(): void; - /** - * Tell the crypto module to register for MatrixClient events which it needs to - * listen for - * - * @param eventEmitter - event source where we can register - * for event notifications - */ - registerEventHandlers(eventEmitter: TypedEventEmitter): void; - /** - * @deprecated this does nothing and will be removed in a future version - */ - start(): void; - /** Stop background processes related to crypto */ - stop(): void; - /** - * Get the Ed25519 key for this device - * - * @returns base64-encoded ed25519 key. - */ - getDeviceEd25519Key(): string | null; - /** - * Get the Curve25519 key for this device - * - * @returns base64-encoded curve25519 key. - */ - getDeviceCurve25519Key(): string | null; - /** - * Set the global override for whether the client should ever send encrypted - * messages to unverified devices. This provides the default for rooms which - * do not specify a value. - * - * @param value - whether to blacklist all unverified devices by default - * - * @deprecated For external code, use {@link MatrixClient#setGlobalBlacklistUnverifiedDevices}. For - * internal code, set {@link MatrixClient#globalBlacklistUnverifiedDevices} directly. - */ - setGlobalBlacklistUnverifiedDevices(value: boolean): void; - /** - * @returns whether to blacklist all unverified devices by default - * - * @deprecated For external code, use {@link MatrixClient#getGlobalBlacklistUnverifiedDevices}. For - * internal code, reference {@link MatrixClient#globalBlacklistUnverifiedDevices} directly. - */ - getGlobalBlacklistUnverifiedDevices(): boolean; - /** - * Upload the device keys to the homeserver. - * @returns A promise that will resolve when the keys are uploaded. - */ - uploadDeviceKeys(): Promise; - /** - * Stores the current one_time_key count which will be handled later (in a call of - * onSyncCompleted). The count is e.g. coming from a /sync response. - * - * @param currentCount - The current count of one_time_keys to be stored - */ - updateOneTimeKeyCount(currentCount: number): void; - setNeedsNewFallback(needsNewFallback: boolean): void; - getNeedsNewFallback(): boolean; - private maybeUploadOneTimeKeys; - private uploadOneTimeKeys; - /** - * Download the keys for a list of users and stores the keys in the session - * store. - * @param userIds - The users to fetch. - * @param forceDownload - Always download the keys even if cached. - * - * @returns A promise which resolves to a map `userId->deviceId->{@link DeviceInfo}`. - */ - downloadKeys(userIds: string[], forceDownload?: boolean): Promise; - /** - * Get the stored device keys for a user id - * - * @param userId - the user to list keys for. - * - * @returns list of devices, or null if we haven't - * managed to get a list of devices for this user yet. - */ - getStoredDevicesForUser(userId: string): Array | null; - /** - * Get the stored keys for a single device - * - * - * @returns device, or undefined - * if we don't know about this device - */ - getStoredDevice(userId: string, deviceId: string): DeviceInfo | undefined; - /** - * Save the device list, if necessary - * - * @param delay - Time in ms before which the save actually happens. - * By default, the save is delayed for a short period in order to batch - * multiple writes, but this behaviour can be disabled by passing 0. - * - * @returns true if the data was saved, false if - * it was not (eg. because no changes were pending). The promise - * will only resolve once the data is saved, so may take some time - * to resolve. - */ - saveDeviceList(delay: number): Promise; - /** - * Update the blocked/verified state of the given device - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param verified - whether to mark the device as verified. Null to - * leave unchanged. - * - * @param blocked - whether to mark the device as blocked. Null to - * leave unchanged. - * - * @param known - whether to mark that the user has been made aware of - * the existence of this device. Null to leave unchanged - * - * @param keys - The list of keys that was present - * during the device verification. This will be double checked with the list - * of keys the given device has currently. - * - * @returns updated DeviceInfo - */ - setDeviceVerification(userId: string, deviceId: string, verified?: boolean | null, blocked?: boolean | null, known?: boolean | null, keys?: Record): Promise; - findVerificationRequestDMInProgress(roomId: string): VerificationRequest | undefined; - getVerificationRequestsToDeviceInProgress(userId: string): VerificationRequest[]; - requestVerificationDM(userId: string, roomId: string): Promise; - requestVerification(userId: string, devices?: string[]): Promise; - private requestVerificationWithChannel; - beginKeyVerification(method: string, userId: string, deviceId: string, transactionId?: string | null): VerificationBase; - legacyDeviceVerification(userId: string, deviceId: string, method: VerificationMethod): Promise; - /** - * Get information on the active olm sessions with a user - *

- * Returns a map from device id to an object with keys 'deviceIdKey' (the - * device's curve25519 identity key) and 'sessions' (an array of objects in the - * same format as that returned by - * {@link OlmDevice#getSessionInfoForDevice}). - *

- * This method is provided for debugging purposes. - * - * @param userId - id of user to inspect - */ - getOlmSessionsForUser(userId: string): Promise>; - /** - * Get the device which sent an event - * - * @param event - event to be checked - */ - getEventSenderDeviceInfo(event: MatrixEvent): DeviceInfo | null; - /** - * Get information about the encryption of an event - * - * @param event - event to be checked - * - * @returns An object with the fields: - * - encrypted: whether the event is encrypted (if not encrypted, some of the - * other properties may not be set) - * - senderKey: the sender's key - * - algorithm: the algorithm used to encrypt the event - * - authenticated: whether we can be sure that the owner of the senderKey - * sent the event - * - sender: the sender's device information, if available - * - mismatchedSender: if the event's ed25519 and curve25519 keys don't match - * (only meaningful if `sender` is set) - */ - getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo; - /** - * Forces the current outbound group session to be discarded such - * that another one will be created next time an event is sent. - * - * @param roomId - The ID of the room to discard the session for - * - * This should not normally be necessary. - */ - forceDiscardSession(roomId: string): Promise; - /** - * Configure a room to use encryption (ie, save a flag in the cryptoStore). - * - * @param roomId - The room ID to enable encryption in. - * - * @param config - The encryption config for the room. - * - * @param inhibitDeviceQuery - true to suppress device list query for - * users in the room (for now). In case lazy loading is enabled, - * the device query is always inhibited as the members are not tracked. - * - * @deprecated It is normally incorrect to call this method directly. Encryption - * is enabled by receiving an `m.room.encryption` event (which we may have sent - * previously). - */ - setRoomEncryption(roomId: string, config: IRoomEncryption, inhibitDeviceQuery?: boolean): Promise; - /** - * Set up encryption for a room. - * - * This is called when an m.room.encryption event is received. It saves a flag - * for the room in the cryptoStore (if it wasn't already set), sets up an "encryptor" for - * the room, and enables device-list tracking for the room. - * - * It does not initiate a device list query for the room. That is normally - * done once we finish processing the sync, in onSyncCompleted. - * - * @param room - The room to enable encryption in. - * @param config - The encryption config for the room. - */ - private setRoomEncryptionImpl; - /** - * Make sure we are tracking the device lists for all users in this room. - * - * @param roomId - The room ID to start tracking devices in. - * @returns when all devices for the room have been fetched and marked to track - * @deprecated there's normally no need to call this function: device list tracking - * will be enabled as soon as we have the full membership list. - */ - trackRoomDevices(roomId: string): Promise; - /** - * Make sure we are tracking the device lists for all users in this room. - * - * This is normally called when we are about to send an encrypted event, to make sure - * we have all the devices in the room; but it is also called when processing an - * m.room.encryption state event (if lazy-loading is disabled), or when members are - * loaded (if lazy-loading is enabled), to prepare the device list. - * - * @param room - Room to enable device-list tracking in - */ - private trackRoomDevicesImpl; - /** - * Try to make sure we have established olm sessions for all known devices for - * the given users. - * - * @param users - list of user ids - * @param force - If true, force a new Olm session to be created. Default false. - * - * @returns resolves once the sessions are complete, to - * an Object mapping from userId to deviceId to - * {@link OlmSessionResult} - */ - ensureOlmSessionsForUsers(users: string[], force?: boolean): Promise>>; - /** - * Get a list containing all of the room keys - * - * @returns a list of session export objects - */ - exportRoomKeys(): Promise; - /** - * Import a list of room keys previously exported by exportRoomKeys - * - * @param keys - a list of session export objects - * @returns a promise which resolves once the keys have been imported - */ - importRoomKeys(keys: IMegolmSessionData[], opts?: IImportRoomKeysOpts): Promise; - /** - * Counts the number of end to end session keys that are waiting to be backed up - * @returns Promise which resolves to the number of sessions requiring backup - */ - countSessionsNeedingBackup(): Promise; - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * - * @param room - the room the event is in - */ - prepareToEncrypt(room: Room): void; - /** - * Encrypt an event according to the configuration of the room. - * - * @param event - event to be sent - * - * @param room - destination room. - * - * @returns Promise which resolves when the event has been - * encrypted, or null if nothing was needed - */ - encryptEvent(event: MatrixEvent, room: Room): Promise; - /** - * Decrypt a received event - * - * - * @returns resolves once we have - * finished decrypting. Rejects with an `algorithms.DecryptionError` if there - * is a problem decrypting the event. - */ - decryptEvent(event: MatrixEvent): Promise; - /** - * Handle the notification from /sync or /keys/changes that device lists have - * been changed. - * - * @param syncData - Object containing sync tokens associated with this sync - * @param syncDeviceLists - device_lists field from /sync, or response from - * /keys/changes - */ - handleDeviceListChanges(syncData: ISyncStateData, syncDeviceLists: Required["device_lists"]): Promise; - /** - * Send a request for some room keys, if we have not already done so - * - * @param resend - whether to resend the key request if there is - * already one - * - * @returns a promise that resolves when the key request is queued - */ - requestRoomKey(requestBody: IRoomKeyRequestBody, recipients: IRoomKeyRequestRecipient[], resend?: boolean): Promise; - /** - * Cancel any earlier room key request - * - * @param requestBody - parameters to match for cancellation - */ - cancelRoomKeyRequest(requestBody: IRoomKeyRequestBody): void; - /** - * Re-send any outgoing key requests, eg after verification - * @returns - */ - cancelAndResendAllOutgoingKeyRequests(): Promise; - /** - * handle an m.room.encryption event - * - * @param room - in which the event was received - * @param event - encryption event to be processed - */ - onCryptoEvent(room: Room, event: MatrixEvent): Promise; - /** - * Called before the result of a sync is processed - * - * @param syncData - the data from the 'MatrixClient.sync' event - */ - onSyncWillProcess(syncData: ISyncStateData): Promise; - /** - * handle the completion of a /sync - * - * This is called after the processing of each successful /sync response. - * It is an opportunity to do a batch process on the information received. - * - * @param syncData - the data from the 'MatrixClient.sync' event - */ - onSyncCompleted(syncData: OnSyncCompletedData): Promise; - /** - * Trigger the appropriate invalidations and removes for a given - * device list - * - * @param deviceLists - device_lists field from /sync, or response from - * /keys/changes - */ - private evalDeviceListChanges; - /** - * Get a list of all the IDs of users we share an e2e room with - * for which we are tracking devices already - * - * @returns List of user IDs - */ - private getTrackedE2eUsers; - /** - * Get a list of the e2e-enabled rooms we are members of, - * and for which we are already tracking the devices - * - * @returns - */ - private getTrackedE2eRooms; - /** - * Encrypts and sends a given object via Olm to-device messages to a given - * set of devices. - * @param userDeviceInfoArr - the devices to send to - * @param payload - fields to include in the encrypted payload - * @returns Promise which - * resolves once the message has been encrypted and sent to the given - * userDeviceMap, and returns the `{ contentMap, deviceInfoByDeviceId }` - * of the successfully sent messages. - */ - encryptAndSendToDevices(userDeviceInfoArr: IOlmDevice[], payload: object): Promise; - private onMembership; - preprocessToDeviceMessages(events: IToDeviceEvent[]): Promise; - preprocessOneTimeKeyCounts(oneTimeKeysCounts: Map): Promise; - preprocessUnusedFallbackKeys(unusedFallbackKeys: Set): Promise; - private onToDeviceEvent; - /** - * Handle a key event - * - * @internal - * @param event - key event - */ - private onRoomKeyEvent; - /** - * Handle a key withheld event - * - * @internal - * @param event - key withheld event - */ - private onRoomKeyWithheldEvent; - /** - * Handle a general key verification event. - * - * @internal - * @param event - verification start event - */ - private onKeyVerificationMessage; - /** - * Handle key verification requests sent as timeline events - * - * @internal - * @param event - the timeline event - * @param room - not used - * @param atStart - not used - * @param removed - not used - * @param whether - this is a live event - */ - private onTimelineEvent; - private handleVerificationEvent; - /** - * Handle a toDevice event that couldn't be decrypted - * - * @internal - * @param event - undecryptable event - */ - private onToDeviceBadEncrypted; - /** - * Handle a change in the membership state of a member of a room - * - * @internal - * @param event - event causing the change - * @param member - user whose membership changed - * @param oldMembership - previous membership - */ - private onRoomMembership; - /** - * Called when we get an m.room_key_request event. - * - * @internal - * @param event - key request event - */ - private onRoomKeyRequestEvent; - /** - * Process any m.room_key_request events which were queued up during the - * current sync. - * - * @internal - */ - private processReceivedRoomKeyRequests; - /** - * Helper for processReceivedRoomKeyRequests - * - */ - private processReceivedRoomKeyRequest; - /** - * Helper for processReceivedRoomKeyRequests - * - */ - private processReceivedRoomKeyRequestCancellation; - /** - * Get a decryptor for a given room and algorithm. - * - * If we already have a decryptor for the given room and algorithm, return - * it. Otherwise try to instantiate it. - * - * @internal - * - * @param roomId - room id for decryptor. If undefined, a temporary - * decryptor is instantiated. - * - * @param algorithm - crypto algorithm - * - * @throws {@link DecryptionError} if the algorithm is unknown - */ - getRoomDecryptor(roomId: string | null, algorithm: string): DecryptionAlgorithm; - /** - * Get all the room decryptors for a given encryption algorithm. - * - * @param algorithm - The encryption algorithm - * - * @returns An array of room decryptors - */ - private getRoomDecryptors; - /** - * sign the given object with our ed25519 key - * - * @param obj - Object to which we will add a 'signatures' property - */ - signObject(obj: T): Promise; -} -/** - * Fix up the backup key, that may be in the wrong format due to a bug in a - * migration step. Some backup keys were stored as a comma-separated list of - * integers, rather than a base64-encoded byte array. If this function is - * passed a string that looks like a list of integers rather than a base64 - * string, it will attempt to convert it to the right format. - * - * @param key - the key to check - * @returns If the key is in the wrong format, then the fixed - * key will be returned. Otherwise null will be returned. - * - */ -export declare function fixBackupKey(key?: string): string | null; -/** - * Represents a received m.room_key_request event - */ -export declare class IncomingRoomKeyRequest { - /** user requesting the key */ - readonly userId: string; - /** device requesting the key */ - readonly deviceId: string; - /** unique id for the request */ - readonly requestId: string; - readonly requestBody: IRoomKeyRequestBody; - /** - * callback which, when called, will ask - * the relevant crypto algorithm implementation to share the keys for - * this request. - */ - share: () => void; - constructor(event: MatrixEvent); -} -/** - * Represents a received m.room_key_request cancellation - */ -declare class IncomingRoomKeyRequestCancellation { - /** user requesting the cancellation */ - readonly userId: string; - /** device requesting the cancellation */ - readonly deviceId: string; - /** unique id for the request to be cancelled */ - readonly requestId: string; - constructor(event: MatrixEvent); -} -export type { IEventDecryptionResult, IMegolmSessionData } from "../@types/crypto"; -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts.map deleted file mode 100644 index c7021f3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/crypto/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js deleted file mode 100644 index d7d8551..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js +++ /dev/null @@ -1,3290 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.IncomingRoomKeyRequest = exports.CryptoEvent = exports.Crypto = void 0; -exports.fixBackupKey = fixBackupKey; -exports.isCryptoAvailable = isCryptoAvailable; -exports.verificationMethods = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _anotherJson = _interopRequireDefault(require("another-json")); -var _uuid = require("uuid"); -var _event = require("../@types/event"); -var _ReEmitter = require("../ReEmitter"); -var _logger = require("../logger"); -var _OlmDevice = require("./OlmDevice"); -var olmlib = _interopRequireWildcard(require("./olmlib")); -var _DeviceList = require("./DeviceList"); -var _deviceinfo = require("./deviceinfo"); -var algorithms = _interopRequireWildcard(require("./algorithms")); -var _CrossSigning = require("./CrossSigning"); -var _EncryptionSetup = require("./EncryptionSetup"); -var _SecretStorage = require("./SecretStorage"); -var _OutgoingRoomKeyRequestManager = require("./OutgoingRoomKeyRequestManager"); -var _indexeddbCryptoStore = require("./store/indexeddb-crypto-store"); -var _QRCode = require("./verification/QRCode"); -var _SAS = require("./verification/SAS"); -var _key_passphrase = require("./key_passphrase"); -var _recoverykey = require("./recoverykey"); -var _VerificationRequest = require("./verification/request/VerificationRequest"); -var _InRoomChannel = require("./verification/request/InRoomChannel"); -var _ToDeviceChannel = require("./verification/request/ToDeviceChannel"); -var _IllegalMethod = require("./verification/IllegalMethod"); -var _errors = require("../errors"); -var _aes = require("./aes"); -var _dehydration = require("./dehydration"); -var _backup = require("./backup"); -var _room = require("../models/room"); -var _roomMember = require("../models/room-member"); -var _event2 = require("../models/event"); -var _client = require("../client"); -var _typedEventEmitter = require("../models/typed-event-emitter"); -var _roomState = require("../models/room-state"); -var _utils = require("../utils"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -const DeviceVerification = _deviceinfo.DeviceInfo.DeviceVerification; -const defaultVerificationMethods = { - [_QRCode.ReciprocateQRCode.NAME]: _QRCode.ReciprocateQRCode, - [_SAS.SAS.NAME]: _SAS.SAS, - // These two can't be used for actual verification, but we do - // need to be able to define them here for the verification flows - // to start. - [_QRCode.SHOW_QR_CODE_METHOD]: _IllegalMethod.IllegalMethod, - [_QRCode.SCAN_QR_CODE_METHOD]: _IllegalMethod.IllegalMethod -}; - -/** - * verification method names - */ -// legacy export identifier -const verificationMethods = { - RECIPROCATE_QR_CODE: _QRCode.ReciprocateQRCode.NAME, - SAS: _SAS.SAS.NAME -}; -exports.verificationMethods = verificationMethods; -function isCryptoAvailable() { - return Boolean(global.Olm); -} -const MIN_FORCE_SESSION_INTERVAL_MS = 60 * 60 * 1000; -let CryptoEvent; -exports.CryptoEvent = CryptoEvent; -(function (CryptoEvent) { - CryptoEvent["DeviceVerificationChanged"] = "deviceVerificationChanged"; - CryptoEvent["UserTrustStatusChanged"] = "userTrustStatusChanged"; - CryptoEvent["UserCrossSigningUpdated"] = "userCrossSigningUpdated"; - CryptoEvent["RoomKeyRequest"] = "crypto.roomKeyRequest"; - CryptoEvent["RoomKeyRequestCancellation"] = "crypto.roomKeyRequestCancellation"; - CryptoEvent["KeyBackupStatus"] = "crypto.keyBackupStatus"; - CryptoEvent["KeyBackupFailed"] = "crypto.keyBackupFailed"; - CryptoEvent["KeyBackupSessionsRemaining"] = "crypto.keyBackupSessionsRemaining"; - CryptoEvent["KeySignatureUploadFailure"] = "crypto.keySignatureUploadFailure"; - CryptoEvent["VerificationRequest"] = "crypto.verification.request"; - CryptoEvent["Warning"] = "crypto.warning"; - CryptoEvent["WillUpdateDevices"] = "crypto.willUpdateDevices"; - CryptoEvent["DevicesUpdated"] = "crypto.devicesUpdated"; - CryptoEvent["KeysChanged"] = "crossSigning.keysChanged"; -})(CryptoEvent || (exports.CryptoEvent = CryptoEvent = {})); -class Crypto extends _typedEventEmitter.TypedEventEmitter { - /** - * @returns The version of Olm. - */ - static getOlmVersion() { - return _OlmDevice.OlmDevice.getOlmVersion(); - } - /** - * Cryptography bits - * - * This module is internal to the js-sdk; the public API is via MatrixClient. - * - * @internal - * - * @param baseApis - base matrix api interface - * - * @param userId - The user ID for the local user - * - * @param deviceId - The identifier for this device. - * - * @param clientStore - the MatrixClient data store. - * - * @param cryptoStore - storage for the crypto layer. - * - * @param roomList - An initialised RoomList object - * - * @param verificationMethods - Array of verification methods to use. - * Each element can either be a string from MatrixClient.verificationMethods - * or a class that implements a verification method. - */ - constructor(baseApis, userId, deviceId, clientStore, cryptoStore, roomList, verificationMethods) { - super(); - this.baseApis = baseApis; - this.userId = userId; - this.deviceId = deviceId; - this.clientStore = clientStore; - this.cryptoStore = cryptoStore; - this.roomList = roomList; - (0, _defineProperty2.default)(this, "backupManager", void 0); - (0, _defineProperty2.default)(this, "crossSigningInfo", void 0); - (0, _defineProperty2.default)(this, "olmDevice", void 0); - (0, _defineProperty2.default)(this, "deviceList", void 0); - (0, _defineProperty2.default)(this, "dehydrationManager", void 0); - (0, _defineProperty2.default)(this, "secretStorage", void 0); - (0, _defineProperty2.default)(this, "reEmitter", void 0); - (0, _defineProperty2.default)(this, "verificationMethods", void 0); - (0, _defineProperty2.default)(this, "supportedAlgorithms", void 0); - (0, _defineProperty2.default)(this, "outgoingRoomKeyRequestManager", void 0); - (0, _defineProperty2.default)(this, "toDeviceVerificationRequests", void 0); - (0, _defineProperty2.default)(this, "inRoomVerificationRequests", void 0); - (0, _defineProperty2.default)(this, "trustCrossSignedDevices", true); - (0, _defineProperty2.default)(this, "lastOneTimeKeyCheck", null); - (0, _defineProperty2.default)(this, "oneTimeKeyCheckInProgress", false); - (0, _defineProperty2.default)(this, "roomEncryptors", new Map()); - (0, _defineProperty2.default)(this, "roomDecryptors", new Map()); - (0, _defineProperty2.default)(this, "deviceKeys", {}); - (0, _defineProperty2.default)(this, "globalBlacklistUnverifiedDevices", false); - (0, _defineProperty2.default)(this, "globalErrorOnUnknownDevices", true); - (0, _defineProperty2.default)(this, "receivedRoomKeyRequests", []); - (0, _defineProperty2.default)(this, "receivedRoomKeyRequestCancellations", []); - (0, _defineProperty2.default)(this, "processingRoomKeyRequests", false); - (0, _defineProperty2.default)(this, "lazyLoadMembers", false); - (0, _defineProperty2.default)(this, "roomDeviceTrackingState", {}); - (0, _defineProperty2.default)(this, "lastNewSessionForced", new _utils.MapWithDefault(() => new _utils.MapWithDefault(() => 0))); - (0, _defineProperty2.default)(this, "sendKeyRequestsImmediately", false); - (0, _defineProperty2.default)(this, "oneTimeKeyCount", void 0); - (0, _defineProperty2.default)(this, "needsNewFallback", void 0); - (0, _defineProperty2.default)(this, "fallbackCleanup", void 0); - (0, _defineProperty2.default)(this, "onDeviceListUserCrossSigningUpdated", async userId => { - if (userId === this.userId) { - // An update to our own cross-signing key. - // Get the new key first: - const newCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId); - const seenPubkey = newCrossSigning ? newCrossSigning.getId() : null; - const currentPubkey = this.crossSigningInfo.getId(); - const changed = currentPubkey !== seenPubkey; - if (currentPubkey && seenPubkey && !changed) { - // If it's not changed, just make sure everything is up to date - await this.checkOwnCrossSigningTrust(); - } else { - // We'll now be in a state where cross-signing on the account is not trusted - // because our locally stored cross-signing keys will not match the ones - // on the server for our account. So we clear our own stored cross-signing keys, - // effectively disabling cross-signing until the user gets verified by the device - // that reset the keys - this.storeTrustedSelfKeys(null); - // emit cross-signing has been disabled - this.emit(CryptoEvent.KeysChanged, {}); - // as the trust for our own user has changed, - // also emit an event for this - this.emit(CryptoEvent.UserTrustStatusChanged, this.userId, this.checkUserTrust(userId)); - } - } else { - await this.checkDeviceVerifications(userId); - - // Update verified before latch using the current state and save the new - // latch value in the device list store. - const crossSigning = this.deviceList.getStoredCrossSigningForUser(userId); - if (crossSigning) { - crossSigning.updateCrossSigningVerifiedBefore(this.checkUserTrust(userId).isCrossSigningVerified()); - this.deviceList.setRawStoredCrossSigningForUser(userId, crossSigning.toStorage()); - } - this.emit(CryptoEvent.UserTrustStatusChanged, userId, this.checkUserTrust(userId)); - } - }); - (0, _defineProperty2.default)(this, "onMembership", (event, member, oldMembership) => { - try { - this.onRoomMembership(event, member, oldMembership); - } catch (e) { - _logger.logger.error("Error handling membership change:", e); - } - }); - (0, _defineProperty2.default)(this, "onToDeviceEvent", event => { - try { - _logger.logger.log(`received to-device ${event.getType()} from: ` + `${event.getSender()} id: ${event.getContent()[_event.ToDeviceMessageId]}`); - if (event.getType() == "m.room_key" || event.getType() == "m.forwarded_room_key") { - this.onRoomKeyEvent(event); - } else if (event.getType() == "m.room_key_request") { - this.onRoomKeyRequestEvent(event); - } else if (event.getType() === "m.secret.request") { - this.secretStorage.onRequestReceived(event); - } else if (event.getType() === "m.secret.send") { - this.secretStorage.onSecretReceived(event); - } else if (event.getType() === "m.room_key.withheld") { - this.onRoomKeyWithheldEvent(event); - } else if (event.getContent().transaction_id) { - this.onKeyVerificationMessage(event); - } else if (event.getContent().msgtype === "m.bad.encrypted") { - this.onToDeviceBadEncrypted(event); - } else if (event.isBeingDecrypted() || event.shouldAttemptDecryption()) { - if (!event.isBeingDecrypted()) { - event.attemptDecryption(this); - } - // once the event has been decrypted, try again - event.once(_event2.MatrixEventEvent.Decrypted, ev => { - this.onToDeviceEvent(ev); - }); - } - } catch (e) { - _logger.logger.error("Error handling toDeviceEvent:", e); - } - }); - (0, _defineProperty2.default)(this, "onTimelineEvent", (event, room, atStart, removed, { - liveEvent = true - } = {}) => { - if (!_InRoomChannel.InRoomChannel.validateEvent(event, this.baseApis)) { - return; - } - const createRequest = event => { - const channel = new _InRoomChannel.InRoomChannel(this.baseApis, event.getRoomId()); - return new _VerificationRequest.VerificationRequest(channel, this.verificationMethods, this.baseApis); - }; - this.handleVerificationEvent(event, this.inRoomVerificationRequests, createRequest, liveEvent); - }); - this.reEmitter = new _ReEmitter.TypedReEmitter(this); - if (verificationMethods) { - this.verificationMethods = new Map(); - for (const method of verificationMethods) { - if (typeof method === "string") { - if (defaultVerificationMethods[method]) { - this.verificationMethods.set(method, defaultVerificationMethods[method]); - } - } else if (method["NAME"]) { - this.verificationMethods.set(method["NAME"], method); - } else { - _logger.logger.warn(`Excluding unknown verification method ${method}`); - } - } - } else { - this.verificationMethods = new Map(Object.entries(defaultVerificationMethods)); - } - this.backupManager = new _backup.BackupManager(baseApis, async () => { - // try to get key from cache - const cachedKey = await this.getSessionBackupPrivateKey(); - if (cachedKey) { - return cachedKey; - } - - // try to get key from secret storage - const storedKey = await this.getSecret("m.megolm_backup.v1"); - if (storedKey) { - // ensure that the key is in the right format. If not, fix the key and - // store the fixed version - const fixedKey = fixBackupKey(storedKey); - if (fixedKey) { - const keys = await this.getSecretStorageKey(); - await this.storeSecret("m.megolm_backup.v1", fixedKey, [keys[0]]); - } - return olmlib.decodeBase64(fixedKey || storedKey); - } - - // try to get key from app - if (this.baseApis.cryptoCallbacks && this.baseApis.cryptoCallbacks.getBackupKey) { - return this.baseApis.cryptoCallbacks.getBackupKey(); - } - throw new Error("Unable to get private key"); - }); - this.olmDevice = new _OlmDevice.OlmDevice(cryptoStore); - this.deviceList = new _DeviceList.DeviceList(baseApis, cryptoStore, this.olmDevice); - - // XXX: This isn't removed at any point, but then none of the event listeners - // this class sets seem to be removed at any point... :/ - this.deviceList.on(CryptoEvent.UserCrossSigningUpdated, this.onDeviceListUserCrossSigningUpdated); - this.reEmitter.reEmit(this.deviceList, [CryptoEvent.DevicesUpdated, CryptoEvent.WillUpdateDevices]); - this.supportedAlgorithms = Array.from(algorithms.DECRYPTION_CLASSES.keys()); - this.outgoingRoomKeyRequestManager = new _OutgoingRoomKeyRequestManager.OutgoingRoomKeyRequestManager(baseApis, this.deviceId, this.cryptoStore); - this.toDeviceVerificationRequests = new _ToDeviceChannel.ToDeviceRequests(); - this.inRoomVerificationRequests = new _InRoomChannel.InRoomRequests(); - const cryptoCallbacks = this.baseApis.cryptoCallbacks || {}; - const cacheCallbacks = (0, _CrossSigning.createCryptoStoreCacheCallbacks)(cryptoStore, this.olmDevice); - this.crossSigningInfo = new _CrossSigning.CrossSigningInfo(userId, cryptoCallbacks, cacheCallbacks); - // Yes, we pass the client twice here: see SecretStorage - this.secretStorage = new _SecretStorage.SecretStorage(baseApis, cryptoCallbacks, baseApis); - this.dehydrationManager = new _dehydration.DehydrationManager(this); - - // Assuming no app-supplied callback, default to getting from SSSS. - if (!cryptoCallbacks.getCrossSigningKey && cryptoCallbacks.getSecretStorageKey) { - cryptoCallbacks.getCrossSigningKey = async type => { - return _CrossSigning.CrossSigningInfo.getFromSecretStorage(type, this.secretStorage); - }; - } - } - - /** - * Initialise the crypto module so that it is ready for use - * - * Returns a promise which resolves once the crypto module is ready for use. - * - * @param exportedOlmDevice - (Optional) data from exported device - * that must be re-created. - */ - async init({ - exportedOlmDevice, - pickleKey - } = {}) { - _logger.logger.log("Crypto: initialising Olm..."); - await global.Olm.init(); - _logger.logger.log(exportedOlmDevice ? "Crypto: initialising Olm device from exported device..." : "Crypto: initialising Olm device..."); - await this.olmDevice.init({ - fromExportedDevice: exportedOlmDevice, - pickleKey - }); - _logger.logger.log("Crypto: loading device list..."); - await this.deviceList.load(); - - // build our device keys: these will later be uploaded - this.deviceKeys["ed25519:" + this.deviceId] = this.olmDevice.deviceEd25519Key; - this.deviceKeys["curve25519:" + this.deviceId] = this.olmDevice.deviceCurve25519Key; - _logger.logger.log("Crypto: fetching own devices..."); - let myDevices = this.deviceList.getRawStoredDevicesForUser(this.userId); - if (!myDevices) { - myDevices = {}; - } - if (!myDevices[this.deviceId]) { - // add our own deviceinfo to the cryptoStore - _logger.logger.log("Crypto: adding this device to the store..."); - const deviceInfo = { - keys: this.deviceKeys, - algorithms: this.supportedAlgorithms, - verified: DeviceVerification.VERIFIED, - known: true - }; - myDevices[this.deviceId] = deviceInfo; - this.deviceList.storeDevicesForUser(this.userId, myDevices); - this.deviceList.saveIfDirty(); - } - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.cryptoStore.getCrossSigningKeys(txn, keys => { - // can be an empty object after resetting cross-signing keys, see storeTrustedSelfKeys - if (keys && Object.keys(keys).length !== 0) { - _logger.logger.log("Loaded cross-signing public keys from crypto store"); - this.crossSigningInfo.setKeys(keys); - } - }); - }); - // make sure we are keeping track of our own devices - // (this is important for key backups & things) - this.deviceList.startTrackingDeviceList(this.userId); - _logger.logger.log("Crypto: checking for key backup..."); - this.backupManager.checkAndStart(); - } - - /** - * Whether to trust a others users signatures of their devices. - * If false, devices will only be considered 'verified' if we have - * verified that device individually (effectively disabling cross-signing). - * - * Default: true - * - * @returns True if trusting cross-signed devices - */ - getCryptoTrustCrossSignedDevices() { - return this.trustCrossSignedDevices; - } - - /** - * See getCryptoTrustCrossSignedDevices - * This may be set before initCrypto() is called to ensure no races occur. - * - * @param val - True to trust cross-signed devices - */ - setCryptoTrustCrossSignedDevices(val) { - this.trustCrossSignedDevices = val; - for (const userId of this.deviceList.getKnownUserIds()) { - const devices = this.deviceList.getRawStoredDevicesForUser(userId); - for (const deviceId of Object.keys(devices)) { - const deviceTrust = this.checkDeviceTrust(userId, deviceId); - // If the device is locally verified then isVerified() is always true, - // so this will only have caused the value to change if the device is - // cross-signing verified but not locally verified - if (!deviceTrust.isLocallyVerified() && deviceTrust.isCrossSigningVerified()) { - const deviceObj = this.deviceList.getStoredDevice(userId, deviceId); - this.emit(CryptoEvent.DeviceVerificationChanged, userId, deviceId, deviceObj); - } - } - } - } - - /** - * Create a recovery key from a user-supplied passphrase. - * - * @param password - Passphrase string that can be entered by the user - * when restoring the backup as an alternative to entering the recovery key. - * Optional. - * @returns Object with public key metadata, encoded private - * recovery key which should be disposed of after displaying to the user, - * and raw private key to avoid round tripping if needed. - */ - async createRecoveryKeyFromPassphrase(password) { - const decryption = new global.Olm.PkDecryption(); - try { - const keyInfo = {}; - if (password) { - const derivation = await (0, _key_passphrase.keyFromPassphrase)(password); - keyInfo.passphrase = { - algorithm: "m.pbkdf2", - iterations: derivation.iterations, - salt: derivation.salt - }; - keyInfo.pubkey = decryption.init_with_private_key(derivation.key); - } else { - keyInfo.pubkey = decryption.generate_key(); - } - const privateKey = decryption.get_private_key(); - const encodedPrivateKey = (0, _recoverykey.encodeRecoveryKey)(privateKey); - return { - keyInfo: keyInfo, - encodedPrivateKey, - privateKey - }; - } finally { - decryption === null || decryption === void 0 ? void 0 : decryption.free(); - } - } - - /** - * Checks if the user has previously published cross-signing keys - * - * This means downloading the devicelist for the user and checking if the list includes - * the cross-signing pseudo-device. - * - * @internal - */ - async userHasCrossSigningKeys() { - await this.downloadKeys([this.userId]); - return this.deviceList.getStoredCrossSigningForUser(this.userId) !== null; - } - - /** - * Checks whether cross signing: - * - is enabled on this account and trusted by this device - * - has private keys either cached locally or stored in secret storage - * - * If this function returns false, bootstrapCrossSigning() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapCrossSigning() completes successfully, this function should - * return true. - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @returns True if cross-signing is ready to be used on this device - */ - async isCrossSigningReady() { - const publicKeysOnDevice = this.crossSigningInfo.getId(); - const privateKeysExistSomewhere = (await this.crossSigningInfo.isStoredInKeyCache()) || (await this.crossSigningInfo.isStoredInSecretStorage(this.secretStorage)); - return !!(publicKeysOnDevice && privateKeysExistSomewhere); - } - - /** - * Checks whether secret storage: - * - is enabled on this account - * - is storing cross-signing private keys - * - is storing session backup key (if enabled) - * - * If this function returns false, bootstrapSecretStorage() can be used - * to fix things such that it returns true. That is to say, after - * bootstrapSecretStorage() completes successfully, this function should - * return true. - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @returns True if secret storage is ready to be used on this device - */ - async isSecretStorageReady() { - const secretStorageKeyInAccount = await this.secretStorage.hasKey(); - const privateKeysInStorage = await this.crossSigningInfo.isStoredInSecretStorage(this.secretStorage); - const sessionBackupInStorage = !this.backupManager.getKeyBackupEnabled() || (await this.baseApis.isKeyBackupKeyStored()); - return !!(secretStorageKeyInAccount && privateKeysInStorage && sessionBackupInStorage); - } - - /** - * Bootstrap cross-signing by creating keys if needed. If everything is already - * set up, then no changes are made, so this is safe to run to ensure - * cross-signing is ready for use. - * - * This function: - * - creates new cross-signing keys if they are not found locally cached nor in - * secret storage (if it has been setup) - * - * The cross-signing API is currently UNSTABLE and may change without notice. - * - * @param authUploadDeviceSigningKeys - Function - * called to await an interactive auth flow when uploading device signing keys. - * @param setupNewCrossSigning - Optional. Reset even if keys - * already exist. - * Args: - * A function that makes the request requiring auth. Receives the - * auth data as an object. Can be called multiple times, first with an empty - * authDict, to obtain the flows. - */ - async bootstrapCrossSigning({ - authUploadDeviceSigningKeys, - setupNewCrossSigning - } = {}) { - _logger.logger.log("Bootstrapping cross-signing"); - const delegateCryptoCallbacks = this.baseApis.cryptoCallbacks; - const builder = new _EncryptionSetup.EncryptionSetupBuilder(this.baseApis.store.accountData, delegateCryptoCallbacks); - const crossSigningInfo = new _CrossSigning.CrossSigningInfo(this.userId, builder.crossSigningCallbacks, builder.crossSigningCallbacks); - - // Reset the cross-signing keys - const resetCrossSigning = async () => { - crossSigningInfo.resetKeys(); - // Sign master key with device key - await this.signObject(crossSigningInfo.keys.master); - - // Store auth flow helper function, as we need to call it when uploading - // to ensure we handle auth errors properly. - builder.addCrossSigningKeys(authUploadDeviceSigningKeys, crossSigningInfo.keys); - - // Cross-sign own device - const device = this.deviceList.getStoredDevice(this.userId, this.deviceId); - const deviceSignature = await crossSigningInfo.signDevice(this.userId, device); - builder.addKeySignature(this.userId, this.deviceId, deviceSignature); - - // Sign message key backup with cross-signing master key - if (this.backupManager.backupInfo) { - await crossSigningInfo.signObject(this.backupManager.backupInfo.auth_data, "master"); - builder.addSessionBackup(this.backupManager.backupInfo); - } - }; - const publicKeysOnDevice = this.crossSigningInfo.getId(); - const privateKeysInCache = await this.crossSigningInfo.isStoredInKeyCache(); - const privateKeysInStorage = await this.crossSigningInfo.isStoredInSecretStorage(this.secretStorage); - const privateKeysExistSomewhere = privateKeysInCache || privateKeysInStorage; - - // Log all relevant state for easier parsing of debug logs. - _logger.logger.log({ - setupNewCrossSigning, - publicKeysOnDevice, - privateKeysInCache, - privateKeysInStorage, - privateKeysExistSomewhere - }); - if (!privateKeysExistSomewhere || setupNewCrossSigning) { - _logger.logger.log("Cross-signing private keys not found locally or in secret storage, " + "creating new keys"); - // If a user has multiple devices, it important to only call bootstrap - // as part of some UI flow (and not silently during startup), as they - // may have setup cross-signing on a platform which has not saved keys - // to secret storage, and this would reset them. In such a case, you - // should prompt the user to verify any existing devices first (and - // request private keys from those devices) before calling bootstrap. - await resetCrossSigning(); - } else if (publicKeysOnDevice && privateKeysInCache) { - _logger.logger.log("Cross-signing public keys trusted and private keys found locally"); - } else if (privateKeysInStorage) { - _logger.logger.log("Cross-signing private keys not found locally, but they are available " + "in secret storage, reading storage and caching locally"); - await this.checkOwnCrossSigningTrust({ - allowPrivateKeyRequests: true - }); - } - - // Assuming no app-supplied callback, default to storing new private keys in - // secret storage if it exists. If it does not, it is assumed this will be - // done as part of setting up secret storage later. - const crossSigningPrivateKeys = builder.crossSigningCallbacks.privateKeys; - if (crossSigningPrivateKeys.size && !this.baseApis.cryptoCallbacks.saveCrossSigningKeys) { - const secretStorage = new _SecretStorage.SecretStorage(builder.accountDataClientAdapter, builder.ssssCryptoCallbacks, undefined); - if (await secretStorage.hasKey()) { - _logger.logger.log("Storing new cross-signing private keys in secret storage"); - // This is writing to in-memory account data in - // builder.accountDataClientAdapter so won't fail - await _CrossSigning.CrossSigningInfo.storeInSecretStorage(crossSigningPrivateKeys, secretStorage); - } - } - const operation = builder.buildOperation(); - await operation.apply(this); - // This persists private keys and public keys as trusted, - // only do this if apply succeeded for now as retry isn't in place yet - await builder.persist(this); - _logger.logger.log("Cross-signing ready"); - } - - /** - * Bootstrap Secure Secret Storage if needed by creating a default key. If everything is - * already set up, then no changes are made, so this is safe to run to ensure secret - * storage is ready for use. - * - * This function - * - creates a new Secure Secret Storage key if no default key exists - * - if a key backup exists, it is migrated to store the key in the Secret - * Storage - * - creates a backup if none exists, and one is requested - * - migrates Secure Secret Storage to use the latest algorithm, if an outdated - * algorithm is found - * - * The Secure Secret Storage API is currently UNSTABLE and may change without notice. - * - * @param createSecretStorageKey - Optional. Function - * called to await a secret storage key creation flow. - * Returns a Promise which resolves to an object with public key metadata, encoded private - * recovery key which should be disposed of after displaying to the user, - * and raw private key to avoid round tripping if needed. - * @param keyBackupInfo - The current key backup object. If passed, - * the passphrase and recovery key from this backup will be used. - * @param setupNewKeyBackup - If true, a new key backup version will be - * created and the private key stored in the new SSSS store. Ignored if keyBackupInfo - * is supplied. - * @param setupNewSecretStorage - Optional. Reset even if keys already exist. - * @param getKeyBackupPassphrase - Optional. Function called to get the user's - * current key backup passphrase. Should return a promise that resolves with a Buffer - * containing the key, or rejects if the key cannot be obtained. - * Returns: - * A promise which resolves to key creation data for - * SecretStorage#addKey: an object with `passphrase` etc fields. - */ - // TODO this does not resolve with what it says it does - async bootstrapSecretStorage({ - createSecretStorageKey = async () => ({}), - keyBackupInfo, - setupNewKeyBackup, - setupNewSecretStorage, - getKeyBackupPassphrase - } = {}) { - _logger.logger.log("Bootstrapping Secure Secret Storage"); - const delegateCryptoCallbacks = this.baseApis.cryptoCallbacks; - const builder = new _EncryptionSetup.EncryptionSetupBuilder(this.baseApis.store.accountData, delegateCryptoCallbacks); - const secretStorage = new _SecretStorage.SecretStorage(builder.accountDataClientAdapter, builder.ssssCryptoCallbacks, undefined); - - // the ID of the new SSSS key, if we create one - let newKeyId = null; - - // create a new SSSS key and set it as default - const createSSSS = async (opts, privateKey) => { - if (privateKey) { - opts.key = privateKey; - } - const { - keyId, - keyInfo - } = await secretStorage.addKey(_SecretStorage.SECRET_STORAGE_ALGORITHM_V1_AES, opts); - if (privateKey) { - // make the private key available to encrypt 4S secrets - builder.ssssCryptoCallbacks.addPrivateKey(keyId, keyInfo, privateKey); - } - await secretStorage.setDefaultKeyId(keyId); - return keyId; - }; - const ensureCanCheckPassphrase = async (keyId, keyInfo) => { - if (!keyInfo.mac) { - var _this$baseApis$crypto, _this$baseApis$crypto2; - const key = await ((_this$baseApis$crypto = (_this$baseApis$crypto2 = this.baseApis.cryptoCallbacks).getSecretStorageKey) === null || _this$baseApis$crypto === void 0 ? void 0 : _this$baseApis$crypto.call(_this$baseApis$crypto2, { - keys: { - [keyId]: keyInfo - } - }, "")); - if (key) { - const privateKey = key[1]; - builder.ssssCryptoCallbacks.addPrivateKey(keyId, keyInfo, privateKey); - const { - iv, - mac - } = await (0, _aes.calculateKeyCheck)(privateKey); - keyInfo.iv = iv; - keyInfo.mac = mac; - await builder.setAccountData(`m.secret_storage.key.${keyId}`, keyInfo); - } - } - }; - const signKeyBackupWithCrossSigning = async keyBackupAuthData => { - if (this.crossSigningInfo.getId() && (await this.crossSigningInfo.isStoredInKeyCache("master"))) { - try { - _logger.logger.log("Adding cross-signing signature to key backup"); - await this.crossSigningInfo.signObject(keyBackupAuthData, "master"); - } catch (e) { - // This step is not critical (just helpful), so we catch here - // and continue if it fails. - _logger.logger.error("Signing key backup with cross-signing keys failed", e); - } - } else { - _logger.logger.warn("Cross-signing keys not available, skipping signature on key backup"); - } - }; - const oldSSSSKey = await this.getSecretStorageKey(); - const [oldKeyId, oldKeyInfo] = oldSSSSKey || [null, null]; - const storageExists = !setupNewSecretStorage && oldKeyInfo && oldKeyInfo.algorithm === _SecretStorage.SECRET_STORAGE_ALGORITHM_V1_AES; - - // Log all relevant state for easier parsing of debug logs. - _logger.logger.log({ - keyBackupInfo, - setupNewKeyBackup, - setupNewSecretStorage, - storageExists, - oldKeyInfo - }); - if (!storageExists && !keyBackupInfo) { - // either we don't have anything, or we've been asked to restart - // from scratch - _logger.logger.log("Secret storage does not exist, creating new storage key"); - - // if we already have a usable default SSSS key and aren't resetting - // SSSS just use it. otherwise, create a new one - // Note: we leave the old SSSS key in place: there could be other - // secrets using it, in theory. We could move them to the new key but a) - // that would mean we'd need to prompt for the old passphrase, and b) - // it's not clear that would be the right thing to do anyway. - const { - keyInfo = {}, - privateKey - } = await createSecretStorageKey(); - newKeyId = await createSSSS(keyInfo, privateKey); - } else if (!storageExists && keyBackupInfo) { - // we have an existing backup, but no SSSS - _logger.logger.log("Secret storage does not exist, using key backup key"); - - // if we have the backup key already cached, use it; otherwise use the - // callback to prompt for the key - const backupKey = (await this.getSessionBackupPrivateKey()) || (await (getKeyBackupPassphrase === null || getKeyBackupPassphrase === void 0 ? void 0 : getKeyBackupPassphrase())); - - // create a new SSSS key and use the backup key as the new SSSS key - const opts = {}; - if (keyBackupInfo.auth_data.private_key_salt && keyBackupInfo.auth_data.private_key_iterations) { - // FIXME: ??? - opts.passphrase = { - algorithm: "m.pbkdf2", - iterations: keyBackupInfo.auth_data.private_key_iterations, - salt: keyBackupInfo.auth_data.private_key_salt, - bits: 256 - }; - } - newKeyId = await createSSSS(opts, backupKey); - - // store the backup key in secret storage - await secretStorage.store("m.megolm_backup.v1", olmlib.encodeBase64(backupKey), [newKeyId]); - - // The backup is trusted because the user provided the private key. - // Sign the backup with the cross-signing key so the key backup can - // be trusted via cross-signing. - await signKeyBackupWithCrossSigning(keyBackupInfo.auth_data); - builder.addSessionBackup(keyBackupInfo); - } else { - // 4S is already set up - _logger.logger.log("Secret storage exists"); - if (oldKeyInfo && oldKeyInfo.algorithm === _SecretStorage.SECRET_STORAGE_ALGORITHM_V1_AES) { - // make sure that the default key has the information needed to - // check the passphrase - await ensureCanCheckPassphrase(oldKeyId, oldKeyInfo); - } - } - - // If we have cross-signing private keys cached, store them in secret - // storage if they are not there already. - if (!this.baseApis.cryptoCallbacks.saveCrossSigningKeys && (await this.isCrossSigningReady()) && (newKeyId || !(await this.crossSigningInfo.isStoredInSecretStorage(secretStorage)))) { - _logger.logger.log("Copying cross-signing private keys from cache to secret storage"); - const crossSigningPrivateKeys = await this.crossSigningInfo.getCrossSigningKeysFromCache(); - // This is writing to in-memory account data in - // builder.accountDataClientAdapter so won't fail - await _CrossSigning.CrossSigningInfo.storeInSecretStorage(crossSigningPrivateKeys, secretStorage); - } - if (setupNewKeyBackup && !keyBackupInfo) { - _logger.logger.log("Creating new message key backup version"); - const info = await this.baseApis.prepareKeyBackupVersion(null /* random key */, - // don't write to secret storage, as it will write to this.secretStorage. - // Here, we want to capture all the side-effects of bootstrapping, - // and want to write to the local secretStorage object - { - secureSecretStorage: false - }); - // write the key ourselves to 4S - const privateKey = (0, _recoverykey.decodeRecoveryKey)(info.recovery_key); - await secretStorage.store("m.megolm_backup.v1", olmlib.encodeBase64(privateKey)); - - // create keyBackupInfo object to add to builder - const data = { - algorithm: info.algorithm, - auth_data: info.auth_data - }; - - // Sign with cross-signing master key - await signKeyBackupWithCrossSigning(data.auth_data); - - // sign with the device fingerprint - await this.signObject(data.auth_data); - builder.addSessionBackup(data); - } - - // Cache the session backup key - const sessionBackupKey = await secretStorage.get("m.megolm_backup.v1"); - if (sessionBackupKey) { - _logger.logger.info("Got session backup key from secret storage: caching"); - // fix up the backup key if it's in the wrong format, and replace - // in secret storage - const fixedBackupKey = fixBackupKey(sessionBackupKey); - if (fixedBackupKey) { - const keyId = newKeyId || oldKeyId; - await secretStorage.store("m.megolm_backup.v1", fixedBackupKey, keyId ? [keyId] : null); - } - const decodedBackupKey = new Uint8Array(olmlib.decodeBase64(fixedBackupKey || sessionBackupKey)); - builder.addSessionBackupPrivateKeyToCache(decodedBackupKey); - } else if (this.backupManager.getKeyBackupEnabled()) { - // key backup is enabled but we don't have a session backup key in SSSS: see if we have one in - // the cache or the user can provide one, and if so, write it to SSSS - const backupKey = (await this.getSessionBackupPrivateKey()) || (await (getKeyBackupPassphrase === null || getKeyBackupPassphrase === void 0 ? void 0 : getKeyBackupPassphrase())); - if (!backupKey) { - // This will require user intervention to recover from since we don't have the key - // backup key anywhere. The user should probably just set up a new key backup and - // the key for the new backup will be stored. If we hit this scenario in the wild - // with any frequency, we should do more than just log an error. - _logger.logger.error("Key backup is enabled but couldn't get key backup key!"); - return; - } - _logger.logger.info("Got session backup key from cache/user that wasn't in SSSS: saving to SSSS"); - await secretStorage.store("m.megolm_backup.v1", olmlib.encodeBase64(backupKey)); - } - const operation = builder.buildOperation(); - await operation.apply(this); - // this persists private keys and public keys as trusted, - // only do this if apply succeeded for now as retry isn't in place yet - await builder.persist(this); - _logger.logger.log("Secure Secret Storage ready"); - } - addSecretStorageKey(algorithm, opts, keyID) { - return this.secretStorage.addKey(algorithm, opts, keyID); - } - hasSecretStorageKey(keyID) { - return this.secretStorage.hasKey(keyID); - } - getSecretStorageKey(keyID) { - return this.secretStorage.getKey(keyID); - } - storeSecret(name, secret, keys) { - return this.secretStorage.store(name, secret, keys); - } - getSecret(name) { - return this.secretStorage.get(name); - } - isSecretStored(name) { - return this.secretStorage.isStored(name); - } - requestSecret(name, devices) { - if (!devices) { - devices = Object.keys(this.deviceList.getRawStoredDevicesForUser(this.userId)); - } - return this.secretStorage.request(name, devices); - } - getDefaultSecretStorageKeyId() { - return this.secretStorage.getDefaultKeyId(); - } - setDefaultSecretStorageKeyId(k) { - return this.secretStorage.setDefaultKeyId(k); - } - checkSecretStorageKey(key, info) { - return this.secretStorage.checkKey(key, info); - } - - /** - * Checks that a given secret storage private key matches a given public key. - * This can be used by the getSecretStorageKey callback to verify that the - * private key it is about to supply is the one that was requested. - * - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkSecretStoragePrivateKey(privateKey, expectedPublicKey) { - let decryption = null; - try { - decryption = new global.Olm.PkDecryption(); - const gotPubkey = decryption.init_with_private_key(privateKey); - // make sure it agrees with the given pubkey - return gotPubkey === expectedPublicKey; - } finally { - var _decryption; - (_decryption = decryption) === null || _decryption === void 0 ? void 0 : _decryption.free(); - } - } - - /** - * Fetches the backup private key, if cached - * @returns the key, if any, or null - */ - async getSessionBackupPrivateKey() { - let key = await new Promise(resolve => { - // TODO types - this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.cryptoStore.getSecretStorePrivateKey(txn, resolve, "m.megolm_backup.v1"); - }); - }); - - // make sure we have a Uint8Array, rather than a string - if (key && typeof key === "string") { - key = new Uint8Array(olmlib.decodeBase64(fixBackupKey(key) || key)); - await this.storeSessionBackupPrivateKey(key); - } - if (key && key.ciphertext) { - const pickleKey = Buffer.from(this.olmDevice.pickleKey); - const decrypted = await (0, _aes.decryptAES)(key, pickleKey, "m.megolm_backup.v1"); - key = olmlib.decodeBase64(decrypted); - } - return key; - } - - /** - * Stores the session backup key to the cache - * @param key - the private key - * @returns a promise so you can catch failures - */ - async storeSessionBackupPrivateKey(key) { - if (!(key instanceof Uint8Array)) { - // eslint-disable-next-line @typescript-eslint/no-base-to-string - throw new Error(`storeSessionBackupPrivateKey expects Uint8Array, got ${key}`); - } - const pickleKey = Buffer.from(this.olmDevice.pickleKey); - const encryptedKey = await (0, _aes.encryptAES)(olmlib.encodeBase64(key), pickleKey, "m.megolm_backup.v1"); - return this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.cryptoStore.storeSecretStorePrivateKey(txn, "m.megolm_backup.v1", encryptedKey); - }); - } - - /** - * Checks that a given cross-signing private key matches a given public key. - * This can be used by the getCrossSigningKey callback to verify that the - * private key it is about to supply is the one that was requested. - * - * @param privateKey - The private key - * @param expectedPublicKey - The public key - * @returns true if the key matches, otherwise false - */ - checkCrossSigningPrivateKey(privateKey, expectedPublicKey) { - let signing = null; - try { - signing = new global.Olm.PkSigning(); - const gotPubkey = signing.init_with_seed(privateKey); - // make sure it agrees with the given pubkey - return gotPubkey === expectedPublicKey; - } finally { - var _signing; - (_signing = signing) === null || _signing === void 0 ? void 0 : _signing.free(); - } - } - - /** - * Run various follow-up actions after cross-signing keys have changed locally - * (either by resetting the keys for the account or by getting them from secret - * storage), such as signing the current device, upgrading device - * verifications, etc. - */ - async afterCrossSigningLocalKeyChange() { - _logger.logger.info("Starting cross-signing key change post-processing"); - - // sign the current device with the new key, and upload to the server - const device = this.deviceList.getStoredDevice(this.userId, this.deviceId); - const signedDevice = await this.crossSigningInfo.signDevice(this.userId, device); - _logger.logger.info(`Starting background key sig upload for ${this.deviceId}`); - const upload = ({ - shouldEmit = false - }) => { - return this.baseApis.uploadKeySignatures({ - [this.userId]: { - [this.deviceId]: signedDevice - } - }).then(response => { - const { - failures - } = response || {}; - if (Object.keys(failures || []).length > 0) { - if (shouldEmit) { - this.baseApis.emit(CryptoEvent.KeySignatureUploadFailure, failures, "afterCrossSigningLocalKeyChange", upload // continuation - ); - } - - throw new _errors.KeySignatureUploadError("Key upload failed", { - failures - }); - } - _logger.logger.info(`Finished background key sig upload for ${this.deviceId}`); - }).catch(e => { - _logger.logger.error(`Error during background key sig upload for ${this.deviceId}`, e); - }); - }; - upload({ - shouldEmit: true - }); - const shouldUpgradeCb = this.baseApis.cryptoCallbacks.shouldUpgradeDeviceVerifications; - if (shouldUpgradeCb) { - _logger.logger.info("Starting device verification upgrade"); - - // Check all users for signatures if upgrade callback present - // FIXME: do this in batches - const users = {}; - for (const [userId, crossSigningInfo] of Object.entries(this.deviceList.crossSigningInfo)) { - const upgradeInfo = await this.checkForDeviceVerificationUpgrade(userId, _CrossSigning.CrossSigningInfo.fromStorage(crossSigningInfo, userId)); - if (upgradeInfo) { - users[userId] = upgradeInfo; - } - } - if (Object.keys(users).length > 0) { - _logger.logger.info(`Found ${Object.keys(users).length} verif users to upgrade`); - try { - const usersToUpgrade = await shouldUpgradeCb({ - users: users - }); - if (usersToUpgrade) { - for (const userId of usersToUpgrade) { - if (userId in users) { - await this.baseApis.setDeviceVerified(userId, users[userId].crossSigningInfo.getId()); - } - } - } - } catch (e) { - _logger.logger.log("shouldUpgradeDeviceVerifications threw an error: not upgrading", e); - } - } - _logger.logger.info("Finished device verification upgrade"); - } - _logger.logger.info("Finished cross-signing key change post-processing"); - } - - /** - * Check if a user's cross-signing key is a candidate for upgrading from device - * verification. - * - * @param userId - the user whose cross-signing information is to be checked - * @param crossSigningInfo - the cross-signing information to check - */ - async checkForDeviceVerificationUpgrade(userId, crossSigningInfo) { - // only upgrade if this is the first cross-signing key that we've seen for - // them, and if their cross-signing key isn't already verified - const trustLevel = this.crossSigningInfo.checkUserTrust(crossSigningInfo); - if (crossSigningInfo.firstUse && !trustLevel.isVerified()) { - const devices = this.deviceList.getRawStoredDevicesForUser(userId); - const deviceIds = await this.checkForValidDeviceSignature(userId, crossSigningInfo.keys.master, devices); - if (deviceIds.length) { - return { - devices: deviceIds.map(deviceId => _deviceinfo.DeviceInfo.fromStorage(devices[deviceId], deviceId)), - crossSigningInfo - }; - } - } - } - - /** - * Check if the cross-signing key is signed by a verified device. - * - * @param userId - the user ID whose key is being checked - * @param key - the key that is being checked - * @param devices - the user's devices. Should be a map from device ID - * to device info - */ - async checkForValidDeviceSignature(userId, key, devices) { - const deviceIds = []; - if (devices && key.signatures && key.signatures[userId]) { - for (const signame of Object.keys(key.signatures[userId])) { - const [, deviceId] = signame.split(":", 2); - if (deviceId in devices && devices[deviceId].verified === DeviceVerification.VERIFIED) { - try { - await olmlib.verifySignature(this.olmDevice, key, userId, deviceId, devices[deviceId].keys[signame]); - deviceIds.push(deviceId); - } catch (e) {} - } - } - } - return deviceIds; - } - - /** - * Get the user's cross-signing key ID. - * - * @param type - The type of key to get the ID of. One of - * "master", "self_signing", or "user_signing". Defaults to "master". - * - * @returns the key ID - */ - getCrossSigningId(type) { - return this.crossSigningInfo.getId(type); - } - - /** - * Get the cross signing information for a given user. - * - * @param userId - the user ID to get the cross-signing info for. - * - * @returns the cross signing information for the user. - */ - getStoredCrossSigningForUser(userId) { - return this.deviceList.getStoredCrossSigningForUser(userId); - } - - /** - * Check whether a given user is trusted. - * - * @param userId - The ID of the user to check. - * - * @returns - */ - checkUserTrust(userId) { - const userCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId); - if (!userCrossSigning) { - return new _CrossSigning.UserTrustLevel(false, false, false); - } - return this.crossSigningInfo.checkUserTrust(userCrossSigning); - } - - /** - * Check whether a given device is trusted. - * - * @param userId - The ID of the user whose devices is to be checked. - * @param deviceId - The ID of the device to check - * - * @returns - */ - checkDeviceTrust(userId, deviceId) { - const device = this.deviceList.getStoredDevice(userId, deviceId); - return this.checkDeviceInfoTrust(userId, device); - } - - /** - * Check whether a given deviceinfo is trusted. - * - * @param userId - The ID of the user whose devices is to be checked. - * @param device - The device info object to check - * - * @returns - */ - checkDeviceInfoTrust(userId, device) { - const trustedLocally = !!(device !== null && device !== void 0 && device.isVerified()); - const userCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId); - if (device && userCrossSigning) { - // The trustCrossSignedDevices only affects trust of other people's cross-signing - // signatures - const trustCrossSig = this.trustCrossSignedDevices || userId === this.userId; - return this.crossSigningInfo.checkDeviceTrust(userCrossSigning, device, trustedLocally, trustCrossSig); - } else { - return new _CrossSigning.DeviceTrustLevel(false, false, trustedLocally, false); - } - } - - /** - * Check whether one of our own devices is cross-signed by our - * user's stored keys, regardless of whether we trust those keys yet. - * - * @param deviceId - The ID of the device to check - * - * @returns true if the device is cross-signed - */ - checkIfOwnDeviceCrossSigned(deviceId) { - var _userCrossSigning$che; - const device = this.deviceList.getStoredDevice(this.userId, deviceId); - if (!device) return false; - const userCrossSigning = this.deviceList.getStoredCrossSigningForUser(this.userId); - return (_userCrossSigning$che = userCrossSigning === null || userCrossSigning === void 0 ? void 0 : userCrossSigning.checkDeviceTrust(userCrossSigning, device, false, true).isCrossSigningVerified()) !== null && _userCrossSigning$che !== void 0 ? _userCrossSigning$che : false; - } - - /* - * Event handler for DeviceList's userNewDevices event - */ - - /** - * Check the copy of our cross-signing key that we have in the device list and - * see if we can get the private key. If so, mark it as trusted. - */ - async checkOwnCrossSigningTrust({ - allowPrivateKeyRequests = false - } = {}) { - const userId = this.userId; - - // Before proceeding, ensure our cross-signing public keys have been - // downloaded via the device list. - await this.downloadKeys([this.userId]); - - // Also check which private keys are locally cached. - const crossSigningPrivateKeys = await this.crossSigningInfo.getCrossSigningKeysFromCache(); - - // If we see an update to our own master key, check it against the master - // key we have and, if it matches, mark it as verified - - // First, get the new cross-signing info - const newCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId); - if (!newCrossSigning) { - _logger.logger.error("Got cross-signing update event for user " + userId + " but no new cross-signing information found!"); - return; - } - const seenPubkey = newCrossSigning.getId(); - const masterChanged = this.crossSigningInfo.getId() !== seenPubkey; - const masterExistsNotLocallyCached = newCrossSigning.getId() && !crossSigningPrivateKeys.has("master"); - if (masterChanged) { - _logger.logger.info("Got new master public key", seenPubkey); - } - if (allowPrivateKeyRequests && (masterChanged || masterExistsNotLocallyCached)) { - _logger.logger.info("Attempting to retrieve cross-signing master private key"); - let signing = null; - // It's important for control flow that we leave any errors alone for - // higher levels to handle so that e.g. cancelling access properly - // aborts any larger operation as well. - try { - const ret = await this.crossSigningInfo.getCrossSigningKey("master", seenPubkey); - signing = ret[1]; - _logger.logger.info("Got cross-signing master private key"); - } finally { - var _signing2; - (_signing2 = signing) === null || _signing2 === void 0 ? void 0 : _signing2.free(); - } - } - const oldSelfSigningId = this.crossSigningInfo.getId("self_signing"); - const oldUserSigningId = this.crossSigningInfo.getId("user_signing"); - - // Update the version of our keys in our cross-signing object and the local store - this.storeTrustedSelfKeys(newCrossSigning.keys); - const selfSigningChanged = oldSelfSigningId !== newCrossSigning.getId("self_signing"); - const userSigningChanged = oldUserSigningId !== newCrossSigning.getId("user_signing"); - const selfSigningExistsNotLocallyCached = newCrossSigning.getId("self_signing") && !crossSigningPrivateKeys.has("self_signing"); - const userSigningExistsNotLocallyCached = newCrossSigning.getId("user_signing") && !crossSigningPrivateKeys.has("user_signing"); - const keySignatures = {}; - if (selfSigningChanged) { - _logger.logger.info("Got new self-signing key", newCrossSigning.getId("self_signing")); - } - if (allowPrivateKeyRequests && (selfSigningChanged || selfSigningExistsNotLocallyCached)) { - _logger.logger.info("Attempting to retrieve cross-signing self-signing private key"); - let signing = null; - try { - const ret = await this.crossSigningInfo.getCrossSigningKey("self_signing", newCrossSigning.getId("self_signing")); - signing = ret[1]; - _logger.logger.info("Got cross-signing self-signing private key"); - } finally { - var _signing3; - (_signing3 = signing) === null || _signing3 === void 0 ? void 0 : _signing3.free(); - } - const device = this.deviceList.getStoredDevice(this.userId, this.deviceId); - const signedDevice = await this.crossSigningInfo.signDevice(this.userId, device); - keySignatures[this.deviceId] = signedDevice; - } - if (userSigningChanged) { - _logger.logger.info("Got new user-signing key", newCrossSigning.getId("user_signing")); - } - if (allowPrivateKeyRequests && (userSigningChanged || userSigningExistsNotLocallyCached)) { - _logger.logger.info("Attempting to retrieve cross-signing user-signing private key"); - let signing = null; - try { - const ret = await this.crossSigningInfo.getCrossSigningKey("user_signing", newCrossSigning.getId("user_signing")); - signing = ret[1]; - _logger.logger.info("Got cross-signing user-signing private key"); - } finally { - var _signing4; - (_signing4 = signing) === null || _signing4 === void 0 ? void 0 : _signing4.free(); - } - } - if (masterChanged) { - const masterKey = this.crossSigningInfo.keys.master; - await this.signObject(masterKey); - const deviceSig = masterKey.signatures[this.userId]["ed25519:" + this.deviceId]; - // Include only the _new_ device signature in the upload. - // We may have existing signatures from deleted devices, which will cause - // the entire upload to fail. - keySignatures[this.crossSigningInfo.getId()] = Object.assign({}, masterKey, { - signatures: { - [this.userId]: { - ["ed25519:" + this.deviceId]: deviceSig - } - } - }); - } - const keysToUpload = Object.keys(keySignatures); - if (keysToUpload.length) { - const upload = ({ - shouldEmit = false - }) => { - _logger.logger.info(`Starting background key sig upload for ${keysToUpload}`); - return this.baseApis.uploadKeySignatures({ - [this.userId]: keySignatures - }).then(response => { - const { - failures - } = response || {}; - _logger.logger.info(`Finished background key sig upload for ${keysToUpload}`); - if (Object.keys(failures || []).length > 0) { - if (shouldEmit) { - this.baseApis.emit(CryptoEvent.KeySignatureUploadFailure, failures, "checkOwnCrossSigningTrust", upload); - } - throw new _errors.KeySignatureUploadError("Key upload failed", { - failures - }); - } - }).catch(e => { - _logger.logger.error(`Error during background key sig upload for ${keysToUpload}`, e); - }); - }; - upload({ - shouldEmit: true - }); - } - this.emit(CryptoEvent.UserTrustStatusChanged, userId, this.checkUserTrust(userId)); - if (masterChanged) { - this.emit(CryptoEvent.KeysChanged, {}); - await this.afterCrossSigningLocalKeyChange(); - } - - // Now we may be able to trust our key backup - await this.backupManager.checkKeyBackup(); - // FIXME: if we previously trusted the backup, should we automatically sign - // the backup with the new key (if not already signed)? - } - - /** - * Store a set of keys as our own, trusted, cross-signing keys. - * - * @param keys - The new trusted set of keys - */ - async storeTrustedSelfKeys(keys) { - if (keys) { - this.crossSigningInfo.setKeys(keys); - } else { - this.crossSigningInfo.clearKeys(); - } - await this.cryptoStore.doTxn("readwrite", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_ACCOUNT], txn => { - this.cryptoStore.storeCrossSigningKeys(txn, this.crossSigningInfo.keys); - }); - } - - /** - * Check if the master key is signed by a verified device, and if so, prompt - * the application to mark it as verified. - * - * @param userId - the user ID whose key should be checked - */ - async checkDeviceVerifications(userId) { - const shouldUpgradeCb = this.baseApis.cryptoCallbacks.shouldUpgradeDeviceVerifications; - if (!shouldUpgradeCb) { - // Upgrading skipped when callback is not present. - return; - } - _logger.logger.info(`Starting device verification upgrade for ${userId}`); - if (this.crossSigningInfo.keys.user_signing) { - const crossSigningInfo = this.deviceList.getStoredCrossSigningForUser(userId); - if (crossSigningInfo) { - const upgradeInfo = await this.checkForDeviceVerificationUpgrade(userId, crossSigningInfo); - if (upgradeInfo) { - const usersToUpgrade = await shouldUpgradeCb({ - users: { - [userId]: upgradeInfo - } - }); - if (usersToUpgrade.includes(userId)) { - await this.baseApis.setDeviceVerified(userId, crossSigningInfo.getId()); - } - } - } - } - _logger.logger.info(`Finished device verification upgrade for ${userId}`); - } - - /** - */ - enableLazyLoading() { - this.lazyLoadMembers = true; - } - - /** - * Tell the crypto module to register for MatrixClient events which it needs to - * listen for - * - * @param eventEmitter - event source where we can register - * for event notifications - */ - registerEventHandlers(eventEmitter) { - eventEmitter.on(_roomMember.RoomMemberEvent.Membership, this.onMembership); - eventEmitter.on(_client.ClientEvent.ToDeviceEvent, this.onToDeviceEvent); - eventEmitter.on(_room.RoomEvent.Timeline, this.onTimelineEvent); - eventEmitter.on(_event2.MatrixEventEvent.Decrypted, this.onTimelineEvent); - } - - /** - * @deprecated this does nothing and will be removed in a future version - */ - start() { - _logger.logger.warn("MatrixClient.crypto.start() is deprecated"); - } - - /** Stop background processes related to crypto */ - stop() { - this.outgoingRoomKeyRequestManager.stop(); - this.deviceList.stop(); - this.dehydrationManager.stop(); - } - - /** - * Get the Ed25519 key for this device - * - * @returns base64-encoded ed25519 key. - */ - getDeviceEd25519Key() { - return this.olmDevice.deviceEd25519Key; - } - - /** - * Get the Curve25519 key for this device - * - * @returns base64-encoded curve25519 key. - */ - getDeviceCurve25519Key() { - return this.olmDevice.deviceCurve25519Key; - } - - /** - * Set the global override for whether the client should ever send encrypted - * messages to unverified devices. This provides the default for rooms which - * do not specify a value. - * - * @param value - whether to blacklist all unverified devices by default - * - * @deprecated For external code, use {@link MatrixClient#setGlobalBlacklistUnverifiedDevices}. For - * internal code, set {@link MatrixClient#globalBlacklistUnverifiedDevices} directly. - */ - setGlobalBlacklistUnverifiedDevices(value) { - this.globalBlacklistUnverifiedDevices = value; - } - - /** - * @returns whether to blacklist all unverified devices by default - * - * @deprecated For external code, use {@link MatrixClient#getGlobalBlacklistUnverifiedDevices}. For - * internal code, reference {@link MatrixClient#globalBlacklistUnverifiedDevices} directly. - */ - getGlobalBlacklistUnverifiedDevices() { - return this.globalBlacklistUnverifiedDevices; - } - - /** - * Upload the device keys to the homeserver. - * @returns A promise that will resolve when the keys are uploaded. - */ - uploadDeviceKeys() { - const deviceKeys = { - algorithms: this.supportedAlgorithms, - device_id: this.deviceId, - keys: this.deviceKeys, - user_id: this.userId - }; - return this.signObject(deviceKeys).then(() => { - return this.baseApis.uploadKeysRequest({ - device_keys: deviceKeys - }); - }); - } - - /** - * Stores the current one_time_key count which will be handled later (in a call of - * onSyncCompleted). The count is e.g. coming from a /sync response. - * - * @param currentCount - The current count of one_time_keys to be stored - */ - updateOneTimeKeyCount(currentCount) { - if (isFinite(currentCount)) { - this.oneTimeKeyCount = currentCount; - } else { - throw new TypeError("Parameter for updateOneTimeKeyCount has to be a number"); - } - } - setNeedsNewFallback(needsNewFallback) { - this.needsNewFallback = needsNewFallback; - } - getNeedsNewFallback() { - return !!this.needsNewFallback; - } - - // check if it's time to upload one-time keys, and do so if so. - maybeUploadOneTimeKeys() { - // frequency with which to check & upload one-time keys - const uploadPeriod = 1000 * 60; // one minute - - // max number of keys to upload at once - // Creating keys can be an expensive operation so we limit the - // number we generate in one go to avoid blocking the application - // for too long. - const maxKeysPerCycle = 5; - if (this.oneTimeKeyCheckInProgress) { - return; - } - const now = Date.now(); - if (this.lastOneTimeKeyCheck !== null && now - this.lastOneTimeKeyCheck < uploadPeriod) { - // we've done a key upload recently. - return; - } - this.lastOneTimeKeyCheck = now; - - // We need to keep a pool of one time public keys on the server so that - // other devices can start conversations with us. But we can only store - // a finite number of private keys in the olm Account object. - // To complicate things further then can be a delay between a device - // claiming a public one time key from the server and it sending us a - // message. We need to keep the corresponding private key locally until - // we receive the message. - // But that message might never arrive leaving us stuck with duff - // private keys clogging up our local storage. - // So we need some kind of engineering compromise to balance all of - // these factors. - - // Check how many keys we can store in the Account object. - const maxOneTimeKeys = this.olmDevice.maxNumberOfOneTimeKeys(); - // Try to keep at most half that number on the server. This leaves the - // rest of the slots free to hold keys that have been claimed from the - // server but we haven't received a message for. - // If we run out of slots when generating new keys then olm will - // discard the oldest private keys first. This will eventually clean - // out stale private keys that won't receive a message. - const keyLimit = Math.floor(maxOneTimeKeys / 2); - const uploadLoop = async keyCount => { - while (keyLimit > keyCount || this.getNeedsNewFallback()) { - // Ask olm to generate new one time keys, then upload them to synapse. - if (keyLimit > keyCount) { - _logger.logger.info("generating oneTimeKeys"); - const keysThisLoop = Math.min(keyLimit - keyCount, maxKeysPerCycle); - await this.olmDevice.generateOneTimeKeys(keysThisLoop); - } - if (this.getNeedsNewFallback()) { - const fallbackKeys = await this.olmDevice.getFallbackKey(); - // if fallbackKeys is non-empty, we've already generated a - // fallback key, but it hasn't been published yet, so we - // can use that instead of generating a new one - if (!fallbackKeys.curve25519 || Object.keys(fallbackKeys.curve25519).length == 0) { - _logger.logger.info("generating fallback key"); - if (this.fallbackCleanup) { - // cancel any pending fallback cleanup because generating - // a new fallback key will already drop the old fallback - // that would have been dropped, and we don't want to kill - // the current key - clearTimeout(this.fallbackCleanup); - delete this.fallbackCleanup; - } - await this.olmDevice.generateFallbackKey(); - } - } - _logger.logger.info("calling uploadOneTimeKeys"); - const res = await this.uploadOneTimeKeys(); - if (res.one_time_key_counts && res.one_time_key_counts.signed_curve25519) { - // if the response contains a more up to date value use this - // for the next loop - keyCount = res.one_time_key_counts.signed_curve25519; - } else { - throw new Error("response for uploading keys does not contain " + "one_time_key_counts.signed_curve25519"); - } - } - }; - this.oneTimeKeyCheckInProgress = true; - Promise.resolve().then(() => { - if (this.oneTimeKeyCount !== undefined) { - // We already have the current one_time_key count from a /sync response. - // Use this value instead of asking the server for the current key count. - return Promise.resolve(this.oneTimeKeyCount); - } - // ask the server how many keys we have - return this.baseApis.uploadKeysRequest({}).then(res => { - return res.one_time_key_counts.signed_curve25519 || 0; - }); - }).then(keyCount => { - // Start the uploadLoop with the current keyCount. The function checks if - // we need to upload new keys or not. - // If there are too many keys on the server then we don't need to - // create any more keys. - return uploadLoop(keyCount); - }).catch(e => { - _logger.logger.error("Error uploading one-time keys", e.stack || e); - }).finally(() => { - // reset oneTimeKeyCount to prevent start uploading based on old data. - // it will be set again on the next /sync-response - this.oneTimeKeyCount = undefined; - this.oneTimeKeyCheckInProgress = false; - }); - } - - // returns a promise which resolves to the response - async uploadOneTimeKeys() { - const promises = []; - let fallbackJson; - if (this.getNeedsNewFallback()) { - fallbackJson = {}; - const fallbackKeys = await this.olmDevice.getFallbackKey(); - for (const [keyId, key] of Object.entries(fallbackKeys.curve25519)) { - const k = { - key, - fallback: true - }; - fallbackJson["signed_curve25519:" + keyId] = k; - promises.push(this.signObject(k)); - } - this.setNeedsNewFallback(false); - } - const oneTimeKeys = await this.olmDevice.getOneTimeKeys(); - const oneTimeJson = {}; - for (const keyId in oneTimeKeys.curve25519) { - if (oneTimeKeys.curve25519.hasOwnProperty(keyId)) { - const k = { - key: oneTimeKeys.curve25519[keyId] - }; - oneTimeJson["signed_curve25519:" + keyId] = k; - promises.push(this.signObject(k)); - } - } - await Promise.all(promises); - const requestBody = { - one_time_keys: oneTimeJson - }; - if (fallbackJson) { - requestBody["org.matrix.msc2732.fallback_keys"] = fallbackJson; - requestBody["fallback_keys"] = fallbackJson; - } - const res = await this.baseApis.uploadKeysRequest(requestBody); - if (fallbackJson) { - this.fallbackCleanup = setTimeout(() => { - delete this.fallbackCleanup; - this.olmDevice.forgetOldFallbackKey(); - }, 60 * 60 * 1000); - } - await this.olmDevice.markKeysAsPublished(); - return res; - } - - /** - * Download the keys for a list of users and stores the keys in the session - * store. - * @param userIds - The users to fetch. - * @param forceDownload - Always download the keys even if cached. - * - * @returns A promise which resolves to a map `userId->deviceId->{@link DeviceInfo}`. - */ - downloadKeys(userIds, forceDownload) { - return this.deviceList.downloadKeys(userIds, !!forceDownload); - } - - /** - * Get the stored device keys for a user id - * - * @param userId - the user to list keys for. - * - * @returns list of devices, or null if we haven't - * managed to get a list of devices for this user yet. - */ - getStoredDevicesForUser(userId) { - return this.deviceList.getStoredDevicesForUser(userId); - } - - /** - * Get the stored keys for a single device - * - * - * @returns device, or undefined - * if we don't know about this device - */ - getStoredDevice(userId, deviceId) { - return this.deviceList.getStoredDevice(userId, deviceId); - } - - /** - * Save the device list, if necessary - * - * @param delay - Time in ms before which the save actually happens. - * By default, the save is delayed for a short period in order to batch - * multiple writes, but this behaviour can be disabled by passing 0. - * - * @returns true if the data was saved, false if - * it was not (eg. because no changes were pending). The promise - * will only resolve once the data is saved, so may take some time - * to resolve. - */ - saveDeviceList(delay) { - return this.deviceList.saveIfDirty(delay); - } - - /** - * Update the blocked/verified state of the given device - * - * @param userId - owner of the device - * @param deviceId - unique identifier for the device or user's - * cross-signing public key ID. - * - * @param verified - whether to mark the device as verified. Null to - * leave unchanged. - * - * @param blocked - whether to mark the device as blocked. Null to - * leave unchanged. - * - * @param known - whether to mark that the user has been made aware of - * the existence of this device. Null to leave unchanged - * - * @param keys - The list of keys that was present - * during the device verification. This will be double checked with the list - * of keys the given device has currently. - * - * @returns updated DeviceInfo - */ - async setDeviceVerification(userId, deviceId, verified = null, blocked = null, known = null, keys) { - // Check if the 'device' is actually a cross signing key - // The js-sdk's verification treats cross-signing keys as devices - // and so uses this method to mark them verified. - const xsk = this.deviceList.getStoredCrossSigningForUser(userId); - if (xsk && xsk.getId() === deviceId) { - if (blocked !== null || known !== null) { - throw new Error("Cannot set blocked or known for a cross-signing key"); - } - if (!verified) { - throw new Error("Cannot set a cross-signing key as unverified"); - } - const gotKeyId = keys ? Object.values(keys)[0] : null; - if (keys && (Object.values(keys).length !== 1 || gotKeyId !== xsk.getId())) { - throw new Error(`Key did not match expected value: expected ${xsk.getId()}, got ${gotKeyId}`); - } - if (!this.crossSigningInfo.getId() && userId === this.crossSigningInfo.userId) { - this.storeTrustedSelfKeys(xsk.keys); - // This will cause our own user trust to change, so emit the event - this.emit(CryptoEvent.UserTrustStatusChanged, this.userId, this.checkUserTrust(userId)); - } - - // Now sign the master key with our user signing key (unless it's ourself) - if (userId !== this.userId) { - _logger.logger.info("Master key " + xsk.getId() + " for " + userId + " marked verified. Signing..."); - const device = await this.crossSigningInfo.signUser(xsk); - if (device) { - const upload = async ({ - shouldEmit = false - }) => { - _logger.logger.info("Uploading signature for " + userId + "..."); - const response = await this.baseApis.uploadKeySignatures({ - [userId]: { - [deviceId]: device - } - }); - const { - failures - } = response || {}; - if (Object.keys(failures || []).length > 0) { - if (shouldEmit) { - this.baseApis.emit(CryptoEvent.KeySignatureUploadFailure, failures, "setDeviceVerification", upload); - } - /* Throwing here causes the process to be cancelled and the other - * user to be notified */ - throw new _errors.KeySignatureUploadError("Key upload failed", { - failures - }); - } - }; - await upload({ - shouldEmit: true - }); - - // This will emit events when it comes back down the sync - // (we could do local echo to speed things up) - } - - return device; // TODO types - } else { - return xsk; - } - } - const devices = this.deviceList.getRawStoredDevicesForUser(userId); - if (!devices || !devices[deviceId]) { - throw new Error("Unknown device " + userId + ":" + deviceId); - } - const dev = devices[deviceId]; - let verificationStatus = dev.verified; - if (verified) { - if (keys) { - for (const [keyId, key] of Object.entries(keys)) { - if (dev.keys[keyId] !== key) { - throw new Error(`Key did not match expected value: expected ${key}, got ${dev.keys[keyId]}`); - } - } - } - verificationStatus = DeviceVerification.VERIFIED; - } else if (verified !== null && verificationStatus == DeviceVerification.VERIFIED) { - verificationStatus = DeviceVerification.UNVERIFIED; - } - if (blocked) { - verificationStatus = DeviceVerification.BLOCKED; - } else if (blocked !== null && verificationStatus == DeviceVerification.BLOCKED) { - verificationStatus = DeviceVerification.UNVERIFIED; - } - let knownStatus = dev.known; - if (known !== null) { - knownStatus = known; - } - if (dev.verified !== verificationStatus || dev.known !== knownStatus) { - dev.verified = verificationStatus; - dev.known = knownStatus; - this.deviceList.storeDevicesForUser(userId, devices); - this.deviceList.saveIfDirty(); - } - - // do cross-signing - if (verified && userId === this.userId) { - _logger.logger.info("Own device " + deviceId + " marked verified: signing"); - - // Signing only needed if other device not already signed - let device; - const deviceTrust = this.checkDeviceTrust(userId, deviceId); - if (deviceTrust.isCrossSigningVerified()) { - _logger.logger.log(`Own device ${deviceId} already cross-signing verified`); - } else { - device = await this.crossSigningInfo.signDevice(userId, _deviceinfo.DeviceInfo.fromStorage(dev, deviceId)); - } - if (device) { - const upload = async ({ - shouldEmit = false - }) => { - _logger.logger.info("Uploading signature for " + deviceId); - const response = await this.baseApis.uploadKeySignatures({ - [userId]: { - [deviceId]: device - } - }); - const { - failures - } = response || {}; - if (Object.keys(failures || []).length > 0) { - if (shouldEmit) { - this.baseApis.emit(CryptoEvent.KeySignatureUploadFailure, failures, "setDeviceVerification", upload // continuation - ); - } - - throw new _errors.KeySignatureUploadError("Key upload failed", { - failures - }); - } - }; - await upload({ - shouldEmit: true - }); - // XXX: we'll need to wait for the device list to be updated - } - } - - const deviceObj = _deviceinfo.DeviceInfo.fromStorage(dev, deviceId); - this.emit(CryptoEvent.DeviceVerificationChanged, userId, deviceId, deviceObj); - return deviceObj; - } - findVerificationRequestDMInProgress(roomId) { - return this.inRoomVerificationRequests.findRequestInProgress(roomId); - } - getVerificationRequestsToDeviceInProgress(userId) { - return this.toDeviceVerificationRequests.getRequestsInProgress(userId); - } - requestVerificationDM(userId, roomId) { - const existingRequest = this.inRoomVerificationRequests.findRequestInProgress(roomId); - if (existingRequest) { - return Promise.resolve(existingRequest); - } - const channel = new _InRoomChannel.InRoomChannel(this.baseApis, roomId, userId); - return this.requestVerificationWithChannel(userId, channel, this.inRoomVerificationRequests); - } - requestVerification(userId, devices) { - if (!devices) { - devices = Object.keys(this.deviceList.getRawStoredDevicesForUser(userId)); - } - const existingRequest = this.toDeviceVerificationRequests.findRequestInProgress(userId, devices); - if (existingRequest) { - return Promise.resolve(existingRequest); - } - const channel = new _ToDeviceChannel.ToDeviceChannel(this.baseApis, userId, devices, _ToDeviceChannel.ToDeviceChannel.makeTransactionId()); - return this.requestVerificationWithChannel(userId, channel, this.toDeviceVerificationRequests); - } - async requestVerificationWithChannel(userId, channel, requestsMap) { - let request = new _VerificationRequest.VerificationRequest(channel, this.verificationMethods, this.baseApis); - // if transaction id is already known, add request - if (channel.transactionId) { - requestsMap.setRequestByChannel(channel, request); - } - await request.sendRequest(); - // don't replace the request created by a racing remote echo - const racingRequest = requestsMap.getRequestByChannel(channel); - if (racingRequest) { - request = racingRequest; - } else { - _logger.logger.log(`Crypto: adding new request to ` + `requestsByTxnId with id ${channel.transactionId} ${channel.roomId}`); - requestsMap.setRequestByChannel(channel, request); - } - return request; - } - beginKeyVerification(method, userId, deviceId, transactionId = null) { - let request; - if (transactionId) { - request = this.toDeviceVerificationRequests.getRequestBySenderAndTxnId(userId, transactionId); - if (!request) { - throw new Error(`No request found for user ${userId} with ` + `transactionId ${transactionId}`); - } - } else { - transactionId = _ToDeviceChannel.ToDeviceChannel.makeTransactionId(); - const channel = new _ToDeviceChannel.ToDeviceChannel(this.baseApis, userId, [deviceId], transactionId, deviceId); - request = new _VerificationRequest.VerificationRequest(channel, this.verificationMethods, this.baseApis); - this.toDeviceVerificationRequests.setRequestBySenderAndTxnId(userId, transactionId, request); - } - return request.beginKeyVerification(method, { - userId, - deviceId - }); - } - async legacyDeviceVerification(userId, deviceId, method) { - const transactionId = _ToDeviceChannel.ToDeviceChannel.makeTransactionId(); - const channel = new _ToDeviceChannel.ToDeviceChannel(this.baseApis, userId, [deviceId], transactionId, deviceId); - const request = new _VerificationRequest.VerificationRequest(channel, this.verificationMethods, this.baseApis); - this.toDeviceVerificationRequests.setRequestBySenderAndTxnId(userId, transactionId, request); - const verifier = request.beginKeyVerification(method, { - userId, - deviceId - }); - // either reject by an error from verify() while sending .start - // or resolve when the request receives the - // local (fake remote) echo for sending the .start event - await Promise.race([verifier.verify(), request.waitFor(r => r.started)]); - return request; - } - - /** - * Get information on the active olm sessions with a user - *

- * Returns a map from device id to an object with keys 'deviceIdKey' (the - * device's curve25519 identity key) and 'sessions' (an array of objects in the - * same format as that returned by - * {@link OlmDevice#getSessionInfoForDevice}). - *

- * This method is provided for debugging purposes. - * - * @param userId - id of user to inspect - */ - async getOlmSessionsForUser(userId) { - const devices = this.getStoredDevicesForUser(userId) || []; - const result = {}; - for (const device of devices) { - const deviceKey = device.getIdentityKey(); - const sessions = await this.olmDevice.getSessionInfoForDevice(deviceKey); - result[device.deviceId] = { - deviceIdKey: deviceKey, - sessions: sessions - }; - } - return result; - } - - /** - * Get the device which sent an event - * - * @param event - event to be checked - */ - getEventSenderDeviceInfo(event) { - const senderKey = event.getSenderKey(); - const algorithm = event.getWireContent().algorithm; - if (!senderKey || !algorithm) { - return null; - } - if (event.isKeySourceUntrusted()) { - // we got the key for this event from a source that we consider untrusted - return null; - } - - // senderKey is the Curve25519 identity key of the device which the event - // was sent from. In the case of Megolm, it's actually the Curve25519 - // identity key of the device which set up the Megolm session. - - const device = this.deviceList.getDeviceByIdentityKey(algorithm, senderKey); - if (device === null) { - // we haven't downloaded the details of this device yet. - return null; - } - - // so far so good, but now we need to check that the sender of this event - // hadn't advertised someone else's Curve25519 key as their own. We do that - // by checking the Ed25519 claimed by the event (or, in the case of megolm, - // the event which set up the megolm session), to check that it matches the - // fingerprint of the purported sending device. - // - // (see https://github.com/vector-im/vector-web/issues/2215) - - const claimedKey = event.getClaimedEd25519Key(); - if (!claimedKey) { - _logger.logger.warn("Event " + event.getId() + " claims no ed25519 key: " + "cannot verify sending device"); - return null; - } - if (claimedKey !== device.getFingerprint()) { - _logger.logger.warn("Event " + event.getId() + " claims ed25519 key " + claimedKey + " but sender device has key " + device.getFingerprint()); - return null; - } - return device; - } - - /** - * Get information about the encryption of an event - * - * @param event - event to be checked - * - * @returns An object with the fields: - * - encrypted: whether the event is encrypted (if not encrypted, some of the - * other properties may not be set) - * - senderKey: the sender's key - * - algorithm: the algorithm used to encrypt the event - * - authenticated: whether we can be sure that the owner of the senderKey - * sent the event - * - sender: the sender's device information, if available - * - mismatchedSender: if the event's ed25519 and curve25519 keys don't match - * (only meaningful if `sender` is set) - */ - getEventEncryptionInfo(event) { - var _event$getSenderKey, _this$deviceList$getD; - const ret = {}; - ret.senderKey = (_event$getSenderKey = event.getSenderKey()) !== null && _event$getSenderKey !== void 0 ? _event$getSenderKey : undefined; - ret.algorithm = event.getWireContent().algorithm; - if (!ret.senderKey || !ret.algorithm) { - ret.encrypted = false; - return ret; - } - ret.encrypted = true; - if (event.isKeySourceUntrusted()) { - // we got the key this event from somewhere else - // TODO: check if we can trust the forwarders. - ret.authenticated = false; - } else { - ret.authenticated = true; - } - - // senderKey is the Curve25519 identity key of the device which the event - // was sent from. In the case of Megolm, it's actually the Curve25519 - // identity key of the device which set up the Megolm session. - - ret.sender = (_this$deviceList$getD = this.deviceList.getDeviceByIdentityKey(ret.algorithm, ret.senderKey)) !== null && _this$deviceList$getD !== void 0 ? _this$deviceList$getD : undefined; - - // so far so good, but now we need to check that the sender of this event - // hadn't advertised someone else's Curve25519 key as their own. We do that - // by checking the Ed25519 claimed by the event (or, in the case of megolm, - // the event which set up the megolm session), to check that it matches the - // fingerprint of the purported sending device. - // - // (see https://github.com/vector-im/vector-web/issues/2215) - - const claimedKey = event.getClaimedEd25519Key(); - if (!claimedKey) { - _logger.logger.warn("Event " + event.getId() + " claims no ed25519 key: " + "cannot verify sending device"); - ret.mismatchedSender = true; - } - if (ret.sender && claimedKey !== ret.sender.getFingerprint()) { - _logger.logger.warn("Event " + event.getId() + " claims ed25519 key " + claimedKey + "but sender device has key " + ret.sender.getFingerprint()); - ret.mismatchedSender = true; - } - return ret; - } - - /** - * Forces the current outbound group session to be discarded such - * that another one will be created next time an event is sent. - * - * @param roomId - The ID of the room to discard the session for - * - * This should not normally be necessary. - */ - forceDiscardSession(roomId) { - const alg = this.roomEncryptors.get(roomId); - if (alg === undefined) throw new Error("Room not encrypted"); - if (alg.forceDiscardSession === undefined) { - throw new Error("Room encryption algorithm doesn't support session discarding"); - } - alg.forceDiscardSession(); - return Promise.resolve(); - } - - /** - * Configure a room to use encryption (ie, save a flag in the cryptoStore). - * - * @param roomId - The room ID to enable encryption in. - * - * @param config - The encryption config for the room. - * - * @param inhibitDeviceQuery - true to suppress device list query for - * users in the room (for now). In case lazy loading is enabled, - * the device query is always inhibited as the members are not tracked. - * - * @deprecated It is normally incorrect to call this method directly. Encryption - * is enabled by receiving an `m.room.encryption` event (which we may have sent - * previously). - */ - async setRoomEncryption(roomId, config, inhibitDeviceQuery) { - const room = this.clientStore.getRoom(roomId); - if (!room) { - throw new Error(`Unable to enable encryption tracking devices in unknown room ${roomId}`); - } - await this.setRoomEncryptionImpl(room, config); - if (!this.lazyLoadMembers && !inhibitDeviceQuery) { - this.deviceList.refreshOutdatedDeviceLists(); - } - } - - /** - * Set up encryption for a room. - * - * This is called when an m.room.encryption event is received. It saves a flag - * for the room in the cryptoStore (if it wasn't already set), sets up an "encryptor" for - * the room, and enables device-list tracking for the room. - * - * It does not initiate a device list query for the room. That is normally - * done once we finish processing the sync, in onSyncCompleted. - * - * @param room - The room to enable encryption in. - * @param config - The encryption config for the room. - */ - async setRoomEncryptionImpl(room, config) { - const roomId = room.roomId; - - // ignore crypto events with no algorithm defined - // This will happen if a crypto event is redacted before we fetch the room state - // It would otherwise just throw later as an unknown algorithm would, but we may - // as well catch this here - if (!config.algorithm) { - _logger.logger.log("Ignoring setRoomEncryption with no algorithm"); - return; - } - - // if state is being replayed from storage, we might already have a configuration - // for this room as they are persisted as well. - // We just need to make sure the algorithm is initialized in this case. - // However, if the new config is different, - // we should bail out as room encryption can't be changed once set. - const existingConfig = this.roomList.getRoomEncryption(roomId); - if (existingConfig) { - if (JSON.stringify(existingConfig) != JSON.stringify(config)) { - _logger.logger.error("Ignoring m.room.encryption event which requests " + "a change of config in " + roomId); - return; - } - } - // if we already have encryption in this room, we should ignore this event, - // as it would reset the encryption algorithm. - // This is at least expected to be called twice, as sync calls onCryptoEvent - // for both the timeline and state sections in the /sync response, - // the encryption event would appear in both. - // If it's called more than twice though, - // it signals a bug on client or server. - const existingAlg = this.roomEncryptors.get(roomId); - if (existingAlg) { - return; - } - - // _roomList.getRoomEncryption will not race with _roomList.setRoomEncryption - // because it first stores in memory. We should await the promise only - // after all the in-memory state (roomEncryptors and _roomList) has been updated - // to avoid races when calling this method multiple times. Hence keep a hold of the promise. - let storeConfigPromise = null; - if (!existingConfig) { - storeConfigPromise = this.roomList.setRoomEncryption(roomId, config); - } - const AlgClass = algorithms.ENCRYPTION_CLASSES.get(config.algorithm); - if (!AlgClass) { - throw new Error("Unable to encrypt with " + config.algorithm); - } - const alg = new AlgClass({ - userId: this.userId, - deviceId: this.deviceId, - crypto: this, - olmDevice: this.olmDevice, - baseApis: this.baseApis, - roomId, - config - }); - this.roomEncryptors.set(roomId, alg); - if (storeConfigPromise) { - await storeConfigPromise; - } - _logger.logger.log(`Enabling encryption in ${roomId}`); - - // we don't want to force a download of the full membership list of this room, but as soon as we have that - // list we can start tracking the device list. - if (room.membersLoaded()) { - await this.trackRoomDevicesImpl(room); - } else { - // wait for the membership list to be loaded - const onState = _state => { - room.off(_roomState.RoomStateEvent.Update, onState); - if (room.membersLoaded()) { - this.trackRoomDevicesImpl(room).catch(e => { - _logger.logger.error(`Error enabling device tracking in ${roomId}`, e); - }); - } - }; - room.on(_roomState.RoomStateEvent.Update, onState); - } - } - - /** - * Make sure we are tracking the device lists for all users in this room. - * - * @param roomId - The room ID to start tracking devices in. - * @returns when all devices for the room have been fetched and marked to track - * @deprecated there's normally no need to call this function: device list tracking - * will be enabled as soon as we have the full membership list. - */ - trackRoomDevices(roomId) { - const room = this.clientStore.getRoom(roomId); - if (!room) { - throw new Error(`Unable to start tracking devices in unknown room ${roomId}`); - } - return this.trackRoomDevicesImpl(room); - } - - /** - * Make sure we are tracking the device lists for all users in this room. - * - * This is normally called when we are about to send an encrypted event, to make sure - * we have all the devices in the room; but it is also called when processing an - * m.room.encryption state event (if lazy-loading is disabled), or when members are - * loaded (if lazy-loading is enabled), to prepare the device list. - * - * @param room - Room to enable device-list tracking in - */ - trackRoomDevicesImpl(room) { - const roomId = room.roomId; - const trackMembers = async () => { - // not an encrypted room - if (!this.roomEncryptors.has(roomId)) { - return; - } - _logger.logger.log(`Starting to track devices for room ${roomId} ...`); - const members = await room.getEncryptionTargetMembers(); - members.forEach(m => { - this.deviceList.startTrackingDeviceList(m.userId); - }); - }; - let promise = this.roomDeviceTrackingState[roomId]; - if (!promise) { - promise = trackMembers(); - this.roomDeviceTrackingState[roomId] = promise.catch(err => { - delete this.roomDeviceTrackingState[roomId]; - throw err; - }); - } - return promise; - } - - /** - * Try to make sure we have established olm sessions for all known devices for - * the given users. - * - * @param users - list of user ids - * @param force - If true, force a new Olm session to be created. Default false. - * - * @returns resolves once the sessions are complete, to - * an Object mapping from userId to deviceId to - * {@link OlmSessionResult} - */ - ensureOlmSessionsForUsers(users, force) { - // map user Id → DeviceInfo[] - const devicesByUser = new Map(); - for (const userId of users) { - const userDevices = []; - devicesByUser.set(userId, userDevices); - const devices = this.getStoredDevicesForUser(userId) || []; - for (const deviceInfo of devices) { - const key = deviceInfo.getIdentityKey(); - if (key == this.olmDevice.deviceCurve25519Key) { - // don't bother setting up session to ourself - continue; - } - if (deviceInfo.verified == DeviceVerification.BLOCKED) { - // don't bother setting up sessions with blocked users - continue; - } - userDevices.push(deviceInfo); - } - } - return olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, devicesByUser, force); - } - - /** - * Get a list containing all of the room keys - * - * @returns a list of session export objects - */ - async exportRoomKeys() { - const exportedSessions = []; - await this.cryptoStore.doTxn("readonly", [_indexeddbCryptoStore.IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS], txn => { - this.cryptoStore.getAllEndToEndInboundGroupSessions(txn, s => { - if (s === null) return; - const sess = this.olmDevice.exportInboundGroupSession(s.senderKey, s.sessionId, s.sessionData); - delete sess.first_known_index; - sess.algorithm = olmlib.MEGOLM_ALGORITHM; - exportedSessions.push(sess); - }); - }); - return exportedSessions; - } - - /** - * Import a list of room keys previously exported by exportRoomKeys - * - * @param keys - a list of session export objects - * @returns a promise which resolves once the keys have been imported - */ - importRoomKeys(keys, opts = {}) { - let successes = 0; - let failures = 0; - const total = keys.length; - function updateProgress() { - var _opts$progressCallbac; - (_opts$progressCallbac = opts.progressCallback) === null || _opts$progressCallbac === void 0 ? void 0 : _opts$progressCallbac.call(opts, { - stage: "load_keys", - successes, - failures, - total - }); - } - return Promise.all(keys.map(key => { - if (!key.room_id || !key.algorithm) { - _logger.logger.warn("ignoring room key entry with missing fields", key); - failures++; - if (opts.progressCallback) { - updateProgress(); - } - return null; - } - const alg = this.getRoomDecryptor(key.room_id, key.algorithm); - return alg.importRoomKey(key, opts).finally(() => { - successes++; - if (opts.progressCallback) { - updateProgress(); - } - }); - })).then(); - } - - /** - * Counts the number of end to end session keys that are waiting to be backed up - * @returns Promise which resolves to the number of sessions requiring backup - */ - countSessionsNeedingBackup() { - return this.backupManager.countSessionsNeedingBackup(); - } - - /** - * Perform any background tasks that can be done before a message is ready to - * send, in order to speed up sending of the message. - * - * @param room - the room the event is in - */ - prepareToEncrypt(room) { - const alg = this.roomEncryptors.get(room.roomId); - if (alg) { - alg.prepareToEncrypt(room); - } - } - - /** - * Encrypt an event according to the configuration of the room. - * - * @param event - event to be sent - * - * @param room - destination room. - * - * @returns Promise which resolves when the event has been - * encrypted, or null if nothing was needed - */ - async encryptEvent(event, room) { - const roomId = event.getRoomId(); - const alg = this.roomEncryptors.get(roomId); - if (!alg) { - // MatrixClient has already checked that this room should be encrypted, - // so this is an unexpected situation. - throw new Error("Room " + roomId + " was previously configured to use encryption, but is " + "no longer. Perhaps the homeserver is hiding the " + "configuration event."); - } - - // wait for all the room devices to be loaded - await this.trackRoomDevicesImpl(room); - let content = event.getContent(); - // If event has an m.relates_to then we need - // to put this on the wrapping event instead - const mRelatesTo = content["m.relates_to"]; - if (mRelatesTo) { - // Clone content here so we don't remove `m.relates_to` from the local-echo - content = Object.assign({}, content); - delete content["m.relates_to"]; - } - - // Treat element's performance metrics the same as `m.relates_to` (when present) - const elementPerfMetrics = content["io.element.performance_metrics"]; - if (elementPerfMetrics) { - content = Object.assign({}, content); - delete content["io.element.performance_metrics"]; - } - const encryptedContent = await alg.encryptMessage(room, event.getType(), content); - if (mRelatesTo) { - encryptedContent["m.relates_to"] = mRelatesTo; - } - if (elementPerfMetrics) { - encryptedContent["io.element.performance_metrics"] = elementPerfMetrics; - } - event.makeEncrypted("m.room.encrypted", encryptedContent, this.olmDevice.deviceCurve25519Key, this.olmDevice.deviceEd25519Key); - } - - /** - * Decrypt a received event - * - * - * @returns resolves once we have - * finished decrypting. Rejects with an `algorithms.DecryptionError` if there - * is a problem decrypting the event. - */ - async decryptEvent(event) { - if (event.isRedacted()) { - // Try to decrypt the redaction event, to support encrypted - // redaction reasons. If we can't decrypt, just fall back to using - // the original redacted_because. - const redactionEvent = new _event2.MatrixEvent(_objectSpread({ - room_id: event.getRoomId() - }, event.getUnsigned().redacted_because)); - let redactedBecause = event.getUnsigned().redacted_because; - if (redactionEvent.isEncrypted()) { - try { - const decryptedEvent = await this.decryptEvent(redactionEvent); - redactedBecause = decryptedEvent.clearEvent; - } catch (e) { - _logger.logger.warn("Decryption of redaction failed. Falling back to unencrypted event.", e); - } - } - return { - clearEvent: { - room_id: event.getRoomId(), - type: "m.room.message", - content: {}, - unsigned: { - redacted_because: redactedBecause - } - } - }; - } else { - const content = event.getWireContent(); - const alg = this.getRoomDecryptor(event.getRoomId(), content.algorithm); - return alg.decryptEvent(event); - } - } - - /** - * Handle the notification from /sync or /keys/changes that device lists have - * been changed. - * - * @param syncData - Object containing sync tokens associated with this sync - * @param syncDeviceLists - device_lists field from /sync, or response from - * /keys/changes - */ - async handleDeviceListChanges(syncData, syncDeviceLists) { - // Initial syncs don't have device change lists. We'll either get the complete list - // of changes for the interval or will have invalidated everything in willProcessSync - if (!syncData.oldSyncToken) return; - - // Here, we're relying on the fact that we only ever save the sync data after - // sucessfully saving the device list data, so we're guaranteed that the device - // list store is at least as fresh as the sync token from the sync store, ie. - // any device changes received in sync tokens prior to the 'next' token here - // have been processed and are reflected in the current device list. - // If we didn't make this assumption, we'd have to use the /keys/changes API - // to get key changes between the sync token in the device list and the 'old' - // sync token used here to make sure we didn't miss any. - await this.evalDeviceListChanges(syncDeviceLists); - } - - /** - * Send a request for some room keys, if we have not already done so - * - * @param resend - whether to resend the key request if there is - * already one - * - * @returns a promise that resolves when the key request is queued - */ - requestRoomKey(requestBody, recipients, resend = false) { - return this.outgoingRoomKeyRequestManager.queueRoomKeyRequest(requestBody, recipients, resend).then(() => { - if (this.sendKeyRequestsImmediately) { - this.outgoingRoomKeyRequestManager.sendQueuedRequests(); - } - }).catch(e => { - // this normally means we couldn't talk to the store - _logger.logger.error("Error requesting key for event", e); - }); - } - - /** - * Cancel any earlier room key request - * - * @param requestBody - parameters to match for cancellation - */ - cancelRoomKeyRequest(requestBody) { - this.outgoingRoomKeyRequestManager.cancelRoomKeyRequest(requestBody).catch(e => { - _logger.logger.warn("Error clearing pending room key requests", e); - }); - } - - /** - * Re-send any outgoing key requests, eg after verification - * @returns - */ - async cancelAndResendAllOutgoingKeyRequests() { - await this.outgoingRoomKeyRequestManager.cancelAndResendAllOutgoingRequests(); - } - - /** - * handle an m.room.encryption event - * - * @param room - in which the event was received - * @param event - encryption event to be processed - */ - async onCryptoEvent(room, event) { - const content = event.getContent(); - await this.setRoomEncryptionImpl(room, content); - } - - /** - * Called before the result of a sync is processed - * - * @param syncData - the data from the 'MatrixClient.sync' event - */ - async onSyncWillProcess(syncData) { - if (!syncData.oldSyncToken) { - // If there is no old sync token, we start all our tracking from - // scratch, so mark everything as untracked. onCryptoEvent will - // be called for all e2e rooms during the processing of the sync, - // at which point we'll start tracking all the users of that room. - _logger.logger.log("Initial sync performed - resetting device tracking state"); - this.deviceList.stopTrackingAllDeviceLists(); - // we always track our own device list (for key backups etc) - this.deviceList.startTrackingDeviceList(this.userId); - this.roomDeviceTrackingState = {}; - } - this.sendKeyRequestsImmediately = false; - } - - /** - * handle the completion of a /sync - * - * This is called after the processing of each successful /sync response. - * It is an opportunity to do a batch process on the information received. - * - * @param syncData - the data from the 'MatrixClient.sync' event - */ - async onSyncCompleted(syncData) { - var _syncData$nextSyncTok; - this.deviceList.setSyncToken((_syncData$nextSyncTok = syncData.nextSyncToken) !== null && _syncData$nextSyncTok !== void 0 ? _syncData$nextSyncTok : null); - this.deviceList.saveIfDirty(); - - // we always track our own device list (for key backups etc) - this.deviceList.startTrackingDeviceList(this.userId); - this.deviceList.refreshOutdatedDeviceLists(); - - // we don't start uploading one-time keys until we've caught up with - // to-device messages, to help us avoid throwing away one-time-keys that we - // are about to receive messages for - // (https://github.com/vector-im/element-web/issues/2782). - if (!syncData.catchingUp) { - this.maybeUploadOneTimeKeys(); - this.processReceivedRoomKeyRequests(); - - // likewise don't start requesting keys until we've caught up - // on to_device messages, otherwise we'll request keys that we're - // just about to get. - this.outgoingRoomKeyRequestManager.sendQueuedRequests(); - - // Sync has finished so send key requests straight away. - this.sendKeyRequestsImmediately = true; - } - } - - /** - * Trigger the appropriate invalidations and removes for a given - * device list - * - * @param deviceLists - device_lists field from /sync, or response from - * /keys/changes - */ - async evalDeviceListChanges(deviceLists) { - if (Array.isArray(deviceLists === null || deviceLists === void 0 ? void 0 : deviceLists.changed)) { - deviceLists.changed.forEach(u => { - this.deviceList.invalidateUserDeviceList(u); - }); - } - if (Array.isArray(deviceLists === null || deviceLists === void 0 ? void 0 : deviceLists.left) && deviceLists.left.length) { - // Check we really don't share any rooms with these users - // any more: the server isn't required to give us the - // exact correct set. - const e2eUserIds = new Set(await this.getTrackedE2eUsers()); - deviceLists.left.forEach(u => { - if (!e2eUserIds.has(u)) { - this.deviceList.stopTrackingDeviceList(u); - } - }); - } - } - - /** - * Get a list of all the IDs of users we share an e2e room with - * for which we are tracking devices already - * - * @returns List of user IDs - */ - async getTrackedE2eUsers() { - const e2eUserIds = []; - for (const room of this.getTrackedE2eRooms()) { - const members = await room.getEncryptionTargetMembers(); - for (const member of members) { - e2eUserIds.push(member.userId); - } - } - return e2eUserIds; - } - - /** - * Get a list of the e2e-enabled rooms we are members of, - * and for which we are already tracking the devices - * - * @returns - */ - getTrackedE2eRooms() { - return this.clientStore.getRooms().filter(room => { - // check for rooms with encryption enabled - const alg = this.roomEncryptors.get(room.roomId); - if (!alg) { - return false; - } - if (!this.roomDeviceTrackingState[room.roomId]) { - return false; - } - - // ignore any rooms which we have left - const myMembership = room.getMyMembership(); - return myMembership === "join" || myMembership === "invite"; - }); - } - - /** - * Encrypts and sends a given object via Olm to-device messages to a given - * set of devices. - * @param userDeviceInfoArr - the devices to send to - * @param payload - fields to include in the encrypted payload - * @returns Promise which - * resolves once the message has been encrypted and sent to the given - * userDeviceMap, and returns the `{ contentMap, deviceInfoByDeviceId }` - * of the successfully sent messages. - */ - async encryptAndSendToDevices(userDeviceInfoArr, payload) { - const toDeviceBatch = { - eventType: _event.EventType.RoomMessageEncrypted, - batch: [] - }; - try { - await Promise.all(userDeviceInfoArr.map(async ({ - userId, - deviceInfo - }) => { - const deviceId = deviceInfo.deviceId; - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: {}, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - toDeviceBatch.batch.push({ - userId, - deviceId, - payload: encryptedContent - }); - await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, new Map([[userId, [deviceInfo]]])); - await olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.userId, this.deviceId, this.olmDevice, userId, deviceInfo, payload); - })); - - // prune out any devices that encryptMessageForDevice could not encrypt for, - // in which case it will have just not added anything to the ciphertext object. - // There's no point sending messages to devices if we couldn't encrypt to them, - // since that's effectively a blank message. - toDeviceBatch.batch = toDeviceBatch.batch.filter(msg => { - if (Object.keys(msg.payload.ciphertext).length > 0) { - return true; - } else { - _logger.logger.log(`No ciphertext for device ${msg.userId}:${msg.deviceId}: pruning`); - return false; - } - }); - try { - await this.baseApis.queueToDevice(toDeviceBatch); - } catch (e) { - _logger.logger.error("sendToDevice failed", e); - throw e; - } - } catch (e) { - _logger.logger.error("encryptAndSendToDevices promises failed", e); - throw e; - } - } - async preprocessToDeviceMessages(events) { - // all we do here is filter out encrypted to-device messages with the wrong algorithm. Decryption - // happens later in decryptEvent, via the EventMapper - return events.filter(toDevice => { - var _toDevice$content; - if (toDevice.type === _event.EventType.RoomMessageEncrypted && !["m.olm.v1.curve25519-aes-sha2"].includes((_toDevice$content = toDevice.content) === null || _toDevice$content === void 0 ? void 0 : _toDevice$content.algorithm)) { - _logger.logger.log("Ignoring invalid encrypted to-device event from " + toDevice.sender); - return false; - } - return true; - }); - } - preprocessOneTimeKeyCounts(oneTimeKeysCounts) { - const currentCount = oneTimeKeysCounts.get("signed_curve25519") || 0; - this.updateOneTimeKeyCount(currentCount); - return Promise.resolve(); - } - preprocessUnusedFallbackKeys(unusedFallbackKeys) { - this.setNeedsNewFallback(!unusedFallbackKeys.has("signed_curve25519")); - return Promise.resolve(); - } - /** - * Handle a key event - * - * @internal - * @param event - key event - */ - onRoomKeyEvent(event) { - const content = event.getContent(); - if (!content.room_id || !content.algorithm) { - _logger.logger.error("key event is missing fields"); - return; - } - if (!this.backupManager.checkedForBackup) { - // don't bother awaiting on this - the important thing is that we retry if we - // haven't managed to check before - this.backupManager.checkAndStart(); - } - const alg = this.getRoomDecryptor(content.room_id, content.algorithm); - alg.onRoomKeyEvent(event); - } - - /** - * Handle a key withheld event - * - * @internal - * @param event - key withheld event - */ - onRoomKeyWithheldEvent(event) { - const content = event.getContent(); - if (content.code !== "m.no_olm" && (!content.room_id || !content.session_id) || !content.algorithm || !content.sender_key) { - _logger.logger.error("key withheld event is missing fields"); - return; - } - _logger.logger.info(`Got room key withheld event from ${event.getSender()} ` + `for ${content.algorithm} session ${content.sender_key}|${content.session_id} ` + `in room ${content.room_id} with code ${content.code} (${content.reason})`); - const alg = this.getRoomDecryptor(content.room_id, content.algorithm); - if (alg.onRoomKeyWithheldEvent) { - alg.onRoomKeyWithheldEvent(event); - } - if (!content.room_id) { - // retry decryption for all events sent by the sender_key. This will - // update the events to show a message indicating that the olm session was - // wedged. - const roomDecryptors = this.getRoomDecryptors(content.algorithm); - for (const decryptor of roomDecryptors) { - decryptor.retryDecryptionFromSender(content.sender_key); - } - } - } - - /** - * Handle a general key verification event. - * - * @internal - * @param event - verification start event - */ - onKeyVerificationMessage(event) { - if (!_ToDeviceChannel.ToDeviceChannel.validateEvent(event, this.baseApis)) { - return; - } - const createRequest = event => { - if (!_ToDeviceChannel.ToDeviceChannel.canCreateRequest(_ToDeviceChannel.ToDeviceChannel.getEventType(event))) { - return; - } - const content = event.getContent(); - const deviceId = content && content.from_device; - if (!deviceId) { - return; - } - const userId = event.getSender(); - const channel = new _ToDeviceChannel.ToDeviceChannel(this.baseApis, userId, [deviceId]); - return new _VerificationRequest.VerificationRequest(channel, this.verificationMethods, this.baseApis); - }; - this.handleVerificationEvent(event, this.toDeviceVerificationRequests, createRequest); - } - - /** - * Handle key verification requests sent as timeline events - * - * @internal - * @param event - the timeline event - * @param room - not used - * @param atStart - not used - * @param removed - not used - * @param whether - this is a live event - */ - - async handleVerificationEvent(event, requestsMap, createRequest, isLiveEvent = true) { - // Wait for event to get its final ID with pendingEventOrdering: "chronological", since DM channels depend on it. - if (event.isSending() && event.status != _event2.EventStatus.SENT) { - let eventIdListener; - let statusListener; - try { - await new Promise((resolve, reject) => { - eventIdListener = resolve; - statusListener = () => { - if (event.status == _event2.EventStatus.CANCELLED) { - reject(new Error("Event status set to CANCELLED.")); - } - }; - event.once(_event2.MatrixEventEvent.LocalEventIdReplaced, eventIdListener); - event.on(_event2.MatrixEventEvent.Status, statusListener); - }); - } catch (err) { - _logger.logger.error("error while waiting for the verification event to be sent: ", err); - return; - } finally { - event.removeListener(_event2.MatrixEventEvent.LocalEventIdReplaced, eventIdListener); - event.removeListener(_event2.MatrixEventEvent.Status, statusListener); - } - } - let request = requestsMap.getRequest(event); - let isNewRequest = false; - if (!request) { - request = createRequest(event); - // a request could not be made from this event, so ignore event - if (!request) { - _logger.logger.log(`Crypto: could not find VerificationRequest for ` + `${event.getType()}, and could not create one, so ignoring.`); - return; - } - isNewRequest = true; - requestsMap.setRequest(event, request); - } - event.setVerificationRequest(request); - try { - await request.channel.handleEvent(event, request, isLiveEvent); - } catch (err) { - _logger.logger.error("error while handling verification event", err); - } - const shouldEmit = isNewRequest && !request.initiatedByMe && !request.invalid && - // check it has enough events to pass the UNSENT stage - !request.observeOnly; - if (shouldEmit) { - this.baseApis.emit(CryptoEvent.VerificationRequest, request); - } - } - - /** - * Handle a toDevice event that couldn't be decrypted - * - * @internal - * @param event - undecryptable event - */ - async onToDeviceBadEncrypted(event) { - const content = event.getWireContent(); - const sender = event.getSender(); - const algorithm = content.algorithm; - const deviceKey = content.sender_key; - this.baseApis.emit(_client.ClientEvent.UndecryptableToDeviceEvent, event); - - // retry decryption for all events sent by the sender_key. This will - // update the events to show a message indicating that the olm session was - // wedged. - const retryDecryption = () => { - const roomDecryptors = this.getRoomDecryptors(olmlib.MEGOLM_ALGORITHM); - for (const decryptor of roomDecryptors) { - decryptor.retryDecryptionFromSender(deviceKey); - } - }; - if (sender === undefined || deviceKey === undefined || deviceKey === undefined) { - return; - } - - // check when we last forced a new session with this device: if we've already done so - // recently, don't do it again. - const lastNewSessionDevices = this.lastNewSessionForced.getOrCreate(sender); - const lastNewSessionForced = lastNewSessionDevices.getOrCreate(deviceKey); - if (lastNewSessionForced + MIN_FORCE_SESSION_INTERVAL_MS > Date.now()) { - _logger.logger.debug("New session already forced with device " + sender + ":" + deviceKey + " at " + lastNewSessionForced + ": not forcing another"); - await this.olmDevice.recordSessionProblem(deviceKey, "wedged", true); - retryDecryption(); - return; - } - - // establish a new olm session with this device since we're failing to decrypt messages - // on a current session. - // Note that an undecryptable message from another device could easily be spoofed - - // is there anything we can do to mitigate this? - let device = this.deviceList.getDeviceByIdentityKey(algorithm, deviceKey); - if (!device) { - // if we don't know about the device, fetch the user's devices again - // and retry before giving up - await this.downloadKeys([sender], false); - device = this.deviceList.getDeviceByIdentityKey(algorithm, deviceKey); - if (!device) { - _logger.logger.info("Couldn't find device for identity key " + deviceKey + ": not re-establishing session"); - await this.olmDevice.recordSessionProblem(deviceKey, "wedged", false); - retryDecryption(); - return; - } - } - const devicesByUser = new Map([[sender, [device]]]); - await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, devicesByUser, true); - lastNewSessionDevices.set(deviceKey, Date.now()); - - // Now send a blank message on that session so the other side knows about it. - // (The keyshare request is sent in the clear so that won't do) - // We send this first such that, as long as the toDevice messages arrive in the - // same order we sent them, the other end will get this first, set up the new session, - // then get the keyshare request and send the key over this new session (because it - // is the session it has most recently received a message on). - const encryptedContent = { - algorithm: olmlib.OLM_ALGORITHM, - sender_key: this.olmDevice.deviceCurve25519Key, - ciphertext: {}, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }; - await olmlib.encryptMessageForDevice(encryptedContent.ciphertext, this.userId, this.deviceId, this.olmDevice, sender, device, { - type: "m.dummy" - }); - await this.olmDevice.recordSessionProblem(deviceKey, "wedged", true); - retryDecryption(); - await this.baseApis.sendToDevice("m.room.encrypted", new Map([[sender, new Map([[device.deviceId, encryptedContent]])]])); - - // Most of the time this probably won't be necessary since we'll have queued up a key request when - // we failed to decrypt the message and will be waiting a bit for the key to arrive before sending - // it. This won't always be the case though so we need to re-send any that have already been sent - // to avoid races. - const requestsToResend = await this.outgoingRoomKeyRequestManager.getOutgoingSentRoomKeyRequest(sender, device.deviceId); - for (const keyReq of requestsToResend) { - this.requestRoomKey(keyReq.requestBody, keyReq.recipients, true); - } - } - - /** - * Handle a change in the membership state of a member of a room - * - * @internal - * @param event - event causing the change - * @param member - user whose membership changed - * @param oldMembership - previous membership - */ - onRoomMembership(event, member, oldMembership) { - // this event handler is registered on the *client* (as opposed to the room - // member itself), which means it is only called on changes to the *live* - // membership state (ie, it is not called when we back-paginate, nor when - // we load the state in the initialsync). - // - // Further, it is automatically registered and called when new members - // arrive in the room. - - const roomId = member.roomId; - const alg = this.roomEncryptors.get(roomId); - if (!alg) { - // not encrypting in this room - return; - } - // only mark users in this room as tracked if we already started tracking in this room - // this way we don't start device queries after sync on behalf of this room which we won't use - // the result of anyway, as we'll need to do a query again once all the members are fetched - // by calling _trackRoomDevices - if (roomId in this.roomDeviceTrackingState) { - var _this$clientStore$get; - if (member.membership == "join") { - _logger.logger.log("Join event for " + member.userId + " in " + roomId); - // make sure we are tracking the deviceList for this user - this.deviceList.startTrackingDeviceList(member.userId); - } else if (member.membership == "invite" && (_this$clientStore$get = this.clientStore.getRoom(roomId)) !== null && _this$clientStore$get !== void 0 && _this$clientStore$get.shouldEncryptForInvitedMembers()) { - _logger.logger.log("Invite event for " + member.userId + " in " + roomId); - this.deviceList.startTrackingDeviceList(member.userId); - } - } - alg.onRoomMembership(event, member, oldMembership); - } - - /** - * Called when we get an m.room_key_request event. - * - * @internal - * @param event - key request event - */ - onRoomKeyRequestEvent(event) { - const content = event.getContent(); - if (content.action === "request") { - // Queue it up for now, because they tend to arrive before the room state - // events at initial sync, and we want to see if we know anything about the - // room before passing them on to the app. - const req = new IncomingRoomKeyRequest(event); - this.receivedRoomKeyRequests.push(req); - } else if (content.action === "request_cancellation") { - const req = new IncomingRoomKeyRequestCancellation(event); - this.receivedRoomKeyRequestCancellations.push(req); - } - } - - /** - * Process any m.room_key_request events which were queued up during the - * current sync. - * - * @internal - */ - async processReceivedRoomKeyRequests() { - if (this.processingRoomKeyRequests) { - // we're still processing last time's requests; keep queuing new ones - // up for now. - return; - } - this.processingRoomKeyRequests = true; - try { - // we need to grab and clear the queues in the synchronous bit of this method, - // so that we don't end up racing with the next /sync. - const requests = this.receivedRoomKeyRequests; - this.receivedRoomKeyRequests = []; - const cancellations = this.receivedRoomKeyRequestCancellations; - this.receivedRoomKeyRequestCancellations = []; - - // Process all of the requests, *then* all of the cancellations. - // - // This makes sure that if we get a request and its cancellation in the - // same /sync result, then we process the request before the - // cancellation (and end up with a cancelled request), rather than the - // cancellation before the request (and end up with an outstanding - // request which should have been cancelled.) - await Promise.all(requests.map(req => this.processReceivedRoomKeyRequest(req))); - await Promise.all(cancellations.map(cancellation => this.processReceivedRoomKeyRequestCancellation(cancellation))); - } catch (e) { - _logger.logger.error(`Error processing room key requsts: ${e}`); - } finally { - this.processingRoomKeyRequests = false; - } - } - - /** - * Helper for processReceivedRoomKeyRequests - * - */ - async processReceivedRoomKeyRequest(req) { - const userId = req.userId; - const deviceId = req.deviceId; - const body = req.requestBody; - const roomId = body.room_id; - const alg = body.algorithm; - _logger.logger.log(`m.room_key_request from ${userId}:${deviceId}` + ` for ${roomId} / ${body.session_id} (id ${req.requestId})`); - if (userId !== this.userId) { - if (!this.roomEncryptors.get(roomId)) { - _logger.logger.debug(`room key request for unencrypted room ${roomId}`); - return; - } - const encryptor = this.roomEncryptors.get(roomId); - const device = this.deviceList.getStoredDevice(userId, deviceId); - if (!device) { - _logger.logger.debug(`Ignoring keyshare for unknown device ${userId}:${deviceId}`); - return; - } - try { - await encryptor.reshareKeyWithDevice(body.sender_key, body.session_id, userId, device); - } catch (e) { - _logger.logger.warn("Failed to re-share keys for session " + body.session_id + " with device " + userId + ":" + device.deviceId, e); - } - return; - } - if (deviceId === this.deviceId) { - // We'll always get these because we send room key requests to - // '*' (ie. 'all devices') which includes the sending device, - // so ignore requests from ourself because apart from it being - // very silly, it won't work because an Olm session cannot send - // messages to itself. - // The log here is probably superfluous since we know this will - // always happen, but let's log anyway for now just in case it - // causes issues. - _logger.logger.log("Ignoring room key request from ourselves"); - return; - } - - // todo: should we queue up requests we don't yet have keys for, - // in case they turn up later? - - // if we don't have a decryptor for this room/alg, we don't have - // the keys for the requested events, and can drop the requests. - if (!this.roomDecryptors.has(roomId)) { - _logger.logger.log(`room key request for unencrypted room ${roomId}`); - return; - } - const decryptor = this.roomDecryptors.get(roomId).get(alg); - if (!decryptor) { - _logger.logger.log(`room key request for unknown alg ${alg} in room ${roomId}`); - return; - } - if (!(await decryptor.hasKeysForKeyRequest(req))) { - _logger.logger.log(`room key request for unknown session ${roomId} / ` + body.session_id); - return; - } - req.share = () => { - decryptor.shareKeysWithDevice(req); - }; - - // if the device is verified already, share the keys - if (this.checkDeviceTrust(userId, deviceId).isVerified()) { - _logger.logger.log("device is already verified: sharing keys"); - req.share(); - return; - } - this.emit(CryptoEvent.RoomKeyRequest, req); - } - - /** - * Helper for processReceivedRoomKeyRequests - * - */ - async processReceivedRoomKeyRequestCancellation(cancellation) { - _logger.logger.log(`m.room_key_request cancellation for ${cancellation.userId}:` + `${cancellation.deviceId} (id ${cancellation.requestId})`); - - // we should probably only notify the app of cancellations we told it - // about, but we don't currently have a record of that, so we just pass - // everything through. - this.emit(CryptoEvent.RoomKeyRequestCancellation, cancellation); - } - - /** - * Get a decryptor for a given room and algorithm. - * - * If we already have a decryptor for the given room and algorithm, return - * it. Otherwise try to instantiate it. - * - * @internal - * - * @param roomId - room id for decryptor. If undefined, a temporary - * decryptor is instantiated. - * - * @param algorithm - crypto algorithm - * - * @throws {@link DecryptionError} if the algorithm is unknown - */ - getRoomDecryptor(roomId, algorithm) { - let decryptors; - let alg; - if (roomId) { - decryptors = this.roomDecryptors.get(roomId); - if (!decryptors) { - decryptors = new Map(); - this.roomDecryptors.set(roomId, decryptors); - } - alg = decryptors.get(algorithm); - if (alg) { - return alg; - } - } - const AlgClass = algorithms.DECRYPTION_CLASSES.get(algorithm); - if (!AlgClass) { - throw new algorithms.DecryptionError("UNKNOWN_ENCRYPTION_ALGORITHM", 'Unknown encryption algorithm "' + algorithm + '".'); - } - alg = new AlgClass({ - userId: this.userId, - crypto: this, - olmDevice: this.olmDevice, - baseApis: this.baseApis, - roomId: roomId !== null && roomId !== void 0 ? roomId : undefined - }); - if (decryptors) { - decryptors.set(algorithm, alg); - } - return alg; - } - - /** - * Get all the room decryptors for a given encryption algorithm. - * - * @param algorithm - The encryption algorithm - * - * @returns An array of room decryptors - */ - getRoomDecryptors(algorithm) { - const decryptors = []; - for (const d of this.roomDecryptors.values()) { - if (d.has(algorithm)) { - decryptors.push(d.get(algorithm)); - } - } - return decryptors; - } - - /** - * sign the given object with our ed25519 key - * - * @param obj - Object to which we will add a 'signatures' property - */ - async signObject(obj) { - const sigs = new Map(Object.entries(obj.signatures || {})); - const unsigned = obj.unsigned; - delete obj.signatures; - delete obj.unsigned; - const userSignatures = sigs.get(this.userId) || {}; - sigs.set(this.userId, userSignatures); - userSignatures["ed25519:" + this.deviceId] = await this.olmDevice.sign(_anotherJson.default.stringify(obj)); - obj.signatures = (0, _utils.recursiveMapToObject)(sigs); - if (unsigned !== undefined) obj.unsigned = unsigned; - } -} - -/** - * Fix up the backup key, that may be in the wrong format due to a bug in a - * migration step. Some backup keys were stored as a comma-separated list of - * integers, rather than a base64-encoded byte array. If this function is - * passed a string that looks like a list of integers rather than a base64 - * string, it will attempt to convert it to the right format. - * - * @param key - the key to check - * @returns If the key is in the wrong format, then the fixed - * key will be returned. Otherwise null will be returned. - * - */ -exports.Crypto = Crypto; -function fixBackupKey(key) { - if (typeof key !== "string" || key.indexOf(",") < 0) { - return null; - } - const fixedKey = Uint8Array.from(key.split(","), x => parseInt(x)); - return olmlib.encodeBase64(fixedKey); -} - -/** - * Represents a received m.room_key_request event - */ -class IncomingRoomKeyRequest { - /** user requesting the key */ - - /** device requesting the key */ - - /** unique id for the request */ - - /** - * callback which, when called, will ask - * the relevant crypto algorithm implementation to share the keys for - * this request. - */ - - constructor(event) { - (0, _defineProperty2.default)(this, "userId", void 0); - (0, _defineProperty2.default)(this, "deviceId", void 0); - (0, _defineProperty2.default)(this, "requestId", void 0); - (0, _defineProperty2.default)(this, "requestBody", void 0); - (0, _defineProperty2.default)(this, "share", void 0); - const content = event.getContent(); - this.userId = event.getSender(); - this.deviceId = content.requesting_device_id; - this.requestId = content.request_id; - this.requestBody = content.body || {}; - this.share = () => { - throw new Error("don't know how to share keys for this request yet"); - }; - } -} - -/** - * Represents a received m.room_key_request cancellation - */ -exports.IncomingRoomKeyRequest = IncomingRoomKeyRequest; -class IncomingRoomKeyRequestCancellation { - /** user requesting the cancellation */ - - /** device requesting the cancellation */ - - /** unique id for the request to be cancelled */ - - constructor(event) { - (0, _defineProperty2.default)(this, "userId", void 0); - (0, _defineProperty2.default)(this, "deviceId", void 0); - (0, _defineProperty2.default)(this, "requestId", void 0); - const content = event.getContent(); - this.userId = event.getSender(); - this.deviceId = content.requesting_device_id; - this.requestId = content.request_id; - } -} - -// a number of types are re-exported for backwards compatibility, in case any applications are referencing it. -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js.map deleted file mode 100644 index c9b3f6a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["_anotherJson","_interopRequireDefault","require","_uuid","_event","_ReEmitter","_logger","_OlmDevice","olmlib","_interopRequireWildcard","_DeviceList","_deviceinfo","algorithms","_CrossSigning","_EncryptionSetup","_SecretStorage","_OutgoingRoomKeyRequestManager","_indexeddbCryptoStore","_QRCode","_SAS","_key_passphrase","_recoverykey","_VerificationRequest","_InRoomChannel","_ToDeviceChannel","_IllegalMethod","_errors","_aes","_dehydration","_backup","_room","_roomMember","_event2","_client","_typedEventEmitter","_roomState","_utils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","DeviceVerification","DeviceInfo","defaultVerificationMethods","ReciprocateQRCode","NAME","SASVerification","SHOW_QR_CODE_METHOD","IllegalMethod","SCAN_QR_CODE_METHOD","verificationMethods","RECIPROCATE_QR_CODE","SAS","exports","isCryptoAvailable","Boolean","global","Olm","MIN_FORCE_SESSION_INTERVAL_MS","CryptoEvent","Crypto","TypedEventEmitter","getOlmVersion","OlmDevice","constructor","baseApis","userId","deviceId","clientStore","cryptoStore","roomList","Map","MapWithDefault","newCrossSigning","deviceList","getStoredCrossSigningForUser","seenPubkey","getId","currentPubkey","crossSigningInfo","changed","checkOwnCrossSigningTrust","storeTrustedSelfKeys","emit","KeysChanged","UserTrustStatusChanged","checkUserTrust","checkDeviceVerifications","crossSigning","updateCrossSigningVerifiedBefore","isCrossSigningVerified","setRawStoredCrossSigningForUser","toStorage","event","member","oldMembership","onRoomMembership","e","logger","error","log","getType","getSender","getContent","ToDeviceMessageId","onRoomKeyEvent","onRoomKeyRequestEvent","secretStorage","onRequestReceived","onSecretReceived","onRoomKeyWithheldEvent","transaction_id","onKeyVerificationMessage","msgtype","onToDeviceBadEncrypted","isBeingDecrypted","shouldAttemptDecryption","attemptDecryption","once","MatrixEventEvent","Decrypted","ev","onToDeviceEvent","room","atStart","removed","liveEvent","InRoomChannel","validateEvent","createRequest","channel","getRoomId","VerificationRequest","handleVerificationEvent","inRoomVerificationRequests","reEmitter","TypedReEmitter","method","warn","entries","backupManager","BackupManager","cachedKey","getSessionBackupPrivateKey","storedKey","getSecret","fixedKey","fixBackupKey","getSecretStorageKey","storeSecret","decodeBase64","cryptoCallbacks","getBackupKey","Error","olmDevice","DeviceList","on","UserCrossSigningUpdated","onDeviceListUserCrossSigningUpdated","reEmit","DevicesUpdated","WillUpdateDevices","supportedAlgorithms","Array","from","DECRYPTION_CLASSES","outgoingRoomKeyRequestManager","OutgoingRoomKeyRequestManager","toDeviceVerificationRequests","ToDeviceRequests","InRoomRequests","cacheCallbacks","createCryptoStoreCacheCallbacks","CrossSigningInfo","SecretStorage","dehydrationManager","DehydrationManager","getCrossSigningKey","type","getFromSecretStorage","init","exportedOlmDevice","pickleKey","fromExportedDevice","load","deviceKeys","deviceEd25519Key","deviceCurve25519Key","myDevices","getRawStoredDevicesForUser","deviceInfo","verified","VERIFIED","known","storeDevicesForUser","saveIfDirty","doTxn","IndexedDBCryptoStore","STORE_ACCOUNT","txn","getCrossSigningKeys","setKeys","startTrackingDeviceList","checkAndStart","getCryptoTrustCrossSignedDevices","trustCrossSignedDevices","setCryptoTrustCrossSignedDevices","val","getKnownUserIds","devices","deviceTrust","checkDeviceTrust","isLocallyVerified","deviceObj","getStoredDevice","DeviceVerificationChanged","createRecoveryKeyFromPassphrase","password","decryption","PkDecryption","keyInfo","derivation","keyFromPassphrase","passphrase","algorithm","iterations","salt","pubkey","init_with_private_key","generate_key","privateKey","get_private_key","encodedPrivateKey","encodeRecoveryKey","free","userHasCrossSigningKeys","downloadKeys","isCrossSigningReady","publicKeysOnDevice","privateKeysExistSomewhere","isStoredInKeyCache","isStoredInSecretStorage","isSecretStorageReady","secretStorageKeyInAccount","hasKey","privateKeysInStorage","sessionBackupInStorage","getKeyBackupEnabled","isKeyBackupKeyStored","bootstrapCrossSigning","authUploadDeviceSigningKeys","setupNewCrossSigning","delegateCryptoCallbacks","builder","EncryptionSetupBuilder","store","accountData","crossSigningCallbacks","resetCrossSigning","resetKeys","signObject","master","addCrossSigningKeys","device","deviceSignature","signDevice","addKeySignature","backupInfo","auth_data","addSessionBackup","privateKeysInCache","allowPrivateKeyRequests","crossSigningPrivateKeys","privateKeys","size","saveCrossSigningKeys","accountDataClientAdapter","ssssCryptoCallbacks","undefined","storeInSecretStorage","operation","buildOperation","persist","bootstrapSecretStorage","createSecretStorageKey","keyBackupInfo","setupNewKeyBackup","setupNewSecretStorage","getKeyBackupPassphrase","newKeyId","createSSSS","opts","keyId","addKey","SECRET_STORAGE_ALGORITHM_V1_AES","addPrivateKey","setDefaultKeyId","ensureCanCheckPassphrase","mac","_this$baseApis$crypto","_this$baseApis$crypto2","iv","calculateKeyCheck","setAccountData","signKeyBackupWithCrossSigning","keyBackupAuthData","oldSSSSKey","oldKeyId","oldKeyInfo","storageExists","backupKey","private_key_salt","private_key_iterations","bits","encodeBase64","getCrossSigningKeysFromCache","info","prepareKeyBackupVersion","secureSecretStorage","decodeRecoveryKey","recovery_key","data","sessionBackupKey","fixedBackupKey","decodedBackupKey","Uint8Array","addSessionBackupPrivateKeyToCache","addSecretStorageKey","keyID","hasSecretStorageKey","getKey","name","secret","isSecretStored","isStored","requestSecret","request","getDefaultSecretStorageKeyId","getDefaultKeyId","setDefaultSecretStorageKeyId","k","checkSecretStorageKey","checkKey","checkSecretStoragePrivateKey","expectedPublicKey","gotPubkey","_decryption","Promise","resolve","getSecretStorePrivateKey","storeSessionBackupPrivateKey","ciphertext","Buffer","decrypted","decryptAES","encryptedKey","encryptAES","storeSecretStorePrivateKey","checkCrossSigningPrivateKey","signing","PkSigning","init_with_seed","_signing","afterCrossSigningLocalKeyChange","signedDevice","upload","shouldEmit","uploadKeySignatures","then","response","failures","KeySignatureUploadFailure","KeySignatureUploadError","catch","shouldUpgradeCb","shouldUpgradeDeviceVerifications","users","upgradeInfo","checkForDeviceVerificationUpgrade","fromStorage","usersToUpgrade","setDeviceVerified","trustLevel","firstUse","isVerified","deviceIds","checkForValidDeviceSignature","map","signatures","signame","split","verifySignature","getCrossSigningId","userCrossSigning","UserTrustLevel","checkDeviceInfoTrust","trustedLocally","trustCrossSig","DeviceTrustLevel","checkIfOwnDeviceCrossSigned","_userCrossSigning$che","masterChanged","masterExistsNotLocallyCached","ret","_signing2","oldSelfSigningId","oldUserSigningId","selfSigningChanged","userSigningChanged","selfSigningExistsNotLocallyCached","userSigningExistsNotLocallyCached","keySignatures","_signing3","_signing4","masterKey","deviceSig","assign","keysToUpload","checkKeyBackup","clearKeys","storeCrossSigningKeys","user_signing","includes","enableLazyLoading","lazyLoadMembers","registerEventHandlers","eventEmitter","RoomMemberEvent","Membership","onMembership","ClientEvent","ToDeviceEvent","RoomEvent","Timeline","onTimelineEvent","start","stop","getDeviceEd25519Key","getDeviceCurve25519Key","setGlobalBlacklistUnverifiedDevices","value","globalBlacklistUnverifiedDevices","getGlobalBlacklistUnverifiedDevices","uploadDeviceKeys","device_id","user_id","uploadKeysRequest","device_keys","updateOneTimeKeyCount","currentCount","isFinite","oneTimeKeyCount","TypeError","setNeedsNewFallback","needsNewFallback","getNeedsNewFallback","maybeUploadOneTimeKeys","uploadPeriod","maxKeysPerCycle","oneTimeKeyCheckInProgress","now","Date","lastOneTimeKeyCheck","maxOneTimeKeys","maxNumberOfOneTimeKeys","keyLimit","Math","floor","uploadLoop","keyCount","keysThisLoop","min","generateOneTimeKeys","fallbackKeys","getFallbackKey","curve25519","fallbackCleanup","clearTimeout","generateFallbackKey","res","uploadOneTimeKeys","one_time_key_counts","signed_curve25519","stack","finally","promises","fallbackJson","fallback","oneTimeKeys","getOneTimeKeys","oneTimeJson","all","requestBody","one_time_keys","setTimeout","forgetOldFallbackKey","markKeysAsPublished","userIds","forceDownload","getStoredDevicesForUser","saveDeviceList","delay","setDeviceVerification","blocked","xsk","gotKeyId","values","signUser","dev","verificationStatus","UNVERIFIED","BLOCKED","knownStatus","findVerificationRequestDMInProgress","roomId","findRequestInProgress","getVerificationRequestsToDeviceInProgress","getRequestsInProgress","requestVerificationDM","existingRequest","requestVerificationWithChannel","requestVerification","ToDeviceChannel","makeTransactionId","requestsMap","transactionId","setRequestByChannel","sendRequest","racingRequest","getRequestByChannel","beginKeyVerification","getRequestBySenderAndTxnId","setRequestBySenderAndTxnId","legacyDeviceVerification","verifier","race","verify","waitFor","r","started","getOlmSessionsForUser","result","deviceKey","getIdentityKey","sessions","getSessionInfoForDevice","deviceIdKey","getEventSenderDeviceInfo","senderKey","getSenderKey","getWireContent","isKeySourceUntrusted","getDeviceByIdentityKey","claimedKey","getClaimedEd25519Key","getFingerprint","getEventEncryptionInfo","_event$getSenderKey","_this$deviceList$getD","encrypted","authenticated","sender","mismatchedSender","forceDiscardSession","alg","roomEncryptors","setRoomEncryption","config","inhibitDeviceQuery","getRoom","setRoomEncryptionImpl","refreshOutdatedDeviceLists","existingConfig","getRoomEncryption","JSON","stringify","existingAlg","storeConfigPromise","AlgClass","ENCRYPTION_CLASSES","crypto","membersLoaded","trackRoomDevicesImpl","onState","_state","off","RoomStateEvent","Update","trackRoomDevices","trackMembers","members","getEncryptionTargetMembers","m","promise","roomDeviceTrackingState","err","ensureOlmSessionsForUsers","force","devicesByUser","userDevices","ensureOlmSessionsForDevices","exportRoomKeys","exportedSessions","STORE_INBOUND_GROUP_SESSIONS","getAllEndToEndInboundGroupSessions","s","sess","exportInboundGroupSession","sessionId","sessionData","first_known_index","MEGOLM_ALGORITHM","importRoomKeys","successes","total","updateProgress","_opts$progressCallbac","progressCallback","stage","room_id","getRoomDecryptor","importRoomKey","countSessionsNeedingBackup","prepareToEncrypt","encryptEvent","content","mRelatesTo","elementPerfMetrics","encryptedContent","encryptMessage","makeEncrypted","decryptEvent","isRedacted","redactionEvent","MatrixEvent","getUnsigned","redacted_because","redactedBecause","isEncrypted","decryptedEvent","clearEvent","unsigned","handleDeviceListChanges","syncData","syncDeviceLists","oldSyncToken","evalDeviceListChanges","requestRoomKey","recipients","resend","queueRoomKeyRequest","sendKeyRequestsImmediately","sendQueuedRequests","cancelRoomKeyRequest","cancelAndResendAllOutgoingKeyRequests","cancelAndResendAllOutgoingRequests","onCryptoEvent","onSyncWillProcess","stopTrackingAllDeviceLists","onSyncCompleted","_syncData$nextSyncTok","setSyncToken","nextSyncToken","catchingUp","processReceivedRoomKeyRequests","deviceLists","isArray","u","invalidateUserDeviceList","left","e2eUserIds","Set","getTrackedE2eUsers","stopTrackingDeviceList","getTrackedE2eRooms","getRooms","myMembership","getMyMembership","encryptAndSendToDevices","userDeviceInfoArr","payload","toDeviceBatch","eventType","EventType","RoomMessageEncrypted","batch","OLM_ALGORITHM","sender_key","uuidv4","encryptMessageForDevice","msg","queueToDevice","preprocessToDeviceMessages","events","toDevice","_toDevice$content","preprocessOneTimeKeyCounts","oneTimeKeysCounts","preprocessUnusedFallbackKeys","unusedFallbackKeys","checkedForBackup","code","session_id","reason","roomDecryptors","getRoomDecryptors","decryptor","retryDecryptionFromSender","canCreateRequest","getEventType","from_device","isLiveEvent","isSending","status","EventStatus","SENT","eventIdListener","statusListener","reject","CANCELLED","LocalEventIdReplaced","Status","removeListener","getRequest","isNewRequest","setRequest","setVerificationRequest","handleEvent","initiatedByMe","invalid","observeOnly","UndecryptableToDeviceEvent","retryDecryption","lastNewSessionDevices","lastNewSessionForced","getOrCreate","debug","recordSessionProblem","sendToDevice","requestsToResend","getOutgoingSentRoomKeyRequest","keyReq","_this$clientStore$get","membership","shouldEncryptForInvitedMembers","action","req","IncomingRoomKeyRequest","receivedRoomKeyRequests","IncomingRoomKeyRequestCancellation","receivedRoomKeyRequestCancellations","processingRoomKeyRequests","requests","cancellations","processReceivedRoomKeyRequest","cancellation","processReceivedRoomKeyRequestCancellation","body","requestId","encryptor","reshareKeyWithDevice","hasKeysForKeyRequest","share","shareKeysWithDevice","RoomKeyRequest","RoomKeyRequestCancellation","decryptors","DecryptionError","d","sigs","userSignatures","sign","anotherjson","recursiveMapToObject","indexOf","x","parseInt","requesting_device_id","request_id"],"sources":["../../src/crypto/index.ts"],"sourcesContent":["/*\nCopyright 2016 OpenMarket Ltd\nCopyright 2017 Vector Creations Ltd\nCopyright 2018-2019 New Vector Ltd\nCopyright 2019-2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport anotherjson from \"another-json\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport type { IDeviceKeys, IEventDecryptionResult, IMegolmSessionData, IOneTimeKey } from \"../@types/crypto\";\nimport type { PkDecryption, PkSigning } from \"@matrix-org/olm\";\nimport { EventType, ToDeviceMessageId } from \"../@types/event\";\nimport { TypedReEmitter } from \"../ReEmitter\";\nimport { logger } from \"../logger\";\nimport { IExportedDevice, OlmDevice } from \"./OlmDevice\";\nimport { IOlmDevice } from \"./algorithms/megolm\";\nimport * as olmlib from \"./olmlib\";\nimport { DeviceInfoMap, DeviceList } from \"./DeviceList\";\nimport { DeviceInfo, IDevice } from \"./deviceinfo\";\nimport type { DecryptionAlgorithm, EncryptionAlgorithm } from \"./algorithms\";\nimport * as algorithms from \"./algorithms\";\nimport { createCryptoStoreCacheCallbacks, CrossSigningInfo, DeviceTrustLevel, UserTrustLevel } from \"./CrossSigning\";\nimport { EncryptionSetupBuilder } from \"./EncryptionSetup\";\nimport {\n IAccountDataClient,\n ISecretRequest,\n SECRET_STORAGE_ALGORITHM_V1_AES,\n SecretStorage,\n SecretStorageKeyObject,\n SecretStorageKeyTuple,\n} from \"./SecretStorage\";\nimport {\n IAddSecretStorageKeyOpts,\n ICreateSecretStorageOpts,\n IEncryptedEventInfo,\n IImportRoomKeysOpts,\n IRecoveryKey,\n} from \"./api\";\nimport { OutgoingRoomKeyRequestManager } from \"./OutgoingRoomKeyRequestManager\";\nimport { IndexedDBCryptoStore } from \"./store/indexeddb-crypto-store\";\nimport { VerificationBase } from \"./verification/Base\";\nimport { ReciprocateQRCode, SCAN_QR_CODE_METHOD, SHOW_QR_CODE_METHOD } from \"./verification/QRCode\";\nimport { SAS as SASVerification } from \"./verification/SAS\";\nimport { keyFromPassphrase } from \"./key_passphrase\";\nimport { decodeRecoveryKey, encodeRecoveryKey } from \"./recoverykey\";\nimport { VerificationRequest } from \"./verification/request/VerificationRequest\";\nimport { InRoomChannel, InRoomRequests } from \"./verification/request/InRoomChannel\";\nimport { ToDeviceChannel, ToDeviceRequests, Request } from \"./verification/request/ToDeviceChannel\";\nimport { IllegalMethod } from \"./verification/IllegalMethod\";\nimport { KeySignatureUploadError } from \"../errors\";\nimport { calculateKeyCheck, decryptAES, encryptAES } from \"./aes\";\nimport { DehydrationManager } from \"./dehydration\";\nimport { BackupManager } from \"./backup\";\nimport { IStore } from \"../store\";\nimport { Room, RoomEvent } from \"../models/room\";\nimport { RoomMember, RoomMemberEvent } from \"../models/room-member\";\nimport { EventStatus, IEvent, MatrixEvent, MatrixEventEvent } from \"../models/event\";\nimport { ToDeviceBatch } from \"../models/ToDeviceMessage\";\nimport {\n ClientEvent,\n ICrossSigningKey,\n IKeysUploadResponse,\n ISignedKey,\n IUploadKeySignaturesResponse,\n MatrixClient,\n} from \"../client\";\nimport type { IRoomEncryption, RoomList } from \"./RoomList\";\nimport { IKeyBackupInfo } from \"./keybackup\";\nimport { ISyncStateData } from \"../sync\";\nimport { CryptoStore } from \"./store/base\";\nimport { IVerificationChannel } from \"./verification/request/Channel\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { IContent } from \"../models/event\";\nimport { ISyncResponse, IToDeviceEvent } from \"../sync-accumulator\";\nimport { ISignatures } from \"../@types/signed\";\nimport { IMessage } from \"./algorithms/olm\";\nimport { CryptoBackend, OnSyncCompletedData } from \"../common-crypto/CryptoBackend\";\nimport { RoomState, RoomStateEvent } from \"../models/room-state\";\nimport { MapWithDefault, recursiveMapToObject } from \"../utils\";\nimport { SecretStorageKeyDescription } from \"../secret-storage\";\n\nconst DeviceVerification = DeviceInfo.DeviceVerification;\n\nconst defaultVerificationMethods = {\n [ReciprocateQRCode.NAME]: ReciprocateQRCode,\n [SASVerification.NAME]: SASVerification,\n\n // These two can't be used for actual verification, but we do\n // need to be able to define them here for the verification flows\n // to start.\n [SHOW_QR_CODE_METHOD]: IllegalMethod,\n [SCAN_QR_CODE_METHOD]: IllegalMethod,\n} as const;\n\n/**\n * verification method names\n */\n// legacy export identifier\nexport const verificationMethods = {\n RECIPROCATE_QR_CODE: ReciprocateQRCode.NAME,\n SAS: SASVerification.NAME,\n} as const;\n\nexport type VerificationMethod = keyof typeof verificationMethods | string;\n\nexport function isCryptoAvailable(): boolean {\n return Boolean(global.Olm);\n}\n\nconst MIN_FORCE_SESSION_INTERVAL_MS = 60 * 60 * 1000;\n\ninterface IInitOpts {\n exportedOlmDevice?: IExportedDevice;\n pickleKey?: string;\n}\n\nexport interface IBootstrapCrossSigningOpts {\n /** Optional. Reset even if keys already exist. */\n setupNewCrossSigning?: boolean;\n /**\n * A function that makes the request requiring auth. Receives the auth data as an object.\n * Can be called multiple times, first with an empty authDict, to obtain the flows.\n */\n authUploadDeviceSigningKeys?(makeRequest: (authData: any) => Promise<{}>): Promise;\n}\n\nexport interface ICryptoCallbacks {\n getCrossSigningKey?: (keyType: string, pubKey: string) => Promise;\n saveCrossSigningKeys?: (keys: Record) => void;\n shouldUpgradeDeviceVerifications?: (users: Record) => Promise;\n getSecretStorageKey?: (\n keys: { keys: Record },\n name: string,\n ) => Promise<[string, Uint8Array] | null>;\n cacheSecretStorageKey?: (keyId: string, keyInfo: SecretStorageKeyDescription, key: Uint8Array) => void;\n onSecretRequested?: (\n userId: string,\n deviceId: string,\n requestId: string,\n secretName: string,\n deviceTrust: DeviceTrustLevel,\n ) => Promise;\n getDehydrationKey?: (\n keyInfo: SecretStorageKeyDescription,\n checkFunc: (key: Uint8Array) => void,\n ) => Promise;\n getBackupKey?: () => Promise;\n}\n\n/* eslint-disable camelcase */\ninterface IRoomKey {\n room_id: string;\n algorithm: string;\n}\n\n/**\n * The parameters of a room key request. The details of the request may\n * vary with the crypto algorithm, but the management and storage layers for\n * outgoing requests expect it to have 'room_id' and 'session_id' properties.\n */\nexport interface IRoomKeyRequestBody extends IRoomKey {\n session_id: string;\n sender_key: string;\n}\n\n/* eslint-enable camelcase */\n\ninterface IDeviceVerificationUpgrade {\n devices: DeviceInfo[];\n crossSigningInfo: CrossSigningInfo;\n}\n\nexport interface ICheckOwnCrossSigningTrustOpts {\n allowPrivateKeyRequests?: boolean;\n}\n\ninterface IUserOlmSession {\n deviceIdKey: string;\n sessions: {\n sessionId: string;\n hasReceivedMessage: boolean;\n }[];\n}\n\nexport interface IRoomKeyRequestRecipient {\n userId: string;\n deviceId: string;\n}\n\ninterface ISignableObject {\n signatures?: ISignatures;\n unsigned?: object;\n}\n\nexport interface IRequestsMap {\n getRequest(event: MatrixEvent): VerificationRequest | undefined;\n getRequestByChannel(channel: IVerificationChannel): VerificationRequest | undefined;\n setRequest(event: MatrixEvent, request: VerificationRequest): void;\n setRequestByChannel(channel: IVerificationChannel, request: VerificationRequest): void;\n}\n\n/* eslint-disable camelcase */\nexport interface IOlmEncryptedContent {\n algorithm: typeof olmlib.OLM_ALGORITHM;\n sender_key: string;\n ciphertext: Record;\n [ToDeviceMessageId]?: string;\n}\n\nexport interface IMegolmEncryptedContent {\n algorithm: typeof olmlib.MEGOLM_ALGORITHM;\n sender_key: string;\n session_id: string;\n device_id: string;\n ciphertext: string;\n [ToDeviceMessageId]?: string;\n}\n/* eslint-enable camelcase */\n\nexport type IEncryptedContent = IOlmEncryptedContent | IMegolmEncryptedContent;\n\nexport enum CryptoEvent {\n DeviceVerificationChanged = \"deviceVerificationChanged\",\n UserTrustStatusChanged = \"userTrustStatusChanged\",\n UserCrossSigningUpdated = \"userCrossSigningUpdated\",\n RoomKeyRequest = \"crypto.roomKeyRequest\",\n RoomKeyRequestCancellation = \"crypto.roomKeyRequestCancellation\",\n KeyBackupStatus = \"crypto.keyBackupStatus\",\n KeyBackupFailed = \"crypto.keyBackupFailed\",\n KeyBackupSessionsRemaining = \"crypto.keyBackupSessionsRemaining\",\n KeySignatureUploadFailure = \"crypto.keySignatureUploadFailure\",\n VerificationRequest = \"crypto.verification.request\",\n Warning = \"crypto.warning\",\n WillUpdateDevices = \"crypto.willUpdateDevices\",\n DevicesUpdated = \"crypto.devicesUpdated\",\n KeysChanged = \"crossSigning.keysChanged\",\n}\n\nexport type CryptoEventHandlerMap = {\n /**\n * Fires when a device is marked as verified/unverified/blocked/unblocked by\n * {@link MatrixClient#setDeviceVerified|MatrixClient.setDeviceVerified} or\n * {@link MatrixClient#setDeviceBlocked|MatrixClient.setDeviceBlocked}.\n *\n * @param userId - the owner of the verified device\n * @param deviceId - the id of the verified device\n * @param deviceInfo - updated device information\n */\n [CryptoEvent.DeviceVerificationChanged]: (userId: string, deviceId: string, device: DeviceInfo) => void;\n /**\n * Fires when the trust status of a user changes\n * If userId is the userId of the logged-in user, this indicated a change\n * in the trust status of the cross-signing data on the account.\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n * @experimental\n *\n * @param userId - the userId of the user in question\n * @param trustLevel - The new trust level of the user\n */\n [CryptoEvent.UserTrustStatusChanged]: (userId: string, trustLevel: UserTrustLevel) => void;\n /**\n * Fires when we receive a room key request\n *\n * @param req - request details\n */\n [CryptoEvent.RoomKeyRequest]: (request: IncomingRoomKeyRequest) => void;\n /**\n * Fires when we receive a room key request cancellation\n */\n [CryptoEvent.RoomKeyRequestCancellation]: (request: IncomingRoomKeyRequestCancellation) => void;\n /**\n * Fires whenever the status of e2e key backup changes, as returned by getKeyBackupEnabled()\n * @param enabled - true if key backup has been enabled, otherwise false\n * @example\n * ```\n * matrixClient.on(\"crypto.keyBackupStatus\", function(enabled){\n * if (enabled) {\n * [...]\n * }\n * });\n * ```\n */\n [CryptoEvent.KeyBackupStatus]: (enabled: boolean) => void;\n [CryptoEvent.KeyBackupFailed]: (errcode: string) => void;\n [CryptoEvent.KeyBackupSessionsRemaining]: (remaining: number) => void;\n [CryptoEvent.KeySignatureUploadFailure]: (\n failures: IUploadKeySignaturesResponse[\"failures\"],\n source: \"checkOwnCrossSigningTrust\" | \"afterCrossSigningLocalKeyChange\" | \"setDeviceVerification\",\n upload: (opts: { shouldEmit: boolean }) => Promise,\n ) => void;\n /**\n * Fires when a key verification is requested.\n */\n [CryptoEvent.VerificationRequest]: (request: VerificationRequest) => void;\n /**\n * Fires when the app may wish to warn the user about something related\n * the end-to-end crypto.\n *\n * @param type - One of the strings listed above\n */\n [CryptoEvent.Warning]: (type: string) => void;\n /**\n * Fires when the user's cross-signing keys have changed or cross-signing\n * has been enabled/disabled. The client can use getStoredCrossSigningForUser\n * with the user ID of the logged in user to check if cross-signing is\n * enabled on the account. If enabled, it can test whether the current key\n * is trusted using with checkUserTrust with the user ID of the logged\n * in user. The checkOwnCrossSigningTrust function may be used to reconcile\n * the trust in the account key.\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n * @experimental\n */\n [CryptoEvent.KeysChanged]: (data: {}) => void;\n /**\n * Fires whenever the stored devices for a user will be updated\n * @param users - A list of user IDs that will be updated\n * @param initialFetch - If true, the store is empty (apart\n * from our own device) and is being seeded.\n */\n [CryptoEvent.WillUpdateDevices]: (users: string[], initialFetch: boolean) => void;\n /**\n * Fires whenever the stored devices for a user have changed\n * @param users - A list of user IDs that were updated\n * @param initialFetch - If true, the store was empty (apart\n * from our own device) and has been seeded.\n */\n [CryptoEvent.DevicesUpdated]: (users: string[], initialFetch: boolean) => void;\n [CryptoEvent.UserCrossSigningUpdated]: (userId: string) => void;\n};\n\nexport class Crypto extends TypedEventEmitter implements CryptoBackend {\n /**\n * @returns The version of Olm.\n */\n public static getOlmVersion(): [number, number, number] {\n return OlmDevice.getOlmVersion();\n }\n\n public readonly backupManager: BackupManager;\n public readonly crossSigningInfo: CrossSigningInfo;\n public readonly olmDevice: OlmDevice;\n public readonly deviceList: DeviceList;\n public readonly dehydrationManager: DehydrationManager;\n public readonly secretStorage: SecretStorage;\n\n private readonly reEmitter: TypedReEmitter;\n private readonly verificationMethods: Map;\n public readonly supportedAlgorithms: string[];\n private readonly outgoingRoomKeyRequestManager: OutgoingRoomKeyRequestManager;\n private readonly toDeviceVerificationRequests: ToDeviceRequests;\n public readonly inRoomVerificationRequests: InRoomRequests;\n\n private trustCrossSignedDevices = true;\n // the last time we did a check for the number of one-time-keys on the server.\n private lastOneTimeKeyCheck: number | null = null;\n private oneTimeKeyCheckInProgress = false;\n\n // EncryptionAlgorithm instance for each room\n private roomEncryptors = new Map();\n // map from algorithm to DecryptionAlgorithm instance, for each room\n private roomDecryptors = new Map>();\n\n private deviceKeys: Record = {}; // type: key\n\n public globalBlacklistUnverifiedDevices = false;\n public globalErrorOnUnknownDevices = true;\n\n // list of IncomingRoomKeyRequests/IncomingRoomKeyRequestCancellations\n // we received in the current sync.\n private receivedRoomKeyRequests: IncomingRoomKeyRequest[] = [];\n private receivedRoomKeyRequestCancellations: IncomingRoomKeyRequestCancellation[] = [];\n // true if we are currently processing received room key requests\n private processingRoomKeyRequests = false;\n // controls whether device tracking is delayed\n // until calling encryptEvent or trackRoomDevices,\n // or done immediately upon enabling room encryption.\n private lazyLoadMembers = false;\n // in case lazyLoadMembers is true,\n // track if an initial tracking of all the room members\n // has happened for a given room. This is delayed\n // to avoid loading room members as long as possible.\n private roomDeviceTrackingState: { [roomId: string]: Promise } = {};\n\n // The timestamp of the last time we forced establishment\n // of a new session for each device, in milliseconds.\n // {\n // userId: {\n // deviceId: 1234567890000,\n // },\n // }\n // Map: user Id → device Id → timestamp\n private lastNewSessionForced: MapWithDefault> = new MapWithDefault(\n () => new MapWithDefault(() => 0),\n );\n\n // This flag will be unset whilst the client processes a sync response\n // so that we don't start requesting keys until we've actually finished\n // processing the response.\n private sendKeyRequestsImmediately = false;\n\n private oneTimeKeyCount?: number;\n private needsNewFallback?: boolean;\n private fallbackCleanup?: ReturnType;\n\n /**\n * Cryptography bits\n *\n * This module is internal to the js-sdk; the public API is via MatrixClient.\n *\n * @internal\n *\n * @param baseApis - base matrix api interface\n *\n * @param userId - The user ID for the local user\n *\n * @param deviceId - The identifier for this device.\n *\n * @param clientStore - the MatrixClient data store.\n *\n * @param cryptoStore - storage for the crypto layer.\n *\n * @param roomList - An initialised RoomList object\n *\n * @param verificationMethods - Array of verification methods to use.\n * Each element can either be a string from MatrixClient.verificationMethods\n * or a class that implements a verification method.\n */\n public constructor(\n public readonly baseApis: MatrixClient,\n public readonly userId: string,\n private readonly deviceId: string,\n private readonly clientStore: IStore,\n public readonly cryptoStore: CryptoStore,\n private readonly roomList: RoomList,\n verificationMethods: Array,\n ) {\n super();\n this.reEmitter = new TypedReEmitter(this);\n\n if (verificationMethods) {\n this.verificationMethods = new Map();\n for (const method of verificationMethods) {\n if (typeof method === \"string\") {\n if (defaultVerificationMethods[method]) {\n this.verificationMethods.set(\n method,\n defaultVerificationMethods[method],\n );\n }\n } else if (method[\"NAME\"]) {\n this.verificationMethods.set(method[\"NAME\"], method as typeof VerificationBase);\n } else {\n logger.warn(`Excluding unknown verification method ${method}`);\n }\n }\n } else {\n this.verificationMethods = new Map(Object.entries(defaultVerificationMethods)) as Map<\n VerificationMethod,\n typeof VerificationBase\n >;\n }\n\n this.backupManager = new BackupManager(baseApis, async () => {\n // try to get key from cache\n const cachedKey = await this.getSessionBackupPrivateKey();\n if (cachedKey) {\n return cachedKey;\n }\n\n // try to get key from secret storage\n const storedKey = await this.getSecret(\"m.megolm_backup.v1\");\n\n if (storedKey) {\n // ensure that the key is in the right format. If not, fix the key and\n // store the fixed version\n const fixedKey = fixBackupKey(storedKey);\n if (fixedKey) {\n const keys = await this.getSecretStorageKey();\n await this.storeSecret(\"m.megolm_backup.v1\", fixedKey, [keys![0]]);\n }\n\n return olmlib.decodeBase64(fixedKey || storedKey);\n }\n\n // try to get key from app\n if (this.baseApis.cryptoCallbacks && this.baseApis.cryptoCallbacks.getBackupKey) {\n return this.baseApis.cryptoCallbacks.getBackupKey();\n }\n\n throw new Error(\"Unable to get private key\");\n });\n\n this.olmDevice = new OlmDevice(cryptoStore);\n this.deviceList = new DeviceList(baseApis, cryptoStore, this.olmDevice);\n\n // XXX: This isn't removed at any point, but then none of the event listeners\n // this class sets seem to be removed at any point... :/\n this.deviceList.on(CryptoEvent.UserCrossSigningUpdated, this.onDeviceListUserCrossSigningUpdated);\n this.reEmitter.reEmit(this.deviceList, [CryptoEvent.DevicesUpdated, CryptoEvent.WillUpdateDevices]);\n\n this.supportedAlgorithms = Array.from(algorithms.DECRYPTION_CLASSES.keys());\n\n this.outgoingRoomKeyRequestManager = new OutgoingRoomKeyRequestManager(\n baseApis,\n this.deviceId,\n this.cryptoStore,\n );\n\n this.toDeviceVerificationRequests = new ToDeviceRequests();\n this.inRoomVerificationRequests = new InRoomRequests();\n\n const cryptoCallbacks = this.baseApis.cryptoCallbacks || {};\n const cacheCallbacks = createCryptoStoreCacheCallbacks(cryptoStore, this.olmDevice);\n\n this.crossSigningInfo = new CrossSigningInfo(userId, cryptoCallbacks, cacheCallbacks);\n // Yes, we pass the client twice here: see SecretStorage\n this.secretStorage = new SecretStorage(baseApis as IAccountDataClient, cryptoCallbacks, baseApis);\n this.dehydrationManager = new DehydrationManager(this);\n\n // Assuming no app-supplied callback, default to getting from SSSS.\n if (!cryptoCallbacks.getCrossSigningKey && cryptoCallbacks.getSecretStorageKey) {\n cryptoCallbacks.getCrossSigningKey = async (type): Promise => {\n return CrossSigningInfo.getFromSecretStorage(type, this.secretStorage);\n };\n }\n }\n\n /**\n * Initialise the crypto module so that it is ready for use\n *\n * Returns a promise which resolves once the crypto module is ready for use.\n *\n * @param exportedOlmDevice - (Optional) data from exported device\n * that must be re-created.\n */\n public async init({ exportedOlmDevice, pickleKey }: IInitOpts = {}): Promise {\n logger.log(\"Crypto: initialising Olm...\");\n await global.Olm.init();\n logger.log(\n exportedOlmDevice\n ? \"Crypto: initialising Olm device from exported device...\"\n : \"Crypto: initialising Olm device...\",\n );\n await this.olmDevice.init({ fromExportedDevice: exportedOlmDevice, pickleKey });\n logger.log(\"Crypto: loading device list...\");\n await this.deviceList.load();\n\n // build our device keys: these will later be uploaded\n this.deviceKeys[\"ed25519:\" + this.deviceId] = this.olmDevice.deviceEd25519Key!;\n this.deviceKeys[\"curve25519:\" + this.deviceId] = this.olmDevice.deviceCurve25519Key!;\n\n logger.log(\"Crypto: fetching own devices...\");\n let myDevices = this.deviceList.getRawStoredDevicesForUser(this.userId);\n\n if (!myDevices) {\n myDevices = {};\n }\n\n if (!myDevices[this.deviceId]) {\n // add our own deviceinfo to the cryptoStore\n logger.log(\"Crypto: adding this device to the store...\");\n const deviceInfo = {\n keys: this.deviceKeys,\n algorithms: this.supportedAlgorithms,\n verified: DeviceVerification.VERIFIED,\n known: true,\n };\n\n myDevices[this.deviceId] = deviceInfo;\n this.deviceList.storeDevicesForUser(this.userId, myDevices);\n this.deviceList.saveIfDirty();\n }\n\n await this.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.cryptoStore.getCrossSigningKeys(txn, (keys) => {\n // can be an empty object after resetting cross-signing keys, see storeTrustedSelfKeys\n if (keys && Object.keys(keys).length !== 0) {\n logger.log(\"Loaded cross-signing public keys from crypto store\");\n this.crossSigningInfo.setKeys(keys);\n }\n });\n });\n // make sure we are keeping track of our own devices\n // (this is important for key backups & things)\n this.deviceList.startTrackingDeviceList(this.userId);\n\n logger.log(\"Crypto: checking for key backup...\");\n this.backupManager.checkAndStart();\n }\n\n /**\n * Whether to trust a others users signatures of their devices.\n * If false, devices will only be considered 'verified' if we have\n * verified that device individually (effectively disabling cross-signing).\n *\n * Default: true\n *\n * @returns True if trusting cross-signed devices\n */\n public getCryptoTrustCrossSignedDevices(): boolean {\n return this.trustCrossSignedDevices;\n }\n\n /**\n * See getCryptoTrustCrossSignedDevices\n\n * This may be set before initCrypto() is called to ensure no races occur.\n *\n * @param val - True to trust cross-signed devices\n */\n public setCryptoTrustCrossSignedDevices(val: boolean): void {\n this.trustCrossSignedDevices = val;\n\n for (const userId of this.deviceList.getKnownUserIds()) {\n const devices = this.deviceList.getRawStoredDevicesForUser(userId);\n for (const deviceId of Object.keys(devices)) {\n const deviceTrust = this.checkDeviceTrust(userId, deviceId);\n // If the device is locally verified then isVerified() is always true,\n // so this will only have caused the value to change if the device is\n // cross-signing verified but not locally verified\n if (!deviceTrust.isLocallyVerified() && deviceTrust.isCrossSigningVerified()) {\n const deviceObj = this.deviceList.getStoredDevice(userId, deviceId)!;\n this.emit(CryptoEvent.DeviceVerificationChanged, userId, deviceId, deviceObj);\n }\n }\n }\n }\n\n /**\n * Create a recovery key from a user-supplied passphrase.\n *\n * @param password - Passphrase string that can be entered by the user\n * when restoring the backup as an alternative to entering the recovery key.\n * Optional.\n * @returns Object with public key metadata, encoded private\n * recovery key which should be disposed of after displaying to the user,\n * and raw private key to avoid round tripping if needed.\n */\n public async createRecoveryKeyFromPassphrase(password?: string): Promise {\n const decryption = new global.Olm.PkDecryption();\n try {\n const keyInfo: Partial = {};\n if (password) {\n const derivation = await keyFromPassphrase(password);\n keyInfo.passphrase = {\n algorithm: \"m.pbkdf2\",\n iterations: derivation.iterations,\n salt: derivation.salt,\n };\n keyInfo.pubkey = decryption.init_with_private_key(derivation.key);\n } else {\n keyInfo.pubkey = decryption.generate_key();\n }\n const privateKey = decryption.get_private_key();\n const encodedPrivateKey = encodeRecoveryKey(privateKey);\n return {\n keyInfo: keyInfo as IRecoveryKey[\"keyInfo\"],\n encodedPrivateKey,\n privateKey,\n };\n } finally {\n decryption?.free();\n }\n }\n\n /**\n * Checks if the user has previously published cross-signing keys\n *\n * This means downloading the devicelist for the user and checking if the list includes\n * the cross-signing pseudo-device.\n *\n * @internal\n */\n public async userHasCrossSigningKeys(): Promise {\n await this.downloadKeys([this.userId]);\n return this.deviceList.getStoredCrossSigningForUser(this.userId) !== null;\n }\n\n /**\n * Checks whether cross signing:\n * - is enabled on this account and trusted by this device\n * - has private keys either cached locally or stored in secret storage\n *\n * If this function returns false, bootstrapCrossSigning() can be used\n * to fix things such that it returns true. That is to say, after\n * bootstrapCrossSigning() completes successfully, this function should\n * return true.\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @returns True if cross-signing is ready to be used on this device\n */\n public async isCrossSigningReady(): Promise {\n const publicKeysOnDevice = this.crossSigningInfo.getId();\n const privateKeysExistSomewhere =\n (await this.crossSigningInfo.isStoredInKeyCache()) ||\n (await this.crossSigningInfo.isStoredInSecretStorage(this.secretStorage));\n\n return !!(publicKeysOnDevice && privateKeysExistSomewhere);\n }\n\n /**\n * Checks whether secret storage:\n * - is enabled on this account\n * - is storing cross-signing private keys\n * - is storing session backup key (if enabled)\n *\n * If this function returns false, bootstrapSecretStorage() can be used\n * to fix things such that it returns true. That is to say, after\n * bootstrapSecretStorage() completes successfully, this function should\n * return true.\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @returns True if secret storage is ready to be used on this device\n */\n public async isSecretStorageReady(): Promise {\n const secretStorageKeyInAccount = await this.secretStorage.hasKey();\n const privateKeysInStorage = await this.crossSigningInfo.isStoredInSecretStorage(this.secretStorage);\n const sessionBackupInStorage =\n !this.backupManager.getKeyBackupEnabled() || (await this.baseApis.isKeyBackupKeyStored());\n\n return !!(secretStorageKeyInAccount && privateKeysInStorage && sessionBackupInStorage);\n }\n\n /**\n * Bootstrap cross-signing by creating keys if needed. If everything is already\n * set up, then no changes are made, so this is safe to run to ensure\n * cross-signing is ready for use.\n *\n * This function:\n * - creates new cross-signing keys if they are not found locally cached nor in\n * secret storage (if it has been setup)\n *\n * The cross-signing API is currently UNSTABLE and may change without notice.\n *\n * @param authUploadDeviceSigningKeys - Function\n * called to await an interactive auth flow when uploading device signing keys.\n * @param setupNewCrossSigning - Optional. Reset even if keys\n * already exist.\n * Args:\n * A function that makes the request requiring auth. Receives the\n * auth data as an object. Can be called multiple times, first with an empty\n * authDict, to obtain the flows.\n */\n public async bootstrapCrossSigning({\n authUploadDeviceSigningKeys,\n setupNewCrossSigning,\n }: IBootstrapCrossSigningOpts = {}): Promise {\n logger.log(\"Bootstrapping cross-signing\");\n\n const delegateCryptoCallbacks = this.baseApis.cryptoCallbacks;\n const builder = new EncryptionSetupBuilder(this.baseApis.store.accountData, delegateCryptoCallbacks);\n const crossSigningInfo = new CrossSigningInfo(\n this.userId,\n builder.crossSigningCallbacks,\n builder.crossSigningCallbacks,\n );\n\n // Reset the cross-signing keys\n const resetCrossSigning = async (): Promise => {\n crossSigningInfo.resetKeys();\n // Sign master key with device key\n await this.signObject(crossSigningInfo.keys.master);\n\n // Store auth flow helper function, as we need to call it when uploading\n // to ensure we handle auth errors properly.\n builder.addCrossSigningKeys(authUploadDeviceSigningKeys, crossSigningInfo.keys);\n\n // Cross-sign own device\n const device = this.deviceList.getStoredDevice(this.userId, this.deviceId)!;\n const deviceSignature = await crossSigningInfo.signDevice(this.userId, device);\n builder.addKeySignature(this.userId, this.deviceId, deviceSignature!);\n\n // Sign message key backup with cross-signing master key\n if (this.backupManager.backupInfo) {\n await crossSigningInfo.signObject(this.backupManager.backupInfo.auth_data, \"master\");\n builder.addSessionBackup(this.backupManager.backupInfo);\n }\n };\n\n const publicKeysOnDevice = this.crossSigningInfo.getId();\n const privateKeysInCache = await this.crossSigningInfo.isStoredInKeyCache();\n const privateKeysInStorage = await this.crossSigningInfo.isStoredInSecretStorage(this.secretStorage);\n const privateKeysExistSomewhere = privateKeysInCache || privateKeysInStorage;\n\n // Log all relevant state for easier parsing of debug logs.\n logger.log({\n setupNewCrossSigning,\n publicKeysOnDevice,\n privateKeysInCache,\n privateKeysInStorage,\n privateKeysExistSomewhere,\n });\n\n if (!privateKeysExistSomewhere || setupNewCrossSigning) {\n logger.log(\"Cross-signing private keys not found locally or in secret storage, \" + \"creating new keys\");\n // If a user has multiple devices, it important to only call bootstrap\n // as part of some UI flow (and not silently during startup), as they\n // may have setup cross-signing on a platform which has not saved keys\n // to secret storage, and this would reset them. In such a case, you\n // should prompt the user to verify any existing devices first (and\n // request private keys from those devices) before calling bootstrap.\n await resetCrossSigning();\n } else if (publicKeysOnDevice && privateKeysInCache) {\n logger.log(\"Cross-signing public keys trusted and private keys found locally\");\n } else if (privateKeysInStorage) {\n logger.log(\n \"Cross-signing private keys not found locally, but they are available \" +\n \"in secret storage, reading storage and caching locally\",\n );\n await this.checkOwnCrossSigningTrust({\n allowPrivateKeyRequests: true,\n });\n }\n\n // Assuming no app-supplied callback, default to storing new private keys in\n // secret storage if it exists. If it does not, it is assumed this will be\n // done as part of setting up secret storage later.\n const crossSigningPrivateKeys = builder.crossSigningCallbacks.privateKeys;\n if (crossSigningPrivateKeys.size && !this.baseApis.cryptoCallbacks.saveCrossSigningKeys) {\n const secretStorage = new SecretStorage(\n builder.accountDataClientAdapter,\n builder.ssssCryptoCallbacks,\n undefined,\n );\n if (await secretStorage.hasKey()) {\n logger.log(\"Storing new cross-signing private keys in secret storage\");\n // This is writing to in-memory account data in\n // builder.accountDataClientAdapter so won't fail\n await CrossSigningInfo.storeInSecretStorage(crossSigningPrivateKeys, secretStorage);\n }\n }\n\n const operation = builder.buildOperation();\n await operation.apply(this);\n // This persists private keys and public keys as trusted,\n // only do this if apply succeeded for now as retry isn't in place yet\n await builder.persist(this);\n\n logger.log(\"Cross-signing ready\");\n }\n\n /**\n * Bootstrap Secure Secret Storage if needed by creating a default key. If everything is\n * already set up, then no changes are made, so this is safe to run to ensure secret\n * storage is ready for use.\n *\n * This function\n * - creates a new Secure Secret Storage key if no default key exists\n * - if a key backup exists, it is migrated to store the key in the Secret\n * Storage\n * - creates a backup if none exists, and one is requested\n * - migrates Secure Secret Storage to use the latest algorithm, if an outdated\n * algorithm is found\n *\n * The Secure Secret Storage API is currently UNSTABLE and may change without notice.\n *\n * @param createSecretStorageKey - Optional. Function\n * called to await a secret storage key creation flow.\n * Returns a Promise which resolves to an object with public key metadata, encoded private\n * recovery key which should be disposed of after displaying to the user,\n * and raw private key to avoid round tripping if needed.\n * @param keyBackupInfo - The current key backup object. If passed,\n * the passphrase and recovery key from this backup will be used.\n * @param setupNewKeyBackup - If true, a new key backup version will be\n * created and the private key stored in the new SSSS store. Ignored if keyBackupInfo\n * is supplied.\n * @param setupNewSecretStorage - Optional. Reset even if keys already exist.\n * @param getKeyBackupPassphrase - Optional. Function called to get the user's\n * current key backup passphrase. Should return a promise that resolves with a Buffer\n * containing the key, or rejects if the key cannot be obtained.\n * Returns:\n * A promise which resolves to key creation data for\n * SecretStorage#addKey: an object with `passphrase` etc fields.\n */\n // TODO this does not resolve with what it says it does\n public async bootstrapSecretStorage({\n createSecretStorageKey = async (): Promise => ({} as IRecoveryKey),\n keyBackupInfo,\n setupNewKeyBackup,\n setupNewSecretStorage,\n getKeyBackupPassphrase,\n }: ICreateSecretStorageOpts = {}): Promise {\n logger.log(\"Bootstrapping Secure Secret Storage\");\n const delegateCryptoCallbacks = this.baseApis.cryptoCallbacks;\n const builder = new EncryptionSetupBuilder(this.baseApis.store.accountData, delegateCryptoCallbacks);\n const secretStorage = new SecretStorage(\n builder.accountDataClientAdapter,\n builder.ssssCryptoCallbacks,\n undefined,\n );\n\n // the ID of the new SSSS key, if we create one\n let newKeyId: string | null = null;\n\n // create a new SSSS key and set it as default\n const createSSSS = async (opts: IAddSecretStorageKeyOpts, privateKey?: Uint8Array): Promise => {\n if (privateKey) {\n opts.key = privateKey;\n }\n\n const { keyId, keyInfo } = await secretStorage.addKey(SECRET_STORAGE_ALGORITHM_V1_AES, opts);\n\n if (privateKey) {\n // make the private key available to encrypt 4S secrets\n builder.ssssCryptoCallbacks.addPrivateKey(keyId, keyInfo, privateKey);\n }\n\n await secretStorage.setDefaultKeyId(keyId);\n return keyId;\n };\n\n const ensureCanCheckPassphrase = async (keyId: string, keyInfo: SecretStorageKeyDescription): Promise => {\n if (!keyInfo.mac) {\n const key = await this.baseApis.cryptoCallbacks.getSecretStorageKey?.(\n { keys: { [keyId]: keyInfo } },\n \"\",\n );\n if (key) {\n const privateKey = key[1];\n builder.ssssCryptoCallbacks.addPrivateKey(keyId, keyInfo, privateKey);\n const { iv, mac } = await calculateKeyCheck(privateKey);\n keyInfo.iv = iv;\n keyInfo.mac = mac;\n\n await builder.setAccountData(`m.secret_storage.key.${keyId}`, keyInfo);\n }\n }\n };\n\n const signKeyBackupWithCrossSigning = async (keyBackupAuthData: IKeyBackupInfo[\"auth_data\"]): Promise => {\n if (this.crossSigningInfo.getId() && (await this.crossSigningInfo.isStoredInKeyCache(\"master\"))) {\n try {\n logger.log(\"Adding cross-signing signature to key backup\");\n await this.crossSigningInfo.signObject(keyBackupAuthData, \"master\");\n } catch (e) {\n // This step is not critical (just helpful), so we catch here\n // and continue if it fails.\n logger.error(\"Signing key backup with cross-signing keys failed\", e);\n }\n } else {\n logger.warn(\"Cross-signing keys not available, skipping signature on key backup\");\n }\n };\n\n const oldSSSSKey = await this.getSecretStorageKey();\n const [oldKeyId, oldKeyInfo] = oldSSSSKey || [null, null];\n const storageExists =\n !setupNewSecretStorage && oldKeyInfo && oldKeyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES;\n\n // Log all relevant state for easier parsing of debug logs.\n logger.log({\n keyBackupInfo,\n setupNewKeyBackup,\n setupNewSecretStorage,\n storageExists,\n oldKeyInfo,\n });\n\n if (!storageExists && !keyBackupInfo) {\n // either we don't have anything, or we've been asked to restart\n // from scratch\n logger.log(\"Secret storage does not exist, creating new storage key\");\n\n // if we already have a usable default SSSS key and aren't resetting\n // SSSS just use it. otherwise, create a new one\n // Note: we leave the old SSSS key in place: there could be other\n // secrets using it, in theory. We could move them to the new key but a)\n // that would mean we'd need to prompt for the old passphrase, and b)\n // it's not clear that would be the right thing to do anyway.\n const { keyInfo = {} as IAddSecretStorageKeyOpts, privateKey } = await createSecretStorageKey();\n newKeyId = await createSSSS(keyInfo, privateKey);\n } else if (!storageExists && keyBackupInfo) {\n // we have an existing backup, but no SSSS\n logger.log(\"Secret storage does not exist, using key backup key\");\n\n // if we have the backup key already cached, use it; otherwise use the\n // callback to prompt for the key\n const backupKey = (await this.getSessionBackupPrivateKey()) || (await getKeyBackupPassphrase?.());\n\n // create a new SSSS key and use the backup key as the new SSSS key\n const opts = {} as IAddSecretStorageKeyOpts;\n\n if (keyBackupInfo.auth_data.private_key_salt && keyBackupInfo.auth_data.private_key_iterations) {\n // FIXME: ???\n opts.passphrase = {\n algorithm: \"m.pbkdf2\",\n iterations: keyBackupInfo.auth_data.private_key_iterations,\n salt: keyBackupInfo.auth_data.private_key_salt,\n bits: 256,\n };\n }\n\n newKeyId = await createSSSS(opts, backupKey);\n\n // store the backup key in secret storage\n await secretStorage.store(\"m.megolm_backup.v1\", olmlib.encodeBase64(backupKey!), [newKeyId]);\n\n // The backup is trusted because the user provided the private key.\n // Sign the backup with the cross-signing key so the key backup can\n // be trusted via cross-signing.\n await signKeyBackupWithCrossSigning(keyBackupInfo.auth_data);\n\n builder.addSessionBackup(keyBackupInfo);\n } else {\n // 4S is already set up\n logger.log(\"Secret storage exists\");\n\n if (oldKeyInfo && oldKeyInfo.algorithm === SECRET_STORAGE_ALGORITHM_V1_AES) {\n // make sure that the default key has the information needed to\n // check the passphrase\n await ensureCanCheckPassphrase(oldKeyId, oldKeyInfo);\n }\n }\n\n // If we have cross-signing private keys cached, store them in secret\n // storage if they are not there already.\n if (\n !this.baseApis.cryptoCallbacks.saveCrossSigningKeys &&\n (await this.isCrossSigningReady()) &&\n (newKeyId || !(await this.crossSigningInfo.isStoredInSecretStorage(secretStorage)))\n ) {\n logger.log(\"Copying cross-signing private keys from cache to secret storage\");\n const crossSigningPrivateKeys = await this.crossSigningInfo.getCrossSigningKeysFromCache();\n // This is writing to in-memory account data in\n // builder.accountDataClientAdapter so won't fail\n await CrossSigningInfo.storeInSecretStorage(crossSigningPrivateKeys, secretStorage);\n }\n\n if (setupNewKeyBackup && !keyBackupInfo) {\n logger.log(\"Creating new message key backup version\");\n const info = await this.baseApis.prepareKeyBackupVersion(\n null /* random key */,\n // don't write to secret storage, as it will write to this.secretStorage.\n // Here, we want to capture all the side-effects of bootstrapping,\n // and want to write to the local secretStorage object\n { secureSecretStorage: false },\n );\n // write the key ourselves to 4S\n const privateKey = decodeRecoveryKey(info.recovery_key);\n await secretStorage.store(\"m.megolm_backup.v1\", olmlib.encodeBase64(privateKey));\n\n // create keyBackupInfo object to add to builder\n const data: IKeyBackupInfo = {\n algorithm: info.algorithm,\n auth_data: info.auth_data,\n };\n\n // Sign with cross-signing master key\n await signKeyBackupWithCrossSigning(data.auth_data);\n\n // sign with the device fingerprint\n await this.signObject(data.auth_data);\n\n builder.addSessionBackup(data);\n }\n\n // Cache the session backup key\n const sessionBackupKey = await secretStorage.get(\"m.megolm_backup.v1\");\n if (sessionBackupKey) {\n logger.info(\"Got session backup key from secret storage: caching\");\n // fix up the backup key if it's in the wrong format, and replace\n // in secret storage\n const fixedBackupKey = fixBackupKey(sessionBackupKey);\n if (fixedBackupKey) {\n const keyId = newKeyId || oldKeyId;\n await secretStorage.store(\"m.megolm_backup.v1\", fixedBackupKey, keyId ? [keyId] : null);\n }\n const decodedBackupKey = new Uint8Array(olmlib.decodeBase64(fixedBackupKey || sessionBackupKey));\n builder.addSessionBackupPrivateKeyToCache(decodedBackupKey);\n } else if (this.backupManager.getKeyBackupEnabled()) {\n // key backup is enabled but we don't have a session backup key in SSSS: see if we have one in\n // the cache or the user can provide one, and if so, write it to SSSS\n const backupKey = (await this.getSessionBackupPrivateKey()) || (await getKeyBackupPassphrase?.());\n if (!backupKey) {\n // This will require user intervention to recover from since we don't have the key\n // backup key anywhere. The user should probably just set up a new key backup and\n // the key for the new backup will be stored. If we hit this scenario in the wild\n // with any frequency, we should do more than just log an error.\n logger.error(\"Key backup is enabled but couldn't get key backup key!\");\n return;\n }\n logger.info(\"Got session backup key from cache/user that wasn't in SSSS: saving to SSSS\");\n await secretStorage.store(\"m.megolm_backup.v1\", olmlib.encodeBase64(backupKey));\n }\n\n const operation = builder.buildOperation();\n await operation.apply(this);\n // this persists private keys and public keys as trusted,\n // only do this if apply succeeded for now as retry isn't in place yet\n await builder.persist(this);\n\n logger.log(\"Secure Secret Storage ready\");\n }\n\n public addSecretStorageKey(\n algorithm: string,\n opts: IAddSecretStorageKeyOpts,\n keyID?: string,\n ): Promise {\n return this.secretStorage.addKey(algorithm, opts, keyID);\n }\n\n public hasSecretStorageKey(keyID?: string): Promise {\n return this.secretStorage.hasKey(keyID);\n }\n\n public getSecretStorageKey(keyID?: string): Promise {\n return this.secretStorage.getKey(keyID);\n }\n\n public storeSecret(name: string, secret: string, keys?: string[]): Promise {\n return this.secretStorage.store(name, secret, keys);\n }\n\n public getSecret(name: string): Promise {\n return this.secretStorage.get(name);\n }\n\n public isSecretStored(name: string): Promise | null> {\n return this.secretStorage.isStored(name);\n }\n\n public requestSecret(name: string, devices: string[]): ISecretRequest {\n if (!devices) {\n devices = Object.keys(this.deviceList.getRawStoredDevicesForUser(this.userId));\n }\n return this.secretStorage.request(name, devices);\n }\n\n public getDefaultSecretStorageKeyId(): Promise {\n return this.secretStorage.getDefaultKeyId();\n }\n\n public setDefaultSecretStorageKeyId(k: string): Promise {\n return this.secretStorage.setDefaultKeyId(k);\n }\n\n public checkSecretStorageKey(key: Uint8Array, info: SecretStorageKeyDescription): Promise {\n return this.secretStorage.checkKey(key, info);\n }\n\n /**\n * Checks that a given secret storage private key matches a given public key.\n * This can be used by the getSecretStorageKey callback to verify that the\n * private key it is about to supply is the one that was requested.\n *\n * @param privateKey - The private key\n * @param expectedPublicKey - The public key\n * @returns true if the key matches, otherwise false\n */\n public checkSecretStoragePrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean {\n let decryption: PkDecryption | null = null;\n try {\n decryption = new global.Olm.PkDecryption();\n const gotPubkey = decryption.init_with_private_key(privateKey);\n // make sure it agrees with the given pubkey\n return gotPubkey === expectedPublicKey;\n } finally {\n decryption?.free();\n }\n }\n\n /**\n * Fetches the backup private key, if cached\n * @returns the key, if any, or null\n */\n public async getSessionBackupPrivateKey(): Promise {\n let key = await new Promise((resolve) => {\n // TODO types\n this.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.cryptoStore.getSecretStorePrivateKey(txn, resolve, \"m.megolm_backup.v1\");\n });\n });\n\n // make sure we have a Uint8Array, rather than a string\n if (key && typeof key === \"string\") {\n key = new Uint8Array(olmlib.decodeBase64(fixBackupKey(key) || key));\n await this.storeSessionBackupPrivateKey(key);\n }\n if (key && key.ciphertext) {\n const pickleKey = Buffer.from(this.olmDevice.pickleKey);\n const decrypted = await decryptAES(key, pickleKey, \"m.megolm_backup.v1\");\n key = olmlib.decodeBase64(decrypted);\n }\n return key;\n }\n\n /**\n * Stores the session backup key to the cache\n * @param key - the private key\n * @returns a promise so you can catch failures\n */\n public async storeSessionBackupPrivateKey(key: ArrayLike): Promise {\n if (!(key instanceof Uint8Array)) {\n // eslint-disable-next-line @typescript-eslint/no-base-to-string\n throw new Error(`storeSessionBackupPrivateKey expects Uint8Array, got ${key}`);\n }\n const pickleKey = Buffer.from(this.olmDevice.pickleKey);\n const encryptedKey = await encryptAES(olmlib.encodeBase64(key), pickleKey, \"m.megolm_backup.v1\");\n return this.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.cryptoStore.storeSecretStorePrivateKey(txn, \"m.megolm_backup.v1\", encryptedKey);\n });\n }\n\n /**\n * Checks that a given cross-signing private key matches a given public key.\n * This can be used by the getCrossSigningKey callback to verify that the\n * private key it is about to supply is the one that was requested.\n *\n * @param privateKey - The private key\n * @param expectedPublicKey - The public key\n * @returns true if the key matches, otherwise false\n */\n public checkCrossSigningPrivateKey(privateKey: Uint8Array, expectedPublicKey: string): boolean {\n let signing: PkSigning | null = null;\n try {\n signing = new global.Olm.PkSigning();\n const gotPubkey = signing.init_with_seed(privateKey);\n // make sure it agrees with the given pubkey\n return gotPubkey === expectedPublicKey;\n } finally {\n signing?.free();\n }\n }\n\n /**\n * Run various follow-up actions after cross-signing keys have changed locally\n * (either by resetting the keys for the account or by getting them from secret\n * storage), such as signing the current device, upgrading device\n * verifications, etc.\n */\n private async afterCrossSigningLocalKeyChange(): Promise {\n logger.info(\"Starting cross-signing key change post-processing\");\n\n // sign the current device with the new key, and upload to the server\n const device = this.deviceList.getStoredDevice(this.userId, this.deviceId)!;\n const signedDevice = await this.crossSigningInfo.signDevice(this.userId, device);\n logger.info(`Starting background key sig upload for ${this.deviceId}`);\n\n const upload = ({ shouldEmit = false }): Promise => {\n return this.baseApis\n .uploadKeySignatures({\n [this.userId]: {\n [this.deviceId]: signedDevice!,\n },\n })\n .then((response) => {\n const { failures } = response || {};\n if (Object.keys(failures || []).length > 0) {\n if (shouldEmit) {\n this.baseApis.emit(\n CryptoEvent.KeySignatureUploadFailure,\n failures,\n \"afterCrossSigningLocalKeyChange\",\n upload, // continuation\n );\n }\n throw new KeySignatureUploadError(\"Key upload failed\", { failures });\n }\n logger.info(`Finished background key sig upload for ${this.deviceId}`);\n })\n .catch((e) => {\n logger.error(`Error during background key sig upload for ${this.deviceId}`, e);\n });\n };\n upload({ shouldEmit: true });\n\n const shouldUpgradeCb = this.baseApis.cryptoCallbacks.shouldUpgradeDeviceVerifications;\n if (shouldUpgradeCb) {\n logger.info(\"Starting device verification upgrade\");\n\n // Check all users for signatures if upgrade callback present\n // FIXME: do this in batches\n const users: Record = {};\n for (const [userId, crossSigningInfo] of Object.entries(this.deviceList.crossSigningInfo)) {\n const upgradeInfo = await this.checkForDeviceVerificationUpgrade(\n userId,\n CrossSigningInfo.fromStorage(crossSigningInfo, userId),\n );\n if (upgradeInfo) {\n users[userId] = upgradeInfo;\n }\n }\n\n if (Object.keys(users).length > 0) {\n logger.info(`Found ${Object.keys(users).length} verif users to upgrade`);\n try {\n const usersToUpgrade = await shouldUpgradeCb({ users: users });\n if (usersToUpgrade) {\n for (const userId of usersToUpgrade) {\n if (userId in users) {\n await this.baseApis.setDeviceVerified(userId, users[userId].crossSigningInfo.getId()!);\n }\n }\n }\n } catch (e) {\n logger.log(\"shouldUpgradeDeviceVerifications threw an error: not upgrading\", e);\n }\n }\n\n logger.info(\"Finished device verification upgrade\");\n }\n\n logger.info(\"Finished cross-signing key change post-processing\");\n }\n\n /**\n * Check if a user's cross-signing key is a candidate for upgrading from device\n * verification.\n *\n * @param userId - the user whose cross-signing information is to be checked\n * @param crossSigningInfo - the cross-signing information to check\n */\n private async checkForDeviceVerificationUpgrade(\n userId: string,\n crossSigningInfo: CrossSigningInfo,\n ): Promise {\n // only upgrade if this is the first cross-signing key that we've seen for\n // them, and if their cross-signing key isn't already verified\n const trustLevel = this.crossSigningInfo.checkUserTrust(crossSigningInfo);\n if (crossSigningInfo.firstUse && !trustLevel.isVerified()) {\n const devices = this.deviceList.getRawStoredDevicesForUser(userId);\n const deviceIds = await this.checkForValidDeviceSignature(userId, crossSigningInfo.keys.master, devices);\n if (deviceIds.length) {\n return {\n devices: deviceIds.map((deviceId) => DeviceInfo.fromStorage(devices[deviceId], deviceId)),\n crossSigningInfo,\n };\n }\n }\n }\n\n /**\n * Check if the cross-signing key is signed by a verified device.\n *\n * @param userId - the user ID whose key is being checked\n * @param key - the key that is being checked\n * @param devices - the user's devices. Should be a map from device ID\n * to device info\n */\n private async checkForValidDeviceSignature(\n userId: string,\n key: ICrossSigningKey,\n devices: Record,\n ): Promise {\n const deviceIds: string[] = [];\n if (devices && key.signatures && key.signatures[userId]) {\n for (const signame of Object.keys(key.signatures[userId])) {\n const [, deviceId] = signame.split(\":\", 2);\n if (deviceId in devices && devices[deviceId].verified === DeviceVerification.VERIFIED) {\n try {\n await olmlib.verifySignature(\n this.olmDevice,\n key,\n userId,\n deviceId,\n devices[deviceId].keys[signame],\n );\n deviceIds.push(deviceId);\n } catch (e) {}\n }\n }\n }\n return deviceIds;\n }\n\n /**\n * Get the user's cross-signing key ID.\n *\n * @param type - The type of key to get the ID of. One of\n * \"master\", \"self_signing\", or \"user_signing\". Defaults to \"master\".\n *\n * @returns the key ID\n */\n public getCrossSigningId(type: string): string | null {\n return this.crossSigningInfo.getId(type);\n }\n\n /**\n * Get the cross signing information for a given user.\n *\n * @param userId - the user ID to get the cross-signing info for.\n *\n * @returns the cross signing information for the user.\n */\n public getStoredCrossSigningForUser(userId: string): CrossSigningInfo | null {\n return this.deviceList.getStoredCrossSigningForUser(userId);\n }\n\n /**\n * Check whether a given user is trusted.\n *\n * @param userId - The ID of the user to check.\n *\n * @returns\n */\n public checkUserTrust(userId: string): UserTrustLevel {\n const userCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId);\n if (!userCrossSigning) {\n return new UserTrustLevel(false, false, false);\n }\n return this.crossSigningInfo.checkUserTrust(userCrossSigning);\n }\n\n /**\n * Check whether a given device is trusted.\n *\n * @param userId - The ID of the user whose devices is to be checked.\n * @param deviceId - The ID of the device to check\n *\n * @returns\n */\n public checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel {\n const device = this.deviceList.getStoredDevice(userId, deviceId);\n return this.checkDeviceInfoTrust(userId, device);\n }\n\n /**\n * Check whether a given deviceinfo is trusted.\n *\n * @param userId - The ID of the user whose devices is to be checked.\n * @param device - The device info object to check\n *\n * @returns\n */\n public checkDeviceInfoTrust(userId: string, device?: DeviceInfo): DeviceTrustLevel {\n const trustedLocally = !!device?.isVerified();\n\n const userCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId);\n if (device && userCrossSigning) {\n // The trustCrossSignedDevices only affects trust of other people's cross-signing\n // signatures\n const trustCrossSig = this.trustCrossSignedDevices || userId === this.userId;\n return this.crossSigningInfo.checkDeviceTrust(userCrossSigning, device, trustedLocally, trustCrossSig);\n } else {\n return new DeviceTrustLevel(false, false, trustedLocally, false);\n }\n }\n\n /**\n * Check whether one of our own devices is cross-signed by our\n * user's stored keys, regardless of whether we trust those keys yet.\n *\n * @param deviceId - The ID of the device to check\n *\n * @returns true if the device is cross-signed\n */\n public checkIfOwnDeviceCrossSigned(deviceId: string): boolean {\n const device = this.deviceList.getStoredDevice(this.userId, deviceId);\n if (!device) return false;\n const userCrossSigning = this.deviceList.getStoredCrossSigningForUser(this.userId);\n return (\n userCrossSigning?.checkDeviceTrust(userCrossSigning, device, false, true).isCrossSigningVerified() ?? false\n );\n }\n\n /*\n * Event handler for DeviceList's userNewDevices event\n */\n private onDeviceListUserCrossSigningUpdated = async (userId: string): Promise => {\n if (userId === this.userId) {\n // An update to our own cross-signing key.\n // Get the new key first:\n const newCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId);\n const seenPubkey = newCrossSigning ? newCrossSigning.getId() : null;\n const currentPubkey = this.crossSigningInfo.getId();\n const changed = currentPubkey !== seenPubkey;\n\n if (currentPubkey && seenPubkey && !changed) {\n // If it's not changed, just make sure everything is up to date\n await this.checkOwnCrossSigningTrust();\n } else {\n // We'll now be in a state where cross-signing on the account is not trusted\n // because our locally stored cross-signing keys will not match the ones\n // on the server for our account. So we clear our own stored cross-signing keys,\n // effectively disabling cross-signing until the user gets verified by the device\n // that reset the keys\n this.storeTrustedSelfKeys(null);\n // emit cross-signing has been disabled\n this.emit(CryptoEvent.KeysChanged, {});\n // as the trust for our own user has changed,\n // also emit an event for this\n this.emit(CryptoEvent.UserTrustStatusChanged, this.userId, this.checkUserTrust(userId));\n }\n } else {\n await this.checkDeviceVerifications(userId);\n\n // Update verified before latch using the current state and save the new\n // latch value in the device list store.\n const crossSigning = this.deviceList.getStoredCrossSigningForUser(userId);\n if (crossSigning) {\n crossSigning.updateCrossSigningVerifiedBefore(this.checkUserTrust(userId).isCrossSigningVerified());\n this.deviceList.setRawStoredCrossSigningForUser(userId, crossSigning.toStorage());\n }\n\n this.emit(CryptoEvent.UserTrustStatusChanged, userId, this.checkUserTrust(userId));\n }\n };\n\n /**\n * Check the copy of our cross-signing key that we have in the device list and\n * see if we can get the private key. If so, mark it as trusted.\n */\n public async checkOwnCrossSigningTrust({\n allowPrivateKeyRequests = false,\n }: ICheckOwnCrossSigningTrustOpts = {}): Promise {\n const userId = this.userId;\n\n // Before proceeding, ensure our cross-signing public keys have been\n // downloaded via the device list.\n await this.downloadKeys([this.userId]);\n\n // Also check which private keys are locally cached.\n const crossSigningPrivateKeys = await this.crossSigningInfo.getCrossSigningKeysFromCache();\n\n // If we see an update to our own master key, check it against the master\n // key we have and, if it matches, mark it as verified\n\n // First, get the new cross-signing info\n const newCrossSigning = this.deviceList.getStoredCrossSigningForUser(userId);\n if (!newCrossSigning) {\n logger.error(\n \"Got cross-signing update event for user \" + userId + \" but no new cross-signing information found!\",\n );\n return;\n }\n\n const seenPubkey = newCrossSigning.getId()!;\n const masterChanged = this.crossSigningInfo.getId() !== seenPubkey;\n const masterExistsNotLocallyCached = newCrossSigning.getId() && !crossSigningPrivateKeys.has(\"master\");\n if (masterChanged) {\n logger.info(\"Got new master public key\", seenPubkey);\n }\n if (allowPrivateKeyRequests && (masterChanged || masterExistsNotLocallyCached)) {\n logger.info(\"Attempting to retrieve cross-signing master private key\");\n let signing: PkSigning | null = null;\n // It's important for control flow that we leave any errors alone for\n // higher levels to handle so that e.g. cancelling access properly\n // aborts any larger operation as well.\n try {\n const ret = await this.crossSigningInfo.getCrossSigningKey(\"master\", seenPubkey);\n signing = ret[1];\n logger.info(\"Got cross-signing master private key\");\n } finally {\n signing?.free();\n }\n }\n\n const oldSelfSigningId = this.crossSigningInfo.getId(\"self_signing\");\n const oldUserSigningId = this.crossSigningInfo.getId(\"user_signing\");\n\n // Update the version of our keys in our cross-signing object and the local store\n this.storeTrustedSelfKeys(newCrossSigning.keys);\n\n const selfSigningChanged = oldSelfSigningId !== newCrossSigning.getId(\"self_signing\");\n const userSigningChanged = oldUserSigningId !== newCrossSigning.getId(\"user_signing\");\n\n const selfSigningExistsNotLocallyCached =\n newCrossSigning.getId(\"self_signing\") && !crossSigningPrivateKeys.has(\"self_signing\");\n const userSigningExistsNotLocallyCached =\n newCrossSigning.getId(\"user_signing\") && !crossSigningPrivateKeys.has(\"user_signing\");\n\n const keySignatures: Record = {};\n\n if (selfSigningChanged) {\n logger.info(\"Got new self-signing key\", newCrossSigning.getId(\"self_signing\"));\n }\n if (allowPrivateKeyRequests && (selfSigningChanged || selfSigningExistsNotLocallyCached)) {\n logger.info(\"Attempting to retrieve cross-signing self-signing private key\");\n let signing: PkSigning | null = null;\n try {\n const ret = await this.crossSigningInfo.getCrossSigningKey(\n \"self_signing\",\n newCrossSigning.getId(\"self_signing\")!,\n );\n signing = ret[1];\n logger.info(\"Got cross-signing self-signing private key\");\n } finally {\n signing?.free();\n }\n\n const device = this.deviceList.getStoredDevice(this.userId, this.deviceId)!;\n const signedDevice = await this.crossSigningInfo.signDevice(this.userId, device);\n keySignatures[this.deviceId] = signedDevice!;\n }\n if (userSigningChanged) {\n logger.info(\"Got new user-signing key\", newCrossSigning.getId(\"user_signing\"));\n }\n if (allowPrivateKeyRequests && (userSigningChanged || userSigningExistsNotLocallyCached)) {\n logger.info(\"Attempting to retrieve cross-signing user-signing private key\");\n let signing: PkSigning | null = null;\n try {\n const ret = await this.crossSigningInfo.getCrossSigningKey(\n \"user_signing\",\n newCrossSigning.getId(\"user_signing\")!,\n );\n signing = ret[1];\n logger.info(\"Got cross-signing user-signing private key\");\n } finally {\n signing?.free();\n }\n }\n\n if (masterChanged) {\n const masterKey = this.crossSigningInfo.keys.master;\n await this.signObject(masterKey);\n const deviceSig = masterKey.signatures![this.userId][\"ed25519:\" + this.deviceId];\n // Include only the _new_ device signature in the upload.\n // We may have existing signatures from deleted devices, which will cause\n // the entire upload to fail.\n keySignatures[this.crossSigningInfo.getId()!] = Object.assign({} as ISignedKey, masterKey, {\n signatures: {\n [this.userId]: {\n [\"ed25519:\" + this.deviceId]: deviceSig,\n },\n },\n });\n }\n\n const keysToUpload = Object.keys(keySignatures);\n if (keysToUpload.length) {\n const upload = ({ shouldEmit = false }): Promise => {\n logger.info(`Starting background key sig upload for ${keysToUpload}`);\n return this.baseApis\n .uploadKeySignatures({ [this.userId]: keySignatures })\n .then((response) => {\n const { failures } = response || {};\n logger.info(`Finished background key sig upload for ${keysToUpload}`);\n if (Object.keys(failures || []).length > 0) {\n if (shouldEmit) {\n this.baseApis.emit(\n CryptoEvent.KeySignatureUploadFailure,\n failures,\n \"checkOwnCrossSigningTrust\",\n upload,\n );\n }\n throw new KeySignatureUploadError(\"Key upload failed\", { failures });\n }\n })\n .catch((e) => {\n logger.error(`Error during background key sig upload for ${keysToUpload}`, e);\n });\n };\n upload({ shouldEmit: true });\n }\n\n this.emit(CryptoEvent.UserTrustStatusChanged, userId, this.checkUserTrust(userId));\n\n if (masterChanged) {\n this.emit(CryptoEvent.KeysChanged, {});\n await this.afterCrossSigningLocalKeyChange();\n }\n\n // Now we may be able to trust our key backup\n await this.backupManager.checkKeyBackup();\n // FIXME: if we previously trusted the backup, should we automatically sign\n // the backup with the new key (if not already signed)?\n }\n\n /**\n * Store a set of keys as our own, trusted, cross-signing keys.\n *\n * @param keys - The new trusted set of keys\n */\n private async storeTrustedSelfKeys(keys: Record | null): Promise {\n if (keys) {\n this.crossSigningInfo.setKeys(keys);\n } else {\n this.crossSigningInfo.clearKeys();\n }\n await this.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n this.cryptoStore.storeCrossSigningKeys(txn, this.crossSigningInfo.keys);\n });\n }\n\n /**\n * Check if the master key is signed by a verified device, and if so, prompt\n * the application to mark it as verified.\n *\n * @param userId - the user ID whose key should be checked\n */\n private async checkDeviceVerifications(userId: string): Promise {\n const shouldUpgradeCb = this.baseApis.cryptoCallbacks.shouldUpgradeDeviceVerifications;\n if (!shouldUpgradeCb) {\n // Upgrading skipped when callback is not present.\n return;\n }\n logger.info(`Starting device verification upgrade for ${userId}`);\n if (this.crossSigningInfo.keys.user_signing) {\n const crossSigningInfo = this.deviceList.getStoredCrossSigningForUser(userId);\n if (crossSigningInfo) {\n const upgradeInfo = await this.checkForDeviceVerificationUpgrade(userId, crossSigningInfo);\n if (upgradeInfo) {\n const usersToUpgrade = await shouldUpgradeCb({\n users: {\n [userId]: upgradeInfo,\n },\n });\n if (usersToUpgrade.includes(userId)) {\n await this.baseApis.setDeviceVerified(userId, crossSigningInfo.getId()!);\n }\n }\n }\n }\n logger.info(`Finished device verification upgrade for ${userId}`);\n }\n\n /**\n */\n public enableLazyLoading(): void {\n this.lazyLoadMembers = true;\n }\n\n /**\n * Tell the crypto module to register for MatrixClient events which it needs to\n * listen for\n *\n * @param eventEmitter - event source where we can register\n * for event notifications\n */\n public registerEventHandlers(\n eventEmitter: TypedEventEmitter<\n RoomMemberEvent.Membership | ClientEvent.ToDeviceEvent | RoomEvent.Timeline | MatrixEventEvent.Decrypted,\n any\n >,\n ): void {\n eventEmitter.on(RoomMemberEvent.Membership, this.onMembership);\n eventEmitter.on(ClientEvent.ToDeviceEvent, this.onToDeviceEvent);\n eventEmitter.on(RoomEvent.Timeline, this.onTimelineEvent);\n eventEmitter.on(MatrixEventEvent.Decrypted, this.onTimelineEvent);\n }\n\n /**\n * @deprecated this does nothing and will be removed in a future version\n */\n public start(): void {\n logger.warn(\"MatrixClient.crypto.start() is deprecated\");\n }\n\n /** Stop background processes related to crypto */\n public stop(): void {\n this.outgoingRoomKeyRequestManager.stop();\n this.deviceList.stop();\n this.dehydrationManager.stop();\n }\n\n /**\n * Get the Ed25519 key for this device\n *\n * @returns base64-encoded ed25519 key.\n */\n public getDeviceEd25519Key(): string | null {\n return this.olmDevice.deviceEd25519Key;\n }\n\n /**\n * Get the Curve25519 key for this device\n *\n * @returns base64-encoded curve25519 key.\n */\n public getDeviceCurve25519Key(): string | null {\n return this.olmDevice.deviceCurve25519Key;\n }\n\n /**\n * Set the global override for whether the client should ever send encrypted\n * messages to unverified devices. This provides the default for rooms which\n * do not specify a value.\n *\n * @param value - whether to blacklist all unverified devices by default\n *\n * @deprecated For external code, use {@link MatrixClient#setGlobalBlacklistUnverifiedDevices}. For\n * internal code, set {@link MatrixClient#globalBlacklistUnverifiedDevices} directly.\n */\n public setGlobalBlacklistUnverifiedDevices(value: boolean): void {\n this.globalBlacklistUnverifiedDevices = value;\n }\n\n /**\n * @returns whether to blacklist all unverified devices by default\n *\n * @deprecated For external code, use {@link MatrixClient#getGlobalBlacklistUnverifiedDevices}. For\n * internal code, reference {@link MatrixClient#globalBlacklistUnverifiedDevices} directly.\n */\n public getGlobalBlacklistUnverifiedDevices(): boolean {\n return this.globalBlacklistUnverifiedDevices;\n }\n\n /**\n * Upload the device keys to the homeserver.\n * @returns A promise that will resolve when the keys are uploaded.\n */\n public uploadDeviceKeys(): Promise {\n const deviceKeys = {\n algorithms: this.supportedAlgorithms,\n device_id: this.deviceId,\n keys: this.deviceKeys,\n user_id: this.userId,\n };\n\n return this.signObject(deviceKeys).then(() => {\n return this.baseApis.uploadKeysRequest({\n device_keys: deviceKeys as Required,\n });\n });\n }\n\n /**\n * Stores the current one_time_key count which will be handled later (in a call of\n * onSyncCompleted). The count is e.g. coming from a /sync response.\n *\n * @param currentCount - The current count of one_time_keys to be stored\n */\n public updateOneTimeKeyCount(currentCount: number): void {\n if (isFinite(currentCount)) {\n this.oneTimeKeyCount = currentCount;\n } else {\n throw new TypeError(\"Parameter for updateOneTimeKeyCount has to be a number\");\n }\n }\n\n public setNeedsNewFallback(needsNewFallback: boolean): void {\n this.needsNewFallback = needsNewFallback;\n }\n\n public getNeedsNewFallback(): boolean {\n return !!this.needsNewFallback;\n }\n\n // check if it's time to upload one-time keys, and do so if so.\n private maybeUploadOneTimeKeys(): void {\n // frequency with which to check & upload one-time keys\n const uploadPeriod = 1000 * 60; // one minute\n\n // max number of keys to upload at once\n // Creating keys can be an expensive operation so we limit the\n // number we generate in one go to avoid blocking the application\n // for too long.\n const maxKeysPerCycle = 5;\n\n if (this.oneTimeKeyCheckInProgress) {\n return;\n }\n\n const now = Date.now();\n if (this.lastOneTimeKeyCheck !== null && now - this.lastOneTimeKeyCheck < uploadPeriod) {\n // we've done a key upload recently.\n return;\n }\n\n this.lastOneTimeKeyCheck = now;\n\n // We need to keep a pool of one time public keys on the server so that\n // other devices can start conversations with us. But we can only store\n // a finite number of private keys in the olm Account object.\n // To complicate things further then can be a delay between a device\n // claiming a public one time key from the server and it sending us a\n // message. We need to keep the corresponding private key locally until\n // we receive the message.\n // But that message might never arrive leaving us stuck with duff\n // private keys clogging up our local storage.\n // So we need some kind of engineering compromise to balance all of\n // these factors.\n\n // Check how many keys we can store in the Account object.\n const maxOneTimeKeys = this.olmDevice.maxNumberOfOneTimeKeys();\n // Try to keep at most half that number on the server. This leaves the\n // rest of the slots free to hold keys that have been claimed from the\n // server but we haven't received a message for.\n // If we run out of slots when generating new keys then olm will\n // discard the oldest private keys first. This will eventually clean\n // out stale private keys that won't receive a message.\n const keyLimit = Math.floor(maxOneTimeKeys / 2);\n\n const uploadLoop = async (keyCount: number): Promise => {\n while (keyLimit > keyCount || this.getNeedsNewFallback()) {\n // Ask olm to generate new one time keys, then upload them to synapse.\n if (keyLimit > keyCount) {\n logger.info(\"generating oneTimeKeys\");\n const keysThisLoop = Math.min(keyLimit - keyCount, maxKeysPerCycle);\n await this.olmDevice.generateOneTimeKeys(keysThisLoop);\n }\n\n if (this.getNeedsNewFallback()) {\n const fallbackKeys = await this.olmDevice.getFallbackKey();\n // if fallbackKeys is non-empty, we've already generated a\n // fallback key, but it hasn't been published yet, so we\n // can use that instead of generating a new one\n if (!fallbackKeys.curve25519 || Object.keys(fallbackKeys.curve25519).length == 0) {\n logger.info(\"generating fallback key\");\n if (this.fallbackCleanup) {\n // cancel any pending fallback cleanup because generating\n // a new fallback key will already drop the old fallback\n // that would have been dropped, and we don't want to kill\n // the current key\n clearTimeout(this.fallbackCleanup);\n delete this.fallbackCleanup;\n }\n await this.olmDevice.generateFallbackKey();\n }\n }\n\n logger.info(\"calling uploadOneTimeKeys\");\n const res = await this.uploadOneTimeKeys();\n if (res.one_time_key_counts && res.one_time_key_counts.signed_curve25519) {\n // if the response contains a more up to date value use this\n // for the next loop\n keyCount = res.one_time_key_counts.signed_curve25519;\n } else {\n throw new Error(\n \"response for uploading keys does not contain \" + \"one_time_key_counts.signed_curve25519\",\n );\n }\n }\n };\n\n this.oneTimeKeyCheckInProgress = true;\n Promise.resolve()\n .then(() => {\n if (this.oneTimeKeyCount !== undefined) {\n // We already have the current one_time_key count from a /sync response.\n // Use this value instead of asking the server for the current key count.\n return Promise.resolve(this.oneTimeKeyCount);\n }\n // ask the server how many keys we have\n return this.baseApis.uploadKeysRequest({}).then((res) => {\n return res.one_time_key_counts.signed_curve25519 || 0;\n });\n })\n .then((keyCount) => {\n // Start the uploadLoop with the current keyCount. The function checks if\n // we need to upload new keys or not.\n // If there are too many keys on the server then we don't need to\n // create any more keys.\n return uploadLoop(keyCount);\n })\n .catch((e) => {\n logger.error(\"Error uploading one-time keys\", e.stack || e);\n })\n .finally(() => {\n // reset oneTimeKeyCount to prevent start uploading based on old data.\n // it will be set again on the next /sync-response\n this.oneTimeKeyCount = undefined;\n this.oneTimeKeyCheckInProgress = false;\n });\n }\n\n // returns a promise which resolves to the response\n private async uploadOneTimeKeys(): Promise {\n const promises: Promise[] = [];\n\n let fallbackJson: Record | undefined;\n if (this.getNeedsNewFallback()) {\n fallbackJson = {};\n const fallbackKeys = await this.olmDevice.getFallbackKey();\n for (const [keyId, key] of Object.entries(fallbackKeys.curve25519)) {\n const k = { key, fallback: true };\n fallbackJson[\"signed_curve25519:\" + keyId] = k;\n promises.push(this.signObject(k));\n }\n this.setNeedsNewFallback(false);\n }\n\n const oneTimeKeys = await this.olmDevice.getOneTimeKeys();\n const oneTimeJson: Record = {};\n\n for (const keyId in oneTimeKeys.curve25519) {\n if (oneTimeKeys.curve25519.hasOwnProperty(keyId)) {\n const k = {\n key: oneTimeKeys.curve25519[keyId],\n };\n oneTimeJson[\"signed_curve25519:\" + keyId] = k;\n promises.push(this.signObject(k));\n }\n }\n\n await Promise.all(promises);\n\n const requestBody: Record = {\n one_time_keys: oneTimeJson,\n };\n\n if (fallbackJson) {\n requestBody[\"org.matrix.msc2732.fallback_keys\"] = fallbackJson;\n requestBody[\"fallback_keys\"] = fallbackJson;\n }\n\n const res = await this.baseApis.uploadKeysRequest(requestBody);\n\n if (fallbackJson) {\n this.fallbackCleanup = setTimeout(() => {\n delete this.fallbackCleanup;\n this.olmDevice.forgetOldFallbackKey();\n }, 60 * 60 * 1000);\n }\n\n await this.olmDevice.markKeysAsPublished();\n return res;\n }\n\n /**\n * Download the keys for a list of users and stores the keys in the session\n * store.\n * @param userIds - The users to fetch.\n * @param forceDownload - Always download the keys even if cached.\n *\n * @returns A promise which resolves to a map `userId->deviceId->{@link DeviceInfo}`.\n */\n public downloadKeys(userIds: string[], forceDownload?: boolean): Promise {\n return this.deviceList.downloadKeys(userIds, !!forceDownload);\n }\n\n /**\n * Get the stored device keys for a user id\n *\n * @param userId - the user to list keys for.\n *\n * @returns list of devices, or null if we haven't\n * managed to get a list of devices for this user yet.\n */\n public getStoredDevicesForUser(userId: string): Array | null {\n return this.deviceList.getStoredDevicesForUser(userId);\n }\n\n /**\n * Get the stored keys for a single device\n *\n *\n * @returns device, or undefined\n * if we don't know about this device\n */\n public getStoredDevice(userId: string, deviceId: string): DeviceInfo | undefined {\n return this.deviceList.getStoredDevice(userId, deviceId);\n }\n\n /**\n * Save the device list, if necessary\n *\n * @param delay - Time in ms before which the save actually happens.\n * By default, the save is delayed for a short period in order to batch\n * multiple writes, but this behaviour can be disabled by passing 0.\n *\n * @returns true if the data was saved, false if\n * it was not (eg. because no changes were pending). The promise\n * will only resolve once the data is saved, so may take some time\n * to resolve.\n */\n public saveDeviceList(delay: number): Promise {\n return this.deviceList.saveIfDirty(delay);\n }\n\n /**\n * Update the blocked/verified state of the given device\n *\n * @param userId - owner of the device\n * @param deviceId - unique identifier for the device or user's\n * cross-signing public key ID.\n *\n * @param verified - whether to mark the device as verified. Null to\n * leave unchanged.\n *\n * @param blocked - whether to mark the device as blocked. Null to\n * leave unchanged.\n *\n * @param known - whether to mark that the user has been made aware of\n * the existence of this device. Null to leave unchanged\n *\n * @param keys - The list of keys that was present\n * during the device verification. This will be double checked with the list\n * of keys the given device has currently.\n *\n * @returns updated DeviceInfo\n */\n public async setDeviceVerification(\n userId: string,\n deviceId: string,\n verified: boolean | null = null,\n blocked: boolean | null = null,\n known: boolean | null = null,\n keys?: Record,\n ): Promise {\n // Check if the 'device' is actually a cross signing key\n // The js-sdk's verification treats cross-signing keys as devices\n // and so uses this method to mark them verified.\n const xsk = this.deviceList.getStoredCrossSigningForUser(userId);\n if (xsk && xsk.getId() === deviceId) {\n if (blocked !== null || known !== null) {\n throw new Error(\"Cannot set blocked or known for a cross-signing key\");\n }\n if (!verified) {\n throw new Error(\"Cannot set a cross-signing key as unverified\");\n }\n const gotKeyId = keys ? Object.values(keys)[0] : null;\n if (keys && (Object.values(keys).length !== 1 || gotKeyId !== xsk.getId())) {\n throw new Error(`Key did not match expected value: expected ${xsk.getId()}, got ${gotKeyId}`);\n }\n\n if (!this.crossSigningInfo.getId() && userId === this.crossSigningInfo.userId) {\n this.storeTrustedSelfKeys(xsk.keys);\n // This will cause our own user trust to change, so emit the event\n this.emit(CryptoEvent.UserTrustStatusChanged, this.userId, this.checkUserTrust(userId));\n }\n\n // Now sign the master key with our user signing key (unless it's ourself)\n if (userId !== this.userId) {\n logger.info(\"Master key \" + xsk.getId() + \" for \" + userId + \" marked verified. Signing...\");\n const device = await this.crossSigningInfo.signUser(xsk);\n if (device) {\n const upload = async ({ shouldEmit = false }): Promise => {\n logger.info(\"Uploading signature for \" + userId + \"...\");\n const response = await this.baseApis.uploadKeySignatures({\n [userId]: {\n [deviceId]: device,\n },\n });\n const { failures } = response || {};\n if (Object.keys(failures || []).length > 0) {\n if (shouldEmit) {\n this.baseApis.emit(\n CryptoEvent.KeySignatureUploadFailure,\n failures,\n \"setDeviceVerification\",\n upload,\n );\n }\n /* Throwing here causes the process to be cancelled and the other\n * user to be notified */\n throw new KeySignatureUploadError(\"Key upload failed\", { failures });\n }\n };\n await upload({ shouldEmit: true });\n\n // This will emit events when it comes back down the sync\n // (we could do local echo to speed things up)\n }\n return device as any; // TODO types\n } else {\n return xsk;\n }\n }\n\n const devices = this.deviceList.getRawStoredDevicesForUser(userId);\n if (!devices || !devices[deviceId]) {\n throw new Error(\"Unknown device \" + userId + \":\" + deviceId);\n }\n\n const dev = devices[deviceId];\n let verificationStatus = dev.verified;\n\n if (verified) {\n if (keys) {\n for (const [keyId, key] of Object.entries(keys)) {\n if (dev.keys[keyId] !== key) {\n throw new Error(`Key did not match expected value: expected ${key}, got ${dev.keys[keyId]}`);\n }\n }\n }\n verificationStatus = DeviceVerification.VERIFIED;\n } else if (verified !== null && verificationStatus == DeviceVerification.VERIFIED) {\n verificationStatus = DeviceVerification.UNVERIFIED;\n }\n\n if (blocked) {\n verificationStatus = DeviceVerification.BLOCKED;\n } else if (blocked !== null && verificationStatus == DeviceVerification.BLOCKED) {\n verificationStatus = DeviceVerification.UNVERIFIED;\n }\n\n let knownStatus = dev.known;\n if (known !== null) {\n knownStatus = known;\n }\n\n if (dev.verified !== verificationStatus || dev.known !== knownStatus) {\n dev.verified = verificationStatus;\n dev.known = knownStatus;\n this.deviceList.storeDevicesForUser(userId, devices);\n this.deviceList.saveIfDirty();\n }\n\n // do cross-signing\n if (verified && userId === this.userId) {\n logger.info(\"Own device \" + deviceId + \" marked verified: signing\");\n\n // Signing only needed if other device not already signed\n let device: ISignedKey | undefined;\n const deviceTrust = this.checkDeviceTrust(userId, deviceId);\n if (deviceTrust.isCrossSigningVerified()) {\n logger.log(`Own device ${deviceId} already cross-signing verified`);\n } else {\n device = (await this.crossSigningInfo.signDevice(userId, DeviceInfo.fromStorage(dev, deviceId)))!;\n }\n\n if (device) {\n const upload = async ({ shouldEmit = false }): Promise => {\n logger.info(\"Uploading signature for \" + deviceId);\n const response = await this.baseApis.uploadKeySignatures({\n [userId]: {\n [deviceId]: device!,\n },\n });\n const { failures } = response || {};\n if (Object.keys(failures || []).length > 0) {\n if (shouldEmit) {\n this.baseApis.emit(\n CryptoEvent.KeySignatureUploadFailure,\n failures,\n \"setDeviceVerification\",\n upload, // continuation\n );\n }\n throw new KeySignatureUploadError(\"Key upload failed\", { failures });\n }\n };\n await upload({ shouldEmit: true });\n // XXX: we'll need to wait for the device list to be updated\n }\n }\n\n const deviceObj = DeviceInfo.fromStorage(dev, deviceId);\n this.emit(CryptoEvent.DeviceVerificationChanged, userId, deviceId, deviceObj);\n return deviceObj;\n }\n\n public findVerificationRequestDMInProgress(roomId: string): VerificationRequest | undefined {\n return this.inRoomVerificationRequests.findRequestInProgress(roomId);\n }\n\n public getVerificationRequestsToDeviceInProgress(userId: string): VerificationRequest[] {\n return this.toDeviceVerificationRequests.getRequestsInProgress(userId);\n }\n\n public requestVerificationDM(userId: string, roomId: string): Promise {\n const existingRequest = this.inRoomVerificationRequests.findRequestInProgress(roomId);\n if (existingRequest) {\n return Promise.resolve(existingRequest);\n }\n const channel = new InRoomChannel(this.baseApis, roomId, userId);\n return this.requestVerificationWithChannel(userId, channel, this.inRoomVerificationRequests);\n }\n\n public requestVerification(userId: string, devices?: string[]): Promise {\n if (!devices) {\n devices = Object.keys(this.deviceList.getRawStoredDevicesForUser(userId));\n }\n const existingRequest = this.toDeviceVerificationRequests.findRequestInProgress(userId, devices);\n if (existingRequest) {\n return Promise.resolve(existingRequest);\n }\n const channel = new ToDeviceChannel(this.baseApis, userId, devices, ToDeviceChannel.makeTransactionId());\n return this.requestVerificationWithChannel(userId, channel, this.toDeviceVerificationRequests);\n }\n\n private async requestVerificationWithChannel(\n userId: string,\n channel: IVerificationChannel,\n requestsMap: IRequestsMap,\n ): Promise {\n let request = new VerificationRequest(channel, this.verificationMethods, this.baseApis);\n // if transaction id is already known, add request\n if (channel.transactionId) {\n requestsMap.setRequestByChannel(channel, request);\n }\n await request.sendRequest();\n // don't replace the request created by a racing remote echo\n const racingRequest = requestsMap.getRequestByChannel(channel);\n if (racingRequest) {\n request = racingRequest;\n } else {\n logger.log(\n `Crypto: adding new request to ` + `requestsByTxnId with id ${channel.transactionId} ${channel.roomId}`,\n );\n requestsMap.setRequestByChannel(channel, request);\n }\n return request;\n }\n\n public beginKeyVerification(\n method: string,\n userId: string,\n deviceId: string,\n transactionId: string | null = null,\n ): VerificationBase {\n let request: Request | undefined;\n if (transactionId) {\n request = this.toDeviceVerificationRequests.getRequestBySenderAndTxnId(userId, transactionId);\n if (!request) {\n throw new Error(`No request found for user ${userId} with ` + `transactionId ${transactionId}`);\n }\n } else {\n transactionId = ToDeviceChannel.makeTransactionId();\n const channel = new ToDeviceChannel(this.baseApis, userId, [deviceId], transactionId, deviceId);\n request = new VerificationRequest(channel, this.verificationMethods, this.baseApis);\n this.toDeviceVerificationRequests.setRequestBySenderAndTxnId(userId, transactionId, request);\n }\n return request.beginKeyVerification(method, { userId, deviceId });\n }\n\n public async legacyDeviceVerification(\n userId: string,\n deviceId: string,\n method: VerificationMethod,\n ): Promise {\n const transactionId = ToDeviceChannel.makeTransactionId();\n const channel = new ToDeviceChannel(this.baseApis, userId, [deviceId], transactionId, deviceId);\n const request = new VerificationRequest(channel, this.verificationMethods, this.baseApis);\n this.toDeviceVerificationRequests.setRequestBySenderAndTxnId(userId, transactionId, request);\n const verifier = request.beginKeyVerification(method, { userId, deviceId });\n // either reject by an error from verify() while sending .start\n // or resolve when the request receives the\n // local (fake remote) echo for sending the .start event\n await Promise.race([verifier.verify(), request.waitFor((r) => r.started)]);\n return request;\n }\n\n /**\n * Get information on the active olm sessions with a user\n *

\n * Returns a map from device id to an object with keys 'deviceIdKey' (the\n * device's curve25519 identity key) and 'sessions' (an array of objects in the\n * same format as that returned by\n * {@link OlmDevice#getSessionInfoForDevice}).\n *

\n * This method is provided for debugging purposes.\n *\n * @param userId - id of user to inspect\n */\n public async getOlmSessionsForUser(userId: string): Promise> {\n const devices = this.getStoredDevicesForUser(userId) || [];\n const result: { [deviceId: string]: IUserOlmSession } = {};\n for (const device of devices) {\n const deviceKey = device.getIdentityKey();\n const sessions = await this.olmDevice.getSessionInfoForDevice(deviceKey);\n\n result[device.deviceId] = {\n deviceIdKey: deviceKey,\n sessions: sessions,\n };\n }\n return result;\n }\n\n /**\n * Get the device which sent an event\n *\n * @param event - event to be checked\n */\n public getEventSenderDeviceInfo(event: MatrixEvent): DeviceInfo | null {\n const senderKey = event.getSenderKey();\n const algorithm = event.getWireContent().algorithm;\n\n if (!senderKey || !algorithm) {\n return null;\n }\n\n if (event.isKeySourceUntrusted()) {\n // we got the key for this event from a source that we consider untrusted\n return null;\n }\n\n // senderKey is the Curve25519 identity key of the device which the event\n // was sent from. In the case of Megolm, it's actually the Curve25519\n // identity key of the device which set up the Megolm session.\n\n const device = this.deviceList.getDeviceByIdentityKey(algorithm, senderKey);\n\n if (device === null) {\n // we haven't downloaded the details of this device yet.\n return null;\n }\n\n // so far so good, but now we need to check that the sender of this event\n // hadn't advertised someone else's Curve25519 key as their own. We do that\n // by checking the Ed25519 claimed by the event (or, in the case of megolm,\n // the event which set up the megolm session), to check that it matches the\n // fingerprint of the purported sending device.\n //\n // (see https://github.com/vector-im/vector-web/issues/2215)\n\n const claimedKey = event.getClaimedEd25519Key();\n if (!claimedKey) {\n logger.warn(\"Event \" + event.getId() + \" claims no ed25519 key: \" + \"cannot verify sending device\");\n return null;\n }\n\n if (claimedKey !== device.getFingerprint()) {\n logger.warn(\n \"Event \" +\n event.getId() +\n \" claims ed25519 key \" +\n claimedKey +\n \" but sender device has key \" +\n device.getFingerprint(),\n );\n return null;\n }\n\n return device;\n }\n\n /**\n * Get information about the encryption of an event\n *\n * @param event - event to be checked\n *\n * @returns An object with the fields:\n * - encrypted: whether the event is encrypted (if not encrypted, some of the\n * other properties may not be set)\n * - senderKey: the sender's key\n * - algorithm: the algorithm used to encrypt the event\n * - authenticated: whether we can be sure that the owner of the senderKey\n * sent the event\n * - sender: the sender's device information, if available\n * - mismatchedSender: if the event's ed25519 and curve25519 keys don't match\n * (only meaningful if `sender` is set)\n */\n public getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo {\n const ret: Partial = {};\n\n ret.senderKey = event.getSenderKey() ?? undefined;\n ret.algorithm = event.getWireContent().algorithm;\n\n if (!ret.senderKey || !ret.algorithm) {\n ret.encrypted = false;\n return ret as IEncryptedEventInfo;\n }\n ret.encrypted = true;\n\n if (event.isKeySourceUntrusted()) {\n // we got the key this event from somewhere else\n // TODO: check if we can trust the forwarders.\n ret.authenticated = false;\n } else {\n ret.authenticated = true;\n }\n\n // senderKey is the Curve25519 identity key of the device which the event\n // was sent from. In the case of Megolm, it's actually the Curve25519\n // identity key of the device which set up the Megolm session.\n\n ret.sender = this.deviceList.getDeviceByIdentityKey(ret.algorithm, ret.senderKey) ?? undefined;\n\n // so far so good, but now we need to check that the sender of this event\n // hadn't advertised someone else's Curve25519 key as their own. We do that\n // by checking the Ed25519 claimed by the event (or, in the case of megolm,\n // the event which set up the megolm session), to check that it matches the\n // fingerprint of the purported sending device.\n //\n // (see https://github.com/vector-im/vector-web/issues/2215)\n\n const claimedKey = event.getClaimedEd25519Key();\n if (!claimedKey) {\n logger.warn(\"Event \" + event.getId() + \" claims no ed25519 key: \" + \"cannot verify sending device\");\n ret.mismatchedSender = true;\n }\n\n if (ret.sender && claimedKey !== ret.sender.getFingerprint()) {\n logger.warn(\n \"Event \" +\n event.getId() +\n \" claims ed25519 key \" +\n claimedKey +\n \"but sender device has key \" +\n ret.sender.getFingerprint(),\n );\n ret.mismatchedSender = true;\n }\n\n return ret as IEncryptedEventInfo;\n }\n\n /**\n * Forces the current outbound group session to be discarded such\n * that another one will be created next time an event is sent.\n *\n * @param roomId - The ID of the room to discard the session for\n *\n * This should not normally be necessary.\n */\n public forceDiscardSession(roomId: string): Promise {\n const alg = this.roomEncryptors.get(roomId);\n if (alg === undefined) throw new Error(\"Room not encrypted\");\n if (alg.forceDiscardSession === undefined) {\n throw new Error(\"Room encryption algorithm doesn't support session discarding\");\n }\n alg.forceDiscardSession();\n return Promise.resolve();\n }\n\n /**\n * Configure a room to use encryption (ie, save a flag in the cryptoStore).\n *\n * @param roomId - The room ID to enable encryption in.\n *\n * @param config - The encryption config for the room.\n *\n * @param inhibitDeviceQuery - true to suppress device list query for\n * users in the room (for now). In case lazy loading is enabled,\n * the device query is always inhibited as the members are not tracked.\n *\n * @deprecated It is normally incorrect to call this method directly. Encryption\n * is enabled by receiving an `m.room.encryption` event (which we may have sent\n * previously).\n */\n public async setRoomEncryption(\n roomId: string,\n config: IRoomEncryption,\n inhibitDeviceQuery?: boolean,\n ): Promise {\n const room = this.clientStore.getRoom(roomId);\n if (!room) {\n throw new Error(`Unable to enable encryption tracking devices in unknown room ${roomId}`);\n }\n await this.setRoomEncryptionImpl(room, config);\n if (!this.lazyLoadMembers && !inhibitDeviceQuery) {\n this.deviceList.refreshOutdatedDeviceLists();\n }\n }\n\n /**\n * Set up encryption for a room.\n *\n * This is called when an m.room.encryption event is received. It saves a flag\n * for the room in the cryptoStore (if it wasn't already set), sets up an \"encryptor\" for\n * the room, and enables device-list tracking for the room.\n *\n * It does not initiate a device list query for the room. That is normally\n * done once we finish processing the sync, in onSyncCompleted.\n *\n * @param room - The room to enable encryption in.\n * @param config - The encryption config for the room.\n */\n private async setRoomEncryptionImpl(room: Room, config: IRoomEncryption): Promise {\n const roomId = room.roomId;\n\n // ignore crypto events with no algorithm defined\n // This will happen if a crypto event is redacted before we fetch the room state\n // It would otherwise just throw later as an unknown algorithm would, but we may\n // as well catch this here\n if (!config.algorithm) {\n logger.log(\"Ignoring setRoomEncryption with no algorithm\");\n return;\n }\n\n // if state is being replayed from storage, we might already have a configuration\n // for this room as they are persisted as well.\n // We just need to make sure the algorithm is initialized in this case.\n // However, if the new config is different,\n // we should bail out as room encryption can't be changed once set.\n const existingConfig = this.roomList.getRoomEncryption(roomId);\n if (existingConfig) {\n if (JSON.stringify(existingConfig) != JSON.stringify(config)) {\n logger.error(\"Ignoring m.room.encryption event which requests \" + \"a change of config in \" + roomId);\n return;\n }\n }\n // if we already have encryption in this room, we should ignore this event,\n // as it would reset the encryption algorithm.\n // This is at least expected to be called twice, as sync calls onCryptoEvent\n // for both the timeline and state sections in the /sync response,\n // the encryption event would appear in both.\n // If it's called more than twice though,\n // it signals a bug on client or server.\n const existingAlg = this.roomEncryptors.get(roomId);\n if (existingAlg) {\n return;\n }\n\n // _roomList.getRoomEncryption will not race with _roomList.setRoomEncryption\n // because it first stores in memory. We should await the promise only\n // after all the in-memory state (roomEncryptors and _roomList) has been updated\n // to avoid races when calling this method multiple times. Hence keep a hold of the promise.\n let storeConfigPromise: Promise | null = null;\n if (!existingConfig) {\n storeConfigPromise = this.roomList.setRoomEncryption(roomId, config);\n }\n\n const AlgClass = algorithms.ENCRYPTION_CLASSES.get(config.algorithm);\n if (!AlgClass) {\n throw new Error(\"Unable to encrypt with \" + config.algorithm);\n }\n\n const alg = new AlgClass({\n userId: this.userId,\n deviceId: this.deviceId,\n crypto: this,\n olmDevice: this.olmDevice,\n baseApis: this.baseApis,\n roomId,\n config,\n });\n this.roomEncryptors.set(roomId, alg);\n\n if (storeConfigPromise) {\n await storeConfigPromise;\n }\n\n logger.log(`Enabling encryption in ${roomId}`);\n\n // we don't want to force a download of the full membership list of this room, but as soon as we have that\n // list we can start tracking the device list.\n if (room.membersLoaded()) {\n await this.trackRoomDevicesImpl(room);\n } else {\n // wait for the membership list to be loaded\n const onState = (_state: RoomState): void => {\n room.off(RoomStateEvent.Update, onState);\n if (room.membersLoaded()) {\n this.trackRoomDevicesImpl(room).catch((e) => {\n logger.error(`Error enabling device tracking in ${roomId}`, e);\n });\n }\n };\n room.on(RoomStateEvent.Update, onState);\n }\n }\n\n /**\n * Make sure we are tracking the device lists for all users in this room.\n *\n * @param roomId - The room ID to start tracking devices in.\n * @returns when all devices for the room have been fetched and marked to track\n * @deprecated there's normally no need to call this function: device list tracking\n * will be enabled as soon as we have the full membership list.\n */\n public trackRoomDevices(roomId: string): Promise {\n const room = this.clientStore.getRoom(roomId);\n if (!room) {\n throw new Error(`Unable to start tracking devices in unknown room ${roomId}`);\n }\n return this.trackRoomDevicesImpl(room);\n }\n\n /**\n * Make sure we are tracking the device lists for all users in this room.\n *\n * This is normally called when we are about to send an encrypted event, to make sure\n * we have all the devices in the room; but it is also called when processing an\n * m.room.encryption state event (if lazy-loading is disabled), or when members are\n * loaded (if lazy-loading is enabled), to prepare the device list.\n *\n * @param room - Room to enable device-list tracking in\n */\n private trackRoomDevicesImpl(room: Room): Promise {\n const roomId = room.roomId;\n const trackMembers = async (): Promise => {\n // not an encrypted room\n if (!this.roomEncryptors.has(roomId)) {\n return;\n }\n logger.log(`Starting to track devices for room ${roomId} ...`);\n const members = await room.getEncryptionTargetMembers();\n members.forEach((m) => {\n this.deviceList.startTrackingDeviceList(m.userId);\n });\n };\n\n let promise = this.roomDeviceTrackingState[roomId];\n if (!promise) {\n promise = trackMembers();\n this.roomDeviceTrackingState[roomId] = promise.catch((err) => {\n delete this.roomDeviceTrackingState[roomId];\n throw err;\n });\n }\n return promise;\n }\n\n /**\n * Try to make sure we have established olm sessions for all known devices for\n * the given users.\n *\n * @param users - list of user ids\n * @param force - If true, force a new Olm session to be created. Default false.\n *\n * @returns resolves once the sessions are complete, to\n * an Object mapping from userId to deviceId to\n * {@link OlmSessionResult}\n */\n public ensureOlmSessionsForUsers(\n users: string[],\n force?: boolean,\n ): Promise>> {\n // map user Id → DeviceInfo[]\n const devicesByUser: Map = new Map();\n\n for (const userId of users) {\n const userDevices: DeviceInfo[] = [];\n devicesByUser.set(userId, userDevices);\n\n const devices = this.getStoredDevicesForUser(userId) || [];\n for (const deviceInfo of devices) {\n const key = deviceInfo.getIdentityKey();\n if (key == this.olmDevice.deviceCurve25519Key) {\n // don't bother setting up session to ourself\n continue;\n }\n if (deviceInfo.verified == DeviceVerification.BLOCKED) {\n // don't bother setting up sessions with blocked users\n continue;\n }\n\n userDevices.push(deviceInfo);\n }\n }\n\n return olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, devicesByUser, force);\n }\n\n /**\n * Get a list containing all of the room keys\n *\n * @returns a list of session export objects\n */\n public async exportRoomKeys(): Promise {\n const exportedSessions: IMegolmSessionData[] = [];\n await this.cryptoStore.doTxn(\"readonly\", [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS], (txn) => {\n this.cryptoStore.getAllEndToEndInboundGroupSessions(txn, (s) => {\n if (s === null) return;\n\n const sess = this.olmDevice.exportInboundGroupSession(s.senderKey, s.sessionId, s.sessionData!);\n delete sess.first_known_index;\n sess.algorithm = olmlib.MEGOLM_ALGORITHM;\n exportedSessions.push(sess);\n });\n });\n\n return exportedSessions;\n }\n\n /**\n * Import a list of room keys previously exported by exportRoomKeys\n *\n * @param keys - a list of session export objects\n * @returns a promise which resolves once the keys have been imported\n */\n public importRoomKeys(keys: IMegolmSessionData[], opts: IImportRoomKeysOpts = {}): Promise {\n let successes = 0;\n let failures = 0;\n const total = keys.length;\n\n function updateProgress(): void {\n opts.progressCallback?.({\n stage: \"load_keys\",\n successes,\n failures,\n total,\n });\n }\n\n return Promise.all(\n keys.map((key) => {\n if (!key.room_id || !key.algorithm) {\n logger.warn(\"ignoring room key entry with missing fields\", key);\n failures++;\n if (opts.progressCallback) {\n updateProgress();\n }\n return null;\n }\n\n const alg = this.getRoomDecryptor(key.room_id, key.algorithm);\n return alg.importRoomKey(key, opts).finally(() => {\n successes++;\n if (opts.progressCallback) {\n updateProgress();\n }\n });\n }),\n ).then();\n }\n\n /**\n * Counts the number of end to end session keys that are waiting to be backed up\n * @returns Promise which resolves to the number of sessions requiring backup\n */\n public countSessionsNeedingBackup(): Promise {\n return this.backupManager.countSessionsNeedingBackup();\n }\n\n /**\n * Perform any background tasks that can be done before a message is ready to\n * send, in order to speed up sending of the message.\n *\n * @param room - the room the event is in\n */\n public prepareToEncrypt(room: Room): void {\n const alg = this.roomEncryptors.get(room.roomId);\n if (alg) {\n alg.prepareToEncrypt(room);\n }\n }\n\n /**\n * Encrypt an event according to the configuration of the room.\n *\n * @param event - event to be sent\n *\n * @param room - destination room.\n *\n * @returns Promise which resolves when the event has been\n * encrypted, or null if nothing was needed\n */\n public async encryptEvent(event: MatrixEvent, room: Room): Promise {\n const roomId = event.getRoomId()!;\n\n const alg = this.roomEncryptors.get(roomId);\n if (!alg) {\n // MatrixClient has already checked that this room should be encrypted,\n // so this is an unexpected situation.\n throw new Error(\n \"Room \" +\n roomId +\n \" was previously configured to use encryption, but is \" +\n \"no longer. Perhaps the homeserver is hiding the \" +\n \"configuration event.\",\n );\n }\n\n // wait for all the room devices to be loaded\n await this.trackRoomDevicesImpl(room);\n\n let content = event.getContent();\n // If event has an m.relates_to then we need\n // to put this on the wrapping event instead\n const mRelatesTo = content[\"m.relates_to\"];\n if (mRelatesTo) {\n // Clone content here so we don't remove `m.relates_to` from the local-echo\n content = Object.assign({}, content);\n delete content[\"m.relates_to\"];\n }\n\n // Treat element's performance metrics the same as `m.relates_to` (when present)\n const elementPerfMetrics = content[\"io.element.performance_metrics\"];\n if (elementPerfMetrics) {\n content = Object.assign({}, content);\n delete content[\"io.element.performance_metrics\"];\n }\n\n const encryptedContent = (await alg.encryptMessage(room, event.getType(), content)) as IContent;\n\n if (mRelatesTo) {\n encryptedContent[\"m.relates_to\"] = mRelatesTo;\n }\n if (elementPerfMetrics) {\n encryptedContent[\"io.element.performance_metrics\"] = elementPerfMetrics;\n }\n\n event.makeEncrypted(\n \"m.room.encrypted\",\n encryptedContent,\n this.olmDevice.deviceCurve25519Key!,\n this.olmDevice.deviceEd25519Key!,\n );\n }\n\n /**\n * Decrypt a received event\n *\n *\n * @returns resolves once we have\n * finished decrypting. Rejects with an `algorithms.DecryptionError` if there\n * is a problem decrypting the event.\n */\n public async decryptEvent(event: MatrixEvent): Promise {\n if (event.isRedacted()) {\n // Try to decrypt the redaction event, to support encrypted\n // redaction reasons. If we can't decrypt, just fall back to using\n // the original redacted_because.\n const redactionEvent = new MatrixEvent({\n room_id: event.getRoomId(),\n ...event.getUnsigned().redacted_because,\n });\n let redactedBecause: IEvent = event.getUnsigned().redacted_because!;\n if (redactionEvent.isEncrypted()) {\n try {\n const decryptedEvent = await this.decryptEvent(redactionEvent);\n redactedBecause = decryptedEvent.clearEvent as IEvent;\n } catch (e) {\n logger.warn(\"Decryption of redaction failed. Falling back to unencrypted event.\", e);\n }\n }\n\n return {\n clearEvent: {\n room_id: event.getRoomId(),\n type: \"m.room.message\",\n content: {},\n unsigned: {\n redacted_because: redactedBecause,\n },\n },\n };\n } else {\n const content = event.getWireContent();\n const alg = this.getRoomDecryptor(event.getRoomId()!, content.algorithm);\n return alg.decryptEvent(event);\n }\n }\n\n /**\n * Handle the notification from /sync or /keys/changes that device lists have\n * been changed.\n *\n * @param syncData - Object containing sync tokens associated with this sync\n * @param syncDeviceLists - device_lists field from /sync, or response from\n * /keys/changes\n */\n public async handleDeviceListChanges(\n syncData: ISyncStateData,\n syncDeviceLists: Required[\"device_lists\"],\n ): Promise {\n // Initial syncs don't have device change lists. We'll either get the complete list\n // of changes for the interval or will have invalidated everything in willProcessSync\n if (!syncData.oldSyncToken) return;\n\n // Here, we're relying on the fact that we only ever save the sync data after\n // sucessfully saving the device list data, so we're guaranteed that the device\n // list store is at least as fresh as the sync token from the sync store, ie.\n // any device changes received in sync tokens prior to the 'next' token here\n // have been processed and are reflected in the current device list.\n // If we didn't make this assumption, we'd have to use the /keys/changes API\n // to get key changes between the sync token in the device list and the 'old'\n // sync token used here to make sure we didn't miss any.\n await this.evalDeviceListChanges(syncDeviceLists);\n }\n\n /**\n * Send a request for some room keys, if we have not already done so\n *\n * @param resend - whether to resend the key request if there is\n * already one\n *\n * @returns a promise that resolves when the key request is queued\n */\n public requestRoomKey(\n requestBody: IRoomKeyRequestBody,\n recipients: IRoomKeyRequestRecipient[],\n resend = false,\n ): Promise {\n return this.outgoingRoomKeyRequestManager\n .queueRoomKeyRequest(requestBody, recipients, resend)\n .then(() => {\n if (this.sendKeyRequestsImmediately) {\n this.outgoingRoomKeyRequestManager.sendQueuedRequests();\n }\n })\n .catch((e) => {\n // this normally means we couldn't talk to the store\n logger.error(\"Error requesting key for event\", e);\n });\n }\n\n /**\n * Cancel any earlier room key request\n *\n * @param requestBody - parameters to match for cancellation\n */\n public cancelRoomKeyRequest(requestBody: IRoomKeyRequestBody): void {\n this.outgoingRoomKeyRequestManager.cancelRoomKeyRequest(requestBody).catch((e) => {\n logger.warn(\"Error clearing pending room key requests\", e);\n });\n }\n\n /**\n * Re-send any outgoing key requests, eg after verification\n * @returns\n */\n public async cancelAndResendAllOutgoingKeyRequests(): Promise {\n await this.outgoingRoomKeyRequestManager.cancelAndResendAllOutgoingRequests();\n }\n\n /**\n * handle an m.room.encryption event\n *\n * @param room - in which the event was received\n * @param event - encryption event to be processed\n */\n public async onCryptoEvent(room: Room, event: MatrixEvent): Promise {\n const content = event.getContent();\n await this.setRoomEncryptionImpl(room, content);\n }\n\n /**\n * Called before the result of a sync is processed\n *\n * @param syncData - the data from the 'MatrixClient.sync' event\n */\n public async onSyncWillProcess(syncData: ISyncStateData): Promise {\n if (!syncData.oldSyncToken) {\n // If there is no old sync token, we start all our tracking from\n // scratch, so mark everything as untracked. onCryptoEvent will\n // be called for all e2e rooms during the processing of the sync,\n // at which point we'll start tracking all the users of that room.\n logger.log(\"Initial sync performed - resetting device tracking state\");\n this.deviceList.stopTrackingAllDeviceLists();\n // we always track our own device list (for key backups etc)\n this.deviceList.startTrackingDeviceList(this.userId);\n this.roomDeviceTrackingState = {};\n }\n\n this.sendKeyRequestsImmediately = false;\n }\n\n /**\n * handle the completion of a /sync\n *\n * This is called after the processing of each successful /sync response.\n * It is an opportunity to do a batch process on the information received.\n *\n * @param syncData - the data from the 'MatrixClient.sync' event\n */\n public async onSyncCompleted(syncData: OnSyncCompletedData): Promise {\n this.deviceList.setSyncToken(syncData.nextSyncToken ?? null);\n this.deviceList.saveIfDirty();\n\n // we always track our own device list (for key backups etc)\n this.deviceList.startTrackingDeviceList(this.userId);\n\n this.deviceList.refreshOutdatedDeviceLists();\n\n // we don't start uploading one-time keys until we've caught up with\n // to-device messages, to help us avoid throwing away one-time-keys that we\n // are about to receive messages for\n // (https://github.com/vector-im/element-web/issues/2782).\n if (!syncData.catchingUp) {\n this.maybeUploadOneTimeKeys();\n this.processReceivedRoomKeyRequests();\n\n // likewise don't start requesting keys until we've caught up\n // on to_device messages, otherwise we'll request keys that we're\n // just about to get.\n this.outgoingRoomKeyRequestManager.sendQueuedRequests();\n\n // Sync has finished so send key requests straight away.\n this.sendKeyRequestsImmediately = true;\n }\n }\n\n /**\n * Trigger the appropriate invalidations and removes for a given\n * device list\n *\n * @param deviceLists - device_lists field from /sync, or response from\n * /keys/changes\n */\n private async evalDeviceListChanges(deviceLists: Required[\"device_lists\"]): Promise {\n if (Array.isArray(deviceLists?.changed)) {\n deviceLists.changed.forEach((u) => {\n this.deviceList.invalidateUserDeviceList(u);\n });\n }\n\n if (Array.isArray(deviceLists?.left) && deviceLists.left.length) {\n // Check we really don't share any rooms with these users\n // any more: the server isn't required to give us the\n // exact correct set.\n const e2eUserIds = new Set(await this.getTrackedE2eUsers());\n\n deviceLists.left.forEach((u) => {\n if (!e2eUserIds.has(u)) {\n this.deviceList.stopTrackingDeviceList(u);\n }\n });\n }\n }\n\n /**\n * Get a list of all the IDs of users we share an e2e room with\n * for which we are tracking devices already\n *\n * @returns List of user IDs\n */\n private async getTrackedE2eUsers(): Promise {\n const e2eUserIds: string[] = [];\n for (const room of this.getTrackedE2eRooms()) {\n const members = await room.getEncryptionTargetMembers();\n for (const member of members) {\n e2eUserIds.push(member.userId);\n }\n }\n return e2eUserIds;\n }\n\n /**\n * Get a list of the e2e-enabled rooms we are members of,\n * and for which we are already tracking the devices\n *\n * @returns\n */\n private getTrackedE2eRooms(): Room[] {\n return this.clientStore.getRooms().filter((room) => {\n // check for rooms with encryption enabled\n const alg = this.roomEncryptors.get(room.roomId);\n if (!alg) {\n return false;\n }\n if (!this.roomDeviceTrackingState[room.roomId]) {\n return false;\n }\n\n // ignore any rooms which we have left\n const myMembership = room.getMyMembership();\n return myMembership === \"join\" || myMembership === \"invite\";\n });\n }\n\n /**\n * Encrypts and sends a given object via Olm to-device messages to a given\n * set of devices.\n * @param userDeviceInfoArr - the devices to send to\n * @param payload - fields to include in the encrypted payload\n * @returns Promise which\n * resolves once the message has been encrypted and sent to the given\n * userDeviceMap, and returns the `{ contentMap, deviceInfoByDeviceId }`\n * of the successfully sent messages.\n */\n public async encryptAndSendToDevices(userDeviceInfoArr: IOlmDevice[], payload: object): Promise {\n const toDeviceBatch: ToDeviceBatch = {\n eventType: EventType.RoomMessageEncrypted,\n batch: [],\n };\n\n try {\n await Promise.all(\n userDeviceInfoArr.map(async ({ userId, deviceInfo }) => {\n const deviceId = deviceInfo.deviceId;\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n [ToDeviceMessageId]: uuidv4(),\n };\n\n toDeviceBatch.batch.push({\n userId,\n deviceId,\n payload: encryptedContent,\n });\n\n await olmlib.ensureOlmSessionsForDevices(\n this.olmDevice,\n this.baseApis,\n new Map([[userId, [deviceInfo]]]),\n );\n await olmlib.encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.userId,\n this.deviceId,\n this.olmDevice,\n userId,\n deviceInfo,\n payload,\n );\n }),\n );\n\n // prune out any devices that encryptMessageForDevice could not encrypt for,\n // in which case it will have just not added anything to the ciphertext object.\n // There's no point sending messages to devices if we couldn't encrypt to them,\n // since that's effectively a blank message.\n toDeviceBatch.batch = toDeviceBatch.batch.filter((msg) => {\n if (Object.keys(msg.payload.ciphertext).length > 0) {\n return true;\n } else {\n logger.log(`No ciphertext for device ${msg.userId}:${msg.deviceId}: pruning`);\n return false;\n }\n });\n\n try {\n await this.baseApis.queueToDevice(toDeviceBatch);\n } catch (e) {\n logger.error(\"sendToDevice failed\", e);\n throw e;\n }\n } catch (e) {\n logger.error(\"encryptAndSendToDevices promises failed\", e);\n throw e;\n }\n }\n\n private onMembership = (event: MatrixEvent, member: RoomMember, oldMembership?: string): void => {\n try {\n this.onRoomMembership(event, member, oldMembership);\n } catch (e) {\n logger.error(\"Error handling membership change:\", e);\n }\n };\n\n public async preprocessToDeviceMessages(events: IToDeviceEvent[]): Promise {\n // all we do here is filter out encrypted to-device messages with the wrong algorithm. Decryption\n // happens later in decryptEvent, via the EventMapper\n return events.filter((toDevice) => {\n if (\n toDevice.type === EventType.RoomMessageEncrypted &&\n ![\"m.olm.v1.curve25519-aes-sha2\"].includes(toDevice.content?.algorithm)\n ) {\n logger.log(\"Ignoring invalid encrypted to-device event from \" + toDevice.sender);\n return false;\n }\n return true;\n });\n }\n\n public preprocessOneTimeKeyCounts(oneTimeKeysCounts: Map): Promise {\n const currentCount = oneTimeKeysCounts.get(\"signed_curve25519\") || 0;\n this.updateOneTimeKeyCount(currentCount);\n return Promise.resolve();\n }\n\n public preprocessUnusedFallbackKeys(unusedFallbackKeys: Set): Promise {\n this.setNeedsNewFallback(!unusedFallbackKeys.has(\"signed_curve25519\"));\n return Promise.resolve();\n }\n\n private onToDeviceEvent = (event: MatrixEvent): void => {\n try {\n logger.log(\n `received to-device ${event.getType()} from: ` +\n `${event.getSender()} id: ${event.getContent()[ToDeviceMessageId]}`,\n );\n\n if (event.getType() == \"m.room_key\" || event.getType() == \"m.forwarded_room_key\") {\n this.onRoomKeyEvent(event);\n } else if (event.getType() == \"m.room_key_request\") {\n this.onRoomKeyRequestEvent(event);\n } else if (event.getType() === \"m.secret.request\") {\n this.secretStorage.onRequestReceived(event);\n } else if (event.getType() === \"m.secret.send\") {\n this.secretStorage.onSecretReceived(event);\n } else if (event.getType() === \"m.room_key.withheld\") {\n this.onRoomKeyWithheldEvent(event);\n } else if (event.getContent().transaction_id) {\n this.onKeyVerificationMessage(event);\n } else if (event.getContent().msgtype === \"m.bad.encrypted\") {\n this.onToDeviceBadEncrypted(event);\n } else if (event.isBeingDecrypted() || event.shouldAttemptDecryption()) {\n if (!event.isBeingDecrypted()) {\n event.attemptDecryption(this);\n }\n // once the event has been decrypted, try again\n event.once(MatrixEventEvent.Decrypted, (ev) => {\n this.onToDeviceEvent(ev);\n });\n }\n } catch (e) {\n logger.error(\"Error handling toDeviceEvent:\", e);\n }\n };\n\n /**\n * Handle a key event\n *\n * @internal\n * @param event - key event\n */\n private onRoomKeyEvent(event: MatrixEvent): void {\n const content = event.getContent();\n\n if (!content.room_id || !content.algorithm) {\n logger.error(\"key event is missing fields\");\n return;\n }\n\n if (!this.backupManager.checkedForBackup) {\n // don't bother awaiting on this - the important thing is that we retry if we\n // haven't managed to check before\n this.backupManager.checkAndStart();\n }\n\n const alg = this.getRoomDecryptor(content.room_id, content.algorithm);\n alg.onRoomKeyEvent(event);\n }\n\n /**\n * Handle a key withheld event\n *\n * @internal\n * @param event - key withheld event\n */\n private onRoomKeyWithheldEvent(event: MatrixEvent): void {\n const content = event.getContent();\n\n if (\n (content.code !== \"m.no_olm\" && (!content.room_id || !content.session_id)) ||\n !content.algorithm ||\n !content.sender_key\n ) {\n logger.error(\"key withheld event is missing fields\");\n return;\n }\n\n logger.info(\n `Got room key withheld event from ${event.getSender()} ` +\n `for ${content.algorithm} session ${content.sender_key}|${content.session_id} ` +\n `in room ${content.room_id} with code ${content.code} (${content.reason})`,\n );\n\n const alg = this.getRoomDecryptor(content.room_id, content.algorithm);\n if (alg.onRoomKeyWithheldEvent) {\n alg.onRoomKeyWithheldEvent(event);\n }\n if (!content.room_id) {\n // retry decryption for all events sent by the sender_key. This will\n // update the events to show a message indicating that the olm session was\n // wedged.\n const roomDecryptors = this.getRoomDecryptors(content.algorithm);\n for (const decryptor of roomDecryptors) {\n decryptor.retryDecryptionFromSender(content.sender_key);\n }\n }\n }\n\n /**\n * Handle a general key verification event.\n *\n * @internal\n * @param event - verification start event\n */\n private onKeyVerificationMessage(event: MatrixEvent): void {\n if (!ToDeviceChannel.validateEvent(event, this.baseApis)) {\n return;\n }\n const createRequest = (event: MatrixEvent): VerificationRequest | undefined => {\n if (!ToDeviceChannel.canCreateRequest(ToDeviceChannel.getEventType(event))) {\n return;\n }\n const content = event.getContent();\n const deviceId = content && content.from_device;\n if (!deviceId) {\n return;\n }\n const userId = event.getSender()!;\n const channel = new ToDeviceChannel(this.baseApis, userId, [deviceId]);\n return new VerificationRequest(channel, this.verificationMethods, this.baseApis);\n };\n this.handleVerificationEvent(event, this.toDeviceVerificationRequests, createRequest);\n }\n\n /**\n * Handle key verification requests sent as timeline events\n *\n * @internal\n * @param event - the timeline event\n * @param room - not used\n * @param atStart - not used\n * @param removed - not used\n * @param whether - this is a live event\n */\n private onTimelineEvent = (\n event: MatrixEvent,\n room: Room,\n atStart: boolean,\n removed: boolean,\n { liveEvent = true } = {},\n ): void => {\n if (!InRoomChannel.validateEvent(event, this.baseApis)) {\n return;\n }\n const createRequest = (event: MatrixEvent): VerificationRequest => {\n const channel = new InRoomChannel(this.baseApis, event.getRoomId()!);\n return new VerificationRequest(channel, this.verificationMethods, this.baseApis);\n };\n this.handleVerificationEvent(event, this.inRoomVerificationRequests, createRequest, liveEvent);\n };\n\n private async handleVerificationEvent(\n event: MatrixEvent,\n requestsMap: IRequestsMap,\n createRequest: (event: MatrixEvent) => VerificationRequest | undefined,\n isLiveEvent = true,\n ): Promise {\n // Wait for event to get its final ID with pendingEventOrdering: \"chronological\", since DM channels depend on it.\n if (event.isSending() && event.status != EventStatus.SENT) {\n let eventIdListener: () => void;\n let statusListener: () => void;\n try {\n await new Promise((resolve, reject) => {\n eventIdListener = resolve;\n statusListener = (): void => {\n if (event.status == EventStatus.CANCELLED) {\n reject(new Error(\"Event status set to CANCELLED.\"));\n }\n };\n event.once(MatrixEventEvent.LocalEventIdReplaced, eventIdListener);\n event.on(MatrixEventEvent.Status, statusListener);\n });\n } catch (err) {\n logger.error(\"error while waiting for the verification event to be sent: \", err);\n return;\n } finally {\n event.removeListener(MatrixEventEvent.LocalEventIdReplaced, eventIdListener!);\n event.removeListener(MatrixEventEvent.Status, statusListener!);\n }\n }\n let request: VerificationRequest | undefined = requestsMap.getRequest(event);\n let isNewRequest = false;\n if (!request) {\n request = createRequest(event);\n // a request could not be made from this event, so ignore event\n if (!request) {\n logger.log(\n `Crypto: could not find VerificationRequest for ` +\n `${event.getType()}, and could not create one, so ignoring.`,\n );\n return;\n }\n isNewRequest = true;\n requestsMap.setRequest(event, request);\n }\n event.setVerificationRequest(request);\n try {\n await request.channel.handleEvent(event, request, isLiveEvent);\n } catch (err) {\n logger.error(\"error while handling verification event\", err);\n }\n const shouldEmit =\n isNewRequest &&\n !request.initiatedByMe &&\n !request.invalid && // check it has enough events to pass the UNSENT stage\n !request.observeOnly;\n if (shouldEmit) {\n this.baseApis.emit(CryptoEvent.VerificationRequest, request);\n }\n }\n\n /**\n * Handle a toDevice event that couldn't be decrypted\n *\n * @internal\n * @param event - undecryptable event\n */\n private async onToDeviceBadEncrypted(event: MatrixEvent): Promise {\n const content = event.getWireContent();\n const sender = event.getSender();\n const algorithm = content.algorithm;\n const deviceKey = content.sender_key;\n\n this.baseApis.emit(ClientEvent.UndecryptableToDeviceEvent, event);\n\n // retry decryption for all events sent by the sender_key. This will\n // update the events to show a message indicating that the olm session was\n // wedged.\n const retryDecryption = (): void => {\n const roomDecryptors = this.getRoomDecryptors(olmlib.MEGOLM_ALGORITHM);\n for (const decryptor of roomDecryptors) {\n decryptor.retryDecryptionFromSender(deviceKey);\n }\n };\n\n if (sender === undefined || deviceKey === undefined || deviceKey === undefined) {\n return;\n }\n\n // check when we last forced a new session with this device: if we've already done so\n // recently, don't do it again.\n const lastNewSessionDevices = this.lastNewSessionForced.getOrCreate(sender);\n const lastNewSessionForced = lastNewSessionDevices.getOrCreate(deviceKey);\n if (lastNewSessionForced + MIN_FORCE_SESSION_INTERVAL_MS > Date.now()) {\n logger.debug(\n \"New session already forced with device \" +\n sender +\n \":\" +\n deviceKey +\n \" at \" +\n lastNewSessionForced +\n \": not forcing another\",\n );\n await this.olmDevice.recordSessionProblem(deviceKey, \"wedged\", true);\n retryDecryption();\n return;\n }\n\n // establish a new olm session with this device since we're failing to decrypt messages\n // on a current session.\n // Note that an undecryptable message from another device could easily be spoofed -\n // is there anything we can do to mitigate this?\n let device = this.deviceList.getDeviceByIdentityKey(algorithm, deviceKey);\n if (!device) {\n // if we don't know about the device, fetch the user's devices again\n // and retry before giving up\n await this.downloadKeys([sender], false);\n device = this.deviceList.getDeviceByIdentityKey(algorithm, deviceKey);\n if (!device) {\n logger.info(\"Couldn't find device for identity key \" + deviceKey + \": not re-establishing session\");\n await this.olmDevice.recordSessionProblem(deviceKey, \"wedged\", false);\n retryDecryption();\n return;\n }\n }\n const devicesByUser = new Map([[sender, [device]]]);\n await olmlib.ensureOlmSessionsForDevices(this.olmDevice, this.baseApis, devicesByUser, true);\n\n lastNewSessionDevices.set(deviceKey, Date.now());\n\n // Now send a blank message on that session so the other side knows about it.\n // (The keyshare request is sent in the clear so that won't do)\n // We send this first such that, as long as the toDevice messages arrive in the\n // same order we sent them, the other end will get this first, set up the new session,\n // then get the keyshare request and send the key over this new session (because it\n // is the session it has most recently received a message on).\n const encryptedContent: IEncryptedContent = {\n algorithm: olmlib.OLM_ALGORITHM,\n sender_key: this.olmDevice.deviceCurve25519Key!,\n ciphertext: {},\n [ToDeviceMessageId]: uuidv4(),\n };\n await olmlib.encryptMessageForDevice(\n encryptedContent.ciphertext,\n this.userId,\n this.deviceId,\n this.olmDevice,\n sender,\n device,\n { type: \"m.dummy\" },\n );\n\n await this.olmDevice.recordSessionProblem(deviceKey, \"wedged\", true);\n retryDecryption();\n\n await this.baseApis.sendToDevice(\n \"m.room.encrypted\",\n new Map([[sender, new Map([[device.deviceId, encryptedContent]])]]),\n );\n\n // Most of the time this probably won't be necessary since we'll have queued up a key request when\n // we failed to decrypt the message and will be waiting a bit for the key to arrive before sending\n // it. This won't always be the case though so we need to re-send any that have already been sent\n // to avoid races.\n const requestsToResend = await this.outgoingRoomKeyRequestManager.getOutgoingSentRoomKeyRequest(\n sender,\n device.deviceId,\n );\n for (const keyReq of requestsToResend) {\n this.requestRoomKey(keyReq.requestBody, keyReq.recipients, true);\n }\n }\n\n /**\n * Handle a change in the membership state of a member of a room\n *\n * @internal\n * @param event - event causing the change\n * @param member - user whose membership changed\n * @param oldMembership - previous membership\n */\n private onRoomMembership(event: MatrixEvent, member: RoomMember, oldMembership?: string): void {\n // this event handler is registered on the *client* (as opposed to the room\n // member itself), which means it is only called on changes to the *live*\n // membership state (ie, it is not called when we back-paginate, nor when\n // we load the state in the initialsync).\n //\n // Further, it is automatically registered and called when new members\n // arrive in the room.\n\n const roomId = member.roomId;\n\n const alg = this.roomEncryptors.get(roomId);\n if (!alg) {\n // not encrypting in this room\n return;\n }\n // only mark users in this room as tracked if we already started tracking in this room\n // this way we don't start device queries after sync on behalf of this room which we won't use\n // the result of anyway, as we'll need to do a query again once all the members are fetched\n // by calling _trackRoomDevices\n if (roomId in this.roomDeviceTrackingState) {\n if (member.membership == \"join\") {\n logger.log(\"Join event for \" + member.userId + \" in \" + roomId);\n // make sure we are tracking the deviceList for this user\n this.deviceList.startTrackingDeviceList(member.userId);\n } else if (\n member.membership == \"invite\" &&\n this.clientStore.getRoom(roomId)?.shouldEncryptForInvitedMembers()\n ) {\n logger.log(\"Invite event for \" + member.userId + \" in \" + roomId);\n this.deviceList.startTrackingDeviceList(member.userId);\n }\n }\n\n alg.onRoomMembership(event, member, oldMembership);\n }\n\n /**\n * Called when we get an m.room_key_request event.\n *\n * @internal\n * @param event - key request event\n */\n private onRoomKeyRequestEvent(event: MatrixEvent): void {\n const content = event.getContent();\n if (content.action === \"request\") {\n // Queue it up for now, because they tend to arrive before the room state\n // events at initial sync, and we want to see if we know anything about the\n // room before passing them on to the app.\n const req = new IncomingRoomKeyRequest(event);\n this.receivedRoomKeyRequests.push(req);\n } else if (content.action === \"request_cancellation\") {\n const req = new IncomingRoomKeyRequestCancellation(event);\n this.receivedRoomKeyRequestCancellations.push(req);\n }\n }\n\n /**\n * Process any m.room_key_request events which were queued up during the\n * current sync.\n *\n * @internal\n */\n private async processReceivedRoomKeyRequests(): Promise {\n if (this.processingRoomKeyRequests) {\n // we're still processing last time's requests; keep queuing new ones\n // up for now.\n return;\n }\n this.processingRoomKeyRequests = true;\n\n try {\n // we need to grab and clear the queues in the synchronous bit of this method,\n // so that we don't end up racing with the next /sync.\n const requests = this.receivedRoomKeyRequests;\n this.receivedRoomKeyRequests = [];\n const cancellations = this.receivedRoomKeyRequestCancellations;\n this.receivedRoomKeyRequestCancellations = [];\n\n // Process all of the requests, *then* all of the cancellations.\n //\n // This makes sure that if we get a request and its cancellation in the\n // same /sync result, then we process the request before the\n // cancellation (and end up with a cancelled request), rather than the\n // cancellation before the request (and end up with an outstanding\n // request which should have been cancelled.)\n await Promise.all(requests.map((req) => this.processReceivedRoomKeyRequest(req)));\n await Promise.all(\n cancellations.map((cancellation) => this.processReceivedRoomKeyRequestCancellation(cancellation)),\n );\n } catch (e) {\n logger.error(`Error processing room key requsts: ${e}`);\n } finally {\n this.processingRoomKeyRequests = false;\n }\n }\n\n /**\n * Helper for processReceivedRoomKeyRequests\n *\n */\n private async processReceivedRoomKeyRequest(req: IncomingRoomKeyRequest): Promise {\n const userId = req.userId;\n const deviceId = req.deviceId;\n\n const body = req.requestBody;\n const roomId = body.room_id;\n const alg = body.algorithm;\n\n logger.log(\n `m.room_key_request from ${userId}:${deviceId}` +\n ` for ${roomId} / ${body.session_id} (id ${req.requestId})`,\n );\n\n if (userId !== this.userId) {\n if (!this.roomEncryptors.get(roomId)) {\n logger.debug(`room key request for unencrypted room ${roomId}`);\n return;\n }\n const encryptor = this.roomEncryptors.get(roomId)!;\n const device = this.deviceList.getStoredDevice(userId, deviceId);\n if (!device) {\n logger.debug(`Ignoring keyshare for unknown device ${userId}:${deviceId}`);\n return;\n }\n\n try {\n await encryptor.reshareKeyWithDevice!(body.sender_key, body.session_id, userId, device);\n } catch (e) {\n logger.warn(\n \"Failed to re-share keys for session \" +\n body.session_id +\n \" with device \" +\n userId +\n \":\" +\n device.deviceId,\n e,\n );\n }\n return;\n }\n\n if (deviceId === this.deviceId) {\n // We'll always get these because we send room key requests to\n // '*' (ie. 'all devices') which includes the sending device,\n // so ignore requests from ourself because apart from it being\n // very silly, it won't work because an Olm session cannot send\n // messages to itself.\n // The log here is probably superfluous since we know this will\n // always happen, but let's log anyway for now just in case it\n // causes issues.\n logger.log(\"Ignoring room key request from ourselves\");\n return;\n }\n\n // todo: should we queue up requests we don't yet have keys for,\n // in case they turn up later?\n\n // if we don't have a decryptor for this room/alg, we don't have\n // the keys for the requested events, and can drop the requests.\n if (!this.roomDecryptors.has(roomId)) {\n logger.log(`room key request for unencrypted room ${roomId}`);\n return;\n }\n\n const decryptor = this.roomDecryptors.get(roomId)!.get(alg);\n if (!decryptor) {\n logger.log(`room key request for unknown alg ${alg} in room ${roomId}`);\n return;\n }\n\n if (!(await decryptor.hasKeysForKeyRequest(req))) {\n logger.log(`room key request for unknown session ${roomId} / ` + body.session_id);\n return;\n }\n\n req.share = (): void => {\n decryptor.shareKeysWithDevice(req);\n };\n\n // if the device is verified already, share the keys\n if (this.checkDeviceTrust(userId, deviceId).isVerified()) {\n logger.log(\"device is already verified: sharing keys\");\n req.share();\n return;\n }\n\n this.emit(CryptoEvent.RoomKeyRequest, req);\n }\n\n /**\n * Helper for processReceivedRoomKeyRequests\n *\n */\n private async processReceivedRoomKeyRequestCancellation(\n cancellation: IncomingRoomKeyRequestCancellation,\n ): Promise {\n logger.log(\n `m.room_key_request cancellation for ${cancellation.userId}:` +\n `${cancellation.deviceId} (id ${cancellation.requestId})`,\n );\n\n // we should probably only notify the app of cancellations we told it\n // about, but we don't currently have a record of that, so we just pass\n // everything through.\n this.emit(CryptoEvent.RoomKeyRequestCancellation, cancellation);\n }\n\n /**\n * Get a decryptor for a given room and algorithm.\n *\n * If we already have a decryptor for the given room and algorithm, return\n * it. Otherwise try to instantiate it.\n *\n * @internal\n *\n * @param roomId - room id for decryptor. If undefined, a temporary\n * decryptor is instantiated.\n *\n * @param algorithm - crypto algorithm\n *\n * @throws {@link DecryptionError} if the algorithm is unknown\n */\n public getRoomDecryptor(roomId: string | null, algorithm: string): DecryptionAlgorithm {\n let decryptors: Map | undefined;\n let alg: DecryptionAlgorithm | undefined;\n\n if (roomId) {\n decryptors = this.roomDecryptors.get(roomId);\n if (!decryptors) {\n decryptors = new Map();\n this.roomDecryptors.set(roomId, decryptors);\n }\n\n alg = decryptors.get(algorithm);\n if (alg) {\n return alg;\n }\n }\n\n const AlgClass = algorithms.DECRYPTION_CLASSES.get(algorithm);\n if (!AlgClass) {\n throw new algorithms.DecryptionError(\n \"UNKNOWN_ENCRYPTION_ALGORITHM\",\n 'Unknown encryption algorithm \"' + algorithm + '\".',\n );\n }\n alg = new AlgClass({\n userId: this.userId,\n crypto: this,\n olmDevice: this.olmDevice,\n baseApis: this.baseApis,\n roomId: roomId ?? undefined,\n });\n\n if (decryptors) {\n decryptors.set(algorithm, alg);\n }\n return alg;\n }\n\n /**\n * Get all the room decryptors for a given encryption algorithm.\n *\n * @param algorithm - The encryption algorithm\n *\n * @returns An array of room decryptors\n */\n private getRoomDecryptors(algorithm: string): DecryptionAlgorithm[] {\n const decryptors: DecryptionAlgorithm[] = [];\n for (const d of this.roomDecryptors.values()) {\n if (d.has(algorithm)) {\n decryptors.push(d.get(algorithm)!);\n }\n }\n return decryptors;\n }\n\n /**\n * sign the given object with our ed25519 key\n *\n * @param obj - Object to which we will add a 'signatures' property\n */\n public async signObject(obj: T): Promise {\n const sigs = new Map(Object.entries(obj.signatures || {}));\n const unsigned = obj.unsigned;\n\n delete obj.signatures;\n delete obj.unsigned;\n\n const userSignatures = sigs.get(this.userId) || {};\n sigs.set(this.userId, userSignatures);\n userSignatures[\"ed25519:\" + this.deviceId] = await this.olmDevice.sign(anotherjson.stringify(obj));\n obj.signatures = recursiveMapToObject(sigs);\n if (unsigned !== undefined) obj.unsigned = unsigned;\n }\n}\n\n/**\n * Fix up the backup key, that may be in the wrong format due to a bug in a\n * migration step. Some backup keys were stored as a comma-separated list of\n * integers, rather than a base64-encoded byte array. If this function is\n * passed a string that looks like a list of integers rather than a base64\n * string, it will attempt to convert it to the right format.\n *\n * @param key - the key to check\n * @returns If the key is in the wrong format, then the fixed\n * key will be returned. Otherwise null will be returned.\n *\n */\nexport function fixBackupKey(key?: string): string | null {\n if (typeof key !== \"string\" || key.indexOf(\",\") < 0) {\n return null;\n }\n const fixedKey = Uint8Array.from(key.split(\",\"), (x) => parseInt(x));\n return olmlib.encodeBase64(fixedKey);\n}\n\n/**\n * Represents a received m.room_key_request event\n */\nexport class IncomingRoomKeyRequest {\n /** user requesting the key */\n public readonly userId: string;\n /** device requesting the key */\n public readonly deviceId: string;\n /** unique id for the request */\n public readonly requestId: string;\n public readonly requestBody: IRoomKeyRequestBody;\n /**\n * callback which, when called, will ask\n * the relevant crypto algorithm implementation to share the keys for\n * this request.\n */\n public share: () => void;\n\n public constructor(event: MatrixEvent) {\n const content = event.getContent();\n\n this.userId = event.getSender()!;\n this.deviceId = content.requesting_device_id;\n this.requestId = content.request_id;\n this.requestBody = content.body || {};\n this.share = (): void => {\n throw new Error(\"don't know how to share keys for this request yet\");\n };\n }\n}\n\n/**\n * Represents a received m.room_key_request cancellation\n */\nclass IncomingRoomKeyRequestCancellation {\n /** user requesting the cancellation */\n public readonly userId: string;\n /** device requesting the cancellation */\n public readonly deviceId: string;\n /** unique id for the request to be cancelled */\n public readonly requestId: string;\n\n public constructor(event: MatrixEvent) {\n const content = event.getContent();\n\n this.userId = event.getSender()!;\n this.deviceId = content.requesting_device_id;\n this.requestId = content.request_id;\n }\n}\n\n// a number of types are re-exported for backwards compatibility, in case any applications are referencing it.\nexport type { IEventDecryptionResult, IMegolmSessionData } from \"../@types/crypto\";\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts deleted file mode 100644 index 0ca19fd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -interface IAuthData { - private_key_salt?: string; - private_key_iterations?: number; - private_key_bits?: number; -} -interface IKey { - key: Uint8Array; - salt: string; - iterations: number; -} -export declare function keyFromAuthData(authData: IAuthData, password: string): Promise; -export declare function keyFromPassphrase(password: string): Promise; -export declare function deriveKey(password: string, salt: string, iterations: number, numBits?: number): Promise; -export {}; -//# sourceMappingURL=key_passphrase.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts.map deleted file mode 100644 index dd8646a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"key_passphrase.d.ts","sourceRoot":"","sources":["../../src/crypto/key_passphrase.ts"],"names":[],"mappings":"AAwBA,UAAU,SAAS;IACf,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAGD,UAAU,IAAI;IACV,GAAG,EAAE,UAAU,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;CACtB;AAED,wBAAgB,eAAe,CAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAe1F;AAED,wBAAsB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAUvE;AAED,wBAAsB,SAAS,CAC3B,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,MAAM,EACZ,UAAU,EAAE,MAAM,EAClB,OAAO,SAAkB,GAC1B,OAAO,CAAC,UAAU,CAAC,CAqBrB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js deleted file mode 100644 index 4ebe4ec..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js +++ /dev/null @@ -1,68 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.deriveKey = deriveKey; -exports.keyFromAuthData = keyFromAuthData; -exports.keyFromPassphrase = keyFromPassphrase; -var _randomstring = require("../randomstring"); -var _crypto = require("./crypto"); -/* -Copyright 2018 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const DEFAULT_ITERATIONS = 500000; -const DEFAULT_BITSIZE = 256; - -/* eslint-disable camelcase */ - -function keyFromAuthData(authData, password) { - if (!global.Olm) { - throw new Error("Olm is not available"); - } - if (!authData.private_key_salt || !authData.private_key_iterations) { - throw new Error("Salt and/or iterations not found: " + "this backup cannot be restored with a passphrase"); - } - return deriveKey(password, authData.private_key_salt, authData.private_key_iterations, authData.private_key_bits || DEFAULT_BITSIZE); -} -async function keyFromPassphrase(password) { - if (!global.Olm) { - throw new Error("Olm is not available"); - } - const salt = (0, _randomstring.randomString)(32); - const key = await deriveKey(password, salt, DEFAULT_ITERATIONS, DEFAULT_BITSIZE); - return { - key, - salt, - iterations: DEFAULT_ITERATIONS - }; -} -async function deriveKey(password, salt, iterations, numBits = DEFAULT_BITSIZE) { - if (!_crypto.subtleCrypto || !_crypto.TextEncoder) { - throw new Error("Password-based backup is not available on this platform"); - } - const key = await _crypto.subtleCrypto.importKey("raw", new _crypto.TextEncoder().encode(password), { - name: "PBKDF2" - }, false, ["deriveBits"]); - const keybits = await _crypto.subtleCrypto.deriveBits({ - name: "PBKDF2", - salt: new _crypto.TextEncoder().encode(salt), - iterations: iterations, - hash: "SHA-512" - }, key, numBits); - return new Uint8Array(keybits); -} -//# sourceMappingURL=key_passphrase.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js.map deleted file mode 100644 index 9429e8b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/key_passphrase.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"key_passphrase.js","names":["_randomstring","require","_crypto","DEFAULT_ITERATIONS","DEFAULT_BITSIZE","keyFromAuthData","authData","password","global","Olm","Error","private_key_salt","private_key_iterations","deriveKey","private_key_bits","keyFromPassphrase","salt","randomString","key","iterations","numBits","subtleCrypto","TextEncoder","importKey","encode","name","keybits","deriveBits","hash","Uint8Array"],"sources":["../../src/crypto/key_passphrase.ts"],"sourcesContent":["/*\nCopyright 2018 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { randomString } from \"../randomstring\";\nimport { subtleCrypto, TextEncoder } from \"./crypto\";\n\nconst DEFAULT_ITERATIONS = 500000;\n\nconst DEFAULT_BITSIZE = 256;\n\n/* eslint-disable camelcase */\ninterface IAuthData {\n private_key_salt?: string;\n private_key_iterations?: number;\n private_key_bits?: number;\n}\n/* eslint-enable camelcase */\n\ninterface IKey {\n key: Uint8Array;\n salt: string;\n iterations: number;\n}\n\nexport function keyFromAuthData(authData: IAuthData, password: string): Promise {\n if (!global.Olm) {\n throw new Error(\"Olm is not available\");\n }\n\n if (!authData.private_key_salt || !authData.private_key_iterations) {\n throw new Error(\"Salt and/or iterations not found: \" + \"this backup cannot be restored with a passphrase\");\n }\n\n return deriveKey(\n password,\n authData.private_key_salt,\n authData.private_key_iterations,\n authData.private_key_bits || DEFAULT_BITSIZE,\n );\n}\n\nexport async function keyFromPassphrase(password: string): Promise {\n if (!global.Olm) {\n throw new Error(\"Olm is not available\");\n }\n\n const salt = randomString(32);\n\n const key = await deriveKey(password, salt, DEFAULT_ITERATIONS, DEFAULT_BITSIZE);\n\n return { key, salt, iterations: DEFAULT_ITERATIONS };\n}\n\nexport async function deriveKey(\n password: string,\n salt: string,\n iterations: number,\n numBits = DEFAULT_BITSIZE,\n): Promise {\n if (!subtleCrypto || !TextEncoder) {\n throw new Error(\"Password-based backup is not available on this platform\");\n }\n\n const key = await subtleCrypto.importKey(\"raw\", new TextEncoder().encode(password), { name: \"PBKDF2\" }, false, [\n \"deriveBits\",\n ]);\n\n const keybits = await subtleCrypto.deriveBits(\n {\n name: \"PBKDF2\",\n salt: new TextEncoder().encode(salt),\n iterations: iterations,\n hash: \"SHA-512\",\n },\n key,\n numBits,\n );\n\n return new Uint8Array(keybits);\n}\n"],"mappings":";;;;;;;;AAgBA,IAAAA,aAAA,GAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AAjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAKA,MAAME,kBAAkB,GAAG,MAAM;AAEjC,MAAMC,eAAe,GAAG,GAAG;;AAE3B;;AAcO,SAASC,eAAeA,CAACC,QAAmB,EAAEC,QAAgB,EAAuB;EACxF,IAAI,CAACC,MAAM,CAACC,GAAG,EAAE;IACb,MAAM,IAAIC,KAAK,CAAC,sBAAsB,CAAC;EAC3C;EAEA,IAAI,CAACJ,QAAQ,CAACK,gBAAgB,IAAI,CAACL,QAAQ,CAACM,sBAAsB,EAAE;IAChE,MAAM,IAAIF,KAAK,CAAC,oCAAoC,GAAG,kDAAkD,CAAC;EAC9G;EAEA,OAAOG,SAAS,CACZN,QAAQ,EACRD,QAAQ,CAACK,gBAAgB,EACzBL,QAAQ,CAACM,sBAAsB,EAC/BN,QAAQ,CAACQ,gBAAgB,IAAIV,eAAe,CAC/C;AACL;AAEO,eAAeW,iBAAiBA,CAACR,QAAgB,EAAiB;EACrE,IAAI,CAACC,MAAM,CAACC,GAAG,EAAE;IACb,MAAM,IAAIC,KAAK,CAAC,sBAAsB,CAAC;EAC3C;EAEA,MAAMM,IAAI,GAAG,IAAAC,0BAAY,EAAC,EAAE,CAAC;EAE7B,MAAMC,GAAG,GAAG,MAAML,SAAS,CAACN,QAAQ,EAAES,IAAI,EAAEb,kBAAkB,EAAEC,eAAe,CAAC;EAEhF,OAAO;IAAEc,GAAG;IAAEF,IAAI;IAAEG,UAAU,EAAEhB;EAAmB,CAAC;AACxD;AAEO,eAAeU,SAASA,CAC3BN,QAAgB,EAChBS,IAAY,EACZG,UAAkB,EAClBC,OAAO,GAAGhB,eAAe,EACN;EACnB,IAAI,CAACiB,oBAAY,IAAI,CAACC,mBAAW,EAAE;IAC/B,MAAM,IAAIZ,KAAK,CAAC,yDAAyD,CAAC;EAC9E;EAEA,MAAMQ,GAAG,GAAG,MAAMG,oBAAY,CAACE,SAAS,CAAC,KAAK,EAAE,IAAID,mBAAW,EAAE,CAACE,MAAM,CAACjB,QAAQ,CAAC,EAAE;IAAEkB,IAAI,EAAE;EAAS,CAAC,EAAE,KAAK,EAAE,CAC3G,YAAY,CACf,CAAC;EAEF,MAAMC,OAAO,GAAG,MAAML,oBAAY,CAACM,UAAU,CACzC;IACIF,IAAI,EAAE,QAAQ;IACdT,IAAI,EAAE,IAAIM,mBAAW,EAAE,CAACE,MAAM,CAACR,IAAI,CAAC;IACpCG,UAAU,EAAEA,UAAU;IACtBS,IAAI,EAAE;EACV,CAAC,EACDV,GAAG,EACHE,OAAO,CACV;EAED,OAAO,IAAIS,UAAU,CAACH,OAAO,CAAC;AAClC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts deleted file mode 100644 index 3e46e9e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts +++ /dev/null @@ -1,53 +0,0 @@ -import { ISigned } from "../@types/signed"; -import { IEncryptedPayload } from "./aes"; -export interface Curve25519SessionData { - ciphertext: string; - ephemeral: string; - mac: string; -} -export interface IKeyBackupSession { - first_message_index: number; - forwarded_count: number; - is_verified: boolean; - session_data: T; -} -export interface IKeyBackupRoomSessions { - [sessionId: string]: IKeyBackupSession; -} -export interface ICurve25519AuthData { - public_key: string; - private_key_salt?: string; - private_key_iterations?: number; - private_key_bits?: number; -} -export interface IAes256AuthData { - iv: string; - mac: string; - private_key_salt?: string; - private_key_iterations?: number; -} -export interface IKeyBackupInfo { - algorithm: string; - auth_data: ISigned & (ICurve25519AuthData | IAes256AuthData); - count?: number; - etag?: string; - version?: string; -} -export interface IKeyBackupPrepareOpts { - /** - * Whether to use Secure Secret Storage to store the key encrypting key backups. - * Optional, defaults to false. - */ - secureSecretStorage: boolean; -} -export interface IKeyBackupRestoreResult { - total: number; - imported: number; -} -export interface IKeyBackupRestoreOpts { - cacheCompleteCallback?: () => void; - progressCallback?: (progress: { - stage: string; - }) => void; -} -//# sourceMappingURL=keybackup.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts.map deleted file mode 100644 index 0d54fcc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"keybackup.d.ts","sourceRoot":"","sources":["../../src/crypto/keybackup.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAE1C,MAAM,WAAW,qBAAqB;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,GAAG,EAAE,MAAM,CAAC;CACf;AAGD,MAAM,WAAW,iBAAiB,CAAC,CAAC,GAAG,qBAAqB,GAAG,iBAAiB;IAC5E,mBAAmB,EAAE,MAAM,CAAC;IAC5B,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,OAAO,CAAC;IACrB,YAAY,EAAE,CAAC,CAAC;CACnB;AAED,MAAM,WAAW,sBAAsB;IACnC,CAAC,SAAS,EAAE,MAAM,GAAG,iBAAiB,CAAC;CAC1C;AAED,MAAM,WAAW,mBAAmB;IAChC,UAAU,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,eAAe;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,MAAM,CAAC;IACZ,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,sBAAsB,CAAC,EAAE,MAAM,CAAC;CACnC;AAED,MAAM,WAAW,cAAc;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,OAAO,GAAG,CAAC,mBAAmB,GAAG,eAAe,CAAC,CAAC;IAC7D,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;CACpB;AAGD,MAAM,WAAW,qBAAqB;IAClC;;;OAGG;IACH,mBAAmB,EAAE,OAAO,CAAC;CAChC;AAED,MAAM,WAAW,uBAAuB;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,qBAAqB;IAClC,qBAAqB,CAAC,EAAE,MAAM,IAAI,CAAC;IACnC,gBAAgB,CAAC,EAAE,CAAC,QAAQ,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;CAC5D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js deleted file mode 100644 index ad0a8ab..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=keybackup.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js.map deleted file mode 100644 index e54a145..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/keybackup.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"keybackup.js","names":[],"sources":["../../src/crypto/keybackup.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ISigned } from \"../@types/signed\";\nimport { IEncryptedPayload } from \"./aes\";\n\nexport interface Curve25519SessionData {\n ciphertext: string;\n ephemeral: string;\n mac: string;\n}\n\n/* eslint-disable camelcase */\nexport interface IKeyBackupSession {\n first_message_index: number;\n forwarded_count: number;\n is_verified: boolean;\n session_data: T;\n}\n\nexport interface IKeyBackupRoomSessions {\n [sessionId: string]: IKeyBackupSession;\n}\n\nexport interface ICurve25519AuthData {\n public_key: string;\n private_key_salt?: string;\n private_key_iterations?: number;\n private_key_bits?: number;\n}\n\nexport interface IAes256AuthData {\n iv: string;\n mac: string;\n private_key_salt?: string;\n private_key_iterations?: number;\n}\n\nexport interface IKeyBackupInfo {\n algorithm: string;\n auth_data: ISigned & (ICurve25519AuthData | IAes256AuthData);\n count?: number;\n etag?: string;\n version?: string; // number contained within\n}\n/* eslint-enable camelcase */\n\nexport interface IKeyBackupPrepareOpts {\n /**\n * Whether to use Secure Secret Storage to store the key encrypting key backups.\n * Optional, defaults to false.\n */\n secureSecretStorage: boolean;\n}\n\nexport interface IKeyBackupRestoreResult {\n total: number;\n imported: number;\n}\n\nexport interface IKeyBackupRestoreOpts {\n cacheCompleteCallback?: () => void;\n progressCallback?: (progress: { stage: string }) => void;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts deleted file mode 100644 index 18ee3c9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts +++ /dev/null @@ -1,146 +0,0 @@ -import type { PkSigning } from "@matrix-org/olm"; -import type { IOneTimeKey } from "../@types/crypto"; -import { OlmDevice } from "./OlmDevice"; -import { DeviceInfo } from "./deviceinfo"; -import { MatrixClient } from "../client"; -import { ISignatures } from "../@types/signed"; -import { MatrixEvent } from "../models/event"; -import { IMessage } from "./algorithms/olm"; -declare enum Algorithm { - Olm = "m.olm.v1.curve25519-aes-sha2", - Megolm = "m.megolm.v1.aes-sha2", - MegolmBackup = "m.megolm_backup.v1.curve25519-aes-sha2" -} -/** - * matrix algorithm tag for olm - */ -export declare const OLM_ALGORITHM = Algorithm.Olm; -/** - * matrix algorithm tag for megolm - */ -export declare const MEGOLM_ALGORITHM = Algorithm.Megolm; -/** - * matrix algorithm tag for megolm backups - */ -export declare const MEGOLM_BACKUP_ALGORITHM = Algorithm.MegolmBackup; -export interface IOlmSessionResult { - /** device info */ - device: DeviceInfo; - /** base64 olm session id; null if no session could be established */ - sessionId: string | null; -} -/** - * Encrypt an event payload for an Olm device - * - * @param resultsObject - The `ciphertext` property - * of the m.room.encrypted event to which to add our result - * - * @param olmDevice - olm.js wrapper - * @param payloadFields - fields to include in the encrypted payload - * - * Returns a promise which resolves (to undefined) when the payload - * has been encrypted into `resultsObject` - */ -export declare function encryptMessageForDevice(resultsObject: Record, ourUserId: string, ourDeviceId: string | undefined, olmDevice: OlmDevice, recipientUserId: string, recipientDevice: DeviceInfo, payloadFields: Record): Promise; -interface IExistingOlmSession { - device: DeviceInfo; - sessionId: string | null; -} -/** - * Get the existing olm sessions for the given devices, and the devices that - * don't have olm sessions. - * - * - * - * @param devicesByUser - map from userid to list of devices to ensure sessions for - * - * @returns resolves to an array. The first element of the array is a - * a map of user IDs to arrays of deviceInfo, representing the devices that - * don't have established olm sessions. The second element of the array is - * a map from userId to deviceId to {@link OlmSessionResult} - */ -export declare function getExistingOlmSessions(olmDevice: OlmDevice, baseApis: MatrixClient, devicesByUser: Record): Promise<[Map, Map>]>; -/** - * Try to make sure we have established olm sessions for the given devices. - * - * @param devicesByUser - map from userid to list of devices to ensure sessions for - * - * @param force - If true, establish a new session even if one - * already exists. - * - * @param otkTimeout - The timeout in milliseconds when requesting - * one-time keys for establishing new olm sessions. - * - * @param failedServers - An array to fill with remote servers that - * failed to respond to one-time-key requests. - * - * @param log - A possibly customised log - * - * @returns resolves once the sessions are complete, to - * an Object mapping from userId to deviceId to - * {@link OlmSessionResult} - */ -export declare function ensureOlmSessionsForDevices(olmDevice: OlmDevice, baseApis: MatrixClient, devicesByUser: Map, force?: boolean, otkTimeout?: number, failedServers?: string[], log?: import("../logger").PrefixedLogger): Promise>>; -export interface IObject { - unsigned?: object; - signatures?: ISignatures; -} -/** - * Verify the signature on an object - * - * @param olmDevice - olm wrapper to use for verify op - * - * @param obj - object to check signature on. - * - * @param signingUserId - ID of the user whose signature should be checked - * - * @param signingDeviceId - ID of the device whose signature should be checked - * - * @param signingKey - base64-ed ed25519 public key - * - * Returns a promise which resolves (to undefined) if the the signature is good, - * or rejects with an Error if it is bad. - */ -export declare function verifySignature(olmDevice: OlmDevice, obj: IOneTimeKey | IObject, signingUserId: string, signingDeviceId: string, signingKey: string): Promise; -/** - * Sign a JSON object using public key cryptography - * @param obj - Object to sign. The object will be modified to include - * the new signature - * @param key - the signing object or the private key - * seed - * @param userId - The user ID who owns the signing key - * @param pubKey - The public key (ignored if key is a seed) - * @returns the signature for the object - */ -export declare function pkSign(obj: object & IObject, key: Uint8Array | PkSigning, userId: string, pubKey: string): string; -/** - * Verify a signed JSON object - * @param obj - Object to verify - * @param pubKey - The public key to use to verify - * @param userId - The user ID who signed the object - */ -export declare function pkVerify(obj: IObject, pubKey: string, userId: string): void; -/** - * Check that an event was encrypted using olm. - */ -export declare function isOlmEncrypted(event: MatrixEvent): boolean; -/** - * Encode a typed array of uint8 as base64. - * @param uint8Array - The data to encode. - * @returns The base64. - */ -export declare function encodeBase64(uint8Array: ArrayBuffer | Uint8Array): string; -/** - * Encode a typed array of uint8 as unpadded base64. - * @param uint8Array - The data to encode. - * @returns The unpadded base64. - */ -export declare function encodeUnpaddedBase64(uint8Array: ArrayBuffer | Uint8Array): string; -/** - * Decode a base64 string to a typed array of uint8. - * @param base64 - The base64 to decode. - * @returns The decoded data. - */ -export declare function decodeBase64(base64: string): Uint8Array; -export {}; -//# sourceMappingURL=olmlib.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts.map deleted file mode 100644 index 684b819..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"olmlib.d.ts","sourceRoot":"","sources":["../../src/crypto/olmlib.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js deleted file mode 100644 index 0b5b14c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js +++ /dev/null @@ -1,467 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.OLM_ALGORITHM = exports.MEGOLM_BACKUP_ALGORITHM = exports.MEGOLM_ALGORITHM = void 0; -exports.decodeBase64 = decodeBase64; -exports.encodeBase64 = encodeBase64; -exports.encodeUnpaddedBase64 = encodeUnpaddedBase64; -exports.encryptMessageForDevice = encryptMessageForDevice; -exports.ensureOlmSessionsForDevices = ensureOlmSessionsForDevices; -exports.getExistingOlmSessions = getExistingOlmSessions; -exports.isOlmEncrypted = isOlmEncrypted; -exports.pkSign = pkSign; -exports.pkVerify = pkVerify; -exports.verifySignature = verifySignature; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _anotherJson = _interopRequireDefault(require("another-json")); -var _logger = require("../logger"); -var _event = require("../@types/event"); -var _utils = require("../utils"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -var Algorithm; -/** - * matrix algorithm tag for olm - */ -(function (Algorithm) { - Algorithm["Olm"] = "m.olm.v1.curve25519-aes-sha2"; - Algorithm["Megolm"] = "m.megolm.v1.aes-sha2"; - Algorithm["MegolmBackup"] = "m.megolm_backup.v1.curve25519-aes-sha2"; -})(Algorithm || (Algorithm = {})); -const OLM_ALGORITHM = Algorithm.Olm; - -/** - * matrix algorithm tag for megolm - */ -exports.OLM_ALGORITHM = OLM_ALGORITHM; -const MEGOLM_ALGORITHM = Algorithm.Megolm; - -/** - * matrix algorithm tag for megolm backups - */ -exports.MEGOLM_ALGORITHM = MEGOLM_ALGORITHM; -const MEGOLM_BACKUP_ALGORITHM = Algorithm.MegolmBackup; -exports.MEGOLM_BACKUP_ALGORITHM = MEGOLM_BACKUP_ALGORITHM; -/** - * Encrypt an event payload for an Olm device - * - * @param resultsObject - The `ciphertext` property - * of the m.room.encrypted event to which to add our result - * - * @param olmDevice - olm.js wrapper - * @param payloadFields - fields to include in the encrypted payload - * - * Returns a promise which resolves (to undefined) when the payload - * has been encrypted into `resultsObject` - */ -async function encryptMessageForDevice(resultsObject, ourUserId, ourDeviceId, olmDevice, recipientUserId, recipientDevice, payloadFields) { - const deviceKey = recipientDevice.getIdentityKey(); - const sessionId = await olmDevice.getSessionIdForDevice(deviceKey); - if (sessionId === null) { - // If we don't have a session for a device then - // we can't encrypt a message for it. - _logger.logger.log(`[olmlib.encryptMessageForDevice] Unable to find Olm session for device ` + `${recipientUserId}:${recipientDevice.deviceId}`); - return; - } - _logger.logger.log(`[olmlib.encryptMessageForDevice] Using Olm session ${sessionId} for device ` + `${recipientUserId}:${recipientDevice.deviceId}`); - const payload = _objectSpread({ - sender: ourUserId, - // TODO this appears to no longer be used whatsoever - sender_device: ourDeviceId, - // Include the Ed25519 key so that the recipient knows what - // device this message came from. - // We don't need to include the curve25519 key since the - // recipient will already know this from the olm headers. - // When combined with the device keys retrieved from the - // homeserver signed by the ed25519 key this proves that - // the curve25519 key and the ed25519 key are owned by - // the same device. - keys: { - ed25519: olmDevice.deviceEd25519Key - }, - // include the recipient device details in the payload, - // to avoid unknown key attacks, per - // https://github.com/vector-im/vector-web/issues/2483 - recipient: recipientUserId, - recipient_keys: { - ed25519: recipientDevice.getFingerprint() - } - }, payloadFields); - - // TODO: technically, a bunch of that stuff only needs to be included for - // pre-key messages: after that, both sides know exactly which devices are - // involved in the session. If we're looking to reduce data transfer in the - // future, we could elide them for subsequent messages. - - resultsObject[deviceKey] = await olmDevice.encryptMessage(deviceKey, sessionId, JSON.stringify(payload)); -} -/** - * Get the existing olm sessions for the given devices, and the devices that - * don't have olm sessions. - * - * - * - * @param devicesByUser - map from userid to list of devices to ensure sessions for - * - * @returns resolves to an array. The first element of the array is a - * a map of user IDs to arrays of deviceInfo, representing the devices that - * don't have established olm sessions. The second element of the array is - * a map from userId to deviceId to {@link OlmSessionResult} - */ -async function getExistingOlmSessions(olmDevice, baseApis, devicesByUser) { - // map user Id → DeviceInfo[] - const devicesWithoutSession = new _utils.MapWithDefault(() => []); - // map user Id → device Id → IExistingOlmSession - const sessions = new _utils.MapWithDefault(() => new Map()); - const promises = []; - for (const [userId, devices] of Object.entries(devicesByUser)) { - for (const deviceInfo of devices) { - const deviceId = deviceInfo.deviceId; - const key = deviceInfo.getIdentityKey(); - promises.push((async () => { - const sessionId = await olmDevice.getSessionIdForDevice(key, true); - if (sessionId === null) { - devicesWithoutSession.getOrCreate(userId).push(deviceInfo); - } else { - sessions.getOrCreate(userId).set(deviceId, { - device: deviceInfo, - sessionId: sessionId - }); - } - })()); - } - } - await Promise.all(promises); - return [devicesWithoutSession, sessions]; -} - -/** - * Try to make sure we have established olm sessions for the given devices. - * - * @param devicesByUser - map from userid to list of devices to ensure sessions for - * - * @param force - If true, establish a new session even if one - * already exists. - * - * @param otkTimeout - The timeout in milliseconds when requesting - * one-time keys for establishing new olm sessions. - * - * @param failedServers - An array to fill with remote servers that - * failed to respond to one-time-key requests. - * - * @param log - A possibly customised log - * - * @returns resolves once the sessions are complete, to - * an Object mapping from userId to deviceId to - * {@link OlmSessionResult} - */ -async function ensureOlmSessionsForDevices(olmDevice, baseApis, devicesByUser, force = false, otkTimeout, failedServers, log = _logger.logger) { - const devicesWithoutSession = [ - // [userId, deviceId], ... - ]; - // map user Id → device Id → IExistingOlmSession - const result = new Map(); - // map device key → resolve session fn - const resolveSession = new Map(); - - // Mark all sessions this task intends to update as in progress. It is - // important to do this for all devices this task cares about in a single - // synchronous operation, as otherwise it is possible to have deadlocks - // where multiple tasks wait indefinitely on another task to update some set - // of common devices. - for (const devices of devicesByUser.values()) { - for (const deviceInfo of devices) { - const key = deviceInfo.getIdentityKey(); - if (key === olmDevice.deviceCurve25519Key) { - // We don't start sessions with ourself, so there's no need to - // mark it in progress. - continue; - } - if (!olmDevice.sessionsInProgress[key]) { - // pre-emptively mark the session as in-progress to avoid race - // conditions. If we find that we already have a session, then - // we'll resolve - olmDevice.sessionsInProgress[key] = new Promise(resolve => { - resolveSession.set(key, v => { - delete olmDevice.sessionsInProgress[key]; - resolve(v); - }); - }); - } - } - } - for (const [userId, devices] of devicesByUser) { - const resultDevices = new Map(); - result.set(userId, resultDevices); - for (const deviceInfo of devices) { - const deviceId = deviceInfo.deviceId; - const key = deviceInfo.getIdentityKey(); - if (key === olmDevice.deviceCurve25519Key) { - // We should never be trying to start a session with ourself. - // Apart from talking to yourself being the first sign of madness, - // olm sessions can't do this because they get confused when - // they get a message and see that the 'other side' has started a - // new chain when this side has an active sender chain. - // If you see this message being logged in the wild, we should find - // the thing that is trying to send Olm messages to itself and fix it. - log.info("Attempted to start session with ourself! Ignoring"); - // We must fill in the section in the return value though, as callers - // expect it to be there. - resultDevices.set(deviceId, { - device: deviceInfo, - sessionId: null - }); - continue; - } - const forWhom = `for ${key} (${userId}:${deviceId})`; - const sessionId = await olmDevice.getSessionIdForDevice(key, !!resolveSession.get(key), log); - const resolveSessionFn = resolveSession.get(key); - if (sessionId !== null && resolveSessionFn) { - // we found a session, but we had marked the session as - // in-progress, so resolve it now, which will unmark it and - // unblock anything that was waiting - resolveSessionFn(); - } - if (sessionId === null || force) { - if (force) { - log.info(`Forcing new Olm session ${forWhom}`); - } else { - log.info(`Making new Olm session ${forWhom}`); - } - devicesWithoutSession.push([userId, deviceId]); - } - resultDevices.set(deviceId, { - device: deviceInfo, - sessionId: sessionId - }); - } - } - if (devicesWithoutSession.length === 0) { - return result; - } - const oneTimeKeyAlgorithm = "signed_curve25519"; - let res; - let taskDetail = `one-time keys for ${devicesWithoutSession.length} devices`; - try { - log.debug(`Claiming ${taskDetail}`); - res = await baseApis.claimOneTimeKeys(devicesWithoutSession, oneTimeKeyAlgorithm, otkTimeout); - log.debug(`Claimed ${taskDetail}`); - } catch (e) { - for (const resolver of resolveSession.values()) { - resolver(); - } - log.log(`Failed to claim ${taskDetail}`, e, devicesWithoutSession); - throw e; - } - if (failedServers && "failures" in res) { - failedServers.push(...Object.keys(res.failures)); - } - const otkResult = res.one_time_keys || {}; - const promises = []; - for (const [userId, devices] of devicesByUser) { - const userRes = otkResult[userId] || {}; - for (const deviceInfo of devices) { - var _result$get, _result$get$get; - const deviceId = deviceInfo.deviceId; - const key = deviceInfo.getIdentityKey(); - if (key === olmDevice.deviceCurve25519Key) { - // We've already logged about this above. Skip here too - // otherwise we'll log saying there are no one-time keys - // which will be confusing. - continue; - } - if ((_result$get = result.get(userId)) !== null && _result$get !== void 0 && (_result$get$get = _result$get.get(deviceId)) !== null && _result$get$get !== void 0 && _result$get$get.sessionId && !force) { - // we already have a result for this device - continue; - } - const deviceRes = userRes[deviceId] || {}; - let oneTimeKey = null; - for (const keyId in deviceRes) { - if (keyId.indexOf(oneTimeKeyAlgorithm + ":") === 0) { - oneTimeKey = deviceRes[keyId]; - } - } - if (!oneTimeKey) { - var _resolveSession$get; - log.warn(`No one-time keys (alg=${oneTimeKeyAlgorithm}) ` + `for device ${userId}:${deviceId}`); - (_resolveSession$get = resolveSession.get(key)) === null || _resolveSession$get === void 0 ? void 0 : _resolveSession$get(); - continue; - } - promises.push(_verifyKeyAndStartSession(olmDevice, oneTimeKey, userId, deviceInfo).then(sid => { - var _resolveSession$get2, _result$get2; - (_resolveSession$get2 = resolveSession.get(key)) === null || _resolveSession$get2 === void 0 ? void 0 : _resolveSession$get2(sid !== null && sid !== void 0 ? sid : undefined); - const deviceInfo = (_result$get2 = result.get(userId)) === null || _result$get2 === void 0 ? void 0 : _result$get2.get(deviceId); - if (deviceInfo) deviceInfo.sessionId = sid; - }, e => { - var _resolveSession$get3; - (_resolveSession$get3 = resolveSession.get(key)) === null || _resolveSession$get3 === void 0 ? void 0 : _resolveSession$get3(); - throw e; - })); - } - } - taskDetail = `Olm sessions for ${promises.length} devices`; - log.debug(`Starting ${taskDetail}`); - await Promise.all(promises); - log.debug(`Started ${taskDetail}`); - return result; -} -async function _verifyKeyAndStartSession(olmDevice, oneTimeKey, userId, deviceInfo) { - const deviceId = deviceInfo.deviceId; - try { - await verifySignature(olmDevice, oneTimeKey, userId, deviceId, deviceInfo.getFingerprint()); - } catch (e) { - _logger.logger.error("Unable to verify signature on one-time key for device " + userId + ":" + deviceId + ":", e); - return null; - } - let sid; - try { - sid = await olmDevice.createOutboundSession(deviceInfo.getIdentityKey(), oneTimeKey.key); - } catch (e) { - // possibly a bad key - _logger.logger.error("Error starting olm session with device " + userId + ":" + deviceId + ": " + e); - return null; - } - _logger.logger.log("Started new olm sessionid " + sid + " for device " + userId + ":" + deviceId); - return sid; -} -/** - * Verify the signature on an object - * - * @param olmDevice - olm wrapper to use for verify op - * - * @param obj - object to check signature on. - * - * @param signingUserId - ID of the user whose signature should be checked - * - * @param signingDeviceId - ID of the device whose signature should be checked - * - * @param signingKey - base64-ed ed25519 public key - * - * Returns a promise which resolves (to undefined) if the the signature is good, - * or rejects with an Error if it is bad. - */ -async function verifySignature(olmDevice, obj, signingUserId, signingDeviceId, signingKey) { - const signKeyId = "ed25519:" + signingDeviceId; - const signatures = obj.signatures || {}; - const userSigs = signatures[signingUserId] || {}; - const signature = userSigs[signKeyId]; - if (!signature) { - throw Error("No signature"); - } - - // prepare the canonical json: remove unsigned and signatures, and stringify with anotherjson - const mangledObj = Object.assign({}, obj); - if ("unsigned" in mangledObj) { - delete mangledObj.unsigned; - } - delete mangledObj.signatures; - const json = _anotherJson.default.stringify(mangledObj); - olmDevice.verifySignature(signingKey, json, signature); -} - -/** - * Sign a JSON object using public key cryptography - * @param obj - Object to sign. The object will be modified to include - * the new signature - * @param key - the signing object or the private key - * seed - * @param userId - The user ID who owns the signing key - * @param pubKey - The public key (ignored if key is a seed) - * @returns the signature for the object - */ -function pkSign(obj, key, userId, pubKey) { - let createdKey = false; - if (key instanceof Uint8Array) { - const keyObj = new global.Olm.PkSigning(); - pubKey = keyObj.init_with_seed(key); - key = keyObj; - createdKey = true; - } - const sigs = obj.signatures || {}; - delete obj.signatures; - const unsigned = obj.unsigned; - if (obj.unsigned) delete obj.unsigned; - try { - const mysigs = sigs[userId] || {}; - sigs[userId] = mysigs; - return mysigs["ed25519:" + pubKey] = key.sign(_anotherJson.default.stringify(obj)); - } finally { - obj.signatures = sigs; - if (unsigned) obj.unsigned = unsigned; - if (createdKey) { - key.free(); - } - } -} - -/** - * Verify a signed JSON object - * @param obj - Object to verify - * @param pubKey - The public key to use to verify - * @param userId - The user ID who signed the object - */ -function pkVerify(obj, pubKey, userId) { - const keyId = "ed25519:" + pubKey; - if (!(obj.signatures && obj.signatures[userId] && obj.signatures[userId][keyId])) { - throw new Error("No signature"); - } - const signature = obj.signatures[userId][keyId]; - const util = new global.Olm.Utility(); - const sigs = obj.signatures; - delete obj.signatures; - const unsigned = obj.unsigned; - if (obj.unsigned) delete obj.unsigned; - try { - util.ed25519_verify(pubKey, _anotherJson.default.stringify(obj), signature); - } finally { - obj.signatures = sigs; - if (unsigned) obj.unsigned = unsigned; - util.free(); - } -} - -/** - * Check that an event was encrypted using olm. - */ -function isOlmEncrypted(event) { - if (!event.getSenderKey()) { - _logger.logger.error("Event has no sender key (not encrypted?)"); - return false; - } - if (event.getWireType() !== _event.EventType.RoomMessageEncrypted || !["m.olm.v1.curve25519-aes-sha2"].includes(event.getWireContent().algorithm)) { - _logger.logger.error("Event was not encrypted using an appropriate algorithm"); - return false; - } - return true; -} - -/** - * Encode a typed array of uint8 as base64. - * @param uint8Array - The data to encode. - * @returns The base64. - */ -function encodeBase64(uint8Array) { - return Buffer.from(uint8Array).toString("base64"); -} - -/** - * Encode a typed array of uint8 as unpadded base64. - * @param uint8Array - The data to encode. - * @returns The unpadded base64. - */ -function encodeUnpaddedBase64(uint8Array) { - return encodeBase64(uint8Array).replace(/=+$/g, ""); -} - -/** - * Decode a base64 string to a typed array of uint8. - * @param base64 - The base64 to decode. - * @returns The decoded data. - */ -function decodeBase64(base64) { - return Buffer.from(base64, "base64"); -} -//# sourceMappingURL=olmlib.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js.map deleted file mode 100644 index ebd886f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/olmlib.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"olmlib.js","names":["_anotherJson","_interopRequireDefault","require","_logger","_event","_utils","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","Algorithm","OLM_ALGORITHM","Olm","exports","MEGOLM_ALGORITHM","Megolm","MEGOLM_BACKUP_ALGORITHM","MegolmBackup","encryptMessageForDevice","resultsObject","ourUserId","ourDeviceId","olmDevice","recipientUserId","recipientDevice","payloadFields","deviceKey","getIdentityKey","sessionId","getSessionIdForDevice","logger","log","deviceId","payload","sender","sender_device","ed25519","deviceEd25519Key","recipient","recipient_keys","getFingerprint","encryptMessage","JSON","stringify","getExistingOlmSessions","baseApis","devicesByUser","devicesWithoutSession","MapWithDefault","sessions","Map","promises","userId","devices","entries","deviceInfo","getOrCreate","set","device","Promise","all","ensureOlmSessionsForDevices","force","otkTimeout","failedServers","result","resolveSession","values","deviceCurve25519Key","sessionsInProgress","resolve","v","resultDevices","info","forWhom","get","resolveSessionFn","oneTimeKeyAlgorithm","res","taskDetail","debug","claimOneTimeKeys","e","resolver","failures","otkResult","one_time_keys","userRes","_result$get","_result$get$get","deviceRes","oneTimeKey","keyId","indexOf","_resolveSession$get","warn","_verifyKeyAndStartSession","then","sid","_resolveSession$get2","_result$get2","undefined","_resolveSession$get3","verifySignature","error","createOutboundSession","obj","signingUserId","signingDeviceId","signingKey","signKeyId","signatures","userSigs","signature","Error","mangledObj","assign","unsigned","json","anotherjson","pkSign","pubKey","createdKey","Uint8Array","keyObj","global","PkSigning","init_with_seed","sigs","mysigs","sign","free","pkVerify","util","Utility","ed25519_verify","isOlmEncrypted","event","getSenderKey","getWireType","EventType","RoomMessageEncrypted","includes","getWireContent","algorithm","encodeBase64","uint8Array","Buffer","from","toString","encodeUnpaddedBase64","replace","decodeBase64","base64"],"sources":["../../src/crypto/olmlib.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Utilities common to olm encryption algorithms\n */\n\nimport anotherjson from \"another-json\";\n\nimport type { PkSigning } from \"@matrix-org/olm\";\nimport type { IOneTimeKey } from \"../@types/crypto\";\nimport { OlmDevice } from \"./OlmDevice\";\nimport { DeviceInfo } from \"./deviceinfo\";\nimport { logger } from \"../logger\";\nimport { IClaimOTKsResult, MatrixClient } from \"../client\";\nimport { ISignatures } from \"../@types/signed\";\nimport { MatrixEvent } from \"../models/event\";\nimport { EventType } from \"../@types/event\";\nimport { IMessage } from \"./algorithms/olm\";\nimport { MapWithDefault } from \"../utils\";\n\nenum Algorithm {\n Olm = \"m.olm.v1.curve25519-aes-sha2\",\n Megolm = \"m.megolm.v1.aes-sha2\",\n MegolmBackup = \"m.megolm_backup.v1.curve25519-aes-sha2\",\n}\n\n/**\n * matrix algorithm tag for olm\n */\nexport const OLM_ALGORITHM = Algorithm.Olm;\n\n/**\n * matrix algorithm tag for megolm\n */\nexport const MEGOLM_ALGORITHM = Algorithm.Megolm;\n\n/**\n * matrix algorithm tag for megolm backups\n */\nexport const MEGOLM_BACKUP_ALGORITHM = Algorithm.MegolmBackup;\n\nexport interface IOlmSessionResult {\n /** device info */\n device: DeviceInfo;\n /** base64 olm session id; null if no session could be established */\n sessionId: string | null;\n}\n\n/**\n * Encrypt an event payload for an Olm device\n *\n * @param resultsObject - The `ciphertext` property\n * of the m.room.encrypted event to which to add our result\n *\n * @param olmDevice - olm.js wrapper\n * @param payloadFields - fields to include in the encrypted payload\n *\n * Returns a promise which resolves (to undefined) when the payload\n * has been encrypted into `resultsObject`\n */\nexport async function encryptMessageForDevice(\n resultsObject: Record,\n ourUserId: string,\n ourDeviceId: string | undefined,\n olmDevice: OlmDevice,\n recipientUserId: string,\n recipientDevice: DeviceInfo,\n payloadFields: Record,\n): Promise {\n const deviceKey = recipientDevice.getIdentityKey();\n const sessionId = await olmDevice.getSessionIdForDevice(deviceKey);\n if (sessionId === null) {\n // If we don't have a session for a device then\n // we can't encrypt a message for it.\n logger.log(\n `[olmlib.encryptMessageForDevice] Unable to find Olm session for device ` +\n `${recipientUserId}:${recipientDevice.deviceId}`,\n );\n return;\n }\n\n logger.log(\n `[olmlib.encryptMessageForDevice] Using Olm session ${sessionId} for device ` +\n `${recipientUserId}:${recipientDevice.deviceId}`,\n );\n\n const payload = {\n sender: ourUserId,\n // TODO this appears to no longer be used whatsoever\n sender_device: ourDeviceId,\n\n // Include the Ed25519 key so that the recipient knows what\n // device this message came from.\n // We don't need to include the curve25519 key since the\n // recipient will already know this from the olm headers.\n // When combined with the device keys retrieved from the\n // homeserver signed by the ed25519 key this proves that\n // the curve25519 key and the ed25519 key are owned by\n // the same device.\n keys: {\n ed25519: olmDevice.deviceEd25519Key,\n },\n\n // include the recipient device details in the payload,\n // to avoid unknown key attacks, per\n // https://github.com/vector-im/vector-web/issues/2483\n recipient: recipientUserId,\n recipient_keys: {\n ed25519: recipientDevice.getFingerprint(),\n },\n ...payloadFields,\n };\n\n // TODO: technically, a bunch of that stuff only needs to be included for\n // pre-key messages: after that, both sides know exactly which devices are\n // involved in the session. If we're looking to reduce data transfer in the\n // future, we could elide them for subsequent messages.\n\n resultsObject[deviceKey] = await olmDevice.encryptMessage(deviceKey, sessionId, JSON.stringify(payload));\n}\n\ninterface IExistingOlmSession {\n device: DeviceInfo;\n sessionId: string | null;\n}\n\n/**\n * Get the existing olm sessions for the given devices, and the devices that\n * don't have olm sessions.\n *\n *\n *\n * @param devicesByUser - map from userid to list of devices to ensure sessions for\n *\n * @returns resolves to an array. The first element of the array is a\n * a map of user IDs to arrays of deviceInfo, representing the devices that\n * don't have established olm sessions. The second element of the array is\n * a map from userId to deviceId to {@link OlmSessionResult}\n */\nexport async function getExistingOlmSessions(\n olmDevice: OlmDevice,\n baseApis: MatrixClient,\n devicesByUser: Record,\n): Promise<[Map, Map>]> {\n // map user Id → DeviceInfo[]\n const devicesWithoutSession: MapWithDefault = new MapWithDefault(() => []);\n // map user Id → device Id → IExistingOlmSession\n const sessions: MapWithDefault> = new MapWithDefault(() => new Map());\n\n const promises: Promise[] = [];\n\n for (const [userId, devices] of Object.entries(devicesByUser)) {\n for (const deviceInfo of devices) {\n const deviceId = deviceInfo.deviceId;\n const key = deviceInfo.getIdentityKey();\n promises.push(\n (async (): Promise => {\n const sessionId = await olmDevice.getSessionIdForDevice(key, true);\n if (sessionId === null) {\n devicesWithoutSession.getOrCreate(userId).push(deviceInfo);\n } else {\n sessions.getOrCreate(userId).set(deviceId, {\n device: deviceInfo,\n sessionId: sessionId,\n });\n }\n })(),\n );\n }\n }\n\n await Promise.all(promises);\n\n return [devicesWithoutSession, sessions];\n}\n\n/**\n * Try to make sure we have established olm sessions for the given devices.\n *\n * @param devicesByUser - map from userid to list of devices to ensure sessions for\n *\n * @param force - If true, establish a new session even if one\n * already exists.\n *\n * @param otkTimeout - The timeout in milliseconds when requesting\n * one-time keys for establishing new olm sessions.\n *\n * @param failedServers - An array to fill with remote servers that\n * failed to respond to one-time-key requests.\n *\n * @param log - A possibly customised log\n *\n * @returns resolves once the sessions are complete, to\n * an Object mapping from userId to deviceId to\n * {@link OlmSessionResult}\n */\nexport async function ensureOlmSessionsForDevices(\n olmDevice: OlmDevice,\n baseApis: MatrixClient,\n devicesByUser: Map,\n force = false,\n otkTimeout?: number,\n failedServers?: string[],\n log = logger,\n): Promise>> {\n const devicesWithoutSession: [string, string][] = [\n // [userId, deviceId], ...\n ];\n // map user Id → device Id → IExistingOlmSession\n const result: Map> = new Map();\n // map device key → resolve session fn\n const resolveSession: Map void> = new Map();\n\n // Mark all sessions this task intends to update as in progress. It is\n // important to do this for all devices this task cares about in a single\n // synchronous operation, as otherwise it is possible to have deadlocks\n // where multiple tasks wait indefinitely on another task to update some set\n // of common devices.\n for (const devices of devicesByUser.values()) {\n for (const deviceInfo of devices) {\n const key = deviceInfo.getIdentityKey();\n\n if (key === olmDevice.deviceCurve25519Key) {\n // We don't start sessions with ourself, so there's no need to\n // mark it in progress.\n continue;\n }\n\n if (!olmDevice.sessionsInProgress[key]) {\n // pre-emptively mark the session as in-progress to avoid race\n // conditions. If we find that we already have a session, then\n // we'll resolve\n olmDevice.sessionsInProgress[key] = new Promise((resolve) => {\n resolveSession.set(key, (v: any): void => {\n delete olmDevice.sessionsInProgress[key];\n resolve(v);\n });\n });\n }\n }\n }\n\n for (const [userId, devices] of devicesByUser) {\n const resultDevices = new Map();\n result.set(userId, resultDevices);\n\n for (const deviceInfo of devices) {\n const deviceId = deviceInfo.deviceId;\n const key = deviceInfo.getIdentityKey();\n\n if (key === olmDevice.deviceCurve25519Key) {\n // We should never be trying to start a session with ourself.\n // Apart from talking to yourself being the first sign of madness,\n // olm sessions can't do this because they get confused when\n // they get a message and see that the 'other side' has started a\n // new chain when this side has an active sender chain.\n // If you see this message being logged in the wild, we should find\n // the thing that is trying to send Olm messages to itself and fix it.\n log.info(\"Attempted to start session with ourself! Ignoring\");\n // We must fill in the section in the return value though, as callers\n // expect it to be there.\n resultDevices.set(deviceId, {\n device: deviceInfo,\n sessionId: null,\n });\n continue;\n }\n\n const forWhom = `for ${key} (${userId}:${deviceId})`;\n const sessionId = await olmDevice.getSessionIdForDevice(key, !!resolveSession.get(key), log);\n const resolveSessionFn = resolveSession.get(key);\n if (sessionId !== null && resolveSessionFn) {\n // we found a session, but we had marked the session as\n // in-progress, so resolve it now, which will unmark it and\n // unblock anything that was waiting\n resolveSessionFn();\n }\n if (sessionId === null || force) {\n if (force) {\n log.info(`Forcing new Olm session ${forWhom}`);\n } else {\n log.info(`Making new Olm session ${forWhom}`);\n }\n devicesWithoutSession.push([userId, deviceId]);\n }\n resultDevices.set(deviceId, {\n device: deviceInfo,\n sessionId: sessionId,\n });\n }\n }\n\n if (devicesWithoutSession.length === 0) {\n return result;\n }\n\n const oneTimeKeyAlgorithm = \"signed_curve25519\";\n let res: IClaimOTKsResult;\n let taskDetail = `one-time keys for ${devicesWithoutSession.length} devices`;\n try {\n log.debug(`Claiming ${taskDetail}`);\n res = await baseApis.claimOneTimeKeys(devicesWithoutSession, oneTimeKeyAlgorithm, otkTimeout);\n log.debug(`Claimed ${taskDetail}`);\n } catch (e) {\n for (const resolver of resolveSession.values()) {\n resolver();\n }\n log.log(`Failed to claim ${taskDetail}`, e, devicesWithoutSession);\n throw e;\n }\n\n if (failedServers && \"failures\" in res) {\n failedServers.push(...Object.keys(res.failures));\n }\n\n const otkResult = res.one_time_keys || ({} as IClaimOTKsResult[\"one_time_keys\"]);\n const promises: Promise[] = [];\n for (const [userId, devices] of devicesByUser) {\n const userRes = otkResult[userId] || {};\n for (const deviceInfo of devices) {\n const deviceId = deviceInfo.deviceId;\n const key = deviceInfo.getIdentityKey();\n\n if (key === olmDevice.deviceCurve25519Key) {\n // We've already logged about this above. Skip here too\n // otherwise we'll log saying there are no one-time keys\n // which will be confusing.\n continue;\n }\n\n if (result.get(userId)?.get(deviceId)?.sessionId && !force) {\n // we already have a result for this device\n continue;\n }\n\n const deviceRes = userRes[deviceId] || {};\n let oneTimeKey: IOneTimeKey | null = null;\n for (const keyId in deviceRes) {\n if (keyId.indexOf(oneTimeKeyAlgorithm + \":\") === 0) {\n oneTimeKey = deviceRes[keyId];\n }\n }\n\n if (!oneTimeKey) {\n log.warn(`No one-time keys (alg=${oneTimeKeyAlgorithm}) ` + `for device ${userId}:${deviceId}`);\n resolveSession.get(key)?.();\n continue;\n }\n\n promises.push(\n _verifyKeyAndStartSession(olmDevice, oneTimeKey, userId, deviceInfo).then(\n (sid) => {\n resolveSession.get(key)?.(sid ?? undefined);\n const deviceInfo = result.get(userId)?.get(deviceId);\n if (deviceInfo) deviceInfo.sessionId = sid;\n },\n (e) => {\n resolveSession.get(key)?.();\n throw e;\n },\n ),\n );\n }\n }\n\n taskDetail = `Olm sessions for ${promises.length} devices`;\n log.debug(`Starting ${taskDetail}`);\n await Promise.all(promises);\n log.debug(`Started ${taskDetail}`);\n return result;\n}\n\nasync function _verifyKeyAndStartSession(\n olmDevice: OlmDevice,\n oneTimeKey: IOneTimeKey,\n userId: string,\n deviceInfo: DeviceInfo,\n): Promise {\n const deviceId = deviceInfo.deviceId;\n try {\n await verifySignature(olmDevice, oneTimeKey, userId, deviceId, deviceInfo.getFingerprint());\n } catch (e) {\n logger.error(\"Unable to verify signature on one-time key for device \" + userId + \":\" + deviceId + \":\", e);\n return null;\n }\n\n let sid;\n try {\n sid = await olmDevice.createOutboundSession(deviceInfo.getIdentityKey(), oneTimeKey.key);\n } catch (e) {\n // possibly a bad key\n logger.error(\"Error starting olm session with device \" + userId + \":\" + deviceId + \": \" + e);\n return null;\n }\n\n logger.log(\"Started new olm sessionid \" + sid + \" for device \" + userId + \":\" + deviceId);\n return sid;\n}\n\nexport interface IObject {\n unsigned?: object;\n signatures?: ISignatures;\n}\n\n/**\n * Verify the signature on an object\n *\n * @param olmDevice - olm wrapper to use for verify op\n *\n * @param obj - object to check signature on.\n *\n * @param signingUserId - ID of the user whose signature should be checked\n *\n * @param signingDeviceId - ID of the device whose signature should be checked\n *\n * @param signingKey - base64-ed ed25519 public key\n *\n * Returns a promise which resolves (to undefined) if the the signature is good,\n * or rejects with an Error if it is bad.\n */\nexport async function verifySignature(\n olmDevice: OlmDevice,\n obj: IOneTimeKey | IObject,\n signingUserId: string,\n signingDeviceId: string,\n signingKey: string,\n): Promise {\n const signKeyId = \"ed25519:\" + signingDeviceId;\n const signatures = obj.signatures || {};\n const userSigs = signatures[signingUserId] || {};\n const signature = userSigs[signKeyId];\n if (!signature) {\n throw Error(\"No signature\");\n }\n\n // prepare the canonical json: remove unsigned and signatures, and stringify with anotherjson\n const mangledObj = Object.assign({}, obj);\n if (\"unsigned\" in mangledObj) {\n delete mangledObj.unsigned;\n }\n delete mangledObj.signatures;\n const json = anotherjson.stringify(mangledObj);\n\n olmDevice.verifySignature(signingKey, json, signature);\n}\n\n/**\n * Sign a JSON object using public key cryptography\n * @param obj - Object to sign. The object will be modified to include\n * the new signature\n * @param key - the signing object or the private key\n * seed\n * @param userId - The user ID who owns the signing key\n * @param pubKey - The public key (ignored if key is a seed)\n * @returns the signature for the object\n */\nexport function pkSign(obj: object & IObject, key: Uint8Array | PkSigning, userId: string, pubKey: string): string {\n let createdKey = false;\n if (key instanceof Uint8Array) {\n const keyObj = new global.Olm.PkSigning();\n pubKey = keyObj.init_with_seed(key);\n key = keyObj;\n createdKey = true;\n }\n const sigs = obj.signatures || {};\n delete obj.signatures;\n const unsigned = obj.unsigned;\n if (obj.unsigned) delete obj.unsigned;\n try {\n const mysigs = sigs[userId] || {};\n sigs[userId] = mysigs;\n\n return (mysigs[\"ed25519:\" + pubKey] = key.sign(anotherjson.stringify(obj)));\n } finally {\n obj.signatures = sigs;\n if (unsigned) obj.unsigned = unsigned;\n if (createdKey) {\n key.free();\n }\n }\n}\n\n/**\n * Verify a signed JSON object\n * @param obj - Object to verify\n * @param pubKey - The public key to use to verify\n * @param userId - The user ID who signed the object\n */\nexport function pkVerify(obj: IObject, pubKey: string, userId: string): void {\n const keyId = \"ed25519:\" + pubKey;\n if (!(obj.signatures && obj.signatures[userId] && obj.signatures[userId][keyId])) {\n throw new Error(\"No signature\");\n }\n const signature = obj.signatures[userId][keyId];\n const util = new global.Olm.Utility();\n const sigs = obj.signatures;\n delete obj.signatures;\n const unsigned = obj.unsigned;\n if (obj.unsigned) delete obj.unsigned;\n try {\n util.ed25519_verify(pubKey, anotherjson.stringify(obj), signature);\n } finally {\n obj.signatures = sigs;\n if (unsigned) obj.unsigned = unsigned;\n util.free();\n }\n}\n\n/**\n * Check that an event was encrypted using olm.\n */\nexport function isOlmEncrypted(event: MatrixEvent): boolean {\n if (!event.getSenderKey()) {\n logger.error(\"Event has no sender key (not encrypted?)\");\n return false;\n }\n if (\n event.getWireType() !== EventType.RoomMessageEncrypted ||\n ![\"m.olm.v1.curve25519-aes-sha2\"].includes(event.getWireContent().algorithm)\n ) {\n logger.error(\"Event was not encrypted using an appropriate algorithm\");\n return false;\n }\n return true;\n}\n\n/**\n * Encode a typed array of uint8 as base64.\n * @param uint8Array - The data to encode.\n * @returns The base64.\n */\nexport function encodeBase64(uint8Array: ArrayBuffer | Uint8Array): string {\n return Buffer.from(uint8Array).toString(\"base64\");\n}\n\n/**\n * Encode a typed array of uint8 as unpadded base64.\n * @param uint8Array - The data to encode.\n * @returns The unpadded base64.\n */\nexport function encodeUnpaddedBase64(uint8Array: ArrayBuffer | Uint8Array): string {\n return encodeBase64(uint8Array).replace(/=+$/g, \"\");\n}\n\n/**\n * Decode a base64 string to a typed array of uint8.\n * @param base64 - The base64 to decode.\n * @returns The decoded data.\n */\nexport function decodeBase64(base64: string): Uint8Array {\n return Buffer.from(base64, \"base64\");\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts deleted file mode 100644 index c0625cf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts +++ /dev/null @@ -1,3 +0,0 @@ -export declare function encodeRecoveryKey(key: ArrayLike): string | undefined; -export declare function decodeRecoveryKey(recoveryKey: string): Uint8Array; -//# sourceMappingURL=recoverykey.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts.map deleted file mode 100644 index c65ac16..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"recoverykey.d.ts","sourceRoot":"","sources":["../../src/crypto/recoverykey.ts"],"names":[],"mappings":"AAsBA,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,SAAS,CAAC,MAAM,CAAC,GAAG,MAAM,GAAG,SAAS,CAa5E;AAED,wBAAgB,iBAAiB,CAAC,WAAW,EAAE,MAAM,GAAG,UAAU,CAwBjE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js deleted file mode 100644 index fb12171..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js +++ /dev/null @@ -1,62 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.decodeRecoveryKey = decodeRecoveryKey; -exports.encodeRecoveryKey = encodeRecoveryKey; -var bs58 = _interopRequireWildcard(require("bs58")); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2018 New Vector Ltd - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// picked arbitrarily but to try & avoid clashing with any bitcoin ones -// (which are also base58 encoded, but bitcoin's involve a lot more hashing) -const OLM_RECOVERY_KEY_PREFIX = [0x8b, 0x01]; -function encodeRecoveryKey(key) { - var _base58key$match; - const buf = Buffer.alloc(OLM_RECOVERY_KEY_PREFIX.length + key.length + 1); - buf.set(OLM_RECOVERY_KEY_PREFIX, 0); - buf.set(key, OLM_RECOVERY_KEY_PREFIX.length); - let parity = 0; - for (let i = 0; i < buf.length - 1; ++i) { - parity ^= buf[i]; - } - buf[buf.length - 1] = parity; - const base58key = bs58.encode(buf); - return (_base58key$match = base58key.match(/.{1,4}/g)) === null || _base58key$match === void 0 ? void 0 : _base58key$match.join(" "); -} -function decodeRecoveryKey(recoveryKey) { - const result = bs58.decode(recoveryKey.replace(/ /g, "")); - let parity = 0; - for (const b of result) { - parity ^= b; - } - if (parity !== 0) { - throw new Error("Incorrect parity"); - } - for (let i = 0; i < OLM_RECOVERY_KEY_PREFIX.length; ++i) { - if (result[i] !== OLM_RECOVERY_KEY_PREFIX[i]) { - throw new Error("Incorrect prefix"); - } - } - if (result.length !== OLM_RECOVERY_KEY_PREFIX.length + global.Olm.PRIVATE_KEY_LENGTH + 1) { - throw new Error("Incorrect length"); - } - return Uint8Array.from(result.slice(OLM_RECOVERY_KEY_PREFIX.length, OLM_RECOVERY_KEY_PREFIX.length + global.Olm.PRIVATE_KEY_LENGTH)); -} -//# sourceMappingURL=recoverykey.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js.map deleted file mode 100644 index d4a04d3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/recoverykey.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"recoverykey.js","names":["bs58","_interopRequireWildcard","require","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","OLM_RECOVERY_KEY_PREFIX","encodeRecoveryKey","_base58key$match","buf","Buffer","alloc","length","parity","i","base58key","encode","match","join","decodeRecoveryKey","recoveryKey","result","decode","replace","b","Error","global","Olm","PRIVATE_KEY_LENGTH","Uint8Array","from","slice"],"sources":["../../src/crypto/recoverykey.ts"],"sourcesContent":["/*\nCopyright 2018 New Vector Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as bs58 from \"bs58\";\n\n// picked arbitrarily but to try & avoid clashing with any bitcoin ones\n// (which are also base58 encoded, but bitcoin's involve a lot more hashing)\nconst OLM_RECOVERY_KEY_PREFIX = [0x8b, 0x01];\n\nexport function encodeRecoveryKey(key: ArrayLike): string | undefined {\n const buf = Buffer.alloc(OLM_RECOVERY_KEY_PREFIX.length + key.length + 1);\n buf.set(OLM_RECOVERY_KEY_PREFIX, 0);\n buf.set(key, OLM_RECOVERY_KEY_PREFIX.length);\n\n let parity = 0;\n for (let i = 0; i < buf.length - 1; ++i) {\n parity ^= buf[i];\n }\n buf[buf.length - 1] = parity;\n const base58key = bs58.encode(buf);\n\n return base58key.match(/.{1,4}/g)?.join(\" \");\n}\n\nexport function decodeRecoveryKey(recoveryKey: string): Uint8Array {\n const result = bs58.decode(recoveryKey.replace(/ /g, \"\"));\n\n let parity = 0;\n for (const b of result) {\n parity ^= b;\n }\n if (parity !== 0) {\n throw new Error(\"Incorrect parity\");\n }\n\n for (let i = 0; i < OLM_RECOVERY_KEY_PREFIX.length; ++i) {\n if (result[i] !== OLM_RECOVERY_KEY_PREFIX[i]) {\n throw new Error(\"Incorrect prefix\");\n }\n }\n\n if (result.length !== OLM_RECOVERY_KEY_PREFIX.length + global.Olm.PRIVATE_KEY_LENGTH + 1) {\n throw new Error(\"Incorrect length\");\n }\n\n return Uint8Array.from(\n result.slice(OLM_RECOVERY_KEY_PREFIX.length, OLM_RECOVERY_KEY_PREFIX.length + global.Olm.PRIVATE_KEY_LENGTH),\n );\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts deleted file mode 100644 index ccef9c5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts +++ /dev/null @@ -1,143 +0,0 @@ -import { IRoomKeyRequestBody, IRoomKeyRequestRecipient } from "../index"; -import { RoomKeyRequestState } from "../OutgoingRoomKeyRequestManager"; -import { ICrossSigningKey } from "../../client"; -import { IOlmDevice } from "../algorithms/megolm"; -import { TrackingStatus } from "../DeviceList"; -import { IRoomEncryption } from "../RoomList"; -import { IDevice } from "../deviceinfo"; -import { ICrossSigningInfo } from "../CrossSigning"; -import { PrefixedLogger } from "../../logger"; -import { InboundGroupSessionData } from "../OlmDevice"; -import { MatrixEvent } from "../../models/event"; -import { DehydrationManager } from "../dehydration"; -import { IEncryptedPayload } from "../aes"; -/** - * Internal module. Definitions for storage for the crypto module - */ -export interface SecretStorePrivateKeys { - "dehydration": { - keyInfo: DehydrationManager["keyInfo"]; - key: IEncryptedPayload; - deviceDisplayName: string; - time: number; - } | null; - "m.megolm_backup.v1": IEncryptedPayload; -} -/** - * Abstraction of things that can store data required for end-to-end encryption - */ -export interface CryptoStore { - startup(): Promise; - deleteAllData(): Promise; - getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise; - getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise; - getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise; - getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise; - getOutgoingRoomKeyRequestsByTarget(userId: string, deviceId: string, wantedStates: number[]): Promise; - updateOutgoingRoomKeyRequest(requestId: string, expectedState: number, updates: Partial): Promise; - deleteOutgoingRoomKeyRequest(requestId: string, expectedState: number): Promise; - getAccount(txn: unknown, func: (accountPickle: string | null) => void): void; - storeAccount(txn: unknown, accountPickle: string): void; - getCrossSigningKeys(txn: unknown, func: (keys: Record | null) => void): void; - getSecretStorePrivateKey(txn: unknown, func: (key: SecretStorePrivateKeys[K] | null) => void, type: K): void; - storeCrossSigningKeys(txn: unknown, keys: Record): void; - storeSecretStorePrivateKey(txn: unknown, type: K, key: SecretStorePrivateKeys[K]): void; - countEndToEndSessions(txn: unknown, func: (count: number) => void): void; - getEndToEndSession(deviceKey: string, sessionId: string, txn: unknown, func: (session: ISessionInfo | null) => void): void; - getEndToEndSessions(deviceKey: string, txn: unknown, func: (sessions: { - [sessionId: string]: ISessionInfo; - }) => void): void; - getAllEndToEndSessions(txn: unknown, func: (session: ISessionInfo | null) => void): void; - storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void; - storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise; - getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise; - filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise; - getEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, txn: unknown, func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void): void; - getAllEndToEndInboundGroupSessions(txn: unknown, func: (session: ISession | null) => void): void; - addEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: unknown): void; - storeEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: unknown): void; - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key: string, sessionId: string, sessionData: IWithheld, txn: unknown): void; - getEndToEndDeviceData(txn: unknown, func: (deviceData: IDeviceData | null) => void): void; - storeEndToEndDeviceData(deviceData: IDeviceData, txn: unknown): void; - storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: unknown): void; - getEndToEndRooms(txn: unknown, func: (rooms: Record) => void): void; - getSessionsNeedingBackup(limit: number): Promise; - countSessionsNeedingBackup(txn?: unknown): Promise; - unmarkSessionsNeedingBackup(sessions: ISession[], txn?: unknown): Promise; - markSessionsNeedingBackup(sessions: ISession[], txn?: unknown): Promise; - addSharedHistoryInboundGroupSession(roomId: string, senderKey: string, sessionId: string, txn?: unknown): void; - getSharedHistoryInboundGroupSessions(roomId: string, txn?: unknown): Promise<[senderKey: string, sessionId: string][]>; - addParkedSharedHistory(roomId: string, data: ParkedSharedHistory, txn?: unknown): void; - takeParkedSharedHistory(roomId: string, txn?: unknown): Promise; - doTxn(mode: Mode, stores: Iterable, func: (txn: unknown) => T, log?: PrefixedLogger): Promise; -} -export type Mode = "readonly" | "readwrite"; -export interface ISession { - senderKey: string; - sessionId: string; - sessionData?: InboundGroupSessionData; -} -export interface ISessionInfo { - deviceKey?: string; - sessionId?: string; - session?: string; - lastReceivedMessageTs?: number; -} -export interface IDeviceData { - devices: { - [userId: string]: { - [deviceId: string]: IDevice; - }; - }; - trackingStatus: { - [userId: string]: TrackingStatus; - }; - crossSigningInfo?: Record; - syncToken?: string; -} -export interface IProblem { - type: string; - fixed: boolean; - time: number; -} -export interface IWithheld { - room_id: string; - code: string; - reason: string; -} -/** - * Represents an outgoing room key request - */ -export interface OutgoingRoomKeyRequest { - /** - * Unique id for this request. Used for both an id within the request for later pairing with a cancellation, - * and for the transaction id when sending the to_device messages to our local server. - */ - requestId: string; - requestTxnId?: string; - /** - * Transaction id for the cancellation, if any - */ - cancellationTxnId?: string; - /** - * List of recipients for the request - */ - recipients: IRoomKeyRequestRecipient[]; - /** - * Parameters for the request - */ - requestBody: IRoomKeyRequestBody; - /** - * current state of this request (states are defined in {@link OutgoingRoomKeyRequestManager}) - */ - state: RoomKeyRequestState; -} -export interface ParkedSharedHistory { - senderId: string; - senderKey: string; - sessionId: string; - sessionKey: string; - keysClaimed: ReturnType; - forwardingCurve25519KeyChain: string[]; -} -//# sourceMappingURL=base.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts.map deleted file mode 100644 index 429688e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../src/crypto/store/base.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js deleted file mode 100644 index f14b94a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=base.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js.map deleted file mode 100644 index 2235433..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/base.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"base.js","names":[],"sources":["../../../src/crypto/store/base.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IRoomKeyRequestBody, IRoomKeyRequestRecipient } from \"../index\";\nimport { RoomKeyRequestState } from \"../OutgoingRoomKeyRequestManager\";\nimport { ICrossSigningKey } from \"../../client\";\nimport { IOlmDevice } from \"../algorithms/megolm\";\nimport { TrackingStatus } from \"../DeviceList\";\nimport { IRoomEncryption } from \"../RoomList\";\nimport { IDevice } from \"../deviceinfo\";\nimport { ICrossSigningInfo } from \"../CrossSigning\";\nimport { PrefixedLogger } from \"../../logger\";\nimport { InboundGroupSessionData } from \"../OlmDevice\";\nimport { MatrixEvent } from \"../../models/event\";\nimport { DehydrationManager } from \"../dehydration\";\nimport { IEncryptedPayload } from \"../aes\";\n\n/**\n * Internal module. Definitions for storage for the crypto module\n */\n\nexport interface SecretStorePrivateKeys {\n \"dehydration\": {\n keyInfo: DehydrationManager[\"keyInfo\"];\n key: IEncryptedPayload;\n deviceDisplayName: string;\n time: number;\n } | null;\n \"m.megolm_backup.v1\": IEncryptedPayload;\n}\n\n/**\n * Abstraction of things that can store data required for end-to-end encryption\n */\nexport interface CryptoStore {\n startup(): Promise;\n deleteAllData(): Promise;\n getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise;\n getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise;\n getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise;\n getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise;\n getOutgoingRoomKeyRequestsByTarget(\n userId: string,\n deviceId: string,\n wantedStates: number[],\n ): Promise;\n updateOutgoingRoomKeyRequest(\n requestId: string,\n expectedState: number,\n updates: Partial,\n ): Promise;\n deleteOutgoingRoomKeyRequest(requestId: string, expectedState: number): Promise;\n\n // Olm Account\n getAccount(txn: unknown, func: (accountPickle: string | null) => void): void;\n storeAccount(txn: unknown, accountPickle: string): void;\n getCrossSigningKeys(txn: unknown, func: (keys: Record | null) => void): void;\n getSecretStorePrivateKey(\n txn: unknown,\n func: (key: SecretStorePrivateKeys[K] | null) => void,\n type: K,\n ): void;\n storeCrossSigningKeys(txn: unknown, keys: Record): void;\n storeSecretStorePrivateKey(\n txn: unknown,\n type: K,\n key: SecretStorePrivateKeys[K],\n ): void;\n\n // Olm Sessions\n countEndToEndSessions(txn: unknown, func: (count: number) => void): void;\n getEndToEndSession(\n deviceKey: string,\n sessionId: string,\n txn: unknown,\n func: (session: ISessionInfo | null) => void,\n ): void;\n getEndToEndSessions(\n deviceKey: string,\n txn: unknown,\n func: (sessions: { [sessionId: string]: ISessionInfo }) => void,\n ): void;\n getAllEndToEndSessions(txn: unknown, func: (session: ISessionInfo | null) => void): void;\n storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void;\n storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise;\n getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise;\n filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise;\n\n // Inbound Group Sessions\n getEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n txn: unknown,\n func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,\n ): void;\n getAllEndToEndInboundGroupSessions(txn: unknown, func: (session: ISession | null) => void): void;\n addEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: unknown,\n ): void;\n storeEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: unknown,\n ): void;\n storeEndToEndInboundGroupSessionWithheld(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: IWithheld,\n txn: unknown,\n ): void;\n\n // Device Data\n getEndToEndDeviceData(txn: unknown, func: (deviceData: IDeviceData | null) => void): void;\n storeEndToEndDeviceData(deviceData: IDeviceData, txn: unknown): void;\n storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: unknown): void;\n getEndToEndRooms(txn: unknown, func: (rooms: Record) => void): void;\n getSessionsNeedingBackup(limit: number): Promise;\n countSessionsNeedingBackup(txn?: unknown): Promise;\n unmarkSessionsNeedingBackup(sessions: ISession[], txn?: unknown): Promise;\n markSessionsNeedingBackup(sessions: ISession[], txn?: unknown): Promise;\n addSharedHistoryInboundGroupSession(roomId: string, senderKey: string, sessionId: string, txn?: unknown): void;\n getSharedHistoryInboundGroupSessions(\n roomId: string,\n txn?: unknown,\n ): Promise<[senderKey: string, sessionId: string][]>;\n addParkedSharedHistory(roomId: string, data: ParkedSharedHistory, txn?: unknown): void;\n takeParkedSharedHistory(roomId: string, txn?: unknown): Promise;\n\n // Session key backups\n doTxn(mode: Mode, stores: Iterable, func: (txn: unknown) => T, log?: PrefixedLogger): Promise;\n}\n\nexport type Mode = \"readonly\" | \"readwrite\";\n\nexport interface ISession {\n senderKey: string;\n sessionId: string;\n sessionData?: InboundGroupSessionData;\n}\n\nexport interface ISessionInfo {\n deviceKey?: string;\n sessionId?: string;\n session?: string;\n lastReceivedMessageTs?: number;\n}\n\nexport interface IDeviceData {\n devices: {\n [userId: string]: {\n [deviceId: string]: IDevice;\n };\n };\n trackingStatus: {\n [userId: string]: TrackingStatus;\n };\n crossSigningInfo?: Record;\n syncToken?: string;\n}\n\nexport interface IProblem {\n type: string;\n fixed: boolean;\n time: number;\n}\n\nexport interface IWithheld {\n // eslint-disable-next-line camelcase\n room_id: string;\n code: string;\n reason: string;\n}\n\n/**\n * Represents an outgoing room key request\n */\nexport interface OutgoingRoomKeyRequest {\n /**\n * Unique id for this request. Used for both an id within the request for later pairing with a cancellation,\n * and for the transaction id when sending the to_device messages to our local server.\n */\n requestId: string;\n requestTxnId?: string;\n /**\n * Transaction id for the cancellation, if any\n */\n cancellationTxnId?: string;\n /**\n * List of recipients for the request\n */\n recipients: IRoomKeyRequestRecipient[];\n /**\n * Parameters for the request\n */\n requestBody: IRoomKeyRequestBody;\n /**\n * current state of this request (states are defined in {@link OutgoingRoomKeyRequestManager})\n */\n state: RoomKeyRequestState;\n}\n\nexport interface ParkedSharedHistory {\n senderId: string;\n senderKey: string;\n sessionId: string;\n sessionKey: string;\n keysClaimed: ReturnType; // XXX: Less type dependence on MatrixEvent\n forwardingCurve25519KeyChain: string[];\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts deleted file mode 100644 index a111890..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts +++ /dev/null @@ -1,130 +0,0 @@ -import { PrefixedLogger } from "../../logger"; -import { CryptoStore, IDeviceData, IProblem, ISession, ISessionInfo, IWithheld, Mode, OutgoingRoomKeyRequest, ParkedSharedHistory, SecretStorePrivateKeys } from "./base"; -import { IRoomKeyRequestBody } from "../index"; -import { ICrossSigningKey } from "../../client"; -import { IOlmDevice } from "../algorithms/megolm"; -import { IRoomEncryption } from "../RoomList"; -import { InboundGroupSessionData } from "../OlmDevice"; -/** - * Implementation of a CryptoStore which is backed by an existing - * IndexedDB connection. Generally you want IndexedDBCryptoStore - * which connects to the database and defers to one of these. - */ -export declare class Backend implements CryptoStore { - private db; - private nextTxnId; - /** - */ - constructor(db: IDBDatabase); - startup(): Promise; - deleteAllData(): Promise; - /** - * Look for an existing outgoing room key request, and if none is found, - * add a new one - * - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest}: either the - * same instance as passed in, or the existing one. - */ - getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise; - /** - * Look for an existing room key request - * - * @param requestBody - existing request to look for - * - * @returns resolves to the matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found - */ - getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise; - /** - * look for an existing room key request in the db - * - * @internal - * @param txn - database transaction - * @param requestBody - existing request to look for - * @param callback - function to call with the results of the - * search. Either passed a matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found. - */ - private _getOutgoingRoomKeyRequest; - /** - * Look for room key requests by state - * - * @param wantedStates - list of acceptable states - * - * @returns resolves to the a - * {@link OutgoingRoomKeyRequest}, or null if - * there are no pending requests in those states. If there are multiple - * requests in those states, an arbitrary one is chosen. - */ - getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise; - /** - * - * @returns All elements in a given state - */ - getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise; - getOutgoingRoomKeyRequestsByTarget(userId: string, deviceId: string, wantedStates: number[]): Promise; - /** - * Look for an existing room key request by id and state, and update it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * @param updates - name/value map of updates to apply - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest} - * updated request, or null if no matching row was found - */ - updateOutgoingRoomKeyRequest(requestId: string, expectedState: number, updates: Partial): Promise; - /** - * Look for an existing room key request by id and state, and delete it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * - * @returns resolves once the operation is completed - */ - deleteOutgoingRoomKeyRequest(requestId: string, expectedState: number): Promise; - getAccount(txn: IDBTransaction, func: (accountPickle: string | null) => void): void; - storeAccount(txn: IDBTransaction, accountPickle: string): void; - getCrossSigningKeys(txn: IDBTransaction, func: (keys: Record | null) => void): void; - getSecretStorePrivateKey(txn: IDBTransaction, func: (key: SecretStorePrivateKeys[K] | null) => void, type: K): void; - storeCrossSigningKeys(txn: IDBTransaction, keys: Record): void; - storeSecretStorePrivateKey(txn: IDBTransaction, type: K, key: SecretStorePrivateKeys[K]): void; - countEndToEndSessions(txn: IDBTransaction, func: (count: number) => void): void; - getEndToEndSessions(deviceKey: string, txn: IDBTransaction, func: (sessions: { - [sessionId: string]: ISessionInfo; - }) => void): void; - getEndToEndSession(deviceKey: string, sessionId: string, txn: IDBTransaction, func: (session: ISessionInfo | null) => void): void; - getAllEndToEndSessions(txn: IDBTransaction, func: (session: ISessionInfo | null) => void): void; - storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: IDBTransaction): void; - storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise; - getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise; - filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise; - getEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, txn: IDBTransaction, func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void): void; - getAllEndToEndInboundGroupSessions(txn: IDBTransaction, func: (session: ISession | null) => void): void; - addEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: IDBTransaction): void; - storeEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: IDBTransaction): void; - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key: string, sessionId: string, sessionData: IWithheld, txn: IDBTransaction): void; - getEndToEndDeviceData(txn: IDBTransaction, func: (deviceData: IDeviceData | null) => void): void; - storeEndToEndDeviceData(deviceData: IDeviceData, txn: IDBTransaction): void; - storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: IDBTransaction): void; - getEndToEndRooms(txn: IDBTransaction, func: (rooms: Record) => void): void; - getSessionsNeedingBackup(limit: number): Promise; - countSessionsNeedingBackup(txn?: IDBTransaction): Promise; - unmarkSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise; - markSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise; - addSharedHistoryInboundGroupSession(roomId: string, senderKey: string, sessionId: string, txn?: IDBTransaction): void; - getSharedHistoryInboundGroupSessions(roomId: string, txn?: IDBTransaction): Promise<[senderKey: string, sessionId: string][]>; - addParkedSharedHistory(roomId: string, parkedData: ParkedSharedHistory, txn?: IDBTransaction): void; - takeParkedSharedHistory(roomId: string, txn?: IDBTransaction): Promise; - doTxn(mode: Mode, stores: string | string[], func: (txn: IDBTransaction) => T, log?: PrefixedLogger): Promise; -} -export declare const VERSION: number; -export declare function upgradeDatabase(db: IDBDatabase, oldVersion: number): void; -//# sourceMappingURL=indexeddb-crypto-store-backend.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts.map deleted file mode 100644 index 2c199a3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-crypto-store-backend.d.ts","sourceRoot":"","sources":["../../../src/crypto/store/indexeddb-crypto-store-backend.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js deleted file mode 100644 index 8e1bb6e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js +++ /dev/null @@ -1,918 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.VERSION = exports.Backend = void 0; -exports.upgradeDatabase = upgradeDatabase; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../../logger"); -var utils = _interopRequireWildcard(require("../../utils")); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2017 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const PROFILE_TRANSACTIONS = false; - -/** - * Implementation of a CryptoStore which is backed by an existing - * IndexedDB connection. Generally you want IndexedDBCryptoStore - * which connects to the database and defers to one of these. - */ -class Backend { - /** - */ - constructor(db) { - this.db = db; - (0, _defineProperty2.default)(this, "nextTxnId", 0); - // make sure we close the db on `onversionchange` - otherwise - // attempts to delete the database will block (and subsequent - // attempts to re-create it will also block). - db.onversionchange = () => { - _logger.logger.log(`versionchange for indexeddb ${this.db.name}: closing`); - db.close(); - }; - } - async startup() { - // No work to do, as the startup is done by the caller (e.g IndexedDBCryptoStore) - // by passing us a ready IDBDatabase instance - return this; - } - async deleteAllData() { - throw Error("This is not implemented, call IDBFactory::deleteDatabase(dbName) instead."); - } - - /** - * Look for an existing outgoing room key request, and if none is found, - * add a new one - * - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest}: either the - * same instance as passed in, or the existing one. - */ - getOrAddOutgoingRoomKeyRequest(request) { - const requestBody = request.requestBody; - return new Promise((resolve, reject) => { - const txn = this.db.transaction("outgoingRoomKeyRequests", "readwrite"); - txn.onerror = reject; - - // first see if we already have an entry for this request. - this._getOutgoingRoomKeyRequest(txn, requestBody, existing => { - if (existing) { - // this entry matches the request - return it. - _logger.logger.log(`already have key request outstanding for ` + `${requestBody.room_id} / ${requestBody.session_id}: ` + `not sending another`); - resolve(existing); - return; - } - - // we got to the end of the list without finding a match - // - add the new request. - _logger.logger.log(`enqueueing key request for ${requestBody.room_id} / ` + requestBody.session_id); - txn.oncomplete = () => { - resolve(request); - }; - const store = txn.objectStore("outgoingRoomKeyRequests"); - store.add(request); - }); - }); - } - - /** - * Look for an existing room key request - * - * @param requestBody - existing request to look for - * - * @returns resolves to the matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found - */ - getOutgoingRoomKeyRequest(requestBody) { - return new Promise((resolve, reject) => { - const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly"); - txn.onerror = reject; - this._getOutgoingRoomKeyRequest(txn, requestBody, existing => { - resolve(existing); - }); - }); - } - - /** - * look for an existing room key request in the db - * - * @internal - * @param txn - database transaction - * @param requestBody - existing request to look for - * @param callback - function to call with the results of the - * search. Either passed a matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found. - */ - // eslint-disable-next-line @typescript-eslint/naming-convention - _getOutgoingRoomKeyRequest(txn, requestBody, callback) { - const store = txn.objectStore("outgoingRoomKeyRequests"); - const idx = store.index("session"); - const cursorReq = idx.openCursor([requestBody.room_id, requestBody.session_id]); - cursorReq.onsuccess = () => { - const cursor = cursorReq.result; - if (!cursor) { - // no match found - callback(null); - return; - } - const existing = cursor.value; - if (utils.deepCompare(existing.requestBody, requestBody)) { - // got a match - callback(existing); - return; - } - - // look at the next entry in the index - cursor.continue(); - }; - } - - /** - * Look for room key requests by state - * - * @param wantedStates - list of acceptable states - * - * @returns resolves to the a - * {@link OutgoingRoomKeyRequest}, or null if - * there are no pending requests in those states. If there are multiple - * requests in those states, an arbitrary one is chosen. - */ - getOutgoingRoomKeyRequestByState(wantedStates) { - if (wantedStates.length === 0) { - return Promise.resolve(null); - } - - // this is a bit tortuous because we need to make sure we do the lookup - // in a single transaction, to avoid having a race with the insertion - // code. - - // index into the wantedStates array - let stateIndex = 0; - let result; - function onsuccess() { - const cursor = this.result; - if (cursor) { - // got a match - result = cursor.value; - return; - } - - // try the next state in the list - stateIndex++; - if (stateIndex >= wantedStates.length) { - // no matches - return; - } - const wantedState = wantedStates[stateIndex]; - const cursorReq = this.source.openCursor(wantedState); - cursorReq.onsuccess = onsuccess; - } - const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly"); - const store = txn.objectStore("outgoingRoomKeyRequests"); - const wantedState = wantedStates[stateIndex]; - const cursorReq = store.index("state").openCursor(wantedState); - cursorReq.onsuccess = onsuccess; - return promiseifyTxn(txn).then(() => result); - } - - /** - * - * @returns All elements in a given state - */ - getAllOutgoingRoomKeyRequestsByState(wantedState) { - return new Promise((resolve, reject) => { - const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly"); - const store = txn.objectStore("outgoingRoomKeyRequests"); - const index = store.index("state"); - const request = index.getAll(wantedState); - request.onsuccess = () => resolve(request.result); - request.onerror = () => reject(request.error); - }); - } - getOutgoingRoomKeyRequestsByTarget(userId, deviceId, wantedStates) { - let stateIndex = 0; - const results = []; - function onsuccess() { - const cursor = this.result; - if (cursor) { - const keyReq = cursor.value; - if (keyReq.recipients.some(recipient => recipient.userId === userId && recipient.deviceId === deviceId)) { - results.push(keyReq); - } - cursor.continue(); - } else { - // try the next state in the list - stateIndex++; - if (stateIndex >= wantedStates.length) { - // no matches - return; - } - const wantedState = wantedStates[stateIndex]; - const cursorReq = this.source.openCursor(wantedState); - cursorReq.onsuccess = onsuccess; - } - } - const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly"); - const store = txn.objectStore("outgoingRoomKeyRequests"); - const wantedState = wantedStates[stateIndex]; - const cursorReq = store.index("state").openCursor(wantedState); - cursorReq.onsuccess = onsuccess; - return promiseifyTxn(txn).then(() => results); - } - - /** - * Look for an existing room key request by id and state, and update it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * @param updates - name/value map of updates to apply - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest} - * updated request, or null if no matching row was found - */ - updateOutgoingRoomKeyRequest(requestId, expectedState, updates) { - let result = null; - function onsuccess() { - const cursor = this.result; - if (!cursor) { - return; - } - const data = cursor.value; - if (data.state != expectedState) { - _logger.logger.warn(`Cannot update room key request from ${expectedState} ` + `as it was already updated to ${data.state}`); - return; - } - Object.assign(data, updates); - cursor.update(data); - result = data; - } - const txn = this.db.transaction("outgoingRoomKeyRequests", "readwrite"); - const cursorReq = txn.objectStore("outgoingRoomKeyRequests").openCursor(requestId); - cursorReq.onsuccess = onsuccess; - return promiseifyTxn(txn).then(() => result); - } - - /** - * Look for an existing room key request by id and state, and delete it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * - * @returns resolves once the operation is completed - */ - deleteOutgoingRoomKeyRequest(requestId, expectedState) { - const txn = this.db.transaction("outgoingRoomKeyRequests", "readwrite"); - const cursorReq = txn.objectStore("outgoingRoomKeyRequests").openCursor(requestId); - cursorReq.onsuccess = () => { - const cursor = cursorReq.result; - if (!cursor) { - return; - } - const data = cursor.value; - if (data.state != expectedState) { - _logger.logger.warn(`Cannot delete room key request in state ${data.state} ` + `(expected ${expectedState})`); - return; - } - cursor.delete(); - }; - return promiseifyTxn(txn); - } - - // Olm Account - - getAccount(txn, func) { - const objectStore = txn.objectStore("account"); - const getReq = objectStore.get("-"); - getReq.onsuccess = function () { - try { - func(getReq.result || null); - } catch (e) { - abortWithException(txn, e); - } - }; - } - storeAccount(txn, accountPickle) { - const objectStore = txn.objectStore("account"); - objectStore.put(accountPickle, "-"); - } - getCrossSigningKeys(txn, func) { - const objectStore = txn.objectStore("account"); - const getReq = objectStore.get("crossSigningKeys"); - getReq.onsuccess = function () { - try { - func(getReq.result || null); - } catch (e) { - abortWithException(txn, e); - } - }; - } - getSecretStorePrivateKey(txn, func, type) { - const objectStore = txn.objectStore("account"); - const getReq = objectStore.get(`ssss_cache:${type}`); - getReq.onsuccess = function () { - try { - func(getReq.result || null); - } catch (e) { - abortWithException(txn, e); - } - }; - } - storeCrossSigningKeys(txn, keys) { - const objectStore = txn.objectStore("account"); - objectStore.put(keys, "crossSigningKeys"); - } - storeSecretStorePrivateKey(txn, type, key) { - const objectStore = txn.objectStore("account"); - objectStore.put(key, `ssss_cache:${type}`); - } - - // Olm Sessions - - countEndToEndSessions(txn, func) { - const objectStore = txn.objectStore("sessions"); - const countReq = objectStore.count(); - countReq.onsuccess = function () { - try { - func(countReq.result); - } catch (e) { - abortWithException(txn, e); - } - }; - } - getEndToEndSessions(deviceKey, txn, func) { - const objectStore = txn.objectStore("sessions"); - const idx = objectStore.index("deviceKey"); - const getReq = idx.openCursor(deviceKey); - const results = {}; - getReq.onsuccess = function () { - const cursor = getReq.result; - if (cursor) { - results[cursor.value.sessionId] = { - session: cursor.value.session, - lastReceivedMessageTs: cursor.value.lastReceivedMessageTs - }; - cursor.continue(); - } else { - try { - func(results); - } catch (e) { - abortWithException(txn, e); - } - } - }; - } - getEndToEndSession(deviceKey, sessionId, txn, func) { - const objectStore = txn.objectStore("sessions"); - const getReq = objectStore.get([deviceKey, sessionId]); - getReq.onsuccess = function () { - try { - if (getReq.result) { - func({ - session: getReq.result.session, - lastReceivedMessageTs: getReq.result.lastReceivedMessageTs - }); - } else { - func(null); - } - } catch (e) { - abortWithException(txn, e); - } - }; - } - getAllEndToEndSessions(txn, func) { - const objectStore = txn.objectStore("sessions"); - const getReq = objectStore.openCursor(); - getReq.onsuccess = function () { - try { - const cursor = getReq.result; - if (cursor) { - func(cursor.value); - cursor.continue(); - } else { - func(null); - } - } catch (e) { - abortWithException(txn, e); - } - }; - } - storeEndToEndSession(deviceKey, sessionId, sessionInfo, txn) { - const objectStore = txn.objectStore("sessions"); - objectStore.put({ - deviceKey, - sessionId, - session: sessionInfo.session, - lastReceivedMessageTs: sessionInfo.lastReceivedMessageTs - }); - } - async storeEndToEndSessionProblem(deviceKey, type, fixed) { - const txn = this.db.transaction("session_problems", "readwrite"); - const objectStore = txn.objectStore("session_problems"); - objectStore.put({ - deviceKey, - type, - fixed, - time: Date.now() - }); - await promiseifyTxn(txn); - } - async getEndToEndSessionProblem(deviceKey, timestamp) { - let result = null; - const txn = this.db.transaction("session_problems", "readwrite"); - const objectStore = txn.objectStore("session_problems"); - const index = objectStore.index("deviceKey"); - const req = index.getAll(deviceKey); - req.onsuccess = () => { - const problems = req.result; - if (!problems.length) { - result = null; - return; - } - problems.sort((a, b) => { - return a.time - b.time; - }); - const lastProblem = problems[problems.length - 1]; - for (const problem of problems) { - if (problem.time > timestamp) { - result = Object.assign({}, problem, { - fixed: lastProblem.fixed - }); - return; - } - } - if (lastProblem.fixed) { - result = null; - } else { - result = lastProblem; - } - }; - await promiseifyTxn(txn); - return result; - } - - // FIXME: we should probably prune this when devices get deleted - async filterOutNotifiedErrorDevices(devices) { - const txn = this.db.transaction("notified_error_devices", "readwrite"); - const objectStore = txn.objectStore("notified_error_devices"); - const ret = []; - await Promise.all(devices.map(device => { - return new Promise(resolve => { - const { - userId, - deviceInfo - } = device; - const getReq = objectStore.get([userId, deviceInfo.deviceId]); - getReq.onsuccess = function () { - if (!getReq.result) { - objectStore.put({ - userId, - deviceId: deviceInfo.deviceId - }); - ret.push(device); - } - resolve(); - }; - }); - })); - return ret; - } - - // Inbound group sessions - - getEndToEndInboundGroupSession(senderCurve25519Key, sessionId, txn, func) { - let session = false; - let withheld = false; - const objectStore = txn.objectStore("inbound_group_sessions"); - const getReq = objectStore.get([senderCurve25519Key, sessionId]); - getReq.onsuccess = function () { - try { - if (getReq.result) { - session = getReq.result.session; - } else { - session = null; - } - if (withheld !== false) { - func(session, withheld); - } - } catch (e) { - abortWithException(txn, e); - } - }; - const withheldObjectStore = txn.objectStore("inbound_group_sessions_withheld"); - const withheldGetReq = withheldObjectStore.get([senderCurve25519Key, sessionId]); - withheldGetReq.onsuccess = function () { - try { - if (withheldGetReq.result) { - withheld = withheldGetReq.result.session; - } else { - withheld = null; - } - if (session !== false) { - func(session, withheld); - } - } catch (e) { - abortWithException(txn, e); - } - }; - } - getAllEndToEndInboundGroupSessions(txn, func) { - const objectStore = txn.objectStore("inbound_group_sessions"); - const getReq = objectStore.openCursor(); - getReq.onsuccess = function () { - const cursor = getReq.result; - if (cursor) { - try { - func({ - senderKey: cursor.value.senderCurve25519Key, - sessionId: cursor.value.sessionId, - sessionData: cursor.value.session - }); - } catch (e) { - abortWithException(txn, e); - } - cursor.continue(); - } else { - try { - func(null); - } catch (e) { - abortWithException(txn, e); - } - } - }; - } - addEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - const objectStore = txn.objectStore("inbound_group_sessions"); - const addReq = objectStore.add({ - senderCurve25519Key, - sessionId, - session: sessionData - }); - addReq.onerror = ev => { - var _addReq$error; - if (((_addReq$error = addReq.error) === null || _addReq$error === void 0 ? void 0 : _addReq$error.name) === "ConstraintError") { - // This stops the error from triggering the txn's onerror - ev.stopPropagation(); - // ...and this stops it from aborting the transaction - ev.preventDefault(); - _logger.logger.log("Ignoring duplicate inbound group session: " + senderCurve25519Key + " / " + sessionId); - } else { - abortWithException(txn, new Error("Failed to add inbound group session: " + addReq.error)); - } - }; - } - storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - const objectStore = txn.objectStore("inbound_group_sessions"); - objectStore.put({ - senderCurve25519Key, - sessionId, - session: sessionData - }); - } - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId, sessionData, txn) { - const objectStore = txn.objectStore("inbound_group_sessions_withheld"); - objectStore.put({ - senderCurve25519Key, - sessionId, - session: sessionData - }); - } - getEndToEndDeviceData(txn, func) { - const objectStore = txn.objectStore("device_data"); - const getReq = objectStore.get("-"); - getReq.onsuccess = function () { - try { - func(getReq.result || null); - } catch (e) { - abortWithException(txn, e); - } - }; - } - storeEndToEndDeviceData(deviceData, txn) { - const objectStore = txn.objectStore("device_data"); - objectStore.put(deviceData, "-"); - } - storeEndToEndRoom(roomId, roomInfo, txn) { - const objectStore = txn.objectStore("rooms"); - objectStore.put(roomInfo, roomId); - } - getEndToEndRooms(txn, func) { - const rooms = {}; - const objectStore = txn.objectStore("rooms"); - const getReq = objectStore.openCursor(); - getReq.onsuccess = function () { - const cursor = getReq.result; - if (cursor) { - rooms[cursor.key] = cursor.value; - cursor.continue(); - } else { - try { - func(rooms); - } catch (e) { - abortWithException(txn, e); - } - } - }; - } - - // session backups - - getSessionsNeedingBackup(limit) { - return new Promise((resolve, reject) => { - const sessions = []; - const txn = this.db.transaction(["sessions_needing_backup", "inbound_group_sessions"], "readonly"); - txn.onerror = reject; - txn.oncomplete = function () { - resolve(sessions); - }; - const objectStore = txn.objectStore("sessions_needing_backup"); - const sessionStore = txn.objectStore("inbound_group_sessions"); - const getReq = objectStore.openCursor(); - getReq.onsuccess = function () { - const cursor = getReq.result; - if (cursor) { - const sessionGetReq = sessionStore.get(cursor.key); - sessionGetReq.onsuccess = function () { - sessions.push({ - senderKey: sessionGetReq.result.senderCurve25519Key, - sessionId: sessionGetReq.result.sessionId, - sessionData: sessionGetReq.result.session - }); - }; - if (!limit || sessions.length < limit) { - cursor.continue(); - } - } - }; - }); - } - countSessionsNeedingBackup(txn) { - if (!txn) { - txn = this.db.transaction("sessions_needing_backup", "readonly"); - } - const objectStore = txn.objectStore("sessions_needing_backup"); - return new Promise((resolve, reject) => { - const req = objectStore.count(); - req.onerror = reject; - req.onsuccess = () => resolve(req.result); - }); - } - async unmarkSessionsNeedingBackup(sessions, txn) { - if (!txn) { - txn = this.db.transaction("sessions_needing_backup", "readwrite"); - } - const objectStore = txn.objectStore("sessions_needing_backup"); - await Promise.all(sessions.map(session => { - return new Promise((resolve, reject) => { - const req = objectStore.delete([session.senderKey, session.sessionId]); - req.onsuccess = resolve; - req.onerror = reject; - }); - })); - } - async markSessionsNeedingBackup(sessions, txn) { - if (!txn) { - txn = this.db.transaction("sessions_needing_backup", "readwrite"); - } - const objectStore = txn.objectStore("sessions_needing_backup"); - await Promise.all(sessions.map(session => { - return new Promise((resolve, reject) => { - const req = objectStore.put({ - senderCurve25519Key: session.senderKey, - sessionId: session.sessionId - }); - req.onsuccess = resolve; - req.onerror = reject; - }); - })); - } - addSharedHistoryInboundGroupSession(roomId, senderKey, sessionId, txn) { - if (!txn) { - txn = this.db.transaction("shared_history_inbound_group_sessions", "readwrite"); - } - const objectStore = txn.objectStore("shared_history_inbound_group_sessions"); - const req = objectStore.get([roomId]); - req.onsuccess = () => { - const { - sessions - } = req.result || { - sessions: [] - }; - sessions.push([senderKey, sessionId]); - objectStore.put({ - roomId, - sessions - }); - }; - } - getSharedHistoryInboundGroupSessions(roomId, txn) { - if (!txn) { - txn = this.db.transaction("shared_history_inbound_group_sessions", "readonly"); - } - const objectStore = txn.objectStore("shared_history_inbound_group_sessions"); - const req = objectStore.get([roomId]); - return new Promise((resolve, reject) => { - req.onsuccess = () => { - const { - sessions - } = req.result || { - sessions: [] - }; - resolve(sessions); - }; - req.onerror = reject; - }); - } - addParkedSharedHistory(roomId, parkedData, txn) { - if (!txn) { - txn = this.db.transaction("parked_shared_history", "readwrite"); - } - const objectStore = txn.objectStore("parked_shared_history"); - const req = objectStore.get([roomId]); - req.onsuccess = () => { - const { - parked - } = req.result || { - parked: [] - }; - parked.push(parkedData); - objectStore.put({ - roomId, - parked - }); - }; - } - takeParkedSharedHistory(roomId, txn) { - if (!txn) { - txn = this.db.transaction("parked_shared_history", "readwrite"); - } - const cursorReq = txn.objectStore("parked_shared_history").openCursor(roomId); - return new Promise((resolve, reject) => { - cursorReq.onsuccess = () => { - const cursor = cursorReq.result; - if (!cursor) { - resolve([]); - return; - } - const data = cursor.value; - cursor.delete(); - resolve(data); - }; - cursorReq.onerror = reject; - }); - } - doTxn(mode, stores, func, log = _logger.logger) { - let startTime; - let description; - if (PROFILE_TRANSACTIONS) { - const txnId = this.nextTxnId++; - startTime = Date.now(); - description = `${mode} crypto store transaction ${txnId} in ${stores}`; - log.debug(`Starting ${description}`); - } - const txn = this.db.transaction(stores, mode); - const promise = promiseifyTxn(txn); - const result = func(txn); - if (PROFILE_TRANSACTIONS) { - promise.then(() => { - const elapsedTime = Date.now() - startTime; - log.debug(`Finished ${description}, took ${elapsedTime} ms`); - }, () => { - const elapsedTime = Date.now() - startTime; - log.error(`Failed ${description}, took ${elapsedTime} ms`); - }); - } - return promise.then(() => { - return result; - }); - } -} -exports.Backend = Backend; -const DB_MIGRATIONS = [db => { - createDatabase(db); -}, db => { - db.createObjectStore("account"); -}, db => { - const sessionsStore = db.createObjectStore("sessions", { - keyPath: ["deviceKey", "sessionId"] - }); - sessionsStore.createIndex("deviceKey", "deviceKey"); -}, db => { - db.createObjectStore("inbound_group_sessions", { - keyPath: ["senderCurve25519Key", "sessionId"] - }); -}, db => { - db.createObjectStore("device_data"); -}, db => { - db.createObjectStore("rooms"); -}, db => { - db.createObjectStore("sessions_needing_backup", { - keyPath: ["senderCurve25519Key", "sessionId"] - }); -}, db => { - db.createObjectStore("inbound_group_sessions_withheld", { - keyPath: ["senderCurve25519Key", "sessionId"] - }); -}, db => { - const problemsStore = db.createObjectStore("session_problems", { - keyPath: ["deviceKey", "time"] - }); - problemsStore.createIndex("deviceKey", "deviceKey"); - db.createObjectStore("notified_error_devices", { - keyPath: ["userId", "deviceId"] - }); -}, db => { - db.createObjectStore("shared_history_inbound_group_sessions", { - keyPath: ["roomId"] - }); -}, db => { - db.createObjectStore("parked_shared_history", { - keyPath: ["roomId"] - }); -} -// Expand as needed. -]; - -const VERSION = DB_MIGRATIONS.length; -exports.VERSION = VERSION; -function upgradeDatabase(db, oldVersion) { - _logger.logger.log(`Upgrading IndexedDBCryptoStore from version ${oldVersion}` + ` to ${VERSION}`); - DB_MIGRATIONS.forEach((migration, index) => { - if (oldVersion <= index) migration(db); - }); -} -function createDatabase(db) { - const outgoingRoomKeyRequestsStore = db.createObjectStore("outgoingRoomKeyRequests", { - keyPath: "requestId" - }); - - // we assume that the RoomKeyRequestBody will have room_id and session_id - // properties, to make the index efficient. - outgoingRoomKeyRequestsStore.createIndex("session", ["requestBody.room_id", "requestBody.session_id"]); - outgoingRoomKeyRequestsStore.createIndex("state", "state"); -} -/* - * Aborts a transaction with a given exception - * The transaction promise will be rejected with this exception. - */ -function abortWithException(txn, e) { - // We cheekily stick our exception onto the transaction object here - // We could alternatively make the thing we pass back to the app - // an object containing the transaction and exception. - txn._mx_abortexception = e; - try { - txn.abort(); - } catch (e) { - // sometimes we won't be able to abort the transaction - // (ie. if it's aborted or completed) - } -} -function promiseifyTxn(txn) { - return new Promise((resolve, reject) => { - txn.oncomplete = () => { - if (txn._mx_abortexception !== undefined) { - reject(txn._mx_abortexception); - } - resolve(null); - }; - txn.onerror = event => { - if (txn._mx_abortexception !== undefined) { - reject(txn._mx_abortexception); - } else { - _logger.logger.log("Error performing indexeddb txn", event); - reject(txn.error); - } - }; - txn.onabort = event => { - if (txn._mx_abortexception !== undefined) { - reject(txn._mx_abortexception); - } else { - _logger.logger.log("Error performing indexeddb txn", event); - reject(txn.error); - } - }; - }); -} -//# sourceMappingURL=indexeddb-crypto-store-backend.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js.map deleted file mode 100644 index 4395ab3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store-backend.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-crypto-store-backend.js","names":["_logger","require","utils","_interopRequireWildcard","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","PROFILE_TRANSACTIONS","Backend","constructor","db","_defineProperty2","onversionchange","logger","log","name","close","startup","deleteAllData","Error","getOrAddOutgoingRoomKeyRequest","request","requestBody","Promise","resolve","reject","txn","transaction","onerror","_getOutgoingRoomKeyRequest","existing","room_id","session_id","oncomplete","store","objectStore","add","getOutgoingRoomKeyRequest","callback","idx","index","cursorReq","openCursor","onsuccess","cursor","result","value","deepCompare","continue","getOutgoingRoomKeyRequestByState","wantedStates","length","stateIndex","wantedState","source","promiseifyTxn","then","getAllOutgoingRoomKeyRequestsByState","getAll","error","getOutgoingRoomKeyRequestsByTarget","userId","deviceId","results","keyReq","recipients","some","recipient","push","updateOutgoingRoomKeyRequest","requestId","expectedState","updates","data","state","warn","assign","update","deleteOutgoingRoomKeyRequest","delete","getAccount","func","getReq","e","abortWithException","storeAccount","accountPickle","put","getCrossSigningKeys","getSecretStorePrivateKey","type","storeCrossSigningKeys","keys","storeSecretStorePrivateKey","countEndToEndSessions","countReq","count","getEndToEndSessions","deviceKey","sessionId","session","lastReceivedMessageTs","getEndToEndSession","getAllEndToEndSessions","storeEndToEndSession","sessionInfo","storeEndToEndSessionProblem","fixed","time","Date","now","getEndToEndSessionProblem","timestamp","req","problems","sort","a","b","lastProblem","problem","filterOutNotifiedErrorDevices","devices","ret","all","map","device","deviceInfo","getEndToEndInboundGroupSession","senderCurve25519Key","withheld","withheldObjectStore","withheldGetReq","getAllEndToEndInboundGroupSessions","senderKey","sessionData","addEndToEndInboundGroupSession","addReq","ev","_addReq$error","stopPropagation","preventDefault","storeEndToEndInboundGroupSession","storeEndToEndInboundGroupSessionWithheld","getEndToEndDeviceData","storeEndToEndDeviceData","deviceData","storeEndToEndRoom","roomId","roomInfo","getEndToEndRooms","rooms","getSessionsNeedingBackup","limit","sessions","sessionStore","sessionGetReq","countSessionsNeedingBackup","unmarkSessionsNeedingBackup","markSessionsNeedingBackup","addSharedHistoryInboundGroupSession","getSharedHistoryInboundGroupSessions","addParkedSharedHistory","parkedData","parked","takeParkedSharedHistory","doTxn","mode","stores","startTime","description","txnId","nextTxnId","debug","promise","elapsedTime","exports","DB_MIGRATIONS","createDatabase","createObjectStore","sessionsStore","keyPath","createIndex","problemsStore","VERSION","upgradeDatabase","oldVersion","forEach","migration","outgoingRoomKeyRequestsStore","_mx_abortexception","abort","undefined","event","onabort"],"sources":["../../../src/crypto/store/indexeddb-crypto-store-backend.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger, PrefixedLogger } from \"../../logger\";\nimport * as utils from \"../../utils\";\nimport {\n CryptoStore,\n IDeviceData,\n IProblem,\n ISession,\n ISessionInfo,\n IWithheld,\n Mode,\n OutgoingRoomKeyRequest,\n ParkedSharedHistory,\n SecretStorePrivateKeys,\n} from \"./base\";\nimport { IRoomKeyRequestBody, IRoomKeyRequestRecipient } from \"../index\";\nimport { ICrossSigningKey } from \"../../client\";\nimport { IOlmDevice } from \"../algorithms/megolm\";\nimport { IRoomEncryption } from \"../RoomList\";\nimport { InboundGroupSessionData } from \"../OlmDevice\";\n\nconst PROFILE_TRANSACTIONS = false;\n\n/**\n * Implementation of a CryptoStore which is backed by an existing\n * IndexedDB connection. Generally you want IndexedDBCryptoStore\n * which connects to the database and defers to one of these.\n */\nexport class Backend implements CryptoStore {\n private nextTxnId = 0;\n\n /**\n */\n public constructor(private db: IDBDatabase) {\n // make sure we close the db on `onversionchange` - otherwise\n // attempts to delete the database will block (and subsequent\n // attempts to re-create it will also block).\n db.onversionchange = (): void => {\n logger.log(`versionchange for indexeddb ${this.db.name}: closing`);\n db.close();\n };\n }\n\n public async startup(): Promise {\n // No work to do, as the startup is done by the caller (e.g IndexedDBCryptoStore)\n // by passing us a ready IDBDatabase instance\n return this;\n }\n public async deleteAllData(): Promise {\n throw Error(\"This is not implemented, call IDBFactory::deleteDatabase(dbName) instead.\");\n }\n\n /**\n * Look for an existing outgoing room key request, and if none is found,\n * add a new one\n *\n *\n * @returns resolves to\n * {@link OutgoingRoomKeyRequest}: either the\n * same instance as passed in, or the existing one.\n */\n public getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise {\n const requestBody = request.requestBody;\n\n return new Promise((resolve, reject) => {\n const txn = this.db.transaction(\"outgoingRoomKeyRequests\", \"readwrite\");\n txn.onerror = reject;\n\n // first see if we already have an entry for this request.\n this._getOutgoingRoomKeyRequest(txn, requestBody, (existing) => {\n if (existing) {\n // this entry matches the request - return it.\n logger.log(\n `already have key request outstanding for ` +\n `${requestBody.room_id} / ${requestBody.session_id}: ` +\n `not sending another`,\n );\n resolve(existing);\n return;\n }\n\n // we got to the end of the list without finding a match\n // - add the new request.\n logger.log(`enqueueing key request for ${requestBody.room_id} / ` + requestBody.session_id);\n txn.oncomplete = (): void => {\n resolve(request);\n };\n const store = txn.objectStore(\"outgoingRoomKeyRequests\");\n store.add(request);\n });\n });\n }\n\n /**\n * Look for an existing room key request\n *\n * @param requestBody - existing request to look for\n *\n * @returns resolves to the matching\n * {@link OutgoingRoomKeyRequest}, or null if\n * not found\n */\n public getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise {\n return new Promise((resolve, reject) => {\n const txn = this.db.transaction(\"outgoingRoomKeyRequests\", \"readonly\");\n txn.onerror = reject;\n\n this._getOutgoingRoomKeyRequest(txn, requestBody, (existing) => {\n resolve(existing);\n });\n });\n }\n\n /**\n * look for an existing room key request in the db\n *\n * @internal\n * @param txn - database transaction\n * @param requestBody - existing request to look for\n * @param callback - function to call with the results of the\n * search. Either passed a matching\n * {@link OutgoingRoomKeyRequest}, or null if\n * not found.\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n private _getOutgoingRoomKeyRequest(\n txn: IDBTransaction,\n requestBody: IRoomKeyRequestBody,\n callback: (req: OutgoingRoomKeyRequest | null) => void,\n ): void {\n const store = txn.objectStore(\"outgoingRoomKeyRequests\");\n\n const idx = store.index(\"session\");\n const cursorReq = idx.openCursor([requestBody.room_id, requestBody.session_id]);\n\n cursorReq.onsuccess = (): void => {\n const cursor = cursorReq.result;\n if (!cursor) {\n // no match found\n callback(null);\n return;\n }\n\n const existing = cursor.value;\n\n if (utils.deepCompare(existing.requestBody, requestBody)) {\n // got a match\n callback(existing);\n return;\n }\n\n // look at the next entry in the index\n cursor.continue();\n };\n }\n\n /**\n * Look for room key requests by state\n *\n * @param wantedStates - list of acceptable states\n *\n * @returns resolves to the a\n * {@link OutgoingRoomKeyRequest}, or null if\n * there are no pending requests in those states. If there are multiple\n * requests in those states, an arbitrary one is chosen.\n */\n public getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise {\n if (wantedStates.length === 0) {\n return Promise.resolve(null);\n }\n\n // this is a bit tortuous because we need to make sure we do the lookup\n // in a single transaction, to avoid having a race with the insertion\n // code.\n\n // index into the wantedStates array\n let stateIndex = 0;\n let result: OutgoingRoomKeyRequest;\n\n function onsuccess(this: IDBRequest): void {\n const cursor = this.result;\n if (cursor) {\n // got a match\n result = cursor.value;\n return;\n }\n\n // try the next state in the list\n stateIndex++;\n if (stateIndex >= wantedStates.length) {\n // no matches\n return;\n }\n\n const wantedState = wantedStates[stateIndex];\n const cursorReq = (this.source as IDBIndex).openCursor(wantedState);\n cursorReq.onsuccess = onsuccess;\n }\n\n const txn = this.db.transaction(\"outgoingRoomKeyRequests\", \"readonly\");\n const store = txn.objectStore(\"outgoingRoomKeyRequests\");\n\n const wantedState = wantedStates[stateIndex];\n const cursorReq = store.index(\"state\").openCursor(wantedState);\n cursorReq.onsuccess = onsuccess;\n\n return promiseifyTxn(txn).then(() => result);\n }\n\n /**\n *\n * @returns All elements in a given state\n */\n public getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise {\n return new Promise((resolve, reject) => {\n const txn = this.db.transaction(\"outgoingRoomKeyRequests\", \"readonly\");\n const store = txn.objectStore(\"outgoingRoomKeyRequests\");\n const index = store.index(\"state\");\n const request = index.getAll(wantedState);\n\n request.onsuccess = (): void => resolve(request.result);\n request.onerror = (): void => reject(request.error);\n });\n }\n\n public getOutgoingRoomKeyRequestsByTarget(\n userId: string,\n deviceId: string,\n wantedStates: number[],\n ): Promise {\n let stateIndex = 0;\n const results: OutgoingRoomKeyRequest[] = [];\n\n function onsuccess(this: IDBRequest): void {\n const cursor = this.result;\n if (cursor) {\n const keyReq = cursor.value;\n if (\n keyReq.recipients.some(\n (recipient: IRoomKeyRequestRecipient) =>\n recipient.userId === userId && recipient.deviceId === deviceId,\n )\n ) {\n results.push(keyReq);\n }\n cursor.continue();\n } else {\n // try the next state in the list\n stateIndex++;\n if (stateIndex >= wantedStates.length) {\n // no matches\n return;\n }\n\n const wantedState = wantedStates[stateIndex];\n const cursorReq = (this.source as IDBIndex).openCursor(wantedState);\n cursorReq.onsuccess = onsuccess;\n }\n }\n\n const txn = this.db.transaction(\"outgoingRoomKeyRequests\", \"readonly\");\n const store = txn.objectStore(\"outgoingRoomKeyRequests\");\n\n const wantedState = wantedStates[stateIndex];\n const cursorReq = store.index(\"state\").openCursor(wantedState);\n cursorReq.onsuccess = onsuccess;\n\n return promiseifyTxn(txn).then(() => results);\n }\n\n /**\n * Look for an existing room key request by id and state, and update it if\n * found\n *\n * @param requestId - ID of request to update\n * @param expectedState - state we expect to find the request in\n * @param updates - name/value map of updates to apply\n *\n * @returns resolves to\n * {@link OutgoingRoomKeyRequest}\n * updated request, or null if no matching row was found\n */\n public updateOutgoingRoomKeyRequest(\n requestId: string,\n expectedState: number,\n updates: Partial,\n ): Promise {\n let result: OutgoingRoomKeyRequest | null = null;\n\n function onsuccess(this: IDBRequest): void {\n const cursor = this.result;\n if (!cursor) {\n return;\n }\n const data = cursor.value;\n if (data.state != expectedState) {\n logger.warn(\n `Cannot update room key request from ${expectedState} ` +\n `as it was already updated to ${data.state}`,\n );\n return;\n }\n Object.assign(data, updates);\n cursor.update(data);\n result = data;\n }\n\n const txn = this.db.transaction(\"outgoingRoomKeyRequests\", \"readwrite\");\n const cursorReq = txn.objectStore(\"outgoingRoomKeyRequests\").openCursor(requestId);\n cursorReq.onsuccess = onsuccess;\n return promiseifyTxn(txn).then(() => result);\n }\n\n /**\n * Look for an existing room key request by id and state, and delete it if\n * found\n *\n * @param requestId - ID of request to update\n * @param expectedState - state we expect to find the request in\n *\n * @returns resolves once the operation is completed\n */\n public deleteOutgoingRoomKeyRequest(\n requestId: string,\n expectedState: number,\n ): Promise {\n const txn = this.db.transaction(\"outgoingRoomKeyRequests\", \"readwrite\");\n const cursorReq = txn.objectStore(\"outgoingRoomKeyRequests\").openCursor(requestId);\n cursorReq.onsuccess = (): void => {\n const cursor = cursorReq.result;\n if (!cursor) {\n return;\n }\n const data = cursor.value;\n if (data.state != expectedState) {\n logger.warn(`Cannot delete room key request in state ${data.state} ` + `(expected ${expectedState})`);\n return;\n }\n cursor.delete();\n };\n return promiseifyTxn(txn);\n }\n\n // Olm Account\n\n public getAccount(txn: IDBTransaction, func: (accountPickle: string | null) => void): void {\n const objectStore = txn.objectStore(\"account\");\n const getReq = objectStore.get(\"-\");\n getReq.onsuccess = function (): void {\n try {\n func(getReq.result || null);\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public storeAccount(txn: IDBTransaction, accountPickle: string): void {\n const objectStore = txn.objectStore(\"account\");\n objectStore.put(accountPickle, \"-\");\n }\n\n public getCrossSigningKeys(\n txn: IDBTransaction,\n func: (keys: Record | null) => void,\n ): void {\n const objectStore = txn.objectStore(\"account\");\n const getReq = objectStore.get(\"crossSigningKeys\");\n getReq.onsuccess = function (): void {\n try {\n func(getReq.result || null);\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public getSecretStorePrivateKey(\n txn: IDBTransaction,\n func: (key: SecretStorePrivateKeys[K] | null) => void,\n type: K,\n ): void {\n const objectStore = txn.objectStore(\"account\");\n const getReq = objectStore.get(`ssss_cache:${type}`);\n getReq.onsuccess = function (): void {\n try {\n func(getReq.result || null);\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public storeCrossSigningKeys(txn: IDBTransaction, keys: Record): void {\n const objectStore = txn.objectStore(\"account\");\n objectStore.put(keys, \"crossSigningKeys\");\n }\n\n public storeSecretStorePrivateKey(\n txn: IDBTransaction,\n type: K,\n key: SecretStorePrivateKeys[K],\n ): void {\n const objectStore = txn.objectStore(\"account\");\n objectStore.put(key, `ssss_cache:${type}`);\n }\n\n // Olm Sessions\n\n public countEndToEndSessions(txn: IDBTransaction, func: (count: number) => void): void {\n const objectStore = txn.objectStore(\"sessions\");\n const countReq = objectStore.count();\n countReq.onsuccess = function (): void {\n try {\n func(countReq.result);\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public getEndToEndSessions(\n deviceKey: string,\n txn: IDBTransaction,\n func: (sessions: { [sessionId: string]: ISessionInfo }) => void,\n ): void {\n const objectStore = txn.objectStore(\"sessions\");\n const idx = objectStore.index(\"deviceKey\");\n const getReq = idx.openCursor(deviceKey);\n const results: Parameters[2]>[0] = {};\n getReq.onsuccess = function (): void {\n const cursor = getReq.result;\n if (cursor) {\n results[cursor.value.sessionId] = {\n session: cursor.value.session,\n lastReceivedMessageTs: cursor.value.lastReceivedMessageTs,\n };\n cursor.continue();\n } else {\n try {\n func(results);\n } catch (e) {\n abortWithException(txn, e);\n }\n }\n };\n }\n\n public getEndToEndSession(\n deviceKey: string,\n sessionId: string,\n txn: IDBTransaction,\n func: (session: ISessionInfo | null) => void,\n ): void {\n const objectStore = txn.objectStore(\"sessions\");\n const getReq = objectStore.get([deviceKey, sessionId]);\n getReq.onsuccess = function (): void {\n try {\n if (getReq.result) {\n func({\n session: getReq.result.session,\n lastReceivedMessageTs: getReq.result.lastReceivedMessageTs,\n });\n } else {\n func(null);\n }\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public getAllEndToEndSessions(txn: IDBTransaction, func: (session: ISessionInfo | null) => void): void {\n const objectStore = txn.objectStore(\"sessions\");\n const getReq = objectStore.openCursor();\n getReq.onsuccess = function (): void {\n try {\n const cursor = getReq.result;\n if (cursor) {\n func(cursor.value);\n cursor.continue();\n } else {\n func(null);\n }\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public storeEndToEndSession(\n deviceKey: string,\n sessionId: string,\n sessionInfo: ISessionInfo,\n txn: IDBTransaction,\n ): void {\n const objectStore = txn.objectStore(\"sessions\");\n objectStore.put({\n deviceKey,\n sessionId,\n session: sessionInfo.session,\n lastReceivedMessageTs: sessionInfo.lastReceivedMessageTs,\n });\n }\n\n public async storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise {\n const txn = this.db.transaction(\"session_problems\", \"readwrite\");\n const objectStore = txn.objectStore(\"session_problems\");\n objectStore.put({\n deviceKey,\n type,\n fixed,\n time: Date.now(),\n });\n await promiseifyTxn(txn);\n }\n\n public async getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise {\n let result: IProblem | null = null;\n const txn = this.db.transaction(\"session_problems\", \"readwrite\");\n const objectStore = txn.objectStore(\"session_problems\");\n const index = objectStore.index(\"deviceKey\");\n const req = index.getAll(deviceKey);\n req.onsuccess = (): void => {\n const problems = req.result;\n if (!problems.length) {\n result = null;\n return;\n }\n problems.sort((a, b) => {\n return a.time - b.time;\n });\n const lastProblem = problems[problems.length - 1];\n for (const problem of problems) {\n if (problem.time > timestamp) {\n result = Object.assign({}, problem, { fixed: lastProblem.fixed });\n return;\n }\n }\n if (lastProblem.fixed) {\n result = null;\n } else {\n result = lastProblem;\n }\n };\n await promiseifyTxn(txn);\n return result;\n }\n\n // FIXME: we should probably prune this when devices get deleted\n public async filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise {\n const txn = this.db.transaction(\"notified_error_devices\", \"readwrite\");\n const objectStore = txn.objectStore(\"notified_error_devices\");\n\n const ret: IOlmDevice[] = [];\n\n await Promise.all(\n devices.map((device) => {\n return new Promise((resolve) => {\n const { userId, deviceInfo } = device;\n const getReq = objectStore.get([userId, deviceInfo.deviceId]);\n getReq.onsuccess = function (): void {\n if (!getReq.result) {\n objectStore.put({ userId, deviceId: deviceInfo.deviceId });\n ret.push(device);\n }\n resolve();\n };\n });\n }),\n );\n\n return ret;\n }\n\n // Inbound group sessions\n\n public getEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n txn: IDBTransaction,\n func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,\n ): void {\n let session: InboundGroupSessionData | null | boolean = false;\n let withheld: IWithheld | null | boolean = false;\n const objectStore = txn.objectStore(\"inbound_group_sessions\");\n const getReq = objectStore.get([senderCurve25519Key, sessionId]);\n getReq.onsuccess = function (): void {\n try {\n if (getReq.result) {\n session = getReq.result.session;\n } else {\n session = null;\n }\n if (withheld !== false) {\n func(session as InboundGroupSessionData, withheld as IWithheld);\n }\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n\n const withheldObjectStore = txn.objectStore(\"inbound_group_sessions_withheld\");\n const withheldGetReq = withheldObjectStore.get([senderCurve25519Key, sessionId]);\n withheldGetReq.onsuccess = function (): void {\n try {\n if (withheldGetReq.result) {\n withheld = withheldGetReq.result.session;\n } else {\n withheld = null;\n }\n if (session !== false) {\n func(session as InboundGroupSessionData, withheld as IWithheld);\n }\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public getAllEndToEndInboundGroupSessions(txn: IDBTransaction, func: (session: ISession | null) => void): void {\n const objectStore = txn.objectStore(\"inbound_group_sessions\");\n const getReq = objectStore.openCursor();\n getReq.onsuccess = function (): void {\n const cursor = getReq.result;\n if (cursor) {\n try {\n func({\n senderKey: cursor.value.senderCurve25519Key,\n sessionId: cursor.value.sessionId,\n sessionData: cursor.value.session,\n });\n } catch (e) {\n abortWithException(txn, e);\n }\n cursor.continue();\n } else {\n try {\n func(null);\n } catch (e) {\n abortWithException(txn, e);\n }\n }\n };\n }\n\n public addEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: IDBTransaction,\n ): void {\n const objectStore = txn.objectStore(\"inbound_group_sessions\");\n const addReq = objectStore.add({\n senderCurve25519Key,\n sessionId,\n session: sessionData,\n });\n addReq.onerror = (ev): void => {\n if (addReq.error?.name === \"ConstraintError\") {\n // This stops the error from triggering the txn's onerror\n ev.stopPropagation();\n // ...and this stops it from aborting the transaction\n ev.preventDefault();\n logger.log(\"Ignoring duplicate inbound group session: \" + senderCurve25519Key + \" / \" + sessionId);\n } else {\n abortWithException(txn, new Error(\"Failed to add inbound group session: \" + addReq.error));\n }\n };\n }\n\n public storeEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: IDBTransaction,\n ): void {\n const objectStore = txn.objectStore(\"inbound_group_sessions\");\n objectStore.put({\n senderCurve25519Key,\n sessionId,\n session: sessionData,\n });\n }\n\n public storeEndToEndInboundGroupSessionWithheld(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: IWithheld,\n txn: IDBTransaction,\n ): void {\n const objectStore = txn.objectStore(\"inbound_group_sessions_withheld\");\n objectStore.put({\n senderCurve25519Key,\n sessionId,\n session: sessionData,\n });\n }\n\n public getEndToEndDeviceData(txn: IDBTransaction, func: (deviceData: IDeviceData | null) => void): void {\n const objectStore = txn.objectStore(\"device_data\");\n const getReq = objectStore.get(\"-\");\n getReq.onsuccess = function (): void {\n try {\n func(getReq.result || null);\n } catch (e) {\n abortWithException(txn, e);\n }\n };\n }\n\n public storeEndToEndDeviceData(deviceData: IDeviceData, txn: IDBTransaction): void {\n const objectStore = txn.objectStore(\"device_data\");\n objectStore.put(deviceData, \"-\");\n }\n\n public storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: IDBTransaction): void {\n const objectStore = txn.objectStore(\"rooms\");\n objectStore.put(roomInfo, roomId);\n }\n\n public getEndToEndRooms(txn: IDBTransaction, func: (rooms: Record) => void): void {\n const rooms: Parameters[1]>[0] = {};\n const objectStore = txn.objectStore(\"rooms\");\n const getReq = objectStore.openCursor();\n getReq.onsuccess = function (): void {\n const cursor = getReq.result;\n if (cursor) {\n rooms[cursor.key as string] = cursor.value;\n cursor.continue();\n } else {\n try {\n func(rooms);\n } catch (e) {\n abortWithException(txn, e);\n }\n }\n };\n }\n\n // session backups\n\n public getSessionsNeedingBackup(limit: number): Promise {\n return new Promise((resolve, reject) => {\n const sessions: ISession[] = [];\n\n const txn = this.db.transaction([\"sessions_needing_backup\", \"inbound_group_sessions\"], \"readonly\");\n txn.onerror = reject;\n txn.oncomplete = function (): void {\n resolve(sessions);\n };\n const objectStore = txn.objectStore(\"sessions_needing_backup\");\n const sessionStore = txn.objectStore(\"inbound_group_sessions\");\n const getReq = objectStore.openCursor();\n getReq.onsuccess = function (): void {\n const cursor = getReq.result;\n if (cursor) {\n const sessionGetReq = sessionStore.get(cursor.key);\n sessionGetReq.onsuccess = function (): void {\n sessions.push({\n senderKey: sessionGetReq.result.senderCurve25519Key,\n sessionId: sessionGetReq.result.sessionId,\n sessionData: sessionGetReq.result.session,\n });\n };\n if (!limit || sessions.length < limit) {\n cursor.continue();\n }\n }\n };\n });\n }\n\n public countSessionsNeedingBackup(txn?: IDBTransaction): Promise {\n if (!txn) {\n txn = this.db.transaction(\"sessions_needing_backup\", \"readonly\");\n }\n const objectStore = txn.objectStore(\"sessions_needing_backup\");\n return new Promise((resolve, reject) => {\n const req = objectStore.count();\n req.onerror = reject;\n req.onsuccess = (): void => resolve(req.result);\n });\n }\n\n public async unmarkSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise {\n if (!txn) {\n txn = this.db.transaction(\"sessions_needing_backup\", \"readwrite\");\n }\n const objectStore = txn.objectStore(\"sessions_needing_backup\");\n await Promise.all(\n sessions.map((session) => {\n return new Promise((resolve, reject) => {\n const req = objectStore.delete([session.senderKey, session.sessionId]);\n req.onsuccess = resolve;\n req.onerror = reject;\n });\n }),\n );\n }\n\n public async markSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise {\n if (!txn) {\n txn = this.db.transaction(\"sessions_needing_backup\", \"readwrite\");\n }\n const objectStore = txn.objectStore(\"sessions_needing_backup\");\n await Promise.all(\n sessions.map((session) => {\n return new Promise((resolve, reject) => {\n const req = objectStore.put({\n senderCurve25519Key: session.senderKey,\n sessionId: session.sessionId,\n });\n req.onsuccess = resolve;\n req.onerror = reject;\n });\n }),\n );\n }\n\n public addSharedHistoryInboundGroupSession(\n roomId: string,\n senderKey: string,\n sessionId: string,\n txn?: IDBTransaction,\n ): void {\n if (!txn) {\n txn = this.db.transaction(\"shared_history_inbound_group_sessions\", \"readwrite\");\n }\n const objectStore = txn.objectStore(\"shared_history_inbound_group_sessions\");\n const req = objectStore.get([roomId]);\n req.onsuccess = (): void => {\n const { sessions } = req.result || { sessions: [] };\n sessions.push([senderKey, sessionId]);\n objectStore.put({ roomId, sessions });\n };\n }\n\n public getSharedHistoryInboundGroupSessions(\n roomId: string,\n txn?: IDBTransaction,\n ): Promise<[senderKey: string, sessionId: string][]> {\n if (!txn) {\n txn = this.db.transaction(\"shared_history_inbound_group_sessions\", \"readonly\");\n }\n const objectStore = txn.objectStore(\"shared_history_inbound_group_sessions\");\n const req = objectStore.get([roomId]);\n return new Promise((resolve, reject) => {\n req.onsuccess = (): void => {\n const { sessions } = req.result || { sessions: [] };\n resolve(sessions);\n };\n req.onerror = reject;\n });\n }\n\n public addParkedSharedHistory(roomId: string, parkedData: ParkedSharedHistory, txn?: IDBTransaction): void {\n if (!txn) {\n txn = this.db.transaction(\"parked_shared_history\", \"readwrite\");\n }\n const objectStore = txn.objectStore(\"parked_shared_history\");\n const req = objectStore.get([roomId]);\n req.onsuccess = (): void => {\n const { parked } = req.result || { parked: [] };\n parked.push(parkedData);\n objectStore.put({ roomId, parked });\n };\n }\n\n public takeParkedSharedHistory(roomId: string, txn?: IDBTransaction): Promise {\n if (!txn) {\n txn = this.db.transaction(\"parked_shared_history\", \"readwrite\");\n }\n const cursorReq = txn.objectStore(\"parked_shared_history\").openCursor(roomId);\n return new Promise((resolve, reject) => {\n cursorReq.onsuccess = (): void => {\n const cursor = cursorReq.result;\n if (!cursor) {\n resolve([]);\n return;\n }\n const data = cursor.value;\n cursor.delete();\n resolve(data);\n };\n cursorReq.onerror = reject;\n });\n }\n\n public doTxn(\n mode: Mode,\n stores: string | string[],\n func: (txn: IDBTransaction) => T,\n log: PrefixedLogger = logger,\n ): Promise {\n let startTime: number;\n let description: string;\n if (PROFILE_TRANSACTIONS) {\n const txnId = this.nextTxnId++;\n startTime = Date.now();\n description = `${mode} crypto store transaction ${txnId} in ${stores}`;\n log.debug(`Starting ${description}`);\n }\n const txn = this.db.transaction(stores, mode);\n const promise = promiseifyTxn(txn);\n const result = func(txn);\n if (PROFILE_TRANSACTIONS) {\n promise.then(\n () => {\n const elapsedTime = Date.now() - startTime;\n log.debug(`Finished ${description}, took ${elapsedTime} ms`);\n },\n () => {\n const elapsedTime = Date.now() - startTime;\n log.error(`Failed ${description}, took ${elapsedTime} ms`);\n },\n );\n }\n return promise.then(() => {\n return result;\n });\n }\n}\n\ntype DbMigration = (db: IDBDatabase) => void;\nconst DB_MIGRATIONS: DbMigration[] = [\n (db): void => {\n createDatabase(db);\n },\n (db): void => {\n db.createObjectStore(\"account\");\n },\n (db): void => {\n const sessionsStore = db.createObjectStore(\"sessions\", {\n keyPath: [\"deviceKey\", \"sessionId\"],\n });\n sessionsStore.createIndex(\"deviceKey\", \"deviceKey\");\n },\n (db): void => {\n db.createObjectStore(\"inbound_group_sessions\", {\n keyPath: [\"senderCurve25519Key\", \"sessionId\"],\n });\n },\n (db): void => {\n db.createObjectStore(\"device_data\");\n },\n (db): void => {\n db.createObjectStore(\"rooms\");\n },\n (db): void => {\n db.createObjectStore(\"sessions_needing_backup\", {\n keyPath: [\"senderCurve25519Key\", \"sessionId\"],\n });\n },\n (db): void => {\n db.createObjectStore(\"inbound_group_sessions_withheld\", {\n keyPath: [\"senderCurve25519Key\", \"sessionId\"],\n });\n },\n (db): void => {\n const problemsStore = db.createObjectStore(\"session_problems\", {\n keyPath: [\"deviceKey\", \"time\"],\n });\n problemsStore.createIndex(\"deviceKey\", \"deviceKey\");\n\n db.createObjectStore(\"notified_error_devices\", {\n keyPath: [\"userId\", \"deviceId\"],\n });\n },\n (db): void => {\n db.createObjectStore(\"shared_history_inbound_group_sessions\", {\n keyPath: [\"roomId\"],\n });\n },\n (db): void => {\n db.createObjectStore(\"parked_shared_history\", {\n keyPath: [\"roomId\"],\n });\n },\n // Expand as needed.\n];\nexport const VERSION = DB_MIGRATIONS.length;\n\nexport function upgradeDatabase(db: IDBDatabase, oldVersion: number): void {\n logger.log(`Upgrading IndexedDBCryptoStore from version ${oldVersion}` + ` to ${VERSION}`);\n DB_MIGRATIONS.forEach((migration, index) => {\n if (oldVersion <= index) migration(db);\n });\n}\n\nfunction createDatabase(db: IDBDatabase): void {\n const outgoingRoomKeyRequestsStore = db.createObjectStore(\"outgoingRoomKeyRequests\", { keyPath: \"requestId\" });\n\n // we assume that the RoomKeyRequestBody will have room_id and session_id\n // properties, to make the index efficient.\n outgoingRoomKeyRequestsStore.createIndex(\"session\", [\"requestBody.room_id\", \"requestBody.session_id\"]);\n\n outgoingRoomKeyRequestsStore.createIndex(\"state\", \"state\");\n}\n\ninterface IWrappedIDBTransaction extends IDBTransaction {\n _mx_abortexception: Error; // eslint-disable-line camelcase\n}\n\n/*\n * Aborts a transaction with a given exception\n * The transaction promise will be rejected with this exception.\n */\nfunction abortWithException(txn: IDBTransaction, e: Error): void {\n // We cheekily stick our exception onto the transaction object here\n // We could alternatively make the thing we pass back to the app\n // an object containing the transaction and exception.\n (txn as IWrappedIDBTransaction)._mx_abortexception = e;\n try {\n txn.abort();\n } catch (e) {\n // sometimes we won't be able to abort the transaction\n // (ie. if it's aborted or completed)\n }\n}\n\nfunction promiseifyTxn(txn: IDBTransaction): Promise {\n return new Promise((resolve, reject) => {\n txn.oncomplete = (): void => {\n if ((txn as IWrappedIDBTransaction)._mx_abortexception !== undefined) {\n reject((txn as IWrappedIDBTransaction)._mx_abortexception);\n }\n resolve(null);\n };\n txn.onerror = (event): void => {\n if ((txn as IWrappedIDBTransaction)._mx_abortexception !== undefined) {\n reject((txn as IWrappedIDBTransaction)._mx_abortexception);\n } else {\n logger.log(\"Error performing indexeddb txn\", event);\n reject(txn.error);\n }\n };\n txn.onabort = (event): void => {\n if ((txn as IWrappedIDBTransaction)._mx_abortexception !== undefined) {\n reject((txn as IWrappedIDBTransaction)._mx_abortexception);\n } else {\n logger.log(\"Error performing indexeddb txn\", event);\n reject(txn.error);\n }\n };\n });\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts deleted file mode 100644 index 32fcc52..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts +++ /dev/null @@ -1,360 +0,0 @@ -import { PrefixedLogger } from "../../logger"; -import { CryptoStore, IDeviceData, IProblem, ISession, ISessionInfo, IWithheld, Mode, OutgoingRoomKeyRequest, ParkedSharedHistory, SecretStorePrivateKeys } from "./base"; -import { IRoomKeyRequestBody } from "../index"; -import { ICrossSigningKey } from "../../client"; -import { IOlmDevice } from "../algorithms/megolm"; -import { IRoomEncryption } from "../RoomList"; -import { InboundGroupSessionData } from "../OlmDevice"; -/** - * Internal module. indexeddb storage for e2e. - */ -/** - * An implementation of CryptoStore, which is normally backed by an indexeddb, - * but with fallback to MemoryCryptoStore. - */ -export declare class IndexedDBCryptoStore implements CryptoStore { - private readonly indexedDB; - private readonly dbName; - static STORE_ACCOUNT: string; - static STORE_SESSIONS: string; - static STORE_INBOUND_GROUP_SESSIONS: string; - static STORE_INBOUND_GROUP_SESSIONS_WITHHELD: string; - static STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS: string; - static STORE_PARKED_SHARED_HISTORY: string; - static STORE_DEVICE_DATA: string; - static STORE_ROOMS: string; - static STORE_BACKUP: string; - static exists(indexedDB: IDBFactory, dbName: string): Promise; - private backendPromise?; - private backend?; - /** - * Create a new IndexedDBCryptoStore - * - * @param indexedDB - global indexedDB instance - * @param dbName - name of db to connect to - */ - constructor(indexedDB: IDBFactory, dbName: string); - /** - * Ensure the database exists and is up-to-date, or fall back to - * a local storage or in-memory store. - * - * This must be called before the store can be used. - * - * @returns resolves to either an IndexedDBCryptoStoreBackend.Backend, - * or a MemoryCryptoStore - */ - startup(): Promise; - /** - * Delete all data from this store. - * - * @returns resolves when the store has been cleared. - */ - deleteAllData(): Promise; - /** - * Look for an existing outgoing room key request, and if none is found, - * add a new one - * - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest}: either the - * same instance as passed in, or the existing one. - */ - getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise; - /** - * Look for an existing room key request - * - * @param requestBody - existing request to look for - * - * @returns resolves to the matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found - */ - getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise; - /** - * Look for room key requests by state - * - * @param wantedStates - list of acceptable states - * - * @returns resolves to the a - * {@link OutgoingRoomKeyRequest}, or null if - * there are no pending requests in those states. If there are multiple - * requests in those states, an arbitrary one is chosen. - */ - getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise; - /** - * Look for room key requests by state – - * unlike above, return a list of all entries in one state. - * - * @returns Returns an array of requests in the given state - */ - getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise; - /** - * Look for room key requests by target device and state - * - * @param userId - Target user ID - * @param deviceId - Target device ID - * @param wantedStates - list of acceptable states - * - * @returns resolves to a list of all the - * {@link OutgoingRoomKeyRequest} - */ - getOutgoingRoomKeyRequestsByTarget(userId: string, deviceId: string, wantedStates: number[]): Promise; - /** - * Look for an existing room key request by id and state, and update it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * @param updates - name/value map of updates to apply - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest} - * updated request, or null if no matching row was found - */ - updateOutgoingRoomKeyRequest(requestId: string, expectedState: number, updates: Partial): Promise; - /** - * Look for an existing room key request by id and state, and delete it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * - * @returns resolves once the operation is completed - */ - deleteOutgoingRoomKeyRequest(requestId: string, expectedState: number): Promise; - getAccount(txn: IDBTransaction, func: (accountPickle: string | null) => void): void; - /** - * Write the account pickle to the store. - * This requires an active transaction. See doTxn(). - * - * @param txn - An active transaction. See doTxn(). - * @param accountPickle - The new account pickle to store. - */ - storeAccount(txn: IDBTransaction, accountPickle: string): void; - /** - * Get the public part of the cross-signing keys (eg. self-signing key, - * user signing key). - * - * @param txn - An active transaction. See doTxn(). - * @param func - Called with the account keys object: - * `{ key_type: base64 encoded seed }` where key type = user_signing_key_seed or self_signing_key_seed - */ - getCrossSigningKeys(txn: IDBTransaction, func: (keys: Record | null) => void): void; - /** - * @param txn - An active transaction. See doTxn(). - * @param func - Called with the private key - * @param type - A key type - */ - getSecretStorePrivateKey(txn: IDBTransaction, func: (key: SecretStorePrivateKeys[K] | null) => void, type: K): void; - /** - * Write the cross-signing keys back to the store - * - * @param txn - An active transaction. See doTxn(). - * @param keys - keys object as getCrossSigningKeys() - */ - storeCrossSigningKeys(txn: IDBTransaction, keys: Record): void; - /** - * Write the cross-signing private keys back to the store - * - * @param txn - An active transaction. See doTxn(). - * @param type - The type of cross-signing private key to store - * @param key - keys object as getCrossSigningKeys() - */ - storeSecretStorePrivateKey(txn: IDBTransaction, type: K, key: SecretStorePrivateKeys[K]): void; - /** - * Returns the number of end-to-end sessions in the store - * @param txn - An active transaction. See doTxn(). - * @param func - Called with the count of sessions - */ - countEndToEndSessions(txn: IDBTransaction, func: (count: number) => void): void; - /** - * Retrieve a specific end-to-end session between the logged-in user - * and another device. - * @param deviceKey - The public key of the other device. - * @param sessionId - The ID of the session to retrieve - * @param txn - An active transaction. See doTxn(). - * @param func - Called with A map from sessionId - * to session information object with 'session' key being the - * Base64 end-to-end session and lastReceivedMessageTs being the - * timestamp in milliseconds at which the session last received - * a message. - */ - getEndToEndSession(deviceKey: string, sessionId: string, txn: IDBTransaction, func: (session: ISessionInfo | null) => void): void; - /** - * Retrieve the end-to-end sessions between the logged-in user and another - * device. - * @param deviceKey - The public key of the other device. - * @param txn - An active transaction. See doTxn(). - * @param func - Called with A map from sessionId - * to session information object with 'session' key being the - * Base64 end-to-end session and lastReceivedMessageTs being the - * timestamp in milliseconds at which the session last received - * a message. - */ - getEndToEndSessions(deviceKey: string, txn: IDBTransaction, func: (sessions: { - [sessionId: string]: ISessionInfo; - }) => void): void; - /** - * Retrieve all end-to-end sessions - * @param txn - An active transaction. See doTxn(). - * @param func - Called one for each session with - * an object with, deviceKey, lastReceivedMessageTs, sessionId - * and session keys. - */ - getAllEndToEndSessions(txn: IDBTransaction, func: (session: ISessionInfo | null) => void): void; - /** - * Store a session between the logged-in user and another device - * @param deviceKey - The public key of the other device. - * @param sessionId - The ID for this end-to-end session. - * @param sessionInfo - Session information object - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: IDBTransaction): void; - storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise; - getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise; - filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise; - /** - * Retrieve the end-to-end inbound group session for a given - * server key and session ID - * @param senderCurve25519Key - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param txn - An active transaction. See doTxn(). - * @param func - Called with A map from sessionId - * to Base64 end-to-end session. - */ - getEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, txn: IDBTransaction, func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void): void; - /** - * Fetches all inbound group sessions in the store - * @param txn - An active transaction. See doTxn(). - * @param func - Called once for each group session - * in the store with an object having keys `{senderKey, sessionId, sessionData}`, - * then once with null to indicate the end of the list. - */ - getAllEndToEndInboundGroupSessions(txn: IDBTransaction, func: (session: ISession | null) => void): void; - /** - * Adds an end-to-end inbound group session to the store. - * If there already exists an inbound group session with the same - * senderCurve25519Key and sessionID, the session will not be added. - * @param senderCurve25519Key - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param sessionData - The session data structure - * @param txn - An active transaction. See doTxn(). - */ - addEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: IDBTransaction): void; - /** - * Writes an end-to-end inbound group session to the store. - * If there already exists an inbound group session with the same - * senderCurve25519Key and sessionID, it will be overwritten. - * @param senderCurve25519Key - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param sessionData - The session data structure - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: IDBTransaction): void; - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key: string, sessionId: string, sessionData: IWithheld, txn: IDBTransaction): void; - /** - * Store the state of all tracked devices - * This contains devices for each user, a tracking state for each user - * and a sync token matching the point in time the snapshot represents. - * These all need to be written out in full each time such that the snapshot - * is always consistent, so they are stored in one object. - * - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndDeviceData(deviceData: IDeviceData, txn: IDBTransaction): void; - /** - * Get the state of all tracked devices - * - * @param txn - An active transaction. See doTxn(). - * @param func - Function called with the - * device data - */ - getEndToEndDeviceData(txn: IDBTransaction, func: (deviceData: IDeviceData | null) => void): void; - /** - * Store the end-to-end state for a room. - * @param roomId - The room's ID. - * @param roomInfo - The end-to-end info for the room. - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: IDBTransaction): void; - /** - * Get an object of `roomId->roomInfo` for all e2e rooms in the store - * @param txn - An active transaction. See doTxn(). - * @param func - Function called with the end-to-end encrypted rooms - */ - getEndToEndRooms(txn: IDBTransaction, func: (rooms: Record) => void): void; - /** - * Get the inbound group sessions that need to be backed up. - * @param limit - The maximum number of sessions to retrieve. 0 - * for no limit. - * @returns resolves to an array of inbound group sessions - */ - getSessionsNeedingBackup(limit: number): Promise; - /** - * Count the inbound group sessions that need to be backed up. - * @param txn - An active transaction. See doTxn(). (optional) - * @returns resolves to the number of sessions - */ - countSessionsNeedingBackup(txn?: IDBTransaction): Promise; - /** - * Unmark sessions as needing to be backed up. - * @param sessions - The sessions that need to be backed up. - * @param txn - An active transaction. See doTxn(). (optional) - * @returns resolves when the sessions are unmarked - */ - unmarkSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise; - /** - * Mark sessions as needing to be backed up. - * @param sessions - The sessions that need to be backed up. - * @param txn - An active transaction. See doTxn(). (optional) - * @returns resolves when the sessions are marked - */ - markSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise; - /** - * Add a shared-history group session for a room. - * @param roomId - The room that the key belongs to - * @param senderKey - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param txn - An active transaction. See doTxn(). (optional) - */ - addSharedHistoryInboundGroupSession(roomId: string, senderKey: string, sessionId: string, txn?: IDBTransaction): void; - /** - * Get the shared-history group session for a room. - * @param roomId - The room that the key belongs to - * @param txn - An active transaction. See doTxn(). (optional) - * @returns Promise which resolves to an array of [senderKey, sessionId] - */ - getSharedHistoryInboundGroupSessions(roomId: string, txn?: IDBTransaction): Promise<[senderKey: string, sessionId: string][]>; - /** - * Park a shared-history group session for a room we may be invited to later. - */ - addParkedSharedHistory(roomId: string, parkedData: ParkedSharedHistory, txn?: IDBTransaction): void; - /** - * Pop out all shared-history group sessions for a room. - */ - takeParkedSharedHistory(roomId: string, txn?: IDBTransaction): Promise; - /** - * Perform a transaction on the crypto store. Any store methods - * that require a transaction (txn) object to be passed in may - * only be called within a callback of either this function or - * one of the store functions operating on the same transaction. - * - * @param mode - 'readwrite' if you need to call setter - * functions with this transaction. Otherwise, 'readonly'. - * @param stores - List IndexedDBCryptoStore.STORE_* - * options representing all types of object that will be - * accessed or written to with this transaction. - * @param func - Function called with the - * transaction object: an opaque object that should be passed - * to store functions. - * @param log - A possibly customised log - * @returns Promise that resolves with the result of the `func` - * when the transaction is complete. If the backend is - * async (ie. the indexeddb backend) any of the callback - * functions throwing an exception will cause this promise to - * reject with that exception. On synchronous backends, the - * exception will propagate to the caller of the getFoo method. - */ - doTxn(mode: Mode, stores: Iterable, func: (txn: IDBTransaction) => T, log?: PrefixedLogger): Promise; -} -//# sourceMappingURL=indexeddb-crypto-store.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts.map deleted file mode 100644 index d66170a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-crypto-store.d.ts","sourceRoot":"","sources":["../../../src/crypto/store/indexeddb-crypto-store.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js deleted file mode 100644 index 0f68d63..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js +++ /dev/null @@ -1,601 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.IndexedDBCryptoStore = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../../logger"); -var _localStorageCryptoStore = require("./localStorage-crypto-store"); -var _memoryCryptoStore = require("./memory-crypto-store"); -var IndexedDBCryptoStoreBackend = _interopRequireWildcard(require("./indexeddb-crypto-store-backend")); -var _errors = require("../../errors"); -var IndexedDBHelpers = _interopRequireWildcard(require("../../indexeddb-helpers")); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2017 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Internal module. indexeddb storage for e2e. - */ - -/** - * An implementation of CryptoStore, which is normally backed by an indexeddb, - * but with fallback to MemoryCryptoStore. - */ -class IndexedDBCryptoStore { - static exists(indexedDB, dbName) { - return IndexedDBHelpers.exists(indexedDB, dbName); - } - /** - * Create a new IndexedDBCryptoStore - * - * @param indexedDB - global indexedDB instance - * @param dbName - name of db to connect to - */ - constructor(indexedDB, dbName) { - this.indexedDB = indexedDB; - this.dbName = dbName; - (0, _defineProperty2.default)(this, "backendPromise", void 0); - (0, _defineProperty2.default)(this, "backend", void 0); - } - - /** - * Ensure the database exists and is up-to-date, or fall back to - * a local storage or in-memory store. - * - * This must be called before the store can be used. - * - * @returns resolves to either an IndexedDBCryptoStoreBackend.Backend, - * or a MemoryCryptoStore - */ - startup() { - if (this.backendPromise) { - return this.backendPromise; - } - this.backendPromise = new Promise((resolve, reject) => { - if (!this.indexedDB) { - reject(new Error("no indexeddb support available")); - return; - } - _logger.logger.log(`connecting to indexeddb ${this.dbName}`); - const req = this.indexedDB.open(this.dbName, IndexedDBCryptoStoreBackend.VERSION); - req.onupgradeneeded = ev => { - const db = req.result; - const oldVersion = ev.oldVersion; - IndexedDBCryptoStoreBackend.upgradeDatabase(db, oldVersion); - }; - req.onblocked = () => { - _logger.logger.log(`can't yet open IndexedDBCryptoStore because it is open elsewhere`); - }; - req.onerror = ev => { - _logger.logger.log("Error connecting to indexeddb", ev); - reject(req.error); - }; - req.onsuccess = () => { - const db = req.result; - _logger.logger.log(`connected to indexeddb ${this.dbName}`); - resolve(new IndexedDBCryptoStoreBackend.Backend(db)); - }; - }).then(backend => { - // Edge has IndexedDB but doesn't support compund keys which we use fairly extensively. - // Try a dummy query which will fail if the browser doesn't support compund keys, so - // we can fall back to a different backend. - return backend.doTxn("readonly", [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD], txn => { - backend.getEndToEndInboundGroupSession("", "", txn, () => {}); - }).then(() => backend); - }).catch(e => { - if (e.name === "VersionError") { - _logger.logger.warn("Crypto DB is too new for us to use!", e); - // don't fall back to a different store: the user has crypto data - // in this db so we should use it or nothing at all. - throw new _errors.InvalidCryptoStoreError(_errors.InvalidCryptoStoreState.TooNew); - } - _logger.logger.warn(`unable to connect to indexeddb ${this.dbName}` + `: falling back to localStorage store: ${e}`); - try { - return new _localStorageCryptoStore.LocalStorageCryptoStore(global.localStorage); - } catch (e) { - _logger.logger.warn(`unable to open localStorage: falling back to in-memory store: ${e}`); - return new _memoryCryptoStore.MemoryCryptoStore(); - } - }).then(backend => { - this.backend = backend; - return backend; - }); - return this.backendPromise; - } - - /** - * Delete all data from this store. - * - * @returns resolves when the store has been cleared. - */ - deleteAllData() { - return new Promise((resolve, reject) => { - if (!this.indexedDB) { - reject(new Error("no indexeddb support available")); - return; - } - _logger.logger.log(`Removing indexeddb instance: ${this.dbName}`); - const req = this.indexedDB.deleteDatabase(this.dbName); - req.onblocked = () => { - _logger.logger.log(`can't yet delete IndexedDBCryptoStore because it is open elsewhere`); - }; - req.onerror = ev => { - _logger.logger.log("Error deleting data from indexeddb", ev); - reject(req.error); - }; - req.onsuccess = () => { - _logger.logger.log(`Removed indexeddb instance: ${this.dbName}`); - resolve(); - }; - }).catch(e => { - // in firefox, with indexedDB disabled, this fails with a - // DOMError. We treat this as non-fatal, so that people can - // still use the app. - _logger.logger.warn(`unable to delete IndexedDBCryptoStore: ${e}`); - }); - } - - /** - * Look for an existing outgoing room key request, and if none is found, - * add a new one - * - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest}: either the - * same instance as passed in, or the existing one. - */ - getOrAddOutgoingRoomKeyRequest(request) { - return this.backend.getOrAddOutgoingRoomKeyRequest(request); - } - - /** - * Look for an existing room key request - * - * @param requestBody - existing request to look for - * - * @returns resolves to the matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found - */ - getOutgoingRoomKeyRequest(requestBody) { - return this.backend.getOutgoingRoomKeyRequest(requestBody); - } - - /** - * Look for room key requests by state - * - * @param wantedStates - list of acceptable states - * - * @returns resolves to the a - * {@link OutgoingRoomKeyRequest}, or null if - * there are no pending requests in those states. If there are multiple - * requests in those states, an arbitrary one is chosen. - */ - getOutgoingRoomKeyRequestByState(wantedStates) { - return this.backend.getOutgoingRoomKeyRequestByState(wantedStates); - } - - /** - * Look for room key requests by state – - * unlike above, return a list of all entries in one state. - * - * @returns Returns an array of requests in the given state - */ - getAllOutgoingRoomKeyRequestsByState(wantedState) { - return this.backend.getAllOutgoingRoomKeyRequestsByState(wantedState); - } - - /** - * Look for room key requests by target device and state - * - * @param userId - Target user ID - * @param deviceId - Target device ID - * @param wantedStates - list of acceptable states - * - * @returns resolves to a list of all the - * {@link OutgoingRoomKeyRequest} - */ - getOutgoingRoomKeyRequestsByTarget(userId, deviceId, wantedStates) { - return this.backend.getOutgoingRoomKeyRequestsByTarget(userId, deviceId, wantedStates); - } - - /** - * Look for an existing room key request by id and state, and update it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * @param updates - name/value map of updates to apply - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest} - * updated request, or null if no matching row was found - */ - updateOutgoingRoomKeyRequest(requestId, expectedState, updates) { - return this.backend.updateOutgoingRoomKeyRequest(requestId, expectedState, updates); - } - - /** - * Look for an existing room key request by id and state, and delete it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * - * @returns resolves once the operation is completed - */ - deleteOutgoingRoomKeyRequest(requestId, expectedState) { - return this.backend.deleteOutgoingRoomKeyRequest(requestId, expectedState); - } - - // Olm Account - - /* - * Get the account pickle from the store. - * This requires an active transaction. See doTxn(). - * - * @param txn - An active transaction. See doTxn(). - * @param func - Called with the account pickle - */ - getAccount(txn, func) { - this.backend.getAccount(txn, func); - } - - /** - * Write the account pickle to the store. - * This requires an active transaction. See doTxn(). - * - * @param txn - An active transaction. See doTxn(). - * @param accountPickle - The new account pickle to store. - */ - storeAccount(txn, accountPickle) { - this.backend.storeAccount(txn, accountPickle); - } - - /** - * Get the public part of the cross-signing keys (eg. self-signing key, - * user signing key). - * - * @param txn - An active transaction. See doTxn(). - * @param func - Called with the account keys object: - * `{ key_type: base64 encoded seed }` where key type = user_signing_key_seed or self_signing_key_seed - */ - getCrossSigningKeys(txn, func) { - this.backend.getCrossSigningKeys(txn, func); - } - - /** - * @param txn - An active transaction. See doTxn(). - * @param func - Called with the private key - * @param type - A key type - */ - getSecretStorePrivateKey(txn, func, type) { - this.backend.getSecretStorePrivateKey(txn, func, type); - } - - /** - * Write the cross-signing keys back to the store - * - * @param txn - An active transaction. See doTxn(). - * @param keys - keys object as getCrossSigningKeys() - */ - storeCrossSigningKeys(txn, keys) { - this.backend.storeCrossSigningKeys(txn, keys); - } - - /** - * Write the cross-signing private keys back to the store - * - * @param txn - An active transaction. See doTxn(). - * @param type - The type of cross-signing private key to store - * @param key - keys object as getCrossSigningKeys() - */ - storeSecretStorePrivateKey(txn, type, key) { - this.backend.storeSecretStorePrivateKey(txn, type, key); - } - - // Olm sessions - - /** - * Returns the number of end-to-end sessions in the store - * @param txn - An active transaction. See doTxn(). - * @param func - Called with the count of sessions - */ - countEndToEndSessions(txn, func) { - this.backend.countEndToEndSessions(txn, func); - } - - /** - * Retrieve a specific end-to-end session between the logged-in user - * and another device. - * @param deviceKey - The public key of the other device. - * @param sessionId - The ID of the session to retrieve - * @param txn - An active transaction. See doTxn(). - * @param func - Called with A map from sessionId - * to session information object with 'session' key being the - * Base64 end-to-end session and lastReceivedMessageTs being the - * timestamp in milliseconds at which the session last received - * a message. - */ - getEndToEndSession(deviceKey, sessionId, txn, func) { - this.backend.getEndToEndSession(deviceKey, sessionId, txn, func); - } - - /** - * Retrieve the end-to-end sessions between the logged-in user and another - * device. - * @param deviceKey - The public key of the other device. - * @param txn - An active transaction. See doTxn(). - * @param func - Called with A map from sessionId - * to session information object with 'session' key being the - * Base64 end-to-end session and lastReceivedMessageTs being the - * timestamp in milliseconds at which the session last received - * a message. - */ - getEndToEndSessions(deviceKey, txn, func) { - this.backend.getEndToEndSessions(deviceKey, txn, func); - } - - /** - * Retrieve all end-to-end sessions - * @param txn - An active transaction. See doTxn(). - * @param func - Called one for each session with - * an object with, deviceKey, lastReceivedMessageTs, sessionId - * and session keys. - */ - getAllEndToEndSessions(txn, func) { - this.backend.getAllEndToEndSessions(txn, func); - } - - /** - * Store a session between the logged-in user and another device - * @param deviceKey - The public key of the other device. - * @param sessionId - The ID for this end-to-end session. - * @param sessionInfo - Session information object - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndSession(deviceKey, sessionId, sessionInfo, txn) { - this.backend.storeEndToEndSession(deviceKey, sessionId, sessionInfo, txn); - } - storeEndToEndSessionProblem(deviceKey, type, fixed) { - return this.backend.storeEndToEndSessionProblem(deviceKey, type, fixed); - } - getEndToEndSessionProblem(deviceKey, timestamp) { - return this.backend.getEndToEndSessionProblem(deviceKey, timestamp); - } - filterOutNotifiedErrorDevices(devices) { - return this.backend.filterOutNotifiedErrorDevices(devices); - } - - // Inbound group sessions - - /** - * Retrieve the end-to-end inbound group session for a given - * server key and session ID - * @param senderCurve25519Key - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param txn - An active transaction. See doTxn(). - * @param func - Called with A map from sessionId - * to Base64 end-to-end session. - */ - getEndToEndInboundGroupSession(senderCurve25519Key, sessionId, txn, func) { - this.backend.getEndToEndInboundGroupSession(senderCurve25519Key, sessionId, txn, func); - } - - /** - * Fetches all inbound group sessions in the store - * @param txn - An active transaction. See doTxn(). - * @param func - Called once for each group session - * in the store with an object having keys `{senderKey, sessionId, sessionData}`, - * then once with null to indicate the end of the list. - */ - getAllEndToEndInboundGroupSessions(txn, func) { - this.backend.getAllEndToEndInboundGroupSessions(txn, func); - } - - /** - * Adds an end-to-end inbound group session to the store. - * If there already exists an inbound group session with the same - * senderCurve25519Key and sessionID, the session will not be added. - * @param senderCurve25519Key - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param sessionData - The session data structure - * @param txn - An active transaction. See doTxn(). - */ - addEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - this.backend.addEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn); - } - - /** - * Writes an end-to-end inbound group session to the store. - * If there already exists an inbound group session with the same - * senderCurve25519Key and sessionID, it will be overwritten. - * @param senderCurve25519Key - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param sessionData - The session data structure - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - this.backend.storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn); - } - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId, sessionData, txn) { - this.backend.storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId, sessionData, txn); - } - - // End-to-end device tracking - - /** - * Store the state of all tracked devices - * This contains devices for each user, a tracking state for each user - * and a sync token matching the point in time the snapshot represents. - * These all need to be written out in full each time such that the snapshot - * is always consistent, so they are stored in one object. - * - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndDeviceData(deviceData, txn) { - this.backend.storeEndToEndDeviceData(deviceData, txn); - } - - /** - * Get the state of all tracked devices - * - * @param txn - An active transaction. See doTxn(). - * @param func - Function called with the - * device data - */ - getEndToEndDeviceData(txn, func) { - this.backend.getEndToEndDeviceData(txn, func); - } - - // End to End Rooms - - /** - * Store the end-to-end state for a room. - * @param roomId - The room's ID. - * @param roomInfo - The end-to-end info for the room. - * @param txn - An active transaction. See doTxn(). - */ - storeEndToEndRoom(roomId, roomInfo, txn) { - this.backend.storeEndToEndRoom(roomId, roomInfo, txn); - } - - /** - * Get an object of `roomId->roomInfo` for all e2e rooms in the store - * @param txn - An active transaction. See doTxn(). - * @param func - Function called with the end-to-end encrypted rooms - */ - getEndToEndRooms(txn, func) { - this.backend.getEndToEndRooms(txn, func); - } - - // session backups - - /** - * Get the inbound group sessions that need to be backed up. - * @param limit - The maximum number of sessions to retrieve. 0 - * for no limit. - * @returns resolves to an array of inbound group sessions - */ - getSessionsNeedingBackup(limit) { - return this.backend.getSessionsNeedingBackup(limit); - } - - /** - * Count the inbound group sessions that need to be backed up. - * @param txn - An active transaction. See doTxn(). (optional) - * @returns resolves to the number of sessions - */ - countSessionsNeedingBackup(txn) { - return this.backend.countSessionsNeedingBackup(txn); - } - - /** - * Unmark sessions as needing to be backed up. - * @param sessions - The sessions that need to be backed up. - * @param txn - An active transaction. See doTxn(). (optional) - * @returns resolves when the sessions are unmarked - */ - unmarkSessionsNeedingBackup(sessions, txn) { - return this.backend.unmarkSessionsNeedingBackup(sessions, txn); - } - - /** - * Mark sessions as needing to be backed up. - * @param sessions - The sessions that need to be backed up. - * @param txn - An active transaction. See doTxn(). (optional) - * @returns resolves when the sessions are marked - */ - markSessionsNeedingBackup(sessions, txn) { - return this.backend.markSessionsNeedingBackup(sessions, txn); - } - - /** - * Add a shared-history group session for a room. - * @param roomId - The room that the key belongs to - * @param senderKey - The sender's curve 25519 key - * @param sessionId - The ID of the session - * @param txn - An active transaction. See doTxn(). (optional) - */ - addSharedHistoryInboundGroupSession(roomId, senderKey, sessionId, txn) { - this.backend.addSharedHistoryInboundGroupSession(roomId, senderKey, sessionId, txn); - } - - /** - * Get the shared-history group session for a room. - * @param roomId - The room that the key belongs to - * @param txn - An active transaction. See doTxn(). (optional) - * @returns Promise which resolves to an array of [senderKey, sessionId] - */ - getSharedHistoryInboundGroupSessions(roomId, txn) { - return this.backend.getSharedHistoryInboundGroupSessions(roomId, txn); - } - - /** - * Park a shared-history group session for a room we may be invited to later. - */ - addParkedSharedHistory(roomId, parkedData, txn) { - this.backend.addParkedSharedHistory(roomId, parkedData, txn); - } - - /** - * Pop out all shared-history group sessions for a room. - */ - takeParkedSharedHistory(roomId, txn) { - return this.backend.takeParkedSharedHistory(roomId, txn); - } - - /** - * Perform a transaction on the crypto store. Any store methods - * that require a transaction (txn) object to be passed in may - * only be called within a callback of either this function or - * one of the store functions operating on the same transaction. - * - * @param mode - 'readwrite' if you need to call setter - * functions with this transaction. Otherwise, 'readonly'. - * @param stores - List IndexedDBCryptoStore.STORE_* - * options representing all types of object that will be - * accessed or written to with this transaction. - * @param func - Function called with the - * transaction object: an opaque object that should be passed - * to store functions. - * @param log - A possibly customised log - * @returns Promise that resolves with the result of the `func` - * when the transaction is complete. If the backend is - * async (ie. the indexeddb backend) any of the callback - * functions throwing an exception will cause this promise to - * reject with that exception. On synchronous backends, the - * exception will propagate to the caller of the getFoo method. - */ - doTxn(mode, stores, func, log) { - return this.backend.doTxn(mode, stores, func, log); - } -} -exports.IndexedDBCryptoStore = IndexedDBCryptoStore; -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_ACCOUNT", "account"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_SESSIONS", "sessions"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_INBOUND_GROUP_SESSIONS", "inbound_group_sessions"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_INBOUND_GROUP_SESSIONS_WITHHELD", "inbound_group_sessions_withheld"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS", "shared_history_inbound_group_sessions"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_PARKED_SHARED_HISTORY", "parked_shared_history"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_DEVICE_DATA", "device_data"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_ROOMS", "rooms"); -(0, _defineProperty2.default)(IndexedDBCryptoStore, "STORE_BACKUP", "sessions_needing_backup"); -//# sourceMappingURL=indexeddb-crypto-store.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js.map deleted file mode 100644 index 38cad1e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/indexeddb-crypto-store.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-crypto-store.js","names":["_logger","require","_localStorageCryptoStore","_memoryCryptoStore","IndexedDBCryptoStoreBackend","_interopRequireWildcard","_errors","IndexedDBHelpers","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","IndexedDBCryptoStore","exists","indexedDB","dbName","constructor","_defineProperty2","startup","backendPromise","Promise","resolve","reject","Error","logger","log","req","open","VERSION","onupgradeneeded","ev","db","result","oldVersion","upgradeDatabase","onblocked","onerror","error","onsuccess","Backend","then","backend","doTxn","STORE_INBOUND_GROUP_SESSIONS","STORE_INBOUND_GROUP_SESSIONS_WITHHELD","txn","getEndToEndInboundGroupSession","catch","e","name","warn","InvalidCryptoStoreError","InvalidCryptoStoreState","TooNew","LocalStorageCryptoStore","global","localStorage","MemoryCryptoStore","deleteAllData","deleteDatabase","getOrAddOutgoingRoomKeyRequest","request","getOutgoingRoomKeyRequest","requestBody","getOutgoingRoomKeyRequestByState","wantedStates","getAllOutgoingRoomKeyRequestsByState","wantedState","getOutgoingRoomKeyRequestsByTarget","userId","deviceId","updateOutgoingRoomKeyRequest","requestId","expectedState","updates","deleteOutgoingRoomKeyRequest","getAccount","func","storeAccount","accountPickle","getCrossSigningKeys","getSecretStorePrivateKey","type","storeCrossSigningKeys","keys","storeSecretStorePrivateKey","countEndToEndSessions","getEndToEndSession","deviceKey","sessionId","getEndToEndSessions","getAllEndToEndSessions","storeEndToEndSession","sessionInfo","storeEndToEndSessionProblem","fixed","getEndToEndSessionProblem","timestamp","filterOutNotifiedErrorDevices","devices","senderCurve25519Key","getAllEndToEndInboundGroupSessions","addEndToEndInboundGroupSession","sessionData","storeEndToEndInboundGroupSession","storeEndToEndInboundGroupSessionWithheld","storeEndToEndDeviceData","deviceData","getEndToEndDeviceData","storeEndToEndRoom","roomId","roomInfo","getEndToEndRooms","getSessionsNeedingBackup","limit","countSessionsNeedingBackup","unmarkSessionsNeedingBackup","sessions","markSessionsNeedingBackup","addSharedHistoryInboundGroupSession","senderKey","getSharedHistoryInboundGroupSessions","addParkedSharedHistory","parkedData","takeParkedSharedHistory","mode","stores","exports"],"sources":["../../../src/crypto/store/indexeddb-crypto-store.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger, PrefixedLogger } from \"../../logger\";\nimport { LocalStorageCryptoStore } from \"./localStorage-crypto-store\";\nimport { MemoryCryptoStore } from \"./memory-crypto-store\";\nimport * as IndexedDBCryptoStoreBackend from \"./indexeddb-crypto-store-backend\";\nimport { InvalidCryptoStoreError, InvalidCryptoStoreState } from \"../../errors\";\nimport * as IndexedDBHelpers from \"../../indexeddb-helpers\";\nimport {\n CryptoStore,\n IDeviceData,\n IProblem,\n ISession,\n ISessionInfo,\n IWithheld,\n Mode,\n OutgoingRoomKeyRequest,\n ParkedSharedHistory,\n SecretStorePrivateKeys,\n} from \"./base\";\nimport { IRoomKeyRequestBody } from \"../index\";\nimport { ICrossSigningKey } from \"../../client\";\nimport { IOlmDevice } from \"../algorithms/megolm\";\nimport { IRoomEncryption } from \"../RoomList\";\nimport { InboundGroupSessionData } from \"../OlmDevice\";\n\n/**\n * Internal module. indexeddb storage for e2e.\n */\n\n/**\n * An implementation of CryptoStore, which is normally backed by an indexeddb,\n * but with fallback to MemoryCryptoStore.\n */\nexport class IndexedDBCryptoStore implements CryptoStore {\n public static STORE_ACCOUNT = \"account\";\n public static STORE_SESSIONS = \"sessions\";\n public static STORE_INBOUND_GROUP_SESSIONS = \"inbound_group_sessions\";\n public static STORE_INBOUND_GROUP_SESSIONS_WITHHELD = \"inbound_group_sessions_withheld\";\n public static STORE_SHARED_HISTORY_INBOUND_GROUP_SESSIONS = \"shared_history_inbound_group_sessions\";\n public static STORE_PARKED_SHARED_HISTORY = \"parked_shared_history\";\n public static STORE_DEVICE_DATA = \"device_data\";\n public static STORE_ROOMS = \"rooms\";\n public static STORE_BACKUP = \"sessions_needing_backup\";\n\n public static exists(indexedDB: IDBFactory, dbName: string): Promise {\n return IndexedDBHelpers.exists(indexedDB, dbName);\n }\n\n private backendPromise?: Promise;\n private backend?: CryptoStore;\n\n /**\n * Create a new IndexedDBCryptoStore\n *\n * @param indexedDB - global indexedDB instance\n * @param dbName - name of db to connect to\n */\n public constructor(private readonly indexedDB: IDBFactory, private readonly dbName: string) {}\n\n /**\n * Ensure the database exists and is up-to-date, or fall back to\n * a local storage or in-memory store.\n *\n * This must be called before the store can be used.\n *\n * @returns resolves to either an IndexedDBCryptoStoreBackend.Backend,\n * or a MemoryCryptoStore\n */\n public startup(): Promise {\n if (this.backendPromise) {\n return this.backendPromise;\n }\n\n this.backendPromise = new Promise((resolve, reject) => {\n if (!this.indexedDB) {\n reject(new Error(\"no indexeddb support available\"));\n return;\n }\n\n logger.log(`connecting to indexeddb ${this.dbName}`);\n\n const req = this.indexedDB.open(this.dbName, IndexedDBCryptoStoreBackend.VERSION);\n\n req.onupgradeneeded = (ev): void => {\n const db = req.result;\n const oldVersion = ev.oldVersion;\n IndexedDBCryptoStoreBackend.upgradeDatabase(db, oldVersion);\n };\n\n req.onblocked = (): void => {\n logger.log(`can't yet open IndexedDBCryptoStore because it is open elsewhere`);\n };\n\n req.onerror = (ev): void => {\n logger.log(\"Error connecting to indexeddb\", ev);\n reject(req.error);\n };\n\n req.onsuccess = (): void => {\n const db = req.result;\n\n logger.log(`connected to indexeddb ${this.dbName}`);\n resolve(new IndexedDBCryptoStoreBackend.Backend(db));\n };\n })\n .then((backend) => {\n // Edge has IndexedDB but doesn't support compund keys which we use fairly extensively.\n // Try a dummy query which will fail if the browser doesn't support compund keys, so\n // we can fall back to a different backend.\n return backend\n .doTxn(\n \"readonly\",\n [\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS,\n IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS_WITHHELD,\n ],\n (txn) => {\n backend.getEndToEndInboundGroupSession(\"\", \"\", txn, () => {});\n },\n )\n .then(() => backend);\n })\n .catch((e) => {\n if (e.name === \"VersionError\") {\n logger.warn(\"Crypto DB is too new for us to use!\", e);\n // don't fall back to a different store: the user has crypto data\n // in this db so we should use it or nothing at all.\n throw new InvalidCryptoStoreError(InvalidCryptoStoreState.TooNew);\n }\n logger.warn(\n `unable to connect to indexeddb ${this.dbName}` + `: falling back to localStorage store: ${e}`,\n );\n\n try {\n return new LocalStorageCryptoStore(global.localStorage);\n } catch (e) {\n logger.warn(`unable to open localStorage: falling back to in-memory store: ${e}`);\n return new MemoryCryptoStore();\n }\n })\n .then((backend) => {\n this.backend = backend;\n return backend;\n });\n\n return this.backendPromise;\n }\n\n /**\n * Delete all data from this store.\n *\n * @returns resolves when the store has been cleared.\n */\n public deleteAllData(): Promise {\n return new Promise((resolve, reject) => {\n if (!this.indexedDB) {\n reject(new Error(\"no indexeddb support available\"));\n return;\n }\n\n logger.log(`Removing indexeddb instance: ${this.dbName}`);\n const req = this.indexedDB.deleteDatabase(this.dbName);\n\n req.onblocked = (): void => {\n logger.log(`can't yet delete IndexedDBCryptoStore because it is open elsewhere`);\n };\n\n req.onerror = (ev): void => {\n logger.log(\"Error deleting data from indexeddb\", ev);\n reject(req.error);\n };\n\n req.onsuccess = (): void => {\n logger.log(`Removed indexeddb instance: ${this.dbName}`);\n resolve();\n };\n }).catch((e) => {\n // in firefox, with indexedDB disabled, this fails with a\n // DOMError. We treat this as non-fatal, so that people can\n // still use the app.\n logger.warn(`unable to delete IndexedDBCryptoStore: ${e}`);\n });\n }\n\n /**\n * Look for an existing outgoing room key request, and if none is found,\n * add a new one\n *\n *\n * @returns resolves to\n * {@link OutgoingRoomKeyRequest}: either the\n * same instance as passed in, or the existing one.\n */\n public getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise {\n return this.backend!.getOrAddOutgoingRoomKeyRequest(request);\n }\n\n /**\n * Look for an existing room key request\n *\n * @param requestBody - existing request to look for\n *\n * @returns resolves to the matching\n * {@link OutgoingRoomKeyRequest}, or null if\n * not found\n */\n public getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise {\n return this.backend!.getOutgoingRoomKeyRequest(requestBody);\n }\n\n /**\n * Look for room key requests by state\n *\n * @param wantedStates - list of acceptable states\n *\n * @returns resolves to the a\n * {@link OutgoingRoomKeyRequest}, or null if\n * there are no pending requests in those states. If there are multiple\n * requests in those states, an arbitrary one is chosen.\n */\n public getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise {\n return this.backend!.getOutgoingRoomKeyRequestByState(wantedStates);\n }\n\n /**\n * Look for room key requests by state –\n * unlike above, return a list of all entries in one state.\n *\n * @returns Returns an array of requests in the given state\n */\n public getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise {\n return this.backend!.getAllOutgoingRoomKeyRequestsByState(wantedState);\n }\n\n /**\n * Look for room key requests by target device and state\n *\n * @param userId - Target user ID\n * @param deviceId - Target device ID\n * @param wantedStates - list of acceptable states\n *\n * @returns resolves to a list of all the\n * {@link OutgoingRoomKeyRequest}\n */\n public getOutgoingRoomKeyRequestsByTarget(\n userId: string,\n deviceId: string,\n wantedStates: number[],\n ): Promise {\n return this.backend!.getOutgoingRoomKeyRequestsByTarget(userId, deviceId, wantedStates);\n }\n\n /**\n * Look for an existing room key request by id and state, and update it if\n * found\n *\n * @param requestId - ID of request to update\n * @param expectedState - state we expect to find the request in\n * @param updates - name/value map of updates to apply\n *\n * @returns resolves to\n * {@link OutgoingRoomKeyRequest}\n * updated request, or null if no matching row was found\n */\n public updateOutgoingRoomKeyRequest(\n requestId: string,\n expectedState: number,\n updates: Partial,\n ): Promise {\n return this.backend!.updateOutgoingRoomKeyRequest(requestId, expectedState, updates);\n }\n\n /**\n * Look for an existing room key request by id and state, and delete it if\n * found\n *\n * @param requestId - ID of request to update\n * @param expectedState - state we expect to find the request in\n *\n * @returns resolves once the operation is completed\n */\n public deleteOutgoingRoomKeyRequest(\n requestId: string,\n expectedState: number,\n ): Promise {\n return this.backend!.deleteOutgoingRoomKeyRequest(requestId, expectedState);\n }\n\n // Olm Account\n\n /*\n * Get the account pickle from the store.\n * This requires an active transaction. See doTxn().\n *\n * @param txn - An active transaction. See doTxn().\n * @param func - Called with the account pickle\n */\n public getAccount(txn: IDBTransaction, func: (accountPickle: string | null) => void): void {\n this.backend!.getAccount(txn, func);\n }\n\n /**\n * Write the account pickle to the store.\n * This requires an active transaction. See doTxn().\n *\n * @param txn - An active transaction. See doTxn().\n * @param accountPickle - The new account pickle to store.\n */\n public storeAccount(txn: IDBTransaction, accountPickle: string): void {\n this.backend!.storeAccount(txn, accountPickle);\n }\n\n /**\n * Get the public part of the cross-signing keys (eg. self-signing key,\n * user signing key).\n *\n * @param txn - An active transaction. See doTxn().\n * @param func - Called with the account keys object:\n * `{ key_type: base64 encoded seed }` where key type = user_signing_key_seed or self_signing_key_seed\n */\n public getCrossSigningKeys(\n txn: IDBTransaction,\n func: (keys: Record | null) => void,\n ): void {\n this.backend!.getCrossSigningKeys(txn, func);\n }\n\n /**\n * @param txn - An active transaction. See doTxn().\n * @param func - Called with the private key\n * @param type - A key type\n */\n public getSecretStorePrivateKey(\n txn: IDBTransaction,\n func: (key: SecretStorePrivateKeys[K] | null) => void,\n type: K,\n ): void {\n this.backend!.getSecretStorePrivateKey(txn, func, type);\n }\n\n /**\n * Write the cross-signing keys back to the store\n *\n * @param txn - An active transaction. See doTxn().\n * @param keys - keys object as getCrossSigningKeys()\n */\n public storeCrossSigningKeys(txn: IDBTransaction, keys: Record): void {\n this.backend!.storeCrossSigningKeys(txn, keys);\n }\n\n /**\n * Write the cross-signing private keys back to the store\n *\n * @param txn - An active transaction. See doTxn().\n * @param type - The type of cross-signing private key to store\n * @param key - keys object as getCrossSigningKeys()\n */\n public storeSecretStorePrivateKey(\n txn: IDBTransaction,\n type: K,\n key: SecretStorePrivateKeys[K],\n ): void {\n this.backend!.storeSecretStorePrivateKey(txn, type, key);\n }\n\n // Olm sessions\n\n /**\n * Returns the number of end-to-end sessions in the store\n * @param txn - An active transaction. See doTxn().\n * @param func - Called with the count of sessions\n */\n public countEndToEndSessions(txn: IDBTransaction, func: (count: number) => void): void {\n this.backend!.countEndToEndSessions(txn, func);\n }\n\n /**\n * Retrieve a specific end-to-end session between the logged-in user\n * and another device.\n * @param deviceKey - The public key of the other device.\n * @param sessionId - The ID of the session to retrieve\n * @param txn - An active transaction. See doTxn().\n * @param func - Called with A map from sessionId\n * to session information object with 'session' key being the\n * Base64 end-to-end session and lastReceivedMessageTs being the\n * timestamp in milliseconds at which the session last received\n * a message.\n */\n public getEndToEndSession(\n deviceKey: string,\n sessionId: string,\n txn: IDBTransaction,\n func: (session: ISessionInfo | null) => void,\n ): void {\n this.backend!.getEndToEndSession(deviceKey, sessionId, txn, func);\n }\n\n /**\n * Retrieve the end-to-end sessions between the logged-in user and another\n * device.\n * @param deviceKey - The public key of the other device.\n * @param txn - An active transaction. See doTxn().\n * @param func - Called with A map from sessionId\n * to session information object with 'session' key being the\n * Base64 end-to-end session and lastReceivedMessageTs being the\n * timestamp in milliseconds at which the session last received\n * a message.\n */\n public getEndToEndSessions(\n deviceKey: string,\n txn: IDBTransaction,\n func: (sessions: { [sessionId: string]: ISessionInfo }) => void,\n ): void {\n this.backend!.getEndToEndSessions(deviceKey, txn, func);\n }\n\n /**\n * Retrieve all end-to-end sessions\n * @param txn - An active transaction. See doTxn().\n * @param func - Called one for each session with\n * an object with, deviceKey, lastReceivedMessageTs, sessionId\n * and session keys.\n */\n public getAllEndToEndSessions(txn: IDBTransaction, func: (session: ISessionInfo | null) => void): void {\n this.backend!.getAllEndToEndSessions(txn, func);\n }\n\n /**\n * Store a session between the logged-in user and another device\n * @param deviceKey - The public key of the other device.\n * @param sessionId - The ID for this end-to-end session.\n * @param sessionInfo - Session information object\n * @param txn - An active transaction. See doTxn().\n */\n public storeEndToEndSession(\n deviceKey: string,\n sessionId: string,\n sessionInfo: ISessionInfo,\n txn: IDBTransaction,\n ): void {\n this.backend!.storeEndToEndSession(deviceKey, sessionId, sessionInfo, txn);\n }\n\n public storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise {\n return this.backend!.storeEndToEndSessionProblem(deviceKey, type, fixed);\n }\n\n public getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise {\n return this.backend!.getEndToEndSessionProblem(deviceKey, timestamp);\n }\n\n public filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise {\n return this.backend!.filterOutNotifiedErrorDevices(devices);\n }\n\n // Inbound group sessions\n\n /**\n * Retrieve the end-to-end inbound group session for a given\n * server key and session ID\n * @param senderCurve25519Key - The sender's curve 25519 key\n * @param sessionId - The ID of the session\n * @param txn - An active transaction. See doTxn().\n * @param func - Called with A map from sessionId\n * to Base64 end-to-end session.\n */\n public getEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n txn: IDBTransaction,\n func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,\n ): void {\n this.backend!.getEndToEndInboundGroupSession(senderCurve25519Key, sessionId, txn, func);\n }\n\n /**\n * Fetches all inbound group sessions in the store\n * @param txn - An active transaction. See doTxn().\n * @param func - Called once for each group session\n * in the store with an object having keys `{senderKey, sessionId, sessionData}`,\n * then once with null to indicate the end of the list.\n */\n public getAllEndToEndInboundGroupSessions(txn: IDBTransaction, func: (session: ISession | null) => void): void {\n this.backend!.getAllEndToEndInboundGroupSessions(txn, func);\n }\n\n /**\n * Adds an end-to-end inbound group session to the store.\n * If there already exists an inbound group session with the same\n * senderCurve25519Key and sessionID, the session will not be added.\n * @param senderCurve25519Key - The sender's curve 25519 key\n * @param sessionId - The ID of the session\n * @param sessionData - The session data structure\n * @param txn - An active transaction. See doTxn().\n */\n public addEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: IDBTransaction,\n ): void {\n this.backend!.addEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn);\n }\n\n /**\n * Writes an end-to-end inbound group session to the store.\n * If there already exists an inbound group session with the same\n * senderCurve25519Key and sessionID, it will be overwritten.\n * @param senderCurve25519Key - The sender's curve 25519 key\n * @param sessionId - The ID of the session\n * @param sessionData - The session data structure\n * @param txn - An active transaction. See doTxn().\n */\n public storeEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: IDBTransaction,\n ): void {\n this.backend!.storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn);\n }\n\n public storeEndToEndInboundGroupSessionWithheld(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: IWithheld,\n txn: IDBTransaction,\n ): void {\n this.backend!.storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId, sessionData, txn);\n }\n\n // End-to-end device tracking\n\n /**\n * Store the state of all tracked devices\n * This contains devices for each user, a tracking state for each user\n * and a sync token matching the point in time the snapshot represents.\n * These all need to be written out in full each time such that the snapshot\n * is always consistent, so they are stored in one object.\n *\n * @param txn - An active transaction. See doTxn().\n */\n public storeEndToEndDeviceData(deviceData: IDeviceData, txn: IDBTransaction): void {\n this.backend!.storeEndToEndDeviceData(deviceData, txn);\n }\n\n /**\n * Get the state of all tracked devices\n *\n * @param txn - An active transaction. See doTxn().\n * @param func - Function called with the\n * device data\n */\n public getEndToEndDeviceData(txn: IDBTransaction, func: (deviceData: IDeviceData | null) => void): void {\n this.backend!.getEndToEndDeviceData(txn, func);\n }\n\n // End to End Rooms\n\n /**\n * Store the end-to-end state for a room.\n * @param roomId - The room's ID.\n * @param roomInfo - The end-to-end info for the room.\n * @param txn - An active transaction. See doTxn().\n */\n public storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: IDBTransaction): void {\n this.backend!.storeEndToEndRoom(roomId, roomInfo, txn);\n }\n\n /**\n * Get an object of `roomId->roomInfo` for all e2e rooms in the store\n * @param txn - An active transaction. See doTxn().\n * @param func - Function called with the end-to-end encrypted rooms\n */\n public getEndToEndRooms(txn: IDBTransaction, func: (rooms: Record) => void): void {\n this.backend!.getEndToEndRooms(txn, func);\n }\n\n // session backups\n\n /**\n * Get the inbound group sessions that need to be backed up.\n * @param limit - The maximum number of sessions to retrieve. 0\n * for no limit.\n * @returns resolves to an array of inbound group sessions\n */\n public getSessionsNeedingBackup(limit: number): Promise {\n return this.backend!.getSessionsNeedingBackup(limit);\n }\n\n /**\n * Count the inbound group sessions that need to be backed up.\n * @param txn - An active transaction. See doTxn(). (optional)\n * @returns resolves to the number of sessions\n */\n public countSessionsNeedingBackup(txn?: IDBTransaction): Promise {\n return this.backend!.countSessionsNeedingBackup(txn);\n }\n\n /**\n * Unmark sessions as needing to be backed up.\n * @param sessions - The sessions that need to be backed up.\n * @param txn - An active transaction. See doTxn(). (optional)\n * @returns resolves when the sessions are unmarked\n */\n public unmarkSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise {\n return this.backend!.unmarkSessionsNeedingBackup(sessions, txn);\n }\n\n /**\n * Mark sessions as needing to be backed up.\n * @param sessions - The sessions that need to be backed up.\n * @param txn - An active transaction. See doTxn(). (optional)\n * @returns resolves when the sessions are marked\n */\n public markSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise {\n return this.backend!.markSessionsNeedingBackup(sessions, txn);\n }\n\n /**\n * Add a shared-history group session for a room.\n * @param roomId - The room that the key belongs to\n * @param senderKey - The sender's curve 25519 key\n * @param sessionId - The ID of the session\n * @param txn - An active transaction. See doTxn(). (optional)\n */\n public addSharedHistoryInboundGroupSession(\n roomId: string,\n senderKey: string,\n sessionId: string,\n txn?: IDBTransaction,\n ): void {\n this.backend!.addSharedHistoryInboundGroupSession(roomId, senderKey, sessionId, txn);\n }\n\n /**\n * Get the shared-history group session for a room.\n * @param roomId - The room that the key belongs to\n * @param txn - An active transaction. See doTxn(). (optional)\n * @returns Promise which resolves to an array of [senderKey, sessionId]\n */\n public getSharedHistoryInboundGroupSessions(\n roomId: string,\n txn?: IDBTransaction,\n ): Promise<[senderKey: string, sessionId: string][]> {\n return this.backend!.getSharedHistoryInboundGroupSessions(roomId, txn);\n }\n\n /**\n * Park a shared-history group session for a room we may be invited to later.\n */\n public addParkedSharedHistory(roomId: string, parkedData: ParkedSharedHistory, txn?: IDBTransaction): void {\n this.backend!.addParkedSharedHistory(roomId, parkedData, txn);\n }\n\n /**\n * Pop out all shared-history group sessions for a room.\n */\n public takeParkedSharedHistory(roomId: string, txn?: IDBTransaction): Promise {\n return this.backend!.takeParkedSharedHistory(roomId, txn);\n }\n\n /**\n * Perform a transaction on the crypto store. Any store methods\n * that require a transaction (txn) object to be passed in may\n * only be called within a callback of either this function or\n * one of the store functions operating on the same transaction.\n *\n * @param mode - 'readwrite' if you need to call setter\n * functions with this transaction. Otherwise, 'readonly'.\n * @param stores - List IndexedDBCryptoStore.STORE_*\n * options representing all types of object that will be\n * accessed or written to with this transaction.\n * @param func - Function called with the\n * transaction object: an opaque object that should be passed\n * to store functions.\n * @param log - A possibly customised log\n * @returns Promise that resolves with the result of the `func`\n * when the transaction is complete. If the backend is\n * async (ie. the indexeddb backend) any of the callback\n * functions throwing an exception will cause this promise to\n * reject with that exception. On synchronous backends, the\n * exception will propagate to the caller of the getFoo method.\n */\n public doTxn(\n mode: Mode,\n stores: Iterable,\n func: (txn: IDBTransaction) => T,\n log?: PrefixedLogger,\n ): Promise {\n return this.backend!.doTxn(mode, stores, func as (txn: unknown) => T, log);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts deleted file mode 100644 index a13aadf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts +++ /dev/null @@ -1,49 +0,0 @@ -import { MemoryCryptoStore } from "./memory-crypto-store"; -import { IDeviceData, IProblem, ISession, ISessionInfo, IWithheld, Mode, SecretStorePrivateKeys } from "./base"; -import { IOlmDevice } from "../algorithms/megolm"; -import { IRoomEncryption } from "../RoomList"; -import { ICrossSigningKey } from "../../client"; -import { InboundGroupSessionData } from "../OlmDevice"; -export declare class LocalStorageCryptoStore extends MemoryCryptoStore { - private readonly store; - static exists(store: Storage): boolean; - constructor(store: Storage); - countEndToEndSessions(txn: unknown, func: (count: number) => void): void; - private _getEndToEndSessions; - getEndToEndSession(deviceKey: string, sessionId: string, txn: unknown, func: (session: ISessionInfo) => void): void; - getEndToEndSessions(deviceKey: string, txn: unknown, func: (sessions: { - [sessionId: string]: ISessionInfo; - }) => void): void; - getAllEndToEndSessions(txn: unknown, func: (session: ISessionInfo) => void): void; - storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void; - storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise; - getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise; - filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise; - getEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, txn: unknown, func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void): void; - getAllEndToEndInboundGroupSessions(txn: unknown, func: (session: ISession | null) => void): void; - addEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: unknown): void; - storeEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: unknown): void; - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key: string, sessionId: string, sessionData: IWithheld, txn: unknown): void; - getEndToEndDeviceData(txn: unknown, func: (deviceData: IDeviceData | null) => void): void; - storeEndToEndDeviceData(deviceData: IDeviceData, txn: unknown): void; - storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: unknown): void; - getEndToEndRooms(txn: unknown, func: (rooms: Record) => void): void; - getSessionsNeedingBackup(limit: number): Promise; - countSessionsNeedingBackup(): Promise; - unmarkSessionsNeedingBackup(sessions: ISession[]): Promise; - markSessionsNeedingBackup(sessions: ISession[]): Promise; - /** - * Delete all data from this store. - * - * @returns Promise which resolves when the store has been cleared. - */ - deleteAllData(): Promise; - getAccount(txn: unknown, func: (accountPickle: string | null) => void): void; - storeAccount(txn: unknown, accountPickle: string): void; - getCrossSigningKeys(txn: unknown, func: (keys: Record | null) => void): void; - getSecretStorePrivateKey(txn: unknown, func: (key: SecretStorePrivateKeys[K] | null) => void, type: K): void; - storeCrossSigningKeys(txn: unknown, keys: Record): void; - storeSecretStorePrivateKey(txn: unknown, type: K, key: SecretStorePrivateKeys[K]): void; - doTxn(mode: Mode, stores: Iterable, func: (txn: unknown) => T): Promise; -} -//# sourceMappingURL=localStorage-crypto-store.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts.map deleted file mode 100644 index e49704d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"localStorage-crypto-store.d.ts","sourceRoot":"","sources":["../../../src/crypto/store/localStorage-crypto-store.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js deleted file mode 100644 index 03e99a1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js +++ /dev/null @@ -1,333 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.LocalStorageCryptoStore = void 0; -var _logger = require("../../logger"); -var _memoryCryptoStore = require("./memory-crypto-store"); -var _utils = require("../../utils"); -/* -Copyright 2017 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Internal module. Partial localStorage backed storage for e2e. - * This is not a full crypto store, just the in-memory store with - * some things backed by localStorage. It exists because indexedDB - * is broken in Firefox private mode or set to, "will not remember - * history". - */ - -const E2E_PREFIX = "crypto."; -const KEY_END_TO_END_ACCOUNT = E2E_PREFIX + "account"; -const KEY_CROSS_SIGNING_KEYS = E2E_PREFIX + "cross_signing_keys"; -const KEY_NOTIFIED_ERROR_DEVICES = E2E_PREFIX + "notified_error_devices"; -const KEY_DEVICE_DATA = E2E_PREFIX + "device_data"; -const KEY_INBOUND_SESSION_PREFIX = E2E_PREFIX + "inboundgroupsessions/"; -const KEY_INBOUND_SESSION_WITHHELD_PREFIX = E2E_PREFIX + "inboundgroupsessions.withheld/"; -const KEY_ROOMS_PREFIX = E2E_PREFIX + "rooms/"; -const KEY_SESSIONS_NEEDING_BACKUP = E2E_PREFIX + "sessionsneedingbackup"; -function keyEndToEndSessions(deviceKey) { - return E2E_PREFIX + "sessions/" + deviceKey; -} -function keyEndToEndSessionProblems(deviceKey) { - return E2E_PREFIX + "session.problems/" + deviceKey; -} -function keyEndToEndInboundGroupSession(senderKey, sessionId) { - return KEY_INBOUND_SESSION_PREFIX + senderKey + "/" + sessionId; -} -function keyEndToEndInboundGroupSessionWithheld(senderKey, sessionId) { - return KEY_INBOUND_SESSION_WITHHELD_PREFIX + senderKey + "/" + sessionId; -} -function keyEndToEndRoomsPrefix(roomId) { - return KEY_ROOMS_PREFIX + roomId; -} -class LocalStorageCryptoStore extends _memoryCryptoStore.MemoryCryptoStore { - static exists(store) { - const length = store.length; - for (let i = 0; i < length; i++) { - var _store$key; - if ((_store$key = store.key(i)) !== null && _store$key !== void 0 && _store$key.startsWith(E2E_PREFIX)) { - return true; - } - } - return false; - } - constructor(store) { - super(); - this.store = store; - } - - // Olm Sessions - - countEndToEndSessions(txn, func) { - let count = 0; - for (let i = 0; i < this.store.length; ++i) { - var _this$store$key; - if ((_this$store$key = this.store.key(i)) !== null && _this$store$key !== void 0 && _this$store$key.startsWith(keyEndToEndSessions(""))) ++count; - } - func(count); - } - - // eslint-disable-next-line @typescript-eslint/naming-convention - _getEndToEndSessions(deviceKey) { - const sessions = getJsonItem(this.store, keyEndToEndSessions(deviceKey)); - const fixedSessions = {}; - - // fix up any old sessions to be objects rather than just the base64 pickle - for (const [sid, val] of Object.entries(sessions || {})) { - if (typeof val === "string") { - fixedSessions[sid] = { - session: val - }; - } else { - fixedSessions[sid] = val; - } - } - return fixedSessions; - } - getEndToEndSession(deviceKey, sessionId, txn, func) { - const sessions = this._getEndToEndSessions(deviceKey); - func(sessions[sessionId] || {}); - } - getEndToEndSessions(deviceKey, txn, func) { - func(this._getEndToEndSessions(deviceKey) || {}); - } - getAllEndToEndSessions(txn, func) { - for (let i = 0; i < this.store.length; ++i) { - var _this$store$key2; - if ((_this$store$key2 = this.store.key(i)) !== null && _this$store$key2 !== void 0 && _this$store$key2.startsWith(keyEndToEndSessions(""))) { - const deviceKey = this.store.key(i).split("/")[1]; - for (const sess of Object.values(this._getEndToEndSessions(deviceKey))) { - func(sess); - } - } - } - } - storeEndToEndSession(deviceKey, sessionId, sessionInfo, txn) { - const sessions = this._getEndToEndSessions(deviceKey) || {}; - sessions[sessionId] = sessionInfo; - setJsonItem(this.store, keyEndToEndSessions(deviceKey), sessions); - } - async storeEndToEndSessionProblem(deviceKey, type, fixed) { - const key = keyEndToEndSessionProblems(deviceKey); - const problems = getJsonItem(this.store, key) || []; - problems.push({ - type, - fixed, - time: Date.now() - }); - problems.sort((a, b) => { - return a.time - b.time; - }); - setJsonItem(this.store, key, problems); - } - async getEndToEndSessionProblem(deviceKey, timestamp) { - const key = keyEndToEndSessionProblems(deviceKey); - const problems = getJsonItem(this.store, key) || []; - if (!problems.length) { - return null; - } - const lastProblem = problems[problems.length - 1]; - for (const problem of problems) { - if (problem.time > timestamp) { - return Object.assign({}, problem, { - fixed: lastProblem.fixed - }); - } - } - if (lastProblem.fixed) { - return null; - } else { - return lastProblem; - } - } - async filterOutNotifiedErrorDevices(devices) { - const notifiedErrorDevices = getJsonItem(this.store, KEY_NOTIFIED_ERROR_DEVICES) || {}; - const ret = []; - for (const device of devices) { - const { - userId, - deviceInfo - } = device; - if (userId in notifiedErrorDevices) { - if (!(deviceInfo.deviceId in notifiedErrorDevices[userId])) { - ret.push(device); - (0, _utils.safeSet)(notifiedErrorDevices[userId], deviceInfo.deviceId, true); - } - } else { - ret.push(device); - (0, _utils.safeSet)(notifiedErrorDevices, userId, { - [deviceInfo.deviceId]: true - }); - } - } - setJsonItem(this.store, KEY_NOTIFIED_ERROR_DEVICES, notifiedErrorDevices); - return ret; - } - - // Inbound Group Sessions - - getEndToEndInboundGroupSession(senderCurve25519Key, sessionId, txn, func) { - func(getJsonItem(this.store, keyEndToEndInboundGroupSession(senderCurve25519Key, sessionId)), getJsonItem(this.store, keyEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId))); - } - getAllEndToEndInboundGroupSessions(txn, func) { - for (let i = 0; i < this.store.length; ++i) { - const key = this.store.key(i); - if (key !== null && key !== void 0 && key.startsWith(KEY_INBOUND_SESSION_PREFIX)) { - // we can't use split, as the components we are trying to split out - // might themselves contain '/' characters. We rely on the - // senderKey being a (32-byte) curve25519 key, base64-encoded - // (hence 43 characters long). - - func({ - senderKey: key.slice(KEY_INBOUND_SESSION_PREFIX.length, KEY_INBOUND_SESSION_PREFIX.length + 43), - sessionId: key.slice(KEY_INBOUND_SESSION_PREFIX.length + 44), - sessionData: getJsonItem(this.store, key) - }); - } - } - func(null); - } - addEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - const existing = getJsonItem(this.store, keyEndToEndInboundGroupSession(senderCurve25519Key, sessionId)); - if (!existing) { - this.storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn); - } - } - storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - setJsonItem(this.store, keyEndToEndInboundGroupSession(senderCurve25519Key, sessionId), sessionData); - } - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId, sessionData, txn) { - setJsonItem(this.store, keyEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId), sessionData); - } - getEndToEndDeviceData(txn, func) { - func(getJsonItem(this.store, KEY_DEVICE_DATA)); - } - storeEndToEndDeviceData(deviceData, txn) { - setJsonItem(this.store, KEY_DEVICE_DATA, deviceData); - } - storeEndToEndRoom(roomId, roomInfo, txn) { - setJsonItem(this.store, keyEndToEndRoomsPrefix(roomId), roomInfo); - } - getEndToEndRooms(txn, func) { - const result = {}; - const prefix = keyEndToEndRoomsPrefix(""); - for (let i = 0; i < this.store.length; ++i) { - const key = this.store.key(i); - if (key !== null && key !== void 0 && key.startsWith(prefix)) { - const roomId = key.slice(prefix.length); - result[roomId] = getJsonItem(this.store, key); - } - } - func(result); - } - getSessionsNeedingBackup(limit) { - const sessionsNeedingBackup = getJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {}; - const sessions = []; - for (const session in sessionsNeedingBackup) { - if (Object.prototype.hasOwnProperty.call(sessionsNeedingBackup, session)) { - // see getAllEndToEndInboundGroupSessions for the magic number explanations - const senderKey = session.slice(0, 43); - const sessionId = session.slice(44); - this.getEndToEndInboundGroupSession(senderKey, sessionId, null, sessionData => { - sessions.push({ - senderKey: senderKey, - sessionId: sessionId, - sessionData: sessionData - }); - }); - if (limit && sessions.length >= limit) { - break; - } - } - } - return Promise.resolve(sessions); - } - countSessionsNeedingBackup() { - const sessionsNeedingBackup = getJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {}; - return Promise.resolve(Object.keys(sessionsNeedingBackup).length); - } - unmarkSessionsNeedingBackup(sessions) { - const sessionsNeedingBackup = getJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {}; - for (const session of sessions) { - delete sessionsNeedingBackup[session.senderKey + "/" + session.sessionId]; - } - setJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP, sessionsNeedingBackup); - return Promise.resolve(); - } - markSessionsNeedingBackup(sessions) { - const sessionsNeedingBackup = getJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {}; - for (const session of sessions) { - sessionsNeedingBackup[session.senderKey + "/" + session.sessionId] = true; - } - setJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP, sessionsNeedingBackup); - return Promise.resolve(); - } - - /** - * Delete all data from this store. - * - * @returns Promise which resolves when the store has been cleared. - */ - deleteAllData() { - this.store.removeItem(KEY_END_TO_END_ACCOUNT); - return Promise.resolve(); - } - - // Olm account - - getAccount(txn, func) { - const accountPickle = getJsonItem(this.store, KEY_END_TO_END_ACCOUNT); - func(accountPickle); - } - storeAccount(txn, accountPickle) { - setJsonItem(this.store, KEY_END_TO_END_ACCOUNT, accountPickle); - } - getCrossSigningKeys(txn, func) { - const keys = getJsonItem(this.store, KEY_CROSS_SIGNING_KEYS); - func(keys); - } - getSecretStorePrivateKey(txn, func, type) { - const key = getJsonItem(this.store, E2E_PREFIX + `ssss_cache.${type}`); - func(key); - } - storeCrossSigningKeys(txn, keys) { - setJsonItem(this.store, KEY_CROSS_SIGNING_KEYS, keys); - } - storeSecretStorePrivateKey(txn, type, key) { - setJsonItem(this.store, E2E_PREFIX + `ssss_cache.${type}`, key); - } - doTxn(mode, stores, func) { - return Promise.resolve(func(null)); - } -} -exports.LocalStorageCryptoStore = LocalStorageCryptoStore; -function getJsonItem(store, key) { - try { - // if the key is absent, store.getItem() returns null, and - // JSON.parse(null) === null, so this returns null. - return JSON.parse(store.getItem(key)); - } catch (e) { - _logger.logger.log("Error: Failed to get key %s: %s", key, e.message); - _logger.logger.log(e.stack); - } - return null; -} -function setJsonItem(store, key, val) { - store.setItem(key, JSON.stringify(val)); -} -//# sourceMappingURL=localStorage-crypto-store.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js.map deleted file mode 100644 index cb5dc11..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/localStorage-crypto-store.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"localStorage-crypto-store.js","names":["_logger","require","_memoryCryptoStore","_utils","E2E_PREFIX","KEY_END_TO_END_ACCOUNT","KEY_CROSS_SIGNING_KEYS","KEY_NOTIFIED_ERROR_DEVICES","KEY_DEVICE_DATA","KEY_INBOUND_SESSION_PREFIX","KEY_INBOUND_SESSION_WITHHELD_PREFIX","KEY_ROOMS_PREFIX","KEY_SESSIONS_NEEDING_BACKUP","keyEndToEndSessions","deviceKey","keyEndToEndSessionProblems","keyEndToEndInboundGroupSession","senderKey","sessionId","keyEndToEndInboundGroupSessionWithheld","keyEndToEndRoomsPrefix","roomId","LocalStorageCryptoStore","MemoryCryptoStore","exists","store","length","i","_store$key","key","startsWith","constructor","countEndToEndSessions","txn","func","count","_this$store$key","_getEndToEndSessions","sessions","getJsonItem","fixedSessions","sid","val","Object","entries","session","getEndToEndSession","getEndToEndSessions","getAllEndToEndSessions","_this$store$key2","split","sess","values","storeEndToEndSession","sessionInfo","setJsonItem","storeEndToEndSessionProblem","type","fixed","problems","push","time","Date","now","sort","a","b","getEndToEndSessionProblem","timestamp","lastProblem","problem","assign","filterOutNotifiedErrorDevices","devices","notifiedErrorDevices","ret","device","userId","deviceInfo","deviceId","safeSet","getEndToEndInboundGroupSession","senderCurve25519Key","getAllEndToEndInboundGroupSessions","slice","sessionData","addEndToEndInboundGroupSession","existing","storeEndToEndInboundGroupSession","storeEndToEndInboundGroupSessionWithheld","getEndToEndDeviceData","storeEndToEndDeviceData","deviceData","storeEndToEndRoom","roomInfo","getEndToEndRooms","result","prefix","getSessionsNeedingBackup","limit","sessionsNeedingBackup","prototype","hasOwnProperty","call","Promise","resolve","countSessionsNeedingBackup","keys","unmarkSessionsNeedingBackup","markSessionsNeedingBackup","deleteAllData","removeItem","getAccount","accountPickle","storeAccount","getCrossSigningKeys","getSecretStorePrivateKey","storeCrossSigningKeys","storeSecretStorePrivateKey","doTxn","mode","stores","exports","JSON","parse","getItem","e","logger","log","message","stack","setItem","stringify"],"sources":["../../../src/crypto/store/localStorage-crypto-store.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../../logger\";\nimport { MemoryCryptoStore } from \"./memory-crypto-store\";\nimport { IDeviceData, IProblem, ISession, ISessionInfo, IWithheld, Mode, SecretStorePrivateKeys } from \"./base\";\nimport { IOlmDevice } from \"../algorithms/megolm\";\nimport { IRoomEncryption } from \"../RoomList\";\nimport { ICrossSigningKey } from \"../../client\";\nimport { InboundGroupSessionData } from \"../OlmDevice\";\nimport { safeSet } from \"../../utils\";\n\n/**\n * Internal module. Partial localStorage backed storage for e2e.\n * This is not a full crypto store, just the in-memory store with\n * some things backed by localStorage. It exists because indexedDB\n * is broken in Firefox private mode or set to, \"will not remember\n * history\".\n */\n\nconst E2E_PREFIX = \"crypto.\";\nconst KEY_END_TO_END_ACCOUNT = E2E_PREFIX + \"account\";\nconst KEY_CROSS_SIGNING_KEYS = E2E_PREFIX + \"cross_signing_keys\";\nconst KEY_NOTIFIED_ERROR_DEVICES = E2E_PREFIX + \"notified_error_devices\";\nconst KEY_DEVICE_DATA = E2E_PREFIX + \"device_data\";\nconst KEY_INBOUND_SESSION_PREFIX = E2E_PREFIX + \"inboundgroupsessions/\";\nconst KEY_INBOUND_SESSION_WITHHELD_PREFIX = E2E_PREFIX + \"inboundgroupsessions.withheld/\";\nconst KEY_ROOMS_PREFIX = E2E_PREFIX + \"rooms/\";\nconst KEY_SESSIONS_NEEDING_BACKUP = E2E_PREFIX + \"sessionsneedingbackup\";\n\nfunction keyEndToEndSessions(deviceKey: string): string {\n return E2E_PREFIX + \"sessions/\" + deviceKey;\n}\n\nfunction keyEndToEndSessionProblems(deviceKey: string): string {\n return E2E_PREFIX + \"session.problems/\" + deviceKey;\n}\n\nfunction keyEndToEndInboundGroupSession(senderKey: string, sessionId: string): string {\n return KEY_INBOUND_SESSION_PREFIX + senderKey + \"/\" + sessionId;\n}\n\nfunction keyEndToEndInboundGroupSessionWithheld(senderKey: string, sessionId: string): string {\n return KEY_INBOUND_SESSION_WITHHELD_PREFIX + senderKey + \"/\" + sessionId;\n}\n\nfunction keyEndToEndRoomsPrefix(roomId: string): string {\n return KEY_ROOMS_PREFIX + roomId;\n}\n\nexport class LocalStorageCryptoStore extends MemoryCryptoStore {\n public static exists(store: Storage): boolean {\n const length = store.length;\n for (let i = 0; i < length; i++) {\n if (store.key(i)?.startsWith(E2E_PREFIX)) {\n return true;\n }\n }\n return false;\n }\n\n public constructor(private readonly store: Storage) {\n super();\n }\n\n // Olm Sessions\n\n public countEndToEndSessions(txn: unknown, func: (count: number) => void): void {\n let count = 0;\n for (let i = 0; i < this.store.length; ++i) {\n if (this.store.key(i)?.startsWith(keyEndToEndSessions(\"\"))) ++count;\n }\n func(count);\n }\n\n // eslint-disable-next-line @typescript-eslint/naming-convention\n private _getEndToEndSessions(deviceKey: string): Record {\n const sessions = getJsonItem(this.store, keyEndToEndSessions(deviceKey));\n const fixedSessions: Record = {};\n\n // fix up any old sessions to be objects rather than just the base64 pickle\n for (const [sid, val] of Object.entries(sessions || {})) {\n if (typeof val === \"string\") {\n fixedSessions[sid] = {\n session: val,\n };\n } else {\n fixedSessions[sid] = val;\n }\n }\n\n return fixedSessions;\n }\n\n public getEndToEndSession(\n deviceKey: string,\n sessionId: string,\n txn: unknown,\n func: (session: ISessionInfo) => void,\n ): void {\n const sessions = this._getEndToEndSessions(deviceKey);\n func(sessions[sessionId] || {});\n }\n\n public getEndToEndSessions(\n deviceKey: string,\n txn: unknown,\n func: (sessions: { [sessionId: string]: ISessionInfo }) => void,\n ): void {\n func(this._getEndToEndSessions(deviceKey) || {});\n }\n\n public getAllEndToEndSessions(txn: unknown, func: (session: ISessionInfo) => void): void {\n for (let i = 0; i < this.store.length; ++i) {\n if (this.store.key(i)?.startsWith(keyEndToEndSessions(\"\"))) {\n const deviceKey = this.store.key(i)!.split(\"/\")[1];\n for (const sess of Object.values(this._getEndToEndSessions(deviceKey))) {\n func(sess);\n }\n }\n }\n }\n\n public storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void {\n const sessions = this._getEndToEndSessions(deviceKey) || {};\n sessions[sessionId] = sessionInfo;\n setJsonItem(this.store, keyEndToEndSessions(deviceKey), sessions);\n }\n\n public async storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise {\n const key = keyEndToEndSessionProblems(deviceKey);\n const problems = getJsonItem(this.store, key) || [];\n problems.push({ type, fixed, time: Date.now() });\n problems.sort((a, b) => {\n return a.time - b.time;\n });\n setJsonItem(this.store, key, problems);\n }\n\n public async getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise {\n const key = keyEndToEndSessionProblems(deviceKey);\n const problems = getJsonItem(this.store, key) || [];\n if (!problems.length) {\n return null;\n }\n const lastProblem = problems[problems.length - 1];\n for (const problem of problems) {\n if (problem.time > timestamp) {\n return Object.assign({}, problem, { fixed: lastProblem.fixed });\n }\n }\n if (lastProblem.fixed) {\n return null;\n } else {\n return lastProblem;\n }\n }\n\n public async filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise {\n const notifiedErrorDevices =\n getJsonItem(this.store, KEY_NOTIFIED_ERROR_DEVICES) || {};\n const ret: IOlmDevice[] = [];\n\n for (const device of devices) {\n const { userId, deviceInfo } = device;\n if (userId in notifiedErrorDevices) {\n if (!(deviceInfo.deviceId in notifiedErrorDevices[userId])) {\n ret.push(device);\n safeSet(notifiedErrorDevices[userId], deviceInfo.deviceId, true);\n }\n } else {\n ret.push(device);\n safeSet(notifiedErrorDevices, userId, { [deviceInfo.deviceId]: true });\n }\n }\n\n setJsonItem(this.store, KEY_NOTIFIED_ERROR_DEVICES, notifiedErrorDevices);\n\n return ret;\n }\n\n // Inbound Group Sessions\n\n public getEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n txn: unknown,\n func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,\n ): void {\n func(\n getJsonItem(this.store, keyEndToEndInboundGroupSession(senderCurve25519Key, sessionId)),\n getJsonItem(this.store, keyEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId)),\n );\n }\n\n public getAllEndToEndInboundGroupSessions(txn: unknown, func: (session: ISession | null) => void): void {\n for (let i = 0; i < this.store.length; ++i) {\n const key = this.store.key(i);\n if (key?.startsWith(KEY_INBOUND_SESSION_PREFIX)) {\n // we can't use split, as the components we are trying to split out\n // might themselves contain '/' characters. We rely on the\n // senderKey being a (32-byte) curve25519 key, base64-encoded\n // (hence 43 characters long).\n\n func({\n senderKey: key.slice(KEY_INBOUND_SESSION_PREFIX.length, KEY_INBOUND_SESSION_PREFIX.length + 43),\n sessionId: key.slice(KEY_INBOUND_SESSION_PREFIX.length + 44),\n sessionData: getJsonItem(this.store, key)!,\n });\n }\n }\n func(null);\n }\n\n public addEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: unknown,\n ): void {\n const existing = getJsonItem(this.store, keyEndToEndInboundGroupSession(senderCurve25519Key, sessionId));\n if (!existing) {\n this.storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn);\n }\n }\n\n public storeEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: unknown,\n ): void {\n setJsonItem(this.store, keyEndToEndInboundGroupSession(senderCurve25519Key, sessionId), sessionData);\n }\n\n public storeEndToEndInboundGroupSessionWithheld(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: IWithheld,\n txn: unknown,\n ): void {\n setJsonItem(this.store, keyEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId), sessionData);\n }\n\n public getEndToEndDeviceData(txn: unknown, func: (deviceData: IDeviceData | null) => void): void {\n func(getJsonItem(this.store, KEY_DEVICE_DATA));\n }\n\n public storeEndToEndDeviceData(deviceData: IDeviceData, txn: unknown): void {\n setJsonItem(this.store, KEY_DEVICE_DATA, deviceData);\n }\n\n public storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: unknown): void {\n setJsonItem(this.store, keyEndToEndRoomsPrefix(roomId), roomInfo);\n }\n\n public getEndToEndRooms(txn: unknown, func: (rooms: Record) => void): void {\n const result: Record = {};\n const prefix = keyEndToEndRoomsPrefix(\"\");\n\n for (let i = 0; i < this.store.length; ++i) {\n const key = this.store.key(i);\n if (key?.startsWith(prefix)) {\n const roomId = key.slice(prefix.length);\n result[roomId] = getJsonItem(this.store, key)!;\n }\n }\n func(result);\n }\n\n public getSessionsNeedingBackup(limit: number): Promise {\n const sessionsNeedingBackup = getJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {};\n const sessions: ISession[] = [];\n\n for (const session in sessionsNeedingBackup) {\n if (Object.prototype.hasOwnProperty.call(sessionsNeedingBackup, session)) {\n // see getAllEndToEndInboundGroupSessions for the magic number explanations\n const senderKey = session.slice(0, 43);\n const sessionId = session.slice(44);\n this.getEndToEndInboundGroupSession(senderKey, sessionId, null, (sessionData) => {\n sessions.push({\n senderKey: senderKey,\n sessionId: sessionId,\n sessionData: sessionData!,\n });\n });\n if (limit && sessions.length >= limit) {\n break;\n }\n }\n }\n return Promise.resolve(sessions);\n }\n\n public countSessionsNeedingBackup(): Promise {\n const sessionsNeedingBackup = getJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {};\n return Promise.resolve(Object.keys(sessionsNeedingBackup).length);\n }\n\n public unmarkSessionsNeedingBackup(sessions: ISession[]): Promise {\n const sessionsNeedingBackup =\n getJsonItem<{\n [senderKeySessionId: string]: string;\n }>(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {};\n for (const session of sessions) {\n delete sessionsNeedingBackup[session.senderKey + \"/\" + session.sessionId];\n }\n setJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP, sessionsNeedingBackup);\n return Promise.resolve();\n }\n\n public markSessionsNeedingBackup(sessions: ISession[]): Promise {\n const sessionsNeedingBackup =\n getJsonItem<{\n [senderKeySessionId: string]: boolean;\n }>(this.store, KEY_SESSIONS_NEEDING_BACKUP) || {};\n for (const session of sessions) {\n sessionsNeedingBackup[session.senderKey + \"/\" + session.sessionId] = true;\n }\n setJsonItem(this.store, KEY_SESSIONS_NEEDING_BACKUP, sessionsNeedingBackup);\n return Promise.resolve();\n }\n\n /**\n * Delete all data from this store.\n *\n * @returns Promise which resolves when the store has been cleared.\n */\n public deleteAllData(): Promise {\n this.store.removeItem(KEY_END_TO_END_ACCOUNT);\n return Promise.resolve();\n }\n\n // Olm account\n\n public getAccount(txn: unknown, func: (accountPickle: string | null) => void): void {\n const accountPickle = getJsonItem(this.store, KEY_END_TO_END_ACCOUNT);\n func(accountPickle);\n }\n\n public storeAccount(txn: unknown, accountPickle: string): void {\n setJsonItem(this.store, KEY_END_TO_END_ACCOUNT, accountPickle);\n }\n\n public getCrossSigningKeys(txn: unknown, func: (keys: Record | null) => void): void {\n const keys = getJsonItem>(this.store, KEY_CROSS_SIGNING_KEYS);\n func(keys);\n }\n\n public getSecretStorePrivateKey(\n txn: unknown,\n func: (key: SecretStorePrivateKeys[K] | null) => void,\n type: K,\n ): void {\n const key = getJsonItem(this.store, E2E_PREFIX + `ssss_cache.${type}`);\n func(key);\n }\n\n public storeCrossSigningKeys(txn: unknown, keys: Record): void {\n setJsonItem(this.store, KEY_CROSS_SIGNING_KEYS, keys);\n }\n\n public storeSecretStorePrivateKey(\n txn: unknown,\n type: K,\n key: SecretStorePrivateKeys[K],\n ): void {\n setJsonItem(this.store, E2E_PREFIX + `ssss_cache.${type}`, key);\n }\n\n public doTxn(mode: Mode, stores: Iterable, func: (txn: unknown) => T): Promise {\n return Promise.resolve(func(null));\n }\n}\n\nfunction getJsonItem(store: Storage, key: string): T | null {\n try {\n // if the key is absent, store.getItem() returns null, and\n // JSON.parse(null) === null, so this returns null.\n return JSON.parse(store.getItem(key)!);\n } catch (e) {\n logger.log(\"Error: Failed to get key %s: %s\", key, (e).message);\n logger.log((e).stack);\n }\n return null;\n}\n\nfunction setJsonItem(store: Storage, key: string, val: T): void {\n store.setItem(key, JSON.stringify(val));\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts deleted file mode 100644 index 9d2c4cd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts +++ /dev/null @@ -1,144 +0,0 @@ -import { CryptoStore, IDeviceData, IProblem, ISession, ISessionInfo, IWithheld, Mode, OutgoingRoomKeyRequest, ParkedSharedHistory, SecretStorePrivateKeys } from "./base"; -import { IRoomKeyRequestBody } from "../index"; -import { ICrossSigningKey } from "../../client"; -import { IOlmDevice } from "../algorithms/megolm"; -import { IRoomEncryption } from "../RoomList"; -import { InboundGroupSessionData } from "../OlmDevice"; -/** - * Internal module. in-memory storage for e2e. - */ -export declare class MemoryCryptoStore implements CryptoStore { - private outgoingRoomKeyRequests; - private account; - private crossSigningKeys; - private privateKeys; - private sessions; - private sessionProblems; - private notifiedErrorDevices; - private inboundGroupSessions; - private inboundGroupSessionsWithheld; - private deviceData; - private rooms; - private sessionsNeedingBackup; - private sharedHistoryInboundGroupSessions; - private parkedSharedHistory; - /** - * Ensure the database exists and is up-to-date. - * - * This must be called before the store can be used. - * - * @returns resolves to the store. - */ - startup(): Promise; - /** - * Delete all data from this store. - * - * @returns Promise which resolves when the store has been cleared. - */ - deleteAllData(): Promise; - /** - * Look for an existing outgoing room key request, and if none is found, - * add a new one - * - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest}: either the - * same instance as passed in, or the existing one. - */ - getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise; - /** - * Look for an existing room key request - * - * @param requestBody - existing request to look for - * - * @returns resolves to the matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found - */ - getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise; - /** - * Looks for existing room key request, and returns the result synchronously. - * - * @internal - * - * @param requestBody - existing request to look for - * - * @returns - * the matching request, or null if not found - */ - private _getOutgoingRoomKeyRequest; - /** - * Look for room key requests by state - * - * @param wantedStates - list of acceptable states - * - * @returns resolves to the a - * {@link OutgoingRoomKeyRequest}, or null if - * there are no pending requests in those states - */ - getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise; - /** - * - * @returns All OutgoingRoomKeyRequests in state - */ - getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise; - getOutgoingRoomKeyRequestsByTarget(userId: string, deviceId: string, wantedStates: number[]): Promise; - /** - * Look for an existing room key request by id and state, and update it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * @param updates - name/value map of updates to apply - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest} - * updated request, or null if no matching row was found - */ - updateOutgoingRoomKeyRequest(requestId: string, expectedState: number, updates: Partial): Promise; - /** - * Look for an existing room key request by id and state, and delete it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * - * @returns resolves once the operation is completed - */ - deleteOutgoingRoomKeyRequest(requestId: string, expectedState: number): Promise; - getAccount(txn: unknown, func: (accountPickle: string | null) => void): void; - storeAccount(txn: unknown, accountPickle: string): void; - getCrossSigningKeys(txn: unknown, func: (keys: Record | null) => void): void; - getSecretStorePrivateKey(txn: unknown, func: (key: SecretStorePrivateKeys[K] | null) => void, type: K): void; - storeCrossSigningKeys(txn: unknown, keys: Record): void; - storeSecretStorePrivateKey(txn: unknown, type: K, key: SecretStorePrivateKeys[K]): void; - countEndToEndSessions(txn: unknown, func: (count: number) => void): void; - getEndToEndSession(deviceKey: string, sessionId: string, txn: unknown, func: (session: ISessionInfo) => void): void; - getEndToEndSessions(deviceKey: string, txn: unknown, func: (sessions: { - [sessionId: string]: ISessionInfo; - }) => void): void; - getAllEndToEndSessions(txn: unknown, func: (session: ISessionInfo) => void): void; - storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void; - storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise; - getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise; - filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise; - getEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, txn: unknown, func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void): void; - getAllEndToEndInboundGroupSessions(txn: unknown, func: (session: ISession | null) => void): void; - addEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: unknown): void; - storeEndToEndInboundGroupSession(senderCurve25519Key: string, sessionId: string, sessionData: InboundGroupSessionData, txn: unknown): void; - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key: string, sessionId: string, sessionData: IWithheld, txn: unknown): void; - getEndToEndDeviceData(txn: unknown, func: (deviceData: IDeviceData | null) => void): void; - storeEndToEndDeviceData(deviceData: IDeviceData, txn: unknown): void; - storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: unknown): void; - getEndToEndRooms(txn: unknown, func: (rooms: Record) => void): void; - getSessionsNeedingBackup(limit: number): Promise; - countSessionsNeedingBackup(): Promise; - unmarkSessionsNeedingBackup(sessions: ISession[]): Promise; - markSessionsNeedingBackup(sessions: ISession[]): Promise; - addSharedHistoryInboundGroupSession(roomId: string, senderKey: string, sessionId: string): void; - getSharedHistoryInboundGroupSessions(roomId: string): Promise<[senderKey: string, sessionId: string][]>; - addParkedSharedHistory(roomId: string, parkedData: ParkedSharedHistory): void; - takeParkedSharedHistory(roomId: string): Promise; - doTxn(mode: Mode, stores: Iterable, func: (txn?: unknown) => T): Promise; -} -//# sourceMappingURL=memory-crypto-store.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts.map deleted file mode 100644 index f9c8a15..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"memory-crypto-store.d.ts","sourceRoot":"","sources":["../../../src/crypto/store/memory-crypto-store.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js deleted file mode 100644 index fd52162..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js +++ /dev/null @@ -1,429 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MemoryCryptoStore = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../../logger"); -var utils = _interopRequireWildcard(require("../../utils")); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * Internal module. in-memory storage for e2e. - */ - -class MemoryCryptoStore { - constructor() { - (0, _defineProperty2.default)(this, "outgoingRoomKeyRequests", []); - (0, _defineProperty2.default)(this, "account", null); - (0, _defineProperty2.default)(this, "crossSigningKeys", null); - (0, _defineProperty2.default)(this, "privateKeys", {}); - (0, _defineProperty2.default)(this, "sessions", {}); - (0, _defineProperty2.default)(this, "sessionProblems", {}); - (0, _defineProperty2.default)(this, "notifiedErrorDevices", {}); - (0, _defineProperty2.default)(this, "inboundGroupSessions", {}); - (0, _defineProperty2.default)(this, "inboundGroupSessionsWithheld", {}); - (0, _defineProperty2.default)(this, "deviceData", null); - (0, _defineProperty2.default)(this, "rooms", {}); - (0, _defineProperty2.default)(this, "sessionsNeedingBackup", {}); - (0, _defineProperty2.default)(this, "sharedHistoryInboundGroupSessions", {}); - (0, _defineProperty2.default)(this, "parkedSharedHistory", new Map()); - } - // keyed by room ID - - /** - * Ensure the database exists and is up-to-date. - * - * This must be called before the store can be used. - * - * @returns resolves to the store. - */ - async startup() { - // No startup work to do for the memory store. - return this; - } - - /** - * Delete all data from this store. - * - * @returns Promise which resolves when the store has been cleared. - */ - deleteAllData() { - return Promise.resolve(); - } - - /** - * Look for an existing outgoing room key request, and if none is found, - * add a new one - * - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest}: either the - * same instance as passed in, or the existing one. - */ - getOrAddOutgoingRoomKeyRequest(request) { - const requestBody = request.requestBody; - return utils.promiseTry(() => { - // first see if we already have an entry for this request. - const existing = this._getOutgoingRoomKeyRequest(requestBody); - if (existing) { - // this entry matches the request - return it. - _logger.logger.log(`already have key request outstanding for ` + `${requestBody.room_id} / ${requestBody.session_id}: ` + `not sending another`); - return existing; - } - - // we got to the end of the list without finding a match - // - add the new request. - _logger.logger.log(`enqueueing key request for ${requestBody.room_id} / ` + requestBody.session_id); - this.outgoingRoomKeyRequests.push(request); - return request; - }); - } - - /** - * Look for an existing room key request - * - * @param requestBody - existing request to look for - * - * @returns resolves to the matching - * {@link OutgoingRoomKeyRequest}, or null if - * not found - */ - getOutgoingRoomKeyRequest(requestBody) { - return Promise.resolve(this._getOutgoingRoomKeyRequest(requestBody)); - } - - /** - * Looks for existing room key request, and returns the result synchronously. - * - * @internal - * - * @param requestBody - existing request to look for - * - * @returns - * the matching request, or null if not found - */ - // eslint-disable-next-line @typescript-eslint/naming-convention - _getOutgoingRoomKeyRequest(requestBody) { - for (const existing of this.outgoingRoomKeyRequests) { - if (utils.deepCompare(existing.requestBody, requestBody)) { - return existing; - } - } - return null; - } - - /** - * Look for room key requests by state - * - * @param wantedStates - list of acceptable states - * - * @returns resolves to the a - * {@link OutgoingRoomKeyRequest}, or null if - * there are no pending requests in those states - */ - getOutgoingRoomKeyRequestByState(wantedStates) { - for (const req of this.outgoingRoomKeyRequests) { - for (const state of wantedStates) { - if (req.state === state) { - return Promise.resolve(req); - } - } - } - return Promise.resolve(null); - } - - /** - * - * @returns All OutgoingRoomKeyRequests in state - */ - getAllOutgoingRoomKeyRequestsByState(wantedState) { - return Promise.resolve(this.outgoingRoomKeyRequests.filter(r => r.state == wantedState)); - } - getOutgoingRoomKeyRequestsByTarget(userId, deviceId, wantedStates) { - const results = []; - for (const req of this.outgoingRoomKeyRequests) { - for (const state of wantedStates) { - if (req.state === state && req.recipients.some(recipient => recipient.userId === userId && recipient.deviceId === deviceId)) { - results.push(req); - } - } - } - return Promise.resolve(results); - } - - /** - * Look for an existing room key request by id and state, and update it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * @param updates - name/value map of updates to apply - * - * @returns resolves to - * {@link OutgoingRoomKeyRequest} - * updated request, or null if no matching row was found - */ - updateOutgoingRoomKeyRequest(requestId, expectedState, updates) { - for (const req of this.outgoingRoomKeyRequests) { - if (req.requestId !== requestId) { - continue; - } - if (req.state !== expectedState) { - _logger.logger.warn(`Cannot update room key request from ${expectedState} ` + `as it was already updated to ${req.state}`); - return Promise.resolve(null); - } - Object.assign(req, updates); - return Promise.resolve(req); - } - return Promise.resolve(null); - } - - /** - * Look for an existing room key request by id and state, and delete it if - * found - * - * @param requestId - ID of request to update - * @param expectedState - state we expect to find the request in - * - * @returns resolves once the operation is completed - */ - deleteOutgoingRoomKeyRequest(requestId, expectedState) { - for (let i = 0; i < this.outgoingRoomKeyRequests.length; i++) { - const req = this.outgoingRoomKeyRequests[i]; - if (req.requestId !== requestId) { - continue; - } - if (req.state != expectedState) { - _logger.logger.warn(`Cannot delete room key request in state ${req.state} ` + `(expected ${expectedState})`); - return Promise.resolve(null); - } - this.outgoingRoomKeyRequests.splice(i, 1); - return Promise.resolve(req); - } - return Promise.resolve(null); - } - - // Olm Account - - getAccount(txn, func) { - func(this.account); - } - storeAccount(txn, accountPickle) { - this.account = accountPickle; - } - getCrossSigningKeys(txn, func) { - func(this.crossSigningKeys); - } - getSecretStorePrivateKey(txn, func, type) { - const result = this.privateKeys[type]; - func(result || null); - } - storeCrossSigningKeys(txn, keys) { - this.crossSigningKeys = keys; - } - storeSecretStorePrivateKey(txn, type, key) { - this.privateKeys[type] = key; - } - - // Olm Sessions - - countEndToEndSessions(txn, func) { - func(Object.keys(this.sessions).length); - } - getEndToEndSession(deviceKey, sessionId, txn, func) { - const deviceSessions = this.sessions[deviceKey] || {}; - func(deviceSessions[sessionId] || null); - } - getEndToEndSessions(deviceKey, txn, func) { - func(this.sessions[deviceKey] || {}); - } - getAllEndToEndSessions(txn, func) { - Object.entries(this.sessions).forEach(([deviceKey, deviceSessions]) => { - Object.entries(deviceSessions).forEach(([sessionId, session]) => { - func(_objectSpread(_objectSpread({}, session), {}, { - deviceKey, - sessionId - })); - }); - }); - } - storeEndToEndSession(deviceKey, sessionId, sessionInfo, txn) { - let deviceSessions = this.sessions[deviceKey]; - if (deviceSessions === undefined) { - deviceSessions = {}; - this.sessions[deviceKey] = deviceSessions; - } - deviceSessions[sessionId] = sessionInfo; - } - async storeEndToEndSessionProblem(deviceKey, type, fixed) { - const problems = this.sessionProblems[deviceKey] = this.sessionProblems[deviceKey] || []; - problems.push({ - type, - fixed, - time: Date.now() - }); - problems.sort((a, b) => { - return a.time - b.time; - }); - } - async getEndToEndSessionProblem(deviceKey, timestamp) { - const problems = this.sessionProblems[deviceKey] || []; - if (!problems.length) { - return null; - } - const lastProblem = problems[problems.length - 1]; - for (const problem of problems) { - if (problem.time > timestamp) { - return Object.assign({}, problem, { - fixed: lastProblem.fixed - }); - } - } - if (lastProblem.fixed) { - return null; - } else { - return lastProblem; - } - } - async filterOutNotifiedErrorDevices(devices) { - const notifiedErrorDevices = this.notifiedErrorDevices; - const ret = []; - for (const device of devices) { - const { - userId, - deviceInfo - } = device; - if (userId in notifiedErrorDevices) { - if (!(deviceInfo.deviceId in notifiedErrorDevices[userId])) { - ret.push(device); - (0, utils.safeSet)(notifiedErrorDevices[userId], deviceInfo.deviceId, true); - } - } else { - ret.push(device); - (0, utils.safeSet)(notifiedErrorDevices, userId, { - [deviceInfo.deviceId]: true - }); - } - } - return ret; - } - - // Inbound Group Sessions - - getEndToEndInboundGroupSession(senderCurve25519Key, sessionId, txn, func) { - const k = senderCurve25519Key + "/" + sessionId; - func(this.inboundGroupSessions[k] || null, this.inboundGroupSessionsWithheld[k] || null); - } - getAllEndToEndInboundGroupSessions(txn, func) { - for (const key of Object.keys(this.inboundGroupSessions)) { - // we can't use split, as the components we are trying to split out - // might themselves contain '/' characters. We rely on the - // senderKey being a (32-byte) curve25519 key, base64-encoded - // (hence 43 characters long). - - func({ - senderKey: key.slice(0, 43), - sessionId: key.slice(44), - sessionData: this.inboundGroupSessions[key] - }); - } - func(null); - } - addEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - const k = senderCurve25519Key + "/" + sessionId; - if (this.inboundGroupSessions[k] === undefined) { - this.inboundGroupSessions[k] = sessionData; - } - } - storeEndToEndInboundGroupSession(senderCurve25519Key, sessionId, sessionData, txn) { - this.inboundGroupSessions[senderCurve25519Key + "/" + sessionId] = sessionData; - } - storeEndToEndInboundGroupSessionWithheld(senderCurve25519Key, sessionId, sessionData, txn) { - const k = senderCurve25519Key + "/" + sessionId; - this.inboundGroupSessionsWithheld[k] = sessionData; - } - - // Device Data - - getEndToEndDeviceData(txn, func) { - func(this.deviceData); - } - storeEndToEndDeviceData(deviceData, txn) { - this.deviceData = deviceData; - } - - // E2E rooms - - storeEndToEndRoom(roomId, roomInfo, txn) { - this.rooms[roomId] = roomInfo; - } - getEndToEndRooms(txn, func) { - func(this.rooms); - } - getSessionsNeedingBackup(limit) { - const sessions = []; - for (const session in this.sessionsNeedingBackup) { - if (this.inboundGroupSessions[session]) { - sessions.push({ - senderKey: session.slice(0, 43), - sessionId: session.slice(44), - sessionData: this.inboundGroupSessions[session] - }); - if (limit && session.length >= limit) { - break; - } - } - } - return Promise.resolve(sessions); - } - countSessionsNeedingBackup() { - return Promise.resolve(Object.keys(this.sessionsNeedingBackup).length); - } - unmarkSessionsNeedingBackup(sessions) { - for (const session of sessions) { - const sessionKey = session.senderKey + "/" + session.sessionId; - delete this.sessionsNeedingBackup[sessionKey]; - } - return Promise.resolve(); - } - markSessionsNeedingBackup(sessions) { - for (const session of sessions) { - const sessionKey = session.senderKey + "/" + session.sessionId; - this.sessionsNeedingBackup[sessionKey] = true; - } - return Promise.resolve(); - } - addSharedHistoryInboundGroupSession(roomId, senderKey, sessionId) { - const sessions = this.sharedHistoryInboundGroupSessions[roomId] || []; - sessions.push([senderKey, sessionId]); - this.sharedHistoryInboundGroupSessions[roomId] = sessions; - } - getSharedHistoryInboundGroupSessions(roomId) { - return Promise.resolve(this.sharedHistoryInboundGroupSessions[roomId] || []); - } - addParkedSharedHistory(roomId, parkedData) { - var _this$parkedSharedHis; - const parked = (_this$parkedSharedHis = this.parkedSharedHistory.get(roomId)) !== null && _this$parkedSharedHis !== void 0 ? _this$parkedSharedHis : []; - parked.push(parkedData); - this.parkedSharedHistory.set(roomId, parked); - } - takeParkedSharedHistory(roomId) { - var _this$parkedSharedHis2; - const parked = (_this$parkedSharedHis2 = this.parkedSharedHistory.get(roomId)) !== null && _this$parkedSharedHis2 !== void 0 ? _this$parkedSharedHis2 : []; - this.parkedSharedHistory.delete(roomId); - return Promise.resolve(parked); - } - - // Session key backups - - doTxn(mode, stores, func) { - return Promise.resolve(func(null)); - } -} -exports.MemoryCryptoStore = MemoryCryptoStore; -//# sourceMappingURL=memory-crypto-store.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js.map deleted file mode 100644 index c976150..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/store/memory-crypto-store.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"memory-crypto-store.js","names":["_logger","require","utils","_interopRequireWildcard","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","MemoryCryptoStore","constructor","Map","startup","deleteAllData","Promise","resolve","getOrAddOutgoingRoomKeyRequest","request","requestBody","promiseTry","existing","_getOutgoingRoomKeyRequest","logger","log","room_id","session_id","outgoingRoomKeyRequests","getOutgoingRoomKeyRequest","deepCompare","getOutgoingRoomKeyRequestByState","wantedStates","req","state","getAllOutgoingRoomKeyRequestsByState","wantedState","r","getOutgoingRoomKeyRequestsByTarget","userId","deviceId","results","recipients","some","recipient","updateOutgoingRoomKeyRequest","requestId","expectedState","updates","warn","assign","deleteOutgoingRoomKeyRequest","splice","getAccount","txn","func","account","storeAccount","accountPickle","getCrossSigningKeys","crossSigningKeys","getSecretStorePrivateKey","type","result","privateKeys","storeCrossSigningKeys","storeSecretStorePrivateKey","countEndToEndSessions","sessions","getEndToEndSession","deviceKey","sessionId","deviceSessions","getEndToEndSessions","getAllEndToEndSessions","entries","session","storeEndToEndSession","sessionInfo","undefined","storeEndToEndSessionProblem","fixed","problems","sessionProblems","time","Date","now","sort","a","b","getEndToEndSessionProblem","timestamp","lastProblem","problem","filterOutNotifiedErrorDevices","devices","notifiedErrorDevices","ret","device","deviceInfo","safeSet","getEndToEndInboundGroupSession","senderCurve25519Key","k","inboundGroupSessions","inboundGroupSessionsWithheld","getAllEndToEndInboundGroupSessions","senderKey","slice","sessionData","addEndToEndInboundGroupSession","storeEndToEndInboundGroupSession","storeEndToEndInboundGroupSessionWithheld","getEndToEndDeviceData","deviceData","storeEndToEndDeviceData","storeEndToEndRoom","roomId","roomInfo","rooms","getEndToEndRooms","getSessionsNeedingBackup","limit","sessionsNeedingBackup","countSessionsNeedingBackup","unmarkSessionsNeedingBackup","sessionKey","markSessionsNeedingBackup","addSharedHistoryInboundGroupSession","sharedHistoryInboundGroupSessions","getSharedHistoryInboundGroupSessions","addParkedSharedHistory","parkedData","_this$parkedSharedHis","parked","parkedSharedHistory","takeParkedSharedHistory","_this$parkedSharedHis2","delete","doTxn","mode","stores","exports"],"sources":["../../../src/crypto/store/memory-crypto-store.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../../logger\";\nimport * as utils from \"../../utils\";\nimport {\n CryptoStore,\n IDeviceData,\n IProblem,\n ISession,\n ISessionInfo,\n IWithheld,\n Mode,\n OutgoingRoomKeyRequest,\n ParkedSharedHistory,\n SecretStorePrivateKeys,\n} from \"./base\";\nimport { IRoomKeyRequestBody } from \"../index\";\nimport { ICrossSigningKey } from \"../../client\";\nimport { IOlmDevice } from \"../algorithms/megolm\";\nimport { IRoomEncryption } from \"../RoomList\";\nimport { InboundGroupSessionData } from \"../OlmDevice\";\nimport { safeSet } from \"../../utils\";\n\n/**\n * Internal module. in-memory storage for e2e.\n */\n\nexport class MemoryCryptoStore implements CryptoStore {\n private outgoingRoomKeyRequests: OutgoingRoomKeyRequest[] = [];\n private account: string | null = null;\n private crossSigningKeys: Record | null = null;\n private privateKeys: Partial = {};\n\n private sessions: { [deviceKey: string]: { [sessionId: string]: ISessionInfo } } = {};\n private sessionProblems: { [deviceKey: string]: IProblem[] } = {};\n private notifiedErrorDevices: { [userId: string]: { [deviceId: string]: boolean } } = {};\n private inboundGroupSessions: { [sessionKey: string]: InboundGroupSessionData } = {};\n private inboundGroupSessionsWithheld: Record = {};\n // Opaque device data object\n private deviceData: IDeviceData | null = null;\n private rooms: { [roomId: string]: IRoomEncryption } = {};\n private sessionsNeedingBackup: { [sessionKey: string]: boolean } = {};\n private sharedHistoryInboundGroupSessions: { [roomId: string]: [senderKey: string, sessionId: string][] } = {};\n private parkedSharedHistory = new Map(); // keyed by room ID\n\n /**\n * Ensure the database exists and is up-to-date.\n *\n * This must be called before the store can be used.\n *\n * @returns resolves to the store.\n */\n public async startup(): Promise {\n // No startup work to do for the memory store.\n return this;\n }\n\n /**\n * Delete all data from this store.\n *\n * @returns Promise which resolves when the store has been cleared.\n */\n public deleteAllData(): Promise {\n return Promise.resolve();\n }\n\n /**\n * Look for an existing outgoing room key request, and if none is found,\n * add a new one\n *\n *\n * @returns resolves to\n * {@link OutgoingRoomKeyRequest}: either the\n * same instance as passed in, or the existing one.\n */\n public getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise {\n const requestBody = request.requestBody;\n\n return utils.promiseTry(() => {\n // first see if we already have an entry for this request.\n const existing = this._getOutgoingRoomKeyRequest(requestBody);\n\n if (existing) {\n // this entry matches the request - return it.\n logger.log(\n `already have key request outstanding for ` +\n `${requestBody.room_id} / ${requestBody.session_id}: ` +\n `not sending another`,\n );\n return existing;\n }\n\n // we got to the end of the list without finding a match\n // - add the new request.\n logger.log(`enqueueing key request for ${requestBody.room_id} / ` + requestBody.session_id);\n this.outgoingRoomKeyRequests.push(request);\n return request;\n });\n }\n\n /**\n * Look for an existing room key request\n *\n * @param requestBody - existing request to look for\n *\n * @returns resolves to the matching\n * {@link OutgoingRoomKeyRequest}, or null if\n * not found\n */\n public getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise {\n return Promise.resolve(this._getOutgoingRoomKeyRequest(requestBody));\n }\n\n /**\n * Looks for existing room key request, and returns the result synchronously.\n *\n * @internal\n *\n * @param requestBody - existing request to look for\n *\n * @returns\n * the matching request, or null if not found\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n private _getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): OutgoingRoomKeyRequest | null {\n for (const existing of this.outgoingRoomKeyRequests) {\n if (utils.deepCompare(existing.requestBody, requestBody)) {\n return existing;\n }\n }\n return null;\n }\n\n /**\n * Look for room key requests by state\n *\n * @param wantedStates - list of acceptable states\n *\n * @returns resolves to the a\n * {@link OutgoingRoomKeyRequest}, or null if\n * there are no pending requests in those states\n */\n public getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise {\n for (const req of this.outgoingRoomKeyRequests) {\n for (const state of wantedStates) {\n if (req.state === state) {\n return Promise.resolve(req);\n }\n }\n }\n return Promise.resolve(null);\n }\n\n /**\n *\n * @returns All OutgoingRoomKeyRequests in state\n */\n public getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise {\n return Promise.resolve(this.outgoingRoomKeyRequests.filter((r) => r.state == wantedState));\n }\n\n public getOutgoingRoomKeyRequestsByTarget(\n userId: string,\n deviceId: string,\n wantedStates: number[],\n ): Promise {\n const results: OutgoingRoomKeyRequest[] = [];\n\n for (const req of this.outgoingRoomKeyRequests) {\n for (const state of wantedStates) {\n if (\n req.state === state &&\n req.recipients.some((recipient) => recipient.userId === userId && recipient.deviceId === deviceId)\n ) {\n results.push(req);\n }\n }\n }\n return Promise.resolve(results);\n }\n\n /**\n * Look for an existing room key request by id and state, and update it if\n * found\n *\n * @param requestId - ID of request to update\n * @param expectedState - state we expect to find the request in\n * @param updates - name/value map of updates to apply\n *\n * @returns resolves to\n * {@link OutgoingRoomKeyRequest}\n * updated request, or null if no matching row was found\n */\n public updateOutgoingRoomKeyRequest(\n requestId: string,\n expectedState: number,\n updates: Partial,\n ): Promise {\n for (const req of this.outgoingRoomKeyRequests) {\n if (req.requestId !== requestId) {\n continue;\n }\n\n if (req.state !== expectedState) {\n logger.warn(\n `Cannot update room key request from ${expectedState} ` +\n `as it was already updated to ${req.state}`,\n );\n return Promise.resolve(null);\n }\n Object.assign(req, updates);\n return Promise.resolve(req);\n }\n\n return Promise.resolve(null);\n }\n\n /**\n * Look for an existing room key request by id and state, and delete it if\n * found\n *\n * @param requestId - ID of request to update\n * @param expectedState - state we expect to find the request in\n *\n * @returns resolves once the operation is completed\n */\n public deleteOutgoingRoomKeyRequest(\n requestId: string,\n expectedState: number,\n ): Promise {\n for (let i = 0; i < this.outgoingRoomKeyRequests.length; i++) {\n const req = this.outgoingRoomKeyRequests[i];\n\n if (req.requestId !== requestId) {\n continue;\n }\n\n if (req.state != expectedState) {\n logger.warn(`Cannot delete room key request in state ${req.state} ` + `(expected ${expectedState})`);\n return Promise.resolve(null);\n }\n\n this.outgoingRoomKeyRequests.splice(i, 1);\n return Promise.resolve(req);\n }\n\n return Promise.resolve(null);\n }\n\n // Olm Account\n\n public getAccount(txn: unknown, func: (accountPickle: string | null) => void): void {\n func(this.account);\n }\n\n public storeAccount(txn: unknown, accountPickle: string): void {\n this.account = accountPickle;\n }\n\n public getCrossSigningKeys(txn: unknown, func: (keys: Record | null) => void): void {\n func(this.crossSigningKeys);\n }\n\n public getSecretStorePrivateKey(\n txn: unknown,\n func: (key: SecretStorePrivateKeys[K] | null) => void,\n type: K,\n ): void {\n const result = this.privateKeys[type] as SecretStorePrivateKeys[K] | undefined;\n func(result || null);\n }\n\n public storeCrossSigningKeys(txn: unknown, keys: Record): void {\n this.crossSigningKeys = keys;\n }\n\n public storeSecretStorePrivateKey(\n txn: unknown,\n type: K,\n key: SecretStorePrivateKeys[K],\n ): void {\n this.privateKeys[type] = key;\n }\n\n // Olm Sessions\n\n public countEndToEndSessions(txn: unknown, func: (count: number) => void): void {\n func(Object.keys(this.sessions).length);\n }\n\n public getEndToEndSession(\n deviceKey: string,\n sessionId: string,\n txn: unknown,\n func: (session: ISessionInfo) => void,\n ): void {\n const deviceSessions = this.sessions[deviceKey] || {};\n func(deviceSessions[sessionId] || null);\n }\n\n public getEndToEndSessions(\n deviceKey: string,\n txn: unknown,\n func: (sessions: { [sessionId: string]: ISessionInfo }) => void,\n ): void {\n func(this.sessions[deviceKey] || {});\n }\n\n public getAllEndToEndSessions(txn: unknown, func: (session: ISessionInfo) => void): void {\n Object.entries(this.sessions).forEach(([deviceKey, deviceSessions]) => {\n Object.entries(deviceSessions).forEach(([sessionId, session]) => {\n func({\n ...session,\n deviceKey,\n sessionId,\n });\n });\n });\n }\n\n public storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void {\n let deviceSessions = this.sessions[deviceKey];\n if (deviceSessions === undefined) {\n deviceSessions = {};\n this.sessions[deviceKey] = deviceSessions;\n }\n deviceSessions[sessionId] = sessionInfo;\n }\n\n public async storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise {\n const problems = (this.sessionProblems[deviceKey] = this.sessionProblems[deviceKey] || []);\n problems.push({ type, fixed, time: Date.now() });\n problems.sort((a, b) => {\n return a.time - b.time;\n });\n }\n\n public async getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise {\n const problems = this.sessionProblems[deviceKey] || [];\n if (!problems.length) {\n return null;\n }\n const lastProblem = problems[problems.length - 1];\n for (const problem of problems) {\n if (problem.time > timestamp) {\n return Object.assign({}, problem, { fixed: lastProblem.fixed });\n }\n }\n if (lastProblem.fixed) {\n return null;\n } else {\n return lastProblem;\n }\n }\n\n public async filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise {\n const notifiedErrorDevices = this.notifiedErrorDevices;\n const ret: IOlmDevice[] = [];\n\n for (const device of devices) {\n const { userId, deviceInfo } = device;\n if (userId in notifiedErrorDevices) {\n if (!(deviceInfo.deviceId in notifiedErrorDevices[userId])) {\n ret.push(device);\n safeSet(notifiedErrorDevices[userId], deviceInfo.deviceId, true);\n }\n } else {\n ret.push(device);\n safeSet(notifiedErrorDevices, userId, { [deviceInfo.deviceId]: true });\n }\n }\n\n return ret;\n }\n\n // Inbound Group Sessions\n\n public getEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n txn: unknown,\n func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,\n ): void {\n const k = senderCurve25519Key + \"/\" + sessionId;\n func(this.inboundGroupSessions[k] || null, this.inboundGroupSessionsWithheld[k] || null);\n }\n\n public getAllEndToEndInboundGroupSessions(txn: unknown, func: (session: ISession | null) => void): void {\n for (const key of Object.keys(this.inboundGroupSessions)) {\n // we can't use split, as the components we are trying to split out\n // might themselves contain '/' characters. We rely on the\n // senderKey being a (32-byte) curve25519 key, base64-encoded\n // (hence 43 characters long).\n\n func({\n senderKey: key.slice(0, 43),\n sessionId: key.slice(44),\n sessionData: this.inboundGroupSessions[key],\n });\n }\n func(null);\n }\n\n public addEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: unknown,\n ): void {\n const k = senderCurve25519Key + \"/\" + sessionId;\n if (this.inboundGroupSessions[k] === undefined) {\n this.inboundGroupSessions[k] = sessionData;\n }\n }\n\n public storeEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: unknown,\n ): void {\n this.inboundGroupSessions[senderCurve25519Key + \"/\" + sessionId] = sessionData;\n }\n\n public storeEndToEndInboundGroupSessionWithheld(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: IWithheld,\n txn: unknown,\n ): void {\n const k = senderCurve25519Key + \"/\" + sessionId;\n this.inboundGroupSessionsWithheld[k] = sessionData;\n }\n\n // Device Data\n\n public getEndToEndDeviceData(txn: unknown, func: (deviceData: IDeviceData | null) => void): void {\n func(this.deviceData);\n }\n\n public storeEndToEndDeviceData(deviceData: IDeviceData, txn: unknown): void {\n this.deviceData = deviceData;\n }\n\n // E2E rooms\n\n public storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: unknown): void {\n this.rooms[roomId] = roomInfo;\n }\n\n public getEndToEndRooms(txn: unknown, func: (rooms: Record) => void): void {\n func(this.rooms);\n }\n\n public getSessionsNeedingBackup(limit: number): Promise {\n const sessions: ISession[] = [];\n for (const session in this.sessionsNeedingBackup) {\n if (this.inboundGroupSessions[session]) {\n sessions.push({\n senderKey: session.slice(0, 43),\n sessionId: session.slice(44),\n sessionData: this.inboundGroupSessions[session],\n });\n if (limit && session.length >= limit) {\n break;\n }\n }\n }\n return Promise.resolve(sessions);\n }\n\n public countSessionsNeedingBackup(): Promise {\n return Promise.resolve(Object.keys(this.sessionsNeedingBackup).length);\n }\n\n public unmarkSessionsNeedingBackup(sessions: ISession[]): Promise {\n for (const session of sessions) {\n const sessionKey = session.senderKey + \"/\" + session.sessionId;\n delete this.sessionsNeedingBackup[sessionKey];\n }\n return Promise.resolve();\n }\n\n public markSessionsNeedingBackup(sessions: ISession[]): Promise {\n for (const session of sessions) {\n const sessionKey = session.senderKey + \"/\" + session.sessionId;\n this.sessionsNeedingBackup[sessionKey] = true;\n }\n return Promise.resolve();\n }\n\n public addSharedHistoryInboundGroupSession(roomId: string, senderKey: string, sessionId: string): void {\n const sessions = this.sharedHistoryInboundGroupSessions[roomId] || [];\n sessions.push([senderKey, sessionId]);\n this.sharedHistoryInboundGroupSessions[roomId] = sessions;\n }\n\n public getSharedHistoryInboundGroupSessions(roomId: string): Promise<[senderKey: string, sessionId: string][]> {\n return Promise.resolve(this.sharedHistoryInboundGroupSessions[roomId] || []);\n }\n\n public addParkedSharedHistory(roomId: string, parkedData: ParkedSharedHistory): void {\n const parked = this.parkedSharedHistory.get(roomId) ?? [];\n parked.push(parkedData);\n this.parkedSharedHistory.set(roomId, parked);\n }\n\n public takeParkedSharedHistory(roomId: string): Promise {\n const parked = this.parkedSharedHistory.get(roomId) ?? [];\n this.parkedSharedHistory.delete(roomId);\n return Promise.resolve(parked);\n }\n\n // Session key backups\n\n public doTxn(mode: Mode, stores: Iterable, func: (txn?: unknown) => T): Promise {\n return Promise.resolve(func(null));\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts deleted file mode 100644 index 413728c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts +++ /dev/null @@ -1,87 +0,0 @@ -/** - * Base class for verification methods. - */ -import { MatrixEvent } from "../../models/event"; -import { DeviceInfo } from "../deviceinfo"; -import { KeysDuringVerification } from "../CrossSigning"; -import { IVerificationChannel } from "./request/Channel"; -import { MatrixClient } from "../../client"; -import { VerificationRequest } from "./request/VerificationRequest"; -import { ListenerMap, TypedEventEmitter } from "../../models/typed-event-emitter"; -export declare class SwitchStartEventError extends Error { - readonly startEvent: MatrixEvent | null; - constructor(startEvent: MatrixEvent | null); -} -export type KeyVerifier = (keyId: string, device: DeviceInfo, keyInfo: string) => void; -export declare enum VerificationEvent { - Cancel = "cancel" -} -export type VerificationEventHandlerMap = { - [VerificationEvent.Cancel]: (e: Error | MatrixEvent) => void; -}; -export declare class VerificationBase> extends TypedEventEmitter { - readonly channel: IVerificationChannel; - readonly baseApis: MatrixClient; - readonly userId: string; - readonly deviceId: string; - startEvent: MatrixEvent | null; - readonly request: VerificationRequest; - private cancelled; - private _done; - private promise; - private transactionTimeoutTimer; - protected expectedEvent?: string; - private resolve?; - private reject?; - private resolveEvent?; - private rejectEvent?; - private started?; - /** - * Base class for verification methods. - * - *

Once a verifier object is created, the verification can be started by - * calling the verify() method, which will return a promise that will - * resolve when the verification is completed, or reject if it could not - * complete.

- * - *

Subclasses must have a NAME class property.

- * - * @param channel - the verification channel to send verification messages over. - * TODO: Channel types - * - * @param baseApis - base matrix api interface - * - * @param userId - the user ID that is being verified - * - * @param deviceId - the device ID that is being verified - * - * @param startEvent - the m.key.verification.start event that - * initiated this verification, if any - * - * @param request - the key verification request object related to - * this verification, if any - */ - constructor(channel: IVerificationChannel, baseApis: MatrixClient, userId: string, deviceId: string, startEvent: MatrixEvent | null, request: VerificationRequest); - get initiatedByMe(): boolean; - get hasBeenCancelled(): boolean; - private resetTimer; - private endTimer; - protected send(type: string, uncompletedContent: Record): Promise; - protected waitForEvent(type: string): Promise; - canSwitchStartEvent(event: MatrixEvent): boolean; - switchStartEvent(event: MatrixEvent): void; - handleEvent(e: MatrixEvent): void; - done(): Promise; - cancel(e: Error | MatrixEvent): void; - /** - * Begin the key verification - * - * @returns Promise which resolves when the verification has - * completed. - */ - verify(): Promise; - protected doVerification?: () => Promise; - protected verifyKeys(userId: string, keys: Record, verifier: KeyVerifier): Promise; - get events(): string[] | undefined; -} -//# sourceMappingURL=Base.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts.map deleted file mode 100644 index 30d70f8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Base.d.ts","sourceRoot":"","sources":["../../../src/crypto/verification/Base.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js deleted file mode 100644 index 31150dc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js +++ /dev/null @@ -1,347 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.VerificationEvent = exports.VerificationBase = exports.SwitchStartEventError = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _event = require("../../models/event"); -var _event2 = require("../../@types/event"); -var _logger = require("../../logger"); -var _deviceinfo = require("../deviceinfo"); -var _Error = require("./Error"); -var _CrossSigning = require("../CrossSigning"); -var _typedEventEmitter = require("../../models/typed-event-emitter"); -/* -Copyright 2018 New Vector Ltd -Copyright 2020 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Base class for verification methods. - */ - -const timeoutException = new Error("Verification timed out"); -class SwitchStartEventError extends Error { - constructor(startEvent) { - super(); - this.startEvent = startEvent; - } -} -exports.SwitchStartEventError = SwitchStartEventError; -let VerificationEvent; -exports.VerificationEvent = VerificationEvent; -(function (VerificationEvent) { - VerificationEvent["Cancel"] = "cancel"; -})(VerificationEvent || (exports.VerificationEvent = VerificationEvent = {})); -class VerificationBase extends _typedEventEmitter.TypedEventEmitter { - /** - * Base class for verification methods. - * - *

Once a verifier object is created, the verification can be started by - * calling the verify() method, which will return a promise that will - * resolve when the verification is completed, or reject if it could not - * complete.

- * - *

Subclasses must have a NAME class property.

- * - * @param channel - the verification channel to send verification messages over. - * TODO: Channel types - * - * @param baseApis - base matrix api interface - * - * @param userId - the user ID that is being verified - * - * @param deviceId - the device ID that is being verified - * - * @param startEvent - the m.key.verification.start event that - * initiated this verification, if any - * - * @param request - the key verification request object related to - * this verification, if any - */ - constructor(channel, baseApis, userId, deviceId, startEvent, request) { - super(); - this.channel = channel; - this.baseApis = baseApis; - this.userId = userId; - this.deviceId = deviceId; - this.startEvent = startEvent; - this.request = request; - (0, _defineProperty2.default)(this, "cancelled", false); - (0, _defineProperty2.default)(this, "_done", false); - (0, _defineProperty2.default)(this, "promise", null); - (0, _defineProperty2.default)(this, "transactionTimeoutTimer", null); - (0, _defineProperty2.default)(this, "expectedEvent", void 0); - (0, _defineProperty2.default)(this, "resolve", void 0); - (0, _defineProperty2.default)(this, "reject", void 0); - (0, _defineProperty2.default)(this, "resolveEvent", void 0); - (0, _defineProperty2.default)(this, "rejectEvent", void 0); - (0, _defineProperty2.default)(this, "started", void 0); - (0, _defineProperty2.default)(this, "doVerification", void 0); - } - get initiatedByMe() { - // if there is no start event yet, - // we probably want to send it, - // which happens if we initiate - if (!this.startEvent) { - return true; - } - const sender = this.startEvent.getSender(); - const content = this.startEvent.getContent(); - return sender === this.baseApis.getUserId() && content.from_device === this.baseApis.getDeviceId(); - } - get hasBeenCancelled() { - return this.cancelled; - } - resetTimer() { - _logger.logger.info("Refreshing/starting the verification transaction timeout timer"); - if (this.transactionTimeoutTimer !== null) { - clearTimeout(this.transactionTimeoutTimer); - } - this.transactionTimeoutTimer = setTimeout(() => { - if (!this._done && !this.cancelled) { - _logger.logger.info("Triggering verification timeout"); - this.cancel(timeoutException); - } - }, 10 * 60 * 1000); // 10 minutes - } - - endTimer() { - if (this.transactionTimeoutTimer !== null) { - clearTimeout(this.transactionTimeoutTimer); - this.transactionTimeoutTimer = null; - } - } - send(type, uncompletedContent) { - return this.channel.send(type, uncompletedContent); - } - waitForEvent(type) { - if (this._done) { - return Promise.reject(new Error("Verification is already done")); - } - const existingEvent = this.request.getEventFromOtherParty(type); - if (existingEvent) { - return Promise.resolve(existingEvent); - } - this.expectedEvent = type; - return new Promise((resolve, reject) => { - this.resolveEvent = resolve; - this.rejectEvent = reject; - }); - } - canSwitchStartEvent(event) { - return false; - } - switchStartEvent(event) { - if (this.canSwitchStartEvent(event)) { - _logger.logger.log("Verification Base: switching verification start event", { - restartingFlow: !!this.rejectEvent - }); - if (this.rejectEvent) { - const reject = this.rejectEvent; - this.rejectEvent = undefined; - reject(new SwitchStartEventError(event)); - } else { - this.startEvent = event; - } - } - } - handleEvent(e) { - if (this._done) { - return; - } else if (e.getType() === this.expectedEvent) { - // if we receive an expected m.key.verification.done, then just - // ignore it, since we don't need to do anything about it - if (this.expectedEvent !== _event2.EventType.KeyVerificationDone) { - var _this$resolveEvent; - this.expectedEvent = undefined; - this.rejectEvent = undefined; - this.resetTimer(); - (_this$resolveEvent = this.resolveEvent) === null || _this$resolveEvent === void 0 ? void 0 : _this$resolveEvent.call(this, e); - } - } else if (e.getType() === _event2.EventType.KeyVerificationCancel) { - const reject = this.reject; - this.reject = undefined; - // there is only promise to reject if verify has been called - if (reject) { - const content = e.getContent(); - const { - reason, - code - } = content; - reject(new Error(`Other side cancelled verification ` + `because ${reason} (${code})`)); - } - } else if (this.expectedEvent) { - // only cancel if there is an event expected. - // if there is no event expected, it means verify() wasn't called - // and we're just replaying the timeline events when syncing - // after a refresh when the events haven't been stored in the cache yet. - const exception = new Error("Unexpected message: expecting " + this.expectedEvent + " but got " + e.getType()); - this.expectedEvent = undefined; - if (this.rejectEvent) { - const reject = this.rejectEvent; - this.rejectEvent = undefined; - reject(exception); - } - this.cancel(exception); - } - } - async done() { - this.endTimer(); // always kill the activity timer - if (!this._done) { - var _this$resolve; - this.request.onVerifierFinished(); - (_this$resolve = this.resolve) === null || _this$resolve === void 0 ? void 0 : _this$resolve.call(this); - return (0, _CrossSigning.requestKeysDuringVerification)(this.baseApis, this.userId, this.deviceId); - } - } - cancel(e) { - this.endTimer(); // always kill the activity timer - if (!this._done) { - this.cancelled = true; - this.request.onVerifierCancelled(); - if (this.userId && this.deviceId) { - // send a cancellation to the other user (if it wasn't - // cancelled by the other user) - if (e === timeoutException) { - const timeoutEvent = (0, _Error.newTimeoutError)(); - this.send(timeoutEvent.getType(), timeoutEvent.getContent()); - } else if (e instanceof _event.MatrixEvent) { - const sender = e.getSender(); - if (sender !== this.userId) { - const content = e.getContent(); - if (e.getType() === _event2.EventType.KeyVerificationCancel) { - content.code = content.code || "m.unknown"; - content.reason = content.reason || content.body || "Unknown reason"; - this.send(_event2.EventType.KeyVerificationCancel, content); - } else { - this.send(_event2.EventType.KeyVerificationCancel, { - code: "m.unknown", - reason: content.body || "Unknown reason" - }); - } - } - } else { - this.send(_event2.EventType.KeyVerificationCancel, { - code: "m.unknown", - reason: e.toString() - }); - } - } - if (this.promise !== null) { - // when we cancel without a promise, we end up with a promise - // but no reject function. If cancel is called again, we'd error. - if (this.reject) this.reject(e); - } else { - // FIXME: this causes an "Uncaught promise" console message - // if nothing ends up chaining this promise. - this.promise = Promise.reject(e); - } - // Also emit a 'cancel' event that the app can listen for to detect cancellation - // before calling verify() - this.emit(VerificationEvent.Cancel, e); - } - } - - /** - * Begin the key verification - * - * @returns Promise which resolves when the verification has - * completed. - */ - verify() { - if (this.promise) return this.promise; - this.promise = new Promise((resolve, reject) => { - this.resolve = (...args) => { - this._done = true; - this.endTimer(); - resolve(...args); - }; - this.reject = e => { - this._done = true; - this.endTimer(); - reject(e); - }; - }); - if (this.doVerification && !this.started) { - this.started = true; - this.resetTimer(); // restart the timeout - new Promise((resolve, reject) => { - var _deviceList$getStored; - const crossSignId = (_deviceList$getStored = this.baseApis.crypto.deviceList.getStoredCrossSigningForUser(this.userId)) === null || _deviceList$getStored === void 0 ? void 0 : _deviceList$getStored.getId(); - if (crossSignId === this.deviceId) { - reject(new Error("Device ID is the same as the cross-signing ID")); - } - resolve(); - }).then(() => this.doVerification()).then(this.done.bind(this), this.cancel.bind(this)); - } - return this.promise; - } - async verifyKeys(userId, keys, verifier) { - // we try to verify all the keys that we're told about, but we might - // not know about all of them, so keep track of the keys that we know - // about, and ignore the rest - const verifiedDevices = []; - for (const [keyId, keyInfo] of Object.entries(keys)) { - const deviceId = keyId.split(":", 2)[1]; - const device = this.baseApis.getStoredDevice(userId, deviceId); - if (device) { - verifier(keyId, device, keyInfo); - verifiedDevices.push([deviceId, keyId, device.keys[keyId]]); - } else { - const crossSigningInfo = this.baseApis.crypto.deviceList.getStoredCrossSigningForUser(userId); - if (crossSigningInfo && crossSigningInfo.getId() === deviceId) { - verifier(keyId, _deviceinfo.DeviceInfo.fromStorage({ - keys: { - [keyId]: deviceId - } - }, deviceId), keyInfo); - verifiedDevices.push([deviceId, keyId, deviceId]); - } else { - _logger.logger.warn(`verification: Could not find device ${deviceId} to verify`); - } - } - } - - // if none of the keys could be verified, then error because the app - // should be informed about that - if (!verifiedDevices.length) { - throw new Error("No devices could be verified"); - } - _logger.logger.info("Verification completed! Marking devices verified: ", verifiedDevices); - // TODO: There should probably be a batch version of this, otherwise it's going - // to upload each signature in a separate API call which is silly because the - // API supports as many signatures as you like. - for (const [deviceId, keyId, key] of verifiedDevices) { - await this.baseApis.crypto.setDeviceVerification(userId, deviceId, true, null, null, { - [keyId]: key - }); - } - - // if one of the user's own devices is being marked as verified / unverified, - // check the key backup status, since whether or not we use this depends on - // whether it has a signature from a verified device - if (userId == this.baseApis.credentials.userId) { - await this.baseApis.checkKeyBackup(); - } - } - get events() { - return undefined; - } -} -exports.VerificationBase = VerificationBase; -//# sourceMappingURL=Base.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js.map deleted file mode 100644 index 058d197..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Base.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Base.js","names":["_event","require","_event2","_logger","_deviceinfo","_Error","_CrossSigning","_typedEventEmitter","timeoutException","Error","SwitchStartEventError","constructor","startEvent","exports","VerificationEvent","VerificationBase","TypedEventEmitter","channel","baseApis","userId","deviceId","request","_defineProperty2","default","initiatedByMe","sender","getSender","content","getContent","getUserId","from_device","getDeviceId","hasBeenCancelled","cancelled","resetTimer","logger","info","transactionTimeoutTimer","clearTimeout","setTimeout","_done","cancel","endTimer","send","type","uncompletedContent","waitForEvent","Promise","reject","existingEvent","getEventFromOtherParty","resolve","expectedEvent","resolveEvent","rejectEvent","canSwitchStartEvent","event","switchStartEvent","log","restartingFlow","undefined","handleEvent","e","getType","EventType","KeyVerificationDone","_this$resolveEvent","call","KeyVerificationCancel","reason","code","exception","done","_this$resolve","onVerifierFinished","requestKeysDuringVerification","onVerifierCancelled","timeoutEvent","newTimeoutError","MatrixEvent","body","toString","promise","emit","Cancel","verify","args","doVerification","started","_deviceList$getStored","crossSignId","crypto","deviceList","getStoredCrossSigningForUser","getId","then","bind","verifyKeys","keys","verifier","verifiedDevices","keyId","keyInfo","Object","entries","split","device","getStoredDevice","push","crossSigningInfo","DeviceInfo","fromStorage","warn","length","key","setDeviceVerification","credentials","checkKeyBackup","events"],"sources":["../../../src/crypto/verification/Base.ts"],"sourcesContent":["/*\nCopyright 2018 New Vector Ltd\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Base class for verification methods.\n */\n\nimport { MatrixEvent } from \"../../models/event\";\nimport { EventType } from \"../../@types/event\";\nimport { logger } from \"../../logger\";\nimport { DeviceInfo } from \"../deviceinfo\";\nimport { newTimeoutError } from \"./Error\";\nimport { KeysDuringVerification, requestKeysDuringVerification } from \"../CrossSigning\";\nimport { IVerificationChannel } from \"./request/Channel\";\nimport { MatrixClient } from \"../../client\";\nimport { VerificationRequest } from \"./request/VerificationRequest\";\nimport { ListenerMap, TypedEventEmitter } from \"../../models/typed-event-emitter\";\n\nconst timeoutException = new Error(\"Verification timed out\");\n\nexport class SwitchStartEventError extends Error {\n public constructor(public readonly startEvent: MatrixEvent | null) {\n super();\n }\n}\n\nexport type KeyVerifier = (keyId: string, device: DeviceInfo, keyInfo: string) => void;\n\nexport enum VerificationEvent {\n Cancel = \"cancel\",\n}\n\nexport type VerificationEventHandlerMap = {\n [VerificationEvent.Cancel]: (e: Error | MatrixEvent) => void;\n};\n\nexport class VerificationBase<\n Events extends string,\n Arguments extends ListenerMap,\n> extends TypedEventEmitter {\n private cancelled = false;\n private _done = false;\n private promise: Promise | null = null;\n private transactionTimeoutTimer: ReturnType | null = null;\n protected expectedEvent?: string;\n private resolve?: () => void;\n private reject?: (e: Error | MatrixEvent) => void;\n private resolveEvent?: (e: MatrixEvent) => void;\n private rejectEvent?: (e: Error) => void;\n private started?: boolean;\n\n /**\n * Base class for verification methods.\n *\n *

Once a verifier object is created, the verification can be started by\n * calling the verify() method, which will return a promise that will\n * resolve when the verification is completed, or reject if it could not\n * complete.

\n *\n *

Subclasses must have a NAME class property.

\n *\n * @param channel - the verification channel to send verification messages over.\n * TODO: Channel types\n *\n * @param baseApis - base matrix api interface\n *\n * @param userId - the user ID that is being verified\n *\n * @param deviceId - the device ID that is being verified\n *\n * @param startEvent - the m.key.verification.start event that\n * initiated this verification, if any\n *\n * @param request - the key verification request object related to\n * this verification, if any\n */\n public constructor(\n public readonly channel: IVerificationChannel,\n public readonly baseApis: MatrixClient,\n public readonly userId: string,\n public readonly deviceId: string,\n public startEvent: MatrixEvent | null,\n public readonly request: VerificationRequest,\n ) {\n super();\n }\n\n public get initiatedByMe(): boolean {\n // if there is no start event yet,\n // we probably want to send it,\n // which happens if we initiate\n if (!this.startEvent) {\n return true;\n }\n const sender = this.startEvent.getSender();\n const content = this.startEvent.getContent();\n return sender === this.baseApis.getUserId() && content.from_device === this.baseApis.getDeviceId();\n }\n\n public get hasBeenCancelled(): boolean {\n return this.cancelled;\n }\n\n private resetTimer(): void {\n logger.info(\"Refreshing/starting the verification transaction timeout timer\");\n if (this.transactionTimeoutTimer !== null) {\n clearTimeout(this.transactionTimeoutTimer);\n }\n this.transactionTimeoutTimer = setTimeout(() => {\n if (!this._done && !this.cancelled) {\n logger.info(\"Triggering verification timeout\");\n this.cancel(timeoutException);\n }\n }, 10 * 60 * 1000); // 10 minutes\n }\n\n private endTimer(): void {\n if (this.transactionTimeoutTimer !== null) {\n clearTimeout(this.transactionTimeoutTimer);\n this.transactionTimeoutTimer = null;\n }\n }\n\n protected send(type: string, uncompletedContent: Record): Promise {\n return this.channel.send(type, uncompletedContent);\n }\n\n protected waitForEvent(type: string): Promise {\n if (this._done) {\n return Promise.reject(new Error(\"Verification is already done\"));\n }\n const existingEvent = this.request.getEventFromOtherParty(type);\n if (existingEvent) {\n return Promise.resolve(existingEvent);\n }\n\n this.expectedEvent = type;\n return new Promise((resolve, reject) => {\n this.resolveEvent = resolve;\n this.rejectEvent = reject;\n });\n }\n\n public canSwitchStartEvent(event: MatrixEvent): boolean {\n return false;\n }\n\n public switchStartEvent(event: MatrixEvent): void {\n if (this.canSwitchStartEvent(event)) {\n logger.log(\"Verification Base: switching verification start event\", { restartingFlow: !!this.rejectEvent });\n if (this.rejectEvent) {\n const reject = this.rejectEvent;\n this.rejectEvent = undefined;\n reject(new SwitchStartEventError(event));\n } else {\n this.startEvent = event;\n }\n }\n }\n\n public handleEvent(e: MatrixEvent): void {\n if (this._done) {\n return;\n } else if (e.getType() === this.expectedEvent) {\n // if we receive an expected m.key.verification.done, then just\n // ignore it, since we don't need to do anything about it\n if (this.expectedEvent !== EventType.KeyVerificationDone) {\n this.expectedEvent = undefined;\n this.rejectEvent = undefined;\n this.resetTimer();\n this.resolveEvent?.(e);\n }\n } else if (e.getType() === EventType.KeyVerificationCancel) {\n const reject = this.reject;\n this.reject = undefined;\n // there is only promise to reject if verify has been called\n if (reject) {\n const content = e.getContent();\n const { reason, code } = content;\n reject(new Error(`Other side cancelled verification ` + `because ${reason} (${code})`));\n }\n } else if (this.expectedEvent) {\n // only cancel if there is an event expected.\n // if there is no event expected, it means verify() wasn't called\n // and we're just replaying the timeline events when syncing\n // after a refresh when the events haven't been stored in the cache yet.\n const exception = new Error(\n \"Unexpected message: expecting \" + this.expectedEvent + \" but got \" + e.getType(),\n );\n this.expectedEvent = undefined;\n if (this.rejectEvent) {\n const reject = this.rejectEvent;\n this.rejectEvent = undefined;\n reject(exception);\n }\n this.cancel(exception);\n }\n }\n\n public async done(): Promise {\n this.endTimer(); // always kill the activity timer\n if (!this._done) {\n this.request.onVerifierFinished();\n this.resolve?.();\n return requestKeysDuringVerification(this.baseApis, this.userId, this.deviceId);\n }\n }\n\n public cancel(e: Error | MatrixEvent): void {\n this.endTimer(); // always kill the activity timer\n if (!this._done) {\n this.cancelled = true;\n this.request.onVerifierCancelled();\n if (this.userId && this.deviceId) {\n // send a cancellation to the other user (if it wasn't\n // cancelled by the other user)\n if (e === timeoutException) {\n const timeoutEvent = newTimeoutError();\n this.send(timeoutEvent.getType(), timeoutEvent.getContent());\n } else if (e instanceof MatrixEvent) {\n const sender = e.getSender();\n if (sender !== this.userId) {\n const content = e.getContent();\n if (e.getType() === EventType.KeyVerificationCancel) {\n content.code = content.code || \"m.unknown\";\n content.reason = content.reason || content.body || \"Unknown reason\";\n this.send(EventType.KeyVerificationCancel, content);\n } else {\n this.send(EventType.KeyVerificationCancel, {\n code: \"m.unknown\",\n reason: content.body || \"Unknown reason\",\n });\n }\n }\n } else {\n this.send(EventType.KeyVerificationCancel, {\n code: \"m.unknown\",\n reason: e.toString(),\n });\n }\n }\n if (this.promise !== null) {\n // when we cancel without a promise, we end up with a promise\n // but no reject function. If cancel is called again, we'd error.\n if (this.reject) this.reject(e);\n } else {\n // FIXME: this causes an \"Uncaught promise\" console message\n // if nothing ends up chaining this promise.\n this.promise = Promise.reject(e);\n }\n // Also emit a 'cancel' event that the app can listen for to detect cancellation\n // before calling verify()\n this.emit(VerificationEvent.Cancel, e);\n }\n }\n\n /**\n * Begin the key verification\n *\n * @returns Promise which resolves when the verification has\n * completed.\n */\n public verify(): Promise {\n if (this.promise) return this.promise;\n\n this.promise = new Promise((resolve, reject) => {\n this.resolve = (...args): void => {\n this._done = true;\n this.endTimer();\n resolve(...args);\n };\n this.reject = (e: Error | MatrixEvent): void => {\n this._done = true;\n this.endTimer();\n reject(e);\n };\n });\n if (this.doVerification && !this.started) {\n this.started = true;\n this.resetTimer(); // restart the timeout\n new Promise((resolve, reject) => {\n const crossSignId = this.baseApis.crypto!.deviceList.getStoredCrossSigningForUser(this.userId)?.getId();\n if (crossSignId === this.deviceId) {\n reject(new Error(\"Device ID is the same as the cross-signing ID\"));\n }\n resolve();\n })\n .then(() => this.doVerification!())\n .then(this.done.bind(this), this.cancel.bind(this));\n }\n return this.promise;\n }\n\n protected doVerification?: () => Promise;\n\n protected async verifyKeys(userId: string, keys: Record, verifier: KeyVerifier): Promise {\n // we try to verify all the keys that we're told about, but we might\n // not know about all of them, so keep track of the keys that we know\n // about, and ignore the rest\n const verifiedDevices: [string, string, string][] = [];\n\n for (const [keyId, keyInfo] of Object.entries(keys)) {\n const deviceId = keyId.split(\":\", 2)[1];\n const device = this.baseApis.getStoredDevice(userId, deviceId);\n if (device) {\n verifier(keyId, device, keyInfo);\n verifiedDevices.push([deviceId, keyId, device.keys[keyId]]);\n } else {\n const crossSigningInfo = this.baseApis.crypto!.deviceList.getStoredCrossSigningForUser(userId);\n if (crossSigningInfo && crossSigningInfo.getId() === deviceId) {\n verifier(\n keyId,\n DeviceInfo.fromStorage(\n {\n keys: {\n [keyId]: deviceId,\n },\n },\n deviceId,\n ),\n keyInfo,\n );\n verifiedDevices.push([deviceId, keyId, deviceId]);\n } else {\n logger.warn(`verification: Could not find device ${deviceId} to verify`);\n }\n }\n }\n\n // if none of the keys could be verified, then error because the app\n // should be informed about that\n if (!verifiedDevices.length) {\n throw new Error(\"No devices could be verified\");\n }\n\n logger.info(\"Verification completed! Marking devices verified: \", verifiedDevices);\n // TODO: There should probably be a batch version of this, otherwise it's going\n // to upload each signature in a separate API call which is silly because the\n // API supports as many signatures as you like.\n for (const [deviceId, keyId, key] of verifiedDevices) {\n await this.baseApis.crypto!.setDeviceVerification(userId, deviceId, true, null, null, { [keyId]: key });\n }\n\n // if one of the user's own devices is being marked as verified / unverified,\n // check the key backup status, since whether or not we use this depends on\n // whether it has a signature from a verified device\n if (userId == this.baseApis.credentials.userId) {\n await this.baseApis.checkKeyBackup();\n }\n }\n\n public get events(): string[] | undefined {\n return undefined;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts deleted file mode 100644 index b8fac30..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts +++ /dev/null @@ -1,35 +0,0 @@ -/** - * Error messages. - */ -import { MatrixEvent } from "../../models/event"; -export declare function newVerificationError(code: string, reason: string, extraData?: Record): MatrixEvent; -export declare function errorFactory(code: string, reason: string): (extraData?: Record) => MatrixEvent; -/** - * The verification was cancelled by the user. - */ -export declare const newUserCancelledError: (extraData?: Record) => MatrixEvent; -/** - * The verification timed out. - */ -export declare const newTimeoutError: (extraData?: Record) => MatrixEvent; -/** - * An unknown method was selected. - */ -export declare const newUnknownMethodError: (extraData?: Record) => MatrixEvent; -/** - * An unexpected message was sent. - */ -export declare const newUnexpectedMessageError: (extraData?: Record) => MatrixEvent; -/** - * The key does not match. - */ -export declare const newKeyMismatchError: (extraData?: Record) => MatrixEvent; -/** - * An invalid message was sent. - */ -export declare const newInvalidMessageError: (extraData?: Record) => MatrixEvent; -export declare function errorFromEvent(event: MatrixEvent): { - code: string; - reason: string; -}; -//# sourceMappingURL=Error.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts.map deleted file mode 100644 index 63a87b1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Error.d.ts","sourceRoot":"","sources":["../../../src/crypto/verification/Error.ts"],"names":[],"mappings":"AAgBA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,WAAW,CAM/G;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,WAAW,CAI3G;AAED;;GAEG;AACH,eAAO,MAAM,qBAAqB,eATuC,OAAO,MAAM,EAAE,GAAG,CAAC,KAAK,WASjB,CAAC;AAEjF;;GAEG;AACH,eAAO,MAAM,eAAe,eAd6C,OAAO,MAAM,EAAE,GAAG,CAAC,KAAK,WAc5B,CAAC;AAEtE;;GAEG;AACH,eAAO,MAAM,qBAAqB,eAnBuC,OAAO,MAAM,EAAE,GAAG,CAAC,KAAK,WAmBV,CAAC;AAExF;;GAEG;AACH,eAAO,MAAM,yBAAyB,eAxBmC,OAAO,MAAM,EAAE,GAAG,CAAC,KAAK,WAwBE,CAAC;AAEpG;;GAEG;AACH,eAAO,MAAM,mBAAmB,eA7ByC,OAAO,MAAM,EAAE,GAAG,CAAC,KAAK,WA6BhB,CAAC;AAElF;;GAEG;AACH,eAAO,MAAM,sBAAsB,eAlCsC,OAAO,MAAM,EAAE,GAAG,CAAC,KAAK,WAkCP,CAAC;AAE3F,wBAAgB,cAAc,CAAC,KAAK,EAAE,WAAW,GAAG;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAQnF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js deleted file mode 100644 index 3b4c690..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js +++ /dev/null @@ -1,101 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.errorFactory = errorFactory; -exports.errorFromEvent = errorFromEvent; -exports.newUserCancelledError = exports.newUnknownMethodError = exports.newUnexpectedMessageError = exports.newTimeoutError = exports.newKeyMismatchError = exports.newInvalidMessageError = void 0; -exports.newVerificationError = newVerificationError; -var _event = require("../../models/event"); -var _event2 = require("../../@types/event"); -/* -Copyright 2018 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Error messages. - */ - -function newVerificationError(code, reason, extraData) { - const content = Object.assign({}, { - code, - reason - }, extraData); - return new _event.MatrixEvent({ - type: _event2.EventType.KeyVerificationCancel, - content - }); -} -function errorFactory(code, reason) { - return function (extraData) { - return newVerificationError(code, reason, extraData); - }; -} - -/** - * The verification was cancelled by the user. - */ -const newUserCancelledError = errorFactory("m.user", "Cancelled by user"); - -/** - * The verification timed out. - */ -exports.newUserCancelledError = newUserCancelledError; -const newTimeoutError = errorFactory("m.timeout", "Timed out"); - -/** - * An unknown method was selected. - */ -exports.newTimeoutError = newTimeoutError; -const newUnknownMethodError = errorFactory("m.unknown_method", "Unknown method"); - -/** - * An unexpected message was sent. - */ -exports.newUnknownMethodError = newUnknownMethodError; -const newUnexpectedMessageError = errorFactory("m.unexpected_message", "Unexpected message"); - -/** - * The key does not match. - */ -exports.newUnexpectedMessageError = newUnexpectedMessageError; -const newKeyMismatchError = errorFactory("m.key_mismatch", "Key mismatch"); - -/** - * An invalid message was sent. - */ -exports.newKeyMismatchError = newKeyMismatchError; -const newInvalidMessageError = errorFactory("m.invalid_message", "Invalid message"); -exports.newInvalidMessageError = newInvalidMessageError; -function errorFromEvent(event) { - const content = event.getContent(); - if (content) { - const { - code, - reason - } = content; - return { - code, - reason - }; - } else { - return { - code: "Unknown error", - reason: "m.unknown" - }; - } -} -//# sourceMappingURL=Error.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js.map deleted file mode 100644 index 955658f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/Error.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Error.js","names":["_event","require","_event2","newVerificationError","code","reason","extraData","content","Object","assign","MatrixEvent","type","EventType","KeyVerificationCancel","errorFactory","newUserCancelledError","exports","newTimeoutError","newUnknownMethodError","newUnexpectedMessageError","newKeyMismatchError","newInvalidMessageError","errorFromEvent","event","getContent"],"sources":["../../../src/crypto/verification/Error.ts"],"sourcesContent":["/*\nCopyright 2018 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Error messages.\n */\n\nimport { MatrixEvent } from \"../../models/event\";\nimport { EventType } from \"../../@types/event\";\n\nexport function newVerificationError(code: string, reason: string, extraData?: Record): MatrixEvent {\n const content = Object.assign({}, { code, reason }, extraData);\n return new MatrixEvent({\n type: EventType.KeyVerificationCancel,\n content,\n });\n}\n\nexport function errorFactory(code: string, reason: string): (extraData?: Record) => MatrixEvent {\n return function (extraData?: Record) {\n return newVerificationError(code, reason, extraData);\n };\n}\n\n/**\n * The verification was cancelled by the user.\n */\nexport const newUserCancelledError = errorFactory(\"m.user\", \"Cancelled by user\");\n\n/**\n * The verification timed out.\n */\nexport const newTimeoutError = errorFactory(\"m.timeout\", \"Timed out\");\n\n/**\n * An unknown method was selected.\n */\nexport const newUnknownMethodError = errorFactory(\"m.unknown_method\", \"Unknown method\");\n\n/**\n * An unexpected message was sent.\n */\nexport const newUnexpectedMessageError = errorFactory(\"m.unexpected_message\", \"Unexpected message\");\n\n/**\n * The key does not match.\n */\nexport const newKeyMismatchError = errorFactory(\"m.key_mismatch\", \"Key mismatch\");\n\n/**\n * An invalid message was sent.\n */\nexport const newInvalidMessageError = errorFactory(\"m.invalid_message\", \"Invalid message\");\n\nexport function errorFromEvent(event: MatrixEvent): { code: string; reason: string } {\n const content = event.getContent();\n if (content) {\n const { code, reason } = content;\n return { code, reason };\n } else {\n return { code: \"Unknown error\", reason: \"m.unknown\" };\n }\n}\n"],"mappings":";;;;;;;;;AAoBA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AArBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAKO,SAASE,oBAAoBA,CAACC,IAAY,EAAEC,MAAc,EAAEC,SAA+B,EAAe;EAC7G,MAAMC,OAAO,GAAGC,MAAM,CAACC,MAAM,CAAC,CAAC,CAAC,EAAE;IAAEL,IAAI;IAAEC;EAAO,CAAC,EAAEC,SAAS,CAAC;EAC9D,OAAO,IAAII,kBAAW,CAAC;IACnBC,IAAI,EAAEC,iBAAS,CAACC,qBAAqB;IACrCN;EACJ,CAAC,CAAC;AACN;AAEO,SAASO,YAAYA,CAACV,IAAY,EAAEC,MAAc,EAAoD;EACzG,OAAO,UAAUC,SAA+B,EAAE;IAC9C,OAAOH,oBAAoB,CAACC,IAAI,EAAEC,MAAM,EAAEC,SAAS,CAAC;EACxD,CAAC;AACL;;AAEA;AACA;AACA;AACO,MAAMS,qBAAqB,GAAGD,YAAY,CAAC,QAAQ,EAAE,mBAAmB,CAAC;;AAEhF;AACA;AACA;AAFAE,OAAA,CAAAD,qBAAA,GAAAA,qBAAA;AAGO,MAAME,eAAe,GAAGH,YAAY,CAAC,WAAW,EAAE,WAAW,CAAC;;AAErE;AACA;AACA;AAFAE,OAAA,CAAAC,eAAA,GAAAA,eAAA;AAGO,MAAMC,qBAAqB,GAAGJ,YAAY,CAAC,kBAAkB,EAAE,gBAAgB,CAAC;;AAEvF;AACA;AACA;AAFAE,OAAA,CAAAE,qBAAA,GAAAA,qBAAA;AAGO,MAAMC,yBAAyB,GAAGL,YAAY,CAAC,sBAAsB,EAAE,oBAAoB,CAAC;;AAEnG;AACA;AACA;AAFAE,OAAA,CAAAG,yBAAA,GAAAA,yBAAA;AAGO,MAAMC,mBAAmB,GAAGN,YAAY,CAAC,gBAAgB,EAAE,cAAc,CAAC;;AAEjF;AACA;AACA;AAFAE,OAAA,CAAAI,mBAAA,GAAAA,mBAAA;AAGO,MAAMC,sBAAsB,GAAGP,YAAY,CAAC,mBAAmB,EAAE,iBAAiB,CAAC;AAACE,OAAA,CAAAK,sBAAA,GAAAA,sBAAA;AAEpF,SAASC,cAAcA,CAACC,KAAkB,EAAoC;EACjF,MAAMhB,OAAO,GAAGgB,KAAK,CAACC,UAAU,EAAE;EAClC,IAAIjB,OAAO,EAAE;IACT,MAAM;MAAEH,IAAI;MAAEC;IAAO,CAAC,GAAGE,OAAO;IAChC,OAAO;MAAEH,IAAI;MAAEC;IAAO,CAAC;EAC3B,CAAC,MAAM;IACH,OAAO;MAAED,IAAI,EAAE,eAAe;MAAEC,MAAM,EAAE;IAAY,CAAC;EACzD;AACJ"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts deleted file mode 100644 index b0b08b1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -/** - * Verification method that is illegal to have (cannot possibly - * do verification with this method). - */ -import { VerificationBase as Base, VerificationEvent, VerificationEventHandlerMap } from "./Base"; -import { IVerificationChannel } from "./request/Channel"; -import { MatrixClient } from "../../client"; -import { MatrixEvent } from "../../models/event"; -import { VerificationRequest } from "./request/VerificationRequest"; -export declare class IllegalMethod extends Base { - static factory(channel: IVerificationChannel, baseApis: MatrixClient, userId: string, deviceId: string, startEvent: MatrixEvent, request: VerificationRequest): IllegalMethod; - static get NAME(): string; - protected doVerification: () => Promise; -} -//# sourceMappingURL=IllegalMethod.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts.map deleted file mode 100644 index f06ce4b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"IllegalMethod.d.ts","sourceRoot":"","sources":["../../../src/crypto/verification/IllegalMethod.ts"],"names":[],"mappings":"AAgBA;;;GAGG;AAEH,OAAO,EAAE,gBAAgB,IAAI,IAAI,EAAE,iBAAiB,EAAE,2BAA2B,EAAE,MAAM,QAAQ,CAAC;AAClG,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAEpE,qBAAa,aAAc,SAAQ,IAAI,CAAC,iBAAiB,EAAE,2BAA2B,CAAC;WACrE,OAAO,CACjB,OAAO,EAAE,oBAAoB,EAC7B,QAAQ,EAAE,YAAY,EACtB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,WAAW,EACvB,OAAO,EAAE,mBAAmB,GAC7B,aAAa;IAKhB,WAAkB,IAAI,IAAI,MAAM,CAI/B;IAED,SAAS,CAAC,cAAc,QAAa,QAAQ,IAAI,CAAC,CAEhD;CACL"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js deleted file mode 100644 index c67a675..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js +++ /dev/null @@ -1,50 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.IllegalMethod = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _Base = require("./Base"); -/* -Copyright 2020 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Verification method that is illegal to have (cannot possibly - * do verification with this method). - */ - -class IllegalMethod extends _Base.VerificationBase { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "doVerification", async () => { - throw new Error("Verification is not possible with this method"); - }); - } - static factory(channel, baseApis, userId, deviceId, startEvent, request) { - return new IllegalMethod(channel, baseApis, userId, deviceId, startEvent, request); - } - - // eslint-disable-next-line @typescript-eslint/naming-convention - static get NAME() { - // Typically the name will be something else, but to complete - // the contract we offer a default one here. - return "org.matrix.illegal_method"; - } -} -exports.IllegalMethod = IllegalMethod; -//# sourceMappingURL=IllegalMethod.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js.map deleted file mode 100644 index df32c4a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/IllegalMethod.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"IllegalMethod.js","names":["_Base","require","IllegalMethod","Base","constructor","args","_defineProperty2","default","Error","factory","channel","baseApis","userId","deviceId","startEvent","request","NAME","exports"],"sources":["../../../src/crypto/verification/IllegalMethod.ts"],"sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Verification method that is illegal to have (cannot possibly\n * do verification with this method).\n */\n\nimport { VerificationBase as Base, VerificationEvent, VerificationEventHandlerMap } from \"./Base\";\nimport { IVerificationChannel } from \"./request/Channel\";\nimport { MatrixClient } from \"../../client\";\nimport { MatrixEvent } from \"../../models/event\";\nimport { VerificationRequest } from \"./request/VerificationRequest\";\n\nexport class IllegalMethod extends Base {\n public static factory(\n channel: IVerificationChannel,\n baseApis: MatrixClient,\n userId: string,\n deviceId: string,\n startEvent: MatrixEvent,\n request: VerificationRequest,\n ): IllegalMethod {\n return new IllegalMethod(channel, baseApis, userId, deviceId, startEvent, request);\n }\n\n // eslint-disable-next-line @typescript-eslint/naming-convention\n public static get NAME(): string {\n // Typically the name will be something else, but to complete\n // the contract we offer a default one here.\n return \"org.matrix.illegal_method\";\n }\n\n protected doVerification = async (): Promise => {\n throw new Error(\"Verification is not possible with this method\");\n };\n}\n"],"mappings":";;;;;;;;AAqBA,IAAAA,KAAA,GAAAC,OAAA;AArBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAQO,MAAMC,aAAa,SAASC,sBAAI,CAAiD;EAAAC,YAAA,GAAAC,IAAA;IAAA,SAAAA,IAAA;IAAA,IAAAC,gBAAA,CAAAC,OAAA,0BAmBzD,YAA2B;MAClD,MAAM,IAAIC,KAAK,CAAC,+CAA+C,CAAC;IACpE,CAAC;EAAA;EApBD,OAAcC,OAAOA,CACjBC,OAA6B,EAC7BC,QAAsB,EACtBC,MAAc,EACdC,QAAgB,EAChBC,UAAuB,EACvBC,OAA4B,EACf;IACb,OAAO,IAAIb,aAAa,CAACQ,OAAO,EAAEC,QAAQ,EAAEC,MAAM,EAAEC,QAAQ,EAAEC,UAAU,EAAEC,OAAO,CAAC;EACtF;;EAEA;EACA,WAAkBC,IAAIA,CAAA,EAAW;IAC7B;IACA;IACA,OAAO,2BAA2B;EACtC;AAKJ;AAACC,OAAA,CAAAf,aAAA,GAAAA,aAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts deleted file mode 100644 index 0286f45..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts +++ /dev/null @@ -1,54 +0,0 @@ -/// -/** - * QR code key verification. - */ -import { VerificationBase as Base, VerificationEventHandlerMap } from "./Base"; -import { VerificationRequest } from "./request/VerificationRequest"; -import { MatrixClient } from "../../client"; -import { IVerificationChannel } from "./request/Channel"; -import { MatrixEvent } from "../../models/event"; -export declare const SHOW_QR_CODE_METHOD = "m.qr_code.show.v1"; -export declare const SCAN_QR_CODE_METHOD = "m.qr_code.scan.v1"; -interface IReciprocateQr { - confirm(): void; - cancel(): void; -} -export declare enum QrCodeEvent { - ShowReciprocateQr = "show_reciprocate_qr" -} -type EventHandlerMap = { - [QrCodeEvent.ShowReciprocateQr]: (qr: IReciprocateQr) => void; -} & VerificationEventHandlerMap; -export declare class ReciprocateQRCode extends Base { - reciprocateQREvent?: IReciprocateQr; - static factory(channel: IVerificationChannel, baseApis: MatrixClient, userId: string, deviceId: string, startEvent: MatrixEvent, request: VerificationRequest): ReciprocateQRCode; - static get NAME(): string; - protected doVerification: () => Promise; -} -declare enum Mode { - VerifyOtherUser = 0, - VerifySelfTrusted = 1, - VerifySelfUntrusted = 2 -} -export declare class QRCodeData { - readonly mode: Mode; - private readonly sharedSecret; - readonly otherUserMasterKey: string | null; - readonly otherDeviceKey: string | null; - readonly myMasterKey: string | null; - private readonly buffer; - constructor(mode: Mode, sharedSecret: string, otherUserMasterKey: string | null, otherDeviceKey: string | null, myMasterKey: string | null, buffer: Buffer); - static create(request: VerificationRequest, client: MatrixClient): Promise; - /** - * The unpadded base64 encoded shared secret. - */ - get encodedSharedSecret(): string; - getBuffer(): Buffer; - private static generateSharedSecret; - private static getOtherDeviceKey; - private static determineMode; - private static generateQrData; - private static generateBuffer; -} -export {}; -//# sourceMappingURL=QRCode.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts.map deleted file mode 100644 index b76c304..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"QRCode.d.ts","sourceRoot":"","sources":["../../../src/crypto/verification/QRCode.ts"],"names":[],"mappings":";AAgBA;;GAEG;AAEH,OAAO,EAAE,gBAAgB,IAAI,IAAI,EAAE,2BAA2B,EAAE,MAAM,QAAQ,CAAC;AAI/E,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,eAAO,MAAM,mBAAmB,sBAAsB,CAAC;AACvD,eAAO,MAAM,mBAAmB,sBAAsB,CAAC;AAEvD,UAAU,cAAc;IACpB,OAAO,IAAI,IAAI,CAAC;IAChB,MAAM,IAAI,IAAI,CAAC;CAClB;AAED,oBAAY,WAAW;IACnB,iBAAiB,wBAAwB;CAC5C;AAED,KAAK,eAAe,GAAG;IACnB,CAAC,WAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,EAAE,EAAE,cAAc,KAAK,IAAI,CAAC;CACjE,GAAG,2BAA2B,CAAC;AAEhC,qBAAa,iBAAkB,SAAQ,IAAI,CAAC,WAAW,EAAE,eAAe,CAAC;IAC9D,kBAAkB,CAAC,EAAE,cAAc,CAAC;WAE7B,OAAO,CACjB,OAAO,EAAE,oBAAoB,EAC7B,QAAQ,EAAE,YAAY,EACtB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,WAAW,EACvB,OAAO,EAAE,mBAAmB,GAC7B,iBAAiB;IAKpB,WAAkB,IAAI,IAAI,MAAM,CAE/B;IAED,SAAS,CAAC,cAAc,QAAa,QAAQ,IAAI,CAAC,CA+DhD;CACL;AAKD,aAAK,IAAI;IACL,eAAe,IAAO;IACtB,iBAAiB,IAAO;IACxB,mBAAmB,IAAO;CAC7B;AAYD,qBAAa,UAAU;aAEC,IAAI,EAAE,IAAI;IAC1B,OAAO,CAAC,QAAQ,CAAC,YAAY;aAEb,kBAAkB,EAAE,MAAM,GAAG,IAAI;aAEjC,cAAc,EAAE,MAAM,GAAG,IAAI;aAE7B,WAAW,EAAE,MAAM,GAAG,IAAI;IAC1C,OAAO,CAAC,QAAQ,CAAC,MAAM;gBARP,IAAI,EAAE,IAAI,EACT,YAAY,EAAE,MAAM,EAErB,kBAAkB,EAAE,MAAM,GAAG,IAAI,EAEjC,cAAc,EAAE,MAAM,GAAG,IAAI,EAE7B,WAAW,EAAE,MAAM,GAAG,IAAI,EACzB,MAAM,EAAE,MAAM;WAGf,MAAM,CAAC,OAAO,EAAE,mBAAmB,EAAE,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC,UAAU,CAAC;IA6BnG;;OAEG;IACH,IAAW,mBAAmB,IAAI,MAAM,CAEvC;IAEM,SAAS,IAAI,MAAM;IAI1B,OAAO,CAAC,MAAM,CAAC,oBAAoB;mBAMd,iBAAiB;IAUtC,OAAO,CAAC,MAAM,CAAC,aAAa;IAiB5B,OAAO,CAAC,MAAM,CAAC,cAAc;IAyC7B,OAAO,CAAC,MAAM,CAAC,cAAc;CAkChC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js deleted file mode 100644 index 6e6ba1c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js +++ /dev/null @@ -1,272 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SHOW_QR_CODE_METHOD = exports.SCAN_QR_CODE_METHOD = exports.ReciprocateQRCode = exports.QrCodeEvent = exports.QRCodeData = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _Base = require("./Base"); -var _Error = require("./Error"); -var _olmlib = require("../olmlib"); -var _logger = require("../../logger"); -/* -Copyright 2018 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * QR code key verification. - */ - -const SHOW_QR_CODE_METHOD = "m.qr_code.show.v1"; -exports.SHOW_QR_CODE_METHOD = SHOW_QR_CODE_METHOD; -const SCAN_QR_CODE_METHOD = "m.qr_code.scan.v1"; -exports.SCAN_QR_CODE_METHOD = SCAN_QR_CODE_METHOD; -let QrCodeEvent; -exports.QrCodeEvent = QrCodeEvent; -(function (QrCodeEvent) { - QrCodeEvent["ShowReciprocateQr"] = "show_reciprocate_qr"; -})(QrCodeEvent || (exports.QrCodeEvent = QrCodeEvent = {})); -class ReciprocateQRCode extends _Base.VerificationBase { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "reciprocateQREvent", void 0); - (0, _defineProperty2.default)(this, "doVerification", async () => { - if (!this.startEvent) { - // TODO: Support scanning QR codes - throw new Error("It is not currently possible to start verification" + "with this method yet."); - } - const { - qrCodeData - } = this.request; - // 1. check the secret - if (this.startEvent.getContent()["secret"] !== (qrCodeData === null || qrCodeData === void 0 ? void 0 : qrCodeData.encodedSharedSecret)) { - throw (0, _Error.newKeyMismatchError)(); - } - - // 2. ask if other user shows shield as well - await new Promise((resolve, reject) => { - this.reciprocateQREvent = { - confirm: resolve, - cancel: () => reject((0, _Error.newUserCancelledError)()) - }; - this.emit(QrCodeEvent.ShowReciprocateQr, this.reciprocateQREvent); - }); - - // 3. determine key to sign / mark as trusted - const keys = {}; - switch (qrCodeData === null || qrCodeData === void 0 ? void 0 : qrCodeData.mode) { - case Mode.VerifyOtherUser: - { - // add master key to keys to be signed, only if we're not doing self-verification - const masterKey = qrCodeData.otherUserMasterKey; - keys[`ed25519:${masterKey}`] = masterKey; - break; - } - case Mode.VerifySelfTrusted: - { - const deviceId = this.request.targetDevice.deviceId; - keys[`ed25519:${deviceId}`] = qrCodeData.otherDeviceKey; - break; - } - case Mode.VerifySelfUntrusted: - { - const masterKey = qrCodeData.myMasterKey; - keys[`ed25519:${masterKey}`] = masterKey; - break; - } - } - - // 4. sign the key (or mark own MSK as verified in case of MODE_VERIFY_SELF_TRUSTED) - await this.verifyKeys(this.userId, keys, (keyId, device, keyInfo) => { - // make sure the device has the expected keys - const targetKey = keys[keyId]; - if (!targetKey) throw (0, _Error.newKeyMismatchError)(); - if (keyInfo !== targetKey) { - _logger.logger.error("key ID from key info does not match"); - throw (0, _Error.newKeyMismatchError)(); - } - for (const deviceKeyId in device.keys) { - if (!deviceKeyId.startsWith("ed25519")) continue; - const deviceTargetKey = keys[deviceKeyId]; - if (!deviceTargetKey) throw (0, _Error.newKeyMismatchError)(); - if (device.keys[deviceKeyId] !== deviceTargetKey) { - _logger.logger.error("master key does not match"); - throw (0, _Error.newKeyMismatchError)(); - } - } - }); - }); - } - static factory(channel, baseApis, userId, deviceId, startEvent, request) { - return new ReciprocateQRCode(channel, baseApis, userId, deviceId, startEvent, request); - } - - // eslint-disable-next-line @typescript-eslint/naming-convention - static get NAME() { - return "m.reciprocate.v1"; - } -} -exports.ReciprocateQRCode = ReciprocateQRCode; -const CODE_VERSION = 0x02; // the version of binary QR codes we support -const BINARY_PREFIX = "MATRIX"; // ASCII, used to prefix the binary format -var Mode; // We do not trust the master key -(function (Mode) { - Mode[Mode["VerifyOtherUser"] = 0] = "VerifyOtherUser"; - Mode[Mode["VerifySelfTrusted"] = 1] = "VerifySelfTrusted"; - Mode[Mode["VerifySelfUntrusted"] = 2] = "VerifySelfUntrusted"; -})(Mode || (Mode = {})); -class QRCodeData { - constructor(mode, sharedSecret, - // only set when mode is MODE_VERIFY_OTHER_USER, master key of other party at time of generating QR code - otherUserMasterKey, - // only set when mode is MODE_VERIFY_SELF_TRUSTED, device key of other party at time of generating QR code - otherDeviceKey, - // only set when mode is MODE_VERIFY_SELF_UNTRUSTED, own master key at time of generating QR code - myMasterKey, buffer) { - this.mode = mode; - this.sharedSecret = sharedSecret; - this.otherUserMasterKey = otherUserMasterKey; - this.otherDeviceKey = otherDeviceKey; - this.myMasterKey = myMasterKey; - this.buffer = buffer; - } - static async create(request, client) { - const sharedSecret = QRCodeData.generateSharedSecret(); - const mode = QRCodeData.determineMode(request, client); - let otherUserMasterKey = null; - let otherDeviceKey = null; - let myMasterKey = null; - if (mode === Mode.VerifyOtherUser) { - const otherUserCrossSigningInfo = client.getStoredCrossSigningForUser(request.otherUserId); - otherUserMasterKey = otherUserCrossSigningInfo.getId("master"); - } else if (mode === Mode.VerifySelfTrusted) { - otherDeviceKey = await QRCodeData.getOtherDeviceKey(request, client); - } else if (mode === Mode.VerifySelfUntrusted) { - const myUserId = client.getUserId(); - const myCrossSigningInfo = client.getStoredCrossSigningForUser(myUserId); - myMasterKey = myCrossSigningInfo.getId("master"); - } - const qrData = QRCodeData.generateQrData(request, client, mode, sharedSecret, otherUserMasterKey, otherDeviceKey, myMasterKey); - const buffer = QRCodeData.generateBuffer(qrData); - return new QRCodeData(mode, sharedSecret, otherUserMasterKey, otherDeviceKey, myMasterKey, buffer); - } - - /** - * The unpadded base64 encoded shared secret. - */ - get encodedSharedSecret() { - return this.sharedSecret; - } - getBuffer() { - return this.buffer; - } - static generateSharedSecret() { - const secretBytes = new Uint8Array(11); - global.crypto.getRandomValues(secretBytes); - return (0, _olmlib.encodeUnpaddedBase64)(secretBytes); - } - static async getOtherDeviceKey(request, client) { - const myUserId = client.getUserId(); - const otherDevice = request.targetDevice; - const device = otherDevice.deviceId ? client.getStoredDevice(myUserId, otherDevice.deviceId) : undefined; - if (!device) { - throw new Error("could not find device " + (otherDevice === null || otherDevice === void 0 ? void 0 : otherDevice.deviceId)); - } - return device.getFingerprint(); - } - static determineMode(request, client) { - const myUserId = client.getUserId(); - const otherUserId = request.otherUserId; - let mode = Mode.VerifyOtherUser; - if (myUserId === otherUserId) { - // Mode changes depending on whether or not we trust the master cross signing key - const myTrust = client.checkUserTrust(myUserId); - if (myTrust.isCrossSigningVerified()) { - mode = Mode.VerifySelfTrusted; - } else { - mode = Mode.VerifySelfUntrusted; - } - } - return mode; - } - static generateQrData(request, client, mode, encodedSharedSecret, otherUserMasterKey, otherDeviceKey, myMasterKey) { - const myUserId = client.getUserId(); - const transactionId = request.channel.transactionId; - const qrData = { - prefix: BINARY_PREFIX, - version: CODE_VERSION, - mode, - transactionId, - firstKeyB64: "", - // worked out shortly - secondKeyB64: "", - // worked out shortly - secretB64: encodedSharedSecret - }; - const myCrossSigningInfo = client.getStoredCrossSigningForUser(myUserId); - if (mode === Mode.VerifyOtherUser) { - // First key is our master cross signing key - qrData.firstKeyB64 = myCrossSigningInfo.getId("master"); - // Second key is the other user's master cross signing key - qrData.secondKeyB64 = otherUserMasterKey; - } else if (mode === Mode.VerifySelfTrusted) { - // First key is our master cross signing key - qrData.firstKeyB64 = myCrossSigningInfo.getId("master"); - qrData.secondKeyB64 = otherDeviceKey; - } else if (mode === Mode.VerifySelfUntrusted) { - // First key is our device's key - qrData.firstKeyB64 = client.getDeviceEd25519Key(); - // Second key is what we think our master cross signing key is - qrData.secondKeyB64 = myMasterKey; - } - return qrData; - } - static generateBuffer(qrData) { - let buf = Buffer.alloc(0); // we'll concat our way through life - - const appendByte = b => { - const tmpBuf = Buffer.from([b]); - buf = Buffer.concat([buf, tmpBuf]); - }; - const appendInt = i => { - const tmpBuf = Buffer.alloc(2); - tmpBuf.writeInt16BE(i, 0); - buf = Buffer.concat([buf, tmpBuf]); - }; - const appendStr = (s, enc, withLengthPrefix = true) => { - const tmpBuf = Buffer.from(s, enc); - if (withLengthPrefix) appendInt(tmpBuf.byteLength); - buf = Buffer.concat([buf, tmpBuf]); - }; - const appendEncBase64 = b64 => { - const b = (0, _olmlib.decodeBase64)(b64); - const tmpBuf = Buffer.from(b); - buf = Buffer.concat([buf, tmpBuf]); - }; - - // Actually build the buffer for the QR code - appendStr(qrData.prefix, "ascii", false); - appendByte(qrData.version); - appendByte(qrData.mode); - appendStr(qrData.transactionId, "utf-8"); - appendEncBase64(qrData.firstKeyB64); - appendEncBase64(qrData.secondKeyB64); - appendEncBase64(qrData.secretB64); - return buf; - } -} -exports.QRCodeData = QRCodeData; -//# sourceMappingURL=QRCode.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js.map deleted file mode 100644 index 4f2ac08..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/QRCode.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"QRCode.js","names":["_Base","require","_Error","_olmlib","_logger","SHOW_QR_CODE_METHOD","exports","SCAN_QR_CODE_METHOD","QrCodeEvent","ReciprocateQRCode","Base","constructor","args","_defineProperty2","default","startEvent","Error","qrCodeData","request","getContent","encodedSharedSecret","newKeyMismatchError","Promise","resolve","reject","reciprocateQREvent","confirm","cancel","newUserCancelledError","emit","ShowReciprocateQr","keys","mode","Mode","VerifyOtherUser","masterKey","otherUserMasterKey","VerifySelfTrusted","deviceId","targetDevice","otherDeviceKey","VerifySelfUntrusted","myMasterKey","verifyKeys","userId","keyId","device","keyInfo","targetKey","logger","error","deviceKeyId","startsWith","deviceTargetKey","factory","channel","baseApis","NAME","CODE_VERSION","BINARY_PREFIX","QRCodeData","sharedSecret","buffer","create","client","generateSharedSecret","determineMode","otherUserCrossSigningInfo","getStoredCrossSigningForUser","otherUserId","getId","getOtherDeviceKey","myUserId","getUserId","myCrossSigningInfo","qrData","generateQrData","generateBuffer","getBuffer","secretBytes","Uint8Array","global","crypto","getRandomValues","encodeUnpaddedBase64","otherDevice","getStoredDevice","undefined","getFingerprint","myTrust","checkUserTrust","isCrossSigningVerified","transactionId","prefix","version","firstKeyB64","secondKeyB64","secretB64","getDeviceEd25519Key","buf","Buffer","alloc","appendByte","b","tmpBuf","from","concat","appendInt","i","writeInt16BE","appendStr","s","enc","withLengthPrefix","byteLength","appendEncBase64","b64","decodeBase64"],"sources":["../../../src/crypto/verification/QRCode.ts"],"sourcesContent":["/*\nCopyright 2018 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * QR code key verification.\n */\n\nimport { VerificationBase as Base, VerificationEventHandlerMap } from \"./Base\";\nimport { newKeyMismatchError, newUserCancelledError } from \"./Error\";\nimport { decodeBase64, encodeUnpaddedBase64 } from \"../olmlib\";\nimport { logger } from \"../../logger\";\nimport { VerificationRequest } from \"./request/VerificationRequest\";\nimport { MatrixClient } from \"../../client\";\nimport { IVerificationChannel } from \"./request/Channel\";\nimport { MatrixEvent } from \"../../models/event\";\n\nexport const SHOW_QR_CODE_METHOD = \"m.qr_code.show.v1\";\nexport const SCAN_QR_CODE_METHOD = \"m.qr_code.scan.v1\";\n\ninterface IReciprocateQr {\n confirm(): void;\n cancel(): void;\n}\n\nexport enum QrCodeEvent {\n ShowReciprocateQr = \"show_reciprocate_qr\",\n}\n\ntype EventHandlerMap = {\n [QrCodeEvent.ShowReciprocateQr]: (qr: IReciprocateQr) => void;\n} & VerificationEventHandlerMap;\n\nexport class ReciprocateQRCode extends Base {\n public reciprocateQREvent?: IReciprocateQr;\n\n public static factory(\n channel: IVerificationChannel,\n baseApis: MatrixClient,\n userId: string,\n deviceId: string,\n startEvent: MatrixEvent,\n request: VerificationRequest,\n ): ReciprocateQRCode {\n return new ReciprocateQRCode(channel, baseApis, userId, deviceId, startEvent, request);\n }\n\n // eslint-disable-next-line @typescript-eslint/naming-convention\n public static get NAME(): string {\n return \"m.reciprocate.v1\";\n }\n\n protected doVerification = async (): Promise => {\n if (!this.startEvent) {\n // TODO: Support scanning QR codes\n throw new Error(\"It is not currently possible to start verification\" + \"with this method yet.\");\n }\n\n const { qrCodeData } = this.request;\n // 1. check the secret\n if (this.startEvent.getContent()[\"secret\"] !== qrCodeData?.encodedSharedSecret) {\n throw newKeyMismatchError();\n }\n\n // 2. ask if other user shows shield as well\n await new Promise((resolve, reject) => {\n this.reciprocateQREvent = {\n confirm: resolve,\n cancel: () => reject(newUserCancelledError()),\n };\n this.emit(QrCodeEvent.ShowReciprocateQr, this.reciprocateQREvent);\n });\n\n // 3. determine key to sign / mark as trusted\n const keys: Record = {};\n\n switch (qrCodeData?.mode) {\n case Mode.VerifyOtherUser: {\n // add master key to keys to be signed, only if we're not doing self-verification\n const masterKey = qrCodeData.otherUserMasterKey;\n keys[`ed25519:${masterKey}`] = masterKey!;\n break;\n }\n case Mode.VerifySelfTrusted: {\n const deviceId = this.request.targetDevice.deviceId;\n keys[`ed25519:${deviceId}`] = qrCodeData.otherDeviceKey!;\n break;\n }\n case Mode.VerifySelfUntrusted: {\n const masterKey = qrCodeData.myMasterKey;\n keys[`ed25519:${masterKey}`] = masterKey!;\n break;\n }\n }\n\n // 4. sign the key (or mark own MSK as verified in case of MODE_VERIFY_SELF_TRUSTED)\n await this.verifyKeys(this.userId, keys, (keyId, device, keyInfo) => {\n // make sure the device has the expected keys\n const targetKey = keys[keyId];\n if (!targetKey) throw newKeyMismatchError();\n\n if (keyInfo !== targetKey) {\n logger.error(\"key ID from key info does not match\");\n throw newKeyMismatchError();\n }\n for (const deviceKeyId in device.keys) {\n if (!deviceKeyId.startsWith(\"ed25519\")) continue;\n const deviceTargetKey = keys[deviceKeyId];\n if (!deviceTargetKey) throw newKeyMismatchError();\n if (device.keys[deviceKeyId] !== deviceTargetKey) {\n logger.error(\"master key does not match\");\n throw newKeyMismatchError();\n }\n }\n });\n };\n}\n\nconst CODE_VERSION = 0x02; // the version of binary QR codes we support\nconst BINARY_PREFIX = \"MATRIX\"; // ASCII, used to prefix the binary format\n\nenum Mode {\n VerifyOtherUser = 0x00, // Verifying someone who isn't us\n VerifySelfTrusted = 0x01, // We trust the master key\n VerifySelfUntrusted = 0x02, // We do not trust the master key\n}\n\ninterface IQrData {\n prefix: string;\n version: number;\n mode: Mode;\n transactionId?: string;\n firstKeyB64: string;\n secondKeyB64: string;\n secretB64: string;\n}\n\nexport class QRCodeData {\n public constructor(\n public readonly mode: Mode,\n private readonly sharedSecret: string,\n // only set when mode is MODE_VERIFY_OTHER_USER, master key of other party at time of generating QR code\n public readonly otherUserMasterKey: string | null,\n // only set when mode is MODE_VERIFY_SELF_TRUSTED, device key of other party at time of generating QR code\n public readonly otherDeviceKey: string | null,\n // only set when mode is MODE_VERIFY_SELF_UNTRUSTED, own master key at time of generating QR code\n public readonly myMasterKey: string | null,\n private readonly buffer: Buffer,\n ) {}\n\n public static async create(request: VerificationRequest, client: MatrixClient): Promise {\n const sharedSecret = QRCodeData.generateSharedSecret();\n const mode = QRCodeData.determineMode(request, client);\n let otherUserMasterKey: string | null = null;\n let otherDeviceKey: string | null = null;\n let myMasterKey: string | null = null;\n if (mode === Mode.VerifyOtherUser) {\n const otherUserCrossSigningInfo = client.getStoredCrossSigningForUser(request.otherUserId);\n otherUserMasterKey = otherUserCrossSigningInfo!.getId(\"master\");\n } else if (mode === Mode.VerifySelfTrusted) {\n otherDeviceKey = await QRCodeData.getOtherDeviceKey(request, client);\n } else if (mode === Mode.VerifySelfUntrusted) {\n const myUserId = client.getUserId()!;\n const myCrossSigningInfo = client.getStoredCrossSigningForUser(myUserId);\n myMasterKey = myCrossSigningInfo!.getId(\"master\");\n }\n const qrData = QRCodeData.generateQrData(\n request,\n client,\n mode,\n sharedSecret,\n otherUserMasterKey!,\n otherDeviceKey!,\n myMasterKey!,\n );\n const buffer = QRCodeData.generateBuffer(qrData);\n return new QRCodeData(mode, sharedSecret, otherUserMasterKey, otherDeviceKey, myMasterKey, buffer);\n }\n\n /**\n * The unpadded base64 encoded shared secret.\n */\n public get encodedSharedSecret(): string {\n return this.sharedSecret;\n }\n\n public getBuffer(): Buffer {\n return this.buffer;\n }\n\n private static generateSharedSecret(): string {\n const secretBytes = new Uint8Array(11);\n global.crypto.getRandomValues(secretBytes);\n return encodeUnpaddedBase64(secretBytes);\n }\n\n private static async getOtherDeviceKey(request: VerificationRequest, client: MatrixClient): Promise {\n const myUserId = client.getUserId()!;\n const otherDevice = request.targetDevice;\n const device = otherDevice.deviceId ? client.getStoredDevice(myUserId, otherDevice.deviceId) : undefined;\n if (!device) {\n throw new Error(\"could not find device \" + otherDevice?.deviceId);\n }\n return device.getFingerprint();\n }\n\n private static determineMode(request: VerificationRequest, client: MatrixClient): Mode {\n const myUserId = client.getUserId();\n const otherUserId = request.otherUserId;\n\n let mode = Mode.VerifyOtherUser;\n if (myUserId === otherUserId) {\n // Mode changes depending on whether or not we trust the master cross signing key\n const myTrust = client.checkUserTrust(myUserId);\n if (myTrust.isCrossSigningVerified()) {\n mode = Mode.VerifySelfTrusted;\n } else {\n mode = Mode.VerifySelfUntrusted;\n }\n }\n return mode;\n }\n\n private static generateQrData(\n request: VerificationRequest,\n client: MatrixClient,\n mode: Mode,\n encodedSharedSecret: string,\n otherUserMasterKey?: string,\n otherDeviceKey?: string,\n myMasterKey?: string,\n ): IQrData {\n const myUserId = client.getUserId()!;\n const transactionId = request.channel.transactionId;\n const qrData: IQrData = {\n prefix: BINARY_PREFIX,\n version: CODE_VERSION,\n mode,\n transactionId,\n firstKeyB64: \"\", // worked out shortly\n secondKeyB64: \"\", // worked out shortly\n secretB64: encodedSharedSecret,\n };\n\n const myCrossSigningInfo = client.getStoredCrossSigningForUser(myUserId);\n\n if (mode === Mode.VerifyOtherUser) {\n // First key is our master cross signing key\n qrData.firstKeyB64 = myCrossSigningInfo!.getId(\"master\")!;\n // Second key is the other user's master cross signing key\n qrData.secondKeyB64 = otherUserMasterKey!;\n } else if (mode === Mode.VerifySelfTrusted) {\n // First key is our master cross signing key\n qrData.firstKeyB64 = myCrossSigningInfo!.getId(\"master\")!;\n qrData.secondKeyB64 = otherDeviceKey!;\n } else if (mode === Mode.VerifySelfUntrusted) {\n // First key is our device's key\n qrData.firstKeyB64 = client.getDeviceEd25519Key()!;\n // Second key is what we think our master cross signing key is\n qrData.secondKeyB64 = myMasterKey!;\n }\n return qrData;\n }\n\n private static generateBuffer(qrData: IQrData): Buffer {\n let buf = Buffer.alloc(0); // we'll concat our way through life\n\n const appendByte = (b: number): void => {\n const tmpBuf = Buffer.from([b]);\n buf = Buffer.concat([buf, tmpBuf]);\n };\n const appendInt = (i: number): void => {\n const tmpBuf = Buffer.alloc(2);\n tmpBuf.writeInt16BE(i, 0);\n buf = Buffer.concat([buf, tmpBuf]);\n };\n const appendStr = (s: string, enc: BufferEncoding, withLengthPrefix = true): void => {\n const tmpBuf = Buffer.from(s, enc);\n if (withLengthPrefix) appendInt(tmpBuf.byteLength);\n buf = Buffer.concat([buf, tmpBuf]);\n };\n const appendEncBase64 = (b64: string): void => {\n const b = decodeBase64(b64);\n const tmpBuf = Buffer.from(b);\n buf = Buffer.concat([buf, tmpBuf]);\n };\n\n // Actually build the buffer for the QR code\n appendStr(qrData.prefix, \"ascii\", false);\n appendByte(qrData.version);\n appendByte(qrData.mode);\n appendStr(qrData.transactionId!, \"utf-8\");\n appendEncBase64(qrData.firstKeyB64);\n appendEncBase64(qrData.secondKeyB64);\n appendEncBase64(qrData.secretB64);\n\n return buf;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts deleted file mode 100644 index 0854f13..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts +++ /dev/null @@ -1,37 +0,0 @@ -import { VerificationBase as Base, VerificationEventHandlerMap } from "./Base"; -import { MatrixEvent } from "../../models/event"; -type EmojiMapping = [emoji: string, name: string]; -export interface IGeneratedSas { - decimal?: [number, number, number]; - emoji?: EmojiMapping[]; -} -export interface ISasEvent { - sas: IGeneratedSas; - confirm(): Promise; - cancel(): void; - mismatch(): void; -} -export declare enum SasEvent { - ShowSas = "show_sas" -} -type EventHandlerMap = { - [SasEvent.ShowSas]: (sas: ISasEvent) => void; -} & VerificationEventHandlerMap; -export declare class SAS extends Base { - private waitingForAccept?; - ourSASPubKey?: string; - theirSASPubKey?: string; - sasEvent?: ISasEvent; - static get NAME(): string; - get events(): string[]; - protected doVerification: () => Promise; - canSwitchStartEvent(event: MatrixEvent): boolean; - private sendStart; - private verifyAndCheckMAC; - private doSendVerification; - private doRespondVerification; - private sendMAC; - private checkMAC; -} -export {}; -//# sourceMappingURL=SAS.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts.map deleted file mode 100644 index 7e02a7b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SAS.d.ts","sourceRoot":"","sources":["../../../src/crypto/verification/SAS.ts"],"names":[],"mappings":"AAuBA,OAAO,EAAE,gBAAgB,IAAI,IAAI,EAAyB,2BAA2B,EAAE,MAAM,QAAQ,CAAC;AAStG,OAAO,EAAY,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAc3D,KAAK,YAAY,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;AAyFlD,MAAM,WAAW,aAAa;IAC1B,OAAO,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACnC,KAAK,CAAC,EAAE,YAAY,EAAE,CAAC;CAC1B;AAED,MAAM,WAAW,SAAS;IACtB,GAAG,EAAE,aAAa,CAAC;IACnB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACzB,MAAM,IAAI,IAAI,CAAC;IACf,QAAQ,IAAI,IAAI,CAAC;CACpB;AA6ED,oBAAY,QAAQ;IAChB,OAAO,aAAa;CACvB;AAED,KAAK,eAAe,GAAG;IACnB,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,IAAI,CAAC;CAChD,GAAG,2BAA2B,CAAC;AAEhC,qBAAa,GAAI,SAAQ,IAAI,CAAC,QAAQ,EAAE,eAAe,CAAC;IACpD,OAAO,CAAC,gBAAgB,CAAC,CAAU;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,SAAS,CAAC;IAG5B,WAAkB,IAAI,IAAI,MAAM,CAE/B;IAED,IAAW,MAAM,IAAI,MAAM,EAAE,CAE5B;IAED,SAAS,CAAC,cAAc,QAAa,QAAQ,IAAI,CAAC,CAyBhD;IAEK,mBAAmB,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO;YAQzC,SAAS;YAcT,iBAAiB;YAsCjB,kBAAkB;YAiElB,qBAAqB;IA8CnC,OAAO,CAAC,OAAO;YA0BD,QAAQ;CAsBzB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js deleted file mode 100644 index 781e203..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js +++ /dev/null @@ -1,453 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SasEvent = exports.SAS = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _anotherJson = _interopRequireDefault(require("another-json")); -var _Base = require("./Base"); -var _Error = require("./Error"); -var _logger = require("../../logger"); -var _SASDecimal = require("./SASDecimal"); -var _event = require("../../@types/event"); -/* -Copyright 2018 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Short Authentication String (SAS) verification. - */ - -const START_TYPE = _event.EventType.KeyVerificationStart; -const EVENTS = [_event.EventType.KeyVerificationAccept, _event.EventType.KeyVerificationKey, _event.EventType.KeyVerificationMac]; -let olmutil; -const newMismatchedSASError = (0, _Error.errorFactory)("m.mismatched_sas", "Mismatched short authentication string"); -const newMismatchedCommitmentError = (0, _Error.errorFactory)("m.mismatched_commitment", "Mismatched commitment"); -const emojiMapping = [["🐶", "dog"], -// 0 -["🐱", "cat"], -// 1 -["🦁", "lion"], -// 2 -["🐎", "horse"], -// 3 -["🦄", "unicorn"], -// 4 -["🐷", "pig"], -// 5 -["🐘", "elephant"], -// 6 -["🐰", "rabbit"], -// 7 -["🐼", "panda"], -// 8 -["🐓", "rooster"], -// 9 -["🐧", "penguin"], -// 10 -["🐢", "turtle"], -// 11 -["🐟", "fish"], -// 12 -["🐙", "octopus"], -// 13 -["🦋", "butterfly"], -// 14 -["🌷", "flower"], -// 15 -["🌳", "tree"], -// 16 -["🌵", "cactus"], -// 17 -["🍄", "mushroom"], -// 18 -["🌏", "globe"], -// 19 -["🌙", "moon"], -// 20 -["☁️", "cloud"], -// 21 -["🔥", "fire"], -// 22 -["🍌", "banana"], -// 23 -["🍎", "apple"], -// 24 -["🍓", "strawberry"], -// 25 -["🌽", "corn"], -// 26 -["🍕", "pizza"], -// 27 -["🎂", "cake"], -// 28 -["❤️", "heart"], -// 29 -["🙂", "smiley"], -// 30 -["🤖", "robot"], -// 31 -["🎩", "hat"], -// 32 -["👓", "glasses"], -// 33 -["🔧", "spanner"], -// 34 -["🎅", "santa"], -// 35 -["👍", "thumbs up"], -// 36 -["☂️", "umbrella"], -// 37 -["⌛", "hourglass"], -// 38 -["⏰", "clock"], -// 39 -["🎁", "gift"], -// 40 -["💡", "light bulb"], -// 41 -["📕", "book"], -// 42 -["✏️", "pencil"], -// 43 -["📎", "paperclip"], -// 44 -["✂️", "scissors"], -// 45 -["🔒", "lock"], -// 46 -["🔑", "key"], -// 47 -["🔨", "hammer"], -// 48 -["☎️", "telephone"], -// 49 -["🏁", "flag"], -// 50 -["🚂", "train"], -// 51 -["🚲", "bicycle"], -// 52 -["✈️", "aeroplane"], -// 53 -["🚀", "rocket"], -// 54 -["🏆", "trophy"], -// 55 -["⚽", "ball"], -// 56 -["🎸", "guitar"], -// 57 -["🎺", "trumpet"], -// 58 -["🔔", "bell"], -// 59 -["⚓️", "anchor"], -// 60 -["🎧", "headphones"], -// 61 -["📁", "folder"], -// 62 -["📌", "pin"] // 63 -]; - -function generateEmojiSas(sasBytes) { - const emojis = [ - // just like base64 encoding - sasBytes[0] >> 2, (sasBytes[0] & 0x3) << 4 | sasBytes[1] >> 4, (sasBytes[1] & 0xf) << 2 | sasBytes[2] >> 6, sasBytes[2] & 0x3f, sasBytes[3] >> 2, (sasBytes[3] & 0x3) << 4 | sasBytes[4] >> 4, (sasBytes[4] & 0xf) << 2 | sasBytes[5] >> 6]; - return emojis.map(num => emojiMapping[num]); -} -const sasGenerators = { - decimal: _SASDecimal.generateDecimalSas, - emoji: generateEmojiSas -}; -function generateSas(sasBytes, methods) { - const sas = {}; - for (const method of methods) { - if (method in sasGenerators) { - // @ts-ignore - ts doesn't like us mixing types like this - sas[method] = sasGenerators[method](Array.from(sasBytes)); - } - } - return sas; -} -const macMethods = { - "hkdf-hmac-sha256": "calculate_mac", - "org.matrix.msc3783.hkdf-hmac-sha256": "calculate_mac_fixed_base64", - "hkdf-hmac-sha256.v2": "calculate_mac_fixed_base64", - "hmac-sha256": "calculate_mac_long_kdf" -}; -function calculateMAC(olmSAS, method) { - return function (input, info) { - const mac = olmSAS[macMethods[method]](input, info); - _logger.logger.log("SAS calculateMAC:", method, [input, info], mac); - return mac; - }; -} -const calculateKeyAgreement = { - // eslint-disable-next-line @typescript-eslint/naming-convention - "curve25519-hkdf-sha256": function (sas, olmSAS, bytes) { - const ourInfo = `${sas.baseApis.getUserId()}|${sas.baseApis.deviceId}|` + `${sas.ourSASPubKey}|`; - const theirInfo = `${sas.userId}|${sas.deviceId}|${sas.theirSASPubKey}|`; - const sasInfo = "MATRIX_KEY_VERIFICATION_SAS|" + (sas.initiatedByMe ? ourInfo + theirInfo : theirInfo + ourInfo) + sas.channel.transactionId; - return olmSAS.generate_bytes(sasInfo, bytes); - }, - "curve25519": function (sas, olmSAS, bytes) { - const ourInfo = `${sas.baseApis.getUserId()}${sas.baseApis.deviceId}`; - const theirInfo = `${sas.userId}${sas.deviceId}`; - const sasInfo = "MATRIX_KEY_VERIFICATION_SAS" + (sas.initiatedByMe ? ourInfo + theirInfo : theirInfo + ourInfo) + sas.channel.transactionId; - return olmSAS.generate_bytes(sasInfo, bytes); - } -}; -/* lists of algorithms/methods that are supported. The key agreement, hashes, - * and MAC lists should be sorted in order of preference (most preferred - * first). - */ -const KEY_AGREEMENT_LIST = ["curve25519-hkdf-sha256", "curve25519"]; -const HASHES_LIST = ["sha256"]; -const MAC_LIST = ["hkdf-hmac-sha256.v2", "org.matrix.msc3783.hkdf-hmac-sha256", "hkdf-hmac-sha256", "hmac-sha256"]; -const SAS_LIST = Object.keys(sasGenerators); -const KEY_AGREEMENT_SET = new Set(KEY_AGREEMENT_LIST); -const HASHES_SET = new Set(HASHES_LIST); -const MAC_SET = new Set(MAC_LIST); -const SAS_SET = new Set(SAS_LIST); -function intersection(anArray, aSet) { - return Array.isArray(anArray) ? anArray.filter(x => aSet.has(x)) : []; -} -let SasEvent; -exports.SasEvent = SasEvent; -(function (SasEvent) { - SasEvent["ShowSas"] = "show_sas"; -})(SasEvent || (exports.SasEvent = SasEvent = {})); -class SAS extends _Base.VerificationBase { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "waitingForAccept", void 0); - (0, _defineProperty2.default)(this, "ourSASPubKey", void 0); - (0, _defineProperty2.default)(this, "theirSASPubKey", void 0); - (0, _defineProperty2.default)(this, "sasEvent", void 0); - (0, _defineProperty2.default)(this, "doVerification", async () => { - await global.Olm.init(); - olmutil = olmutil || new global.Olm.Utility(); - - // make sure user's keys are downloaded - await this.baseApis.downloadKeys([this.userId]); - let retry = false; - do { - try { - if (this.initiatedByMe) { - return await this.doSendVerification(); - } else { - return await this.doRespondVerification(); - } - } catch (err) { - if (err instanceof _Base.SwitchStartEventError) { - // this changes what initiatedByMe returns - this.startEvent = err.startEvent; - retry = true; - } else { - throw err; - } - } - } while (retry); - }); - } - // eslint-disable-next-line @typescript-eslint/naming-convention - static get NAME() { - return "m.sas.v1"; - } - get events() { - return EVENTS; - } - canSwitchStartEvent(event) { - if (event.getType() !== START_TYPE) { - return false; - } - const content = event.getContent(); - return (content === null || content === void 0 ? void 0 : content.method) === SAS.NAME && !!this.waitingForAccept; - } - async sendStart() { - const startContent = this.channel.completeContent(START_TYPE, { - method: SAS.NAME, - from_device: this.baseApis.deviceId, - key_agreement_protocols: KEY_AGREEMENT_LIST, - hashes: HASHES_LIST, - message_authentication_codes: MAC_LIST, - // FIXME: allow app to specify what SAS methods can be used - short_authentication_string: SAS_LIST - }); - await this.channel.sendCompleted(START_TYPE, startContent); - return startContent; - } - async verifyAndCheckMAC(keyAgreement, sasMethods, olmSAS, macMethod) { - const sasBytes = calculateKeyAgreement[keyAgreement](this, olmSAS, 6); - const verifySAS = new Promise((resolve, reject) => { - this.sasEvent = { - sas: generateSas(sasBytes, sasMethods), - confirm: async () => { - try { - await this.sendMAC(olmSAS, macMethod); - resolve(); - } catch (err) { - reject(err); - } - }, - cancel: () => reject((0, _Error.newUserCancelledError)()), - mismatch: () => reject(newMismatchedSASError()) - }; - this.emit(SasEvent.ShowSas, this.sasEvent); - }); - const [e] = await Promise.all([this.waitForEvent(_event.EventType.KeyVerificationMac).then(e => { - // we don't expect any more messages from the other - // party, and they may send a m.key.verification.done - // when they're done on their end - this.expectedEvent = _event.EventType.KeyVerificationDone; - return e; - }), verifySAS]); - const content = e.getContent(); - await this.checkMAC(olmSAS, content, macMethod); - } - async doSendVerification() { - this.waitingForAccept = true; - let startContent; - if (this.startEvent) { - startContent = this.channel.completedContentFromEvent(this.startEvent); - } else { - startContent = await this.sendStart(); - } - - // we might have switched to a different start event, - // but was we didn't call _waitForEvent there was no - // call that could throw yet. So check manually that - // we're still on the initiator side - if (!this.initiatedByMe) { - throw new _Base.SwitchStartEventError(this.startEvent); - } - let e; - try { - e = await this.waitForEvent(_event.EventType.KeyVerificationAccept); - } finally { - this.waitingForAccept = false; - } - let content = e.getContent(); - const sasMethods = intersection(content.short_authentication_string, SAS_SET); - if (!(KEY_AGREEMENT_SET.has(content.key_agreement_protocol) && HASHES_SET.has(content.hash) && MAC_SET.has(content.message_authentication_code) && sasMethods.length)) { - throw (0, _Error.newUnknownMethodError)(); - } - if (typeof content.commitment !== "string") { - throw (0, _Error.newInvalidMessageError)(); - } - const keyAgreement = content.key_agreement_protocol; - const macMethod = content.message_authentication_code; - const hashCommitment = content.commitment; - const olmSAS = new global.Olm.SAS(); - try { - this.ourSASPubKey = olmSAS.get_pubkey(); - await this.send(_event.EventType.KeyVerificationKey, { - key: this.ourSASPubKey - }); - e = await this.waitForEvent(_event.EventType.KeyVerificationKey); - // FIXME: make sure event is properly formed - content = e.getContent(); - const commitmentStr = content.key + _anotherJson.default.stringify(startContent); - // TODO: use selected hash function (when we support multiple) - if (olmutil.sha256(commitmentStr) !== hashCommitment) { - throw newMismatchedCommitmentError(); - } - this.theirSASPubKey = content.key; - olmSAS.set_their_key(content.key); - await this.verifyAndCheckMAC(keyAgreement, sasMethods, olmSAS, macMethod); - } finally { - olmSAS.free(); - } - } - async doRespondVerification() { - // as m.related_to is not included in the encrypted content in e2e rooms, - // we need to make sure it is added - let content = this.channel.completedContentFromEvent(this.startEvent); - - // Note: we intersect using our pre-made lists, rather than the sets, - // so that the result will be in our order of preference. Then - // fetching the first element from the array will give our preferred - // method out of the ones offered by the other party. - const keyAgreement = intersection(KEY_AGREEMENT_LIST, new Set(content.key_agreement_protocols))[0]; - const hashMethod = intersection(HASHES_LIST, new Set(content.hashes))[0]; - const macMethod = intersection(MAC_LIST, new Set(content.message_authentication_codes))[0]; - // FIXME: allow app to specify what SAS methods can be used - const sasMethods = intersection(content.short_authentication_string, SAS_SET); - if (!(keyAgreement !== undefined && hashMethod !== undefined && macMethod !== undefined && sasMethods.length)) { - throw (0, _Error.newUnknownMethodError)(); - } - const olmSAS = new global.Olm.SAS(); - try { - const commitmentStr = olmSAS.get_pubkey() + _anotherJson.default.stringify(content); - await this.send(_event.EventType.KeyVerificationAccept, { - key_agreement_protocol: keyAgreement, - hash: hashMethod, - message_authentication_code: macMethod, - short_authentication_string: sasMethods, - // TODO: use selected hash function (when we support multiple) - commitment: olmutil.sha256(commitmentStr) - }); - const e = await this.waitForEvent(_event.EventType.KeyVerificationKey); - // FIXME: make sure event is properly formed - content = e.getContent(); - this.theirSASPubKey = content.key; - olmSAS.set_their_key(content.key); - this.ourSASPubKey = olmSAS.get_pubkey(); - await this.send(_event.EventType.KeyVerificationKey, { - key: this.ourSASPubKey - }); - await this.verifyAndCheckMAC(keyAgreement, sasMethods, olmSAS, macMethod); - } finally { - olmSAS.free(); - } - } - sendMAC(olmSAS, method) { - const mac = {}; - const keyList = []; - const baseInfo = "MATRIX_KEY_VERIFICATION_MAC" + this.baseApis.getUserId() + this.baseApis.deviceId + this.userId + this.deviceId + this.channel.transactionId; - const deviceKeyId = `ed25519:${this.baseApis.deviceId}`; - mac[deviceKeyId] = calculateMAC(olmSAS, method)(this.baseApis.getDeviceEd25519Key(), baseInfo + deviceKeyId); - keyList.push(deviceKeyId); - const crossSigningId = this.baseApis.getCrossSigningId(); - if (crossSigningId) { - const crossSigningKeyId = `ed25519:${crossSigningId}`; - mac[crossSigningKeyId] = calculateMAC(olmSAS, method)(crossSigningId, baseInfo + crossSigningKeyId); - keyList.push(crossSigningKeyId); - } - const keys = calculateMAC(olmSAS, method)(keyList.sort().join(","), baseInfo + "KEY_IDS"); - return this.send(_event.EventType.KeyVerificationMac, { - mac, - keys - }); - } - async checkMAC(olmSAS, content, method) { - const baseInfo = "MATRIX_KEY_VERIFICATION_MAC" + this.userId + this.deviceId + this.baseApis.getUserId() + this.baseApis.deviceId + this.channel.transactionId; - if (content.keys !== calculateMAC(olmSAS, method)(Object.keys(content.mac).sort().join(","), baseInfo + "KEY_IDS")) { - throw (0, _Error.newKeyMismatchError)(); - } - await this.verifyKeys(this.userId, content.mac, (keyId, device, keyInfo) => { - if (keyInfo !== calculateMAC(olmSAS, method)(device.keys[keyId], baseInfo + keyId)) { - throw (0, _Error.newKeyMismatchError)(); - } - }); - } -} -exports.SAS = SAS; -//# sourceMappingURL=SAS.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js.map deleted file mode 100644 index be47b3f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SAS.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SAS.js","names":["_anotherJson","_interopRequireDefault","require","_Base","_Error","_logger","_SASDecimal","_event","START_TYPE","EventType","KeyVerificationStart","EVENTS","KeyVerificationAccept","KeyVerificationKey","KeyVerificationMac","olmutil","newMismatchedSASError","errorFactory","newMismatchedCommitmentError","emojiMapping","generateEmojiSas","sasBytes","emojis","map","num","sasGenerators","decimal","generateDecimalSas","emoji","generateSas","methods","sas","method","Array","from","macMethods","calculateMAC","olmSAS","input","info","mac","logger","log","calculateKeyAgreement","curve25519-hkdf-sha256","bytes","ourInfo","baseApis","getUserId","deviceId","ourSASPubKey","theirInfo","userId","theirSASPubKey","sasInfo","initiatedByMe","channel","transactionId","generate_bytes","curve25519","KEY_AGREEMENT_LIST","HASHES_LIST","MAC_LIST","SAS_LIST","Object","keys","KEY_AGREEMENT_SET","Set","HASHES_SET","MAC_SET","SAS_SET","intersection","anArray","aSet","isArray","filter","x","has","SasEvent","exports","SAS","Base","constructor","args","_defineProperty2","default","global","Olm","init","Utility","downloadKeys","retry","doSendVerification","doRespondVerification","err","SwitchStartEventError","startEvent","NAME","events","canSwitchStartEvent","event","getType","content","getContent","waitingForAccept","sendStart","startContent","completeContent","from_device","key_agreement_protocols","hashes","message_authentication_codes","short_authentication_string","sendCompleted","verifyAndCheckMAC","keyAgreement","sasMethods","macMethod","verifySAS","Promise","resolve","reject","sasEvent","confirm","sendMAC","cancel","newUserCancelledError","mismatch","emit","ShowSas","e","all","waitForEvent","then","expectedEvent","KeyVerificationDone","checkMAC","completedContentFromEvent","key_agreement_protocol","hash","message_authentication_code","length","newUnknownMethodError","commitment","newInvalidMessageError","hashCommitment","get_pubkey","send","key","commitmentStr","anotherjson","stringify","sha256","set_their_key","free","hashMethod","undefined","keyList","baseInfo","deviceKeyId","getDeviceEd25519Key","push","crossSigningId","getCrossSigningId","crossSigningKeyId","sort","join","newKeyMismatchError","verifyKeys","keyId","device","keyInfo"],"sources":["../../../src/crypto/verification/SAS.ts"],"sourcesContent":["/*\nCopyright 2018 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Short Authentication String (SAS) verification.\n */\n\nimport anotherjson from \"another-json\";\nimport { Utility, SAS as OlmSAS } from \"@matrix-org/olm\";\n\nimport { VerificationBase as Base, SwitchStartEventError, VerificationEventHandlerMap } from \"./Base\";\nimport {\n errorFactory,\n newInvalidMessageError,\n newKeyMismatchError,\n newUnknownMethodError,\n newUserCancelledError,\n} from \"./Error\";\nimport { logger } from \"../../logger\";\nimport { IContent, MatrixEvent } from \"../../models/event\";\nimport { generateDecimalSas } from \"./SASDecimal\";\nimport { EventType } from \"../../@types/event\";\n\nconst START_TYPE = EventType.KeyVerificationStart;\n\nconst EVENTS = [EventType.KeyVerificationAccept, EventType.KeyVerificationKey, EventType.KeyVerificationMac];\n\nlet olmutil: Utility;\n\nconst newMismatchedSASError = errorFactory(\"m.mismatched_sas\", \"Mismatched short authentication string\");\n\nconst newMismatchedCommitmentError = errorFactory(\"m.mismatched_commitment\", \"Mismatched commitment\");\n\ntype EmojiMapping = [emoji: string, name: string];\n\nconst emojiMapping: EmojiMapping[] = [\n [\"🐶\", \"dog\"], // 0\n [\"🐱\", \"cat\"], // 1\n [\"🦁\", \"lion\"], // 2\n [\"🐎\", \"horse\"], // 3\n [\"🦄\", \"unicorn\"], // 4\n [\"🐷\", \"pig\"], // 5\n [\"🐘\", \"elephant\"], // 6\n [\"🐰\", \"rabbit\"], // 7\n [\"🐼\", \"panda\"], // 8\n [\"🐓\", \"rooster\"], // 9\n [\"🐧\", \"penguin\"], // 10\n [\"🐢\", \"turtle\"], // 11\n [\"🐟\", \"fish\"], // 12\n [\"🐙\", \"octopus\"], // 13\n [\"🦋\", \"butterfly\"], // 14\n [\"🌷\", \"flower\"], // 15\n [\"🌳\", \"tree\"], // 16\n [\"🌵\", \"cactus\"], // 17\n [\"🍄\", \"mushroom\"], // 18\n [\"🌏\", \"globe\"], // 19\n [\"🌙\", \"moon\"], // 20\n [\"☁️\", \"cloud\"], // 21\n [\"🔥\", \"fire\"], // 22\n [\"🍌\", \"banana\"], // 23\n [\"🍎\", \"apple\"], // 24\n [\"🍓\", \"strawberry\"], // 25\n [\"🌽\", \"corn\"], // 26\n [\"🍕\", \"pizza\"], // 27\n [\"🎂\", \"cake\"], // 28\n [\"❤️\", \"heart\"], // 29\n [\"🙂\", \"smiley\"], // 30\n [\"🤖\", \"robot\"], // 31\n [\"🎩\", \"hat\"], // 32\n [\"👓\", \"glasses\"], // 33\n [\"🔧\", \"spanner\"], // 34\n [\"🎅\", \"santa\"], // 35\n [\"👍\", \"thumbs up\"], // 36\n [\"☂️\", \"umbrella\"], // 37\n [\"⌛\", \"hourglass\"], // 38\n [\"⏰\", \"clock\"], // 39\n [\"🎁\", \"gift\"], // 40\n [\"💡\", \"light bulb\"], // 41\n [\"📕\", \"book\"], // 42\n [\"✏️\", \"pencil\"], // 43\n [\"📎\", \"paperclip\"], // 44\n [\"✂️\", \"scissors\"], // 45\n [\"🔒\", \"lock\"], // 46\n [\"🔑\", \"key\"], // 47\n [\"🔨\", \"hammer\"], // 48\n [\"☎️\", \"telephone\"], // 49\n [\"🏁\", \"flag\"], // 50\n [\"🚂\", \"train\"], // 51\n [\"🚲\", \"bicycle\"], // 52\n [\"✈️\", \"aeroplane\"], // 53\n [\"🚀\", \"rocket\"], // 54\n [\"🏆\", \"trophy\"], // 55\n [\"⚽\", \"ball\"], // 56\n [\"🎸\", \"guitar\"], // 57\n [\"🎺\", \"trumpet\"], // 58\n [\"🔔\", \"bell\"], // 59\n [\"⚓️\", \"anchor\"], // 60\n [\"🎧\", \"headphones\"], // 61\n [\"📁\", \"folder\"], // 62\n [\"📌\", \"pin\"], // 63\n];\n\nfunction generateEmojiSas(sasBytes: number[]): EmojiMapping[] {\n const emojis = [\n // just like base64 encoding\n sasBytes[0] >> 2,\n ((sasBytes[0] & 0x3) << 4) | (sasBytes[1] >> 4),\n ((sasBytes[1] & 0xf) << 2) | (sasBytes[2] >> 6),\n sasBytes[2] & 0x3f,\n sasBytes[3] >> 2,\n ((sasBytes[3] & 0x3) << 4) | (sasBytes[4] >> 4),\n ((sasBytes[4] & 0xf) << 2) | (sasBytes[5] >> 6),\n ];\n\n return emojis.map((num) => emojiMapping[num]);\n}\n\nconst sasGenerators = {\n decimal: generateDecimalSas,\n emoji: generateEmojiSas,\n} as const;\n\nexport interface IGeneratedSas {\n decimal?: [number, number, number];\n emoji?: EmojiMapping[];\n}\n\nexport interface ISasEvent {\n sas: IGeneratedSas;\n confirm(): Promise;\n cancel(): void;\n mismatch(): void;\n}\n\nfunction generateSas(sasBytes: Uint8Array, methods: string[]): IGeneratedSas {\n const sas: IGeneratedSas = {};\n for (const method of methods) {\n if (method in sasGenerators) {\n // @ts-ignore - ts doesn't like us mixing types like this\n sas[method] = sasGenerators[method](Array.from(sasBytes));\n }\n }\n return sas;\n}\n\nconst macMethods = {\n \"hkdf-hmac-sha256\": \"calculate_mac\",\n \"org.matrix.msc3783.hkdf-hmac-sha256\": \"calculate_mac_fixed_base64\",\n \"hkdf-hmac-sha256.v2\": \"calculate_mac_fixed_base64\",\n \"hmac-sha256\": \"calculate_mac_long_kdf\",\n} as const;\n\ntype MacMethod = keyof typeof macMethods;\n\nfunction calculateMAC(olmSAS: OlmSAS, method: MacMethod) {\n return function (input: string, info: string): string {\n const mac = olmSAS[macMethods[method]](input, info);\n logger.log(\"SAS calculateMAC:\", method, [input, info], mac);\n return mac;\n };\n}\n\nconst calculateKeyAgreement = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n \"curve25519-hkdf-sha256\": function (sas: SAS, olmSAS: OlmSAS, bytes: number): Uint8Array {\n const ourInfo = `${sas.baseApis.getUserId()}|${sas.baseApis.deviceId}|` + `${sas.ourSASPubKey}|`;\n const theirInfo = `${sas.userId}|${sas.deviceId}|${sas.theirSASPubKey}|`;\n const sasInfo =\n \"MATRIX_KEY_VERIFICATION_SAS|\" +\n (sas.initiatedByMe ? ourInfo + theirInfo : theirInfo + ourInfo) +\n sas.channel.transactionId;\n return olmSAS.generate_bytes(sasInfo, bytes);\n },\n \"curve25519\": function (sas: SAS, olmSAS: OlmSAS, bytes: number): Uint8Array {\n const ourInfo = `${sas.baseApis.getUserId()}${sas.baseApis.deviceId}`;\n const theirInfo = `${sas.userId}${sas.deviceId}`;\n const sasInfo =\n \"MATRIX_KEY_VERIFICATION_SAS\" +\n (sas.initiatedByMe ? ourInfo + theirInfo : theirInfo + ourInfo) +\n sas.channel.transactionId;\n return olmSAS.generate_bytes(sasInfo, bytes);\n },\n} as const;\n\ntype KeyAgreement = keyof typeof calculateKeyAgreement;\n\n/* lists of algorithms/methods that are supported. The key agreement, hashes,\n * and MAC lists should be sorted in order of preference (most preferred\n * first).\n */\nconst KEY_AGREEMENT_LIST: KeyAgreement[] = [\"curve25519-hkdf-sha256\", \"curve25519\"];\nconst HASHES_LIST = [\"sha256\"];\nconst MAC_LIST: MacMethod[] = [\n \"hkdf-hmac-sha256.v2\",\n \"org.matrix.msc3783.hkdf-hmac-sha256\",\n \"hkdf-hmac-sha256\",\n \"hmac-sha256\",\n];\nconst SAS_LIST = Object.keys(sasGenerators);\n\nconst KEY_AGREEMENT_SET = new Set(KEY_AGREEMENT_LIST);\nconst HASHES_SET = new Set(HASHES_LIST);\nconst MAC_SET = new Set(MAC_LIST);\nconst SAS_SET = new Set(SAS_LIST);\n\nfunction intersection(anArray: T[], aSet: Set): T[] {\n return Array.isArray(anArray) ? anArray.filter((x) => aSet.has(x)) : [];\n}\n\nexport enum SasEvent {\n ShowSas = \"show_sas\",\n}\n\ntype EventHandlerMap = {\n [SasEvent.ShowSas]: (sas: ISasEvent) => void;\n} & VerificationEventHandlerMap;\n\nexport class SAS extends Base {\n private waitingForAccept?: boolean;\n public ourSASPubKey?: string;\n public theirSASPubKey?: string;\n public sasEvent?: ISasEvent;\n\n // eslint-disable-next-line @typescript-eslint/naming-convention\n public static get NAME(): string {\n return \"m.sas.v1\";\n }\n\n public get events(): string[] {\n return EVENTS;\n }\n\n protected doVerification = async (): Promise => {\n await global.Olm.init();\n olmutil = olmutil || new global.Olm.Utility();\n\n // make sure user's keys are downloaded\n await this.baseApis.downloadKeys([this.userId]);\n\n let retry = false;\n do {\n try {\n if (this.initiatedByMe) {\n return await this.doSendVerification();\n } else {\n return await this.doRespondVerification();\n }\n } catch (err) {\n if (err instanceof SwitchStartEventError) {\n // this changes what initiatedByMe returns\n this.startEvent = err.startEvent;\n retry = true;\n } else {\n throw err;\n }\n }\n } while (retry);\n };\n\n public canSwitchStartEvent(event: MatrixEvent): boolean {\n if (event.getType() !== START_TYPE) {\n return false;\n }\n const content = event.getContent();\n return content?.method === SAS.NAME && !!this.waitingForAccept;\n }\n\n private async sendStart(): Promise> {\n const startContent = this.channel.completeContent(START_TYPE, {\n method: SAS.NAME,\n from_device: this.baseApis.deviceId,\n key_agreement_protocols: KEY_AGREEMENT_LIST,\n hashes: HASHES_LIST,\n message_authentication_codes: MAC_LIST,\n // FIXME: allow app to specify what SAS methods can be used\n short_authentication_string: SAS_LIST,\n });\n await this.channel.sendCompleted(START_TYPE, startContent);\n return startContent;\n }\n\n private async verifyAndCheckMAC(\n keyAgreement: KeyAgreement,\n sasMethods: string[],\n olmSAS: OlmSAS,\n macMethod: MacMethod,\n ): Promise {\n const sasBytes = calculateKeyAgreement[keyAgreement](this, olmSAS, 6);\n const verifySAS = new Promise((resolve, reject) => {\n this.sasEvent = {\n sas: generateSas(sasBytes, sasMethods),\n confirm: async (): Promise => {\n try {\n await this.sendMAC(olmSAS, macMethod);\n resolve();\n } catch (err) {\n reject(err);\n }\n },\n cancel: () => reject(newUserCancelledError()),\n mismatch: () => reject(newMismatchedSASError()),\n };\n this.emit(SasEvent.ShowSas, this.sasEvent);\n });\n\n const [e] = await Promise.all([\n this.waitForEvent(EventType.KeyVerificationMac).then((e) => {\n // we don't expect any more messages from the other\n // party, and they may send a m.key.verification.done\n // when they're done on their end\n this.expectedEvent = EventType.KeyVerificationDone;\n return e;\n }),\n verifySAS,\n ]);\n const content = e.getContent();\n await this.checkMAC(olmSAS, content, macMethod);\n }\n\n private async doSendVerification(): Promise {\n this.waitingForAccept = true;\n let startContent;\n if (this.startEvent) {\n startContent = this.channel.completedContentFromEvent(this.startEvent);\n } else {\n startContent = await this.sendStart();\n }\n\n // we might have switched to a different start event,\n // but was we didn't call _waitForEvent there was no\n // call that could throw yet. So check manually that\n // we're still on the initiator side\n if (!this.initiatedByMe) {\n throw new SwitchStartEventError(this.startEvent);\n }\n\n let e: MatrixEvent;\n try {\n e = await this.waitForEvent(EventType.KeyVerificationAccept);\n } finally {\n this.waitingForAccept = false;\n }\n let content = e.getContent();\n const sasMethods = intersection(content.short_authentication_string, SAS_SET);\n if (\n !(\n KEY_AGREEMENT_SET.has(content.key_agreement_protocol) &&\n HASHES_SET.has(content.hash) &&\n MAC_SET.has(content.message_authentication_code) &&\n sasMethods.length\n )\n ) {\n throw newUnknownMethodError();\n }\n if (typeof content.commitment !== \"string\") {\n throw newInvalidMessageError();\n }\n const keyAgreement = content.key_agreement_protocol;\n const macMethod = content.message_authentication_code;\n const hashCommitment = content.commitment;\n const olmSAS = new global.Olm.SAS();\n try {\n this.ourSASPubKey = olmSAS.get_pubkey();\n await this.send(EventType.KeyVerificationKey, {\n key: this.ourSASPubKey,\n });\n\n e = await this.waitForEvent(EventType.KeyVerificationKey);\n // FIXME: make sure event is properly formed\n content = e.getContent();\n const commitmentStr = content.key + anotherjson.stringify(startContent);\n // TODO: use selected hash function (when we support multiple)\n if (olmutil.sha256(commitmentStr) !== hashCommitment) {\n throw newMismatchedCommitmentError();\n }\n this.theirSASPubKey = content.key;\n olmSAS.set_their_key(content.key);\n\n await this.verifyAndCheckMAC(keyAgreement, sasMethods, olmSAS, macMethod);\n } finally {\n olmSAS.free();\n }\n }\n\n private async doRespondVerification(): Promise {\n // as m.related_to is not included in the encrypted content in e2e rooms,\n // we need to make sure it is added\n let content = this.channel.completedContentFromEvent(this.startEvent!);\n\n // Note: we intersect using our pre-made lists, rather than the sets,\n // so that the result will be in our order of preference. Then\n // fetching the first element from the array will give our preferred\n // method out of the ones offered by the other party.\n const keyAgreement = intersection(KEY_AGREEMENT_LIST, new Set(content.key_agreement_protocols))[0];\n const hashMethod = intersection(HASHES_LIST, new Set(content.hashes))[0];\n const macMethod = intersection(MAC_LIST, new Set(content.message_authentication_codes))[0];\n // FIXME: allow app to specify what SAS methods can be used\n const sasMethods = intersection(content.short_authentication_string, SAS_SET);\n if (!(keyAgreement !== undefined && hashMethod !== undefined && macMethod !== undefined && sasMethods.length)) {\n throw newUnknownMethodError();\n }\n\n const olmSAS = new global.Olm.SAS();\n try {\n const commitmentStr = olmSAS.get_pubkey() + anotherjson.stringify(content);\n await this.send(EventType.KeyVerificationAccept, {\n key_agreement_protocol: keyAgreement,\n hash: hashMethod,\n message_authentication_code: macMethod,\n short_authentication_string: sasMethods,\n // TODO: use selected hash function (when we support multiple)\n commitment: olmutil.sha256(commitmentStr),\n });\n\n const e = await this.waitForEvent(EventType.KeyVerificationKey);\n // FIXME: make sure event is properly formed\n content = e.getContent();\n this.theirSASPubKey = content.key;\n olmSAS.set_their_key(content.key);\n this.ourSASPubKey = olmSAS.get_pubkey();\n await this.send(EventType.KeyVerificationKey, {\n key: this.ourSASPubKey,\n });\n\n await this.verifyAndCheckMAC(keyAgreement, sasMethods, olmSAS, macMethod);\n } finally {\n olmSAS.free();\n }\n }\n\n private sendMAC(olmSAS: OlmSAS, method: MacMethod): Promise {\n const mac: Record = {};\n const keyList: string[] = [];\n const baseInfo =\n \"MATRIX_KEY_VERIFICATION_MAC\" +\n this.baseApis.getUserId() +\n this.baseApis.deviceId +\n this.userId +\n this.deviceId +\n this.channel.transactionId;\n\n const deviceKeyId = `ed25519:${this.baseApis.deviceId}`;\n mac[deviceKeyId] = calculateMAC(olmSAS, method)(this.baseApis.getDeviceEd25519Key()!, baseInfo + deviceKeyId);\n keyList.push(deviceKeyId);\n\n const crossSigningId = this.baseApis.getCrossSigningId();\n if (crossSigningId) {\n const crossSigningKeyId = `ed25519:${crossSigningId}`;\n mac[crossSigningKeyId] = calculateMAC(olmSAS, method)(crossSigningId, baseInfo + crossSigningKeyId);\n keyList.push(crossSigningKeyId);\n }\n\n const keys = calculateMAC(olmSAS, method)(keyList.sort().join(\",\"), baseInfo + \"KEY_IDS\");\n return this.send(EventType.KeyVerificationMac, { mac, keys });\n }\n\n private async checkMAC(olmSAS: OlmSAS, content: IContent, method: MacMethod): Promise {\n const baseInfo =\n \"MATRIX_KEY_VERIFICATION_MAC\" +\n this.userId +\n this.deviceId +\n this.baseApis.getUserId() +\n this.baseApis.deviceId +\n this.channel.transactionId;\n\n if (\n content.keys !==\n calculateMAC(olmSAS, method)(Object.keys(content.mac).sort().join(\",\"), baseInfo + \"KEY_IDS\")\n ) {\n throw newKeyMismatchError();\n }\n\n await this.verifyKeys(this.userId, content.mac, (keyId, device, keyInfo) => {\n if (keyInfo !== calculateMAC(olmSAS, method)(device.keys[keyId], baseInfo + keyId)) {\n throw newKeyMismatchError();\n }\n });\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts deleted file mode 100644 index 673b56a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -/** - * Implementation of decimal encoding of SAS as per: - * https://spec.matrix.org/v1.4/client-server-api/#sas-method-decimal - * @param sasBytes - the five bytes generated by HKDF - * @returns the derived three numbers between 1000 and 9191 inclusive - */ -export declare function generateDecimalSas(sasBytes: number[]): [number, number, number]; -//# sourceMappingURL=SASDecimal.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts.map deleted file mode 100644 index bc7a0fa..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SASDecimal.d.ts","sourceRoot":"","sources":["../../../src/crypto/verification/SASDecimal.ts"],"names":[],"mappings":"AAgBA;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAc/E"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js deleted file mode 100644 index 5ed2ea7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js +++ /dev/null @@ -1,40 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.generateDecimalSas = generateDecimalSas; -/* -Copyright 2018 - 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Implementation of decimal encoding of SAS as per: - * https://spec.matrix.org/v1.4/client-server-api/#sas-method-decimal - * @param sasBytes - the five bytes generated by HKDF - * @returns the derived three numbers between 1000 and 9191 inclusive - */ -function generateDecimalSas(sasBytes) { - /* - * +--------+--------+--------+--------+--------+ - * | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 4 | - * +--------+--------+--------+--------+--------+ - * bits: 87654321 87654321 87654321 87654321 87654321 - * \____________/\_____________/\____________/ - * 1st number 2nd number 3rd number - */ - return [(sasBytes[0] << 5 | sasBytes[1] >> 3) + 1000, ((sasBytes[1] & 0x7) << 10 | sasBytes[2] << 2 | sasBytes[3] >> 6) + 1000, ((sasBytes[3] & 0x3f) << 7 | sasBytes[4] >> 1) + 1000]; -} -//# sourceMappingURL=SASDecimal.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js.map deleted file mode 100644 index 5138d2b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/SASDecimal.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SASDecimal.js","names":["generateDecimalSas","sasBytes"],"sources":["../../../src/crypto/verification/SASDecimal.ts"],"sourcesContent":["/*\nCopyright 2018 - 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Implementation of decimal encoding of SAS as per:\n * https://spec.matrix.org/v1.4/client-server-api/#sas-method-decimal\n * @param sasBytes - the five bytes generated by HKDF\n * @returns the derived three numbers between 1000 and 9191 inclusive\n */\nexport function generateDecimalSas(sasBytes: number[]): [number, number, number] {\n /*\n * +--------+--------+--------+--------+--------+\n * | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 4 |\n * +--------+--------+--------+--------+--------+\n * bits: 87654321 87654321 87654321 87654321 87654321\n * \\____________/\\_____________/\\____________/\n * 1st number 2nd number 3rd number\n */\n return [\n ((sasBytes[0] << 5) | (sasBytes[1] >> 3)) + 1000,\n (((sasBytes[1] & 0x7) << 10) | (sasBytes[2] << 2) | (sasBytes[3] >> 6)) + 1000,\n (((sasBytes[3] & 0x3f) << 7) | (sasBytes[4] >> 1)) + 1000,\n ];\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO,SAASA,kBAAkBA,CAACC,QAAkB,EAA4B;EAC7E;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;EACI,OAAO,CACH,CAAEA,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAKA,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAE,IAAI,IAAI,EAChD,CAAE,CAACA,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,KAAK,EAAE,GAAKA,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAE,GAAIA,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAE,IAAI,IAAI,EAC9E,CAAE,CAACA,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,GAAKA,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAE,IAAI,IAAI,CAC5D;AACL"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts deleted file mode 100644 index f9948e2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts +++ /dev/null @@ -1,18 +0,0 @@ -import { MatrixEvent } from "../../../models/event"; -import { VerificationRequest } from "./VerificationRequest"; -export interface IVerificationChannel { - request?: VerificationRequest; - readonly userId?: string; - readonly roomId?: string; - readonly deviceId?: string; - readonly transactionId?: string; - readonly receiveStartFromOtherDevices?: boolean; - getTimestamp(event: MatrixEvent): number; - send(type: string, uncompletedContent: Record): Promise; - completeContent(type: string, content: Record): Record; - sendCompleted(type: string, content: Record): Promise; - completedContentFromEvent(event: MatrixEvent): Record; - canCreateRequest(type: string): boolean; - handleEvent(event: MatrixEvent, request: VerificationRequest, isLiveEvent: boolean): Promise; -} -//# sourceMappingURL=Channel.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts.map deleted file mode 100644 index 9951a5f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Channel.d.ts","sourceRoot":"","sources":["../../../../src/crypto/verification/request/Channel.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,WAAW,oBAAoB;IACjC,OAAO,CAAC,EAAE,mBAAmB,CAAC;IAC9B,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC;IAChC,QAAQ,CAAC,4BAA4B,CAAC,EAAE,OAAO,CAAC;IAChD,YAAY,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM,CAAC;IACzC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3E,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACjF,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzE,yBAAyB,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACnE,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC;IACxC,WAAW,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACtG"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js deleted file mode 100644 index 93fbf04..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=Channel.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js.map deleted file mode 100644 index 9d7004f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/Channel.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Channel.js","names":[],"sources":["../../../../src/crypto/verification/request/Channel.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixEvent } from \"../../../models/event\";\nimport { VerificationRequest } from \"./VerificationRequest\";\n\nexport interface IVerificationChannel {\n request?: VerificationRequest;\n readonly userId?: string;\n readonly roomId?: string;\n readonly deviceId?: string;\n readonly transactionId?: string;\n readonly receiveStartFromOtherDevices?: boolean;\n getTimestamp(event: MatrixEvent): number;\n send(type: string, uncompletedContent: Record): Promise;\n completeContent(type: string, content: Record): Record;\n sendCompleted(type: string, content: Record): Promise;\n completedContentFromEvent(event: MatrixEvent): Record;\n canCreateRequest(type: string): boolean;\n handleEvent(event: MatrixEvent, request: VerificationRequest, isLiveEvent: boolean): Promise;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts deleted file mode 100644 index c646c90..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts +++ /dev/null @@ -1,113 +0,0 @@ -import { VerificationRequest } from "./VerificationRequest"; -import { IVerificationChannel } from "./Channel"; -import { MatrixClient } from "../../../client"; -import { MatrixEvent } from "../../../models/event"; -import { IRequestsMap } from "../.."; -/** - * A key verification channel that sends verification events in the timeline of a room. - * Uses the event id of the initial m.key.verification.request event as a transaction id. - */ -export declare class InRoomChannel implements IVerificationChannel { - private readonly client; - readonly roomId: string; - userId?: string | undefined; - private requestEventId?; - /** - * @param client - the matrix client, to send messages with and get current user & device from. - * @param roomId - id of the room where verification events should be posted in, should be a DM with the given user. - * @param userId - id of user that the verification request is directed at, should be present in the room. - */ - constructor(client: MatrixClient, roomId: string, userId?: string | undefined); - get receiveStartFromOtherDevices(): boolean; - /** The transaction id generated/used by this verification channel */ - get transactionId(): string | undefined; - static getOtherPartyUserId(event: MatrixEvent, client: MatrixClient): string | undefined; - /** - * @param event - the event to get the timestamp of - * @returns the timestamp when the event was sent - */ - getTimestamp(event: MatrixEvent): number; - /** - * Checks whether the given event type should be allowed to initiate a new VerificationRequest over this channel - * @param type - the event type to check - * @returns boolean flag - */ - static canCreateRequest(type: string): boolean; - canCreateRequest(type: string): boolean; - /** - * Extract the transaction id used by a given key verification event, if any - * @param event - the event - * @returns the transaction id - */ - static getTransactionId(event: MatrixEvent): string | undefined; - /** - * Checks whether this event is a well-formed key verification event. - * This only does checks that don't rely on the current state of a potentially already channel - * so we can prevent channels being created by invalid events. - * `handleEvent` can do more checks and choose to ignore invalid events. - * @param event - the event to validate - * @param client - the client to get the current user and device id from - * @returns whether the event is valid and should be passed to handleEvent - */ - static validateEvent(event: MatrixEvent, client: MatrixClient): boolean; - /** - * As m.key.verification.request events are as m.room.message events with the InRoomChannel - * to have a fallback message in non-supporting clients, we map the real event type - * to the symbolic one to keep things in unison with ToDeviceChannel - * @param event - the event to get the type of - * @returns the "symbolic" event type - */ - static getEventType(event: MatrixEvent): string; - /** - * Changes the state of the channel, request, and verifier in response to a key verification event. - * @param event - to handle - * @param request - the request to forward handling to - * @param isLiveEvent - whether this is an even received through sync or not - * @returns a promise that resolves when any requests as an answer to the passed-in event are sent. - */ - handleEvent(event: MatrixEvent, request: VerificationRequest, isLiveEvent?: boolean): Promise; - /** - * Adds the transaction id (relation) back to a received event - * so it has the same format as returned by `completeContent` before sending. - * The relation can not appear on the event content because of encryption, - * relations are excluded from encryption. - * @param event - the received event - * @returns the content object with the relation added again - */ - completedContentFromEvent(event: MatrixEvent): Record; - /** - * Add all the fields to content needed for sending it over this channel. - * This is public so verification methods (SAS uses this) can get the exact - * content that will be sent independent of the used channel, - * as they need to calculate the hash of it. - * @param type - the event type - * @param content - the (incomplete) content - * @returns the complete content, as it will be sent. - */ - completeContent(type: string, content: Record): Record; - /** - * Send an event over the channel with the content not having gone through `completeContent`. - * @param type - the event type - * @param uncompletedContent - the (incomplete) content - * @returns the promise of the request - */ - send(type: string, uncompletedContent: Record): Promise; - /** - * Send an event over the channel with the content having gone through `completeContent` already. - * @param type - the event type - * @returns the promise of the request - */ - sendCompleted(type: string, content: Record): Promise; -} -export declare class InRoomRequests implements IRequestsMap { - private requestsByRoomId; - getRequest(event: MatrixEvent): VerificationRequest | undefined; - getRequestByChannel(channel: InRoomChannel): VerificationRequest | undefined; - private getRequestByTxnId; - setRequest(event: MatrixEvent, request: VerificationRequest): void; - setRequestByChannel(channel: IVerificationChannel, request: VerificationRequest): void; - private doSetRequest; - removeRequest(event: MatrixEvent): void; - findRequestInProgress(roomId: string): VerificationRequest | undefined; -} -//# sourceMappingURL=InRoomChannel.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts.map deleted file mode 100644 index 05c308c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"InRoomChannel.d.ts","sourceRoot":"","sources":["../../../../src/crypto/verification/request/InRoomChannel.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,mBAAmB,EAAwC,MAAM,uBAAuB,CAAC;AAElG,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAEjD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAMrC;;;GAGG;AACH,qBAAa,aAAc,YAAW,oBAAoB;IAQnC,OAAO,CAAC,QAAQ,CAAC,MAAM;aAAgC,MAAM,EAAE,MAAM;IAAS,MAAM,CAAC;IAPxG,OAAO,CAAC,cAAc,CAAC,CAAS;IAEhC;;;;OAIG;gBACiC,MAAM,EAAE,YAAY,EAAkB,MAAM,EAAE,MAAM,EAAS,MAAM,CAAC,oBAAQ;IAEhH,IAAW,4BAA4B,IAAI,OAAO,CAEjD;IAED,qEAAqE;IACrE,IAAW,aAAa,IAAI,MAAM,GAAG,SAAS,CAE7C;WAEa,mBAAmB,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,GAAG,MAAM,GAAG,SAAS;IAiB/F;;;OAGG;IACI,YAAY,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM;IAI/C;;;;OAIG;WACW,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI9C,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI9C;;;;OAIG;WACW,gBAAgB,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM,GAAG,SAAS;IAWtE;;;;;;;;OAQG;WACW,aAAa,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,GAAG,OAAO;IA8B9E;;;;;;OAMG;WACW,YAAY,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM;IAkBtD;;;;;;OAMG;IACU,WAAW,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,UAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAuC9G;;;;;;;OAOG;IACI,yBAAyB,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAQzE;;;;;;;;OAQG;IACI,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IA4BvF;;;;;OAKG;IACI,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAKjF;;;;OAIG;IACU,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;CAUxF;AAED,qBAAa,cAAe,YAAW,YAAY;IAC/C,OAAO,CAAC,gBAAgB,CAAuD;IAExE,UAAU,CAAC,KAAK,EAAE,WAAW,GAAG,mBAAmB,GAAG,SAAS;IAM/D,mBAAmB,CAAC,OAAO,EAAE,aAAa,GAAG,mBAAmB,GAAG,SAAS;IAInF,OAAO,CAAC,iBAAiB;IAOlB,UAAU,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,mBAAmB,GAAG,IAAI;IAIlE,mBAAmB,CAAC,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,mBAAmB,GAAG,IAAI;IAI7F,OAAO,CAAC,YAAY;IASb,aAAa,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI;IAWvC,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,mBAAmB,GAAG,SAAS;CAUhF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js deleted file mode 100644 index 480e980..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js +++ /dev/null @@ -1,344 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.InRoomRequests = exports.InRoomChannel = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _VerificationRequest = require("./VerificationRequest"); -var _logger = require("../../../logger"); -var _event = require("../../../@types/event"); -/* -Copyright 2018 New Vector Ltd -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const MESSAGE_TYPE = _event.EventType.RoomMessage; -const M_REFERENCE = "m.reference"; -const M_RELATES_TO = "m.relates_to"; - -/** - * A key verification channel that sends verification events in the timeline of a room. - * Uses the event id of the initial m.key.verification.request event as a transaction id. - */ -class InRoomChannel { - /** - * @param client - the matrix client, to send messages with and get current user & device from. - * @param roomId - id of the room where verification events should be posted in, should be a DM with the given user. - * @param userId - id of user that the verification request is directed at, should be present in the room. - */ - constructor(client, roomId, userId) { - this.client = client; - this.roomId = roomId; - this.userId = userId; - (0, _defineProperty2.default)(this, "requestEventId", void 0); - } - get receiveStartFromOtherDevices() { - return true; - } - - /** The transaction id generated/used by this verification channel */ - get transactionId() { - return this.requestEventId; - } - static getOtherPartyUserId(event, client) { - const type = InRoomChannel.getEventType(event); - if (type !== _VerificationRequest.REQUEST_TYPE) { - return; - } - const ownUserId = client.getUserId(); - const sender = event.getSender(); - const content = event.getContent(); - const receiver = content.to; - if (sender === ownUserId) { - return receiver; - } else if (receiver === ownUserId) { - return sender; - } - } - - /** - * @param event - the event to get the timestamp of - * @returns the timestamp when the event was sent - */ - getTimestamp(event) { - return event.getTs(); - } - - /** - * Checks whether the given event type should be allowed to initiate a new VerificationRequest over this channel - * @param type - the event type to check - * @returns boolean flag - */ - static canCreateRequest(type) { - return type === _VerificationRequest.REQUEST_TYPE; - } - canCreateRequest(type) { - return InRoomChannel.canCreateRequest(type); - } - - /** - * Extract the transaction id used by a given key verification event, if any - * @param event - the event - * @returns the transaction id - */ - static getTransactionId(event) { - if (InRoomChannel.getEventType(event) === _VerificationRequest.REQUEST_TYPE) { - return event.getId(); - } else { - const relation = event.getRelation(); - if ((relation === null || relation === void 0 ? void 0 : relation.rel_type) === M_REFERENCE) { - return relation.event_id; - } - } - } - - /** - * Checks whether this event is a well-formed key verification event. - * This only does checks that don't rely on the current state of a potentially already channel - * so we can prevent channels being created by invalid events. - * `handleEvent` can do more checks and choose to ignore invalid events. - * @param event - the event to validate - * @param client - the client to get the current user and device id from - * @returns whether the event is valid and should be passed to handleEvent - */ - static validateEvent(event, client) { - const txnId = InRoomChannel.getTransactionId(event); - if (typeof txnId !== "string" || txnId.length === 0) { - return false; - } - const type = InRoomChannel.getEventType(event); - const content = event.getContent(); - - // from here on we're fairly sure that this is supposed to be - // part of a verification request, so be noisy when rejecting something - if (type === _VerificationRequest.REQUEST_TYPE) { - if (!content || typeof content.to !== "string" || !content.to.length) { - _logger.logger.log("InRoomChannel: validateEvent: " + "no valid to " + (content && content.to)); - return false; - } - - // ignore requests that are not direct to or sent by the syncing user - if (!InRoomChannel.getOtherPartyUserId(event, client)) { - _logger.logger.log("InRoomChannel: validateEvent: " + `not directed to or sent by me: ${event.getSender()}` + `, ${content && content.to}`); - return false; - } - } - return _VerificationRequest.VerificationRequest.validateEvent(type, event, client); - } - - /** - * As m.key.verification.request events are as m.room.message events with the InRoomChannel - * to have a fallback message in non-supporting clients, we map the real event type - * to the symbolic one to keep things in unison with ToDeviceChannel - * @param event - the event to get the type of - * @returns the "symbolic" event type - */ - static getEventType(event) { - const type = event.getType(); - if (type === MESSAGE_TYPE) { - const content = event.getContent(); - if (content) { - const { - msgtype - } = content; - if (msgtype === _VerificationRequest.REQUEST_TYPE) { - return _VerificationRequest.REQUEST_TYPE; - } - } - } - if (type && type !== _VerificationRequest.REQUEST_TYPE) { - return type; - } else { - return ""; - } - } - - /** - * Changes the state of the channel, request, and verifier in response to a key verification event. - * @param event - to handle - * @param request - the request to forward handling to - * @param isLiveEvent - whether this is an even received through sync or not - * @returns a promise that resolves when any requests as an answer to the passed-in event are sent. - */ - async handleEvent(event, request, isLiveEvent = false) { - // prevent processing the same event multiple times, as under - // some circumstances Room.timeline can get emitted twice for the same event - if (request.hasEventId(event.getId())) { - return; - } - const type = InRoomChannel.getEventType(event); - // do validations that need state (roomId, userId), - // ignore if invalid - - if (event.getRoomId() !== this.roomId) { - return; - } - // set userId if not set already - if (!this.userId) { - const userId = InRoomChannel.getOtherPartyUserId(event, this.client); - if (userId) { - this.userId = userId; - } - } - // ignore events not sent by us or the other party - const ownUserId = this.client.getUserId(); - const sender = event.getSender(); - if (this.userId) { - if (sender !== ownUserId && sender !== this.userId) { - _logger.logger.log(`InRoomChannel: ignoring verification event from non-participating sender ${sender}`); - return; - } - } - if (!this.requestEventId) { - this.requestEventId = InRoomChannel.getTransactionId(event); - } - const isRemoteEcho = !!event.getUnsigned().transaction_id; - const isSentByUs = event.getSender() === this.client.getUserId(); - return request.handleEvent(type, event, isLiveEvent, isRemoteEcho, isSentByUs); - } - - /** - * Adds the transaction id (relation) back to a received event - * so it has the same format as returned by `completeContent` before sending. - * The relation can not appear on the event content because of encryption, - * relations are excluded from encryption. - * @param event - the received event - * @returns the content object with the relation added again - */ - completedContentFromEvent(event) { - // ensure m.related_to is included in e2ee rooms - // as the field is excluded from encryption - const content = Object.assign({}, event.getContent()); - content[M_RELATES_TO] = event.getRelation(); - return content; - } - - /** - * Add all the fields to content needed for sending it over this channel. - * This is public so verification methods (SAS uses this) can get the exact - * content that will be sent independent of the used channel, - * as they need to calculate the hash of it. - * @param type - the event type - * @param content - the (incomplete) content - * @returns the complete content, as it will be sent. - */ - completeContent(type, content) { - content = Object.assign({}, content); - if (type === _VerificationRequest.REQUEST_TYPE || type === _VerificationRequest.READY_TYPE || type === _VerificationRequest.START_TYPE) { - content.from_device = this.client.getDeviceId(); - } - if (type === _VerificationRequest.REQUEST_TYPE) { - // type is mapped to m.room.message in the send method - content = { - body: this.client.getUserId() + " is requesting to verify " + "your key, but your client does not support in-chat key " + "verification. You will need to use legacy key " + "verification to verify keys.", - msgtype: _VerificationRequest.REQUEST_TYPE, - to: this.userId, - from_device: content.from_device, - methods: content.methods - }; - } else { - content[M_RELATES_TO] = { - rel_type: M_REFERENCE, - event_id: this.transactionId - }; - } - return content; - } - - /** - * Send an event over the channel with the content not having gone through `completeContent`. - * @param type - the event type - * @param uncompletedContent - the (incomplete) content - * @returns the promise of the request - */ - send(type, uncompletedContent) { - const content = this.completeContent(type, uncompletedContent); - return this.sendCompleted(type, content); - } - - /** - * Send an event over the channel with the content having gone through `completeContent` already. - * @param type - the event type - * @returns the promise of the request - */ - async sendCompleted(type, content) { - let sendType = type; - if (type === _VerificationRequest.REQUEST_TYPE) { - sendType = MESSAGE_TYPE; - } - const response = await this.client.sendEvent(this.roomId, sendType, content); - if (type === _VerificationRequest.REQUEST_TYPE) { - this.requestEventId = response.event_id; - } - } -} -exports.InRoomChannel = InRoomChannel; -class InRoomRequests { - constructor() { - (0, _defineProperty2.default)(this, "requestsByRoomId", new Map()); - } - getRequest(event) { - const roomId = event.getRoomId(); - const txnId = InRoomChannel.getTransactionId(event); - return this.getRequestByTxnId(roomId, txnId); - } - getRequestByChannel(channel) { - return this.getRequestByTxnId(channel.roomId, channel.transactionId); - } - getRequestByTxnId(roomId, txnId) { - const requestsByTxnId = this.requestsByRoomId.get(roomId); - if (requestsByTxnId) { - return requestsByTxnId.get(txnId); - } - } - setRequest(event, request) { - this.doSetRequest(event.getRoomId(), InRoomChannel.getTransactionId(event), request); - } - setRequestByChannel(channel, request) { - this.doSetRequest(channel.roomId, channel.transactionId, request); - } - doSetRequest(roomId, txnId, request) { - let requestsByTxnId = this.requestsByRoomId.get(roomId); - if (!requestsByTxnId) { - requestsByTxnId = new Map(); - this.requestsByRoomId.set(roomId, requestsByTxnId); - } - requestsByTxnId.set(txnId, request); - } - removeRequest(event) { - const roomId = event.getRoomId(); - const requestsByTxnId = this.requestsByRoomId.get(roomId); - if (requestsByTxnId) { - requestsByTxnId.delete(InRoomChannel.getTransactionId(event)); - if (requestsByTxnId.size === 0) { - this.requestsByRoomId.delete(roomId); - } - } - } - findRequestInProgress(roomId) { - const requestsByTxnId = this.requestsByRoomId.get(roomId); - if (requestsByTxnId) { - for (const request of requestsByTxnId.values()) { - if (request.pending) { - return request; - } - } - } - } -} -exports.InRoomRequests = InRoomRequests; -//# sourceMappingURL=InRoomChannel.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js.map deleted file mode 100644 index 5b61e18..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/InRoomChannel.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"InRoomChannel.js","names":["_VerificationRequest","require","_logger","_event","MESSAGE_TYPE","EventType","RoomMessage","M_REFERENCE","M_RELATES_TO","InRoomChannel","constructor","client","roomId","userId","_defineProperty2","default","receiveStartFromOtherDevices","transactionId","requestEventId","getOtherPartyUserId","event","type","getEventType","REQUEST_TYPE","ownUserId","getUserId","sender","getSender","content","getContent","receiver","to","getTimestamp","getTs","canCreateRequest","getTransactionId","getId","relation","getRelation","rel_type","event_id","validateEvent","txnId","length","logger","log","VerificationRequest","getType","msgtype","handleEvent","request","isLiveEvent","hasEventId","getRoomId","isRemoteEcho","getUnsigned","transaction_id","isSentByUs","completedContentFromEvent","Object","assign","completeContent","READY_TYPE","START_TYPE","from_device","getDeviceId","body","methods","send","uncompletedContent","sendCompleted","sendType","response","sendEvent","exports","InRoomRequests","Map","getRequest","getRequestByTxnId","getRequestByChannel","channel","requestsByTxnId","requestsByRoomId","get","setRequest","doSetRequest","setRequestByChannel","set","removeRequest","delete","size","findRequestInProgress","values","pending"],"sources":["../../../../src/crypto/verification/request/InRoomChannel.ts"],"sourcesContent":["/*\nCopyright 2018 New Vector Ltd\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { VerificationRequest, REQUEST_TYPE, READY_TYPE, START_TYPE } from \"./VerificationRequest\";\nimport { logger } from \"../../../logger\";\nimport { IVerificationChannel } from \"./Channel\";\nimport { EventType } from \"../../../@types/event\";\nimport { MatrixClient } from \"../../../client\";\nimport { MatrixEvent } from \"../../../models/event\";\nimport { IRequestsMap } from \"../..\";\n\nconst MESSAGE_TYPE = EventType.RoomMessage;\nconst M_REFERENCE = \"m.reference\";\nconst M_RELATES_TO = \"m.relates_to\";\n\n/**\n * A key verification channel that sends verification events in the timeline of a room.\n * Uses the event id of the initial m.key.verification.request event as a transaction id.\n */\nexport class InRoomChannel implements IVerificationChannel {\n private requestEventId?: string;\n\n /**\n * @param client - the matrix client, to send messages with and get current user & device from.\n * @param roomId - id of the room where verification events should be posted in, should be a DM with the given user.\n * @param userId - id of user that the verification request is directed at, should be present in the room.\n */\n public constructor(private readonly client: MatrixClient, public readonly roomId: string, public userId?: string) {}\n\n public get receiveStartFromOtherDevices(): boolean {\n return true;\n }\n\n /** The transaction id generated/used by this verification channel */\n public get transactionId(): string | undefined {\n return this.requestEventId;\n }\n\n public static getOtherPartyUserId(event: MatrixEvent, client: MatrixClient): string | undefined {\n const type = InRoomChannel.getEventType(event);\n if (type !== REQUEST_TYPE) {\n return;\n }\n const ownUserId = client.getUserId();\n const sender = event.getSender();\n const content = event.getContent();\n const receiver = content.to;\n\n if (sender === ownUserId) {\n return receiver;\n } else if (receiver === ownUserId) {\n return sender;\n }\n }\n\n /**\n * @param event - the event to get the timestamp of\n * @returns the timestamp when the event was sent\n */\n public getTimestamp(event: MatrixEvent): number {\n return event.getTs();\n }\n\n /**\n * Checks whether the given event type should be allowed to initiate a new VerificationRequest over this channel\n * @param type - the event type to check\n * @returns boolean flag\n */\n public static canCreateRequest(type: string): boolean {\n return type === REQUEST_TYPE;\n }\n\n public canCreateRequest(type: string): boolean {\n return InRoomChannel.canCreateRequest(type);\n }\n\n /**\n * Extract the transaction id used by a given key verification event, if any\n * @param event - the event\n * @returns the transaction id\n */\n public static getTransactionId(event: MatrixEvent): string | undefined {\n if (InRoomChannel.getEventType(event) === REQUEST_TYPE) {\n return event.getId();\n } else {\n const relation = event.getRelation();\n if (relation?.rel_type === M_REFERENCE) {\n return relation.event_id;\n }\n }\n }\n\n /**\n * Checks whether this event is a well-formed key verification event.\n * This only does checks that don't rely on the current state of a potentially already channel\n * so we can prevent channels being created by invalid events.\n * `handleEvent` can do more checks and choose to ignore invalid events.\n * @param event - the event to validate\n * @param client - the client to get the current user and device id from\n * @returns whether the event is valid and should be passed to handleEvent\n */\n public static validateEvent(event: MatrixEvent, client: MatrixClient): boolean {\n const txnId = InRoomChannel.getTransactionId(event);\n if (typeof txnId !== \"string\" || txnId.length === 0) {\n return false;\n }\n const type = InRoomChannel.getEventType(event);\n const content = event.getContent();\n\n // from here on we're fairly sure that this is supposed to be\n // part of a verification request, so be noisy when rejecting something\n if (type === REQUEST_TYPE) {\n if (!content || typeof content.to !== \"string\" || !content.to.length) {\n logger.log(\"InRoomChannel: validateEvent: \" + \"no valid to \" + (content && content.to));\n return false;\n }\n\n // ignore requests that are not direct to or sent by the syncing user\n if (!InRoomChannel.getOtherPartyUserId(event, client)) {\n logger.log(\n \"InRoomChannel: validateEvent: \" +\n `not directed to or sent by me: ${event.getSender()}` +\n `, ${content && content.to}`,\n );\n return false;\n }\n }\n\n return VerificationRequest.validateEvent(type, event, client);\n }\n\n /**\n * As m.key.verification.request events are as m.room.message events with the InRoomChannel\n * to have a fallback message in non-supporting clients, we map the real event type\n * to the symbolic one to keep things in unison with ToDeviceChannel\n * @param event - the event to get the type of\n * @returns the \"symbolic\" event type\n */\n public static getEventType(event: MatrixEvent): string {\n const type = event.getType();\n if (type === MESSAGE_TYPE) {\n const content = event.getContent();\n if (content) {\n const { msgtype } = content;\n if (msgtype === REQUEST_TYPE) {\n return REQUEST_TYPE;\n }\n }\n }\n if (type && type !== REQUEST_TYPE) {\n return type;\n } else {\n return \"\";\n }\n }\n\n /**\n * Changes the state of the channel, request, and verifier in response to a key verification event.\n * @param event - to handle\n * @param request - the request to forward handling to\n * @param isLiveEvent - whether this is an even received through sync or not\n * @returns a promise that resolves when any requests as an answer to the passed-in event are sent.\n */\n public async handleEvent(event: MatrixEvent, request: VerificationRequest, isLiveEvent = false): Promise {\n // prevent processing the same event multiple times, as under\n // some circumstances Room.timeline can get emitted twice for the same event\n if (request.hasEventId(event.getId()!)) {\n return;\n }\n const type = InRoomChannel.getEventType(event);\n // do validations that need state (roomId, userId),\n // ignore if invalid\n\n if (event.getRoomId() !== this.roomId) {\n return;\n }\n // set userId if not set already\n if (!this.userId) {\n const userId = InRoomChannel.getOtherPartyUserId(event, this.client);\n if (userId) {\n this.userId = userId;\n }\n }\n // ignore events not sent by us or the other party\n const ownUserId = this.client.getUserId();\n const sender = event.getSender();\n if (this.userId) {\n if (sender !== ownUserId && sender !== this.userId) {\n logger.log(`InRoomChannel: ignoring verification event from non-participating sender ${sender}`);\n return;\n }\n }\n if (!this.requestEventId) {\n this.requestEventId = InRoomChannel.getTransactionId(event);\n }\n\n const isRemoteEcho = !!event.getUnsigned().transaction_id;\n const isSentByUs = event.getSender() === this.client.getUserId();\n\n return request.handleEvent(type, event, isLiveEvent, isRemoteEcho, isSentByUs);\n }\n\n /**\n * Adds the transaction id (relation) back to a received event\n * so it has the same format as returned by `completeContent` before sending.\n * The relation can not appear on the event content because of encryption,\n * relations are excluded from encryption.\n * @param event - the received event\n * @returns the content object with the relation added again\n */\n public completedContentFromEvent(event: MatrixEvent): Record {\n // ensure m.related_to is included in e2ee rooms\n // as the field is excluded from encryption\n const content = Object.assign({}, event.getContent());\n content[M_RELATES_TO] = event.getRelation()!;\n return content;\n }\n\n /**\n * Add all the fields to content needed for sending it over this channel.\n * This is public so verification methods (SAS uses this) can get the exact\n * content that will be sent independent of the used channel,\n * as they need to calculate the hash of it.\n * @param type - the event type\n * @param content - the (incomplete) content\n * @returns the complete content, as it will be sent.\n */\n public completeContent(type: string, content: Record): Record {\n content = Object.assign({}, content);\n if (type === REQUEST_TYPE || type === READY_TYPE || type === START_TYPE) {\n content.from_device = this.client.getDeviceId();\n }\n if (type === REQUEST_TYPE) {\n // type is mapped to m.room.message in the send method\n content = {\n body:\n this.client.getUserId() +\n \" is requesting to verify \" +\n \"your key, but your client does not support in-chat key \" +\n \"verification. You will need to use legacy key \" +\n \"verification to verify keys.\",\n msgtype: REQUEST_TYPE,\n to: this.userId,\n from_device: content.from_device,\n methods: content.methods,\n };\n } else {\n content[M_RELATES_TO] = {\n rel_type: M_REFERENCE,\n event_id: this.transactionId,\n };\n }\n return content;\n }\n\n /**\n * Send an event over the channel with the content not having gone through `completeContent`.\n * @param type - the event type\n * @param uncompletedContent - the (incomplete) content\n * @returns the promise of the request\n */\n public send(type: string, uncompletedContent: Record): Promise {\n const content = this.completeContent(type, uncompletedContent);\n return this.sendCompleted(type, content);\n }\n\n /**\n * Send an event over the channel with the content having gone through `completeContent` already.\n * @param type - the event type\n * @returns the promise of the request\n */\n public async sendCompleted(type: string, content: Record): Promise {\n let sendType = type;\n if (type === REQUEST_TYPE) {\n sendType = MESSAGE_TYPE;\n }\n const response = await this.client.sendEvent(this.roomId, sendType, content);\n if (type === REQUEST_TYPE) {\n this.requestEventId = response.event_id;\n }\n }\n}\n\nexport class InRoomRequests implements IRequestsMap {\n private requestsByRoomId = new Map>();\n\n public getRequest(event: MatrixEvent): VerificationRequest | undefined {\n const roomId = event.getRoomId()!;\n const txnId = InRoomChannel.getTransactionId(event)!;\n return this.getRequestByTxnId(roomId, txnId);\n }\n\n public getRequestByChannel(channel: InRoomChannel): VerificationRequest | undefined {\n return this.getRequestByTxnId(channel.roomId, channel.transactionId!);\n }\n\n private getRequestByTxnId(roomId: string, txnId: string): VerificationRequest | undefined {\n const requestsByTxnId = this.requestsByRoomId.get(roomId);\n if (requestsByTxnId) {\n return requestsByTxnId.get(txnId);\n }\n }\n\n public setRequest(event: MatrixEvent, request: VerificationRequest): void {\n this.doSetRequest(event.getRoomId()!, InRoomChannel.getTransactionId(event)!, request);\n }\n\n public setRequestByChannel(channel: IVerificationChannel, request: VerificationRequest): void {\n this.doSetRequest(channel.roomId!, channel.transactionId!, request);\n }\n\n private doSetRequest(roomId: string, txnId: string, request: VerificationRequest): void {\n let requestsByTxnId = this.requestsByRoomId.get(roomId);\n if (!requestsByTxnId) {\n requestsByTxnId = new Map();\n this.requestsByRoomId.set(roomId, requestsByTxnId);\n }\n requestsByTxnId.set(txnId, request);\n }\n\n public removeRequest(event: MatrixEvent): void {\n const roomId = event.getRoomId()!;\n const requestsByTxnId = this.requestsByRoomId.get(roomId);\n if (requestsByTxnId) {\n requestsByTxnId.delete(InRoomChannel.getTransactionId(event)!);\n if (requestsByTxnId.size === 0) {\n this.requestsByRoomId.delete(roomId);\n }\n }\n }\n\n public findRequestInProgress(roomId: string): VerificationRequest | undefined {\n const requestsByTxnId = this.requestsByRoomId.get(roomId);\n if (requestsByTxnId) {\n for (const request of requestsByTxnId.values()) {\n if (request.pending) {\n return request;\n }\n }\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts deleted file mode 100644 index f7e97e8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts +++ /dev/null @@ -1,105 +0,0 @@ -import { VerificationRequest } from "./VerificationRequest"; -import { MatrixEvent } from "../../../models/event"; -import { IVerificationChannel } from "./Channel"; -import { MatrixClient } from "../../../client"; -import { IRequestsMap } from "../.."; -export type Request = VerificationRequest; -/** - * A key verification channel that sends verification events over to_device messages. - * Generates its own transaction ids. - */ -export declare class ToDeviceChannel implements IVerificationChannel { - private readonly client; - readonly userId: string; - private readonly devices; - transactionId?: string | undefined; - deviceId?: string | undefined; - request?: VerificationRequest; - constructor(client: MatrixClient, userId: string, devices: string[], transactionId?: string | undefined, deviceId?: string | undefined); - isToDevices(devices: string[]): boolean; - static getEventType(event: MatrixEvent): string; - /** - * Extract the transaction id used by a given key verification event, if any - * @param event - the event - * @returns the transaction id - */ - static getTransactionId(event: MatrixEvent): string; - /** - * Checks whether the given event type should be allowed to initiate a new VerificationRequest over this channel - * @param type - the event type to check - * @returns boolean flag - */ - static canCreateRequest(type: string): boolean; - canCreateRequest(type: string): boolean; - /** - * Checks whether this event is a well-formed key verification event. - * This only does checks that don't rely on the current state of a potentially already channel - * so we can prevent channels being created by invalid events. - * `handleEvent` can do more checks and choose to ignore invalid events. - * @param event - the event to validate - * @param client - the client to get the current user and device id from - * @returns whether the event is valid and should be passed to handleEvent - */ - static validateEvent(event: MatrixEvent, client: MatrixClient): boolean; - /** - * @param event - the event to get the timestamp of - * @returns the timestamp when the event was sent - */ - getTimestamp(event: MatrixEvent): number; - /** - * Changes the state of the channel, request, and verifier in response to a key verification event. - * @param event - to handle - * @param request - the request to forward handling to - * @param isLiveEvent - whether this is an even received through sync or not - * @returns a promise that resolves when any requests as an answer to the passed-in event are sent. - */ - handleEvent(event: MatrixEvent, request: Request, isLiveEvent?: boolean): Promise; - /** - * See {@link InRoomChannel#completedContentFromEvent} for why this is needed. - * @param event - the received event - * @returns the content object - */ - completedContentFromEvent(event: MatrixEvent): Record; - /** - * Add all the fields to content needed for sending it over this channel. - * This is public so verification methods (SAS uses this) can get the exact - * content that will be sent independent of the used channel, - * as they need to calculate the hash of it. - * @param type - the event type - * @param content - the (incomplete) content - * @returns the complete content, as it will be sent. - */ - completeContent(type: string, content: Record): Record; - /** - * Send an event over the channel with the content not having gone through `completeContent`. - * @param type - the event type - * @param uncompletedContent - the (incomplete) content - * @returns the promise of the request - */ - send(type: string, uncompletedContent?: Record): Promise; - /** - * Send an event over the channel with the content having gone through `completeContent` already. - * @param type - the event type - * @returns the promise of the request - */ - sendCompleted(type: string, content: Record): Promise; - private sendToDevices; - /** - * Allow Crypto module to create and know the transaction id before the .start event gets sent. - * @returns the transaction id - */ - static makeTransactionId(): string; -} -export declare class ToDeviceRequests implements IRequestsMap { - private requestsByUserId; - getRequest(event: MatrixEvent): Request | undefined; - getRequestByChannel(channel: ToDeviceChannel): Request | undefined; - getRequestBySenderAndTxnId(sender: string, txnId: string): Request | undefined; - setRequest(event: MatrixEvent, request: Request): void; - setRequestByChannel(channel: ToDeviceChannel, request: Request): void; - setRequestBySenderAndTxnId(sender: string, txnId: string, request: Request): void; - removeRequest(event: MatrixEvent): void; - findRequestInProgress(userId: string, devices: string[]): Request | undefined; - getRequestsInProgress(userId: string): Request[]; -} -//# sourceMappingURL=ToDeviceChannel.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts.map deleted file mode 100644 index f6a0de2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ToDeviceChannel.d.ts","sourceRoot":"","sources":["../../../../src/crypto/verification/request/ToDeviceChannel.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js deleted file mode 100644 index 3f6e48c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js +++ /dev/null @@ -1,324 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ToDeviceRequests = exports.ToDeviceChannel = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _randomstring = require("../../../randomstring"); -var _logger = require("../../../logger"); -var _VerificationRequest = require("./VerificationRequest"); -var _Error = require("../Error"); -var _event = require("../../../models/event"); -/* -Copyright 2018 New Vector Ltd -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * A key verification channel that sends verification events over to_device messages. - * Generates its own transaction ids. - */ -class ToDeviceChannel { - // userId and devices of user we're about to verify - constructor(client, userId, devices, transactionId, deviceId) { - this.client = client; - this.userId = userId; - this.devices = devices; - this.transactionId = transactionId; - this.deviceId = deviceId; - (0, _defineProperty2.default)(this, "request", void 0); - } - isToDevices(devices) { - if (devices.length === this.devices.length) { - for (const device of devices) { - if (!this.devices.includes(device)) { - return false; - } - } - return true; - } else { - return false; - } - } - static getEventType(event) { - return event.getType(); - } - - /** - * Extract the transaction id used by a given key verification event, if any - * @param event - the event - * @returns the transaction id - */ - static getTransactionId(event) { - const content = event.getContent(); - return content && content.transaction_id; - } - - /** - * Checks whether the given event type should be allowed to initiate a new VerificationRequest over this channel - * @param type - the event type to check - * @returns boolean flag - */ - static canCreateRequest(type) { - return type === _VerificationRequest.REQUEST_TYPE || type === _VerificationRequest.START_TYPE; - } - canCreateRequest(type) { - return ToDeviceChannel.canCreateRequest(type); - } - - /** - * Checks whether this event is a well-formed key verification event. - * This only does checks that don't rely on the current state of a potentially already channel - * so we can prevent channels being created by invalid events. - * `handleEvent` can do more checks and choose to ignore invalid events. - * @param event - the event to validate - * @param client - the client to get the current user and device id from - * @returns whether the event is valid and should be passed to handleEvent - */ - static validateEvent(event, client) { - if (event.isCancelled()) { - _logger.logger.warn("Ignoring flagged verification request from " + event.getSender()); - return false; - } - const content = event.getContent(); - if (!content) { - _logger.logger.warn("ToDeviceChannel.validateEvent: invalid: no content"); - return false; - } - if (!content.transaction_id) { - _logger.logger.warn("ToDeviceChannel.validateEvent: invalid: no transaction_id"); - return false; - } - const type = event.getType(); - if (type === _VerificationRequest.REQUEST_TYPE) { - if (!Number.isFinite(content.timestamp)) { - _logger.logger.warn("ToDeviceChannel.validateEvent: invalid: no timestamp"); - return false; - } - if (event.getSender() === client.getUserId() && content.from_device == client.getDeviceId()) { - // ignore requests from ourselves, because it doesn't make sense for a - // device to verify itself - _logger.logger.warn("ToDeviceChannel.validateEvent: invalid: from own device"); - return false; - } - } - return _VerificationRequest.VerificationRequest.validateEvent(type, event, client); - } - - /** - * @param event - the event to get the timestamp of - * @returns the timestamp when the event was sent - */ - getTimestamp(event) { - const content = event.getContent(); - return content && content.timestamp; - } - - /** - * Changes the state of the channel, request, and verifier in response to a key verification event. - * @param event - to handle - * @param request - the request to forward handling to - * @param isLiveEvent - whether this is an even received through sync or not - * @returns a promise that resolves when any requests as an answer to the passed-in event are sent. - */ - async handleEvent(event, request, isLiveEvent = false) { - const type = event.getType(); - const content = event.getContent(); - if (type === _VerificationRequest.REQUEST_TYPE || type === _VerificationRequest.READY_TYPE || type === _VerificationRequest.START_TYPE) { - if (!this.transactionId) { - this.transactionId = content.transaction_id; - } - const deviceId = content.from_device; - // adopt deviceId if not set before and valid - if (!this.deviceId && this.devices.includes(deviceId)) { - this.deviceId = deviceId; - } - // if no device id or different from adopted one, cancel with sender - if (!this.deviceId || this.deviceId !== deviceId) { - // also check that message came from the device we sent the request to earlier on - // and do send a cancel message to that device - // (but don't cancel the request for the device we should be talking to) - const cancelContent = this.completeContent(_VerificationRequest.CANCEL_TYPE, (0, _Error.errorFromEvent)((0, _Error.newUnexpectedMessageError)())); - return this.sendToDevices(_VerificationRequest.CANCEL_TYPE, cancelContent, [deviceId]); - } - } - const wasStarted = request.phase === _VerificationRequest.PHASE_STARTED || request.phase === _VerificationRequest.PHASE_READY; - await request.handleEvent(event.getType(), event, isLiveEvent, false, false); - const isStarted = request.phase === _VerificationRequest.PHASE_STARTED || request.phase === _VerificationRequest.PHASE_READY; - const isAcceptingEvent = type === _VerificationRequest.START_TYPE || type === _VerificationRequest.READY_TYPE; - // the request has picked a ready or start event, tell the other devices about it - if (isAcceptingEvent && !wasStarted && isStarted && this.deviceId) { - const nonChosenDevices = this.devices.filter(d => d !== this.deviceId && d !== this.client.getDeviceId()); - if (nonChosenDevices.length) { - const message = this.completeContent(_VerificationRequest.CANCEL_TYPE, { - code: "m.accepted", - reason: "Verification request accepted by another device" - }); - await this.sendToDevices(_VerificationRequest.CANCEL_TYPE, message, nonChosenDevices); - } - } - } - - /** - * See {@link InRoomChannel#completedContentFromEvent} for why this is needed. - * @param event - the received event - * @returns the content object - */ - completedContentFromEvent(event) { - return event.getContent(); - } - - /** - * Add all the fields to content needed for sending it over this channel. - * This is public so verification methods (SAS uses this) can get the exact - * content that will be sent independent of the used channel, - * as they need to calculate the hash of it. - * @param type - the event type - * @param content - the (incomplete) content - * @returns the complete content, as it will be sent. - */ - completeContent(type, content) { - // make a copy - content = Object.assign({}, content); - if (this.transactionId) { - content.transaction_id = this.transactionId; - } - if (type === _VerificationRequest.REQUEST_TYPE || type === _VerificationRequest.READY_TYPE || type === _VerificationRequest.START_TYPE) { - content.from_device = this.client.getDeviceId(); - } - if (type === _VerificationRequest.REQUEST_TYPE) { - content.timestamp = Date.now(); - } - return content; - } - - /** - * Send an event over the channel with the content not having gone through `completeContent`. - * @param type - the event type - * @param uncompletedContent - the (incomplete) content - * @returns the promise of the request - */ - send(type, uncompletedContent = {}) { - // create transaction id when sending request - if ((type === _VerificationRequest.REQUEST_TYPE || type === _VerificationRequest.START_TYPE) && !this.transactionId) { - this.transactionId = ToDeviceChannel.makeTransactionId(); - } - const content = this.completeContent(type, uncompletedContent); - return this.sendCompleted(type, content); - } - - /** - * Send an event over the channel with the content having gone through `completeContent` already. - * @param type - the event type - * @returns the promise of the request - */ - async sendCompleted(type, content) { - let result; - if (type === _VerificationRequest.REQUEST_TYPE || type === _VerificationRequest.CANCEL_TYPE && !this.deviceId) { - result = await this.sendToDevices(type, content, this.devices); - } else { - result = await this.sendToDevices(type, content, [this.deviceId]); - } - // the VerificationRequest state machine requires remote echos of the event - // the client sends itself, so we fake this for to_device messages - const remoteEchoEvent = new _event.MatrixEvent({ - sender: this.client.getUserId(), - content, - type - }); - await this.request.handleEvent(type, remoteEchoEvent, /*isLiveEvent=*/true, /*isRemoteEcho=*/true, /*isSentByUs=*/true); - return result; - } - async sendToDevices(type, content, devices) { - if (devices.length) { - const deviceMessages = new Map(); - for (const deviceId of devices) { - deviceMessages.set(deviceId, content); - } - await this.client.sendToDevice(type, new Map([[this.userId, deviceMessages]])); - } - } - - /** - * Allow Crypto module to create and know the transaction id before the .start event gets sent. - * @returns the transaction id - */ - static makeTransactionId() { - return (0, _randomstring.randomString)(32); - } -} -exports.ToDeviceChannel = ToDeviceChannel; -class ToDeviceRequests { - constructor() { - (0, _defineProperty2.default)(this, "requestsByUserId", new Map()); - } - getRequest(event) { - return this.getRequestBySenderAndTxnId(event.getSender(), ToDeviceChannel.getTransactionId(event)); - } - getRequestByChannel(channel) { - return this.getRequestBySenderAndTxnId(channel.userId, channel.transactionId); - } - getRequestBySenderAndTxnId(sender, txnId) { - const requestsByTxnId = this.requestsByUserId.get(sender); - if (requestsByTxnId) { - return requestsByTxnId.get(txnId); - } - } - setRequest(event, request) { - this.setRequestBySenderAndTxnId(event.getSender(), ToDeviceChannel.getTransactionId(event), request); - } - setRequestByChannel(channel, request) { - this.setRequestBySenderAndTxnId(channel.userId, channel.transactionId, request); - } - setRequestBySenderAndTxnId(sender, txnId, request) { - let requestsByTxnId = this.requestsByUserId.get(sender); - if (!requestsByTxnId) { - requestsByTxnId = new Map(); - this.requestsByUserId.set(sender, requestsByTxnId); - } - requestsByTxnId.set(txnId, request); - } - removeRequest(event) { - const userId = event.getSender(); - const requestsByTxnId = this.requestsByUserId.get(userId); - if (requestsByTxnId) { - requestsByTxnId.delete(ToDeviceChannel.getTransactionId(event)); - if (requestsByTxnId.size === 0) { - this.requestsByUserId.delete(userId); - } - } - } - findRequestInProgress(userId, devices) { - const requestsByTxnId = this.requestsByUserId.get(userId); - if (requestsByTxnId) { - for (const request of requestsByTxnId.values()) { - if (request.pending && request.channel.isToDevices(devices)) { - return request; - } - } - } - } - getRequestsInProgress(userId) { - const requestsByTxnId = this.requestsByUserId.get(userId); - if (requestsByTxnId) { - return Array.from(requestsByTxnId.values()).filter(r => r.pending); - } - return []; - } -} -exports.ToDeviceRequests = ToDeviceRequests; -//# sourceMappingURL=ToDeviceChannel.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js.map deleted file mode 100644 index 52bb286..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/ToDeviceChannel.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ToDeviceChannel.js","names":["_randomstring","require","_logger","_VerificationRequest","_Error","_event","ToDeviceChannel","constructor","client","userId","devices","transactionId","deviceId","_defineProperty2","default","isToDevices","length","device","includes","getEventType","event","getType","getTransactionId","content","getContent","transaction_id","canCreateRequest","type","REQUEST_TYPE","START_TYPE","validateEvent","isCancelled","logger","warn","getSender","Number","isFinite","timestamp","getUserId","from_device","getDeviceId","VerificationRequest","getTimestamp","handleEvent","request","isLiveEvent","READY_TYPE","cancelContent","completeContent","CANCEL_TYPE","errorFromEvent","newUnexpectedMessageError","sendToDevices","wasStarted","phase","PHASE_STARTED","PHASE_READY","isStarted","isAcceptingEvent","nonChosenDevices","filter","d","message","code","reason","completedContentFromEvent","Object","assign","Date","now","send","uncompletedContent","makeTransactionId","sendCompleted","result","remoteEchoEvent","MatrixEvent","sender","deviceMessages","Map","set","sendToDevice","randomString","exports","ToDeviceRequests","getRequest","getRequestBySenderAndTxnId","getRequestByChannel","channel","txnId","requestsByTxnId","requestsByUserId","get","setRequest","setRequestBySenderAndTxnId","setRequestByChannel","removeRequest","delete","size","findRequestInProgress","values","pending","getRequestsInProgress","Array","from","r"],"sources":["../../../../src/crypto/verification/request/ToDeviceChannel.ts"],"sourcesContent":["/*\nCopyright 2018 New Vector Ltd\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { randomString } from \"../../../randomstring\";\nimport { logger } from \"../../../logger\";\nimport {\n CANCEL_TYPE,\n PHASE_STARTED,\n PHASE_READY,\n REQUEST_TYPE,\n READY_TYPE,\n START_TYPE,\n VerificationRequest,\n} from \"./VerificationRequest\";\nimport { errorFromEvent, newUnexpectedMessageError } from \"../Error\";\nimport { MatrixEvent } from \"../../../models/event\";\nimport { IVerificationChannel } from \"./Channel\";\nimport { MatrixClient } from \"../../../client\";\nimport { IRequestsMap } from \"../..\";\n\nexport type Request = VerificationRequest;\n\n/**\n * A key verification channel that sends verification events over to_device messages.\n * Generates its own transaction ids.\n */\nexport class ToDeviceChannel implements IVerificationChannel {\n public request?: VerificationRequest;\n\n // userId and devices of user we're about to verify\n public constructor(\n private readonly client: MatrixClient,\n public readonly userId: string,\n private readonly devices: string[],\n public transactionId?: string,\n public deviceId?: string,\n ) {}\n\n public isToDevices(devices: string[]): boolean {\n if (devices.length === this.devices.length) {\n for (const device of devices) {\n if (!this.devices.includes(device)) {\n return false;\n }\n }\n return true;\n } else {\n return false;\n }\n }\n\n public static getEventType(event: MatrixEvent): string {\n return event.getType();\n }\n\n /**\n * Extract the transaction id used by a given key verification event, if any\n * @param event - the event\n * @returns the transaction id\n */\n public static getTransactionId(event: MatrixEvent): string {\n const content = event.getContent();\n return content && content.transaction_id;\n }\n\n /**\n * Checks whether the given event type should be allowed to initiate a new VerificationRequest over this channel\n * @param type - the event type to check\n * @returns boolean flag\n */\n public static canCreateRequest(type: string): boolean {\n return type === REQUEST_TYPE || type === START_TYPE;\n }\n\n public canCreateRequest(type: string): boolean {\n return ToDeviceChannel.canCreateRequest(type);\n }\n\n /**\n * Checks whether this event is a well-formed key verification event.\n * This only does checks that don't rely on the current state of a potentially already channel\n * so we can prevent channels being created by invalid events.\n * `handleEvent` can do more checks and choose to ignore invalid events.\n * @param event - the event to validate\n * @param client - the client to get the current user and device id from\n * @returns whether the event is valid and should be passed to handleEvent\n */\n public static validateEvent(event: MatrixEvent, client: MatrixClient): boolean {\n if (event.isCancelled()) {\n logger.warn(\"Ignoring flagged verification request from \" + event.getSender());\n return false;\n }\n const content = event.getContent();\n if (!content) {\n logger.warn(\"ToDeviceChannel.validateEvent: invalid: no content\");\n return false;\n }\n\n if (!content.transaction_id) {\n logger.warn(\"ToDeviceChannel.validateEvent: invalid: no transaction_id\");\n return false;\n }\n\n const type = event.getType();\n\n if (type === REQUEST_TYPE) {\n if (!Number.isFinite(content.timestamp)) {\n logger.warn(\"ToDeviceChannel.validateEvent: invalid: no timestamp\");\n return false;\n }\n if (event.getSender() === client.getUserId() && content.from_device == client.getDeviceId()) {\n // ignore requests from ourselves, because it doesn't make sense for a\n // device to verify itself\n logger.warn(\"ToDeviceChannel.validateEvent: invalid: from own device\");\n return false;\n }\n }\n\n return VerificationRequest.validateEvent(type, event, client);\n }\n\n /**\n * @param event - the event to get the timestamp of\n * @returns the timestamp when the event was sent\n */\n public getTimestamp(event: MatrixEvent): number {\n const content = event.getContent();\n return content && content.timestamp;\n }\n\n /**\n * Changes the state of the channel, request, and verifier in response to a key verification event.\n * @param event - to handle\n * @param request - the request to forward handling to\n * @param isLiveEvent - whether this is an even received through sync or not\n * @returns a promise that resolves when any requests as an answer to the passed-in event are sent.\n */\n public async handleEvent(event: MatrixEvent, request: Request, isLiveEvent = false): Promise {\n const type = event.getType();\n const content = event.getContent();\n if (type === REQUEST_TYPE || type === READY_TYPE || type === START_TYPE) {\n if (!this.transactionId) {\n this.transactionId = content.transaction_id;\n }\n const deviceId = content.from_device;\n // adopt deviceId if not set before and valid\n if (!this.deviceId && this.devices.includes(deviceId)) {\n this.deviceId = deviceId;\n }\n // if no device id or different from adopted one, cancel with sender\n if (!this.deviceId || this.deviceId !== deviceId) {\n // also check that message came from the device we sent the request to earlier on\n // and do send a cancel message to that device\n // (but don't cancel the request for the device we should be talking to)\n const cancelContent = this.completeContent(CANCEL_TYPE, errorFromEvent(newUnexpectedMessageError()));\n return this.sendToDevices(CANCEL_TYPE, cancelContent, [deviceId]);\n }\n }\n const wasStarted = request.phase === PHASE_STARTED || request.phase === PHASE_READY;\n\n await request.handleEvent(event.getType(), event, isLiveEvent, false, false);\n\n const isStarted = request.phase === PHASE_STARTED || request.phase === PHASE_READY;\n\n const isAcceptingEvent = type === START_TYPE || type === READY_TYPE;\n // the request has picked a ready or start event, tell the other devices about it\n if (isAcceptingEvent && !wasStarted && isStarted && this.deviceId) {\n const nonChosenDevices = this.devices.filter((d) => d !== this.deviceId && d !== this.client.getDeviceId());\n if (nonChosenDevices.length) {\n const message = this.completeContent(CANCEL_TYPE, {\n code: \"m.accepted\",\n reason: \"Verification request accepted by another device\",\n });\n await this.sendToDevices(CANCEL_TYPE, message, nonChosenDevices);\n }\n }\n }\n\n /**\n * See {@link InRoomChannel#completedContentFromEvent} for why this is needed.\n * @param event - the received event\n * @returns the content object\n */\n public completedContentFromEvent(event: MatrixEvent): Record {\n return event.getContent();\n }\n\n /**\n * Add all the fields to content needed for sending it over this channel.\n * This is public so verification methods (SAS uses this) can get the exact\n * content that will be sent independent of the used channel,\n * as they need to calculate the hash of it.\n * @param type - the event type\n * @param content - the (incomplete) content\n * @returns the complete content, as it will be sent.\n */\n public completeContent(type: string, content: Record): Record {\n // make a copy\n content = Object.assign({}, content);\n if (this.transactionId) {\n content.transaction_id = this.transactionId;\n }\n if (type === REQUEST_TYPE || type === READY_TYPE || type === START_TYPE) {\n content.from_device = this.client.getDeviceId();\n }\n if (type === REQUEST_TYPE) {\n content.timestamp = Date.now();\n }\n return content;\n }\n\n /**\n * Send an event over the channel with the content not having gone through `completeContent`.\n * @param type - the event type\n * @param uncompletedContent - the (incomplete) content\n * @returns the promise of the request\n */\n public send(type: string, uncompletedContent: Record = {}): Promise {\n // create transaction id when sending request\n if ((type === REQUEST_TYPE || type === START_TYPE) && !this.transactionId) {\n this.transactionId = ToDeviceChannel.makeTransactionId();\n }\n const content = this.completeContent(type, uncompletedContent);\n return this.sendCompleted(type, content);\n }\n\n /**\n * Send an event over the channel with the content having gone through `completeContent` already.\n * @param type - the event type\n * @returns the promise of the request\n */\n public async sendCompleted(type: string, content: Record): Promise {\n let result;\n if (type === REQUEST_TYPE || (type === CANCEL_TYPE && !this.deviceId)) {\n result = await this.sendToDevices(type, content, this.devices);\n } else {\n result = await this.sendToDevices(type, content, [this.deviceId!]);\n }\n // the VerificationRequest state machine requires remote echos of the event\n // the client sends itself, so we fake this for to_device messages\n const remoteEchoEvent = new MatrixEvent({\n sender: this.client.getUserId()!,\n content,\n type,\n });\n await this.request!.handleEvent(\n type,\n remoteEchoEvent,\n /*isLiveEvent=*/ true,\n /*isRemoteEcho=*/ true,\n /*isSentByUs=*/ true,\n );\n return result;\n }\n\n private async sendToDevices(type: string, content: Record, devices: string[]): Promise {\n if (devices.length) {\n const deviceMessages: Map> = new Map();\n for (const deviceId of devices) {\n deviceMessages.set(deviceId, content);\n }\n\n await this.client.sendToDevice(type, new Map([[this.userId, deviceMessages]]));\n }\n }\n\n /**\n * Allow Crypto module to create and know the transaction id before the .start event gets sent.\n * @returns the transaction id\n */\n public static makeTransactionId(): string {\n return randomString(32);\n }\n}\n\nexport class ToDeviceRequests implements IRequestsMap {\n private requestsByUserId = new Map>();\n\n public getRequest(event: MatrixEvent): Request | undefined {\n return this.getRequestBySenderAndTxnId(event.getSender()!, ToDeviceChannel.getTransactionId(event));\n }\n\n public getRequestByChannel(channel: ToDeviceChannel): Request | undefined {\n return this.getRequestBySenderAndTxnId(channel.userId, channel.transactionId!);\n }\n\n public getRequestBySenderAndTxnId(sender: string, txnId: string): Request | undefined {\n const requestsByTxnId = this.requestsByUserId.get(sender);\n if (requestsByTxnId) {\n return requestsByTxnId.get(txnId);\n }\n }\n\n public setRequest(event: MatrixEvent, request: Request): void {\n this.setRequestBySenderAndTxnId(event.getSender()!, ToDeviceChannel.getTransactionId(event), request);\n }\n\n public setRequestByChannel(channel: ToDeviceChannel, request: Request): void {\n this.setRequestBySenderAndTxnId(channel.userId, channel.transactionId!, request);\n }\n\n public setRequestBySenderAndTxnId(sender: string, txnId: string, request: Request): void {\n let requestsByTxnId = this.requestsByUserId.get(sender);\n if (!requestsByTxnId) {\n requestsByTxnId = new Map();\n this.requestsByUserId.set(sender, requestsByTxnId);\n }\n requestsByTxnId.set(txnId, request);\n }\n\n public removeRequest(event: MatrixEvent): void {\n const userId = event.getSender()!;\n const requestsByTxnId = this.requestsByUserId.get(userId);\n if (requestsByTxnId) {\n requestsByTxnId.delete(ToDeviceChannel.getTransactionId(event));\n if (requestsByTxnId.size === 0) {\n this.requestsByUserId.delete(userId);\n }\n }\n }\n\n public findRequestInProgress(userId: string, devices: string[]): Request | undefined {\n const requestsByTxnId = this.requestsByUserId.get(userId);\n if (requestsByTxnId) {\n for (const request of requestsByTxnId.values()) {\n if (request.pending && request.channel.isToDevices(devices)) {\n return request;\n }\n }\n }\n }\n\n public getRequestsInProgress(userId: string): Request[] {\n const requestsByTxnId = this.requestsByUserId.get(userId);\n if (requestsByTxnId) {\n return Array.from(requestsByTxnId.values()).filter((r) => r.pending);\n }\n return [];\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts deleted file mode 100644 index 8d16b31..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts +++ /dev/null @@ -1,208 +0,0 @@ -import { QRCodeData } from "../QRCode"; -import { IVerificationChannel } from "./Channel"; -import { MatrixClient } from "../../../client"; -import { MatrixEvent } from "../../../models/event"; -import { VerificationBase } from "../Base"; -import { VerificationMethod } from "../../index"; -import { TypedEventEmitter } from "../../../models/typed-event-emitter"; -export declare const EVENT_PREFIX = "m.key.verification."; -export declare const REQUEST_TYPE: string; -export declare const START_TYPE: string; -export declare const CANCEL_TYPE: string; -export declare const DONE_TYPE: string; -export declare const READY_TYPE: string; -export declare enum Phase { - Unsent = 1, - Requested = 2, - Ready = 3, - Started = 4, - Cancelled = 5, - Done = 6 -} -export declare const PHASE_UNSENT = Phase.Unsent; -export declare const PHASE_REQUESTED = Phase.Requested; -export declare const PHASE_READY = Phase.Ready; -export declare const PHASE_STARTED = Phase.Started; -export declare const PHASE_CANCELLED = Phase.Cancelled; -export declare const PHASE_DONE = Phase.Done; -interface ITargetDevice { - userId?: string; - deviceId?: string; -} -export declare enum VerificationRequestEvent { - Change = "change" -} -type EventHandlerMap = { - /** - * Fires whenever the state of the request object has changed. - */ - [VerificationRequestEvent.Change]: () => void; -}; -/** - * State machine for verification requests. - * Things that differ based on what channel is used to - * send and receive verification events are put in `InRoomChannel` or `ToDeviceChannel`. - */ -export declare class VerificationRequest extends TypedEventEmitter { - readonly channel: C; - private readonly verificationMethods; - private readonly client; - private eventsByUs; - private eventsByThem; - private _observeOnly; - private timeoutTimer; - private _accepting; - private _declining; - private verifierHasFinished; - private _cancelled; - private _chosenMethod; - private _qrCodeData; - private requestReceivedAt; - private commonMethods; - private _phase; - _cancellingUserId?: string; - private _verifier?; - constructor(channel: C, verificationMethods: Map, client: MatrixClient); - /** - * Stateless validation logic not specific to the channel. - * Invoked by the same static method in either channel. - * @param type - the "symbolic" event type, as returned by the `getEventType` function on the channel. - * @param event - the event to validate. Don't call getType() on it but use the `type` parameter instead. - * @param client - the client to get the current user and device id from - * @returns whether the event is valid and should be passed to handleEvent - */ - static validateEvent(type: string, event: MatrixEvent, client: MatrixClient): boolean; - get invalid(): boolean; - /** returns whether the phase is PHASE_REQUESTED */ - get requested(): boolean; - /** returns whether the phase is PHASE_CANCELLED */ - get cancelled(): boolean; - /** returns whether the phase is PHASE_READY */ - get ready(): boolean; - /** returns whether the phase is PHASE_STARTED */ - get started(): boolean; - /** returns whether the phase is PHASE_DONE */ - get done(): boolean; - /** once the phase is PHASE_STARTED (and !initiatedByMe) or PHASE_READY: common methods supported by both sides */ - get methods(): VerificationMethod[]; - /** the method picked in the .start event */ - get chosenMethod(): VerificationMethod | null; - calculateEventTimeout(event: MatrixEvent): number; - /** The current remaining amount of ms before the request should be automatically cancelled */ - get timeout(): number; - /** - * The key verification request event. - * @returns The request event, or falsey if not found. - */ - get requestEvent(): MatrixEvent | undefined; - /** current phase of the request. Some properties might only be defined in a current phase. */ - get phase(): Phase; - /** The verifier to do the actual verification, once the method has been established. Only defined when the `phase` is PHASE_STARTED. */ - get verifier(): VerificationBase | undefined; - get canAccept(): boolean; - get accepting(): boolean; - get declining(): boolean; - /** whether this request has sent it's initial event and needs more events to complete */ - get pending(): boolean; - /** Only set after a .ready if the other party can scan a QR code */ - get qrCodeData(): QRCodeData | null; - /** Checks whether the other party supports a given verification method. - * This is useful when setting up the QR code UI, as it is somewhat asymmetrical: - * if the other party supports SCAN_QR, we should show a QR code in the UI, and vice versa. - * For methods that need to be supported by both ends, use the `methods` property. - * @param method - the method to check - * @param force - to check even if the phase is not ready or started yet, internal usage - * @returns whether or not the other party said the supported the method */ - otherPartySupportsMethod(method: string, force?: boolean): boolean; - /** Whether this request was initiated by the syncing user. - * For InRoomChannel, this is who sent the .request event. - * For ToDeviceChannel, this is who sent the .start event - */ - get initiatedByMe(): boolean; - /** The id of the user that initiated the request */ - get requestingUserId(): string; - /** The id of the user that (will) receive(d) the request */ - get receivingUserId(): string; - /** The user id of the other party in this request */ - get otherUserId(): string; - get isSelfVerification(): boolean; - /** - * The id of the user that cancelled the request, - * only defined when phase is PHASE_CANCELLED - */ - get cancellingUserId(): string | undefined; - /** - * The cancellation code e.g m.user which is responsible for cancelling this verification - */ - get cancellationCode(): string; - get observeOnly(): boolean; - /** - * Gets which device the verification should be started with - * given the events sent so far in the verification. This is the - * same algorithm used to determine which device to send the - * verification to when no specific device is specified. - * @returns The device information - */ - get targetDevice(): ITargetDevice; - beginKeyVerification(method: VerificationMethod, targetDevice?: ITargetDevice | null): VerificationBase; - /** - * sends the initial .request event. - * @returns resolves when the event has been sent. - */ - sendRequest(): Promise; - /** - * Cancels the request, sending a cancellation to the other party - * @param reason - the error reason to send the cancellation with - * @param code - the error code to send the cancellation with - * @returns resolves when the event has been sent. - */ - cancel({ reason, code }?: { - reason?: string | undefined; - code?: string | undefined; - }): Promise; - /** - * Accepts the request, sending a .ready event to the other party - * @returns resolves when the event has been sent. - */ - accept(): Promise; - /** - * Can be used to listen for state changes until the callback returns true. - * @param fn - callback to evaluate whether the request is in the desired state. - * Takes the request as an argument. - * @returns that resolves once the callback returns true - * @throws Error when the request is cancelled - */ - waitFor(fn: (request: VerificationRequest) => boolean): Promise; - private setPhase; - private getEventByEither; - private getEventBy; - private calculatePhaseTransitions; - private transitionToPhase; - private applyPhaseTransitions; - private isWinningStartRace; - hasEventId(eventId: string): boolean; - /** - * Changes the state of the request and verifier in response to a key verification event. - * @param type - the "symbolic" event type, as returned by the `getEventType` function on the channel. - * @param event - the event to handle. Don't call getType() on it but use the `type` parameter instead. - * @param isLiveEvent - whether this is an even received through sync or not - * @param isRemoteEcho - whether this is the remote echo of an event sent by the same device - * @param isSentByUs - whether this event is sent by a party that can accept and/or observe the request like one of our peers. - * For InRoomChannel this means any device for the syncing user. For ToDeviceChannel, just the syncing device. - * @returns a promise that resolves when any requests as an answer to the passed-in event are sent. - */ - handleEvent(type: string, event: MatrixEvent, isLiveEvent: boolean, isRemoteEcho: boolean, isSentByUs: boolean): Promise; - private setupTimeout; - private cancelOnTimeout; - private cancelOnError; - private adjustObserveOnly; - private addEvent; - private createVerifier; - private wasSentByOwnUser; - private wasSentByOwnDevice; - onVerifierCancelled(): void; - onVerifierFinished(): void; - getEventFromOtherParty(type: string): MatrixEvent | undefined; -} -export {}; -//# sourceMappingURL=VerificationRequest.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts.map deleted file mode 100644 index 37ca935..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"VerificationRequest.d.ts","sourceRoot":"","sources":["../../../../src/crypto/verification/request/VerificationRequest.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js deleted file mode 100644 index f6e4dc0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js +++ /dev/null @@ -1,876 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.VerificationRequestEvent = exports.VerificationRequest = exports.START_TYPE = exports.REQUEST_TYPE = exports.READY_TYPE = exports.Phase = exports.PHASE_UNSENT = exports.PHASE_STARTED = exports.PHASE_REQUESTED = exports.PHASE_READY = exports.PHASE_DONE = exports.PHASE_CANCELLED = exports.EVENT_PREFIX = exports.DONE_TYPE = exports.CANCEL_TYPE = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../../../logger"); -var _Error = require("../Error"); -var _QRCode = require("../QRCode"); -var _event = require("../../../@types/event"); -var _typedEventEmitter = require("../../../models/typed-event-emitter"); -/* -Copyright 2018 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// How long after the event's timestamp that the request times out -const TIMEOUT_FROM_EVENT_TS = 10 * 60 * 1000; // 10 minutes - -// How long after we receive the event that the request times out -const TIMEOUT_FROM_EVENT_RECEIPT = 2 * 60 * 1000; // 2 minutes - -// to avoid almost expired verification notifications -// from showing a notification and almost immediately -// disappearing, also ignore verification requests that -// are this amount of time away from expiring. -const VERIFICATION_REQUEST_MARGIN = 3 * 1000; // 3 seconds - -const EVENT_PREFIX = "m.key.verification."; -exports.EVENT_PREFIX = EVENT_PREFIX; -const REQUEST_TYPE = EVENT_PREFIX + "request"; -exports.REQUEST_TYPE = REQUEST_TYPE; -const START_TYPE = EVENT_PREFIX + "start"; -exports.START_TYPE = START_TYPE; -const CANCEL_TYPE = EVENT_PREFIX + "cancel"; -exports.CANCEL_TYPE = CANCEL_TYPE; -const DONE_TYPE = EVENT_PREFIX + "done"; -exports.DONE_TYPE = DONE_TYPE; -const READY_TYPE = EVENT_PREFIX + "ready"; -exports.READY_TYPE = READY_TYPE; -let Phase; // Legacy export fields -exports.Phase = Phase; -(function (Phase) { - Phase[Phase["Unsent"] = 1] = "Unsent"; - Phase[Phase["Requested"] = 2] = "Requested"; - Phase[Phase["Ready"] = 3] = "Ready"; - Phase[Phase["Started"] = 4] = "Started"; - Phase[Phase["Cancelled"] = 5] = "Cancelled"; - Phase[Phase["Done"] = 6] = "Done"; -})(Phase || (exports.Phase = Phase = {})); -const PHASE_UNSENT = Phase.Unsent; -exports.PHASE_UNSENT = PHASE_UNSENT; -const PHASE_REQUESTED = Phase.Requested; -exports.PHASE_REQUESTED = PHASE_REQUESTED; -const PHASE_READY = Phase.Ready; -exports.PHASE_READY = PHASE_READY; -const PHASE_STARTED = Phase.Started; -exports.PHASE_STARTED = PHASE_STARTED; -const PHASE_CANCELLED = Phase.Cancelled; -exports.PHASE_CANCELLED = PHASE_CANCELLED; -const PHASE_DONE = Phase.Done; -exports.PHASE_DONE = PHASE_DONE; -let VerificationRequestEvent; -exports.VerificationRequestEvent = VerificationRequestEvent; -(function (VerificationRequestEvent) { - VerificationRequestEvent["Change"] = "change"; -})(VerificationRequestEvent || (exports.VerificationRequestEvent = VerificationRequestEvent = {})); -/** - * State machine for verification requests. - * Things that differ based on what channel is used to - * send and receive verification events are put in `InRoomChannel` or `ToDeviceChannel`. - */ -class VerificationRequest extends _typedEventEmitter.TypedEventEmitter { - // we keep a copy of the QR Code data (including other user master key) around - // for QR reciprocate verification, to protect against - // cross-signing identity reset between the .ready and .start event - // and signing the wrong key after .start - - // The timestamp when we received the request event from the other side - - // Used in tests only - - constructor(channel, verificationMethods, client) { - super(); - this.channel = channel; - this.verificationMethods = verificationMethods; - this.client = client; - (0, _defineProperty2.default)(this, "eventsByUs", new Map()); - (0, _defineProperty2.default)(this, "eventsByThem", new Map()); - (0, _defineProperty2.default)(this, "_observeOnly", false); - (0, _defineProperty2.default)(this, "timeoutTimer", null); - (0, _defineProperty2.default)(this, "_accepting", false); - (0, _defineProperty2.default)(this, "_declining", false); - (0, _defineProperty2.default)(this, "verifierHasFinished", false); - (0, _defineProperty2.default)(this, "_cancelled", false); - (0, _defineProperty2.default)(this, "_chosenMethod", null); - (0, _defineProperty2.default)(this, "_qrCodeData", null); - (0, _defineProperty2.default)(this, "requestReceivedAt", null); - (0, _defineProperty2.default)(this, "commonMethods", []); - (0, _defineProperty2.default)(this, "_phase", void 0); - (0, _defineProperty2.default)(this, "_cancellingUserId", void 0); - (0, _defineProperty2.default)(this, "_verifier", void 0); - (0, _defineProperty2.default)(this, "cancelOnTimeout", async () => { - try { - if (this.initiatedByMe) { - await this.cancel({ - reason: "Other party didn't accept in time", - code: "m.timeout" - }); - } else { - await this.cancel({ - reason: "User didn't accept in time", - code: "m.timeout" - }); - } - } catch (err) { - _logger.logger.error("Error while cancelling verification request", err); - } - }); - this.channel.request = this; - this.setPhase(PHASE_UNSENT, false); - } - - /** - * Stateless validation logic not specific to the channel. - * Invoked by the same static method in either channel. - * @param type - the "symbolic" event type, as returned by the `getEventType` function on the channel. - * @param event - the event to validate. Don't call getType() on it but use the `type` parameter instead. - * @param client - the client to get the current user and device id from - * @returns whether the event is valid and should be passed to handleEvent - */ - static validateEvent(type, event, client) { - const content = event.getContent(); - if (!type || !type.startsWith(EVENT_PREFIX)) { - return false; - } - - // from here on we're fairly sure that this is supposed to be - // part of a verification request, so be noisy when rejecting something - if (!content) { - _logger.logger.log("VerificationRequest: validateEvent: no content"); - return false; - } - if (type === REQUEST_TYPE || type === READY_TYPE) { - if (!Array.isArray(content.methods)) { - _logger.logger.log("VerificationRequest: validateEvent: " + "fail because methods"); - return false; - } - } - if (type === REQUEST_TYPE || type === READY_TYPE || type === START_TYPE) { - if (typeof content.from_device !== "string" || content.from_device.length === 0) { - _logger.logger.log("VerificationRequest: validateEvent: " + "fail because from_device"); - return false; - } - } - return true; - } - get invalid() { - return this.phase === PHASE_UNSENT; - } - - /** returns whether the phase is PHASE_REQUESTED */ - get requested() { - return this.phase === PHASE_REQUESTED; - } - - /** returns whether the phase is PHASE_CANCELLED */ - get cancelled() { - return this.phase === PHASE_CANCELLED; - } - - /** returns whether the phase is PHASE_READY */ - get ready() { - return this.phase === PHASE_READY; - } - - /** returns whether the phase is PHASE_STARTED */ - get started() { - return this.phase === PHASE_STARTED; - } - - /** returns whether the phase is PHASE_DONE */ - get done() { - return this.phase === PHASE_DONE; - } - - /** once the phase is PHASE_STARTED (and !initiatedByMe) or PHASE_READY: common methods supported by both sides */ - get methods() { - return this.commonMethods; - } - - /** the method picked in the .start event */ - get chosenMethod() { - return this._chosenMethod; - } - calculateEventTimeout(event) { - let effectiveExpiresAt = this.channel.getTimestamp(event) + TIMEOUT_FROM_EVENT_TS; - if (this.requestReceivedAt && !this.initiatedByMe && this.phase <= PHASE_REQUESTED) { - const expiresAtByReceipt = this.requestReceivedAt + TIMEOUT_FROM_EVENT_RECEIPT; - effectiveExpiresAt = Math.min(effectiveExpiresAt, expiresAtByReceipt); - } - return Math.max(0, effectiveExpiresAt - Date.now()); - } - - /** The current remaining amount of ms before the request should be automatically cancelled */ - get timeout() { - const requestEvent = this.getEventByEither(REQUEST_TYPE); - if (requestEvent) { - return this.calculateEventTimeout(requestEvent); - } - return 0; - } - - /** - * The key verification request event. - * @returns The request event, or falsey if not found. - */ - get requestEvent() { - return this.getEventByEither(REQUEST_TYPE); - } - - /** current phase of the request. Some properties might only be defined in a current phase. */ - get phase() { - return this._phase; - } - - /** The verifier to do the actual verification, once the method has been established. Only defined when the `phase` is PHASE_STARTED. */ - get verifier() { - return this._verifier; - } - get canAccept() { - return this.phase < PHASE_READY && !this._accepting && !this._declining; - } - get accepting() { - return this._accepting; - } - get declining() { - return this._declining; - } - - /** whether this request has sent it's initial event and needs more events to complete */ - get pending() { - return !this.observeOnly && this._phase !== PHASE_DONE && this._phase !== PHASE_CANCELLED; - } - - /** Only set after a .ready if the other party can scan a QR code */ - get qrCodeData() { - return this._qrCodeData; - } - - /** Checks whether the other party supports a given verification method. - * This is useful when setting up the QR code UI, as it is somewhat asymmetrical: - * if the other party supports SCAN_QR, we should show a QR code in the UI, and vice versa. - * For methods that need to be supported by both ends, use the `methods` property. - * @param method - the method to check - * @param force - to check even if the phase is not ready or started yet, internal usage - * @returns whether or not the other party said the supported the method */ - otherPartySupportsMethod(method, force = false) { - if (!force && !this.ready && !this.started) { - return false; - } - const theirMethodEvent = this.eventsByThem.get(REQUEST_TYPE) || this.eventsByThem.get(READY_TYPE); - if (!theirMethodEvent) { - // if we started straight away with .start event, - // we are assuming that the other side will support the - // chosen method, so return true for that. - if (this.started && this.initiatedByMe) { - const myStartEvent = this.eventsByUs.get(START_TYPE); - const content = myStartEvent && myStartEvent.getContent(); - const myStartMethod = content && content.method; - return method == myStartMethod; - } - return false; - } - const content = theirMethodEvent.getContent(); - if (!content) { - return false; - } - const { - methods - } = content; - if (!Array.isArray(methods)) { - return false; - } - return methods.includes(method); - } - - /** Whether this request was initiated by the syncing user. - * For InRoomChannel, this is who sent the .request event. - * For ToDeviceChannel, this is who sent the .start event - */ - get initiatedByMe() { - // event created by us but no remote echo has been received yet - const noEventsYet = this.eventsByUs.size + this.eventsByThem.size === 0; - if (this._phase === PHASE_UNSENT && noEventsYet) { - return true; - } - const hasMyRequest = this.eventsByUs.has(REQUEST_TYPE); - const hasTheirRequest = this.eventsByThem.has(REQUEST_TYPE); - if (hasMyRequest && !hasTheirRequest) { - return true; - } - if (!hasMyRequest && hasTheirRequest) { - return false; - } - const hasMyStart = this.eventsByUs.has(START_TYPE); - const hasTheirStart = this.eventsByThem.has(START_TYPE); - if (hasMyStart && !hasTheirStart) { - return true; - } - return false; - } - - /** The id of the user that initiated the request */ - get requestingUserId() { - if (this.initiatedByMe) { - return this.client.getUserId(); - } else { - return this.otherUserId; - } - } - - /** The id of the user that (will) receive(d) the request */ - get receivingUserId() { - if (this.initiatedByMe) { - return this.otherUserId; - } else { - return this.client.getUserId(); - } - } - - /** The user id of the other party in this request */ - get otherUserId() { - return this.channel.userId; - } - get isSelfVerification() { - return this.client.getUserId() === this.otherUserId; - } - - /** - * The id of the user that cancelled the request, - * only defined when phase is PHASE_CANCELLED - */ - get cancellingUserId() { - const myCancel = this.eventsByUs.get(CANCEL_TYPE); - const theirCancel = this.eventsByThem.get(CANCEL_TYPE); - if (myCancel && (!theirCancel || myCancel.getId() < theirCancel.getId())) { - return myCancel.getSender(); - } - if (theirCancel) { - return theirCancel.getSender(); - } - return undefined; - } - - /** - * The cancellation code e.g m.user which is responsible for cancelling this verification - */ - get cancellationCode() { - const ev = this.getEventByEither(CANCEL_TYPE); - return ev ? ev.getContent().code : null; - } - get observeOnly() { - return this._observeOnly; - } - - /** - * Gets which device the verification should be started with - * given the events sent so far in the verification. This is the - * same algorithm used to determine which device to send the - * verification to when no specific device is specified. - * @returns The device information - */ - get targetDevice() { - const theirFirstEvent = this.eventsByThem.get(REQUEST_TYPE) || this.eventsByThem.get(READY_TYPE) || this.eventsByThem.get(START_TYPE); - const theirFirstContent = theirFirstEvent === null || theirFirstEvent === void 0 ? void 0 : theirFirstEvent.getContent(); - const fromDevice = theirFirstContent === null || theirFirstContent === void 0 ? void 0 : theirFirstContent.from_device; - return { - userId: this.otherUserId, - deviceId: fromDevice - }; - } - - /* Start the key verification, creating a verifier and sending a .start event. - * If no previous events have been sent, pass in `targetDevice` to set who to direct this request to. - * @param method - the name of the verification method to use. - * @param targetDevice.userId the id of the user to direct this request to - * @param targetDevice.deviceId the id of the device to direct this request to - * @returns the verifier of the given method - */ - beginKeyVerification(method, targetDevice = null) { - // need to allow also when unsent in case of to_device - if (!this.observeOnly && !this._verifier) { - const validStartPhase = this.phase === PHASE_REQUESTED || this.phase === PHASE_READY || this.phase === PHASE_UNSENT && this.channel.canCreateRequest(START_TYPE); - if (validStartPhase) { - // when called on a request that was initiated with .request event - // check the method is supported by both sides - if (this.commonMethods.length && !this.commonMethods.includes(method)) { - throw (0, _Error.newUnknownMethodError)(); - } - this._verifier = this.createVerifier(method, null, targetDevice); - if (!this._verifier) { - throw (0, _Error.newUnknownMethodError)(); - } - this._chosenMethod = method; - } - } - return this._verifier; - } - - /** - * sends the initial .request event. - * @returns resolves when the event has been sent. - */ - async sendRequest() { - if (!this.observeOnly && this._phase === PHASE_UNSENT) { - const methods = [...this.verificationMethods.keys()]; - await this.channel.send(REQUEST_TYPE, { - methods - }); - } - } - - /** - * Cancels the request, sending a cancellation to the other party - * @param reason - the error reason to send the cancellation with - * @param code - the error code to send the cancellation with - * @returns resolves when the event has been sent. - */ - async cancel({ - reason = "User declined", - code = "m.user" - } = {}) { - if (!this.observeOnly && this._phase !== PHASE_CANCELLED) { - this._declining = true; - this.emit(VerificationRequestEvent.Change); - if (this._verifier) { - return this._verifier.cancel((0, _Error.errorFactory)(code, reason)()); - } else { - this._cancellingUserId = this.client.getUserId(); - await this.channel.send(CANCEL_TYPE, { - code, - reason - }); - } - } - } - - /** - * Accepts the request, sending a .ready event to the other party - * @returns resolves when the event has been sent. - */ - async accept() { - if (!this.observeOnly && this.phase === PHASE_REQUESTED && !this.initiatedByMe) { - const methods = [...this.verificationMethods.keys()]; - this._accepting = true; - this.emit(VerificationRequestEvent.Change); - await this.channel.send(READY_TYPE, { - methods - }); - } - } - - /** - * Can be used to listen for state changes until the callback returns true. - * @param fn - callback to evaluate whether the request is in the desired state. - * Takes the request as an argument. - * @returns that resolves once the callback returns true - * @throws Error when the request is cancelled - */ - waitFor(fn) { - return new Promise((resolve, reject) => { - const check = () => { - let handled = false; - if (fn(this)) { - resolve(this); - handled = true; - } else if (this.cancelled) { - reject(new Error("cancelled")); - handled = true; - } - if (handled) { - this.off(VerificationRequestEvent.Change, check); - } - return handled; - }; - if (!check()) { - this.on(VerificationRequestEvent.Change, check); - } - }); - } - setPhase(phase, notify = true) { - this._phase = phase; - if (notify) { - this.emit(VerificationRequestEvent.Change); - } - } - getEventByEither(type) { - return this.eventsByThem.get(type) || this.eventsByUs.get(type); - } - getEventBy(type, byThem = false) { - if (byThem) { - return this.eventsByThem.get(type); - } else { - return this.eventsByUs.get(type); - } - } - calculatePhaseTransitions() { - const transitions = [{ - phase: PHASE_UNSENT - }]; - const phase = () => transitions[transitions.length - 1].phase; - - // always pass by .request first to be sure channel.userId has been set - const hasRequestByThem = this.eventsByThem.has(REQUEST_TYPE); - const requestEvent = this.getEventBy(REQUEST_TYPE, hasRequestByThem); - if (requestEvent) { - transitions.push({ - phase: PHASE_REQUESTED, - event: requestEvent - }); - } - const readyEvent = requestEvent && this.getEventBy(READY_TYPE, !hasRequestByThem); - if (readyEvent && phase() === PHASE_REQUESTED) { - transitions.push({ - phase: PHASE_READY, - event: readyEvent - }); - } - let startEvent; - if (readyEvent || !requestEvent) { - const theirStartEvent = this.eventsByThem.get(START_TYPE); - const ourStartEvent = this.eventsByUs.get(START_TYPE); - // any party can send .start after a .ready or unsent - if (theirStartEvent && ourStartEvent) { - startEvent = theirStartEvent.getSender() < ourStartEvent.getSender() ? theirStartEvent : ourStartEvent; - } else { - startEvent = theirStartEvent ? theirStartEvent : ourStartEvent; - } - } else { - startEvent = this.getEventBy(START_TYPE, !hasRequestByThem); - } - if (startEvent) { - const fromRequestPhase = phase() === PHASE_REQUESTED && (requestEvent === null || requestEvent === void 0 ? void 0 : requestEvent.getSender()) !== startEvent.getSender(); - const fromUnsentPhase = phase() === PHASE_UNSENT && this.channel.canCreateRequest(START_TYPE); - if (fromRequestPhase || phase() === PHASE_READY || fromUnsentPhase) { - transitions.push({ - phase: PHASE_STARTED, - event: startEvent - }); - } - } - const ourDoneEvent = this.eventsByUs.get(DONE_TYPE); - if (this.verifierHasFinished || ourDoneEvent && phase() === PHASE_STARTED) { - transitions.push({ - phase: PHASE_DONE - }); - } - const cancelEvent = this.getEventByEither(CANCEL_TYPE); - if ((this._cancelled || cancelEvent) && phase() !== PHASE_DONE) { - transitions.push({ - phase: PHASE_CANCELLED, - event: cancelEvent - }); - return transitions; - } - return transitions; - } - transitionToPhase(transition) { - const { - phase, - event - } = transition; - // get common methods - if (phase === PHASE_REQUESTED || phase === PHASE_READY) { - if (!this.wasSentByOwnDevice(event)) { - const content = event.getContent(); - this.commonMethods = content.methods.filter(m => this.verificationMethods.has(m)); - } - } - // detect if we're not a party in the request, and we should just observe - if (!this.observeOnly) { - // if requested or accepted by one of my other devices - if (phase === PHASE_REQUESTED || phase === PHASE_STARTED || phase === PHASE_READY) { - if (this.channel.receiveStartFromOtherDevices && this.wasSentByOwnUser(event) && !this.wasSentByOwnDevice(event)) { - this._observeOnly = true; - } - } - } - // create verifier - if (phase === PHASE_STARTED) { - const { - method - } = event.getContent(); - if (!this._verifier && !this.observeOnly) { - this._verifier = this.createVerifier(method, event); - if (!this._verifier) { - this.cancel({ - code: "m.unknown_method", - reason: `Unknown method: ${method}` - }); - } else { - this._chosenMethod = method; - } - } - } - } - applyPhaseTransitions() { - const transitions = this.calculatePhaseTransitions(); - const existingIdx = transitions.findIndex(t => t.phase === this.phase); - // trim off phases we already went through, if any - const newTransitions = transitions.slice(existingIdx + 1); - // transition to all new phases - for (const transition of newTransitions) { - this.transitionToPhase(transition); - } - return newTransitions; - } - isWinningStartRace(newEvent) { - if (newEvent.getType() !== START_TYPE) { - return false; - } - const oldEvent = this._verifier.startEvent; - let oldRaceIdentifier; - if (this.isSelfVerification) { - // if the verifier does not have a startEvent, - // it is because it's still sending and we are on the initator side - // we know we are sending a .start event because we already - // have a verifier (checked in calling method) - if (oldEvent) { - const oldContent = oldEvent.getContent(); - oldRaceIdentifier = oldContent && oldContent.from_device; - } else { - oldRaceIdentifier = this.client.getDeviceId(); - } - } else { - if (oldEvent) { - oldRaceIdentifier = oldEvent.getSender(); - } else { - oldRaceIdentifier = this.client.getUserId(); - } - } - let newRaceIdentifier; - if (this.isSelfVerification) { - const newContent = newEvent.getContent(); - newRaceIdentifier = newContent && newContent.from_device; - } else { - newRaceIdentifier = newEvent.getSender(); - } - return newRaceIdentifier < oldRaceIdentifier; - } - hasEventId(eventId) { - for (const event of this.eventsByUs.values()) { - if (event.getId() === eventId) { - return true; - } - } - for (const event of this.eventsByThem.values()) { - if (event.getId() === eventId) { - return true; - } - } - return false; - } - - /** - * Changes the state of the request and verifier in response to a key verification event. - * @param type - the "symbolic" event type, as returned by the `getEventType` function on the channel. - * @param event - the event to handle. Don't call getType() on it but use the `type` parameter instead. - * @param isLiveEvent - whether this is an even received through sync or not - * @param isRemoteEcho - whether this is the remote echo of an event sent by the same device - * @param isSentByUs - whether this event is sent by a party that can accept and/or observe the request like one of our peers. - * For InRoomChannel this means any device for the syncing user. For ToDeviceChannel, just the syncing device. - * @returns a promise that resolves when any requests as an answer to the passed-in event are sent. - */ - async handleEvent(type, event, isLiveEvent, isRemoteEcho, isSentByUs) { - // if reached phase cancelled or done, ignore anything else that comes - if (this.done || this.cancelled) { - return; - } - const wasObserveOnly = this._observeOnly; - this.adjustObserveOnly(event, isLiveEvent); - if (!this.observeOnly && !isRemoteEcho) { - if (await this.cancelOnError(type, event)) { - return; - } - } - - // This assumes verification won't need to send an event with - // the same type for the same party twice. - // This is true for QR and SAS verification, and was - // added here to prevent verification getting cancelled - // when the server duplicates an event (https://github.com/matrix-org/synapse/issues/3365) - const isDuplicateEvent = isSentByUs ? this.eventsByUs.has(type) : this.eventsByThem.has(type); - if (isDuplicateEvent) { - return; - } - const oldPhase = this.phase; - this.addEvent(type, event, isSentByUs); - - // this will create if needed the verifier so needs to happen before calling it - const newTransitions = this.applyPhaseTransitions(); - try { - // only pass events from the other side to the verifier, - // no remote echos of our own events - if (this._verifier && !this.observeOnly) { - const newEventWinsRace = this.isWinningStartRace(event); - if (this._verifier.canSwitchStartEvent(event) && newEventWinsRace) { - this._verifier.switchStartEvent(event); - } else if (!isRemoteEcho) { - var _this$_verifier$event; - if (type === CANCEL_TYPE || (_this$_verifier$event = this._verifier.events) !== null && _this$_verifier$event !== void 0 && _this$_verifier$event.includes(type)) { - this._verifier.handleEvent(event); - } - } - } - if (newTransitions.length) { - // create QRCodeData if the other side can scan - // important this happens before emitting a phase change, - // so listeners can rely on it being there already - // We only do this for live events because it is important that - // we sign the keys that were in the QR code, and not the keys - // we happen to have at some later point in time. - if (isLiveEvent && newTransitions.some(t => t.phase === PHASE_READY)) { - const shouldGenerateQrCode = this.otherPartySupportsMethod(_QRCode.SCAN_QR_CODE_METHOD, true); - if (shouldGenerateQrCode) { - this._qrCodeData = await _QRCode.QRCodeData.create(this, this.client); - } - } - const lastTransition = newTransitions[newTransitions.length - 1]; - const { - phase - } = lastTransition; - this.setupTimeout(phase); - // set phase as last thing as this emits the "change" event - this.setPhase(phase); - } else if (this._observeOnly !== wasObserveOnly) { - this.emit(VerificationRequestEvent.Change); - } - } finally { - // log events we processed so we can see from rageshakes what events were added to a request - _logger.logger.log(`Verification request ${this.channel.transactionId}: ` + `${type} event with id:${event.getId()}, ` + `content:${JSON.stringify(event.getContent())} ` + `deviceId:${this.channel.deviceId}, ` + `sender:${event.getSender()}, isSentByUs:${isSentByUs}, ` + `isLiveEvent:${isLiveEvent}, isRemoteEcho:${isRemoteEcho}, ` + `phase:${oldPhase}=>${this.phase}, ` + `observeOnly:${wasObserveOnly}=>${this._observeOnly}`); - } - } - setupTimeout(phase) { - const shouldTimeout = !this.timeoutTimer && !this.observeOnly && phase === PHASE_REQUESTED; - if (shouldTimeout) { - this.timeoutTimer = setTimeout(this.cancelOnTimeout, this.timeout); - } - if (this.timeoutTimer) { - const shouldClear = phase === PHASE_STARTED || phase === PHASE_READY || phase === PHASE_DONE || phase === PHASE_CANCELLED; - if (shouldClear) { - clearTimeout(this.timeoutTimer); - this.timeoutTimer = null; - } - } - } - async cancelOnError(type, event) { - if (type === START_TYPE) { - const method = event.getContent().method; - if (!this.verificationMethods.has(method)) { - await this.cancel((0, _Error.errorFromEvent)((0, _Error.newUnknownMethodError)())); - return true; - } - } - const isUnexpectedRequest = type === REQUEST_TYPE && this.phase !== PHASE_UNSENT; - const isUnexpectedReady = type === READY_TYPE && this.phase !== PHASE_REQUESTED && this.phase !== PHASE_STARTED; - // only if phase has passed from PHASE_UNSENT should we cancel, because events - // are allowed to come in in any order (at least with InRoomChannel). So we only know - // we're dealing with a valid request we should participate in once we've moved to PHASE_REQUESTED. - // Before that, we could be looking at somebody else's verification request and we just - // happen to be in the room - if (this.phase !== PHASE_UNSENT && (isUnexpectedRequest || isUnexpectedReady)) { - _logger.logger.warn(`Cancelling, unexpected ${type} verification ` + `event from ${event.getSender()}`); - const reason = `Unexpected ${type} event in phase ${this.phase}`; - await this.cancel((0, _Error.errorFromEvent)((0, _Error.newUnexpectedMessageError)({ - reason - }))); - return true; - } - return false; - } - adjustObserveOnly(event, isLiveEvent = false) { - // don't send out events for historical requests - if (!isLiveEvent) { - this._observeOnly = true; - } - if (this.calculateEventTimeout(event) < VERIFICATION_REQUEST_MARGIN) { - this._observeOnly = true; - } - } - addEvent(type, event, isSentByUs = false) { - if (isSentByUs) { - this.eventsByUs.set(type, event); - } else { - this.eventsByThem.set(type, event); - } - - // once we know the userId of the other party (from the .request event) - // see if any event by anyone else crept into this.eventsByThem - if (type === REQUEST_TYPE) { - for (const [type, event] of this.eventsByThem.entries()) { - if (event.getSender() !== this.otherUserId) { - this.eventsByThem.delete(type); - } - } - // also remember when we received the request event - this.requestReceivedAt = Date.now(); - } - } - createVerifier(method, startEvent = null, targetDevice = null) { - if (!targetDevice) { - targetDevice = this.targetDevice; - } - const { - userId, - deviceId - } = targetDevice; - const VerifierCtor = this.verificationMethods.get(method); - if (!VerifierCtor) { - _logger.logger.warn("could not find verifier constructor for method", method); - return; - } - return new VerifierCtor(this.channel, this.client, userId, deviceId, startEvent, this); - } - wasSentByOwnUser(event) { - return (event === null || event === void 0 ? void 0 : event.getSender()) === this.client.getUserId(); - } - - // only for .request, .ready or .start - wasSentByOwnDevice(event) { - if (!this.wasSentByOwnUser(event)) { - return false; - } - const content = event.getContent(); - if (!content || content.from_device !== this.client.getDeviceId()) { - return false; - } - return true; - } - onVerifierCancelled() { - this._cancelled = true; - // move to cancelled phase - const newTransitions = this.applyPhaseTransitions(); - if (newTransitions.length) { - this.setPhase(newTransitions[newTransitions.length - 1].phase); - } - } - onVerifierFinished() { - this.channel.send(_event.EventType.KeyVerificationDone, {}); - this.verifierHasFinished = true; - // move to .done phase - const newTransitions = this.applyPhaseTransitions(); - if (newTransitions.length) { - this.setPhase(newTransitions[newTransitions.length - 1].phase); - } - } - getEventFromOtherParty(type) { - return this.eventsByThem.get(type); - } -} -exports.VerificationRequest = VerificationRequest; -//# sourceMappingURL=VerificationRequest.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js.map deleted file mode 100644 index 4d110ef..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/verification/request/VerificationRequest.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"VerificationRequest.js","names":["_logger","require","_Error","_QRCode","_event","_typedEventEmitter","TIMEOUT_FROM_EVENT_TS","TIMEOUT_FROM_EVENT_RECEIPT","VERIFICATION_REQUEST_MARGIN","EVENT_PREFIX","exports","REQUEST_TYPE","START_TYPE","CANCEL_TYPE","DONE_TYPE","READY_TYPE","Phase","PHASE_UNSENT","Unsent","PHASE_REQUESTED","Requested","PHASE_READY","Ready","PHASE_STARTED","Started","PHASE_CANCELLED","Cancelled","PHASE_DONE","Done","VerificationRequestEvent","VerificationRequest","TypedEventEmitter","constructor","channel","verificationMethods","client","_defineProperty2","default","Map","initiatedByMe","cancel","reason","code","err","logger","error","request","setPhase","validateEvent","type","event","content","getContent","startsWith","log","Array","isArray","methods","from_device","length","invalid","phase","requested","cancelled","ready","started","done","commonMethods","chosenMethod","_chosenMethod","calculateEventTimeout","effectiveExpiresAt","getTimestamp","requestReceivedAt","expiresAtByReceipt","Math","min","max","Date","now","timeout","requestEvent","getEventByEither","_phase","verifier","_verifier","canAccept","_accepting","_declining","accepting","declining","pending","observeOnly","qrCodeData","_qrCodeData","otherPartySupportsMethod","method","force","theirMethodEvent","eventsByThem","get","myStartEvent","eventsByUs","myStartMethod","includes","noEventsYet","size","hasMyRequest","has","hasTheirRequest","hasMyStart","hasTheirStart","requestingUserId","getUserId","otherUserId","receivingUserId","userId","isSelfVerification","cancellingUserId","myCancel","theirCancel","getId","getSender","undefined","cancellationCode","ev","_observeOnly","targetDevice","theirFirstEvent","theirFirstContent","fromDevice","deviceId","beginKeyVerification","validStartPhase","canCreateRequest","newUnknownMethodError","createVerifier","sendRequest","keys","send","emit","Change","errorFactory","_cancellingUserId","accept","waitFor","fn","Promise","resolve","reject","check","handled","Error","off","on","notify","getEventBy","byThem","calculatePhaseTransitions","transitions","hasRequestByThem","push","readyEvent","startEvent","theirStartEvent","ourStartEvent","fromRequestPhase","fromUnsentPhase","ourDoneEvent","verifierHasFinished","cancelEvent","_cancelled","transitionToPhase","transition","wasSentByOwnDevice","filter","m","receiveStartFromOtherDevices","wasSentByOwnUser","applyPhaseTransitions","existingIdx","findIndex","t","newTransitions","slice","isWinningStartRace","newEvent","getType","oldEvent","oldRaceIdentifier","oldContent","getDeviceId","newRaceIdentifier","newContent","hasEventId","eventId","values","handleEvent","isLiveEvent","isRemoteEcho","isSentByUs","wasObserveOnly","adjustObserveOnly","cancelOnError","isDuplicateEvent","oldPhase","addEvent","newEventWinsRace","canSwitchStartEvent","switchStartEvent","_this$_verifier$event","events","some","shouldGenerateQrCode","SCAN_QR_CODE_METHOD","QRCodeData","create","lastTransition","setupTimeout","transactionId","JSON","stringify","shouldTimeout","timeoutTimer","setTimeout","cancelOnTimeout","shouldClear","clearTimeout","errorFromEvent","isUnexpectedRequest","isUnexpectedReady","warn","newUnexpectedMessageError","set","entries","delete","VerifierCtor","onVerifierCancelled","onVerifierFinished","EventType","KeyVerificationDone","getEventFromOtherParty"],"sources":["../../../../src/crypto/verification/request/VerificationRequest.ts"],"sourcesContent":["/*\nCopyright 2018 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../../../logger\";\nimport { errorFactory, errorFromEvent, newUnexpectedMessageError, newUnknownMethodError } from \"../Error\";\nimport { QRCodeData, SCAN_QR_CODE_METHOD } from \"../QRCode\";\nimport { IVerificationChannel } from \"./Channel\";\nimport { MatrixClient } from \"../../../client\";\nimport { MatrixEvent } from \"../../../models/event\";\nimport { EventType } from \"../../../@types/event\";\nimport { VerificationBase } from \"../Base\";\nimport { VerificationMethod } from \"../../index\";\nimport { TypedEventEmitter } from \"../../../models/typed-event-emitter\";\n\n// How long after the event's timestamp that the request times out\nconst TIMEOUT_FROM_EVENT_TS = 10 * 60 * 1000; // 10 minutes\n\n// How long after we receive the event that the request times out\nconst TIMEOUT_FROM_EVENT_RECEIPT = 2 * 60 * 1000; // 2 minutes\n\n// to avoid almost expired verification notifications\n// from showing a notification and almost immediately\n// disappearing, also ignore verification requests that\n// are this amount of time away from expiring.\nconst VERIFICATION_REQUEST_MARGIN = 3 * 1000; // 3 seconds\n\nexport const EVENT_PREFIX = \"m.key.verification.\";\nexport const REQUEST_TYPE = EVENT_PREFIX + \"request\";\nexport const START_TYPE = EVENT_PREFIX + \"start\";\nexport const CANCEL_TYPE = EVENT_PREFIX + \"cancel\";\nexport const DONE_TYPE = EVENT_PREFIX + \"done\";\nexport const READY_TYPE = EVENT_PREFIX + \"ready\";\n\nexport enum Phase {\n Unsent = 1,\n Requested,\n Ready,\n Started,\n Cancelled,\n Done,\n}\n\n// Legacy export fields\nexport const PHASE_UNSENT = Phase.Unsent;\nexport const PHASE_REQUESTED = Phase.Requested;\nexport const PHASE_READY = Phase.Ready;\nexport const PHASE_STARTED = Phase.Started;\nexport const PHASE_CANCELLED = Phase.Cancelled;\nexport const PHASE_DONE = Phase.Done;\n\ninterface ITargetDevice {\n userId?: string;\n deviceId?: string;\n}\n\ninterface ITransition {\n phase: Phase;\n event?: MatrixEvent;\n}\n\nexport enum VerificationRequestEvent {\n Change = \"change\",\n}\n\ntype EventHandlerMap = {\n /**\n * Fires whenever the state of the request object has changed.\n */\n [VerificationRequestEvent.Change]: () => void;\n};\n\n/**\n * State machine for verification requests.\n * Things that differ based on what channel is used to\n * send and receive verification events are put in `InRoomChannel` or `ToDeviceChannel`.\n */\nexport class VerificationRequest extends TypedEventEmitter<\n VerificationRequestEvent,\n EventHandlerMap\n> {\n private eventsByUs = new Map();\n private eventsByThem = new Map();\n private _observeOnly = false;\n private timeoutTimer: ReturnType | null = null;\n private _accepting = false;\n private _declining = false;\n private verifierHasFinished = false;\n private _cancelled = false;\n private _chosenMethod: VerificationMethod | null = null;\n // we keep a copy of the QR Code data (including other user master key) around\n // for QR reciprocate verification, to protect against\n // cross-signing identity reset between the .ready and .start event\n // and signing the wrong key after .start\n private _qrCodeData: QRCodeData | null = null;\n\n // The timestamp when we received the request event from the other side\n private requestReceivedAt: number | null = null;\n\n private commonMethods: VerificationMethod[] = [];\n private _phase!: Phase;\n public _cancellingUserId?: string; // Used in tests only\n private _verifier?: VerificationBase;\n\n public constructor(\n public readonly channel: C,\n private readonly verificationMethods: Map,\n private readonly client: MatrixClient,\n ) {\n super();\n this.channel.request = this;\n this.setPhase(PHASE_UNSENT, false);\n }\n\n /**\n * Stateless validation logic not specific to the channel.\n * Invoked by the same static method in either channel.\n * @param type - the \"symbolic\" event type, as returned by the `getEventType` function on the channel.\n * @param event - the event to validate. Don't call getType() on it but use the `type` parameter instead.\n * @param client - the client to get the current user and device id from\n * @returns whether the event is valid and should be passed to handleEvent\n */\n public static validateEvent(type: string, event: MatrixEvent, client: MatrixClient): boolean {\n const content = event.getContent();\n\n if (!type || !type.startsWith(EVENT_PREFIX)) {\n return false;\n }\n\n // from here on we're fairly sure that this is supposed to be\n // part of a verification request, so be noisy when rejecting something\n if (!content) {\n logger.log(\"VerificationRequest: validateEvent: no content\");\n return false;\n }\n\n if (type === REQUEST_TYPE || type === READY_TYPE) {\n if (!Array.isArray(content.methods)) {\n logger.log(\"VerificationRequest: validateEvent: \" + \"fail because methods\");\n return false;\n }\n }\n\n if (type === REQUEST_TYPE || type === READY_TYPE || type === START_TYPE) {\n if (typeof content.from_device !== \"string\" || content.from_device.length === 0) {\n logger.log(\"VerificationRequest: validateEvent: \" + \"fail because from_device\");\n return false;\n }\n }\n\n return true;\n }\n\n public get invalid(): boolean {\n return this.phase === PHASE_UNSENT;\n }\n\n /** returns whether the phase is PHASE_REQUESTED */\n public get requested(): boolean {\n return this.phase === PHASE_REQUESTED;\n }\n\n /** returns whether the phase is PHASE_CANCELLED */\n public get cancelled(): boolean {\n return this.phase === PHASE_CANCELLED;\n }\n\n /** returns whether the phase is PHASE_READY */\n public get ready(): boolean {\n return this.phase === PHASE_READY;\n }\n\n /** returns whether the phase is PHASE_STARTED */\n public get started(): boolean {\n return this.phase === PHASE_STARTED;\n }\n\n /** returns whether the phase is PHASE_DONE */\n public get done(): boolean {\n return this.phase === PHASE_DONE;\n }\n\n /** once the phase is PHASE_STARTED (and !initiatedByMe) or PHASE_READY: common methods supported by both sides */\n public get methods(): VerificationMethod[] {\n return this.commonMethods;\n }\n\n /** the method picked in the .start event */\n public get chosenMethod(): VerificationMethod | null {\n return this._chosenMethod;\n }\n\n public calculateEventTimeout(event: MatrixEvent): number {\n let effectiveExpiresAt = this.channel.getTimestamp(event) + TIMEOUT_FROM_EVENT_TS;\n\n if (this.requestReceivedAt && !this.initiatedByMe && this.phase <= PHASE_REQUESTED) {\n const expiresAtByReceipt = this.requestReceivedAt + TIMEOUT_FROM_EVENT_RECEIPT;\n effectiveExpiresAt = Math.min(effectiveExpiresAt, expiresAtByReceipt);\n }\n\n return Math.max(0, effectiveExpiresAt - Date.now());\n }\n\n /** The current remaining amount of ms before the request should be automatically cancelled */\n public get timeout(): number {\n const requestEvent = this.getEventByEither(REQUEST_TYPE);\n if (requestEvent) {\n return this.calculateEventTimeout(requestEvent);\n }\n return 0;\n }\n\n /**\n * The key verification request event.\n * @returns The request event, or falsey if not found.\n */\n public get requestEvent(): MatrixEvent | undefined {\n return this.getEventByEither(REQUEST_TYPE);\n }\n\n /** current phase of the request. Some properties might only be defined in a current phase. */\n public get phase(): Phase {\n return this._phase;\n }\n\n /** The verifier to do the actual verification, once the method has been established. Only defined when the `phase` is PHASE_STARTED. */\n public get verifier(): VerificationBase | undefined {\n return this._verifier;\n }\n\n public get canAccept(): boolean {\n return this.phase < PHASE_READY && !this._accepting && !this._declining;\n }\n\n public get accepting(): boolean {\n return this._accepting;\n }\n\n public get declining(): boolean {\n return this._declining;\n }\n\n /** whether this request has sent it's initial event and needs more events to complete */\n public get pending(): boolean {\n return !this.observeOnly && this._phase !== PHASE_DONE && this._phase !== PHASE_CANCELLED;\n }\n\n /** Only set after a .ready if the other party can scan a QR code */\n public get qrCodeData(): QRCodeData | null {\n return this._qrCodeData;\n }\n\n /** Checks whether the other party supports a given verification method.\n * This is useful when setting up the QR code UI, as it is somewhat asymmetrical:\n * if the other party supports SCAN_QR, we should show a QR code in the UI, and vice versa.\n * For methods that need to be supported by both ends, use the `methods` property.\n * @param method - the method to check\n * @param force - to check even if the phase is not ready or started yet, internal usage\n * @returns whether or not the other party said the supported the method */\n public otherPartySupportsMethod(method: string, force = false): boolean {\n if (!force && !this.ready && !this.started) {\n return false;\n }\n const theirMethodEvent = this.eventsByThem.get(REQUEST_TYPE) || this.eventsByThem.get(READY_TYPE);\n if (!theirMethodEvent) {\n // if we started straight away with .start event,\n // we are assuming that the other side will support the\n // chosen method, so return true for that.\n if (this.started && this.initiatedByMe) {\n const myStartEvent = this.eventsByUs.get(START_TYPE);\n const content = myStartEvent && myStartEvent.getContent();\n const myStartMethod = content && content.method;\n return method == myStartMethod;\n }\n return false;\n }\n const content = theirMethodEvent.getContent();\n if (!content) {\n return false;\n }\n const { methods } = content;\n if (!Array.isArray(methods)) {\n return false;\n }\n\n return methods.includes(method);\n }\n\n /** Whether this request was initiated by the syncing user.\n * For InRoomChannel, this is who sent the .request event.\n * For ToDeviceChannel, this is who sent the .start event\n */\n public get initiatedByMe(): boolean {\n // event created by us but no remote echo has been received yet\n const noEventsYet = this.eventsByUs.size + this.eventsByThem.size === 0;\n if (this._phase === PHASE_UNSENT && noEventsYet) {\n return true;\n }\n const hasMyRequest = this.eventsByUs.has(REQUEST_TYPE);\n const hasTheirRequest = this.eventsByThem.has(REQUEST_TYPE);\n if (hasMyRequest && !hasTheirRequest) {\n return true;\n }\n if (!hasMyRequest && hasTheirRequest) {\n return false;\n }\n const hasMyStart = this.eventsByUs.has(START_TYPE);\n const hasTheirStart = this.eventsByThem.has(START_TYPE);\n if (hasMyStart && !hasTheirStart) {\n return true;\n }\n return false;\n }\n\n /** The id of the user that initiated the request */\n public get requestingUserId(): string {\n if (this.initiatedByMe) {\n return this.client.getUserId()!;\n } else {\n return this.otherUserId;\n }\n }\n\n /** The id of the user that (will) receive(d) the request */\n public get receivingUserId(): string {\n if (this.initiatedByMe) {\n return this.otherUserId;\n } else {\n return this.client.getUserId()!;\n }\n }\n\n /** The user id of the other party in this request */\n public get otherUserId(): string {\n return this.channel.userId!;\n }\n\n public get isSelfVerification(): boolean {\n return this.client.getUserId() === this.otherUserId;\n }\n\n /**\n * The id of the user that cancelled the request,\n * only defined when phase is PHASE_CANCELLED\n */\n public get cancellingUserId(): string | undefined {\n const myCancel = this.eventsByUs.get(CANCEL_TYPE);\n const theirCancel = this.eventsByThem.get(CANCEL_TYPE);\n\n if (myCancel && (!theirCancel || myCancel.getId()! < theirCancel.getId()!)) {\n return myCancel.getSender();\n }\n if (theirCancel) {\n return theirCancel.getSender();\n }\n return undefined;\n }\n\n /**\n * The cancellation code e.g m.user which is responsible for cancelling this verification\n */\n public get cancellationCode(): string {\n const ev = this.getEventByEither(CANCEL_TYPE);\n return ev ? ev.getContent().code : null;\n }\n\n public get observeOnly(): boolean {\n return this._observeOnly;\n }\n\n /**\n * Gets which device the verification should be started with\n * given the events sent so far in the verification. This is the\n * same algorithm used to determine which device to send the\n * verification to when no specific device is specified.\n * @returns The device information\n */\n public get targetDevice(): ITargetDevice {\n const theirFirstEvent =\n this.eventsByThem.get(REQUEST_TYPE) ||\n this.eventsByThem.get(READY_TYPE) ||\n this.eventsByThem.get(START_TYPE);\n const theirFirstContent = theirFirstEvent?.getContent();\n const fromDevice = theirFirstContent?.from_device;\n return {\n userId: this.otherUserId,\n deviceId: fromDevice,\n };\n }\n\n /* Start the key verification, creating a verifier and sending a .start event.\n * If no previous events have been sent, pass in `targetDevice` to set who to direct this request to.\n * @param method - the name of the verification method to use.\n * @param targetDevice.userId the id of the user to direct this request to\n * @param targetDevice.deviceId the id of the device to direct this request to\n * @returns the verifier of the given method\n */\n public beginKeyVerification(\n method: VerificationMethod,\n targetDevice: ITargetDevice | null = null,\n ): VerificationBase {\n // need to allow also when unsent in case of to_device\n if (!this.observeOnly && !this._verifier) {\n const validStartPhase =\n this.phase === PHASE_REQUESTED ||\n this.phase === PHASE_READY ||\n (this.phase === PHASE_UNSENT && this.channel.canCreateRequest(START_TYPE));\n if (validStartPhase) {\n // when called on a request that was initiated with .request event\n // check the method is supported by both sides\n if (this.commonMethods.length && !this.commonMethods.includes(method)) {\n throw newUnknownMethodError();\n }\n this._verifier = this.createVerifier(method, null, targetDevice);\n if (!this._verifier) {\n throw newUnknownMethodError();\n }\n this._chosenMethod = method;\n }\n }\n return this._verifier!;\n }\n\n /**\n * sends the initial .request event.\n * @returns resolves when the event has been sent.\n */\n public async sendRequest(): Promise {\n if (!this.observeOnly && this._phase === PHASE_UNSENT) {\n const methods = [...this.verificationMethods.keys()];\n await this.channel.send(REQUEST_TYPE, { methods });\n }\n }\n\n /**\n * Cancels the request, sending a cancellation to the other party\n * @param reason - the error reason to send the cancellation with\n * @param code - the error code to send the cancellation with\n * @returns resolves when the event has been sent.\n */\n public async cancel({ reason = \"User declined\", code = \"m.user\" } = {}): Promise {\n if (!this.observeOnly && this._phase !== PHASE_CANCELLED) {\n this._declining = true;\n this.emit(VerificationRequestEvent.Change);\n if (this._verifier) {\n return this._verifier.cancel(errorFactory(code, reason)());\n } else {\n this._cancellingUserId = this.client.getUserId()!;\n await this.channel.send(CANCEL_TYPE, { code, reason });\n }\n }\n }\n\n /**\n * Accepts the request, sending a .ready event to the other party\n * @returns resolves when the event has been sent.\n */\n public async accept(): Promise {\n if (!this.observeOnly && this.phase === PHASE_REQUESTED && !this.initiatedByMe) {\n const methods = [...this.verificationMethods.keys()];\n this._accepting = true;\n this.emit(VerificationRequestEvent.Change);\n await this.channel.send(READY_TYPE, { methods });\n }\n }\n\n /**\n * Can be used to listen for state changes until the callback returns true.\n * @param fn - callback to evaluate whether the request is in the desired state.\n * Takes the request as an argument.\n * @returns that resolves once the callback returns true\n * @throws Error when the request is cancelled\n */\n public waitFor(fn: (request: VerificationRequest) => boolean): Promise {\n return new Promise((resolve, reject) => {\n const check = (): boolean => {\n let handled = false;\n if (fn(this)) {\n resolve(this);\n handled = true;\n } else if (this.cancelled) {\n reject(new Error(\"cancelled\"));\n handled = true;\n }\n if (handled) {\n this.off(VerificationRequestEvent.Change, check);\n }\n return handled;\n };\n if (!check()) {\n this.on(VerificationRequestEvent.Change, check);\n }\n });\n }\n\n private setPhase(phase: Phase, notify = true): void {\n this._phase = phase;\n if (notify) {\n this.emit(VerificationRequestEvent.Change);\n }\n }\n\n private getEventByEither(type: string): MatrixEvent | undefined {\n return this.eventsByThem.get(type) || this.eventsByUs.get(type);\n }\n\n private getEventBy(type: string, byThem = false): MatrixEvent | undefined {\n if (byThem) {\n return this.eventsByThem.get(type);\n } else {\n return this.eventsByUs.get(type);\n }\n }\n\n private calculatePhaseTransitions(): ITransition[] {\n const transitions: ITransition[] = [{ phase: PHASE_UNSENT }];\n const phase = (): Phase => transitions[transitions.length - 1].phase;\n\n // always pass by .request first to be sure channel.userId has been set\n const hasRequestByThem = this.eventsByThem.has(REQUEST_TYPE);\n const requestEvent = this.getEventBy(REQUEST_TYPE, hasRequestByThem);\n if (requestEvent) {\n transitions.push({ phase: PHASE_REQUESTED, event: requestEvent });\n }\n\n const readyEvent = requestEvent && this.getEventBy(READY_TYPE, !hasRequestByThem);\n if (readyEvent && phase() === PHASE_REQUESTED) {\n transitions.push({ phase: PHASE_READY, event: readyEvent });\n }\n\n let startEvent: MatrixEvent | undefined;\n if (readyEvent || !requestEvent) {\n const theirStartEvent = this.eventsByThem.get(START_TYPE);\n const ourStartEvent = this.eventsByUs.get(START_TYPE);\n // any party can send .start after a .ready or unsent\n if (theirStartEvent && ourStartEvent) {\n startEvent =\n theirStartEvent.getSender()! < ourStartEvent.getSender()! ? theirStartEvent : ourStartEvent;\n } else {\n startEvent = theirStartEvent ? theirStartEvent : ourStartEvent;\n }\n } else {\n startEvent = this.getEventBy(START_TYPE, !hasRequestByThem);\n }\n if (startEvent) {\n const fromRequestPhase =\n phase() === PHASE_REQUESTED && requestEvent?.getSender() !== startEvent.getSender();\n const fromUnsentPhase = phase() === PHASE_UNSENT && this.channel.canCreateRequest(START_TYPE);\n if (fromRequestPhase || phase() === PHASE_READY || fromUnsentPhase) {\n transitions.push({ phase: PHASE_STARTED, event: startEvent });\n }\n }\n\n const ourDoneEvent = this.eventsByUs.get(DONE_TYPE);\n if (this.verifierHasFinished || (ourDoneEvent && phase() === PHASE_STARTED)) {\n transitions.push({ phase: PHASE_DONE });\n }\n\n const cancelEvent = this.getEventByEither(CANCEL_TYPE);\n if ((this._cancelled || cancelEvent) && phase() !== PHASE_DONE) {\n transitions.push({ phase: PHASE_CANCELLED, event: cancelEvent });\n return transitions;\n }\n\n return transitions;\n }\n\n private transitionToPhase(transition: ITransition): void {\n const { phase, event } = transition;\n // get common methods\n if (phase === PHASE_REQUESTED || phase === PHASE_READY) {\n if (!this.wasSentByOwnDevice(event)) {\n const content = event!.getContent<{\n methods: string[];\n }>();\n this.commonMethods = content.methods.filter((m) => this.verificationMethods.has(m));\n }\n }\n // detect if we're not a party in the request, and we should just observe\n if (!this.observeOnly) {\n // if requested or accepted by one of my other devices\n if (phase === PHASE_REQUESTED || phase === PHASE_STARTED || phase === PHASE_READY) {\n if (\n this.channel.receiveStartFromOtherDevices &&\n this.wasSentByOwnUser(event) &&\n !this.wasSentByOwnDevice(event)\n ) {\n this._observeOnly = true;\n }\n }\n }\n // create verifier\n if (phase === PHASE_STARTED) {\n const { method } = event!.getContent();\n if (!this._verifier && !this.observeOnly) {\n this._verifier = this.createVerifier(method, event);\n if (!this._verifier) {\n this.cancel({\n code: \"m.unknown_method\",\n reason: `Unknown method: ${method}`,\n });\n } else {\n this._chosenMethod = method;\n }\n }\n }\n }\n\n private applyPhaseTransitions(): ITransition[] {\n const transitions = this.calculatePhaseTransitions();\n const existingIdx = transitions.findIndex((t) => t.phase === this.phase);\n // trim off phases we already went through, if any\n const newTransitions = transitions.slice(existingIdx + 1);\n // transition to all new phases\n for (const transition of newTransitions) {\n this.transitionToPhase(transition);\n }\n return newTransitions;\n }\n\n private isWinningStartRace(newEvent: MatrixEvent): boolean {\n if (newEvent.getType() !== START_TYPE) {\n return false;\n }\n const oldEvent = this._verifier!.startEvent;\n\n let oldRaceIdentifier;\n if (this.isSelfVerification) {\n // if the verifier does not have a startEvent,\n // it is because it's still sending and we are on the initator side\n // we know we are sending a .start event because we already\n // have a verifier (checked in calling method)\n if (oldEvent) {\n const oldContent = oldEvent.getContent();\n oldRaceIdentifier = oldContent && oldContent.from_device;\n } else {\n oldRaceIdentifier = this.client.getDeviceId();\n }\n } else {\n if (oldEvent) {\n oldRaceIdentifier = oldEvent.getSender();\n } else {\n oldRaceIdentifier = this.client.getUserId();\n }\n }\n\n let newRaceIdentifier;\n if (this.isSelfVerification) {\n const newContent = newEvent.getContent();\n newRaceIdentifier = newContent && newContent.from_device;\n } else {\n newRaceIdentifier = newEvent.getSender();\n }\n return newRaceIdentifier < oldRaceIdentifier;\n }\n\n public hasEventId(eventId: string): boolean {\n for (const event of this.eventsByUs.values()) {\n if (event.getId() === eventId) {\n return true;\n }\n }\n for (const event of this.eventsByThem.values()) {\n if (event.getId() === eventId) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Changes the state of the request and verifier in response to a key verification event.\n * @param type - the \"symbolic\" event type, as returned by the `getEventType` function on the channel.\n * @param event - the event to handle. Don't call getType() on it but use the `type` parameter instead.\n * @param isLiveEvent - whether this is an even received through sync or not\n * @param isRemoteEcho - whether this is the remote echo of an event sent by the same device\n * @param isSentByUs - whether this event is sent by a party that can accept and/or observe the request like one of our peers.\n * For InRoomChannel this means any device for the syncing user. For ToDeviceChannel, just the syncing device.\n * @returns a promise that resolves when any requests as an answer to the passed-in event are sent.\n */\n public async handleEvent(\n type: string,\n event: MatrixEvent,\n isLiveEvent: boolean,\n isRemoteEcho: boolean,\n isSentByUs: boolean,\n ): Promise {\n // if reached phase cancelled or done, ignore anything else that comes\n if (this.done || this.cancelled) {\n return;\n }\n const wasObserveOnly = this._observeOnly;\n\n this.adjustObserveOnly(event, isLiveEvent);\n\n if (!this.observeOnly && !isRemoteEcho) {\n if (await this.cancelOnError(type, event)) {\n return;\n }\n }\n\n // This assumes verification won't need to send an event with\n // the same type for the same party twice.\n // This is true for QR and SAS verification, and was\n // added here to prevent verification getting cancelled\n // when the server duplicates an event (https://github.com/matrix-org/synapse/issues/3365)\n const isDuplicateEvent = isSentByUs ? this.eventsByUs.has(type) : this.eventsByThem.has(type);\n if (isDuplicateEvent) {\n return;\n }\n\n const oldPhase = this.phase;\n this.addEvent(type, event, isSentByUs);\n\n // this will create if needed the verifier so needs to happen before calling it\n const newTransitions = this.applyPhaseTransitions();\n try {\n // only pass events from the other side to the verifier,\n // no remote echos of our own events\n if (this._verifier && !this.observeOnly) {\n const newEventWinsRace = this.isWinningStartRace(event);\n if (this._verifier.canSwitchStartEvent(event) && newEventWinsRace) {\n this._verifier.switchStartEvent(event);\n } else if (!isRemoteEcho) {\n if (type === CANCEL_TYPE || this._verifier.events?.includes(type)) {\n this._verifier.handleEvent(event);\n }\n }\n }\n\n if (newTransitions.length) {\n // create QRCodeData if the other side can scan\n // important this happens before emitting a phase change,\n // so listeners can rely on it being there already\n // We only do this for live events because it is important that\n // we sign the keys that were in the QR code, and not the keys\n // we happen to have at some later point in time.\n if (isLiveEvent && newTransitions.some((t) => t.phase === PHASE_READY)) {\n const shouldGenerateQrCode = this.otherPartySupportsMethod(SCAN_QR_CODE_METHOD, true);\n if (shouldGenerateQrCode) {\n this._qrCodeData = await QRCodeData.create(this, this.client);\n }\n }\n\n const lastTransition = newTransitions[newTransitions.length - 1];\n const { phase } = lastTransition;\n\n this.setupTimeout(phase);\n // set phase as last thing as this emits the \"change\" event\n this.setPhase(phase);\n } else if (this._observeOnly !== wasObserveOnly) {\n this.emit(VerificationRequestEvent.Change);\n }\n } finally {\n // log events we processed so we can see from rageshakes what events were added to a request\n logger.log(\n `Verification request ${this.channel.transactionId}: ` +\n `${type} event with id:${event.getId()}, ` +\n `content:${JSON.stringify(event.getContent())} ` +\n `deviceId:${this.channel.deviceId}, ` +\n `sender:${event.getSender()}, isSentByUs:${isSentByUs}, ` +\n `isLiveEvent:${isLiveEvent}, isRemoteEcho:${isRemoteEcho}, ` +\n `phase:${oldPhase}=>${this.phase}, ` +\n `observeOnly:${wasObserveOnly}=>${this._observeOnly}`,\n );\n }\n }\n\n private setupTimeout(phase: Phase): void {\n const shouldTimeout = !this.timeoutTimer && !this.observeOnly && phase === PHASE_REQUESTED;\n\n if (shouldTimeout) {\n this.timeoutTimer = setTimeout(this.cancelOnTimeout, this.timeout);\n }\n if (this.timeoutTimer) {\n const shouldClear =\n phase === PHASE_STARTED || phase === PHASE_READY || phase === PHASE_DONE || phase === PHASE_CANCELLED;\n if (shouldClear) {\n clearTimeout(this.timeoutTimer);\n this.timeoutTimer = null;\n }\n }\n }\n\n private cancelOnTimeout = async (): Promise => {\n try {\n if (this.initiatedByMe) {\n await this.cancel({\n reason: \"Other party didn't accept in time\",\n code: \"m.timeout\",\n });\n } else {\n await this.cancel({\n reason: \"User didn't accept in time\",\n code: \"m.timeout\",\n });\n }\n } catch (err) {\n logger.error(\"Error while cancelling verification request\", err);\n }\n };\n\n private async cancelOnError(type: string, event: MatrixEvent): Promise {\n if (type === START_TYPE) {\n const method = event.getContent().method;\n if (!this.verificationMethods.has(method)) {\n await this.cancel(errorFromEvent(newUnknownMethodError()));\n return true;\n }\n }\n\n const isUnexpectedRequest = type === REQUEST_TYPE && this.phase !== PHASE_UNSENT;\n const isUnexpectedReady = type === READY_TYPE && this.phase !== PHASE_REQUESTED && this.phase !== PHASE_STARTED;\n // only if phase has passed from PHASE_UNSENT should we cancel, because events\n // are allowed to come in in any order (at least with InRoomChannel). So we only know\n // we're dealing with a valid request we should participate in once we've moved to PHASE_REQUESTED.\n // Before that, we could be looking at somebody else's verification request and we just\n // happen to be in the room\n if (this.phase !== PHASE_UNSENT && (isUnexpectedRequest || isUnexpectedReady)) {\n logger.warn(`Cancelling, unexpected ${type} verification ` + `event from ${event.getSender()}`);\n const reason = `Unexpected ${type} event in phase ${this.phase}`;\n await this.cancel(errorFromEvent(newUnexpectedMessageError({ reason })));\n return true;\n }\n return false;\n }\n\n private adjustObserveOnly(event: MatrixEvent, isLiveEvent = false): void {\n // don't send out events for historical requests\n if (!isLiveEvent) {\n this._observeOnly = true;\n }\n if (this.calculateEventTimeout(event) < VERIFICATION_REQUEST_MARGIN) {\n this._observeOnly = true;\n }\n }\n\n private addEvent(type: string, event: MatrixEvent, isSentByUs = false): void {\n if (isSentByUs) {\n this.eventsByUs.set(type, event);\n } else {\n this.eventsByThem.set(type, event);\n }\n\n // once we know the userId of the other party (from the .request event)\n // see if any event by anyone else crept into this.eventsByThem\n if (type === REQUEST_TYPE) {\n for (const [type, event] of this.eventsByThem.entries()) {\n if (event.getSender() !== this.otherUserId) {\n this.eventsByThem.delete(type);\n }\n }\n // also remember when we received the request event\n this.requestReceivedAt = Date.now();\n }\n }\n\n private createVerifier(\n method: VerificationMethod,\n startEvent: MatrixEvent | null = null,\n targetDevice: ITargetDevice | null = null,\n ): VerificationBase | undefined {\n if (!targetDevice) {\n targetDevice = this.targetDevice;\n }\n const { userId, deviceId } = targetDevice;\n\n const VerifierCtor = this.verificationMethods.get(method);\n if (!VerifierCtor) {\n logger.warn(\"could not find verifier constructor for method\", method);\n return;\n }\n return new VerifierCtor(this.channel, this.client, userId!, deviceId!, startEvent, this);\n }\n\n private wasSentByOwnUser(event?: MatrixEvent): boolean {\n return event?.getSender() === this.client.getUserId();\n }\n\n // only for .request, .ready or .start\n private wasSentByOwnDevice(event?: MatrixEvent): boolean {\n if (!this.wasSentByOwnUser(event)) {\n return false;\n }\n const content = event!.getContent();\n if (!content || content.from_device !== this.client.getDeviceId()) {\n return false;\n }\n return true;\n }\n\n public onVerifierCancelled(): void {\n this._cancelled = true;\n // move to cancelled phase\n const newTransitions = this.applyPhaseTransitions();\n if (newTransitions.length) {\n this.setPhase(newTransitions[newTransitions.length - 1].phase);\n }\n }\n\n public onVerifierFinished(): void {\n this.channel.send(EventType.KeyVerificationDone, {});\n this.verifierHasFinished = true;\n // move to .done phase\n const newTransitions = this.applyPhaseTransitions();\n if (newTransitions.length) {\n this.setPhase(newTransitions[newTransitions.length - 1].phase);\n }\n }\n\n public getEventFromOtherParty(type: string): MatrixEvent | undefined {\n return this.eventsByThem.get(type);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts deleted file mode 100644 index 0754b64..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts +++ /dev/null @@ -1,86 +0,0 @@ -import { WidgetApi } from "matrix-widget-api"; -import { ISendEventResponse } from "./@types/requests"; -import { MatrixClient, IMatrixClientCreateOpts, IStartClientOpts, SendToDeviceContentMap } from "./client"; -import { SyncState } from "./sync"; -import { MatrixEvent } from "./models/event"; -import { Room } from "./models/room"; -import { ToDeviceBatch } from "./models/ToDeviceMessage"; -import { DeviceInfo } from "./crypto/deviceinfo"; -import { IOlmDevice } from "./crypto/algorithms/megolm"; -interface IStateEventRequest { - eventType: string; - stateKey?: string; -} -export interface ICapabilities { - /** - * Event types that this client expects to send. - */ - sendEvent?: string[]; - /** - * Event types that this client expects to receive. - */ - receiveEvent?: string[]; - /** - * Message types that this client expects to send, or true for all message - * types. - */ - sendMessage?: string[] | true; - /** - * Message types that this client expects to receive, or true for all - * message types. - */ - receiveMessage?: string[] | true; - /** - * Types of state events that this client expects to send. - */ - sendState?: IStateEventRequest[]; - /** - * Types of state events that this client expects to receive. - */ - receiveState?: IStateEventRequest[]; - /** - * To-device event types that this client expects to send. - */ - sendToDevice?: string[]; - /** - * To-device event types that this client expects to receive. - */ - receiveToDevice?: string[]; - /** - * Whether this client needs access to TURN servers. - * @defaultValue false - */ - turnServers?: boolean; -} -/** - * A MatrixClient that routes its requests through the widget API instead of the - * real CS API. - * @experimental This class is considered unstable! - */ -export declare class RoomWidgetClient extends MatrixClient { - private readonly widgetApi; - private readonly capabilities; - private readonly roomId; - private room?; - private widgetApiReady; - private lifecycle?; - private syncState; - constructor(widgetApi: WidgetApi, capabilities: ICapabilities, roomId: string, opts: IMatrixClientCreateOpts); - startClient(opts?: IStartClientOpts): Promise; - stopClient(): void; - joinRoom(roomIdOrAlias: string): Promise; - protected encryptAndSendEvent(room: Room, event: MatrixEvent): Promise; - sendStateEvent(roomId: string, eventType: string, content: any, stateKey?: string): Promise; - sendToDevice(eventType: string, contentMap: SendToDeviceContentMap): Promise<{}>; - queueToDevice({ eventType, batch }: ToDeviceBatch): Promise; - encryptAndSendToDevices(userDeviceInfoArr: IOlmDevice[], payload: object): Promise; - checkTurnServers(): Promise; - getSyncState(): SyncState | null; - private setSyncState; - private ack; - private onEvent; - private onToDevice; - private watchTurnServers; -} -export {}; -//# sourceMappingURL=embedded.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts.map deleted file mode 100644 index 85a3198..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"embedded.d.ts","sourceRoot":"","sources":["../src/embedded.ts"],"names":[],"mappings":"AAgBA,OAAO,EACH,SAAS,EAQZ,MAAM,mBAAmB,CAAC;AAG3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAGvD,OAAO,EAAE,YAAY,EAAe,uBAAuB,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;AACxH,OAAO,EAAW,SAAS,EAAE,MAAM,QAAQ,CAAC;AAE5C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,aAAa,EAAmB,MAAM,0BAA0B,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAGxD,UAAU,kBAAkB;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,aAAa;IAC1B;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IAExB;;;OAGG;IACH,WAAW,CAAC,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAC9B;;;OAGG;IACH,cAAc,CAAC,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAEjC;;OAEG;IACH,SAAS,CAAC,EAAE,kBAAkB,EAAE,CAAC;IACjC;;OAEG;IACH,YAAY,CAAC,EAAE,kBAAkB,EAAE,CAAC;IAEpC;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB;;OAEG;IACH,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAE3B;;;OAGG;IACH,WAAW,CAAC,EAAE,OAAO,CAAC;CACzB;AAED;;;;GAIG;AACH,qBAAa,gBAAiB,SAAQ,YAAY;IAO1C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAR3B,OAAO,CAAC,IAAI,CAAC,CAAO;IACpB,OAAO,CAAC,cAAc,CAAyE;IAC/F,OAAO,CAAC,SAAS,CAAC,CAAkB;IACpC,OAAO,CAAC,SAAS,CAA0B;gBAGtB,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,aAAa,EAC3B,MAAM,EAAE,MAAM,EAC/B,IAAI,EAAE,uBAAuB;IAgDpB,WAAW,CAAC,IAAI,GAAE,gBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;IA8C7D,UAAU,IAAI,IAAI;IAQZ,QAAQ,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;cAK3C,mBAAmB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAanF,cAAc,CACvB,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,GAAG,EACZ,QAAQ,SAAK,GACd,OAAO,CAAC,kBAAkB,CAAC;IAIjB,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,sBAAsB,GAAG,OAAO,CAAC,EAAE,CAAC;IAKhF,aAAa,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAUjE,uBAAuB,CAAC,iBAAiB,EAAE,UAAU,CAAC,UAAU,CAAC,EAAE,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAepG,gBAAgB,IAAI,OAAO,CAAC,OAAO,CAAC;IAK1C,YAAY,IAAI,SAAS,GAAG,IAAI;IAIvC,OAAO,CAAC,YAAY;YAMN,GAAG;IAIjB,OAAO,CAAC,OAAO,CAiBb;IAEF,OAAO,CAAC,UAAU,CAchB;YAEY,gBAAgB;CAyBjC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js deleted file mode 100644 index f0baa16..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js +++ /dev/null @@ -1,265 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomWidgetClient = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _matrixWidgetApi = require("matrix-widget-api"); -var _event = require("./models/event"); -var _event2 = require("./@types/event"); -var _logger = require("./logger"); -var _client = require("./client"); -var _sync = require("./sync"); -var _slidingSyncSdk = require("./sliding-sync-sdk"); -var _user = require("./models/user"); -var _utils = require("./utils"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * A MatrixClient that routes its requests through the widget API instead of the - * real CS API. - * @experimental This class is considered unstable! - */ -class RoomWidgetClient extends _client.MatrixClient { - constructor(widgetApi, capabilities, roomId, opts) { - var _capabilities$sendEve, _capabilities$receive, _capabilities$sendSta, _capabilities$receive2, _capabilities$sendEve2, _capabilities$receive3, _capabilities$sendSta2, _capabilities$receive4, _capabilities$sendToD, _capabilities$receive5; - super(opts); - - // Request capabilities for the functionality this client needs to support - this.widgetApi = widgetApi; - this.capabilities = capabilities; - this.roomId = roomId; - (0, _defineProperty2.default)(this, "room", void 0); - (0, _defineProperty2.default)(this, "widgetApiReady", new Promise(resolve => this.widgetApi.once("ready", resolve))); - (0, _defineProperty2.default)(this, "lifecycle", void 0); - (0, _defineProperty2.default)(this, "syncState", null); - (0, _defineProperty2.default)(this, "onEvent", async ev => { - ev.preventDefault(); - - // Verify the room ID matches, since it's possible for the client to - // send us events from other rooms if this widget is always on screen - if (ev.detail.data.room_id === this.roomId) { - const event = new _event.MatrixEvent(ev.detail.data); - await this.syncApi.injectRoomEvents(this.room, [], [event]); - this.emit(_client.ClientEvent.Event, event); - this.setSyncState(_sync.SyncState.Syncing); - _logger.logger.info(`Received event ${event.getId()} ${event.getType()} ${event.getStateKey()}`); - } else { - const { - event_id: eventId, - room_id: roomId - } = ev.detail.data; - _logger.logger.info(`Received event ${eventId} for a different room ${roomId}; discarding`); - } - await this.ack(ev); - }); - (0, _defineProperty2.default)(this, "onToDevice", async ev => { - ev.preventDefault(); - const event = new _event.MatrixEvent({ - type: ev.detail.data.type, - sender: ev.detail.data.sender, - content: ev.detail.data.content - }); - // Mark the event as encrypted if it was, using fake contents and keys since those are unknown to us - if (ev.detail.data.encrypted) event.makeEncrypted(_event2.EventType.RoomMessageEncrypted, {}, "", ""); - this.emit(_client.ClientEvent.ToDeviceEvent, event); - this.setSyncState(_sync.SyncState.Syncing); - await this.ack(ev); - }); - if ((_capabilities$sendEve = capabilities.sendEvent) !== null && _capabilities$sendEve !== void 0 && _capabilities$sendEve.length || (_capabilities$receive = capabilities.receiveEvent) !== null && _capabilities$receive !== void 0 && _capabilities$receive.length || capabilities.sendMessage === true || Array.isArray(capabilities.sendMessage) && capabilities.sendMessage.length || capabilities.receiveMessage === true || Array.isArray(capabilities.receiveMessage) && capabilities.receiveMessage.length || (_capabilities$sendSta = capabilities.sendState) !== null && _capabilities$sendSta !== void 0 && _capabilities$sendSta.length || (_capabilities$receive2 = capabilities.receiveState) !== null && _capabilities$receive2 !== void 0 && _capabilities$receive2.length) { - widgetApi.requestCapabilityForRoomTimeline(roomId); - } - (_capabilities$sendEve2 = capabilities.sendEvent) === null || _capabilities$sendEve2 === void 0 ? void 0 : _capabilities$sendEve2.forEach(eventType => widgetApi.requestCapabilityToSendEvent(eventType)); - (_capabilities$receive3 = capabilities.receiveEvent) === null || _capabilities$receive3 === void 0 ? void 0 : _capabilities$receive3.forEach(eventType => widgetApi.requestCapabilityToReceiveEvent(eventType)); - if (capabilities.sendMessage === true) { - widgetApi.requestCapabilityToSendMessage(); - } else if (Array.isArray(capabilities.sendMessage)) { - capabilities.sendMessage.forEach(msgType => widgetApi.requestCapabilityToSendMessage(msgType)); - } - if (capabilities.receiveMessage === true) { - widgetApi.requestCapabilityToReceiveMessage(); - } else if (Array.isArray(capabilities.receiveMessage)) { - capabilities.receiveMessage.forEach(msgType => widgetApi.requestCapabilityToReceiveMessage(msgType)); - } - (_capabilities$sendSta2 = capabilities.sendState) === null || _capabilities$sendSta2 === void 0 ? void 0 : _capabilities$sendSta2.forEach(({ - eventType, - stateKey - }) => widgetApi.requestCapabilityToSendState(eventType, stateKey)); - (_capabilities$receive4 = capabilities.receiveState) === null || _capabilities$receive4 === void 0 ? void 0 : _capabilities$receive4.forEach(({ - eventType, - stateKey - }) => widgetApi.requestCapabilityToReceiveState(eventType, stateKey)); - (_capabilities$sendToD = capabilities.sendToDevice) === null || _capabilities$sendToD === void 0 ? void 0 : _capabilities$sendToD.forEach(eventType => widgetApi.requestCapabilityToSendToDevice(eventType)); - (_capabilities$receive5 = capabilities.receiveToDevice) === null || _capabilities$receive5 === void 0 ? void 0 : _capabilities$receive5.forEach(eventType => widgetApi.requestCapabilityToReceiveToDevice(eventType)); - if (capabilities.turnServers) { - widgetApi.requestCapability(_matrixWidgetApi.MatrixCapabilities.MSC3846TurnServers); - } - widgetApi.on(`action:${_matrixWidgetApi.WidgetApiToWidgetAction.SendEvent}`, this.onEvent); - widgetApi.on(`action:${_matrixWidgetApi.WidgetApiToWidgetAction.SendToDevice}`, this.onToDevice); - - // Open communication with the host - widgetApi.start(); - } - async startClient(opts = {}) { - var _this$capabilities$re, _this$capabilities$re2; - this.lifecycle = new AbortController(); - - // Create our own user object artificially (instead of waiting for sync) - // so it's always available, even if the user is not in any rooms etc. - const userId = this.getUserId(); - if (userId) { - this.store.storeUser(new _user.User(userId)); - } - - // Even though we have no access token and cannot sync, the sync class - // still has some valuable helper methods that we make use of, so we - // instantiate it anyways - if (opts.slidingSync) { - this.syncApi = new _slidingSyncSdk.SlidingSyncSdk(opts.slidingSync, this, opts, this.buildSyncApiOptions()); - } else { - this.syncApi = new _sync.SyncApi(this, opts, this.buildSyncApiOptions()); - } - this.room = this.syncApi.createRoom(this.roomId); - this.store.storeRoom(this.room); - await this.widgetApiReady; - - // Backfill the requested events - // We only get the most recent event for every type + state key combo, - // so it doesn't really matter what order we inject them in - await Promise.all((_this$capabilities$re = (_this$capabilities$re2 = this.capabilities.receiveState) === null || _this$capabilities$re2 === void 0 ? void 0 : _this$capabilities$re2.map(async ({ - eventType, - stateKey - }) => { - const rawEvents = await this.widgetApi.readStateEvents(eventType, undefined, stateKey, [this.roomId]); - const events = rawEvents.map(rawEvent => new _event.MatrixEvent(rawEvent)); - await this.syncApi.injectRoomEvents(this.room, [], events); - events.forEach(event => { - this.emit(_client.ClientEvent.Event, event); - _logger.logger.info(`Backfilled event ${event.getId()} ${event.getType()} ${event.getStateKey()}`); - }); - })) !== null && _this$capabilities$re !== void 0 ? _this$capabilities$re : []); - this.setSyncState(_sync.SyncState.Syncing); - _logger.logger.info("Finished backfilling events"); - - // Watch for TURN servers, if requested - if (this.capabilities.turnServers) this.watchTurnServers(); - } - stopClient() { - this.widgetApi.off(`action:${_matrixWidgetApi.WidgetApiToWidgetAction.SendEvent}`, this.onEvent); - this.widgetApi.off(`action:${_matrixWidgetApi.WidgetApiToWidgetAction.SendToDevice}`, this.onToDevice); - super.stopClient(); - this.lifecycle.abort(); // Signal to other async tasks that the client has stopped - } - - async joinRoom(roomIdOrAlias) { - if (roomIdOrAlias === this.roomId) return this.room; - throw new Error(`Unknown room: ${roomIdOrAlias}`); - } - async encryptAndSendEvent(room, event) { - let response; - try { - response = await this.widgetApi.sendRoomEvent(event.getType(), event.getContent(), room.roomId); - } catch (e) { - this.updatePendingEventStatus(room, event, _event.EventStatus.NOT_SENT); - throw e; - } - room.updatePendingEvent(event, _event.EventStatus.SENT, response.event_id); - return { - event_id: response.event_id - }; - } - async sendStateEvent(roomId, eventType, content, stateKey = "") { - return await this.widgetApi.sendStateEvent(eventType, stateKey, content, roomId); - } - async sendToDevice(eventType, contentMap) { - await this.widgetApi.sendToDevice(eventType, false, (0, _utils.recursiveMapToObject)(contentMap)); - return {}; - } - async queueToDevice({ - eventType, - batch - }) { - // map: user Id → device Id → payload - const contentMap = new _utils.MapWithDefault(() => new Map()); - for (const { - userId, - deviceId, - payload - } of batch) { - contentMap.getOrCreate(userId).set(deviceId, payload); - } - await this.widgetApi.sendToDevice(eventType, false, (0, _utils.recursiveMapToObject)(contentMap)); - } - async encryptAndSendToDevices(userDeviceInfoArr, payload) { - // map: user Id → device Id → payload - const contentMap = new _utils.MapWithDefault(() => new Map()); - for (const { - userId, - deviceInfo: { - deviceId - } - } of userDeviceInfoArr) { - contentMap.getOrCreate(userId).set(deviceId, payload); - } - await this.widgetApi.sendToDevice(payload.type, true, (0, _utils.recursiveMapToObject)(contentMap)); - } - - // Overridden since we get TURN servers automatically over the widget API, - // and this method would otherwise complain about missing an access token - async checkTurnServers() { - return this.turnServers.length > 0; - } - - // Overridden since we 'sync' manually without the sync API - getSyncState() { - return this.syncState; - } - setSyncState(state) { - const oldState = this.syncState; - this.syncState = state; - this.emit(_client.ClientEvent.Sync, state, oldState); - } - async ack(ev) { - await this.widgetApi.transport.reply(ev.detail, {}); - } - async watchTurnServers() { - const servers = this.widgetApi.getTurnServers(); - const onClientStopped = () => { - servers.return(undefined); - }; - this.lifecycle.signal.addEventListener("abort", onClientStopped); - try { - for await (const server of servers) { - this.turnServers = [{ - urls: server.uris, - username: server.username, - credential: server.password - }]; - this.emit(_client.ClientEvent.TurnServers, this.turnServers); - _logger.logger.log(`Received TURN server: ${server.uris}`); - } - } catch (e) { - _logger.logger.warn("Error watching TURN servers", e); - } finally { - this.lifecycle.signal.removeEventListener("abort", onClientStopped); - } - } -} -exports.RoomWidgetClient = RoomWidgetClient; -//# sourceMappingURL=embedded.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js.map deleted file mode 100644 index fa8b390..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/embedded.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"embedded.js","names":["_matrixWidgetApi","require","_event","_event2","_logger","_client","_sync","_slidingSyncSdk","_user","_utils","RoomWidgetClient","MatrixClient","constructor","widgetApi","capabilities","roomId","opts","_capabilities$sendEve","_capabilities$receive","_capabilities$sendSta","_capabilities$receive2","_capabilities$sendEve2","_capabilities$receive3","_capabilities$sendSta2","_capabilities$receive4","_capabilities$sendToD","_capabilities$receive5","_defineProperty2","default","Promise","resolve","once","ev","preventDefault","detail","data","room_id","event","MatrixEvent","syncApi","injectRoomEvents","room","emit","ClientEvent","Event","setSyncState","SyncState","Syncing","logger","info","getId","getType","getStateKey","event_id","eventId","ack","type","sender","content","encrypted","makeEncrypted","EventType","RoomMessageEncrypted","ToDeviceEvent","sendEvent","length","receiveEvent","sendMessage","Array","isArray","receiveMessage","sendState","receiveState","requestCapabilityForRoomTimeline","forEach","eventType","requestCapabilityToSendEvent","requestCapabilityToReceiveEvent","requestCapabilityToSendMessage","msgType","requestCapabilityToReceiveMessage","stateKey","requestCapabilityToSendState","requestCapabilityToReceiveState","sendToDevice","requestCapabilityToSendToDevice","receiveToDevice","requestCapabilityToReceiveToDevice","turnServers","requestCapability","MatrixCapabilities","MSC3846TurnServers","on","WidgetApiToWidgetAction","SendEvent","onEvent","SendToDevice","onToDevice","start","startClient","_this$capabilities$re","_this$capabilities$re2","lifecycle","AbortController","userId","getUserId","store","storeUser","User","slidingSync","SlidingSyncSdk","buildSyncApiOptions","SyncApi","createRoom","storeRoom","widgetApiReady","all","map","rawEvents","readStateEvents","undefined","events","rawEvent","watchTurnServers","stopClient","off","abort","joinRoom","roomIdOrAlias","Error","encryptAndSendEvent","response","sendRoomEvent","getContent","e","updatePendingEventStatus","EventStatus","NOT_SENT","updatePendingEvent","SENT","sendStateEvent","contentMap","recursiveMapToObject","queueToDevice","batch","MapWithDefault","Map","deviceId","payload","getOrCreate","set","encryptAndSendToDevices","userDeviceInfoArr","deviceInfo","checkTurnServers","getSyncState","syncState","state","oldState","Sync","transport","reply","servers","getTurnServers","onClientStopped","return","signal","addEventListener","server","urls","uris","username","credential","password","TurnServers","log","warn","removeEventListener","exports"],"sources":["../src/embedded.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport {\n WidgetApi,\n WidgetApiToWidgetAction,\n MatrixCapabilities,\n IWidgetApiRequest,\n IWidgetApiAcknowledgeResponseData,\n ISendEventToWidgetActionRequest,\n ISendToDeviceToWidgetActionRequest,\n ISendEventFromWidgetResponseData,\n} from \"matrix-widget-api\";\n\nimport { IEvent, IContent, EventStatus } from \"./models/event\";\nimport { ISendEventResponse } from \"./@types/requests\";\nimport { EventType } from \"./@types/event\";\nimport { logger } from \"./logger\";\nimport { MatrixClient, ClientEvent, IMatrixClientCreateOpts, IStartClientOpts, SendToDeviceContentMap } from \"./client\";\nimport { SyncApi, SyncState } from \"./sync\";\nimport { SlidingSyncSdk } from \"./sliding-sync-sdk\";\nimport { MatrixEvent } from \"./models/event\";\nimport { User } from \"./models/user\";\nimport { Room } from \"./models/room\";\nimport { ToDeviceBatch, ToDevicePayload } from \"./models/ToDeviceMessage\";\nimport { DeviceInfo } from \"./crypto/deviceinfo\";\nimport { IOlmDevice } from \"./crypto/algorithms/megolm\";\nimport { MapWithDefault, recursiveMapToObject } from \"./utils\";\n\ninterface IStateEventRequest {\n eventType: string;\n stateKey?: string;\n}\n\nexport interface ICapabilities {\n /**\n * Event types that this client expects to send.\n */\n sendEvent?: string[];\n /**\n * Event types that this client expects to receive.\n */\n receiveEvent?: string[];\n\n /**\n * Message types that this client expects to send, or true for all message\n * types.\n */\n sendMessage?: string[] | true;\n /**\n * Message types that this client expects to receive, or true for all\n * message types.\n */\n receiveMessage?: string[] | true;\n\n /**\n * Types of state events that this client expects to send.\n */\n sendState?: IStateEventRequest[];\n /**\n * Types of state events that this client expects to receive.\n */\n receiveState?: IStateEventRequest[];\n\n /**\n * To-device event types that this client expects to send.\n */\n sendToDevice?: string[];\n /**\n * To-device event types that this client expects to receive.\n */\n receiveToDevice?: string[];\n\n /**\n * Whether this client needs access to TURN servers.\n * @defaultValue false\n */\n turnServers?: boolean;\n}\n\n/**\n * A MatrixClient that routes its requests through the widget API instead of the\n * real CS API.\n * @experimental This class is considered unstable!\n */\nexport class RoomWidgetClient extends MatrixClient {\n private room?: Room;\n private widgetApiReady = new Promise((resolve) => this.widgetApi.once(\"ready\", resolve));\n private lifecycle?: AbortController;\n private syncState: SyncState | null = null;\n\n public constructor(\n private readonly widgetApi: WidgetApi,\n private readonly capabilities: ICapabilities,\n private readonly roomId: string,\n opts: IMatrixClientCreateOpts,\n ) {\n super(opts);\n\n // Request capabilities for the functionality this client needs to support\n if (\n capabilities.sendEvent?.length ||\n capabilities.receiveEvent?.length ||\n capabilities.sendMessage === true ||\n (Array.isArray(capabilities.sendMessage) && capabilities.sendMessage.length) ||\n capabilities.receiveMessage === true ||\n (Array.isArray(capabilities.receiveMessage) && capabilities.receiveMessage.length) ||\n capabilities.sendState?.length ||\n capabilities.receiveState?.length\n ) {\n widgetApi.requestCapabilityForRoomTimeline(roomId);\n }\n capabilities.sendEvent?.forEach((eventType) => widgetApi.requestCapabilityToSendEvent(eventType));\n capabilities.receiveEvent?.forEach((eventType) => widgetApi.requestCapabilityToReceiveEvent(eventType));\n if (capabilities.sendMessage === true) {\n widgetApi.requestCapabilityToSendMessage();\n } else if (Array.isArray(capabilities.sendMessage)) {\n capabilities.sendMessage.forEach((msgType) => widgetApi.requestCapabilityToSendMessage(msgType));\n }\n if (capabilities.receiveMessage === true) {\n widgetApi.requestCapabilityToReceiveMessage();\n } else if (Array.isArray(capabilities.receiveMessage)) {\n capabilities.receiveMessage.forEach((msgType) => widgetApi.requestCapabilityToReceiveMessage(msgType));\n }\n capabilities.sendState?.forEach(({ eventType, stateKey }) =>\n widgetApi.requestCapabilityToSendState(eventType, stateKey),\n );\n capabilities.receiveState?.forEach(({ eventType, stateKey }) =>\n widgetApi.requestCapabilityToReceiveState(eventType, stateKey),\n );\n capabilities.sendToDevice?.forEach((eventType) => widgetApi.requestCapabilityToSendToDevice(eventType));\n capabilities.receiveToDevice?.forEach((eventType) => widgetApi.requestCapabilityToReceiveToDevice(eventType));\n if (capabilities.turnServers) {\n widgetApi.requestCapability(MatrixCapabilities.MSC3846TurnServers);\n }\n\n widgetApi.on(`action:${WidgetApiToWidgetAction.SendEvent}`, this.onEvent);\n widgetApi.on(`action:${WidgetApiToWidgetAction.SendToDevice}`, this.onToDevice);\n\n // Open communication with the host\n widgetApi.start();\n }\n\n public async startClient(opts: IStartClientOpts = {}): Promise {\n this.lifecycle = new AbortController();\n\n // Create our own user object artificially (instead of waiting for sync)\n // so it's always available, even if the user is not in any rooms etc.\n const userId = this.getUserId();\n if (userId) {\n this.store.storeUser(new User(userId));\n }\n\n // Even though we have no access token and cannot sync, the sync class\n // still has some valuable helper methods that we make use of, so we\n // instantiate it anyways\n if (opts.slidingSync) {\n this.syncApi = new SlidingSyncSdk(opts.slidingSync, this, opts, this.buildSyncApiOptions());\n } else {\n this.syncApi = new SyncApi(this, opts, this.buildSyncApiOptions());\n }\n\n this.room = this.syncApi.createRoom(this.roomId);\n this.store.storeRoom(this.room);\n\n await this.widgetApiReady;\n\n // Backfill the requested events\n // We only get the most recent event for every type + state key combo,\n // so it doesn't really matter what order we inject them in\n await Promise.all(\n this.capabilities.receiveState?.map(async ({ eventType, stateKey }) => {\n const rawEvents = await this.widgetApi.readStateEvents(eventType, undefined, stateKey, [this.roomId]);\n const events = rawEvents.map((rawEvent) => new MatrixEvent(rawEvent as Partial));\n\n await this.syncApi!.injectRoomEvents(this.room!, [], events);\n events.forEach((event) => {\n this.emit(ClientEvent.Event, event);\n logger.info(`Backfilled event ${event.getId()} ${event.getType()} ${event.getStateKey()}`);\n });\n }) ?? [],\n );\n this.setSyncState(SyncState.Syncing);\n logger.info(\"Finished backfilling events\");\n\n // Watch for TURN servers, if requested\n if (this.capabilities.turnServers) this.watchTurnServers();\n }\n\n public stopClient(): void {\n this.widgetApi.off(`action:${WidgetApiToWidgetAction.SendEvent}`, this.onEvent);\n this.widgetApi.off(`action:${WidgetApiToWidgetAction.SendToDevice}`, this.onToDevice);\n\n super.stopClient();\n this.lifecycle!.abort(); // Signal to other async tasks that the client has stopped\n }\n\n public async joinRoom(roomIdOrAlias: string): Promise {\n if (roomIdOrAlias === this.roomId) return this.room!;\n throw new Error(`Unknown room: ${roomIdOrAlias}`);\n }\n\n protected async encryptAndSendEvent(room: Room, event: MatrixEvent): Promise {\n let response: ISendEventFromWidgetResponseData;\n try {\n response = await this.widgetApi.sendRoomEvent(event.getType(), event.getContent(), room.roomId);\n } catch (e) {\n this.updatePendingEventStatus(room, event, EventStatus.NOT_SENT);\n throw e;\n }\n\n room.updatePendingEvent(event, EventStatus.SENT, response.event_id);\n return { event_id: response.event_id };\n }\n\n public async sendStateEvent(\n roomId: string,\n eventType: string,\n content: any,\n stateKey = \"\",\n ): Promise {\n return await this.widgetApi.sendStateEvent(eventType, stateKey, content, roomId);\n }\n\n public async sendToDevice(eventType: string, contentMap: SendToDeviceContentMap): Promise<{}> {\n await this.widgetApi.sendToDevice(eventType, false, recursiveMapToObject(contentMap));\n return {};\n }\n\n public async queueToDevice({ eventType, batch }: ToDeviceBatch): Promise {\n // map: user Id → device Id → payload\n const contentMap: MapWithDefault> = new MapWithDefault(() => new Map());\n for (const { userId, deviceId, payload } of batch) {\n contentMap.getOrCreate(userId).set(deviceId, payload);\n }\n\n await this.widgetApi.sendToDevice(eventType, false, recursiveMapToObject(contentMap));\n }\n\n public async encryptAndSendToDevices(userDeviceInfoArr: IOlmDevice[], payload: object): Promise {\n // map: user Id → device Id → payload\n const contentMap: MapWithDefault> = new MapWithDefault(() => new Map());\n for (const {\n userId,\n deviceInfo: { deviceId },\n } of userDeviceInfoArr) {\n contentMap.getOrCreate(userId).set(deviceId, payload);\n }\n\n await this.widgetApi.sendToDevice((payload as { type: string }).type, true, recursiveMapToObject(contentMap));\n }\n\n // Overridden since we get TURN servers automatically over the widget API,\n // and this method would otherwise complain about missing an access token\n public async checkTurnServers(): Promise {\n return this.turnServers.length > 0;\n }\n\n // Overridden since we 'sync' manually without the sync API\n public getSyncState(): SyncState | null {\n return this.syncState;\n }\n\n private setSyncState(state: SyncState): void {\n const oldState = this.syncState;\n this.syncState = state;\n this.emit(ClientEvent.Sync, state, oldState);\n }\n\n private async ack(ev: CustomEvent): Promise {\n await this.widgetApi.transport.reply(ev.detail, {});\n }\n\n private onEvent = async (ev: CustomEvent): Promise => {\n ev.preventDefault();\n\n // Verify the room ID matches, since it's possible for the client to\n // send us events from other rooms if this widget is always on screen\n if (ev.detail.data.room_id === this.roomId) {\n const event = new MatrixEvent(ev.detail.data as Partial);\n await this.syncApi!.injectRoomEvents(this.room!, [], [event]);\n this.emit(ClientEvent.Event, event);\n this.setSyncState(SyncState.Syncing);\n logger.info(`Received event ${event.getId()} ${event.getType()} ${event.getStateKey()}`);\n } else {\n const { event_id: eventId, room_id: roomId } = ev.detail.data;\n logger.info(`Received event ${eventId} for a different room ${roomId}; discarding`);\n }\n\n await this.ack(ev);\n };\n\n private onToDevice = async (ev: CustomEvent): Promise => {\n ev.preventDefault();\n\n const event = new MatrixEvent({\n type: ev.detail.data.type,\n sender: ev.detail.data.sender,\n content: ev.detail.data.content as IContent,\n });\n // Mark the event as encrypted if it was, using fake contents and keys since those are unknown to us\n if (ev.detail.data.encrypted) event.makeEncrypted(EventType.RoomMessageEncrypted, {}, \"\", \"\");\n\n this.emit(ClientEvent.ToDeviceEvent, event);\n this.setSyncState(SyncState.Syncing);\n await this.ack(ev);\n };\n\n private async watchTurnServers(): Promise {\n const servers = this.widgetApi.getTurnServers();\n const onClientStopped = (): void => {\n servers.return(undefined);\n };\n this.lifecycle!.signal.addEventListener(\"abort\", onClientStopped);\n\n try {\n for await (const server of servers) {\n this.turnServers = [\n {\n urls: server.uris,\n username: server.username,\n credential: server.password,\n },\n ];\n this.emit(ClientEvent.TurnServers, this.turnServers);\n logger.log(`Received TURN server: ${server.uris}`);\n }\n } catch (e) {\n logger.warn(\"Error watching TURN servers\", e);\n } finally {\n this.lifecycle!.signal.removeEventListener(\"abort\", onClientStopped);\n }\n }\n}\n"],"mappings":";;;;;;;;AAgBA,IAAAA,gBAAA,GAAAC,OAAA;AAWA,IAAAC,MAAA,GAAAD,OAAA;AAEA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AACA,IAAAI,OAAA,GAAAJ,OAAA;AACA,IAAAK,KAAA,GAAAL,OAAA;AACA,IAAAM,eAAA,GAAAN,OAAA;AAEA,IAAAO,KAAA,GAAAP,OAAA;AAKA,IAAAQ,MAAA,GAAAR,OAAA;AAxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA+EA;AACA;AACA;AACA;AACA;AACO,MAAMS,gBAAgB,SAASC,oBAAY,CAAC;EAMxCC,WAAWA,CACGC,SAAoB,EACpBC,YAA2B,EAC3BC,MAAc,EAC/BC,IAA6B,EAC/B;IAAA,IAAAC,qBAAA,EAAAC,qBAAA,EAAAC,qBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,qBAAA,EAAAC,sBAAA;IACE,KAAK,CAACV,IAAI,CAAC;;IAEX;IAAA,KAPiBH,SAAoB,GAApBA,SAAoB;IAAA,KACpBC,YAA2B,GAA3BA,YAA2B;IAAA,KAC3BC,MAAc,GAAdA,MAAc;IAAA,IAAAY,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,0BAPV,IAAIC,OAAO,CAAQC,OAAO,IAAK,IAAI,CAACjB,SAAS,CAACkB,IAAI,CAAC,OAAO,EAAED,OAAO,CAAC,CAAC;IAAA,IAAAH,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,qBAExD,IAAI;IAAA,IAAAD,gBAAA,CAAAC,OAAA,mBAwLxB,MAAOI,EAAgD,IAAoB;MACzFA,EAAE,CAACC,cAAc,EAAE;;MAEnB;MACA;MACA,IAAID,EAAE,CAACE,MAAM,CAACC,IAAI,CAACC,OAAO,KAAK,IAAI,CAACrB,MAAM,EAAE;QACxC,MAAMsB,KAAK,GAAG,IAAIC,kBAAW,CAACN,EAAE,CAACE,MAAM,CAACC,IAAI,CAAoB;QAChE,MAAM,IAAI,CAACI,OAAO,CAAEC,gBAAgB,CAAC,IAAI,CAACC,IAAI,EAAG,EAAE,EAAE,CAACJ,KAAK,CAAC,CAAC;QAC7D,IAAI,CAACK,IAAI,CAACC,mBAAW,CAACC,KAAK,EAAEP,KAAK,CAAC;QACnC,IAAI,CAACQ,YAAY,CAACC,eAAS,CAACC,OAAO,CAAC;QACpCC,cAAM,CAACC,IAAI,CAAE,kBAAiBZ,KAAK,CAACa,KAAK,EAAG,IAAGb,KAAK,CAACc,OAAO,EAAG,IAAGd,KAAK,CAACe,WAAW,EAAG,EAAC,CAAC;MAC5F,CAAC,MAAM;QACH,MAAM;UAAEC,QAAQ,EAAEC,OAAO;UAAElB,OAAO,EAAErB;QAAO,CAAC,GAAGiB,EAAE,CAACE,MAAM,CAACC,IAAI;QAC7Da,cAAM,CAACC,IAAI,CAAE,kBAAiBK,OAAQ,yBAAwBvC,MAAO,cAAa,CAAC;MACvF;MAEA,MAAM,IAAI,CAACwC,GAAG,CAACvB,EAAE,CAAC;IACtB,CAAC;IAAA,IAAAL,gBAAA,CAAAC,OAAA,sBAEoB,MAAOI,EAAmD,IAAoB;MAC/FA,EAAE,CAACC,cAAc,EAAE;MAEnB,MAAMI,KAAK,GAAG,IAAIC,kBAAW,CAAC;QAC1BkB,IAAI,EAAExB,EAAE,CAACE,MAAM,CAACC,IAAI,CAACqB,IAAI;QACzBC,MAAM,EAAEzB,EAAE,CAACE,MAAM,CAACC,IAAI,CAACsB,MAAM;QAC7BC,OAAO,EAAE1B,EAAE,CAACE,MAAM,CAACC,IAAI,CAACuB;MAC5B,CAAC,CAAC;MACF;MACA,IAAI1B,EAAE,CAACE,MAAM,CAACC,IAAI,CAACwB,SAAS,EAAEtB,KAAK,CAACuB,aAAa,CAACC,iBAAS,CAACC,oBAAoB,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC;MAE7F,IAAI,CAACpB,IAAI,CAACC,mBAAW,CAACoB,aAAa,EAAE1B,KAAK,CAAC;MAC3C,IAAI,CAACQ,YAAY,CAACC,eAAS,CAACC,OAAO,CAAC;MACpC,MAAM,IAAI,CAACQ,GAAG,CAACvB,EAAE,CAAC;IACtB,CAAC;IA9MG,IACI,CAAAf,qBAAA,GAAAH,YAAY,CAACkD,SAAS,cAAA/C,qBAAA,eAAtBA,qBAAA,CAAwBgD,MAAM,KAAA/C,qBAAA,GAC9BJ,YAAY,CAACoD,YAAY,cAAAhD,qBAAA,eAAzBA,qBAAA,CAA2B+C,MAAM,IACjCnD,YAAY,CAACqD,WAAW,KAAK,IAAI,IAChCC,KAAK,CAACC,OAAO,CAACvD,YAAY,CAACqD,WAAW,CAAC,IAAIrD,YAAY,CAACqD,WAAW,CAACF,MAAO,IAC5EnD,YAAY,CAACwD,cAAc,KAAK,IAAI,IACnCF,KAAK,CAACC,OAAO,CAACvD,YAAY,CAACwD,cAAc,CAAC,IAAIxD,YAAY,CAACwD,cAAc,CAACL,MAAO,KAAA9C,qBAAA,GAClFL,YAAY,CAACyD,SAAS,cAAApD,qBAAA,eAAtBA,qBAAA,CAAwB8C,MAAM,KAAA7C,sBAAA,GAC9BN,YAAY,CAAC0D,YAAY,cAAApD,sBAAA,eAAzBA,sBAAA,CAA2B6C,MAAM,EACnC;MACEpD,SAAS,CAAC4D,gCAAgC,CAAC1D,MAAM,CAAC;IACtD;IACA,CAAAM,sBAAA,GAAAP,YAAY,CAACkD,SAAS,cAAA3C,sBAAA,uBAAtBA,sBAAA,CAAwBqD,OAAO,CAAEC,SAAS,IAAK9D,SAAS,CAAC+D,4BAA4B,CAACD,SAAS,CAAC,CAAC;IACjG,CAAArD,sBAAA,GAAAR,YAAY,CAACoD,YAAY,cAAA5C,sBAAA,uBAAzBA,sBAAA,CAA2BoD,OAAO,CAAEC,SAAS,IAAK9D,SAAS,CAACgE,+BAA+B,CAACF,SAAS,CAAC,CAAC;IACvG,IAAI7D,YAAY,CAACqD,WAAW,KAAK,IAAI,EAAE;MACnCtD,SAAS,CAACiE,8BAA8B,EAAE;IAC9C,CAAC,MAAM,IAAIV,KAAK,CAACC,OAAO,CAACvD,YAAY,CAACqD,WAAW,CAAC,EAAE;MAChDrD,YAAY,CAACqD,WAAW,CAACO,OAAO,CAAEK,OAAO,IAAKlE,SAAS,CAACiE,8BAA8B,CAACC,OAAO,CAAC,CAAC;IACpG;IACA,IAAIjE,YAAY,CAACwD,cAAc,KAAK,IAAI,EAAE;MACtCzD,SAAS,CAACmE,iCAAiC,EAAE;IACjD,CAAC,MAAM,IAAIZ,KAAK,CAACC,OAAO,CAACvD,YAAY,CAACwD,cAAc,CAAC,EAAE;MACnDxD,YAAY,CAACwD,cAAc,CAACI,OAAO,CAAEK,OAAO,IAAKlE,SAAS,CAACmE,iCAAiC,CAACD,OAAO,CAAC,CAAC;IAC1G;IACA,CAAAxD,sBAAA,GAAAT,YAAY,CAACyD,SAAS,cAAAhD,sBAAA,uBAAtBA,sBAAA,CAAwBmD,OAAO,CAAC,CAAC;MAAEC,SAAS;MAAEM;IAAS,CAAC,KACpDpE,SAAS,CAACqE,4BAA4B,CAACP,SAAS,EAAEM,QAAQ,CAAC,CAC9D;IACD,CAAAzD,sBAAA,GAAAV,YAAY,CAAC0D,YAAY,cAAAhD,sBAAA,uBAAzBA,sBAAA,CAA2BkD,OAAO,CAAC,CAAC;MAAEC,SAAS;MAAEM;IAAS,CAAC,KACvDpE,SAAS,CAACsE,+BAA+B,CAACR,SAAS,EAAEM,QAAQ,CAAC,CACjE;IACD,CAAAxD,qBAAA,GAAAX,YAAY,CAACsE,YAAY,cAAA3D,qBAAA,uBAAzBA,qBAAA,CAA2BiD,OAAO,CAAEC,SAAS,IAAK9D,SAAS,CAACwE,+BAA+B,CAACV,SAAS,CAAC,CAAC;IACvG,CAAAjD,sBAAA,GAAAZ,YAAY,CAACwE,eAAe,cAAA5D,sBAAA,uBAA5BA,sBAAA,CAA8BgD,OAAO,CAAEC,SAAS,IAAK9D,SAAS,CAAC0E,kCAAkC,CAACZ,SAAS,CAAC,CAAC;IAC7G,IAAI7D,YAAY,CAAC0E,WAAW,EAAE;MAC1B3E,SAAS,CAAC4E,iBAAiB,CAACC,mCAAkB,CAACC,kBAAkB,CAAC;IACtE;IAEA9E,SAAS,CAAC+E,EAAE,CAAE,UAASC,wCAAuB,CAACC,SAAU,EAAC,EAAE,IAAI,CAACC,OAAO,CAAC;IACzElF,SAAS,CAAC+E,EAAE,CAAE,UAASC,wCAAuB,CAACG,YAAa,EAAC,EAAE,IAAI,CAACC,UAAU,CAAC;;IAE/E;IACApF,SAAS,CAACqF,KAAK,EAAE;EACrB;EAEA,MAAaC,WAAWA,CAACnF,IAAsB,GAAG,CAAC,CAAC,EAAiB;IAAA,IAAAoF,qBAAA,EAAAC,sBAAA;IACjE,IAAI,CAACC,SAAS,GAAG,IAAIC,eAAe,EAAE;;IAEtC;IACA;IACA,MAAMC,MAAM,GAAG,IAAI,CAACC,SAAS,EAAE;IAC/B,IAAID,MAAM,EAAE;MACR,IAAI,CAACE,KAAK,CAACC,SAAS,CAAC,IAAIC,UAAI,CAACJ,MAAM,CAAC,CAAC;IAC1C;;IAEA;IACA;IACA;IACA,IAAIxF,IAAI,CAAC6F,WAAW,EAAE;MAClB,IAAI,CAACtE,OAAO,GAAG,IAAIuE,8BAAc,CAAC9F,IAAI,CAAC6F,WAAW,EAAE,IAAI,EAAE7F,IAAI,EAAE,IAAI,CAAC+F,mBAAmB,EAAE,CAAC;IAC/F,CAAC,MAAM;MACH,IAAI,CAACxE,OAAO,GAAG,IAAIyE,aAAO,CAAC,IAAI,EAAEhG,IAAI,EAAE,IAAI,CAAC+F,mBAAmB,EAAE,CAAC;IACtE;IAEA,IAAI,CAACtE,IAAI,GAAG,IAAI,CAACF,OAAO,CAAC0E,UAAU,CAAC,IAAI,CAAClG,MAAM,CAAC;IAChD,IAAI,CAAC2F,KAAK,CAACQ,SAAS,CAAC,IAAI,CAACzE,IAAI,CAAC;IAE/B,MAAM,IAAI,CAAC0E,cAAc;;IAEzB;IACA;IACA;IACA,MAAMtF,OAAO,CAACuF,GAAG,EAAAhB,qBAAA,IAAAC,sBAAA,GACb,IAAI,CAACvF,YAAY,CAAC0D,YAAY,cAAA6B,sBAAA,uBAA9BA,sBAAA,CAAgCgB,GAAG,CAAC,OAAO;MAAE1C,SAAS;MAAEM;IAAS,CAAC,KAAK;MACnE,MAAMqC,SAAS,GAAG,MAAM,IAAI,CAACzG,SAAS,CAAC0G,eAAe,CAAC5C,SAAS,EAAE6C,SAAS,EAAEvC,QAAQ,EAAE,CAAC,IAAI,CAAClE,MAAM,CAAC,CAAC;MACrG,MAAM0G,MAAM,GAAGH,SAAS,CAACD,GAAG,CAAEK,QAAQ,IAAK,IAAIpF,kBAAW,CAACoF,QAAQ,CAAoB,CAAC;MAExF,MAAM,IAAI,CAACnF,OAAO,CAAEC,gBAAgB,CAAC,IAAI,CAACC,IAAI,EAAG,EAAE,EAAEgF,MAAM,CAAC;MAC5DA,MAAM,CAAC/C,OAAO,CAAErC,KAAK,IAAK;QACtB,IAAI,CAACK,IAAI,CAACC,mBAAW,CAACC,KAAK,EAAEP,KAAK,CAAC;QACnCW,cAAM,CAACC,IAAI,CAAE,oBAAmBZ,KAAK,CAACa,KAAK,EAAG,IAAGb,KAAK,CAACc,OAAO,EAAG,IAAGd,KAAK,CAACe,WAAW,EAAG,EAAC,CAAC;MAC9F,CAAC,CAAC;IACN,CAAC,CAAC,cAAAgD,qBAAA,cAAAA,qBAAA,GAAI,EAAE,CACX;IACD,IAAI,CAACvD,YAAY,CAACC,eAAS,CAACC,OAAO,CAAC;IACpCC,cAAM,CAACC,IAAI,CAAC,6BAA6B,CAAC;;IAE1C;IACA,IAAI,IAAI,CAACnC,YAAY,CAAC0E,WAAW,EAAE,IAAI,CAACmC,gBAAgB,EAAE;EAC9D;EAEOC,UAAUA,CAAA,EAAS;IACtB,IAAI,CAAC/G,SAAS,CAACgH,GAAG,CAAE,UAAShC,wCAAuB,CAACC,SAAU,EAAC,EAAE,IAAI,CAACC,OAAO,CAAC;IAC/E,IAAI,CAAClF,SAAS,CAACgH,GAAG,CAAE,UAAShC,wCAAuB,CAACG,YAAa,EAAC,EAAE,IAAI,CAACC,UAAU,CAAC;IAErF,KAAK,CAAC2B,UAAU,EAAE;IAClB,IAAI,CAACtB,SAAS,CAAEwB,KAAK,EAAE,CAAC,CAAC;EAC7B;;EAEA,MAAaC,QAAQA,CAACC,aAAqB,EAAiB;IACxD,IAAIA,aAAa,KAAK,IAAI,CAACjH,MAAM,EAAE,OAAO,IAAI,CAAC0B,IAAI;IACnD,MAAM,IAAIwF,KAAK,CAAE,iBAAgBD,aAAc,EAAC,CAAC;EACrD;EAEA,MAAgBE,mBAAmBA,CAACzF,IAAU,EAAEJ,KAAkB,EAA+B;IAC7F,IAAI8F,QAA0C;IAC9C,IAAI;MACAA,QAAQ,GAAG,MAAM,IAAI,CAACtH,SAAS,CAACuH,aAAa,CAAC/F,KAAK,CAACc,OAAO,EAAE,EAAEd,KAAK,CAACgG,UAAU,EAAE,EAAE5F,IAAI,CAAC1B,MAAM,CAAC;IACnG,CAAC,CAAC,OAAOuH,CAAC,EAAE;MACR,IAAI,CAACC,wBAAwB,CAAC9F,IAAI,EAAEJ,KAAK,EAAEmG,kBAAW,CAACC,QAAQ,CAAC;MAChE,MAAMH,CAAC;IACX;IAEA7F,IAAI,CAACiG,kBAAkB,CAACrG,KAAK,EAAEmG,kBAAW,CAACG,IAAI,EAAER,QAAQ,CAAC9E,QAAQ,CAAC;IACnE,OAAO;MAAEA,QAAQ,EAAE8E,QAAQ,CAAC9E;IAAS,CAAC;EAC1C;EAEA,MAAauF,cAAcA,CACvB7H,MAAc,EACd4D,SAAiB,EACjBjB,OAAY,EACZuB,QAAQ,GAAG,EAAE,EACc;IAC3B,OAAO,MAAM,IAAI,CAACpE,SAAS,CAAC+H,cAAc,CAACjE,SAAS,EAAEM,QAAQ,EAAEvB,OAAO,EAAE3C,MAAM,CAAC;EACpF;EAEA,MAAaqE,YAAYA,CAACT,SAAiB,EAAEkE,UAAkC,EAAe;IAC1F,MAAM,IAAI,CAAChI,SAAS,CAACuE,YAAY,CAACT,SAAS,EAAE,KAAK,EAAE,IAAAmE,2BAAoB,EAACD,UAAU,CAAC,CAAC;IACrF,OAAO,CAAC,CAAC;EACb;EAEA,MAAaE,aAAaA,CAAC;IAAEpE,SAAS;IAAEqE;EAAqB,CAAC,EAAiB;IAC3E;IACA,MAAMH,UAAgE,GAAG,IAAII,qBAAc,CAAC,MAAM,IAAIC,GAAG,EAAE,CAAC;IAC5G,KAAK,MAAM;MAAE1C,MAAM;MAAE2C,QAAQ;MAAEC;IAAQ,CAAC,IAAIJ,KAAK,EAAE;MAC/CH,UAAU,CAACQ,WAAW,CAAC7C,MAAM,CAAC,CAAC8C,GAAG,CAACH,QAAQ,EAAEC,OAAO,CAAC;IACzD;IAEA,MAAM,IAAI,CAACvI,SAAS,CAACuE,YAAY,CAACT,SAAS,EAAE,KAAK,EAAE,IAAAmE,2BAAoB,EAACD,UAAU,CAAC,CAAC;EACzF;EAEA,MAAaU,uBAAuBA,CAACC,iBAA2C,EAAEJ,OAAe,EAAiB;IAC9G;IACA,MAAMP,UAAuD,GAAG,IAAII,qBAAc,CAAC,MAAM,IAAIC,GAAG,EAAE,CAAC;IACnG,KAAK,MAAM;MACP1C,MAAM;MACNiD,UAAU,EAAE;QAAEN;MAAS;IAC3B,CAAC,IAAIK,iBAAiB,EAAE;MACpBX,UAAU,CAACQ,WAAW,CAAC7C,MAAM,CAAC,CAAC8C,GAAG,CAACH,QAAQ,EAAEC,OAAO,CAAC;IACzD;IAEA,MAAM,IAAI,CAACvI,SAAS,CAACuE,YAAY,CAAEgE,OAAO,CAAsB5F,IAAI,EAAE,IAAI,EAAE,IAAAsF,2BAAoB,EAACD,UAAU,CAAC,CAAC;EACjH;;EAEA;EACA;EACA,MAAaa,gBAAgBA,CAAA,EAAqB;IAC9C,OAAO,IAAI,CAAClE,WAAW,CAACvB,MAAM,GAAG,CAAC;EACtC;;EAEA;EACO0F,YAAYA,CAAA,EAAqB;IACpC,OAAO,IAAI,CAACC,SAAS;EACzB;EAEQ/G,YAAYA,CAACgH,KAAgB,EAAQ;IACzC,MAAMC,QAAQ,GAAG,IAAI,CAACF,SAAS;IAC/B,IAAI,CAACA,SAAS,GAAGC,KAAK;IACtB,IAAI,CAACnH,IAAI,CAACC,mBAAW,CAACoH,IAAI,EAAEF,KAAK,EAAEC,QAAQ,CAAC;EAChD;EAEA,MAAcvG,GAAGA,CAACvB,EAAkC,EAAiB;IACjE,MAAM,IAAI,CAACnB,SAAS,CAACmJ,SAAS,CAACC,KAAK,CAAoCjI,EAAE,CAACE,MAAM,EAAE,CAAC,CAAC,CAAC;EAC1F;EAqCA,MAAcyF,gBAAgBA,CAAA,EAAkB;IAC5C,MAAMuC,OAAO,GAAG,IAAI,CAACrJ,SAAS,CAACsJ,cAAc,EAAE;IAC/C,MAAMC,eAAe,GAAGA,CAAA,KAAY;MAChCF,OAAO,CAACG,MAAM,CAAC7C,SAAS,CAAC;IAC7B,CAAC;IACD,IAAI,CAAClB,SAAS,CAAEgE,MAAM,CAACC,gBAAgB,CAAC,OAAO,EAAEH,eAAe,CAAC;IAEjE,IAAI;MACA,WAAW,MAAMI,MAAM,IAAIN,OAAO,EAAE;QAChC,IAAI,CAAC1E,WAAW,GAAG,CACf;UACIiF,IAAI,EAAED,MAAM,CAACE,IAAI;UACjBC,QAAQ,EAAEH,MAAM,CAACG,QAAQ;UACzBC,UAAU,EAAEJ,MAAM,CAACK;QACvB,CAAC,CACJ;QACD,IAAI,CAACnI,IAAI,CAACC,mBAAW,CAACmI,WAAW,EAAE,IAAI,CAACtF,WAAW,CAAC;QACpDxC,cAAM,CAAC+H,GAAG,CAAE,yBAAwBP,MAAM,CAACE,IAAK,EAAC,CAAC;MACtD;IACJ,CAAC,CAAC,OAAOpC,CAAC,EAAE;MACRtF,cAAM,CAACgI,IAAI,CAAC,6BAA6B,EAAE1C,CAAC,CAAC;IACjD,CAAC,SAAS;MACN,IAAI,CAAChC,SAAS,CAAEgE,MAAM,CAACW,mBAAmB,CAAC,OAAO,EAAEb,eAAe,CAAC;IACxE;EACJ;AACJ;AAACc,OAAA,CAAAxK,gBAAA,GAAAA,gBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts deleted file mode 100644 index 3cc9ee1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts +++ /dev/null @@ -1,22 +0,0 @@ -export declare enum InvalidStoreState { - ToggledLazyLoading = 0 -} -export declare class InvalidStoreError extends Error { - readonly reason: InvalidStoreState; - readonly value: any; - static TOGGLED_LAZY_LOADING: InvalidStoreState; - constructor(reason: InvalidStoreState, value: any); -} -export declare enum InvalidCryptoStoreState { - TooNew = "TOO_NEW" -} -export declare class InvalidCryptoStoreError extends Error { - readonly reason: InvalidCryptoStoreState; - static TOO_NEW: InvalidCryptoStoreState; - constructor(reason: InvalidCryptoStoreState); -} -export declare class KeySignatureUploadError extends Error { - readonly value: any; - constructor(message: string, value: any); -} -//# sourceMappingURL=errors.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts.map deleted file mode 100644 index c083ce6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAgBA,oBAAY,iBAAiB;IACzB,kBAAkB,IAAA;CACrB;AAED,qBAAa,iBAAkB,SAAQ,KAAK;aAGL,MAAM,EAAE,iBAAiB;aAAkB,KAAK,EAAE,GAAG;IAFxF,OAAc,oBAAoB,oBAAwC;gBAEvC,MAAM,EAAE,iBAAiB,EAAkB,KAAK,EAAE,GAAG;CAO3F;AAED,oBAAY,uBAAuB;IAC/B,MAAM,YAAY;CACrB;AAED,qBAAa,uBAAwB,SAAQ,KAAK;aAGX,MAAM,EAAE,uBAAuB;IAFlE,OAAc,OAAO,0BAAkC;gBAEpB,MAAM,EAAE,uBAAuB;CAOrE;AAED,qBAAa,uBAAwB,SAAQ,KAAK;aACM,KAAK,EAAE,GAAG;gBAA3C,OAAO,EAAE,MAAM,EAAkB,KAAK,EAAE,GAAG;CAGjE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js deleted file mode 100644 index f614f3f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js +++ /dev/null @@ -1,62 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.KeySignatureUploadError = exports.InvalidStoreState = exports.InvalidStoreError = exports.InvalidCryptoStoreState = exports.InvalidCryptoStoreError = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let InvalidStoreState; -exports.InvalidStoreState = InvalidStoreState; -(function (InvalidStoreState) { - InvalidStoreState[InvalidStoreState["ToggledLazyLoading"] = 0] = "ToggledLazyLoading"; -})(InvalidStoreState || (exports.InvalidStoreState = InvalidStoreState = {})); -class InvalidStoreError extends Error { - constructor(reason, value) { - const message = `Store is invalid because ${reason}, ` + `please stop the client, delete all data and start the client again`; - super(message); - this.reason = reason; - this.value = value; - this.name = "InvalidStoreError"; - } -} -exports.InvalidStoreError = InvalidStoreError; -(0, _defineProperty2.default)(InvalidStoreError, "TOGGLED_LAZY_LOADING", InvalidStoreState.ToggledLazyLoading); -let InvalidCryptoStoreState; -exports.InvalidCryptoStoreState = InvalidCryptoStoreState; -(function (InvalidCryptoStoreState) { - InvalidCryptoStoreState["TooNew"] = "TOO_NEW"; -})(InvalidCryptoStoreState || (exports.InvalidCryptoStoreState = InvalidCryptoStoreState = {})); -class InvalidCryptoStoreError extends Error { - constructor(reason) { - const message = `Crypto store is invalid because ${reason}, ` + `please stop the client, delete all data and start the client again`; - super(message); - this.reason = reason; - this.name = "InvalidCryptoStoreError"; - } -} -exports.InvalidCryptoStoreError = InvalidCryptoStoreError; -(0, _defineProperty2.default)(InvalidCryptoStoreError, "TOO_NEW", InvalidCryptoStoreState.TooNew); -class KeySignatureUploadError extends Error { - constructor(message, value) { - super(message); - this.value = value; - } -} -exports.KeySignatureUploadError = KeySignatureUploadError; -//# sourceMappingURL=errors.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js.map deleted file mode 100644 index 1dd02b3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/errors.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"errors.js","names":["InvalidStoreState","exports","InvalidStoreError","Error","constructor","reason","value","message","name","_defineProperty2","default","ToggledLazyLoading","InvalidCryptoStoreState","InvalidCryptoStoreError","TooNew","KeySignatureUploadError"],"sources":["../src/errors.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport enum InvalidStoreState {\n ToggledLazyLoading,\n}\n\nexport class InvalidStoreError extends Error {\n public static TOGGLED_LAZY_LOADING = InvalidStoreState.ToggledLazyLoading;\n\n public constructor(public readonly reason: InvalidStoreState, public readonly value: any) {\n const message =\n `Store is invalid because ${reason}, ` +\n `please stop the client, delete all data and start the client again`;\n super(message);\n this.name = \"InvalidStoreError\";\n }\n}\n\nexport enum InvalidCryptoStoreState {\n TooNew = \"TOO_NEW\",\n}\n\nexport class InvalidCryptoStoreError extends Error {\n public static TOO_NEW = InvalidCryptoStoreState.TooNew;\n\n public constructor(public readonly reason: InvalidCryptoStoreState) {\n const message =\n `Crypto store is invalid because ${reason}, ` +\n `please stop the client, delete all data and start the client again`;\n super(message);\n this.name = \"InvalidCryptoStoreError\";\n }\n}\n\nexport class KeySignatureUploadError extends Error {\n public constructor(message: string, public readonly value: any) {\n super(message);\n }\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAgBYA,iBAAiB;AAAAC,OAAA,CAAAD,iBAAA,GAAAA,iBAAA;AAAA,WAAjBA,iBAAiB;EAAjBA,iBAAiB,CAAjBA,iBAAiB;AAAA,GAAjBA,iBAAiB,KAAAC,OAAA,CAAAD,iBAAA,GAAjBA,iBAAiB;AAItB,MAAME,iBAAiB,SAASC,KAAK,CAAC;EAGlCC,WAAWA,CAAiBC,MAAyB,EAAkBC,KAAU,EAAE;IACtF,MAAMC,OAAO,GACR,4BAA2BF,MAAO,IAAG,GACrC,oEAAmE;IACxE,KAAK,CAACE,OAAO,CAAC;IAAC,KAJgBF,MAAyB,GAAzBA,MAAyB;IAAA,KAAkBC,KAAU,GAAVA,KAAU;IAKpF,IAAI,CAACE,IAAI,GAAG,mBAAmB;EACnC;AACJ;AAACP,OAAA,CAAAC,iBAAA,GAAAA,iBAAA;AAAA,IAAAO,gBAAA,CAAAC,OAAA,EAVYR,iBAAiB,0BACWF,iBAAiB,CAACW,kBAAkB;AAAA,IAWjEC,uBAAuB;AAAAX,OAAA,CAAAW,uBAAA,GAAAA,uBAAA;AAAA,WAAvBA,uBAAuB;EAAvBA,uBAAuB;AAAA,GAAvBA,uBAAuB,KAAAX,OAAA,CAAAW,uBAAA,GAAvBA,uBAAuB;AAI5B,MAAMC,uBAAuB,SAASV,KAAK,CAAC;EAGxCC,WAAWA,CAAiBC,MAA+B,EAAE;IAChE,MAAME,OAAO,GACR,mCAAkCF,MAAO,IAAG,GAC5C,oEAAmE;IACxE,KAAK,CAACE,OAAO,CAAC;IAAC,KAJgBF,MAA+B,GAA/BA,MAA+B;IAK9D,IAAI,CAACG,IAAI,GAAG,yBAAyB;EACzC;AACJ;AAACP,OAAA,CAAAY,uBAAA,GAAAA,uBAAA;AAAA,IAAAJ,gBAAA,CAAAC,OAAA,EAVYG,uBAAuB,aACRD,uBAAuB,CAACE,MAAM;AAWnD,MAAMC,uBAAuB,SAASZ,KAAK,CAAC;EACxCC,WAAWA,CAACG,OAAe,EAAkBD,KAAU,EAAE;IAC5D,KAAK,CAACC,OAAO,CAAC;IAAC,KADiCD,KAAU,GAAVA,KAAU;EAE9D;AACJ;AAACL,OAAA,CAAAc,uBAAA,GAAAA,uBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts deleted file mode 100644 index 24af3fc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -import { MatrixClient } from "./client"; -import { IEvent, MatrixEvent } from "./models/event"; -export type EventMapper = (obj: Partial) => MatrixEvent; -export interface MapperOpts { - preventReEmit?: boolean; - decrypt?: boolean; - toDevice?: boolean; -} -export declare function eventMapperFor(client: MatrixClient, options: MapperOpts): EventMapper; -//# sourceMappingURL=event-mapper.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts.map deleted file mode 100644 index 4137b3b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-mapper.d.ts","sourceRoot":"","sources":["../src/event-mapper.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAoB,MAAM,gBAAgB,CAAC;AAGvE,MAAM,MAAM,WAAW,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,MAAM,CAAC,KAAK,WAAW,CAAC;AAEhE,MAAM,WAAW,UAAU;IAEvB,aAAa,CAAC,EAAE,OAAO,CAAC;IAExB,OAAO,CAAC,EAAE,OAAO,CAAC;IAElB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,UAAU,GAAG,WAAW,CAiErF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js deleted file mode 100644 index c020dc2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js +++ /dev/null @@ -1,72 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.eventMapperFor = eventMapperFor; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _event = require("./models/event"); -var _event2 = require("./@types/event"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -function eventMapperFor(client, options) { - let preventReEmit = Boolean(options.preventReEmit); - const decrypt = options.decrypt !== false; - function mapper(plainOldJsObject) { - if (options.toDevice) { - delete plainOldJsObject.room_id; - } - const room = client.getRoom(plainOldJsObject.room_id); - let event; - // If the event is already known to the room, let's re-use the model rather than duplicating. - // We avoid doing this to state events as they may be forward or backwards looking which tweaks behaviour. - if (room && plainOldJsObject.state_key === undefined) { - event = room.findEventById(plainOldJsObject.event_id); - } - if (!event || event.status) { - event = new _event.MatrixEvent(plainOldJsObject); - } else { - // merge the latest unsigned data from the server - event.setUnsigned(_objectSpread(_objectSpread({}, event.getUnsigned()), plainOldJsObject.unsigned)); - // prevent doubling up re-emitters - preventReEmit = true; - } - - // if there is a complete edit bundled alongside the event, perform the replacement. - // (prior to MSC3925, events were automatically replaced on the server-side. MSC3925 proposes that that doesn't - // happen automatically but the server does provide us with the whole content of the edit event.) - const bundledEdit = event.getServerAggregatedRelation(_event2.RelationType.Replace); - if (bundledEdit !== null && bundledEdit !== void 0 && bundledEdit.content) { - const replacement = mapper(bundledEdit); - // XXX: it's worth noting that the spec says we should only respect encrypted edits if, once decrypted, the - // replacement has a `m.new_content` property. The problem is that we haven't yet decrypted the replacement - // (it should be happening in the background), so we can't enforce this. Possibly we should for decryption - // to complete, but that sounds a bit racy. For now, we just assume it's ok. - event.makeReplaced(replacement); - } - const thread = room === null || room === void 0 ? void 0 : room.findThreadForEvent(event); - if (thread) { - event.setThread(thread); - } - - // TODO: once we get rid of the old libolm-backed crypto, we can restrict this to room events (rather than - // to-device events), because the rust implementation decrypts to-device messages at a higher level. - // Generally we probably want to use a different eventMapper implementation for to-device events because - if (event.isEncrypted()) { - if (!preventReEmit) { - client.reEmitter.reEmit(event, [_event.MatrixEventEvent.Decrypted]); - } - if (decrypt) { - client.decryptEventIfNeeded(event); - } - } - if (!preventReEmit) { - client.reEmitter.reEmit(event, [_event.MatrixEventEvent.Replaced, _event.MatrixEventEvent.VisibilityChange]); - room === null || room === void 0 ? void 0 : room.reEmitter.reEmit(event, [_event.MatrixEventEvent.BeforeRedaction]); - } - return event; - } - return mapper; -} -//# sourceMappingURL=event-mapper.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js.map deleted file mode 100644 index c33ab23..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/event-mapper.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-mapper.js","names":["_event","require","_event2","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","eventMapperFor","client","options","preventReEmit","Boolean","decrypt","mapper","plainOldJsObject","toDevice","room_id","room","getRoom","event","state_key","undefined","findEventById","event_id","status","MatrixEvent","setUnsigned","getUnsigned","unsigned","bundledEdit","getServerAggregatedRelation","RelationType","Replace","content","replacement","makeReplaced","thread","findThreadForEvent","setThread","isEncrypted","reEmitter","reEmit","MatrixEventEvent","Decrypted","decryptEventIfNeeded","Replaced","VisibilityChange","BeforeRedaction"],"sources":["../src/event-mapper.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixClient } from \"./client\";\nimport { IEvent, MatrixEvent, MatrixEventEvent } from \"./models/event\";\nimport { RelationType } from \"./@types/event\";\n\nexport type EventMapper = (obj: Partial) => MatrixEvent;\n\nexport interface MapperOpts {\n // don't re-emit events emitted on an event mapped by this mapper on the client\n preventReEmit?: boolean;\n // decrypt event proactively\n decrypt?: boolean;\n // the event is a to_device event\n toDevice?: boolean;\n}\n\nexport function eventMapperFor(client: MatrixClient, options: MapperOpts): EventMapper {\n let preventReEmit = Boolean(options.preventReEmit);\n const decrypt = options.decrypt !== false;\n\n function mapper(plainOldJsObject: Partial): MatrixEvent {\n if (options.toDevice) {\n delete plainOldJsObject.room_id;\n }\n\n const room = client.getRoom(plainOldJsObject.room_id);\n\n let event: MatrixEvent | undefined;\n // If the event is already known to the room, let's re-use the model rather than duplicating.\n // We avoid doing this to state events as they may be forward or backwards looking which tweaks behaviour.\n if (room && plainOldJsObject.state_key === undefined) {\n event = room.findEventById(plainOldJsObject.event_id!);\n }\n\n if (!event || event.status) {\n event = new MatrixEvent(plainOldJsObject);\n } else {\n // merge the latest unsigned data from the server\n event.setUnsigned({ ...event.getUnsigned(), ...plainOldJsObject.unsigned });\n // prevent doubling up re-emitters\n preventReEmit = true;\n }\n\n // if there is a complete edit bundled alongside the event, perform the replacement.\n // (prior to MSC3925, events were automatically replaced on the server-side. MSC3925 proposes that that doesn't\n // happen automatically but the server does provide us with the whole content of the edit event.)\n const bundledEdit = event.getServerAggregatedRelation>(RelationType.Replace);\n if (bundledEdit?.content) {\n const replacement = mapper(bundledEdit);\n // XXX: it's worth noting that the spec says we should only respect encrypted edits if, once decrypted, the\n // replacement has a `m.new_content` property. The problem is that we haven't yet decrypted the replacement\n // (it should be happening in the background), so we can't enforce this. Possibly we should for decryption\n // to complete, but that sounds a bit racy. For now, we just assume it's ok.\n event.makeReplaced(replacement);\n }\n\n const thread = room?.findThreadForEvent(event);\n if (thread) {\n event.setThread(thread);\n }\n\n // TODO: once we get rid of the old libolm-backed crypto, we can restrict this to room events (rather than\n // to-device events), because the rust implementation decrypts to-device messages at a higher level.\n // Generally we probably want to use a different eventMapper implementation for to-device events because\n if (event.isEncrypted()) {\n if (!preventReEmit) {\n client.reEmitter.reEmit(event, [MatrixEventEvent.Decrypted]);\n }\n if (decrypt) {\n client.decryptEventIfNeeded(event);\n }\n }\n\n if (!preventReEmit) {\n client.reEmitter.reEmit(event, [MatrixEventEvent.Replaced, MatrixEventEvent.VisibilityChange]);\n room?.reEmitter.reEmit(event, [MatrixEventEvent.BeforeRedaction]);\n }\n return event;\n }\n\n return mapper;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts deleted file mode 100644 index 75cd64a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts +++ /dev/null @@ -1,38 +0,0 @@ -import { ExtensibleEventType, IPartialEvent } from "../@types/extensible_events"; -/** - * Represents an Extensible Event in Matrix. - */ -export declare abstract class ExtensibleEvent { - readonly wireFormat: IPartialEvent; - protected constructor(wireFormat: IPartialEvent); - /** - * Shortcut to wireFormat.content - */ - get wireContent(): TContent; - /** - * Serializes the event into a format which can be used to send the - * event to the room. - * @returns The serialized event. - */ - abstract serialize(): IPartialEvent; - /** - * Determines if this event is equivalent to the provided event type. - * This is recommended over `instanceof` checks due to issues in the JS - * runtime (and layering of dependencies in some projects). - * - * Implementations should pass this check off to their super classes - * if their own checks fail. Some primary implementations do not extend - * fallback classes given they support the primary type first. Thus, - * those classes may return false if asked about their fallback - * representation. - * - * Note that this only checks primary event types: legacy events, like - * m.room.message, should/will fail this check. - * @param primaryEventType - The (potentially namespaced) event - * type. - * @returns True if this event *could* be represented as the - * given type. - */ - abstract isEquivalentTo(primaryEventType: ExtensibleEventType): boolean; -} -//# sourceMappingURL=ExtensibleEvent.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts.map deleted file mode 100644 index 7849c73..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ExtensibleEvent.d.ts","sourceRoot":"","sources":["../../src/extensible_events_v1/ExtensibleEvent.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAEjF;;GAEG;AACH,8BAAsB,eAAe,CAAC,QAAQ,SAAS,MAAM,GAAG,MAAM;aAC5B,UAAU,EAAE,aAAa,CAAC,QAAQ,CAAC;IAAzE,SAAS,aAA6B,UAAU,EAAE,aAAa,CAAC,QAAQ,CAAC;IAEzE;;OAEG;IACH,IAAW,WAAW,IAAI,QAAQ,CAEjC;IAED;;;;OAIG;aACa,SAAS,IAAI,aAAa,CAAC,MAAM,CAAC;IAElD;;;;;;;;;;;;;;;;;OAiBG;aACa,cAAc,CAAC,gBAAgB,EAAE,mBAAmB,GAAG,OAAO;CACjF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js deleted file mode 100644 index 82fa0a8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js +++ /dev/null @@ -1,45 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ExtensibleEvent = void 0; -/* -Copyright 2021 - 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Represents an Extensible Event in Matrix. - */ -class ExtensibleEvent { - constructor(wireFormat) { - this.wireFormat = wireFormat; - } - - /** - * Shortcut to wireFormat.content - */ - get wireContent() { - return this.wireFormat.content; - } - - /** - * Serializes the event into a format which can be used to send the - * event to the room. - * @returns The serialized event. - */ -} -exports.ExtensibleEvent = ExtensibleEvent; -//# sourceMappingURL=ExtensibleEvent.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js.map deleted file mode 100644 index a73e309..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/ExtensibleEvent.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ExtensibleEvent.js","names":["ExtensibleEvent","constructor","wireFormat","wireContent","content","exports"],"sources":["../../src/extensible_events_v1/ExtensibleEvent.ts"],"sourcesContent":["/*\nCopyright 2021 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ExtensibleEventType, IPartialEvent } from \"../@types/extensible_events\";\n\n/**\n * Represents an Extensible Event in Matrix.\n */\nexport abstract class ExtensibleEvent {\n protected constructor(public readonly wireFormat: IPartialEvent) {}\n\n /**\n * Shortcut to wireFormat.content\n */\n public get wireContent(): TContent {\n return this.wireFormat.content;\n }\n\n /**\n * Serializes the event into a format which can be used to send the\n * event to the room.\n * @returns The serialized event.\n */\n public abstract serialize(): IPartialEvent;\n\n /**\n * Determines if this event is equivalent to the provided event type.\n * This is recommended over `instanceof` checks due to issues in the JS\n * runtime (and layering of dependencies in some projects).\n *\n * Implementations should pass this check off to their super classes\n * if their own checks fail. Some primary implementations do not extend\n * fallback classes given they support the primary type first. Thus,\n * those classes may return false if asked about their fallback\n * representation.\n *\n * Note that this only checks primary event types: legacy events, like\n * m.room.message, should/will fail this check.\n * @param primaryEventType - The (potentially namespaced) event\n * type.\n * @returns True if this event *could* be represented as the\n * given type.\n */\n public abstract isEquivalentTo(primaryEventType: ExtensibleEventType): boolean;\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIA;AACA;AACA;AACO,MAAeA,eAAe,CAAmC;EAC1DC,WAAWA,CAAiBC,UAAmC,EAAE;IAAA,KAArCA,UAAmC,GAAnCA,UAAmC;EAAG;;EAE5E;AACJ;AACA;EACI,IAAWC,WAAWA,CAAA,EAAa;IAC/B,OAAO,IAAI,CAACD,UAAU,CAACE,OAAO;EAClC;;EAEA;AACJ;AACA;AACA;AACA;AAsBA;AAACC,OAAA,CAAAL,eAAA,GAAAA,eAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts deleted file mode 100644 index ee5e276..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts +++ /dev/null @@ -1,7 +0,0 @@ -/** - * Thrown when an event is unforgivably unparsable. - */ -export declare class InvalidEventError extends Error { - constructor(message: string); -} -//# sourceMappingURL=InvalidEventError.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts.map deleted file mode 100644 index a3d9cf0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"InvalidEventError.d.ts","sourceRoot":"","sources":["../../src/extensible_events_v1/InvalidEventError.ts"],"names":[],"mappings":"AAgBA;;GAEG;AACH,qBAAa,iBAAkB,SAAQ,KAAK;gBACrB,OAAO,EAAE,MAAM;CAGrC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js deleted file mode 100644 index fd1740a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js +++ /dev/null @@ -1,32 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.InvalidEventError = void 0; -/* -Copyright 2022 - 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Thrown when an event is unforgivably unparsable. - */ -class InvalidEventError extends Error { - constructor(message) { - super(message); - } -} -exports.InvalidEventError = InvalidEventError; -//# sourceMappingURL=InvalidEventError.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js.map deleted file mode 100644 index 2469740..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/InvalidEventError.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"InvalidEventError.js","names":["InvalidEventError","Error","constructor","message","exports"],"sources":["../../src/extensible_events_v1/InvalidEventError.ts"],"sourcesContent":["/*\nCopyright 2022 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Thrown when an event is unforgivably unparsable.\n */\nexport class InvalidEventError extends Error {\n public constructor(message: string) {\n super(message);\n }\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACO,MAAMA,iBAAiB,SAASC,KAAK,CAAC;EAClCC,WAAWA,CAACC,OAAe,EAAE;IAChC,KAAK,CAACA,OAAO,CAAC;EAClB;AACJ;AAACC,OAAA,CAAAJ,iBAAA,GAAAA,iBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts deleted file mode 100644 index 0d67fcd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts +++ /dev/null @@ -1,45 +0,0 @@ -import { Optional } from "matrix-events-sdk"; -import { ExtensibleEvent } from "./ExtensibleEvent"; -import { ExtensibleEventType, IMessageRendering, IPartialEvent, ExtensibleAnyMessageEventContent } from "../@types/extensible_events"; -/** - * Represents a message event. Message events are the simplest form of event with - * just text (optionally of different mimetypes, like HTML). - * - * Message events can additionally be an Emote or Notice, though typically those - * are represented as EmoteEvent and NoticeEvent respectively. - */ -export declare class MessageEvent extends ExtensibleEvent { - /** - * The default text for the event. - */ - readonly text: string; - /** - * The default HTML for the event, if provided. - */ - readonly html: Optional; - /** - * All the different renderings of the message. Note that this is the same - * format as an m.message body but may contain elements not found directly - * in the event content: this is because this is interpreted based off the - * other information available in the event. - */ - readonly renderings: IMessageRendering[]; - /** - * Creates a new MessageEvent from a pure format. Note that the event is - * *not* parsed here: it will be treated as a literal m.message primary - * typed event. - * @param wireFormat - The event. - */ - constructor(wireFormat: IPartialEvent); - isEquivalentTo(primaryEventType: ExtensibleEventType): boolean; - protected serializeMMessageOnly(): ExtensibleAnyMessageEventContent; - serialize(): IPartialEvent; - /** - * Creates a new MessageEvent from text and HTML. - * @param text - The text. - * @param html - Optional HTML. - * @returns The representative message event. - */ - static from(text: string, html?: string): MessageEvent; -} -//# sourceMappingURL=MessageEvent.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts.map deleted file mode 100644 index 053dd6a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MessageEvent.d.ts","sourceRoot":"","sources":["../../src/extensible_events_v1/MessageEvent.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EACH,mBAAmB,EACnB,iBAAiB,EACjB,aAAa,EAIb,gCAAgC,EAEnC,MAAM,6BAA6B,CAAC;AAIrC;;;;;;GAMG;AACH,qBAAa,YAAa,SAAQ,eAAe,CAAC,gCAAgC,CAAC;IAC/E;;OAEG;IACH,SAAgB,IAAI,EAAE,MAAM,CAAC;IAE7B;;OAEG;IACH,SAAgB,IAAI,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;IAEvC;;;;;OAKG;IACH,SAAgB,UAAU,EAAE,iBAAiB,EAAE,CAAC;IAEhD;;;;;OAKG;gBACgB,UAAU,EAAE,aAAa,CAAC,gCAAgC,CAAC;IA8BvE,cAAc,CAAC,gBAAgB,EAAE,mBAAmB,GAAG,OAAO;IAIrE,SAAS,CAAC,qBAAqB,IAAI,gCAAgC;IAkB5D,SAAS,IAAI,aAAa,CAAC,MAAM,CAAC;IAazC;;;;;OAKG;WACW,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,YAAY;CAShE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js deleted file mode 100644 index ab8c3ca..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js +++ /dev/null @@ -1,128 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MessageEvent = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _ExtensibleEvent = require("./ExtensibleEvent"); -var _extensible_events = require("../@types/extensible_events"); -var _utilities = require("./utilities"); -var _InvalidEventError = require("./InvalidEventError"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * Represents a message event. Message events are the simplest form of event with - * just text (optionally of different mimetypes, like HTML). - * - * Message events can additionally be an Emote or Notice, though typically those - * are represented as EmoteEvent and NoticeEvent respectively. - */ -class MessageEvent extends _ExtensibleEvent.ExtensibleEvent { - /** - * The default text for the event. - */ - - /** - * The default HTML for the event, if provided. - */ - - /** - * All the different renderings of the message. Note that this is the same - * format as an m.message body but may contain elements not found directly - * in the event content: this is because this is interpreted based off the - * other information available in the event. - */ - - /** - * Creates a new MessageEvent from a pure format. Note that the event is - * *not* parsed here: it will be treated as a literal m.message primary - * typed event. - * @param wireFormat - The event. - */ - constructor(wireFormat) { - super(wireFormat); - (0, _defineProperty2.default)(this, "text", void 0); - (0, _defineProperty2.default)(this, "html", void 0); - (0, _defineProperty2.default)(this, "renderings", void 0); - const mmessage = _extensible_events.M_MESSAGE.findIn(this.wireContent); - const mtext = _extensible_events.M_TEXT.findIn(this.wireContent); - const mhtml = _extensible_events.M_HTML.findIn(this.wireContent); - if ((0, _utilities.isProvided)(mmessage)) { - if (!Array.isArray(mmessage)) { - throw new _InvalidEventError.InvalidEventError("m.message contents must be an array"); - } - const text = mmessage.find(r => !(0, _utilities.isProvided)(r.mimetype) || r.mimetype === "text/plain"); - const html = mmessage.find(r => r.mimetype === "text/html"); - if (!text) throw new _InvalidEventError.InvalidEventError("m.message is missing a plain text representation"); - this.text = text.body; - this.html = html === null || html === void 0 ? void 0 : html.body; - this.renderings = mmessage; - } else if ((0, _utilities.isOptionalAString)(mtext)) { - this.text = mtext; - this.html = mhtml; - this.renderings = [{ - body: mtext, - mimetype: "text/plain" - }]; - if (this.html) { - this.renderings.push({ - body: this.html, - mimetype: "text/html" - }); - } - } else { - throw new _InvalidEventError.InvalidEventError("Missing textual representation for event"); - } - } - isEquivalentTo(primaryEventType) { - return (0, _extensible_events.isEventTypeSame)(primaryEventType, _extensible_events.M_MESSAGE); - } - serializeMMessageOnly() { - let messageRendering = { - [_extensible_events.M_MESSAGE.name]: this.renderings - }; - - // Use the shorthand if it's just a simple text event - if (this.renderings.length === 1) { - const mime = this.renderings[0].mimetype; - if (mime === undefined || mime === "text/plain") { - messageRendering = { - [_extensible_events.M_TEXT.name]: this.renderings[0].body - }; - } - } - return messageRendering; - } - serialize() { - var _this$html; - return { - type: "m.room.message", - content: _objectSpread(_objectSpread({}, this.serializeMMessageOnly()), {}, { - body: this.text, - msgtype: "m.text", - format: this.html ? "org.matrix.custom.html" : undefined, - formatted_body: (_this$html = this.html) !== null && _this$html !== void 0 ? _this$html : undefined - }) - }; - } - - /** - * Creates a new MessageEvent from text and HTML. - * @param text - The text. - * @param html - Optional HTML. - * @returns The representative message event. - */ - static from(text, html) { - return new MessageEvent({ - type: _extensible_events.M_MESSAGE.name, - content: { - [_extensible_events.M_TEXT.name]: text, - [_extensible_events.M_HTML.name]: html - } - }); - } -} -exports.MessageEvent = MessageEvent; -//# sourceMappingURL=MessageEvent.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js.map deleted file mode 100644 index 0306c34..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/MessageEvent.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MessageEvent.js","names":["_ExtensibleEvent","require","_extensible_events","_utilities","_InvalidEventError","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","MessageEvent","ExtensibleEvent","constructor","wireFormat","mmessage","M_MESSAGE","findIn","wireContent","mtext","M_TEXT","mhtml","M_HTML","isProvided","Array","isArray","InvalidEventError","text","find","r","mimetype","html","body","renderings","isOptionalAString","isEquivalentTo","primaryEventType","isEventTypeSame","serializeMMessageOnly","messageRendering","name","mime","undefined","serialize","_this$html","type","content","msgtype","format","formatted_body","from","exports"],"sources":["../../src/extensible_events_v1/MessageEvent.ts"],"sourcesContent":["/*\nCopyright 2022 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Optional } from \"matrix-events-sdk\";\n\nimport { ExtensibleEvent } from \"./ExtensibleEvent\";\nimport {\n ExtensibleEventType,\n IMessageRendering,\n IPartialEvent,\n isEventTypeSame,\n M_HTML,\n M_MESSAGE,\n ExtensibleAnyMessageEventContent,\n M_TEXT,\n} from \"../@types/extensible_events\";\nimport { isOptionalAString, isProvided } from \"./utilities\";\nimport { InvalidEventError } from \"./InvalidEventError\";\n\n/**\n * Represents a message event. Message events are the simplest form of event with\n * just text (optionally of different mimetypes, like HTML).\n *\n * Message events can additionally be an Emote or Notice, though typically those\n * are represented as EmoteEvent and NoticeEvent respectively.\n */\nexport class MessageEvent extends ExtensibleEvent {\n /**\n * The default text for the event.\n */\n public readonly text: string;\n\n /**\n * The default HTML for the event, if provided.\n */\n public readonly html: Optional;\n\n /**\n * All the different renderings of the message. Note that this is the same\n * format as an m.message body but may contain elements not found directly\n * in the event content: this is because this is interpreted based off the\n * other information available in the event.\n */\n public readonly renderings: IMessageRendering[];\n\n /**\n * Creates a new MessageEvent from a pure format. Note that the event is\n * *not* parsed here: it will be treated as a literal m.message primary\n * typed event.\n * @param wireFormat - The event.\n */\n public constructor(wireFormat: IPartialEvent) {\n super(wireFormat);\n\n const mmessage = M_MESSAGE.findIn(this.wireContent);\n const mtext = M_TEXT.findIn(this.wireContent);\n const mhtml = M_HTML.findIn(this.wireContent);\n if (isProvided(mmessage)) {\n if (!Array.isArray(mmessage)) {\n throw new InvalidEventError(\"m.message contents must be an array\");\n }\n const text = mmessage.find((r) => !isProvided(r.mimetype) || r.mimetype === \"text/plain\");\n const html = mmessage.find((r) => r.mimetype === \"text/html\");\n\n if (!text) throw new InvalidEventError(\"m.message is missing a plain text representation\");\n\n this.text = text.body;\n this.html = html?.body;\n this.renderings = mmessage;\n } else if (isOptionalAString(mtext)) {\n this.text = mtext;\n this.html = mhtml;\n this.renderings = [{ body: mtext, mimetype: \"text/plain\" }];\n if (this.html) {\n this.renderings.push({ body: this.html, mimetype: \"text/html\" });\n }\n } else {\n throw new InvalidEventError(\"Missing textual representation for event\");\n }\n }\n\n public isEquivalentTo(primaryEventType: ExtensibleEventType): boolean {\n return isEventTypeSame(primaryEventType, M_MESSAGE);\n }\n\n protected serializeMMessageOnly(): ExtensibleAnyMessageEventContent {\n let messageRendering: ExtensibleAnyMessageEventContent = {\n [M_MESSAGE.name]: this.renderings,\n };\n\n // Use the shorthand if it's just a simple text event\n if (this.renderings.length === 1) {\n const mime = this.renderings[0].mimetype;\n if (mime === undefined || mime === \"text/plain\") {\n messageRendering = {\n [M_TEXT.name]: this.renderings[0].body,\n };\n }\n }\n\n return messageRendering;\n }\n\n public serialize(): IPartialEvent {\n return {\n type: \"m.room.message\",\n content: {\n ...this.serializeMMessageOnly(),\n body: this.text,\n msgtype: \"m.text\",\n format: this.html ? \"org.matrix.custom.html\" : undefined,\n formatted_body: this.html ?? undefined,\n },\n };\n }\n\n /**\n * Creates a new MessageEvent from text and HTML.\n * @param text - The text.\n * @param html - Optional HTML.\n * @returns The representative message event.\n */\n public static from(text: string, html?: string): MessageEvent {\n return new MessageEvent({\n type: M_MESSAGE.name,\n content: {\n [M_TEXT.name]: text,\n [M_HTML.name]: html,\n },\n });\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts deleted file mode 100644 index 7601f64..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts +++ /dev/null @@ -1,33 +0,0 @@ -import { ExtensibleEventType, IPartialEvent } from "../@types/extensible_events"; -import { PollEndEventContent } from "../@types/polls"; -import { ExtensibleEvent } from "./ExtensibleEvent"; -import { MessageEvent } from "./MessageEvent"; -/** - * Represents a poll end/closure event. - */ -export declare class PollEndEvent extends ExtensibleEvent { - /** - * The poll start event ID referenced by the response. - */ - readonly pollEventId: string; - /** - * The closing message for the event. - */ - readonly closingMessage: MessageEvent; - /** - * Creates a new PollEndEvent from a pure format. Note that the event is *not* - * parsed here: it will be treated as a literal m.poll.response primary typed event. - * @param wireFormat - The event. - */ - constructor(wireFormat: IPartialEvent); - isEquivalentTo(primaryEventType: ExtensibleEventType): boolean; - serialize(): IPartialEvent; - /** - * Creates a new PollEndEvent from a poll event ID. - * @param pollEventId - The poll start event ID. - * @param message - A closing message, typically revealing the top answer. - * @returns The representative poll closure event. - */ - static from(pollEventId: string, message: string): PollEndEvent; -} -//# sourceMappingURL=PollEndEvent.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts.map deleted file mode 100644 index 71345fb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PollEndEvent.d.ts","sourceRoot":"","sources":["../../src/extensible_events_v1/PollEndEvent.ts"],"names":[],"mappings":"AAgBA,OAAO,EACH,mBAAmB,EACnB,aAAa,EAIhB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAc,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEpD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C;;GAEG;AACH,qBAAa,YAAa,SAAQ,eAAe,CAAC,mBAAmB,CAAC;IAClE;;OAEG;IACH,SAAgB,WAAW,EAAE,MAAM,CAAC;IAEpC;;OAEG;IACH,SAAgB,cAAc,EAAE,YAAY,CAAC;IAE7C;;;;OAIG;gBACgB,UAAU,EAAE,aAAa,CAAC,mBAAmB,CAAC;IAY1D,cAAc,CAAC,gBAAgB,EAAE,mBAAmB,GAAG,OAAO;IAI9D,SAAS,IAAI,aAAa,CAAC,MAAM,CAAC;IAczC;;;;;OAKG;WACW,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,YAAY;CAazE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js deleted file mode 100644 index d91328a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js +++ /dev/null @@ -1,81 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PollEndEvent = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _extensible_events = require("../@types/extensible_events"); -var _polls = require("../@types/polls"); -var _ExtensibleEvent = require("./ExtensibleEvent"); -var _InvalidEventError = require("./InvalidEventError"); -var _MessageEvent = require("./MessageEvent"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * Represents a poll end/closure event. - */ -class PollEndEvent extends _ExtensibleEvent.ExtensibleEvent { - /** - * The poll start event ID referenced by the response. - */ - - /** - * The closing message for the event. - */ - - /** - * Creates a new PollEndEvent from a pure format. Note that the event is *not* - * parsed here: it will be treated as a literal m.poll.response primary typed event. - * @param wireFormat - The event. - */ - constructor(wireFormat) { - super(wireFormat); - (0, _defineProperty2.default)(this, "pollEventId", void 0); - (0, _defineProperty2.default)(this, "closingMessage", void 0); - const rel = this.wireContent["m.relates_to"]; - if (!_extensible_events.REFERENCE_RELATION.matches(rel === null || rel === void 0 ? void 0 : rel.rel_type) || typeof (rel === null || rel === void 0 ? void 0 : rel.event_id) !== "string") { - throw new _InvalidEventError.InvalidEventError("Relationship must be a reference to an event"); - } - this.pollEventId = rel.event_id; - this.closingMessage = new _MessageEvent.MessageEvent(this.wireFormat); - } - isEquivalentTo(primaryEventType) { - return (0, _extensible_events.isEventTypeSame)(primaryEventType, _polls.M_POLL_END); - } - serialize() { - return { - type: _polls.M_POLL_END.name, - content: _objectSpread({ - "m.relates_to": { - rel_type: _extensible_events.REFERENCE_RELATION.name, - event_id: this.pollEventId - }, - [_polls.M_POLL_END.name]: {} - }, this.closingMessage.serialize().content) - }; - } - - /** - * Creates a new PollEndEvent from a poll event ID. - * @param pollEventId - The poll start event ID. - * @param message - A closing message, typically revealing the top answer. - * @returns The representative poll closure event. - */ - static from(pollEventId, message) { - return new PollEndEvent({ - type: _polls.M_POLL_END.name, - content: { - "m.relates_to": { - rel_type: _extensible_events.REFERENCE_RELATION.name, - event_id: pollEventId - }, - [_polls.M_POLL_END.name]: {}, - [_extensible_events.M_TEXT.name]: message - } - }); - } -} -exports.PollEndEvent = PollEndEvent; -//# sourceMappingURL=PollEndEvent.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js.map deleted file mode 100644 index bca48e7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollEndEvent.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PollEndEvent.js","names":["_extensible_events","require","_polls","_ExtensibleEvent","_InvalidEventError","_MessageEvent","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","PollEndEvent","ExtensibleEvent","constructor","wireFormat","rel","wireContent","REFERENCE_RELATION","matches","rel_type","event_id","InvalidEventError","pollEventId","closingMessage","MessageEvent","isEquivalentTo","primaryEventType","isEventTypeSame","M_POLL_END","serialize","type","name","content","from","message","M_TEXT","exports"],"sources":["../../src/extensible_events_v1/PollEndEvent.ts"],"sourcesContent":["/*\nCopyright 2022 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport {\n ExtensibleEventType,\n IPartialEvent,\n isEventTypeSame,\n M_TEXT,\n REFERENCE_RELATION,\n} from \"../@types/extensible_events\";\nimport { M_POLL_END, PollEndEventContent } from \"../@types/polls\";\nimport { ExtensibleEvent } from \"./ExtensibleEvent\";\nimport { InvalidEventError } from \"./InvalidEventError\";\nimport { MessageEvent } from \"./MessageEvent\";\n\n/**\n * Represents a poll end/closure event.\n */\nexport class PollEndEvent extends ExtensibleEvent {\n /**\n * The poll start event ID referenced by the response.\n */\n public readonly pollEventId: string;\n\n /**\n * The closing message for the event.\n */\n public readonly closingMessage: MessageEvent;\n\n /**\n * Creates a new PollEndEvent from a pure format. Note that the event is *not*\n * parsed here: it will be treated as a literal m.poll.response primary typed event.\n * @param wireFormat - The event.\n */\n public constructor(wireFormat: IPartialEvent) {\n super(wireFormat);\n\n const rel = this.wireContent[\"m.relates_to\"];\n if (!REFERENCE_RELATION.matches(rel?.rel_type) || typeof rel?.event_id !== \"string\") {\n throw new InvalidEventError(\"Relationship must be a reference to an event\");\n }\n\n this.pollEventId = rel.event_id;\n this.closingMessage = new MessageEvent(this.wireFormat);\n }\n\n public isEquivalentTo(primaryEventType: ExtensibleEventType): boolean {\n return isEventTypeSame(primaryEventType, M_POLL_END);\n }\n\n public serialize(): IPartialEvent {\n return {\n type: M_POLL_END.name,\n content: {\n \"m.relates_to\": {\n rel_type: REFERENCE_RELATION.name,\n event_id: this.pollEventId,\n },\n [M_POLL_END.name]: {},\n ...this.closingMessage.serialize().content,\n },\n };\n }\n\n /**\n * Creates a new PollEndEvent from a poll event ID.\n * @param pollEventId - The poll start event ID.\n * @param message - A closing message, typically revealing the top answer.\n * @returns The representative poll closure event.\n */\n public static from(pollEventId: string, message: string): PollEndEvent {\n return new PollEndEvent({\n type: M_POLL_END.name,\n content: {\n \"m.relates_to\": {\n rel_type: REFERENCE_RELATION.name,\n event_id: pollEventId,\n },\n [M_POLL_END.name]: {},\n [M_TEXT.name]: message,\n },\n });\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts deleted file mode 100644 index 6c373d7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts +++ /dev/null @@ -1,49 +0,0 @@ -import { ExtensibleEvent } from "./ExtensibleEvent"; -import { PollResponseEventContent } from "../@types/polls"; -import { ExtensibleEventType, IPartialEvent } from "../@types/extensible_events"; -import { PollStartEvent } from "./PollStartEvent"; -/** - * Represents a poll response event. - */ -export declare class PollResponseEvent extends ExtensibleEvent { - private internalAnswerIds; - private internalSpoiled; - /** - * The provided answers for the poll. Note that this may be falsy/unpredictable if - * the `spoiled` property is true. - */ - get answerIds(): string[]; - /** - * The poll start event ID referenced by the response. - */ - readonly pollEventId: string; - /** - * Whether the vote is spoiled. - */ - get spoiled(): boolean; - /** - * Creates a new PollResponseEvent from a pure format. Note that the event is *not* - * parsed here: it will be treated as a literal m.poll.response primary typed event. - * - * To validate the response against a poll, call `validateAgainst` after creation. - * @param wireFormat - The event. - */ - constructor(wireFormat: IPartialEvent); - /** - * Validates the poll response using the poll start event as a frame of reference. This - * is used to determine if the vote is spoiled, whether the answers are valid, etc. - * @param poll - The poll start event. - */ - validateAgainst(poll: PollStartEvent | null): void; - isEquivalentTo(primaryEventType: ExtensibleEventType): boolean; - serialize(): IPartialEvent; - /** - * Creates a new PollResponseEvent from a set of answers. To spoil the vote, pass an empty - * answers array. - * @param answers - The user's answers. Should be valid from a poll's answer IDs. - * @param pollEventId - The poll start event ID. - * @returns The representative poll response event. - */ - static from(answers: string[], pollEventId: string): PollResponseEvent; -} -//# sourceMappingURL=PollResponseEvent.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts.map deleted file mode 100644 index 9e82f31..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PollResponseEvent.d.ts","sourceRoot":"","sources":["../../src/extensible_events_v1/PollResponseEvent.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAmB,wBAAwB,EAAuB,MAAM,iBAAiB,CAAC;AACjG,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAuC,MAAM,6BAA6B,CAAC;AAEtH,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD;;GAEG;AACH,qBAAa,iBAAkB,SAAQ,eAAe,CAAC,wBAAwB,CAAC;IAC5E,OAAO,CAAC,iBAAiB,CAAgB;IACzC,OAAO,CAAC,eAAe,CAAS;IAEhC;;;OAGG;IACH,IAAW,SAAS,IAAI,MAAM,EAAE,CAE/B;IAED;;OAEG;IACH,SAAgB,WAAW,EAAE,MAAM,CAAC;IAEpC;;OAEG;IACH,IAAW,OAAO,IAAI,OAAO,CAE5B;IAED;;;;;;OAMG;gBACgB,UAAU,EAAE,aAAa,CAAC,wBAAwB,CAAC;IAYtE;;;;OAIG;IACI,eAAe,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,GAAG,IAAI;IA6BlD,cAAc,CAAC,gBAAgB,EAAE,mBAAmB,GAAG,OAAO;IAI9D,SAAS,IAAI,aAAa,CAAC,MAAM,CAAC;IAezC;;;;;;OAMG;WACW,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,GAAG,iBAAiB;CAchF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js deleted file mode 100644 index 736f108..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js +++ /dev/null @@ -1,143 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PollResponseEvent = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _ExtensibleEvent = require("./ExtensibleEvent"); -var _polls = require("../@types/polls"); -var _extensible_events = require("../@types/extensible_events"); -var _InvalidEventError = require("./InvalidEventError"); -/* -Copyright 2022 - 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Represents a poll response event. - */ -class PollResponseEvent extends _ExtensibleEvent.ExtensibleEvent { - /** - * The provided answers for the poll. Note that this may be falsy/unpredictable if - * the `spoiled` property is true. - */ - get answerIds() { - return this.internalAnswerIds; - } - - /** - * The poll start event ID referenced by the response. - */ - - /** - * Whether the vote is spoiled. - */ - get spoiled() { - return this.internalSpoiled; - } - - /** - * Creates a new PollResponseEvent from a pure format. Note that the event is *not* - * parsed here: it will be treated as a literal m.poll.response primary typed event. - * - * To validate the response against a poll, call `validateAgainst` after creation. - * @param wireFormat - The event. - */ - constructor(wireFormat) { - super(wireFormat); - (0, _defineProperty2.default)(this, "internalAnswerIds", []); - (0, _defineProperty2.default)(this, "internalSpoiled", false); - (0, _defineProperty2.default)(this, "pollEventId", void 0); - const rel = this.wireContent["m.relates_to"]; - if (!_extensible_events.REFERENCE_RELATION.matches(rel === null || rel === void 0 ? void 0 : rel.rel_type) || typeof (rel === null || rel === void 0 ? void 0 : rel.event_id) !== "string") { - throw new _InvalidEventError.InvalidEventError("Relationship must be a reference to an event"); - } - this.pollEventId = rel.event_id; - this.validateAgainst(null); - } - - /** - * Validates the poll response using the poll start event as a frame of reference. This - * is used to determine if the vote is spoiled, whether the answers are valid, etc. - * @param poll - The poll start event. - */ - validateAgainst(poll) { - var _response$answers; - const response = _polls.M_POLL_RESPONSE.findIn(this.wireContent); - if (!Array.isArray(response === null || response === void 0 ? void 0 : response.answers)) { - this.internalSpoiled = true; - this.internalAnswerIds = []; - return; - } - let answers = (_response$answers = response === null || response === void 0 ? void 0 : response.answers) !== null && _response$answers !== void 0 ? _response$answers : []; - if (answers.some(a => typeof a !== "string") || answers.length === 0) { - this.internalSpoiled = true; - this.internalAnswerIds = []; - return; - } - if (poll) { - if (answers.some(a => !poll.answers.some(pa => pa.id === a))) { - this.internalSpoiled = true; - this.internalAnswerIds = []; - return; - } - answers = answers.slice(0, poll.maxSelections); - } - this.internalAnswerIds = answers; - this.internalSpoiled = false; - } - isEquivalentTo(primaryEventType) { - return (0, _extensible_events.isEventTypeSame)(primaryEventType, _polls.M_POLL_RESPONSE); - } - serialize() { - return { - type: _polls.M_POLL_RESPONSE.name, - content: { - "m.relates_to": { - rel_type: _extensible_events.REFERENCE_RELATION.name, - event_id: this.pollEventId - }, - [_polls.M_POLL_RESPONSE.name]: { - answers: this.spoiled ? undefined : this.answerIds - } - } - }; - } - - /** - * Creates a new PollResponseEvent from a set of answers. To spoil the vote, pass an empty - * answers array. - * @param answers - The user's answers. Should be valid from a poll's answer IDs. - * @param pollEventId - The poll start event ID. - * @returns The representative poll response event. - */ - static from(answers, pollEventId) { - return new PollResponseEvent({ - type: _polls.M_POLL_RESPONSE.name, - content: { - "m.relates_to": { - rel_type: _extensible_events.REFERENCE_RELATION.name, - event_id: pollEventId - }, - [_polls.M_POLL_RESPONSE.name]: { - answers: answers - } - } - }); - } -} -exports.PollResponseEvent = PollResponseEvent; -//# sourceMappingURL=PollResponseEvent.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js.map deleted file mode 100644 index 669c498..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollResponseEvent.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PollResponseEvent.js","names":["_ExtensibleEvent","require","_polls","_extensible_events","_InvalidEventError","PollResponseEvent","ExtensibleEvent","answerIds","internalAnswerIds","spoiled","internalSpoiled","constructor","wireFormat","_defineProperty2","default","rel","wireContent","REFERENCE_RELATION","matches","rel_type","event_id","InvalidEventError","pollEventId","validateAgainst","poll","_response$answers","response","M_POLL_RESPONSE","findIn","Array","isArray","answers","some","a","length","pa","id","slice","maxSelections","isEquivalentTo","primaryEventType","isEventTypeSame","serialize","type","name","content","undefined","from","exports"],"sources":["../../src/extensible_events_v1/PollResponseEvent.ts"],"sourcesContent":["/*\nCopyright 2022 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ExtensibleEvent } from \"./ExtensibleEvent\";\nimport { M_POLL_RESPONSE, PollResponseEventContent, PollResponseSubtype } from \"../@types/polls\";\nimport { ExtensibleEventType, IPartialEvent, isEventTypeSame, REFERENCE_RELATION } from \"../@types/extensible_events\";\nimport { InvalidEventError } from \"./InvalidEventError\";\nimport { PollStartEvent } from \"./PollStartEvent\";\n\n/**\n * Represents a poll response event.\n */\nexport class PollResponseEvent extends ExtensibleEvent {\n private internalAnswerIds: string[] = [];\n private internalSpoiled = false;\n\n /**\n * The provided answers for the poll. Note that this may be falsy/unpredictable if\n * the `spoiled` property is true.\n */\n public get answerIds(): string[] {\n return this.internalAnswerIds;\n }\n\n /**\n * The poll start event ID referenced by the response.\n */\n public readonly pollEventId: string;\n\n /**\n * Whether the vote is spoiled.\n */\n public get spoiled(): boolean {\n return this.internalSpoiled;\n }\n\n /**\n * Creates a new PollResponseEvent from a pure format. Note that the event is *not*\n * parsed here: it will be treated as a literal m.poll.response primary typed event.\n *\n * To validate the response against a poll, call `validateAgainst` after creation.\n * @param wireFormat - The event.\n */\n public constructor(wireFormat: IPartialEvent) {\n super(wireFormat);\n\n const rel = this.wireContent[\"m.relates_to\"];\n if (!REFERENCE_RELATION.matches(rel?.rel_type) || typeof rel?.event_id !== \"string\") {\n throw new InvalidEventError(\"Relationship must be a reference to an event\");\n }\n\n this.pollEventId = rel.event_id;\n this.validateAgainst(null);\n }\n\n /**\n * Validates the poll response using the poll start event as a frame of reference. This\n * is used to determine if the vote is spoiled, whether the answers are valid, etc.\n * @param poll - The poll start event.\n */\n public validateAgainst(poll: PollStartEvent | null): void {\n const response = M_POLL_RESPONSE.findIn(this.wireContent);\n if (!Array.isArray(response?.answers)) {\n this.internalSpoiled = true;\n this.internalAnswerIds = [];\n return;\n }\n\n let answers = response?.answers ?? [];\n if (answers.some((a) => typeof a !== \"string\") || answers.length === 0) {\n this.internalSpoiled = true;\n this.internalAnswerIds = [];\n return;\n }\n\n if (poll) {\n if (answers.some((a) => !poll.answers.some((pa) => pa.id === a))) {\n this.internalSpoiled = true;\n this.internalAnswerIds = [];\n return;\n }\n\n answers = answers.slice(0, poll.maxSelections);\n }\n\n this.internalAnswerIds = answers;\n this.internalSpoiled = false;\n }\n\n public isEquivalentTo(primaryEventType: ExtensibleEventType): boolean {\n return isEventTypeSame(primaryEventType, M_POLL_RESPONSE);\n }\n\n public serialize(): IPartialEvent {\n return {\n type: M_POLL_RESPONSE.name,\n content: {\n \"m.relates_to\": {\n rel_type: REFERENCE_RELATION.name,\n event_id: this.pollEventId,\n },\n [M_POLL_RESPONSE.name]: {\n answers: this.spoiled ? undefined : this.answerIds,\n },\n },\n };\n }\n\n /**\n * Creates a new PollResponseEvent from a set of answers. To spoil the vote, pass an empty\n * answers array.\n * @param answers - The user's answers. Should be valid from a poll's answer IDs.\n * @param pollEventId - The poll start event ID.\n * @returns The representative poll response event.\n */\n public static from(answers: string[], pollEventId: string): PollResponseEvent {\n return new PollResponseEvent({\n type: M_POLL_RESPONSE.name,\n content: {\n \"m.relates_to\": {\n rel_type: REFERENCE_RELATION.name,\n event_id: pollEventId,\n },\n [M_POLL_RESPONSE.name]: {\n answers: answers,\n },\n },\n });\n }\n}\n"],"mappings":";;;;;;;;AAgBA,IAAAA,gBAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,kBAAA,GAAAF,OAAA;AACA,IAAAG,kBAAA,GAAAH,OAAA;AAnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAQA;AACA;AACA;AACO,MAAMI,iBAAiB,SAASC,gCAAe,CAA2B;EAI7E;AACJ;AACA;AACA;EACI,IAAWC,SAASA,CAAA,EAAa;IAC7B,OAAO,IAAI,CAACC,iBAAiB;EACjC;;EAEA;AACJ;AACA;;EAGI;AACJ;AACA;EACI,IAAWC,OAAOA,CAAA,EAAY;IAC1B,OAAO,IAAI,CAACC,eAAe;EAC/B;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;EACWC,WAAWA,CAACC,UAAmD,EAAE;IACpE,KAAK,CAACA,UAAU,CAAC;IAAC,IAAAC,gBAAA,CAAAC,OAAA,6BA/BgB,EAAE;IAAA,IAAAD,gBAAA,CAAAC,OAAA,2BACd,KAAK;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAgC3B,MAAMC,GAAG,GAAG,IAAI,CAACC,WAAW,CAAC,cAAc,CAAC;IAC5C,IAAI,CAACC,qCAAkB,CAACC,OAAO,CAACH,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEI,QAAQ,CAAC,IAAI,QAAOJ,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEK,QAAQ,MAAK,QAAQ,EAAE;MACjF,MAAM,IAAIC,oCAAiB,CAAC,8CAA8C,CAAC;IAC/E;IAEA,IAAI,CAACC,WAAW,GAAGP,GAAG,CAACK,QAAQ;IAC/B,IAAI,CAACG,eAAe,CAAC,IAAI,CAAC;EAC9B;;EAEA;AACJ;AACA;AACA;AACA;EACWA,eAAeA,CAACC,IAA2B,EAAQ;IAAA,IAAAC,iBAAA;IACtD,MAAMC,QAAQ,GAAGC,sBAAe,CAACC,MAAM,CAAsB,IAAI,CAACZ,WAAW,CAAC;IAC9E,IAAI,CAACa,KAAK,CAACC,OAAO,CAACJ,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEK,OAAO,CAAC,EAAE;MACnC,IAAI,CAACrB,eAAe,GAAG,IAAI;MAC3B,IAAI,CAACF,iBAAiB,GAAG,EAAE;MAC3B;IACJ;IAEA,IAAIuB,OAAO,IAAAN,iBAAA,GAAGC,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEK,OAAO,cAAAN,iBAAA,cAAAA,iBAAA,GAAI,EAAE;IACrC,IAAIM,OAAO,CAACC,IAAI,CAAEC,CAAC,IAAK,OAAOA,CAAC,KAAK,QAAQ,CAAC,IAAIF,OAAO,CAACG,MAAM,KAAK,CAAC,EAAE;MACpE,IAAI,CAACxB,eAAe,GAAG,IAAI;MAC3B,IAAI,CAACF,iBAAiB,GAAG,EAAE;MAC3B;IACJ;IAEA,IAAIgB,IAAI,EAAE;MACN,IAAIO,OAAO,CAACC,IAAI,CAAEC,CAAC,IAAK,CAACT,IAAI,CAACO,OAAO,CAACC,IAAI,CAAEG,EAAE,IAAKA,EAAE,CAACC,EAAE,KAAKH,CAAC,CAAC,CAAC,EAAE;QAC9D,IAAI,CAACvB,eAAe,GAAG,IAAI;QAC3B,IAAI,CAACF,iBAAiB,GAAG,EAAE;QAC3B;MACJ;MAEAuB,OAAO,GAAGA,OAAO,CAACM,KAAK,CAAC,CAAC,EAAEb,IAAI,CAACc,aAAa,CAAC;IAClD;IAEA,IAAI,CAAC9B,iBAAiB,GAAGuB,OAAO;IAChC,IAAI,CAACrB,eAAe,GAAG,KAAK;EAChC;EAEO6B,cAAcA,CAACC,gBAAqC,EAAW;IAClE,OAAO,IAAAC,kCAAe,EAACD,gBAAgB,EAAEb,sBAAe,CAAC;EAC7D;EAEOe,SAASA,CAAA,EAA0B;IACtC,OAAO;MACHC,IAAI,EAAEhB,sBAAe,CAACiB,IAAI;MAC1BC,OAAO,EAAE;QACL,cAAc,EAAE;UACZ1B,QAAQ,EAAEF,qCAAkB,CAAC2B,IAAI;UACjCxB,QAAQ,EAAE,IAAI,CAACE;QACnB,CAAC;QACD,CAACK,sBAAe,CAACiB,IAAI,GAAG;UACpBb,OAAO,EAAE,IAAI,CAACtB,OAAO,GAAGqC,SAAS,GAAG,IAAI,CAACvC;QAC7C;MACJ;IACJ,CAAC;EACL;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;EACI,OAAcwC,IAAIA,CAAChB,OAAiB,EAAET,WAAmB,EAAqB;IAC1E,OAAO,IAAIjB,iBAAiB,CAAC;MACzBsC,IAAI,EAAEhB,sBAAe,CAACiB,IAAI;MAC1BC,OAAO,EAAE;QACL,cAAc,EAAE;UACZ1B,QAAQ,EAAEF,qCAAkB,CAAC2B,IAAI;UACjCxB,QAAQ,EAAEE;QACd,CAAC;QACD,CAACK,sBAAe,CAACiB,IAAI,GAAG;UACpBb,OAAO,EAAEA;QACb;MACJ;IACJ,CAAC,CAAC;EACN;AACJ;AAACiB,OAAA,CAAA3C,iBAAA,GAAAA,iBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts deleted file mode 100644 index 6e0f205..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts +++ /dev/null @@ -1,71 +0,0 @@ -import { MessageEvent } from "./MessageEvent"; -import { ExtensibleEventType, IPartialEvent } from "../@types/extensible_events"; -import { KnownPollKind, PollStartEventContent, PollAnswer } from "../@types/polls"; -import { ExtensibleEvent } from "./ExtensibleEvent"; -/** - * Represents a poll answer. Note that this is represented as a subtype and is - * not registered as a parsable event - it is implied for usage exclusively - * within the PollStartEvent parsing. - */ -export declare class PollAnswerSubevent extends MessageEvent { - /** - * The answer ID. - */ - readonly id: string; - constructor(wireFormat: IPartialEvent); - serialize(): IPartialEvent; - /** - * Creates a new PollAnswerSubevent from ID and text. - * @param id - The answer ID (unique within the poll). - * @param text - The text. - * @returns The representative answer. - */ - static from(id: string, text: string): PollAnswerSubevent; -} -/** - * Represents a poll start event. - */ -export declare class PollStartEvent extends ExtensibleEvent { - /** - * The question being asked, as a MessageEvent node. - */ - readonly question: MessageEvent; - /** - * The interpreted kind of poll. Note that this will infer a value that is known to the - * SDK rather than verbatim - this means unknown types will be represented as undisclosed - * polls. - * - * To get the raw kind, use rawKind. - */ - readonly kind: KnownPollKind; - /** - * The true kind as provided by the event sender. Might not be valid. - */ - readonly rawKind: string; - /** - * The maximum number of selections a user is allowed to make. - */ - readonly maxSelections: number; - /** - * The possible answers for the poll. - */ - readonly answers: PollAnswerSubevent[]; - /** - * Creates a new PollStartEvent from a pure format. Note that the event is *not* - * parsed here: it will be treated as a literal m.poll.start primary typed event. - * @param wireFormat - The event. - */ - constructor(wireFormat: IPartialEvent); - isEquivalentTo(primaryEventType: ExtensibleEventType): boolean; - serialize(): IPartialEvent; - /** - * Creates a new PollStartEvent from question, answers, and metadata. - * @param question - The question to ask. - * @param answers - The answers. Should be unique within each other. - * @param kind - The kind of poll. - * @param maxSelections - The maximum number of selections. Must be 1 or higher. - * @returns The representative poll start event. - */ - static from(question: string, answers: string[], kind: KnownPollKind | string, maxSelections?: number): PollStartEvent; -} -//# sourceMappingURL=PollStartEvent.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts.map deleted file mode 100644 index bda6343..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PollStartEvent.d.ts","sourceRoot":"","sources":["../../src/extensible_events_v1/PollStartEvent.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAA2B,MAAM,6BAA6B,CAAC;AAC1G,OAAO,EACH,aAAa,EAIb,qBAAqB,EAErB,UAAU,EACb,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEpD;;;;GAIG;AACH,qBAAa,kBAAmB,SAAQ,YAAY;IAChD;;OAEG;IACH,SAAgB,EAAE,EAAE,MAAM,CAAC;gBAER,UAAU,EAAE,aAAa,CAAC,UAAU,CAAC;IAUjD,SAAS,IAAI,aAAa,CAAC,MAAM,CAAC;IAUzC;;;;;OAKG;WACW,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,kBAAkB;CASnE;AAED;;GAEG;AACH,qBAAa,cAAe,SAAQ,eAAe,CAAC,qBAAqB,CAAC;IACtE;;OAEG;IACH,SAAgB,QAAQ,EAAE,YAAY,CAAC;IAEvC;;;;;;OAMG;IACH,SAAgB,IAAI,EAAE,aAAa,CAAC;IAEpC;;OAEG;IACH,SAAgB,OAAO,EAAE,MAAM,CAAC;IAEhC;;OAEG;IACH,SAAgB,aAAa,EAAE,MAAM,CAAC;IAEtC;;OAEG;IACH,SAAgB,OAAO,EAAE,kBAAkB,EAAE,CAAC;IAE9C;;;;OAIG;gBACgB,UAAU,EAAE,aAAa,CAAC,qBAAqB,CAAC;IAqC5D,cAAc,CAAC,gBAAgB,EAAE,mBAAmB,GAAG,OAAO;IAI9D,SAAS,IAAI,aAAa,CAAC,MAAM,CAAC;IAezC;;;;;;;OAOG;WACW,IAAI,CACd,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EAAE,EACjB,IAAI,EAAE,aAAa,GAAG,MAAM,EAC5B,aAAa,SAAI,GAClB,cAAc;CAcpB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js deleted file mode 100644 index f7e1527..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js +++ /dev/null @@ -1,183 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PollStartEvent = exports.PollAnswerSubevent = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _matrixEventsSdk = require("matrix-events-sdk"); -var _MessageEvent = require("./MessageEvent"); -var _extensible_events = require("../@types/extensible_events"); -var _polls = require("../@types/polls"); -var _InvalidEventError = require("./InvalidEventError"); -var _ExtensibleEvent = require("./ExtensibleEvent"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * Represents a poll answer. Note that this is represented as a subtype and is - * not registered as a parsable event - it is implied for usage exclusively - * within the PollStartEvent parsing. - */ -class PollAnswerSubevent extends _MessageEvent.MessageEvent { - /** - * The answer ID. - */ - - constructor(wireFormat) { - super(wireFormat); - (0, _defineProperty2.default)(this, "id", void 0); - const id = wireFormat.content.id; - if (!id || typeof id !== "string") { - throw new _InvalidEventError.InvalidEventError("Answer ID must be a non-empty string"); - } - this.id = id; - } - serialize() { - return { - type: "org.matrix.sdk.poll.answer", - content: _objectSpread({ - id: this.id - }, this.serializeMMessageOnly()) - }; - } - - /** - * Creates a new PollAnswerSubevent from ID and text. - * @param id - The answer ID (unique within the poll). - * @param text - The text. - * @returns The representative answer. - */ - static from(id, text) { - return new PollAnswerSubevent({ - type: "org.matrix.sdk.poll.answer", - content: { - id: id, - [_extensible_events.M_TEXT.name]: text - } - }); - } -} - -/** - * Represents a poll start event. - */ -exports.PollAnswerSubevent = PollAnswerSubevent; -class PollStartEvent extends _ExtensibleEvent.ExtensibleEvent { - /** - * The question being asked, as a MessageEvent node. - */ - - /** - * The interpreted kind of poll. Note that this will infer a value that is known to the - * SDK rather than verbatim - this means unknown types will be represented as undisclosed - * polls. - * - * To get the raw kind, use rawKind. - */ - - /** - * The true kind as provided by the event sender. Might not be valid. - */ - - /** - * The maximum number of selections a user is allowed to make. - */ - - /** - * The possible answers for the poll. - */ - - /** - * Creates a new PollStartEvent from a pure format. Note that the event is *not* - * parsed here: it will be treated as a literal m.poll.start primary typed event. - * @param wireFormat - The event. - */ - constructor(wireFormat) { - super(wireFormat); - (0, _defineProperty2.default)(this, "question", void 0); - (0, _defineProperty2.default)(this, "kind", void 0); - (0, _defineProperty2.default)(this, "rawKind", void 0); - (0, _defineProperty2.default)(this, "maxSelections", void 0); - (0, _defineProperty2.default)(this, "answers", void 0); - const poll = _polls.M_POLL_START.findIn(this.wireContent); - if (!(poll !== null && poll !== void 0 && poll.question)) { - throw new _InvalidEventError.InvalidEventError("A question is required"); - } - this.question = new _MessageEvent.MessageEvent({ - type: "org.matrix.sdk.poll.question", - content: poll.question - }); - this.rawKind = poll.kind; - if (_polls.M_POLL_KIND_DISCLOSED.matches(this.rawKind)) { - this.kind = _polls.M_POLL_KIND_DISCLOSED; - } else { - this.kind = _polls.M_POLL_KIND_UNDISCLOSED; // default & assumed value - } - - this.maxSelections = Number.isFinite(poll.max_selections) && poll.max_selections > 0 ? poll.max_selections : 1; - if (!Array.isArray(poll.answers)) { - throw new _InvalidEventError.InvalidEventError("Poll answers must be an array"); - } - const answers = poll.answers.slice(0, 20).map(a => new PollAnswerSubevent({ - type: "org.matrix.sdk.poll.answer", - content: a - })); - if (answers.length <= 0) { - throw new _InvalidEventError.InvalidEventError("No answers available"); - } - this.answers = answers; - } - isEquivalentTo(primaryEventType) { - return (0, _extensible_events.isEventTypeSame)(primaryEventType, _polls.M_POLL_START); - } - serialize() { - return { - type: _polls.M_POLL_START.name, - content: { - [_polls.M_POLL_START.name]: { - question: this.question.serialize().content, - kind: this.rawKind, - max_selections: this.maxSelections, - answers: this.answers.map(a => a.serialize().content) - }, - [_extensible_events.M_TEXT.name]: `${this.question.text}\n${this.answers.map((a, i) => `${i + 1}. ${a.text}`).join("\n")}` - } - }; - } - - /** - * Creates a new PollStartEvent from question, answers, and metadata. - * @param question - The question to ask. - * @param answers - The answers. Should be unique within each other. - * @param kind - The kind of poll. - * @param maxSelections - The maximum number of selections. Must be 1 or higher. - * @returns The representative poll start event. - */ - static from(question, answers, kind, maxSelections = 1) { - return new PollStartEvent({ - type: _polls.M_POLL_START.name, - content: { - [_extensible_events.M_TEXT.name]: question, - // unused by parsing - [_polls.M_POLL_START.name]: { - question: { - [_extensible_events.M_TEXT.name]: question - }, - kind: kind instanceof _matrixEventsSdk.NamespacedValue ? kind.name : kind, - max_selections: maxSelections, - answers: answers.map(a => ({ - id: makeId(), - [_extensible_events.M_TEXT.name]: a - })) - } - } - }); - } -} -exports.PollStartEvent = PollStartEvent; -const LETTERS = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; -function makeId() { - return [...Array(16)].map(() => LETTERS.charAt(Math.floor(Math.random() * LETTERS.length))).join(""); -} -//# sourceMappingURL=PollStartEvent.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js.map deleted file mode 100644 index 83744a0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/PollStartEvent.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"PollStartEvent.js","names":["_matrixEventsSdk","require","_MessageEvent","_extensible_events","_polls","_InvalidEventError","_ExtensibleEvent","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","PollAnswerSubevent","MessageEvent","constructor","wireFormat","id","content","InvalidEventError","serialize","type","serializeMMessageOnly","from","text","M_TEXT","name","exports","PollStartEvent","ExtensibleEvent","poll","M_POLL_START","findIn","wireContent","question","rawKind","kind","M_POLL_KIND_DISCLOSED","matches","M_POLL_KIND_UNDISCLOSED","maxSelections","Number","isFinite","max_selections","Array","isArray","answers","slice","map","a","isEquivalentTo","primaryEventType","isEventTypeSame","join","NamespacedValue","makeId","LETTERS","charAt","Math","floor","random"],"sources":["../../src/extensible_events_v1/PollStartEvent.ts"],"sourcesContent":["/*\nCopyright 2022 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { NamespacedValue } from \"matrix-events-sdk\";\n\nimport { MessageEvent } from \"./MessageEvent\";\nimport { ExtensibleEventType, IPartialEvent, isEventTypeSame, M_TEXT } from \"../@types/extensible_events\";\nimport {\n KnownPollKind,\n M_POLL_KIND_DISCLOSED,\n M_POLL_KIND_UNDISCLOSED,\n M_POLL_START,\n PollStartEventContent,\n PollStartSubtype,\n PollAnswer,\n} from \"../@types/polls\";\nimport { InvalidEventError } from \"./InvalidEventError\";\nimport { ExtensibleEvent } from \"./ExtensibleEvent\";\n\n/**\n * Represents a poll answer. Note that this is represented as a subtype and is\n * not registered as a parsable event - it is implied for usage exclusively\n * within the PollStartEvent parsing.\n */\nexport class PollAnswerSubevent extends MessageEvent {\n /**\n * The answer ID.\n */\n public readonly id: string;\n\n public constructor(wireFormat: IPartialEvent) {\n super(wireFormat);\n\n const id = wireFormat.content.id;\n if (!id || typeof id !== \"string\") {\n throw new InvalidEventError(\"Answer ID must be a non-empty string\");\n }\n this.id = id;\n }\n\n public serialize(): IPartialEvent {\n return {\n type: \"org.matrix.sdk.poll.answer\",\n content: {\n id: this.id,\n ...this.serializeMMessageOnly(),\n },\n };\n }\n\n /**\n * Creates a new PollAnswerSubevent from ID and text.\n * @param id - The answer ID (unique within the poll).\n * @param text - The text.\n * @returns The representative answer.\n */\n public static from(id: string, text: string): PollAnswerSubevent {\n return new PollAnswerSubevent({\n type: \"org.matrix.sdk.poll.answer\",\n content: {\n id: id,\n [M_TEXT.name]: text,\n },\n });\n }\n}\n\n/**\n * Represents a poll start event.\n */\nexport class PollStartEvent extends ExtensibleEvent {\n /**\n * The question being asked, as a MessageEvent node.\n */\n public readonly question: MessageEvent;\n\n /**\n * The interpreted kind of poll. Note that this will infer a value that is known to the\n * SDK rather than verbatim - this means unknown types will be represented as undisclosed\n * polls.\n *\n * To get the raw kind, use rawKind.\n */\n public readonly kind: KnownPollKind;\n\n /**\n * The true kind as provided by the event sender. Might not be valid.\n */\n public readonly rawKind: string;\n\n /**\n * The maximum number of selections a user is allowed to make.\n */\n public readonly maxSelections: number;\n\n /**\n * The possible answers for the poll.\n */\n public readonly answers: PollAnswerSubevent[];\n\n /**\n * Creates a new PollStartEvent from a pure format. Note that the event is *not*\n * parsed here: it will be treated as a literal m.poll.start primary typed event.\n * @param wireFormat - The event.\n */\n public constructor(wireFormat: IPartialEvent) {\n super(wireFormat);\n\n const poll = M_POLL_START.findIn(this.wireContent);\n\n if (!poll?.question) {\n throw new InvalidEventError(\"A question is required\");\n }\n\n this.question = new MessageEvent({ type: \"org.matrix.sdk.poll.question\", content: poll.question });\n\n this.rawKind = poll.kind;\n if (M_POLL_KIND_DISCLOSED.matches(this.rawKind)) {\n this.kind = M_POLL_KIND_DISCLOSED;\n } else {\n this.kind = M_POLL_KIND_UNDISCLOSED; // default & assumed value\n }\n\n this.maxSelections =\n Number.isFinite(poll.max_selections) && poll.max_selections! > 0 ? poll.max_selections! : 1;\n\n if (!Array.isArray(poll.answers)) {\n throw new InvalidEventError(\"Poll answers must be an array\");\n }\n const answers = poll.answers.slice(0, 20).map(\n (a) =>\n new PollAnswerSubevent({\n type: \"org.matrix.sdk.poll.answer\",\n content: a,\n }),\n );\n if (answers.length <= 0) {\n throw new InvalidEventError(\"No answers available\");\n }\n this.answers = answers;\n }\n\n public isEquivalentTo(primaryEventType: ExtensibleEventType): boolean {\n return isEventTypeSame(primaryEventType, M_POLL_START);\n }\n\n public serialize(): IPartialEvent {\n return {\n type: M_POLL_START.name,\n content: {\n [M_POLL_START.name]: {\n question: this.question.serialize().content,\n kind: this.rawKind,\n max_selections: this.maxSelections,\n answers: this.answers.map((a) => a.serialize().content),\n },\n [M_TEXT.name]: `${this.question.text}\\n${this.answers.map((a, i) => `${i + 1}. ${a.text}`).join(\"\\n\")}`,\n },\n };\n }\n\n /**\n * Creates a new PollStartEvent from question, answers, and metadata.\n * @param question - The question to ask.\n * @param answers - The answers. Should be unique within each other.\n * @param kind - The kind of poll.\n * @param maxSelections - The maximum number of selections. Must be 1 or higher.\n * @returns The representative poll start event.\n */\n public static from(\n question: string,\n answers: string[],\n kind: KnownPollKind | string,\n maxSelections = 1,\n ): PollStartEvent {\n return new PollStartEvent({\n type: M_POLL_START.name,\n content: {\n [M_TEXT.name]: question, // unused by parsing\n [M_POLL_START.name]: {\n question: { [M_TEXT.name]: question },\n kind: kind instanceof NamespacedValue ? kind.name : kind,\n max_selections: maxSelections,\n answers: answers.map((a) => ({ id: makeId(), [M_TEXT.name]: a })),\n },\n },\n });\n }\n}\n\nconst LETTERS = \"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789\";\nfunction makeId(): string {\n return [...Array(16)].map(() => LETTERS.charAt(Math.floor(Math.random() * LETTERS.length))).join(\"\");\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts deleted file mode 100644 index 67483fa..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts +++ /dev/null @@ -1,14 +0,0 @@ -import { Optional } from "matrix-events-sdk"; -/** - * Determines if the given optional was provided a value. - * @param s - The optional to test. - * @returns True if the value is defined. - */ -export declare function isProvided(s: Optional): boolean; -/** - * Determines if the given optional string is a defined string. - * @param s - The input string. - * @returns True if the input is a defined string. - */ -export declare function isOptionalAString(s: Optional): s is string; -//# sourceMappingURL=utilities.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts.map deleted file mode 100644 index b28b961..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"utilities.d.ts","sourceRoot":"","sources":["../../src/extensible_events_v1/utilities.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,GAAG,OAAO,CAErD;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,MAAM,CAElE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js deleted file mode 100644 index cc489a7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js +++ /dev/null @@ -1,41 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.isOptionalAString = isOptionalAString; -exports.isProvided = isProvided; -/* -Copyright 2021 - 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Determines if the given optional was provided a value. - * @param s - The optional to test. - * @returns True if the value is defined. - */ -function isProvided(s) { - return s !== null && s !== undefined; -} - -/** - * Determines if the given optional string is a defined string. - * @param s - The input string. - * @returns True if the input is a defined string. - */ -function isOptionalAString(s) { - return isProvided(s) && typeof s === "string"; -} -//# sourceMappingURL=utilities.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js.map deleted file mode 100644 index e52d6a5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/extensible_events_v1/utilities.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"utilities.js","names":["isProvided","s","undefined","isOptionalAString"],"sources":["../../src/extensible_events_v1/utilities.ts"],"sourcesContent":["/*\nCopyright 2021 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Optional } from \"matrix-events-sdk\";\n\n/**\n * Determines if the given optional was provided a value.\n * @param s - The optional to test.\n * @returns True if the value is defined.\n */\nexport function isProvided(s: Optional): boolean {\n return s !== null && s !== undefined;\n}\n\n/**\n * Determines if the given optional string is a defined string.\n * @param s - The input string.\n * @returns True if the input is a defined string.\n */\nexport function isOptionalAString(s: Optional): s is string {\n return isProvided(s) && typeof s === \"string\";\n}\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIA;AACA;AACA;AACA;AACA;AACO,SAASA,UAAUA,CAAIC,CAAc,EAAW;EACnD,OAAOA,CAAC,KAAK,IAAI,IAAIA,CAAC,KAAKC,SAAS;AACxC;;AAEA;AACA;AACA;AACA;AACA;AACO,SAASC,iBAAiBA,CAACF,CAAmB,EAAe;EAChE,OAAOD,UAAU,CAACC,CAAC,CAAC,IAAI,OAAOA,CAAC,KAAK,QAAQ;AACjD"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts deleted file mode 100644 index 72d913c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -import { IServerVersions } from "./client"; -export declare enum ServerSupport { - Stable = 0, - Unstable = 1, - Unsupported = 2 -} -export declare enum Feature { - Thread = "Thread", - ThreadUnreadNotifications = "ThreadUnreadNotifications", - LoginTokenRequest = "LoginTokenRequest", - RelationBasedRedactions = "RelationBasedRedactions", - AccountDataDeletion = "AccountDataDeletion" -} -export declare function buildFeatureSupportMap(versions: IServerVersions): Promise>; -//# sourceMappingURL=feature.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts.map deleted file mode 100644 index 38d606b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"feature.d.ts","sourceRoot":"","sources":["../src/feature.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C,oBAAY,aAAa;IACrB,MAAM,IAAA;IACN,QAAQ,IAAA;IACR,WAAW,IAAA;CACd;AAED,oBAAY,OAAO;IACf,MAAM,WAAW;IACjB,yBAAyB,8BAA8B;IACvD,iBAAiB,sBAAsB;IACvC,uBAAuB,4BAA4B;IACnD,mBAAmB,wBAAwB;CAC9C;AA2BD,wBAAsB,sBAAsB,CAAC,QAAQ,EAAE,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAiB5G"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js deleted file mode 100644 index 452ff7e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js +++ /dev/null @@ -1,77 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ServerSupport = exports.Feature = void 0; -exports.buildFeatureSupportMap = buildFeatureSupportMap; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let ServerSupport; -exports.ServerSupport = ServerSupport; -(function (ServerSupport) { - ServerSupport[ServerSupport["Stable"] = 0] = "Stable"; - ServerSupport[ServerSupport["Unstable"] = 1] = "Unstable"; - ServerSupport[ServerSupport["Unsupported"] = 2] = "Unsupported"; -})(ServerSupport || (exports.ServerSupport = ServerSupport = {})); -let Feature; -exports.Feature = Feature; -(function (Feature) { - Feature["Thread"] = "Thread"; - Feature["ThreadUnreadNotifications"] = "ThreadUnreadNotifications"; - Feature["LoginTokenRequest"] = "LoginTokenRequest"; - Feature["RelationBasedRedactions"] = "RelationBasedRedactions"; - Feature["AccountDataDeletion"] = "AccountDataDeletion"; -})(Feature || (exports.Feature = Feature = {})); -const featureSupportResolver = { - [Feature.Thread]: { - unstablePrefixes: ["org.matrix.msc3440"], - matrixVersion: "v1.3" - }, - [Feature.ThreadUnreadNotifications]: { - unstablePrefixes: ["org.matrix.msc3771", "org.matrix.msc3773"], - matrixVersion: "v1.4" - }, - [Feature.LoginTokenRequest]: { - unstablePrefixes: ["org.matrix.msc3882"] - }, - [Feature.RelationBasedRedactions]: { - unstablePrefixes: ["org.matrix.msc3912"] - }, - [Feature.AccountDataDeletion]: { - unstablePrefixes: ["org.matrix.msc3391"] - } -}; -async function buildFeatureSupportMap(versions) { - const supportMap = new Map(); - for (const [feature, supportCondition] of Object.entries(featureSupportResolver)) { - var _versions$versions$in, _versions$versions, _supportCondition$uns, _supportCondition$uns2; - const supportMatrixVersion = (_versions$versions$in = (_versions$versions = versions.versions) === null || _versions$versions === void 0 ? void 0 : _versions$versions.includes(supportCondition.matrixVersion || "")) !== null && _versions$versions$in !== void 0 ? _versions$versions$in : false; - const supportUnstablePrefixes = (_supportCondition$uns = (_supportCondition$uns2 = supportCondition.unstablePrefixes) === null || _supportCondition$uns2 === void 0 ? void 0 : _supportCondition$uns2.every(unstablePrefix => { - var _versions$unstable_fe; - return ((_versions$unstable_fe = versions.unstable_features) === null || _versions$unstable_fe === void 0 ? void 0 : _versions$unstable_fe[unstablePrefix]) === true; - })) !== null && _supportCondition$uns !== void 0 ? _supportCondition$uns : false; - if (supportMatrixVersion) { - supportMap.set(feature, ServerSupport.Stable); - } else if (supportUnstablePrefixes) { - supportMap.set(feature, ServerSupport.Unstable); - } else { - supportMap.set(feature, ServerSupport.Unsupported); - } - } - return supportMap; -} -//# sourceMappingURL=feature.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js.map deleted file mode 100644 index e425935..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/feature.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"feature.js","names":["ServerSupport","exports","Feature","featureSupportResolver","Thread","unstablePrefixes","matrixVersion","ThreadUnreadNotifications","LoginTokenRequest","RelationBasedRedactions","AccountDataDeletion","buildFeatureSupportMap","versions","supportMap","Map","feature","supportCondition","Object","entries","_versions$versions$in","_versions$versions","_supportCondition$uns","_supportCondition$uns2","supportMatrixVersion","includes","supportUnstablePrefixes","every","unstablePrefix","_versions$unstable_fe","unstable_features","set","Stable","Unstable","Unsupported"],"sources":["../src/feature.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IServerVersions } from \"./client\";\n\nexport enum ServerSupport {\n Stable,\n Unstable,\n Unsupported,\n}\n\nexport enum Feature {\n Thread = \"Thread\",\n ThreadUnreadNotifications = \"ThreadUnreadNotifications\",\n LoginTokenRequest = \"LoginTokenRequest\",\n RelationBasedRedactions = \"RelationBasedRedactions\",\n AccountDataDeletion = \"AccountDataDeletion\",\n}\n\ntype FeatureSupportCondition = {\n unstablePrefixes?: string[];\n matrixVersion?: string;\n};\n\nconst featureSupportResolver: Record = {\n [Feature.Thread]: {\n unstablePrefixes: [\"org.matrix.msc3440\"],\n matrixVersion: \"v1.3\",\n },\n [Feature.ThreadUnreadNotifications]: {\n unstablePrefixes: [\"org.matrix.msc3771\", \"org.matrix.msc3773\"],\n matrixVersion: \"v1.4\",\n },\n [Feature.LoginTokenRequest]: {\n unstablePrefixes: [\"org.matrix.msc3882\"],\n },\n [Feature.RelationBasedRedactions]: {\n unstablePrefixes: [\"org.matrix.msc3912\"],\n },\n [Feature.AccountDataDeletion]: {\n unstablePrefixes: [\"org.matrix.msc3391\"],\n },\n};\n\nexport async function buildFeatureSupportMap(versions: IServerVersions): Promise> {\n const supportMap = new Map();\n for (const [feature, supportCondition] of Object.entries(featureSupportResolver)) {\n const supportMatrixVersion = versions.versions?.includes(supportCondition.matrixVersion || \"\") ?? false;\n const supportUnstablePrefixes =\n supportCondition.unstablePrefixes?.every((unstablePrefix) => {\n return versions.unstable_features?.[unstablePrefix] === true;\n }) ?? false;\n if (supportMatrixVersion) {\n supportMap.set(feature as Feature, ServerSupport.Stable);\n } else if (supportUnstablePrefixes) {\n supportMap.set(feature as Feature, ServerSupport.Unstable);\n } else {\n supportMap.set(feature as Feature, ServerSupport.Unsupported);\n }\n }\n return supportMap;\n}\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAkBYA,aAAa;AAAAC,OAAA,CAAAD,aAAA,GAAAA,aAAA;AAAA,WAAbA,aAAa;EAAbA,aAAa,CAAbA,aAAa;EAAbA,aAAa,CAAbA,aAAa;EAAbA,aAAa,CAAbA,aAAa;AAAA,GAAbA,aAAa,KAAAC,OAAA,CAAAD,aAAA,GAAbA,aAAa;AAAA,IAMbE,OAAO;AAAAD,OAAA,CAAAC,OAAA,GAAAA,OAAA;AAAA,WAAPA,OAAO;EAAPA,OAAO;EAAPA,OAAO;EAAPA,OAAO;EAAPA,OAAO;EAAPA,OAAO;AAAA,GAAPA,OAAO,KAAAD,OAAA,CAAAC,OAAA,GAAPA,OAAO;AAanB,MAAMC,sBAA+D,GAAG;EACpE,CAACD,OAAO,CAACE,MAAM,GAAG;IACdC,gBAAgB,EAAE,CAAC,oBAAoB,CAAC;IACxCC,aAAa,EAAE;EACnB,CAAC;EACD,CAACJ,OAAO,CAACK,yBAAyB,GAAG;IACjCF,gBAAgB,EAAE,CAAC,oBAAoB,EAAE,oBAAoB,CAAC;IAC9DC,aAAa,EAAE;EACnB,CAAC;EACD,CAACJ,OAAO,CAACM,iBAAiB,GAAG;IACzBH,gBAAgB,EAAE,CAAC,oBAAoB;EAC3C,CAAC;EACD,CAACH,OAAO,CAACO,uBAAuB,GAAG;IAC/BJ,gBAAgB,EAAE,CAAC,oBAAoB;EAC3C,CAAC;EACD,CAACH,OAAO,CAACQ,mBAAmB,GAAG;IAC3BL,gBAAgB,EAAE,CAAC,oBAAoB;EAC3C;AACJ,CAAC;AAEM,eAAeM,sBAAsBA,CAACC,QAAyB,EAAwC;EAC1G,MAAMC,UAAU,GAAG,IAAIC,GAAG,EAA0B;EACpD,KAAK,MAAM,CAACC,OAAO,EAAEC,gBAAgB,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACf,sBAAsB,CAAC,EAAE;IAAA,IAAAgB,qBAAA,EAAAC,kBAAA,EAAAC,qBAAA,EAAAC,sBAAA;IAC9E,MAAMC,oBAAoB,IAAAJ,qBAAA,IAAAC,kBAAA,GAAGR,QAAQ,CAACA,QAAQ,cAAAQ,kBAAA,uBAAjBA,kBAAA,CAAmBI,QAAQ,CAACR,gBAAgB,CAACV,aAAa,IAAI,EAAE,CAAC,cAAAa,qBAAA,cAAAA,qBAAA,GAAI,KAAK;IACvG,MAAMM,uBAAuB,IAAAJ,qBAAA,IAAAC,sBAAA,GACzBN,gBAAgB,CAACX,gBAAgB,cAAAiB,sBAAA,uBAAjCA,sBAAA,CAAmCI,KAAK,CAAEC,cAAc,IAAK;MAAA,IAAAC,qBAAA;MACzD,OAAO,EAAAA,qBAAA,GAAAhB,QAAQ,CAACiB,iBAAiB,cAAAD,qBAAA,uBAA1BA,qBAAA,CAA6BD,cAAc,CAAC,MAAK,IAAI;IAChE,CAAC,CAAC,cAAAN,qBAAA,cAAAA,qBAAA,GAAI,KAAK;IACf,IAAIE,oBAAoB,EAAE;MACtBV,UAAU,CAACiB,GAAG,CAACf,OAAO,EAAaf,aAAa,CAAC+B,MAAM,CAAC;IAC5D,CAAC,MAAM,IAAIN,uBAAuB,EAAE;MAChCZ,UAAU,CAACiB,GAAG,CAACf,OAAO,EAAaf,aAAa,CAACgC,QAAQ,CAAC;IAC9D,CAAC,MAAM;MACHnB,UAAU,CAACiB,GAAG,CAACf,OAAO,EAAaf,aAAa,CAACiC,WAAW,CAAC;IACjE;EACJ;EACA,OAAOpB,UAAU;AACrB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts deleted file mode 100644 index 1fd215b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts +++ /dev/null @@ -1,64 +0,0 @@ -import { RelationType } from "./@types/event"; -import { MatrixEvent } from "./models/event"; -export interface IFilterComponent { - "types"?: string[]; - "not_types"?: string[]; - "rooms"?: string[]; - "not_rooms"?: string[]; - "senders"?: string[]; - "not_senders"?: string[]; - "contains_url"?: boolean; - "limit"?: number; - "related_by_senders"?: Array; - "related_by_rel_types"?: string[]; - "io.element.relation_senders"?: Array; - "io.element.relation_types"?: string[]; -} -/** - * FilterComponent is a section of a Filter definition which defines the - * types, rooms, senders filters etc to be applied to a particular type of resource. - * This is all ported over from synapse's Filter object. - * - * N.B. that synapse refers to these as 'Filters', and what js-sdk refers to as - * 'Filters' are referred to as 'FilterCollections'. - */ -export declare class FilterComponent { - private filterJson; - readonly userId?: string | null | undefined; - constructor(filterJson: IFilterComponent, userId?: string | null | undefined); - /** - * Checks with the filter component matches the given event - * @param event - event to be checked against the filter - * @returns true if the event matches the filter - */ - check(event: MatrixEvent): boolean; - /** - * Converts the filter component into the form expected over the wire - */ - toJSON(): object; - /** - * Checks whether the filter component matches the given event fields. - * @param roomId - the roomId for the event being checked - * @param sender - the sender of the event being checked - * @param eventType - the type of the event being checked - * @param containsUrl - whether the event contains a content.url field - * @param relationTypes - whether has aggregated relation of the given type - * @param relationSenders - whether one of the relation is sent by the user listed - * @returns true if the event fields match the filter - */ - private checkFields; - private arrayMatchesFilter; - /** - * Filters a list of events down to those which match this filter component - * @param events - Events to be checked against the filter component - * @returns events which matched the filter component - */ - filter(events: MatrixEvent[]): MatrixEvent[]; - /** - * Returns the limit field for a given filter component, providing a default of - * 10 if none is otherwise specified. Cargo-culted from Synapse. - * @returns the limit for this filter component. - */ - limit(): number; -} -//# sourceMappingURL=filter-component.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts.map deleted file mode 100644 index a92a832..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"filter-component.d.ts","sourceRoot":"","sources":["../src/filter-component.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAoB7C,MAAM,WAAW,gBAAgB;IAC7B,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,oBAAoB,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC,CAAC;IACpD,sBAAsB,CAAC,EAAE,MAAM,EAAE,CAAC;IAGlC,6BAA6B,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC,CAAC;IAC7D,2BAA2B,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1C;AAGD;;;;;;;GAOG;AACH,qBAAa,eAAe;IACL,OAAO,CAAC,UAAU;aAAoC,MAAM,CAAC;gBAArD,UAAU,EAAE,gBAAgB,EAAkB,MAAM,CAAC,2BAA2B;IAE3G;;;;OAIG;IACI,KAAK,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO;IAuBzC;;OAEG;IACI,MAAM,IAAI,MAAM;IAcvB;;;;;;;;;OASG;IACH,OAAO,CAAC,WAAW;IAwDnB,OAAO,CAAC,kBAAkB;IAS1B;;;;OAIG;IACI,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE,GAAG,WAAW,EAAE;IAInD;;;;OAIG;IACI,KAAK,IAAI,MAAM;CAGzB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js deleted file mode 100644 index e8e15ad..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js +++ /dev/null @@ -1,173 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.FilterComponent = void 0; -var _thread = require("./models/thread"); -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Checks if a value matches a given field value, which may be a * terminated - * wildcard pattern. - * @param actualValue - The value to be compared - * @param filterValue - The filter pattern to be compared - * @returns true if the actualValue matches the filterValue - */ -function matchesWildcard(actualValue, filterValue) { - if (filterValue.endsWith("*")) { - const typePrefix = filterValue.slice(0, -1); - return actualValue.slice(0, typePrefix.length) === typePrefix; - } else { - return actualValue === filterValue; - } -} - -/* eslint-disable camelcase */ - -/* eslint-enable camelcase */ - -/** - * FilterComponent is a section of a Filter definition which defines the - * types, rooms, senders filters etc to be applied to a particular type of resource. - * This is all ported over from synapse's Filter object. - * - * N.B. that synapse refers to these as 'Filters', and what js-sdk refers to as - * 'Filters' are referred to as 'FilterCollections'. - */ -class FilterComponent { - constructor(filterJson, userId) { - this.filterJson = filterJson; - this.userId = userId; - } - - /** - * Checks with the filter component matches the given event - * @param event - event to be checked against the filter - * @returns true if the event matches the filter - */ - check(event) { - var _event$getUnsigned, _bundledRelationships; - const bundledRelationships = ((_event$getUnsigned = event.getUnsigned()) === null || _event$getUnsigned === void 0 ? void 0 : _event$getUnsigned["m.relations"]) || {}; - const relations = Object.keys(bundledRelationships); - // Relation senders allows in theory a look-up of any senders - // however clients can only know about the current user participation status - // as sending a whole list of participants could be proven problematic in terms - // of performance - // This should be improved when bundled relationships solve that problem - const relationSenders = []; - if (this.userId && bundledRelationships !== null && bundledRelationships !== void 0 && (_bundledRelationships = bundledRelationships[_thread.THREAD_RELATION_TYPE.name]) !== null && _bundledRelationships !== void 0 && _bundledRelationships.current_user_participated) { - relationSenders.push(this.userId); - } - return this.checkFields(event.getRoomId(), event.getSender(), event.getType(), event.getContent() ? event.getContent().url !== undefined : false, relations, relationSenders); - } - - /** - * Converts the filter component into the form expected over the wire - */ - toJSON() { - return { - types: this.filterJson.types || null, - not_types: this.filterJson.not_types || [], - rooms: this.filterJson.rooms || null, - not_rooms: this.filterJson.not_rooms || [], - senders: this.filterJson.senders || null, - not_senders: this.filterJson.not_senders || [], - contains_url: this.filterJson.contains_url || null, - [_thread.FILTER_RELATED_BY_SENDERS.name]: this.filterJson[_thread.FILTER_RELATED_BY_SENDERS.name] || [], - [_thread.FILTER_RELATED_BY_REL_TYPES.name]: this.filterJson[_thread.FILTER_RELATED_BY_REL_TYPES.name] || [] - }; - } - - /** - * Checks whether the filter component matches the given event fields. - * @param roomId - the roomId for the event being checked - * @param sender - the sender of the event being checked - * @param eventType - the type of the event being checked - * @param containsUrl - whether the event contains a content.url field - * @param relationTypes - whether has aggregated relation of the given type - * @param relationSenders - whether one of the relation is sent by the user listed - * @returns true if the event fields match the filter - */ - checkFields(roomId, sender, eventType, containsUrl, relationTypes, relationSenders) { - const literalKeys = { - rooms: function (v) { - return roomId === v; - }, - senders: function (v) { - return sender === v; - }, - types: function (v) { - return matchesWildcard(eventType, v); - } - }; - for (const name in literalKeys) { - const matchFunc = literalKeys[name]; - const notName = "not_" + name; - const disallowedValues = this.filterJson[notName]; - if (disallowedValues !== null && disallowedValues !== void 0 && disallowedValues.some(matchFunc)) { - return false; - } - const allowedValues = this.filterJson[name]; - if (allowedValues && !allowedValues.some(matchFunc)) { - return false; - } - } - const containsUrlFilter = this.filterJson.contains_url; - if (containsUrlFilter !== undefined && containsUrlFilter !== containsUrl) { - return false; - } - const relationTypesFilter = this.filterJson[_thread.FILTER_RELATED_BY_REL_TYPES.name]; - if (relationTypesFilter !== undefined) { - if (!this.arrayMatchesFilter(relationTypesFilter, relationTypes)) { - return false; - } - } - const relationSendersFilter = this.filterJson[_thread.FILTER_RELATED_BY_SENDERS.name]; - if (relationSendersFilter !== undefined) { - if (!this.arrayMatchesFilter(relationSendersFilter, relationSenders)) { - return false; - } - } - return true; - } - arrayMatchesFilter(filter, values) { - return values.length > 0 && filter.every(value => { - return values.includes(value); - }); - } - - /** - * Filters a list of events down to those which match this filter component - * @param events - Events to be checked against the filter component - * @returns events which matched the filter component - */ - filter(events) { - return events.filter(this.check, this); - } - - /** - * Returns the limit field for a given filter component, providing a default of - * 10 if none is otherwise specified. Cargo-culted from Synapse. - * @returns the limit for this filter component. - */ - limit() { - return this.filterJson.limit !== undefined ? this.filterJson.limit : 10; - } -} -exports.FilterComponent = FilterComponent; -//# sourceMappingURL=filter-component.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js.map deleted file mode 100644 index be485bc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter-component.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"filter-component.js","names":["_thread","require","matchesWildcard","actualValue","filterValue","endsWith","typePrefix","slice","length","FilterComponent","constructor","filterJson","userId","check","event","_event$getUnsigned","_bundledRelationships","bundledRelationships","getUnsigned","relations","Object","keys","relationSenders","THREAD_RELATION_TYPE","name","current_user_participated","push","checkFields","getRoomId","getSender","getType","getContent","url","undefined","toJSON","types","not_types","rooms","not_rooms","senders","not_senders","contains_url","FILTER_RELATED_BY_SENDERS","FILTER_RELATED_BY_REL_TYPES","roomId","sender","eventType","containsUrl","relationTypes","literalKeys","v","matchFunc","notName","disallowedValues","some","allowedValues","containsUrlFilter","relationTypesFilter","arrayMatchesFilter","relationSendersFilter","filter","values","every","value","includes","events","limit","exports"],"sources":["../src/filter-component.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { RelationType } from \"./@types/event\";\nimport { MatrixEvent } from \"./models/event\";\nimport { FILTER_RELATED_BY_REL_TYPES, FILTER_RELATED_BY_SENDERS, THREAD_RELATION_TYPE } from \"./models/thread\";\n\n/**\n * Checks if a value matches a given field value, which may be a * terminated\n * wildcard pattern.\n * @param actualValue - The value to be compared\n * @param filterValue - The filter pattern to be compared\n * @returns true if the actualValue matches the filterValue\n */\nfunction matchesWildcard(actualValue: string, filterValue: string): boolean {\n if (filterValue.endsWith(\"*\")) {\n const typePrefix = filterValue.slice(0, -1);\n return actualValue.slice(0, typePrefix.length) === typePrefix;\n } else {\n return actualValue === filterValue;\n }\n}\n\n/* eslint-disable camelcase */\nexport interface IFilterComponent {\n \"types\"?: string[];\n \"not_types\"?: string[];\n \"rooms\"?: string[];\n \"not_rooms\"?: string[];\n \"senders\"?: string[];\n \"not_senders\"?: string[];\n \"contains_url\"?: boolean;\n \"limit\"?: number;\n \"related_by_senders\"?: Array;\n \"related_by_rel_types\"?: string[];\n\n // Unstable values\n \"io.element.relation_senders\"?: Array;\n \"io.element.relation_types\"?: string[];\n}\n/* eslint-enable camelcase */\n\n/**\n * FilterComponent is a section of a Filter definition which defines the\n * types, rooms, senders filters etc to be applied to a particular type of resource.\n * This is all ported over from synapse's Filter object.\n *\n * N.B. that synapse refers to these as 'Filters', and what js-sdk refers to as\n * 'Filters' are referred to as 'FilterCollections'.\n */\nexport class FilterComponent {\n public constructor(private filterJson: IFilterComponent, public readonly userId?: string | undefined | null) {}\n\n /**\n * Checks with the filter component matches the given event\n * @param event - event to be checked against the filter\n * @returns true if the event matches the filter\n */\n public check(event: MatrixEvent): boolean {\n const bundledRelationships = event.getUnsigned()?.[\"m.relations\"] || {};\n const relations: Array = Object.keys(bundledRelationships);\n // Relation senders allows in theory a look-up of any senders\n // however clients can only know about the current user participation status\n // as sending a whole list of participants could be proven problematic in terms\n // of performance\n // This should be improved when bundled relationships solve that problem\n const relationSenders: string[] = [];\n if (this.userId && bundledRelationships?.[THREAD_RELATION_TYPE.name]?.current_user_participated) {\n relationSenders.push(this.userId);\n }\n\n return this.checkFields(\n event.getRoomId(),\n event.getSender(),\n event.getType(),\n event.getContent() ? event.getContent().url !== undefined : false,\n relations,\n relationSenders,\n );\n }\n\n /**\n * Converts the filter component into the form expected over the wire\n */\n public toJSON(): object {\n return {\n types: this.filterJson.types || null,\n not_types: this.filterJson.not_types || [],\n rooms: this.filterJson.rooms || null,\n not_rooms: this.filterJson.not_rooms || [],\n senders: this.filterJson.senders || null,\n not_senders: this.filterJson.not_senders || [],\n contains_url: this.filterJson.contains_url || null,\n [FILTER_RELATED_BY_SENDERS.name]: this.filterJson[FILTER_RELATED_BY_SENDERS.name] || [],\n [FILTER_RELATED_BY_REL_TYPES.name]: this.filterJson[FILTER_RELATED_BY_REL_TYPES.name] || [],\n };\n }\n\n /**\n * Checks whether the filter component matches the given event fields.\n * @param roomId - the roomId for the event being checked\n * @param sender - the sender of the event being checked\n * @param eventType - the type of the event being checked\n * @param containsUrl - whether the event contains a content.url field\n * @param relationTypes - whether has aggregated relation of the given type\n * @param relationSenders - whether one of the relation is sent by the user listed\n * @returns true if the event fields match the filter\n */\n private checkFields(\n roomId: string | undefined,\n sender: string | undefined,\n eventType: string,\n containsUrl: boolean,\n relationTypes: Array,\n relationSenders: string[],\n ): boolean {\n const literalKeys = {\n rooms: function (v: string): boolean {\n return roomId === v;\n },\n senders: function (v: string): boolean {\n return sender === v;\n },\n types: function (v: string): boolean {\n return matchesWildcard(eventType, v);\n },\n } as const;\n\n for (const name in literalKeys) {\n const matchFunc = literalKeys[name];\n const notName = \"not_\" + name;\n const disallowedValues = this.filterJson[<`not_${keyof typeof literalKeys}`>notName];\n if (disallowedValues?.some(matchFunc)) {\n return false;\n }\n\n const allowedValues = this.filterJson[name as keyof typeof literalKeys];\n if (allowedValues && !allowedValues.some(matchFunc)) {\n return false;\n }\n }\n\n const containsUrlFilter = this.filterJson.contains_url;\n if (containsUrlFilter !== undefined && containsUrlFilter !== containsUrl) {\n return false;\n }\n\n const relationTypesFilter = this.filterJson[FILTER_RELATED_BY_REL_TYPES.name];\n if (relationTypesFilter !== undefined) {\n if (!this.arrayMatchesFilter(relationTypesFilter, relationTypes)) {\n return false;\n }\n }\n\n const relationSendersFilter = this.filterJson[FILTER_RELATED_BY_SENDERS.name];\n if (relationSendersFilter !== undefined) {\n if (!this.arrayMatchesFilter(relationSendersFilter, relationSenders)) {\n return false;\n }\n }\n\n return true;\n }\n\n private arrayMatchesFilter(filter: any[], values: any[]): boolean {\n return (\n values.length > 0 &&\n filter.every((value) => {\n return values.includes(value);\n })\n );\n }\n\n /**\n * Filters a list of events down to those which match this filter component\n * @param events - Events to be checked against the filter component\n * @returns events which matched the filter component\n */\n public filter(events: MatrixEvent[]): MatrixEvent[] {\n return events.filter(this.check, this);\n }\n\n /**\n * Returns the limit field for a given filter component, providing a default of\n * 10 if none is otherwise specified. Cargo-culted from Synapse.\n * @returns the limit for this filter component.\n */\n public limit(): number {\n return this.filterJson.limit !== undefined ? this.filterJson.limit : 10;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts deleted file mode 100644 index 2f0523a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts +++ /dev/null @@ -1,97 +0,0 @@ -import { EventType, RelationType } from "./@types/event"; -import { FilterComponent, IFilterComponent } from "./filter-component"; -import { MatrixEvent } from "./models/event"; -export interface IFilterDefinition { - event_fields?: string[]; - event_format?: "client" | "federation"; - presence?: IFilterComponent; - account_data?: IFilterComponent; - room?: IRoomFilter; -} -export interface IRoomEventFilter extends IFilterComponent { - "lazy_load_members"?: boolean; - "include_redundant_members"?: boolean; - "types"?: Array; - "related_by_senders"?: Array; - "related_by_rel_types"?: string[]; - "unread_thread_notifications"?: boolean; - "org.matrix.msc3773.unread_thread_notifications"?: boolean; - "io.element.relation_senders"?: Array; - "io.element.relation_types"?: string[]; -} -interface IStateFilter extends IRoomEventFilter { -} -interface IRoomFilter { - not_rooms?: string[]; - rooms?: string[]; - ephemeral?: IRoomEventFilter; - include_leave?: boolean; - state?: IStateFilter; - timeline?: IRoomEventFilter; - account_data?: IRoomEventFilter; -} -export declare class Filter { - readonly userId: string | undefined | null; - filterId?: string | undefined; - static LAZY_LOADING_MESSAGES_FILTER: { - lazy_load_members: boolean; - }; - /** - * Create a filter from existing data. - */ - static fromJson(userId: string | undefined | null, filterId: string, jsonObj: IFilterDefinition): Filter; - private definition; - private roomFilter?; - private roomTimelineFilter?; - /** - * Construct a new Filter. - * @param userId - The user ID for this filter. - * @param filterId - The filter ID if known. - */ - constructor(userId: string | undefined | null, filterId?: string | undefined); - /** - * Get the ID of this filter on your homeserver (if known) - * @returns The filter ID - */ - getFilterId(): string | undefined; - /** - * Get the JSON body of the filter. - * @returns The filter definition - */ - getDefinition(): IFilterDefinition; - /** - * Set the JSON body of the filter - * @param definition - The filter definition - */ - setDefinition(definition: IFilterDefinition): void; - /** - * Get the room.timeline filter component of the filter - * @returns room timeline filter component - */ - getRoomTimelineFilterComponent(): FilterComponent | undefined; - /** - * Filter the list of events based on whether they are allowed in a timeline - * based on this filter - * @param events - the list of events being filtered - * @returns the list of events which match the filter - */ - filterRoomTimeline(events: MatrixEvent[]): MatrixEvent[]; - /** - * Set the max number of events to return for each room's timeline. - * @param limit - The max number of events to return for each room. - */ - setTimelineLimit(limit: number): void; - /** - * Enable threads unread notification - */ - setUnreadThreadNotifications(enabled: boolean): void; - setLazyLoadMembers(enabled: boolean): void; - /** - * Control whether left rooms should be included in responses. - * @param includeLeave - True to make rooms the user has left appear - * in responses. - */ - setIncludeLeaveRooms(includeLeave: boolean): void; -} -export {}; -//# sourceMappingURL=filter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts.map deleted file mode 100644 index b14c30f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../src/filter.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEzD,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAiB7C,MAAM,WAAW,iBAAiB;IAC9B,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,YAAY,CAAC,EAAE,QAAQ,GAAG,YAAY,CAAC;IACvC,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,YAAY,CAAC,EAAE,gBAAgB,CAAC;IAChC,IAAI,CAAC,EAAE,WAAW,CAAC;CACtB;AAED,MAAM,WAAW,gBAAiB,SAAQ,gBAAgB;IACtD,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,2BAA2B,CAAC,EAAE,OAAO,CAAC;IACtC,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,CAAC;IACpC,oBAAoB,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC,CAAC;IACpD,sBAAsB,CAAC,EAAE,MAAM,EAAE,CAAC;IAClC,6BAA6B,CAAC,EAAE,OAAO,CAAC;IACxC,gDAAgD,CAAC,EAAE,OAAO,CAAC;IAG3D,6BAA6B,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC,CAAC;IAC7D,2BAA2B,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1C;AAED,UAAU,YAAa,SAAQ,gBAAgB;CAAG;AAElD,UAAU,WAAW;IACjB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IACjB,SAAS,CAAC,EAAE,gBAAgB,CAAC;IAC7B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,KAAK,CAAC,EAAE,YAAY,CAAC;IACrB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,YAAY,CAAC,EAAE,gBAAgB,CAAC;CACnC;AAGD,qBAAa,MAAM;aAuBoB,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAAS,QAAQ,CAAC;IAtBtF,OAAc,4BAA4B;;MAExC;IAEF;;OAEG;WACW,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,iBAAiB,GAAG,MAAM;IAM/G,OAAO,CAAC,UAAU,CAAyB;IAC3C,OAAO,CAAC,UAAU,CAAC,CAAkB;IACrC,OAAO,CAAC,kBAAkB,CAAC,CAAkB;IAE7C;;;;OAIG;gBACgC,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,EAAS,QAAQ,CAAC,oBAAQ;IAE9F;;;OAGG;IACI,WAAW,IAAI,MAAM,GAAG,SAAS;IAIxC;;;OAGG;IACI,aAAa,IAAI,iBAAiB;IAIzC;;;OAGG;IACI,aAAa,CAAC,UAAU,EAAE,iBAAiB,GAAG,IAAI;IAiEzD;;;OAGG;IACI,8BAA8B,IAAI,eAAe,GAAG,SAAS;IAIpE;;;;;OAKG;IACI,kBAAkB,CAAC,MAAM,EAAE,WAAW,EAAE,GAAG,WAAW,EAAE;IAU/D;;;OAGG;IACI,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAI5C;;OAEG;IACI,4BAA4B,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAapD,kBAAkB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAIjD;;;;OAIG;IACI,oBAAoB,CAAC,YAAY,EAAE,OAAO,GAAG,IAAI;CAG3D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js deleted file mode 100644 index 8f18d57..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js +++ /dev/null @@ -1,199 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.Filter = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _sync = require("./@types/sync"); -var _filterComponent = require("./filter-component"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - */ -function setProp(obj, keyNesting, val) { - const nestedKeys = keyNesting.split("."); - let currentObj = obj; - for (let i = 0; i < nestedKeys.length - 1; i++) { - if (!currentObj[nestedKeys[i]]) { - currentObj[nestedKeys[i]] = {}; - } - currentObj = currentObj[nestedKeys[i]]; - } - currentObj[nestedKeys[nestedKeys.length - 1]] = val; -} - -/* eslint-disable camelcase */ - -/* eslint-enable camelcase */ - -class Filter { - /** - * Create a filter from existing data. - */ - static fromJson(userId, filterId, jsonObj) { - const filter = new Filter(userId, filterId); - filter.setDefinition(jsonObj); - return filter; - } - /** - * Construct a new Filter. - * @param userId - The user ID for this filter. - * @param filterId - The filter ID if known. - */ - constructor(userId, filterId) { - this.userId = userId; - this.filterId = filterId; - (0, _defineProperty2.default)(this, "definition", {}); - (0, _defineProperty2.default)(this, "roomFilter", void 0); - (0, _defineProperty2.default)(this, "roomTimelineFilter", void 0); - } - - /** - * Get the ID of this filter on your homeserver (if known) - * @returns The filter ID - */ - getFilterId() { - return this.filterId; - } - - /** - * Get the JSON body of the filter. - * @returns The filter definition - */ - getDefinition() { - return this.definition; - } - - /** - * Set the JSON body of the filter - * @param definition - The filter definition - */ - setDefinition(definition) { - this.definition = definition; - - // This is all ported from synapse's FilterCollection() - - // definitions look something like: - // { - // "room": { - // "rooms": ["!abcde:example.com"], - // "not_rooms": ["!123456:example.com"], - // "state": { - // "types": ["m.room.*"], - // "not_rooms": ["!726s6s6q:example.com"], - // "lazy_load_members": true, - // }, - // "timeline": { - // "limit": 10, - // "types": ["m.room.message"], - // "not_rooms": ["!726s6s6q:example.com"], - // "not_senders": ["@spam:example.com"] - // "contains_url": true - // }, - // "ephemeral": { - // "types": ["m.receipt", "m.typing"], - // "not_rooms": ["!726s6s6q:example.com"], - // "not_senders": ["@spam:example.com"] - // } - // }, - // "presence": { - // "types": ["m.presence"], - // "not_senders": ["@alice:example.com"] - // }, - // "event_format": "client", - // "event_fields": ["type", "content", "sender"] - // } - - const roomFilterJson = definition.room; - - // consider the top level rooms/not_rooms filter - const roomFilterFields = {}; - if (roomFilterJson) { - if (roomFilterJson.rooms) { - roomFilterFields.rooms = roomFilterJson.rooms; - } - if (roomFilterJson.rooms) { - roomFilterFields.not_rooms = roomFilterJson.not_rooms; - } - } - this.roomFilter = new _filterComponent.FilterComponent(roomFilterFields, this.userId); - this.roomTimelineFilter = new _filterComponent.FilterComponent((roomFilterJson === null || roomFilterJson === void 0 ? void 0 : roomFilterJson.timeline) || {}, this.userId); - - // don't bother porting this from synapse yet: - // this._room_state_filter = - // new FilterComponent(roomFilterJson.state || {}); - // this._room_ephemeral_filter = - // new FilterComponent(roomFilterJson.ephemeral || {}); - // this._room_account_data_filter = - // new FilterComponent(roomFilterJson.account_data || {}); - // this._presence_filter = - // new FilterComponent(definition.presence || {}); - // this._account_data_filter = - // new FilterComponent(definition.account_data || {}); - } - - /** - * Get the room.timeline filter component of the filter - * @returns room timeline filter component - */ - getRoomTimelineFilterComponent() { - return this.roomTimelineFilter; - } - - /** - * Filter the list of events based on whether they are allowed in a timeline - * based on this filter - * @param events - the list of events being filtered - * @returns the list of events which match the filter - */ - filterRoomTimeline(events) { - if (this.roomFilter) { - events = this.roomFilter.filter(events); - } - if (this.roomTimelineFilter) { - events = this.roomTimelineFilter.filter(events); - } - return events; - } - - /** - * Set the max number of events to return for each room's timeline. - * @param limit - The max number of events to return for each room. - */ - setTimelineLimit(limit) { - setProp(this.definition, "room.timeline.limit", limit); - } - - /** - * Enable threads unread notification - */ - setUnreadThreadNotifications(enabled) { - var _this$definition, _this$definition2, _this$definition2$roo; - this.definition = _objectSpread(_objectSpread({}, this.definition), {}, { - room: _objectSpread(_objectSpread({}, (_this$definition = this.definition) === null || _this$definition === void 0 ? void 0 : _this$definition.room), {}, { - timeline: _objectSpread(_objectSpread({}, (_this$definition2 = this.definition) === null || _this$definition2 === void 0 ? void 0 : (_this$definition2$roo = _this$definition2.room) === null || _this$definition2$roo === void 0 ? void 0 : _this$definition2$roo.timeline), {}, { - [_sync.UNREAD_THREAD_NOTIFICATIONS.name]: enabled - }) - }) - }); - } - setLazyLoadMembers(enabled) { - setProp(this.definition, "room.state.lazy_load_members", enabled); - } - - /** - * Control whether left rooms should be included in responses. - * @param includeLeave - True to make rooms the user has left appear - * in responses. - */ - setIncludeLeaveRooms(includeLeave) { - setProp(this.definition, "room.include_leave", includeLeave); - } -} -exports.Filter = Filter; -(0, _defineProperty2.default)(Filter, "LAZY_LOADING_MESSAGES_FILTER", { - lazy_load_members: true -}); -//# sourceMappingURL=filter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js.map deleted file mode 100644 index 5d21bf8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/filter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"filter.js","names":["_sync","require","_filterComponent","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","setProp","obj","keyNesting","val","nestedKeys","split","currentObj","Filter","fromJson","userId","filterId","jsonObj","setDefinition","constructor","getFilterId","getDefinition","definition","roomFilterJson","room","roomFilterFields","rooms","not_rooms","roomFilter","FilterComponent","roomTimelineFilter","timeline","getRoomTimelineFilterComponent","filterRoomTimeline","events","setTimelineLimit","limit","setUnreadThreadNotifications","enabled","_this$definition","_this$definition2","_this$definition2$roo","UNREAD_THREAD_NOTIFICATIONS","name","setLazyLoadMembers","setIncludeLeaveRooms","includeLeave","exports","lazy_load_members"],"sources":["../src/filter.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EventType, RelationType } from \"./@types/event\";\nimport { UNREAD_THREAD_NOTIFICATIONS } from \"./@types/sync\";\nimport { FilterComponent, IFilterComponent } from \"./filter-component\";\nimport { MatrixEvent } from \"./models/event\";\n\n/**\n */\nfunction setProp(obj: Record, keyNesting: string, val: any): void {\n const nestedKeys = keyNesting.split(\".\") as [keyof typeof obj];\n let currentObj = obj;\n for (let i = 0; i < nestedKeys.length - 1; i++) {\n if (!currentObj[nestedKeys[i]]) {\n currentObj[nestedKeys[i]] = {};\n }\n currentObj = currentObj[nestedKeys[i]];\n }\n currentObj[nestedKeys[nestedKeys.length - 1]] = val;\n}\n\n/* eslint-disable camelcase */\nexport interface IFilterDefinition {\n event_fields?: string[];\n event_format?: \"client\" | \"federation\";\n presence?: IFilterComponent;\n account_data?: IFilterComponent;\n room?: IRoomFilter;\n}\n\nexport interface IRoomEventFilter extends IFilterComponent {\n \"lazy_load_members\"?: boolean;\n \"include_redundant_members\"?: boolean;\n \"types\"?: Array;\n \"related_by_senders\"?: Array;\n \"related_by_rel_types\"?: string[];\n \"unread_thread_notifications\"?: boolean;\n \"org.matrix.msc3773.unread_thread_notifications\"?: boolean;\n\n // Unstable values\n \"io.element.relation_senders\"?: Array;\n \"io.element.relation_types\"?: string[];\n}\n\ninterface IStateFilter extends IRoomEventFilter {}\n\ninterface IRoomFilter {\n not_rooms?: string[];\n rooms?: string[];\n ephemeral?: IRoomEventFilter;\n include_leave?: boolean;\n state?: IStateFilter;\n timeline?: IRoomEventFilter;\n account_data?: IRoomEventFilter;\n}\n/* eslint-enable camelcase */\n\nexport class Filter {\n public static LAZY_LOADING_MESSAGES_FILTER = {\n lazy_load_members: true,\n };\n\n /**\n * Create a filter from existing data.\n */\n public static fromJson(userId: string | undefined | null, filterId: string, jsonObj: IFilterDefinition): Filter {\n const filter = new Filter(userId, filterId);\n filter.setDefinition(jsonObj);\n return filter;\n }\n\n private definition: IFilterDefinition = {};\n private roomFilter?: FilterComponent;\n private roomTimelineFilter?: FilterComponent;\n\n /**\n * Construct a new Filter.\n * @param userId - The user ID for this filter.\n * @param filterId - The filter ID if known.\n */\n public constructor(public readonly userId: string | undefined | null, public filterId?: string) {}\n\n /**\n * Get the ID of this filter on your homeserver (if known)\n * @returns The filter ID\n */\n public getFilterId(): string | undefined {\n return this.filterId;\n }\n\n /**\n * Get the JSON body of the filter.\n * @returns The filter definition\n */\n public getDefinition(): IFilterDefinition {\n return this.definition;\n }\n\n /**\n * Set the JSON body of the filter\n * @param definition - The filter definition\n */\n public setDefinition(definition: IFilterDefinition): void {\n this.definition = definition;\n\n // This is all ported from synapse's FilterCollection()\n\n // definitions look something like:\n // {\n // \"room\": {\n // \"rooms\": [\"!abcde:example.com\"],\n // \"not_rooms\": [\"!123456:example.com\"],\n // \"state\": {\n // \"types\": [\"m.room.*\"],\n // \"not_rooms\": [\"!726s6s6q:example.com\"],\n // \"lazy_load_members\": true,\n // },\n // \"timeline\": {\n // \"limit\": 10,\n // \"types\": [\"m.room.message\"],\n // \"not_rooms\": [\"!726s6s6q:example.com\"],\n // \"not_senders\": [\"@spam:example.com\"]\n // \"contains_url\": true\n // },\n // \"ephemeral\": {\n // \"types\": [\"m.receipt\", \"m.typing\"],\n // \"not_rooms\": [\"!726s6s6q:example.com\"],\n // \"not_senders\": [\"@spam:example.com\"]\n // }\n // },\n // \"presence\": {\n // \"types\": [\"m.presence\"],\n // \"not_senders\": [\"@alice:example.com\"]\n // },\n // \"event_format\": \"client\",\n // \"event_fields\": [\"type\", \"content\", \"sender\"]\n // }\n\n const roomFilterJson = definition.room;\n\n // consider the top level rooms/not_rooms filter\n const roomFilterFields: IRoomFilter = {};\n if (roomFilterJson) {\n if (roomFilterJson.rooms) {\n roomFilterFields.rooms = roomFilterJson.rooms;\n }\n if (roomFilterJson.rooms) {\n roomFilterFields.not_rooms = roomFilterJson.not_rooms;\n }\n }\n\n this.roomFilter = new FilterComponent(roomFilterFields, this.userId);\n this.roomTimelineFilter = new FilterComponent(roomFilterJson?.timeline || {}, this.userId);\n\n // don't bother porting this from synapse yet:\n // this._room_state_filter =\n // new FilterComponent(roomFilterJson.state || {});\n // this._room_ephemeral_filter =\n // new FilterComponent(roomFilterJson.ephemeral || {});\n // this._room_account_data_filter =\n // new FilterComponent(roomFilterJson.account_data || {});\n // this._presence_filter =\n // new FilterComponent(definition.presence || {});\n // this._account_data_filter =\n // new FilterComponent(definition.account_data || {});\n }\n\n /**\n * Get the room.timeline filter component of the filter\n * @returns room timeline filter component\n */\n public getRoomTimelineFilterComponent(): FilterComponent | undefined {\n return this.roomTimelineFilter;\n }\n\n /**\n * Filter the list of events based on whether they are allowed in a timeline\n * based on this filter\n * @param events - the list of events being filtered\n * @returns the list of events which match the filter\n */\n public filterRoomTimeline(events: MatrixEvent[]): MatrixEvent[] {\n if (this.roomFilter) {\n events = this.roomFilter.filter(events);\n }\n if (this.roomTimelineFilter) {\n events = this.roomTimelineFilter.filter(events);\n }\n return events;\n }\n\n /**\n * Set the max number of events to return for each room's timeline.\n * @param limit - The max number of events to return for each room.\n */\n public setTimelineLimit(limit: number): void {\n setProp(this.definition, \"room.timeline.limit\", limit);\n }\n\n /**\n * Enable threads unread notification\n */\n public setUnreadThreadNotifications(enabled: boolean): void {\n this.definition = {\n ...this.definition,\n room: {\n ...this.definition?.room,\n timeline: {\n ...this.definition?.room?.timeline,\n [UNREAD_THREAD_NOTIFICATIONS.name]: enabled,\n },\n },\n };\n }\n\n public setLazyLoadMembers(enabled: boolean): void {\n setProp(this.definition, \"room.state.lazy_load_members\", enabled);\n }\n\n /**\n * Control whether left rooms should be included in responses.\n * @param includeLeave - True to make rooms the user has left appear\n * in responses.\n */\n public setIncludeLeaveRooms(includeLeave: boolean): void {\n setProp(this.definition, \"room.include_leave\", includeLeave);\n }\n}\n"],"mappings":";;;;;;;;AAiBA,IAAAA,KAAA,GAAAC,OAAA;AACA,IAAAC,gBAAA,GAAAD,OAAA;AAAuE,SAAAE,QAAAC,MAAA,EAAAC,cAAA,QAAAC,IAAA,GAAAC,MAAA,CAAAD,IAAA,CAAAF,MAAA,OAAAG,MAAA,CAAAC,qBAAA,QAAAC,OAAA,GAAAF,MAAA,CAAAC,qBAAA,CAAAJ,MAAA,GAAAC,cAAA,KAAAI,OAAA,GAAAA,OAAA,CAAAC,MAAA,WAAAC,GAAA,WAAAJ,MAAA,CAAAK,wBAAA,CAAAR,MAAA,EAAAO,GAAA,EAAAE,UAAA,OAAAP,IAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,IAAA,EAAAG,OAAA,YAAAH,IAAA;AAAA,SAAAU,cAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,WAAAF,SAAA,CAAAD,CAAA,IAAAC,SAAA,CAAAD,CAAA,QAAAA,CAAA,OAAAf,OAAA,CAAAI,MAAA,CAAAc,MAAA,OAAAC,OAAA,WAAAC,GAAA,QAAAC,gBAAA,CAAAC,OAAA,EAAAR,MAAA,EAAAM,GAAA,EAAAF,MAAA,CAAAE,GAAA,SAAAhB,MAAA,CAAAmB,yBAAA,GAAAnB,MAAA,CAAAoB,gBAAA,CAAAV,MAAA,EAAAV,MAAA,CAAAmB,yBAAA,CAAAL,MAAA,KAAAlB,OAAA,CAAAI,MAAA,CAAAc,MAAA,GAAAC,OAAA,WAAAC,GAAA,IAAAhB,MAAA,CAAAqB,cAAA,CAAAX,MAAA,EAAAM,GAAA,EAAAhB,MAAA,CAAAK,wBAAA,CAAAS,MAAA,EAAAE,GAAA,iBAAAN,MAAA;AAGvE;AACA;AACA,SAASY,OAAOA,CAACC,GAAwB,EAAEC,UAAkB,EAAEC,GAAQ,EAAQ;EAC3E,MAAMC,UAAU,GAAGF,UAAU,CAACG,KAAK,CAAC,GAAG,CAAuB;EAC9D,IAAIC,UAAU,GAAGL,GAAG;EACpB,KAAK,IAAIZ,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGe,UAAU,CAACb,MAAM,GAAG,CAAC,EAAEF,CAAC,EAAE,EAAE;IAC5C,IAAI,CAACiB,UAAU,CAACF,UAAU,CAACf,CAAC,CAAC,CAAC,EAAE;MAC5BiB,UAAU,CAACF,UAAU,CAACf,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAClC;IACAiB,UAAU,GAAGA,UAAU,CAACF,UAAU,CAACf,CAAC,CAAC,CAAC;EAC1C;EACAiB,UAAU,CAACF,UAAU,CAACA,UAAU,CAACb,MAAM,GAAG,CAAC,CAAC,CAAC,GAAGY,GAAG;AACvD;;AAEA;;AAkCA;;AAEO,MAAMI,MAAM,CAAC;EAKhB;AACJ;AACA;EACI,OAAcC,QAAQA,CAACC,MAAiC,EAAEC,QAAgB,EAAEC,OAA0B,EAAU;IAC5G,MAAM9B,MAAM,GAAG,IAAI0B,MAAM,CAACE,MAAM,EAAEC,QAAQ,CAAC;IAC3C7B,MAAM,CAAC+B,aAAa,CAACD,OAAO,CAAC;IAC7B,OAAO9B,MAAM;EACjB;EAMA;AACJ;AACA;AACA;AACA;EACWgC,WAAWA,CAAiBJ,MAAiC,EAASC,QAAiB,EAAE;IAAA,KAA7DD,MAAiC,GAAjCA,MAAiC;IAAA,KAASC,QAAiB,GAAjBA,QAAiB;IAAA,IAAAf,gBAAA,CAAAC,OAAA,sBATtD,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;EASuD;;EAEjG;AACJ;AACA;AACA;EACWkB,WAAWA,CAAA,EAAuB;IACrC,OAAO,IAAI,CAACJ,QAAQ;EACxB;;EAEA;AACJ;AACA;AACA;EACWK,aAAaA,CAAA,EAAsB;IACtC,OAAO,IAAI,CAACC,UAAU;EAC1B;;EAEA;AACJ;AACA;AACA;EACWJ,aAAaA,CAACI,UAA6B,EAAQ;IACtD,IAAI,CAACA,UAAU,GAAGA,UAAU;;IAE5B;;IAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;;IAEA,MAAMC,cAAc,GAAGD,UAAU,CAACE,IAAI;;IAEtC;IACA,MAAMC,gBAA6B,GAAG,CAAC,CAAC;IACxC,IAAIF,cAAc,EAAE;MAChB,IAAIA,cAAc,CAACG,KAAK,EAAE;QACtBD,gBAAgB,CAACC,KAAK,GAAGH,cAAc,CAACG,KAAK;MACjD;MACA,IAAIH,cAAc,CAACG,KAAK,EAAE;QACtBD,gBAAgB,CAACE,SAAS,GAAGJ,cAAc,CAACI,SAAS;MACzD;IACJ;IAEA,IAAI,CAACC,UAAU,GAAG,IAAIC,gCAAe,CAACJ,gBAAgB,EAAE,IAAI,CAACV,MAAM,CAAC;IACpE,IAAI,CAACe,kBAAkB,GAAG,IAAID,gCAAe,CAAC,CAAAN,cAAc,aAAdA,cAAc,uBAAdA,cAAc,CAAEQ,QAAQ,KAAI,CAAC,CAAC,EAAE,IAAI,CAAChB,MAAM,CAAC;;IAE1F;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;EACJ;;EAEA;AACJ;AACA;AACA;EACWiB,8BAA8BA,CAAA,EAAgC;IACjE,OAAO,IAAI,CAACF,kBAAkB;EAClC;;EAEA;AACJ;AACA;AACA;AACA;AACA;EACWG,kBAAkBA,CAACC,MAAqB,EAAiB;IAC5D,IAAI,IAAI,CAACN,UAAU,EAAE;MACjBM,MAAM,GAAG,IAAI,CAACN,UAAU,CAACzC,MAAM,CAAC+C,MAAM,CAAC;IAC3C;IACA,IAAI,IAAI,CAACJ,kBAAkB,EAAE;MACzBI,MAAM,GAAG,IAAI,CAACJ,kBAAkB,CAAC3C,MAAM,CAAC+C,MAAM,CAAC;IACnD;IACA,OAAOA,MAAM;EACjB;;EAEA;AACJ;AACA;AACA;EACWC,gBAAgBA,CAACC,KAAa,EAAQ;IACzC9B,OAAO,CAAC,IAAI,CAACgB,UAAU,EAAE,qBAAqB,EAAEc,KAAK,CAAC;EAC1D;;EAEA;AACJ;AACA;EACWC,4BAA4BA,CAACC,OAAgB,EAAQ;IAAA,IAAAC,gBAAA,EAAAC,iBAAA,EAAAC,qBAAA;IACxD,IAAI,CAACnB,UAAU,GAAA7B,aAAA,CAAAA,aAAA,KACR,IAAI,CAAC6B,UAAU;MAClBE,IAAI,EAAA/B,aAAA,CAAAA,aAAA,MAAA8C,gBAAA,GACG,IAAI,CAACjB,UAAU,cAAAiB,gBAAA,uBAAfA,gBAAA,CAAiBf,IAAI;QACxBO,QAAQ,EAAAtC,aAAA,CAAAA,aAAA,MAAA+C,iBAAA,GACD,IAAI,CAAClB,UAAU,cAAAkB,iBAAA,wBAAAC,qBAAA,GAAfD,iBAAA,CAAiBhB,IAAI,cAAAiB,qBAAA,uBAArBA,qBAAA,CAAuBV,QAAQ;UAClC,CAACW,iCAA2B,CAACC,IAAI,GAAGL;QAAO;MAC9C;IACJ,EACJ;EACL;EAEOM,kBAAkBA,CAACN,OAAgB,EAAQ;IAC9ChC,OAAO,CAAC,IAAI,CAACgB,UAAU,EAAE,8BAA8B,EAAEgB,OAAO,CAAC;EACrE;;EAEA;AACJ;AACA;AACA;AACA;EACWO,oBAAoBA,CAACC,YAAqB,EAAQ;IACrDxC,OAAO,CAAC,IAAI,CAACgB,UAAU,EAAE,oBAAoB,EAAEwB,YAAY,CAAC;EAChE;AACJ;AAACC,OAAA,CAAAlC,MAAA,GAAAA,MAAA;AAAA,IAAAZ,gBAAA,CAAAC,OAAA,EA1KYW,MAAM,kCAC8B;EACzCmC,iBAAiB,EAAE;AACvB,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts deleted file mode 100644 index f5b21c2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts +++ /dev/null @@ -1,43 +0,0 @@ -import { IUsageLimit } from "../@types/partials"; -import { MatrixEvent } from "../models/event"; -interface IErrorJson extends Partial { - [key: string]: any; - errcode?: string; - error?: string; -} -/** - * Construct a generic HTTP error. This is a JavaScript Error with additional information - * specific to HTTP responses. - * @param msg - The error message to include. - * @param httpStatus - The HTTP response status code. - */ -export declare class HTTPError extends Error { - readonly httpStatus?: number | undefined; - constructor(msg: string, httpStatus?: number | undefined); -} -export declare class MatrixError extends HTTPError { - readonly httpStatus?: number | undefined; - url?: string | undefined; - event?: MatrixEvent | undefined; - readonly errcode?: string; - data: IErrorJson; - /** - * Construct a Matrix error. This is a JavaScript Error with additional - * information specific to the standard Matrix error response. - * @param errorJson - The Matrix error JSON returned from the homeserver. - * @param httpStatus - The numeric HTTP status code given - */ - constructor(errorJson?: IErrorJson, httpStatus?: number | undefined, url?: string | undefined, event?: MatrixEvent | undefined); -} -/** - * Construct a ConnectionError. This is a JavaScript Error indicating - * that a request failed because of some error with the connection, either - * CORS was not correctly configured on the server, the server didn't response, - * the request timed out, or the internet connection on the client side went down. - */ -export declare class ConnectionError extends Error { - constructor(message: string, cause?: Error); - get name(): string; -} -export {}; -//# sourceMappingURL=errors.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts.map deleted file mode 100644 index f13050a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/http-api/errors.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,UAAU,UAAW,SAAQ,OAAO,CAAC,WAAW,CAAC;IAC7C,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;;;;GAKG;AACH,qBAAa,SAAU,SAAQ,KAAK;aACgB,UAAU,CAAC;gBAAxC,GAAG,EAAE,MAAM,EAAkB,UAAU,CAAC,oBAAQ;CAGtE;AAED,qBAAa,WAAY,SAAQ,SAAS;aAclB,UAAU,CAAC;IACpB,GAAG,CAAC;IACJ,KAAK,CAAC;IAdjB,SAAgB,OAAO,CAAC,EAAE,MAAM,CAAC;IAE1B,IAAI,EAAE,UAAU,CAAC;IAExB;;;;;OAKG;gBAEC,SAAS,GAAE,UAAe,EACV,UAAU,CAAC,oBAAQ,EAC5B,GAAG,CAAC,oBAAQ,EACZ,KAAK,CAAC,yBAAa;CAcjC;AAED;;;;;GAKG;AACH,qBAAa,eAAgB,SAAQ,KAAK;gBACnB,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;IAIjD,IAAW,IAAI,IAAI,MAAM,CAExB;CACJ"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js deleted file mode 100644 index 88ec475..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js +++ /dev/null @@ -1,85 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MatrixError = exports.HTTPError = exports.ConnectionError = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Construct a generic HTTP error. This is a JavaScript Error with additional information - * specific to HTTP responses. - * @param msg - The error message to include. - * @param httpStatus - The HTTP response status code. - */ -class HTTPError extends Error { - constructor(msg, httpStatus) { - super(msg); - this.httpStatus = httpStatus; - } -} -exports.HTTPError = HTTPError; -class MatrixError extends HTTPError { - // The Matrix 'errcode' value, e.g. "M_FORBIDDEN". - - // The raw Matrix error JSON used to construct this object. - - /** - * Construct a Matrix error. This is a JavaScript Error with additional - * information specific to the standard Matrix error response. - * @param errorJson - The Matrix error JSON returned from the homeserver. - * @param httpStatus - The numeric HTTP status code given - */ - constructor(errorJson = {}, httpStatus, url, event) { - let message = errorJson.error || "Unknown message"; - if (httpStatus) { - message = `[${httpStatus}] ${message}`; - } - if (url) { - message = `${message} (${url})`; - } - super(`MatrixError: ${message}`, httpStatus); - this.httpStatus = httpStatus; - this.url = url; - this.event = event; - (0, _defineProperty2.default)(this, "errcode", void 0); - (0, _defineProperty2.default)(this, "data", void 0); - this.errcode = errorJson.errcode; - this.name = errorJson.errcode || "Unknown error code"; - this.data = errorJson; - } -} - -/** - * Construct a ConnectionError. This is a JavaScript Error indicating - * that a request failed because of some error with the connection, either - * CORS was not correctly configured on the server, the server didn't response, - * the request timed out, or the internet connection on the client side went down. - */ -exports.MatrixError = MatrixError; -class ConnectionError extends Error { - constructor(message, cause) { - super(message + (cause ? `: ${cause.message}` : "")); - } - get name() { - return "ConnectionError"; - } -} -exports.ConnectionError = ConnectionError; -//# sourceMappingURL=errors.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js.map deleted file mode 100644 index db59fe9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/errors.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"errors.js","names":["HTTPError","Error","constructor","msg","httpStatus","exports","MatrixError","errorJson","url","event","message","error","_defineProperty2","default","errcode","name","data","ConnectionError","cause"],"sources":["../../src/http-api/errors.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IUsageLimit } from \"../@types/partials\";\nimport { MatrixEvent } from \"../models/event\";\n\ninterface IErrorJson extends Partial {\n [key: string]: any; // extensible\n errcode?: string;\n error?: string;\n}\n\n/**\n * Construct a generic HTTP error. This is a JavaScript Error with additional information\n * specific to HTTP responses.\n * @param msg - The error message to include.\n * @param httpStatus - The HTTP response status code.\n */\nexport class HTTPError extends Error {\n public constructor(msg: string, public readonly httpStatus?: number) {\n super(msg);\n }\n}\n\nexport class MatrixError extends HTTPError {\n // The Matrix 'errcode' value, e.g. \"M_FORBIDDEN\".\n public readonly errcode?: string;\n // The raw Matrix error JSON used to construct this object.\n public data: IErrorJson;\n\n /**\n * Construct a Matrix error. This is a JavaScript Error with additional\n * information specific to the standard Matrix error response.\n * @param errorJson - The Matrix error JSON returned from the homeserver.\n * @param httpStatus - The numeric HTTP status code given\n */\n public constructor(\n errorJson: IErrorJson = {},\n public readonly httpStatus?: number,\n public url?: string,\n public event?: MatrixEvent,\n ) {\n let message = errorJson.error || \"Unknown message\";\n if (httpStatus) {\n message = `[${httpStatus}] ${message}`;\n }\n if (url) {\n message = `${message} (${url})`;\n }\n super(`MatrixError: ${message}`, httpStatus);\n this.errcode = errorJson.errcode;\n this.name = errorJson.errcode || \"Unknown error code\";\n this.data = errorJson;\n }\n}\n\n/**\n * Construct a ConnectionError. This is a JavaScript Error indicating\n * that a request failed because of some error with the connection, either\n * CORS was not correctly configured on the server, the server didn't response,\n * the request timed out, or the internet connection on the client side went down.\n */\nexport class ConnectionError extends Error {\n public constructor(message: string, cause?: Error) {\n super(message + (cause ? `: ${cause.message}` : \"\"));\n }\n\n public get name(): string {\n return \"ConnectionError\";\n }\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAWA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMA,SAAS,SAASC,KAAK,CAAC;EAC1BC,WAAWA,CAACC,GAAW,EAAkBC,UAAmB,EAAE;IACjE,KAAK,CAACD,GAAG,CAAC;IAAC,KADiCC,UAAmB,GAAnBA,UAAmB;EAEnE;AACJ;AAACC,OAAA,CAAAL,SAAA,GAAAA,SAAA;AAEM,MAAMM,WAAW,SAASN,SAAS,CAAC;EACvC;;EAEA;;EAGA;AACJ;AACA;AACA;AACA;AACA;EACWE,WAAWA,CACdK,SAAqB,GAAG,CAAC,CAAC,EACVH,UAAmB,EAC5BI,GAAY,EACZC,KAAmB,EAC5B;IACE,IAAIC,OAAO,GAAGH,SAAS,CAACI,KAAK,IAAI,iBAAiB;IAClD,IAAIP,UAAU,EAAE;MACZM,OAAO,GAAI,IAAGN,UAAW,KAAIM,OAAQ,EAAC;IAC1C;IACA,IAAIF,GAAG,EAAE;MACLE,OAAO,GAAI,GAAEA,OAAQ,KAAIF,GAAI,GAAE;IACnC;IACA,KAAK,CAAE,gBAAeE,OAAQ,EAAC,EAAEN,UAAU,CAAC;IAAC,KAX7BA,UAAmB,GAAnBA,UAAmB;IAAA,KAC5BI,GAAY,GAAZA,GAAY;IAAA,KACZC,KAAmB,GAAnBA,KAAmB;IAAA,IAAAG,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAU1B,IAAI,CAACC,OAAO,GAAGP,SAAS,CAACO,OAAO;IAChC,IAAI,CAACC,IAAI,GAAGR,SAAS,CAACO,OAAO,IAAI,oBAAoB;IACrD,IAAI,CAACE,IAAI,GAAGT,SAAS;EACzB;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AALAF,OAAA,CAAAC,WAAA,GAAAA,WAAA;AAMO,MAAMW,eAAe,SAAShB,KAAK,CAAC;EAChCC,WAAWA,CAACQ,OAAe,EAAEQ,KAAa,EAAE;IAC/C,KAAK,CAACR,OAAO,IAAIQ,KAAK,GAAI,KAAIA,KAAK,CAACR,OAAQ,EAAC,GAAG,EAAE,CAAC,CAAC;EACxD;EAEA,IAAWK,IAAIA,CAAA,EAAW;IACtB,OAAO,iBAAiB;EAC5B;AACJ;AAACV,OAAA,CAAAY,eAAA,GAAAA,eAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts deleted file mode 100644 index 60d0440..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts +++ /dev/null @@ -1,105 +0,0 @@ -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { Method } from "./method"; -import { HttpApiEvent, HttpApiEventHandlerMap, IHttpOpts, IRequestOpts } from "./interface"; -import { QueryDict } from "../utils"; -type Body = Record | BodyInit; -interface TypedResponse extends Response { - json(): Promise; -} -export type ResponseType = O extends undefined ? T : O extends { - onlyData: true; -} ? T : TypedResponse; -export declare class FetchHttpApi { - private eventEmitter; - readonly opts: O; - private abortController; - constructor(eventEmitter: TypedEventEmitter, opts: O); - abort(): void; - fetch(resource: URL | string, options?: RequestInit): ReturnType; - /** - * Sets the base URL for the identity server - * @param url - The new base url - */ - setIdBaseUrl(url: string): void; - idServerRequest>(method: Method, path: string, params: Record | undefined, prefix: string, accessToken?: string): Promise>; - /** - * Perform an authorised request to the homeserver. - * @param method - The HTTP method e.g. "GET". - * @param path - The HTTP path after the supplied prefix e.g. - * "/createRoom". - * - * @param queryParams - A dict of query params (these will NOT be - * urlencoded). If unspecified, there will be no query params. - * - * @param body - The HTTP JSON body. - * - * @param opts - additional options. If a number is specified, - * this is treated as `opts.localTimeoutMs`. - * - * @returns Promise which resolves to - * ``` - * { - * data: {Object}, - * headers: {Object}, - * code: {Number}, - * } - * ``` - * If `onlyData` is set, this will resolve to the `data` object only. - * @returns Rejects with an error if a problem occurred. - * This includes network problems and Matrix-specific error JSON. - */ - authedRequest(method: Method, path: string, queryParams?: QueryDict, body?: Body, opts?: IRequestOpts): Promise>; - /** - * Perform a request to the homeserver without any credentials. - * @param method - The HTTP method e.g. "GET". - * @param path - The HTTP path after the supplied prefix e.g. - * "/createRoom". - * - * @param queryParams - A dict of query params (these will NOT be - * urlencoded). If unspecified, there will be no query params. - * - * @param body - The HTTP JSON body. - * - * @param opts - additional options - * - * @returns Promise which resolves to - * ``` - * { - * data: {Object}, - * headers: {Object}, - * code: {Number}, - * } - * ``` - * If `onlyData is set, this will resolve to the data` - * object only. - * @returns Rejects with an error if a problem - * occurred. This includes network problems and Matrix-specific error JSON. - */ - request(method: Method, path: string, queryParams?: QueryDict, body?: Body, opts?: IRequestOpts): Promise>; - /** - * Perform a request to an arbitrary URL. - * @param method - The HTTP method e.g. "GET". - * @param url - The HTTP URL object. - * - * @param body - The HTTP JSON body. - * - * @param opts - additional options - * - * @returns Promise which resolves to data unless `onlyData` is specified as false, - * where the resolved value will be a fetch Response object. - * @returns Rejects with an error if a problem - * occurred. This includes network problems and Matrix-specific error JSON. - */ - requestOtherUrl(method: Method, url: URL | string, body?: Body, opts?: Pick): Promise>; - /** - * Form and return a homeserver request URL based on the given path params and prefix. - * @param path - The HTTP path after the supplied prefix e.g. "/createRoom". - * @param queryParams - A dict of query params (these will NOT be urlencoded). - * @param prefix - The full prefix to use e.g. "/_matrix/client/v2_alpha", defaulting to this.opts.prefix. - * @param baseUrl - The baseUrl to use e.g. "https://matrix.org/", defaulting to this.opts.baseUrl. - * @returns URL - */ - getUrl(path: string, queryParams?: QueryDict, prefix?: string, baseUrl?: string): URL; -} -export {}; -//# sourceMappingURL=fetch.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts.map deleted file mode 100644 index 42f4b1f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../src/http-api/fetch.ts"],"names":[],"mappings":"AAqBA,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE5F,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAErC,KAAK,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,QAAQ,CAAC;AAE3C,UAAU,aAAa,CAAC,CAAC,CAAE,SAAQ,QAAQ;IACvC,IAAI,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC;CACtB;AAED,MAAM,MAAM,YAAY,CAAC,CAAC,EAAE,CAAC,SAAS,SAAS,IAAI,CAAC,SAAS,SAAS,GAChE,CAAC,GACD,CAAC,SAAS;IAAE,QAAQ,EAAE,IAAI,CAAA;CAAE,GAC5B,CAAC,GACD,aAAa,CAAC,CAAC,CAAC,CAAC;AAEvB,qBAAa,YAAY,CAAC,CAAC,SAAS,SAAS;IAIrC,OAAO,CAAC,YAAY;aACJ,IAAI,EAAE,CAAC;IAJ3B,OAAO,CAAC,eAAe,CAAyB;gBAGpC,YAAY,EAAE,iBAAiB,CAAC,YAAY,EAAE,sBAAsB,CAAC,EAC7D,IAAI,EAAE,CAAC;IAOpB,KAAK,IAAI,IAAI;IAKb,KAAK,CAAC,QAAQ,EAAE,GAAG,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,GAAG,UAAU,CAAC,OAAO,MAAM,CAAC,KAAK,CAAC;IAO5F;;;OAGG;IACI,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAI/B,eAAe,CAAC,CAAC,SAAS,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACzD,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,GAAG,SAAS,EACrD,MAAM,EAAE,MAAM,EACd,WAAW,CAAC,EAAE,MAAM,GACrB,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IA0B9B;;;;;;;;;;;;;;;;;;;;;;;;;OAyBG;IACI,aAAa,CAAC,CAAC,EAClB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,WAAW,CAAC,EAAE,SAAS,EACvB,IAAI,CAAC,EAAE,IAAI,EACX,IAAI,GAAE,YAAiB,GACxB,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAkC9B;;;;;;;;;;;;;;;;;;;;;;;;;OAyBG;IACI,OAAO,CAAC,CAAC,EACZ,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,WAAW,CAAC,EAAE,SAAS,EACvB,IAAI,CAAC,EAAE,IAAI,EACX,IAAI,CAAC,EAAE,YAAY,GACpB,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAK9B;;;;;;;;;;;;;OAaG;IACU,eAAe,CAAC,CAAC,EAC1B,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,GAAG,GAAG,MAAM,EACjB,IAAI,CAAC,EAAE,IAAI,EACX,IAAI,GAAE,IAAI,CAAC,YAAY,EAAE,SAAS,GAAG,MAAM,GAAG,gBAAgB,GAAG,WAAW,GAAG,aAAa,CAAM,GACnG,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAqE9B;;;;;;;OAOG;IACI,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,GAAG;CAO/F"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js deleted file mode 100644 index d009861..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js +++ /dev/null @@ -1,271 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.FetchHttpApi = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var utils = _interopRequireWildcard(require("../utils")); -var _method = require("./method"); -var _errors = require("./errors"); -var _interface = require("./interface"); -var _utils2 = require("./utils"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * This is an internal module. See {@link MatrixHttpApi} for the public class. - */ - -class FetchHttpApi { - constructor(eventEmitter, opts) { - var _opts$useAuthorizatio; - this.eventEmitter = eventEmitter; - this.opts = opts; - (0, _defineProperty2.default)(this, "abortController", new AbortController()); - utils.checkObjectHasKeys(opts, ["baseUrl", "prefix"]); - opts.onlyData = !!opts.onlyData; - opts.useAuthorizationHeader = (_opts$useAuthorizatio = opts.useAuthorizationHeader) !== null && _opts$useAuthorizatio !== void 0 ? _opts$useAuthorizatio : true; - } - abort() { - this.abortController.abort(); - this.abortController = new AbortController(); - } - fetch(resource, options) { - if (this.opts.fetchFn) { - return this.opts.fetchFn(resource, options); - } - return global.fetch(resource, options); - } - - /** - * Sets the base URL for the identity server - * @param url - The new base url - */ - setIdBaseUrl(url) { - this.opts.idBaseUrl = url; - } - idServerRequest(method, path, params, prefix, accessToken) { - if (!this.opts.idBaseUrl) { - throw new Error("No identity server base URL set"); - } - let queryParams = undefined; - let body = undefined; - if (method === _method.Method.Get) { - queryParams = params; - } else { - body = params; - } - const fullUri = this.getUrl(path, queryParams, prefix, this.opts.idBaseUrl); - const opts = { - json: true, - headers: {} - }; - if (accessToken) { - opts.headers.Authorization = `Bearer ${accessToken}`; - } - return this.requestOtherUrl(method, fullUri, body, opts); - } - - /** - * Perform an authorised request to the homeserver. - * @param method - The HTTP method e.g. "GET". - * @param path - The HTTP path after the supplied prefix e.g. - * "/createRoom". - * - * @param queryParams - A dict of query params (these will NOT be - * urlencoded). If unspecified, there will be no query params. - * - * @param body - The HTTP JSON body. - * - * @param opts - additional options. If a number is specified, - * this is treated as `opts.localTimeoutMs`. - * - * @returns Promise which resolves to - * ``` - * { - * data: {Object}, - * headers: {Object}, - * code: {Number}, - * } - * ``` - * If `onlyData` is set, this will resolve to the `data` object only. - * @returns Rejects with an error if a problem occurred. - * This includes network problems and Matrix-specific error JSON. - */ - authedRequest(method, path, queryParams, body, opts = {}) { - if (!queryParams) queryParams = {}; - if (this.opts.accessToken) { - if (this.opts.useAuthorizationHeader) { - if (!opts.headers) { - opts.headers = {}; - } - if (!opts.headers.Authorization) { - opts.headers.Authorization = "Bearer " + this.opts.accessToken; - } - if (queryParams.access_token) { - delete queryParams.access_token; - } - } else if (!queryParams.access_token) { - queryParams.access_token = this.opts.accessToken; - } - } - const requestPromise = this.request(method, path, queryParams, body, opts); - requestPromise.catch(err => { - if (err.errcode == "M_UNKNOWN_TOKEN" && !(opts !== null && opts !== void 0 && opts.inhibitLogoutEmit)) { - this.eventEmitter.emit(_interface.HttpApiEvent.SessionLoggedOut, err); - } else if (err.errcode == "M_CONSENT_NOT_GIVEN") { - this.eventEmitter.emit(_interface.HttpApiEvent.NoConsent, err.message, err.data.consent_uri); - } - }); - - // return the original promise, otherwise tests break due to it having to - // go around the event loop one more time to process the result of the request - return requestPromise; - } - - /** - * Perform a request to the homeserver without any credentials. - * @param method - The HTTP method e.g. "GET". - * @param path - The HTTP path after the supplied prefix e.g. - * "/createRoom". - * - * @param queryParams - A dict of query params (these will NOT be - * urlencoded). If unspecified, there will be no query params. - * - * @param body - The HTTP JSON body. - * - * @param opts - additional options - * - * @returns Promise which resolves to - * ``` - * { - * data: {Object}, - * headers: {Object}, - * code: {Number}, - * } - * ``` - * If `onlyData is set, this will resolve to the data` - * object only. - * @returns Rejects with an error if a problem - * occurred. This includes network problems and Matrix-specific error JSON. - */ - request(method, path, queryParams, body, opts) { - const fullUri = this.getUrl(path, queryParams, opts === null || opts === void 0 ? void 0 : opts.prefix, opts === null || opts === void 0 ? void 0 : opts.baseUrl); - return this.requestOtherUrl(method, fullUri, body, opts); - } - - /** - * Perform a request to an arbitrary URL. - * @param method - The HTTP method e.g. "GET". - * @param url - The HTTP URL object. - * - * @param body - The HTTP JSON body. - * - * @param opts - additional options - * - * @returns Promise which resolves to data unless `onlyData` is specified as false, - * where the resolved value will be a fetch Response object. - * @returns Rejects with an error if a problem - * occurred. This includes network problems and Matrix-specific error JSON. - */ - async requestOtherUrl(method, url, body, opts = {}) { - var _opts$json, _body$constructor, _opts$localTimeoutMs, _opts$keepAlive; - const headers = Object.assign({}, opts.headers || {}); - const json = (_opts$json = opts.json) !== null && _opts$json !== void 0 ? _opts$json : true; - // We can't use getPrototypeOf here as objects made in other contexts e.g. over postMessage won't have same ref - const jsonBody = json && (body === null || body === void 0 ? void 0 : (_body$constructor = body.constructor) === null || _body$constructor === void 0 ? void 0 : _body$constructor.name) === Object.name; - if (json) { - if (jsonBody && !headers["Content-Type"]) { - headers["Content-Type"] = "application/json"; - } - if (!headers["Accept"]) { - headers["Accept"] = "application/json"; - } - } - const timeout = (_opts$localTimeoutMs = opts.localTimeoutMs) !== null && _opts$localTimeoutMs !== void 0 ? _opts$localTimeoutMs : this.opts.localTimeoutMs; - const keepAlive = (_opts$keepAlive = opts.keepAlive) !== null && _opts$keepAlive !== void 0 ? _opts$keepAlive : false; - const signals = [this.abortController.signal]; - if (timeout !== undefined) { - signals.push((0, _utils2.timeoutSignal)(timeout)); - } - if (opts.abortSignal) { - signals.push(opts.abortSignal); - } - let data; - if (jsonBody) { - data = JSON.stringify(body); - } else { - data = body; - } - const { - signal, - cleanup - } = (0, _utils2.anySignal)(signals); - let res; - try { - res = await this.fetch(url, { - signal, - method, - body: data, - headers, - mode: "cors", - redirect: "follow", - referrer: "", - referrerPolicy: "no-referrer", - cache: "no-cache", - credentials: "omit", - // we send credentials via headers - keepalive: keepAlive - }); - } catch (e) { - if (e.name === "AbortError") { - throw e; - } - throw new _errors.ConnectionError("fetch failed", e); - } finally { - cleanup(); - } - if (!res.ok) { - throw (0, _utils2.parseErrorResponse)(res, await res.text()); - } - if (this.opts.onlyData) { - return json ? res.json() : res.text(); - } - return res; - } - - /** - * Form and return a homeserver request URL based on the given path params and prefix. - * @param path - The HTTP path after the supplied prefix e.g. "/createRoom". - * @param queryParams - A dict of query params (these will NOT be urlencoded). - * @param prefix - The full prefix to use e.g. "/_matrix/client/v2_alpha", defaulting to this.opts.prefix. - * @param baseUrl - The baseUrl to use e.g. "https://matrix.org/", defaulting to this.opts.baseUrl. - * @returns URL - */ - getUrl(path, queryParams, prefix, baseUrl) { - const url = new URL((baseUrl !== null && baseUrl !== void 0 ? baseUrl : this.opts.baseUrl) + (prefix !== null && prefix !== void 0 ? prefix : this.opts.prefix) + path); - if (queryParams) { - utils.encodeParams(queryParams, url.searchParams); - } - return url; - } -} -exports.FetchHttpApi = FetchHttpApi; -//# sourceMappingURL=fetch.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js.map deleted file mode 100644 index b5e30ee..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/fetch.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"fetch.js","names":["utils","_interopRequireWildcard","require","_method","_errors","_interface","_utils2","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","FetchHttpApi","constructor","eventEmitter","opts","_opts$useAuthorizatio","_defineProperty2","AbortController","checkObjectHasKeys","onlyData","useAuthorizationHeader","abort","abortController","fetch","resource","options","fetchFn","global","setIdBaseUrl","url","idBaseUrl","idServerRequest","method","path","params","prefix","accessToken","Error","queryParams","undefined","body","Method","Get","fullUri","getUrl","json","headers","Authorization","requestOtherUrl","authedRequest","access_token","requestPromise","request","catch","err","errcode","inhibitLogoutEmit","emit","HttpApiEvent","SessionLoggedOut","NoConsent","message","data","consent_uri","baseUrl","_opts$json","_body$constructor","_opts$localTimeoutMs","_opts$keepAlive","assign","jsonBody","name","timeout","localTimeoutMs","keepAlive","signals","signal","push","timeoutSignal","abortSignal","JSON","stringify","cleanup","anySignal","res","mode","redirect","referrer","referrerPolicy","credentials","keepalive","e","ConnectionError","ok","parseErrorResponse","text","URL","encodeParams","searchParams","exports"],"sources":["../../src/http-api/fetch.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module. See {@link MatrixHttpApi} for the public class.\n */\n\nimport * as utils from \"../utils\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { Method } from \"./method\";\nimport { ConnectionError, MatrixError } from \"./errors\";\nimport { HttpApiEvent, HttpApiEventHandlerMap, IHttpOpts, IRequestOpts } from \"./interface\";\nimport { anySignal, parseErrorResponse, timeoutSignal } from \"./utils\";\nimport { QueryDict } from \"../utils\";\n\ntype Body = Record | BodyInit;\n\ninterface TypedResponse extends Response {\n json(): Promise;\n}\n\nexport type ResponseType = O extends undefined\n ? T\n : O extends { onlyData: true }\n ? T\n : TypedResponse;\n\nexport class FetchHttpApi {\n private abortController = new AbortController();\n\n public constructor(\n private eventEmitter: TypedEventEmitter,\n public readonly opts: O,\n ) {\n utils.checkObjectHasKeys(opts, [\"baseUrl\", \"prefix\"]);\n opts.onlyData = !!opts.onlyData;\n opts.useAuthorizationHeader = opts.useAuthorizationHeader ?? true;\n }\n\n public abort(): void {\n this.abortController.abort();\n this.abortController = new AbortController();\n }\n\n public fetch(resource: URL | string, options?: RequestInit): ReturnType {\n if (this.opts.fetchFn) {\n return this.opts.fetchFn(resource, options);\n }\n return global.fetch(resource, options);\n }\n\n /**\n * Sets the base URL for the identity server\n * @param url - The new base url\n */\n public setIdBaseUrl(url: string): void {\n this.opts.idBaseUrl = url;\n }\n\n public idServerRequest>(\n method: Method,\n path: string,\n params: Record | undefined,\n prefix: string,\n accessToken?: string,\n ): Promise> {\n if (!this.opts.idBaseUrl) {\n throw new Error(\"No identity server base URL set\");\n }\n\n let queryParams: QueryDict | undefined = undefined;\n let body: Record | undefined = undefined;\n if (method === Method.Get) {\n queryParams = params;\n } else {\n body = params;\n }\n\n const fullUri = this.getUrl(path, queryParams, prefix, this.opts.idBaseUrl);\n\n const opts: IRequestOpts = {\n json: true,\n headers: {},\n };\n if (accessToken) {\n opts.headers!.Authorization = `Bearer ${accessToken}`;\n }\n\n return this.requestOtherUrl(method, fullUri, body, opts);\n }\n\n /**\n * Perform an authorised request to the homeserver.\n * @param method - The HTTP method e.g. \"GET\".\n * @param path - The HTTP path after the supplied prefix e.g.\n * \"/createRoom\".\n *\n * @param queryParams - A dict of query params (these will NOT be\n * urlencoded). If unspecified, there will be no query params.\n *\n * @param body - The HTTP JSON body.\n *\n * @param opts - additional options. If a number is specified,\n * this is treated as `opts.localTimeoutMs`.\n *\n * @returns Promise which resolves to\n * ```\n * {\n * data: {Object},\n * headers: {Object},\n * code: {Number},\n * }\n * ```\n * If `onlyData` is set, this will resolve to the `data` object only.\n * @returns Rejects with an error if a problem occurred.\n * This includes network problems and Matrix-specific error JSON.\n */\n public authedRequest(\n method: Method,\n path: string,\n queryParams?: QueryDict,\n body?: Body,\n opts: IRequestOpts = {},\n ): Promise> {\n if (!queryParams) queryParams = {};\n\n if (this.opts.accessToken) {\n if (this.opts.useAuthorizationHeader) {\n if (!opts.headers) {\n opts.headers = {};\n }\n if (!opts.headers.Authorization) {\n opts.headers.Authorization = \"Bearer \" + this.opts.accessToken;\n }\n if (queryParams.access_token) {\n delete queryParams.access_token;\n }\n } else if (!queryParams.access_token) {\n queryParams.access_token = this.opts.accessToken;\n }\n }\n\n const requestPromise = this.request(method, path, queryParams, body, opts);\n\n requestPromise.catch((err: MatrixError) => {\n if (err.errcode == \"M_UNKNOWN_TOKEN\" && !opts?.inhibitLogoutEmit) {\n this.eventEmitter.emit(HttpApiEvent.SessionLoggedOut, err);\n } else if (err.errcode == \"M_CONSENT_NOT_GIVEN\") {\n this.eventEmitter.emit(HttpApiEvent.NoConsent, err.message, err.data.consent_uri);\n }\n });\n\n // return the original promise, otherwise tests break due to it having to\n // go around the event loop one more time to process the result of the request\n return requestPromise;\n }\n\n /**\n * Perform a request to the homeserver without any credentials.\n * @param method - The HTTP method e.g. \"GET\".\n * @param path - The HTTP path after the supplied prefix e.g.\n * \"/createRoom\".\n *\n * @param queryParams - A dict of query params (these will NOT be\n * urlencoded). If unspecified, there will be no query params.\n *\n * @param body - The HTTP JSON body.\n *\n * @param opts - additional options\n *\n * @returns Promise which resolves to\n * ```\n * {\n * data: {Object},\n * headers: {Object},\n * code: {Number},\n * }\n * ```\n * If `onlyData is set, this will resolve to the data`\n * object only.\n * @returns Rejects with an error if a problem\n * occurred. This includes network problems and Matrix-specific error JSON.\n */\n public request(\n method: Method,\n path: string,\n queryParams?: QueryDict,\n body?: Body,\n opts?: IRequestOpts,\n ): Promise> {\n const fullUri = this.getUrl(path, queryParams, opts?.prefix, opts?.baseUrl);\n return this.requestOtherUrl(method, fullUri, body, opts);\n }\n\n /**\n * Perform a request to an arbitrary URL.\n * @param method - The HTTP method e.g. \"GET\".\n * @param url - The HTTP URL object.\n *\n * @param body - The HTTP JSON body.\n *\n * @param opts - additional options\n *\n * @returns Promise which resolves to data unless `onlyData` is specified as false,\n * where the resolved value will be a fetch Response object.\n * @returns Rejects with an error if a problem\n * occurred. This includes network problems and Matrix-specific error JSON.\n */\n public async requestOtherUrl(\n method: Method,\n url: URL | string,\n body?: Body,\n opts: Pick = {},\n ): Promise> {\n const headers = Object.assign({}, opts.headers || {});\n const json = opts.json ?? true;\n // We can't use getPrototypeOf here as objects made in other contexts e.g. over postMessage won't have same ref\n const jsonBody = json && body?.constructor?.name === Object.name;\n\n if (json) {\n if (jsonBody && !headers[\"Content-Type\"]) {\n headers[\"Content-Type\"] = \"application/json\";\n }\n\n if (!headers[\"Accept\"]) {\n headers[\"Accept\"] = \"application/json\";\n }\n }\n\n const timeout = opts.localTimeoutMs ?? this.opts.localTimeoutMs;\n const keepAlive = opts.keepAlive ?? false;\n const signals = [this.abortController.signal];\n if (timeout !== undefined) {\n signals.push(timeoutSignal(timeout));\n }\n if (opts.abortSignal) {\n signals.push(opts.abortSignal);\n }\n\n let data: BodyInit;\n if (jsonBody) {\n data = JSON.stringify(body);\n } else {\n data = body as BodyInit;\n }\n\n const { signal, cleanup } = anySignal(signals);\n\n let res: Response;\n try {\n res = await this.fetch(url, {\n signal,\n method,\n body: data,\n headers,\n mode: \"cors\",\n redirect: \"follow\",\n referrer: \"\",\n referrerPolicy: \"no-referrer\",\n cache: \"no-cache\",\n credentials: \"omit\", // we send credentials via headers\n keepalive: keepAlive,\n });\n } catch (e) {\n if ((e).name === \"AbortError\") {\n throw e;\n }\n throw new ConnectionError(\"fetch failed\", e);\n } finally {\n cleanup();\n }\n\n if (!res.ok) {\n throw parseErrorResponse(res, await res.text());\n }\n\n if (this.opts.onlyData) {\n return json ? res.json() : res.text();\n }\n return res as ResponseType;\n }\n\n /**\n * Form and return a homeserver request URL based on the given path params and prefix.\n * @param path - The HTTP path after the supplied prefix e.g. \"/createRoom\".\n * @param queryParams - A dict of query params (these will NOT be urlencoded).\n * @param prefix - The full prefix to use e.g. \"/_matrix/client/v2_alpha\", defaulting to this.opts.prefix.\n * @param baseUrl - The baseUrl to use e.g. \"https://matrix.org/\", defaulting to this.opts.baseUrl.\n * @returns URL\n */\n public getUrl(path: string, queryParams?: QueryDict, prefix?: string, baseUrl?: string): URL {\n const url = new URL((baseUrl ?? this.opts.baseUrl) + (prefix ?? this.opts.prefix) + path);\n if (queryParams) {\n utils.encodeParams(queryParams, url.searchParams);\n }\n return url;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts deleted file mode 100644 index 0825c4e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts +++ /dev/null @@ -1,33 +0,0 @@ -import { FetchHttpApi } from "./fetch"; -import { FileType, IContentUri, IHttpOpts, Upload, UploadOpts, UploadResponse } from "./interface"; -export * from "./interface"; -export * from "./prefix"; -export * from "./errors"; -export * from "./method"; -export * from "./utils"; -export declare class MatrixHttpApi extends FetchHttpApi { - private uploads; - /** - * Upload content to the homeserver - * - * @param file - The object to upload. On a browser, something that - * can be sent to XMLHttpRequest.send (typically a File). Under node.js, - * a Buffer, String or ReadStream. - * - * @param opts - options object - * - * @returns Promise which resolves to response object, as - * determined by this.opts.onlyData, opts.rawResponse, and - * opts.onlyContentUri. Rejects with an error (usually a MatrixError). - */ - uploadContent(file: FileType, opts?: UploadOpts): Promise; - cancelUpload(promise: Promise): boolean; - getCurrentUploads(): Upload[]; - /** - * Get the content repository url with query parameters. - * @returns An object with a 'base', 'path' and 'params' for base URL, - * path and query parameters respectively. - */ - getContentUri(): IContentUri; -} -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts.map deleted file mode 100644 index e8dd81a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/http-api/index.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAQnG,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC;AAExB,qBAAa,aAAa,CAAC,CAAC,SAAS,SAAS,CAAE,SAAQ,YAAY,CAAC,CAAC,CAAC;IACnE,OAAO,CAAC,OAAO,CAAgB;IAE/B;;;;;;;;;;;;OAYG;IACI,aAAa,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,GAAE,UAAe,GAAG,OAAO,CAAC,cAAc,CAAC;IAoH7E,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,cAAc,CAAC,GAAG,OAAO;IASvD,iBAAiB,IAAI,MAAM,EAAE;IAIpC;;;;OAIG;IACI,aAAa,IAAI,WAAW;CAStC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js deleted file mode 100644 index ec2a00c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js +++ /dev/null @@ -1,244 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -var _exportNames = { - MatrixHttpApi: true -}; -exports.MatrixHttpApi = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _fetch = require("./fetch"); -var _prefix = require("./prefix"); -Object.keys(_prefix).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _prefix[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _prefix[key]; - } - }); -}); -var utils = _interopRequireWildcard(require("../utils")); -var callbacks = _interopRequireWildcard(require("../realtime-callbacks")); -var _method = require("./method"); -Object.keys(_method).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _method[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _method[key]; - } - }); -}); -var _errors = require("./errors"); -Object.keys(_errors).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _errors[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _errors[key]; - } - }); -}); -var _utils2 = require("./utils"); -Object.keys(_utils2).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _utils2[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _utils2[key]; - } - }); -}); -var _interface = require("./interface"); -Object.keys(_interface).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _interface[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _interface[key]; - } - }); -}); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class MatrixHttpApi extends _fetch.FetchHttpApi { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "uploads", []); - } - /** - * Upload content to the homeserver - * - * @param file - The object to upload. On a browser, something that - * can be sent to XMLHttpRequest.send (typically a File). Under node.js, - * a Buffer, String or ReadStream. - * - * @param opts - options object - * - * @returns Promise which resolves to response object, as - * determined by this.opts.onlyData, opts.rawResponse, and - * opts.onlyContentUri. Rejects with an error (usually a MatrixError). - */ - uploadContent(file, opts = {}) { - var _opts$includeFilename, _opts$abortController, _ref, _opts$type, _opts$name; - const includeFilename = (_opts$includeFilename = opts.includeFilename) !== null && _opts$includeFilename !== void 0 ? _opts$includeFilename : true; - const abortController = (_opts$abortController = opts.abortController) !== null && _opts$abortController !== void 0 ? _opts$abortController : new AbortController(); - - // If the file doesn't have a mime type, use a default since the HS errors if we don't supply one. - const contentType = (_ref = (_opts$type = opts.type) !== null && _opts$type !== void 0 ? _opts$type : file.type) !== null && _ref !== void 0 ? _ref : "application/octet-stream"; - const fileName = (_opts$name = opts.name) !== null && _opts$name !== void 0 ? _opts$name : file.name; - const upload = { - loaded: 0, - total: 0, - abortController - }; - const defer = utils.defer(); - if (global.XMLHttpRequest) { - const xhr = new global.XMLHttpRequest(); - const timeoutFn = function () { - xhr.abort(); - defer.reject(new Error("Timeout")); - }; - - // set an initial timeout of 30s; we'll advance it each time we get a progress notification - let timeoutTimer = callbacks.setTimeout(timeoutFn, 30000); - xhr.onreadystatechange = function () { - switch (xhr.readyState) { - case global.XMLHttpRequest.DONE: - callbacks.clearTimeout(timeoutTimer); - try { - if (xhr.status === 0) { - throw new DOMException(xhr.statusText, "AbortError"); // mimic fetch API - } - - if (!xhr.responseText) { - throw new Error("No response body."); - } - if (xhr.status >= 400) { - defer.reject((0, _utils2.parseErrorResponse)(xhr, xhr.responseText)); - } else { - defer.resolve(JSON.parse(xhr.responseText)); - } - } catch (err) { - if (err.name === "AbortError") { - defer.reject(err); - return; - } - defer.reject(new _errors.ConnectionError("request failed", err)); - } - break; - } - }; - xhr.upload.onprogress = ev => { - var _opts$progressHandler; - callbacks.clearTimeout(timeoutTimer); - upload.loaded = ev.loaded; - upload.total = ev.total; - timeoutTimer = callbacks.setTimeout(timeoutFn, 30000); - (_opts$progressHandler = opts.progressHandler) === null || _opts$progressHandler === void 0 ? void 0 : _opts$progressHandler.call(opts, { - loaded: ev.loaded, - total: ev.total - }); - }; - const url = this.getUrl("/upload", undefined, _prefix.MediaPrefix.R0); - if (includeFilename && fileName) { - url.searchParams.set("filename", encodeURIComponent(fileName)); - } - if (!this.opts.useAuthorizationHeader && this.opts.accessToken) { - url.searchParams.set("access_token", encodeURIComponent(this.opts.accessToken)); - } - xhr.open(_method.Method.Post, url.href); - if (this.opts.useAuthorizationHeader && this.opts.accessToken) { - xhr.setRequestHeader("Authorization", "Bearer " + this.opts.accessToken); - } - xhr.setRequestHeader("Content-Type", contentType); - xhr.send(file); - abortController.signal.addEventListener("abort", () => { - xhr.abort(); - }); - } else { - const queryParams = {}; - if (includeFilename && fileName) { - queryParams.filename = fileName; - } - const headers = { - "Content-Type": contentType - }; - this.authedRequest(_method.Method.Post, "/upload", queryParams, file, { - prefix: _prefix.MediaPrefix.R0, - headers, - abortSignal: abortController.signal - }).then(response => { - return this.opts.onlyData ? response : response.json(); - }).then(defer.resolve, defer.reject); - } - - // remove the upload from the list on completion - upload.promise = defer.promise.finally(() => { - utils.removeElement(this.uploads, elem => elem === upload); - }); - abortController.signal.addEventListener("abort", () => { - utils.removeElement(this.uploads, elem => elem === upload); - defer.reject(new DOMException("Aborted", "AbortError")); - }); - this.uploads.push(upload); - return upload.promise; - } - cancelUpload(promise) { - const upload = this.uploads.find(u => u.promise === promise); - if (upload) { - upload.abortController.abort(); - return true; - } - return false; - } - getCurrentUploads() { - return this.uploads; - } - - /** - * Get the content repository url with query parameters. - * @returns An object with a 'base', 'path' and 'params' for base URL, - * path and query parameters respectively. - */ - getContentUri() { - return { - base: this.opts.baseUrl, - path: _prefix.MediaPrefix.R0 + "/upload", - params: { - access_token: this.opts.accessToken - } - }; - } -} -exports.MatrixHttpApi = MatrixHttpApi; -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js.map deleted file mode 100644 index f497156..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["_fetch","require","_prefix","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","utils","_interopRequireWildcard","callbacks","_method","_errors","_utils2","_interface","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","newObj","hasPropertyDescriptor","getOwnPropertyDescriptor","desc","set","MatrixHttpApi","FetchHttpApi","constructor","args","_defineProperty2","uploadContent","file","opts","_opts$includeFilename","_opts$abortController","_ref","_opts$type","_opts$name","includeFilename","abortController","AbortController","contentType","type","fileName","name","upload","loaded","total","defer","global","XMLHttpRequest","xhr","timeoutFn","abort","reject","Error","timeoutTimer","setTimeout","onreadystatechange","readyState","DONE","clearTimeout","status","DOMException","statusText","responseText","parseErrorResponse","resolve","JSON","parse","err","ConnectionError","onprogress","ev","_opts$progressHandler","progressHandler","url","getUrl","undefined","MediaPrefix","R0","searchParams","encodeURIComponent","useAuthorizationHeader","accessToken","open","Method","Post","href","setRequestHeader","send","signal","addEventListener","queryParams","filename","headers","authedRequest","prefix","abortSignal","then","response","onlyData","json","promise","finally","removeElement","uploads","elem","push","cancelUpload","find","u","getCurrentUploads","getContentUri","base","baseUrl","path","params","access_token"],"sources":["../../src/http-api/index.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { FetchHttpApi } from \"./fetch\";\nimport { FileType, IContentUri, IHttpOpts, Upload, UploadOpts, UploadResponse } from \"./interface\";\nimport { MediaPrefix } from \"./prefix\";\nimport * as utils from \"../utils\";\nimport * as callbacks from \"../realtime-callbacks\";\nimport { Method } from \"./method\";\nimport { ConnectionError } from \"./errors\";\nimport { parseErrorResponse } from \"./utils\";\n\nexport * from \"./interface\";\nexport * from \"./prefix\";\nexport * from \"./errors\";\nexport * from \"./method\";\nexport * from \"./utils\";\n\nexport class MatrixHttpApi extends FetchHttpApi {\n private uploads: Upload[] = [];\n\n /**\n * Upload content to the homeserver\n *\n * @param file - The object to upload. On a browser, something that\n * can be sent to XMLHttpRequest.send (typically a File). Under node.js,\n * a Buffer, String or ReadStream.\n *\n * @param opts - options object\n *\n * @returns Promise which resolves to response object, as\n * determined by this.opts.onlyData, opts.rawResponse, and\n * opts.onlyContentUri. Rejects with an error (usually a MatrixError).\n */\n public uploadContent(file: FileType, opts: UploadOpts = {}): Promise {\n const includeFilename = opts.includeFilename ?? true;\n const abortController = opts.abortController ?? new AbortController();\n\n // If the file doesn't have a mime type, use a default since the HS errors if we don't supply one.\n const contentType = opts.type ?? (file as File).type ?? \"application/octet-stream\";\n const fileName = opts.name ?? (file as File).name;\n\n const upload = {\n loaded: 0,\n total: 0,\n abortController,\n } as Upload;\n const defer = utils.defer();\n\n if (global.XMLHttpRequest) {\n const xhr = new global.XMLHttpRequest();\n\n const timeoutFn = function (): void {\n xhr.abort();\n defer.reject(new Error(\"Timeout\"));\n };\n\n // set an initial timeout of 30s; we'll advance it each time we get a progress notification\n let timeoutTimer = callbacks.setTimeout(timeoutFn, 30000);\n\n xhr.onreadystatechange = function (): void {\n switch (xhr.readyState) {\n case global.XMLHttpRequest.DONE:\n callbacks.clearTimeout(timeoutTimer);\n try {\n if (xhr.status === 0) {\n throw new DOMException(xhr.statusText, \"AbortError\"); // mimic fetch API\n }\n if (!xhr.responseText) {\n throw new Error(\"No response body.\");\n }\n\n if (xhr.status >= 400) {\n defer.reject(parseErrorResponse(xhr, xhr.responseText));\n } else {\n defer.resolve(JSON.parse(xhr.responseText));\n }\n } catch (err) {\n if ((err).name === \"AbortError\") {\n defer.reject(err);\n return;\n }\n defer.reject(new ConnectionError(\"request failed\", err));\n }\n break;\n }\n };\n\n xhr.upload.onprogress = (ev: ProgressEvent): void => {\n callbacks.clearTimeout(timeoutTimer);\n upload.loaded = ev.loaded;\n upload.total = ev.total;\n timeoutTimer = callbacks.setTimeout(timeoutFn, 30000);\n opts.progressHandler?.({\n loaded: ev.loaded,\n total: ev.total,\n });\n };\n\n const url = this.getUrl(\"/upload\", undefined, MediaPrefix.R0);\n\n if (includeFilename && fileName) {\n url.searchParams.set(\"filename\", encodeURIComponent(fileName));\n }\n\n if (!this.opts.useAuthorizationHeader && this.opts.accessToken) {\n url.searchParams.set(\"access_token\", encodeURIComponent(this.opts.accessToken));\n }\n\n xhr.open(Method.Post, url.href);\n if (this.opts.useAuthorizationHeader && this.opts.accessToken) {\n xhr.setRequestHeader(\"Authorization\", \"Bearer \" + this.opts.accessToken);\n }\n xhr.setRequestHeader(\"Content-Type\", contentType);\n xhr.send(file);\n\n abortController.signal.addEventListener(\"abort\", () => {\n xhr.abort();\n });\n } else {\n const queryParams: utils.QueryDict = {};\n if (includeFilename && fileName) {\n queryParams.filename = fileName;\n }\n\n const headers: Record = { \"Content-Type\": contentType };\n\n this.authedRequest(Method.Post, \"/upload\", queryParams, file, {\n prefix: MediaPrefix.R0,\n headers,\n abortSignal: abortController.signal,\n })\n .then((response) => {\n return this.opts.onlyData ? response : response.json();\n })\n .then(defer.resolve, defer.reject);\n }\n\n // remove the upload from the list on completion\n upload.promise = defer.promise.finally(() => {\n utils.removeElement(this.uploads, (elem) => elem === upload);\n });\n abortController.signal.addEventListener(\"abort\", () => {\n utils.removeElement(this.uploads, (elem) => elem === upload);\n defer.reject(new DOMException(\"Aborted\", \"AbortError\"));\n });\n this.uploads.push(upload);\n return upload.promise;\n }\n\n public cancelUpload(promise: Promise): boolean {\n const upload = this.uploads.find((u) => u.promise === promise);\n if (upload) {\n upload.abortController.abort();\n return true;\n }\n return false;\n }\n\n public getCurrentUploads(): Upload[] {\n return this.uploads;\n }\n\n /**\n * Get the content repository url with query parameters.\n * @returns An object with a 'base', 'path' and 'params' for base URL,\n * path and query parameters respectively.\n */\n public getContentUri(): IContentUri {\n return {\n base: this.opts.baseUrl,\n path: MediaPrefix.R0 + \"/upload\",\n params: {\n access_token: this.opts.accessToken!,\n },\n };\n }\n}\n"],"mappings":";;;;;;;;;;;AAgBA,IAAAA,MAAA,GAAAC,OAAA;AAEA,IAAAC,OAAA,GAAAD,OAAA;AAQAE,MAAA,CAAAC,IAAA,CAAAF,OAAA,EAAAG,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAJ,OAAA,CAAAI,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAZ,OAAA,CAAAI,GAAA;IAAA;EAAA;AAAA;AAPA,IAAAS,KAAA,GAAAC,uBAAA,CAAAf,OAAA;AACA,IAAAgB,SAAA,GAAAD,uBAAA,CAAAf,OAAA;AACA,IAAAiB,OAAA,GAAAjB,OAAA;AAOAE,MAAA,CAAAC,IAAA,CAAAc,OAAA,EAAAb,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAY,OAAA,CAAAZ,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAI,OAAA,CAAAZ,GAAA;IAAA;EAAA;AAAA;AANA,IAAAa,OAAA,GAAAlB,OAAA;AAKAE,MAAA,CAAAC,IAAA,CAAAe,OAAA,EAAAd,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAa,OAAA,CAAAb,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAK,OAAA,CAAAb,GAAA;IAAA;EAAA;AAAA;AAJA,IAAAc,OAAA,GAAAnB,OAAA;AAMAE,MAAA,CAAAC,IAAA,CAAAgB,OAAA,EAAAf,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAc,OAAA,CAAAd,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAM,OAAA,CAAAd,GAAA;IAAA;EAAA;AAAA;AAJA,IAAAe,UAAA,GAAApB,OAAA;AAAAE,MAAA,CAAAC,IAAA,CAAAiB,UAAA,EAAAhB,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAe,UAAA,CAAAf,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAO,UAAA,CAAAf,GAAA;IAAA;EAAA;AAAA;AAA4B,SAAAgB,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAP,wBAAAW,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAhB,GAAA,CAAAa,GAAA,SAAAK,MAAA,WAAAC,qBAAA,GAAA9B,MAAA,CAAAS,cAAA,IAAAT,MAAA,CAAA+B,wBAAA,WAAA5B,GAAA,IAAAqB,GAAA,QAAArB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAkB,GAAA,EAAArB,GAAA,SAAA6B,IAAA,GAAAF,qBAAA,GAAA9B,MAAA,CAAA+B,wBAAA,CAAAP,GAAA,EAAArB,GAAA,cAAA6B,IAAA,KAAAA,IAAA,CAAArB,GAAA,IAAAqB,IAAA,CAAAC,GAAA,KAAAjC,MAAA,CAAAS,cAAA,CAAAoB,MAAA,EAAA1B,GAAA,EAAA6B,IAAA,YAAAH,MAAA,CAAA1B,GAAA,IAAAqB,GAAA,CAAArB,GAAA,SAAA0B,MAAA,CAAAH,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAM,GAAA,CAAAT,GAAA,EAAAK,MAAA,YAAAA,MAAA;AAzB5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAiBO,MAAMK,aAAa,SAA8BC,mBAAY,CAAI;EAAAC,YAAA,GAAAC,IAAA;IAAA,SAAAA,IAAA;IAAA,IAAAC,gBAAA,CAAAZ,OAAA,mBACxC,EAAE;EAAA;EAE9B;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACWa,aAAaA,CAACC,IAAc,EAAEC,IAAgB,GAAG,CAAC,CAAC,EAA2B;IAAA,IAAAC,qBAAA,EAAAC,qBAAA,EAAAC,IAAA,EAAAC,UAAA,EAAAC,UAAA;IACjF,MAAMC,eAAe,IAAAL,qBAAA,GAAGD,IAAI,CAACM,eAAe,cAAAL,qBAAA,cAAAA,qBAAA,GAAI,IAAI;IACpD,MAAMM,eAAe,IAAAL,qBAAA,GAAGF,IAAI,CAACO,eAAe,cAAAL,qBAAA,cAAAA,qBAAA,GAAI,IAAIM,eAAe,EAAE;;IAErE;IACA,MAAMC,WAAW,IAAAN,IAAA,IAAAC,UAAA,GAAGJ,IAAI,CAACU,IAAI,cAAAN,UAAA,cAAAA,UAAA,GAAKL,IAAI,CAAUW,IAAI,cAAAP,IAAA,cAAAA,IAAA,GAAI,0BAA0B;IAClF,MAAMQ,QAAQ,IAAAN,UAAA,GAAGL,IAAI,CAACY,IAAI,cAAAP,UAAA,cAAAA,UAAA,GAAKN,IAAI,CAAUa,IAAI;IAEjD,MAAMC,MAAM,GAAG;MACXC,MAAM,EAAE,CAAC;MACTC,KAAK,EAAE,CAAC;MACRR;IACJ,CAAW;IACX,MAAMS,KAAK,GAAG7C,KAAK,CAAC6C,KAAK,EAAkB;IAE3C,IAAIC,MAAM,CAACC,cAAc,EAAE;MACvB,MAAMC,GAAG,GAAG,IAAIF,MAAM,CAACC,cAAc,EAAE;MAEvC,MAAME,SAAS,GAAG,SAAAA,CAAA,EAAkB;QAChCD,GAAG,CAACE,KAAK,EAAE;QACXL,KAAK,CAACM,MAAM,CAAC,IAAIC,KAAK,CAAC,SAAS,CAAC,CAAC;MACtC,CAAC;;MAED;MACA,IAAIC,YAAY,GAAGnD,SAAS,CAACoD,UAAU,CAACL,SAAS,EAAE,KAAK,CAAC;MAEzDD,GAAG,CAACO,kBAAkB,GAAG,YAAkB;QACvC,QAAQP,GAAG,CAACQ,UAAU;UAClB,KAAKV,MAAM,CAACC,cAAc,CAACU,IAAI;YAC3BvD,SAAS,CAACwD,YAAY,CAACL,YAAY,CAAC;YACpC,IAAI;cACA,IAAIL,GAAG,CAACW,MAAM,KAAK,CAAC,EAAE;gBAClB,MAAM,IAAIC,YAAY,CAACZ,GAAG,CAACa,UAAU,EAAE,YAAY,CAAC,CAAC,CAAC;cAC1D;;cACA,IAAI,CAACb,GAAG,CAACc,YAAY,EAAE;gBACnB,MAAM,IAAIV,KAAK,CAAC,mBAAmB,CAAC;cACxC;cAEA,IAAIJ,GAAG,CAACW,MAAM,IAAI,GAAG,EAAE;gBACnBd,KAAK,CAACM,MAAM,CAAC,IAAAY,0BAAkB,EAACf,GAAG,EAAEA,GAAG,CAACc,YAAY,CAAC,CAAC;cAC3D,CAAC,MAAM;gBACHjB,KAAK,CAACmB,OAAO,CAACC,IAAI,CAACC,KAAK,CAAClB,GAAG,CAACc,YAAY,CAAC,CAAC;cAC/C;YACJ,CAAC,CAAC,OAAOK,GAAG,EAAE;cACV,IAAYA,GAAG,CAAE1B,IAAI,KAAK,YAAY,EAAE;gBACpCI,KAAK,CAACM,MAAM,CAACgB,GAAG,CAAC;gBACjB;cACJ;cACAtB,KAAK,CAACM,MAAM,CAAC,IAAIiB,uBAAe,CAAC,gBAAgB,EAASD,GAAG,CAAC,CAAC;YACnE;YACA;QAAM;MAElB,CAAC;MAEDnB,GAAG,CAACN,MAAM,CAAC2B,UAAU,GAAIC,EAAiB,IAAW;QAAA,IAAAC,qBAAA;QACjDrE,SAAS,CAACwD,YAAY,CAACL,YAAY,CAAC;QACpCX,MAAM,CAACC,MAAM,GAAG2B,EAAE,CAAC3B,MAAM;QACzBD,MAAM,CAACE,KAAK,GAAG0B,EAAE,CAAC1B,KAAK;QACvBS,YAAY,GAAGnD,SAAS,CAACoD,UAAU,CAACL,SAAS,EAAE,KAAK,CAAC;QACrD,CAAAsB,qBAAA,GAAA1C,IAAI,CAAC2C,eAAe,cAAAD,qBAAA,uBAApBA,qBAAA,CAAA7E,IAAA,CAAAmC,IAAI,EAAmB;UACnBc,MAAM,EAAE2B,EAAE,CAAC3B,MAAM;UACjBC,KAAK,EAAE0B,EAAE,CAAC1B;QACd,CAAC,CAAC;MACN,CAAC;MAED,MAAM6B,GAAG,GAAG,IAAI,CAACC,MAAM,CAAC,SAAS,EAAEC,SAAS,EAAEC,mBAAW,CAACC,EAAE,CAAC;MAE7D,IAAI1C,eAAe,IAAIK,QAAQ,EAAE;QAC7BiC,GAAG,CAACK,YAAY,CAACzD,GAAG,CAAC,UAAU,EAAE0D,kBAAkB,CAACvC,QAAQ,CAAC,CAAC;MAClE;MAEA,IAAI,CAAC,IAAI,CAACX,IAAI,CAACmD,sBAAsB,IAAI,IAAI,CAACnD,IAAI,CAACoD,WAAW,EAAE;QAC5DR,GAAG,CAACK,YAAY,CAACzD,GAAG,CAAC,cAAc,EAAE0D,kBAAkB,CAAC,IAAI,CAAClD,IAAI,CAACoD,WAAW,CAAC,CAAC;MACnF;MAEAjC,GAAG,CAACkC,IAAI,CAACC,cAAM,CAACC,IAAI,EAAEX,GAAG,CAACY,IAAI,CAAC;MAC/B,IAAI,IAAI,CAACxD,IAAI,CAACmD,sBAAsB,IAAI,IAAI,CAACnD,IAAI,CAACoD,WAAW,EAAE;QAC3DjC,GAAG,CAACsC,gBAAgB,CAAC,eAAe,EAAE,SAAS,GAAG,IAAI,CAACzD,IAAI,CAACoD,WAAW,CAAC;MAC5E;MACAjC,GAAG,CAACsC,gBAAgB,CAAC,cAAc,EAAEhD,WAAW,CAAC;MACjDU,GAAG,CAACuC,IAAI,CAAC3D,IAAI,CAAC;MAEdQ,eAAe,CAACoD,MAAM,CAACC,gBAAgB,CAAC,OAAO,EAAE,MAAM;QACnDzC,GAAG,CAACE,KAAK,EAAE;MACf,CAAC,CAAC;IACN,CAAC,MAAM;MACH,MAAMwC,WAA4B,GAAG,CAAC,CAAC;MACvC,IAAIvD,eAAe,IAAIK,QAAQ,EAAE;QAC7BkD,WAAW,CAACC,QAAQ,GAAGnD,QAAQ;MACnC;MAEA,MAAMoD,OAA+B,GAAG;QAAE,cAAc,EAAEtD;MAAY,CAAC;MAEvE,IAAI,CAACuD,aAAa,CAAiBV,cAAM,CAACC,IAAI,EAAE,SAAS,EAAEM,WAAW,EAAE9D,IAAI,EAAE;QAC1EkE,MAAM,EAAElB,mBAAW,CAACC,EAAE;QACtBe,OAAO;QACPG,WAAW,EAAE3D,eAAe,CAACoD;MACjC,CAAC,CAAC,CACGQ,IAAI,CAAEC,QAAQ,IAAK;QAChB,OAAO,IAAI,CAACpE,IAAI,CAACqE,QAAQ,GAAmBD,QAAQ,GAAGA,QAAQ,CAACE,IAAI,EAAE;MAC1E,CAAC,CAAC,CACDH,IAAI,CAACnD,KAAK,CAACmB,OAAO,EAAEnB,KAAK,CAACM,MAAM,CAAC;IAC1C;;IAEA;IACAT,MAAM,CAAC0D,OAAO,GAAGvD,KAAK,CAACuD,OAAO,CAACC,OAAO,CAAC,MAAM;MACzCrG,KAAK,CAACsG,aAAa,CAAC,IAAI,CAACC,OAAO,EAAGC,IAAI,IAAKA,IAAI,KAAK9D,MAAM,CAAC;IAChE,CAAC,CAAC;IACFN,eAAe,CAACoD,MAAM,CAACC,gBAAgB,CAAC,OAAO,EAAE,MAAM;MACnDzF,KAAK,CAACsG,aAAa,CAAC,IAAI,CAACC,OAAO,EAAGC,IAAI,IAAKA,IAAI,KAAK9D,MAAM,CAAC;MAC5DG,KAAK,CAACM,MAAM,CAAC,IAAIS,YAAY,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;IAC3D,CAAC,CAAC;IACF,IAAI,CAAC2C,OAAO,CAACE,IAAI,CAAC/D,MAAM,CAAC;IACzB,OAAOA,MAAM,CAAC0D,OAAO;EACzB;EAEOM,YAAYA,CAACN,OAAgC,EAAW;IAC3D,MAAM1D,MAAM,GAAG,IAAI,CAAC6D,OAAO,CAACI,IAAI,CAAEC,CAAC,IAAKA,CAAC,CAACR,OAAO,KAAKA,OAAO,CAAC;IAC9D,IAAI1D,MAAM,EAAE;MACRA,MAAM,CAACN,eAAe,CAACc,KAAK,EAAE;MAC9B,OAAO,IAAI;IACf;IACA,OAAO,KAAK;EAChB;EAEO2D,iBAAiBA,CAAA,EAAa;IACjC,OAAO,IAAI,CAACN,OAAO;EACvB;;EAEA;AACJ;AACA;AACA;AACA;EACWO,aAAaA,CAAA,EAAgB;IAChC,OAAO;MACHC,IAAI,EAAE,IAAI,CAAClF,IAAI,CAACmF,OAAO;MACvBC,IAAI,EAAErC,mBAAW,CAACC,EAAE,GAAG,SAAS;MAChCqC,MAAM,EAAE;QACJC,YAAY,EAAE,IAAI,CAACtF,IAAI,CAACoD;MAC5B;IACJ,CAAC;EACL;AACJ;AAACrF,OAAA,CAAA0B,aAAA,GAAAA,aAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts deleted file mode 100644 index 321a67e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts +++ /dev/null @@ -1,113 +0,0 @@ -import { MatrixError } from "./errors"; -export interface IHttpOpts { - fetchFn?: typeof global.fetch; - baseUrl: string; - idBaseUrl?: string; - prefix: string; - extraParams?: Record; - accessToken?: string; - useAuthorizationHeader?: boolean; - onlyData?: boolean; - localTimeoutMs?: number; -} -export interface IRequestOpts { - /** - * The alternative base url to use. - * If not specified, uses this.opts.baseUrl - */ - baseUrl?: string; - /** - * The full prefix to use e.g. - * "/_matrix/client/v2_alpha". If not specified, uses this.opts.prefix. - */ - prefix?: string; - /** - * map of additional request headers - */ - headers?: Record; - abortSignal?: AbortSignal; - /** - * The maximum amount of time to wait before - * timing out the request. If not specified, there is no timeout. - */ - localTimeoutMs?: number; - keepAlive?: boolean; - json?: boolean; - inhibitLogoutEmit?: boolean; -} -export interface IContentUri { - base: string; - path: string; - params: { - access_token: string; - }; -} -export declare enum HttpApiEvent { - SessionLoggedOut = "Session.logged_out", - NoConsent = "no_consent" -} -export type HttpApiEventHandlerMap = { - /** - * Fires whenever the login session the JS SDK is using is no - * longer valid and the user must log in again. - * NB. This only fires when action is required from the user, not - * when then login session can be renewed by using a refresh token. - * @example - * ``` - * matrixClient.on("Session.logged_out", function(errorObj){ - * // show the login screen - * }); - * ``` - */ - [HttpApiEvent.SessionLoggedOut]: (err: MatrixError) => void; - /** - * Fires when the JS SDK receives a M_CONSENT_NOT_GIVEN error in response - * to a HTTP request. - * @example - * ``` - * matrixClient.on("no_consent", function(message, contentUri) { - * console.info(message + ' Go to ' + contentUri); - * }); - * ``` - */ - [HttpApiEvent.NoConsent]: (message: string, consentUri: string) => void; -}; -export interface UploadProgress { - loaded: number; - total: number; -} -export interface UploadOpts { - /** - * Name to give the file on the server. Defaults to file.name. - */ - name?: string; - /** - * Content-type for the upload. Defaults to - * file.type, or applicaton/octet-stream. - */ - type?: string; - /** - * if false will not send the filename, - * e.g for encrypted file uploads where filename leaks are undesirable. - * Defaults to true. - */ - includeFilename?: boolean; - /** - * Optional. Called when a chunk of - * data has been uploaded, with an object containing the fields `loaded` - * (number of bytes transferred) and `total` (total size, if known). - */ - progressHandler?(progress: UploadProgress): void; - abortController?: AbortController; -} -export interface Upload { - loaded: number; - total: number; - promise: Promise; - abortController: AbortController; -} -export interface UploadResponse { - content_uri: string; -} -export type FileType = XMLHttpRequestBodyInit; -//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts.map deleted file mode 100644 index 47f3140..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../src/http-api/interface.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,MAAM,WAAW,SAAS;IACtB,OAAO,CAAC,EAAE,OAAO,MAAM,CAAC,KAAK,CAAC;IAE9B,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAErC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,sBAAsB,CAAC,EAAE,OAAO,CAAC;IAEjC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,YAAY;IACzB;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B;;;OAGG;IACH,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,IAAI,CAAC,EAAE,OAAO,CAAC;IAKf,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC/B;AAED,MAAM,WAAW,WAAW;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE;QAEJ,YAAY,EAAE,MAAM,CAAC;KACxB,CAAC;CACL;AAED,oBAAY,YAAY;IACpB,gBAAgB,uBAAuB;IACvC,SAAS,eAAe;CAC3B;AAED,MAAM,MAAM,sBAAsB,GAAG;IACjC;;;;;;;;;;;OAWG;IACH,CAAC,YAAY,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,EAAE,WAAW,KAAK,IAAI,CAAC;IAC5D;;;;;;;;;OASG;IACH,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;CAC3E,CAAC;AAEF,MAAM,WAAW,cAAc;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,UAAU;IACvB;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;;;OAGG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;;;;OAIG;IACH,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B;;;;OAIG;IACH,eAAe,CAAC,CAAC,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;IACjD,eAAe,CAAC,EAAE,eAAe,CAAC;CACrC;AAED,MAAM,WAAW,MAAM;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,OAAO,CAAC,cAAc,CAAC,CAAC;IACjC,eAAe,EAAE,eAAe,CAAC;CACpC;AAED,MAAM,WAAW,cAAc;IAE3B,WAAW,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,MAAM,QAAQ,GAAG,sBAAsB,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js deleted file mode 100644 index 9510b45..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.HttpApiEvent = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let HttpApiEvent; -exports.HttpApiEvent = HttpApiEvent; -(function (HttpApiEvent) { - HttpApiEvent["SessionLoggedOut"] = "Session.logged_out"; - HttpApiEvent["NoConsent"] = "no_consent"; -})(HttpApiEvent || (exports.HttpApiEvent = HttpApiEvent = {})); -//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js.map deleted file mode 100644 index 06baa9f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/interface.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"interface.js","names":["HttpApiEvent","exports"],"sources":["../../src/http-api/interface.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixError } from \"./errors\";\n\nexport interface IHttpOpts {\n fetchFn?: typeof global.fetch;\n\n baseUrl: string;\n idBaseUrl?: string;\n prefix: string;\n extraParams?: Record;\n\n accessToken?: string;\n useAuthorizationHeader?: boolean; // defaults to true\n\n onlyData?: boolean;\n localTimeoutMs?: number;\n}\n\nexport interface IRequestOpts {\n /**\n * The alternative base url to use.\n * If not specified, uses this.opts.baseUrl\n */\n baseUrl?: string;\n /**\n * The full prefix to use e.g.\n * \"/_matrix/client/v2_alpha\". If not specified, uses this.opts.prefix.\n */\n prefix?: string;\n /**\n * map of additional request headers\n */\n headers?: Record;\n abortSignal?: AbortSignal;\n /**\n * The maximum amount of time to wait before\n * timing out the request. If not specified, there is no timeout.\n */\n localTimeoutMs?: number;\n keepAlive?: boolean; // defaults to false\n json?: boolean; // defaults to true\n\n // Set to true to prevent the request function from emitting a Session.logged_out event.\n // This is intended for use on endpoints where M_UNKNOWN_TOKEN is a valid/notable error response,\n // such as with token refreshes.\n inhibitLogoutEmit?: boolean;\n}\n\nexport interface IContentUri {\n base: string;\n path: string;\n params: {\n // eslint-disable-next-line camelcase\n access_token: string;\n };\n}\n\nexport enum HttpApiEvent {\n SessionLoggedOut = \"Session.logged_out\",\n NoConsent = \"no_consent\",\n}\n\nexport type HttpApiEventHandlerMap = {\n /**\n * Fires whenever the login session the JS SDK is using is no\n * longer valid and the user must log in again.\n * NB. This only fires when action is required from the user, not\n * when then login session can be renewed by using a refresh token.\n * @example\n * ```\n * matrixClient.on(\"Session.logged_out\", function(errorObj){\n * // show the login screen\n * });\n * ```\n */\n [HttpApiEvent.SessionLoggedOut]: (err: MatrixError) => void;\n /**\n * Fires when the JS SDK receives a M_CONSENT_NOT_GIVEN error in response\n * to a HTTP request.\n * @example\n * ```\n * matrixClient.on(\"no_consent\", function(message, contentUri) {\n * console.info(message + ' Go to ' + contentUri);\n * });\n * ```\n */\n [HttpApiEvent.NoConsent]: (message: string, consentUri: string) => void;\n};\n\nexport interface UploadProgress {\n loaded: number;\n total: number;\n}\n\nexport interface UploadOpts {\n /**\n * Name to give the file on the server. Defaults to file.name.\n */\n name?: string;\n /**\n * Content-type for the upload. Defaults to\n * file.type, or applicaton/octet-stream.\n */\n type?: string;\n /**\n * if false will not send the filename,\n * e.g for encrypted file uploads where filename leaks are undesirable.\n * Defaults to true.\n */\n includeFilename?: boolean;\n /**\n * Optional. Called when a chunk of\n * data has been uploaded, with an object containing the fields `loaded`\n * (number of bytes transferred) and `total` (total size, if known).\n */\n progressHandler?(progress: UploadProgress): void;\n abortController?: AbortController;\n}\n\nexport interface Upload {\n loaded: number;\n total: number;\n promise: Promise;\n abortController: AbortController;\n}\n\nexport interface UploadResponse {\n // eslint-disable-next-line camelcase\n content_uri: string;\n}\n\nexport type FileType = XMLHttpRequestBodyInit;\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAwEYA,YAAY;AAAAC,OAAA,CAAAD,YAAA,GAAAA,YAAA;AAAA,WAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;AAAA,GAAZA,YAAY,KAAAC,OAAA,CAAAD,YAAA,GAAZA,YAAY"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts deleted file mode 100644 index 6cf2bd8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts +++ /dev/null @@ -1,7 +0,0 @@ -export declare enum Method { - Get = "GET", - Put = "PUT", - Post = "POST", - Delete = "DELETE" -} -//# sourceMappingURL=method.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts.map deleted file mode 100644 index d03e27b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"method.d.ts","sourceRoot":"","sources":["../../src/http-api/method.ts"],"names":[],"mappings":"AAgBA,oBAAY,MAAM;IACd,GAAG,QAAQ;IACX,GAAG,QAAQ;IACX,IAAI,SAAS;IACb,MAAM,WAAW;CACpB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js deleted file mode 100644 index a72c48b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js +++ /dev/null @@ -1,30 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.Method = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let Method; -exports.Method = Method; -(function (Method) { - Method["Get"] = "GET"; - Method["Put"] = "PUT"; - Method["Post"] = "POST"; - Method["Delete"] = "DELETE"; -})(Method || (exports.Method = Method = {})); -//# sourceMappingURL=method.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js.map deleted file mode 100644 index 2cbf2f5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/method.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"method.js","names":["Method","exports"],"sources":["../../src/http-api/method.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport enum Method {\n Get = \"GET\",\n Put = \"PUT\",\n Post = \"POST\",\n Delete = \"DELETE\",\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAgBYA,MAAM;AAAAC,OAAA,CAAAD,MAAA,GAAAA,MAAA;AAAA,WAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;EAANA,MAAM;AAAA,GAANA,MAAM,KAAAC,OAAA,CAAAD,MAAA,GAANA,MAAM"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts deleted file mode 100644 index e12d6a7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts +++ /dev/null @@ -1,31 +0,0 @@ -export declare enum ClientPrefix { - /** - * A constant representing the URI path for release 0 of the Client-Server HTTP API. - */ - R0 = "/_matrix/client/r0", - /** - * A constant representing the URI path for the legacy release v1 of the Client-Server HTTP API. - */ - V1 = "/_matrix/client/v1", - /** - * A constant representing the URI path for Client-Server API endpoints versioned at v3. - */ - V3 = "/_matrix/client/v3", - /** - * A constant representing the URI path for as-yet unspecified Client-Server HTTP APIs. - */ - Unstable = "/_matrix/client/unstable" -} -export declare enum IdentityPrefix { - /** - * URI path for the v2 identity API - */ - V2 = "/_matrix/identity/v2" -} -export declare enum MediaPrefix { - /** - * URI path for the media repo API - */ - R0 = "/_matrix/media/r0" -} -//# sourceMappingURL=prefix.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts.map deleted file mode 100644 index a5a4d0c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"prefix.d.ts","sourceRoot":"","sources":["../../src/http-api/prefix.ts"],"names":[],"mappings":"AAgBA,oBAAY,YAAY;IACpB;;OAEG;IACH,EAAE,uBAAuB;IACzB;;OAEG;IACH,EAAE,uBAAuB;IACzB;;OAEG;IACH,EAAE,uBAAuB;IACzB;;OAEG;IACH,QAAQ,6BAA6B;CACxC;AAED,oBAAY,cAAc;IACtB;;OAEG;IACH,EAAE,yBAAyB;CAC9B;AAED,oBAAY,WAAW;IACnB;;OAEG;IACH,EAAE,sBAAsB;CAC3B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js deleted file mode 100644 index 7db19ba..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js +++ /dev/null @@ -1,40 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MediaPrefix = exports.IdentityPrefix = exports.ClientPrefix = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let ClientPrefix; -exports.ClientPrefix = ClientPrefix; -(function (ClientPrefix) { - ClientPrefix["R0"] = "/_matrix/client/r0"; - ClientPrefix["V1"] = "/_matrix/client/v1"; - ClientPrefix["V3"] = "/_matrix/client/v3"; - ClientPrefix["Unstable"] = "/_matrix/client/unstable"; -})(ClientPrefix || (exports.ClientPrefix = ClientPrefix = {})); -let IdentityPrefix; -exports.IdentityPrefix = IdentityPrefix; -(function (IdentityPrefix) { - IdentityPrefix["V2"] = "/_matrix/identity/v2"; -})(IdentityPrefix || (exports.IdentityPrefix = IdentityPrefix = {})); -let MediaPrefix; -exports.MediaPrefix = MediaPrefix; -(function (MediaPrefix) { - MediaPrefix["R0"] = "/_matrix/media/r0"; -})(MediaPrefix || (exports.MediaPrefix = MediaPrefix = {})); -//# sourceMappingURL=prefix.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js.map deleted file mode 100644 index 9a3e6d6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/prefix.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"prefix.js","names":["ClientPrefix","exports","IdentityPrefix","MediaPrefix"],"sources":["../../src/http-api/prefix.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport enum ClientPrefix {\n /**\n * A constant representing the URI path for release 0 of the Client-Server HTTP API.\n */\n R0 = \"/_matrix/client/r0\",\n /**\n * A constant representing the URI path for the legacy release v1 of the Client-Server HTTP API.\n */\n V1 = \"/_matrix/client/v1\",\n /**\n * A constant representing the URI path for Client-Server API endpoints versioned at v3.\n */\n V3 = \"/_matrix/client/v3\",\n /**\n * A constant representing the URI path for as-yet unspecified Client-Server HTTP APIs.\n */\n Unstable = \"/_matrix/client/unstable\",\n}\n\nexport enum IdentityPrefix {\n /**\n * URI path for the v2 identity API\n */\n V2 = \"/_matrix/identity/v2\",\n}\n\nexport enum MediaPrefix {\n /**\n * URI path for the media repo API\n */\n R0 = \"/_matrix/media/r0\",\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAgBYA,YAAY;AAAAC,OAAA,CAAAD,YAAA,GAAAA,YAAA;AAAA,WAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;EAAZA,YAAY;AAAA,GAAZA,YAAY,KAAAC,OAAA,CAAAD,YAAA,GAAZA,YAAY;AAAA,IAmBZE,cAAc;AAAAD,OAAA,CAAAC,cAAA,GAAAA,cAAA;AAAA,WAAdA,cAAc;EAAdA,cAAc;AAAA,GAAdA,cAAc,KAAAD,OAAA,CAAAC,cAAA,GAAdA,cAAc;AAAA,IAOdC,WAAW;AAAAF,OAAA,CAAAE,WAAA,GAAAA,WAAA;AAAA,WAAXA,WAAW;EAAXA,WAAW;AAAA,GAAXA,WAAW,KAAAF,OAAA,CAAAE,WAAA,GAAXA,WAAW"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts deleted file mode 100644 index 0814e80..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts +++ /dev/null @@ -1,25 +0,0 @@ -export declare function timeoutSignal(ms: number): AbortSignal; -export declare function anySignal(signals: AbortSignal[]): { - signal: AbortSignal; - cleanup(): void; -}; -/** - * Attempt to turn an HTTP error response into a Javascript Error. - * - * If it is a JSON response, we will parse it into a MatrixError. Otherwise - * we return a generic Error. - * - * @param response - response object - * @param body - raw body of the response - * @returns - */ -export declare function parseErrorResponse(response: XMLHttpRequest | Response, body?: string): Error; -/** - * Retries a network operation run in a callback. - * @param maxAttempts - maximum attempts to try - * @param callback - callback that returns a promise of the network operation. If rejected with ConnectionError, it will be retried by calling the callback again. - * @returns the result of the network operation - * @throws {@link ConnectionError} If after maxAttempts the callback still throws ConnectionError - */ -export declare function retryNetworkOperation(maxAttempts: number, callback: () => Promise): Promise; -//# sourceMappingURL=utils.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts.map deleted file mode 100644 index 4ff990f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/http-api/utils.ts"],"names":[],"mappings":"AAuBA,wBAAgB,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,WAAW,CAOrD;AAED,wBAAgB,SAAS,CAAC,OAAO,EAAE,WAAW,EAAE,GAAG;IAC/C,MAAM,EAAE,WAAW,CAAC;IACpB,OAAO,IAAI,IAAI,CAAC;CACnB,CA0BA;AAED;;;;;;;;;GASG;AACH,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,cAAc,GAAG,QAAQ,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,KAAK,CAmB5F;AAgCD;;;;;;GAMG;AACH,wBAAsB,qBAAqB,CAAC,CAAC,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAqB1G"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js deleted file mode 100644 index 9115598..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js +++ /dev/null @@ -1,145 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.anySignal = anySignal; -exports.parseErrorResponse = parseErrorResponse; -exports.retryNetworkOperation = retryNetworkOperation; -exports.timeoutSignal = timeoutSignal; -var _contentType3 = require("content-type"); -var _logger = require("../logger"); -var _utils = require("../utils"); -var _errors = require("./errors"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// Ponyfill for https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal/timeout -function timeoutSignal(ms) { - const controller = new AbortController(); - setTimeout(() => { - controller.abort(); - }, ms); - return controller.signal; -} -function anySignal(signals) { - const controller = new AbortController(); - function cleanup() { - for (const signal of signals) { - signal.removeEventListener("abort", onAbort); - } - } - function onAbort() { - controller.abort(); - cleanup(); - } - for (const signal of signals) { - if (signal.aborted) { - onAbort(); - break; - } - signal.addEventListener("abort", onAbort); - } - return { - signal: controller.signal, - cleanup - }; -} - -/** - * Attempt to turn an HTTP error response into a Javascript Error. - * - * If it is a JSON response, we will parse it into a MatrixError. Otherwise - * we return a generic Error. - * - * @param response - response object - * @param body - raw body of the response - * @returns - */ -function parseErrorResponse(response, body) { - var _contentType, _contentType2; - let contentType; - try { - contentType = getResponseContentType(response); - } catch (e) { - return e; - } - if (((_contentType = contentType) === null || _contentType === void 0 ? void 0 : _contentType.type) === "application/json" && body) { - return new _errors.MatrixError(JSON.parse(body), response.status, isXhr(response) ? response.responseURL : response.url); - } - if (((_contentType2 = contentType) === null || _contentType2 === void 0 ? void 0 : _contentType2.type) === "text/plain") { - return new _errors.HTTPError(`Server returned ${response.status} error: ${body}`, response.status); - } - return new _errors.HTTPError(`Server returned ${response.status} error`, response.status); -} -function isXhr(response) { - return "getResponseHeader" in response; -} - -/** - * extract the Content-Type header from the response object, and - * parse it to a `{type, parameters}` object. - * - * returns null if no content-type header could be found. - * - * @param response - response object - * @returns parsed content-type header, or null if not found - */ -function getResponseContentType(response) { - let contentType; - if (isXhr(response)) { - contentType = response.getResponseHeader("Content-Type"); - } else { - contentType = response.headers.get("Content-Type"); - } - if (!contentType) return null; - try { - return (0, _contentType3.parse)(contentType); - } catch (e) { - throw new Error(`Error parsing Content-Type '${contentType}': ${e}`); - } -} - -/** - * Retries a network operation run in a callback. - * @param maxAttempts - maximum attempts to try - * @param callback - callback that returns a promise of the network operation. If rejected with ConnectionError, it will be retried by calling the callback again. - * @returns the result of the network operation - * @throws {@link ConnectionError} If after maxAttempts the callback still throws ConnectionError - */ -async function retryNetworkOperation(maxAttempts, callback) { - let attempts = 0; - let lastConnectionError = null; - while (attempts < maxAttempts) { - try { - if (attempts > 0) { - const timeout = 1000 * Math.pow(2, attempts); - _logger.logger.log(`network operation failed ${attempts} times, retrying in ${timeout}ms...`); - await (0, _utils.sleep)(timeout); - } - return await callback(); - } catch (err) { - if (err instanceof _errors.ConnectionError) { - attempts += 1; - lastConnectionError = err; - } else { - throw err; - } - } - } - throw lastConnectionError; -} -//# sourceMappingURL=utils.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js.map deleted file mode 100644 index 41425cc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/http-api/utils.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"utils.js","names":["_contentType3","require","_logger","_utils","_errors","timeoutSignal","ms","controller","AbortController","setTimeout","abort","signal","anySignal","signals","cleanup","removeEventListener","onAbort","aborted","addEventListener","parseErrorResponse","response","body","_contentType","_contentType2","contentType","getResponseContentType","e","type","MatrixError","JSON","parse","status","isXhr","responseURL","url","HTTPError","getResponseHeader","headers","get","parseContentType","Error","retryNetworkOperation","maxAttempts","callback","attempts","lastConnectionError","timeout","Math","pow","logger","log","sleep","err","ConnectionError"],"sources":["../../src/http-api/utils.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { parse as parseContentType, ParsedMediaType } from \"content-type\";\n\nimport { logger } from \"../logger\";\nimport { sleep } from \"../utils\";\nimport { ConnectionError, HTTPError, MatrixError } from \"./errors\";\n\n// Ponyfill for https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal/timeout\nexport function timeoutSignal(ms: number): AbortSignal {\n const controller = new AbortController();\n setTimeout(() => {\n controller.abort();\n }, ms);\n\n return controller.signal;\n}\n\nexport function anySignal(signals: AbortSignal[]): {\n signal: AbortSignal;\n cleanup(): void;\n} {\n const controller = new AbortController();\n\n function cleanup(): void {\n for (const signal of signals) {\n signal.removeEventListener(\"abort\", onAbort);\n }\n }\n\n function onAbort(): void {\n controller.abort();\n cleanup();\n }\n\n for (const signal of signals) {\n if (signal.aborted) {\n onAbort();\n break;\n }\n signal.addEventListener(\"abort\", onAbort);\n }\n\n return {\n signal: controller.signal,\n cleanup,\n };\n}\n\n/**\n * Attempt to turn an HTTP error response into a Javascript Error.\n *\n * If it is a JSON response, we will parse it into a MatrixError. Otherwise\n * we return a generic Error.\n *\n * @param response - response object\n * @param body - raw body of the response\n * @returns\n */\nexport function parseErrorResponse(response: XMLHttpRequest | Response, body?: string): Error {\n let contentType: ParsedMediaType | null;\n try {\n contentType = getResponseContentType(response);\n } catch (e) {\n return e;\n }\n\n if (contentType?.type === \"application/json\" && body) {\n return new MatrixError(\n JSON.parse(body),\n response.status,\n isXhr(response) ? response.responseURL : response.url,\n );\n }\n if (contentType?.type === \"text/plain\") {\n return new HTTPError(`Server returned ${response.status} error: ${body}`, response.status);\n }\n return new HTTPError(`Server returned ${response.status} error`, response.status);\n}\n\nfunction isXhr(response: XMLHttpRequest | Response): response is XMLHttpRequest {\n return \"getResponseHeader\" in response;\n}\n\n/**\n * extract the Content-Type header from the response object, and\n * parse it to a `{type, parameters}` object.\n *\n * returns null if no content-type header could be found.\n *\n * @param response - response object\n * @returns parsed content-type header, or null if not found\n */\nfunction getResponseContentType(response: XMLHttpRequest | Response): ParsedMediaType | null {\n let contentType: string | null;\n if (isXhr(response)) {\n contentType = response.getResponseHeader(\"Content-Type\");\n } else {\n contentType = response.headers.get(\"Content-Type\");\n }\n\n if (!contentType) return null;\n\n try {\n return parseContentType(contentType);\n } catch (e) {\n throw new Error(`Error parsing Content-Type '${contentType}': ${e}`);\n }\n}\n\n/**\n * Retries a network operation run in a callback.\n * @param maxAttempts - maximum attempts to try\n * @param callback - callback that returns a promise of the network operation. If rejected with ConnectionError, it will be retried by calling the callback again.\n * @returns the result of the network operation\n * @throws {@link ConnectionError} If after maxAttempts the callback still throws ConnectionError\n */\nexport async function retryNetworkOperation(maxAttempts: number, callback: () => Promise): Promise {\n let attempts = 0;\n let lastConnectionError: ConnectionError | null = null;\n while (attempts < maxAttempts) {\n try {\n if (attempts > 0) {\n const timeout = 1000 * Math.pow(2, attempts);\n logger.log(`network operation failed ${attempts} times, retrying in ${timeout}ms...`);\n await sleep(timeout);\n }\n return await callback();\n } catch (err) {\n if (err instanceof ConnectionError) {\n attempts += 1;\n lastConnectionError = err;\n } else {\n throw err;\n }\n }\n }\n throw lastConnectionError;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts deleted file mode 100644 index 16784f6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -import * as matrixcs from "./matrix"; -export * from "./matrix"; -export default matrixcs; -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts.map deleted file mode 100644 index a152b99..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,QAAQ,MAAM,UAAU,CAAC;AAOrC,cAAc,UAAU,CAAC;AACzB,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js deleted file mode 100644 index 613a61c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js +++ /dev/null @@ -1,44 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -var _exportNames = {}; -exports.default = void 0; -var matrixcs = _interopRequireWildcard(require("./matrix")); -Object.keys(matrixcs).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === matrixcs[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return matrixcs[key]; - } - }); -}); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -if (global.__js_sdk_entrypoint) { - throw new Error("Multiple matrix-js-sdk entrypoints detected!"); -} -global.__js_sdk_entrypoint = true; -var _default = matrixcs; -exports.default = _default; -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js.map deleted file mode 100644 index e618408..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["matrixcs","_interopRequireWildcard","require","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","newObj","hasPropertyDescriptor","getOwnPropertyDescriptor","desc","set","global","__js_sdk_entrypoint","Error","_default"],"sources":["../src/index.ts"],"sourcesContent":["/*\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as matrixcs from \"./matrix\";\n\nif (global.__js_sdk_entrypoint) {\n throw new Error(\"Multiple matrix-js-sdk entrypoints detected!\");\n}\nglobal.__js_sdk_entrypoint = true;\n\nexport * from \"./matrix\";\nexport default matrixcs;\n"],"mappings":";;;;;;;AAgBA,IAAAA,QAAA,GAAAC,uBAAA,CAAAC,OAAA;AAOAC,MAAA,CAAAC,IAAA,CAAAJ,QAAA,EAAAK,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAN,QAAA,CAAAM,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAd,QAAA,CAAAM,GAAA;IAAA;EAAA;AAAA;AAAyB,SAAAS,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAf,wBAAAmB,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAT,GAAA,CAAAM,GAAA,SAAAK,MAAA,WAAAC,qBAAA,GAAAvB,MAAA,CAAAS,cAAA,IAAAT,MAAA,CAAAwB,wBAAA,WAAArB,GAAA,IAAAc,GAAA,QAAAd,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAW,GAAA,EAAAd,GAAA,SAAAsB,IAAA,GAAAF,qBAAA,GAAAvB,MAAA,CAAAwB,wBAAA,CAAAP,GAAA,EAAAd,GAAA,cAAAsB,IAAA,KAAAA,IAAA,CAAAd,GAAA,IAAAc,IAAA,CAAAC,GAAA,KAAA1B,MAAA,CAAAS,cAAA,CAAAa,MAAA,EAAAnB,GAAA,EAAAsB,IAAA,YAAAH,MAAA,CAAAnB,GAAA,IAAAc,GAAA,CAAAd,GAAA,SAAAmB,MAAA,CAAAH,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAM,GAAA,CAAAT,GAAA,EAAAK,MAAA,YAAAA,MAAA;AAvBzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIA,IAAIK,MAAM,CAACC,mBAAmB,EAAE;EAC5B,MAAM,IAAIC,KAAK,CAAC,8CAA8C,CAAC;AACnE;AACAF,MAAM,CAACC,mBAAmB,GAAG,IAAI;AAAC,IAAAE,QAAA,GAGnBjC,QAAQ;AAAAW,OAAA,CAAAW,OAAA,GAAAW,QAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts deleted file mode 100644 index dd5a966..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -/** - * Check if an IndexedDB database exists. The only way to do so is to try opening it, so - * we do that and then delete it did not exist before. - * - * @param indexedDB - The `indexedDB` interface - * @param dbName - The database name to test for - * @returns Whether the database exists - */ -export declare function exists(indexedDB: IDBFactory, dbName: string): Promise; -//# sourceMappingURL=indexeddb-helpers.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts.map deleted file mode 100644 index 692f5c7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-helpers.d.ts","sourceRoot":"","sources":["../src/indexeddb-helpers.ts"],"names":[],"mappings":"AAgBA;;;;;;;GAOG;AACH,wBAAgB,MAAM,CAAC,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAyB9E"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js deleted file mode 100644 index 2714e1b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js +++ /dev/null @@ -1,57 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.exists = exists; -/* -Copyright 2019 New Vector Ltd - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Check if an IndexedDB database exists. The only way to do so is to try opening it, so - * we do that and then delete it did not exist before. - * - * @param indexedDB - The `indexedDB` interface - * @param dbName - The database name to test for - * @returns Whether the database exists - */ -function exists(indexedDB, dbName) { - return new Promise((resolve, reject) => { - let exists = true; - const req = indexedDB.open(dbName); - req.onupgradeneeded = () => { - // Since we did not provide an explicit version when opening, this event - // should only fire if the DB did not exist before at any version. - exists = false; - }; - req.onblocked = () => reject(req.error); - req.onsuccess = () => { - const db = req.result; - db.close(); - if (!exists) { - // The DB did not exist before, but has been created as part of this - // existence check. Delete it now to restore previous state. Delete can - // actually take a while to complete in some browsers, so don't wait for - // it. This won't block future open calls that a store might issue next to - // properly set up the DB. - indexedDB.deleteDatabase(dbName); - } - resolve(exists); - }; - req.onerror = () => reject(req.error); - }); -} -//# sourceMappingURL=indexeddb-helpers.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js.map deleted file mode 100644 index 33a8ca1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-helpers.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-helpers.js","names":["exists","indexedDB","dbName","Promise","resolve","reject","req","open","onupgradeneeded","onblocked","error","onsuccess","db","result","close","deleteDatabase","onerror"],"sources":["../src/indexeddb-helpers.ts"],"sourcesContent":["/*\nCopyright 2019 New Vector Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Check if an IndexedDB database exists. The only way to do so is to try opening it, so\n * we do that and then delete it did not exist before.\n *\n * @param indexedDB - The `indexedDB` interface\n * @param dbName - The database name to test for\n * @returns Whether the database exists\n */\nexport function exists(indexedDB: IDBFactory, dbName: string): Promise {\n return new Promise((resolve, reject) => {\n let exists = true;\n const req = indexedDB.open(dbName);\n req.onupgradeneeded = (): void => {\n // Since we did not provide an explicit version when opening, this event\n // should only fire if the DB did not exist before at any version.\n exists = false;\n };\n req.onblocked = (): void => reject(req.error);\n req.onsuccess = (): void => {\n const db = req.result;\n db.close();\n if (!exists) {\n // The DB did not exist before, but has been created as part of this\n // existence check. Delete it now to restore previous state. Delete can\n // actually take a while to complete in some browsers, so don't wait for\n // it. This won't block future open calls that a store might issue next to\n // properly set up the DB.\n indexedDB.deleteDatabase(dbName);\n }\n resolve(exists);\n };\n req.onerror = (): void => reject(req.error);\n });\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASA,MAAMA,CAACC,SAAqB,EAAEC,MAAc,EAAoB;EAC5E,OAAO,IAAIC,OAAO,CAAU,CAACC,OAAO,EAAEC,MAAM,KAAK;IAC7C,IAAIL,MAAM,GAAG,IAAI;IACjB,MAAMM,GAAG,GAAGL,SAAS,CAACM,IAAI,CAACL,MAAM,CAAC;IAClCI,GAAG,CAACE,eAAe,GAAG,MAAY;MAC9B;MACA;MACAR,MAAM,GAAG,KAAK;IAClB,CAAC;IACDM,GAAG,CAACG,SAAS,GAAG,MAAYJ,MAAM,CAACC,GAAG,CAACI,KAAK,CAAC;IAC7CJ,GAAG,CAACK,SAAS,GAAG,MAAY;MACxB,MAAMC,EAAE,GAAGN,GAAG,CAACO,MAAM;MACrBD,EAAE,CAACE,KAAK,EAAE;MACV,IAAI,CAACd,MAAM,EAAE;QACT;QACA;QACA;QACA;QACA;QACAC,SAAS,CAACc,cAAc,CAACb,MAAM,CAAC;MACpC;MACAE,OAAO,CAACJ,MAAM,CAAC;IACnB,CAAC;IACDM,GAAG,CAACU,OAAO,GAAG,MAAYX,MAAM,CAACC,GAAG,CAACI,KAAK,CAAC;EAC/C,CAAC,CAAC;AACN"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts deleted file mode 100644 index 0d2d64a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts +++ /dev/null @@ -1,7 +0,0 @@ -/** - * Separate exports file for the indexeddb web worker, which is designed - * to be used separately - */ -/** The {@link IndexedDBStoreWorker} class. */ -export { IndexedDBStoreWorker } from "./store/indexeddb-store-worker"; -//# sourceMappingURL=indexeddb-worker.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts.map deleted file mode 100644 index 8ade76d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-worker.d.ts","sourceRoot":"","sources":["../src/indexeddb-worker.ts"],"names":[],"mappings":"AAiBA;;;GAGG;AAEH,8CAA8C;AAC9C,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js deleted file mode 100644 index c9d78f8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js +++ /dev/null @@ -1,13 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -Object.defineProperty(exports, "IndexedDBStoreWorker", { - enumerable: true, - get: function () { - return _indexeddbStoreWorker.IndexedDBStoreWorker; - } -}); -var _indexeddbStoreWorker = require("./store/indexeddb-store-worker"); -//# sourceMappingURL=indexeddb-worker.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js.map deleted file mode 100644 index a520ddf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/indexeddb-worker.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-worker.js","names":["_indexeddbStoreWorker","require"],"sources":["../src/indexeddb-worker.ts"],"sourcesContent":["/*\nCopyright 2017 Vector Creations Ltd\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Separate exports file for the indexeddb web worker, which is designed\n * to be used separately\n */\n\n/** The {@link IndexedDBStoreWorker} class. */\nexport { IndexedDBStoreWorker } from \"./store/indexeddb-store-worker\";\n"],"mappings":";;;;;;;;;;;AAuBA,IAAAA,qBAAA,GAAAC,OAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts deleted file mode 100644 index f50594e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts +++ /dev/null @@ -1,270 +0,0 @@ -import { MatrixClient } from "./client"; -export interface UIAFlow { - stages: AuthType[]; -} -export interface IInputs { - emailAddress?: string; - phoneCountry?: string; - phoneNumber?: string; - registrationToken?: string; -} -export interface IStageStatus { - emailSid?: string; - errcode?: string; - error?: string; -} -export interface IAuthData { - session?: string; - type?: string; - completed?: string[]; - flows?: UIAFlow[]; - available_flows?: UIAFlow[]; - stages?: string[]; - required_stages?: AuthType[]; - params?: Record>; - data?: Record; - errcode?: string; - error?: string; - user_id?: string; - device_id?: string; - access_token?: string; -} -export declare enum AuthType { - Password = "m.login.password", - Recaptcha = "m.login.recaptcha", - Terms = "m.login.terms", - Email = "m.login.email.identity", - Msisdn = "m.login.msisdn", - Sso = "m.login.sso", - SsoUnstable = "org.matrix.login.sso", - Dummy = "m.login.dummy", - RegistrationToken = "m.login.registration_token", - UnstableRegistrationToken = "org.matrix.msc3231.login.registration_token" -} -export interface IAuthDict { - type?: string; - session?: string; - user?: string; - identifier?: any; - password?: string; - response?: string; - threepid_creds?: any; - threepidCreds?: any; - token?: string; -} -interface IOpts { - /** - * A matrix client to use for the auth process - */ - matrixClient: MatrixClient; - /** - * Error response from the last request. If null, a request will be made with no auth before starting. - */ - authData?: IAuthData; - /** - * Inputs provided by the user and used by different stages of the auto process. - * The inputs provided will affect what flow is chosen. - */ - inputs?: IInputs; - /** - * If resuming an existing interactive auth session, the sessionId of that session. - */ - sessionId?: string; - /** - * If resuming an existing interactive auth session, the client secret for that session - */ - clientSecret?: string; - /** - * If returning from having completed m.login.email.identity auth, the sid for the email verification session. - */ - emailSid?: string; - /** - * Called with the new auth dict to submit the request. - * Also passes a second deprecated arg which is a flag set to true if this request is a background request. - * The busyChanged callback should be used instead of the background flag. - * Should return a promise which resolves to the successful response or rejects with a MatrixError. - */ - doRequest(auth: IAuthData | null, background: boolean): Promise; - /** - * Called when the status of the UI auth changes, - * ie. when the state of an auth stage changes of when the auth flow moves to a new stage. - * The arguments are: the login type (eg m.login.password); and an object which is either an error or an - * informational object specific to the login type. - * If the 'errcode' key is defined, the object is an error, and has keys: - * errcode: string, the textual error code, eg. M_UNKNOWN - * error: string, human readable string describing the error - * - * The login type specific objects are as follows: - * m.login.email.identity: - * * emailSid: string, the sid of the active email auth session - */ - stateUpdated(nextStage: AuthType, status: IStageStatus): void; - /** - * A function that takes the email address (string), clientSecret (string), attempt number (int) and - * sessionId (string) and calls the relevant requestToken function and returns the promise returned by that - * function. - * If the resulting promise rejects, the rejection will propagate through to the attemptAuth promise. - */ - requestEmailToken(email: string, secret: string, attempt: number, session: string): Promise<{ - sid: string; - }>; - /** - * Called whenever the interactive auth logic becomes busy submitting information provided by the user or finishes. - * After this has been called with true the UI should indicate that a request is in progress - * until it is called again with false. - */ - busyChanged?(busy: boolean): void; - startAuthStage?(nextStage: string): Promise; -} -/** - * Abstracts the logic used to drive the interactive auth process. - * - *

Components implementing an interactive auth flow should instantiate one of - * these, passing in the necessary callbacks to the constructor. They should - * then call attemptAuth, which will return a promise which will resolve or - * reject when the interactive-auth process completes. - * - *

Meanwhile, calls will be made to the startAuthStage and doRequest - * callbacks, and information gathered from the user can be submitted with - * submitAuthDict. - * - * @param opts - options object - */ -export declare class InteractiveAuth { - private readonly matrixClient; - private readonly inputs; - private readonly clientSecret; - private readonly requestCallback; - private readonly busyChangedCallback?; - private readonly stateUpdatedCallback; - private readonly requestEmailTokenCallback; - private data; - private emailSid?; - private requestingEmailToken; - private attemptAuthDeferred; - private chosenFlow; - private currentStage; - private emailAttempt; - private submitPromise; - constructor(opts: IOpts); - /** - * begin the authentication process. - * - * @returns which resolves to the response on success, - * or rejects with the error on failure. Rejects with NoAuthFlowFoundError if - * no suitable authentication flow can be found - */ - attemptAuth(): Promise; - /** - * Poll to check if the auth session or current stage has been - * completed out-of-band. If so, the attemptAuth promise will - * be resolved. - */ - poll(): Promise; - /** - * get the auth session ID - * - * @returns session id - */ - getSessionId(): string | undefined; - /** - * get the client secret used for validation sessions - * with the identity server. - * - * @returns client secret - */ - getClientSecret(): string; - /** - * get the server params for a given stage - * - * @param loginType - login type for the stage - * @returns any parameters from the server for this stage - */ - getStageParams(loginType: string): Record | undefined; - getChosenFlow(): UIAFlow | null; - /** - * submit a new auth dict and fire off the request. This will either - * make attemptAuth resolve/reject, or cause the startAuthStage callback - * to be called for a new stage. - * - * @param authData - new auth dict to send to the server. Should - * include a `type` property denoting the login type, as well as any - * other params for that stage. - * @param background - If true, this request failing will not result - * in the attemptAuth promise being rejected. This can be set to true - * for requests that just poll to see if auth has been completed elsewhere. - */ - submitAuthDict(authData: IAuthDict, background?: boolean): Promise; - /** - * Gets the sid for the email validation session - * Specific to m.login.email.identity - * - * @returns The sid of the email auth session - */ - getEmailSid(): string | undefined; - /** - * Sets the sid for the email validation session - * This must be set in order to successfully poll for completion - * of the email validation. - * Specific to m.login.email.identity - * - * @param sid - The sid for the email validation session - */ - setEmailSid(sid: string): void; - /** - * Requests a new email token and sets the email sid for the validation session - */ - requestEmailToken: () => Promise; - /** - * Fire off a request, and either resolve the promise, or call - * startAuthStage. - * - * @internal - * @param auth - new auth dict, including session id - * @param background - If true, this request is a background poll, so it - * failing will not result in the attemptAuth promise being rejected. - * This can be set to true for requests that just poll to see if auth has - * been completed elsewhere. - */ - private doRequest; - /** - * Pick the next stage and call the callback - * - * @internal - * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found - */ - private startNextAuthStage; - /** - * Pick the next auth stage - * - * @internal - * @returns login type - * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found - */ - private chooseStage; - /** - * Pick one of the flows from the returned list - * If a flow using all of the inputs is found, it will - * be returned, otherwise, null will be returned. - * - * Only flows using all given inputs are chosen because it - * is likely to be surprising if the user provides a - * credential and it is not used. For example, for registration, - * this could result in the email not being used which would leave - * the account with no means to reset a password. - * - * @internal - * @returns flow - * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found - */ - private chooseFlow; - /** - * Get the first uncompleted stage in the given flow - * - * @internal - * @returns login type - */ - private firstUncompletedStage; -} -export {}; -//# sourceMappingURL=interactive-auth.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts.map deleted file mode 100644 index fc85b28..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"interactive-auth.d.ts","sourceRoot":"","sources":["../src/interactive-auth.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js deleted file mode 100644 index 7acf359..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js +++ /dev/null @@ -1,488 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.InteractiveAuth = exports.AuthType = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("./logger"); -var _utils = require("./utils"); -/* -Copyright 2016 OpenMarket Ltd -Copyright 2017 Vector Creations Ltd -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const EMAIL_STAGE_TYPE = "m.login.email.identity"; -const MSISDN_STAGE_TYPE = "m.login.msisdn"; -let AuthType; -exports.AuthType = AuthType; -(function (AuthType) { - AuthType["Password"] = "m.login.password"; - AuthType["Recaptcha"] = "m.login.recaptcha"; - AuthType["Terms"] = "m.login.terms"; - AuthType["Email"] = "m.login.email.identity"; - AuthType["Msisdn"] = "m.login.msisdn"; - AuthType["Sso"] = "m.login.sso"; - AuthType["SsoUnstable"] = "org.matrix.login.sso"; - AuthType["Dummy"] = "m.login.dummy"; - AuthType["RegistrationToken"] = "m.login.registration_token"; - AuthType["UnstableRegistrationToken"] = "org.matrix.msc3231.login.registration_token"; -})(AuthType || (exports.AuthType = AuthType = {})); -class NoAuthFlowFoundError extends Error { - // eslint-disable-next-line @typescript-eslint/naming-convention, camelcase - constructor(m, required_stages, flows) { - super(m); - this.required_stages = required_stages; - this.flows = flows; - (0, _defineProperty2.default)(this, "name", "NoAuthFlowFoundError"); - } -} -/** - * Abstracts the logic used to drive the interactive auth process. - * - *

Components implementing an interactive auth flow should instantiate one of - * these, passing in the necessary callbacks to the constructor. They should - * then call attemptAuth, which will return a promise which will resolve or - * reject when the interactive-auth process completes. - * - *

Meanwhile, calls will be made to the startAuthStage and doRequest - * callbacks, and information gathered from the user can be submitted with - * submitAuthDict. - * - * @param opts - options object - */ -class InteractiveAuth { - // if we are currently trying to submit an auth dict (which includes polling) - // the promise the will resolve/reject when it completes - - constructor(opts) { - (0, _defineProperty2.default)(this, "matrixClient", void 0); - (0, _defineProperty2.default)(this, "inputs", void 0); - (0, _defineProperty2.default)(this, "clientSecret", void 0); - (0, _defineProperty2.default)(this, "requestCallback", void 0); - (0, _defineProperty2.default)(this, "busyChangedCallback", void 0); - (0, _defineProperty2.default)(this, "stateUpdatedCallback", void 0); - (0, _defineProperty2.default)(this, "requestEmailTokenCallback", void 0); - (0, _defineProperty2.default)(this, "data", void 0); - (0, _defineProperty2.default)(this, "emailSid", void 0); - (0, _defineProperty2.default)(this, "requestingEmailToken", false); - (0, _defineProperty2.default)(this, "attemptAuthDeferred", null); - (0, _defineProperty2.default)(this, "chosenFlow", null); - (0, _defineProperty2.default)(this, "currentStage", null); - (0, _defineProperty2.default)(this, "emailAttempt", 1); - (0, _defineProperty2.default)(this, "submitPromise", null); - (0, _defineProperty2.default)(this, "requestEmailToken", async () => { - if (!this.requestingEmailToken) { - _logger.logger.trace("Requesting email token. Attempt: " + this.emailAttempt); - // If we've picked a flow with email auth, we send the email - // now because we want the request to fail as soon as possible - // if the email address is not valid (ie. already taken or not - // registered, depending on what the operation is). - this.requestingEmailToken = true; - try { - const requestTokenResult = await this.requestEmailTokenCallback(this.inputs.emailAddress, this.clientSecret, this.emailAttempt++, this.data.session); - this.emailSid = requestTokenResult.sid; - _logger.logger.trace("Email token request succeeded"); - } finally { - this.requestingEmailToken = false; - } - } else { - _logger.logger.warn("Could not request email token: Already requesting"); - } - }); - this.matrixClient = opts.matrixClient; - this.data = opts.authData || {}; - this.requestCallback = opts.doRequest; - this.busyChangedCallback = opts.busyChanged; - // startAuthStage included for backwards compat - this.stateUpdatedCallback = opts.stateUpdated || opts.startAuthStage; - this.requestEmailTokenCallback = opts.requestEmailToken; - this.inputs = opts.inputs || {}; - if (opts.sessionId) this.data.session = opts.sessionId; - this.clientSecret = opts.clientSecret || this.matrixClient.generateClientSecret(); - this.emailSid = opts.emailSid; - } - - /** - * begin the authentication process. - * - * @returns which resolves to the response on success, - * or rejects with the error on failure. Rejects with NoAuthFlowFoundError if - * no suitable authentication flow can be found - */ - attemptAuth() { - var _this$data; - // This promise will be quite long-lived and will resolve when the - // request is authenticated and completes successfully. - this.attemptAuthDeferred = (0, _utils.defer)(); - // pluck the promise out now, as doRequest may clear before we return - const promise = this.attemptAuthDeferred.promise; - - // if we have no flows, try a request to acquire the flows - if (!((_this$data = this.data) !== null && _this$data !== void 0 && _this$data.flows)) { - var _this$busyChangedCall; - (_this$busyChangedCall = this.busyChangedCallback) === null || _this$busyChangedCall === void 0 ? void 0 : _this$busyChangedCall.call(this, true); - // use the existing sessionId, if one is present. - const auth = this.data.session ? { - session: this.data.session - } : null; - this.doRequest(auth).finally(() => { - var _this$busyChangedCall2; - (_this$busyChangedCall2 = this.busyChangedCallback) === null || _this$busyChangedCall2 === void 0 ? void 0 : _this$busyChangedCall2.call(this, false); - }); - } else { - this.startNextAuthStage(); - } - return promise; - } - - /** - * Poll to check if the auth session or current stage has been - * completed out-of-band. If so, the attemptAuth promise will - * be resolved. - */ - async poll() { - if (!this.data.session) return; - // likewise don't poll if there is no auth session in progress - if (!this.attemptAuthDeferred) return; - // if we currently have a request in flight, there's no point making - // another just to check what the status is - if (this.submitPromise) return; - let authDict = {}; - if (this.currentStage == EMAIL_STAGE_TYPE) { - // The email can be validated out-of-band, but we need to provide the - // creds so the HS can go & check it. - if (this.emailSid) { - const creds = { - sid: this.emailSid, - client_secret: this.clientSecret - }; - if (await this.matrixClient.doesServerRequireIdServerParam()) { - const idServerParsedUrl = new URL(this.matrixClient.getIdentityServerUrl()); - creds.id_server = idServerParsedUrl.host; - } - authDict = { - type: EMAIL_STAGE_TYPE, - // TODO: Remove `threepid_creds` once servers support proper UIA - // See https://github.com/matrix-org/synapse/issues/5665 - // See https://github.com/matrix-org/matrix-doc/issues/2220 - threepid_creds: creds, - threepidCreds: creds - }; - } - } - this.submitAuthDict(authDict, true); - } - - /** - * get the auth session ID - * - * @returns session id - */ - getSessionId() { - var _this$data2; - return (_this$data2 = this.data) === null || _this$data2 === void 0 ? void 0 : _this$data2.session; - } - - /** - * get the client secret used for validation sessions - * with the identity server. - * - * @returns client secret - */ - getClientSecret() { - return this.clientSecret; - } - - /** - * get the server params for a given stage - * - * @param loginType - login type for the stage - * @returns any parameters from the server for this stage - */ - getStageParams(loginType) { - var _this$data$params; - return (_this$data$params = this.data.params) === null || _this$data$params === void 0 ? void 0 : _this$data$params[loginType]; - } - getChosenFlow() { - return this.chosenFlow; - } - - /** - * submit a new auth dict and fire off the request. This will either - * make attemptAuth resolve/reject, or cause the startAuthStage callback - * to be called for a new stage. - * - * @param authData - new auth dict to send to the server. Should - * include a `type` property denoting the login type, as well as any - * other params for that stage. - * @param background - If true, this request failing will not result - * in the attemptAuth promise being rejected. This can be set to true - * for requests that just poll to see if auth has been completed elsewhere. - */ - async submitAuthDict(authData, background = false) { - if (!this.attemptAuthDeferred) { - throw new Error("submitAuthDict() called before attemptAuth()"); - } - if (!background) { - var _this$busyChangedCall3; - (_this$busyChangedCall3 = this.busyChangedCallback) === null || _this$busyChangedCall3 === void 0 ? void 0 : _this$busyChangedCall3.call(this, true); - } - - // if we're currently trying a request, wait for it to finish - // as otherwise we can get multiple 200 responses which can mean - // things like multiple logins for register requests. - // (but discard any exceptions as we only care when its done, - // not whether it worked or not) - while (this.submitPromise) { - try { - await this.submitPromise; - } catch (e) {} - } - - // use the sessionid from the last request, if one is present. - let auth; - if (this.data.session) { - auth = { - session: this.data.session - }; - Object.assign(auth, authData); - } else { - auth = authData; - } - try { - // NB. the 'background' flag is deprecated by the busyChanged - // callback and is here for backwards compat - this.submitPromise = this.doRequest(auth, background); - await this.submitPromise; - } finally { - this.submitPromise = null; - if (!background) { - var _this$busyChangedCall4; - (_this$busyChangedCall4 = this.busyChangedCallback) === null || _this$busyChangedCall4 === void 0 ? void 0 : _this$busyChangedCall4.call(this, false); - } - } - } - - /** - * Gets the sid for the email validation session - * Specific to m.login.email.identity - * - * @returns The sid of the email auth session - */ - getEmailSid() { - return this.emailSid; - } - - /** - * Sets the sid for the email validation session - * This must be set in order to successfully poll for completion - * of the email validation. - * Specific to m.login.email.identity - * - * @param sid - The sid for the email validation session - */ - setEmailSid(sid) { - this.emailSid = sid; - } - - /** - * Requests a new email token and sets the email sid for the validation session - */ - - /** - * Fire off a request, and either resolve the promise, or call - * startAuthStage. - * - * @internal - * @param auth - new auth dict, including session id - * @param background - If true, this request is a background poll, so it - * failing will not result in the attemptAuth promise being rejected. - * This can be set to true for requests that just poll to see if auth has - * been completed elsewhere. - */ - async doRequest(auth, background = false) { - try { - const result = await this.requestCallback(auth, background); - this.attemptAuthDeferred.resolve(result); - this.attemptAuthDeferred = null; - } catch (error) { - var _data$flows, _data, _this$chosenFlow; - // sometimes UI auth errors don't come with flows - const errorFlows = (_data$flows = (_data = error.data) === null || _data === void 0 ? void 0 : _data.flows) !== null && _data$flows !== void 0 ? _data$flows : null; - const haveFlows = this.data.flows || Boolean(errorFlows); - if (error.httpStatus !== 401 || !error.data || !haveFlows) { - // doesn't look like an interactive-auth failure. - if (!background) { - var _this$attemptAuthDefe; - (_this$attemptAuthDefe = this.attemptAuthDeferred) === null || _this$attemptAuthDefe === void 0 ? void 0 : _this$attemptAuthDefe.reject(error); - } else { - // We ignore all failures here (even non-UI auth related ones) - // since we don't want to suddenly fail if the internet connection - // had a blip whilst we were polling - _logger.logger.log("Background poll request failed doing UI auth: ignoring", error); - } - } - if (!error.data) { - error.data = {}; - } - // if the error didn't come with flows, completed flows or session ID, - // copy over the ones we have. Synapse sometimes sends responses without - // any UI auth data (eg. when polling for email validation, if the email - // has not yet been validated). This appears to be a Synapse bug, which - // we workaround here. - if (!error.data.flows && !error.data.completed && !error.data.session) { - error.data.flows = this.data.flows; - error.data.completed = this.data.completed; - error.data.session = this.data.session; - } - this.data = error.data; - try { - this.startNextAuthStage(); - } catch (e) { - this.attemptAuthDeferred.reject(e); - this.attemptAuthDeferred = null; - return; - } - if (!this.emailSid && (_this$chosenFlow = this.chosenFlow) !== null && _this$chosenFlow !== void 0 && _this$chosenFlow.stages.includes(AuthType.Email)) { - try { - await this.requestEmailToken(); - // NB. promise is not resolved here - at some point, doRequest - // will be called again and if the user has jumped through all - // the hoops correctly, auth will be complete and the request - // will succeed. - // Also, we should expose the fact that this request has compledted - // so clients can know that the email has actually been sent. - } catch (e) { - // we failed to request an email token, so fail the request. - // This could be due to the email already beeing registered - // (or not being registered, depending on what we're trying - // to do) or it could be a network failure. Either way, pass - // the failure up as the user can't complete auth if we can't - // send the email, for whatever reason. - this.attemptAuthDeferred.reject(e); - this.attemptAuthDeferred = null; - } - } - } - } - - /** - * Pick the next stage and call the callback - * - * @internal - * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found - */ - startNextAuthStage() { - var _this$data3, _this$data4; - const nextStage = this.chooseStage(); - if (!nextStage) { - throw new Error("No incomplete flows from the server"); - } - this.currentStage = nextStage; - if (nextStage === AuthType.Dummy) { - this.submitAuthDict({ - type: "m.login.dummy" - }); - return; - } - if ((_this$data3 = this.data) !== null && _this$data3 !== void 0 && _this$data3.errcode || (_this$data4 = this.data) !== null && _this$data4 !== void 0 && _this$data4.error) { - var _this$data5, _this$data6; - this.stateUpdatedCallback(nextStage, { - errcode: ((_this$data5 = this.data) === null || _this$data5 === void 0 ? void 0 : _this$data5.errcode) || "", - error: ((_this$data6 = this.data) === null || _this$data6 === void 0 ? void 0 : _this$data6.error) || "" - }); - return; - } - this.stateUpdatedCallback(nextStage, nextStage === EMAIL_STAGE_TYPE ? { - emailSid: this.emailSid - } : {}); - } - - /** - * Pick the next auth stage - * - * @internal - * @returns login type - * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found - */ - chooseStage() { - if (this.chosenFlow === null) { - this.chosenFlow = this.chooseFlow(); - } - _logger.logger.log("Active flow => %s", JSON.stringify(this.chosenFlow)); - const nextStage = this.firstUncompletedStage(this.chosenFlow); - _logger.logger.log("Next stage: %s", nextStage); - return nextStage; - } - - /** - * Pick one of the flows from the returned list - * If a flow using all of the inputs is found, it will - * be returned, otherwise, null will be returned. - * - * Only flows using all given inputs are chosen because it - * is likely to be surprising if the user provides a - * credential and it is not used. For example, for registration, - * this could result in the email not being used which would leave - * the account with no means to reset a password. - * - * @internal - * @returns flow - * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found - */ - chooseFlow() { - const flows = this.data.flows || []; - - // we've been given an email or we've already done an email part - const haveEmail = Boolean(this.inputs.emailAddress) || Boolean(this.emailSid); - const haveMsisdn = Boolean(this.inputs.phoneCountry) && Boolean(this.inputs.phoneNumber); - for (const flow of flows) { - let flowHasEmail = false; - let flowHasMsisdn = false; - for (const stage of flow.stages) { - if (stage === EMAIL_STAGE_TYPE) { - flowHasEmail = true; - } else if (stage == MSISDN_STAGE_TYPE) { - flowHasMsisdn = true; - } - } - if (flowHasEmail == haveEmail && flowHasMsisdn == haveMsisdn) { - return flow; - } - } - const requiredStages = []; - if (haveEmail) requiredStages.push(EMAIL_STAGE_TYPE); - if (haveMsisdn) requiredStages.push(MSISDN_STAGE_TYPE); - // Throw an error with a fairly generic description, but with more - // information such that the app can give a better one if so desired. - throw new NoAuthFlowFoundError("No appropriate authentication flow found", requiredStages, flows); - } - - /** - * Get the first uncompleted stage in the given flow - * - * @internal - * @returns login type - */ - firstUncompletedStage(flow) { - const completed = this.data.completed || []; - return flow.stages.find(stageType => !completed.includes(stageType)); - } -} -exports.InteractiveAuth = InteractiveAuth; -//# sourceMappingURL=interactive-auth.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js.map deleted file mode 100644 index 53c05b8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/interactive-auth.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"interactive-auth.js","names":["_logger","require","_utils","EMAIL_STAGE_TYPE","MSISDN_STAGE_TYPE","AuthType","exports","NoAuthFlowFoundError","Error","constructor","m","required_stages","flows","_defineProperty2","default","InteractiveAuth","opts","requestingEmailToken","logger","trace","emailAttempt","requestTokenResult","requestEmailTokenCallback","inputs","emailAddress","clientSecret","data","session","emailSid","sid","warn","matrixClient","authData","requestCallback","doRequest","busyChangedCallback","busyChanged","stateUpdatedCallback","stateUpdated","startAuthStage","requestEmailToken","sessionId","generateClientSecret","attemptAuth","_this$data","attemptAuthDeferred","defer","promise","_this$busyChangedCall","call","auth","finally","_this$busyChangedCall2","startNextAuthStage","poll","submitPromise","authDict","currentStage","creds","client_secret","doesServerRequireIdServerParam","idServerParsedUrl","URL","getIdentityServerUrl","id_server","host","type","threepid_creds","threepidCreds","submitAuthDict","getSessionId","_this$data2","getClientSecret","getStageParams","loginType","_this$data$params","params","getChosenFlow","chosenFlow","background","_this$busyChangedCall3","e","Object","assign","_this$busyChangedCall4","getEmailSid","setEmailSid","result","resolve","error","_data$flows","_data","_this$chosenFlow","errorFlows","haveFlows","Boolean","httpStatus","_this$attemptAuthDefe","reject","log","completed","stages","includes","Email","_this$data3","_this$data4","nextStage","chooseStage","Dummy","errcode","_this$data5","_this$data6","chooseFlow","JSON","stringify","firstUncompletedStage","haveEmail","haveMsisdn","phoneCountry","phoneNumber","flow","flowHasEmail","flowHasMsisdn","stage","requiredStages","push","find","stageType"],"sources":["../src/interactive-auth.ts"],"sourcesContent":["/*\nCopyright 2016 OpenMarket Ltd\nCopyright 2017 Vector Creations Ltd\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"./logger\";\nimport { MatrixClient } from \"./client\";\nimport { defer, IDeferred } from \"./utils\";\nimport { MatrixError } from \"./http-api\";\n\nconst EMAIL_STAGE_TYPE = \"m.login.email.identity\";\nconst MSISDN_STAGE_TYPE = \"m.login.msisdn\";\n\nexport interface UIAFlow {\n stages: AuthType[];\n}\n\nexport interface IInputs {\n // An email address. If supplied, a flow using email verification will be chosen.\n emailAddress?: string;\n // An ISO two letter country code. Gives the country that opts.phoneNumber should be resolved relative to.\n phoneCountry?: string;\n // A phone number. If supplied, a flow using phone number validation will be chosen.\n phoneNumber?: string;\n registrationToken?: string;\n}\n\nexport interface IStageStatus {\n emailSid?: string;\n errcode?: string;\n error?: string;\n}\n\nexport interface IAuthData {\n session?: string;\n type?: string;\n completed?: string[];\n flows?: UIAFlow[];\n available_flows?: UIAFlow[];\n stages?: string[];\n required_stages?: AuthType[];\n params?: Record>;\n data?: Record;\n errcode?: string;\n error?: string;\n user_id?: string;\n device_id?: string;\n access_token?: string;\n}\n\nexport enum AuthType {\n Password = \"m.login.password\",\n Recaptcha = \"m.login.recaptcha\",\n Terms = \"m.login.terms\",\n Email = \"m.login.email.identity\",\n Msisdn = \"m.login.msisdn\",\n Sso = \"m.login.sso\",\n SsoUnstable = \"org.matrix.login.sso\",\n Dummy = \"m.login.dummy\",\n RegistrationToken = \"m.login.registration_token\",\n // For backwards compatability with servers that have not yet updated to\n // use the stable \"m.login.registration_token\" type.\n // The authentication flow is the same in both cases.\n UnstableRegistrationToken = \"org.matrix.msc3231.login.registration_token\",\n}\n\nexport interface IAuthDict {\n // [key: string]: any;\n type?: string;\n session?: string;\n // TODO: Remove `user` once servers support proper UIA\n // See https://github.com/vector-im/element-web/issues/10312\n user?: string;\n identifier?: any;\n password?: string;\n response?: string;\n // TODO: Remove `threepid_creds` once servers support proper UIA\n // See https://github.com/vector-im/element-web/issues/10312\n // See https://github.com/matrix-org/matrix-doc/issues/2220\n // eslint-disable-next-line camelcase\n threepid_creds?: any;\n threepidCreds?: any;\n // For m.login.registration_token type\n token?: string;\n}\n\nclass NoAuthFlowFoundError extends Error {\n public name = \"NoAuthFlowFoundError\";\n\n // eslint-disable-next-line @typescript-eslint/naming-convention, camelcase\n public constructor(m: string, public readonly required_stages: string[], public readonly flows: UIAFlow[]) {\n super(m);\n }\n}\n\ninterface IOpts {\n /**\n * A matrix client to use for the auth process\n */\n matrixClient: MatrixClient;\n /**\n * Error response from the last request. If null, a request will be made with no auth before starting.\n */\n authData?: IAuthData;\n /**\n * Inputs provided by the user and used by different stages of the auto process.\n * The inputs provided will affect what flow is chosen.\n */\n inputs?: IInputs;\n /**\n * If resuming an existing interactive auth session, the sessionId of that session.\n */\n sessionId?: string;\n /**\n * If resuming an existing interactive auth session, the client secret for that session\n */\n clientSecret?: string;\n /**\n * If returning from having completed m.login.email.identity auth, the sid for the email verification session.\n */\n emailSid?: string;\n\n /**\n * Called with the new auth dict to submit the request.\n * Also passes a second deprecated arg which is a flag set to true if this request is a background request.\n * The busyChanged callback should be used instead of the background flag.\n * Should return a promise which resolves to the successful response or rejects with a MatrixError.\n */\n doRequest(auth: IAuthData | null, background: boolean): Promise;\n /**\n * Called when the status of the UI auth changes,\n * ie. when the state of an auth stage changes of when the auth flow moves to a new stage.\n * The arguments are: the login type (eg m.login.password); and an object which is either an error or an\n * informational object specific to the login type.\n * If the 'errcode' key is defined, the object is an error, and has keys:\n * errcode: string, the textual error code, eg. M_UNKNOWN\n * error: string, human readable string describing the error\n *\n * The login type specific objects are as follows:\n * m.login.email.identity:\n * * emailSid: string, the sid of the active email auth session\n */\n stateUpdated(nextStage: AuthType, status: IStageStatus): void;\n\n /**\n * A function that takes the email address (string), clientSecret (string), attempt number (int) and\n * sessionId (string) and calls the relevant requestToken function and returns the promise returned by that\n * function.\n * If the resulting promise rejects, the rejection will propagate through to the attemptAuth promise.\n */\n requestEmailToken(email: string, secret: string, attempt: number, session: string): Promise<{ sid: string }>;\n /**\n * Called whenever the interactive auth logic becomes busy submitting information provided by the user or finishes.\n * After this has been called with true the UI should indicate that a request is in progress\n * until it is called again with false.\n */\n busyChanged?(busy: boolean): void;\n startAuthStage?(nextStage: string): Promise; // LEGACY\n}\n\n/**\n * Abstracts the logic used to drive the interactive auth process.\n *\n *

Components implementing an interactive auth flow should instantiate one of\n * these, passing in the necessary callbacks to the constructor. They should\n * then call attemptAuth, which will return a promise which will resolve or\n * reject when the interactive-auth process completes.\n *\n *

Meanwhile, calls will be made to the startAuthStage and doRequest\n * callbacks, and information gathered from the user can be submitted with\n * submitAuthDict.\n *\n * @param opts - options object\n */\nexport class InteractiveAuth {\n private readonly matrixClient: MatrixClient;\n private readonly inputs: IInputs;\n private readonly clientSecret: string;\n private readonly requestCallback: IOpts[\"doRequest\"];\n private readonly busyChangedCallback?: IOpts[\"busyChanged\"];\n private readonly stateUpdatedCallback: IOpts[\"stateUpdated\"];\n private readonly requestEmailTokenCallback: IOpts[\"requestEmailToken\"];\n\n private data: IAuthData;\n private emailSid?: string;\n private requestingEmailToken = false;\n private attemptAuthDeferred: IDeferred | null = null;\n private chosenFlow: UIAFlow | null = null;\n private currentStage: string | null = null;\n\n private emailAttempt = 1;\n\n // if we are currently trying to submit an auth dict (which includes polling)\n // the promise the will resolve/reject when it completes\n private submitPromise: Promise | null = null;\n\n public constructor(opts: IOpts) {\n this.matrixClient = opts.matrixClient;\n this.data = opts.authData || {};\n this.requestCallback = opts.doRequest;\n this.busyChangedCallback = opts.busyChanged;\n // startAuthStage included for backwards compat\n this.stateUpdatedCallback = opts.stateUpdated || opts.startAuthStage;\n this.requestEmailTokenCallback = opts.requestEmailToken;\n this.inputs = opts.inputs || {};\n\n if (opts.sessionId) this.data.session = opts.sessionId;\n this.clientSecret = opts.clientSecret || this.matrixClient.generateClientSecret();\n this.emailSid = opts.emailSid;\n }\n\n /**\n * begin the authentication process.\n *\n * @returns which resolves to the response on success,\n * or rejects with the error on failure. Rejects with NoAuthFlowFoundError if\n * no suitable authentication flow can be found\n */\n public attemptAuth(): Promise {\n // This promise will be quite long-lived and will resolve when the\n // request is authenticated and completes successfully.\n this.attemptAuthDeferred = defer();\n // pluck the promise out now, as doRequest may clear before we return\n const promise = this.attemptAuthDeferred.promise;\n\n // if we have no flows, try a request to acquire the flows\n if (!this.data?.flows) {\n this.busyChangedCallback?.(true);\n // use the existing sessionId, if one is present.\n const auth = this.data.session ? { session: this.data.session } : null;\n this.doRequest(auth).finally(() => {\n this.busyChangedCallback?.(false);\n });\n } else {\n this.startNextAuthStage();\n }\n\n return promise;\n }\n\n /**\n * Poll to check if the auth session or current stage has been\n * completed out-of-band. If so, the attemptAuth promise will\n * be resolved.\n */\n public async poll(): Promise {\n if (!this.data.session) return;\n // likewise don't poll if there is no auth session in progress\n if (!this.attemptAuthDeferred) return;\n // if we currently have a request in flight, there's no point making\n // another just to check what the status is\n if (this.submitPromise) return;\n\n let authDict: IAuthDict = {};\n if (this.currentStage == EMAIL_STAGE_TYPE) {\n // The email can be validated out-of-band, but we need to provide the\n // creds so the HS can go & check it.\n if (this.emailSid) {\n const creds: Record = {\n sid: this.emailSid,\n client_secret: this.clientSecret,\n };\n if (await this.matrixClient.doesServerRequireIdServerParam()) {\n const idServerParsedUrl = new URL(this.matrixClient.getIdentityServerUrl()!);\n creds.id_server = idServerParsedUrl.host;\n }\n authDict = {\n type: EMAIL_STAGE_TYPE,\n // TODO: Remove `threepid_creds` once servers support proper UIA\n // See https://github.com/matrix-org/synapse/issues/5665\n // See https://github.com/matrix-org/matrix-doc/issues/2220\n threepid_creds: creds,\n threepidCreds: creds,\n };\n }\n }\n\n this.submitAuthDict(authDict, true);\n }\n\n /**\n * get the auth session ID\n *\n * @returns session id\n */\n public getSessionId(): string | undefined {\n return this.data?.session;\n }\n\n /**\n * get the client secret used for validation sessions\n * with the identity server.\n *\n * @returns client secret\n */\n public getClientSecret(): string {\n return this.clientSecret;\n }\n\n /**\n * get the server params for a given stage\n *\n * @param loginType - login type for the stage\n * @returns any parameters from the server for this stage\n */\n public getStageParams(loginType: string): Record | undefined {\n return this.data.params?.[loginType];\n }\n\n public getChosenFlow(): UIAFlow | null {\n return this.chosenFlow;\n }\n\n /**\n * submit a new auth dict and fire off the request. This will either\n * make attemptAuth resolve/reject, or cause the startAuthStage callback\n * to be called for a new stage.\n *\n * @param authData - new auth dict to send to the server. Should\n * include a `type` property denoting the login type, as well as any\n * other params for that stage.\n * @param background - If true, this request failing will not result\n * in the attemptAuth promise being rejected. This can be set to true\n * for requests that just poll to see if auth has been completed elsewhere.\n */\n public async submitAuthDict(authData: IAuthDict, background = false): Promise {\n if (!this.attemptAuthDeferred) {\n throw new Error(\"submitAuthDict() called before attemptAuth()\");\n }\n\n if (!background) {\n this.busyChangedCallback?.(true);\n }\n\n // if we're currently trying a request, wait for it to finish\n // as otherwise we can get multiple 200 responses which can mean\n // things like multiple logins for register requests.\n // (but discard any exceptions as we only care when its done,\n // not whether it worked or not)\n while (this.submitPromise) {\n try {\n await this.submitPromise;\n } catch (e) {}\n }\n\n // use the sessionid from the last request, if one is present.\n let auth: IAuthDict;\n if (this.data.session) {\n auth = {\n session: this.data.session,\n };\n Object.assign(auth, authData);\n } else {\n auth = authData;\n }\n\n try {\n // NB. the 'background' flag is deprecated by the busyChanged\n // callback and is here for backwards compat\n this.submitPromise = this.doRequest(auth, background);\n await this.submitPromise;\n } finally {\n this.submitPromise = null;\n if (!background) {\n this.busyChangedCallback?.(false);\n }\n }\n }\n\n /**\n * Gets the sid for the email validation session\n * Specific to m.login.email.identity\n *\n * @returns The sid of the email auth session\n */\n public getEmailSid(): string | undefined {\n return this.emailSid;\n }\n\n /**\n * Sets the sid for the email validation session\n * This must be set in order to successfully poll for completion\n * of the email validation.\n * Specific to m.login.email.identity\n *\n * @param sid - The sid for the email validation session\n */\n public setEmailSid(sid: string): void {\n this.emailSid = sid;\n }\n\n /**\n * Requests a new email token and sets the email sid for the validation session\n */\n public requestEmailToken = async (): Promise => {\n if (!this.requestingEmailToken) {\n logger.trace(\"Requesting email token. Attempt: \" + this.emailAttempt);\n // If we've picked a flow with email auth, we send the email\n // now because we want the request to fail as soon as possible\n // if the email address is not valid (ie. already taken or not\n // registered, depending on what the operation is).\n this.requestingEmailToken = true;\n try {\n const requestTokenResult = await this.requestEmailTokenCallback(\n this.inputs.emailAddress!,\n this.clientSecret,\n this.emailAttempt++,\n this.data.session!,\n );\n this.emailSid = requestTokenResult.sid;\n logger.trace(\"Email token request succeeded\");\n } finally {\n this.requestingEmailToken = false;\n }\n } else {\n logger.warn(\"Could not request email token: Already requesting\");\n }\n };\n\n /**\n * Fire off a request, and either resolve the promise, or call\n * startAuthStage.\n *\n * @internal\n * @param auth - new auth dict, including session id\n * @param background - If true, this request is a background poll, so it\n * failing will not result in the attemptAuth promise being rejected.\n * This can be set to true for requests that just poll to see if auth has\n * been completed elsewhere.\n */\n private async doRequest(auth: IAuthData | null, background = false): Promise {\n try {\n const result = await this.requestCallback(auth, background);\n this.attemptAuthDeferred!.resolve(result);\n this.attemptAuthDeferred = null;\n } catch (error) {\n // sometimes UI auth errors don't come with flows\n const errorFlows = (error).data?.flows ?? null;\n const haveFlows = this.data.flows || Boolean(errorFlows);\n if ((error).httpStatus !== 401 || !(error).data || !haveFlows) {\n // doesn't look like an interactive-auth failure.\n if (!background) {\n this.attemptAuthDeferred?.reject(error);\n } else {\n // We ignore all failures here (even non-UI auth related ones)\n // since we don't want to suddenly fail if the internet connection\n // had a blip whilst we were polling\n logger.log(\"Background poll request failed doing UI auth: ignoring\", error);\n }\n }\n if (!(error).data) {\n (error).data = {};\n }\n // if the error didn't come with flows, completed flows or session ID,\n // copy over the ones we have. Synapse sometimes sends responses without\n // any UI auth data (eg. when polling for email validation, if the email\n // has not yet been validated). This appears to be a Synapse bug, which\n // we workaround here.\n if (\n !(error).data.flows &&\n !(error).data.completed &&\n !(error).data.session\n ) {\n (error).data.flows = this.data.flows;\n (error).data.completed = this.data.completed;\n (error).data.session = this.data.session;\n }\n this.data = (error).data;\n try {\n this.startNextAuthStage();\n } catch (e) {\n this.attemptAuthDeferred!.reject(e);\n this.attemptAuthDeferred = null;\n return;\n }\n\n if (!this.emailSid && this.chosenFlow?.stages.includes(AuthType.Email)) {\n try {\n await this.requestEmailToken();\n // NB. promise is not resolved here - at some point, doRequest\n // will be called again and if the user has jumped through all\n // the hoops correctly, auth will be complete and the request\n // will succeed.\n // Also, we should expose the fact that this request has compledted\n // so clients can know that the email has actually been sent.\n } catch (e) {\n // we failed to request an email token, so fail the request.\n // This could be due to the email already beeing registered\n // (or not being registered, depending on what we're trying\n // to do) or it could be a network failure. Either way, pass\n // the failure up as the user can't complete auth if we can't\n // send the email, for whatever reason.\n this.attemptAuthDeferred!.reject(e);\n this.attemptAuthDeferred = null;\n }\n }\n }\n }\n\n /**\n * Pick the next stage and call the callback\n *\n * @internal\n * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found\n */\n private startNextAuthStage(): void {\n const nextStage = this.chooseStage();\n if (!nextStage) {\n throw new Error(\"No incomplete flows from the server\");\n }\n this.currentStage = nextStage;\n\n if (nextStage === AuthType.Dummy) {\n this.submitAuthDict({\n type: \"m.login.dummy\",\n });\n return;\n }\n\n if (this.data?.errcode || this.data?.error) {\n this.stateUpdatedCallback(nextStage, {\n errcode: this.data?.errcode || \"\",\n error: this.data?.error || \"\",\n });\n return;\n }\n\n this.stateUpdatedCallback(nextStage, nextStage === EMAIL_STAGE_TYPE ? { emailSid: this.emailSid } : {});\n }\n\n /**\n * Pick the next auth stage\n *\n * @internal\n * @returns login type\n * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found\n */\n private chooseStage(): AuthType | undefined {\n if (this.chosenFlow === null) {\n this.chosenFlow = this.chooseFlow();\n }\n logger.log(\"Active flow => %s\", JSON.stringify(this.chosenFlow));\n const nextStage = this.firstUncompletedStage(this.chosenFlow);\n logger.log(\"Next stage: %s\", nextStage);\n return nextStage;\n }\n\n /**\n * Pick one of the flows from the returned list\n * If a flow using all of the inputs is found, it will\n * be returned, otherwise, null will be returned.\n *\n * Only flows using all given inputs are chosen because it\n * is likely to be surprising if the user provides a\n * credential and it is not used. For example, for registration,\n * this could result in the email not being used which would leave\n * the account with no means to reset a password.\n *\n * @internal\n * @returns flow\n * @throws {@link NoAuthFlowFoundError} If no suitable authentication flow can be found\n */\n private chooseFlow(): UIAFlow {\n const flows = this.data.flows || [];\n\n // we've been given an email or we've already done an email part\n const haveEmail = Boolean(this.inputs.emailAddress) || Boolean(this.emailSid);\n const haveMsisdn = Boolean(this.inputs.phoneCountry) && Boolean(this.inputs.phoneNumber);\n\n for (const flow of flows) {\n let flowHasEmail = false;\n let flowHasMsisdn = false;\n for (const stage of flow.stages) {\n if (stage === EMAIL_STAGE_TYPE) {\n flowHasEmail = true;\n } else if (stage == MSISDN_STAGE_TYPE) {\n flowHasMsisdn = true;\n }\n }\n\n if (flowHasEmail == haveEmail && flowHasMsisdn == haveMsisdn) {\n return flow;\n }\n }\n\n const requiredStages: string[] = [];\n if (haveEmail) requiredStages.push(EMAIL_STAGE_TYPE);\n if (haveMsisdn) requiredStages.push(MSISDN_STAGE_TYPE);\n // Throw an error with a fairly generic description, but with more\n // information such that the app can give a better one if so desired.\n throw new NoAuthFlowFoundError(\"No appropriate authentication flow found\", requiredStages, flows);\n }\n\n /**\n * Get the first uncompleted stage in the given flow\n *\n * @internal\n * @returns login type\n */\n private firstUncompletedStage(flow: UIAFlow): AuthType | undefined {\n const completed = this.data.completed || [];\n return flow.stages.find((stageType) => !completed.includes(stageType));\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts deleted file mode 100644 index 545ca3b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { Logger } from "loglevel"; -/** - * Drop-in replacement for `console` using {@link https://www.npmjs.com/package/loglevel|loglevel}. - * Can be tailored down to specific use cases if needed. - */ -export declare const logger: PrefixedLogger; -export interface PrefixedLogger extends Logger { - withPrefix: (prefix: string) => PrefixedLogger; - prefix: string; -} -//# sourceMappingURL=logger.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts.map deleted file mode 100644 index af79f53..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAiBA,OAAY,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAkCvC;;;GAGG;AACH,eAAO,MAAM,MAAM,gBAAqD,CAAC;AAGzE,MAAM,WAAW,cAAe,SAAQ,MAAM;IAC1C,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,cAAc,CAAC;IAC/C,MAAM,EAAE,MAAM,CAAC;CAClB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js deleted file mode 100644 index d8cf68e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js +++ /dev/null @@ -1,81 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.logger = void 0; -var _loglevel = _interopRequireDefault(require("loglevel")); -/* -Copyright 2018 André Jaenisch -Copyright 2019, 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// This is to demonstrate, that you can use any namespace you want. -// Namespaces allow you to turn on/off the logging for specific parts of the -// application. -// An idea would be to control this via an environment variable (on Node.js). -// See https://www.npmjs.com/package/debug to see how this could be implemented -// Part of #332 is introducing a logging library in the first place. -const DEFAULT_NAMESPACE = "matrix"; - -// because rageshakes in react-sdk hijack the console log, also at module load time, -// initializing the logger here races with the initialization of rageshakes. -// to avoid the issue, we override the methodFactory of loglevel that binds to the -// console methods at initialization time by a factory that looks up the console methods -// when logging so we always get the current value of console methods. -_loglevel.default.methodFactory = function (methodName, logLevel, loggerName) { - return function (...args) { - /* eslint-disable @typescript-eslint/no-invalid-this */ - if (this.prefix) { - args.unshift(this.prefix); - } - /* eslint-enable @typescript-eslint/no-invalid-this */ - const supportedByConsole = methodName === "error" || methodName === "warn" || methodName === "trace" || methodName === "info"; - /* eslint-disable no-console */ - if (supportedByConsole) { - return console[methodName](...args); - } else { - return console.log(...args); - } - /* eslint-enable no-console */ - }; -}; - -/** - * Drop-in replacement for `console` using {@link https://www.npmjs.com/package/loglevel|loglevel}. - * Can be tailored down to specific use cases if needed. - */ -const logger = _loglevel.default.getLogger(DEFAULT_NAMESPACE); -exports.logger = logger; -logger.setLevel(_loglevel.default.levels.DEBUG, false); -function extendLogger(logger) { - logger.withPrefix = function (prefix) { - const existingPrefix = this.prefix || ""; - return getPrefixedLogger(existingPrefix + prefix); - }; -} -extendLogger(logger); -function getPrefixedLogger(prefix) { - const prefixLogger = _loglevel.default.getLogger(`${DEFAULT_NAMESPACE}-${prefix}`); - if (prefixLogger.prefix !== prefix) { - // Only do this setup work the first time through, as loggers are saved by name. - extendLogger(prefixLogger); - prefixLogger.prefix = prefix; - prefixLogger.setLevel(_loglevel.default.levels.DEBUG, false); - } - return prefixLogger; -} -//# sourceMappingURL=logger.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js.map deleted file mode 100644 index 208d5bc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/logger.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"logger.js","names":["_loglevel","_interopRequireDefault","require","DEFAULT_NAMESPACE","log","methodFactory","methodName","logLevel","loggerName","args","prefix","unshift","supportedByConsole","console","logger","getLogger","exports","setLevel","levels","DEBUG","extendLogger","withPrefix","existingPrefix","getPrefixedLogger","prefixLogger"],"sources":["../src/logger.ts"],"sourcesContent":["/*\nCopyright 2018 André Jaenisch\nCopyright 2019, 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport log, { Logger } from \"loglevel\";\n\n// This is to demonstrate, that you can use any namespace you want.\n// Namespaces allow you to turn on/off the logging for specific parts of the\n// application.\n// An idea would be to control this via an environment variable (on Node.js).\n// See https://www.npmjs.com/package/debug to see how this could be implemented\n// Part of #332 is introducing a logging library in the first place.\nconst DEFAULT_NAMESPACE = \"matrix\";\n\n// because rageshakes in react-sdk hijack the console log, also at module load time,\n// initializing the logger here races with the initialization of rageshakes.\n// to avoid the issue, we override the methodFactory of loglevel that binds to the\n// console methods at initialization time by a factory that looks up the console methods\n// when logging so we always get the current value of console methods.\nlog.methodFactory = function (methodName, logLevel, loggerName) {\n return function (this: PrefixedLogger, ...args): void {\n /* eslint-disable @typescript-eslint/no-invalid-this */\n if (this.prefix) {\n args.unshift(this.prefix);\n }\n /* eslint-enable @typescript-eslint/no-invalid-this */\n const supportedByConsole =\n methodName === \"error\" || methodName === \"warn\" || methodName === \"trace\" || methodName === \"info\";\n /* eslint-disable no-console */\n if (supportedByConsole) {\n return console[methodName](...args);\n } else {\n return console.log(...args);\n }\n /* eslint-enable no-console */\n };\n};\n\n/**\n * Drop-in replacement for `console` using {@link https://www.npmjs.com/package/loglevel|loglevel}.\n * Can be tailored down to specific use cases if needed.\n */\nexport const logger = log.getLogger(DEFAULT_NAMESPACE) as PrefixedLogger;\nlogger.setLevel(log.levels.DEBUG, false);\n\nexport interface PrefixedLogger extends Logger {\n withPrefix: (prefix: string) => PrefixedLogger;\n prefix: string;\n}\n\nfunction extendLogger(logger: Logger): void {\n (logger).withPrefix = function (prefix: string): PrefixedLogger {\n const existingPrefix = this.prefix || \"\";\n return getPrefixedLogger(existingPrefix + prefix);\n };\n}\n\nextendLogger(logger);\n\nfunction getPrefixedLogger(prefix: string): PrefixedLogger {\n const prefixLogger = log.getLogger(`${DEFAULT_NAMESPACE}-${prefix}`) as PrefixedLogger;\n if (prefixLogger.prefix !== prefix) {\n // Only do this setup work the first time through, as loggers are saved by name.\n extendLogger(prefixLogger);\n prefixLogger.prefix = prefix;\n prefixLogger.setLevel(log.levels.DEBUG, false);\n }\n return prefixLogger;\n}\n"],"mappings":";;;;;;;AAiBA,IAAAA,SAAA,GAAAC,sBAAA,CAAAC,OAAA;AAjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMC,iBAAiB,GAAG,QAAQ;;AAElC;AACA;AACA;AACA;AACA;AACAC,iBAAG,CAACC,aAAa,GAAG,UAAUC,UAAU,EAAEC,QAAQ,EAAEC,UAAU,EAAE;EAC5D,OAAO,UAAgC,GAAGC,IAAI,EAAQ;IAClD;IACA,IAAI,IAAI,CAACC,MAAM,EAAE;MACbD,IAAI,CAACE,OAAO,CAAC,IAAI,CAACD,MAAM,CAAC;IAC7B;IACA;IACA,MAAME,kBAAkB,GACpBN,UAAU,KAAK,OAAO,IAAIA,UAAU,KAAK,MAAM,IAAIA,UAAU,KAAK,OAAO,IAAIA,UAAU,KAAK,MAAM;IACtG;IACA,IAAIM,kBAAkB,EAAE;MACpB,OAAOC,OAAO,CAACP,UAAU,CAAC,CAAC,GAAGG,IAAI,CAAC;IACvC,CAAC,MAAM;MACH,OAAOI,OAAO,CAACT,GAAG,CAAC,GAAGK,IAAI,CAAC;IAC/B;IACA;EACJ,CAAC;AACL,CAAC;;AAED;AACA;AACA;AACA;AACO,MAAMK,MAAM,GAAGV,iBAAG,CAACW,SAAS,CAACZ,iBAAiB,CAAmB;AAACa,OAAA,CAAAF,MAAA,GAAAA,MAAA;AACzEA,MAAM,CAACG,QAAQ,CAACb,iBAAG,CAACc,MAAM,CAACC,KAAK,EAAE,KAAK,CAAC;AAOxC,SAASC,YAAYA,CAACN,MAAc,EAAQ;EACvBA,MAAM,CAAEO,UAAU,GAAG,UAAUX,MAAc,EAAkB;IAC5E,MAAMY,cAAc,GAAG,IAAI,CAACZ,MAAM,IAAI,EAAE;IACxC,OAAOa,iBAAiB,CAACD,cAAc,GAAGZ,MAAM,CAAC;EACrD,CAAC;AACL;AAEAU,YAAY,CAACN,MAAM,CAAC;AAEpB,SAASS,iBAAiBA,CAACb,MAAc,EAAkB;EACvD,MAAMc,YAAY,GAAGpB,iBAAG,CAACW,SAAS,CAAE,GAAEZ,iBAAkB,IAAGO,MAAO,EAAC,CAAmB;EACtF,IAAIc,YAAY,CAACd,MAAM,KAAKA,MAAM,EAAE;IAChC;IACAU,YAAY,CAACI,YAAY,CAAC;IAC1BA,YAAY,CAACd,MAAM,GAAGA,MAAM;IAC5Bc,YAAY,CAACP,QAAQ,CAACb,iBAAG,CAACc,MAAM,CAACC,KAAK,EAAE,KAAK,CAAC;EAClD;EACA,OAAOK,YAAY;AACvB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts deleted file mode 100644 index 93015ee..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts +++ /dev/null @@ -1,62 +0,0 @@ -import { WidgetApi } from "matrix-widget-api"; -import { MatrixClient, ICreateClientOpts } from "./client"; -import { ICapabilities } from "./embedded"; -import { CryptoStore } from "./crypto/store/base"; -export * from "./client"; -export * from "./embedded"; -export * from "./http-api"; -export * from "./autodiscovery"; -export * from "./sync-accumulator"; -export * from "./errors"; -export * from "./models/beacon"; -export * from "./models/event"; -export * from "./models/room"; -export * from "./models/event-timeline"; -export * from "./models/event-timeline-set"; -export * from "./models/poll"; -export * from "./models/room-member"; -export * from "./models/room-state"; -export * from "./models/user"; -export * from "./scheduler"; -export * from "./filter"; -export * from "./timeline-window"; -export * from "./interactive-auth"; -export * from "./service-types"; -export * from "./store/memory"; -export * from "./store/indexeddb"; -export * from "./crypto/store/memory-crypto-store"; -export * from "./crypto/store/indexeddb-crypto-store"; -export * from "./content-repo"; -export * from "./@types/event"; -export * from "./@types/PushRules"; -export * from "./@types/partials"; -export * from "./@types/requests"; -export * from "./@types/search"; -export * from "./models/room-summary"; -export * as ContentHelpers from "./content-helpers"; -export * as SecretStorage from "./secret-storage"; -export type { ICryptoCallbacks } from "./crypto"; -export { createNewMatrixCall } from "./webrtc/call"; -export type { MatrixCall } from "./webrtc/call"; -export { GroupCallEvent, GroupCallIntent, GroupCallState, GroupCallType } from "./webrtc/groupCall"; -export type { GroupCall } from "./webrtc/groupCall"; -export type { CryptoApi } from "./crypto-api"; -/** - * Configure a different factory to be used for creating crypto stores - * - * @param fac - a function which will return a new {@link CryptoStore} - */ -export declare function setCryptoStoreFactory(fac: () => CryptoStore): void; -/** - * Construct a Matrix Client. Similar to {@link MatrixClient} - * except that the 'request', 'store' and 'scheduler' dependencies are satisfied. - * @param opts - The configuration options for this client. These configuration - * options will be passed directly to {@link MatrixClient}. - * - * @returns A new matrix client. - * @see {@link MatrixClient} for the full list of options for - * `opts`. - */ -export declare function createClient(opts: ICreateClientOpts): MatrixClient; -export declare function createRoomWidgetClient(widgetApi: WidgetApi, capabilities: ICapabilities, roomId: string, opts: ICreateClientOpts): MatrixClient; -//# sourceMappingURL=matrix.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts.map deleted file mode 100644 index cc6f481..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"matrix.d.ts","sourceRoot":"","sources":["../src/matrix.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAK9C,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC3D,OAAO,EAAoB,aAAa,EAAE,MAAM,YAAY,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAElD,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,eAAe,CAAC;AAC9B,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,oCAAoC,CAAC;AACnD,cAAc,uCAAuC,CAAC;AACtD,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,OAAO,KAAK,cAAc,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,aAAa,MAAM,kBAAkB,CAAC;AAClD,YAAY,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpD,YAAY,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACpG,YAAY,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACpD,YAAY,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAI9C;;;;GAIG;AACH,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,MAAM,WAAW,GAAG,IAAI,CAElE;AAcD;;;;;;;;;GASG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,iBAAiB,GAAG,YAAY,CAElE;AAED,wBAAgB,sBAAsB,CAClC,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,aAAa,EAC3B,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,iBAAiB,GACxB,YAAY,CAEd"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js deleted file mode 100644 index 0fcf0f4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js +++ /dev/null @@ -1,487 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -var _exportNames = { - setCryptoStoreFactory: true, - createClient: true, - createRoomWidgetClient: true, - ContentHelpers: true, - SecretStorage: true, - createNewMatrixCall: true, - GroupCallEvent: true, - GroupCallIntent: true, - GroupCallState: true, - GroupCallType: true -}; -exports.ContentHelpers = void 0; -Object.defineProperty(exports, "GroupCallEvent", { - enumerable: true, - get: function () { - return _groupCall.GroupCallEvent; - } -}); -Object.defineProperty(exports, "GroupCallIntent", { - enumerable: true, - get: function () { - return _groupCall.GroupCallIntent; - } -}); -Object.defineProperty(exports, "GroupCallState", { - enumerable: true, - get: function () { - return _groupCall.GroupCallState; - } -}); -Object.defineProperty(exports, "GroupCallType", { - enumerable: true, - get: function () { - return _groupCall.GroupCallType; - } -}); -exports.SecretStorage = void 0; -exports.createClient = createClient; -Object.defineProperty(exports, "createNewMatrixCall", { - enumerable: true, - get: function () { - return _call.createNewMatrixCall; - } -}); -exports.createRoomWidgetClient = createRoomWidgetClient; -exports.setCryptoStoreFactory = setCryptoStoreFactory; -var _memoryCryptoStore = require("./crypto/store/memory-crypto-store"); -Object.keys(_memoryCryptoStore).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _memoryCryptoStore[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _memoryCryptoStore[key]; - } - }); -}); -var _memory = require("./store/memory"); -Object.keys(_memory).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _memory[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _memory[key]; - } - }); -}); -var _scheduler = require("./scheduler"); -Object.keys(_scheduler).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _scheduler[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _scheduler[key]; - } - }); -}); -var _client = require("./client"); -Object.keys(_client).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _client[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _client[key]; - } - }); -}); -var _embedded = require("./embedded"); -Object.keys(_embedded).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _embedded[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _embedded[key]; - } - }); -}); -var _httpApi = require("./http-api"); -Object.keys(_httpApi).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _httpApi[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _httpApi[key]; - } - }); -}); -var _autodiscovery = require("./autodiscovery"); -Object.keys(_autodiscovery).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _autodiscovery[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _autodiscovery[key]; - } - }); -}); -var _syncAccumulator = require("./sync-accumulator"); -Object.keys(_syncAccumulator).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _syncAccumulator[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _syncAccumulator[key]; - } - }); -}); -var _errors = require("./errors"); -Object.keys(_errors).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _errors[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _errors[key]; - } - }); -}); -var _beacon = require("./models/beacon"); -Object.keys(_beacon).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _beacon[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _beacon[key]; - } - }); -}); -var _event = require("./models/event"); -Object.keys(_event).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _event[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _event[key]; - } - }); -}); -var _room = require("./models/room"); -Object.keys(_room).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _room[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _room[key]; - } - }); -}); -var _eventTimeline = require("./models/event-timeline"); -Object.keys(_eventTimeline).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _eventTimeline[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _eventTimeline[key]; - } - }); -}); -var _eventTimelineSet = require("./models/event-timeline-set"); -Object.keys(_eventTimelineSet).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _eventTimelineSet[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _eventTimelineSet[key]; - } - }); -}); -var _poll = require("./models/poll"); -Object.keys(_poll).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _poll[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _poll[key]; - } - }); -}); -var _roomMember = require("./models/room-member"); -Object.keys(_roomMember).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _roomMember[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _roomMember[key]; - } - }); -}); -var _roomState = require("./models/room-state"); -Object.keys(_roomState).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _roomState[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _roomState[key]; - } - }); -}); -var _user = require("./models/user"); -Object.keys(_user).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _user[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _user[key]; - } - }); -}); -var _filter = require("./filter"); -Object.keys(_filter).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _filter[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _filter[key]; - } - }); -}); -var _timelineWindow = require("./timeline-window"); -Object.keys(_timelineWindow).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _timelineWindow[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _timelineWindow[key]; - } - }); -}); -var _interactiveAuth = require("./interactive-auth"); -Object.keys(_interactiveAuth).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _interactiveAuth[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _interactiveAuth[key]; - } - }); -}); -var _serviceTypes = require("./service-types"); -Object.keys(_serviceTypes).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _serviceTypes[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _serviceTypes[key]; - } - }); -}); -var _indexeddb = require("./store/indexeddb"); -Object.keys(_indexeddb).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _indexeddb[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _indexeddb[key]; - } - }); -}); -var _indexeddbCryptoStore = require("./crypto/store/indexeddb-crypto-store"); -Object.keys(_indexeddbCryptoStore).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _indexeddbCryptoStore[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _indexeddbCryptoStore[key]; - } - }); -}); -var _contentRepo = require("./content-repo"); -Object.keys(_contentRepo).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _contentRepo[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _contentRepo[key]; - } - }); -}); -var _event2 = require("./@types/event"); -Object.keys(_event2).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _event2[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _event2[key]; - } - }); -}); -var _PushRules = require("./@types/PushRules"); -Object.keys(_PushRules).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _PushRules[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _PushRules[key]; - } - }); -}); -var _partials = require("./@types/partials"); -Object.keys(_partials).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _partials[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _partials[key]; - } - }); -}); -var _requests = require("./@types/requests"); -Object.keys(_requests).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _requests[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _requests[key]; - } - }); -}); -var _search = require("./@types/search"); -Object.keys(_search).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _search[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _search[key]; - } - }); -}); -var _roomSummary = require("./models/room-summary"); -Object.keys(_roomSummary).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; - if (key in exports && exports[key] === _roomSummary[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _roomSummary[key]; - } - }); -}); -var _ContentHelpers = _interopRequireWildcard(require("./content-helpers")); -exports.ContentHelpers = _ContentHelpers; -var _SecretStorage = _interopRequireWildcard(require("./secret-storage")); -exports.SecretStorage = _SecretStorage; -var _call = require("./webrtc/call"); -var _groupCall = require("./webrtc/groupCall"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2015-2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// used to be located here - -let cryptoStoreFactory = () => new _memoryCryptoStore.MemoryCryptoStore(); - -/** - * Configure a different factory to be used for creating crypto stores - * - * @param fac - a function which will return a new {@link CryptoStore} - */ -function setCryptoStoreFactory(fac) { - cryptoStoreFactory = fac; -} -function amendClientOpts(opts) { - var _opts$store, _opts$scheduler, _opts$cryptoStore; - opts.store = (_opts$store = opts.store) !== null && _opts$store !== void 0 ? _opts$store : new _memory.MemoryStore({ - localStorage: global.localStorage - }); - opts.scheduler = (_opts$scheduler = opts.scheduler) !== null && _opts$scheduler !== void 0 ? _opts$scheduler : new _scheduler.MatrixScheduler(); - opts.cryptoStore = (_opts$cryptoStore = opts.cryptoStore) !== null && _opts$cryptoStore !== void 0 ? _opts$cryptoStore : cryptoStoreFactory(); - return opts; -} - -/** - * Construct a Matrix Client. Similar to {@link MatrixClient} - * except that the 'request', 'store' and 'scheduler' dependencies are satisfied. - * @param opts - The configuration options for this client. These configuration - * options will be passed directly to {@link MatrixClient}. - * - * @returns A new matrix client. - * @see {@link MatrixClient} for the full list of options for - * `opts`. - */ -function createClient(opts) { - return new _client.MatrixClient(amendClientOpts(opts)); -} -function createRoomWidgetClient(widgetApi, capabilities, roomId, opts) { - return new _embedded.RoomWidgetClient(widgetApi, capabilities, roomId, amendClientOpts(opts)); -} -//# sourceMappingURL=matrix.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js.map deleted file mode 100644 index 3469bcf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/matrix.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"matrix.js","names":["_memoryCryptoStore","require","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","_memory","_scheduler","_client","_embedded","_httpApi","_autodiscovery","_syncAccumulator","_errors","_beacon","_event","_room","_eventTimeline","_eventTimelineSet","_poll","_roomMember","_roomState","_user","_filter","_timelineWindow","_interactiveAuth","_serviceTypes","_indexeddb","_indexeddbCryptoStore","_contentRepo","_event2","_PushRules","_partials","_requests","_search","_roomSummary","_ContentHelpers","_interopRequireWildcard","ContentHelpers","_SecretStorage","SecretStorage","_call","_groupCall","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","newObj","hasPropertyDescriptor","getOwnPropertyDescriptor","desc","set","cryptoStoreFactory","MemoryCryptoStore","setCryptoStoreFactory","fac","amendClientOpts","opts","_opts$store","_opts$scheduler","_opts$cryptoStore","store","MemoryStore","localStorage","global","scheduler","MatrixScheduler","cryptoStore","createClient","MatrixClient","createRoomWidgetClient","widgetApi","capabilities","roomId","RoomWidgetClient"],"sources":["../src/matrix.ts"],"sourcesContent":["/*\nCopyright 2015-2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { WidgetApi } from \"matrix-widget-api\";\n\nimport { MemoryCryptoStore } from \"./crypto/store/memory-crypto-store\";\nimport { MemoryStore } from \"./store/memory\";\nimport { MatrixScheduler } from \"./scheduler\";\nimport { MatrixClient, ICreateClientOpts } from \"./client\";\nimport { RoomWidgetClient, ICapabilities } from \"./embedded\";\nimport { CryptoStore } from \"./crypto/store/base\";\n\nexport * from \"./client\";\nexport * from \"./embedded\";\nexport * from \"./http-api\";\nexport * from \"./autodiscovery\";\nexport * from \"./sync-accumulator\";\nexport * from \"./errors\";\nexport * from \"./models/beacon\";\nexport * from \"./models/event\";\nexport * from \"./models/room\";\nexport * from \"./models/event-timeline\";\nexport * from \"./models/event-timeline-set\";\nexport * from \"./models/poll\";\nexport * from \"./models/room-member\";\nexport * from \"./models/room-state\";\nexport * from \"./models/user\";\nexport * from \"./scheduler\";\nexport * from \"./filter\";\nexport * from \"./timeline-window\";\nexport * from \"./interactive-auth\";\nexport * from \"./service-types\";\nexport * from \"./store/memory\";\nexport * from \"./store/indexeddb\";\nexport * from \"./crypto/store/memory-crypto-store\";\nexport * from \"./crypto/store/indexeddb-crypto-store\";\nexport * from \"./content-repo\";\nexport * from \"./@types/event\";\nexport * from \"./@types/PushRules\";\nexport * from \"./@types/partials\";\nexport * from \"./@types/requests\";\nexport * from \"./@types/search\";\nexport * from \"./models/room-summary\";\nexport * as ContentHelpers from \"./content-helpers\";\nexport * as SecretStorage from \"./secret-storage\";\nexport type { ICryptoCallbacks } from \"./crypto\"; // used to be located here\nexport { createNewMatrixCall } from \"./webrtc/call\";\nexport type { MatrixCall } from \"./webrtc/call\";\nexport { GroupCallEvent, GroupCallIntent, GroupCallState, GroupCallType } from \"./webrtc/groupCall\";\nexport type { GroupCall } from \"./webrtc/groupCall\";\nexport type { CryptoApi } from \"./crypto-api\";\n\nlet cryptoStoreFactory = (): CryptoStore => new MemoryCryptoStore();\n\n/**\n * Configure a different factory to be used for creating crypto stores\n *\n * @param fac - a function which will return a new {@link CryptoStore}\n */\nexport function setCryptoStoreFactory(fac: () => CryptoStore): void {\n cryptoStoreFactory = fac;\n}\n\nfunction amendClientOpts(opts: ICreateClientOpts): ICreateClientOpts {\n opts.store =\n opts.store ??\n new MemoryStore({\n localStorage: global.localStorage,\n });\n opts.scheduler = opts.scheduler ?? new MatrixScheduler();\n opts.cryptoStore = opts.cryptoStore ?? cryptoStoreFactory();\n\n return opts;\n}\n\n/**\n * Construct a Matrix Client. Similar to {@link MatrixClient}\n * except that the 'request', 'store' and 'scheduler' dependencies are satisfied.\n * @param opts - The configuration options for this client. These configuration\n * options will be passed directly to {@link MatrixClient}.\n *\n * @returns A new matrix client.\n * @see {@link MatrixClient} for the full list of options for\n * `opts`.\n */\nexport function createClient(opts: ICreateClientOpts): MatrixClient {\n return new MatrixClient(amendClientOpts(opts));\n}\n\nexport function createRoomWidgetClient(\n widgetApi: WidgetApi,\n capabilities: ICapabilities,\n roomId: string,\n opts: ICreateClientOpts,\n): MatrixClient {\n return new RoomWidgetClient(widgetApi, capabilities, roomId, amendClientOpts(opts));\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts deleted file mode 100644 index 11722ab..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts +++ /dev/null @@ -1,86 +0,0 @@ -import { MatrixClient } from "../client"; -import { IEncryptedFile } from "../@types/event"; -import { IContent, MatrixEvent } from "./event"; -import { MSC3089TreeSpace } from "./MSC3089TreeSpace"; -import { FileType } from "../http-api"; -import type { ISendEventResponse } from "../@types/requests"; -/** - * Represents a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) branch - a reference - * to a file (leaf) in the tree. Note that this is UNSTABLE and subject to breaking changes - * without notice. - */ -export declare class MSC3089Branch { - private client; - readonly indexEvent: MatrixEvent; - readonly directory: MSC3089TreeSpace; - constructor(client: MatrixClient, indexEvent: MatrixEvent, directory: MSC3089TreeSpace); - /** - * The file ID. - */ - get id(): string; - /** - * Whether this branch is active/valid. - */ - get isActive(): boolean; - /** - * Version for the file, one-indexed. - */ - get version(): number; - private get roomId(); - /** - * Deletes the file from the tree, including all prior edits/versions. - * @returns Promise which resolves when complete. - */ - delete(): Promise; - /** - * Gets the name for this file. - * @returns The name, or "Unnamed File" if unknown. - */ - getName(): string; - /** - * Sets the name for this file. - * @param name - The new name for this file. - * @returns Promise which resolves when complete. - */ - setName(name: string): Promise; - /** - * Gets whether or not a file is locked. - * @returns True if locked, false otherwise. - */ - isLocked(): boolean; - /** - * Sets a file as locked or unlocked. - * @param locked - True to lock the file, false otherwise. - * @returns Promise which resolves when complete. - */ - setLocked(locked: boolean): Promise; - /** - * Gets information about the file needed to download it. - * @returns Information about the file. - */ - getFileInfo(): Promise<{ - info: IEncryptedFile; - httpUrl: string; - }>; - /** - * Gets the event the file points to. - * @returns Promise which resolves to the file's event. - */ - getFileEvent(): Promise; - /** - * Creates a new version of this file with contents in a type that is compatible with MatrixClient.uploadContent(). - * @param name - The name of the file. - * @param encryptedContents - The encrypted contents. - * @param info - The encrypted file information. - * @param additionalContent - Optional event content fields to include in the message. - * @returns Promise which resolves to the file event's sent response. - */ - createNewVersion(name: string, encryptedContents: FileType, info: Partial, additionalContent?: IContent): Promise; - /** - * Gets the file's version history, starting at this file. - * @returns Promise which resolves to the file's version history, with the - * first element being the current version and the last element being the first version. - */ - getVersionHistory(): Promise; -} -//# sourceMappingURL=MSC3089Branch.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts.map deleted file mode 100644 index bebdb11..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3089Branch.d.ts","sourceRoot":"","sources":["../../src/models/MSC3089Branch.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,cAAc,EAAyC,MAAM,iBAAiB,CAAC;AACxF,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAE7D;;;;GAIG;AACH,qBAAa,aAAa;IAElB,OAAO,CAAC,MAAM;aACE,UAAU,EAAE,WAAW;aACvB,SAAS,EAAE,gBAAgB;gBAFnC,MAAM,EAAE,YAAY,EACZ,UAAU,EAAE,WAAW,EACvB,SAAS,EAAE,gBAAgB;IAK/C;;OAEG;IACH,IAAW,EAAE,IAAI,MAAM,CAMtB;IAED;;OAEG;IACH,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED;;OAEG;IACH,IAAW,OAAO,IAAI,MAAM,CAE3B;IAED,OAAO,KAAK,MAAM,GAEjB;IAED;;;OAGG;IACU,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAQpC;;;OAGG;IACI,OAAO,IAAI,MAAM;IAIxB;;;;OAIG;IACU,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYjD;;;OAGG;IACI,QAAQ,IAAI,OAAO;IAI1B;;;;OAIG;IACU,SAAS,CAAC,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAYtD;;;OAGG;IACU,WAAW,IAAI,OAAO,CAAC;QAAE,IAAI,EAAE,cAAc,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAa9E;;;OAGG;IACU,YAAY,IAAI,OAAO,CAAC,WAAW,CAAC;IAqBjD;;;;;;;OAOG;IACU,gBAAgB,CACzB,IAAI,EAAE,MAAM,EACZ,iBAAiB,EAAE,QAAQ,EAC3B,IAAI,EAAE,OAAO,CAAC,cAAc,CAAC,EAC7B,iBAAiB,CAAC,EAAE,QAAQ,GAC7B,OAAO,CAAC,kBAAkB,CAAC;IAoC9B;;;;OAIG;IACU,iBAAiB,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;CAgC7D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js deleted file mode 100644 index ff45c17..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js +++ /dev/null @@ -1,214 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MSC3089Branch = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _event = require("../@types/event"); -var _eventTimeline = require("./event-timeline"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * Represents a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) branch - a reference - * to a file (leaf) in the tree. Note that this is UNSTABLE and subject to breaking changes - * without notice. - */ -class MSC3089Branch { - constructor(client, indexEvent, directory) { - this.client = client; - this.indexEvent = indexEvent; - this.directory = directory; - } // Nothing to do - - /** - * The file ID. - */ - get id() { - const stateKey = this.indexEvent.getStateKey(); - if (!stateKey) { - throw new Error("State key not found for branch"); - } - return stateKey; - } - - /** - * Whether this branch is active/valid. - */ - get isActive() { - return this.indexEvent.getContent()["active"] === true; - } - - /** - * Version for the file, one-indexed. - */ - get version() { - var _this$indexEvent$getC; - return (_this$indexEvent$getC = this.indexEvent.getContent()["version"]) !== null && _this$indexEvent$getC !== void 0 ? _this$indexEvent$getC : 1; - } - get roomId() { - return this.indexEvent.getRoomId(); - } - - /** - * Deletes the file from the tree, including all prior edits/versions. - * @returns Promise which resolves when complete. - */ - async delete() { - await this.client.sendStateEvent(this.roomId, _event.UNSTABLE_MSC3089_BRANCH.name, {}, this.id); - await this.client.redactEvent(this.roomId, this.id); - const nextVersion = (await this.getVersionHistory())[1]; // [0] will be us - if (nextVersion) await nextVersion.delete(); // implicit recursion - } - - /** - * Gets the name for this file. - * @returns The name, or "Unnamed File" if unknown. - */ - getName() { - return this.indexEvent.getContent()["name"] || "Unnamed File"; - } - - /** - * Sets the name for this file. - * @param name - The new name for this file. - * @returns Promise which resolves when complete. - */ - async setName(name) { - await this.client.sendStateEvent(this.roomId, _event.UNSTABLE_MSC3089_BRANCH.name, _objectSpread(_objectSpread({}, this.indexEvent.getContent()), {}, { - name: name - }), this.id); - } - - /** - * Gets whether or not a file is locked. - * @returns True if locked, false otherwise. - */ - isLocked() { - return this.indexEvent.getContent()["locked"] || false; - } - - /** - * Sets a file as locked or unlocked. - * @param locked - True to lock the file, false otherwise. - * @returns Promise which resolves when complete. - */ - async setLocked(locked) { - await this.client.sendStateEvent(this.roomId, _event.UNSTABLE_MSC3089_BRANCH.name, _objectSpread(_objectSpread({}, this.indexEvent.getContent()), {}, { - locked: locked - }), this.id); - } - - /** - * Gets information about the file needed to download it. - * @returns Information about the file. - */ - async getFileInfo() { - const event = await this.getFileEvent(); - const file = event.getOriginalContent()["file"]; - const httpUrl = this.client.mxcUrlToHttp(file["url"]); - if (!httpUrl) { - throw new Error(`No HTTP URL available for ${file["url"]}`); - } - return { - info: file, - httpUrl: httpUrl - }; - } - - /** - * Gets the event the file points to. - * @returns Promise which resolves to the file's event. - */ - async getFileEvent() { - const room = this.client.getRoom(this.roomId); - if (!room) throw new Error("Unknown room"); - let event = room.getUnfilteredTimelineSet().findEventById(this.id); - - // keep scrolling back if needed until we find the event or reach the start of the room: - while (!event && room.getLiveTimeline().getState(_eventTimeline.EventTimeline.BACKWARDS).paginationToken) { - await this.client.scrollback(room, 100); - event = room.getUnfilteredTimelineSet().findEventById(this.id); - } - if (!event) throw new Error("Failed to find event"); - - // Sometimes the event isn't decrypted for us, so do that. We specifically set `emit: true` - // to ensure that the relations system in the sdk will function. - await this.client.decryptEventIfNeeded(event, { - emit: true, - isRetry: true - }); - return event; - } - - /** - * Creates a new version of this file with contents in a type that is compatible with MatrixClient.uploadContent(). - * @param name - The name of the file. - * @param encryptedContents - The encrypted contents. - * @param info - The encrypted file information. - * @param additionalContent - Optional event content fields to include in the message. - * @returns Promise which resolves to the file event's sent response. - */ - async createNewVersion(name, encryptedContents, info, additionalContent) { - const fileEventResponse = await this.directory.createFile(name, encryptedContents, info, _objectSpread(_objectSpread({}, additionalContent !== null && additionalContent !== void 0 ? additionalContent : {}), {}, { - "m.new_content": true, - "m.relates_to": { - rel_type: _event.RelationType.Replace, - event_id: this.id - } - })); - - // Update the version of the new event - await this.client.sendStateEvent(this.roomId, _event.UNSTABLE_MSC3089_BRANCH.name, { - active: true, - name: name, - version: this.version + 1 - }, fileEventResponse["event_id"]); - - // Deprecate ourselves - await this.client.sendStateEvent(this.roomId, _event.UNSTABLE_MSC3089_BRANCH.name, _objectSpread(_objectSpread({}, this.indexEvent.getContent()), {}, { - active: false - }), this.id); - return fileEventResponse; - } - - /** - * Gets the file's version history, starting at this file. - * @returns Promise which resolves to the file's version history, with the - * first element being the current version and the last element being the first version. - */ - async getVersionHistory() { - const fileHistory = []; - fileHistory.push(this); // start with ourselves - - const room = this.client.getRoom(this.roomId); - if (!room) throw new Error("Invalid or unknown room"); - - // Clone the timeline to reverse it, getting most-recent-first ordering, hopefully - // shortening the awful loop below. Without the clone, we can unintentionally mutate - // the timeline. - const timelineEvents = [...room.getLiveTimeline().getEvents()].reverse(); - - // XXX: This is a very inefficient search, but it's the best we can do with the - // relations structure we have in the SDK. As of writing, it is not worth the - // investment in improving the structure. - let childEvent; - let parentEvent = await this.getFileEvent(); - do { - childEvent = timelineEvents.find(e => e.replacingEventId() === parentEvent.getId()); - if (childEvent) { - const branch = this.directory.getFile(childEvent.getId()); - if (branch) { - fileHistory.push(branch); - parentEvent = childEvent; - } else { - break; // prevent infinite loop - } - } - } while (childEvent); - return fileHistory; - } -} -exports.MSC3089Branch = MSC3089Branch; -//# sourceMappingURL=MSC3089Branch.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js.map deleted file mode 100644 index 888871d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089Branch.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3089Branch.js","names":["_event","require","_eventTimeline","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","MSC3089Branch","constructor","client","indexEvent","directory","id","stateKey","getStateKey","Error","isActive","getContent","version","_this$indexEvent$getC","roomId","getRoomId","delete","sendStateEvent","UNSTABLE_MSC3089_BRANCH","name","redactEvent","nextVersion","getVersionHistory","getName","setName","isLocked","setLocked","locked","getFileInfo","event","getFileEvent","file","getOriginalContent","httpUrl","mxcUrlToHttp","info","room","getRoom","getUnfilteredTimelineSet","findEventById","getLiveTimeline","getState","EventTimeline","BACKWARDS","paginationToken","scrollback","decryptEventIfNeeded","emit","isRetry","createNewVersion","encryptedContents","additionalContent","fileEventResponse","createFile","rel_type","RelationType","Replace","event_id","active","fileHistory","timelineEvents","getEvents","reverse","childEvent","parentEvent","find","e","replacingEventId","getId","branch","getFile","exports"],"sources":["../../src/models/MSC3089Branch.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixClient } from \"../client\";\nimport { IEncryptedFile, RelationType, UNSTABLE_MSC3089_BRANCH } from \"../@types/event\";\nimport { IContent, MatrixEvent } from \"./event\";\nimport { MSC3089TreeSpace } from \"./MSC3089TreeSpace\";\nimport { EventTimeline } from \"./event-timeline\";\nimport { FileType } from \"../http-api\";\nimport type { ISendEventResponse } from \"../@types/requests\";\n\n/**\n * Represents a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) branch - a reference\n * to a file (leaf) in the tree. Note that this is UNSTABLE and subject to breaking changes\n * without notice.\n */\nexport class MSC3089Branch {\n public constructor(\n private client: MatrixClient,\n public readonly indexEvent: MatrixEvent,\n public readonly directory: MSC3089TreeSpace,\n ) {\n // Nothing to do\n }\n\n /**\n * The file ID.\n */\n public get id(): string {\n const stateKey = this.indexEvent.getStateKey();\n if (!stateKey) {\n throw new Error(\"State key not found for branch\");\n }\n return stateKey;\n }\n\n /**\n * Whether this branch is active/valid.\n */\n public get isActive(): boolean {\n return this.indexEvent.getContent()[\"active\"] === true;\n }\n\n /**\n * Version for the file, one-indexed.\n */\n public get version(): number {\n return this.indexEvent.getContent()[\"version\"] ?? 1;\n }\n\n private get roomId(): string {\n return this.indexEvent.getRoomId()!;\n }\n\n /**\n * Deletes the file from the tree, including all prior edits/versions.\n * @returns Promise which resolves when complete.\n */\n public async delete(): Promise {\n await this.client.sendStateEvent(this.roomId, UNSTABLE_MSC3089_BRANCH.name, {}, this.id);\n await this.client.redactEvent(this.roomId, this.id);\n\n const nextVersion = (await this.getVersionHistory())[1]; // [0] will be us\n if (nextVersion) await nextVersion.delete(); // implicit recursion\n }\n\n /**\n * Gets the name for this file.\n * @returns The name, or \"Unnamed File\" if unknown.\n */\n public getName(): string {\n return this.indexEvent.getContent()[\"name\"] || \"Unnamed File\";\n }\n\n /**\n * Sets the name for this file.\n * @param name - The new name for this file.\n * @returns Promise which resolves when complete.\n */\n public async setName(name: string): Promise {\n await this.client.sendStateEvent(\n this.roomId,\n UNSTABLE_MSC3089_BRANCH.name,\n {\n ...this.indexEvent.getContent(),\n name: name,\n },\n this.id,\n );\n }\n\n /**\n * Gets whether or not a file is locked.\n * @returns True if locked, false otherwise.\n */\n public isLocked(): boolean {\n return this.indexEvent.getContent()[\"locked\"] || false;\n }\n\n /**\n * Sets a file as locked or unlocked.\n * @param locked - True to lock the file, false otherwise.\n * @returns Promise which resolves when complete.\n */\n public async setLocked(locked: boolean): Promise {\n await this.client.sendStateEvent(\n this.roomId,\n UNSTABLE_MSC3089_BRANCH.name,\n {\n ...this.indexEvent.getContent(),\n locked: locked,\n },\n this.id,\n );\n }\n\n /**\n * Gets information about the file needed to download it.\n * @returns Information about the file.\n */\n public async getFileInfo(): Promise<{ info: IEncryptedFile; httpUrl: string }> {\n const event = await this.getFileEvent();\n\n const file = event.getOriginalContent()[\"file\"];\n const httpUrl = this.client.mxcUrlToHttp(file[\"url\"]);\n\n if (!httpUrl) {\n throw new Error(`No HTTP URL available for ${file[\"url\"]}`);\n }\n\n return { info: file, httpUrl: httpUrl };\n }\n\n /**\n * Gets the event the file points to.\n * @returns Promise which resolves to the file's event.\n */\n public async getFileEvent(): Promise {\n const room = this.client.getRoom(this.roomId);\n if (!room) throw new Error(\"Unknown room\");\n\n let event: MatrixEvent | undefined = room.getUnfilteredTimelineSet().findEventById(this.id);\n\n // keep scrolling back if needed until we find the event or reach the start of the room:\n while (!event && room.getLiveTimeline().getState(EventTimeline.BACKWARDS)!.paginationToken) {\n await this.client.scrollback(room, 100);\n event = room.getUnfilteredTimelineSet().findEventById(this.id);\n }\n\n if (!event) throw new Error(\"Failed to find event\");\n\n // Sometimes the event isn't decrypted for us, so do that. We specifically set `emit: true`\n // to ensure that the relations system in the sdk will function.\n await this.client.decryptEventIfNeeded(event, { emit: true, isRetry: true });\n\n return event;\n }\n\n /**\n * Creates a new version of this file with contents in a type that is compatible with MatrixClient.uploadContent().\n * @param name - The name of the file.\n * @param encryptedContents - The encrypted contents.\n * @param info - The encrypted file information.\n * @param additionalContent - Optional event content fields to include in the message.\n * @returns Promise which resolves to the file event's sent response.\n */\n public async createNewVersion(\n name: string,\n encryptedContents: FileType,\n info: Partial,\n additionalContent?: IContent,\n ): Promise {\n const fileEventResponse = await this.directory.createFile(name, encryptedContents, info, {\n ...(additionalContent ?? {}),\n \"m.new_content\": true,\n \"m.relates_to\": {\n rel_type: RelationType.Replace,\n event_id: this.id,\n },\n });\n\n // Update the version of the new event\n await this.client.sendStateEvent(\n this.roomId,\n UNSTABLE_MSC3089_BRANCH.name,\n {\n active: true,\n name: name,\n version: this.version + 1,\n },\n fileEventResponse[\"event_id\"],\n );\n\n // Deprecate ourselves\n await this.client.sendStateEvent(\n this.roomId,\n UNSTABLE_MSC3089_BRANCH.name,\n {\n ...this.indexEvent.getContent(),\n active: false,\n },\n this.id,\n );\n\n return fileEventResponse;\n }\n\n /**\n * Gets the file's version history, starting at this file.\n * @returns Promise which resolves to the file's version history, with the\n * first element being the current version and the last element being the first version.\n */\n public async getVersionHistory(): Promise {\n const fileHistory: MSC3089Branch[] = [];\n fileHistory.push(this); // start with ourselves\n\n const room = this.client.getRoom(this.roomId);\n if (!room) throw new Error(\"Invalid or unknown room\");\n\n // Clone the timeline to reverse it, getting most-recent-first ordering, hopefully\n // shortening the awful loop below. Without the clone, we can unintentionally mutate\n // the timeline.\n const timelineEvents = [...room.getLiveTimeline().getEvents()].reverse();\n\n // XXX: This is a very inefficient search, but it's the best we can do with the\n // relations structure we have in the SDK. As of writing, it is not worth the\n // investment in improving the structure.\n let childEvent: MatrixEvent | undefined;\n let parentEvent = await this.getFileEvent();\n do {\n childEvent = timelineEvents.find((e) => e.replacingEventId() === parentEvent.getId());\n if (childEvent) {\n const branch = this.directory.getFile(childEvent.getId()!);\n if (branch) {\n fileHistory.push(branch);\n parentEvent = childEvent;\n } else {\n break; // prevent infinite loop\n }\n }\n } while (childEvent);\n\n return fileHistory;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts deleted file mode 100644 index fce3d15..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts +++ /dev/null @@ -1,164 +0,0 @@ -import { MatrixClient } from "../client"; -import { IEncryptedFile } from "../@types/event"; -import { Room } from "./room"; -import { IContent } from "./event"; -import { MSC3089Branch } from "./MSC3089Branch"; -import { ISendEventResponse } from "../@types/requests"; -import { FileType } from "../http-api"; -/** - * The recommended defaults for a tree space's power levels. Note that this - * is UNSTABLE and subject to breaking changes without notice. - */ -export declare const DEFAULT_TREE_POWER_LEVELS_TEMPLATE: { - invite: number; - kick: number; - ban: number; - redact: number; - state_default: number; - events_default: number; - users_default: number; - events: { - "m.room.power_levels": number; - "m.room.history_visibility": number; - "m.room.tombstone": number; - "m.room.encryption": number; - "m.room.name": number; - "m.room.message": number; - "m.room.encrypted": number; - "m.sticker": number; - }; - users: {}; -}; -/** - * Ease-of-use representation for power levels represented as simple roles. - * Note that this is UNSTABLE and subject to breaking changes without notice. - */ -export declare enum TreePermissions { - Viewer = "viewer", - Editor = "editor", - Owner = "owner" -} -/** - * Represents a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) - * file tree Space. Note that this is UNSTABLE and subject to breaking changes - * without notice. - */ -export declare class MSC3089TreeSpace { - private client; - readonly roomId: string; - readonly room: Room; - constructor(client: MatrixClient, roomId: string); - /** - * Syntactic sugar for room ID of the Space. - */ - get id(): string; - /** - * Whether or not this is a top level space. - */ - get isTopLevel(): boolean; - /** - * Sets the name of the tree space. - * @param name - The new name for the space. - * @returns Promise which resolves when complete. - */ - setName(name: string): Promise; - /** - * Invites a user to the tree space. They will be given the default Viewer - * permission level unless specified elsewhere. - * @param userId - The user ID to invite. - * @param andSubspaces - True (default) to invite the user to all - * directories/subspaces too, recursively. - * @param shareHistoryKeys - True (default) to share encryption keys - * with the invited user. This will allow them to decrypt the events (files) - * in the tree. Keys will not be shared if the room is lacking appropriate - * history visibility (by default, history visibility is "shared" in trees, - * which is an appropriate visibility for these purposes). - * @returns Promise which resolves when complete. - */ - invite(userId: string, andSubspaces?: boolean, shareHistoryKeys?: boolean): Promise; - private retryInvite; - /** - * Sets the permissions of a user to the given role. Note that if setting a user - * to Owner then they will NOT be able to be demoted. If the user does not have - * permission to change the power level of the target, an error will be thrown. - * @param userId - The user ID to change the role of. - * @param role - The role to assign. - * @returns Promise which resolves when complete. - */ - setPermissions(userId: string, role: TreePermissions): Promise; - /** - * Gets the current permissions of a user. Note that any users missing explicit permissions (or not - * in the space) will be considered Viewers. Appropriate membership checks need to be performed - * elsewhere. - * @param userId - The user ID to check permissions of. - * @returns The permissions for the user, defaulting to Viewer. - */ - getPermissions(userId: string): TreePermissions; - /** - * Creates a directory under this tree space, represented as another tree space. - * @param name - The name for the directory. - * @returns Promise which resolves to the created directory. - */ - createDirectory(name: string): Promise; - /** - * Gets a list of all known immediate subdirectories to this tree space. - * @returns The tree spaces (directories). May be empty, but not null. - */ - getDirectories(): MSC3089TreeSpace[]; - /** - * Gets a subdirectory of a given ID under this tree space. Note that this will not recurse - * into children and instead only look one level deep. - * @param roomId - The room ID (directory ID) to find. - * @returns The directory, or undefined if not found. - */ - getDirectory(roomId: string): MSC3089TreeSpace | undefined; - /** - * Deletes the tree, kicking all members and deleting **all subdirectories**. - * @returns Promise which resolves when complete. - */ - delete(): Promise; - private getOrderedChildren; - private getParentRoom; - /** - * Gets the current order index for this directory. Note that if this is the top level space - * then -1 will be returned. - * @returns The order index of this space. - */ - getOrder(): number; - /** - * Sets the order index for this directory within its parent. Note that if this is a top level - * space then an error will be thrown. -1 can be used to move the child to the start, and numbers - * larger than the number of children can be used to move the child to the end. - * @param index - The new order index for this space. - * @returns Promise which resolves when complete. - * @throws Throws if this is a top level space. - */ - setOrder(index: number): Promise; - /** - * Creates (uploads) a new file to this tree. The file must have already been encrypted for the room. - * The file contents are in a type that is compatible with MatrixClient.uploadContent(). - * @param name - The name of the file. - * @param encryptedContents - The encrypted contents. - * @param info - The encrypted file information. - * @param additionalContent - Optional event content fields to include in the message. - * @returns Promise which resolves to the file event's sent response. - */ - createFile(name: string, encryptedContents: FileType, info: Partial, additionalContent?: IContent): Promise; - /** - * Retrieves a file from the tree. - * @param fileEventId - The event ID of the file. - * @returns The file, or null if not found. - */ - getFile(fileEventId: string): MSC3089Branch | null; - /** - * Gets an array of all known files for the tree. - * @returns The known files. May be empty, but not null. - */ - listFiles(): MSC3089Branch[]; - /** - * Gets an array of all known files for the tree, including inactive/invalid ones. - * @returns The known files. May be empty, but not null. - */ - listAllFiles(): MSC3089Branch[]; -} -//# sourceMappingURL=MSC3089TreeSpace.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts.map deleted file mode 100644 index cb8e4f6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3089TreeSpace.d.ts","sourceRoot":"","sources":["../../src/models/MSC3089TreeSpace.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAa,cAAc,EAA2D,MAAM,iBAAiB,CAAC;AACrH,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,OAAO,EAAE,QAAQ,EAAe,MAAM,SAAS,CAAC;AAShD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC;;;GAGG;AACH,eAAO,MAAM,kCAAkC;;;;;;;;;;;;;;;;;;;CA2B9C,CAAC;AAEF;;;GAGG;AACH,oBAAY,eAAe;IACvB,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,KAAK,UAAU;CAClB;AAED;;;;GAIG;AACH,qBAAa,gBAAgB;IAGN,OAAO,CAAC,MAAM;aAAgC,MAAM,EAAE,MAAM;IAF/E,SAAgB,IAAI,EAAE,IAAI,CAAC;gBAEA,MAAM,EAAE,YAAY,EAAkB,MAAM,EAAE,MAAM;IAM/E;;OAEG;IACH,IAAW,EAAE,IAAI,MAAM,CAEtB;IAED;;OAEG;IACH,IAAW,UAAU,IAAI,OAAO,CAM/B;IAED;;;;OAIG;IACU,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIjD;;;;;;;;;;;;OAYG;IACU,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,UAAO,EAAE,gBAAgB,UAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBhG,OAAO,CAAC,WAAW;IAYnB;;;;;;;OAOG;IACU,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IA4BjF;;;;;;OAMG;IACI,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,eAAe;IAetD;;;;OAIG;IACU,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAwBrE;;;OAGG;IACI,cAAc,IAAI,gBAAgB,EAAE;IAiB3C;;;;;OAKG;IACI,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS;IAIjE;;;OAGG;IACU,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAsBpC,OAAO,CAAC,kBAAkB;IA+B1B,OAAO,CAAC,aAAa;IAerB;;;;OAIG;IACI,QAAQ,IAAI,MAAM;IAUzB;;;;;;;OAOG;IACU,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA8GnD;;;;;;;;OAQG;IACU,UAAU,CACnB,IAAI,EAAE,MAAM,EACZ,iBAAiB,EAAE,QAAQ,EAC3B,IAAI,EAAE,OAAO,CAAC,cAAc,CAAC,EAC7B,iBAAiB,CAAC,EAAE,QAAQ,GAC7B,OAAO,CAAC,kBAAkB,CAAC;IAwC9B;;;;OAIG;IACI,OAAO,CAAC,WAAW,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI;IAKzD;;;OAGG;IACI,SAAS,IAAI,aAAa,EAAE;IAInC;;;OAGG;IACI,YAAY,IAAI,aAAa,EAAE;CAIzC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js deleted file mode 100644 index cb23980..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js +++ /dev/null @@ -1,503 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TreePermissions = exports.MSC3089TreeSpace = exports.DEFAULT_TREE_POWER_LEVELS_TEMPLATE = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _pRetry = _interopRequireDefault(require("p-retry")); -var _event = require("../@types/event"); -var _logger = require("../logger"); -var _utils = require("../utils"); -var _MSC3089Branch = require("./MSC3089Branch"); -var _megolm = require("../crypto/algorithms/megolm"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/** - * The recommended defaults for a tree space's power levels. Note that this - * is UNSTABLE and subject to breaking changes without notice. - */ -const DEFAULT_TREE_POWER_LEVELS_TEMPLATE = { - // Owner - invite: 100, - kick: 100, - ban: 100, - // Editor - redact: 50, - state_default: 50, - events_default: 50, - // Viewer - users_default: 0, - // Mixed - events: { - [_event.EventType.RoomPowerLevels]: 100, - [_event.EventType.RoomHistoryVisibility]: 100, - [_event.EventType.RoomTombstone]: 100, - [_event.EventType.RoomEncryption]: 100, - [_event.EventType.RoomName]: 50, - [_event.EventType.RoomMessage]: 50, - [_event.EventType.RoomMessageEncrypted]: 50, - [_event.EventType.Sticker]: 50 - }, - users: {} // defined by calling code -}; - -/** - * Ease-of-use representation for power levels represented as simple roles. - * Note that this is UNSTABLE and subject to breaking changes without notice. - */ -exports.DEFAULT_TREE_POWER_LEVELS_TEMPLATE = DEFAULT_TREE_POWER_LEVELS_TEMPLATE; -let TreePermissions; // "Admin" or PL100 -/** - * Represents a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089) - * file tree Space. Note that this is UNSTABLE and subject to breaking changes - * without notice. - */ -exports.TreePermissions = TreePermissions; -(function (TreePermissions) { - TreePermissions["Viewer"] = "viewer"; - TreePermissions["Editor"] = "editor"; - TreePermissions["Owner"] = "owner"; -})(TreePermissions || (exports.TreePermissions = TreePermissions = {})); -class MSC3089TreeSpace { - constructor(client, roomId) { - this.client = client; - this.roomId = roomId; - (0, _defineProperty2.default)(this, "room", void 0); - this.room = this.client.getRoom(this.roomId); - if (!this.room) throw new Error("Unknown room"); - } - - /** - * Syntactic sugar for room ID of the Space. - */ - get id() { - return this.roomId; - } - - /** - * Whether or not this is a top level space. - */ - get isTopLevel() { - // XXX: This is absolutely not how you find out if the space is top level - // but is safe for a managed usecase like we offer in the SDK. - const parentEvents = this.room.currentState.getStateEvents(_event.EventType.SpaceParent); - if (!(parentEvents !== null && parentEvents !== void 0 && parentEvents.length)) return true; - return parentEvents.every(e => { - var _e$getContent; - return !((_e$getContent = e.getContent()) !== null && _e$getContent !== void 0 && _e$getContent["via"]); - }); - } - - /** - * Sets the name of the tree space. - * @param name - The new name for the space. - * @returns Promise which resolves when complete. - */ - async setName(name) { - await this.client.sendStateEvent(this.roomId, _event.EventType.RoomName, { - name - }, ""); - } - - /** - * Invites a user to the tree space. They will be given the default Viewer - * permission level unless specified elsewhere. - * @param userId - The user ID to invite. - * @param andSubspaces - True (default) to invite the user to all - * directories/subspaces too, recursively. - * @param shareHistoryKeys - True (default) to share encryption keys - * with the invited user. This will allow them to decrypt the events (files) - * in the tree. Keys will not be shared if the room is lacking appropriate - * history visibility (by default, history visibility is "shared" in trees, - * which is an appropriate visibility for these purposes). - * @returns Promise which resolves when complete. - */ - async invite(userId, andSubspaces = true, shareHistoryKeys = true) { - const promises = [this.retryInvite(userId)]; - if (andSubspaces) { - promises.push(...this.getDirectories().map(d => d.invite(userId, andSubspaces, shareHistoryKeys))); - } - return Promise.all(promises).then(() => { - // Note: key sharing is default on because for file trees it is relatively important that the invite - // target can actually decrypt the files. The implied use case is that by inviting a user to the tree - // it means the sender would like the receiver to view/download the files contained within, much like - // sharing a folder in other circles. - if (shareHistoryKeys && (0, _megolm.isRoomSharedHistory)(this.room)) { - // noinspection JSIgnoredPromiseFromCall - we aren't concerned as much if this fails. - this.client.sendSharedHistoryKeys(this.roomId, [userId]); - } - }); - } - retryInvite(userId) { - return (0, _utils.simpleRetryOperation)(async () => { - await this.client.invite(this.roomId, userId).catch(e => { - // We don't want to retry permission errors forever... - if ((e === null || e === void 0 ? void 0 : e.errcode) === "M_FORBIDDEN") { - throw new _pRetry.default.AbortError(e); - } - throw e; - }); - }); - } - - /** - * Sets the permissions of a user to the given role. Note that if setting a user - * to Owner then they will NOT be able to be demoted. If the user does not have - * permission to change the power level of the target, an error will be thrown. - * @param userId - The user ID to change the role of. - * @param role - The role to assign. - * @returns Promise which resolves when complete. - */ - async setPermissions(userId, role) { - var _pls$events; - const currentPls = this.room.currentState.getStateEvents(_event.EventType.RoomPowerLevels, ""); - if (Array.isArray(currentPls)) throw new Error("Unexpected return type for power levels"); - const pls = (currentPls === null || currentPls === void 0 ? void 0 : currentPls.getContent()) || {}; - const viewLevel = pls["users_default"] || 0; - const editLevel = pls["events_default"] || 50; - const adminLevel = ((_pls$events = pls["events"]) === null || _pls$events === void 0 ? void 0 : _pls$events[_event.EventType.RoomPowerLevels]) || 100; - const users = pls["users"] || {}; - switch (role) { - case TreePermissions.Viewer: - users[userId] = viewLevel; - break; - case TreePermissions.Editor: - users[userId] = editLevel; - break; - case TreePermissions.Owner: - users[userId] = adminLevel; - break; - default: - throw new Error("Invalid role: " + role); - } - pls["users"] = users; - await this.client.sendStateEvent(this.roomId, _event.EventType.RoomPowerLevels, pls, ""); - } - - /** - * Gets the current permissions of a user. Note that any users missing explicit permissions (or not - * in the space) will be considered Viewers. Appropriate membership checks need to be performed - * elsewhere. - * @param userId - The user ID to check permissions of. - * @returns The permissions for the user, defaulting to Viewer. - */ - getPermissions(userId) { - var _pls$events2, _pls$users; - const currentPls = this.room.currentState.getStateEvents(_event.EventType.RoomPowerLevels, ""); - if (Array.isArray(currentPls)) throw new Error("Unexpected return type for power levels"); - const pls = (currentPls === null || currentPls === void 0 ? void 0 : currentPls.getContent()) || {}; - const viewLevel = pls["users_default"] || 0; - const editLevel = pls["events_default"] || 50; - const adminLevel = ((_pls$events2 = pls["events"]) === null || _pls$events2 === void 0 ? void 0 : _pls$events2[_event.EventType.RoomPowerLevels]) || 100; - const userLevel = ((_pls$users = pls["users"]) === null || _pls$users === void 0 ? void 0 : _pls$users[userId]) || viewLevel; - if (userLevel >= adminLevel) return TreePermissions.Owner; - if (userLevel >= editLevel) return TreePermissions.Editor; - return TreePermissions.Viewer; - } - - /** - * Creates a directory under this tree space, represented as another tree space. - * @param name - The name for the directory. - * @returns Promise which resolves to the created directory. - */ - async createDirectory(name) { - const directory = await this.client.unstableCreateFileTree(name); - await this.client.sendStateEvent(this.roomId, _event.EventType.SpaceChild, { - via: [this.client.getDomain()] - }, directory.roomId); - await this.client.sendStateEvent(directory.roomId, _event.EventType.SpaceParent, { - via: [this.client.getDomain()] - }, this.roomId); - return directory; - } - - /** - * Gets a list of all known immediate subdirectories to this tree space. - * @returns The tree spaces (directories). May be empty, but not null. - */ - getDirectories() { - const trees = []; - const children = this.room.currentState.getStateEvents(_event.EventType.SpaceChild); - for (const child of children) { - try { - const stateKey = child.getStateKey(); - if (stateKey) { - const tree = this.client.unstableGetFileTreeSpace(stateKey); - if (tree) trees.push(tree); - } - } catch (e) { - _logger.logger.warn("Unable to create tree space instance for listing. Are we joined?", e); - } - } - return trees; - } - - /** - * Gets a subdirectory of a given ID under this tree space. Note that this will not recurse - * into children and instead only look one level deep. - * @param roomId - The room ID (directory ID) to find. - * @returns The directory, or undefined if not found. - */ - getDirectory(roomId) { - return this.getDirectories().find(r => r.roomId === roomId); - } - - /** - * Deletes the tree, kicking all members and deleting **all subdirectories**. - * @returns Promise which resolves when complete. - */ - async delete() { - const subdirectories = this.getDirectories(); - for (const dir of subdirectories) { - await dir.delete(); - } - const kickMemberships = ["invite", "knock", "join"]; - const members = this.room.currentState.getStateEvents(_event.EventType.RoomMember); - for (const member of members) { - const isNotUs = member.getStateKey() !== this.client.getUserId(); - if (isNotUs && kickMemberships.includes(member.getContent().membership)) { - const stateKey = member.getStateKey(); - if (!stateKey) { - throw new Error("State key not found for branch"); - } - await this.client.kick(this.roomId, stateKey, "Room deleted"); - } - } - await this.client.leave(this.roomId); - } - getOrderedChildren(children) { - const ordered = children.map(c => ({ - roomId: c.getStateKey(), - order: c.getContent()["order"] - })).filter(c => c.roomId); - ordered.sort((a, b) => { - if (a.order && !b.order) { - return -1; - } else if (!a.order && b.order) { - return 1; - } else if (!a.order && !b.order) { - var _roomA$currentState$g, _roomA$currentState$g2, _roomB$currentState$g, _roomB$currentState$g2; - const roomA = this.client.getRoom(a.roomId); - const roomB = this.client.getRoom(b.roomId); - if (!roomA || !roomB) { - // just don't bother trying to do more partial sorting - return (0, _utils.lexicographicCompare)(a.roomId, b.roomId); - } - const createTsA = (_roomA$currentState$g = (_roomA$currentState$g2 = roomA.currentState.getStateEvents(_event.EventType.RoomCreate, "")) === null || _roomA$currentState$g2 === void 0 ? void 0 : _roomA$currentState$g2.getTs()) !== null && _roomA$currentState$g !== void 0 ? _roomA$currentState$g : 0; - const createTsB = (_roomB$currentState$g = (_roomB$currentState$g2 = roomB.currentState.getStateEvents(_event.EventType.RoomCreate, "")) === null || _roomB$currentState$g2 === void 0 ? void 0 : _roomB$currentState$g2.getTs()) !== null && _roomB$currentState$g !== void 0 ? _roomB$currentState$g : 0; - if (createTsA === createTsB) { - return (0, _utils.lexicographicCompare)(a.roomId, b.roomId); - } - return createTsA - createTsB; - } else { - // both not-null orders - return (0, _utils.lexicographicCompare)(a.order, b.order); - } - }); - return ordered; - } - getParentRoom() { - const parents = this.room.currentState.getStateEvents(_event.EventType.SpaceParent); - const parent = parents[0]; // XXX: Wild assumption - if (!parent) throw new Error("Expected to have a parent in a non-top level space"); - - // XXX: We are assuming the parent is a valid tree space. - // We probably don't need to validate the parent room state for this usecase though. - const stateKey = parent.getStateKey(); - if (!stateKey) throw new Error("No state key found for parent"); - const parentRoom = this.client.getRoom(stateKey); - if (!parentRoom) throw new Error("Unable to locate room for parent"); - return parentRoom; - } - - /** - * Gets the current order index for this directory. Note that if this is the top level space - * then -1 will be returned. - * @returns The order index of this space. - */ - getOrder() { - if (this.isTopLevel) return -1; - const parentRoom = this.getParentRoom(); - const children = parentRoom.currentState.getStateEvents(_event.EventType.SpaceChild); - const ordered = this.getOrderedChildren(children); - return ordered.findIndex(c => c.roomId === this.roomId); - } - - /** - * Sets the order index for this directory within its parent. Note that if this is a top level - * space then an error will be thrown. -1 can be used to move the child to the start, and numbers - * larger than the number of children can be used to move the child to the end. - * @param index - The new order index for this space. - * @returns Promise which resolves when complete. - * @throws Throws if this is a top level space. - */ - async setOrder(index) { - var _currentChild$getCont2; - if (this.isTopLevel) throw new Error("Cannot set order of top level spaces currently"); - const parentRoom = this.getParentRoom(); - const children = parentRoom.currentState.getStateEvents(_event.EventType.SpaceChild); - const ordered = this.getOrderedChildren(children); - index = Math.max(Math.min(index, ordered.length - 1), 0); - const currentIndex = this.getOrder(); - const movingUp = currentIndex < index; - if (movingUp && index === ordered.length - 1) { - index--; - } else if (!movingUp && index === 0) { - index++; - } - const prev = ordered[movingUp ? index : index - 1]; - const next = ordered[movingUp ? index + 1 : index]; - let newOrder = _utils.DEFAULT_ALPHABET[0]; - let ensureBeforeIsSane = false; - if (!prev) { - // Move to front - if (next !== null && next !== void 0 && next.order) { - newOrder = (0, _utils.prevString)(next.order); - } - } else if (index === ordered.length - 1) { - // Move to back - if (next !== null && next !== void 0 && next.order) { - newOrder = (0, _utils.nextString)(next.order); - } - } else { - // Move somewhere in the middle - const startOrder = prev === null || prev === void 0 ? void 0 : prev.order; - const endOrder = next === null || next === void 0 ? void 0 : next.order; - if (startOrder && endOrder) { - if (startOrder === endOrder) { - // Error case: just move +1 to break out of awful math - newOrder = (0, _utils.nextString)(startOrder); - } else { - newOrder = (0, _utils.averageBetweenStrings)(startOrder, endOrder); - } - } else { - if (startOrder) { - // We're at the end (endOrder is null, so no explicit order) - newOrder = (0, _utils.nextString)(startOrder); - } else if (endOrder) { - // We're at the start (startOrder is null, so nothing before us) - newOrder = (0, _utils.prevString)(endOrder); - } else { - // Both points are unknown. We're likely in a range where all the children - // don't have particular order values, so we may need to update them too. - // The other possibility is there's only us as a child, but we should have - // shown up in the other states. - ensureBeforeIsSane = true; - } - } - } - if (ensureBeforeIsSane) { - // We were asked by the order algorithm to prepare the moving space for a landing - // in the undefined order part of the order array, which means we need to update the - // spaces that come before it with a stable order value. - let lastOrder; - for (let i = 0; i <= index; i++) { - const target = ordered[i]; - if (i === 0) { - lastOrder = target.order; - } - if (!target.order) { - var _currentChild$getCont; - // XXX: We should be creating gaps to avoid conflicts - lastOrder = lastOrder ? (0, _utils.nextString)(lastOrder) : _utils.DEFAULT_ALPHABET[0]; - const currentChild = parentRoom.currentState.getStateEvents(_event.EventType.SpaceChild, target.roomId); - const content = (_currentChild$getCont = currentChild === null || currentChild === void 0 ? void 0 : currentChild.getContent()) !== null && _currentChild$getCont !== void 0 ? _currentChild$getCont : { - via: [this.client.getDomain()] - }; - await this.client.sendStateEvent(parentRoom.roomId, _event.EventType.SpaceChild, _objectSpread(_objectSpread({}, content), {}, { - order: lastOrder - }), target.roomId); - } else { - lastOrder = target.order; - } - } - if (lastOrder) { - newOrder = (0, _utils.nextString)(lastOrder); - } - } - - // TODO: Deal with order conflicts by reordering - - // Now we can finally update our own order state - const currentChild = parentRoom.currentState.getStateEvents(_event.EventType.SpaceChild, this.roomId); - const content = (_currentChild$getCont2 = currentChild === null || currentChild === void 0 ? void 0 : currentChild.getContent()) !== null && _currentChild$getCont2 !== void 0 ? _currentChild$getCont2 : { - via: [this.client.getDomain()] - }; - await this.client.sendStateEvent(parentRoom.roomId, _event.EventType.SpaceChild, _objectSpread(_objectSpread({}, content), {}, { - // TODO: Safely constrain to 50 character limit required by spaces. - order: newOrder - }), this.roomId); - } - - /** - * Creates (uploads) a new file to this tree. The file must have already been encrypted for the room. - * The file contents are in a type that is compatible with MatrixClient.uploadContent(). - * @param name - The name of the file. - * @param encryptedContents - The encrypted contents. - * @param info - The encrypted file information. - * @param additionalContent - Optional event content fields to include in the message. - * @returns Promise which resolves to the file event's sent response. - */ - async createFile(name, encryptedContents, info, additionalContent) { - var _additionalContent; - const { - content_uri: mxc - } = await this.client.uploadContent(encryptedContents, { - includeFilename: false - }); - info.url = mxc; - const fileContent = { - msgtype: _event.MsgType.File, - body: name, - url: mxc, - file: info - }; - additionalContent = (_additionalContent = additionalContent) !== null && _additionalContent !== void 0 ? _additionalContent : {}; - if (additionalContent["m.new_content"]) { - // We do the right thing according to the spec, but due to how relations are - // handled we also end up duplicating this information to the regular `content` - // as well. - additionalContent["m.new_content"] = fileContent; - } - const res = await this.client.sendMessage(this.roomId, _objectSpread(_objectSpread(_objectSpread({}, additionalContent), fileContent), {}, { - [_event.UNSTABLE_MSC3089_LEAF.name]: {} - })); - await this.client.sendStateEvent(this.roomId, _event.UNSTABLE_MSC3089_BRANCH.name, { - active: true, - name: name - }, res["event_id"]); - return res; - } - - /** - * Retrieves a file from the tree. - * @param fileEventId - The event ID of the file. - * @returns The file, or null if not found. - */ - getFile(fileEventId) { - const branch = this.room.currentState.getStateEvents(_event.UNSTABLE_MSC3089_BRANCH.name, fileEventId); - return branch ? new _MSC3089Branch.MSC3089Branch(this.client, branch, this) : null; - } - - /** - * Gets an array of all known files for the tree. - * @returns The known files. May be empty, but not null. - */ - listFiles() { - return this.listAllFiles().filter(b => b.isActive); - } - - /** - * Gets an array of all known files for the tree, including inactive/invalid ones. - * @returns The known files. May be empty, but not null. - */ - listAllFiles() { - var _this$room$currentSta; - const branches = (_this$room$currentSta = this.room.currentState.getStateEvents(_event.UNSTABLE_MSC3089_BRANCH.name)) !== null && _this$room$currentSta !== void 0 ? _this$room$currentSta : []; - return branches.map(e => new _MSC3089Branch.MSC3089Branch(this.client, e, this)); - } -} -exports.MSC3089TreeSpace = MSC3089TreeSpace; -//# sourceMappingURL=MSC3089TreeSpace.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js.map deleted file mode 100644 index a243b4c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/MSC3089TreeSpace.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3089TreeSpace.js","names":["_pRetry","_interopRequireDefault","require","_event","_logger","_utils","_MSC3089Branch","_megolm","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","DEFAULT_TREE_POWER_LEVELS_TEMPLATE","invite","kick","ban","redact","state_default","events_default","users_default","events","EventType","RoomPowerLevels","RoomHistoryVisibility","RoomTombstone","RoomEncryption","RoomName","RoomMessage","RoomMessageEncrypted","Sticker","users","exports","TreePermissions","MSC3089TreeSpace","constructor","client","roomId","room","getRoom","Error","id","isTopLevel","parentEvents","currentState","getStateEvents","SpaceParent","every","e","_e$getContent","getContent","setName","name","sendStateEvent","userId","andSubspaces","shareHistoryKeys","promises","retryInvite","getDirectories","map","d","Promise","all","then","isRoomSharedHistory","sendSharedHistoryKeys","simpleRetryOperation","catch","errcode","promiseRetry","AbortError","setPermissions","role","_pls$events","currentPls","Array","isArray","pls","viewLevel","editLevel","adminLevel","Viewer","Editor","Owner","getPermissions","_pls$events2","_pls$users","userLevel","createDirectory","directory","unstableCreateFileTree","SpaceChild","via","getDomain","trees","children","child","stateKey","getStateKey","tree","unstableGetFileTreeSpace","logger","warn","getDirectory","find","r","delete","subdirectories","dir","kickMemberships","members","RoomMember","member","isNotUs","getUserId","includes","membership","leave","getOrderedChildren","ordered","c","order","sort","a","b","_roomA$currentState$g","_roomA$currentState$g2","_roomB$currentState$g","_roomB$currentState$g2","roomA","roomB","lexicographicCompare","createTsA","RoomCreate","getTs","createTsB","getParentRoom","parents","parent","parentRoom","getOrder","findIndex","setOrder","index","_currentChild$getCont2","Math","max","min","currentIndex","movingUp","prev","next","newOrder","DEFAULT_ALPHABET","ensureBeforeIsSane","prevString","nextString","startOrder","endOrder","averageBetweenStrings","lastOrder","_currentChild$getCont","currentChild","content","createFile","encryptedContents","info","additionalContent","_additionalContent","content_uri","mxc","uploadContent","includeFilename","url","fileContent","msgtype","MsgType","File","body","file","res","sendMessage","UNSTABLE_MSC3089_LEAF","UNSTABLE_MSC3089_BRANCH","active","getFile","fileEventId","branch","MSC3089Branch","listFiles","listAllFiles","isActive","_this$room$currentSta","branches"],"sources":["../../src/models/MSC3089TreeSpace.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport promiseRetry from \"p-retry\";\n\nimport { MatrixClient } from \"../client\";\nimport { EventType, IEncryptedFile, MsgType, UNSTABLE_MSC3089_BRANCH, UNSTABLE_MSC3089_LEAF } from \"../@types/event\";\nimport { Room } from \"./room\";\nimport { logger } from \"../logger\";\nimport { IContent, MatrixEvent } from \"./event\";\nimport {\n averageBetweenStrings,\n DEFAULT_ALPHABET,\n lexicographicCompare,\n nextString,\n prevString,\n simpleRetryOperation,\n} from \"../utils\";\nimport { MSC3089Branch } from \"./MSC3089Branch\";\nimport { isRoomSharedHistory } from \"../crypto/algorithms/megolm\";\nimport { ISendEventResponse } from \"../@types/requests\";\nimport { FileType } from \"../http-api\";\n\n/**\n * The recommended defaults for a tree space's power levels. Note that this\n * is UNSTABLE and subject to breaking changes without notice.\n */\nexport const DEFAULT_TREE_POWER_LEVELS_TEMPLATE = {\n // Owner\n invite: 100,\n kick: 100,\n ban: 100,\n\n // Editor\n redact: 50,\n state_default: 50,\n events_default: 50,\n\n // Viewer\n users_default: 0,\n\n // Mixed\n events: {\n [EventType.RoomPowerLevels]: 100,\n [EventType.RoomHistoryVisibility]: 100,\n [EventType.RoomTombstone]: 100,\n [EventType.RoomEncryption]: 100,\n [EventType.RoomName]: 50,\n [EventType.RoomMessage]: 50,\n [EventType.RoomMessageEncrypted]: 50,\n [EventType.Sticker]: 50,\n },\n\n users: {}, // defined by calling code\n};\n\n/**\n * Ease-of-use representation for power levels represented as simple roles.\n * Note that this is UNSTABLE and subject to breaking changes without notice.\n */\nexport enum TreePermissions {\n Viewer = \"viewer\", // Default\n Editor = \"editor\", // \"Moderator\" or ~PL50\n Owner = \"owner\", // \"Admin\" or PL100\n}\n\n/**\n * Represents a [MSC3089](https://github.com/matrix-org/matrix-doc/pull/3089)\n * file tree Space. Note that this is UNSTABLE and subject to breaking changes\n * without notice.\n */\nexport class MSC3089TreeSpace {\n public readonly room: Room;\n\n public constructor(private client: MatrixClient, public readonly roomId: string) {\n this.room = this.client.getRoom(this.roomId)!;\n\n if (!this.room) throw new Error(\"Unknown room\");\n }\n\n /**\n * Syntactic sugar for room ID of the Space.\n */\n public get id(): string {\n return this.roomId;\n }\n\n /**\n * Whether or not this is a top level space.\n */\n public get isTopLevel(): boolean {\n // XXX: This is absolutely not how you find out if the space is top level\n // but is safe for a managed usecase like we offer in the SDK.\n const parentEvents = this.room.currentState.getStateEvents(EventType.SpaceParent);\n if (!parentEvents?.length) return true;\n return parentEvents.every((e) => !e.getContent()?.[\"via\"]);\n }\n\n /**\n * Sets the name of the tree space.\n * @param name - The new name for the space.\n * @returns Promise which resolves when complete.\n */\n public async setName(name: string): Promise {\n await this.client.sendStateEvent(this.roomId, EventType.RoomName, { name }, \"\");\n }\n\n /**\n * Invites a user to the tree space. They will be given the default Viewer\n * permission level unless specified elsewhere.\n * @param userId - The user ID to invite.\n * @param andSubspaces - True (default) to invite the user to all\n * directories/subspaces too, recursively.\n * @param shareHistoryKeys - True (default) to share encryption keys\n * with the invited user. This will allow them to decrypt the events (files)\n * in the tree. Keys will not be shared if the room is lacking appropriate\n * history visibility (by default, history visibility is \"shared\" in trees,\n * which is an appropriate visibility for these purposes).\n * @returns Promise which resolves when complete.\n */\n public async invite(userId: string, andSubspaces = true, shareHistoryKeys = true): Promise {\n const promises: Promise[] = [this.retryInvite(userId)];\n if (andSubspaces) {\n promises.push(...this.getDirectories().map((d) => d.invite(userId, andSubspaces, shareHistoryKeys)));\n }\n return Promise.all(promises).then(() => {\n // Note: key sharing is default on because for file trees it is relatively important that the invite\n // target can actually decrypt the files. The implied use case is that by inviting a user to the tree\n // it means the sender would like the receiver to view/download the files contained within, much like\n // sharing a folder in other circles.\n if (shareHistoryKeys && isRoomSharedHistory(this.room)) {\n // noinspection JSIgnoredPromiseFromCall - we aren't concerned as much if this fails.\n this.client.sendSharedHistoryKeys(this.roomId, [userId]);\n }\n });\n }\n\n private retryInvite(userId: string): Promise {\n return simpleRetryOperation(async () => {\n await this.client.invite(this.roomId, userId).catch((e) => {\n // We don't want to retry permission errors forever...\n if (e?.errcode === \"M_FORBIDDEN\") {\n throw new promiseRetry.AbortError(e);\n }\n throw e;\n });\n });\n }\n\n /**\n * Sets the permissions of a user to the given role. Note that if setting a user\n * to Owner then they will NOT be able to be demoted. If the user does not have\n * permission to change the power level of the target, an error will be thrown.\n * @param userId - The user ID to change the role of.\n * @param role - The role to assign.\n * @returns Promise which resolves when complete.\n */\n public async setPermissions(userId: string, role: TreePermissions): Promise {\n const currentPls = this.room.currentState.getStateEvents(EventType.RoomPowerLevels, \"\");\n if (Array.isArray(currentPls)) throw new Error(\"Unexpected return type for power levels\");\n\n const pls = currentPls?.getContent() || {};\n const viewLevel = pls[\"users_default\"] || 0;\n const editLevel = pls[\"events_default\"] || 50;\n const adminLevel = pls[\"events\"]?.[EventType.RoomPowerLevels] || 100;\n\n const users = pls[\"users\"] || {};\n switch (role) {\n case TreePermissions.Viewer:\n users[userId] = viewLevel;\n break;\n case TreePermissions.Editor:\n users[userId] = editLevel;\n break;\n case TreePermissions.Owner:\n users[userId] = adminLevel;\n break;\n default:\n throw new Error(\"Invalid role: \" + role);\n }\n pls[\"users\"] = users;\n\n await this.client.sendStateEvent(this.roomId, EventType.RoomPowerLevels, pls, \"\");\n }\n\n /**\n * Gets the current permissions of a user. Note that any users missing explicit permissions (or not\n * in the space) will be considered Viewers. Appropriate membership checks need to be performed\n * elsewhere.\n * @param userId - The user ID to check permissions of.\n * @returns The permissions for the user, defaulting to Viewer.\n */\n public getPermissions(userId: string): TreePermissions {\n const currentPls = this.room.currentState.getStateEvents(EventType.RoomPowerLevels, \"\");\n if (Array.isArray(currentPls)) throw new Error(\"Unexpected return type for power levels\");\n\n const pls = currentPls?.getContent() || {};\n const viewLevel = pls[\"users_default\"] || 0;\n const editLevel = pls[\"events_default\"] || 50;\n const adminLevel = pls[\"events\"]?.[EventType.RoomPowerLevels] || 100;\n\n const userLevel = pls[\"users\"]?.[userId] || viewLevel;\n if (userLevel >= adminLevel) return TreePermissions.Owner;\n if (userLevel >= editLevel) return TreePermissions.Editor;\n return TreePermissions.Viewer;\n }\n\n /**\n * Creates a directory under this tree space, represented as another tree space.\n * @param name - The name for the directory.\n * @returns Promise which resolves to the created directory.\n */\n public async createDirectory(name: string): Promise {\n const directory = await this.client.unstableCreateFileTree(name);\n\n await this.client.sendStateEvent(\n this.roomId,\n EventType.SpaceChild,\n {\n via: [this.client.getDomain()],\n },\n directory.roomId,\n );\n\n await this.client.sendStateEvent(\n directory.roomId,\n EventType.SpaceParent,\n {\n via: [this.client.getDomain()],\n },\n this.roomId,\n );\n\n return directory;\n }\n\n /**\n * Gets a list of all known immediate subdirectories to this tree space.\n * @returns The tree spaces (directories). May be empty, but not null.\n */\n public getDirectories(): MSC3089TreeSpace[] {\n const trees: MSC3089TreeSpace[] = [];\n const children = this.room.currentState.getStateEvents(EventType.SpaceChild);\n for (const child of children) {\n try {\n const stateKey = child.getStateKey();\n if (stateKey) {\n const tree = this.client.unstableGetFileTreeSpace(stateKey);\n if (tree) trees.push(tree);\n }\n } catch (e) {\n logger.warn(\"Unable to create tree space instance for listing. Are we joined?\", e);\n }\n }\n return trees;\n }\n\n /**\n * Gets a subdirectory of a given ID under this tree space. Note that this will not recurse\n * into children and instead only look one level deep.\n * @param roomId - The room ID (directory ID) to find.\n * @returns The directory, or undefined if not found.\n */\n public getDirectory(roomId: string): MSC3089TreeSpace | undefined {\n return this.getDirectories().find((r) => r.roomId === roomId);\n }\n\n /**\n * Deletes the tree, kicking all members and deleting **all subdirectories**.\n * @returns Promise which resolves when complete.\n */\n public async delete(): Promise {\n const subdirectories = this.getDirectories();\n for (const dir of subdirectories) {\n await dir.delete();\n }\n\n const kickMemberships = [\"invite\", \"knock\", \"join\"];\n const members = this.room.currentState.getStateEvents(EventType.RoomMember);\n for (const member of members) {\n const isNotUs = member.getStateKey() !== this.client.getUserId();\n if (isNotUs && kickMemberships.includes(member.getContent().membership!)) {\n const stateKey = member.getStateKey();\n if (!stateKey) {\n throw new Error(\"State key not found for branch\");\n }\n await this.client.kick(this.roomId, stateKey, \"Room deleted\");\n }\n }\n\n await this.client.leave(this.roomId);\n }\n\n private getOrderedChildren(children: MatrixEvent[]): { roomId: string; order: string }[] {\n const ordered: { roomId: string; order: string }[] = children\n .map((c) => ({ roomId: c.getStateKey(), order: c.getContent()[\"order\"] }))\n .filter((c) => c.roomId) as { roomId: string; order: string }[];\n ordered.sort((a, b) => {\n if (a.order && !b.order) {\n return -1;\n } else if (!a.order && b.order) {\n return 1;\n } else if (!a.order && !b.order) {\n const roomA = this.client.getRoom(a.roomId);\n const roomB = this.client.getRoom(b.roomId);\n if (!roomA || !roomB) {\n // just don't bother trying to do more partial sorting\n return lexicographicCompare(a.roomId, b.roomId);\n }\n\n const createTsA = roomA.currentState.getStateEvents(EventType.RoomCreate, \"\")?.getTs() ?? 0;\n const createTsB = roomB.currentState.getStateEvents(EventType.RoomCreate, \"\")?.getTs() ?? 0;\n if (createTsA === createTsB) {\n return lexicographicCompare(a.roomId, b.roomId);\n }\n return createTsA - createTsB;\n } else {\n // both not-null orders\n return lexicographicCompare(a.order, b.order);\n }\n });\n return ordered;\n }\n\n private getParentRoom(): Room {\n const parents = this.room.currentState.getStateEvents(EventType.SpaceParent);\n const parent = parents[0]; // XXX: Wild assumption\n if (!parent) throw new Error(\"Expected to have a parent in a non-top level space\");\n\n // XXX: We are assuming the parent is a valid tree space.\n // We probably don't need to validate the parent room state for this usecase though.\n const stateKey = parent.getStateKey();\n if (!stateKey) throw new Error(\"No state key found for parent\");\n const parentRoom = this.client.getRoom(stateKey);\n if (!parentRoom) throw new Error(\"Unable to locate room for parent\");\n\n return parentRoom;\n }\n\n /**\n * Gets the current order index for this directory. Note that if this is the top level space\n * then -1 will be returned.\n * @returns The order index of this space.\n */\n public getOrder(): number {\n if (this.isTopLevel) return -1;\n\n const parentRoom = this.getParentRoom();\n const children = parentRoom.currentState.getStateEvents(EventType.SpaceChild);\n const ordered = this.getOrderedChildren(children);\n\n return ordered.findIndex((c) => c.roomId === this.roomId);\n }\n\n /**\n * Sets the order index for this directory within its parent. Note that if this is a top level\n * space then an error will be thrown. -1 can be used to move the child to the start, and numbers\n * larger than the number of children can be used to move the child to the end.\n * @param index - The new order index for this space.\n * @returns Promise which resolves when complete.\n * @throws Throws if this is a top level space.\n */\n public async setOrder(index: number): Promise {\n if (this.isTopLevel) throw new Error(\"Cannot set order of top level spaces currently\");\n\n const parentRoom = this.getParentRoom();\n const children = parentRoom.currentState.getStateEvents(EventType.SpaceChild);\n const ordered = this.getOrderedChildren(children);\n index = Math.max(Math.min(index, ordered.length - 1), 0);\n\n const currentIndex = this.getOrder();\n const movingUp = currentIndex < index;\n if (movingUp && index === ordered.length - 1) {\n index--;\n } else if (!movingUp && index === 0) {\n index++;\n }\n\n const prev = ordered[movingUp ? index : index - 1];\n const next = ordered[movingUp ? index + 1 : index];\n\n let newOrder = DEFAULT_ALPHABET[0];\n let ensureBeforeIsSane = false;\n if (!prev) {\n // Move to front\n if (next?.order) {\n newOrder = prevString(next.order);\n }\n } else if (index === ordered.length - 1) {\n // Move to back\n if (next?.order) {\n newOrder = nextString(next.order);\n }\n } else {\n // Move somewhere in the middle\n const startOrder = prev?.order;\n const endOrder = next?.order;\n if (startOrder && endOrder) {\n if (startOrder === endOrder) {\n // Error case: just move +1 to break out of awful math\n newOrder = nextString(startOrder);\n } else {\n newOrder = averageBetweenStrings(startOrder, endOrder);\n }\n } else {\n if (startOrder) {\n // We're at the end (endOrder is null, so no explicit order)\n newOrder = nextString(startOrder);\n } else if (endOrder) {\n // We're at the start (startOrder is null, so nothing before us)\n newOrder = prevString(endOrder);\n } else {\n // Both points are unknown. We're likely in a range where all the children\n // don't have particular order values, so we may need to update them too.\n // The other possibility is there's only us as a child, but we should have\n // shown up in the other states.\n ensureBeforeIsSane = true;\n }\n }\n }\n\n if (ensureBeforeIsSane) {\n // We were asked by the order algorithm to prepare the moving space for a landing\n // in the undefined order part of the order array, which means we need to update the\n // spaces that come before it with a stable order value.\n let lastOrder: string | undefined;\n for (let i = 0; i <= index; i++) {\n const target = ordered[i];\n if (i === 0) {\n lastOrder = target.order;\n }\n if (!target.order) {\n // XXX: We should be creating gaps to avoid conflicts\n lastOrder = lastOrder ? nextString(lastOrder) : DEFAULT_ALPHABET[0];\n const currentChild = parentRoom.currentState.getStateEvents(EventType.SpaceChild, target.roomId);\n const content = currentChild?.getContent() ?? { via: [this.client.getDomain()] };\n await this.client.sendStateEvent(\n parentRoom.roomId,\n EventType.SpaceChild,\n {\n ...content,\n order: lastOrder,\n },\n target.roomId,\n );\n } else {\n lastOrder = target.order;\n }\n }\n if (lastOrder) {\n newOrder = nextString(lastOrder);\n }\n }\n\n // TODO: Deal with order conflicts by reordering\n\n // Now we can finally update our own order state\n const currentChild = parentRoom.currentState.getStateEvents(EventType.SpaceChild, this.roomId);\n const content = currentChild?.getContent() ?? { via: [this.client.getDomain()] };\n await this.client.sendStateEvent(\n parentRoom.roomId,\n EventType.SpaceChild,\n {\n ...content,\n\n // TODO: Safely constrain to 50 character limit required by spaces.\n order: newOrder,\n },\n this.roomId,\n );\n }\n\n /**\n * Creates (uploads) a new file to this tree. The file must have already been encrypted for the room.\n * The file contents are in a type that is compatible with MatrixClient.uploadContent().\n * @param name - The name of the file.\n * @param encryptedContents - The encrypted contents.\n * @param info - The encrypted file information.\n * @param additionalContent - Optional event content fields to include in the message.\n * @returns Promise which resolves to the file event's sent response.\n */\n public async createFile(\n name: string,\n encryptedContents: FileType,\n info: Partial,\n additionalContent?: IContent,\n ): Promise {\n const { content_uri: mxc } = await this.client.uploadContent(encryptedContents, {\n includeFilename: false,\n });\n info.url = mxc;\n\n const fileContent = {\n msgtype: MsgType.File,\n body: name,\n url: mxc,\n file: info,\n };\n\n additionalContent = additionalContent ?? {};\n if (additionalContent[\"m.new_content\"]) {\n // We do the right thing according to the spec, but due to how relations are\n // handled we also end up duplicating this information to the regular `content`\n // as well.\n additionalContent[\"m.new_content\"] = fileContent;\n }\n\n const res = await this.client.sendMessage(this.roomId, {\n ...additionalContent,\n ...fileContent,\n [UNSTABLE_MSC3089_LEAF.name]: {},\n });\n\n await this.client.sendStateEvent(\n this.roomId,\n UNSTABLE_MSC3089_BRANCH.name,\n {\n active: true,\n name: name,\n },\n res[\"event_id\"],\n );\n\n return res;\n }\n\n /**\n * Retrieves a file from the tree.\n * @param fileEventId - The event ID of the file.\n * @returns The file, or null if not found.\n */\n public getFile(fileEventId: string): MSC3089Branch | null {\n const branch = this.room.currentState.getStateEvents(UNSTABLE_MSC3089_BRANCH.name, fileEventId);\n return branch ? new MSC3089Branch(this.client, branch, this) : null;\n }\n\n /**\n * Gets an array of all known files for the tree.\n * @returns The known files. May be empty, but not null.\n */\n public listFiles(): MSC3089Branch[] {\n return this.listAllFiles().filter((b) => b.isActive);\n }\n\n /**\n * Gets an array of all known files for the tree, including inactive/invalid ones.\n * @returns The known files. May be empty, but not null.\n */\n public listAllFiles(): MSC3089Branch[] {\n const branches = this.room.currentState.getStateEvents(UNSTABLE_MSC3089_BRANCH.name) ?? [];\n return branches.map((e) => new MSC3089Branch(this.client, e, this));\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts deleted file mode 100644 index c5c8761..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts +++ /dev/null @@ -1,17 +0,0 @@ -export type ToDevicePayload = Record; -export interface ToDeviceMessage { - userId: string; - deviceId: string; - payload: ToDevicePayload; -} -export interface ToDeviceBatch { - eventType: string; - batch: ToDeviceMessage[]; -} -export interface ToDeviceBatchWithTxnId extends ToDeviceBatch { - txnId: string; -} -export interface IndexedToDeviceBatch extends ToDeviceBatchWithTxnId { - id: number; -} -//# sourceMappingURL=ToDeviceMessage.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts.map deleted file mode 100644 index 4c6f6ed..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ToDeviceMessage.d.ts","sourceRoot":"","sources":["../../src/models/ToDeviceMessage.ts"],"names":[],"mappings":"AAgBA,MAAM,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;AAElD,MAAM,WAAW,eAAe;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,eAAe,CAAC;CAC5B;AAED,MAAM,WAAW,aAAa;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,eAAe,EAAE,CAAC;CAC5B;AAGD,MAAM,WAAW,sBAAuB,SAAQ,aAAa;IACzD,KAAK,EAAE,MAAM,CAAC;CACjB;AAGD,MAAM,WAAW,oBAAqB,SAAQ,sBAAsB;IAChE,EAAE,EAAE,MAAM,CAAC;CACd"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js deleted file mode 100644 index d383c67..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=ToDeviceMessage.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js.map deleted file mode 100644 index 986f7f5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/ToDeviceMessage.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"ToDeviceMessage.js","names":[],"sources":["../../src/models/ToDeviceMessage.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport type ToDevicePayload = Record;\n\nexport interface ToDeviceMessage {\n userId: string;\n deviceId: string;\n payload: ToDevicePayload;\n}\n\nexport interface ToDeviceBatch {\n eventType: string;\n batch: ToDeviceMessage[];\n}\n\n// Only used internally\nexport interface ToDeviceBatchWithTxnId extends ToDeviceBatch {\n txnId: string;\n}\n\n// Only used internally\nexport interface IndexedToDeviceBatch extends ToDeviceBatchWithTxnId {\n id: number;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts deleted file mode 100644 index 3a6918c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts +++ /dev/null @@ -1,53 +0,0 @@ -import { BeaconInfoState, BeaconLocationState } from "../content-helpers"; -import { MatrixEvent } from "./event"; -import { TypedEventEmitter } from "./typed-event-emitter"; -export declare enum BeaconEvent { - New = "Beacon.new", - Update = "Beacon.update", - LivenessChange = "Beacon.LivenessChange", - Destroy = "Beacon.Destroy", - LocationUpdate = "Beacon.LocationUpdate" -} -export type BeaconEventHandlerMap = { - [BeaconEvent.Update]: (event: MatrixEvent, beacon: Beacon) => void; - [BeaconEvent.LivenessChange]: (isLive: boolean, beacon: Beacon) => void; - [BeaconEvent.Destroy]: (beaconIdentifier: string) => void; - [BeaconEvent.LocationUpdate]: (locationState: BeaconLocationState) => void; - [BeaconEvent.Destroy]: (beaconIdentifier: string) => void; -}; -export declare const isTimestampInDuration: (startTimestamp: number, durationMs: number, timestamp: number) => boolean; -export type BeaconIdentifier = string; -export declare const getBeaconInfoIdentifier: (event: MatrixEvent) => BeaconIdentifier; -export declare class Beacon extends TypedEventEmitter, BeaconEventHandlerMap> { - private rootEvent; - readonly roomId: string; - private _beaconInfo; - private _isLive?; - private livenessWatchTimeout?; - private _latestLocationEvent?; - constructor(rootEvent: MatrixEvent); - get isLive(): boolean; - get identifier(): BeaconIdentifier; - get beaconInfoId(): string; - get beaconInfoOwner(): string; - get beaconInfoEventType(): string; - get beaconInfo(): BeaconInfoState; - get latestLocationState(): BeaconLocationState | undefined; - get latestLocationEvent(): MatrixEvent | undefined; - update(beaconInfoEvent: MatrixEvent): void; - destroy(): void; - /** - * Monitor liveness of a beacon - * Emits BeaconEvent.LivenessChange when beacon expires - */ - monitorLiveness(): void; - /** - * Process Beacon locations - * Emits BeaconEvent.LocationUpdate - */ - addLocations(beaconLocationEvents: MatrixEvent[]): void; - private clearLatestLocation; - private setBeaconInfo; - private checkLiveness; -} -//# sourceMappingURL=beacon.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts.map deleted file mode 100644 index 1d7253b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"beacon.d.ts","sourceRoot":"","sources":["../../src/models/beacon.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAA8C,MAAM,oBAAoB,CAAC;AACtH,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,oBAAY,WAAW;IACnB,GAAG,eAAe;IAClB,MAAM,kBAAkB;IACxB,cAAc,0BAA0B;IACxC,OAAO,mBAAmB;IAC1B,cAAc,0BAA0B;CAC3C;AAED,MAAM,MAAM,qBAAqB,GAAG;IAChC,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACnE,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACxE,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,gBAAgB,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1D,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,CAAC,aAAa,EAAE,mBAAmB,KAAK,IAAI,CAAC;IAC3E,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,gBAAgB,EAAE,MAAM,KAAK,IAAI,CAAC;CAC7D,CAAC;AAEF,eAAO,MAAM,qBAAqB,mBAAoB,MAAM,cAAc,MAAM,aAAa,MAAM,KAAG,OAC3B,CAAC;AAI5E,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC;AACtC,eAAO,MAAM,uBAAuB,UAAW,WAAW,KAAG,gBACZ,CAAC;AAGlD,qBAAa,MAAO,SAAQ,iBAAiB,CAAC,OAAO,CAAC,WAAW,EAAE,WAAW,CAAC,GAAG,CAAC,EAAE,qBAAqB,CAAC;IASpF,OAAO,CAAC,SAAS;IARpC,SAAgB,MAAM,EAAE,MAAM,CAAC;IAG/B,OAAO,CAAC,WAAW,CAAmB;IACtC,OAAO,CAAC,OAAO,CAAC,CAAU;IAC1B,OAAO,CAAC,oBAAoB,CAAC,CAAgC;IAC7D,OAAO,CAAC,oBAAoB,CAAC,CAAc;gBAEhB,SAAS,EAAE,WAAW;IAMjD,IAAW,MAAM,IAAI,OAAO,CAE3B;IAED,IAAW,UAAU,IAAI,gBAAgB,CAExC;IAED,IAAW,YAAY,IAAI,MAAM,CAEhC;IAED,IAAW,eAAe,IAAI,MAAM,CAEnC;IAED,IAAW,mBAAmB,IAAI,MAAM,CAEvC;IAED,IAAW,UAAU,IAAI,eAAe,CAEvC;IAED,IAAW,mBAAmB,IAAI,mBAAmB,GAAG,SAAS,CAEhE;IAED,IAAW,mBAAmB,IAAI,WAAW,GAAG,SAAS,CAExD;IAEM,MAAM,CAAC,eAAe,EAAE,WAAW,GAAG,IAAI;IAe1C,OAAO,IAAI,IAAI;IAStB;;;OAGG;IACI,eAAe,IAAI,IAAI;IAuB9B;;;OAGG;IACI,YAAY,CAAC,oBAAoB,EAAE,WAAW,EAAE,GAAG,IAAI;IA2B9D,OAAO,CAAC,mBAAmB,CAGzB;IAEF,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,aAAa;CAqBxB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js deleted file mode 100644 index 93a226d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js +++ /dev/null @@ -1,184 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.isTimestampInDuration = exports.getBeaconInfoIdentifier = exports.BeaconEvent = exports.Beacon = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _contentHelpers = require("../content-helpers"); -var _utils = require("../utils"); -var _typedEventEmitter = require("./typed-event-emitter"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let BeaconEvent; -exports.BeaconEvent = BeaconEvent; -(function (BeaconEvent) { - BeaconEvent["New"] = "Beacon.new"; - BeaconEvent["Update"] = "Beacon.update"; - BeaconEvent["LivenessChange"] = "Beacon.LivenessChange"; - BeaconEvent["Destroy"] = "Beacon.Destroy"; - BeaconEvent["LocationUpdate"] = "Beacon.LocationUpdate"; -})(BeaconEvent || (exports.BeaconEvent = BeaconEvent = {})); -const isTimestampInDuration = (startTimestamp, durationMs, timestamp) => timestamp >= startTimestamp && startTimestamp + durationMs >= timestamp; - -// beacon info events are uniquely identified by -// `_` -exports.isTimestampInDuration = isTimestampInDuration; -const getBeaconInfoIdentifier = event => `${event.getRoomId()}_${event.getStateKey()}`; - -// https://github.com/matrix-org/matrix-spec-proposals/pull/3672 -exports.getBeaconInfoIdentifier = getBeaconInfoIdentifier; -class Beacon extends _typedEventEmitter.TypedEventEmitter { - // beaconInfo is assigned by setBeaconInfo in the constructor - // ! to make tsc believe it is definitely assigned - - constructor(rootEvent) { - super(); - this.rootEvent = rootEvent; - (0, _defineProperty2.default)(this, "roomId", void 0); - (0, _defineProperty2.default)(this, "_beaconInfo", void 0); - (0, _defineProperty2.default)(this, "_isLive", void 0); - (0, _defineProperty2.default)(this, "livenessWatchTimeout", void 0); - (0, _defineProperty2.default)(this, "_latestLocationEvent", void 0); - (0, _defineProperty2.default)(this, "clearLatestLocation", () => { - this._latestLocationEvent = undefined; - this.emit(BeaconEvent.LocationUpdate, this.latestLocationState); - }); - this.roomId = this.rootEvent.getRoomId(); - this.setBeaconInfo(this.rootEvent); - } - get isLive() { - return !!this._isLive; - } - get identifier() { - return getBeaconInfoIdentifier(this.rootEvent); - } - get beaconInfoId() { - return this.rootEvent.getId(); - } - get beaconInfoOwner() { - return this.rootEvent.getStateKey(); - } - get beaconInfoEventType() { - return this.rootEvent.getType(); - } - get beaconInfo() { - return this._beaconInfo; - } - get latestLocationState() { - return this._latestLocationEvent && (0, _contentHelpers.parseBeaconContent)(this._latestLocationEvent.getContent()); - } - get latestLocationEvent() { - return this._latestLocationEvent; - } - update(beaconInfoEvent) { - if (getBeaconInfoIdentifier(beaconInfoEvent) !== this.identifier) { - throw new Error("Invalid updating event"); - } - // don't update beacon with an older event - if (beaconInfoEvent.getTs() < this.rootEvent.getTs()) { - return; - } - this.rootEvent = beaconInfoEvent; - this.setBeaconInfo(this.rootEvent); - this.emit(BeaconEvent.Update, beaconInfoEvent, this); - this.clearLatestLocation(); - } - destroy() { - if (this.livenessWatchTimeout) { - clearTimeout(this.livenessWatchTimeout); - } - this._isLive = false; - this.emit(BeaconEvent.Destroy, this.identifier); - } - - /** - * Monitor liveness of a beacon - * Emits BeaconEvent.LivenessChange when beacon expires - */ - monitorLiveness() { - if (this.livenessWatchTimeout) { - clearTimeout(this.livenessWatchTimeout); - } - this.checkLiveness(); - if (!this.beaconInfo) return; - if (this.isLive) { - const expiryInMs = this.beaconInfo.timestamp + this.beaconInfo.timeout - Date.now(); - if (expiryInMs > 1) { - this.livenessWatchTimeout = setTimeout(() => { - this.monitorLiveness(); - }, expiryInMs); - } - } else if (this.beaconInfo.timestamp > Date.now()) { - // beacon start timestamp is in the future - // check liveness again then - this.livenessWatchTimeout = setTimeout(() => { - this.monitorLiveness(); - }, this.beaconInfo.timestamp - Date.now()); - } - } - - /** - * Process Beacon locations - * Emits BeaconEvent.LocationUpdate - */ - addLocations(beaconLocationEvents) { - var _validLocationEvents$; - // discard locations for beacons that are not live - if (!this.isLive) { - return; - } - const validLocationEvents = beaconLocationEvents.filter(event => { - const content = event.getContent(); - const parsed = (0, _contentHelpers.parseBeaconContent)(content); - if (!parsed.uri || !parsed.timestamp) return false; // we won't be able to process these - const { - timestamp - } = parsed; - return this._beaconInfo.timestamp && - // only include positions that were taken inside the beacon's live period - isTimestampInDuration(this._beaconInfo.timestamp, this._beaconInfo.timeout, timestamp) && ( - // ignore positions older than our current latest location - !this.latestLocationState || timestamp > this.latestLocationState.timestamp); - }); - const latestLocationEvent = (_validLocationEvents$ = validLocationEvents.sort(_utils.sortEventsByLatestContentTimestamp)) === null || _validLocationEvents$ === void 0 ? void 0 : _validLocationEvents$[0]; - if (latestLocationEvent) { - this._latestLocationEvent = latestLocationEvent; - this.emit(BeaconEvent.LocationUpdate, this.latestLocationState); - } - } - setBeaconInfo(event) { - this._beaconInfo = (0, _contentHelpers.parseBeaconInfoContent)(event.getContent()); - this.checkLiveness(); - } - checkLiveness() { - const prevLiveness = this.isLive; - - // element web sets a beacon's start timestamp to the senders local current time - // when Alice's system clock deviates slightly from Bob's a beacon Alice intended to be live - // may have a start timestamp in the future from Bob's POV - // handle this by adding 6min of leniency to the start timestamp when it is in the future - if (!this.beaconInfo) return; - const startTimestamp = this.beaconInfo.timestamp > Date.now() ? this.beaconInfo.timestamp - 360000 /* 6min */ : this.beaconInfo.timestamp; - this._isLive = !!this._beaconInfo.live && !!startTimestamp && isTimestampInDuration(startTimestamp, this._beaconInfo.timeout, Date.now()); - if (prevLiveness !== this.isLive) { - this.emit(BeaconEvent.LivenessChange, this.isLive, this); - } - } -} -exports.Beacon = Beacon; -//# sourceMappingURL=beacon.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js.map deleted file mode 100644 index 15062fb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/beacon.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"beacon.js","names":["_contentHelpers","require","_utils","_typedEventEmitter","BeaconEvent","exports","isTimestampInDuration","startTimestamp","durationMs","timestamp","getBeaconInfoIdentifier","event","getRoomId","getStateKey","Beacon","TypedEventEmitter","constructor","rootEvent","_defineProperty2","default","_latestLocationEvent","undefined","emit","LocationUpdate","latestLocationState","roomId","setBeaconInfo","isLive","_isLive","identifier","beaconInfoId","getId","beaconInfoOwner","beaconInfoEventType","getType","beaconInfo","_beaconInfo","parseBeaconContent","getContent","latestLocationEvent","update","beaconInfoEvent","Error","getTs","Update","clearLatestLocation","destroy","livenessWatchTimeout","clearTimeout","Destroy","monitorLiveness","checkLiveness","expiryInMs","timeout","Date","now","setTimeout","addLocations","beaconLocationEvents","_validLocationEvents$","validLocationEvents","filter","content","parsed","uri","sort","sortEventsByLatestContentTimestamp","parseBeaconInfoContent","prevLiveness","live","LivenessChange"],"sources":["../../src/models/beacon.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MBeaconEventContent } from \"../@types/beacon\";\nimport { BeaconInfoState, BeaconLocationState, parseBeaconContent, parseBeaconInfoContent } from \"../content-helpers\";\nimport { MatrixEvent } from \"./event\";\nimport { sortEventsByLatestContentTimestamp } from \"../utils\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\n\nexport enum BeaconEvent {\n New = \"Beacon.new\",\n Update = \"Beacon.update\",\n LivenessChange = \"Beacon.LivenessChange\",\n Destroy = \"Beacon.Destroy\",\n LocationUpdate = \"Beacon.LocationUpdate\",\n}\n\nexport type BeaconEventHandlerMap = {\n [BeaconEvent.Update]: (event: MatrixEvent, beacon: Beacon) => void;\n [BeaconEvent.LivenessChange]: (isLive: boolean, beacon: Beacon) => void;\n [BeaconEvent.Destroy]: (beaconIdentifier: string) => void;\n [BeaconEvent.LocationUpdate]: (locationState: BeaconLocationState) => void;\n [BeaconEvent.Destroy]: (beaconIdentifier: string) => void;\n};\n\nexport const isTimestampInDuration = (startTimestamp: number, durationMs: number, timestamp: number): boolean =>\n timestamp >= startTimestamp && startTimestamp + durationMs >= timestamp;\n\n// beacon info events are uniquely identified by\n// `_`\nexport type BeaconIdentifier = string;\nexport const getBeaconInfoIdentifier = (event: MatrixEvent): BeaconIdentifier =>\n `${event.getRoomId()}_${event.getStateKey()}`;\n\n// https://github.com/matrix-org/matrix-spec-proposals/pull/3672\nexport class Beacon extends TypedEventEmitter, BeaconEventHandlerMap> {\n public readonly roomId: string;\n // beaconInfo is assigned by setBeaconInfo in the constructor\n // ! to make tsc believe it is definitely assigned\n private _beaconInfo!: BeaconInfoState;\n private _isLive?: boolean;\n private livenessWatchTimeout?: ReturnType;\n private _latestLocationEvent?: MatrixEvent;\n\n public constructor(private rootEvent: MatrixEvent) {\n super();\n this.roomId = this.rootEvent.getRoomId()!;\n this.setBeaconInfo(this.rootEvent);\n }\n\n public get isLive(): boolean {\n return !!this._isLive;\n }\n\n public get identifier(): BeaconIdentifier {\n return getBeaconInfoIdentifier(this.rootEvent);\n }\n\n public get beaconInfoId(): string {\n return this.rootEvent.getId()!;\n }\n\n public get beaconInfoOwner(): string {\n return this.rootEvent.getStateKey()!;\n }\n\n public get beaconInfoEventType(): string {\n return this.rootEvent.getType();\n }\n\n public get beaconInfo(): BeaconInfoState {\n return this._beaconInfo;\n }\n\n public get latestLocationState(): BeaconLocationState | undefined {\n return this._latestLocationEvent && parseBeaconContent(this._latestLocationEvent.getContent());\n }\n\n public get latestLocationEvent(): MatrixEvent | undefined {\n return this._latestLocationEvent;\n }\n\n public update(beaconInfoEvent: MatrixEvent): void {\n if (getBeaconInfoIdentifier(beaconInfoEvent) !== this.identifier) {\n throw new Error(\"Invalid updating event\");\n }\n // don't update beacon with an older event\n if (beaconInfoEvent.getTs() < this.rootEvent.getTs()) {\n return;\n }\n this.rootEvent = beaconInfoEvent;\n this.setBeaconInfo(this.rootEvent);\n\n this.emit(BeaconEvent.Update, beaconInfoEvent, this);\n this.clearLatestLocation();\n }\n\n public destroy(): void {\n if (this.livenessWatchTimeout) {\n clearTimeout(this.livenessWatchTimeout);\n }\n\n this._isLive = false;\n this.emit(BeaconEvent.Destroy, this.identifier);\n }\n\n /**\n * Monitor liveness of a beacon\n * Emits BeaconEvent.LivenessChange when beacon expires\n */\n public monitorLiveness(): void {\n if (this.livenessWatchTimeout) {\n clearTimeout(this.livenessWatchTimeout);\n }\n\n this.checkLiveness();\n if (!this.beaconInfo) return;\n if (this.isLive) {\n const expiryInMs = this.beaconInfo.timestamp! + this.beaconInfo.timeout - Date.now();\n if (expiryInMs > 1) {\n this.livenessWatchTimeout = setTimeout(() => {\n this.monitorLiveness();\n }, expiryInMs);\n }\n } else if (this.beaconInfo.timestamp! > Date.now()) {\n // beacon start timestamp is in the future\n // check liveness again then\n this.livenessWatchTimeout = setTimeout(() => {\n this.monitorLiveness();\n }, this.beaconInfo.timestamp! - Date.now());\n }\n }\n\n /**\n * Process Beacon locations\n * Emits BeaconEvent.LocationUpdate\n */\n public addLocations(beaconLocationEvents: MatrixEvent[]): void {\n // discard locations for beacons that are not live\n if (!this.isLive) {\n return;\n }\n\n const validLocationEvents = beaconLocationEvents.filter((event) => {\n const content = event.getContent();\n const parsed = parseBeaconContent(content);\n if (!parsed.uri || !parsed.timestamp) return false; // we won't be able to process these\n const { timestamp } = parsed;\n return (\n this._beaconInfo.timestamp &&\n // only include positions that were taken inside the beacon's live period\n isTimestampInDuration(this._beaconInfo.timestamp, this._beaconInfo.timeout, timestamp) &&\n // ignore positions older than our current latest location\n (!this.latestLocationState || timestamp > this.latestLocationState.timestamp!)\n );\n });\n const latestLocationEvent = validLocationEvents.sort(sortEventsByLatestContentTimestamp)?.[0];\n\n if (latestLocationEvent) {\n this._latestLocationEvent = latestLocationEvent;\n this.emit(BeaconEvent.LocationUpdate, this.latestLocationState!);\n }\n }\n\n private clearLatestLocation = (): void => {\n this._latestLocationEvent = undefined;\n this.emit(BeaconEvent.LocationUpdate, this.latestLocationState!);\n };\n\n private setBeaconInfo(event: MatrixEvent): void {\n this._beaconInfo = parseBeaconInfoContent(event.getContent());\n this.checkLiveness();\n }\n\n private checkLiveness(): void {\n const prevLiveness = this.isLive;\n\n // element web sets a beacon's start timestamp to the senders local current time\n // when Alice's system clock deviates slightly from Bob's a beacon Alice intended to be live\n // may have a start timestamp in the future from Bob's POV\n // handle this by adding 6min of leniency to the start timestamp when it is in the future\n if (!this.beaconInfo) return;\n const startTimestamp =\n this.beaconInfo.timestamp! > Date.now()\n ? this.beaconInfo.timestamp! - 360000 /* 6min */\n : this.beaconInfo.timestamp;\n this._isLive =\n !!this._beaconInfo.live &&\n !!startTimestamp &&\n isTimestampInDuration(startTimestamp, this._beaconInfo.timeout, Date.now());\n\n if (prevLiveness !== this.isLive) {\n this.emit(BeaconEvent.LivenessChange, this.isLive, this);\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts deleted file mode 100644 index 2b5b748..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts +++ /dev/null @@ -1,62 +0,0 @@ -import { MatrixEvent } from "./event"; -export declare class EventContext { - readonly ourEvent: MatrixEvent; - private timeline; - private ourEventIndex; - private paginateTokens; - /** - * Construct a new EventContext - * - * An eventcontext is used for circumstances such as search results, when we - * have a particular event of interest, and a bunch of events before and after - * it. - * - * It also stores pagination tokens for going backwards and forwards in the - * timeline. - * - * @param ourEvent - the event at the centre of this context - */ - constructor(ourEvent: MatrixEvent); - /** - * Get the main event of interest - * - * This is a convenience function for getTimeline()[getOurEventIndex()]. - * - * @returns The event at the centre of this context. - */ - getEvent(): MatrixEvent; - /** - * Get the list of events in this context - * - * @returns An array of MatrixEvents - */ - getTimeline(): MatrixEvent[]; - /** - * Get the index in the timeline of our event - */ - getOurEventIndex(): number; - /** - * Get a pagination token. - * - * @param backwards - true to get the pagination token for going - */ - getPaginateToken(backwards?: boolean): string | null; - /** - * Set a pagination token. - * - * Generally this will be used only by the matrix js sdk. - * - * @param token - pagination token - * @param backwards - true to set the pagination token for going - * backwards in time - */ - setPaginateToken(token?: string, backwards?: boolean): void; - /** - * Add more events to the timeline - * - * @param events - new events, in timeline order - * @param atStart - true to insert new events at the start - */ - addEvents(events: MatrixEvent[], atStart?: boolean): void; -} -//# sourceMappingURL=event-context.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts.map deleted file mode 100644 index 7186ddf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-context.d.ts","sourceRoot":"","sources":["../../src/models/event-context.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAGtC,qBAAa,YAAY;aAoBc,QAAQ,EAAE,WAAW;IAnBxD,OAAO,CAAC,QAAQ,CAAgB;IAChC,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,cAAc,CAGpB;IAEF;;;;;;;;;;;OAWG;gBACgC,QAAQ,EAAE,WAAW;IAIxD;;;;;;OAMG;IACI,QAAQ,IAAI,WAAW;IAI9B;;;;OAIG;IACI,WAAW,IAAI,WAAW,EAAE;IAInC;;OAEG;IACI,gBAAgB,IAAI,MAAM;IAIjC;;;;OAIG;IACI,gBAAgB,CAAC,SAAS,UAAQ,GAAG,MAAM,GAAG,IAAI;IAIzD;;;;;;;;OAQG;IACI,gBAAgB,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,SAAS,UAAQ,GAAG,IAAI;IAIhE;;;;;OAKG;IACI,SAAS,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE,OAAO,UAAQ,GAAG,IAAI;CAWjE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js deleted file mode 100644 index a6f5ca9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js +++ /dev/null @@ -1,118 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.EventContext = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _eventTimeline = require("./event-timeline"); -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class EventContext { - /** - * Construct a new EventContext - * - * An eventcontext is used for circumstances such as search results, when we - * have a particular event of interest, and a bunch of events before and after - * it. - * - * It also stores pagination tokens for going backwards and forwards in the - * timeline. - * - * @param ourEvent - the event at the centre of this context - */ - constructor(ourEvent) { - this.ourEvent = ourEvent; - (0, _defineProperty2.default)(this, "timeline", void 0); - (0, _defineProperty2.default)(this, "ourEventIndex", 0); - (0, _defineProperty2.default)(this, "paginateTokens", { - [_eventTimeline.Direction.Backward]: null, - [_eventTimeline.Direction.Forward]: null - }); - this.timeline = [ourEvent]; - } - - /** - * Get the main event of interest - * - * This is a convenience function for getTimeline()[getOurEventIndex()]. - * - * @returns The event at the centre of this context. - */ - getEvent() { - return this.timeline[this.ourEventIndex]; - } - - /** - * Get the list of events in this context - * - * @returns An array of MatrixEvents - */ - getTimeline() { - return this.timeline; - } - - /** - * Get the index in the timeline of our event - */ - getOurEventIndex() { - return this.ourEventIndex; - } - - /** - * Get a pagination token. - * - * @param backwards - true to get the pagination token for going - */ - getPaginateToken(backwards = false) { - return this.paginateTokens[backwards ? _eventTimeline.Direction.Backward : _eventTimeline.Direction.Forward]; - } - - /** - * Set a pagination token. - * - * Generally this will be used only by the matrix js sdk. - * - * @param token - pagination token - * @param backwards - true to set the pagination token for going - * backwards in time - */ - setPaginateToken(token, backwards = false) { - this.paginateTokens[backwards ? _eventTimeline.Direction.Backward : _eventTimeline.Direction.Forward] = token !== null && token !== void 0 ? token : null; - } - - /** - * Add more events to the timeline - * - * @param events - new events, in timeline order - * @param atStart - true to insert new events at the start - */ - addEvents(events, atStart = false) { - // TODO: should we share logic with Room.addEventsToTimeline? - // Should Room even use EventContext? - - if (atStart) { - this.timeline = events.concat(this.timeline); - this.ourEventIndex += events.length; - } else { - this.timeline = this.timeline.concat(events); - } - } -} -exports.EventContext = EventContext; -//# sourceMappingURL=event-context.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js.map deleted file mode 100644 index 17df5b8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-context.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-context.js","names":["_eventTimeline","require","EventContext","constructor","ourEvent","_defineProperty2","default","Direction","Backward","Forward","timeline","getEvent","ourEventIndex","getTimeline","getOurEventIndex","getPaginateToken","backwards","paginateTokens","setPaginateToken","token","addEvents","events","atStart","concat","length","exports"],"sources":["../../src/models/event-context.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixEvent } from \"./event\";\nimport { Direction } from \"./event-timeline\";\n\nexport class EventContext {\n private timeline: MatrixEvent[];\n private ourEventIndex = 0;\n private paginateTokens: Record = {\n [Direction.Backward]: null,\n [Direction.Forward]: null,\n };\n\n /**\n * Construct a new EventContext\n *\n * An eventcontext is used for circumstances such as search results, when we\n * have a particular event of interest, and a bunch of events before and after\n * it.\n *\n * It also stores pagination tokens for going backwards and forwards in the\n * timeline.\n *\n * @param ourEvent - the event at the centre of this context\n */\n public constructor(public readonly ourEvent: MatrixEvent) {\n this.timeline = [ourEvent];\n }\n\n /**\n * Get the main event of interest\n *\n * This is a convenience function for getTimeline()[getOurEventIndex()].\n *\n * @returns The event at the centre of this context.\n */\n public getEvent(): MatrixEvent {\n return this.timeline[this.ourEventIndex];\n }\n\n /**\n * Get the list of events in this context\n *\n * @returns An array of MatrixEvents\n */\n public getTimeline(): MatrixEvent[] {\n return this.timeline;\n }\n\n /**\n * Get the index in the timeline of our event\n */\n public getOurEventIndex(): number {\n return this.ourEventIndex;\n }\n\n /**\n * Get a pagination token.\n *\n * @param backwards - true to get the pagination token for going\n */\n public getPaginateToken(backwards = false): string | null {\n return this.paginateTokens[backwards ? Direction.Backward : Direction.Forward];\n }\n\n /**\n * Set a pagination token.\n *\n * Generally this will be used only by the matrix js sdk.\n *\n * @param token - pagination token\n * @param backwards - true to set the pagination token for going\n * backwards in time\n */\n public setPaginateToken(token?: string, backwards = false): void {\n this.paginateTokens[backwards ? Direction.Backward : Direction.Forward] = token ?? null;\n }\n\n /**\n * Add more events to the timeline\n *\n * @param events - new events, in timeline order\n * @param atStart - true to insert new events at the start\n */\n public addEvents(events: MatrixEvent[], atStart = false): void {\n // TODO: should we share logic with Room.addEventsToTimeline?\n // Should Room even use EventContext?\n\n if (atStart) {\n this.timeline = events.concat(this.timeline);\n this.ourEventIndex += events.length;\n } else {\n this.timeline = this.timeline.concat(events);\n }\n }\n}\n"],"mappings":";;;;;;;;AAiBA,IAAAA,cAAA,GAAAC,OAAA;AAjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAKO,MAAMC,YAAY,CAAC;EAQtB;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACWC,WAAWA,CAAiBC,QAAqB,EAAE;IAAA,KAAvBA,QAAqB,GAArBA,QAAqB;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,yBAlBhC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,0BACkC;MACvD,CAACC,wBAAS,CAACC,QAAQ,GAAG,IAAI;MAC1B,CAACD,wBAAS,CAACE,OAAO,GAAG;IACzB,CAAC;IAeG,IAAI,CAACC,QAAQ,GAAG,CAACN,QAAQ,CAAC;EAC9B;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;EACWO,QAAQA,CAAA,EAAgB;IAC3B,OAAO,IAAI,CAACD,QAAQ,CAAC,IAAI,CAACE,aAAa,CAAC;EAC5C;;EAEA;AACJ;AACA;AACA;AACA;EACWC,WAAWA,CAAA,EAAkB;IAChC,OAAO,IAAI,CAACH,QAAQ;EACxB;;EAEA;AACJ;AACA;EACWI,gBAAgBA,CAAA,EAAW;IAC9B,OAAO,IAAI,CAACF,aAAa;EAC7B;;EAEA;AACJ;AACA;AACA;AACA;EACWG,gBAAgBA,CAACC,SAAS,GAAG,KAAK,EAAiB;IACtD,OAAO,IAAI,CAACC,cAAc,CAACD,SAAS,GAAGT,wBAAS,CAACC,QAAQ,GAAGD,wBAAS,CAACE,OAAO,CAAC;EAClF;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACWS,gBAAgBA,CAACC,KAAc,EAAEH,SAAS,GAAG,KAAK,EAAQ;IAC7D,IAAI,CAACC,cAAc,CAACD,SAAS,GAAGT,wBAAS,CAACC,QAAQ,GAAGD,wBAAS,CAACE,OAAO,CAAC,GAAGU,KAAK,aAALA,KAAK,cAALA,KAAK,GAAI,IAAI;EAC3F;;EAEA;AACJ;AACA;AACA;AACA;AACA;EACWC,SAASA,CAACC,MAAqB,EAAEC,OAAO,GAAG,KAAK,EAAQ;IAC3D;IACA;;IAEA,IAAIA,OAAO,EAAE;MACT,IAAI,CAACZ,QAAQ,GAAGW,MAAM,CAACE,MAAM,CAAC,IAAI,CAACb,QAAQ,CAAC;MAC5C,IAAI,CAACE,aAAa,IAAIS,MAAM,CAACG,MAAM;IACvC,CAAC,MAAM;MACH,IAAI,CAACd,QAAQ,GAAG,IAAI,CAACA,QAAQ,CAACa,MAAM,CAACF,MAAM,CAAC;IAChD;EACJ;AACJ;AAACI,OAAA,CAAAvB,YAAA,GAAAA,YAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts deleted file mode 100644 index 1f438ab..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts +++ /dev/null @@ -1,19 +0,0 @@ -/** - * Enum for event statuses. - * @readonly - */ -export declare enum EventStatus { - /** The event was not sent and will no longer be retried. */ - NOT_SENT = "not_sent", - /** The message is being encrypted */ - ENCRYPTING = "encrypting", - /** The event is in the process of being sent. */ - SENDING = "sending", - /** The event is in a queue waiting to be sent. */ - QUEUED = "queued", - /** The event has been sent to the server, but we have not yet received the echo. */ - SENT = "sent", - /** The event was cancelled before it was successfully sent. */ - CANCELLED = "cancelled" -} -//# sourceMappingURL=event-status.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts.map deleted file mode 100644 index f5bcc04..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-status.d.ts","sourceRoot":"","sources":["../../src/models/event-status.ts"],"names":[],"mappings":"AAgBA;;;GAGG;AACH,oBAAY,WAAW;IACnB,4DAA4D;IAC5D,QAAQ,aAAa;IAErB,qCAAqC;IACrC,UAAU,eAAe;IAEzB,iDAAiD;IACjD,OAAO,YAAY;IAEnB,kDAAkD;IAClD,MAAM,WAAW;IAEjB,oFAAoF;IACpF,IAAI,SAAS;IAEb,+DAA+D;IAC/D,SAAS,cAAc;CAC1B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js deleted file mode 100644 index 4c279af..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js +++ /dev/null @@ -1,36 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.EventStatus = void 0; -/* -Copyright 2015 - 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -/** - * Enum for event statuses. - * @readonly - */ -let EventStatus; -exports.EventStatus = EventStatus; -(function (EventStatus) { - EventStatus["NOT_SENT"] = "not_sent"; - EventStatus["ENCRYPTING"] = "encrypting"; - EventStatus["SENDING"] = "sending"; - EventStatus["QUEUED"] = "queued"; - EventStatus["SENT"] = "sent"; - EventStatus["CANCELLED"] = "cancelled"; -})(EventStatus || (exports.EventStatus = EventStatus = {})); -//# sourceMappingURL=event-status.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js.map deleted file mode 100644 index 3fdca8d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-status.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-status.js","names":["EventStatus","exports"],"sources":["../../src/models/event-status.ts"],"sourcesContent":["/*\nCopyright 2015 - 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Enum for event statuses.\n * @readonly\n */\nexport enum EventStatus {\n /** The event was not sent and will no longer be retried. */\n NOT_SENT = \"not_sent\",\n\n /** The message is being encrypted */\n ENCRYPTING = \"encrypting\",\n\n /** The event is in the process of being sent. */\n SENDING = \"sending\",\n\n /** The event is in a queue waiting to be sent. */\n QUEUED = \"queued\",\n\n /** The event has been sent to the server, but we have not yet received the echo. */\n SENT = \"sent\",\n\n /** The event was cancelled before it was successfully sent. */\n CANCELLED = \"cancelled\",\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAHA,IAIYA,WAAW;AAAAC,OAAA,CAAAD,WAAA,GAAAA,WAAA;AAAA,WAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;AAAA,GAAXA,WAAW,KAAAC,OAAA,CAAAD,WAAA,GAAXA,WAAW"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts deleted file mode 100644 index 88bddd6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts +++ /dev/null @@ -1,296 +0,0 @@ -import { EventTimeline, IAddEventOptions } from "./event-timeline"; -import { MatrixEvent } from "./event"; -import { Room, RoomEvent } from "./room"; -import { Filter } from "../filter"; -import { RoomState } from "./room-state"; -import { TypedEventEmitter } from "./typed-event-emitter"; -import { RelationsContainer } from "./relations-container"; -import { MatrixClient } from "../client"; -import { Thread, ThreadFilterType } from "./thread"; -interface IOpts { - timelineSupport?: boolean; - filter?: Filter; - pendingEvents?: boolean; -} -export declare enum DuplicateStrategy { - Ignore = "ignore", - Replace = "replace" -} -export interface IRoomTimelineData { - timeline: EventTimeline; - liveEvent?: boolean; -} -export interface IAddEventToTimelineOptions extends Pick { - /** Whether the sync response came from cache */ - fromCache?: boolean; -} -export interface IAddLiveEventOptions extends Pick { - /** Applies to events in the timeline only. If this is 'replace' then if a - * duplicate is encountered, the event passed to this function will replace - * the existing event in the timeline. If this is not specified, or is - * 'ignore', then the event passed to this function will be ignored - * entirely, preserving the existing event in the timeline. Events are - * identical based on their event ID only. */ - duplicateStrategy?: DuplicateStrategy; -} -type EmittedEvents = RoomEvent.Timeline | RoomEvent.TimelineReset; -export type EventTimelineSetHandlerMap = { - /** - * Fires whenever the timeline in a room is updated. - * @param event - The matrix event which caused this event to fire. - * @param room - The room, if any, whose timeline was updated. - * @param toStartOfTimeline - True if this event was added to the start - * @param removed - True if this event has just been removed from the timeline - * (beginning; oldest) of the timeline e.g. due to pagination. - * - * @param data - more data about the event - * - * @example - * ``` - * matrixClient.on("Room.timeline", - * function(event, room, toStartOfTimeline, removed, data) { - * if (!toStartOfTimeline && data.liveEvent) { - * var messageToAppend = room.timeline.[room.timeline.length - 1]; - * } - * }); - * ``` - */ - [RoomEvent.Timeline]: (event: MatrixEvent, room: Room | undefined, toStartOfTimeline: boolean | undefined, removed: boolean, data: IRoomTimelineData) => void; - /** - * Fires whenever the live timeline in a room is reset. - * - * When we get a 'limited' sync (for example, after a network outage), we reset - * the live timeline to be empty before adding the recent events to the new - * timeline. This event is fired after the timeline is reset, and before the - * new events are added. - * - * @param room - The room whose live timeline was reset, if any - * @param timelineSet - timelineSet room whose live timeline was reset - * @param resetAllTimelines - True if all timelines were reset. - */ - [RoomEvent.TimelineReset]: (room: Room | undefined, eventTimelineSet: EventTimelineSet, resetAllTimelines: boolean) => void; -}; -export declare class EventTimelineSet extends TypedEventEmitter { - readonly room: Room | undefined; - readonly thread?: Thread | undefined; - readonly threadListType: ThreadFilterType | null; - readonly relations: RelationsContainer; - private readonly timelineSupport; - private readonly displayPendingEvents; - private liveTimeline; - private timelines; - private _eventIdToTimeline; - private filter?; - /** - * Construct a set of EventTimeline objects, typically on behalf of a given - * room. A room may have multiple EventTimelineSets for different levels - * of filtering. The global notification list is also an EventTimelineSet, but - * lacks a room. - * - *

This is an ordered sequence of timelines, which may or may not - * be continuous. Each timeline lists a series of events, as well as tracking - * the room state at the start and the end of the timeline (if appropriate). - * It also tracks forward and backward pagination tokens, as well as containing - * links to the next timeline in the sequence. - * - *

There is one special timeline - the 'live' timeline, which represents the - * timeline to which events are being added in real-time as they are received - * from the /sync API. Note that you should not retain references to this - * timeline - even if it is the current timeline right now, it may not remain - * so if the server gives us a timeline gap in /sync. - * - *

In order that we can find events from their ids later, we also maintain a - * map from event_id to timeline and index. - * - * @param room - Room for this timelineSet. May be null for non-room cases, such as the - * notification timeline. - * @param opts - Options inherited from Room. - * @param client - the Matrix client which owns this EventTimelineSet, - * can be omitted if room is specified. - * @param thread - the thread to which this timeline set relates. - * @param isThreadTimeline - Whether this timeline set relates to a thread list timeline - * (e.g., All threads or My threads) - */ - constructor(room: Room | undefined, opts?: IOpts, client?: MatrixClient, thread?: Thread | undefined, threadListType?: ThreadFilterType | null); - /** - * Get all the timelines in this set - * @returns the timelines in this set - */ - getTimelines(): EventTimeline[]; - /** - * Get the filter object this timeline set is filtered on, if any - * @returns the optional filter for this timelineSet - */ - getFilter(): Filter | undefined; - /** - * Set the filter object this timeline set is filtered on - * (passed to the server when paginating via /messages). - * @param filter - the filter for this timelineSet - */ - setFilter(filter?: Filter): void; - /** - * Get the list of pending sent events for this timelineSet's room, filtered - * by the timelineSet's filter if appropriate. - * - * @returns A list of the sent events - * waiting for remote echo. - * - * @throws If `opts.pendingEventOrdering` was not 'detached' - */ - getPendingEvents(): MatrixEvent[]; - /** - * Get the live timeline for this room. - * - * @returns live timeline - */ - getLiveTimeline(): EventTimeline; - /** - * Set the live timeline for this room. - * - * @returns live timeline - */ - setLiveTimeline(timeline: EventTimeline): void; - /** - * Return the timeline (if any) this event is in. - * @param eventId - the eventId being sought - * @returns timeline - */ - eventIdToTimeline(eventId: string): EventTimeline | undefined; - /** - * Track a new event as if it were in the same timeline as an old event, - * replacing it. - * @param oldEventId - event ID of the original event - * @param newEventId - event ID of the replacement event - */ - replaceEventId(oldEventId: string, newEventId: string): void; - /** - * Reset the live timeline, and start a new one. - * - *

This is used when /sync returns a 'limited' timeline. - * - * @param backPaginationToken - token for back-paginating the new timeline - * @param forwardPaginationToken - token for forward-paginating the old live timeline, - * if absent or null, all timelines are reset. - * - * @remarks - * Fires {@link RoomEvent.TimelineReset} - */ - resetLiveTimeline(backPaginationToken?: string, forwardPaginationToken?: string): void; - /** - * Get the timeline which contains the given event, if any - * - * @param eventId - event ID to look for - * @returns timeline containing - * the given event, or null if unknown - */ - getTimelineForEvent(eventId?: string): EventTimeline | null; - /** - * Get an event which is stored in our timelines - * - * @param eventId - event ID to look for - * @returns the given event, or undefined if unknown - */ - findEventById(eventId: string): MatrixEvent | undefined; - /** - * Add a new timeline to this timeline list - * - * @returns newly-created timeline - */ - addTimeline(): EventTimeline; - /** - * Add events to a timeline - * - *

Will fire "Room.timeline" for each event added. - * - * @param events - A list of events to add. - * - * @param toStartOfTimeline - True to add these events to the start - * (oldest) instead of the end (newest) of the timeline. If true, the oldest - * event will be the last element of 'events'. - * - * @param timeline - timeline to - * add events to. - * - * @param paginationToken - token for the next batch of events - * - * @remarks - * Fires {@link RoomEvent.Timeline} - * - */ - addEventsToTimeline(events: MatrixEvent[], toStartOfTimeline: boolean, timeline: EventTimeline, paginationToken?: string | null): void; - /** - * Add an event to the end of this live timeline. - * - * @param event - Event to be added - * @param options - addLiveEvent options - */ - addLiveEvent(event: MatrixEvent, { duplicateStrategy, fromCache, roomState, timelineWasEmpty }: IAddLiveEventOptions): void; - /** - * @deprecated In favor of the overload with `IAddLiveEventOptions` - */ - addLiveEvent(event: MatrixEvent, duplicateStrategy?: DuplicateStrategy, fromCache?: boolean, roomState?: RoomState): void; - /** - * Add event to the given timeline, and emit Room.timeline. Assumes - * we have already checked we don't know about this event. - * - * Will fire "Room.timeline" for each event added. - * - * @param options - addEventToTimeline options - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - addEventToTimeline(event: MatrixEvent, timeline: EventTimeline, { toStartOfTimeline, fromCache, roomState, timelineWasEmpty }: IAddEventToTimelineOptions): void; - /** - * @deprecated In favor of the overload with `IAddEventToTimelineOptions` - */ - addEventToTimeline(event: MatrixEvent, timeline: EventTimeline, toStartOfTimeline: boolean, fromCache?: boolean, roomState?: RoomState): void; - /** - * Replaces event with ID oldEventId with one with newEventId, if oldEventId is - * recognised. Otherwise, add to the live timeline. Used to handle remote echos. - * - * @param localEvent - the new event to be added to the timeline - * @param oldEventId - the ID of the original event - * @param newEventId - the ID of the replacement event - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - handleRemoteEcho(localEvent: MatrixEvent, oldEventId: string, newEventId: string): void; - /** - * Removes a single event from this room. - * - * @param eventId - The id of the event to remove - * - * @returns the removed event, or null if the event was not found - * in this room. - */ - removeEvent(eventId: string): MatrixEvent | null; - /** - * Determine where two events appear in the timeline relative to one another - * - * @param eventId1 - The id of the first event - * @param eventId2 - The id of the second event - - * @returns a number less than zero if eventId1 precedes eventId2, and - * greater than zero if eventId1 succeeds eventId2. zero if they are the - * same event; null if we can't tell (either because we don't know about one - * of the events, or because they are in separate timelines which don't join - * up). - */ - compareEventOrdering(eventId1: string, eventId2: string): number | null; - /** - * Determine whether a given event can sanely be added to this event timeline set, - * for timeline sets relating to a thread, only return true for events in the same - * thread timeline, for timeline sets not relating to a thread only return true - * for events which should be shown in the main room timeline. - * Requires the `room` property to have been set at EventTimelineSet construction time. - * - * @param event - the event to check whether it belongs to this timeline set. - * @throws Error if `room` was not set when constructing this timeline set. - * @returns whether the event belongs to this timeline set. - */ - canContain(event: MatrixEvent): boolean; -} -export {}; -//# sourceMappingURL=event-timeline-set.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts.map deleted file mode 100644 index 20d2e64..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-timeline-set.d.ts","sourceRoot":"","sources":["../../src/models/event-timeline-set.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js deleted file mode 100644 index b0f08b7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js +++ /dev/null @@ -1,725 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.EventTimelineSet = exports.DuplicateStrategy = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _eventTimeline = require("./event-timeline"); -var _logger = require("../logger"); -var _room = require("./room"); -var _typedEventEmitter = require("./typed-event-emitter"); -var _relationsContainer = require("./relations-container"); -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const DEBUG = true; - -/* istanbul ignore next */ -let debuglog; -if (DEBUG) { - // using bind means that we get to keep useful line numbers in the console - debuglog = _logger.logger.log.bind(_logger.logger); -} else { - /* istanbul ignore next */ - debuglog = function () {}; -} -let DuplicateStrategy; -exports.DuplicateStrategy = DuplicateStrategy; -(function (DuplicateStrategy) { - DuplicateStrategy["Ignore"] = "ignore"; - DuplicateStrategy["Replace"] = "replace"; -})(DuplicateStrategy || (exports.DuplicateStrategy = DuplicateStrategy = {})); -class EventTimelineSet extends _typedEventEmitter.TypedEventEmitter { - /** - * Construct a set of EventTimeline objects, typically on behalf of a given - * room. A room may have multiple EventTimelineSets for different levels - * of filtering. The global notification list is also an EventTimelineSet, but - * lacks a room. - * - *

This is an ordered sequence of timelines, which may or may not - * be continuous. Each timeline lists a series of events, as well as tracking - * the room state at the start and the end of the timeline (if appropriate). - * It also tracks forward and backward pagination tokens, as well as containing - * links to the next timeline in the sequence. - * - *

There is one special timeline - the 'live' timeline, which represents the - * timeline to which events are being added in real-time as they are received - * from the /sync API. Note that you should not retain references to this - * timeline - even if it is the current timeline right now, it may not remain - * so if the server gives us a timeline gap in /sync. - * - *

In order that we can find events from their ids later, we also maintain a - * map from event_id to timeline and index. - * - * @param room - Room for this timelineSet. May be null for non-room cases, such as the - * notification timeline. - * @param opts - Options inherited from Room. - * @param client - the Matrix client which owns this EventTimelineSet, - * can be omitted if room is specified. - * @param thread - the thread to which this timeline set relates. - * @param isThreadTimeline - Whether this timeline set relates to a thread list timeline - * (e.g., All threads or My threads) - */ - constructor(room, opts = {}, client, thread, threadListType = null) { - var _this$room$relations, _this$room, _room$client; - super(); - this.room = room; - this.thread = thread; - this.threadListType = threadListType; - (0, _defineProperty2.default)(this, "relations", void 0); - (0, _defineProperty2.default)(this, "timelineSupport", void 0); - (0, _defineProperty2.default)(this, "displayPendingEvents", void 0); - (0, _defineProperty2.default)(this, "liveTimeline", void 0); - (0, _defineProperty2.default)(this, "timelines", void 0); - (0, _defineProperty2.default)(this, "_eventIdToTimeline", new Map()); - (0, _defineProperty2.default)(this, "filter", void 0); - this.timelineSupport = Boolean(opts.timelineSupport); - this.liveTimeline = new _eventTimeline.EventTimeline(this); - this.displayPendingEvents = opts.pendingEvents !== false; - - // just a list - *not* ordered. - this.timelines = [this.liveTimeline]; - this._eventIdToTimeline = new Map(); - this.filter = opts.filter; - this.relations = (_this$room$relations = (_this$room = this.room) === null || _this$room === void 0 ? void 0 : _this$room.relations) !== null && _this$room$relations !== void 0 ? _this$room$relations : new _relationsContainer.RelationsContainer((_room$client = room === null || room === void 0 ? void 0 : room.client) !== null && _room$client !== void 0 ? _room$client : client); - } - - /** - * Get all the timelines in this set - * @returns the timelines in this set - */ - getTimelines() { - return this.timelines; - } - - /** - * Get the filter object this timeline set is filtered on, if any - * @returns the optional filter for this timelineSet - */ - getFilter() { - return this.filter; - } - - /** - * Set the filter object this timeline set is filtered on - * (passed to the server when paginating via /messages). - * @param filter - the filter for this timelineSet - */ - setFilter(filter) { - this.filter = filter; - } - - /** - * Get the list of pending sent events for this timelineSet's room, filtered - * by the timelineSet's filter if appropriate. - * - * @returns A list of the sent events - * waiting for remote echo. - * - * @throws If `opts.pendingEventOrdering` was not 'detached' - */ - getPendingEvents() { - if (!this.room || !this.displayPendingEvents) { - return []; - } - return this.room.getPendingEvents(); - } - /** - * Get the live timeline for this room. - * - * @returns live timeline - */ - getLiveTimeline() { - return this.liveTimeline; - } - - /** - * Set the live timeline for this room. - * - * @returns live timeline - */ - setLiveTimeline(timeline) { - this.liveTimeline = timeline; - } - - /** - * Return the timeline (if any) this event is in. - * @param eventId - the eventId being sought - * @returns timeline - */ - eventIdToTimeline(eventId) { - return this._eventIdToTimeline.get(eventId); - } - - /** - * Track a new event as if it were in the same timeline as an old event, - * replacing it. - * @param oldEventId - event ID of the original event - * @param newEventId - event ID of the replacement event - */ - replaceEventId(oldEventId, newEventId) { - const existingTimeline = this._eventIdToTimeline.get(oldEventId); - if (existingTimeline) { - this._eventIdToTimeline.delete(oldEventId); - this._eventIdToTimeline.set(newEventId, existingTimeline); - } - } - - /** - * Reset the live timeline, and start a new one. - * - *

This is used when /sync returns a 'limited' timeline. - * - * @param backPaginationToken - token for back-paginating the new timeline - * @param forwardPaginationToken - token for forward-paginating the old live timeline, - * if absent or null, all timelines are reset. - * - * @remarks - * Fires {@link RoomEvent.TimelineReset} - */ - resetLiveTimeline(backPaginationToken, forwardPaginationToken) { - // Each EventTimeline has RoomState objects tracking the state at the start - // and end of that timeline. The copies at the end of the live timeline are - // special because they will have listeners attached to monitor changes to - // the current room state, so we move this RoomState from the end of the - // current live timeline to the end of the new one and, if necessary, - // replace it with a newly created one. We also make a copy for the start - // of the new timeline. - - // if timeline support is disabled, forget about the old timelines - const resetAllTimelines = !this.timelineSupport || !forwardPaginationToken; - const oldTimeline = this.liveTimeline; - const newTimeline = resetAllTimelines ? oldTimeline.forkLive(_eventTimeline.EventTimeline.FORWARDS) : oldTimeline.fork(_eventTimeline.EventTimeline.FORWARDS); - if (resetAllTimelines) { - this.timelines = [newTimeline]; - this._eventIdToTimeline = new Map(); - } else { - this.timelines.push(newTimeline); - } - if (forwardPaginationToken) { - // Now set the forward pagination token on the old live timeline - // so it can be forward-paginated. - oldTimeline.setPaginationToken(forwardPaginationToken, _eventTimeline.EventTimeline.FORWARDS); - } - - // make sure we set the pagination token before firing timelineReset, - // otherwise clients which start back-paginating will fail, and then get - // stuck without realising that they *can* back-paginate. - newTimeline.setPaginationToken(backPaginationToken !== null && backPaginationToken !== void 0 ? backPaginationToken : null, _eventTimeline.EventTimeline.BACKWARDS); - - // Now we can swap the live timeline to the new one. - this.liveTimeline = newTimeline; - this.emit(_room.RoomEvent.TimelineReset, this.room, this, resetAllTimelines); - } - - /** - * Get the timeline which contains the given event, if any - * - * @param eventId - event ID to look for - * @returns timeline containing - * the given event, or null if unknown - */ - getTimelineForEvent(eventId) { - if (eventId === null || eventId === undefined) { - return null; - } - const res = this._eventIdToTimeline.get(eventId); - return res === undefined ? null : res; - } - - /** - * Get an event which is stored in our timelines - * - * @param eventId - event ID to look for - * @returns the given event, or undefined if unknown - */ - findEventById(eventId) { - const tl = this.getTimelineForEvent(eventId); - if (!tl) { - return undefined; - } - return tl.getEvents().find(function (ev) { - return ev.getId() == eventId; - }); - } - - /** - * Add a new timeline to this timeline list - * - * @returns newly-created timeline - */ - addTimeline() { - if (!this.timelineSupport) { - throw new Error("timeline support is disabled. Set the 'timelineSupport'" + " parameter to true when creating MatrixClient to enable" + " it."); - } - const timeline = new _eventTimeline.EventTimeline(this); - this.timelines.push(timeline); - return timeline; - } - - /** - * Add events to a timeline - * - *

Will fire "Room.timeline" for each event added. - * - * @param events - A list of events to add. - * - * @param toStartOfTimeline - True to add these events to the start - * (oldest) instead of the end (newest) of the timeline. If true, the oldest - * event will be the last element of 'events'. - * - * @param timeline - timeline to - * add events to. - * - * @param paginationToken - token for the next batch of events - * - * @remarks - * Fires {@link RoomEvent.Timeline} - * - */ - addEventsToTimeline(events, toStartOfTimeline, timeline, paginationToken) { - if (!timeline) { - throw new Error("'timeline' not specified for EventTimelineSet.addEventsToTimeline"); - } - if (!toStartOfTimeline && timeline == this.liveTimeline) { - throw new Error("EventTimelineSet.addEventsToTimeline cannot be used for adding events to " + "the live timeline - use Room.addLiveEvents instead"); - } - if (this.filter) { - events = this.filter.filterRoomTimeline(events); - if (!events.length) { - return; - } - } - const direction = toStartOfTimeline ? _eventTimeline.EventTimeline.BACKWARDS : _eventTimeline.EventTimeline.FORWARDS; - const inverseDirection = toStartOfTimeline ? _eventTimeline.EventTimeline.FORWARDS : _eventTimeline.EventTimeline.BACKWARDS; - - // Adding events to timelines can be quite complicated. The following - // illustrates some of the corner-cases. - // - // Let's say we start by knowing about four timelines. timeline3 and - // timeline4 are neighbours: - // - // timeline1 timeline2 timeline3 timeline4 - // [M] [P] [S] <------> [T] - // - // Now we paginate timeline1, and get the following events from the server: - // [M, N, P, R, S, T, U]. - // - // 1. First, we ignore event M, since we already know about it. - // - // 2. Next, we append N to timeline 1. - // - // 3. Next, we don't add event P, since we already know about it, - // but we do link together the timelines. We now have: - // - // timeline1 timeline2 timeline3 timeline4 - // [M, N] <---> [P] [S] <------> [T] - // - // 4. Now we add event R to timeline2: - // - // timeline1 timeline2 timeline3 timeline4 - // [M, N] <---> [P, R] [S] <------> [T] - // - // Note that we have switched the timeline we are working on from - // timeline1 to timeline2. - // - // 5. We ignore event S, but again join the timelines: - // - // timeline1 timeline2 timeline3 timeline4 - // [M, N] <---> [P, R] <---> [S] <------> [T] - // - // 6. We ignore event T, and the timelines are already joined, so there - // is nothing to do. - // - // 7. Finally, we add event U to timeline4: - // - // timeline1 timeline2 timeline3 timeline4 - // [M, N] <---> [P, R] <---> [S] <------> [T, U] - // - // The important thing to note in the above is what happened when we - // already knew about a given event: - // - // - if it was appropriate, we joined up the timelines (steps 3, 5). - // - in any case, we started adding further events to the timeline which - // contained the event we knew about (steps 3, 5, 6). - // - // - // So much for adding events to the timeline. But what do we want to do - // with the pagination token? - // - // In the case above, we will be given a pagination token which tells us how to - // get events beyond 'U' - in this case, it makes sense to store this - // against timeline4. But what if timeline4 already had 'U' and beyond? in - // that case, our best bet is to throw away the pagination token we were - // given and stick with whatever token timeline4 had previously. In short, - // we want to only store the pagination token if the last event we receive - // is one we didn't previously know about. - // - // We make an exception for this if it turns out that we already knew about - // *all* of the events, and we weren't able to join up any timelines. When - // that happens, it means our existing pagination token is faulty, since it - // is only telling us what we already know. Rather than repeatedly - // paginating with the same token, we might as well use the new pagination - // token in the hope that we eventually work our way out of the mess. - - let didUpdate = false; - let lastEventWasNew = false; - for (const event of events) { - const eventId = event.getId(); - const existingTimeline = this._eventIdToTimeline.get(eventId); - if (!existingTimeline) { - // we don't know about this event yet. Just add it to the timeline. - this.addEventToTimeline(event, timeline, { - toStartOfTimeline - }); - lastEventWasNew = true; - didUpdate = true; - continue; - } - lastEventWasNew = false; - if (existingTimeline == timeline) { - debuglog("Event " + eventId + " already in timeline " + timeline); - continue; - } - const neighbour = timeline.getNeighbouringTimeline(direction); - if (neighbour) { - // this timeline already has a neighbour in the relevant direction; - // let's assume the timelines are already correctly linked up, and - // skip over to it. - // - // there's probably some edge-case here where we end up with an - // event which is in a timeline a way down the chain, and there is - // a break in the chain somewhere. But I can't really imagine how - // that would happen, so I'm going to ignore it for now. - // - if (existingTimeline == neighbour) { - debuglog("Event " + eventId + " in neighbouring timeline - " + "switching to " + existingTimeline); - } else { - debuglog("Event " + eventId + " already in a different " + "timeline " + existingTimeline); - } - timeline = existingTimeline; - continue; - } - - // time to join the timelines. - _logger.logger.info("Already have timeline for " + eventId + " - joining timeline " + timeline + " to " + existingTimeline); - - // Variables to keep the line length limited below. - const existingIsLive = existingTimeline === this.liveTimeline; - const timelineIsLive = timeline === this.liveTimeline; - const backwardsIsLive = direction === _eventTimeline.EventTimeline.BACKWARDS && existingIsLive; - const forwardsIsLive = direction === _eventTimeline.EventTimeline.FORWARDS && timelineIsLive; - if (backwardsIsLive || forwardsIsLive) { - // The live timeline should never be spliced into a non-live position. - // We use independent logging to better discover the problem at a glance. - if (backwardsIsLive) { - _logger.logger.warn("Refusing to set a preceding existingTimeLine on our " + "timeline as the existingTimeLine is live (" + existingTimeline + ")"); - } - if (forwardsIsLive) { - _logger.logger.warn("Refusing to set our preceding timeline on a existingTimeLine " + "as our timeline is live (" + timeline + ")"); - } - continue; // abort splicing - try next event - } - - timeline.setNeighbouringTimeline(existingTimeline, direction); - existingTimeline.setNeighbouringTimeline(timeline, inverseDirection); - timeline = existingTimeline; - didUpdate = true; - } - - // see above - if the last event was new to us, or if we didn't find any - // new information, we update the pagination token for whatever - // timeline we ended up on. - if (lastEventWasNew || !didUpdate) { - if (direction === _eventTimeline.EventTimeline.FORWARDS && timeline === this.liveTimeline) { - _logger.logger.warn({ - lastEventWasNew, - didUpdate - }); // for debugging - _logger.logger.warn(`Refusing to set forwards pagination token of live timeline ` + `${timeline} to ${paginationToken}`); - return; - } - timeline.setPaginationToken(paginationToken !== null && paginationToken !== void 0 ? paginationToken : null, direction); - } - } - - /** - * Add an event to the end of this live timeline. - * - * @param event - Event to be added - * @param options - addLiveEvent options - */ - - addLiveEvent(event, duplicateStrategyOrOpts, fromCache = false, roomState) { - let duplicateStrategy = duplicateStrategyOrOpts || DuplicateStrategy.Ignore; - let timelineWasEmpty; - if (typeof duplicateStrategyOrOpts === "object") { - ({ - duplicateStrategy = DuplicateStrategy.Ignore, - fromCache = false, - roomState, - timelineWasEmpty - } = duplicateStrategyOrOpts); - } else if (duplicateStrategyOrOpts !== undefined) { - // Deprecation warning - // FIXME: Remove after 2023-06-01 (technical debt) - _logger.logger.warn("Overload deprecated: " + "`EventTimelineSet.addLiveEvent(event, duplicateStrategy?, fromCache?, roomState?)` " + "is deprecated in favor of the overload with " + "`EventTimelineSet.addLiveEvent(event, IAddLiveEventOptions)`"); - } - if (this.filter) { - const events = this.filter.filterRoomTimeline([event]); - if (!events.length) { - return; - } - } - const timeline = this._eventIdToTimeline.get(event.getId()); - if (timeline) { - if (duplicateStrategy === DuplicateStrategy.Replace) { - debuglog("EventTimelineSet.addLiveEvent: replacing duplicate event " + event.getId()); - const tlEvents = timeline.getEvents(); - for (let j = 0; j < tlEvents.length; j++) { - if (tlEvents[j].getId() === event.getId()) { - // still need to set the right metadata on this event - if (!roomState) { - roomState = timeline.getState(_eventTimeline.EventTimeline.FORWARDS); - } - _eventTimeline.EventTimeline.setEventMetadata(event, roomState, false); - tlEvents[j] = event; - - // XXX: we need to fire an event when this happens. - break; - } - } - } else { - debuglog("EventTimelineSet.addLiveEvent: ignoring duplicate event " + event.getId()); - } - return; - } - this.addEventToTimeline(event, this.liveTimeline, { - toStartOfTimeline: false, - fromCache, - roomState, - timelineWasEmpty - }); - } - - /** - * Add event to the given timeline, and emit Room.timeline. Assumes - * we have already checked we don't know about this event. - * - * Will fire "Room.timeline" for each event added. - * - * @param options - addEventToTimeline options - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - - addEventToTimeline(event, timeline, toStartOfTimelineOrOpts, fromCache = false, roomState) { - let toStartOfTimeline = !!toStartOfTimelineOrOpts; - let timelineWasEmpty; - if (typeof toStartOfTimelineOrOpts === "object") { - ({ - toStartOfTimeline, - fromCache = false, - roomState, - timelineWasEmpty - } = toStartOfTimelineOrOpts); - } else if (toStartOfTimelineOrOpts !== undefined) { - // Deprecation warning - // FIXME: Remove after 2023-06-01 (technical debt) - _logger.logger.warn("Overload deprecated: " + "`EventTimelineSet.addEventToTimeline(event, timeline, toStartOfTimeline, fromCache?, roomState?)` " + "is deprecated in favor of the overload with " + "`EventTimelineSet.addEventToTimeline(event, timeline, IAddEventToTimelineOptions)`"); - } - if (timeline.getTimelineSet() !== this) { - var _this$thread; - throw new Error(`EventTimelineSet.addEventToTimeline: Timeline=${timeline.toString()} does not belong " + - "in timelineSet(threadId=${(_this$thread = this.thread) === null || _this$thread === void 0 ? void 0 : _this$thread.id})`); - } - - // Make sure events don't get mixed in timelines they shouldn't be in (e.g. a - // threaded message should not be in the main timeline). - // - // We can only run this check for timelines with a `room` because `canContain` - // requires it - if (this.room && !this.canContain(event)) { - var _this$thread2; - let eventDebugString = `event=${event.getId()}`; - if (event.threadRootId) { - eventDebugString += `(belongs to thread=${event.threadRootId})`; - } - _logger.logger.warn(`EventTimelineSet.addEventToTimeline: Ignoring ${eventDebugString} that does not belong ` + `in timeline=${timeline.toString()} timelineSet(threadId=${(_this$thread2 = this.thread) === null || _this$thread2 === void 0 ? void 0 : _this$thread2.id})`); - return; - } - const eventId = event.getId(); - timeline.addEvent(event, { - toStartOfTimeline, - roomState, - timelineWasEmpty - }); - this._eventIdToTimeline.set(eventId, timeline); - this.relations.aggregateParentEvent(event); - this.relations.aggregateChildEvent(event, this); - const data = { - timeline: timeline, - liveEvent: !toStartOfTimeline && timeline == this.liveTimeline && !fromCache - }; - this.emit(_room.RoomEvent.Timeline, event, this.room, Boolean(toStartOfTimeline), false, data); - } - - /** - * Replaces event with ID oldEventId with one with newEventId, if oldEventId is - * recognised. Otherwise, add to the live timeline. Used to handle remote echos. - * - * @param localEvent - the new event to be added to the timeline - * @param oldEventId - the ID of the original event - * @param newEventId - the ID of the replacement event - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - handleRemoteEcho(localEvent, oldEventId, newEventId) { - // XXX: why don't we infer newEventId from localEvent? - const existingTimeline = this._eventIdToTimeline.get(oldEventId); - if (existingTimeline) { - this._eventIdToTimeline.delete(oldEventId); - this._eventIdToTimeline.set(newEventId, existingTimeline); - } else if (!this.filter || this.filter.filterRoomTimeline([localEvent]).length) { - this.addEventToTimeline(localEvent, this.liveTimeline, { - toStartOfTimeline: false - }); - } - } - - /** - * Removes a single event from this room. - * - * @param eventId - The id of the event to remove - * - * @returns the removed event, or null if the event was not found - * in this room. - */ - removeEvent(eventId) { - const timeline = this._eventIdToTimeline.get(eventId); - if (!timeline) { - return null; - } - const removed = timeline.removeEvent(eventId); - if (removed) { - this._eventIdToTimeline.delete(eventId); - const data = { - timeline: timeline - }; - this.emit(_room.RoomEvent.Timeline, removed, this.room, undefined, true, data); - } - return removed; - } - - /** - * Determine where two events appear in the timeline relative to one another - * - * @param eventId1 - The id of the first event - * @param eventId2 - The id of the second event - * @returns a number less than zero if eventId1 precedes eventId2, and - * greater than zero if eventId1 succeeds eventId2. zero if they are the - * same event; null if we can't tell (either because we don't know about one - * of the events, or because they are in separate timelines which don't join - * up). - */ - compareEventOrdering(eventId1, eventId2) { - if (eventId1 == eventId2) { - // optimise this case - return 0; - } - const timeline1 = this._eventIdToTimeline.get(eventId1); - const timeline2 = this._eventIdToTimeline.get(eventId2); - if (timeline1 === undefined) { - return null; - } - if (timeline2 === undefined) { - return null; - } - if (timeline1 === timeline2) { - // both events are in the same timeline - figure out their relative indices - let idx1 = undefined; - let idx2 = undefined; - const events = timeline1.getEvents(); - for (let idx = 0; idx < events.length && (idx1 === undefined || idx2 === undefined); idx++) { - const evId = events[idx].getId(); - if (evId == eventId1) { - idx1 = idx; - } - if (evId == eventId2) { - idx2 = idx; - } - } - return idx1 - idx2; - } - - // the events are in different timelines. Iterate through the - // linkedlist to see which comes first. - - // first work forwards from timeline1 - let tl = timeline1; - while (tl) { - if (tl === timeline2) { - // timeline1 is before timeline2 - return -1; - } - tl = tl.getNeighbouringTimeline(_eventTimeline.EventTimeline.FORWARDS); - } - - // now try backwards from timeline1 - tl = timeline1; - while (tl) { - if (tl === timeline2) { - // timeline2 is before timeline1 - return 1; - } - tl = tl.getNeighbouringTimeline(_eventTimeline.EventTimeline.BACKWARDS); - } - - // the timelines are not contiguous. - return null; - } - - /** - * Determine whether a given event can sanely be added to this event timeline set, - * for timeline sets relating to a thread, only return true for events in the same - * thread timeline, for timeline sets not relating to a thread only return true - * for events which should be shown in the main room timeline. - * Requires the `room` property to have been set at EventTimelineSet construction time. - * - * @param event - the event to check whether it belongs to this timeline set. - * @throws Error if `room` was not set when constructing this timeline set. - * @returns whether the event belongs to this timeline set. - */ - canContain(event) { - if (!this.room) { - throw new Error("Cannot call `EventTimelineSet::canContain without a `room` set. " + "Set the room when creating the EventTimelineSet to call this method."); - } - const { - threadId, - shouldLiveInRoom - } = this.room.eventShouldLiveIn(event); - if (this.thread) { - return this.thread.id === threadId; - } - return shouldLiveInRoom; - } -} -exports.EventTimelineSet = EventTimelineSet; -//# sourceMappingURL=event-timeline-set.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js.map deleted file mode 100644 index fbb25e2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline-set.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-timeline-set.js","names":["_eventTimeline","require","_logger","_room","_typedEventEmitter","_relationsContainer","DEBUG","debuglog","logger","log","bind","DuplicateStrategy","exports","EventTimelineSet","TypedEventEmitter","constructor","room","opts","client","thread","threadListType","_this$room$relations","_this$room","_room$client","_defineProperty2","default","Map","timelineSupport","Boolean","liveTimeline","EventTimeline","displayPendingEvents","pendingEvents","timelines","_eventIdToTimeline","filter","relations","RelationsContainer","getTimelines","getFilter","setFilter","getPendingEvents","getLiveTimeline","setLiveTimeline","timeline","eventIdToTimeline","eventId","get","replaceEventId","oldEventId","newEventId","existingTimeline","delete","set","resetLiveTimeline","backPaginationToken","forwardPaginationToken","resetAllTimelines","oldTimeline","newTimeline","forkLive","FORWARDS","fork","push","setPaginationToken","BACKWARDS","emit","RoomEvent","TimelineReset","getTimelineForEvent","undefined","res","findEventById","tl","getEvents","find","ev","getId","addTimeline","Error","addEventsToTimeline","events","toStartOfTimeline","paginationToken","filterRoomTimeline","length","direction","inverseDirection","didUpdate","lastEventWasNew","event","addEventToTimeline","neighbour","getNeighbouringTimeline","info","existingIsLive","timelineIsLive","backwardsIsLive","forwardsIsLive","warn","setNeighbouringTimeline","addLiveEvent","duplicateStrategyOrOpts","fromCache","roomState","duplicateStrategy","Ignore","timelineWasEmpty","Replace","tlEvents","j","getState","setEventMetadata","toStartOfTimelineOrOpts","getTimelineSet","_this$thread","toString","id","canContain","_this$thread2","eventDebugString","threadRootId","addEvent","aggregateParentEvent","aggregateChildEvent","data","liveEvent","Timeline","handleRemoteEcho","localEvent","removeEvent","removed","compareEventOrdering","eventId1","eventId2","timeline1","timeline2","idx1","idx2","idx","evId","threadId","shouldLiveInRoom","eventShouldLiveIn"],"sources":["../../src/models/event-timeline-set.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EventTimeline, IAddEventOptions } from \"./event-timeline\";\nimport { MatrixEvent } from \"./event\";\nimport { logger } from \"../logger\";\nimport { Room, RoomEvent } from \"./room\";\nimport { Filter } from \"../filter\";\nimport { RoomState } from \"./room-state\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\nimport { RelationsContainer } from \"./relations-container\";\nimport { MatrixClient } from \"../client\";\nimport { Thread, ThreadFilterType } from \"./thread\";\n\nconst DEBUG = true;\n\n/* istanbul ignore next */\nlet debuglog: (...args: any[]) => void;\nif (DEBUG) {\n // using bind means that we get to keep useful line numbers in the console\n debuglog = logger.log.bind(logger);\n} else {\n /* istanbul ignore next */\n debuglog = function (): void {};\n}\n\ninterface IOpts {\n // Set to true to enable improved timeline support.\n timelineSupport?: boolean;\n // The filter object, if any, for this timelineSet.\n filter?: Filter;\n pendingEvents?: boolean;\n}\n\nexport enum DuplicateStrategy {\n Ignore = \"ignore\",\n Replace = \"replace\",\n}\n\nexport interface IRoomTimelineData {\n // the timeline the event was added to/removed from\n timeline: EventTimeline;\n // true if the event was a real-time event added to the end of the live timeline\n liveEvent?: boolean;\n}\n\nexport interface IAddEventToTimelineOptions\n extends Pick {\n /** Whether the sync response came from cache */\n fromCache?: boolean;\n}\n\nexport interface IAddLiveEventOptions\n extends Pick {\n /** Applies to events in the timeline only. If this is 'replace' then if a\n * duplicate is encountered, the event passed to this function will replace\n * the existing event in the timeline. If this is not specified, or is\n * 'ignore', then the event passed to this function will be ignored\n * entirely, preserving the existing event in the timeline. Events are\n * identical based on their event ID only. */\n duplicateStrategy?: DuplicateStrategy;\n}\n\ntype EmittedEvents = RoomEvent.Timeline | RoomEvent.TimelineReset;\n\nexport type EventTimelineSetHandlerMap = {\n /**\n * Fires whenever the timeline in a room is updated.\n * @param event - The matrix event which caused this event to fire.\n * @param room - The room, if any, whose timeline was updated.\n * @param toStartOfTimeline - True if this event was added to the start\n * @param removed - True if this event has just been removed from the timeline\n * (beginning; oldest) of the timeline e.g. due to pagination.\n *\n * @param data - more data about the event\n *\n * @example\n * ```\n * matrixClient.on(\"Room.timeline\",\n * function(event, room, toStartOfTimeline, removed, data) {\n * if (!toStartOfTimeline && data.liveEvent) {\n * var messageToAppend = room.timeline.[room.timeline.length - 1];\n * }\n * });\n * ```\n */\n [RoomEvent.Timeline]: (\n event: MatrixEvent,\n room: Room | undefined,\n toStartOfTimeline: boolean | undefined,\n removed: boolean,\n data: IRoomTimelineData,\n ) => void;\n /**\n * Fires whenever the live timeline in a room is reset.\n *\n * When we get a 'limited' sync (for example, after a network outage), we reset\n * the live timeline to be empty before adding the recent events to the new\n * timeline. This event is fired after the timeline is reset, and before the\n * new events are added.\n *\n * @param room - The room whose live timeline was reset, if any\n * @param timelineSet - timelineSet room whose live timeline was reset\n * @param resetAllTimelines - True if all timelines were reset.\n */\n [RoomEvent.TimelineReset]: (\n room: Room | undefined,\n eventTimelineSet: EventTimelineSet,\n resetAllTimelines: boolean,\n ) => void;\n};\n\nexport class EventTimelineSet extends TypedEventEmitter {\n public readonly relations: RelationsContainer;\n private readonly timelineSupport: boolean;\n private readonly displayPendingEvents: boolean;\n private liveTimeline: EventTimeline;\n private timelines: EventTimeline[];\n private _eventIdToTimeline = new Map();\n private filter?: Filter;\n\n /**\n * Construct a set of EventTimeline objects, typically on behalf of a given\n * room. A room may have multiple EventTimelineSets for different levels\n * of filtering. The global notification list is also an EventTimelineSet, but\n * lacks a room.\n *\n *

This is an ordered sequence of timelines, which may or may not\n * be continuous. Each timeline lists a series of events, as well as tracking\n * the room state at the start and the end of the timeline (if appropriate).\n * It also tracks forward and backward pagination tokens, as well as containing\n * links to the next timeline in the sequence.\n *\n *

There is one special timeline - the 'live' timeline, which represents the\n * timeline to which events are being added in real-time as they are received\n * from the /sync API. Note that you should not retain references to this\n * timeline - even if it is the current timeline right now, it may not remain\n * so if the server gives us a timeline gap in /sync.\n *\n *

In order that we can find events from their ids later, we also maintain a\n * map from event_id to timeline and index.\n *\n * @param room - Room for this timelineSet. May be null for non-room cases, such as the\n * notification timeline.\n * @param opts - Options inherited from Room.\n * @param client - the Matrix client which owns this EventTimelineSet,\n * can be omitted if room is specified.\n * @param thread - the thread to which this timeline set relates.\n * @param isThreadTimeline - Whether this timeline set relates to a thread list timeline\n * (e.g., All threads or My threads)\n */\n public constructor(\n public readonly room: Room | undefined,\n opts: IOpts = {},\n client?: MatrixClient,\n public readonly thread?: Thread,\n public readonly threadListType: ThreadFilterType | null = null,\n ) {\n super();\n\n this.timelineSupport = Boolean(opts.timelineSupport);\n this.liveTimeline = new EventTimeline(this);\n this.displayPendingEvents = opts.pendingEvents !== false;\n\n // just a list - *not* ordered.\n this.timelines = [this.liveTimeline];\n this._eventIdToTimeline = new Map();\n\n this.filter = opts.filter;\n\n this.relations = this.room?.relations ?? new RelationsContainer(room?.client ?? client!);\n }\n\n /**\n * Get all the timelines in this set\n * @returns the timelines in this set\n */\n public getTimelines(): EventTimeline[] {\n return this.timelines;\n }\n\n /**\n * Get the filter object this timeline set is filtered on, if any\n * @returns the optional filter for this timelineSet\n */\n public getFilter(): Filter | undefined {\n return this.filter;\n }\n\n /**\n * Set the filter object this timeline set is filtered on\n * (passed to the server when paginating via /messages).\n * @param filter - the filter for this timelineSet\n */\n public setFilter(filter?: Filter): void {\n this.filter = filter;\n }\n\n /**\n * Get the list of pending sent events for this timelineSet's room, filtered\n * by the timelineSet's filter if appropriate.\n *\n * @returns A list of the sent events\n * waiting for remote echo.\n *\n * @throws If `opts.pendingEventOrdering` was not 'detached'\n */\n public getPendingEvents(): MatrixEvent[] {\n if (!this.room || !this.displayPendingEvents) {\n return [];\n }\n\n return this.room.getPendingEvents();\n }\n /**\n * Get the live timeline for this room.\n *\n * @returns live timeline\n */\n public getLiveTimeline(): EventTimeline {\n return this.liveTimeline;\n }\n\n /**\n * Set the live timeline for this room.\n *\n * @returns live timeline\n */\n public setLiveTimeline(timeline: EventTimeline): void {\n this.liveTimeline = timeline;\n }\n\n /**\n * Return the timeline (if any) this event is in.\n * @param eventId - the eventId being sought\n * @returns timeline\n */\n public eventIdToTimeline(eventId: string): EventTimeline | undefined {\n return this._eventIdToTimeline.get(eventId);\n }\n\n /**\n * Track a new event as if it were in the same timeline as an old event,\n * replacing it.\n * @param oldEventId - event ID of the original event\n * @param newEventId - event ID of the replacement event\n */\n public replaceEventId(oldEventId: string, newEventId: string): void {\n const existingTimeline = this._eventIdToTimeline.get(oldEventId);\n if (existingTimeline) {\n this._eventIdToTimeline.delete(oldEventId);\n this._eventIdToTimeline.set(newEventId, existingTimeline);\n }\n }\n\n /**\n * Reset the live timeline, and start a new one.\n *\n *

This is used when /sync returns a 'limited' timeline.\n *\n * @param backPaginationToken - token for back-paginating the new timeline\n * @param forwardPaginationToken - token for forward-paginating the old live timeline,\n * if absent or null, all timelines are reset.\n *\n * @remarks\n * Fires {@link RoomEvent.TimelineReset}\n */\n public resetLiveTimeline(backPaginationToken?: string, forwardPaginationToken?: string): void {\n // Each EventTimeline has RoomState objects tracking the state at the start\n // and end of that timeline. The copies at the end of the live timeline are\n // special because they will have listeners attached to monitor changes to\n // the current room state, so we move this RoomState from the end of the\n // current live timeline to the end of the new one and, if necessary,\n // replace it with a newly created one. We also make a copy for the start\n // of the new timeline.\n\n // if timeline support is disabled, forget about the old timelines\n const resetAllTimelines = !this.timelineSupport || !forwardPaginationToken;\n\n const oldTimeline = this.liveTimeline;\n const newTimeline = resetAllTimelines\n ? oldTimeline.forkLive(EventTimeline.FORWARDS)\n : oldTimeline.fork(EventTimeline.FORWARDS);\n\n if (resetAllTimelines) {\n this.timelines = [newTimeline];\n this._eventIdToTimeline = new Map();\n } else {\n this.timelines.push(newTimeline);\n }\n\n if (forwardPaginationToken) {\n // Now set the forward pagination token on the old live timeline\n // so it can be forward-paginated.\n oldTimeline.setPaginationToken(forwardPaginationToken, EventTimeline.FORWARDS);\n }\n\n // make sure we set the pagination token before firing timelineReset,\n // otherwise clients which start back-paginating will fail, and then get\n // stuck without realising that they *can* back-paginate.\n newTimeline.setPaginationToken(backPaginationToken ?? null, EventTimeline.BACKWARDS);\n\n // Now we can swap the live timeline to the new one.\n this.liveTimeline = newTimeline;\n this.emit(RoomEvent.TimelineReset, this.room, this, resetAllTimelines);\n }\n\n /**\n * Get the timeline which contains the given event, if any\n *\n * @param eventId - event ID to look for\n * @returns timeline containing\n * the given event, or null if unknown\n */\n public getTimelineForEvent(eventId?: string): EventTimeline | null {\n if (eventId === null || eventId === undefined) {\n return null;\n }\n const res = this._eventIdToTimeline.get(eventId);\n return res === undefined ? null : res;\n }\n\n /**\n * Get an event which is stored in our timelines\n *\n * @param eventId - event ID to look for\n * @returns the given event, or undefined if unknown\n */\n public findEventById(eventId: string): MatrixEvent | undefined {\n const tl = this.getTimelineForEvent(eventId);\n if (!tl) {\n return undefined;\n }\n return tl.getEvents().find(function (ev) {\n return ev.getId() == eventId;\n });\n }\n\n /**\n * Add a new timeline to this timeline list\n *\n * @returns newly-created timeline\n */\n public addTimeline(): EventTimeline {\n if (!this.timelineSupport) {\n throw new Error(\n \"timeline support is disabled. Set the 'timelineSupport'\" +\n \" parameter to true when creating MatrixClient to enable\" +\n \" it.\",\n );\n }\n\n const timeline = new EventTimeline(this);\n this.timelines.push(timeline);\n return timeline;\n }\n\n /**\n * Add events to a timeline\n *\n *

Will fire \"Room.timeline\" for each event added.\n *\n * @param events - A list of events to add.\n *\n * @param toStartOfTimeline - True to add these events to the start\n * (oldest) instead of the end (newest) of the timeline. If true, the oldest\n * event will be the last element of 'events'.\n *\n * @param timeline - timeline to\n * add events to.\n *\n * @param paginationToken - token for the next batch of events\n *\n * @remarks\n * Fires {@link RoomEvent.Timeline}\n *\n */\n public addEventsToTimeline(\n events: MatrixEvent[],\n toStartOfTimeline: boolean,\n timeline: EventTimeline,\n paginationToken?: string | null,\n ): void {\n if (!timeline) {\n throw new Error(\"'timeline' not specified for EventTimelineSet.addEventsToTimeline\");\n }\n\n if (!toStartOfTimeline && timeline == this.liveTimeline) {\n throw new Error(\n \"EventTimelineSet.addEventsToTimeline cannot be used for adding events to \" +\n \"the live timeline - use Room.addLiveEvents instead\",\n );\n }\n\n if (this.filter) {\n events = this.filter.filterRoomTimeline(events);\n if (!events.length) {\n return;\n }\n }\n\n const direction = toStartOfTimeline ? EventTimeline.BACKWARDS : EventTimeline.FORWARDS;\n const inverseDirection = toStartOfTimeline ? EventTimeline.FORWARDS : EventTimeline.BACKWARDS;\n\n // Adding events to timelines can be quite complicated. The following\n // illustrates some of the corner-cases.\n //\n // Let's say we start by knowing about four timelines. timeline3 and\n // timeline4 are neighbours:\n //\n // timeline1 timeline2 timeline3 timeline4\n // [M] [P] [S] <------> [T]\n //\n // Now we paginate timeline1, and get the following events from the server:\n // [M, N, P, R, S, T, U].\n //\n // 1. First, we ignore event M, since we already know about it.\n //\n // 2. Next, we append N to timeline 1.\n //\n // 3. Next, we don't add event P, since we already know about it,\n // but we do link together the timelines. We now have:\n //\n // timeline1 timeline2 timeline3 timeline4\n // [M, N] <---> [P] [S] <------> [T]\n //\n // 4. Now we add event R to timeline2:\n //\n // timeline1 timeline2 timeline3 timeline4\n // [M, N] <---> [P, R] [S] <------> [T]\n //\n // Note that we have switched the timeline we are working on from\n // timeline1 to timeline2.\n //\n // 5. We ignore event S, but again join the timelines:\n //\n // timeline1 timeline2 timeline3 timeline4\n // [M, N] <---> [P, R] <---> [S] <------> [T]\n //\n // 6. We ignore event T, and the timelines are already joined, so there\n // is nothing to do.\n //\n // 7. Finally, we add event U to timeline4:\n //\n // timeline1 timeline2 timeline3 timeline4\n // [M, N] <---> [P, R] <---> [S] <------> [T, U]\n //\n // The important thing to note in the above is what happened when we\n // already knew about a given event:\n //\n // - if it was appropriate, we joined up the timelines (steps 3, 5).\n // - in any case, we started adding further events to the timeline which\n // contained the event we knew about (steps 3, 5, 6).\n //\n //\n // So much for adding events to the timeline. But what do we want to do\n // with the pagination token?\n //\n // In the case above, we will be given a pagination token which tells us how to\n // get events beyond 'U' - in this case, it makes sense to store this\n // against timeline4. But what if timeline4 already had 'U' and beyond? in\n // that case, our best bet is to throw away the pagination token we were\n // given and stick with whatever token timeline4 had previously. In short,\n // we want to only store the pagination token if the last event we receive\n // is one we didn't previously know about.\n //\n // We make an exception for this if it turns out that we already knew about\n // *all* of the events, and we weren't able to join up any timelines. When\n // that happens, it means our existing pagination token is faulty, since it\n // is only telling us what we already know. Rather than repeatedly\n // paginating with the same token, we might as well use the new pagination\n // token in the hope that we eventually work our way out of the mess.\n\n let didUpdate = false;\n let lastEventWasNew = false;\n for (const event of events) {\n const eventId = event.getId()!;\n\n const existingTimeline = this._eventIdToTimeline.get(eventId);\n\n if (!existingTimeline) {\n // we don't know about this event yet. Just add it to the timeline.\n this.addEventToTimeline(event, timeline, {\n toStartOfTimeline,\n });\n lastEventWasNew = true;\n didUpdate = true;\n continue;\n }\n\n lastEventWasNew = false;\n\n if (existingTimeline == timeline) {\n debuglog(\"Event \" + eventId + \" already in timeline \" + timeline);\n continue;\n }\n\n const neighbour = timeline.getNeighbouringTimeline(direction);\n if (neighbour) {\n // this timeline already has a neighbour in the relevant direction;\n // let's assume the timelines are already correctly linked up, and\n // skip over to it.\n //\n // there's probably some edge-case here where we end up with an\n // event which is in a timeline a way down the chain, and there is\n // a break in the chain somewhere. But I can't really imagine how\n // that would happen, so I'm going to ignore it for now.\n //\n if (existingTimeline == neighbour) {\n debuglog(\"Event \" + eventId + \" in neighbouring timeline - \" + \"switching to \" + existingTimeline);\n } else {\n debuglog(\"Event \" + eventId + \" already in a different \" + \"timeline \" + existingTimeline);\n }\n timeline = existingTimeline;\n continue;\n }\n\n // time to join the timelines.\n logger.info(\n \"Already have timeline for \" + eventId + \" - joining timeline \" + timeline + \" to \" + existingTimeline,\n );\n\n // Variables to keep the line length limited below.\n const existingIsLive = existingTimeline === this.liveTimeline;\n const timelineIsLive = timeline === this.liveTimeline;\n\n const backwardsIsLive = direction === EventTimeline.BACKWARDS && existingIsLive;\n const forwardsIsLive = direction === EventTimeline.FORWARDS && timelineIsLive;\n\n if (backwardsIsLive || forwardsIsLive) {\n // The live timeline should never be spliced into a non-live position.\n // We use independent logging to better discover the problem at a glance.\n if (backwardsIsLive) {\n logger.warn(\n \"Refusing to set a preceding existingTimeLine on our \" +\n \"timeline as the existingTimeLine is live (\" +\n existingTimeline +\n \")\",\n );\n }\n if (forwardsIsLive) {\n logger.warn(\n \"Refusing to set our preceding timeline on a existingTimeLine \" +\n \"as our timeline is live (\" +\n timeline +\n \")\",\n );\n }\n continue; // abort splicing - try next event\n }\n\n timeline.setNeighbouringTimeline(existingTimeline, direction);\n existingTimeline.setNeighbouringTimeline(timeline, inverseDirection);\n\n timeline = existingTimeline;\n didUpdate = true;\n }\n\n // see above - if the last event was new to us, or if we didn't find any\n // new information, we update the pagination token for whatever\n // timeline we ended up on.\n if (lastEventWasNew || !didUpdate) {\n if (direction === EventTimeline.FORWARDS && timeline === this.liveTimeline) {\n logger.warn({ lastEventWasNew, didUpdate }); // for debugging\n logger.warn(\n `Refusing to set forwards pagination token of live timeline ` + `${timeline} to ${paginationToken}`,\n );\n return;\n }\n timeline.setPaginationToken(paginationToken ?? null, direction);\n }\n }\n\n /**\n * Add an event to the end of this live timeline.\n *\n * @param event - Event to be added\n * @param options - addLiveEvent options\n */\n public addLiveEvent(\n event: MatrixEvent,\n { duplicateStrategy, fromCache, roomState, timelineWasEmpty }: IAddLiveEventOptions,\n ): void;\n /**\n * @deprecated In favor of the overload with `IAddLiveEventOptions`\n */\n public addLiveEvent(\n event: MatrixEvent,\n duplicateStrategy?: DuplicateStrategy,\n fromCache?: boolean,\n roomState?: RoomState,\n ): void;\n public addLiveEvent(\n event: MatrixEvent,\n duplicateStrategyOrOpts?: DuplicateStrategy | IAddLiveEventOptions,\n fromCache = false,\n roomState?: RoomState,\n ): void {\n let duplicateStrategy = (duplicateStrategyOrOpts as DuplicateStrategy) || DuplicateStrategy.Ignore;\n let timelineWasEmpty: boolean | undefined;\n if (typeof duplicateStrategyOrOpts === \"object\") {\n ({\n duplicateStrategy = DuplicateStrategy.Ignore,\n fromCache = false,\n roomState,\n timelineWasEmpty,\n } = duplicateStrategyOrOpts);\n } else if (duplicateStrategyOrOpts !== undefined) {\n // Deprecation warning\n // FIXME: Remove after 2023-06-01 (technical debt)\n logger.warn(\n \"Overload deprecated: \" +\n \"`EventTimelineSet.addLiveEvent(event, duplicateStrategy?, fromCache?, roomState?)` \" +\n \"is deprecated in favor of the overload with \" +\n \"`EventTimelineSet.addLiveEvent(event, IAddLiveEventOptions)`\",\n );\n }\n\n if (this.filter) {\n const events = this.filter.filterRoomTimeline([event]);\n if (!events.length) {\n return;\n }\n }\n\n const timeline = this._eventIdToTimeline.get(event.getId()!);\n if (timeline) {\n if (duplicateStrategy === DuplicateStrategy.Replace) {\n debuglog(\"EventTimelineSet.addLiveEvent: replacing duplicate event \" + event.getId());\n const tlEvents = timeline.getEvents();\n for (let j = 0; j < tlEvents.length; j++) {\n if (tlEvents[j].getId() === event.getId()) {\n // still need to set the right metadata on this event\n if (!roomState) {\n roomState = timeline.getState(EventTimeline.FORWARDS);\n }\n EventTimeline.setEventMetadata(event, roomState!, false);\n tlEvents[j] = event;\n\n // XXX: we need to fire an event when this happens.\n break;\n }\n }\n } else {\n debuglog(\"EventTimelineSet.addLiveEvent: ignoring duplicate event \" + event.getId());\n }\n return;\n }\n\n this.addEventToTimeline(event, this.liveTimeline, {\n toStartOfTimeline: false,\n fromCache,\n roomState,\n timelineWasEmpty,\n });\n }\n\n /**\n * Add event to the given timeline, and emit Room.timeline. Assumes\n * we have already checked we don't know about this event.\n *\n * Will fire \"Room.timeline\" for each event added.\n *\n * @param options - addEventToTimeline options\n *\n * @remarks\n * Fires {@link RoomEvent.Timeline}\n */\n public addEventToTimeline(\n event: MatrixEvent,\n timeline: EventTimeline,\n { toStartOfTimeline, fromCache, roomState, timelineWasEmpty }: IAddEventToTimelineOptions,\n ): void;\n /**\n * @deprecated In favor of the overload with `IAddEventToTimelineOptions`\n */\n public addEventToTimeline(\n event: MatrixEvent,\n timeline: EventTimeline,\n toStartOfTimeline: boolean,\n fromCache?: boolean,\n roomState?: RoomState,\n ): void;\n public addEventToTimeline(\n event: MatrixEvent,\n timeline: EventTimeline,\n toStartOfTimelineOrOpts: boolean | IAddEventToTimelineOptions,\n fromCache = false,\n roomState?: RoomState,\n ): void {\n let toStartOfTimeline = !!toStartOfTimelineOrOpts;\n let timelineWasEmpty: boolean | undefined;\n if (typeof toStartOfTimelineOrOpts === \"object\") {\n ({ toStartOfTimeline, fromCache = false, roomState, timelineWasEmpty } = toStartOfTimelineOrOpts);\n } else if (toStartOfTimelineOrOpts !== undefined) {\n // Deprecation warning\n // FIXME: Remove after 2023-06-01 (technical debt)\n logger.warn(\n \"Overload deprecated: \" +\n \"`EventTimelineSet.addEventToTimeline(event, timeline, toStartOfTimeline, fromCache?, roomState?)` \" +\n \"is deprecated in favor of the overload with \" +\n \"`EventTimelineSet.addEventToTimeline(event, timeline, IAddEventToTimelineOptions)`\",\n );\n }\n\n if (timeline.getTimelineSet() !== this) {\n throw new Error(`EventTimelineSet.addEventToTimeline: Timeline=${timeline.toString()} does not belong \" +\n \"in timelineSet(threadId=${this.thread?.id})`);\n }\n\n // Make sure events don't get mixed in timelines they shouldn't be in (e.g. a\n // threaded message should not be in the main timeline).\n //\n // We can only run this check for timelines with a `room` because `canContain`\n // requires it\n if (this.room && !this.canContain(event)) {\n let eventDebugString = `event=${event.getId()}`;\n if (event.threadRootId) {\n eventDebugString += `(belongs to thread=${event.threadRootId})`;\n }\n logger.warn(\n `EventTimelineSet.addEventToTimeline: Ignoring ${eventDebugString} that does not belong ` +\n `in timeline=${timeline.toString()} timelineSet(threadId=${this.thread?.id})`,\n );\n return;\n }\n\n const eventId = event.getId()!;\n timeline.addEvent(event, {\n toStartOfTimeline,\n roomState,\n timelineWasEmpty,\n });\n this._eventIdToTimeline.set(eventId, timeline);\n\n this.relations.aggregateParentEvent(event);\n this.relations.aggregateChildEvent(event, this);\n\n const data: IRoomTimelineData = {\n timeline: timeline,\n liveEvent: !toStartOfTimeline && timeline == this.liveTimeline && !fromCache,\n };\n this.emit(RoomEvent.Timeline, event, this.room, Boolean(toStartOfTimeline), false, data);\n }\n\n /**\n * Replaces event with ID oldEventId with one with newEventId, if oldEventId is\n * recognised. Otherwise, add to the live timeline. Used to handle remote echos.\n *\n * @param localEvent - the new event to be added to the timeline\n * @param oldEventId - the ID of the original event\n * @param newEventId - the ID of the replacement event\n *\n * @remarks\n * Fires {@link RoomEvent.Timeline}\n */\n public handleRemoteEcho(localEvent: MatrixEvent, oldEventId: string, newEventId: string): void {\n // XXX: why don't we infer newEventId from localEvent?\n const existingTimeline = this._eventIdToTimeline.get(oldEventId);\n if (existingTimeline) {\n this._eventIdToTimeline.delete(oldEventId);\n this._eventIdToTimeline.set(newEventId, existingTimeline);\n } else if (!this.filter || this.filter.filterRoomTimeline([localEvent]).length) {\n this.addEventToTimeline(localEvent, this.liveTimeline, {\n toStartOfTimeline: false,\n });\n }\n }\n\n /**\n * Removes a single event from this room.\n *\n * @param eventId - The id of the event to remove\n *\n * @returns the removed event, or null if the event was not found\n * in this room.\n */\n public removeEvent(eventId: string): MatrixEvent | null {\n const timeline = this._eventIdToTimeline.get(eventId);\n if (!timeline) {\n return null;\n }\n\n const removed = timeline.removeEvent(eventId);\n if (removed) {\n this._eventIdToTimeline.delete(eventId);\n const data = {\n timeline: timeline,\n };\n this.emit(RoomEvent.Timeline, removed, this.room, undefined, true, data);\n }\n return removed;\n }\n\n /**\n * Determine where two events appear in the timeline relative to one another\n *\n * @param eventId1 - The id of the first event\n * @param eventId2 - The id of the second event\n\n * @returns a number less than zero if eventId1 precedes eventId2, and\n * greater than zero if eventId1 succeeds eventId2. zero if they are the\n * same event; null if we can't tell (either because we don't know about one\n * of the events, or because they are in separate timelines which don't join\n * up).\n */\n public compareEventOrdering(eventId1: string, eventId2: string): number | null {\n if (eventId1 == eventId2) {\n // optimise this case\n return 0;\n }\n\n const timeline1 = this._eventIdToTimeline.get(eventId1);\n const timeline2 = this._eventIdToTimeline.get(eventId2);\n\n if (timeline1 === undefined) {\n return null;\n }\n if (timeline2 === undefined) {\n return null;\n }\n\n if (timeline1 === timeline2) {\n // both events are in the same timeline - figure out their relative indices\n let idx1: number | undefined = undefined;\n let idx2: number | undefined = undefined;\n const events = timeline1.getEvents();\n for (let idx = 0; idx < events.length && (idx1 === undefined || idx2 === undefined); idx++) {\n const evId = events[idx].getId();\n if (evId == eventId1) {\n idx1 = idx;\n }\n if (evId == eventId2) {\n idx2 = idx;\n }\n }\n return idx1! - idx2!;\n }\n\n // the events are in different timelines. Iterate through the\n // linkedlist to see which comes first.\n\n // first work forwards from timeline1\n let tl: EventTimeline | null = timeline1;\n while (tl) {\n if (tl === timeline2) {\n // timeline1 is before timeline2\n return -1;\n }\n tl = tl.getNeighbouringTimeline(EventTimeline.FORWARDS);\n }\n\n // now try backwards from timeline1\n tl = timeline1;\n while (tl) {\n if (tl === timeline2) {\n // timeline2 is before timeline1\n return 1;\n }\n tl = tl.getNeighbouringTimeline(EventTimeline.BACKWARDS);\n }\n\n // the timelines are not contiguous.\n return null;\n }\n\n /**\n * Determine whether a given event can sanely be added to this event timeline set,\n * for timeline sets relating to a thread, only return true for events in the same\n * thread timeline, for timeline sets not relating to a thread only return true\n * for events which should be shown in the main room timeline.\n * Requires the `room` property to have been set at EventTimelineSet construction time.\n *\n * @param event - the event to check whether it belongs to this timeline set.\n * @throws Error if `room` was not set when constructing this timeline set.\n * @returns whether the event belongs to this timeline set.\n */\n public canContain(event: MatrixEvent): boolean {\n if (!this.room) {\n throw new Error(\n \"Cannot call `EventTimelineSet::canContain without a `room` set. \" +\n \"Set the room when creating the EventTimelineSet to call this method.\",\n );\n }\n\n const { threadId, shouldLiveInRoom } = this.room.eventShouldLiveIn(event);\n\n if (this.thread) {\n return this.thread.id === threadId;\n }\n return shouldLiveInRoom;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts deleted file mode 100644 index b6ab2eb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts +++ /dev/null @@ -1,211 +0,0 @@ -import { IMarkerFoundOptions, RoomState } from "./room-state"; -import { EventTimelineSet } from "./event-timeline-set"; -import { MatrixEvent } from "./event"; -import { Filter } from "../filter"; -export interface IInitialiseStateOptions extends Pick { -} -export interface IAddEventOptions extends Pick { - /** Whether to insert the new event at the start of the timeline where the - * oldest events are (timeline is in chronological order, oldest to most - * recent) */ - toStartOfTimeline: boolean; - /** The state events to reconcile metadata from */ - roomState?: RoomState; -} -export declare enum Direction { - Backward = "b", - Forward = "f" -} -export declare class EventTimeline { - private readonly eventTimelineSet; - /** - * Symbolic constant for methods which take a 'direction' argument: - * refers to the start of the timeline, or backwards in time. - */ - static readonly BACKWARDS = Direction.Backward; - /** - * Symbolic constant for methods which take a 'direction' argument: - * refers to the end of the timeline, or forwards in time. - */ - static readonly FORWARDS = Direction.Forward; - /** - * Static helper method to set sender and target properties - * - * @param event - the event whose metadata is to be set - * @param stateContext - the room state to be queried - * @param toStartOfTimeline - if true the event's forwardLooking flag is set false - */ - static setEventMetadata(event: MatrixEvent, stateContext: RoomState, toStartOfTimeline: boolean): void; - private readonly roomId; - private readonly name; - private events; - private baseIndex; - private startState?; - private endState?; - private startToken; - private endToken; - private prevTimeline; - private nextTimeline; - paginationRequests: Record | null>; - /** - * Construct a new EventTimeline - * - *

An EventTimeline represents a contiguous sequence of events in a room. - * - *

As well as keeping track of the events themselves, it stores the state of - * the room at the beginning and end of the timeline, and pagination tokens for - * going backwards and forwards in the timeline. - * - *

In order that clients can meaningfully maintain an index into a timeline, - * the EventTimeline object tracks a 'baseIndex'. This starts at zero, but is - * incremented when events are prepended to the timeline. The index of an event - * relative to baseIndex therefore remains constant. - * - *

Once a timeline joins up with its neighbour, they are linked together into a - * doubly-linked list. - * - * @param eventTimelineSet - the set of timelines this is part of - */ - constructor(eventTimelineSet: EventTimelineSet); - /** - * Initialise the start and end state with the given events - * - *

This can only be called before any events are added. - * - * @param stateEvents - list of state events to initialise the - * state with. - * @throws Error if an attempt is made to call this after addEvent is called. - */ - initialiseState(stateEvents: MatrixEvent[], { timelineWasEmpty }?: IInitialiseStateOptions): void; - /** - * Forks the (live) timeline, taking ownership of the existing directional state of this timeline. - * All attached listeners will keep receiving state updates from the new live timeline state. - * The end state of this timeline gets replaced with an independent copy of the current RoomState, - * and will need a new pagination token if it ever needs to paginate forwards. - - * @param direction - EventTimeline.BACKWARDS to get the state at the - * start of the timeline; EventTimeline.FORWARDS to get the state at the end - * of the timeline. - * - * @returns the new timeline - */ - forkLive(direction: Direction): EventTimeline; - /** - * Creates an independent timeline, inheriting the directional state from this timeline. - * - * @param direction - EventTimeline.BACKWARDS to get the state at the - * start of the timeline; EventTimeline.FORWARDS to get the state at the end - * of the timeline. - * - * @returns the new timeline - */ - fork(direction: Direction): EventTimeline; - /** - * Get the ID of the room for this timeline - * @returns room ID - */ - getRoomId(): string | null; - /** - * Get the filter for this timeline's timelineSet (if any) - * @returns filter - */ - getFilter(): Filter | undefined; - /** - * Get the timelineSet for this timeline - * @returns timelineSet - */ - getTimelineSet(): EventTimelineSet; - /** - * Get the base index. - * - *

This is an index which is incremented when events are prepended to the - * timeline. An individual event therefore stays at the same index in the array - * relative to the base index (although note that a given event's index may - * well be less than the base index, thus giving that event a negative relative - * index). - */ - getBaseIndex(): number; - /** - * Get the list of events in this context - * - * @returns An array of MatrixEvents - */ - getEvents(): MatrixEvent[]; - /** - * Get the room state at the start/end of the timeline - * - * @param direction - EventTimeline.BACKWARDS to get the state at the - * start of the timeline; EventTimeline.FORWARDS to get the state at the end - * of the timeline. - * - * @returns state at the start/end of the timeline - */ - getState(direction: Direction): RoomState | undefined; - /** - * Get a pagination token - * - * @param direction - EventTimeline.BACKWARDS to get the pagination - * token for going backwards in time; EventTimeline.FORWARDS to get the - * pagination token for going forwards in time. - * - * @returns pagination token - */ - getPaginationToken(direction: Direction): string | null; - /** - * Set a pagination token - * - * @param token - pagination token - * - * @param direction - EventTimeline.BACKWARDS to set the pagination - * token for going backwards in time; EventTimeline.FORWARDS to set the - * pagination token for going forwards in time. - */ - setPaginationToken(token: string | null, direction: Direction): void; - /** - * Get the next timeline in the series - * - * @param direction - EventTimeline.BACKWARDS to get the previous - * timeline; EventTimeline.FORWARDS to get the next timeline. - * - * @returns previous or following timeline, if they have been - * joined up. - */ - getNeighbouringTimeline(direction: Direction): EventTimeline | null; - /** - * Set the next timeline in the series - * - * @param neighbour - previous/following timeline - * - * @param direction - EventTimeline.BACKWARDS to set the previous - * timeline; EventTimeline.FORWARDS to set the next timeline. - * - * @throws Error if an attempt is made to set the neighbouring timeline when - * it is already set. - */ - setNeighbouringTimeline(neighbour: EventTimeline, direction: Direction): void; - /** - * Add a new event to the timeline, and update the state - * - * @param event - new event - * @param options - addEvent options - */ - addEvent(event: MatrixEvent, { toStartOfTimeline, roomState, timelineWasEmpty }: IAddEventOptions): void; - /** - * @deprecated In favor of the overload with `IAddEventOptions` - */ - addEvent(event: MatrixEvent, toStartOfTimeline: boolean, roomState?: RoomState): void; - /** - * Remove an event from the timeline - * - * @param eventId - ID of event to be removed - * @returns removed event, or null if not found - */ - removeEvent(eventId: string): MatrixEvent | null; - /** - * Return a string to identify this timeline, for debugging - * - * @returns name for this timeline - */ - toString(): string; -} -//# sourceMappingURL=event-timeline.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts.map deleted file mode 100644 index 4b39d51..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-timeline.d.ts","sourceRoot":"","sources":["../../src/models/event-timeline.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js deleted file mode 100644 index 9857888..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js +++ /dev/null @@ -1,433 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.EventTimeline = exports.Direction = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../logger"); -var _roomState2 = require("./room-state"); -var _event = require("../@types/event"); -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let Direction; -exports.Direction = Direction; -(function (Direction) { - Direction["Backward"] = "b"; - Direction["Forward"] = "f"; -})(Direction || (exports.Direction = Direction = {})); -class EventTimeline { - /** - * Symbolic constant for methods which take a 'direction' argument: - * refers to the start of the timeline, or backwards in time. - */ - - /** - * Symbolic constant for methods which take a 'direction' argument: - * refers to the end of the timeline, or forwards in time. - */ - - /** - * Static helper method to set sender and target properties - * - * @param event - the event whose metadata is to be set - * @param stateContext - the room state to be queried - * @param toStartOfTimeline - if true the event's forwardLooking flag is set false - */ - static setEventMetadata(event, stateContext, toStartOfTimeline) { - var _event$sender, _event$sender$events, _event$target, _event$target$events; - // When we try to generate a sentinel member before we have that member - // in the members object, we still generate a sentinel but it doesn't - // have a membership event, so test to see if events.member is set. We - // check this to avoid overriding non-sentinel members by sentinel ones - // when adding the event to a filtered timeline - if (!((_event$sender = event.sender) !== null && _event$sender !== void 0 && (_event$sender$events = _event$sender.events) !== null && _event$sender$events !== void 0 && _event$sender$events.member)) { - event.sender = stateContext.getSentinelMember(event.getSender()); - } - if (!((_event$target = event.target) !== null && _event$target !== void 0 && (_event$target$events = _event$target.events) !== null && _event$target$events !== void 0 && _event$target$events.member) && event.getType() === _event.EventType.RoomMember) { - event.target = stateContext.getSentinelMember(event.getStateKey()); - } - if (event.isState()) { - // room state has no concept of 'old' or 'current', but we want the - // room state to regress back to previous values if toStartOfTimeline - // is set, which means inspecting prev_content if it exists. This - // is done by toggling the forwardLooking flag. - if (toStartOfTimeline) { - event.forwardLooking = false; - } - } - } - /** - * Construct a new EventTimeline - * - *

An EventTimeline represents a contiguous sequence of events in a room. - * - *

As well as keeping track of the events themselves, it stores the state of - * the room at the beginning and end of the timeline, and pagination tokens for - * going backwards and forwards in the timeline. - * - *

In order that clients can meaningfully maintain an index into a timeline, - * the EventTimeline object tracks a 'baseIndex'. This starts at zero, but is - * incremented when events are prepended to the timeline. The index of an event - * relative to baseIndex therefore remains constant. - * - *

Once a timeline joins up with its neighbour, they are linked together into a - * doubly-linked list. - * - * @param eventTimelineSet - the set of timelines this is part of - */ - constructor(eventTimelineSet) { - var _eventTimelineSet$roo, _eventTimelineSet$roo2; - this.eventTimelineSet = eventTimelineSet; - (0, _defineProperty2.default)(this, "roomId", void 0); - (0, _defineProperty2.default)(this, "name", void 0); - (0, _defineProperty2.default)(this, "events", []); - (0, _defineProperty2.default)(this, "baseIndex", 0); - (0, _defineProperty2.default)(this, "startState", void 0); - (0, _defineProperty2.default)(this, "endState", void 0); - (0, _defineProperty2.default)(this, "startToken", null); - (0, _defineProperty2.default)(this, "endToken", null); - (0, _defineProperty2.default)(this, "prevTimeline", null); - (0, _defineProperty2.default)(this, "nextTimeline", null); - (0, _defineProperty2.default)(this, "paginationRequests", { - [Direction.Backward]: null, - [Direction.Forward]: null - }); - this.roomId = (_eventTimelineSet$roo = (_eventTimelineSet$roo2 = eventTimelineSet.room) === null || _eventTimelineSet$roo2 === void 0 ? void 0 : _eventTimelineSet$roo2.roomId) !== null && _eventTimelineSet$roo !== void 0 ? _eventTimelineSet$roo : null; - if (this.roomId) { - this.startState = new _roomState2.RoomState(this.roomId); - this.endState = new _roomState2.RoomState(this.roomId); - } - - // this is used by client.js - this.paginationRequests = { - b: null, - f: null - }; - this.name = this.roomId + ":" + new Date().toISOString(); - } - - /** - * Initialise the start and end state with the given events - * - *

This can only be called before any events are added. - * - * @param stateEvents - list of state events to initialise the - * state with. - * @throws Error if an attempt is made to call this after addEvent is called. - */ - initialiseState(stateEvents, { - timelineWasEmpty - } = {}) { - var _this$startState, _this$endState; - if (this.events.length > 0) { - throw new Error("Cannot initialise state after events are added"); - } - (_this$startState = this.startState) === null || _this$startState === void 0 ? void 0 : _this$startState.setStateEvents(stateEvents, { - timelineWasEmpty - }); - (_this$endState = this.endState) === null || _this$endState === void 0 ? void 0 : _this$endState.setStateEvents(stateEvents, { - timelineWasEmpty - }); - } - - /** - * Forks the (live) timeline, taking ownership of the existing directional state of this timeline. - * All attached listeners will keep receiving state updates from the new live timeline state. - * The end state of this timeline gets replaced with an independent copy of the current RoomState, - * and will need a new pagination token if it ever needs to paginate forwards. - * @param direction - EventTimeline.BACKWARDS to get the state at the - * start of the timeline; EventTimeline.FORWARDS to get the state at the end - * of the timeline. - * - * @returns the new timeline - */ - forkLive(direction) { - const forkState = this.getState(direction); - const timeline = new EventTimeline(this.eventTimelineSet); - timeline.startState = forkState === null || forkState === void 0 ? void 0 : forkState.clone(); - // Now clobber the end state of the new live timeline with that from the - // previous live timeline. It will be identical except that we'll keep - // using the same RoomMember objects for the 'live' set of members with any - // listeners still attached - timeline.endState = forkState; - // Firstly, we just stole the current timeline's end state, so it needs a new one. - // Make an immutable copy of the state so back pagination will get the correct sentinels. - this.endState = forkState === null || forkState === void 0 ? void 0 : forkState.clone(); - return timeline; - } - - /** - * Creates an independent timeline, inheriting the directional state from this timeline. - * - * @param direction - EventTimeline.BACKWARDS to get the state at the - * start of the timeline; EventTimeline.FORWARDS to get the state at the end - * of the timeline. - * - * @returns the new timeline - */ - fork(direction) { - const forkState = this.getState(direction); - const timeline = new EventTimeline(this.eventTimelineSet); - timeline.startState = forkState === null || forkState === void 0 ? void 0 : forkState.clone(); - timeline.endState = forkState === null || forkState === void 0 ? void 0 : forkState.clone(); - return timeline; - } - - /** - * Get the ID of the room for this timeline - * @returns room ID - */ - getRoomId() { - return this.roomId; - } - - /** - * Get the filter for this timeline's timelineSet (if any) - * @returns filter - */ - getFilter() { - return this.eventTimelineSet.getFilter(); - } - - /** - * Get the timelineSet for this timeline - * @returns timelineSet - */ - getTimelineSet() { - return this.eventTimelineSet; - } - - /** - * Get the base index. - * - *

This is an index which is incremented when events are prepended to the - * timeline. An individual event therefore stays at the same index in the array - * relative to the base index (although note that a given event's index may - * well be less than the base index, thus giving that event a negative relative - * index). - */ - getBaseIndex() { - return this.baseIndex; - } - - /** - * Get the list of events in this context - * - * @returns An array of MatrixEvents - */ - getEvents() { - return this.events; - } - - /** - * Get the room state at the start/end of the timeline - * - * @param direction - EventTimeline.BACKWARDS to get the state at the - * start of the timeline; EventTimeline.FORWARDS to get the state at the end - * of the timeline. - * - * @returns state at the start/end of the timeline - */ - getState(direction) { - if (direction == EventTimeline.BACKWARDS) { - return this.startState; - } else if (direction == EventTimeline.FORWARDS) { - return this.endState; - } else { - throw new Error("Invalid direction '" + direction + "'"); - } - } - - /** - * Get a pagination token - * - * @param direction - EventTimeline.BACKWARDS to get the pagination - * token for going backwards in time; EventTimeline.FORWARDS to get the - * pagination token for going forwards in time. - * - * @returns pagination token - */ - getPaginationToken(direction) { - if (this.roomId) { - return this.getState(direction).paginationToken; - } else if (direction === Direction.Backward) { - return this.startToken; - } else { - return this.endToken; - } - } - - /** - * Set a pagination token - * - * @param token - pagination token - * - * @param direction - EventTimeline.BACKWARDS to set the pagination - * token for going backwards in time; EventTimeline.FORWARDS to set the - * pagination token for going forwards in time. - */ - setPaginationToken(token, direction) { - if (this.roomId) { - this.getState(direction).paginationToken = token; - } else if (direction === Direction.Backward) { - this.startToken = token; - } else { - this.endToken = token; - } - } - - /** - * Get the next timeline in the series - * - * @param direction - EventTimeline.BACKWARDS to get the previous - * timeline; EventTimeline.FORWARDS to get the next timeline. - * - * @returns previous or following timeline, if they have been - * joined up. - */ - getNeighbouringTimeline(direction) { - if (direction == EventTimeline.BACKWARDS) { - return this.prevTimeline; - } else if (direction == EventTimeline.FORWARDS) { - return this.nextTimeline; - } else { - throw new Error("Invalid direction '" + direction + "'"); - } - } - - /** - * Set the next timeline in the series - * - * @param neighbour - previous/following timeline - * - * @param direction - EventTimeline.BACKWARDS to set the previous - * timeline; EventTimeline.FORWARDS to set the next timeline. - * - * @throws Error if an attempt is made to set the neighbouring timeline when - * it is already set. - */ - setNeighbouringTimeline(neighbour, direction) { - if (this.getNeighbouringTimeline(direction)) { - throw new Error("timeline already has a neighbouring timeline - " + "cannot reset neighbour (direction: " + direction + ")"); - } - if (direction == EventTimeline.BACKWARDS) { - this.prevTimeline = neighbour; - } else if (direction == EventTimeline.FORWARDS) { - this.nextTimeline = neighbour; - } else { - throw new Error("Invalid direction '" + direction + "'"); - } - - // make sure we don't try to paginate this timeline - this.setPaginationToken(null, direction); - } - - /** - * Add a new event to the timeline, and update the state - * - * @param event - new event - * @param options - addEvent options - */ - - addEvent(event, toStartOfTimelineOrOpts, roomState) { - let toStartOfTimeline = !!toStartOfTimelineOrOpts; - let timelineWasEmpty; - if (typeof toStartOfTimelineOrOpts === "object") { - ({ - toStartOfTimeline, - roomState, - timelineWasEmpty - } = toStartOfTimelineOrOpts); - } else if (toStartOfTimelineOrOpts !== undefined) { - // Deprecation warning - // FIXME: Remove after 2023-06-01 (technical debt) - _logger.logger.warn("Overload deprecated: " + "`EventTimeline.addEvent(event, toStartOfTimeline, roomState?)` " + "is deprecated in favor of the overload with `EventTimeline.addEvent(event, IAddEventOptions)`"); - } - if (!roomState) { - roomState = toStartOfTimeline ? this.startState : this.endState; - } - const timelineSet = this.getTimelineSet(); - if (timelineSet.room) { - EventTimeline.setEventMetadata(event, roomState, toStartOfTimeline); - - // modify state but only on unfiltered timelineSets - if (event.isState() && timelineSet.room.getUnfilteredTimelineSet() === timelineSet) { - var _roomState; - (_roomState = roomState) === null || _roomState === void 0 ? void 0 : _roomState.setStateEvents([event], { - timelineWasEmpty - }); - // it is possible that the act of setting the state event means we - // can set more metadata (specifically sender/target props), so try - // it again if the prop wasn't previously set. It may also mean that - // the sender/target is updated (if the event set was a room member event) - // so we want to use the *updated* member (new avatar/name) instead. - // - // However, we do NOT want to do this on member events if we're going - // back in time, else we'll set the .sender value for BEFORE the given - // member event, whereas we want to set the .sender value for the ACTUAL - // member event itself. - if (!event.sender || event.getType() === _event.EventType.RoomMember && !toStartOfTimeline) { - EventTimeline.setEventMetadata(event, roomState, toStartOfTimeline); - } - } - } - let insertIndex; - if (toStartOfTimeline) { - insertIndex = 0; - } else { - insertIndex = this.events.length; - } - this.events.splice(insertIndex, 0, event); // insert element - if (toStartOfTimeline) { - this.baseIndex++; - } - } - - /** - * Remove an event from the timeline - * - * @param eventId - ID of event to be removed - * @returns removed event, or null if not found - */ - removeEvent(eventId) { - for (let i = this.events.length - 1; i >= 0; i--) { - const ev = this.events[i]; - if (ev.getId() == eventId) { - this.events.splice(i, 1); - if (i < this.baseIndex) { - this.baseIndex--; - } - return ev; - } - } - return null; - } - - /** - * Return a string to identify this timeline, for debugging - * - * @returns name for this timeline - */ - toString() { - return this.name; - } -} -exports.EventTimeline = EventTimeline; -(0, _defineProperty2.default)(EventTimeline, "BACKWARDS", Direction.Backward); -(0, _defineProperty2.default)(EventTimeline, "FORWARDS", Direction.Forward); -//# sourceMappingURL=event-timeline.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js.map deleted file mode 100644 index 76dd790..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event-timeline.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event-timeline.js","names":["_logger","require","_roomState2","_event","Direction","exports","EventTimeline","setEventMetadata","event","stateContext","toStartOfTimeline","_event$sender","_event$sender$events","_event$target","_event$target$events","sender","events","member","getSentinelMember","getSender","target","getType","EventType","RoomMember","getStateKey","isState","forwardLooking","constructor","eventTimelineSet","_eventTimelineSet$roo","_eventTimelineSet$roo2","_defineProperty2","default","Backward","Forward","roomId","room","startState","RoomState","endState","paginationRequests","b","f","name","Date","toISOString","initialiseState","stateEvents","timelineWasEmpty","_this$startState","_this$endState","length","Error","setStateEvents","forkLive","direction","forkState","getState","timeline","clone","fork","getRoomId","getFilter","getTimelineSet","getBaseIndex","baseIndex","getEvents","BACKWARDS","FORWARDS","getPaginationToken","paginationToken","startToken","endToken","setPaginationToken","token","getNeighbouringTimeline","prevTimeline","nextTimeline","setNeighbouringTimeline","neighbour","addEvent","toStartOfTimelineOrOpts","roomState","undefined","logger","warn","timelineSet","getUnfilteredTimelineSet","_roomState","insertIndex","splice","removeEvent","eventId","i","ev","getId","toString"],"sources":["../../src/models/event-timeline.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../logger\";\nimport { IMarkerFoundOptions, RoomState } from \"./room-state\";\nimport { EventTimelineSet } from \"./event-timeline-set\";\nimport { MatrixEvent } from \"./event\";\nimport { Filter } from \"../filter\";\nimport { EventType } from \"../@types/event\";\n\nexport interface IInitialiseStateOptions extends Pick {\n // This is a separate interface without any extra stuff currently added on\n // top of `IMarkerFoundOptions` just because it feels like they have\n // different concerns. One shouldn't necessarily look to add to\n // `IMarkerFoundOptions` just because they want to add an extra option to\n // `initialiseState`.\n}\n\nexport interface IAddEventOptions extends Pick {\n /** Whether to insert the new event at the start of the timeline where the\n * oldest events are (timeline is in chronological order, oldest to most\n * recent) */\n toStartOfTimeline: boolean;\n /** The state events to reconcile metadata from */\n roomState?: RoomState;\n}\n\nexport enum Direction {\n Backward = \"b\",\n Forward = \"f\",\n}\n\nexport class EventTimeline {\n /**\n * Symbolic constant for methods which take a 'direction' argument:\n * refers to the start of the timeline, or backwards in time.\n */\n public static readonly BACKWARDS = Direction.Backward;\n\n /**\n * Symbolic constant for methods which take a 'direction' argument:\n * refers to the end of the timeline, or forwards in time.\n */\n public static readonly FORWARDS = Direction.Forward;\n\n /**\n * Static helper method to set sender and target properties\n *\n * @param event - the event whose metadata is to be set\n * @param stateContext - the room state to be queried\n * @param toStartOfTimeline - if true the event's forwardLooking flag is set false\n */\n public static setEventMetadata(event: MatrixEvent, stateContext: RoomState, toStartOfTimeline: boolean): void {\n // When we try to generate a sentinel member before we have that member\n // in the members object, we still generate a sentinel but it doesn't\n // have a membership event, so test to see if events.member is set. We\n // check this to avoid overriding non-sentinel members by sentinel ones\n // when adding the event to a filtered timeline\n if (!event.sender?.events?.member) {\n event.sender = stateContext.getSentinelMember(event.getSender()!);\n }\n if (!event.target?.events?.member && event.getType() === EventType.RoomMember) {\n event.target = stateContext.getSentinelMember(event.getStateKey()!);\n }\n\n if (event.isState()) {\n // room state has no concept of 'old' or 'current', but we want the\n // room state to regress back to previous values if toStartOfTimeline\n // is set, which means inspecting prev_content if it exists. This\n // is done by toggling the forwardLooking flag.\n if (toStartOfTimeline) {\n event.forwardLooking = false;\n }\n }\n }\n\n private readonly roomId: string | null;\n private readonly name: string;\n private events: MatrixEvent[] = [];\n private baseIndex = 0;\n\n private startState?: RoomState;\n private endState?: RoomState;\n // If we have a roomId then we delegate pagination token storage to the room state objects `startState` and\n // `endState`, but for things like the notification timeline which mix multiple rooms we store the tokens ourselves.\n private startToken: string | null = null;\n private endToken: string | null = null;\n\n private prevTimeline: EventTimeline | null = null;\n private nextTimeline: EventTimeline | null = null;\n public paginationRequests: Record | null> = {\n [Direction.Backward]: null,\n [Direction.Forward]: null,\n };\n\n /**\n * Construct a new EventTimeline\n *\n *

An EventTimeline represents a contiguous sequence of events in a room.\n *\n *

As well as keeping track of the events themselves, it stores the state of\n * the room at the beginning and end of the timeline, and pagination tokens for\n * going backwards and forwards in the timeline.\n *\n *

In order that clients can meaningfully maintain an index into a timeline,\n * the EventTimeline object tracks a 'baseIndex'. This starts at zero, but is\n * incremented when events are prepended to the timeline. The index of an event\n * relative to baseIndex therefore remains constant.\n *\n *

Once a timeline joins up with its neighbour, they are linked together into a\n * doubly-linked list.\n *\n * @param eventTimelineSet - the set of timelines this is part of\n */\n public constructor(private readonly eventTimelineSet: EventTimelineSet) {\n this.roomId = eventTimelineSet.room?.roomId ?? null;\n if (this.roomId) {\n this.startState = new RoomState(this.roomId);\n this.endState = new RoomState(this.roomId);\n }\n\n // this is used by client.js\n this.paginationRequests = { b: null, f: null };\n\n this.name = this.roomId + \":\" + new Date().toISOString();\n }\n\n /**\n * Initialise the start and end state with the given events\n *\n *

This can only be called before any events are added.\n *\n * @param stateEvents - list of state events to initialise the\n * state with.\n * @throws Error if an attempt is made to call this after addEvent is called.\n */\n public initialiseState(stateEvents: MatrixEvent[], { timelineWasEmpty }: IInitialiseStateOptions = {}): void {\n if (this.events.length > 0) {\n throw new Error(\"Cannot initialise state after events are added\");\n }\n\n this.startState?.setStateEvents(stateEvents, { timelineWasEmpty });\n this.endState?.setStateEvents(stateEvents, { timelineWasEmpty });\n }\n\n /**\n * Forks the (live) timeline, taking ownership of the existing directional state of this timeline.\n * All attached listeners will keep receiving state updates from the new live timeline state.\n * The end state of this timeline gets replaced with an independent copy of the current RoomState,\n * and will need a new pagination token if it ever needs to paginate forwards.\n\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns the new timeline\n */\n public forkLive(direction: Direction): EventTimeline {\n const forkState = this.getState(direction);\n const timeline = new EventTimeline(this.eventTimelineSet);\n timeline.startState = forkState?.clone();\n // Now clobber the end state of the new live timeline with that from the\n // previous live timeline. It will be identical except that we'll keep\n // using the same RoomMember objects for the 'live' set of members with any\n // listeners still attached\n timeline.endState = forkState;\n // Firstly, we just stole the current timeline's end state, so it needs a new one.\n // Make an immutable copy of the state so back pagination will get the correct sentinels.\n this.endState = forkState?.clone();\n return timeline;\n }\n\n /**\n * Creates an independent timeline, inheriting the directional state from this timeline.\n *\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns the new timeline\n */\n public fork(direction: Direction): EventTimeline {\n const forkState = this.getState(direction);\n const timeline = new EventTimeline(this.eventTimelineSet);\n timeline.startState = forkState?.clone();\n timeline.endState = forkState?.clone();\n return timeline;\n }\n\n /**\n * Get the ID of the room for this timeline\n * @returns room ID\n */\n public getRoomId(): string | null {\n return this.roomId;\n }\n\n /**\n * Get the filter for this timeline's timelineSet (if any)\n * @returns filter\n */\n public getFilter(): Filter | undefined {\n return this.eventTimelineSet.getFilter();\n }\n\n /**\n * Get the timelineSet for this timeline\n * @returns timelineSet\n */\n public getTimelineSet(): EventTimelineSet {\n return this.eventTimelineSet;\n }\n\n /**\n * Get the base index.\n *\n *

This is an index which is incremented when events are prepended to the\n * timeline. An individual event therefore stays at the same index in the array\n * relative to the base index (although note that a given event's index may\n * well be less than the base index, thus giving that event a negative relative\n * index).\n */\n public getBaseIndex(): number {\n return this.baseIndex;\n }\n\n /**\n * Get the list of events in this context\n *\n * @returns An array of MatrixEvents\n */\n public getEvents(): MatrixEvent[] {\n return this.events;\n }\n\n /**\n * Get the room state at the start/end of the timeline\n *\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns state at the start/end of the timeline\n */\n public getState(direction: Direction): RoomState | undefined {\n if (direction == EventTimeline.BACKWARDS) {\n return this.startState;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.endState;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Get a pagination token\n *\n * @param direction - EventTimeline.BACKWARDS to get the pagination\n * token for going backwards in time; EventTimeline.FORWARDS to get the\n * pagination token for going forwards in time.\n *\n * @returns pagination token\n */\n public getPaginationToken(direction: Direction): string | null {\n if (this.roomId) {\n return this.getState(direction)!.paginationToken;\n } else if (direction === Direction.Backward) {\n return this.startToken;\n } else {\n return this.endToken;\n }\n }\n\n /**\n * Set a pagination token\n *\n * @param token - pagination token\n *\n * @param direction - EventTimeline.BACKWARDS to set the pagination\n * token for going backwards in time; EventTimeline.FORWARDS to set the\n * pagination token for going forwards in time.\n */\n public setPaginationToken(token: string | null, direction: Direction): void {\n if (this.roomId) {\n this.getState(direction)!.paginationToken = token;\n } else if (direction === Direction.Backward) {\n this.startToken = token;\n } else {\n this.endToken = token;\n }\n }\n\n /**\n * Get the next timeline in the series\n *\n * @param direction - EventTimeline.BACKWARDS to get the previous\n * timeline; EventTimeline.FORWARDS to get the next timeline.\n *\n * @returns previous or following timeline, if they have been\n * joined up.\n */\n public getNeighbouringTimeline(direction: Direction): EventTimeline | null {\n if (direction == EventTimeline.BACKWARDS) {\n return this.prevTimeline;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.nextTimeline;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Set the next timeline in the series\n *\n * @param neighbour - previous/following timeline\n *\n * @param direction - EventTimeline.BACKWARDS to set the previous\n * timeline; EventTimeline.FORWARDS to set the next timeline.\n *\n * @throws Error if an attempt is made to set the neighbouring timeline when\n * it is already set.\n */\n public setNeighbouringTimeline(neighbour: EventTimeline, direction: Direction): void {\n if (this.getNeighbouringTimeline(direction)) {\n throw new Error(\n \"timeline already has a neighbouring timeline - \" +\n \"cannot reset neighbour (direction: \" +\n direction +\n \")\",\n );\n }\n\n if (direction == EventTimeline.BACKWARDS) {\n this.prevTimeline = neighbour;\n } else if (direction == EventTimeline.FORWARDS) {\n this.nextTimeline = neighbour;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n\n // make sure we don't try to paginate this timeline\n this.setPaginationToken(null, direction);\n }\n\n /**\n * Add a new event to the timeline, and update the state\n *\n * @param event - new event\n * @param options - addEvent options\n */\n public addEvent(event: MatrixEvent, { toStartOfTimeline, roomState, timelineWasEmpty }: IAddEventOptions): void;\n /**\n * @deprecated In favor of the overload with `IAddEventOptions`\n */\n public addEvent(event: MatrixEvent, toStartOfTimeline: boolean, roomState?: RoomState): void;\n public addEvent(\n event: MatrixEvent,\n toStartOfTimelineOrOpts: boolean | IAddEventOptions,\n roomState?: RoomState,\n ): void {\n let toStartOfTimeline = !!toStartOfTimelineOrOpts;\n let timelineWasEmpty: boolean | undefined;\n if (typeof toStartOfTimelineOrOpts === \"object\") {\n ({ toStartOfTimeline, roomState, timelineWasEmpty } = toStartOfTimelineOrOpts);\n } else if (toStartOfTimelineOrOpts !== undefined) {\n // Deprecation warning\n // FIXME: Remove after 2023-06-01 (technical debt)\n logger.warn(\n \"Overload deprecated: \" +\n \"`EventTimeline.addEvent(event, toStartOfTimeline, roomState?)` \" +\n \"is deprecated in favor of the overload with `EventTimeline.addEvent(event, IAddEventOptions)`\",\n );\n }\n\n if (!roomState) {\n roomState = toStartOfTimeline ? this.startState : this.endState;\n }\n\n const timelineSet = this.getTimelineSet();\n\n if (timelineSet.room) {\n EventTimeline.setEventMetadata(event, roomState!, toStartOfTimeline);\n\n // modify state but only on unfiltered timelineSets\n if (event.isState() && timelineSet.room.getUnfilteredTimelineSet() === timelineSet) {\n roomState?.setStateEvents([event], { timelineWasEmpty });\n // it is possible that the act of setting the state event means we\n // can set more metadata (specifically sender/target props), so try\n // it again if the prop wasn't previously set. It may also mean that\n // the sender/target is updated (if the event set was a room member event)\n // so we want to use the *updated* member (new avatar/name) instead.\n //\n // However, we do NOT want to do this on member events if we're going\n // back in time, else we'll set the .sender value for BEFORE the given\n // member event, whereas we want to set the .sender value for the ACTUAL\n // member event itself.\n if (!event.sender || (event.getType() === EventType.RoomMember && !toStartOfTimeline)) {\n EventTimeline.setEventMetadata(event, roomState!, toStartOfTimeline);\n }\n }\n }\n\n let insertIndex: number;\n\n if (toStartOfTimeline) {\n insertIndex = 0;\n } else {\n insertIndex = this.events.length;\n }\n\n this.events.splice(insertIndex, 0, event); // insert element\n if (toStartOfTimeline) {\n this.baseIndex++;\n }\n }\n\n /**\n * Remove an event from the timeline\n *\n * @param eventId - ID of event to be removed\n * @returns removed event, or null if not found\n */\n public removeEvent(eventId: string): MatrixEvent | null {\n for (let i = this.events.length - 1; i >= 0; i--) {\n const ev = this.events[i];\n if (ev.getId() == eventId) {\n this.events.splice(i, 1);\n if (i < this.baseIndex) {\n this.baseIndex--;\n }\n return ev;\n }\n }\n return null;\n }\n\n /**\n * Return a string to identify this timeline, for debugging\n *\n * @returns name for this timeline\n */\n public toString(): string {\n return this.name;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts deleted file mode 100644 index d874d29..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts +++ /dev/null @@ -1,759 +0,0 @@ -/** - * This is an internal module. See {@link MatrixEvent} and {@link RoomEvent} for - * the public classes. - */ -import { ExtensibleEvent, Optional } from "matrix-events-sdk"; -import { VerificationRequest } from "../crypto/verification/request/VerificationRequest"; -import { EventType, MsgType, RelationType } from "../@types/event"; -import { Crypto } from "../crypto"; -import { RoomMember } from "./room-member"; -import { Thread, ThreadEvent, EventHandlerMap as ThreadEventHandlerMap } from "./thread"; -import { IActionsObject } from "../pushprocessor"; -import { MatrixError } from "../http-api"; -import { TypedEventEmitter } from "./typed-event-emitter"; -import { EventStatus } from "./event-status"; -import { CryptoBackend } from "../common-crypto/CryptoBackend"; -export { EventStatus } from "./event-status"; -export interface IContent { - [key: string]: any; - "msgtype"?: MsgType | string; - "membership"?: string; - "avatar_url"?: string; - "displayname"?: string; - "m.relates_to"?: IEventRelation; - "org.matrix.msc3952.mentions"?: IMentions; -} -type StrippedState = Required>; -export interface IUnsigned { - "age"?: number; - "prev_sender"?: string; - "prev_content"?: IContent; - "redacted_because"?: IEvent; - "transaction_id"?: string; - "invite_room_state"?: StrippedState[]; - "m.relations"?: Record; -} -export interface IThreadBundledRelationship { - latest_event: IEvent; - count: number; - current_user_participated?: boolean; -} -export interface IEvent { - event_id: string; - type: string; - content: IContent; - sender: string; - room_id?: string; - origin_server_ts: number; - txn_id?: string; - state_key?: string; - membership?: string; - unsigned: IUnsigned; - redacts?: string; - /** - * @deprecated in favour of `sender` - */ - user_id?: string; - /** - * @deprecated in favour of `unsigned.prev_content` - */ - prev_content?: IContent; - /** - * @deprecated in favour of `origin_server_ts` - */ - age?: number; -} -export interface IAggregatedRelation { - origin_server_ts: number; - event_id?: string; - sender?: string; - type?: string; - count?: number; - key?: string; -} -export interface IEventRelation { - "rel_type"?: RelationType | string; - "event_id"?: string; - "is_falling_back"?: boolean; - "m.in_reply_to"?: { - event_id?: string; - }; - "key"?: string; -} -export interface IMentions { - user_ids?: string[]; - room?: boolean; -} -/** - * When an event is a visibility change event, as per MSC3531, - * the visibility change implied by the event. - */ -export interface IVisibilityChange { - /** - * If `true`, the target event should be made visible. - * Otherwise, it should be hidden. - */ - visible: boolean; - /** - * The event id affected. - */ - eventId: string; - /** - * Optionally, a human-readable reason explaining why - * the event was hidden. Ignored if the event was made - * visible. - */ - reason: string | null; -} -export interface IClearEvent { - room_id?: string; - type: string; - content: Omit; - unsigned?: IUnsigned; -} -interface IKeyRequestRecipient { - userId: string; - deviceId: "*" | string; -} -export interface IDecryptOptions { - emit?: boolean; - isRetry?: boolean; - forceRedecryptIfUntrusted?: boolean; -} -/** - * Message hiding, as specified by https://github.com/matrix-org/matrix-doc/pull/3531. - */ -export type MessageVisibility = IMessageVisibilityHidden | IMessageVisibilityVisible; -/** - * Variant of `MessageVisibility` for the case in which the message should be displayed. - */ -export interface IMessageVisibilityVisible { - readonly visible: true; -} -/** - * Variant of `MessageVisibility` for the case in which the message should be hidden. - */ -export interface IMessageVisibilityHidden { - readonly visible: false; - /** - * Optionally, a human-readable reason to show to the user indicating why the - * message has been hidden (e.g. "Message Pending Moderation"). - */ - readonly reason: string | null; -} -export declare enum MatrixEventEvent { - Decrypted = "Event.decrypted", - BeforeRedaction = "Event.beforeRedaction", - VisibilityChange = "Event.visibilityChange", - LocalEventIdReplaced = "Event.localEventIdReplaced", - Status = "Event.status", - Replaced = "Event.replaced", - RelationsCreated = "Event.relationsCreated" -} -export type MatrixEventEmittedEvents = MatrixEventEvent | ThreadEvent.Update; -export type MatrixEventHandlerMap = { - /** - * Fires when an event is decrypted - * - * @param event - The matrix event which has been decrypted - * @param err - The error that occurred during decryption, or `undefined` if no error occurred. - */ - [MatrixEventEvent.Decrypted]: (event: MatrixEvent, err?: Error) => void; - [MatrixEventEvent.BeforeRedaction]: (event: MatrixEvent, redactionEvent: MatrixEvent) => void; - [MatrixEventEvent.VisibilityChange]: (event: MatrixEvent, visible: boolean) => void; - [MatrixEventEvent.LocalEventIdReplaced]: (event: MatrixEvent) => void; - [MatrixEventEvent.Status]: (event: MatrixEvent, status: EventStatus | null) => void; - [MatrixEventEvent.Replaced]: (event: MatrixEvent) => void; - [MatrixEventEvent.RelationsCreated]: (relationType: string, eventType: string) => void; -} & Pick; -export declare class MatrixEvent extends TypedEventEmitter { - event: Partial; - private pushActions; - private _replacingEvent; - private _localRedactionEvent; - private _isCancelled; - private clearEvent?; - private visibility; - private _hasCachedExtEv; - private _cachedExtEv; - private senderCurve25519Key; - private claimedEd25519Key; - private forwardingCurve25519KeyChain; - private untrusted; - private decryptionPromise; - private retryDecryption; - private txnId?; - /** - * A reference to the thread this event belongs to - */ - private thread?; - private threadId?; - private encryptedDisabledForUnverifiedDevices; - localTimestamp: number; - /** - * The room member who sent this event, or null e.g. - * this is a presence event. This is only guaranteed to be set for events that - * appear in a timeline, ie. do not guarantee that it will be set on state - * events. - * @privateRemarks - * Should be read-only - */ - sender: RoomMember | null; - /** - * The room member who is the target of this event, e.g. - * the invitee, the person being banned, etc. - * @privateRemarks - * Should be read-only - */ - target: RoomMember | null; - /** - * The sending status of the event. - * @privateRemarks - * Should be read-only - */ - status: EventStatus | null; - /** - * most recent error associated with sending the event, if any - * @privateRemarks - * Should be read-only - */ - error: MatrixError | null; - /** - * True if this event is 'forward looking', meaning - * that getDirectionalContent() will return event.content and not event.prev_content. - * Only state events may be backwards looking - * Default: true. This property is experimental and may change. - * @privateRemarks - * Should be read-only - */ - forwardLooking: boolean; - verificationRequest?: VerificationRequest; - private readonly reEmitter; - /** - * Construct a Matrix Event object - * - * @param event - The raw (possibly encrypted) event. Do not access - * this property directly unless you absolutely have to. Prefer the getter - * methods defined on this class. Using the getter methods shields your app - * from changes to event JSON between Matrix versions. - */ - constructor(event?: Partial); - /** - * Unstable getter to try and get an extensible event. Note that this might - * return a falsy value if the event could not be parsed as an extensible - * event. - * - * @deprecated Use stable functions where possible. - */ - get unstableExtensibleEvent(): Optional; - private invalidateExtensibleEvent; - /** - * Gets the event as though it would appear unencrypted. If the event is already not - * encrypted, it is simply returned as-is. - * @returns The event in wire format. - */ - getEffectiveEvent(): IEvent; - /** - * Get the event_id for this event. - * @returns The event ID, e.g. $143350589368169JsLZx:localhost - * - */ - getId(): string | undefined; - /** - * Get the user_id for this event. - * @returns The user ID, e.g. `@alice:matrix.org` - */ - getSender(): string | undefined; - /** - * Get the (decrypted, if necessary) type of event. - * - * @returns The event type, e.g. `m.room.message` - */ - getType(): EventType | string; - /** - * Get the (possibly encrypted) type of the event that will be sent to the - * homeserver. - * - * @returns The event type. - */ - getWireType(): EventType | string; - /** - * Get the room_id for this event. This will return `undefined` - * for `m.presence` events. - * @returns The room ID, e.g. !cURbafjkfsMDVwdRDQ:matrix.org - * - */ - getRoomId(): string | undefined; - /** - * Get the timestamp of this event. - * @returns The event timestamp, e.g. `1433502692297` - */ - getTs(): number; - /** - * Get the timestamp of this event, as a Date object. - * @returns The event date, e.g. `new Date(1433502692297)` - */ - getDate(): Date | null; - /** - * Get a string containing details of this event - * - * This is intended for logging, to help trace errors. Example output: - * - * @example - * ``` - * id=$HjnOHV646n0SjLDAqFrgIjim7RCpB7cdMXFrekWYAn type=m.room.encrypted - * sender=@user:example.com room=!room:example.com ts=2022-10-25T17:30:28.404Z - * ``` - */ - getDetails(): string; - /** - * Get the (decrypted, if necessary) event content JSON, even if the event - * was replaced by another event. - * - * @returns The event content JSON, or an empty object. - */ - getOriginalContent(): T; - /** - * Get the (decrypted, if necessary) event content JSON, - * or the content from the replacing event, if any. - * See `makeReplaced`. - * - * @returns The event content JSON, or an empty object. - */ - getContent(): T; - /** - * Get the (possibly encrypted) event content JSON that will be sent to the - * homeserver. - * - * @returns The event content JSON, or an empty object. - */ - getWireContent(): IContent; - /** - * Get the event ID of the thread head - */ - get threadRootId(): string | undefined; - /** - * A helper to check if an event is a thread's head or not - */ - get isThreadRoot(): boolean; - get replyEventId(): string | undefined; - get relationEventId(): string | undefined; - /** - * Get the previous event content JSON. This will only return something for - * state events which exist in the timeline. - * @returns The previous event content JSON, or an empty object. - */ - getPrevContent(): IContent; - /** - * Get either 'content' or 'prev_content' depending on if this event is - * 'forward-looking' or not. This can be modified via event.forwardLooking. - * In practice, this means we get the chronologically earlier content value - * for this event (this method should surely be called getEarlierContent) - * This method is experimental and may change. - * @returns event.content if this event is forward-looking, else - * event.prev_content. - */ - getDirectionalContent(): IContent; - /** - * Get the age of this event. This represents the age of the event when the - * event arrived at the device, and not the age of the event when this - * function was called. - * Can only be returned once the server has echo'ed back - * @returns The age of this event in milliseconds. - */ - getAge(): number | undefined; - /** - * Get the age of the event when this function was called. - * This is the 'age' field adjusted according to how long this client has - * had the event. - * @returns The age of this event in milliseconds. - */ - getLocalAge(): number; - /** - * Get the event state_key if it has one. This will return undefined - * for message events. - * @returns The event's `state_key`. - */ - getStateKey(): string | undefined; - /** - * Check if this event is a state event. - * @returns True if this is a state event. - */ - isState(): boolean; - /** - * Replace the content of this event with encrypted versions. - * (This is used when sending an event; it should not be used by applications). - * - * @internal - * - * @param cryptoType - type of the encrypted event - typically - * "m.room.encrypted" - * - * @param cryptoContent - raw 'content' for the encrypted event. - * - * @param senderCurve25519Key - curve25519 key to record for the - * sender of this event. - * See {@link MatrixEvent#getSenderKey}. - * - * @param claimedEd25519Key - claimed ed25519 key to record for the - * sender if this event. - * See {@link MatrixEvent#getClaimedEd25519Key} - */ - makeEncrypted(cryptoType: string, cryptoContent: object, senderCurve25519Key: string, claimedEd25519Key: string): void; - /** - * Check if this event is currently being decrypted. - * - * @returns True if this event is currently being decrypted, else false. - */ - isBeingDecrypted(): boolean; - getDecryptionPromise(): Promise | null; - /** - * Check if this event is an encrypted event which we failed to decrypt - * - * (This implies that we might retry decryption at some point in the future) - * - * @returns True if this event is an encrypted event which we - * couldn't decrypt. - */ - isDecryptionFailure(): boolean; - get isEncryptedDisabledForUnverifiedDevices(): boolean; - shouldAttemptDecryption(): boolean; - /** - * Start the process of trying to decrypt this event. - * - * (This is used within the SDK: it isn't intended for use by applications) - * - * @internal - * - * @param crypto - crypto module - * - * @returns promise which resolves (to undefined) when the decryption - * attempt is completed. - */ - attemptDecryption(crypto: CryptoBackend, options?: IDecryptOptions): Promise; - /** - * Cancel any room key request for this event and resend another. - * - * @param crypto - crypto module - * @param userId - the user who received this event - * - * @returns a promise that resolves when the request is queued - */ - cancelAndResendKeyRequest(crypto: Crypto, userId: string): Promise; - /** - * Calculate the recipients for keyshare requests. - * - * @param userId - the user who received this event. - * - * @returns array of recipients - */ - getKeyRequestRecipients(userId: string): IKeyRequestRecipient[]; - private decryptionLoop; - private badEncryptedMessage; - /** - * Update the cleartext data on this event. - * - * (This is used after decrypting an event; it should not be used by applications). - * - * @internal - * - * @param decryptionResult - the decryption result, including the plaintext and some key info - * - * @remarks - * Fires {@link MatrixEventEvent.Decrypted} - */ - private setClearData; - /** - * Gets the cleartext content for this event. If the event is not encrypted, - * or encryption has not been completed, this will return null. - * - * @returns The cleartext (decrypted) content for the event - */ - getClearContent(): IContent | null; - /** - * Check if the event is encrypted. - * @returns True if this event is encrypted. - */ - isEncrypted(): boolean; - /** - * The curve25519 key for the device that we think sent this event - * - * For an Olm-encrypted event, this is inferred directly from the DH - * exchange at the start of the session: the curve25519 key is involved in - * the DH exchange, so only a device which holds the private part of that - * key can establish such a session. - * - * For a megolm-encrypted event, it is inferred from the Olm message which - * established the megolm session - */ - getSenderKey(): string | null; - /** - * The additional keys the sender of this encrypted event claims to possess. - * - * Just a wrapper for #getClaimedEd25519Key (q.v.) - */ - getKeysClaimed(): Partial>; - /** - * Get the ed25519 the sender of this event claims to own. - * - * For Olm messages, this claim is encoded directly in the plaintext of the - * event itself. For megolm messages, it is implied by the m.room_key event - * which established the megolm session. - * - * Until we download the device list of the sender, it's just a claim: the - * device list gives a proof that the owner of the curve25519 key used for - * this event (and returned by #getSenderKey) also owns the ed25519 key by - * signing the public curve25519 key with the ed25519 key. - * - * In general, applications should not use this method directly, but should - * instead use MatrixClient.getEventSenderDeviceInfo. - */ - getClaimedEd25519Key(): string | null; - /** - * Get the curve25519 keys of the devices which were involved in telling us - * about the claimedEd25519Key and sender curve25519 key. - * - * Normally this will be empty, but in the case of a forwarded megolm - * session, the sender keys are sent to us by another device (the forwarding - * device), which we need to trust to do this. In that case, the result will - * be a list consisting of one entry. - * - * If the device that sent us the key (A) got it from another device which - * it wasn't prepared to vouch for (B), the result will be [A, B]. And so on. - * - * @returns base64-encoded curve25519 keys, from oldest to newest. - */ - getForwardingCurve25519KeyChain(): string[]; - /** - * Whether the decryption key was obtained from an untrusted source. If so, - * we cannot verify the authenticity of the message. - */ - isKeySourceUntrusted(): boolean | undefined; - getUnsigned(): IUnsigned; - setUnsigned(unsigned: IUnsigned): void; - unmarkLocallyRedacted(): boolean; - markLocallyRedacted(redactionEvent: MatrixEvent): void; - /** - * Change the visibility of an event, as per https://github.com/matrix-org/matrix-doc/pull/3531 . - * - * @param visibilityChange - event holding a hide/unhide payload, or nothing - * if the event is being reset to its original visibility (presumably - * by a visibility event being redacted). - * - * @remarks - * Fires {@link MatrixEventEvent.VisibilityChange} if `visibilityEvent` - * caused a change in the actual visibility of this event, either by making it - * visible (if it was hidden), by making it hidden (if it was visible) or by - * changing the reason (if it was hidden). - */ - applyVisibilityEvent(visibilityChange?: IVisibilityChange): void; - /** - * Return instructions to display or hide the message. - * - * @returns Instructions determining whether the message - * should be displayed. - */ - messageVisibility(): MessageVisibility; - /** - * Update the content of an event in the same way it would be by the server - * if it were redacted before it was sent to us - * - * @param redactionEvent - event causing the redaction - */ - makeRedacted(redactionEvent: MatrixEvent): void; - /** - * Check if this event has been redacted - * - * @returns True if this event has been redacted - */ - isRedacted(): boolean; - /** - * Check if this event is a redaction of another event - * - * @returns True if this event is a redaction - */ - isRedaction(): boolean; - /** - * Return the visibility change caused by this event, - * as per https://github.com/matrix-org/matrix-doc/pull/3531. - * - * @returns If the event is a well-formed visibility change event, - * an instance of `IVisibilityChange`, otherwise `null`. - */ - asVisibilityChange(): IVisibilityChange | null; - /** - * Check if this event alters the visibility of another event, - * as per https://github.com/matrix-org/matrix-doc/pull/3531. - * - * @returns True if this event alters the visibility - * of another event. - */ - isVisibilityEvent(): boolean; - /** - * Get the (decrypted, if necessary) redaction event JSON - * if event was redacted - * - * @returns The redaction event JSON, or an empty object - */ - getRedactionEvent(): IEvent | {} | null; - /** - * Get the push actions, if known, for this event - * - * @returns push actions - */ - getPushActions(): IActionsObject | null; - /** - * Set the push actions for this event. - * - * @param pushActions - push actions - */ - setPushActions(pushActions: IActionsObject | null): void; - /** - * Replace the `event` property and recalculate any properties based on it. - * @param event - the object to assign to the `event` property - */ - handleRemoteEcho(event: object): void; - /** - * Whether the event is in any phase of sending, send failure, waiting for - * remote echo, etc. - */ - isSending(): boolean; - /** - * Update the event's sending status and emit an event as well. - * - * @param status - The new status - */ - setStatus(status: EventStatus | null): void; - replaceLocalEventId(eventId: string): void; - /** - * Get whether the event is a relation event, and of a given type if - * `relType` is passed in. State events cannot be relation events - * - * @param relType - if given, checks that the relation is of the - * given type - */ - isRelation(relType?: string): boolean; - /** - * Get relation info for the event, if any. - */ - getRelation(): IEventRelation | null; - /** - * Set an event that replaces the content of this event, through an m.replace relation. - * - * @param newEvent - the event with the replacing content, if any. - * - * @remarks - * Fires {@link MatrixEventEvent.Replaced} - */ - makeReplaced(newEvent?: MatrixEvent): void; - /** - * Returns the status of any associated edit or redaction - * (not for reactions/annotations as their local echo doesn't affect the original event), - * or else the status of the event. - */ - getAssociatedStatus(): EventStatus | null; - getServerAggregatedRelation(relType: RelationType | string): T | undefined; - /** - * Returns the event ID of the event replacing the content of this event, if any. - */ - replacingEventId(): string | undefined; - /** - * Returns the event replacing the content of this event, if any. - * Replacements are aggregated on the server, so this would only - * return an event in case it came down the sync, or for local echo of edits. - */ - replacingEvent(): MatrixEvent | null; - /** - * Returns the origin_server_ts of the event replacing the content of this event, if any. - */ - replacingEventDate(): Date | undefined; - /** - * Returns the event that wants to redact this event, but hasn't been sent yet. - * @returns the event - */ - localRedactionEvent(): MatrixEvent | null; - /** - * For relations and redactions, returns the event_id this event is referring to. - */ - getAssociatedId(): string | undefined; - /** - * Checks if this event is associated with another event. See `getAssociatedId`. - * @deprecated use hasAssociation instead. - */ - hasAssocation(): boolean; - /** - * Checks if this event is associated with another event. See `getAssociatedId`. - */ - hasAssociation(): boolean; - /** - * Update the related id with a new one. - * - * Used to replace a local id with remote one before sending - * an event with a related id. - * - * @param eventId - the new event id - */ - updateAssociatedId(eventId: string): void; - /** - * Flags an event as cancelled due to future conditions. For example, a verification - * request event in the same sync transaction may be flagged as cancelled to warn - * listeners that a cancellation event is coming down the same pipe shortly. - * @param cancelled - Whether the event is to be cancelled or not. - */ - flagCancelled(cancelled?: boolean): void; - /** - * Gets whether or not the event is flagged as cancelled. See flagCancelled() for - * more information. - * @returns True if the event is cancelled, false otherwise. - */ - isCancelled(): boolean; - /** - * Get a copy/snapshot of this event. The returned copy will be loosely linked - * back to this instance, though will have "frozen" event information. Other - * properties of this MatrixEvent instance will be copied verbatim, which can - * mean they are in reference to this instance despite being on the copy too. - * The reference the snapshot uses does not change, however members aside from - * the underlying event will not be deeply cloned, thus may be mutated internally. - * For example, the sender profile will be copied over at snapshot time, and - * the sender profile internally may mutate without notice to the consumer. - * - * This is meant to be used to snapshot the event details themselves, not the - * features (such as sender) surrounding the event. - * @returns A snapshot of this event. - */ - toSnapshot(): MatrixEvent; - /** - * Determines if this event is equivalent to the given event. This only checks - * the event object itself, not the other properties of the event. Intended for - * use with toSnapshot() to identify events changing. - * @param otherEvent - The other event to check against. - * @returns True if the events are the same, false otherwise. - */ - isEquivalentTo(otherEvent: MatrixEvent): boolean; - /** - * Summarise the event as JSON. This is currently used by React SDK's view - * event source feature and Seshat's event indexing, so take care when - * adjusting the output here. - * - * If encrypted, include both the decrypted and encrypted view of the event. - * - * This is named `toJSON` for use with `JSON.stringify` which checks objects - * for functions named `toJSON` and will call them to customise the output - * if they are defined. - */ - toJSON(): object; - setVerificationRequest(request: VerificationRequest): void; - setTxnId(txnId: string): void; - getTxnId(): string | undefined; - /** - * Set the instance of a thread associated with the current event - * @param thread - the thread - */ - setThread(thread?: Thread): void; - /** - * Get the instance of the thread associated with the current event - */ - getThread(): Thread | undefined; - setThreadId(threadId?: string): void; -} -//# sourceMappingURL=event.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts.map deleted file mode 100644 index c333e86..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event.d.ts","sourceRoot":"","sources":["../../src/models/event.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js deleted file mode 100644 index 76539a6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js +++ /dev/null @@ -1,1433 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -Object.defineProperty(exports, "EventStatus", { - enumerable: true, - get: function () { - return _eventStatus.EventStatus; - } -}); -exports.MatrixEventEvent = exports.MatrixEvent = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _matrixEventsSdk = require("matrix-events-sdk"); -var _logger = require("../logger"); -var _event = require("../@types/event"); -var _utils = require("../utils"); -var _thread = require("./thread"); -var _ReEmitter = require("../ReEmitter"); -var _typedEventEmitter = require("./typed-event-emitter"); -var _algorithms = require("../crypto/algorithms"); -var _OlmDevice = require("../crypto/OlmDevice"); -var _eventStatus = require("./event-status"); -/* -Copyright 2015 - 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * This is an internal module. See {@link MatrixEvent} and {@link RoomEvent} for - * the public classes. - */ - -// A singleton implementing `IMessageVisibilityVisible`. -const MESSAGE_VISIBLE = Object.freeze({ - visible: true -}); -let MatrixEventEvent; -exports.MatrixEventEvent = MatrixEventEvent; -(function (MatrixEventEvent) { - MatrixEventEvent["Decrypted"] = "Event.decrypted"; - MatrixEventEvent["BeforeRedaction"] = "Event.beforeRedaction"; - MatrixEventEvent["VisibilityChange"] = "Event.visibilityChange"; - MatrixEventEvent["LocalEventIdReplaced"] = "Event.localEventIdReplaced"; - MatrixEventEvent["Status"] = "Event.status"; - MatrixEventEvent["Replaced"] = "Event.replaced"; - MatrixEventEvent["RelationsCreated"] = "Event.relationsCreated"; -})(MatrixEventEvent || (exports.MatrixEventEvent = MatrixEventEvent = {})); -class MatrixEvent extends _typedEventEmitter.TypedEventEmitter { - /* Message hiding, as specified by https://github.com/matrix-org/matrix-doc/pull/3531. - Note: We're returning this object, so any value stored here MUST be frozen. - */ - - // Not all events will be extensible-event compatible, so cache a flag in - // addition to a falsy cached event value. We check the flag later on in - // a public getter to decide if the cache is valid. - - /* curve25519 key which we believe belongs to the sender of the event. See - * getSenderKey() - */ - - /* ed25519 key which the sender of this event (for olm) or the creator of - * the megolm session (for megolm) claims to own. See getClaimedEd25519Key() - */ - - /* curve25519 keys of devices involved in telling us about the - * senderCurve25519Key and claimedEd25519Key. - * See getForwardingCurve25519KeyChain(). - */ - - /* where the decryption key is untrusted - */ - - /* if we have a process decrypting this event, a Promise which resolves - * when it is finished. Normally null. - */ - - /* flag to indicate if we should retry decrypting this event after the - * first attempt (eg, we have received new data which means that a second - * attempt may succeed) - */ - - /* The txnId with which this event was sent if it was during this session, - * allows for a unique ID which does not change when the event comes back down sync. - */ - - /** - * A reference to the thread this event belongs to - */ - - /* - * True if this event is an encrypted event which we failed to decrypt, the receiver's device is unverified and - * the sender has disabled encrypting to unverified devices. - */ - - /* Set an approximate timestamp for the event relative the local clock. - * This will inherently be approximate because it doesn't take into account - * the time between the server putting the 'age' field on the event as it sent - * it to us and the time we're now constructing this event, but that's better - * than assuming the local clock is in sync with the origin HS's clock. - */ - - /** - * The room member who sent this event, or null e.g. - * this is a presence event. This is only guaranteed to be set for events that - * appear in a timeline, ie. do not guarantee that it will be set on state - * events. - * @privateRemarks - * Should be read-only - */ - - /** - * The room member who is the target of this event, e.g. - * the invitee, the person being banned, etc. - * @privateRemarks - * Should be read-only - */ - - /** - * The sending status of the event. - * @privateRemarks - * Should be read-only - */ - - /** - * most recent error associated with sending the event, if any - * @privateRemarks - * Should be read-only - */ - - /** - * True if this event is 'forward looking', meaning - * that getDirectionalContent() will return event.content and not event.prev_content. - * Only state events may be backwards looking - * Default: true. This property is experimental and may change. - * @privateRemarks - * Should be read-only - */ - - /* If the event is a `m.key.verification.request` (or to_device `m.key.verification.start`) event, - * `Crypto` will set this the `VerificationRequest` for the event - * so it can be easily accessed from the timeline. - */ - - /** - * Construct a Matrix Event object - * - * @param event - The raw (possibly encrypted) event. Do not access - * this property directly unless you absolutely have to. Prefer the getter - * methods defined on this class. Using the getter methods shields your app - * from changes to event JSON between Matrix versions. - */ - constructor(event = {}) { - var _this$getAge; - super(); - - // intern the values of matrix events to force share strings and reduce the - // amount of needless string duplication. This can save moderate amounts of - // memory (~10% on a 350MB heap). - // 'membership' at the event level (rather than the content level) is a legacy - // field that Element never otherwise looks at, but it will still take up a lot - // of space if we don't intern it. - this.event = event; - (0, _defineProperty2.default)(this, "pushActions", null); - (0, _defineProperty2.default)(this, "_replacingEvent", null); - (0, _defineProperty2.default)(this, "_localRedactionEvent", null); - (0, _defineProperty2.default)(this, "_isCancelled", false); - (0, _defineProperty2.default)(this, "clearEvent", void 0); - (0, _defineProperty2.default)(this, "visibility", MESSAGE_VISIBLE); - (0, _defineProperty2.default)(this, "_hasCachedExtEv", false); - (0, _defineProperty2.default)(this, "_cachedExtEv", undefined); - (0, _defineProperty2.default)(this, "senderCurve25519Key", null); - (0, _defineProperty2.default)(this, "claimedEd25519Key", null); - (0, _defineProperty2.default)(this, "forwardingCurve25519KeyChain", []); - (0, _defineProperty2.default)(this, "untrusted", null); - (0, _defineProperty2.default)(this, "decryptionPromise", null); - (0, _defineProperty2.default)(this, "retryDecryption", false); - (0, _defineProperty2.default)(this, "txnId", void 0); - (0, _defineProperty2.default)(this, "thread", void 0); - (0, _defineProperty2.default)(this, "threadId", void 0); - (0, _defineProperty2.default)(this, "encryptedDisabledForUnverifiedDevices", false); - (0, _defineProperty2.default)(this, "localTimestamp", void 0); - (0, _defineProperty2.default)(this, "sender", null); - (0, _defineProperty2.default)(this, "target", null); - (0, _defineProperty2.default)(this, "status", null); - (0, _defineProperty2.default)(this, "error", null); - (0, _defineProperty2.default)(this, "forwardLooking", true); - (0, _defineProperty2.default)(this, "verificationRequest", void 0); - (0, _defineProperty2.default)(this, "reEmitter", void 0); - ["state_key", "type", "sender", "room_id", "membership"].forEach(prop => { - if (typeof event[prop] !== "string") return; - event[prop] = (0, _utils.internaliseString)(event[prop]); - }); - ["membership", "avatar_url", "displayname"].forEach(prop => { - var _event$content; - if (typeof ((_event$content = event.content) === null || _event$content === void 0 ? void 0 : _event$content[prop]) !== "string") return; - event.content[prop] = (0, _utils.internaliseString)(event.content[prop]); - }); - ["rel_type"].forEach(prop => { - var _event$content2, _event$content2$mRel; - if (typeof ((_event$content2 = event.content) === null || _event$content2 === void 0 ? void 0 : (_event$content2$mRel = _event$content2["m.relates_to"]) === null || _event$content2$mRel === void 0 ? void 0 : _event$content2$mRel[prop]) !== "string") return; - event.content["m.relates_to"][prop] = (0, _utils.internaliseString)(event.content["m.relates_to"][prop]); - }); - this.txnId = event.txn_id; - this.localTimestamp = Date.now() - ((_this$getAge = this.getAge()) !== null && _this$getAge !== void 0 ? _this$getAge : 0); - this.reEmitter = new _ReEmitter.TypedReEmitter(this); - } - - /** - * Unstable getter to try and get an extensible event. Note that this might - * return a falsy value if the event could not be parsed as an extensible - * event. - * - * @deprecated Use stable functions where possible. - */ - get unstableExtensibleEvent() { - if (!this._hasCachedExtEv) { - this._cachedExtEv = _matrixEventsSdk.ExtensibleEvents.parse(this.getEffectiveEvent()); - } - return this._cachedExtEv; - } - invalidateExtensibleEvent() { - // just reset the flag - that'll trick the getter into parsing a new event - this._hasCachedExtEv = false; - } - - /** - * Gets the event as though it would appear unencrypted. If the event is already not - * encrypted, it is simply returned as-is. - * @returns The event in wire format. - */ - getEffectiveEvent() { - const content = Object.assign({}, this.getContent()); // clone for mutation - - if (this.getWireType() === _event.EventType.RoomMessageEncrypted) { - // Encrypted events sometimes aren't symmetrical on the `content` so we'll copy - // that over too, but only for missing properties. We don't copy over mismatches - // between the plain and decrypted copies of `content` because we assume that the - // app is relying on the decrypted version, so we want to expose that as a source - // of truth here too. - for (const [key, value] of Object.entries(this.getWireContent())) { - // Skip fields from the encrypted event schema though - we don't want to leak - // these. - if (["algorithm", "ciphertext", "device_id", "sender_key", "session_id"].includes(key)) { - continue; - } - if (content[key] === undefined) content[key] = value; - } - } - - // clearEvent doesn't have all the fields, so we'll copy what we can from this.event. - // We also copy over our "fixed" content key. - return Object.assign({}, this.event, this.clearEvent, { - content - }); - } - - /** - * Get the event_id for this event. - * @returns The event ID, e.g. $143350589368169JsLZx:localhost - * - */ - getId() { - return this.event.event_id; - } - - /** - * Get the user_id for this event. - * @returns The user ID, e.g. `@alice:matrix.org` - */ - getSender() { - return this.event.sender || this.event.user_id; // v2 / v1 - } - - /** - * Get the (decrypted, if necessary) type of event. - * - * @returns The event type, e.g. `m.room.message` - */ - getType() { - if (this.clearEvent) { - return this.clearEvent.type; - } - return this.event.type; - } - - /** - * Get the (possibly encrypted) type of the event that will be sent to the - * homeserver. - * - * @returns The event type. - */ - getWireType() { - return this.event.type; - } - - /** - * Get the room_id for this event. This will return `undefined` - * for `m.presence` events. - * @returns The room ID, e.g. !cURbafjkfsMDVwdRDQ:matrix.org - * - */ - getRoomId() { - return this.event.room_id; - } - - /** - * Get the timestamp of this event. - * @returns The event timestamp, e.g. `1433502692297` - */ - getTs() { - return this.event.origin_server_ts; - } - - /** - * Get the timestamp of this event, as a Date object. - * @returns The event date, e.g. `new Date(1433502692297)` - */ - getDate() { - return this.event.origin_server_ts ? new Date(this.event.origin_server_ts) : null; - } - - /** - * Get a string containing details of this event - * - * This is intended for logging, to help trace errors. Example output: - * - * @example - * ``` - * id=$HjnOHV646n0SjLDAqFrgIjim7RCpB7cdMXFrekWYAn type=m.room.encrypted - * sender=@user:example.com room=!room:example.com ts=2022-10-25T17:30:28.404Z - * ``` - */ - getDetails() { - let details = `id=${this.getId()} type=${this.getWireType()} sender=${this.getSender()}`; - const room = this.getRoomId(); - if (room) { - details += ` room=${room}`; - } - const date = this.getDate(); - if (date) { - details += ` ts=${date.toISOString()}`; - } - return details; - } - - /** - * Get the (decrypted, if necessary) event content JSON, even if the event - * was replaced by another event. - * - * @returns The event content JSON, or an empty object. - */ - getOriginalContent() { - if (this._localRedactionEvent) { - return {}; - } - if (this.clearEvent) { - return this.clearEvent.content || {}; - } - return this.event.content || {}; - } - - /** - * Get the (decrypted, if necessary) event content JSON, - * or the content from the replacing event, if any. - * See `makeReplaced`. - * - * @returns The event content JSON, or an empty object. - */ - getContent() { - if (this._localRedactionEvent) { - return {}; - } else if (this._replacingEvent) { - return this._replacingEvent.getContent()["m.new_content"] || {}; - } else { - return this.getOriginalContent(); - } - } - - /** - * Get the (possibly encrypted) event content JSON that will be sent to the - * homeserver. - * - * @returns The event content JSON, or an empty object. - */ - getWireContent() { - return this.event.content || {}; - } - - /** - * Get the event ID of the thread head - */ - get threadRootId() { - var _this$getWireContent; - const relatesTo = (_this$getWireContent = this.getWireContent()) === null || _this$getWireContent === void 0 ? void 0 : _this$getWireContent["m.relates_to"]; - if ((relatesTo === null || relatesTo === void 0 ? void 0 : relatesTo.rel_type) === _thread.THREAD_RELATION_TYPE.name) { - return relatesTo.event_id; - } else { - var _this$getThread; - return ((_this$getThread = this.getThread()) === null || _this$getThread === void 0 ? void 0 : _this$getThread.id) || this.threadId; - } - } - - /** - * A helper to check if an event is a thread's head or not - */ - get isThreadRoot() { - var _this$getThread2; - const threadDetails = this.getServerAggregatedRelation(_thread.THREAD_RELATION_TYPE.name); - - // Bundled relationships only returned when the sync response is limited - // hence us having to check both bundled relation and inspect the thread - // model - return !!threadDetails || ((_this$getThread2 = this.getThread()) === null || _this$getThread2 === void 0 ? void 0 : _this$getThread2.id) === this.getId(); - } - get replyEventId() { - var _this$getWireContent$, _this$getWireContent$2; - return (_this$getWireContent$ = this.getWireContent()["m.relates_to"]) === null || _this$getWireContent$ === void 0 ? void 0 : (_this$getWireContent$2 = _this$getWireContent$["m.in_reply_to"]) === null || _this$getWireContent$2 === void 0 ? void 0 : _this$getWireContent$2.event_id; - } - get relationEventId() { - var _this$getWireContent2, _this$getWireContent3; - return (_this$getWireContent2 = this.getWireContent()) === null || _this$getWireContent2 === void 0 ? void 0 : (_this$getWireContent3 = _this$getWireContent2["m.relates_to"]) === null || _this$getWireContent3 === void 0 ? void 0 : _this$getWireContent3.event_id; - } - - /** - * Get the previous event content JSON. This will only return something for - * state events which exist in the timeline. - * @returns The previous event content JSON, or an empty object. - */ - getPrevContent() { - // v2 then v1 then default - return this.getUnsigned().prev_content || this.event.prev_content || {}; - } - - /** - * Get either 'content' or 'prev_content' depending on if this event is - * 'forward-looking' or not. This can be modified via event.forwardLooking. - * In practice, this means we get the chronologically earlier content value - * for this event (this method should surely be called getEarlierContent) - * This method is experimental and may change. - * @returns event.content if this event is forward-looking, else - * event.prev_content. - */ - getDirectionalContent() { - return this.forwardLooking ? this.getContent() : this.getPrevContent(); - } - - /** - * Get the age of this event. This represents the age of the event when the - * event arrived at the device, and not the age of the event when this - * function was called. - * Can only be returned once the server has echo'ed back - * @returns The age of this event in milliseconds. - */ - getAge() { - return this.getUnsigned().age || this.event.age; // v2 / v1 - } - - /** - * Get the age of the event when this function was called. - * This is the 'age' field adjusted according to how long this client has - * had the event. - * @returns The age of this event in milliseconds. - */ - getLocalAge() { - return Date.now() - this.localTimestamp; - } - - /** - * Get the event state_key if it has one. This will return undefined - * for message events. - * @returns The event's `state_key`. - */ - getStateKey() { - return this.event.state_key; - } - - /** - * Check if this event is a state event. - * @returns True if this is a state event. - */ - isState() { - return this.event.state_key !== undefined; - } - - /** - * Replace the content of this event with encrypted versions. - * (This is used when sending an event; it should not be used by applications). - * - * @internal - * - * @param cryptoType - type of the encrypted event - typically - * "m.room.encrypted" - * - * @param cryptoContent - raw 'content' for the encrypted event. - * - * @param senderCurve25519Key - curve25519 key to record for the - * sender of this event. - * See {@link MatrixEvent#getSenderKey}. - * - * @param claimedEd25519Key - claimed ed25519 key to record for the - * sender if this event. - * See {@link MatrixEvent#getClaimedEd25519Key} - */ - makeEncrypted(cryptoType, cryptoContent, senderCurve25519Key, claimedEd25519Key) { - // keep the plain-text data for 'view source' - this.clearEvent = { - type: this.event.type, - content: this.event.content - }; - this.event.type = cryptoType; - this.event.content = cryptoContent; - this.senderCurve25519Key = senderCurve25519Key; - this.claimedEd25519Key = claimedEd25519Key; - } - - /** - * Check if this event is currently being decrypted. - * - * @returns True if this event is currently being decrypted, else false. - */ - isBeingDecrypted() { - return this.decryptionPromise != null; - } - getDecryptionPromise() { - return this.decryptionPromise; - } - - /** - * Check if this event is an encrypted event which we failed to decrypt - * - * (This implies that we might retry decryption at some point in the future) - * - * @returns True if this event is an encrypted event which we - * couldn't decrypt. - */ - isDecryptionFailure() { - var _this$clearEvent, _this$clearEvent$cont; - return ((_this$clearEvent = this.clearEvent) === null || _this$clearEvent === void 0 ? void 0 : (_this$clearEvent$cont = _this$clearEvent.content) === null || _this$clearEvent$cont === void 0 ? void 0 : _this$clearEvent$cont.msgtype) === "m.bad.encrypted"; - } - - /* - * True if this event is an encrypted event which we failed to decrypt, the receiver's device is unverified and - * the sender has disabled encrypting to unverified devices. - */ - get isEncryptedDisabledForUnverifiedDevices() { - return this.isDecryptionFailure() && this.encryptedDisabledForUnverifiedDevices; - } - shouldAttemptDecryption() { - if (this.isRedacted()) return false; - if (this.isBeingDecrypted()) return false; - if (this.clearEvent) return false; - if (!this.isEncrypted()) return false; - return true; - } - - /** - * Start the process of trying to decrypt this event. - * - * (This is used within the SDK: it isn't intended for use by applications) - * - * @internal - * - * @param crypto - crypto module - * - * @returns promise which resolves (to undefined) when the decryption - * attempt is completed. - */ - async attemptDecryption(crypto, options = {}) { - // start with a couple of sanity checks. - if (!this.isEncrypted()) { - throw new Error("Attempt to decrypt event which isn't encrypted"); - } - const alreadyDecrypted = this.clearEvent && !this.isDecryptionFailure(); - const forceRedecrypt = options.forceRedecryptIfUntrusted && this.isKeySourceUntrusted(); - if (alreadyDecrypted && !forceRedecrypt) { - // we may want to just ignore this? let's start with rejecting it. - throw new Error("Attempt to decrypt event which has already been decrypted"); - } - - // if we already have a decryption attempt in progress, then it may - // fail because it was using outdated info. We now have reason to - // succeed where it failed before, but we don't want to have multiple - // attempts going at the same time, so just set a flag that says we have - // new info. - // - if (this.decryptionPromise) { - _logger.logger.log(`Event ${this.getId()} already being decrypted; queueing a retry`); - this.retryDecryption = true; - return this.decryptionPromise; - } - this.decryptionPromise = this.decryptionLoop(crypto, options); - return this.decryptionPromise; - } - - /** - * Cancel any room key request for this event and resend another. - * - * @param crypto - crypto module - * @param userId - the user who received this event - * - * @returns a promise that resolves when the request is queued - */ - cancelAndResendKeyRequest(crypto, userId) { - const wireContent = this.getWireContent(); - return crypto.requestRoomKey({ - algorithm: wireContent.algorithm, - room_id: this.getRoomId(), - session_id: wireContent.session_id, - sender_key: wireContent.sender_key - }, this.getKeyRequestRecipients(userId), true); - } - - /** - * Calculate the recipients for keyshare requests. - * - * @param userId - the user who received this event. - * - * @returns array of recipients - */ - getKeyRequestRecipients(userId) { - // send the request to all of our own devices - const recipients = [{ - userId, - deviceId: "*" - }]; - return recipients; - } - async decryptionLoop(crypto, options = {}) { - // make sure that this method never runs completely synchronously. - // (doing so would mean that we would clear decryptionPromise *before* - // it is set in attemptDecryption - and hence end up with a stuck - // `decryptionPromise`). - await Promise.resolve(); - - // eslint-disable-next-line no-constant-condition - while (true) { - this.retryDecryption = false; - let res; - let err = undefined; - try { - if (!crypto) { - res = this.badEncryptedMessage("Encryption not enabled"); - } else { - res = await crypto.decryptEvent(this); - if (options.isRetry === true) { - _logger.logger.info(`Decrypted event on retry (${this.getDetails()})`); - } - } - } catch (e) { - const detailedError = e instanceof _algorithms.DecryptionError ? e.detailedString : String(e); - err = e; - - // see if we have a retry queued. - // - // NB: make sure to keep this check in the same tick of the - // event loop as `decryptionPromise = null` below - otherwise we - // risk a race: - // - // * A: we check retryDecryption here and see that it is - // false - // * B: we get a second call to attemptDecryption, which sees - // that decryptionPromise is set so sets - // retryDecryption - // * A: we continue below, clear decryptionPromise, and - // never do the retry. - // - if (this.retryDecryption) { - // decryption error, but we have a retry queued. - _logger.logger.log(`Error decrypting event (${this.getDetails()}), but retrying: ${detailedError}`); - continue; - } - - // decryption error, no retries queued. Warn about the error and - // set it to m.bad.encrypted. - // - // the detailedString already includes the name and message of the error, and the stack isn't much use, - // so we don't bother to log `e` separately. - _logger.logger.warn(`Error decrypting event (${this.getDetails()}): ${detailedError}`); - res = this.badEncryptedMessage(String(e)); - } - - // at this point, we've either successfully decrypted the event, or have given up - // (and set res to a 'badEncryptedMessage'). Either way, we can now set the - // cleartext of the event and raise Event.decrypted. - // - // make sure we clear 'decryptionPromise' before sending the 'Event.decrypted' event, - // otherwise the app will be confused to see `isBeingDecrypted` still set when - // there isn't an `Event.decrypted` on the way. - // - // see also notes on retryDecryption above. - // - this.decryptionPromise = null; - this.retryDecryption = false; - this.setClearData(res); - - // Before we emit the event, clear the push actions so that they can be recalculated - // by relevant code. We do this because the clear event has now changed, making it - // so that existing rules can be re-run over the applicable properties. Stuff like - // highlighting when the user's name is mentioned rely on this happening. We also want - // to set the push actions before emitting so that any notification listeners don't - // pick up the wrong contents. - this.setPushActions(null); - if (options.emit !== false) { - this.emit(MatrixEventEvent.Decrypted, this, err); - } - return; - } - } - badEncryptedMessage(reason) { - return { - clearEvent: { - type: _event.EventType.RoomMessage, - content: { - msgtype: "m.bad.encrypted", - body: "** Unable to decrypt: " + reason + " **" - } - }, - encryptedDisabledForUnverifiedDevices: reason === `DecryptionError: ${_OlmDevice.WITHHELD_MESSAGES["m.unverified"]}` - }; - } - - /** - * Update the cleartext data on this event. - * - * (This is used after decrypting an event; it should not be used by applications). - * - * @internal - * - * @param decryptionResult - the decryption result, including the plaintext and some key info - * - * @remarks - * Fires {@link MatrixEventEvent.Decrypted} - */ - setClearData(decryptionResult) { - var _decryptionResult$sen, _decryptionResult$cla; - this.clearEvent = decryptionResult.clearEvent; - this.senderCurve25519Key = (_decryptionResult$sen = decryptionResult.senderCurve25519Key) !== null && _decryptionResult$sen !== void 0 ? _decryptionResult$sen : null; - this.claimedEd25519Key = (_decryptionResult$cla = decryptionResult.claimedEd25519Key) !== null && _decryptionResult$cla !== void 0 ? _decryptionResult$cla : null; - this.forwardingCurve25519KeyChain = decryptionResult.forwardingCurve25519KeyChain || []; - this.untrusted = decryptionResult.untrusted || false; - this.encryptedDisabledForUnverifiedDevices = decryptionResult.encryptedDisabledForUnverifiedDevices || false; - this.invalidateExtensibleEvent(); - } - - /** - * Gets the cleartext content for this event. If the event is not encrypted, - * or encryption has not been completed, this will return null. - * - * @returns The cleartext (decrypted) content for the event - */ - getClearContent() { - return this.clearEvent ? this.clearEvent.content : null; - } - - /** - * Check if the event is encrypted. - * @returns True if this event is encrypted. - */ - isEncrypted() { - return !this.isState() && this.event.type === _event.EventType.RoomMessageEncrypted; - } - - /** - * The curve25519 key for the device that we think sent this event - * - * For an Olm-encrypted event, this is inferred directly from the DH - * exchange at the start of the session: the curve25519 key is involved in - * the DH exchange, so only a device which holds the private part of that - * key can establish such a session. - * - * For a megolm-encrypted event, it is inferred from the Olm message which - * established the megolm session - */ - getSenderKey() { - return this.senderCurve25519Key; - } - - /** - * The additional keys the sender of this encrypted event claims to possess. - * - * Just a wrapper for #getClaimedEd25519Key (q.v.) - */ - getKeysClaimed() { - if (!this.claimedEd25519Key) return {}; - return { - ed25519: this.claimedEd25519Key - }; - } - - /** - * Get the ed25519 the sender of this event claims to own. - * - * For Olm messages, this claim is encoded directly in the plaintext of the - * event itself. For megolm messages, it is implied by the m.room_key event - * which established the megolm session. - * - * Until we download the device list of the sender, it's just a claim: the - * device list gives a proof that the owner of the curve25519 key used for - * this event (and returned by #getSenderKey) also owns the ed25519 key by - * signing the public curve25519 key with the ed25519 key. - * - * In general, applications should not use this method directly, but should - * instead use MatrixClient.getEventSenderDeviceInfo. - */ - getClaimedEd25519Key() { - return this.claimedEd25519Key; - } - - /** - * Get the curve25519 keys of the devices which were involved in telling us - * about the claimedEd25519Key and sender curve25519 key. - * - * Normally this will be empty, but in the case of a forwarded megolm - * session, the sender keys are sent to us by another device (the forwarding - * device), which we need to trust to do this. In that case, the result will - * be a list consisting of one entry. - * - * If the device that sent us the key (A) got it from another device which - * it wasn't prepared to vouch for (B), the result will be [A, B]. And so on. - * - * @returns base64-encoded curve25519 keys, from oldest to newest. - */ - getForwardingCurve25519KeyChain() { - return this.forwardingCurve25519KeyChain; - } - - /** - * Whether the decryption key was obtained from an untrusted source. If so, - * we cannot verify the authenticity of the message. - */ - isKeySourceUntrusted() { - return !!this.untrusted; - } - getUnsigned() { - return this.event.unsigned || {}; - } - setUnsigned(unsigned) { - this.event.unsigned = unsigned; - } - unmarkLocallyRedacted() { - const value = this._localRedactionEvent; - this._localRedactionEvent = null; - if (this.event.unsigned) { - this.event.unsigned.redacted_because = undefined; - } - return !!value; - } - markLocallyRedacted(redactionEvent) { - if (this._localRedactionEvent) return; - this.emit(MatrixEventEvent.BeforeRedaction, this, redactionEvent); - this._localRedactionEvent = redactionEvent; - if (!this.event.unsigned) { - this.event.unsigned = {}; - } - this.event.unsigned.redacted_because = redactionEvent.event; - } - - /** - * Change the visibility of an event, as per https://github.com/matrix-org/matrix-doc/pull/3531 . - * - * @param visibilityChange - event holding a hide/unhide payload, or nothing - * if the event is being reset to its original visibility (presumably - * by a visibility event being redacted). - * - * @remarks - * Fires {@link MatrixEventEvent.VisibilityChange} if `visibilityEvent` - * caused a change in the actual visibility of this event, either by making it - * visible (if it was hidden), by making it hidden (if it was visible) or by - * changing the reason (if it was hidden). - */ - applyVisibilityEvent(visibilityChange) { - var _visibilityChange$vis, _visibilityChange$rea; - const visible = (_visibilityChange$vis = visibilityChange === null || visibilityChange === void 0 ? void 0 : visibilityChange.visible) !== null && _visibilityChange$vis !== void 0 ? _visibilityChange$vis : true; - const reason = (_visibilityChange$rea = visibilityChange === null || visibilityChange === void 0 ? void 0 : visibilityChange.reason) !== null && _visibilityChange$rea !== void 0 ? _visibilityChange$rea : null; - let change = false; - if (this.visibility.visible !== visible) { - change = true; - } else if (!this.visibility.visible && this.visibility["reason"] !== reason) { - change = true; - } - if (change) { - if (visible) { - this.visibility = MESSAGE_VISIBLE; - } else { - this.visibility = Object.freeze({ - visible: false, - reason - }); - } - this.emit(MatrixEventEvent.VisibilityChange, this, visible); - } - } - - /** - * Return instructions to display or hide the message. - * - * @returns Instructions determining whether the message - * should be displayed. - */ - messageVisibility() { - // Note: We may return `this.visibility` without fear, as - // this is a shallow frozen object. - return this.visibility; - } - - /** - * Update the content of an event in the same way it would be by the server - * if it were redacted before it was sent to us - * - * @param redactionEvent - event causing the redaction - */ - makeRedacted(redactionEvent) { - // quick sanity-check - if (!redactionEvent.event) { - throw new Error("invalid redactionEvent in makeRedacted"); - } - this._localRedactionEvent = null; - this.emit(MatrixEventEvent.BeforeRedaction, this, redactionEvent); - this._replacingEvent = null; - // we attempt to replicate what we would see from the server if - // the event had been redacted before we saw it. - // - // The server removes (most of) the content of the event, and adds a - // "redacted_because" key to the unsigned section containing the - // redacted event. - if (!this.event.unsigned) { - this.event.unsigned = {}; - } - this.event.unsigned.redacted_because = redactionEvent.event; - for (const key in this.event) { - if (this.event.hasOwnProperty(key) && !REDACT_KEEP_KEYS.has(key)) { - delete this.event[key]; - } - } - - // If the event is encrypted prune the decrypted bits - if (this.isEncrypted()) { - this.clearEvent = undefined; - } - const keeps = this.getType() in REDACT_KEEP_CONTENT_MAP ? REDACT_KEEP_CONTENT_MAP[this.getType()] : {}; - const content = this.getContent(); - for (const key in content) { - if (content.hasOwnProperty(key) && !keeps[key]) { - delete content[key]; - } - } - this.invalidateExtensibleEvent(); - } - - /** - * Check if this event has been redacted - * - * @returns True if this event has been redacted - */ - isRedacted() { - return Boolean(this.getUnsigned().redacted_because); - } - - /** - * Check if this event is a redaction of another event - * - * @returns True if this event is a redaction - */ - isRedaction() { - return this.getType() === _event.EventType.RoomRedaction; - } - - /** - * Return the visibility change caused by this event, - * as per https://github.com/matrix-org/matrix-doc/pull/3531. - * - * @returns If the event is a well-formed visibility change event, - * an instance of `IVisibilityChange`, otherwise `null`. - */ - asVisibilityChange() { - if (!_event.EVENT_VISIBILITY_CHANGE_TYPE.matches(this.getType())) { - // Not a visibility change event. - return null; - } - const relation = this.getRelation(); - if (!relation || relation.rel_type != "m.reference") { - // Ill-formed, ignore this event. - return null; - } - const eventId = relation.event_id; - if (!eventId) { - // Ill-formed, ignore this event. - return null; - } - const content = this.getWireContent(); - const visible = !!content.visible; - const reason = content.reason; - if (reason && typeof reason != "string") { - // Ill-formed, ignore this event. - return null; - } - // Well-formed visibility change event. - return { - visible, - reason, - eventId - }; - } - - /** - * Check if this event alters the visibility of another event, - * as per https://github.com/matrix-org/matrix-doc/pull/3531. - * - * @returns True if this event alters the visibility - * of another event. - */ - isVisibilityEvent() { - return _event.EVENT_VISIBILITY_CHANGE_TYPE.matches(this.getType()); - } - - /** - * Get the (decrypted, if necessary) redaction event JSON - * if event was redacted - * - * @returns The redaction event JSON, or an empty object - */ - getRedactionEvent() { - var _this$clearEvent2, _this$event$unsigned; - if (!this.isRedacted()) return null; - if ((_this$clearEvent2 = this.clearEvent) !== null && _this$clearEvent2 !== void 0 && _this$clearEvent2.unsigned) { - var _this$clearEvent$unsi, _this$clearEvent3; - return (_this$clearEvent$unsi = (_this$clearEvent3 = this.clearEvent) === null || _this$clearEvent3 === void 0 ? void 0 : _this$clearEvent3.unsigned.redacted_because) !== null && _this$clearEvent$unsi !== void 0 ? _this$clearEvent$unsi : null; - } else if ((_this$event$unsigned = this.event.unsigned) !== null && _this$event$unsigned !== void 0 && _this$event$unsigned.redacted_because) { - return this.event.unsigned.redacted_because; - } else { - return {}; - } - } - - /** - * Get the push actions, if known, for this event - * - * @returns push actions - */ - getPushActions() { - return this.pushActions; - } - - /** - * Set the push actions for this event. - * - * @param pushActions - push actions - */ - setPushActions(pushActions) { - this.pushActions = pushActions; - } - - /** - * Replace the `event` property and recalculate any properties based on it. - * @param event - the object to assign to the `event` property - */ - handleRemoteEcho(event) { - const oldUnsigned = this.getUnsigned(); - const oldId = this.getId(); - this.event = event; - // if this event was redacted before it was sent, it's locally marked as redacted. - // At this point, we've received the remote echo for the event, but not yet for - // the redaction that we are sending ourselves. Preserve the locally redacted - // state by copying over redacted_because so we don't get a flash of - // redacted, not-redacted, redacted as remote echos come in - if (oldUnsigned.redacted_because) { - if (!this.event.unsigned) { - this.event.unsigned = {}; - } - this.event.unsigned.redacted_because = oldUnsigned.redacted_because; - } - // successfully sent. - this.setStatus(null); - if (this.getId() !== oldId) { - // emit the event if it changed - this.emit(MatrixEventEvent.LocalEventIdReplaced, this); - } - this.localTimestamp = Date.now() - this.getAge(); - } - - /** - * Whether the event is in any phase of sending, send failure, waiting for - * remote echo, etc. - */ - isSending() { - return !!this.status; - } - - /** - * Update the event's sending status and emit an event as well. - * - * @param status - The new status - */ - setStatus(status) { - this.status = status; - this.emit(MatrixEventEvent.Status, this, status); - } - replaceLocalEventId(eventId) { - this.event.event_id = eventId; - this.emit(MatrixEventEvent.LocalEventIdReplaced, this); - } - - /** - * Get whether the event is a relation event, and of a given type if - * `relType` is passed in. State events cannot be relation events - * - * @param relType - if given, checks that the relation is of the - * given type - */ - isRelation(relType) { - var _this$getWireContent4; - // Relation info is lifted out of the encrypted content when sent to - // encrypted rooms, so we have to check `getWireContent` for this. - const relation = (_this$getWireContent4 = this.getWireContent()) === null || _this$getWireContent4 === void 0 ? void 0 : _this$getWireContent4["m.relates_to"]; - if (this.isState() && (relation === null || relation === void 0 ? void 0 : relation.rel_type) === _event.RelationType.Replace) { - // State events cannot be m.replace relations - return false; - } - return !!(relation !== null && relation !== void 0 && relation.rel_type && relation.event_id && (relType ? relation.rel_type === relType : true)); - } - - /** - * Get relation info for the event, if any. - */ - getRelation() { - var _this$getWireContent$3; - if (!this.isRelation()) { - return null; - } - return (_this$getWireContent$3 = this.getWireContent()["m.relates_to"]) !== null && _this$getWireContent$3 !== void 0 ? _this$getWireContent$3 : null; - } - - /** - * Set an event that replaces the content of this event, through an m.replace relation. - * - * @param newEvent - the event with the replacing content, if any. - * - * @remarks - * Fires {@link MatrixEventEvent.Replaced} - */ - makeReplaced(newEvent) { - // don't allow redacted events to be replaced. - // if newEvent is null we allow to go through though, - // as with local redaction, the replacing event might get - // cancelled, which should be reflected on the target event. - if (this.isRedacted() && newEvent) { - return; - } - // don't allow state events to be replaced using this mechanism as per MSC2676 - if (this.isState()) { - return; - } - if (this._replacingEvent !== newEvent) { - this._replacingEvent = newEvent !== null && newEvent !== void 0 ? newEvent : null; - this.emit(MatrixEventEvent.Replaced, this); - this.invalidateExtensibleEvent(); - } - } - - /** - * Returns the status of any associated edit or redaction - * (not for reactions/annotations as their local echo doesn't affect the original event), - * or else the status of the event. - */ - getAssociatedStatus() { - if (this._replacingEvent) { - return this._replacingEvent.status; - } else if (this._localRedactionEvent) { - return this._localRedactionEvent.status; - } - return this.status; - } - getServerAggregatedRelation(relType) { - var _this$getUnsigned$mR; - return (_this$getUnsigned$mR = this.getUnsigned()["m.relations"]) === null || _this$getUnsigned$mR === void 0 ? void 0 : _this$getUnsigned$mR[relType]; - } - - /** - * Returns the event ID of the event replacing the content of this event, if any. - */ - replacingEventId() { - const replaceRelation = this.getServerAggregatedRelation(_event.RelationType.Replace); - if (replaceRelation) { - return replaceRelation.event_id; - } else if (this._replacingEvent) { - return this._replacingEvent.getId(); - } - } - - /** - * Returns the event replacing the content of this event, if any. - * Replacements are aggregated on the server, so this would only - * return an event in case it came down the sync, or for local echo of edits. - */ - replacingEvent() { - return this._replacingEvent; - } - - /** - * Returns the origin_server_ts of the event replacing the content of this event, if any. - */ - replacingEventDate() { - const replaceRelation = this.getServerAggregatedRelation(_event.RelationType.Replace); - if (replaceRelation) { - const ts = replaceRelation.origin_server_ts; - if (Number.isFinite(ts)) { - return new Date(ts); - } - } else if (this._replacingEvent) { - var _this$_replacingEvent; - return (_this$_replacingEvent = this._replacingEvent.getDate()) !== null && _this$_replacingEvent !== void 0 ? _this$_replacingEvent : undefined; - } - } - - /** - * Returns the event that wants to redact this event, but hasn't been sent yet. - * @returns the event - */ - localRedactionEvent() { - return this._localRedactionEvent; - } - - /** - * For relations and redactions, returns the event_id this event is referring to. - */ - getAssociatedId() { - const relation = this.getRelation(); - if (this.replyEventId) { - return this.replyEventId; - } else if (relation) { - return relation.event_id; - } else if (this.isRedaction()) { - return this.event.redacts; - } - } - - /** - * Checks if this event is associated with another event. See `getAssociatedId`. - * @deprecated use hasAssociation instead. - */ - hasAssocation() { - return !!this.getAssociatedId(); - } - - /** - * Checks if this event is associated with another event. See `getAssociatedId`. - */ - hasAssociation() { - return !!this.getAssociatedId(); - } - - /** - * Update the related id with a new one. - * - * Used to replace a local id with remote one before sending - * an event with a related id. - * - * @param eventId - the new event id - */ - updateAssociatedId(eventId) { - const relation = this.getRelation(); - if (relation) { - relation.event_id = eventId; - } else if (this.isRedaction()) { - this.event.redacts = eventId; - } - } - - /** - * Flags an event as cancelled due to future conditions. For example, a verification - * request event in the same sync transaction may be flagged as cancelled to warn - * listeners that a cancellation event is coming down the same pipe shortly. - * @param cancelled - Whether the event is to be cancelled or not. - */ - flagCancelled(cancelled = true) { - this._isCancelled = cancelled; - } - - /** - * Gets whether or not the event is flagged as cancelled. See flagCancelled() for - * more information. - * @returns True if the event is cancelled, false otherwise. - */ - isCancelled() { - return this._isCancelled; - } - - /** - * Get a copy/snapshot of this event. The returned copy will be loosely linked - * back to this instance, though will have "frozen" event information. Other - * properties of this MatrixEvent instance will be copied verbatim, which can - * mean they are in reference to this instance despite being on the copy too. - * The reference the snapshot uses does not change, however members aside from - * the underlying event will not be deeply cloned, thus may be mutated internally. - * For example, the sender profile will be copied over at snapshot time, and - * the sender profile internally may mutate without notice to the consumer. - * - * This is meant to be used to snapshot the event details themselves, not the - * features (such as sender) surrounding the event. - * @returns A snapshot of this event. - */ - toSnapshot() { - const ev = new MatrixEvent(JSON.parse(JSON.stringify(this.event))); - for (const [p, v] of Object.entries(this)) { - if (p !== "event") { - // exclude the thing we just cloned - // @ts-ignore - XXX: this is just nasty - ev[p] = v; - } - } - return ev; - } - - /** - * Determines if this event is equivalent to the given event. This only checks - * the event object itself, not the other properties of the event. Intended for - * use with toSnapshot() to identify events changing. - * @param otherEvent - The other event to check against. - * @returns True if the events are the same, false otherwise. - */ - isEquivalentTo(otherEvent) { - if (!otherEvent) return false; - if (otherEvent === this) return true; - const myProps = (0, _utils.deepSortedObjectEntries)(this.event); - const theirProps = (0, _utils.deepSortedObjectEntries)(otherEvent.event); - return JSON.stringify(myProps) === JSON.stringify(theirProps); - } - - /** - * Summarise the event as JSON. This is currently used by React SDK's view - * event source feature and Seshat's event indexing, so take care when - * adjusting the output here. - * - * If encrypted, include both the decrypted and encrypted view of the event. - * - * This is named `toJSON` for use with `JSON.stringify` which checks objects - * for functions named `toJSON` and will call them to customise the output - * if they are defined. - */ - toJSON() { - const event = this.getEffectiveEvent(); - if (!this.isEncrypted()) { - return event; - } - return { - decrypted: event, - encrypted: this.event - }; - } - setVerificationRequest(request) { - this.verificationRequest = request; - } - setTxnId(txnId) { - this.txnId = txnId; - } - getTxnId() { - return this.txnId; - } - - /** - * Set the instance of a thread associated with the current event - * @param thread - the thread - */ - setThread(thread) { - if (this.thread) { - this.reEmitter.stopReEmitting(this.thread, [_thread.ThreadEvent.Update]); - } - this.thread = thread; - this.setThreadId(thread === null || thread === void 0 ? void 0 : thread.id); - if (thread) { - this.reEmitter.reEmit(thread, [_thread.ThreadEvent.Update]); - } - } - - /** - * Get the instance of the thread associated with the current event - */ - getThread() { - return this.thread; - } - setThreadId(threadId) { - this.threadId = threadId; - } -} - -/* REDACT_KEEP_KEYS gives the keys we keep when an event is redacted - * - * This is specified here: - * http://matrix.org/speculator/spec/HEAD/client_server/latest.html#redactions - * - * Also: - * - We keep 'unsigned' since that is created by the local server - * - We keep user_id for backwards-compat with v1 - */ -exports.MatrixEvent = MatrixEvent; -const REDACT_KEEP_KEYS = new Set(["event_id", "type", "room_id", "user_id", "sender", "state_key", "prev_state", "content", "unsigned", "origin_server_ts"]); - -// a map from state event type to the .content keys we keep when an event is redacted -const REDACT_KEEP_CONTENT_MAP = { - [_event.EventType.RoomMember]: { - membership: 1 - }, - [_event.EventType.RoomCreate]: { - creator: 1 - }, - [_event.EventType.RoomJoinRules]: { - join_rule: 1 - }, - [_event.EventType.RoomPowerLevels]: { - ban: 1, - events: 1, - events_default: 1, - kick: 1, - redact: 1, - state_default: 1, - users: 1, - users_default: 1 - } -}; -//# sourceMappingURL=event.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js.map deleted file mode 100644 index cf33248..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/event.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"event.js","names":["_matrixEventsSdk","require","_logger","_event","_utils","_thread","_ReEmitter","_typedEventEmitter","_algorithms","_OlmDevice","_eventStatus","MESSAGE_VISIBLE","Object","freeze","visible","MatrixEventEvent","exports","MatrixEvent","TypedEventEmitter","constructor","event","_this$getAge","_defineProperty2","default","undefined","forEach","prop","internaliseString","_event$content","content","_event$content2","_event$content2$mRel","txnId","txn_id","localTimestamp","Date","now","getAge","reEmitter","TypedReEmitter","unstableExtensibleEvent","_hasCachedExtEv","_cachedExtEv","ExtensibleEvents","parse","getEffectiveEvent","invalidateExtensibleEvent","assign","getContent","getWireType","EventType","RoomMessageEncrypted","key","value","entries","getWireContent","includes","clearEvent","getId","event_id","getSender","sender","user_id","getType","type","getRoomId","room_id","getTs","origin_server_ts","getDate","getDetails","details","room","date","toISOString","getOriginalContent","_localRedactionEvent","_replacingEvent","threadRootId","_this$getWireContent","relatesTo","rel_type","THREAD_RELATION_TYPE","name","_this$getThread","getThread","id","threadId","isThreadRoot","_this$getThread2","threadDetails","getServerAggregatedRelation","replyEventId","_this$getWireContent$","_this$getWireContent$2","relationEventId","_this$getWireContent2","_this$getWireContent3","getPrevContent","getUnsigned","prev_content","getDirectionalContent","forwardLooking","age","getLocalAge","getStateKey","state_key","isState","makeEncrypted","cryptoType","cryptoContent","senderCurve25519Key","claimedEd25519Key","isBeingDecrypted","decryptionPromise","getDecryptionPromise","isDecryptionFailure","_this$clearEvent","_this$clearEvent$cont","msgtype","isEncryptedDisabledForUnverifiedDevices","encryptedDisabledForUnverifiedDevices","shouldAttemptDecryption","isRedacted","isEncrypted","attemptDecryption","crypto","options","Error","alreadyDecrypted","forceRedecrypt","forceRedecryptIfUntrusted","isKeySourceUntrusted","logger","log","retryDecryption","decryptionLoop","cancelAndResendKeyRequest","userId","wireContent","requestRoomKey","algorithm","session_id","sender_key","getKeyRequestRecipients","recipients","deviceId","Promise","resolve","res","err","badEncryptedMessage","decryptEvent","isRetry","info","e","detailedError","DecryptionError","detailedString","String","warn","setClearData","setPushActions","emit","Decrypted","reason","RoomMessage","body","WITHHELD_MESSAGES","decryptionResult","_decryptionResult$sen","_decryptionResult$cla","forwardingCurve25519KeyChain","untrusted","getClearContent","getSenderKey","getKeysClaimed","ed25519","getClaimedEd25519Key","getForwardingCurve25519KeyChain","unsigned","setUnsigned","unmarkLocallyRedacted","redacted_because","markLocallyRedacted","redactionEvent","BeforeRedaction","applyVisibilityEvent","visibilityChange","_visibilityChange$vis","_visibilityChange$rea","change","visibility","VisibilityChange","messageVisibility","makeRedacted","hasOwnProperty","REDACT_KEEP_KEYS","has","keeps","REDACT_KEEP_CONTENT_MAP","Boolean","isRedaction","RoomRedaction","asVisibilityChange","EVENT_VISIBILITY_CHANGE_TYPE","matches","relation","getRelation","eventId","isVisibilityEvent","getRedactionEvent","_this$clearEvent2","_this$event$unsigned","_this$clearEvent$unsi","_this$clearEvent3","getPushActions","pushActions","handleRemoteEcho","oldUnsigned","oldId","setStatus","LocalEventIdReplaced","isSending","status","Status","replaceLocalEventId","isRelation","relType","_this$getWireContent4","RelationType","Replace","_this$getWireContent$3","makeReplaced","newEvent","Replaced","getAssociatedStatus","_this$getUnsigned$mR","replacingEventId","replaceRelation","replacingEvent","replacingEventDate","ts","Number","isFinite","_this$_replacingEvent","localRedactionEvent","getAssociatedId","redacts","hasAssocation","hasAssociation","updateAssociatedId","flagCancelled","cancelled","_isCancelled","isCancelled","toSnapshot","ev","JSON","stringify","p","v","isEquivalentTo","otherEvent","myProps","deepSortedObjectEntries","theirProps","toJSON","decrypted","encrypted","setVerificationRequest","request","verificationRequest","setTxnId","getTxnId","setThread","thread","stopReEmitting","ThreadEvent","Update","setThreadId","reEmit","Set","RoomMember","membership","RoomCreate","creator","RoomJoinRules","join_rule","RoomPowerLevels","ban","events","events_default","kick","redact","state_default","users","users_default"],"sources":["../../src/models/event.ts"],"sourcesContent":["/*\nCopyright 2015 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module. See {@link MatrixEvent} and {@link RoomEvent} for\n * the public classes.\n */\n\nimport { ExtensibleEvent, ExtensibleEvents, Optional } from \"matrix-events-sdk\";\n\nimport type { IEventDecryptionResult } from \"../@types/crypto\";\nimport { logger } from \"../logger\";\nimport { VerificationRequest } from \"../crypto/verification/request/VerificationRequest\";\nimport { EVENT_VISIBILITY_CHANGE_TYPE, EventType, MsgType, RelationType } from \"../@types/event\";\nimport { Crypto } from \"../crypto\";\nimport { deepSortedObjectEntries, internaliseString } from \"../utils\";\nimport { RoomMember } from \"./room-member\";\nimport { Thread, ThreadEvent, EventHandlerMap as ThreadEventHandlerMap, THREAD_RELATION_TYPE } from \"./thread\";\nimport { IActionsObject } from \"../pushprocessor\";\nimport { TypedReEmitter } from \"../ReEmitter\";\nimport { MatrixError } from \"../http-api\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\nimport { EventStatus } from \"./event-status\";\nimport { DecryptionError } from \"../crypto/algorithms\";\nimport { CryptoBackend } from \"../common-crypto/CryptoBackend\";\nimport { WITHHELD_MESSAGES } from \"../crypto/OlmDevice\";\n\nexport { EventStatus } from \"./event-status\";\n\n/* eslint-disable camelcase */\nexport interface IContent {\n [key: string]: any;\n \"msgtype\"?: MsgType | string;\n \"membership\"?: string;\n \"avatar_url\"?: string;\n \"displayname\"?: string;\n \"m.relates_to\"?: IEventRelation;\n\n \"org.matrix.msc3952.mentions\"?: IMentions;\n}\n\ntype StrippedState = Required>;\n\nexport interface IUnsigned {\n \"age\"?: number;\n \"prev_sender\"?: string;\n \"prev_content\"?: IContent;\n \"redacted_because\"?: IEvent;\n \"transaction_id\"?: string;\n \"invite_room_state\"?: StrippedState[];\n \"m.relations\"?: Record; // No common pattern for aggregated relations\n}\n\nexport interface IThreadBundledRelationship {\n latest_event: IEvent;\n count: number;\n current_user_participated?: boolean;\n}\n\nexport interface IEvent {\n event_id: string;\n type: string;\n content: IContent;\n sender: string;\n room_id?: string;\n origin_server_ts: number;\n txn_id?: string;\n state_key?: string;\n membership?: string;\n unsigned: IUnsigned;\n redacts?: string;\n\n /**\n * @deprecated in favour of `sender`\n */\n user_id?: string;\n /**\n * @deprecated in favour of `unsigned.prev_content`\n */\n prev_content?: IContent;\n /**\n * @deprecated in favour of `origin_server_ts`\n */\n age?: number;\n}\n\nexport interface IAggregatedRelation {\n origin_server_ts: number;\n event_id?: string;\n sender?: string;\n type?: string;\n count?: number;\n key?: string;\n}\n\nexport interface IEventRelation {\n \"rel_type\"?: RelationType | string;\n \"event_id\"?: string;\n \"is_falling_back\"?: boolean;\n \"m.in_reply_to\"?: {\n event_id?: string;\n };\n \"key\"?: string;\n}\n\nexport interface IMentions {\n user_ids?: string[];\n room?: boolean;\n}\n\n/**\n * When an event is a visibility change event, as per MSC3531,\n * the visibility change implied by the event.\n */\nexport interface IVisibilityChange {\n /**\n * If `true`, the target event should be made visible.\n * Otherwise, it should be hidden.\n */\n visible: boolean;\n\n /**\n * The event id affected.\n */\n eventId: string;\n\n /**\n * Optionally, a human-readable reason explaining why\n * the event was hidden. Ignored if the event was made\n * visible.\n */\n reason: string | null;\n}\n\nexport interface IClearEvent {\n room_id?: string;\n type: string;\n content: Omit;\n unsigned?: IUnsigned;\n}\n/* eslint-enable camelcase */\n\ninterface IKeyRequestRecipient {\n userId: string;\n deviceId: \"*\" | string;\n}\n\nexport interface IDecryptOptions {\n // Emits \"event.decrypted\" if set to true\n emit?: boolean;\n // True if this is a retry (enables more logging)\n isRetry?: boolean;\n // whether the message should be re-decrypted if it was previously successfully decrypted with an untrusted key\n forceRedecryptIfUntrusted?: boolean;\n}\n\n/**\n * Message hiding, as specified by https://github.com/matrix-org/matrix-doc/pull/3531.\n */\nexport type MessageVisibility = IMessageVisibilityHidden | IMessageVisibilityVisible;\n/**\n * Variant of `MessageVisibility` for the case in which the message should be displayed.\n */\nexport interface IMessageVisibilityVisible {\n readonly visible: true;\n}\n/**\n * Variant of `MessageVisibility` for the case in which the message should be hidden.\n */\nexport interface IMessageVisibilityHidden {\n readonly visible: false;\n /**\n * Optionally, a human-readable reason to show to the user indicating why the\n * message has been hidden (e.g. \"Message Pending Moderation\").\n */\n readonly reason: string | null;\n}\n// A singleton implementing `IMessageVisibilityVisible`.\nconst MESSAGE_VISIBLE: IMessageVisibilityVisible = Object.freeze({ visible: true });\n\nexport enum MatrixEventEvent {\n Decrypted = \"Event.decrypted\",\n BeforeRedaction = \"Event.beforeRedaction\",\n VisibilityChange = \"Event.visibilityChange\",\n LocalEventIdReplaced = \"Event.localEventIdReplaced\",\n Status = \"Event.status\",\n Replaced = \"Event.replaced\",\n RelationsCreated = \"Event.relationsCreated\",\n}\n\nexport type MatrixEventEmittedEvents = MatrixEventEvent | ThreadEvent.Update;\n\nexport type MatrixEventHandlerMap = {\n /**\n * Fires when an event is decrypted\n *\n * @param event - The matrix event which has been decrypted\n * @param err - The error that occurred during decryption, or `undefined` if no error occurred.\n */\n [MatrixEventEvent.Decrypted]: (event: MatrixEvent, err?: Error) => void;\n [MatrixEventEvent.BeforeRedaction]: (event: MatrixEvent, redactionEvent: MatrixEvent) => void;\n [MatrixEventEvent.VisibilityChange]: (event: MatrixEvent, visible: boolean) => void;\n [MatrixEventEvent.LocalEventIdReplaced]: (event: MatrixEvent) => void;\n [MatrixEventEvent.Status]: (event: MatrixEvent, status: EventStatus | null) => void;\n [MatrixEventEvent.Replaced]: (event: MatrixEvent) => void;\n [MatrixEventEvent.RelationsCreated]: (relationType: string, eventType: string) => void;\n} & Pick;\n\nexport class MatrixEvent extends TypedEventEmitter {\n private pushActions: IActionsObject | null = null;\n private _replacingEvent: MatrixEvent | null = null;\n private _localRedactionEvent: MatrixEvent | null = null;\n private _isCancelled = false;\n private clearEvent?: IClearEvent;\n\n /* Message hiding, as specified by https://github.com/matrix-org/matrix-doc/pull/3531.\n\n Note: We're returning this object, so any value stored here MUST be frozen.\n */\n private visibility: MessageVisibility = MESSAGE_VISIBLE;\n\n // Not all events will be extensible-event compatible, so cache a flag in\n // addition to a falsy cached event value. We check the flag later on in\n // a public getter to decide if the cache is valid.\n private _hasCachedExtEv = false;\n private _cachedExtEv: Optional = undefined;\n\n /* curve25519 key which we believe belongs to the sender of the event. See\n * getSenderKey()\n */\n private senderCurve25519Key: string | null = null;\n\n /* ed25519 key which the sender of this event (for olm) or the creator of\n * the megolm session (for megolm) claims to own. See getClaimedEd25519Key()\n */\n private claimedEd25519Key: string | null = null;\n\n /* curve25519 keys of devices involved in telling us about the\n * senderCurve25519Key and claimedEd25519Key.\n * See getForwardingCurve25519KeyChain().\n */\n private forwardingCurve25519KeyChain: string[] = [];\n\n /* where the decryption key is untrusted\n */\n private untrusted: boolean | null = null;\n\n /* if we have a process decrypting this event, a Promise which resolves\n * when it is finished. Normally null.\n */\n private decryptionPromise: Promise | null = null;\n\n /* flag to indicate if we should retry decrypting this event after the\n * first attempt (eg, we have received new data which means that a second\n * attempt may succeed)\n */\n private retryDecryption = false;\n\n /* The txnId with which this event was sent if it was during this session,\n * allows for a unique ID which does not change when the event comes back down sync.\n */\n private txnId?: string;\n\n /**\n * A reference to the thread this event belongs to\n */\n private thread?: Thread;\n private threadId?: string;\n\n /*\n * True if this event is an encrypted event which we failed to decrypt, the receiver's device is unverified and\n * the sender has disabled encrypting to unverified devices.\n */\n private encryptedDisabledForUnverifiedDevices = false;\n\n /* Set an approximate timestamp for the event relative the local clock.\n * This will inherently be approximate because it doesn't take into account\n * the time between the server putting the 'age' field on the event as it sent\n * it to us and the time we're now constructing this event, but that's better\n * than assuming the local clock is in sync with the origin HS's clock.\n */\n public localTimestamp: number;\n\n /**\n * The room member who sent this event, or null e.g.\n * this is a presence event. This is only guaranteed to be set for events that\n * appear in a timeline, ie. do not guarantee that it will be set on state\n * events.\n * @privateRemarks\n * Should be read-only\n */\n public sender: RoomMember | null = null;\n /**\n * The room member who is the target of this event, e.g.\n * the invitee, the person being banned, etc.\n * @privateRemarks\n * Should be read-only\n */\n public target: RoomMember | null = null;\n /**\n * The sending status of the event.\n * @privateRemarks\n * Should be read-only\n */\n public status: EventStatus | null = null;\n /**\n * most recent error associated with sending the event, if any\n * @privateRemarks\n * Should be read-only\n */\n public error: MatrixError | null = null;\n /**\n * True if this event is 'forward looking', meaning\n * that getDirectionalContent() will return event.content and not event.prev_content.\n * Only state events may be backwards looking\n * Default: true. This property is experimental and may change.\n * @privateRemarks\n * Should be read-only\n */\n public forwardLooking = true;\n\n /* If the event is a `m.key.verification.request` (or to_device `m.key.verification.start`) event,\n * `Crypto` will set this the `VerificationRequest` for the event\n * so it can be easily accessed from the timeline.\n */\n public verificationRequest?: VerificationRequest;\n\n private readonly reEmitter: TypedReEmitter;\n\n /**\n * Construct a Matrix Event object\n *\n * @param event - The raw (possibly encrypted) event. Do not access\n * this property directly unless you absolutely have to. Prefer the getter\n * methods defined on this class. Using the getter methods shields your app\n * from changes to event JSON between Matrix versions.\n */\n public constructor(public event: Partial = {}) {\n super();\n\n // intern the values of matrix events to force share strings and reduce the\n // amount of needless string duplication. This can save moderate amounts of\n // memory (~10% on a 350MB heap).\n // 'membership' at the event level (rather than the content level) is a legacy\n // field that Element never otherwise looks at, but it will still take up a lot\n // of space if we don't intern it.\n ([\"state_key\", \"type\", \"sender\", \"room_id\", \"membership\"] as const).forEach((prop) => {\n if (typeof event[prop] !== \"string\") return;\n event[prop] = internaliseString(event[prop]!);\n });\n\n ([\"membership\", \"avatar_url\", \"displayname\"] as const).forEach((prop) => {\n if (typeof event.content?.[prop] !== \"string\") return;\n event.content[prop] = internaliseString(event.content[prop]!);\n });\n\n ([\"rel_type\"] as const).forEach((prop) => {\n if (typeof event.content?.[\"m.relates_to\"]?.[prop] !== \"string\") return;\n event.content[\"m.relates_to\"][prop] = internaliseString(event.content[\"m.relates_to\"][prop]!);\n });\n\n this.txnId = event.txn_id;\n this.localTimestamp = Date.now() - (this.getAge() ?? 0);\n this.reEmitter = new TypedReEmitter(this);\n }\n\n /**\n * Unstable getter to try and get an extensible event. Note that this might\n * return a falsy value if the event could not be parsed as an extensible\n * event.\n *\n * @deprecated Use stable functions where possible.\n */\n public get unstableExtensibleEvent(): Optional {\n if (!this._hasCachedExtEv) {\n this._cachedExtEv = ExtensibleEvents.parse(this.getEffectiveEvent());\n }\n return this._cachedExtEv;\n }\n\n private invalidateExtensibleEvent(): void {\n // just reset the flag - that'll trick the getter into parsing a new event\n this._hasCachedExtEv = false;\n }\n\n /**\n * Gets the event as though it would appear unencrypted. If the event is already not\n * encrypted, it is simply returned as-is.\n * @returns The event in wire format.\n */\n public getEffectiveEvent(): IEvent {\n const content = Object.assign({}, this.getContent()); // clone for mutation\n\n if (this.getWireType() === EventType.RoomMessageEncrypted) {\n // Encrypted events sometimes aren't symmetrical on the `content` so we'll copy\n // that over too, but only for missing properties. We don't copy over mismatches\n // between the plain and decrypted copies of `content` because we assume that the\n // app is relying on the decrypted version, so we want to expose that as a source\n // of truth here too.\n for (const [key, value] of Object.entries(this.getWireContent())) {\n // Skip fields from the encrypted event schema though - we don't want to leak\n // these.\n if ([\"algorithm\", \"ciphertext\", \"device_id\", \"sender_key\", \"session_id\"].includes(key)) {\n continue;\n }\n\n if (content[key] === undefined) content[key] = value;\n }\n }\n\n // clearEvent doesn't have all the fields, so we'll copy what we can from this.event.\n // We also copy over our \"fixed\" content key.\n return Object.assign({}, this.event, this.clearEvent, { content }) as IEvent;\n }\n\n /**\n * Get the event_id for this event.\n * @returns The event ID, e.g. $143350589368169JsLZx:localhost\n * \n */\n public getId(): string | undefined {\n return this.event.event_id;\n }\n\n /**\n * Get the user_id for this event.\n * @returns The user ID, e.g. `@alice:matrix.org`\n */\n public getSender(): string | undefined {\n return this.event.sender || this.event.user_id; // v2 / v1\n }\n\n /**\n * Get the (decrypted, if necessary) type of event.\n *\n * @returns The event type, e.g. `m.room.message`\n */\n public getType(): EventType | string {\n if (this.clearEvent) {\n return this.clearEvent.type;\n }\n return this.event.type!;\n }\n\n /**\n * Get the (possibly encrypted) type of the event that will be sent to the\n * homeserver.\n *\n * @returns The event type.\n */\n public getWireType(): EventType | string {\n return this.event.type!;\n }\n\n /**\n * Get the room_id for this event. This will return `undefined`\n * for `m.presence` events.\n * @returns The room ID, e.g. !cURbafjkfsMDVwdRDQ:matrix.org\n * \n */\n public getRoomId(): string | undefined {\n return this.event.room_id;\n }\n\n /**\n * Get the timestamp of this event.\n * @returns The event timestamp, e.g. `1433502692297`\n */\n public getTs(): number {\n return this.event.origin_server_ts!;\n }\n\n /**\n * Get the timestamp of this event, as a Date object.\n * @returns The event date, e.g. `new Date(1433502692297)`\n */\n public getDate(): Date | null {\n return this.event.origin_server_ts ? new Date(this.event.origin_server_ts) : null;\n }\n\n /**\n * Get a string containing details of this event\n *\n * This is intended for logging, to help trace errors. Example output:\n *\n * @example\n * ```\n * id=$HjnOHV646n0SjLDAqFrgIjim7RCpB7cdMXFrekWYAn type=m.room.encrypted\n * sender=@user:example.com room=!room:example.com ts=2022-10-25T17:30:28.404Z\n * ```\n */\n public getDetails(): string {\n let details = `id=${this.getId()} type=${this.getWireType()} sender=${this.getSender()}`;\n const room = this.getRoomId();\n if (room) {\n details += ` room=${room}`;\n }\n const date = this.getDate();\n if (date) {\n details += ` ts=${date.toISOString()}`;\n }\n return details;\n }\n\n /**\n * Get the (decrypted, if necessary) event content JSON, even if the event\n * was replaced by another event.\n *\n * @returns The event content JSON, or an empty object.\n */\n public getOriginalContent(): T {\n if (this._localRedactionEvent) {\n return {} as T;\n }\n if (this.clearEvent) {\n return (this.clearEvent.content || {}) as T;\n }\n return (this.event.content || {}) as T;\n }\n\n /**\n * Get the (decrypted, if necessary) event content JSON,\n * or the content from the replacing event, if any.\n * See `makeReplaced`.\n *\n * @returns The event content JSON, or an empty object.\n */\n public getContent(): T {\n if (this._localRedactionEvent) {\n return {} as T;\n } else if (this._replacingEvent) {\n return this._replacingEvent.getContent()[\"m.new_content\"] || {};\n } else {\n return this.getOriginalContent();\n }\n }\n\n /**\n * Get the (possibly encrypted) event content JSON that will be sent to the\n * homeserver.\n *\n * @returns The event content JSON, or an empty object.\n */\n public getWireContent(): IContent {\n return this.event.content || {};\n }\n\n /**\n * Get the event ID of the thread head\n */\n public get threadRootId(): string | undefined {\n const relatesTo = this.getWireContent()?.[\"m.relates_to\"];\n if (relatesTo?.rel_type === THREAD_RELATION_TYPE.name) {\n return relatesTo.event_id;\n } else {\n return this.getThread()?.id || this.threadId;\n }\n }\n\n /**\n * A helper to check if an event is a thread's head or not\n */\n public get isThreadRoot(): boolean {\n const threadDetails = this.getServerAggregatedRelation(THREAD_RELATION_TYPE.name);\n\n // Bundled relationships only returned when the sync response is limited\n // hence us having to check both bundled relation and inspect the thread\n // model\n return !!threadDetails || this.getThread()?.id === this.getId();\n }\n\n public get replyEventId(): string | undefined {\n return this.getWireContent()[\"m.relates_to\"]?.[\"m.in_reply_to\"]?.event_id;\n }\n\n public get relationEventId(): string | undefined {\n return this.getWireContent()?.[\"m.relates_to\"]?.event_id;\n }\n\n /**\n * Get the previous event content JSON. This will only return something for\n * state events which exist in the timeline.\n * @returns The previous event content JSON, or an empty object.\n */\n public getPrevContent(): IContent {\n // v2 then v1 then default\n return this.getUnsigned().prev_content || this.event.prev_content || {};\n }\n\n /**\n * Get either 'content' or 'prev_content' depending on if this event is\n * 'forward-looking' or not. This can be modified via event.forwardLooking.\n * In practice, this means we get the chronologically earlier content value\n * for this event (this method should surely be called getEarlierContent)\n * This method is experimental and may change.\n * @returns event.content if this event is forward-looking, else\n * event.prev_content.\n */\n public getDirectionalContent(): IContent {\n return this.forwardLooking ? this.getContent() : this.getPrevContent();\n }\n\n /**\n * Get the age of this event. This represents the age of the event when the\n * event arrived at the device, and not the age of the event when this\n * function was called.\n * Can only be returned once the server has echo'ed back\n * @returns The age of this event in milliseconds.\n */\n public getAge(): number | undefined {\n return this.getUnsigned().age || this.event.age; // v2 / v1\n }\n\n /**\n * Get the age of the event when this function was called.\n * This is the 'age' field adjusted according to how long this client has\n * had the event.\n * @returns The age of this event in milliseconds.\n */\n public getLocalAge(): number {\n return Date.now() - this.localTimestamp;\n }\n\n /**\n * Get the event state_key if it has one. This will return undefined\n * for message events.\n * @returns The event's `state_key`.\n */\n public getStateKey(): string | undefined {\n return this.event.state_key;\n }\n\n /**\n * Check if this event is a state event.\n * @returns True if this is a state event.\n */\n public isState(): boolean {\n return this.event.state_key !== undefined;\n }\n\n /**\n * Replace the content of this event with encrypted versions.\n * (This is used when sending an event; it should not be used by applications).\n *\n * @internal\n *\n * @param cryptoType - type of the encrypted event - typically\n * \"m.room.encrypted\"\n *\n * @param cryptoContent - raw 'content' for the encrypted event.\n *\n * @param senderCurve25519Key - curve25519 key to record for the\n * sender of this event.\n * See {@link MatrixEvent#getSenderKey}.\n *\n * @param claimedEd25519Key - claimed ed25519 key to record for the\n * sender if this event.\n * See {@link MatrixEvent#getClaimedEd25519Key}\n */\n public makeEncrypted(\n cryptoType: string,\n cryptoContent: object,\n senderCurve25519Key: string,\n claimedEd25519Key: string,\n ): void {\n // keep the plain-text data for 'view source'\n this.clearEvent = {\n type: this.event.type!,\n content: this.event.content!,\n };\n this.event.type = cryptoType;\n this.event.content = cryptoContent;\n this.senderCurve25519Key = senderCurve25519Key;\n this.claimedEd25519Key = claimedEd25519Key;\n }\n\n /**\n * Check if this event is currently being decrypted.\n *\n * @returns True if this event is currently being decrypted, else false.\n */\n public isBeingDecrypted(): boolean {\n return this.decryptionPromise != null;\n }\n\n public getDecryptionPromise(): Promise | null {\n return this.decryptionPromise;\n }\n\n /**\n * Check if this event is an encrypted event which we failed to decrypt\n *\n * (This implies that we might retry decryption at some point in the future)\n *\n * @returns True if this event is an encrypted event which we\n * couldn't decrypt.\n */\n public isDecryptionFailure(): boolean {\n return this.clearEvent?.content?.msgtype === \"m.bad.encrypted\";\n }\n\n /*\n * True if this event is an encrypted event which we failed to decrypt, the receiver's device is unverified and\n * the sender has disabled encrypting to unverified devices.\n */\n public get isEncryptedDisabledForUnverifiedDevices(): boolean {\n return this.isDecryptionFailure() && this.encryptedDisabledForUnverifiedDevices;\n }\n\n public shouldAttemptDecryption(): boolean {\n if (this.isRedacted()) return false;\n if (this.isBeingDecrypted()) return false;\n if (this.clearEvent) return false;\n if (!this.isEncrypted()) return false;\n\n return true;\n }\n\n /**\n * Start the process of trying to decrypt this event.\n *\n * (This is used within the SDK: it isn't intended for use by applications)\n *\n * @internal\n *\n * @param crypto - crypto module\n *\n * @returns promise which resolves (to undefined) when the decryption\n * attempt is completed.\n */\n public async attemptDecryption(crypto: CryptoBackend, options: IDecryptOptions = {}): Promise {\n // start with a couple of sanity checks.\n if (!this.isEncrypted()) {\n throw new Error(\"Attempt to decrypt event which isn't encrypted\");\n }\n\n const alreadyDecrypted = this.clearEvent && !this.isDecryptionFailure();\n const forceRedecrypt = options.forceRedecryptIfUntrusted && this.isKeySourceUntrusted();\n if (alreadyDecrypted && !forceRedecrypt) {\n // we may want to just ignore this? let's start with rejecting it.\n throw new Error(\"Attempt to decrypt event which has already been decrypted\");\n }\n\n // if we already have a decryption attempt in progress, then it may\n // fail because it was using outdated info. We now have reason to\n // succeed where it failed before, but we don't want to have multiple\n // attempts going at the same time, so just set a flag that says we have\n // new info.\n //\n if (this.decryptionPromise) {\n logger.log(`Event ${this.getId()} already being decrypted; queueing a retry`);\n this.retryDecryption = true;\n return this.decryptionPromise;\n }\n\n this.decryptionPromise = this.decryptionLoop(crypto, options);\n return this.decryptionPromise;\n }\n\n /**\n * Cancel any room key request for this event and resend another.\n *\n * @param crypto - crypto module\n * @param userId - the user who received this event\n *\n * @returns a promise that resolves when the request is queued\n */\n public cancelAndResendKeyRequest(crypto: Crypto, userId: string): Promise {\n const wireContent = this.getWireContent();\n return crypto.requestRoomKey(\n {\n algorithm: wireContent.algorithm,\n room_id: this.getRoomId()!,\n session_id: wireContent.session_id,\n sender_key: wireContent.sender_key,\n },\n this.getKeyRequestRecipients(userId),\n true,\n );\n }\n\n /**\n * Calculate the recipients for keyshare requests.\n *\n * @param userId - the user who received this event.\n *\n * @returns array of recipients\n */\n public getKeyRequestRecipients(userId: string): IKeyRequestRecipient[] {\n // send the request to all of our own devices\n const recipients = [\n {\n userId,\n deviceId: \"*\",\n },\n ];\n\n return recipients;\n }\n\n private async decryptionLoop(crypto: CryptoBackend, options: IDecryptOptions = {}): Promise {\n // make sure that this method never runs completely synchronously.\n // (doing so would mean that we would clear decryptionPromise *before*\n // it is set in attemptDecryption - and hence end up with a stuck\n // `decryptionPromise`).\n await Promise.resolve();\n\n // eslint-disable-next-line no-constant-condition\n while (true) {\n this.retryDecryption = false;\n\n let res: IEventDecryptionResult;\n let err: Error | undefined = undefined;\n try {\n if (!crypto) {\n res = this.badEncryptedMessage(\"Encryption not enabled\");\n } else {\n res = await crypto.decryptEvent(this);\n if (options.isRetry === true) {\n logger.info(`Decrypted event on retry (${this.getDetails()})`);\n }\n }\n } catch (e) {\n const detailedError = e instanceof DecryptionError ? (e).detailedString : String(e);\n\n err = e as Error;\n\n // see if we have a retry queued.\n //\n // NB: make sure to keep this check in the same tick of the\n // event loop as `decryptionPromise = null` below - otherwise we\n // risk a race:\n //\n // * A: we check retryDecryption here and see that it is\n // false\n // * B: we get a second call to attemptDecryption, which sees\n // that decryptionPromise is set so sets\n // retryDecryption\n // * A: we continue below, clear decryptionPromise, and\n // never do the retry.\n //\n if (this.retryDecryption) {\n // decryption error, but we have a retry queued.\n logger.log(`Error decrypting event (${this.getDetails()}), but retrying: ${detailedError}`);\n continue;\n }\n\n // decryption error, no retries queued. Warn about the error and\n // set it to m.bad.encrypted.\n //\n // the detailedString already includes the name and message of the error, and the stack isn't much use,\n // so we don't bother to log `e` separately.\n logger.warn(`Error decrypting event (${this.getDetails()}): ${detailedError}`);\n\n res = this.badEncryptedMessage(String(e));\n }\n\n // at this point, we've either successfully decrypted the event, or have given up\n // (and set res to a 'badEncryptedMessage'). Either way, we can now set the\n // cleartext of the event and raise Event.decrypted.\n //\n // make sure we clear 'decryptionPromise' before sending the 'Event.decrypted' event,\n // otherwise the app will be confused to see `isBeingDecrypted` still set when\n // there isn't an `Event.decrypted` on the way.\n //\n // see also notes on retryDecryption above.\n //\n this.decryptionPromise = null;\n this.retryDecryption = false;\n this.setClearData(res);\n\n // Before we emit the event, clear the push actions so that they can be recalculated\n // by relevant code. We do this because the clear event has now changed, making it\n // so that existing rules can be re-run over the applicable properties. Stuff like\n // highlighting when the user's name is mentioned rely on this happening. We also want\n // to set the push actions before emitting so that any notification listeners don't\n // pick up the wrong contents.\n this.setPushActions(null);\n\n if (options.emit !== false) {\n this.emit(MatrixEventEvent.Decrypted, this, err);\n }\n\n return;\n }\n }\n\n private badEncryptedMessage(reason: string): IEventDecryptionResult {\n return {\n clearEvent: {\n type: EventType.RoomMessage,\n content: {\n msgtype: \"m.bad.encrypted\",\n body: \"** Unable to decrypt: \" + reason + \" **\",\n },\n },\n encryptedDisabledForUnverifiedDevices: reason === `DecryptionError: ${WITHHELD_MESSAGES[\"m.unverified\"]}`,\n };\n }\n\n /**\n * Update the cleartext data on this event.\n *\n * (This is used after decrypting an event; it should not be used by applications).\n *\n * @internal\n *\n * @param decryptionResult - the decryption result, including the plaintext and some key info\n *\n * @remarks\n * Fires {@link MatrixEventEvent.Decrypted}\n */\n private setClearData(decryptionResult: IEventDecryptionResult): void {\n this.clearEvent = decryptionResult.clearEvent;\n this.senderCurve25519Key = decryptionResult.senderCurve25519Key ?? null;\n this.claimedEd25519Key = decryptionResult.claimedEd25519Key ?? null;\n this.forwardingCurve25519KeyChain = decryptionResult.forwardingCurve25519KeyChain || [];\n this.untrusted = decryptionResult.untrusted || false;\n this.encryptedDisabledForUnverifiedDevices = decryptionResult.encryptedDisabledForUnverifiedDevices || false;\n this.invalidateExtensibleEvent();\n }\n\n /**\n * Gets the cleartext content for this event. If the event is not encrypted,\n * or encryption has not been completed, this will return null.\n *\n * @returns The cleartext (decrypted) content for the event\n */\n public getClearContent(): IContent | null {\n return this.clearEvent ? this.clearEvent.content : null;\n }\n\n /**\n * Check if the event is encrypted.\n * @returns True if this event is encrypted.\n */\n public isEncrypted(): boolean {\n return !this.isState() && this.event.type === EventType.RoomMessageEncrypted;\n }\n\n /**\n * The curve25519 key for the device that we think sent this event\n *\n * For an Olm-encrypted event, this is inferred directly from the DH\n * exchange at the start of the session: the curve25519 key is involved in\n * the DH exchange, so only a device which holds the private part of that\n * key can establish such a session.\n *\n * For a megolm-encrypted event, it is inferred from the Olm message which\n * established the megolm session\n */\n public getSenderKey(): string | null {\n return this.senderCurve25519Key;\n }\n\n /**\n * The additional keys the sender of this encrypted event claims to possess.\n *\n * Just a wrapper for #getClaimedEd25519Key (q.v.)\n */\n public getKeysClaimed(): Partial> {\n if (!this.claimedEd25519Key) return {};\n\n return {\n ed25519: this.claimedEd25519Key,\n };\n }\n\n /**\n * Get the ed25519 the sender of this event claims to own.\n *\n * For Olm messages, this claim is encoded directly in the plaintext of the\n * event itself. For megolm messages, it is implied by the m.room_key event\n * which established the megolm session.\n *\n * Until we download the device list of the sender, it's just a claim: the\n * device list gives a proof that the owner of the curve25519 key used for\n * this event (and returned by #getSenderKey) also owns the ed25519 key by\n * signing the public curve25519 key with the ed25519 key.\n *\n * In general, applications should not use this method directly, but should\n * instead use MatrixClient.getEventSenderDeviceInfo.\n */\n public getClaimedEd25519Key(): string | null {\n return this.claimedEd25519Key;\n }\n\n /**\n * Get the curve25519 keys of the devices which were involved in telling us\n * about the claimedEd25519Key and sender curve25519 key.\n *\n * Normally this will be empty, but in the case of a forwarded megolm\n * session, the sender keys are sent to us by another device (the forwarding\n * device), which we need to trust to do this. In that case, the result will\n * be a list consisting of one entry.\n *\n * If the device that sent us the key (A) got it from another device which\n * it wasn't prepared to vouch for (B), the result will be [A, B]. And so on.\n *\n * @returns base64-encoded curve25519 keys, from oldest to newest.\n */\n public getForwardingCurve25519KeyChain(): string[] {\n return this.forwardingCurve25519KeyChain;\n }\n\n /**\n * Whether the decryption key was obtained from an untrusted source. If so,\n * we cannot verify the authenticity of the message.\n */\n public isKeySourceUntrusted(): boolean | undefined {\n return !!this.untrusted;\n }\n\n public getUnsigned(): IUnsigned {\n return this.event.unsigned || {};\n }\n\n public setUnsigned(unsigned: IUnsigned): void {\n this.event.unsigned = unsigned;\n }\n\n public unmarkLocallyRedacted(): boolean {\n const value = this._localRedactionEvent;\n this._localRedactionEvent = null;\n if (this.event.unsigned) {\n this.event.unsigned.redacted_because = undefined;\n }\n return !!value;\n }\n\n public markLocallyRedacted(redactionEvent: MatrixEvent): void {\n if (this._localRedactionEvent) return;\n this.emit(MatrixEventEvent.BeforeRedaction, this, redactionEvent);\n this._localRedactionEvent = redactionEvent;\n if (!this.event.unsigned) {\n this.event.unsigned = {};\n }\n this.event.unsigned.redacted_because = redactionEvent.event as IEvent;\n }\n\n /**\n * Change the visibility of an event, as per https://github.com/matrix-org/matrix-doc/pull/3531 .\n *\n * @param visibilityChange - event holding a hide/unhide payload, or nothing\n * if the event is being reset to its original visibility (presumably\n * by a visibility event being redacted).\n *\n * @remarks\n * Fires {@link MatrixEventEvent.VisibilityChange} if `visibilityEvent`\n * caused a change in the actual visibility of this event, either by making it\n * visible (if it was hidden), by making it hidden (if it was visible) or by\n * changing the reason (if it was hidden).\n */\n public applyVisibilityEvent(visibilityChange?: IVisibilityChange): void {\n const visible = visibilityChange?.visible ?? true;\n const reason = visibilityChange?.reason ?? null;\n let change = false;\n if (this.visibility.visible !== visible) {\n change = true;\n } else if (!this.visibility.visible && this.visibility[\"reason\"] !== reason) {\n change = true;\n }\n if (change) {\n if (visible) {\n this.visibility = MESSAGE_VISIBLE;\n } else {\n this.visibility = Object.freeze({\n visible: false,\n reason,\n });\n }\n this.emit(MatrixEventEvent.VisibilityChange, this, visible);\n }\n }\n\n /**\n * Return instructions to display or hide the message.\n *\n * @returns Instructions determining whether the message\n * should be displayed.\n */\n public messageVisibility(): MessageVisibility {\n // Note: We may return `this.visibility` without fear, as\n // this is a shallow frozen object.\n return this.visibility;\n }\n\n /**\n * Update the content of an event in the same way it would be by the server\n * if it were redacted before it was sent to us\n *\n * @param redactionEvent - event causing the redaction\n */\n public makeRedacted(redactionEvent: MatrixEvent): void {\n // quick sanity-check\n if (!redactionEvent.event) {\n throw new Error(\"invalid redactionEvent in makeRedacted\");\n }\n\n this._localRedactionEvent = null;\n\n this.emit(MatrixEventEvent.BeforeRedaction, this, redactionEvent);\n\n this._replacingEvent = null;\n // we attempt to replicate what we would see from the server if\n // the event had been redacted before we saw it.\n //\n // The server removes (most of) the content of the event, and adds a\n // \"redacted_because\" key to the unsigned section containing the\n // redacted event.\n if (!this.event.unsigned) {\n this.event.unsigned = {};\n }\n this.event.unsigned.redacted_because = redactionEvent.event as IEvent;\n\n for (const key in this.event) {\n if (this.event.hasOwnProperty(key) && !REDACT_KEEP_KEYS.has(key)) {\n delete this.event[key as keyof IEvent];\n }\n }\n\n // If the event is encrypted prune the decrypted bits\n if (this.isEncrypted()) {\n this.clearEvent = undefined;\n }\n\n const keeps =\n this.getType() in REDACT_KEEP_CONTENT_MAP\n ? REDACT_KEEP_CONTENT_MAP[this.getType() as keyof typeof REDACT_KEEP_CONTENT_MAP]\n : {};\n const content = this.getContent();\n for (const key in content) {\n if (content.hasOwnProperty(key) && !keeps[key]) {\n delete content[key];\n }\n }\n\n this.invalidateExtensibleEvent();\n }\n\n /**\n * Check if this event has been redacted\n *\n * @returns True if this event has been redacted\n */\n public isRedacted(): boolean {\n return Boolean(this.getUnsigned().redacted_because);\n }\n\n /**\n * Check if this event is a redaction of another event\n *\n * @returns True if this event is a redaction\n */\n public isRedaction(): boolean {\n return this.getType() === EventType.RoomRedaction;\n }\n\n /**\n * Return the visibility change caused by this event,\n * as per https://github.com/matrix-org/matrix-doc/pull/3531.\n *\n * @returns If the event is a well-formed visibility change event,\n * an instance of `IVisibilityChange`, otherwise `null`.\n */\n public asVisibilityChange(): IVisibilityChange | null {\n if (!EVENT_VISIBILITY_CHANGE_TYPE.matches(this.getType())) {\n // Not a visibility change event.\n return null;\n }\n const relation = this.getRelation();\n if (!relation || relation.rel_type != \"m.reference\") {\n // Ill-formed, ignore this event.\n return null;\n }\n const eventId = relation.event_id;\n if (!eventId) {\n // Ill-formed, ignore this event.\n return null;\n }\n const content = this.getWireContent();\n const visible = !!content.visible;\n const reason = content.reason;\n if (reason && typeof reason != \"string\") {\n // Ill-formed, ignore this event.\n return null;\n }\n // Well-formed visibility change event.\n return {\n visible,\n reason,\n eventId,\n };\n }\n\n /**\n * Check if this event alters the visibility of another event,\n * as per https://github.com/matrix-org/matrix-doc/pull/3531.\n *\n * @returns True if this event alters the visibility\n * of another event.\n */\n public isVisibilityEvent(): boolean {\n return EVENT_VISIBILITY_CHANGE_TYPE.matches(this.getType());\n }\n\n /**\n * Get the (decrypted, if necessary) redaction event JSON\n * if event was redacted\n *\n * @returns The redaction event JSON, or an empty object\n */\n public getRedactionEvent(): IEvent | {} | null {\n if (!this.isRedacted()) return null;\n\n if (this.clearEvent?.unsigned) {\n return this.clearEvent?.unsigned.redacted_because ?? null;\n } else if (this.event.unsigned?.redacted_because) {\n return this.event.unsigned.redacted_because;\n } else {\n return {};\n }\n }\n\n /**\n * Get the push actions, if known, for this event\n *\n * @returns push actions\n */\n public getPushActions(): IActionsObject | null {\n return this.pushActions;\n }\n\n /**\n * Set the push actions for this event.\n *\n * @param pushActions - push actions\n */\n public setPushActions(pushActions: IActionsObject | null): void {\n this.pushActions = pushActions;\n }\n\n /**\n * Replace the `event` property and recalculate any properties based on it.\n * @param event - the object to assign to the `event` property\n */\n public handleRemoteEcho(event: object): void {\n const oldUnsigned = this.getUnsigned();\n const oldId = this.getId();\n this.event = event;\n // if this event was redacted before it was sent, it's locally marked as redacted.\n // At this point, we've received the remote echo for the event, but not yet for\n // the redaction that we are sending ourselves. Preserve the locally redacted\n // state by copying over redacted_because so we don't get a flash of\n // redacted, not-redacted, redacted as remote echos come in\n if (oldUnsigned.redacted_because) {\n if (!this.event.unsigned) {\n this.event.unsigned = {};\n }\n this.event.unsigned.redacted_because = oldUnsigned.redacted_because;\n }\n // successfully sent.\n this.setStatus(null);\n if (this.getId() !== oldId) {\n // emit the event if it changed\n this.emit(MatrixEventEvent.LocalEventIdReplaced, this);\n }\n\n this.localTimestamp = Date.now() - this.getAge()!;\n }\n\n /**\n * Whether the event is in any phase of sending, send failure, waiting for\n * remote echo, etc.\n */\n public isSending(): boolean {\n return !!this.status;\n }\n\n /**\n * Update the event's sending status and emit an event as well.\n *\n * @param status - The new status\n */\n public setStatus(status: EventStatus | null): void {\n this.status = status;\n this.emit(MatrixEventEvent.Status, this, status);\n }\n\n public replaceLocalEventId(eventId: string): void {\n this.event.event_id = eventId;\n this.emit(MatrixEventEvent.LocalEventIdReplaced, this);\n }\n\n /**\n * Get whether the event is a relation event, and of a given type if\n * `relType` is passed in. State events cannot be relation events\n *\n * @param relType - if given, checks that the relation is of the\n * given type\n */\n public isRelation(relType?: string): boolean {\n // Relation info is lifted out of the encrypted content when sent to\n // encrypted rooms, so we have to check `getWireContent` for this.\n const relation = this.getWireContent()?.[\"m.relates_to\"];\n if (this.isState() && relation?.rel_type === RelationType.Replace) {\n // State events cannot be m.replace relations\n return false;\n }\n return !!(relation?.rel_type && relation.event_id && (relType ? relation.rel_type === relType : true));\n }\n\n /**\n * Get relation info for the event, if any.\n */\n public getRelation(): IEventRelation | null {\n if (!this.isRelation()) {\n return null;\n }\n return this.getWireContent()[\"m.relates_to\"] ?? null;\n }\n\n /**\n * Set an event that replaces the content of this event, through an m.replace relation.\n *\n * @param newEvent - the event with the replacing content, if any.\n *\n * @remarks\n * Fires {@link MatrixEventEvent.Replaced}\n */\n public makeReplaced(newEvent?: MatrixEvent): void {\n // don't allow redacted events to be replaced.\n // if newEvent is null we allow to go through though,\n // as with local redaction, the replacing event might get\n // cancelled, which should be reflected on the target event.\n if (this.isRedacted() && newEvent) {\n return;\n }\n // don't allow state events to be replaced using this mechanism as per MSC2676\n if (this.isState()) {\n return;\n }\n if (this._replacingEvent !== newEvent) {\n this._replacingEvent = newEvent ?? null;\n this.emit(MatrixEventEvent.Replaced, this);\n this.invalidateExtensibleEvent();\n }\n }\n\n /**\n * Returns the status of any associated edit or redaction\n * (not for reactions/annotations as their local echo doesn't affect the original event),\n * or else the status of the event.\n */\n public getAssociatedStatus(): EventStatus | null {\n if (this._replacingEvent) {\n return this._replacingEvent.status;\n } else if (this._localRedactionEvent) {\n return this._localRedactionEvent.status;\n }\n return this.status;\n }\n\n public getServerAggregatedRelation(relType: RelationType | string): T | undefined {\n return this.getUnsigned()[\"m.relations\"]?.[relType];\n }\n\n /**\n * Returns the event ID of the event replacing the content of this event, if any.\n */\n public replacingEventId(): string | undefined {\n const replaceRelation = this.getServerAggregatedRelation(RelationType.Replace);\n if (replaceRelation) {\n return replaceRelation.event_id;\n } else if (this._replacingEvent) {\n return this._replacingEvent.getId();\n }\n }\n\n /**\n * Returns the event replacing the content of this event, if any.\n * Replacements are aggregated on the server, so this would only\n * return an event in case it came down the sync, or for local echo of edits.\n */\n public replacingEvent(): MatrixEvent | null {\n return this._replacingEvent;\n }\n\n /**\n * Returns the origin_server_ts of the event replacing the content of this event, if any.\n */\n public replacingEventDate(): Date | undefined {\n const replaceRelation = this.getServerAggregatedRelation(RelationType.Replace);\n if (replaceRelation) {\n const ts = replaceRelation.origin_server_ts;\n if (Number.isFinite(ts)) {\n return new Date(ts);\n }\n } else if (this._replacingEvent) {\n return this._replacingEvent.getDate() ?? undefined;\n }\n }\n\n /**\n * Returns the event that wants to redact this event, but hasn't been sent yet.\n * @returns the event\n */\n public localRedactionEvent(): MatrixEvent | null {\n return this._localRedactionEvent;\n }\n\n /**\n * For relations and redactions, returns the event_id this event is referring to.\n */\n public getAssociatedId(): string | undefined {\n const relation = this.getRelation();\n if (this.replyEventId) {\n return this.replyEventId;\n } else if (relation) {\n return relation.event_id;\n } else if (this.isRedaction()) {\n return this.event.redacts;\n }\n }\n\n /**\n * Checks if this event is associated with another event. See `getAssociatedId`.\n * @deprecated use hasAssociation instead.\n */\n public hasAssocation(): boolean {\n return !!this.getAssociatedId();\n }\n\n /**\n * Checks if this event is associated with another event. See `getAssociatedId`.\n */\n public hasAssociation(): boolean {\n return !!this.getAssociatedId();\n }\n\n /**\n * Update the related id with a new one.\n *\n * Used to replace a local id with remote one before sending\n * an event with a related id.\n *\n * @param eventId - the new event id\n */\n public updateAssociatedId(eventId: string): void {\n const relation = this.getRelation();\n if (relation) {\n relation.event_id = eventId;\n } else if (this.isRedaction()) {\n this.event.redacts = eventId;\n }\n }\n\n /**\n * Flags an event as cancelled due to future conditions. For example, a verification\n * request event in the same sync transaction may be flagged as cancelled to warn\n * listeners that a cancellation event is coming down the same pipe shortly.\n * @param cancelled - Whether the event is to be cancelled or not.\n */\n public flagCancelled(cancelled = true): void {\n this._isCancelled = cancelled;\n }\n\n /**\n * Gets whether or not the event is flagged as cancelled. See flagCancelled() for\n * more information.\n * @returns True if the event is cancelled, false otherwise.\n */\n public isCancelled(): boolean {\n return this._isCancelled;\n }\n\n /**\n * Get a copy/snapshot of this event. The returned copy will be loosely linked\n * back to this instance, though will have \"frozen\" event information. Other\n * properties of this MatrixEvent instance will be copied verbatim, which can\n * mean they are in reference to this instance despite being on the copy too.\n * The reference the snapshot uses does not change, however members aside from\n * the underlying event will not be deeply cloned, thus may be mutated internally.\n * For example, the sender profile will be copied over at snapshot time, and\n * the sender profile internally may mutate without notice to the consumer.\n *\n * This is meant to be used to snapshot the event details themselves, not the\n * features (such as sender) surrounding the event.\n * @returns A snapshot of this event.\n */\n public toSnapshot(): MatrixEvent {\n const ev = new MatrixEvent(JSON.parse(JSON.stringify(this.event)));\n for (const [p, v] of Object.entries(this)) {\n if (p !== \"event\") {\n // exclude the thing we just cloned\n // @ts-ignore - XXX: this is just nasty\n ev[p as keyof MatrixEvent] = v;\n }\n }\n return ev;\n }\n\n /**\n * Determines if this event is equivalent to the given event. This only checks\n * the event object itself, not the other properties of the event. Intended for\n * use with toSnapshot() to identify events changing.\n * @param otherEvent - The other event to check against.\n * @returns True if the events are the same, false otherwise.\n */\n public isEquivalentTo(otherEvent: MatrixEvent): boolean {\n if (!otherEvent) return false;\n if (otherEvent === this) return true;\n const myProps = deepSortedObjectEntries(this.event);\n const theirProps = deepSortedObjectEntries(otherEvent.event);\n return JSON.stringify(myProps) === JSON.stringify(theirProps);\n }\n\n /**\n * Summarise the event as JSON. This is currently used by React SDK's view\n * event source feature and Seshat's event indexing, so take care when\n * adjusting the output here.\n *\n * If encrypted, include both the decrypted and encrypted view of the event.\n *\n * This is named `toJSON` for use with `JSON.stringify` which checks objects\n * for functions named `toJSON` and will call them to customise the output\n * if they are defined.\n */\n public toJSON(): object {\n const event = this.getEffectiveEvent();\n\n if (!this.isEncrypted()) {\n return event;\n }\n\n return {\n decrypted: event,\n encrypted: this.event,\n };\n }\n\n public setVerificationRequest(request: VerificationRequest): void {\n this.verificationRequest = request;\n }\n\n public setTxnId(txnId: string): void {\n this.txnId = txnId;\n }\n\n public getTxnId(): string | undefined {\n return this.txnId;\n }\n\n /**\n * Set the instance of a thread associated with the current event\n * @param thread - the thread\n */\n public setThread(thread?: Thread): void {\n if (this.thread) {\n this.reEmitter.stopReEmitting(this.thread, [ThreadEvent.Update]);\n }\n this.thread = thread;\n this.setThreadId(thread?.id);\n if (thread) {\n this.reEmitter.reEmit(thread, [ThreadEvent.Update]);\n }\n }\n\n /**\n * Get the instance of the thread associated with the current event\n */\n public getThread(): Thread | undefined {\n return this.thread;\n }\n\n public setThreadId(threadId?: string): void {\n this.threadId = threadId;\n }\n}\n\n/* REDACT_KEEP_KEYS gives the keys we keep when an event is redacted\n *\n * This is specified here:\n * http://matrix.org/speculator/spec/HEAD/client_server/latest.html#redactions\n *\n * Also:\n * - We keep 'unsigned' since that is created by the local server\n * - We keep user_id for backwards-compat with v1\n */\nconst REDACT_KEEP_KEYS = new Set([\n \"event_id\",\n \"type\",\n \"room_id\",\n \"user_id\",\n \"sender\",\n \"state_key\",\n \"prev_state\",\n \"content\",\n \"unsigned\",\n \"origin_server_ts\",\n]);\n\n// a map from state event type to the .content keys we keep when an event is redacted\nconst REDACT_KEEP_CONTENT_MAP: Record> = {\n [EventType.RoomMember]: { membership: 1 },\n [EventType.RoomCreate]: { creator: 1 },\n [EventType.RoomJoinRules]: { join_rule: 1 },\n [EventType.RoomPowerLevels]: {\n ban: 1,\n events: 1,\n events_default: 1,\n kick: 1,\n redact: 1,\n state_default: 1,\n users: 1,\n users_default: 1,\n },\n} as const;\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts deleted file mode 100644 index afb901c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts +++ /dev/null @@ -1,132 +0,0 @@ -import { UnstableValue } from "matrix-events-sdk"; -import { MatrixClient } from "../client"; -import { MatrixEvent } from "./event"; -import { Room } from "./room"; -export declare const POLICIES_ACCOUNT_EVENT_TYPE: UnstableValue<"m.policies", "org.matrix.msc3847.policies">; -export declare const IGNORE_INVITES_ACCOUNT_EVENT_KEY: UnstableValue<"m.ignore.invites", "org.matrix.msc3847.ignore.invites">; -/** - * The various scopes for policies. - */ -export declare enum PolicyScope { - /** - * The policy deals with an individual user, e.g. reject invites - * from this user. - */ - User = "m.policy.user", - /** - * The policy deals with a room, e.g. reject invites towards - * a specific room. - */ - Room = "m.policy.room", - /** - * The policy deals with a server, e.g. reject invites from - * this server. - */ - Server = "m.policy.server" -} -/** - * A container for ignored invites. - * - * # Performance - * - * This implementation is extremely naive. It expects that we are dealing - * with a very short list of sources (e.g. only one). If real-world - * applications turn out to require longer lists, we may need to rework - * our data structures. - */ -export declare class IgnoredInvites { - private readonly client; - constructor(client: MatrixClient); - /** - * Add a new rule. - * - * @param scope - The scope for this rule. - * @param entity - The entity covered by this rule. Globs are supported. - * @param reason - A human-readable reason for introducing this new rule. - * @returns The event id for the new rule. - */ - addRule(scope: PolicyScope, entity: string, reason: string): Promise; - /** - * Remove a rule. - */ - removeRule(event: MatrixEvent): Promise; - /** - * Add a new room to the list of sources. If the user isn't a member of the - * room, attempt to join it. - * - * @param roomId - A valid room id. If this room is already in the list - * of sources, it will not be duplicated. - * @returns `true` if the source was added, `false` if it was already present. - * @throws If `roomId` isn't the id of a room that the current user is already - * member of or can join. - * - * # Safety - * - * This method will rewrite the `Policies` object in the user's account data. - * This rewrite is inherently racy and could overwrite or be overwritten by - * other concurrent rewrites of the same object. - */ - addSource(roomId: string): Promise; - /** - * Find out whether an invite should be ignored. - * - * @param sender - The user id for the user who issued the invite. - * @param roomId - The room to which the user is invited. - * @returns A rule matching the entity, if any was found, `null` otherwise. - */ - getRuleForInvite({ sender, roomId, }: { - sender: string; - roomId: string; - }): Promise>; - /** - * Get the target room, i.e. the room in which any new rule should be written. - * - * If there is no target room setup, a target room is created. - * - * Note: This method is public for testing reasons. Most clients should not need - * to call it directly. - * - * # Safety - * - * This method will rewrite the `Policies` object in the user's account data. - * This rewrite is inherently racy and could overwrite or be overwritten by - * other concurrent rewrites of the same object. - */ - getOrCreateTargetRoom(): Promise; - /** - * Get the list of source rooms, i.e. the rooms from which rules need to be read. - * - * If no source rooms are setup, the target room is used as sole source room. - * - * Note: This method is public for testing reasons. Most clients should not need - * to call it directly. - * - * # Safety - * - * This method will rewrite the `Policies` object in the user's account data. - * This rewrite is inherently racy and could overwrite or be overwritten by - * other concurrent rewrites of the same object. - */ - getOrCreateSourceRooms(): Promise; - /** - * Fetch the `IGNORE_INVITES_POLICIES` object from account data. - * - * If both an unstable prefix version and a stable prefix version are available, - * it will return the stable prefix version preferentially. - * - * The result is *not* validated but is guaranteed to be a non-null object. - * - * @returns A non-null object. - */ - private getIgnoreInvitesPolicies; - /** - * Modify in place the `IGNORE_INVITES_POLICIES` object from account data. - */ - private withIgnoreInvitesPolicies; - /** - * As `getIgnoreInvitesPolicies` but also return the `POLICIES_ACCOUNT_EVENT_TYPE` - * object. - */ - private getPoliciesAndIgnoreInvitesPolicies; -} -//# sourceMappingURL=invites-ignorer.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts.map deleted file mode 100644 index 846564d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"invites-ignorer.d.ts","sourceRoot":"","sources":["../../src/models/invites-ignorer.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAY,WAAW,EAAE,MAAM,SAAS,CAAC;AAIhD,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAK9B,eAAO,MAAM,2BAA2B,4DAAiE,CAAC;AAK1G,eAAO,MAAM,gCAAgC,wEAG5C,CAAC;AAOF;;GAEG;AACH,oBAAY,WAAW;IACnB;;;OAGG;IACH,IAAI,kBAAkB;IAEtB;;;OAGG;IACH,IAAI,kBAAkB;IAEtB;;;OAGG;IACH,MAAM,oBAAoB;CAC7B;AAED;;;;;;;;;GASG;AACH,qBAAa,cAAc;IACJ,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,YAAY;IAExD;;;;;;;OAOG;IACU,OAAO,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAUzF;;OAEG;IACU,UAAU,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAI1D;;;;;;;;;;;;;;;OAeG;IACU,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAmBxD;;;;;;OAMG;IACU,gBAAgB,CAAC,EAC1B,MAAM,EACN,MAAM,GACT,EAAE;QACC,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;KAClB,GAAG,OAAO,CAAC,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IAqDzC;;;;;;;;;;;;;OAaG;IACU,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAgCnD;;;;;;;;;;;;;OAaG;IACU,sBAAsB,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IAqCtD;;;;;;;;;OASG;IACH,OAAO,CAAC,wBAAwB;IAIhC;;OAEG;YACW,yBAAyB;IASvC;;;OAGG;IACH,OAAO,CAAC,mCAAmC;CAmC9C"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js deleted file mode 100644 index dfa3093..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js +++ /dev/null @@ -1,360 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PolicyScope = exports.POLICIES_ACCOUNT_EVENT_TYPE = exports.IgnoredInvites = exports.IGNORE_INVITES_ACCOUNT_EVENT_KEY = void 0; -var _matrixEventsSdk = require("matrix-events-sdk"); -var _eventTimeline = require("./event-timeline"); -var _partials = require("../@types/partials"); -var _utils = require("../utils"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/// The event type storing the user's individual policies. -/// -/// Exported for testing purposes. -const POLICIES_ACCOUNT_EVENT_TYPE = new _matrixEventsSdk.UnstableValue("m.policies", "org.matrix.msc3847.policies"); - -/// The key within the user's individual policies storing the user's ignored invites. -/// -/// Exported for testing purposes. -exports.POLICIES_ACCOUNT_EVENT_TYPE = POLICIES_ACCOUNT_EVENT_TYPE; -const IGNORE_INVITES_ACCOUNT_EVENT_KEY = new _matrixEventsSdk.UnstableValue("m.ignore.invites", "org.matrix.msc3847.ignore.invites"); - -/// The types of recommendations understood. -exports.IGNORE_INVITES_ACCOUNT_EVENT_KEY = IGNORE_INVITES_ACCOUNT_EVENT_KEY; -var PolicyRecommendation; -/** - * The various scopes for policies. - */ -(function (PolicyRecommendation) { - PolicyRecommendation["Ban"] = "m.ban"; -})(PolicyRecommendation || (PolicyRecommendation = {})); -let PolicyScope; -/** - * A container for ignored invites. - * - * # Performance - * - * This implementation is extremely naive. It expects that we are dealing - * with a very short list of sources (e.g. only one). If real-world - * applications turn out to require longer lists, we may need to rework - * our data structures. - */ -exports.PolicyScope = PolicyScope; -(function (PolicyScope) { - PolicyScope["User"] = "m.policy.user"; - PolicyScope["Room"] = "m.policy.room"; - PolicyScope["Server"] = "m.policy.server"; -})(PolicyScope || (exports.PolicyScope = PolicyScope = {})); -class IgnoredInvites { - constructor(client) { - this.client = client; - } - - /** - * Add a new rule. - * - * @param scope - The scope for this rule. - * @param entity - The entity covered by this rule. Globs are supported. - * @param reason - A human-readable reason for introducing this new rule. - * @returns The event id for the new rule. - */ - async addRule(scope, entity, reason) { - const target = await this.getOrCreateTargetRoom(); - const response = await this.client.sendStateEvent(target.roomId, scope, { - entity, - reason, - recommendation: PolicyRecommendation.Ban - }); - return response.event_id; - } - - /** - * Remove a rule. - */ - async removeRule(event) { - await this.client.redactEvent(event.getRoomId(), event.getId()); - } - - /** - * Add a new room to the list of sources. If the user isn't a member of the - * room, attempt to join it. - * - * @param roomId - A valid room id. If this room is already in the list - * of sources, it will not be duplicated. - * @returns `true` if the source was added, `false` if it was already present. - * @throws If `roomId` isn't the id of a room that the current user is already - * member of or can join. - * - * # Safety - * - * This method will rewrite the `Policies` object in the user's account data. - * This rewrite is inherently racy and could overwrite or be overwritten by - * other concurrent rewrites of the same object. - */ - async addSource(roomId) { - // We attempt to join the room *before* calling - // `await this.getOrCreateSourceRooms()` to decrease the duration - // of the racy section. - await this.client.joinRoom(roomId); - // Race starts. - const sources = (await this.getOrCreateSourceRooms()).map(room => room.roomId); - if (sources.includes(roomId)) { - return false; - } - sources.push(roomId); - await this.withIgnoreInvitesPolicies(ignoreInvitesPolicies => { - ignoreInvitesPolicies.sources = sources; - }); - - // Race ends. - return true; - } - - /** - * Find out whether an invite should be ignored. - * - * @param sender - The user id for the user who issued the invite. - * @param roomId - The room to which the user is invited. - * @returns A rule matching the entity, if any was found, `null` otherwise. - */ - async getRuleForInvite({ - sender, - roomId - }) { - // In this implementation, we perform a very naive lookup: - // - search in each policy room; - // - turn each (potentially glob) rule entity into a regexp. - // - // Real-world testing will tell us whether this is performant enough. - // In the (unfortunately likely) case it isn't, there are several manners - // in which we could optimize this: - // - match several entities per go; - // - pre-compile each rule entity into a regexp; - // - pre-compile entire rooms into a single regexp. - const policyRooms = await this.getOrCreateSourceRooms(); - const senderServer = sender.split(":")[1]; - const roomServer = roomId.split(":")[1]; - for (const room of policyRooms) { - const state = room.getUnfilteredTimelineSet().getLiveTimeline().getState(_eventTimeline.EventTimeline.FORWARDS); - for (const { - scope, - entities - } of [{ - scope: PolicyScope.Room, - entities: [roomId] - }, { - scope: PolicyScope.User, - entities: [sender] - }, { - scope: PolicyScope.Server, - entities: [senderServer, roomServer] - }]) { - const events = state.getStateEvents(scope); - for (const event of events) { - const content = event.getContent(); - if ((content === null || content === void 0 ? void 0 : content.recommendation) != PolicyRecommendation.Ban) { - // Ignoring invites only looks at `m.ban` recommendations. - continue; - } - const glob = content === null || content === void 0 ? void 0 : content.entity; - if (!glob) { - // Invalid event. - continue; - } - let regexp; - try { - regexp = new RegExp((0, _utils.globToRegexp)(glob, false)); - } catch (ex) { - // Assume invalid event. - continue; - } - for (const entity of entities) { - if (entity && regexp.test(entity)) { - return event; - } - } - // No match. - } - } - } - - return null; - } - - /** - * Get the target room, i.e. the room in which any new rule should be written. - * - * If there is no target room setup, a target room is created. - * - * Note: This method is public for testing reasons. Most clients should not need - * to call it directly. - * - * # Safety - * - * This method will rewrite the `Policies` object in the user's account data. - * This rewrite is inherently racy and could overwrite or be overwritten by - * other concurrent rewrites of the same object. - */ - async getOrCreateTargetRoom() { - const ignoreInvitesPolicies = this.getIgnoreInvitesPolicies(); - let target = ignoreInvitesPolicies.target; - // Validate `target`. If it is invalid, trash out the current `target` - // and create a new room. - if (typeof target !== "string") { - target = null; - } - if (target) { - // Check that the room exists and is valid. - const room = this.client.getRoom(target); - if (room) { - return room; - } else { - target = null; - } - } - // We need to create our own policy room for ignoring invites. - target = (await this.client.createRoom({ - name: "Individual Policy Room", - preset: _partials.Preset.PrivateChat - })).room_id; - await this.withIgnoreInvitesPolicies(ignoreInvitesPolicies => { - ignoreInvitesPolicies.target = target; - }); - - // Since we have just called `createRoom`, `getRoom` should not be `null`. - return this.client.getRoom(target); - } - - /** - * Get the list of source rooms, i.e. the rooms from which rules need to be read. - * - * If no source rooms are setup, the target room is used as sole source room. - * - * Note: This method is public for testing reasons. Most clients should not need - * to call it directly. - * - * # Safety - * - * This method will rewrite the `Policies` object in the user's account data. - * This rewrite is inherently racy and could overwrite or be overwritten by - * other concurrent rewrites of the same object. - */ - async getOrCreateSourceRooms() { - const ignoreInvitesPolicies = this.getIgnoreInvitesPolicies(); - let sources = ignoreInvitesPolicies.sources; - - // Validate `sources`. If it is invalid, trash out the current `sources` - // and create a new list of sources from `target`. - let hasChanges = false; - if (!Array.isArray(sources)) { - // `sources` could not be an array. - hasChanges = true; - sources = []; - } - let sourceRooms = sources - // `sources` could contain non-string / invalid room ids - .filter(roomId => typeof roomId === "string").map(roomId => this.client.getRoom(roomId)).filter(room => !!room); - if (sourceRooms.length != sources.length) { - hasChanges = true; - } - if (sourceRooms.length == 0) { - // `sources` could be empty (possibly because we've removed - // invalid content) - const target = await this.getOrCreateTargetRoom(); - hasChanges = true; - sourceRooms = [target]; - } - if (hasChanges) { - // Reload `policies`/`ignoreInvitesPolicies` in case it has been changed - // during or by our call to `this.getTargetRoom()`. - await this.withIgnoreInvitesPolicies(ignoreInvitesPolicies => { - ignoreInvitesPolicies.sources = sources; - }); - } - return sourceRooms; - } - - /** - * Fetch the `IGNORE_INVITES_POLICIES` object from account data. - * - * If both an unstable prefix version and a stable prefix version are available, - * it will return the stable prefix version preferentially. - * - * The result is *not* validated but is guaranteed to be a non-null object. - * - * @returns A non-null object. - */ - getIgnoreInvitesPolicies() { - return this.getPoliciesAndIgnoreInvitesPolicies().ignoreInvitesPolicies; - } - - /** - * Modify in place the `IGNORE_INVITES_POLICIES` object from account data. - */ - async withIgnoreInvitesPolicies(cb) { - const { - policies, - ignoreInvitesPolicies - } = this.getPoliciesAndIgnoreInvitesPolicies(); - cb(ignoreInvitesPolicies); - policies[IGNORE_INVITES_ACCOUNT_EVENT_KEY.name] = ignoreInvitesPolicies; - await this.client.setAccountData(POLICIES_ACCOUNT_EVENT_TYPE.name, policies); - } - - /** - * As `getIgnoreInvitesPolicies` but also return the `POLICIES_ACCOUNT_EVENT_TYPE` - * object. - */ - getPoliciesAndIgnoreInvitesPolicies() { - let policies = {}; - for (const key of [POLICIES_ACCOUNT_EVENT_TYPE.name, POLICIES_ACCOUNT_EVENT_TYPE.altName]) { - var _this$client$getAccou; - if (!key) { - continue; - } - const value = (_this$client$getAccou = this.client.getAccountData(key)) === null || _this$client$getAccou === void 0 ? void 0 : _this$client$getAccou.getContent(); - if (value) { - policies = value; - break; - } - } - let ignoreInvitesPolicies = {}; - let hasIgnoreInvitesPolicies = false; - for (const key of [IGNORE_INVITES_ACCOUNT_EVENT_KEY.name, IGNORE_INVITES_ACCOUNT_EVENT_KEY.altName]) { - if (!key) { - continue; - } - const value = policies[key]; - if (value && typeof value == "object") { - ignoreInvitesPolicies = value; - hasIgnoreInvitesPolicies = true; - break; - } - } - if (!hasIgnoreInvitesPolicies) { - policies[IGNORE_INVITES_ACCOUNT_EVENT_KEY.name] = ignoreInvitesPolicies; - } - return { - policies, - ignoreInvitesPolicies - }; - } -} -exports.IgnoredInvites = IgnoredInvites; -//# sourceMappingURL=invites-ignorer.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js.map deleted file mode 100644 index 4e6c8a3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/invites-ignorer.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"invites-ignorer.js","names":["_matrixEventsSdk","require","_eventTimeline","_partials","_utils","POLICIES_ACCOUNT_EVENT_TYPE","UnstableValue","exports","IGNORE_INVITES_ACCOUNT_EVENT_KEY","PolicyRecommendation","PolicyScope","IgnoredInvites","constructor","client","addRule","scope","entity","reason","target","getOrCreateTargetRoom","response","sendStateEvent","roomId","recommendation","Ban","event_id","removeRule","event","redactEvent","getRoomId","getId","addSource","joinRoom","sources","getOrCreateSourceRooms","map","room","includes","push","withIgnoreInvitesPolicies","ignoreInvitesPolicies","getRuleForInvite","sender","policyRooms","senderServer","split","roomServer","state","getUnfilteredTimelineSet","getLiveTimeline","getState","EventTimeline","FORWARDS","entities","Room","User","Server","events","getStateEvents","content","getContent","glob","regexp","RegExp","globToRegexp","ex","test","getIgnoreInvitesPolicies","getRoom","createRoom","name","preset","Preset","PrivateChat","room_id","hasChanges","Array","isArray","sourceRooms","filter","length","getPoliciesAndIgnoreInvitesPolicies","cb","policies","setAccountData","key","altName","_this$client$getAccou","value","getAccountData","hasIgnoreInvitesPolicies"],"sources":["../../src/models/invites-ignorer.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { UnstableValue } from \"matrix-events-sdk\";\n\nimport { MatrixClient } from \"../client\";\nimport { IContent, MatrixEvent } from \"./event\";\nimport { EventTimeline } from \"./event-timeline\";\nimport { Preset } from \"../@types/partials\";\nimport { globToRegexp } from \"../utils\";\nimport { Room } from \"./room\";\n\n/// The event type storing the user's individual policies.\n///\n/// Exported for testing purposes.\nexport const POLICIES_ACCOUNT_EVENT_TYPE = new UnstableValue(\"m.policies\", \"org.matrix.msc3847.policies\");\n\n/// The key within the user's individual policies storing the user's ignored invites.\n///\n/// Exported for testing purposes.\nexport const IGNORE_INVITES_ACCOUNT_EVENT_KEY = new UnstableValue(\n \"m.ignore.invites\",\n \"org.matrix.msc3847.ignore.invites\",\n);\n\n/// The types of recommendations understood.\nenum PolicyRecommendation {\n Ban = \"m.ban\",\n}\n\n/**\n * The various scopes for policies.\n */\nexport enum PolicyScope {\n /**\n * The policy deals with an individual user, e.g. reject invites\n * from this user.\n */\n User = \"m.policy.user\",\n\n /**\n * The policy deals with a room, e.g. reject invites towards\n * a specific room.\n */\n Room = \"m.policy.room\",\n\n /**\n * The policy deals with a server, e.g. reject invites from\n * this server.\n */\n Server = \"m.policy.server\",\n}\n\n/**\n * A container for ignored invites.\n *\n * # Performance\n *\n * This implementation is extremely naive. It expects that we are dealing\n * with a very short list of sources (e.g. only one). If real-world\n * applications turn out to require longer lists, we may need to rework\n * our data structures.\n */\nexport class IgnoredInvites {\n public constructor(private readonly client: MatrixClient) {}\n\n /**\n * Add a new rule.\n *\n * @param scope - The scope for this rule.\n * @param entity - The entity covered by this rule. Globs are supported.\n * @param reason - A human-readable reason for introducing this new rule.\n * @returns The event id for the new rule.\n */\n public async addRule(scope: PolicyScope, entity: string, reason: string): Promise {\n const target = await this.getOrCreateTargetRoom();\n const response = await this.client.sendStateEvent(target.roomId, scope, {\n entity,\n reason,\n recommendation: PolicyRecommendation.Ban,\n });\n return response.event_id;\n }\n\n /**\n * Remove a rule.\n */\n public async removeRule(event: MatrixEvent): Promise {\n await this.client.redactEvent(event.getRoomId()!, event.getId()!);\n }\n\n /**\n * Add a new room to the list of sources. If the user isn't a member of the\n * room, attempt to join it.\n *\n * @param roomId - A valid room id. If this room is already in the list\n * of sources, it will not be duplicated.\n * @returns `true` if the source was added, `false` if it was already present.\n * @throws If `roomId` isn't the id of a room that the current user is already\n * member of or can join.\n *\n * # Safety\n *\n * This method will rewrite the `Policies` object in the user's account data.\n * This rewrite is inherently racy and could overwrite or be overwritten by\n * other concurrent rewrites of the same object.\n */\n public async addSource(roomId: string): Promise {\n // We attempt to join the room *before* calling\n // `await this.getOrCreateSourceRooms()` to decrease the duration\n // of the racy section.\n await this.client.joinRoom(roomId);\n // Race starts.\n const sources = (await this.getOrCreateSourceRooms()).map((room) => room.roomId);\n if (sources.includes(roomId)) {\n return false;\n }\n sources.push(roomId);\n await this.withIgnoreInvitesPolicies((ignoreInvitesPolicies) => {\n ignoreInvitesPolicies.sources = sources;\n });\n\n // Race ends.\n return true;\n }\n\n /**\n * Find out whether an invite should be ignored.\n *\n * @param sender - The user id for the user who issued the invite.\n * @param roomId - The room to which the user is invited.\n * @returns A rule matching the entity, if any was found, `null` otherwise.\n */\n public async getRuleForInvite({\n sender,\n roomId,\n }: {\n sender: string;\n roomId: string;\n }): Promise> {\n // In this implementation, we perform a very naive lookup:\n // - search in each policy room;\n // - turn each (potentially glob) rule entity into a regexp.\n //\n // Real-world testing will tell us whether this is performant enough.\n // In the (unfortunately likely) case it isn't, there are several manners\n // in which we could optimize this:\n // - match several entities per go;\n // - pre-compile each rule entity into a regexp;\n // - pre-compile entire rooms into a single regexp.\n const policyRooms = await this.getOrCreateSourceRooms();\n const senderServer = sender.split(\":\")[1];\n const roomServer = roomId.split(\":\")[1];\n for (const room of policyRooms) {\n const state = room.getUnfilteredTimelineSet().getLiveTimeline().getState(EventTimeline.FORWARDS)!;\n\n for (const { scope, entities } of [\n { scope: PolicyScope.Room, entities: [roomId] },\n { scope: PolicyScope.User, entities: [sender] },\n { scope: PolicyScope.Server, entities: [senderServer, roomServer] },\n ]) {\n const events = state.getStateEvents(scope);\n for (const event of events) {\n const content = event.getContent();\n if (content?.recommendation != PolicyRecommendation.Ban) {\n // Ignoring invites only looks at `m.ban` recommendations.\n continue;\n }\n const glob = content?.entity;\n if (!glob) {\n // Invalid event.\n continue;\n }\n let regexp: RegExp;\n try {\n regexp = new RegExp(globToRegexp(glob, false));\n } catch (ex) {\n // Assume invalid event.\n continue;\n }\n for (const entity of entities) {\n if (entity && regexp.test(entity)) {\n return event;\n }\n }\n // No match.\n }\n }\n }\n return null;\n }\n\n /**\n * Get the target room, i.e. the room in which any new rule should be written.\n *\n * If there is no target room setup, a target room is created.\n *\n * Note: This method is public for testing reasons. Most clients should not need\n * to call it directly.\n *\n * # Safety\n *\n * This method will rewrite the `Policies` object in the user's account data.\n * This rewrite is inherently racy and could overwrite or be overwritten by\n * other concurrent rewrites of the same object.\n */\n public async getOrCreateTargetRoom(): Promise {\n const ignoreInvitesPolicies = this.getIgnoreInvitesPolicies();\n let target = ignoreInvitesPolicies.target;\n // Validate `target`. If it is invalid, trash out the current `target`\n // and create a new room.\n if (typeof target !== \"string\") {\n target = null;\n }\n if (target) {\n // Check that the room exists and is valid.\n const room = this.client.getRoom(target);\n if (room) {\n return room;\n } else {\n target = null;\n }\n }\n // We need to create our own policy room for ignoring invites.\n target = (\n await this.client.createRoom({\n name: \"Individual Policy Room\",\n preset: Preset.PrivateChat,\n })\n ).room_id;\n await this.withIgnoreInvitesPolicies((ignoreInvitesPolicies) => {\n ignoreInvitesPolicies.target = target;\n });\n\n // Since we have just called `createRoom`, `getRoom` should not be `null`.\n return this.client.getRoom(target)!;\n }\n\n /**\n * Get the list of source rooms, i.e. the rooms from which rules need to be read.\n *\n * If no source rooms are setup, the target room is used as sole source room.\n *\n * Note: This method is public for testing reasons. Most clients should not need\n * to call it directly.\n *\n * # Safety\n *\n * This method will rewrite the `Policies` object in the user's account data.\n * This rewrite is inherently racy and could overwrite or be overwritten by\n * other concurrent rewrites of the same object.\n */\n public async getOrCreateSourceRooms(): Promise {\n const ignoreInvitesPolicies = this.getIgnoreInvitesPolicies();\n let sources: string[] = ignoreInvitesPolicies.sources;\n\n // Validate `sources`. If it is invalid, trash out the current `sources`\n // and create a new list of sources from `target`.\n let hasChanges = false;\n if (!Array.isArray(sources)) {\n // `sources` could not be an array.\n hasChanges = true;\n sources = [];\n }\n let sourceRooms = sources\n // `sources` could contain non-string / invalid room ids\n .filter((roomId) => typeof roomId === \"string\")\n .map((roomId) => this.client.getRoom(roomId))\n .filter((room) => !!room) as Room[];\n if (sourceRooms.length != sources.length) {\n hasChanges = true;\n }\n if (sourceRooms.length == 0) {\n // `sources` could be empty (possibly because we've removed\n // invalid content)\n const target = await this.getOrCreateTargetRoom();\n hasChanges = true;\n sourceRooms = [target];\n }\n if (hasChanges) {\n // Reload `policies`/`ignoreInvitesPolicies` in case it has been changed\n // during or by our call to `this.getTargetRoom()`.\n await this.withIgnoreInvitesPolicies((ignoreInvitesPolicies) => {\n ignoreInvitesPolicies.sources = sources;\n });\n }\n return sourceRooms;\n }\n\n /**\n * Fetch the `IGNORE_INVITES_POLICIES` object from account data.\n *\n * If both an unstable prefix version and a stable prefix version are available,\n * it will return the stable prefix version preferentially.\n *\n * The result is *not* validated but is guaranteed to be a non-null object.\n *\n * @returns A non-null object.\n */\n private getIgnoreInvitesPolicies(): { [key: string]: any } {\n return this.getPoliciesAndIgnoreInvitesPolicies().ignoreInvitesPolicies;\n }\n\n /**\n * Modify in place the `IGNORE_INVITES_POLICIES` object from account data.\n */\n private async withIgnoreInvitesPolicies(\n cb: (ignoreInvitesPolicies: { [key: string]: any }) => void,\n ): Promise {\n const { policies, ignoreInvitesPolicies } = this.getPoliciesAndIgnoreInvitesPolicies();\n cb(ignoreInvitesPolicies);\n policies[IGNORE_INVITES_ACCOUNT_EVENT_KEY.name] = ignoreInvitesPolicies;\n await this.client.setAccountData(POLICIES_ACCOUNT_EVENT_TYPE.name, policies);\n }\n\n /**\n * As `getIgnoreInvitesPolicies` but also return the `POLICIES_ACCOUNT_EVENT_TYPE`\n * object.\n */\n private getPoliciesAndIgnoreInvitesPolicies(): {\n policies: { [key: string]: any };\n ignoreInvitesPolicies: { [key: string]: any };\n } {\n let policies: IContent = {};\n for (const key of [POLICIES_ACCOUNT_EVENT_TYPE.name, POLICIES_ACCOUNT_EVENT_TYPE.altName]) {\n if (!key) {\n continue;\n }\n const value = this.client.getAccountData(key)?.getContent();\n if (value) {\n policies = value;\n break;\n }\n }\n\n let ignoreInvitesPolicies = {};\n let hasIgnoreInvitesPolicies = false;\n for (const key of [IGNORE_INVITES_ACCOUNT_EVENT_KEY.name, IGNORE_INVITES_ACCOUNT_EVENT_KEY.altName]) {\n if (!key) {\n continue;\n }\n const value = policies[key];\n if (value && typeof value == \"object\") {\n ignoreInvitesPolicies = value;\n hasIgnoreInvitesPolicies = true;\n break;\n }\n }\n if (!hasIgnoreInvitesPolicies) {\n policies[IGNORE_INVITES_ACCOUNT_EVENT_KEY.name] = ignoreInvitesPolicies;\n }\n\n return { policies, ignoreInvitesPolicies };\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts deleted file mode 100644 index 50e1729..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts +++ /dev/null @@ -1,60 +0,0 @@ -import { MatrixClient } from "../client"; -import { PollStartEvent } from "../extensible_events_v1/PollStartEvent"; -import { MatrixEvent } from "./event"; -import { Relations } from "./relations"; -import { Room } from "./room"; -import { TypedEventEmitter } from "./typed-event-emitter"; -export declare enum PollEvent { - New = "Poll.new", - End = "Poll.end", - Update = "Poll.update", - Responses = "Poll.Responses", - Destroy = "Poll.Destroy", - UndecryptableRelations = "Poll.UndecryptableRelations" -} -export type PollEventHandlerMap = { - [PollEvent.Update]: (event: MatrixEvent, poll: Poll) => void; - [PollEvent.Destroy]: (pollIdentifier: string) => void; - [PollEvent.End]: () => void; - [PollEvent.Responses]: (responses: Relations) => void; - [PollEvent.UndecryptableRelations]: (count: number) => void; -}; -export declare class Poll extends TypedEventEmitter, PollEventHandlerMap> { - readonly rootEvent: MatrixEvent; - private matrixClient; - private room; - readonly roomId: string; - readonly pollEvent: PollStartEvent; - private _isFetchingResponses; - private relationsNextBatch; - private responses; - private endEvent; - /** - * Keep track of undecryptable relations - * As incomplete result sets affect poll results - */ - private undecryptableRelationEventIds; - constructor(rootEvent: MatrixEvent, matrixClient: MatrixClient, room: Room); - get pollId(): string; - get endEventId(): string | undefined; - get isEnded(): boolean; - get isFetchingResponses(): boolean; - get undecryptableRelationsCount(): number; - getResponses(): Promise; - /** - * - * @param event - event with a relation to the rootEvent - * @returns void - */ - onNewRelation(event: MatrixEvent): void; - private fetchResponses; - /** - * Only responses made before the poll ended are valid - * Refilter after an end event is recieved - * To ensure responses are valid - */ - private refilterResponsesOnEnd; - private countUndecryptableEvents; - private validateEndEvent; -} -//# sourceMappingURL=poll.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts.map deleted file mode 100644 index 568e552..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"poll.d.ts","sourceRoot":"","sources":["../../src/models/poll.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,oBAAY,SAAS;IACjB,GAAG,aAAa;IAChB,GAAG,aAAa;IAChB,MAAM,gBAAgB;IACtB,SAAS,mBAAmB;IAC5B,OAAO,iBAAiB;IACxB,sBAAsB,gCAAgC;CACzD;AAED,MAAM,MAAM,mBAAmB,GAAG;IAC9B,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAC7D,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,cAAc,EAAE,MAAM,KAAK,IAAI,CAAC;IACtD,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,MAAM,IAAI,CAAC;IAC5B,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,EAAE,SAAS,KAAK,IAAI,CAAC;IACtD,CAAC,SAAS,CAAC,sBAAsB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CAC/D,CAAC;AAuBF,qBAAa,IAAK,SAAQ,iBAAiB,CAAC,OAAO,CAAC,SAAS,EAAE,SAAS,CAAC,GAAG,CAAC,EAAE,mBAAmB,CAAC;aAa5D,SAAS,EAAE,WAAW;IAAE,OAAO,CAAC,YAAY;IAAgB,OAAO,CAAC,IAAI;IAZ3G,SAAgB,MAAM,EAAE,MAAM,CAAC;IAC/B,SAAgB,SAAS,EAAE,cAAc,CAAC;IAC1C,OAAO,CAAC,oBAAoB,CAAS;IACrC,OAAO,CAAC,kBAAkB,CAAqB;IAC/C,OAAO,CAAC,SAAS,CAA0B;IAC3C,OAAO,CAAC,QAAQ,CAA0B;IAC1C;;;OAGG;IACH,OAAO,CAAC,6BAA6B,CAAqB;gBAEvB,SAAS,EAAE,WAAW,EAAU,YAAY,EAAE,YAAY,EAAU,IAAI,EAAE,IAAI;IASjH,IAAW,MAAM,IAAI,MAAM,CAE1B;IAED,IAAW,UAAU,IAAI,MAAM,GAAG,SAAS,CAE1C;IAED,IAAW,OAAO,IAAI,OAAO,CAE5B;IAED,IAAW,mBAAmB,IAAI,OAAO,CAExC;IAED,IAAW,2BAA2B,IAAI,MAAM,CAE/C;IAEY,YAAY,IAAI,OAAO,CAAC,SAAS,CAAC;IAgB/C;;;;OAIG;IACI,aAAa,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI;YA0BhC,cAAc;IA0D5B;;;;OAIG;IACH,OAAO,CAAC,sBAAsB;IAe9B,OAAO,CAAC,wBAAwB,CAW9B;IAEF,OAAO,CAAC,gBAAgB;CAyB3B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js deleted file mode 100644 index 755119e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js +++ /dev/null @@ -1,231 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PollEvent = exports.Poll = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _polls = require("../@types/polls"); -var _relations = require("./relations"); -var _typedEventEmitter = require("./typed-event-emitter"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let PollEvent; -exports.PollEvent = PollEvent; -(function (PollEvent) { - PollEvent["New"] = "Poll.new"; - PollEvent["End"] = "Poll.end"; - PollEvent["Update"] = "Poll.update"; - PollEvent["Responses"] = "Poll.Responses"; - PollEvent["Destroy"] = "Poll.Destroy"; - PollEvent["UndecryptableRelations"] = "Poll.UndecryptableRelations"; -})(PollEvent || (exports.PollEvent = PollEvent = {})); -const filterResponseRelations = (relationEvents, pollEndTimestamp) => { - const responseEvents = relationEvents.filter(event => { - if (event.isDecryptionFailure()) { - return; - } - return _polls.M_POLL_RESPONSE.matches(event.getType()) && - // From MSC3381: - // "Votes sent on or before the end event's timestamp are valid votes" - event.getTs() <= pollEndTimestamp; - }); - return { - responseEvents - }; -}; -class Poll extends _typedEventEmitter.TypedEventEmitter { - /** - * Keep track of undecryptable relations - * As incomplete result sets affect poll results - */ - - constructor(rootEvent, matrixClient, room) { - super(); - this.rootEvent = rootEvent; - this.matrixClient = matrixClient; - this.room = room; - (0, _defineProperty2.default)(this, "roomId", void 0); - (0, _defineProperty2.default)(this, "pollEvent", void 0); - (0, _defineProperty2.default)(this, "_isFetchingResponses", false); - (0, _defineProperty2.default)(this, "relationsNextBatch", void 0); - (0, _defineProperty2.default)(this, "responses", null); - (0, _defineProperty2.default)(this, "endEvent", void 0); - (0, _defineProperty2.default)(this, "undecryptableRelationEventIds", new Set()); - (0, _defineProperty2.default)(this, "countUndecryptableEvents", events => { - const undecryptableEventIds = events.filter(event => event.isDecryptionFailure()).map(event => event.getId()); - const previousCount = this.undecryptableRelationsCount; - this.undecryptableRelationEventIds = new Set([...this.undecryptableRelationEventIds, ...undecryptableEventIds]); - if (this.undecryptableRelationsCount !== previousCount) { - this.emit(PollEvent.UndecryptableRelations, this.undecryptableRelationsCount); - } - }); - if (!this.rootEvent.getRoomId() || !this.rootEvent.getId()) { - throw new Error("Invalid poll start event."); - } - this.roomId = this.rootEvent.getRoomId(); - this.pollEvent = this.rootEvent.unstableExtensibleEvent; - } - get pollId() { - return this.rootEvent.getId(); - } - get endEventId() { - var _this$endEvent; - return (_this$endEvent = this.endEvent) === null || _this$endEvent === void 0 ? void 0 : _this$endEvent.getId(); - } - get isEnded() { - return !!this.endEvent; - } - get isFetchingResponses() { - return this._isFetchingResponses; - } - get undecryptableRelationsCount() { - return this.undecryptableRelationEventIds.size; - } - async getResponses() { - // if we have already fetched some responses - // just return them - if (this.responses) { - return this.responses; - } - - // if there is no fetching in progress - // start fetching - if (!this.isFetchingResponses) { - await this.fetchResponses(); - } - // return whatever responses we got from the first page - return this.responses; - } - - /** - * - * @param event - event with a relation to the rootEvent - * @returns void - */ - onNewRelation(event) { - var _this$endEvent2; - if (_polls.M_POLL_END.matches(event.getType()) && this.validateEndEvent(event)) { - this.endEvent = event; - this.refilterResponsesOnEnd(); - this.emit(PollEvent.End); - } - - // wait for poll responses to be initialised - if (!this.responses) { - return; - } - const pollEndTimestamp = ((_this$endEvent2 = this.endEvent) === null || _this$endEvent2 === void 0 ? void 0 : _this$endEvent2.getTs()) || Number.MAX_SAFE_INTEGER; - const { - responseEvents - } = filterResponseRelations([event], pollEndTimestamp); - this.countUndecryptableEvents([event]); - if (responseEvents.length) { - responseEvents.forEach(event => { - this.responses.addEvent(event); - }); - this.emit(PollEvent.Responses, this.responses); - } - } - async fetchResponses() { - var _this$endEvent3, _allRelations$nextBat; - this._isFetchingResponses = true; - - // we want: - // - stable and unstable M_POLL_RESPONSE - // - stable and unstable M_POLL_END - // so make one api call and filter by event type client side - const allRelations = await this.matrixClient.relations(this.roomId, this.rootEvent.getId(), "m.reference", undefined, { - from: this.relationsNextBatch || undefined - }); - await Promise.all(allRelations.events.map(event => this.matrixClient.decryptEventIfNeeded(event))); - const responses = this.responses || new _relations.Relations("m.reference", _polls.M_POLL_RESPONSE.name, this.matrixClient, [_polls.M_POLL_RESPONSE.altName]); - const pollEndEvent = allRelations.events.find(event => _polls.M_POLL_END.matches(event.getType())); - if (this.validateEndEvent(pollEndEvent)) { - this.endEvent = pollEndEvent; - this.refilterResponsesOnEnd(); - this.emit(PollEvent.End); - } - const pollCloseTimestamp = ((_this$endEvent3 = this.endEvent) === null || _this$endEvent3 === void 0 ? void 0 : _this$endEvent3.getTs()) || Number.MAX_SAFE_INTEGER; - const { - responseEvents - } = filterResponseRelations(allRelations.events, pollCloseTimestamp); - responseEvents.forEach(event => { - responses.addEvent(event); - }); - this.relationsNextBatch = (_allRelations$nextBat = allRelations.nextBatch) !== null && _allRelations$nextBat !== void 0 ? _allRelations$nextBat : undefined; - this.responses = responses; - this.countUndecryptableEvents(allRelations.events); - - // while there are more pages of relations - // fetch them - if (this.relationsNextBatch) { - // don't await - // we want to return the first page as soon as possible - this.fetchResponses(); - } else { - // no more pages - this._isFetchingResponses = false; - } - - // emit after updating _isFetchingResponses state - this.emit(PollEvent.Responses, this.responses); - } - - /** - * Only responses made before the poll ended are valid - * Refilter after an end event is recieved - * To ensure responses are valid - */ - refilterResponsesOnEnd() { - var _this$endEvent4; - if (!this.responses) { - return; - } - const pollEndTimestamp = ((_this$endEvent4 = this.endEvent) === null || _this$endEvent4 === void 0 ? void 0 : _this$endEvent4.getTs()) || Number.MAX_SAFE_INTEGER; - this.responses.getRelations().forEach(event => { - if (event.getTs() > pollEndTimestamp) { - var _this$responses; - (_this$responses = this.responses) === null || _this$responses === void 0 ? void 0 : _this$responses.removeEvent(event); - } - }); - this.emit(PollEvent.Responses, this.responses); - } - validateEndEvent(endEvent) { - if (!endEvent) { - return false; - } - /** - * Repeated end events are ignored - - * only the first (valid) closure event by origin_server_ts is counted. - */ - if (this.endEvent && this.endEvent.getTs() < endEvent.getTs()) { - return false; - } - - /** - * MSC3381 - * If a m.poll.end event is received from someone other than the poll creator or user with permission to redact - * others' messages in the room, the event must be ignored by clients due to being invalid. - */ - const roomCurrentState = this.room.currentState; - const endEventSender = endEvent.getSender(); - return !!endEventSender && (endEventSender === this.rootEvent.getSender() || roomCurrentState.maySendRedactionForEvent(this.rootEvent, endEventSender)); - } -} -exports.Poll = Poll; -//# sourceMappingURL=poll.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js.map deleted file mode 100644 index 36b4b37..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/poll.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"poll.js","names":["_polls","require","_relations","_typedEventEmitter","PollEvent","exports","filterResponseRelations","relationEvents","pollEndTimestamp","responseEvents","filter","event","isDecryptionFailure","M_POLL_RESPONSE","matches","getType","getTs","Poll","TypedEventEmitter","constructor","rootEvent","matrixClient","room","_defineProperty2","default","Set","events","undecryptableEventIds","map","getId","previousCount","undecryptableRelationsCount","undecryptableRelationEventIds","emit","UndecryptableRelations","getRoomId","Error","roomId","pollEvent","unstableExtensibleEvent","pollId","endEventId","_this$endEvent","endEvent","isEnded","isFetchingResponses","_isFetchingResponses","size","getResponses","responses","fetchResponses","onNewRelation","_this$endEvent2","M_POLL_END","validateEndEvent","refilterResponsesOnEnd","End","Number","MAX_SAFE_INTEGER","countUndecryptableEvents","length","forEach","addEvent","Responses","_this$endEvent3","_allRelations$nextBat","allRelations","relations","undefined","from","relationsNextBatch","Promise","all","decryptEventIfNeeded","Relations","name","altName","pollEndEvent","find","pollCloseTimestamp","nextBatch","_this$endEvent4","getRelations","_this$responses","removeEvent","roomCurrentState","currentState","endEventSender","getSender","maySendRedactionForEvent"],"sources":["../../src/models/poll.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { M_POLL_END, M_POLL_RESPONSE } from \"../@types/polls\";\nimport { MatrixClient } from \"../client\";\nimport { PollStartEvent } from \"../extensible_events_v1/PollStartEvent\";\nimport { MatrixEvent } from \"./event\";\nimport { Relations } from \"./relations\";\nimport { Room } from \"./room\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\n\nexport enum PollEvent {\n New = \"Poll.new\",\n End = \"Poll.end\",\n Update = \"Poll.update\",\n Responses = \"Poll.Responses\",\n Destroy = \"Poll.Destroy\",\n UndecryptableRelations = \"Poll.UndecryptableRelations\",\n}\n\nexport type PollEventHandlerMap = {\n [PollEvent.Update]: (event: MatrixEvent, poll: Poll) => void;\n [PollEvent.Destroy]: (pollIdentifier: string) => void;\n [PollEvent.End]: () => void;\n [PollEvent.Responses]: (responses: Relations) => void;\n [PollEvent.UndecryptableRelations]: (count: number) => void;\n};\n\nconst filterResponseRelations = (\n relationEvents: MatrixEvent[],\n pollEndTimestamp: number,\n): {\n responseEvents: MatrixEvent[];\n} => {\n const responseEvents = relationEvents.filter((event) => {\n if (event.isDecryptionFailure()) {\n return;\n }\n return (\n M_POLL_RESPONSE.matches(event.getType()) &&\n // From MSC3381:\n // \"Votes sent on or before the end event's timestamp are valid votes\"\n event.getTs() <= pollEndTimestamp\n );\n });\n\n return { responseEvents };\n};\n\nexport class Poll extends TypedEventEmitter, PollEventHandlerMap> {\n public readonly roomId: string;\n public readonly pollEvent: PollStartEvent;\n private _isFetchingResponses = false;\n private relationsNextBatch: string | undefined;\n private responses: null | Relations = null;\n private endEvent: MatrixEvent | undefined;\n /**\n * Keep track of undecryptable relations\n * As incomplete result sets affect poll results\n */\n private undecryptableRelationEventIds = new Set();\n\n public constructor(public readonly rootEvent: MatrixEvent, private matrixClient: MatrixClient, private room: Room) {\n super();\n if (!this.rootEvent.getRoomId() || !this.rootEvent.getId()) {\n throw new Error(\"Invalid poll start event.\");\n }\n this.roomId = this.rootEvent.getRoomId()!;\n this.pollEvent = this.rootEvent.unstableExtensibleEvent as unknown as PollStartEvent;\n }\n\n public get pollId(): string {\n return this.rootEvent.getId()!;\n }\n\n public get endEventId(): string | undefined {\n return this.endEvent?.getId();\n }\n\n public get isEnded(): boolean {\n return !!this.endEvent;\n }\n\n public get isFetchingResponses(): boolean {\n return this._isFetchingResponses;\n }\n\n public get undecryptableRelationsCount(): number {\n return this.undecryptableRelationEventIds.size;\n }\n\n public async getResponses(): Promise {\n // if we have already fetched some responses\n // just return them\n if (this.responses) {\n return this.responses;\n }\n\n // if there is no fetching in progress\n // start fetching\n if (!this.isFetchingResponses) {\n await this.fetchResponses();\n }\n // return whatever responses we got from the first page\n return this.responses!;\n }\n\n /**\n *\n * @param event - event with a relation to the rootEvent\n * @returns void\n */\n public onNewRelation(event: MatrixEvent): void {\n if (M_POLL_END.matches(event.getType()) && this.validateEndEvent(event)) {\n this.endEvent = event;\n this.refilterResponsesOnEnd();\n this.emit(PollEvent.End);\n }\n\n // wait for poll responses to be initialised\n if (!this.responses) {\n return;\n }\n\n const pollEndTimestamp = this.endEvent?.getTs() || Number.MAX_SAFE_INTEGER;\n const { responseEvents } = filterResponseRelations([event], pollEndTimestamp);\n\n this.countUndecryptableEvents([event]);\n\n if (responseEvents.length) {\n responseEvents.forEach((event) => {\n this.responses!.addEvent(event);\n });\n\n this.emit(PollEvent.Responses, this.responses);\n }\n }\n\n private async fetchResponses(): Promise {\n this._isFetchingResponses = true;\n\n // we want:\n // - stable and unstable M_POLL_RESPONSE\n // - stable and unstable M_POLL_END\n // so make one api call and filter by event type client side\n const allRelations = await this.matrixClient.relations(\n this.roomId,\n this.rootEvent.getId()!,\n \"m.reference\",\n undefined,\n {\n from: this.relationsNextBatch || undefined,\n },\n );\n\n await Promise.all(allRelations.events.map((event) => this.matrixClient.decryptEventIfNeeded(event)));\n\n const responses =\n this.responses ||\n new Relations(\"m.reference\", M_POLL_RESPONSE.name, this.matrixClient, [M_POLL_RESPONSE.altName!]);\n\n const pollEndEvent = allRelations.events.find((event) => M_POLL_END.matches(event.getType()));\n\n if (this.validateEndEvent(pollEndEvent)) {\n this.endEvent = pollEndEvent;\n this.refilterResponsesOnEnd();\n this.emit(PollEvent.End);\n }\n\n const pollCloseTimestamp = this.endEvent?.getTs() || Number.MAX_SAFE_INTEGER;\n\n const { responseEvents } = filterResponseRelations(allRelations.events, pollCloseTimestamp);\n\n responseEvents.forEach((event) => {\n responses.addEvent(event);\n });\n\n this.relationsNextBatch = allRelations.nextBatch ?? undefined;\n this.responses = responses;\n this.countUndecryptableEvents(allRelations.events);\n\n // while there are more pages of relations\n // fetch them\n if (this.relationsNextBatch) {\n // don't await\n // we want to return the first page as soon as possible\n this.fetchResponses();\n } else {\n // no more pages\n this._isFetchingResponses = false;\n }\n\n // emit after updating _isFetchingResponses state\n this.emit(PollEvent.Responses, this.responses);\n }\n\n /**\n * Only responses made before the poll ended are valid\n * Refilter after an end event is recieved\n * To ensure responses are valid\n */\n private refilterResponsesOnEnd(): void {\n if (!this.responses) {\n return;\n }\n\n const pollEndTimestamp = this.endEvent?.getTs() || Number.MAX_SAFE_INTEGER;\n this.responses.getRelations().forEach((event) => {\n if (event.getTs() > pollEndTimestamp) {\n this.responses?.removeEvent(event);\n }\n });\n\n this.emit(PollEvent.Responses, this.responses);\n }\n\n private countUndecryptableEvents = (events: MatrixEvent[]): void => {\n const undecryptableEventIds = events\n .filter((event) => event.isDecryptionFailure())\n .map((event) => event.getId()!);\n\n const previousCount = this.undecryptableRelationsCount;\n this.undecryptableRelationEventIds = new Set([...this.undecryptableRelationEventIds, ...undecryptableEventIds]);\n\n if (this.undecryptableRelationsCount !== previousCount) {\n this.emit(PollEvent.UndecryptableRelations, this.undecryptableRelationsCount);\n }\n };\n\n private validateEndEvent(endEvent?: MatrixEvent): boolean {\n if (!endEvent) {\n return false;\n }\n /**\n * Repeated end events are ignored -\n * only the first (valid) closure event by origin_server_ts is counted.\n */\n if (this.endEvent && this.endEvent.getTs() < endEvent.getTs()) {\n return false;\n }\n\n /**\n * MSC3381\n * If a m.poll.end event is received from someone other than the poll creator or user with permission to redact\n * others' messages in the room, the event must be ignored by clients due to being invalid.\n */\n const roomCurrentState = this.room.currentState;\n const endEventSender = endEvent.getSender();\n return (\n !!endEventSender &&\n (endEventSender === this.rootEvent.getSender() ||\n roomCurrentState.maySendRedactionForEvent(this.rootEvent, endEventSender))\n );\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts deleted file mode 100644 index 1c228c2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts +++ /dev/null @@ -1,76 +0,0 @@ -import { CachedReceipt, Receipt, ReceiptType, WrappedReceipt } from "../@types/read_receipts"; -import { ListenerMap, TypedEventEmitter } from "./typed-event-emitter"; -import { MatrixEvent } from "./event"; -import { EventTimelineSet } from "./event-timeline-set"; -import { NotificationCountType } from "./room"; -export declare function synthesizeReceipt(userId: string, event: MatrixEvent, receiptType: ReceiptType): MatrixEvent; -export declare abstract class ReadReceipt, SuperclassArguments extends ListenerMap = Arguments> extends TypedEventEmitter { - private receipts; - private receiptCacheByEventId; - abstract getUnfilteredTimelineSet(): EventTimelineSet; - abstract timeline: MatrixEvent[]; - /** - * Gets the latest receipt for a given user in the room - * @param userId - The id of the user for which we want the receipt - * @param ignoreSynthesized - Whether to ignore synthesized receipts or not - * @param receiptType - Optional. The type of the receipt we want to get - * @returns the latest receipts of the chosen type for the chosen user - */ - getReadReceiptForUserId(userId: string, ignoreSynthesized?: boolean, receiptType?: ReceiptType): WrappedReceipt | null; - /** - * Get the ID of the event that a given user has read up to, or null if we - * have received no read receipts from them. - * @param userId - The user ID to get read receipt event ID for - * @param ignoreSynthesized - If true, return only receipts that have been - * sent by the server, not implicit ones generated - * by the JS SDK. - * @returns ID of the latest event that the given user has read, or null. - */ - getEventReadUpTo(userId: string, ignoreSynthesized?: boolean): string | null; - addReceiptToStructure(eventId: string, receiptType: ReceiptType, userId: string, receipt: Receipt, synthetic: boolean): void; - /** - * Get a list of receipts for the given event. - * @param event - the event to get receipts for - * @returns A list of receipts with a userId, type and data keys or - * an empty list. - */ - getReceiptsForEvent(event: MatrixEvent): CachedReceipt[]; - abstract addReceipt(event: MatrixEvent, synthetic: boolean): void; - abstract setUnread(type: NotificationCountType, count: number): void; - /** - * This issue should also be addressed on synapse's side and is tracked as part - * of https://github.com/matrix-org/synapse/issues/14837 - * - * Retrieves the read receipt for the logged in user and checks if it matches - * the last event in the room and whether that event originated from the logged - * in user. - * Under those conditions we can consider the context as read. This is useful - * because we never send read receipts against our own events - * @param userId - the logged in user - */ - fixupNotifications(userId: string): void; - /** - * Add a temporary local-echo receipt to the room to reflect in the - * client the fact that we've sent one. - * @param userId - The user ID if the receipt sender - * @param e - The event that is to be acknowledged - * @param receiptType - The type of receipt - */ - addLocalEchoReceipt(userId: string, e: MatrixEvent, receiptType: ReceiptType): void; - /** - * Get a list of user IDs who have read up to the given event. - * @param event - the event to get read receipts for. - * @returns A list of user IDs. - */ - getUsersReadUpTo(event: MatrixEvent): string[]; - /** - * Determines if the given user has read a particular event ID with the known - * history of the room. This is not a definitive check as it relies only on - * what is available to the room at the time of execution. - * @param userId - The user ID to check the read state of. - * @param eventId - The event ID to check if the user read. - * @returns True if the user has read the event, false otherwise. - */ - hasUserReadEvent(userId: string, eventId: string): boolean; -} -//# sourceMappingURL=read-receipt.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts.map deleted file mode 100644 index 2b5306c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"read-receipt.d.ts","sourceRoot":"","sources":["../../src/models/read-receipt.ts"],"names":[],"mappings":"AAaA,OAAO,EACH,aAAa,EAEb,OAAO,EAEP,WAAW,EACX,cAAc,EACjB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAEvE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAAE,qBAAqB,EAAE,MAAM,QAAQ,CAAC;AAE/C,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,GAAG,WAAW,CAe3G;AAKD,8BAAsB,WAAW,CAC7B,MAAM,SAAS,MAAM,EACrB,SAAS,SAAS,WAAW,CAAC,MAAM,CAAC,EACrC,mBAAmB,SAAS,WAAW,CAAC,GAAG,CAAC,GAAG,SAAS,CAC1D,SAAQ,iBAAiB,CAAC,MAAM,EAAE,SAAS,EAAE,mBAAmB,CAAC;IAM/D,OAAO,CAAC,QAAQ,CAEd;IACF,OAAO,CAAC,qBAAqB,CAA2B;aAExC,wBAAwB,IAAI,gBAAgB;IAC5D,SAAgB,QAAQ,EAAE,WAAW,EAAE,CAAC;IAExC;;;;;;OAMG;IACI,uBAAuB,CAC1B,MAAM,EAAE,MAAM,EACd,iBAAiB,UAAQ,EACzB,WAAW,cAAmB,GAC/B,cAAc,GAAG,IAAI;IASxB;;;;;;;;OAQG;IACI,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,iBAAiB,UAAQ,GAAG,MAAM,GAAG,IAAI;IA4B1E,qBAAqB,CACxB,OAAO,EAAE,MAAM,EACf,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,OAAO,GACnB,IAAI;IAqFP;;;;;OAKG;IACI,mBAAmB,CAAC,KAAK,EAAE,WAAW,GAAG,aAAa,EAAE;aAI/C,UAAU,CAAC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,GAAG,IAAI;aAExD,SAAS,CAAC,IAAI,EAAE,qBAAqB,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAE3E;;;;;;;;;;OAUG;IACI,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAU/C;;;;;;OAMG;IACI,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,GAAG,IAAI;IAI1F;;;;OAIG;IACI,gBAAgB,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM,EAAE;IAUrD;;;;;;;OAOG;IACI,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO;CA2BpE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js deleted file mode 100644 index c5948ef..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js +++ /dev/null @@ -1,267 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ReadReceipt = void 0; -exports.synthesizeReceipt = synthesizeReceipt; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _read_receipts = require("../@types/read_receipts"); -var _typedEventEmitter = require("./typed-event-emitter"); -var utils = _interopRequireWildcard(require("../utils")); -var _event = require("./event"); -var _event2 = require("../@types/event"); -var _room = require("./room"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2022 The Matrix.org Foundation C.I.C. -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - http://www.apache.org/licenses/LICENSE-2.0 -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -function synthesizeReceipt(userId, event, receiptType) { - var _event$threadRootId; - return new _event.MatrixEvent({ - content: { - [event.getId()]: { - [receiptType]: { - [userId]: { - ts: event.getTs(), - thread_id: (_event$threadRootId = event.threadRootId) !== null && _event$threadRootId !== void 0 ? _event$threadRootId : _read_receipts.MAIN_ROOM_TIMELINE - } - } - } - }, - type: _event2.EventType.Receipt, - room_id: event.getRoomId() - }); -} -const ReceiptPairRealIndex = 0; -const ReceiptPairSyntheticIndex = 1; -class ReadReceipt extends _typedEventEmitter.TypedEventEmitter { - constructor(...args) { - super(...args); - (0, _defineProperty2.default)(this, "receipts", new utils.MapWithDefault(() => new Map())); - (0, _defineProperty2.default)(this, "receiptCacheByEventId", new Map()); - (0, _defineProperty2.default)(this, "timeline", void 0); - } - /** - * Gets the latest receipt for a given user in the room - * @param userId - The id of the user for which we want the receipt - * @param ignoreSynthesized - Whether to ignore synthesized receipts or not - * @param receiptType - Optional. The type of the receipt we want to get - * @returns the latest receipts of the chosen type for the chosen user - */ - getReadReceiptForUserId(userId, ignoreSynthesized = false, receiptType = _read_receipts.ReceiptType.Read) { - var _this$receipts$get$ge, _this$receipts$get; - const [realReceipt, syntheticReceipt] = (_this$receipts$get$ge = (_this$receipts$get = this.receipts.get(receiptType)) === null || _this$receipts$get === void 0 ? void 0 : _this$receipts$get.get(userId)) !== null && _this$receipts$get$ge !== void 0 ? _this$receipts$get$ge : [null, null]; - if (ignoreSynthesized) { - return realReceipt; - } - return syntheticReceipt !== null && syntheticReceipt !== void 0 ? syntheticReceipt : realReceipt; - } - - /** - * Get the ID of the event that a given user has read up to, or null if we - * have received no read receipts from them. - * @param userId - The user ID to get read receipt event ID for - * @param ignoreSynthesized - If true, return only receipts that have been - * sent by the server, not implicit ones generated - * by the JS SDK. - * @returns ID of the latest event that the given user has read, or null. - */ - getEventReadUpTo(userId, ignoreSynthesized = false) { - var _publicReadReceipt$da, _privateReadReceipt$d, _ref, _privateReadReceipt$e, _ref2; - // XXX: This is very very ugly and I hope I won't have to ever add a new - // receipt type here again. IMHO this should be done by the server in - // some more intelligent manner or the client should just use timestamps - - const timelineSet = this.getUnfilteredTimelineSet(); - const publicReadReceipt = this.getReadReceiptForUserId(userId, ignoreSynthesized, _read_receipts.ReceiptType.Read); - const privateReadReceipt = this.getReadReceiptForUserId(userId, ignoreSynthesized, _read_receipts.ReceiptType.ReadPrivate); - - // If we have both, compare them - let comparison; - if (publicReadReceipt !== null && publicReadReceipt !== void 0 && publicReadReceipt.eventId && privateReadReceipt !== null && privateReadReceipt !== void 0 && privateReadReceipt.eventId) { - comparison = timelineSet.compareEventOrdering(publicReadReceipt === null || publicReadReceipt === void 0 ? void 0 : publicReadReceipt.eventId, privateReadReceipt === null || privateReadReceipt === void 0 ? void 0 : privateReadReceipt.eventId); - } - - // If we didn't get a comparison try to compare the ts of the receipts - if (!comparison && publicReadReceipt !== null && publicReadReceipt !== void 0 && (_publicReadReceipt$da = publicReadReceipt.data) !== null && _publicReadReceipt$da !== void 0 && _publicReadReceipt$da.ts && privateReadReceipt !== null && privateReadReceipt !== void 0 && (_privateReadReceipt$d = privateReadReceipt.data) !== null && _privateReadReceipt$d !== void 0 && _privateReadReceipt$d.ts) { - var _publicReadReceipt$da2, _privateReadReceipt$d2; - comparison = (publicReadReceipt === null || publicReadReceipt === void 0 ? void 0 : (_publicReadReceipt$da2 = publicReadReceipt.data) === null || _publicReadReceipt$da2 === void 0 ? void 0 : _publicReadReceipt$da2.ts) - (privateReadReceipt === null || privateReadReceipt === void 0 ? void 0 : (_privateReadReceipt$d2 = privateReadReceipt.data) === null || _privateReadReceipt$d2 === void 0 ? void 0 : _privateReadReceipt$d2.ts); - } - - // The public receipt is more likely to drift out of date so the private - // one has precedence - if (!comparison) return (_ref = (_privateReadReceipt$e = privateReadReceipt === null || privateReadReceipt === void 0 ? void 0 : privateReadReceipt.eventId) !== null && _privateReadReceipt$e !== void 0 ? _privateReadReceipt$e : publicReadReceipt === null || publicReadReceipt === void 0 ? void 0 : publicReadReceipt.eventId) !== null && _ref !== void 0 ? _ref : null; - - // If public read receipt is older, return the private one - return (_ref2 = comparison < 0 ? privateReadReceipt === null || privateReadReceipt === void 0 ? void 0 : privateReadReceipt.eventId : publicReadReceipt === null || publicReadReceipt === void 0 ? void 0 : publicReadReceipt.eventId) !== null && _ref2 !== void 0 ? _ref2 : null; - } - addReceiptToStructure(eventId, receiptType, userId, receipt, synthetic) { - var _pair$ReceiptPairSynt2, _pair$ReceiptPairSynt3; - const receiptTypesMap = this.receipts.getOrCreate(receiptType); - let pair = receiptTypesMap.get(userId); - if (!pair) { - pair = [null, null]; - receiptTypesMap.set(userId, pair); - } - let existingReceipt = pair[ReceiptPairRealIndex]; - if (synthetic) { - var _pair$ReceiptPairSynt; - existingReceipt = (_pair$ReceiptPairSynt = pair[ReceiptPairSyntheticIndex]) !== null && _pair$ReceiptPairSynt !== void 0 ? _pair$ReceiptPairSynt : pair[ReceiptPairRealIndex]; - } - if (existingReceipt) { - // we only want to add this receipt if we think it is later than the one we already have. - // This is managed server-side, but because we synthesize RRs locally we have to do it here too. - const ordering = this.getUnfilteredTimelineSet().compareEventOrdering(existingReceipt.eventId, eventId); - if (ordering !== null && ordering >= 0) { - return; - } - } - const wrappedReceipt = { - eventId, - data: receipt - }; - const realReceipt = synthetic ? pair[ReceiptPairRealIndex] : wrappedReceipt; - const syntheticReceipt = synthetic ? wrappedReceipt : pair[ReceiptPairSyntheticIndex]; - let ordering = null; - if (realReceipt && syntheticReceipt) { - ordering = this.getUnfilteredTimelineSet().compareEventOrdering(realReceipt.eventId, syntheticReceipt.eventId); - } - const preferSynthetic = ordering === null || ordering < 0; - - // we don't bother caching just real receipts by event ID as there's nothing that would read it. - // Take the current cached receipt before we overwrite the pair elements. - const cachedReceipt = (_pair$ReceiptPairSynt2 = pair[ReceiptPairSyntheticIndex]) !== null && _pair$ReceiptPairSynt2 !== void 0 ? _pair$ReceiptPairSynt2 : pair[ReceiptPairRealIndex]; - if (synthetic && preferSynthetic) { - pair[ReceiptPairSyntheticIndex] = wrappedReceipt; - } else if (!synthetic) { - pair[ReceiptPairRealIndex] = wrappedReceipt; - if (!preferSynthetic) { - pair[ReceiptPairSyntheticIndex] = null; - } - } - const newCachedReceipt = (_pair$ReceiptPairSynt3 = pair[ReceiptPairSyntheticIndex]) !== null && _pair$ReceiptPairSynt3 !== void 0 ? _pair$ReceiptPairSynt3 : pair[ReceiptPairRealIndex]; - if (cachedReceipt === newCachedReceipt) return; - - // clean up any previous cache entry - if (cachedReceipt && this.receiptCacheByEventId.get(cachedReceipt.eventId)) { - const previousEventId = cachedReceipt.eventId; - // Remove the receipt we're about to clobber out of existence from the cache - this.receiptCacheByEventId.set(previousEventId, this.receiptCacheByEventId.get(previousEventId).filter(r => { - return r.type !== receiptType || r.userId !== userId; - })); - if (this.receiptCacheByEventId.get(previousEventId).length < 1) { - this.receiptCacheByEventId.delete(previousEventId); // clean up the cache keys - } - } - - // cache the new one - if (!this.receiptCacheByEventId.get(eventId)) { - this.receiptCacheByEventId.set(eventId, []); - } - this.receiptCacheByEventId.get(eventId).push({ - userId: userId, - type: receiptType, - data: receipt - }); - } - - /** - * Get a list of receipts for the given event. - * @param event - the event to get receipts for - * @returns A list of receipts with a userId, type and data keys or - * an empty list. - */ - getReceiptsForEvent(event) { - return this.receiptCacheByEventId.get(event.getId()) || []; - } - /** - * This issue should also be addressed on synapse's side and is tracked as part - * of https://github.com/matrix-org/synapse/issues/14837 - * - * Retrieves the read receipt for the logged in user and checks if it matches - * the last event in the room and whether that event originated from the logged - * in user. - * Under those conditions we can consider the context as read. This is useful - * because we never send read receipts against our own events - * @param userId - the logged in user - */ - fixupNotifications(userId) { - const receipt = this.getReadReceiptForUserId(userId, false); - const lastEvent = this.timeline[this.timeline.length - 1]; - if (lastEvent && (receipt === null || receipt === void 0 ? void 0 : receipt.eventId) === lastEvent.getId() && userId === lastEvent.getSender()) { - this.setUnread(_room.NotificationCountType.Total, 0); - this.setUnread(_room.NotificationCountType.Highlight, 0); - } - } - - /** - * Add a temporary local-echo receipt to the room to reflect in the - * client the fact that we've sent one. - * @param userId - The user ID if the receipt sender - * @param e - The event that is to be acknowledged - * @param receiptType - The type of receipt - */ - addLocalEchoReceipt(userId, e, receiptType) { - this.addReceipt(synthesizeReceipt(userId, e, receiptType), true); - } - - /** - * Get a list of user IDs who have read up to the given event. - * @param event - the event to get read receipts for. - * @returns A list of user IDs. - */ - getUsersReadUpTo(event) { - return this.getReceiptsForEvent(event).filter(function (receipt) { - return utils.isSupportedReceiptType(receipt.type); - }).map(function (receipt) { - return receipt.userId; - }); - } - - /** - * Determines if the given user has read a particular event ID with the known - * history of the room. This is not a definitive check as it relies only on - * what is available to the room at the time of execution. - * @param userId - The user ID to check the read state of. - * @param eventId - The event ID to check if the user read. - * @returns True if the user has read the event, false otherwise. - */ - hasUserReadEvent(userId, eventId) { - var _this$timeline; - const readUpToId = this.getEventReadUpTo(userId, false); - if (readUpToId === eventId) return true; - if ((_this$timeline = this.timeline) !== null && _this$timeline !== void 0 && _this$timeline.length && this.timeline[this.timeline.length - 1].getSender() && this.timeline[this.timeline.length - 1].getSender() === userId) { - // It doesn't matter where the event is in the timeline, the user has read - // it because they've sent the latest event. - return true; - } - for (let i = ((_this$timeline2 = this.timeline) === null || _this$timeline2 === void 0 ? void 0 : _this$timeline2.length) - 1; i >= 0; --i) { - var _this$timeline2; - const ev = this.timeline[i]; - - // If we encounter the target event first, the user hasn't read it - // however if we encounter the readUpToId first then the user has read - // it. These rules apply because we're iterating bottom-up. - if (ev.getId() === eventId) return false; - if (ev.getId() === readUpToId) return true; - } - - // We don't know if the user has read it, so assume not. - return false; - } -} -exports.ReadReceipt = ReadReceipt; -//# sourceMappingURL=read-receipt.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js.map deleted file mode 100644 index 435e602..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/read-receipt.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"read-receipt.js","names":["_read_receipts","require","_typedEventEmitter","utils","_interopRequireWildcard","_event","_event2","_room","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","synthesizeReceipt","userId","event","receiptType","_event$threadRootId","MatrixEvent","content","getId","ts","getTs","thread_id","threadRootId","MAIN_ROOM_TIMELINE","type","EventType","Receipt","room_id","getRoomId","ReceiptPairRealIndex","ReceiptPairSyntheticIndex","ReadReceipt","TypedEventEmitter","constructor","args","_defineProperty2","MapWithDefault","Map","getReadReceiptForUserId","ignoreSynthesized","ReceiptType","Read","_this$receipts$get$ge","_this$receipts$get","realReceipt","syntheticReceipt","receipts","getEventReadUpTo","_publicReadReceipt$da","_privateReadReceipt$d","_ref","_privateReadReceipt$e","_ref2","timelineSet","getUnfilteredTimelineSet","publicReadReceipt","privateReadReceipt","ReadPrivate","comparison","eventId","compareEventOrdering","data","_publicReadReceipt$da2","_privateReadReceipt$d2","addReceiptToStructure","receipt","synthetic","_pair$ReceiptPairSynt2","_pair$ReceiptPairSynt3","receiptTypesMap","getOrCreate","pair","existingReceipt","_pair$ReceiptPairSynt","ordering","wrappedReceipt","preferSynthetic","cachedReceipt","newCachedReceipt","receiptCacheByEventId","previousEventId","filter","r","length","delete","push","getReceiptsForEvent","fixupNotifications","lastEvent","timeline","getSender","setUnread","NotificationCountType","Total","Highlight","addLocalEchoReceipt","e","addReceipt","getUsersReadUpTo","isSupportedReceiptType","map","hasUserReadEvent","_this$timeline","readUpToId","i","_this$timeline2","ev","exports"],"sources":["../../src/models/read-receipt.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n http://www.apache.org/licenses/LICENSE-2.0\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport {\n CachedReceipt,\n MAIN_ROOM_TIMELINE,\n Receipt,\n ReceiptCache,\n ReceiptType,\n WrappedReceipt,\n} from \"../@types/read_receipts\";\nimport { ListenerMap, TypedEventEmitter } from \"./typed-event-emitter\";\nimport * as utils from \"../utils\";\nimport { MatrixEvent } from \"./event\";\nimport { EventType } from \"../@types/event\";\nimport { EventTimelineSet } from \"./event-timeline-set\";\nimport { MapWithDefault } from \"../utils\";\nimport { NotificationCountType } from \"./room\";\n\nexport function synthesizeReceipt(userId: string, event: MatrixEvent, receiptType: ReceiptType): MatrixEvent {\n return new MatrixEvent({\n content: {\n [event.getId()!]: {\n [receiptType]: {\n [userId]: {\n ts: event.getTs(),\n thread_id: event.threadRootId ?? MAIN_ROOM_TIMELINE,\n },\n },\n },\n },\n type: EventType.Receipt,\n room_id: event.getRoomId(),\n });\n}\n\nconst ReceiptPairRealIndex = 0;\nconst ReceiptPairSyntheticIndex = 1;\n\nexport abstract class ReadReceipt<\n Events extends string,\n Arguments extends ListenerMap,\n SuperclassArguments extends ListenerMap = Arguments,\n> extends TypedEventEmitter {\n // receipts should clobber based on receipt_type and user_id pairs hence\n // the form of this structure. This is sub-optimal for the exposed APIs\n // which pass in an event ID and get back some receipts, so we also store\n // a pre-cached list for this purpose.\n // Map: receipt type → user Id → receipt\n private receipts = new MapWithDefault>(\n () => new Map(),\n );\n private receiptCacheByEventId: ReceiptCache = new Map();\n\n public abstract getUnfilteredTimelineSet(): EventTimelineSet;\n public abstract timeline: MatrixEvent[];\n\n /**\n * Gets the latest receipt for a given user in the room\n * @param userId - The id of the user for which we want the receipt\n * @param ignoreSynthesized - Whether to ignore synthesized receipts or not\n * @param receiptType - Optional. The type of the receipt we want to get\n * @returns the latest receipts of the chosen type for the chosen user\n */\n public getReadReceiptForUserId(\n userId: string,\n ignoreSynthesized = false,\n receiptType = ReceiptType.Read,\n ): WrappedReceipt | null {\n const [realReceipt, syntheticReceipt] = this.receipts.get(receiptType)?.get(userId) ?? [null, null];\n if (ignoreSynthesized) {\n return realReceipt;\n }\n\n return syntheticReceipt ?? realReceipt;\n }\n\n /**\n * Get the ID of the event that a given user has read up to, or null if we\n * have received no read receipts from them.\n * @param userId - The user ID to get read receipt event ID for\n * @param ignoreSynthesized - If true, return only receipts that have been\n * sent by the server, not implicit ones generated\n * by the JS SDK.\n * @returns ID of the latest event that the given user has read, or null.\n */\n public getEventReadUpTo(userId: string, ignoreSynthesized = false): string | null {\n // XXX: This is very very ugly and I hope I won't have to ever add a new\n // receipt type here again. IMHO this should be done by the server in\n // some more intelligent manner or the client should just use timestamps\n\n const timelineSet = this.getUnfilteredTimelineSet();\n const publicReadReceipt = this.getReadReceiptForUserId(userId, ignoreSynthesized, ReceiptType.Read);\n const privateReadReceipt = this.getReadReceiptForUserId(userId, ignoreSynthesized, ReceiptType.ReadPrivate);\n\n // If we have both, compare them\n let comparison: number | null | undefined;\n if (publicReadReceipt?.eventId && privateReadReceipt?.eventId) {\n comparison = timelineSet.compareEventOrdering(publicReadReceipt?.eventId, privateReadReceipt?.eventId);\n }\n\n // If we didn't get a comparison try to compare the ts of the receipts\n if (!comparison && publicReadReceipt?.data?.ts && privateReadReceipt?.data?.ts) {\n comparison = publicReadReceipt?.data?.ts - privateReadReceipt?.data?.ts;\n }\n\n // The public receipt is more likely to drift out of date so the private\n // one has precedence\n if (!comparison) return privateReadReceipt?.eventId ?? publicReadReceipt?.eventId ?? null;\n\n // If public read receipt is older, return the private one\n return (comparison < 0 ? privateReadReceipt?.eventId : publicReadReceipt?.eventId) ?? null;\n }\n\n public addReceiptToStructure(\n eventId: string,\n receiptType: ReceiptType,\n userId: string,\n receipt: Receipt,\n synthetic: boolean,\n ): void {\n const receiptTypesMap = this.receipts.getOrCreate(receiptType);\n let pair = receiptTypesMap.get(userId);\n\n if (!pair) {\n pair = [null, null];\n receiptTypesMap.set(userId, pair);\n }\n\n let existingReceipt = pair[ReceiptPairRealIndex];\n if (synthetic) {\n existingReceipt = pair[ReceiptPairSyntheticIndex] ?? pair[ReceiptPairRealIndex];\n }\n\n if (existingReceipt) {\n // we only want to add this receipt if we think it is later than the one we already have.\n // This is managed server-side, but because we synthesize RRs locally we have to do it here too.\n const ordering = this.getUnfilteredTimelineSet().compareEventOrdering(existingReceipt.eventId, eventId);\n if (ordering !== null && ordering >= 0) {\n return;\n }\n }\n\n const wrappedReceipt: WrappedReceipt = {\n eventId,\n data: receipt,\n };\n\n const realReceipt = synthetic ? pair[ReceiptPairRealIndex] : wrappedReceipt;\n const syntheticReceipt = synthetic ? wrappedReceipt : pair[ReceiptPairSyntheticIndex];\n\n let ordering: number | null = null;\n if (realReceipt && syntheticReceipt) {\n ordering = this.getUnfilteredTimelineSet().compareEventOrdering(\n realReceipt.eventId,\n syntheticReceipt.eventId,\n );\n }\n\n const preferSynthetic = ordering === null || ordering < 0;\n\n // we don't bother caching just real receipts by event ID as there's nothing that would read it.\n // Take the current cached receipt before we overwrite the pair elements.\n const cachedReceipt = pair[ReceiptPairSyntheticIndex] ?? pair[ReceiptPairRealIndex];\n\n if (synthetic && preferSynthetic) {\n pair[ReceiptPairSyntheticIndex] = wrappedReceipt;\n } else if (!synthetic) {\n pair[ReceiptPairRealIndex] = wrappedReceipt;\n\n if (!preferSynthetic) {\n pair[ReceiptPairSyntheticIndex] = null;\n }\n }\n\n const newCachedReceipt = pair[ReceiptPairSyntheticIndex] ?? pair[ReceiptPairRealIndex];\n if (cachedReceipt === newCachedReceipt) return;\n\n // clean up any previous cache entry\n if (cachedReceipt && this.receiptCacheByEventId.get(cachedReceipt.eventId)) {\n const previousEventId = cachedReceipt.eventId;\n // Remove the receipt we're about to clobber out of existence from the cache\n this.receiptCacheByEventId.set(\n previousEventId,\n this.receiptCacheByEventId.get(previousEventId)!.filter((r) => {\n return r.type !== receiptType || r.userId !== userId;\n }),\n );\n\n if (this.receiptCacheByEventId.get(previousEventId)!.length < 1) {\n this.receiptCacheByEventId.delete(previousEventId); // clean up the cache keys\n }\n }\n\n // cache the new one\n if (!this.receiptCacheByEventId.get(eventId)) {\n this.receiptCacheByEventId.set(eventId, []);\n }\n this.receiptCacheByEventId.get(eventId)!.push({\n userId: userId,\n type: receiptType as ReceiptType,\n data: receipt,\n });\n }\n\n /**\n * Get a list of receipts for the given event.\n * @param event - the event to get receipts for\n * @returns A list of receipts with a userId, type and data keys or\n * an empty list.\n */\n public getReceiptsForEvent(event: MatrixEvent): CachedReceipt[] {\n return this.receiptCacheByEventId.get(event.getId()!) || [];\n }\n\n public abstract addReceipt(event: MatrixEvent, synthetic: boolean): void;\n\n public abstract setUnread(type: NotificationCountType, count: number): void;\n\n /**\n * This issue should also be addressed on synapse's side and is tracked as part\n * of https://github.com/matrix-org/synapse/issues/14837\n *\n * Retrieves the read receipt for the logged in user and checks if it matches\n * the last event in the room and whether that event originated from the logged\n * in user.\n * Under those conditions we can consider the context as read. This is useful\n * because we never send read receipts against our own events\n * @param userId - the logged in user\n */\n public fixupNotifications(userId: string): void {\n const receipt = this.getReadReceiptForUserId(userId, false);\n\n const lastEvent = this.timeline[this.timeline.length - 1];\n if (lastEvent && receipt?.eventId === lastEvent.getId() && userId === lastEvent.getSender()) {\n this.setUnread(NotificationCountType.Total, 0);\n this.setUnread(NotificationCountType.Highlight, 0);\n }\n }\n\n /**\n * Add a temporary local-echo receipt to the room to reflect in the\n * client the fact that we've sent one.\n * @param userId - The user ID if the receipt sender\n * @param e - The event that is to be acknowledged\n * @param receiptType - The type of receipt\n */\n public addLocalEchoReceipt(userId: string, e: MatrixEvent, receiptType: ReceiptType): void {\n this.addReceipt(synthesizeReceipt(userId, e, receiptType), true);\n }\n\n /**\n * Get a list of user IDs who have read up to the given event.\n * @param event - the event to get read receipts for.\n * @returns A list of user IDs.\n */\n public getUsersReadUpTo(event: MatrixEvent): string[] {\n return this.getReceiptsForEvent(event)\n .filter(function (receipt) {\n return utils.isSupportedReceiptType(receipt.type);\n })\n .map(function (receipt) {\n return receipt.userId;\n });\n }\n\n /**\n * Determines if the given user has read a particular event ID with the known\n * history of the room. This is not a definitive check as it relies only on\n * what is available to the room at the time of execution.\n * @param userId - The user ID to check the read state of.\n * @param eventId - The event ID to check if the user read.\n * @returns True if the user has read the event, false otherwise.\n */\n public hasUserReadEvent(userId: string, eventId: string): boolean {\n const readUpToId = this.getEventReadUpTo(userId, false);\n if (readUpToId === eventId) return true;\n\n if (\n this.timeline?.length &&\n this.timeline[this.timeline.length - 1].getSender() &&\n this.timeline[this.timeline.length - 1].getSender() === userId\n ) {\n // It doesn't matter where the event is in the timeline, the user has read\n // it because they've sent the latest event.\n return true;\n }\n\n for (let i = this.timeline?.length - 1; i >= 0; --i) {\n const ev = this.timeline[i];\n\n // If we encounter the target event first, the user hasn't read it\n // however if we encounter the readUpToId first then the user has read\n // it. These rules apply because we're iterating bottom-up.\n if (ev.getId() === eventId) return false;\n if (ev.getId() === readUpToId) return true;\n }\n\n // We don't know if the user has read it, so assume not.\n return false;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts deleted file mode 100644 index 1b1cbcc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { Relations, RelationsEvent, EventHandlerMap } from "./relations"; -import { MatrixEvent } from "./event"; -import { Listener } from "./typed-event-emitter"; -export declare class RelatedRelations { - private relations; - constructor(relations: Relations[]); - getRelations(): MatrixEvent[]; - on(ev: T, fn: Listener): void; - off(ev: T, fn: Listener): void; -} -//# sourceMappingURL=related-relations.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts.map deleted file mode 100644 index 969534e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"related-relations.d.ts","sourceRoot":"","sources":["../../src/models/related-relations.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEjD,qBAAa,gBAAgB;IACzB,OAAO,CAAC,SAAS,CAAc;gBAEZ,SAAS,EAAE,SAAS,EAAE;IAIlC,YAAY,IAAI,WAAW,EAAE;IAI7B,EAAE,CAAC,CAAC,SAAS,cAAc,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,QAAQ,CAAC,cAAc,EAAE,eAAe,EAAE,CAAC,CAAC,GAAG,IAAI;IAI3F,GAAG,CAAC,CAAC,SAAS,cAAc,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,QAAQ,CAAC,cAAc,EAAE,eAAe,EAAE,CAAC,CAAC,GAAG,IAAI;CAGtG"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js deleted file mode 100644 index ac0be44..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js +++ /dev/null @@ -1,41 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RelatedRelations = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class RelatedRelations { - constructor(relations) { - (0, _defineProperty2.default)(this, "relations", void 0); - this.relations = relations.filter(r => !!r); - } - getRelations() { - return this.relations.reduce((c, p) => [...c, ...p.getRelations()], []); - } - on(ev, fn) { - this.relations.forEach(r => r.on(ev, fn)); - } - off(ev, fn) { - this.relations.forEach(r => r.off(ev, fn)); - } -} -exports.RelatedRelations = RelatedRelations; -//# sourceMappingURL=related-relations.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js.map deleted file mode 100644 index 5fb7a0c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/related-relations.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"related-relations.js","names":["RelatedRelations","constructor","relations","_defineProperty2","default","filter","r","getRelations","reduce","c","p","on","ev","fn","forEach","off","exports"],"sources":["../../src/models/related-relations.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Relations, RelationsEvent, EventHandlerMap } from \"./relations\";\nimport { MatrixEvent } from \"./event\";\nimport { Listener } from \"./typed-event-emitter\";\n\nexport class RelatedRelations {\n private relations: Relations[];\n\n public constructor(relations: Relations[]) {\n this.relations = relations.filter((r) => !!r);\n }\n\n public getRelations(): MatrixEvent[] {\n return this.relations.reduce((c, p) => [...c, ...p.getRelations()], []);\n }\n\n public on(ev: T, fn: Listener): void {\n this.relations.forEach((r) => r.on(ev, fn));\n }\n\n public off(ev: T, fn: Listener): void {\n this.relations.forEach((r) => r.off(ev, fn));\n }\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAMO,MAAMA,gBAAgB,CAAC;EAGnBC,WAAWA,CAACC,SAAsB,EAAE;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IACvC,IAAI,CAACF,SAAS,GAAGA,SAAS,CAACG,MAAM,CAAEC,CAAC,IAAK,CAAC,CAACA,CAAC,CAAC;EACjD;EAEOC,YAAYA,CAAA,EAAkB;IACjC,OAAO,IAAI,CAACL,SAAS,CAACM,MAAM,CAAgB,CAACC,CAAC,EAAEC,CAAC,KAAK,CAAC,GAAGD,CAAC,EAAE,GAAGC,CAAC,CAACH,YAAY,EAAE,CAAC,EAAE,EAAE,CAAC;EAC1F;EAEOI,EAAEA,CAA2BC,EAAK,EAAEC,EAAgD,EAAQ;IAC/F,IAAI,CAACX,SAAS,CAACY,OAAO,CAAER,CAAC,IAAKA,CAAC,CAACK,EAAE,CAACC,EAAE,EAAEC,EAAE,CAAC,CAAC;EAC/C;EAEOE,GAAGA,CAA2BH,EAAK,EAAEC,EAAgD,EAAQ;IAChG,IAAI,CAACX,SAAS,CAACY,OAAO,CAAER,CAAC,IAAKA,CAAC,CAACS,GAAG,CAACH,EAAE,EAAEC,EAAE,CAAC,CAAC;EAChD;AACJ;AAACG,OAAA,CAAAhB,gBAAA,GAAAA,gBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts deleted file mode 100644 index 2b2c7ad..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts +++ /dev/null @@ -1,44 +0,0 @@ -import { Relations } from "./relations"; -import { EventType, RelationType } from "../@types/event"; -import { MatrixEvent } from "./event"; -import { EventTimelineSet } from "./event-timeline-set"; -import { MatrixClient } from "../client"; -import { Room } from "./room"; -export declare class RelationsContainer { - private readonly client; - private readonly room?; - private relations; - constructor(client: MatrixClient, room?: Room | undefined); - /** - * Get a collection of child events to a given event in this timeline set. - * - * @param eventId - The ID of the event that you'd like to access child events for. - * For example, with annotations, this would be the ID of the event being annotated. - * @param relationType - The type of relationship involved, such as "m.annotation", "m.reference", "m.replace", etc. - * @param eventType - The relation event's type, such as "m.reaction", etc. - * @throws If `eventId, relationType or eventType` - * are not valid. - * - * @returns - * A container for relation events or undefined if there are no relation events for - * the relationType. - */ - getChildEventsForEvent(eventId: string, relationType: RelationType | string, eventType: EventType | string): Relations | undefined; - getAllChildEventsForEvent(parentEventId: string): MatrixEvent[]; - /** - * Set an event as the target event if any Relations exist for it already. - * Child events can point to other child events as their parent, so this method may be - * called for events which are also logically child events. - * - * @param event - The event to check as relation target. - */ - aggregateParentEvent(event: MatrixEvent): void; - /** - * Add relation events to the relevant relation collection. - * - * @param event - The new child event to be aggregated. - * @param timelineSet - The event timeline set within which to search for the related event if any. - */ - aggregateChildEvent(event: MatrixEvent, timelineSet?: EventTimelineSet): void; -} -//# sourceMappingURL=relations-container.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts.map deleted file mode 100644 index ebb8110..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"relations-container.d.ts","sourceRoot":"","sources":["../../src/models/relations-container.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAe,WAAW,EAAoB,MAAM,SAAS,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,qBAAa,kBAAkB;IAKR,OAAO,CAAC,QAAQ,CAAC,MAAM;IAAgB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;IAFhF,OAAO,CAAC,SAAS,CAAqF;gBAElE,MAAM,EAAE,YAAY,EAAmB,IAAI,CAAC,kBAAM;IAEtF;;;;;;;;;;;;;OAaG;IACI,sBAAsB,CACzB,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,YAAY,GAAG,MAAM,EACnC,SAAS,EAAE,SAAS,GAAG,MAAM,GAC9B,SAAS,GAAG,SAAS;IAIjB,yBAAyB,CAAC,aAAa,EAAE,MAAM,GAAG,WAAW,EAAE;IAYtE;;;;;;OAMG;IACI,oBAAoB,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI;IAWrD;;;;;OAKG;IACI,mBAAmB,CAAC,KAAK,EAAE,WAAW,EAAE,WAAW,CAAC,EAAE,gBAAgB,GAAG,IAAI;CAyDvF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js deleted file mode 100644 index ef516e3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js +++ /dev/null @@ -1,141 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RelationsContainer = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _relations = require("./relations"); -var _event = require("./event"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class RelationsContainer { - // A tree of objects to access a set of related children for an event, as in: - // this.relations.get(parentEventId).get(relationType).get(relationEventType) - - constructor(client, room) { - this.client = client; - this.room = room; - (0, _defineProperty2.default)(this, "relations", new Map()); - } - - /** - * Get a collection of child events to a given event in this timeline set. - * - * @param eventId - The ID of the event that you'd like to access child events for. - * For example, with annotations, this would be the ID of the event being annotated. - * @param relationType - The type of relationship involved, such as "m.annotation", "m.reference", "m.replace", etc. - * @param eventType - The relation event's type, such as "m.reaction", etc. - * @throws If `eventId, relationType or eventType` - * are not valid. - * - * @returns - * A container for relation events or undefined if there are no relation events for - * the relationType. - */ - getChildEventsForEvent(eventId, relationType, eventType) { - var _this$relations$get, _this$relations$get$g; - return (_this$relations$get = this.relations.get(eventId)) === null || _this$relations$get === void 0 ? void 0 : (_this$relations$get$g = _this$relations$get.get(relationType)) === null || _this$relations$get$g === void 0 ? void 0 : _this$relations$get$g.get(eventType); - } - getAllChildEventsForEvent(parentEventId) { - var _this$relations$get2; - const relationsForEvent = (_this$relations$get2 = this.relations.get(parentEventId)) !== null && _this$relations$get2 !== void 0 ? _this$relations$get2 : new Map(); - const events = []; - for (const relationsRecord of relationsForEvent.values()) { - for (const relations of relationsRecord.values()) { - events.push(...relations.getRelations()); - } - } - return events; - } - - /** - * Set an event as the target event if any Relations exist for it already. - * Child events can point to other child events as their parent, so this method may be - * called for events which are also logically child events. - * - * @param event - The event to check as relation target. - */ - aggregateParentEvent(event) { - const relationsForEvent = this.relations.get(event.getId()); - if (!relationsForEvent) return; - for (const relationsWithRelType of relationsForEvent.values()) { - for (const relationsWithEventType of relationsWithRelType.values()) { - relationsWithEventType.setTargetEvent(event); - } - } - } - - /** - * Add relation events to the relevant relation collection. - * - * @param event - The new child event to be aggregated. - * @param timelineSet - The event timeline set within which to search for the related event if any. - */ - aggregateChildEvent(event, timelineSet) { - if (event.isRedacted() || event.status === _event.EventStatus.CANCELLED) { - return; - } - const relation = event.getRelation(); - if (!relation) return; - const onEventDecrypted = () => { - if (event.isDecryptionFailure()) { - // This could for example happen if the encryption keys are not yet available. - // The event may still be decrypted later. Register the listener again. - event.once(_event.MatrixEventEvent.Decrypted, onEventDecrypted); - return; - } - this.aggregateChildEvent(event, timelineSet); - }; - - // If the event is currently encrypted, wait until it has been decrypted. - if (event.isBeingDecrypted() || event.shouldAttemptDecryption()) { - event.once(_event.MatrixEventEvent.Decrypted, onEventDecrypted); - return; - } - const { - event_id: relatesToEventId, - rel_type: relationType - } = relation; - const eventType = event.getType(); - let relationsForEvent = this.relations.get(relatesToEventId); - if (!relationsForEvent) { - relationsForEvent = new Map(); - this.relations.set(relatesToEventId, relationsForEvent); - } - let relationsWithRelType = relationsForEvent.get(relationType); - if (!relationsWithRelType) { - relationsWithRelType = new Map(); - relationsForEvent.set(relationType, relationsWithRelType); - } - let relationsWithEventType = relationsWithRelType.get(eventType); - if (!relationsWithEventType) { - var _this$room, _ref, _timelineSet$findEven; - relationsWithEventType = new _relations.Relations(relationType, eventType, this.client); - relationsWithRelType.set(eventType, relationsWithEventType); - const room = (_this$room = this.room) !== null && _this$room !== void 0 ? _this$room : timelineSet === null || timelineSet === void 0 ? void 0 : timelineSet.room; - const relatesToEvent = (_ref = (_timelineSet$findEven = timelineSet === null || timelineSet === void 0 ? void 0 : timelineSet.findEventById(relatesToEventId)) !== null && _timelineSet$findEven !== void 0 ? _timelineSet$findEven : room === null || room === void 0 ? void 0 : room.findEventById(relatesToEventId)) !== null && _ref !== void 0 ? _ref : room === null || room === void 0 ? void 0 : room.getPendingEvent(relatesToEventId); - if (relatesToEvent) { - relationsWithEventType.setTargetEvent(relatesToEvent); - } - } - relationsWithEventType.addEvent(event); - } -} -exports.RelationsContainer = RelationsContainer; -//# sourceMappingURL=relations-container.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js.map deleted file mode 100644 index b01767c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations-container.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"relations-container.js","names":["_relations","require","_event","RelationsContainer","constructor","client","room","_defineProperty2","default","Map","getChildEventsForEvent","eventId","relationType","eventType","_this$relations$get","_this$relations$get$g","relations","get","getAllChildEventsForEvent","parentEventId","_this$relations$get2","relationsForEvent","events","relationsRecord","values","push","getRelations","aggregateParentEvent","event","getId","relationsWithRelType","relationsWithEventType","setTargetEvent","aggregateChildEvent","timelineSet","isRedacted","status","EventStatus","CANCELLED","relation","getRelation","onEventDecrypted","isDecryptionFailure","once","MatrixEventEvent","Decrypted","isBeingDecrypted","shouldAttemptDecryption","event_id","relatesToEventId","rel_type","getType","set","_this$room","_ref","_timelineSet$findEven","Relations","relatesToEvent","findEventById","getPendingEvent","addEvent","exports"],"sources":["../../src/models/relations-container.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Relations } from \"./relations\";\nimport { EventType, RelationType } from \"../@types/event\";\nimport { EventStatus, MatrixEvent, MatrixEventEvent } from \"./event\";\nimport { EventTimelineSet } from \"./event-timeline-set\";\nimport { MatrixClient } from \"../client\";\nimport { Room } from \"./room\";\n\nexport class RelationsContainer {\n // A tree of objects to access a set of related children for an event, as in:\n // this.relations.get(parentEventId).get(relationType).get(relationEventType)\n private relations = new Map>>();\n\n public constructor(private readonly client: MatrixClient, private readonly room?: Room) {}\n\n /**\n * Get a collection of child events to a given event in this timeline set.\n *\n * @param eventId - The ID of the event that you'd like to access child events for.\n * For example, with annotations, this would be the ID of the event being annotated.\n * @param relationType - The type of relationship involved, such as \"m.annotation\", \"m.reference\", \"m.replace\", etc.\n * @param eventType - The relation event's type, such as \"m.reaction\", etc.\n * @throws If `eventId, relationType or eventType`\n * are not valid.\n *\n * @returns\n * A container for relation events or undefined if there are no relation events for\n * the relationType.\n */\n public getChildEventsForEvent(\n eventId: string,\n relationType: RelationType | string,\n eventType: EventType | string,\n ): Relations | undefined {\n return this.relations.get(eventId)?.get(relationType)?.get(eventType);\n }\n\n public getAllChildEventsForEvent(parentEventId: string): MatrixEvent[] {\n const relationsForEvent =\n this.relations.get(parentEventId) ?? new Map>();\n const events: MatrixEvent[] = [];\n for (const relationsRecord of relationsForEvent.values()) {\n for (const relations of relationsRecord.values()) {\n events.push(...relations.getRelations());\n }\n }\n return events;\n }\n\n /**\n * Set an event as the target event if any Relations exist for it already.\n * Child events can point to other child events as their parent, so this method may be\n * called for events which are also logically child events.\n *\n * @param event - The event to check as relation target.\n */\n public aggregateParentEvent(event: MatrixEvent): void {\n const relationsForEvent = this.relations.get(event.getId()!);\n if (!relationsForEvent) return;\n\n for (const relationsWithRelType of relationsForEvent.values()) {\n for (const relationsWithEventType of relationsWithRelType.values()) {\n relationsWithEventType.setTargetEvent(event);\n }\n }\n }\n\n /**\n * Add relation events to the relevant relation collection.\n *\n * @param event - The new child event to be aggregated.\n * @param timelineSet - The event timeline set within which to search for the related event if any.\n */\n public aggregateChildEvent(event: MatrixEvent, timelineSet?: EventTimelineSet): void {\n if (event.isRedacted() || event.status === EventStatus.CANCELLED) {\n return;\n }\n\n const relation = event.getRelation();\n if (!relation) return;\n\n const onEventDecrypted = (): void => {\n if (event.isDecryptionFailure()) {\n // This could for example happen if the encryption keys are not yet available.\n // The event may still be decrypted later. Register the listener again.\n event.once(MatrixEventEvent.Decrypted, onEventDecrypted);\n return;\n }\n\n this.aggregateChildEvent(event, timelineSet);\n };\n\n // If the event is currently encrypted, wait until it has been decrypted.\n if (event.isBeingDecrypted() || event.shouldAttemptDecryption()) {\n event.once(MatrixEventEvent.Decrypted, onEventDecrypted);\n return;\n }\n\n const { event_id: relatesToEventId, rel_type: relationType } = relation;\n const eventType = event.getType();\n\n let relationsForEvent = this.relations.get(relatesToEventId!);\n if (!relationsForEvent) {\n relationsForEvent = new Map>();\n this.relations.set(relatesToEventId!, relationsForEvent);\n }\n\n let relationsWithRelType = relationsForEvent.get(relationType!);\n if (!relationsWithRelType) {\n relationsWithRelType = new Map();\n relationsForEvent.set(relationType!, relationsWithRelType);\n }\n\n let relationsWithEventType = relationsWithRelType.get(eventType);\n if (!relationsWithEventType) {\n relationsWithEventType = new Relations(relationType!, eventType, this.client);\n relationsWithRelType.set(eventType, relationsWithEventType);\n\n const room = this.room ?? timelineSet?.room;\n const relatesToEvent =\n timelineSet?.findEventById(relatesToEventId!) ??\n room?.findEventById(relatesToEventId!) ??\n room?.getPendingEvent(relatesToEventId!);\n if (relatesToEvent) {\n relationsWithEventType.setTargetEvent(relatesToEvent);\n }\n }\n\n relationsWithEventType.addEvent(event);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts deleted file mode 100644 index e99d3b4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts +++ /dev/null @@ -1,114 +0,0 @@ -import { MatrixEvent } from "./event"; -import { RelationType } from "../@types/event"; -import { TypedEventEmitter } from "./typed-event-emitter"; -import { MatrixClient } from "../client"; -import { Room } from "./room"; -export declare enum RelationsEvent { - Add = "Relations.add", - Remove = "Relations.remove", - Redaction = "Relations.redaction" -} -export type EventHandlerMap = { - [RelationsEvent.Add]: (event: MatrixEvent) => void; - [RelationsEvent.Remove]: (event: MatrixEvent) => void; - [RelationsEvent.Redaction]: (event: MatrixEvent) => void; -}; -/** - * A container for relation events that supports easy access to common ways of - * aggregating such events. Each instance holds events that of a single relation - * type and event type. All of the events also relate to the same original event. - * - * The typical way to get one of these containers is via - * EventTimelineSet#getRelationsForEvent. - */ -export declare class Relations extends TypedEventEmitter { - readonly relationType: RelationType | string; - readonly eventType: string; - readonly altEventTypes?: string[] | undefined; - private relationEventIds; - private relations; - private annotationsByKey; - private annotationsBySender; - private sortedAnnotationsByKey; - private targetEvent; - private creationEmitted; - private readonly client; - /** - * @param relationType - The type of relation involved, such as "m.annotation", "m.reference", "m.replace", etc. - * @param eventType - The relation event's type, such as "m.reaction", etc. - * @param client - The client which created this instance. For backwards compatibility also accepts a Room. - * @param altEventTypes - alt event types for relation events, for example to support unstable prefixed event types - */ - constructor(relationType: RelationType | string, eventType: string, client: MatrixClient | Room, altEventTypes?: string[] | undefined); - /** - * Add relation events to this collection. - * - * @param event - The new relation event to be added. - */ - addEvent(event: MatrixEvent): Promise; - /** - * Remove relation event from this collection. - * - * @param event - The relation event to remove. - */ - removeEvent(event: MatrixEvent): Promise; - /** - * Listens for event status changes to remove cancelled events. - * - * @param event - The event whose status has changed - * @param status - The new status - */ - private onEventStatus; - /** - * Get all relation events in this collection. - * - * These are currently in the order of insertion to this collection, which - * won't match timeline order in the case of scrollback. - * TODO: Tweak `addEvent` to insert correctly for scrollback. - * - * Relation events in insertion order. - */ - getRelations(): MatrixEvent[]; - private addAnnotationToAggregation; - private removeAnnotationFromAggregation; - /** - * For relations that have been redacted, we want to remove them from - * aggregation data sets and emit an update event. - * - * To do so, we listen for `Event.beforeRedaction`, which happens: - * - after the server accepted the redaction and remote echoed back to us - * - before the original event has been marked redacted in the client - * - * @param redactedEvent - The original relation event that is about to be redacted. - */ - private onBeforeRedaction; - /** - * Get all events in this collection grouped by key and sorted by descending - * event count in each group. - * - * This is currently only supported for the annotation relation type. - * - * An array of [key, events] pairs sorted by descending event count. - * The events are stored in a Set (which preserves insertion order). - */ - getSortedAnnotationsByKey(): [string, Set][] | null; - /** - * Get all events in this collection grouped by sender. - * - * This is currently only supported for the annotation relation type. - * - * An object with each relation sender as a key and the matching Set of - * events for that sender as a value. - */ - getAnnotationsBySender(): Record> | null; - /** - * Returns the most recent (and allowed) m.replace relation, if any. - * - * This is currently only supported for the m.replace relation type, - * once the target event is known, see `addEvent`. - */ - getLastReplacement(): Promise; - setTargetEvent(event: MatrixEvent): Promise; - private maybeEmitCreated; -} -//# sourceMappingURL=relations.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts.map deleted file mode 100644 index 356f7c0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"relations.d.ts","sourceRoot":"","sources":["../../src/models/relations.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAoC,WAAW,EAAoB,MAAM,SAAS,CAAC;AAE1F,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,oBAAY,cAAc;IACtB,GAAG,kBAAkB;IACrB,MAAM,qBAAqB;IAC3B,SAAS,wBAAwB;CACpC;AAED,MAAM,MAAM,eAAe,GAAG;IAC1B,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,IAAI,CAAC;IACnD,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,IAAI,CAAC;IACtD,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,IAAI,CAAC;CAC5D,CAAC;AAKF;;;;;;;GAOG;AACH,qBAAa,SAAU,SAAQ,iBAAiB,CAAC,cAAc,EAAE,eAAe,CAAC;aAiBzD,YAAY,EAAE,YAAY,GAAG,MAAM;aACnC,SAAS,EAAE,MAAM;aAEjB,aAAa,CAAC;IAnBlC,OAAO,CAAC,gBAAgB,CAAqB;IAC7C,OAAO,CAAC,SAAS,CAA0B;IAC3C,OAAO,CAAC,gBAAgB,CAAwC;IAChE,OAAO,CAAC,mBAAmB,CAAwC;IACnE,OAAO,CAAC,sBAAsB,CAAoC;IAClE,OAAO,CAAC,WAAW,CAA4B;IAC/C,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAe;IAEtC;;;;;OAKG;gBAEiB,YAAY,EAAE,YAAY,GAAG,MAAM,EACnC,SAAS,EAAE,MAAM,EACjC,MAAM,EAAE,YAAY,GAAG,IAAI,EACX,aAAa,CAAC,sBAAU;IAM5C;;;;OAIG;IACU,QAAQ,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IA0CxD;;;;OAIG;IACU,WAAW,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAiB3D;;;;;OAKG;IACH,OAAO,CAAC,aAAa,CAYnB;IAEF;;;;;;;;OAQG;IACI,YAAY,IAAI,WAAW,EAAE;IAIpC,OAAO,CAAC,0BAA0B;IA2BlC,OAAO,CAAC,+BAA+B;IAuBvC;;;;;;;;;OASG;IACH,OAAO,CAAC,iBAAiB,CAkBvB;IAEF;;;;;;;;OAQG;IACI,yBAAyB,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,EAAE,GAAG,IAAI;IASvE;;;;;;;OAOG;IACI,sBAAsB,IAAI,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,GAAG,IAAI;IASxE;;;;;OAKG;IACU,kBAAkB,IAAI,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IA0CjD,cAAc,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAkB9D,OAAO,CAAC,gBAAgB;CAY3B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js deleted file mode 100644 index 238d6c1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js +++ /dev/null @@ -1,343 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RelationsEvent = exports.Relations = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _event = require("./event"); -var _logger = require("../logger"); -var _event2 = require("../@types/event"); -var _typedEventEmitter = require("./typed-event-emitter"); -var _room = require("./room"); -/* -Copyright 2019, 2021, 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let RelationsEvent; -exports.RelationsEvent = RelationsEvent; -(function (RelationsEvent) { - RelationsEvent["Add"] = "Relations.add"; - RelationsEvent["Remove"] = "Relations.remove"; - RelationsEvent["Redaction"] = "Relations.redaction"; -})(RelationsEvent || (exports.RelationsEvent = RelationsEvent = {})); -const matchesEventType = (eventType, targetEventType, altTargetEventTypes = []) => [targetEventType, ...altTargetEventTypes].includes(eventType); - -/** - * A container for relation events that supports easy access to common ways of - * aggregating such events. Each instance holds events that of a single relation - * type and event type. All of the events also relate to the same original event. - * - * The typical way to get one of these containers is via - * EventTimelineSet#getRelationsForEvent. - */ -class Relations extends _typedEventEmitter.TypedEventEmitter { - /** - * @param relationType - The type of relation involved, such as "m.annotation", "m.reference", "m.replace", etc. - * @param eventType - The relation event's type, such as "m.reaction", etc. - * @param client - The client which created this instance. For backwards compatibility also accepts a Room. - * @param altEventTypes - alt event types for relation events, for example to support unstable prefixed event types - */ - constructor(relationType, eventType, client, altEventTypes) { - super(); - this.relationType = relationType; - this.eventType = eventType; - this.altEventTypes = altEventTypes; - (0, _defineProperty2.default)(this, "relationEventIds", new Set()); - (0, _defineProperty2.default)(this, "relations", new Set()); - (0, _defineProperty2.default)(this, "annotationsByKey", {}); - (0, _defineProperty2.default)(this, "annotationsBySender", {}); - (0, _defineProperty2.default)(this, "sortedAnnotationsByKey", []); - (0, _defineProperty2.default)(this, "targetEvent", null); - (0, _defineProperty2.default)(this, "creationEmitted", false); - (0, _defineProperty2.default)(this, "client", void 0); - (0, _defineProperty2.default)(this, "onEventStatus", (event, status) => { - if (!event.isSending()) { - // Sending is done, so we don't need to listen anymore - event.removeListener(_event.MatrixEventEvent.Status, this.onEventStatus); - return; - } - if (status !== _event.EventStatus.CANCELLED) { - return; - } - // Event was cancelled, remove from the collection - event.removeListener(_event.MatrixEventEvent.Status, this.onEventStatus); - this.removeEvent(event); - }); - (0, _defineProperty2.default)(this, "onBeforeRedaction", async redactedEvent => { - if (!this.relations.has(redactedEvent)) { - return; - } - this.relations.delete(redactedEvent); - if (this.relationType === _event2.RelationType.Annotation) { - // Remove the redacted annotation from aggregation by key - this.removeAnnotationFromAggregation(redactedEvent); - } else if (this.relationType === _event2.RelationType.Replace && this.targetEvent && !this.targetEvent.isState()) { - const lastReplacement = await this.getLastReplacement(); - this.targetEvent.makeReplaced(lastReplacement); - } - redactedEvent.removeListener(_event.MatrixEventEvent.BeforeRedaction, this.onBeforeRedaction); - this.emit(RelationsEvent.Redaction, redactedEvent); - }); - this.client = client instanceof _room.Room ? client.client : client; - } - - /** - * Add relation events to this collection. - * - * @param event - The new relation event to be added. - */ - async addEvent(event) { - if (this.relationEventIds.has(event.getId())) { - return; - } - const relation = event.getRelation(); - if (!relation) { - _logger.logger.error("Event must have relation info"); - return; - } - const relationType = relation.rel_type; - const eventType = event.getType(); - if (this.relationType !== relationType || !matchesEventType(eventType, this.eventType, this.altEventTypes)) { - _logger.logger.error("Event relation info doesn't match this container"); - return; - } - - // If the event is in the process of being sent, listen for cancellation - // so we can remove the event from the collection. - if (event.isSending()) { - event.on(_event.MatrixEventEvent.Status, this.onEventStatus); - } - this.relations.add(event); - this.relationEventIds.add(event.getId()); - if (this.relationType === _event2.RelationType.Annotation) { - this.addAnnotationToAggregation(event); - } else if (this.relationType === _event2.RelationType.Replace && this.targetEvent && !this.targetEvent.isState()) { - const lastReplacement = await this.getLastReplacement(); - this.targetEvent.makeReplaced(lastReplacement); - } - event.on(_event.MatrixEventEvent.BeforeRedaction, this.onBeforeRedaction); - this.emit(RelationsEvent.Add, event); - this.maybeEmitCreated(); - } - - /** - * Remove relation event from this collection. - * - * @param event - The relation event to remove. - */ - async removeEvent(event) { - if (!this.relations.has(event)) { - return; - } - this.relations.delete(event); - if (this.relationType === _event2.RelationType.Annotation) { - this.removeAnnotationFromAggregation(event); - } else if (this.relationType === _event2.RelationType.Replace && this.targetEvent && !this.targetEvent.isState()) { - const lastReplacement = await this.getLastReplacement(); - this.targetEvent.makeReplaced(lastReplacement); - } - this.emit(RelationsEvent.Remove, event); - } - - /** - * Listens for event status changes to remove cancelled events. - * - * @param event - The event whose status has changed - * @param status - The new status - */ - - /** - * Get all relation events in this collection. - * - * These are currently in the order of insertion to this collection, which - * won't match timeline order in the case of scrollback. - * TODO: Tweak `addEvent` to insert correctly for scrollback. - * - * Relation events in insertion order. - */ - getRelations() { - return [...this.relations]; - } - addAnnotationToAggregation(event) { - var _event$getRelation; - const { - key - } = (_event$getRelation = event.getRelation()) !== null && _event$getRelation !== void 0 ? _event$getRelation : {}; - if (!key) return; - let eventsForKey = this.annotationsByKey[key]; - if (!eventsForKey) { - eventsForKey = this.annotationsByKey[key] = new Set(); - this.sortedAnnotationsByKey.push([key, eventsForKey]); - } - // Add the new event to the set for this key - eventsForKey.add(event); - // Re-sort the [key, events] pairs in descending order of event count - this.sortedAnnotationsByKey.sort((a, b) => { - const aEvents = a[1]; - const bEvents = b[1]; - return bEvents.size - aEvents.size; - }); - const sender = event.getSender(); - let eventsFromSender = this.annotationsBySender[sender]; - if (!eventsFromSender) { - eventsFromSender = this.annotationsBySender[sender] = new Set(); - } - // Add the new event to the set for this sender - eventsFromSender.add(event); - } - removeAnnotationFromAggregation(event) { - var _event$getRelation2; - const { - key - } = (_event$getRelation2 = event.getRelation()) !== null && _event$getRelation2 !== void 0 ? _event$getRelation2 : {}; - if (!key) return; - const eventsForKey = this.annotationsByKey[key]; - if (eventsForKey) { - eventsForKey.delete(event); - - // Re-sort the [key, events] pairs in descending order of event count - this.sortedAnnotationsByKey.sort((a, b) => { - const aEvents = a[1]; - const bEvents = b[1]; - return bEvents.size - aEvents.size; - }); - } - const sender = event.getSender(); - const eventsFromSender = this.annotationsBySender[sender]; - if (eventsFromSender) { - eventsFromSender.delete(event); - } - } - - /** - * For relations that have been redacted, we want to remove them from - * aggregation data sets and emit an update event. - * - * To do so, we listen for `Event.beforeRedaction`, which happens: - * - after the server accepted the redaction and remote echoed back to us - * - before the original event has been marked redacted in the client - * - * @param redactedEvent - The original relation event that is about to be redacted. - */ - - /** - * Get all events in this collection grouped by key and sorted by descending - * event count in each group. - * - * This is currently only supported for the annotation relation type. - * - * An array of [key, events] pairs sorted by descending event count. - * The events are stored in a Set (which preserves insertion order). - */ - getSortedAnnotationsByKey() { - if (this.relationType !== _event2.RelationType.Annotation) { - // Other relation types are not grouped currently. - return null; - } - return this.sortedAnnotationsByKey; - } - - /** - * Get all events in this collection grouped by sender. - * - * This is currently only supported for the annotation relation type. - * - * An object with each relation sender as a key and the matching Set of - * events for that sender as a value. - */ - getAnnotationsBySender() { - if (this.relationType !== _event2.RelationType.Annotation) { - // Other relation types are not grouped currently. - return null; - } - return this.annotationsBySender; - } - - /** - * Returns the most recent (and allowed) m.replace relation, if any. - * - * This is currently only supported for the m.replace relation type, - * once the target event is known, see `addEvent`. - */ - async getLastReplacement() { - if (this.relationType !== _event2.RelationType.Replace) { - // Aggregating on last only makes sense for this relation type - return null; - } - if (!this.targetEvent) { - // Don't know which replacements to accept yet. - // This method shouldn't be called before the original - // event is known anyway. - return null; - } - - // the all-knowning server tells us that the event at some point had - // this timestamp for its replacement, so any following replacement should definitely not be less - const replaceRelation = this.targetEvent.getServerAggregatedRelation(_event2.RelationType.Replace); - const minTs = replaceRelation === null || replaceRelation === void 0 ? void 0 : replaceRelation.origin_server_ts; - const lastReplacement = this.getRelations().reduce((last, event) => { - if (event.getSender() !== this.targetEvent.getSender()) { - return last; - } - if (minTs && minTs > event.getTs()) { - return last; - } - if (last && last.getTs() > event.getTs()) { - return last; - } - return event; - }, null); - if (lastReplacement !== null && lastReplacement !== void 0 && lastReplacement.shouldAttemptDecryption() && this.client.isCryptoEnabled()) { - await lastReplacement.attemptDecryption(this.client.crypto); - } else if (lastReplacement !== null && lastReplacement !== void 0 && lastReplacement.isBeingDecrypted()) { - await lastReplacement.getDecryptionPromise(); - } - return lastReplacement; - } - - /* - * @param targetEvent - the event the relations are related to. - */ - async setTargetEvent(event) { - if (this.targetEvent) { - return; - } - this.targetEvent = event; - if (this.relationType === _event2.RelationType.Replace && !this.targetEvent.isState()) { - const replacement = await this.getLastReplacement(); - // this is the initial update, so only call it if we already have something - // to not emit Event.replaced needlessly - if (replacement) { - this.targetEvent.makeReplaced(replacement); - } - } - this.maybeEmitCreated(); - } - maybeEmitCreated() { - if (this.creationEmitted) { - return; - } - // Only emit we're "created" once we have a target event instance _and_ - // at least one related event. - if (!this.targetEvent || !this.relations.size) { - return; - } - this.creationEmitted = true; - this.targetEvent.emit(_event.MatrixEventEvent.RelationsCreated, this.relationType, this.eventType); - } -} -exports.Relations = Relations; -//# sourceMappingURL=relations.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js.map deleted file mode 100644 index eb8ec46..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/relations.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"relations.js","names":["_event","require","_logger","_event2","_typedEventEmitter","_room","RelationsEvent","exports","matchesEventType","eventType","targetEventType","altTargetEventTypes","includes","Relations","TypedEventEmitter","constructor","relationType","client","altEventTypes","_defineProperty2","default","Set","event","status","isSending","removeListener","MatrixEventEvent","Status","onEventStatus","EventStatus","CANCELLED","removeEvent","redactedEvent","relations","has","delete","RelationType","Annotation","removeAnnotationFromAggregation","Replace","targetEvent","isState","lastReplacement","getLastReplacement","makeReplaced","BeforeRedaction","onBeforeRedaction","emit","Redaction","Room","addEvent","relationEventIds","getId","relation","getRelation","logger","error","rel_type","getType","on","add","addAnnotationToAggregation","Add","maybeEmitCreated","Remove","getRelations","_event$getRelation","key","eventsForKey","annotationsByKey","sortedAnnotationsByKey","push","sort","a","b","aEvents","bEvents","size","sender","getSender","eventsFromSender","annotationsBySender","_event$getRelation2","getSortedAnnotationsByKey","getAnnotationsBySender","replaceRelation","getServerAggregatedRelation","minTs","origin_server_ts","reduce","last","getTs","shouldAttemptDecryption","isCryptoEnabled","attemptDecryption","crypto","isBeingDecrypted","getDecryptionPromise","setTargetEvent","replacement","creationEmitted","RelationsCreated"],"sources":["../../src/models/relations.ts"],"sourcesContent":["/*\nCopyright 2019, 2021, 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EventStatus, IAggregatedRelation, MatrixEvent, MatrixEventEvent } from \"./event\";\nimport { logger } from \"../logger\";\nimport { RelationType } from \"../@types/event\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\nimport { MatrixClient } from \"../client\";\nimport { Room } from \"./room\";\n\nexport enum RelationsEvent {\n Add = \"Relations.add\",\n Remove = \"Relations.remove\",\n Redaction = \"Relations.redaction\",\n}\n\nexport type EventHandlerMap = {\n [RelationsEvent.Add]: (event: MatrixEvent) => void;\n [RelationsEvent.Remove]: (event: MatrixEvent) => void;\n [RelationsEvent.Redaction]: (event: MatrixEvent) => void;\n};\n\nconst matchesEventType = (eventType: string, targetEventType: string, altTargetEventTypes: string[] = []): boolean =>\n [targetEventType, ...altTargetEventTypes].includes(eventType);\n\n/**\n * A container for relation events that supports easy access to common ways of\n * aggregating such events. Each instance holds events that of a single relation\n * type and event type. All of the events also relate to the same original event.\n *\n * The typical way to get one of these containers is via\n * EventTimelineSet#getRelationsForEvent.\n */\nexport class Relations extends TypedEventEmitter {\n private relationEventIds = new Set();\n private relations = new Set();\n private annotationsByKey: Record> = {};\n private annotationsBySender: Record> = {};\n private sortedAnnotationsByKey: [string, Set][] = [];\n private targetEvent: MatrixEvent | null = null;\n private creationEmitted = false;\n private readonly client: MatrixClient;\n\n /**\n * @param relationType - The type of relation involved, such as \"m.annotation\", \"m.reference\", \"m.replace\", etc.\n * @param eventType - The relation event's type, such as \"m.reaction\", etc.\n * @param client - The client which created this instance. For backwards compatibility also accepts a Room.\n * @param altEventTypes - alt event types for relation events, for example to support unstable prefixed event types\n */\n public constructor(\n public readonly relationType: RelationType | string,\n public readonly eventType: string,\n client: MatrixClient | Room,\n public readonly altEventTypes?: string[],\n ) {\n super();\n this.client = client instanceof Room ? client.client : client;\n }\n\n /**\n * Add relation events to this collection.\n *\n * @param event - The new relation event to be added.\n */\n public async addEvent(event: MatrixEvent): Promise {\n if (this.relationEventIds.has(event.getId()!)) {\n return;\n }\n\n const relation = event.getRelation();\n if (!relation) {\n logger.error(\"Event must have relation info\");\n return;\n }\n\n const relationType = relation.rel_type;\n const eventType = event.getType();\n\n if (this.relationType !== relationType || !matchesEventType(eventType, this.eventType, this.altEventTypes)) {\n logger.error(\"Event relation info doesn't match this container\");\n return;\n }\n\n // If the event is in the process of being sent, listen for cancellation\n // so we can remove the event from the collection.\n if (event.isSending()) {\n event.on(MatrixEventEvent.Status, this.onEventStatus);\n }\n\n this.relations.add(event);\n this.relationEventIds.add(event.getId()!);\n\n if (this.relationType === RelationType.Annotation) {\n this.addAnnotationToAggregation(event);\n } else if (this.relationType === RelationType.Replace && this.targetEvent && !this.targetEvent.isState()) {\n const lastReplacement = await this.getLastReplacement();\n this.targetEvent.makeReplaced(lastReplacement!);\n }\n\n event.on(MatrixEventEvent.BeforeRedaction, this.onBeforeRedaction);\n\n this.emit(RelationsEvent.Add, event);\n\n this.maybeEmitCreated();\n }\n\n /**\n * Remove relation event from this collection.\n *\n * @param event - The relation event to remove.\n */\n public async removeEvent(event: MatrixEvent): Promise {\n if (!this.relations.has(event)) {\n return;\n }\n\n this.relations.delete(event);\n\n if (this.relationType === RelationType.Annotation) {\n this.removeAnnotationFromAggregation(event);\n } else if (this.relationType === RelationType.Replace && this.targetEvent && !this.targetEvent.isState()) {\n const lastReplacement = await this.getLastReplacement();\n this.targetEvent.makeReplaced(lastReplacement!);\n }\n\n this.emit(RelationsEvent.Remove, event);\n }\n\n /**\n * Listens for event status changes to remove cancelled events.\n *\n * @param event - The event whose status has changed\n * @param status - The new status\n */\n private onEventStatus = (event: MatrixEvent, status: EventStatus | null): void => {\n if (!event.isSending()) {\n // Sending is done, so we don't need to listen anymore\n event.removeListener(MatrixEventEvent.Status, this.onEventStatus);\n return;\n }\n if (status !== EventStatus.CANCELLED) {\n return;\n }\n // Event was cancelled, remove from the collection\n event.removeListener(MatrixEventEvent.Status, this.onEventStatus);\n this.removeEvent(event);\n };\n\n /**\n * Get all relation events in this collection.\n *\n * These are currently in the order of insertion to this collection, which\n * won't match timeline order in the case of scrollback.\n * TODO: Tweak `addEvent` to insert correctly for scrollback.\n *\n * Relation events in insertion order.\n */\n public getRelations(): MatrixEvent[] {\n return [...this.relations];\n }\n\n private addAnnotationToAggregation(event: MatrixEvent): void {\n const { key } = event.getRelation() ?? {};\n if (!key) return;\n\n let eventsForKey = this.annotationsByKey[key];\n if (!eventsForKey) {\n eventsForKey = this.annotationsByKey[key] = new Set();\n this.sortedAnnotationsByKey.push([key, eventsForKey]);\n }\n // Add the new event to the set for this key\n eventsForKey.add(event);\n // Re-sort the [key, events] pairs in descending order of event count\n this.sortedAnnotationsByKey.sort((a, b) => {\n const aEvents = a[1];\n const bEvents = b[1];\n return bEvents.size - aEvents.size;\n });\n\n const sender = event.getSender()!;\n let eventsFromSender = this.annotationsBySender[sender];\n if (!eventsFromSender) {\n eventsFromSender = this.annotationsBySender[sender] = new Set();\n }\n // Add the new event to the set for this sender\n eventsFromSender.add(event);\n }\n\n private removeAnnotationFromAggregation(event: MatrixEvent): void {\n const { key } = event.getRelation() ?? {};\n if (!key) return;\n\n const eventsForKey = this.annotationsByKey[key];\n if (eventsForKey) {\n eventsForKey.delete(event);\n\n // Re-sort the [key, events] pairs in descending order of event count\n this.sortedAnnotationsByKey.sort((a, b) => {\n const aEvents = a[1];\n const bEvents = b[1];\n return bEvents.size - aEvents.size;\n });\n }\n\n const sender = event.getSender()!;\n const eventsFromSender = this.annotationsBySender[sender];\n if (eventsFromSender) {\n eventsFromSender.delete(event);\n }\n }\n\n /**\n * For relations that have been redacted, we want to remove them from\n * aggregation data sets and emit an update event.\n *\n * To do so, we listen for `Event.beforeRedaction`, which happens:\n * - after the server accepted the redaction and remote echoed back to us\n * - before the original event has been marked redacted in the client\n *\n * @param redactedEvent - The original relation event that is about to be redacted.\n */\n private onBeforeRedaction = async (redactedEvent: MatrixEvent): Promise => {\n if (!this.relations.has(redactedEvent)) {\n return;\n }\n\n this.relations.delete(redactedEvent);\n\n if (this.relationType === RelationType.Annotation) {\n // Remove the redacted annotation from aggregation by key\n this.removeAnnotationFromAggregation(redactedEvent);\n } else if (this.relationType === RelationType.Replace && this.targetEvent && !this.targetEvent.isState()) {\n const lastReplacement = await this.getLastReplacement();\n this.targetEvent.makeReplaced(lastReplacement!);\n }\n\n redactedEvent.removeListener(MatrixEventEvent.BeforeRedaction, this.onBeforeRedaction);\n\n this.emit(RelationsEvent.Redaction, redactedEvent);\n };\n\n /**\n * Get all events in this collection grouped by key and sorted by descending\n * event count in each group.\n *\n * This is currently only supported for the annotation relation type.\n *\n * An array of [key, events] pairs sorted by descending event count.\n * The events are stored in a Set (which preserves insertion order).\n */\n public getSortedAnnotationsByKey(): [string, Set][] | null {\n if (this.relationType !== RelationType.Annotation) {\n // Other relation types are not grouped currently.\n return null;\n }\n\n return this.sortedAnnotationsByKey;\n }\n\n /**\n * Get all events in this collection grouped by sender.\n *\n * This is currently only supported for the annotation relation type.\n *\n * An object with each relation sender as a key and the matching Set of\n * events for that sender as a value.\n */\n public getAnnotationsBySender(): Record> | null {\n if (this.relationType !== RelationType.Annotation) {\n // Other relation types are not grouped currently.\n return null;\n }\n\n return this.annotationsBySender;\n }\n\n /**\n * Returns the most recent (and allowed) m.replace relation, if any.\n *\n * This is currently only supported for the m.replace relation type,\n * once the target event is known, see `addEvent`.\n */\n public async getLastReplacement(): Promise {\n if (this.relationType !== RelationType.Replace) {\n // Aggregating on last only makes sense for this relation type\n return null;\n }\n if (!this.targetEvent) {\n // Don't know which replacements to accept yet.\n // This method shouldn't be called before the original\n // event is known anyway.\n return null;\n }\n\n // the all-knowning server tells us that the event at some point had\n // this timestamp for its replacement, so any following replacement should definitely not be less\n const replaceRelation = this.targetEvent.getServerAggregatedRelation(RelationType.Replace);\n const minTs = replaceRelation?.origin_server_ts;\n\n const lastReplacement = this.getRelations().reduce((last, event) => {\n if (event.getSender() !== this.targetEvent!.getSender()) {\n return last;\n }\n if (minTs && minTs > event.getTs()) {\n return last;\n }\n if (last && last.getTs() > event.getTs()) {\n return last;\n }\n return event;\n }, null);\n\n if (lastReplacement?.shouldAttemptDecryption() && this.client.isCryptoEnabled()) {\n await lastReplacement.attemptDecryption(this.client.crypto!);\n } else if (lastReplacement?.isBeingDecrypted()) {\n await lastReplacement.getDecryptionPromise();\n }\n\n return lastReplacement;\n }\n\n /*\n * @param targetEvent - the event the relations are related to.\n */\n public async setTargetEvent(event: MatrixEvent): Promise {\n if (this.targetEvent) {\n return;\n }\n this.targetEvent = event;\n\n if (this.relationType === RelationType.Replace && !this.targetEvent.isState()) {\n const replacement = await this.getLastReplacement();\n // this is the initial update, so only call it if we already have something\n // to not emit Event.replaced needlessly\n if (replacement) {\n this.targetEvent.makeReplaced(replacement);\n }\n }\n\n this.maybeEmitCreated();\n }\n\n private maybeEmitCreated(): void {\n if (this.creationEmitted) {\n return;\n }\n // Only emit we're \"created\" once we have a target event instance _and_\n // at least one related event.\n if (!this.targetEvent || !this.relations.size) {\n return;\n }\n this.creationEmitted = true;\n this.targetEvent.emit(MatrixEventEvent.RelationsCreated, this.relationType, this.eventType);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts deleted file mode 100644 index cfbd4c7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts +++ /dev/null @@ -1,203 +0,0 @@ -import { User } from "./user"; -import { MatrixEvent } from "./event"; -import { RoomState } from "./room-state"; -import { TypedEventEmitter } from "./typed-event-emitter"; -export declare enum RoomMemberEvent { - Membership = "RoomMember.membership", - Name = "RoomMember.name", - PowerLevel = "RoomMember.powerLevel", - Typing = "RoomMember.typing" -} -export type RoomMemberEventHandlerMap = { - /** - * Fires whenever any room member's membership state changes. - * @param event - The matrix event which caused this event to fire. - * @param member - The member whose RoomMember.membership changed. - * @param oldMembership - The previous membership state. Null if it's a new member. - * @example - * ``` - * matrixClient.on("RoomMember.membership", function(event, member, oldMembership){ - * var newState = member.membership; - * }); - * ``` - */ - [RoomMemberEvent.Membership]: (event: MatrixEvent, member: RoomMember, oldMembership?: string) => void; - /** - * Fires whenever any room member's name changes. - * @param event - The matrix event which caused this event to fire. - * @param member - The member whose RoomMember.name changed. - * @param oldName - The previous name. Null if the member didn't have a name previously. - * @example - * ``` - * matrixClient.on("RoomMember.name", function(event, member){ - * var newName = member.name; - * }); - * ``` - */ - [RoomMemberEvent.Name]: (event: MatrixEvent, member: RoomMember, oldName: string | null) => void; - /** - * Fires whenever any room member's power level changes. - * @param event - The matrix event which caused this event to fire. - * @param member - The member whose RoomMember.powerLevel changed. - * @example - * ``` - * matrixClient.on("RoomMember.powerLevel", function(event, member){ - * var newPowerLevel = member.powerLevel; - * var newNormPowerLevel = member.powerLevelNorm; - * }); - * ``` - */ - [RoomMemberEvent.PowerLevel]: (event: MatrixEvent, member: RoomMember) => void; - /** - * Fires whenever any room member's typing state changes. - * @param event - The matrix event which caused this event to fire. - * @param member - The member whose RoomMember.typing changed. - * @example - * ``` - * matrixClient.on("RoomMember.typing", function(event, member){ - * var isTyping = member.typing; - * }); - * ``` - */ - [RoomMemberEvent.Typing]: (event: MatrixEvent, member: RoomMember) => void; -}; -export declare class RoomMember extends TypedEventEmitter { - readonly roomId: string; - readonly userId: string; - private _isOutOfBand; - private modified; - requestedProfileInfo: boolean; - /** - * True if the room member is currently typing. - */ - typing: boolean; - /** - * The human-readable name for this room member. This will be - * disambiguated with a suffix of " (\@user_id:matrix.org)" if another member shares the - * same displayname. - */ - name: string; - /** - * The ambiguous displayname of this room member. - */ - rawDisplayName: string; - /** - * The power level for this room member. - */ - powerLevel: number; - /** - * The normalised power level (0-100) for this room member. - */ - powerLevelNorm: number; - /** - * The User object for this room member, if one exists. - */ - user?: User; - /** - * The membership state for this room member e.g. 'join'. - */ - membership?: string; - /** - * True if the member's name is disambiguated. - */ - disambiguate: boolean; - /** - * The events describing this RoomMember. - */ - events: { - /** - * The m.room.member event for this RoomMember. - */ - member?: MatrixEvent; - }; - /** - * Construct a new room member. - * - * @param roomId - The room ID of the member. - * @param userId - The user ID of the member. - */ - constructor(roomId: string, userId: string); - /** - * Mark the member as coming from a channel that is not sync - */ - markOutOfBand(): void; - /** - * @returns does the member come from a channel that is not sync? - * This is used to store the member seperately - * from the sync state so it available across browser sessions. - */ - isOutOfBand(): boolean; - /** - * Update this room member's membership event. May fire "RoomMember.name" if - * this event updates this member's name. - * @param event - The `m.room.member` event - * @param roomState - Optional. The room state to take into account - * when calculating (e.g. for disambiguating users with the same name). - * - * @remarks - * Fires {@link RoomMemberEvent.Name} - * Fires {@link RoomMemberEvent.Membership} - */ - setMembershipEvent(event: MatrixEvent, roomState?: RoomState): void; - /** - * Update this room member's power level event. May fire - * "RoomMember.powerLevel" if this event updates this member's power levels. - * @param powerLevelEvent - The `m.room.power_levels` event - * - * @remarks - * Fires {@link RoomMemberEvent.PowerLevel} - */ - setPowerLevelEvent(powerLevelEvent: MatrixEvent): void; - /** - * Update this room member's typing event. May fire "RoomMember.typing" if - * this event changes this member's typing state. - * @param event - The typing event - * - * @remarks - * Fires {@link RoomMemberEvent.Typing} - */ - setTypingEvent(event: MatrixEvent): void; - /** - * Update the last modified time to the current time. - */ - private updateModifiedTime; - /** - * Get the timestamp when this RoomMember was last updated. This timestamp is - * updated when properties on this RoomMember are updated. - * It is updated before firing events. - * @returns The timestamp - */ - getLastModifiedTime(): number; - isKicked(): boolean; - /** - * If this member was invited with the is_direct flag set, return - * the user that invited this member - * @returns user id of the inviter - */ - getDMInviter(): string | undefined; - /** - * Get the avatar URL for a room member. - * @param baseUrl - The base homeserver URL See - * {@link MatrixClient#getHomeserverUrl}. - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDefault - (optional) Passing false causes this method to - * return null if the user has no avatar image. Otherwise, a default image URL - * will be returned. Default: true. (Deprecated) - * @param allowDirectLinks - (optional) If true, the avatar URL will be - * returned even if it is a direct hyperlink rather than a matrix content URL. - * If false, any non-matrix content URLs will be ignored. Setting this option to - * true will expose URLs that, if fetched, will leak information about the user - * to anyone who they share a room with. - * @returns the avatar URL or null. - */ - getAvatarUrl(baseUrl: string, width: number, height: number, resizeMethod: string, allowDefault: boolean | undefined, allowDirectLinks: boolean): string | null; - /** - * get the mxc avatar url, either from a state event, or from a lazily loaded member - * @returns the mxc avatar url - */ - getMxcAvatarUrl(): string | undefined; -} -//# sourceMappingURL=room-member.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts.map deleted file mode 100644 index e5267d0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-member.d.ts","sourceRoot":"","sources":["../../src/models/room-member.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js deleted file mode 100644 index 6e8eb3f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js +++ /dev/null @@ -1,377 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomMemberEvent = exports.RoomMember = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _contentRepo = require("../content-repo"); -var utils = _interopRequireWildcard(require("../utils")); -var _logger = require("../logger"); -var _typedEventEmitter = require("./typed-event-emitter"); -var _event = require("../@types/event"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let RoomMemberEvent; -exports.RoomMemberEvent = RoomMemberEvent; -(function (RoomMemberEvent) { - RoomMemberEvent["Membership"] = "RoomMember.membership"; - RoomMemberEvent["Name"] = "RoomMember.name"; - RoomMemberEvent["PowerLevel"] = "RoomMember.powerLevel"; - RoomMemberEvent["Typing"] = "RoomMember.typing"; -})(RoomMemberEvent || (exports.RoomMemberEvent = RoomMemberEvent = {})); -class RoomMember extends _typedEventEmitter.TypedEventEmitter { - // used by sync.ts - - // XXX these should be read-only - /** - * True if the room member is currently typing. - */ - - /** - * The human-readable name for this room member. This will be - * disambiguated with a suffix of " (\@user_id:matrix.org)" if another member shares the - * same displayname. - */ - - /** - * The ambiguous displayname of this room member. - */ - - /** - * The power level for this room member. - */ - - /** - * The normalised power level (0-100) for this room member. - */ - - /** - * The User object for this room member, if one exists. - */ - - /** - * The membership state for this room member e.g. 'join'. - */ - - /** - * True if the member's name is disambiguated. - */ - - /** - * The events describing this RoomMember. - */ - - /** - * Construct a new room member. - * - * @param roomId - The room ID of the member. - * @param userId - The user ID of the member. - */ - constructor(roomId, userId) { - super(); - this.roomId = roomId; - this.userId = userId; - (0, _defineProperty2.default)(this, "_isOutOfBand", false); - (0, _defineProperty2.default)(this, "modified", -1); - (0, _defineProperty2.default)(this, "requestedProfileInfo", false); - (0, _defineProperty2.default)(this, "typing", false); - (0, _defineProperty2.default)(this, "name", void 0); - (0, _defineProperty2.default)(this, "rawDisplayName", void 0); - (0, _defineProperty2.default)(this, "powerLevel", 0); - (0, _defineProperty2.default)(this, "powerLevelNorm", 0); - (0, _defineProperty2.default)(this, "user", void 0); - (0, _defineProperty2.default)(this, "membership", void 0); - (0, _defineProperty2.default)(this, "disambiguate", false); - (0, _defineProperty2.default)(this, "events", {}); - this.name = userId; - this.rawDisplayName = userId; - this.updateModifiedTime(); - } - - /** - * Mark the member as coming from a channel that is not sync - */ - markOutOfBand() { - this._isOutOfBand = true; - } - - /** - * @returns does the member come from a channel that is not sync? - * This is used to store the member seperately - * from the sync state so it available across browser sessions. - */ - isOutOfBand() { - return this._isOutOfBand; - } - - /** - * Update this room member's membership event. May fire "RoomMember.name" if - * this event updates this member's name. - * @param event - The `m.room.member` event - * @param roomState - Optional. The room state to take into account - * when calculating (e.g. for disambiguating users with the same name). - * - * @remarks - * Fires {@link RoomMemberEvent.Name} - * Fires {@link RoomMemberEvent.Membership} - */ - setMembershipEvent(event, roomState) { - var _event$getDirectional, _event$getDirectional2; - const displayName = (_event$getDirectional = event.getDirectionalContent().displayname) !== null && _event$getDirectional !== void 0 ? _event$getDirectional : ""; - if (event.getType() !== _event.EventType.RoomMember) { - return; - } - this._isOutOfBand = false; - this.events.member = event; - const oldMembership = this.membership; - this.membership = event.getDirectionalContent().membership; - if (this.membership === undefined) { - // logging to diagnose https://github.com/vector-im/element-web/issues/20962 - // (logs event content, although only of membership events) - _logger.logger.trace(`membership event with membership undefined (forwardLooking: ${event.forwardLooking})!`, event.getContent(), `prevcontent is `, event.getPrevContent()); - } - this.disambiguate = shouldDisambiguate(this.userId, displayName, roomState); - const oldName = this.name; - this.name = calculateDisplayName(this.userId, displayName, this.disambiguate); - - // not quite raw: we strip direction override chars so it can safely be inserted into - // blocks of text without breaking the text direction - this.rawDisplayName = utils.removeDirectionOverrideChars((_event$getDirectional2 = event.getDirectionalContent().displayname) !== null && _event$getDirectional2 !== void 0 ? _event$getDirectional2 : ""); - if (!this.rawDisplayName || !utils.removeHiddenChars(this.rawDisplayName)) { - this.rawDisplayName = this.userId; - } - if (oldMembership !== this.membership) { - this.updateModifiedTime(); - this.emit(RoomMemberEvent.Membership, event, this, oldMembership); - } - if (oldName !== this.name) { - this.updateModifiedTime(); - this.emit(RoomMemberEvent.Name, event, this, oldName); - } - } - - /** - * Update this room member's power level event. May fire - * "RoomMember.powerLevel" if this event updates this member's power levels. - * @param powerLevelEvent - The `m.room.power_levels` event - * - * @remarks - * Fires {@link RoomMemberEvent.PowerLevel} - */ - setPowerLevelEvent(powerLevelEvent) { - if (powerLevelEvent.getType() !== _event.EventType.RoomPowerLevels || powerLevelEvent.getStateKey() !== "") { - return; - } - const evContent = powerLevelEvent.getDirectionalContent(); - let maxLevel = evContent.users_default || 0; - const users = evContent.users || {}; - Object.values(users).forEach(lvl => { - maxLevel = Math.max(maxLevel, lvl); - }); - const oldPowerLevel = this.powerLevel; - const oldPowerLevelNorm = this.powerLevelNorm; - if (users[this.userId] !== undefined && Number.isInteger(users[this.userId])) { - this.powerLevel = users[this.userId]; - } else if (evContent.users_default !== undefined) { - this.powerLevel = evContent.users_default; - } else { - this.powerLevel = 0; - } - this.powerLevelNorm = 0; - if (maxLevel > 0) { - this.powerLevelNorm = this.powerLevel * 100 / maxLevel; - } - - // emit for changes in powerLevelNorm as well (since the app will need to - // redraw everyone's level if the max has changed) - if (oldPowerLevel !== this.powerLevel || oldPowerLevelNorm !== this.powerLevelNorm) { - this.updateModifiedTime(); - this.emit(RoomMemberEvent.PowerLevel, powerLevelEvent, this); - } - } - - /** - * Update this room member's typing event. May fire "RoomMember.typing" if - * this event changes this member's typing state. - * @param event - The typing event - * - * @remarks - * Fires {@link RoomMemberEvent.Typing} - */ - setTypingEvent(event) { - if (event.getType() !== "m.typing") { - return; - } - const oldTyping = this.typing; - this.typing = false; - const typingList = event.getContent().user_ids; - if (!Array.isArray(typingList)) { - // malformed event :/ bail early. TODO: whine? - return; - } - if (typingList.indexOf(this.userId) !== -1) { - this.typing = true; - } - if (oldTyping !== this.typing) { - this.updateModifiedTime(); - this.emit(RoomMemberEvent.Typing, event, this); - } - } - - /** - * Update the last modified time to the current time. - */ - updateModifiedTime() { - this.modified = Date.now(); - } - - /** - * Get the timestamp when this RoomMember was last updated. This timestamp is - * updated when properties on this RoomMember are updated. - * It is updated before firing events. - * @returns The timestamp - */ - getLastModifiedTime() { - return this.modified; - } - isKicked() { - return this.membership === "leave" && this.events.member !== undefined && this.events.member.getSender() !== this.events.member.getStateKey(); - } - - /** - * If this member was invited with the is_direct flag set, return - * the user that invited this member - * @returns user id of the inviter - */ - getDMInviter() { - // when not available because that room state hasn't been loaded in, - // we don't really know, but more likely to not be a direct chat - if (this.events.member) { - // TODO: persist the is_direct flag on the member as more member events - // come in caused by displayName changes. - - // the is_direct flag is set on the invite member event. - // This is copied on the prev_content section of the join member event - // when the invite is accepted. - - const memberEvent = this.events.member; - let memberContent = memberEvent.getContent(); - let inviteSender = memberEvent.getSender(); - if (memberContent.membership === "join") { - memberContent = memberEvent.getPrevContent(); - inviteSender = memberEvent.getUnsigned().prev_sender; - } - if (memberContent.membership === "invite" && memberContent.is_direct) { - return inviteSender; - } - } - } - - /** - * Get the avatar URL for a room member. - * @param baseUrl - The base homeserver URL See - * {@link MatrixClient#getHomeserverUrl}. - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDefault - (optional) Passing false causes this method to - * return null if the user has no avatar image. Otherwise, a default image URL - * will be returned. Default: true. (Deprecated) - * @param allowDirectLinks - (optional) If true, the avatar URL will be - * returned even if it is a direct hyperlink rather than a matrix content URL. - * If false, any non-matrix content URLs will be ignored. Setting this option to - * true will expose URLs that, if fetched, will leak information about the user - * to anyone who they share a room with. - * @returns the avatar URL or null. - */ - getAvatarUrl(baseUrl, width, height, resizeMethod, allowDefault = true, allowDirectLinks) { - const rawUrl = this.getMxcAvatarUrl(); - if (!rawUrl && !allowDefault) { - return null; - } - const httpUrl = (0, _contentRepo.getHttpUriForMxc)(baseUrl, rawUrl, width, height, resizeMethod, allowDirectLinks); - if (httpUrl) { - return httpUrl; - } - return null; - } - - /** - * get the mxc avatar url, either from a state event, or from a lazily loaded member - * @returns the mxc avatar url - */ - getMxcAvatarUrl() { - if (this.events.member) { - return this.events.member.getDirectionalContent().avatar_url; - } else if (this.user) { - return this.user.avatarUrl; - } - } -} -exports.RoomMember = RoomMember; -const MXID_PATTERN = /@.+:.+/; -const LTR_RTL_PATTERN = /[\u200E\u200F\u202A-\u202F]/; -function shouldDisambiguate(selfUserId, displayName, roomState) { - if (!displayName || displayName === selfUserId) return false; - - // First check if the displayname is something we consider truthy - // after stripping it of zero width characters and padding spaces - if (!utils.removeHiddenChars(displayName)) return false; - if (!roomState) return false; - - // Next check if the name contains something that look like a mxid - // If it does, it may be someone trying to impersonate someone else - // Show full mxid in this case - if (MXID_PATTERN.test(displayName)) return true; - - // Also show mxid if the display name contains any LTR/RTL characters as these - // make it very difficult for us to find similar *looking* display names - // E.g "Mark" could be cloned by writing "kraM" but in RTL. - if (LTR_RTL_PATTERN.test(displayName)) return true; - - // Also show mxid if there are other people with the same or similar - // displayname, after hidden character removal. - const userIds = roomState.getUserIdsWithDisplayName(displayName); - if (userIds.some(u => u !== selfUserId)) return true; - return false; -} -function calculateDisplayName(selfUserId, displayName, disambiguate) { - if (!displayName || displayName === selfUserId) return selfUserId; - if (disambiguate) return utils.removeDirectionOverrideChars(displayName) + " (" + selfUserId + ")"; - - // First check if the displayname is something we consider truthy - // after stripping it of zero width characters and padding spaces - if (!utils.removeHiddenChars(displayName)) return selfUserId; - - // We always strip the direction override characters (LRO and RLO). - // These override the text direction for all subsequent characters - // in the paragraph so if display names contained these, they'd - // need to be wrapped in something to prevent this from leaking out - // (which we can do in HTML but not text) or we'd need to add - // control characters to the string to reset any overrides (eg. - // adding PDF characters at the end). As far as we can see, - // there should be no reason these would be necessary - rtl display - // names should flip into the correct direction automatically based on - // the characters, and you can still embed rtl in ltr or vice versa - // with the embed chars or marker chars. - return utils.removeDirectionOverrideChars(displayName); -} -//# sourceMappingURL=room-member.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js.map deleted file mode 100644 index 003ae8a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-member.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-member.js","names":["_contentRepo","require","utils","_interopRequireWildcard","_logger","_typedEventEmitter","_event","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","RoomMemberEvent","exports","RoomMember","TypedEventEmitter","constructor","roomId","userId","_defineProperty2","name","rawDisplayName","updateModifiedTime","markOutOfBand","_isOutOfBand","isOutOfBand","setMembershipEvent","event","roomState","_event$getDirectional","_event$getDirectional2","displayName","getDirectionalContent","displayname","getType","EventType","events","member","oldMembership","membership","undefined","logger","trace","forwardLooking","getContent","getPrevContent","disambiguate","shouldDisambiguate","oldName","calculateDisplayName","removeDirectionOverrideChars","removeHiddenChars","emit","Membership","Name","setPowerLevelEvent","powerLevelEvent","RoomPowerLevels","getStateKey","evContent","maxLevel","users_default","users","values","forEach","lvl","Math","max","oldPowerLevel","powerLevel","oldPowerLevelNorm","powerLevelNorm","Number","isInteger","PowerLevel","setTypingEvent","oldTyping","typing","typingList","user_ids","Array","isArray","indexOf","Typing","modified","Date","now","getLastModifiedTime","isKicked","getSender","getDMInviter","memberEvent","memberContent","inviteSender","getUnsigned","prev_sender","is_direct","getAvatarUrl","baseUrl","width","height","resizeMethod","allowDefault","allowDirectLinks","rawUrl","getMxcAvatarUrl","httpUrl","getHttpUriForMxc","avatar_url","user","avatarUrl","MXID_PATTERN","LTR_RTL_PATTERN","selfUserId","test","userIds","getUserIdsWithDisplayName","some","u"],"sources":["../../src/models/room-member.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { getHttpUriForMxc } from \"../content-repo\";\nimport * as utils from \"../utils\";\nimport { User } from \"./user\";\nimport { MatrixEvent } from \"./event\";\nimport { RoomState } from \"./room-state\";\nimport { logger } from \"../logger\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\nimport { EventType } from \"../@types/event\";\n\nexport enum RoomMemberEvent {\n Membership = \"RoomMember.membership\",\n Name = \"RoomMember.name\",\n PowerLevel = \"RoomMember.powerLevel\",\n Typing = \"RoomMember.typing\",\n}\n\nexport type RoomMemberEventHandlerMap = {\n /**\n * Fires whenever any room member's membership state changes.\n * @param event - The matrix event which caused this event to fire.\n * @param member - The member whose RoomMember.membership changed.\n * @param oldMembership - The previous membership state. Null if it's a new member.\n * @example\n * ```\n * matrixClient.on(\"RoomMember.membership\", function(event, member, oldMembership){\n * var newState = member.membership;\n * });\n * ```\n */\n [RoomMemberEvent.Membership]: (event: MatrixEvent, member: RoomMember, oldMembership?: string) => void;\n /**\n * Fires whenever any room member's name changes.\n * @param event - The matrix event which caused this event to fire.\n * @param member - The member whose RoomMember.name changed.\n * @param oldName - The previous name. Null if the member didn't have a name previously.\n * @example\n * ```\n * matrixClient.on(\"RoomMember.name\", function(event, member){\n * var newName = member.name;\n * });\n * ```\n */\n [RoomMemberEvent.Name]: (event: MatrixEvent, member: RoomMember, oldName: string | null) => void;\n /**\n * Fires whenever any room member's power level changes.\n * @param event - The matrix event which caused this event to fire.\n * @param member - The member whose RoomMember.powerLevel changed.\n * @example\n * ```\n * matrixClient.on(\"RoomMember.powerLevel\", function(event, member){\n * var newPowerLevel = member.powerLevel;\n * var newNormPowerLevel = member.powerLevelNorm;\n * });\n * ```\n */\n [RoomMemberEvent.PowerLevel]: (event: MatrixEvent, member: RoomMember) => void;\n /**\n * Fires whenever any room member's typing state changes.\n * @param event - The matrix event which caused this event to fire.\n * @param member - The member whose RoomMember.typing changed.\n * @example\n * ```\n * matrixClient.on(\"RoomMember.typing\", function(event, member){\n * var isTyping = member.typing;\n * });\n * ```\n */\n [RoomMemberEvent.Typing]: (event: MatrixEvent, member: RoomMember) => void;\n};\n\nexport class RoomMember extends TypedEventEmitter {\n private _isOutOfBand = false;\n private modified = -1;\n public requestedProfileInfo = false; // used by sync.ts\n\n // XXX these should be read-only\n /**\n * True if the room member is currently typing.\n */\n public typing = false;\n /**\n * The human-readable name for this room member. This will be\n * disambiguated with a suffix of \" (\\@user_id:matrix.org)\" if another member shares the\n * same displayname.\n */\n public name: string;\n /**\n * The ambiguous displayname of this room member.\n */\n public rawDisplayName: string;\n /**\n * The power level for this room member.\n */\n public powerLevel = 0;\n /**\n * The normalised power level (0-100) for this room member.\n */\n public powerLevelNorm = 0;\n /**\n * The User object for this room member, if one exists.\n */\n public user?: User;\n /**\n * The membership state for this room member e.g. 'join'.\n */\n public membership?: string;\n /**\n * True if the member's name is disambiguated.\n */\n public disambiguate = false;\n /**\n * The events describing this RoomMember.\n */\n public events: {\n /**\n * The m.room.member event for this RoomMember.\n */\n member?: MatrixEvent;\n } = {};\n\n /**\n * Construct a new room member.\n *\n * @param roomId - The room ID of the member.\n * @param userId - The user ID of the member.\n */\n public constructor(public readonly roomId: string, public readonly userId: string) {\n super();\n\n this.name = userId;\n this.rawDisplayName = userId;\n this.updateModifiedTime();\n }\n\n /**\n * Mark the member as coming from a channel that is not sync\n */\n public markOutOfBand(): void {\n this._isOutOfBand = true;\n }\n\n /**\n * @returns does the member come from a channel that is not sync?\n * This is used to store the member seperately\n * from the sync state so it available across browser sessions.\n */\n public isOutOfBand(): boolean {\n return this._isOutOfBand;\n }\n\n /**\n * Update this room member's membership event. May fire \"RoomMember.name\" if\n * this event updates this member's name.\n * @param event - The `m.room.member` event\n * @param roomState - Optional. The room state to take into account\n * when calculating (e.g. for disambiguating users with the same name).\n *\n * @remarks\n * Fires {@link RoomMemberEvent.Name}\n * Fires {@link RoomMemberEvent.Membership}\n */\n public setMembershipEvent(event: MatrixEvent, roomState?: RoomState): void {\n const displayName = event.getDirectionalContent().displayname ?? \"\";\n\n if (event.getType() !== EventType.RoomMember) {\n return;\n }\n\n this._isOutOfBand = false;\n\n this.events.member = event;\n\n const oldMembership = this.membership;\n this.membership = event.getDirectionalContent().membership;\n if (this.membership === undefined) {\n // logging to diagnose https://github.com/vector-im/element-web/issues/20962\n // (logs event content, although only of membership events)\n logger.trace(\n `membership event with membership undefined (forwardLooking: ${event.forwardLooking})!`,\n event.getContent(),\n `prevcontent is `,\n event.getPrevContent(),\n );\n }\n\n this.disambiguate = shouldDisambiguate(this.userId, displayName, roomState);\n\n const oldName = this.name;\n this.name = calculateDisplayName(this.userId, displayName, this.disambiguate);\n\n // not quite raw: we strip direction override chars so it can safely be inserted into\n // blocks of text without breaking the text direction\n this.rawDisplayName = utils.removeDirectionOverrideChars(event.getDirectionalContent().displayname ?? \"\");\n if (!this.rawDisplayName || !utils.removeHiddenChars(this.rawDisplayName)) {\n this.rawDisplayName = this.userId;\n }\n\n if (oldMembership !== this.membership) {\n this.updateModifiedTime();\n this.emit(RoomMemberEvent.Membership, event, this, oldMembership);\n }\n if (oldName !== this.name) {\n this.updateModifiedTime();\n this.emit(RoomMemberEvent.Name, event, this, oldName);\n }\n }\n\n /**\n * Update this room member's power level event. May fire\n * \"RoomMember.powerLevel\" if this event updates this member's power levels.\n * @param powerLevelEvent - The `m.room.power_levels` event\n *\n * @remarks\n * Fires {@link RoomMemberEvent.PowerLevel}\n */\n public setPowerLevelEvent(powerLevelEvent: MatrixEvent): void {\n if (powerLevelEvent.getType() !== EventType.RoomPowerLevels || powerLevelEvent.getStateKey() !== \"\") {\n return;\n }\n\n const evContent = powerLevelEvent.getDirectionalContent();\n\n let maxLevel = evContent.users_default || 0;\n const users: { [userId: string]: number } = evContent.users || {};\n Object.values(users).forEach((lvl: number) => {\n maxLevel = Math.max(maxLevel, lvl);\n });\n const oldPowerLevel = this.powerLevel;\n const oldPowerLevelNorm = this.powerLevelNorm;\n\n if (users[this.userId] !== undefined && Number.isInteger(users[this.userId])) {\n this.powerLevel = users[this.userId];\n } else if (evContent.users_default !== undefined) {\n this.powerLevel = evContent.users_default;\n } else {\n this.powerLevel = 0;\n }\n this.powerLevelNorm = 0;\n if (maxLevel > 0) {\n this.powerLevelNorm = (this.powerLevel * 100) / maxLevel;\n }\n\n // emit for changes in powerLevelNorm as well (since the app will need to\n // redraw everyone's level if the max has changed)\n if (oldPowerLevel !== this.powerLevel || oldPowerLevelNorm !== this.powerLevelNorm) {\n this.updateModifiedTime();\n this.emit(RoomMemberEvent.PowerLevel, powerLevelEvent, this);\n }\n }\n\n /**\n * Update this room member's typing event. May fire \"RoomMember.typing\" if\n * this event changes this member's typing state.\n * @param event - The typing event\n *\n * @remarks\n * Fires {@link RoomMemberEvent.Typing}\n */\n public setTypingEvent(event: MatrixEvent): void {\n if (event.getType() !== \"m.typing\") {\n return;\n }\n const oldTyping = this.typing;\n this.typing = false;\n const typingList = event.getContent().user_ids;\n if (!Array.isArray(typingList)) {\n // malformed event :/ bail early. TODO: whine?\n return;\n }\n if (typingList.indexOf(this.userId) !== -1) {\n this.typing = true;\n }\n if (oldTyping !== this.typing) {\n this.updateModifiedTime();\n this.emit(RoomMemberEvent.Typing, event, this);\n }\n }\n\n /**\n * Update the last modified time to the current time.\n */\n private updateModifiedTime(): void {\n this.modified = Date.now();\n }\n\n /**\n * Get the timestamp when this RoomMember was last updated. This timestamp is\n * updated when properties on this RoomMember are updated.\n * It is updated before firing events.\n * @returns The timestamp\n */\n public getLastModifiedTime(): number {\n return this.modified;\n }\n\n public isKicked(): boolean {\n return (\n this.membership === \"leave\" &&\n this.events.member !== undefined &&\n this.events.member.getSender() !== this.events.member.getStateKey()\n );\n }\n\n /**\n * If this member was invited with the is_direct flag set, return\n * the user that invited this member\n * @returns user id of the inviter\n */\n public getDMInviter(): string | undefined {\n // when not available because that room state hasn't been loaded in,\n // we don't really know, but more likely to not be a direct chat\n if (this.events.member) {\n // TODO: persist the is_direct flag on the member as more member events\n // come in caused by displayName changes.\n\n // the is_direct flag is set on the invite member event.\n // This is copied on the prev_content section of the join member event\n // when the invite is accepted.\n\n const memberEvent = this.events.member;\n let memberContent = memberEvent.getContent();\n let inviteSender: string | undefined = memberEvent.getSender();\n\n if (memberContent.membership === \"join\") {\n memberContent = memberEvent.getPrevContent();\n inviteSender = memberEvent.getUnsigned().prev_sender;\n }\n\n if (memberContent.membership === \"invite\" && memberContent.is_direct) {\n return inviteSender;\n }\n }\n }\n\n /**\n * Get the avatar URL for a room member.\n * @param baseUrl - The base homeserver URL See\n * {@link MatrixClient#getHomeserverUrl}.\n * @param width - The desired width of the thumbnail.\n * @param height - The desired height of the thumbnail.\n * @param resizeMethod - The thumbnail resize method to use, either\n * \"crop\" or \"scale\".\n * @param allowDefault - (optional) Passing false causes this method to\n * return null if the user has no avatar image. Otherwise, a default image URL\n * will be returned. Default: true. (Deprecated)\n * @param allowDirectLinks - (optional) If true, the avatar URL will be\n * returned even if it is a direct hyperlink rather than a matrix content URL.\n * If false, any non-matrix content URLs will be ignored. Setting this option to\n * true will expose URLs that, if fetched, will leak information about the user\n * to anyone who they share a room with.\n * @returns the avatar URL or null.\n */\n public getAvatarUrl(\n baseUrl: string,\n width: number,\n height: number,\n resizeMethod: string,\n allowDefault = true,\n allowDirectLinks: boolean,\n ): string | null {\n const rawUrl = this.getMxcAvatarUrl();\n\n if (!rawUrl && !allowDefault) {\n return null;\n }\n const httpUrl = getHttpUriForMxc(baseUrl, rawUrl, width, height, resizeMethod, allowDirectLinks);\n if (httpUrl) {\n return httpUrl;\n }\n return null;\n }\n\n /**\n * get the mxc avatar url, either from a state event, or from a lazily loaded member\n * @returns the mxc avatar url\n */\n public getMxcAvatarUrl(): string | undefined {\n if (this.events.member) {\n return this.events.member.getDirectionalContent().avatar_url;\n } else if (this.user) {\n return this.user.avatarUrl;\n }\n }\n}\n\nconst MXID_PATTERN = /@.+:.+/;\nconst LTR_RTL_PATTERN = /[\\u200E\\u200F\\u202A-\\u202F]/;\n\nfunction shouldDisambiguate(selfUserId: string, displayName?: string, roomState?: RoomState): boolean {\n if (!displayName || displayName === selfUserId) return false;\n\n // First check if the displayname is something we consider truthy\n // after stripping it of zero width characters and padding spaces\n if (!utils.removeHiddenChars(displayName)) return false;\n\n if (!roomState) return false;\n\n // Next check if the name contains something that look like a mxid\n // If it does, it may be someone trying to impersonate someone else\n // Show full mxid in this case\n if (MXID_PATTERN.test(displayName)) return true;\n\n // Also show mxid if the display name contains any LTR/RTL characters as these\n // make it very difficult for us to find similar *looking* display names\n // E.g \"Mark\" could be cloned by writing \"kraM\" but in RTL.\n if (LTR_RTL_PATTERN.test(displayName)) return true;\n\n // Also show mxid if there are other people with the same or similar\n // displayname, after hidden character removal.\n const userIds = roomState.getUserIdsWithDisplayName(displayName);\n if (userIds.some((u) => u !== selfUserId)) return true;\n\n return false;\n}\n\nfunction calculateDisplayName(selfUserId: string, displayName: string | undefined, disambiguate: boolean): string {\n if (!displayName || displayName === selfUserId) return selfUserId;\n\n if (disambiguate) return utils.removeDirectionOverrideChars(displayName) + \" (\" + selfUserId + \")\";\n\n // First check if the displayname is something we consider truthy\n // after stripping it of zero width characters and padding spaces\n if (!utils.removeHiddenChars(displayName)) return selfUserId;\n\n // We always strip the direction override characters (LRO and RLO).\n // These override the text direction for all subsequent characters\n // in the paragraph so if display names contained these, they'd\n // need to be wrapped in something to prevent this from leaking out\n // (which we can do in HTML but not text) or we'd need to add\n // control characters to the string to reset any overrides (eg.\n // adding PDF characters at the end). As far as we can see,\n // there should be no reason these would be necessary - rtl display\n // names should flip into the correct direction automatically based on\n // the characters, and you can still embed rtl in ltr or vice versa\n // with the embed chars or marker chars.\n return utils.removeDirectionOverrideChars(displayName);\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts deleted file mode 100644 index 316a8dd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts +++ /dev/null @@ -1,448 +0,0 @@ -import { RoomMember } from "./room-member"; -import { EventType } from "../@types/event"; -import { MatrixEvent } from "./event"; -import { MatrixClient } from "../client"; -import { GuestAccess, HistoryVisibility, JoinRule } from "../@types/partials"; -import { TypedEventEmitter } from "./typed-event-emitter"; -import { Beacon, BeaconEvent, BeaconEventHandlerMap, BeaconIdentifier } from "./beacon"; -import { TypedReEmitter } from "../ReEmitter"; -export interface IMarkerFoundOptions { - /** Whether the timeline was empty before the marker event arrived in the - * room. This could be happen in a variety of cases: - * 1. From the initial sync - * 2. It's the first state we're seeing after joining the room - * 3. Or whether it's coming from `syncFromCache` - * - * A marker event refers to `UNSTABLE_MSC2716_MARKER` and indicates that - * history was imported somewhere back in time. It specifically points to an - * MSC2716 insertion event where the history was imported at. Marker events - * are sent as state events so they are easily discoverable by clients and - * homeservers and don't get lost in timeline gaps. - */ - timelineWasEmpty?: boolean; -} -declare enum OobStatus { - NotStarted = 0, - InProgress = 1, - Finished = 2 -} -export interface IPowerLevelsContent { - users?: Record; - events?: Record; - users_default?: number; - events_default?: number; - state_default?: number; - ban?: number; - kick?: number; - redact?: number; -} -export declare enum RoomStateEvent { - Events = "RoomState.events", - Members = "RoomState.members", - NewMember = "RoomState.newMember", - Update = "RoomState.update", - BeaconLiveness = "RoomState.BeaconLiveness", - Marker = "RoomState.Marker" -} -export type RoomStateEventHandlerMap = { - /** - * Fires whenever the event dictionary in room state is updated. - * @param event - The matrix event which caused this event to fire. - * @param state - The room state whose RoomState.events dictionary - * was updated. - * @param prevEvent - The event being replaced by the new state, if - * known. Note that this can differ from `getPrevContent()` on the new state event - * as this is the store's view of the last state, not the previous state provided - * by the server. - * @example - * ``` - * matrixClient.on("RoomState.events", function(event, state, prevEvent){ - * var newStateEvent = event; - * }); - * ``` - */ - [RoomStateEvent.Events]: (event: MatrixEvent, state: RoomState, lastStateEvent: MatrixEvent | null) => void; - /** - * Fires whenever a member in the members dictionary is updated in any way. - * @param event - The matrix event which caused this event to fire. - * @param state - The room state whose RoomState.members dictionary - * was updated. - * @param member - The room member that was updated. - * @example - * ``` - * matrixClient.on("RoomState.members", function(event, state, member){ - * var newMembershipState = member.membership; - * }); - * ``` - */ - [RoomStateEvent.Members]: (event: MatrixEvent, state: RoomState, member: RoomMember) => void; - /** - * Fires whenever a member is added to the members dictionary. The RoomMember - * will not be fully populated yet (e.g. no membership state) but will already - * be available in the members dictionary. - * @param event - The matrix event which caused this event to fire. - * @param state - The room state whose RoomState.members dictionary - * was updated with a new entry. - * @param member - The room member that was added. - * @example - * ``` - * matrixClient.on("RoomState.newMember", function(event, state, member){ - * // add event listeners on 'member' - * }); - * ``` - */ - [RoomStateEvent.NewMember]: (event: MatrixEvent, state: RoomState, member: RoomMember) => void; - [RoomStateEvent.Update]: (state: RoomState) => void; - [RoomStateEvent.BeaconLiveness]: (state: RoomState, hasLiveBeacons: boolean) => void; - [RoomStateEvent.Marker]: (event: MatrixEvent, setStateOptions?: IMarkerFoundOptions) => void; - [BeaconEvent.New]: (event: MatrixEvent, beacon: Beacon) => void; -}; -type EmittedEvents = RoomStateEvent | BeaconEvent; -type EventHandlerMap = RoomStateEventHandlerMap & BeaconEventHandlerMap; -export declare class RoomState extends TypedEventEmitter { - readonly roomId: string; - private oobMemberFlags; - readonly reEmitter: TypedReEmitter; - private sentinels; - private displayNameToUserIds; - private userIdsToDisplayNames; - private tokenToInvite; - private joinedMemberCount; - private summaryJoinedMemberCount; - private invitedMemberCount; - private summaryInvitedMemberCount; - private modified; - members: Record; - events: Map>; - paginationToken: string | null; - readonly beacons: Map; - private _liveBeaconIds; - /** - * Construct room state. - * - * Room State represents the state of the room at a given point. - * It can be mutated by adding state events to it. - * There are two types of room member associated with a state event: - * normal member objects (accessed via getMember/getMembers) which mutate - * with the state to represent the current state of that room/user, e.g. - * the object returned by `getMember('@bob:example.com')` will mutate to - * get a different display name if Bob later changes his display name - * in the room. - * There are also 'sentinel' members (accessed via getSentinelMember). - * These also represent the state of room members at the point in time - * represented by the RoomState object, but unlike objects from getMember, - * sentinel objects will always represent the room state as at the time - * getSentinelMember was called, so if Bob subsequently changes his display - * name, a room member object previously acquired with getSentinelMember - * will still have his old display name. Calling getSentinelMember again - * after the display name change will return a new RoomMember object - * with Bob's new display name. - * - * @param roomId - Optional. The ID of the room which has this state. - * If none is specified it just tracks paginationTokens, useful for notifTimelineSet - * @param oobMemberFlags - Optional. The state of loading out of bound members. - * As the timeline might get reset while they are loading, this state needs to be inherited - * and shared when the room state is cloned for the new timeline. - * This should only be passed from clone. - */ - constructor(roomId: string, oobMemberFlags?: { - status: OobStatus; - }); - /** - * Returns the number of joined members in this room - * This method caches the result. - * @returns The number of members in this room whose membership is 'join' - */ - getJoinedMemberCount(): number; - /** - * Set the joined member count explicitly (like from summary part of the sync response) - * @param count - the amount of joined members - */ - setJoinedMemberCount(count: number): void; - /** - * Returns the number of invited members in this room - * @returns The number of members in this room whose membership is 'invite' - */ - getInvitedMemberCount(): number; - /** - * Set the amount of invited members in this room - * @param count - the amount of invited members - */ - setInvitedMemberCount(count: number): void; - /** - * Get all RoomMembers in this room. - * @returns A list of RoomMembers. - */ - getMembers(): RoomMember[]; - /** - * Get all RoomMembers in this room, excluding the user IDs provided. - * @param excludedIds - The user IDs to exclude. - * @returns A list of RoomMembers. - */ - getMembersExcept(excludedIds: string[]): RoomMember[]; - /** - * Get a room member by their user ID. - * @param userId - The room member's user ID. - * @returns The member or null if they do not exist. - */ - getMember(userId: string): RoomMember | null; - /** - * Get a room member whose properties will not change with this room state. You - * typically want this if you want to attach a RoomMember to a MatrixEvent which - * may no longer be represented correctly by Room.currentState or Room.oldState. - * The term 'sentinel' refers to the fact that this RoomMember is an unchanging - * guardian for state at this particular point in time. - * @param userId - The room member's user ID. - * @returns The member or null if they do not exist. - */ - getSentinelMember(userId: string): RoomMember | null; - /** - * Get state events from the state of the room. - * @param eventType - The event type of the state event. - * @param stateKey - Optional. The state_key of the state event. If - * this is `undefined` then all matching state events will be - * returned. - * @returns A list of events if state_key was - * `undefined`, else a single event (or null if no match found). - */ - getStateEvents(eventType: EventType | string): MatrixEvent[]; - getStateEvents(eventType: EventType | string, stateKey: string): MatrixEvent | null; - get hasLiveBeacons(): boolean; - get liveBeaconIds(): BeaconIdentifier[]; - /** - * Creates a copy of this room state so that mutations to either won't affect the other. - * @returns the copy of the room state - */ - clone(): RoomState; - /** - * Add previously unknown state events. - * When lazy loading members while back-paginating, - * the relevant room state for the timeline chunk at the end - * of the chunk can be set with this method. - * @param events - state events to prepend - */ - setUnknownStateEvents(events: MatrixEvent[]): void; - /** - * Add an array of one or more state MatrixEvents, overwriting any existing - * state with the same `{type, stateKey}` tuple. Will fire "RoomState.events" - * for every event added. May fire "RoomState.members" if there are - * `m.room.member` events. May fire "RoomStateEvent.Marker" if there are - * `UNSTABLE_MSC2716_MARKER` events. - * @param stateEvents - a list of state events for this room. - * - * @remarks - * Fires {@link RoomStateEvent.Members} - * Fires {@link RoomStateEvent.NewMember} - * Fires {@link RoomStateEvent.Events} - * Fires {@link RoomStateEvent.Marker} - */ - setStateEvents(stateEvents: MatrixEvent[], markerFoundOptions?: IMarkerFoundOptions): void; - processBeaconEvents(events: MatrixEvent[], matrixClient: MatrixClient): Promise; - /** - * Looks up a member by the given userId, and if it doesn't exist, - * create it and emit the `RoomState.newMember` event. - * This method makes sure the member is added to the members dictionary - * before emitting, as this is done from setStateEvents and setOutOfBandMember. - * @param userId - the id of the user to look up - * @param event - the membership event for the (new) member. Used to emit. - * @returns the member, existing or newly created. - * - * @remarks - * Fires {@link RoomStateEvent.NewMember} - */ - private getOrCreateMember; - private setStateEvent; - /** - * @experimental - */ - private setBeacon; - /** - * @experimental - * Check liveness of room beacons - * emit RoomStateEvent.BeaconLiveness event - */ - private onBeaconLivenessChange; - private getStateEventMatching; - private updateMember; - /** - * Get the out-of-band members loading state, whether loading is needed or not. - * Note that loading might be in progress and hence isn't needed. - * @returns whether or not the members of this room need to be loaded - */ - needsOutOfBandMembers(): boolean; - /** - * Check if loading of out-of-band-members has completed - * - * @returns true if the full membership list of this room has been loaded. False if it is not started or is in - * progress. - */ - outOfBandMembersReady(): boolean; - /** - * Mark this room state as waiting for out-of-band members, - * ensuring it doesn't ask for them to be requested again - * through needsOutOfBandMembers - */ - markOutOfBandMembersStarted(): void; - /** - * Mark this room state as having failed to fetch out-of-band members - */ - markOutOfBandMembersFailed(): void; - /** - * Clears the loaded out-of-band members - */ - clearOutOfBandMembers(): void; - /** - * Sets the loaded out-of-band members. - * @param stateEvents - array of membership state events - */ - setOutOfBandMembers(stateEvents: MatrixEvent[]): void; - /** - * Sets a single out of band member, used by both setOutOfBandMembers and clone - * @param stateEvent - membership state event - */ - private setOutOfBandMember; - /** - * Set the current typing event for this room. - * @param event - The typing event - */ - setTypingEvent(event: MatrixEvent): void; - /** - * Get the m.room.member event which has the given third party invite token. - * - * @param token - The token - * @returns The m.room.member event or null - */ - getInviteForThreePidToken(token: string): MatrixEvent | null; - /** - * Update the last modified time to the current time. - */ - private updateModifiedTime; - /** - * Get the timestamp when this room state was last updated. This timestamp is - * updated when this object has received new state events. - * @returns The timestamp - */ - getLastModifiedTime(): number; - /** - * Get user IDs with the specified or similar display names. - * @param displayName - The display name to get user IDs from. - * @returns An array of user IDs or an empty array. - */ - getUserIdsWithDisplayName(displayName: string): string[]; - /** - * Returns true if userId is in room, event is not redacted and either sender of - * mxEvent or has power level sufficient to redact events other than their own. - * @param mxEvent - The event to test permission for - * @param userId - The user ID of the user to test permission for - * @returns true if the given used ID can redact given event - */ - maySendRedactionForEvent(mxEvent: MatrixEvent, userId: string): boolean; - /** - * Returns true if the given power level is sufficient for action - * @param action - The type of power level to check - * @param powerLevel - The power level of the member - * @returns true if the given power level is sufficient - */ - hasSufficientPowerLevelFor(action: "ban" | "kick" | "redact", powerLevel: number): boolean; - /** - * Short-form for maySendEvent('m.room.message', userId) - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID should be permitted to send - * message events into the given room. - */ - maySendMessage(userId: string): boolean; - /** - * Returns true if the given user ID has permission to send a normal - * event of type `eventType` into this room. - * @param eventType - The type of event to test - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID should be permitted to send - * the given type of event into this room, - * according to the room's state. - */ - maySendEvent(eventType: EventType | string, userId: string): boolean; - /** - * Returns true if the given MatrixClient has permission to send a state - * event of type `stateEventType` into this room. - * @param stateEventType - The type of state events to test - * @param cli - The client to test permission for - * @returns true if the given client should be permitted to send - * the given type of state event into this room, - * according to the room's state. - */ - mayClientSendStateEvent(stateEventType: EventType | string, cli: MatrixClient): boolean; - /** - * Returns true if the given user ID has permission to send a state - * event of type `stateEventType` into this room. - * @param stateEventType - The type of state events to test - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID should be permitted to send - * the given type of state event into this room, - * according to the room's state. - */ - maySendStateEvent(stateEventType: EventType | string, userId: string): boolean; - /** - * Returns true if the given user ID has permission to send a normal or state - * event of type `eventType` into this room. - * @param eventType - The type of event to test - * @param userId - The user ID of the user to test permission for - * @param state - If true, tests if the user may send a state - event of this type. Otherwise tests whether - they may send a regular event. - * @returns true if the given user ID should be permitted to send - * the given type of event into this room, - * according to the room's state. - */ - private maySendEventOfType; - /** - * Returns true if the given user ID has permission to trigger notification - * of type `notifLevelKey` - * @param notifLevelKey - The level of notification to test (eg. 'room') - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID has permission to trigger a - * notification of this type. - */ - mayTriggerNotifOfType(notifLevelKey: string, userId: string): boolean; - /** - * Returns the join rule based on the m.room.join_rule state event, defaulting to `invite`. - * @returns the join_rule applied to this room - */ - getJoinRule(): JoinRule; - /** - * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`. - * @returns the history_visibility applied to this room - */ - getHistoryVisibility(): HistoryVisibility; - /** - * Returns the guest access based on the m.room.guest_access state event, defaulting to `shared`. - * @returns the guest_access applied to this room - */ - getGuestAccess(): GuestAccess; - /** - * Find the predecessor room based on this room state. - * - * @param msc3946ProcessDynamicPredecessor - if true, look for an - * m.room.predecessor state event and use it if found (MSC3946). - * @returns null if this room has no predecessor. Otherwise, returns - * the roomId, last eventId and viaServers of the predecessor room. - * - * If msc3946ProcessDynamicPredecessor is true, use m.predecessor events - * as well as m.room.create events to find predecessors. - * - * Note: if an m.predecessor event is used, eventId may be undefined - * since last_known_event_id is optional. - * - * Note: viaServers may be undefined, and will definitely be undefined if - * this predecessor comes from a RoomCreate event (rather than a - * RoomPredecessor, which has the optional via_servers property). - */ - findPredecessor(msc3946ProcessDynamicPredecessor?: boolean): { - roomId: string; - eventId?: string; - viaServers?: string[]; - } | null; - private updateThirdPartyTokenCache; - private updateDisplayNameCache; -} -export {}; -//# sourceMappingURL=room-state.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts.map deleted file mode 100644 index 090c925..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-state.d.ts","sourceRoot":"","sources":["../../src/models/room-state.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js deleted file mode 100644 index a99ea32..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js +++ /dev/null @@ -1,949 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomStateEvent = exports.RoomState = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _roomMember = require("./room-member"); -var _logger = require("../logger"); -var utils = _interopRequireWildcard(require("../utils")); -var _event = require("../@types/event"); -var _event2 = require("./event"); -var _partials = require("../@types/partials"); -var _typedEventEmitter = require("./typed-event-emitter"); -var _beacon = require("./beacon"); -var _ReEmitter = require("../ReEmitter"); -var _beacon2 = require("../@types/beacon"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -// possible statuses for out-of-band member loading -var OobStatus; -(function (OobStatus) { - OobStatus[OobStatus["NotStarted"] = 0] = "NotStarted"; - OobStatus[OobStatus["InProgress"] = 1] = "InProgress"; - OobStatus[OobStatus["Finished"] = 2] = "Finished"; -})(OobStatus || (OobStatus = {})); -let RoomStateEvent; -exports.RoomStateEvent = RoomStateEvent; -(function (RoomStateEvent) { - RoomStateEvent["Events"] = "RoomState.events"; - RoomStateEvent["Members"] = "RoomState.members"; - RoomStateEvent["NewMember"] = "RoomState.newMember"; - RoomStateEvent["Update"] = "RoomState.update"; - RoomStateEvent["BeaconLiveness"] = "RoomState.BeaconLiveness"; - RoomStateEvent["Marker"] = "RoomState.Marker"; -})(RoomStateEvent || (exports.RoomStateEvent = RoomStateEvent = {})); -class RoomState extends _typedEventEmitter.TypedEventEmitter { - // userId: RoomMember - // stores fuzzy matches to a list of userIDs (applies utils.removeHiddenChars to keys) - - // 3pid invite state_key to m.room.member invite - // cache of the number of joined members - // joined members count from summary api - // once set, we know the server supports the summary api - // and we should only trust that - // we could also only trust that before OOB members - // are loaded but doesn't seem worth the hassle atm - - // same for invited member count - - // XXX: Should be read-only - // The room member dictionary, keyed on the user's ID. - // userId: RoomMember - // The state events dictionary, keyed on the event type and then the state_key value. - // Map> - // The pagination token for this state. - - /** - * Construct room state. - * - * Room State represents the state of the room at a given point. - * It can be mutated by adding state events to it. - * There are two types of room member associated with a state event: - * normal member objects (accessed via getMember/getMembers) which mutate - * with the state to represent the current state of that room/user, e.g. - * the object returned by `getMember('@bob:example.com')` will mutate to - * get a different display name if Bob later changes his display name - * in the room. - * There are also 'sentinel' members (accessed via getSentinelMember). - * These also represent the state of room members at the point in time - * represented by the RoomState object, but unlike objects from getMember, - * sentinel objects will always represent the room state as at the time - * getSentinelMember was called, so if Bob subsequently changes his display - * name, a room member object previously acquired with getSentinelMember - * will still have his old display name. Calling getSentinelMember again - * after the display name change will return a new RoomMember object - * with Bob's new display name. - * - * @param roomId - Optional. The ID of the room which has this state. - * If none is specified it just tracks paginationTokens, useful for notifTimelineSet - * @param oobMemberFlags - Optional. The state of loading out of bound members. - * As the timeline might get reset while they are loading, this state needs to be inherited - * and shared when the room state is cloned for the new timeline. - * This should only be passed from clone. - */ - constructor(roomId, oobMemberFlags = { - status: OobStatus.NotStarted - }) { - super(); - this.roomId = roomId; - this.oobMemberFlags = oobMemberFlags; - (0, _defineProperty2.default)(this, "reEmitter", new _ReEmitter.TypedReEmitter(this)); - (0, _defineProperty2.default)(this, "sentinels", {}); - (0, _defineProperty2.default)(this, "displayNameToUserIds", new Map()); - (0, _defineProperty2.default)(this, "userIdsToDisplayNames", {}); - (0, _defineProperty2.default)(this, "tokenToInvite", {}); - (0, _defineProperty2.default)(this, "joinedMemberCount", null); - (0, _defineProperty2.default)(this, "summaryJoinedMemberCount", null); - (0, _defineProperty2.default)(this, "invitedMemberCount", null); - (0, _defineProperty2.default)(this, "summaryInvitedMemberCount", null); - (0, _defineProperty2.default)(this, "modified", -1); - (0, _defineProperty2.default)(this, "members", {}); - (0, _defineProperty2.default)(this, "events", new Map()); - (0, _defineProperty2.default)(this, "paginationToken", null); - (0, _defineProperty2.default)(this, "beacons", new Map()); - (0, _defineProperty2.default)(this, "_liveBeaconIds", []); - this.updateModifiedTime(); - } - - /** - * Returns the number of joined members in this room - * This method caches the result. - * @returns The number of members in this room whose membership is 'join' - */ - getJoinedMemberCount() { - if (this.summaryJoinedMemberCount !== null) { - return this.summaryJoinedMemberCount; - } - if (this.joinedMemberCount === null) { - this.joinedMemberCount = this.getMembers().reduce((count, m) => { - return m.membership === "join" ? count + 1 : count; - }, 0); - } - return this.joinedMemberCount; - } - - /** - * Set the joined member count explicitly (like from summary part of the sync response) - * @param count - the amount of joined members - */ - setJoinedMemberCount(count) { - this.summaryJoinedMemberCount = count; - } - - /** - * Returns the number of invited members in this room - * @returns The number of members in this room whose membership is 'invite' - */ - getInvitedMemberCount() { - if (this.summaryInvitedMemberCount !== null) { - return this.summaryInvitedMemberCount; - } - if (this.invitedMemberCount === null) { - this.invitedMemberCount = this.getMembers().reduce((count, m) => { - return m.membership === "invite" ? count + 1 : count; - }, 0); - } - return this.invitedMemberCount; - } - - /** - * Set the amount of invited members in this room - * @param count - the amount of invited members - */ - setInvitedMemberCount(count) { - this.summaryInvitedMemberCount = count; - } - - /** - * Get all RoomMembers in this room. - * @returns A list of RoomMembers. - */ - getMembers() { - return Object.values(this.members); - } - - /** - * Get all RoomMembers in this room, excluding the user IDs provided. - * @param excludedIds - The user IDs to exclude. - * @returns A list of RoomMembers. - */ - getMembersExcept(excludedIds) { - return this.getMembers().filter(m => !excludedIds.includes(m.userId)); - } - - /** - * Get a room member by their user ID. - * @param userId - The room member's user ID. - * @returns The member or null if they do not exist. - */ - getMember(userId) { - return this.members[userId] || null; - } - - /** - * Get a room member whose properties will not change with this room state. You - * typically want this if you want to attach a RoomMember to a MatrixEvent which - * may no longer be represented correctly by Room.currentState or Room.oldState. - * The term 'sentinel' refers to the fact that this RoomMember is an unchanging - * guardian for state at this particular point in time. - * @param userId - The room member's user ID. - * @returns The member or null if they do not exist. - */ - getSentinelMember(userId) { - if (!userId) return null; - let sentinel = this.sentinels[userId]; - if (sentinel === undefined) { - sentinel = new _roomMember.RoomMember(this.roomId, userId); - const member = this.members[userId]; - if (member !== null && member !== void 0 && member.events.member) { - sentinel.setMembershipEvent(member.events.member, this); - } - this.sentinels[userId] = sentinel; - } - return sentinel; - } - - /** - * Get state events from the state of the room. - * @param eventType - The event type of the state event. - * @param stateKey - Optional. The state_key of the state event. If - * this is `undefined` then all matching state events will be - * returned. - * @returns A list of events if state_key was - * `undefined`, else a single event (or null if no match found). - */ - - getStateEvents(eventType, stateKey) { - if (!this.events.has(eventType)) { - // no match - return stateKey === undefined ? [] : null; - } - if (stateKey === undefined) { - // return all values - return Array.from(this.events.get(eventType).values()); - } - const event = this.events.get(eventType).get(stateKey); - return event ? event : null; - } - get hasLiveBeacons() { - var _this$liveBeaconIds; - return !!((_this$liveBeaconIds = this.liveBeaconIds) !== null && _this$liveBeaconIds !== void 0 && _this$liveBeaconIds.length); - } - get liveBeaconIds() { - return this._liveBeaconIds; - } - - /** - * Creates a copy of this room state so that mutations to either won't affect the other. - * @returns the copy of the room state - */ - clone() { - const copy = new RoomState(this.roomId, this.oobMemberFlags); - - // Ugly hack: because setStateEvents will mark - // members as susperseding future out of bound members - // if loading is in progress (through oobMemberFlags) - // since these are not new members, we're merely copying them - // set the status to not started - // after copying, we set back the status - const status = this.oobMemberFlags.status; - this.oobMemberFlags.status = OobStatus.NotStarted; - Array.from(this.events.values()).forEach(eventsByStateKey => { - copy.setStateEvents(Array.from(eventsByStateKey.values())); - }); - - // Ugly hack: see above - this.oobMemberFlags.status = status; - if (this.summaryInvitedMemberCount !== null) { - copy.setInvitedMemberCount(this.getInvitedMemberCount()); - } - if (this.summaryJoinedMemberCount !== null) { - copy.setJoinedMemberCount(this.getJoinedMemberCount()); - } - - // copy out of band flags if needed - if (this.oobMemberFlags.status == OobStatus.Finished) { - // copy markOutOfBand flags - this.getMembers().forEach(member => { - if (member.isOutOfBand()) { - var _copy$getMember; - (_copy$getMember = copy.getMember(member.userId)) === null || _copy$getMember === void 0 ? void 0 : _copy$getMember.markOutOfBand(); - } - }); - } - return copy; - } - - /** - * Add previously unknown state events. - * When lazy loading members while back-paginating, - * the relevant room state for the timeline chunk at the end - * of the chunk can be set with this method. - * @param events - state events to prepend - */ - setUnknownStateEvents(events) { - const unknownStateEvents = events.filter(event => { - return !this.events.has(event.getType()) || !this.events.get(event.getType()).has(event.getStateKey()); - }); - this.setStateEvents(unknownStateEvents); - } - - /** - * Add an array of one or more state MatrixEvents, overwriting any existing - * state with the same `{type, stateKey}` tuple. Will fire "RoomState.events" - * for every event added. May fire "RoomState.members" if there are - * `m.room.member` events. May fire "RoomStateEvent.Marker" if there are - * `UNSTABLE_MSC2716_MARKER` events. - * @param stateEvents - a list of state events for this room. - * - * @remarks - * Fires {@link RoomStateEvent.Members} - * Fires {@link RoomStateEvent.NewMember} - * Fires {@link RoomStateEvent.Events} - * Fires {@link RoomStateEvent.Marker} - */ - setStateEvents(stateEvents, markerFoundOptions) { - this.updateModifiedTime(); - - // update the core event dict - stateEvents.forEach(event => { - if (event.getRoomId() !== this.roomId || !event.isState()) return; - if (_beacon2.M_BEACON_INFO.matches(event.getType())) { - this.setBeacon(event); - } - const lastStateEvent = this.getStateEventMatching(event); - this.setStateEvent(event); - if (event.getType() === _event.EventType.RoomMember) { - var _event$getContent$dis; - this.updateDisplayNameCache(event.getStateKey(), (_event$getContent$dis = event.getContent().displayname) !== null && _event$getContent$dis !== void 0 ? _event$getContent$dis : ""); - this.updateThirdPartyTokenCache(event); - } - this.emit(RoomStateEvent.Events, event, this, lastStateEvent); - }); - this.onBeaconLivenessChange(); - // update higher level data structures. This needs to be done AFTER the - // core event dict as these structures may depend on other state events in - // the given array (e.g. disambiguating display names in one go to do both - // clashing names rather than progressively which only catches 1 of them). - stateEvents.forEach(event => { - if (event.getRoomId() !== this.roomId || !event.isState()) return; - if (event.getType() === _event.EventType.RoomMember) { - const userId = event.getStateKey(); - - // leave events apparently elide the displayname or avatar_url, - // so let's fake one up so that we don't leak user ids - // into the timeline - if (event.getContent().membership === "leave" || event.getContent().membership === "ban") { - event.getContent().avatar_url = event.getContent().avatar_url || event.getPrevContent().avatar_url; - event.getContent().displayname = event.getContent().displayname || event.getPrevContent().displayname; - } - const member = this.getOrCreateMember(userId, event); - member.setMembershipEvent(event, this); - this.updateMember(member); - this.emit(RoomStateEvent.Members, event, this, member); - } else if (event.getType() === _event.EventType.RoomPowerLevels) { - // events with unknown state keys should be ignored - // and should not aggregate onto members power levels - if (event.getStateKey() !== "") { - return; - } - const members = Object.values(this.members); - members.forEach(member => { - // We only propagate `RoomState.members` event if the - // power levels has been changed - // large room suffer from large re-rendering especially when not needed - const oldLastModified = member.getLastModifiedTime(); - member.setPowerLevelEvent(event); - if (oldLastModified !== member.getLastModifiedTime()) { - this.emit(RoomStateEvent.Members, event, this, member); - } - }); - - // assume all our sentinels are now out-of-date - this.sentinels = {}; - } else if (_event.UNSTABLE_MSC2716_MARKER.matches(event.getType())) { - this.emit(RoomStateEvent.Marker, event, markerFoundOptions); - } - }); - this.emit(RoomStateEvent.Update, this); - } - async processBeaconEvents(events, matrixClient) { - if (!events.length || - // discard locations if we have no beacons - !this.beacons.size) { - return; - } - const beaconByEventIdDict = [...this.beacons.values()].reduce((dict, beacon) => { - dict[beacon.beaconInfoId] = beacon; - return dict; - }, {}); - const processBeaconRelation = (beaconInfoEventId, event) => { - if (!_beacon2.M_BEACON.matches(event.getType())) { - return; - } - const beacon = beaconByEventIdDict[beaconInfoEventId]; - if (beacon) { - beacon.addLocations([event]); - } - }; - for (const event of events) { - var _event$getRelation; - const relatedToEventId = (_event$getRelation = event.getRelation()) === null || _event$getRelation === void 0 ? void 0 : _event$getRelation.event_id; - // not related to a beacon we know about; discard - if (!relatedToEventId || !beaconByEventIdDict[relatedToEventId]) return; - if (!_beacon2.M_BEACON.matches(event.getType()) && !event.isEncrypted()) return; - try { - await matrixClient.decryptEventIfNeeded(event); - processBeaconRelation(relatedToEventId, event); - } catch { - if (event.isDecryptionFailure()) { - // add an event listener for once the event is decrypted. - event.once(_event2.MatrixEventEvent.Decrypted, async () => { - processBeaconRelation(relatedToEventId, event); - }); - } - } - } - } - - /** - * Looks up a member by the given userId, and if it doesn't exist, - * create it and emit the `RoomState.newMember` event. - * This method makes sure the member is added to the members dictionary - * before emitting, as this is done from setStateEvents and setOutOfBandMember. - * @param userId - the id of the user to look up - * @param event - the membership event for the (new) member. Used to emit. - * @returns the member, existing or newly created. - * - * @remarks - * Fires {@link RoomStateEvent.NewMember} - */ - getOrCreateMember(userId, event) { - let member = this.members[userId]; - if (!member) { - member = new _roomMember.RoomMember(this.roomId, userId); - // add member to members before emitting any events, - // as event handlers often lookup the member - this.members[userId] = member; - this.emit(RoomStateEvent.NewMember, event, this, member); - } - return member; - } - setStateEvent(event) { - if (!this.events.has(event.getType())) { - this.events.set(event.getType(), new Map()); - } - this.events.get(event.getType()).set(event.getStateKey(), event); - } - - /** - * @experimental - */ - setBeacon(event) { - const beaconIdentifier = (0, _beacon.getBeaconInfoIdentifier)(event); - if (this.beacons.has(beaconIdentifier)) { - const beacon = this.beacons.get(beaconIdentifier); - if (event.isRedacted()) { - var _event$getRedactionEv; - if (beacon.beaconInfoId === ((_event$getRedactionEv = event.getRedactionEvent()) === null || _event$getRedactionEv === void 0 ? void 0 : _event$getRedactionEv.redacts)) { - beacon.destroy(); - this.beacons.delete(beaconIdentifier); - } - return; - } - return beacon.update(event); - } - if (event.isRedacted()) { - return; - } - const beacon = new _beacon.Beacon(event); - this.reEmitter.reEmit(beacon, [_beacon.BeaconEvent.New, _beacon.BeaconEvent.Update, _beacon.BeaconEvent.Destroy, _beacon.BeaconEvent.LivenessChange]); - this.emit(_beacon.BeaconEvent.New, event, beacon); - beacon.on(_beacon.BeaconEvent.LivenessChange, this.onBeaconLivenessChange.bind(this)); - beacon.on(_beacon.BeaconEvent.Destroy, this.onBeaconLivenessChange.bind(this)); - this.beacons.set(beacon.identifier, beacon); - } - - /** - * @experimental - * Check liveness of room beacons - * emit RoomStateEvent.BeaconLiveness event - */ - onBeaconLivenessChange() { - this._liveBeaconIds = Array.from(this.beacons.values()).filter(beacon => beacon.isLive).map(beacon => beacon.identifier); - this.emit(RoomStateEvent.BeaconLiveness, this, this.hasLiveBeacons); - } - getStateEventMatching(event) { - var _this$events$get$get, _this$events$get; - return (_this$events$get$get = (_this$events$get = this.events.get(event.getType())) === null || _this$events$get === void 0 ? void 0 : _this$events$get.get(event.getStateKey())) !== null && _this$events$get$get !== void 0 ? _this$events$get$get : null; - } - updateMember(member) { - // this member may have a power level already, so set it. - const pwrLvlEvent = this.getStateEvents(_event.EventType.RoomPowerLevels, ""); - if (pwrLvlEvent) { - member.setPowerLevelEvent(pwrLvlEvent); - } - - // blow away the sentinel which is now outdated - delete this.sentinels[member.userId]; - this.members[member.userId] = member; - this.joinedMemberCount = null; - this.invitedMemberCount = null; - } - - /** - * Get the out-of-band members loading state, whether loading is needed or not. - * Note that loading might be in progress and hence isn't needed. - * @returns whether or not the members of this room need to be loaded - */ - needsOutOfBandMembers() { - return this.oobMemberFlags.status === OobStatus.NotStarted; - } - - /** - * Check if loading of out-of-band-members has completed - * - * @returns true if the full membership list of this room has been loaded. False if it is not started or is in - * progress. - */ - outOfBandMembersReady() { - return this.oobMemberFlags.status === OobStatus.Finished; - } - - /** - * Mark this room state as waiting for out-of-band members, - * ensuring it doesn't ask for them to be requested again - * through needsOutOfBandMembers - */ - markOutOfBandMembersStarted() { - if (this.oobMemberFlags.status !== OobStatus.NotStarted) { - return; - } - this.oobMemberFlags.status = OobStatus.InProgress; - } - - /** - * Mark this room state as having failed to fetch out-of-band members - */ - markOutOfBandMembersFailed() { - if (this.oobMemberFlags.status !== OobStatus.InProgress) { - return; - } - this.oobMemberFlags.status = OobStatus.NotStarted; - } - - /** - * Clears the loaded out-of-band members - */ - clearOutOfBandMembers() { - let count = 0; - Object.keys(this.members).forEach(userId => { - const member = this.members[userId]; - if (member.isOutOfBand()) { - ++count; - delete this.members[userId]; - } - }); - _logger.logger.log(`LL: RoomState removed ${count} members...`); - this.oobMemberFlags.status = OobStatus.NotStarted; - } - - /** - * Sets the loaded out-of-band members. - * @param stateEvents - array of membership state events - */ - setOutOfBandMembers(stateEvents) { - _logger.logger.log(`LL: RoomState about to set ${stateEvents.length} OOB members ...`); - if (this.oobMemberFlags.status !== OobStatus.InProgress) { - return; - } - _logger.logger.log(`LL: RoomState put in finished state ...`); - this.oobMemberFlags.status = OobStatus.Finished; - stateEvents.forEach(e => this.setOutOfBandMember(e)); - this.emit(RoomStateEvent.Update, this); - } - - /** - * Sets a single out of band member, used by both setOutOfBandMembers and clone - * @param stateEvent - membership state event - */ - setOutOfBandMember(stateEvent) { - if (stateEvent.getType() !== _event.EventType.RoomMember) { - return; - } - const userId = stateEvent.getStateKey(); - const existingMember = this.getMember(userId); - // never replace members received as part of the sync - if (existingMember && !existingMember.isOutOfBand()) { - return; - } - const member = this.getOrCreateMember(userId, stateEvent); - member.setMembershipEvent(stateEvent, this); - // needed to know which members need to be stored seperately - // as they are not part of the sync accumulator - // this is cleared by setMembershipEvent so when it's updated through /sync - member.markOutOfBand(); - this.updateDisplayNameCache(member.userId, member.name); - this.setStateEvent(stateEvent); - this.updateMember(member); - this.emit(RoomStateEvent.Members, stateEvent, this, member); - } - - /** - * Set the current typing event for this room. - * @param event - The typing event - */ - setTypingEvent(event) { - Object.values(this.members).forEach(function (member) { - member.setTypingEvent(event); - }); - } - - /** - * Get the m.room.member event which has the given third party invite token. - * - * @param token - The token - * @returns The m.room.member event or null - */ - getInviteForThreePidToken(token) { - return this.tokenToInvite[token] || null; - } - - /** - * Update the last modified time to the current time. - */ - updateModifiedTime() { - this.modified = Date.now(); - } - - /** - * Get the timestamp when this room state was last updated. This timestamp is - * updated when this object has received new state events. - * @returns The timestamp - */ - getLastModifiedTime() { - return this.modified; - } - - /** - * Get user IDs with the specified or similar display names. - * @param displayName - The display name to get user IDs from. - * @returns An array of user IDs or an empty array. - */ - getUserIdsWithDisplayName(displayName) { - var _this$displayNameToUs; - return (_this$displayNameToUs = this.displayNameToUserIds.get(utils.removeHiddenChars(displayName))) !== null && _this$displayNameToUs !== void 0 ? _this$displayNameToUs : []; - } - - /** - * Returns true if userId is in room, event is not redacted and either sender of - * mxEvent or has power level sufficient to redact events other than their own. - * @param mxEvent - The event to test permission for - * @param userId - The user ID of the user to test permission for - * @returns true if the given used ID can redact given event - */ - maySendRedactionForEvent(mxEvent, userId) { - const member = this.getMember(userId); - if (!member || member.membership === "leave") return false; - if (mxEvent.status || mxEvent.isRedacted()) return false; - - // The user may have been the sender, but they can't redact their own message - // if redactions are blocked. - const canRedact = this.maySendEvent(_event.EventType.RoomRedaction, userId); - if (mxEvent.getSender() === userId) return canRedact; - return this.hasSufficientPowerLevelFor("redact", member.powerLevel); - } - - /** - * Returns true if the given power level is sufficient for action - * @param action - The type of power level to check - * @param powerLevel - The power level of the member - * @returns true if the given power level is sufficient - */ - hasSufficientPowerLevelFor(action, powerLevel) { - const powerLevelsEvent = this.getStateEvents(_event.EventType.RoomPowerLevels, ""); - let powerLevels = {}; - if (powerLevelsEvent) { - powerLevels = powerLevelsEvent.getContent(); - } - let requiredLevel = 50; - if (utils.isNumber(powerLevels[action])) { - requiredLevel = powerLevels[action]; - } - return powerLevel >= requiredLevel; - } - - /** - * Short-form for maySendEvent('m.room.message', userId) - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID should be permitted to send - * message events into the given room. - */ - maySendMessage(userId) { - return this.maySendEventOfType(_event.EventType.RoomMessage, userId, false); - } - - /** - * Returns true if the given user ID has permission to send a normal - * event of type `eventType` into this room. - * @param eventType - The type of event to test - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID should be permitted to send - * the given type of event into this room, - * according to the room's state. - */ - maySendEvent(eventType, userId) { - return this.maySendEventOfType(eventType, userId, false); - } - - /** - * Returns true if the given MatrixClient has permission to send a state - * event of type `stateEventType` into this room. - * @param stateEventType - The type of state events to test - * @param cli - The client to test permission for - * @returns true if the given client should be permitted to send - * the given type of state event into this room, - * according to the room's state. - */ - mayClientSendStateEvent(stateEventType, cli) { - if (cli.isGuest() || !cli.credentials.userId) { - return false; - } - return this.maySendStateEvent(stateEventType, cli.credentials.userId); - } - - /** - * Returns true if the given user ID has permission to send a state - * event of type `stateEventType` into this room. - * @param stateEventType - The type of state events to test - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID should be permitted to send - * the given type of state event into this room, - * according to the room's state. - */ - maySendStateEvent(stateEventType, userId) { - return this.maySendEventOfType(stateEventType, userId, true); - } - - /** - * Returns true if the given user ID has permission to send a normal or state - * event of type `eventType` into this room. - * @param eventType - The type of event to test - * @param userId - The user ID of the user to test permission for - * @param state - If true, tests if the user may send a state - event of this type. Otherwise tests whether - they may send a regular event. - * @returns true if the given user ID should be permitted to send - * the given type of event into this room, - * according to the room's state. - */ - maySendEventOfType(eventType, userId, state) { - const powerLevelsEvent = this.getStateEvents(_event.EventType.RoomPowerLevels, ""); - let powerLevels; - let eventsLevels = {}; - let stateDefault = 0; - let eventsDefault = 0; - let powerLevel = 0; - if (powerLevelsEvent) { - powerLevels = powerLevelsEvent.getContent(); - eventsLevels = powerLevels.events || {}; - if (Number.isSafeInteger(powerLevels.state_default)) { - stateDefault = powerLevels.state_default; - } else { - stateDefault = 50; - } - const userPowerLevel = powerLevels.users && powerLevels.users[userId]; - if (Number.isSafeInteger(userPowerLevel)) { - powerLevel = userPowerLevel; - } else if (Number.isSafeInteger(powerLevels.users_default)) { - powerLevel = powerLevels.users_default; - } - if (Number.isSafeInteger(powerLevels.events_default)) { - eventsDefault = powerLevels.events_default; - } - } - let requiredLevel = state ? stateDefault : eventsDefault; - if (Number.isSafeInteger(eventsLevels[eventType])) { - requiredLevel = eventsLevels[eventType]; - } - return powerLevel >= requiredLevel; - } - - /** - * Returns true if the given user ID has permission to trigger notification - * of type `notifLevelKey` - * @param notifLevelKey - The level of notification to test (eg. 'room') - * @param userId - The user ID of the user to test permission for - * @returns true if the given user ID has permission to trigger a - * notification of this type. - */ - mayTriggerNotifOfType(notifLevelKey, userId) { - const member = this.getMember(userId); - if (!member) { - return false; - } - const powerLevelsEvent = this.getStateEvents(_event.EventType.RoomPowerLevels, ""); - let notifLevel = 50; - if (powerLevelsEvent && powerLevelsEvent.getContent() && powerLevelsEvent.getContent().notifications && utils.isNumber(powerLevelsEvent.getContent().notifications[notifLevelKey])) { - notifLevel = powerLevelsEvent.getContent().notifications[notifLevelKey]; - } - return member.powerLevel >= notifLevel; - } - - /** - * Returns the join rule based on the m.room.join_rule state event, defaulting to `invite`. - * @returns the join_rule applied to this room - */ - getJoinRule() { - var _joinRuleEvent$getCon; - const joinRuleEvent = this.getStateEvents(_event.EventType.RoomJoinRules, ""); - const joinRuleContent = (_joinRuleEvent$getCon = joinRuleEvent === null || joinRuleEvent === void 0 ? void 0 : joinRuleEvent.getContent()) !== null && _joinRuleEvent$getCon !== void 0 ? _joinRuleEvent$getCon : {}; - return joinRuleContent["join_rule"] || _partials.JoinRule.Invite; - } - - /** - * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`. - * @returns the history_visibility applied to this room - */ - getHistoryVisibility() { - var _historyVisibilityEve; - const historyVisibilityEvent = this.getStateEvents(_event.EventType.RoomHistoryVisibility, ""); - const historyVisibilityContent = (_historyVisibilityEve = historyVisibilityEvent === null || historyVisibilityEvent === void 0 ? void 0 : historyVisibilityEvent.getContent()) !== null && _historyVisibilityEve !== void 0 ? _historyVisibilityEve : {}; - return historyVisibilityContent["history_visibility"] || _partials.HistoryVisibility.Shared; - } - - /** - * Returns the guest access based on the m.room.guest_access state event, defaulting to `shared`. - * @returns the guest_access applied to this room - */ - getGuestAccess() { - var _guestAccessEvent$get; - const guestAccessEvent = this.getStateEvents(_event.EventType.RoomGuestAccess, ""); - const guestAccessContent = (_guestAccessEvent$get = guestAccessEvent === null || guestAccessEvent === void 0 ? void 0 : guestAccessEvent.getContent()) !== null && _guestAccessEvent$get !== void 0 ? _guestAccessEvent$get : {}; - return guestAccessContent["guest_access"] || _partials.GuestAccess.Forbidden; - } - - /** - * Find the predecessor room based on this room state. - * - * @param msc3946ProcessDynamicPredecessor - if true, look for an - * m.room.predecessor state event and use it if found (MSC3946). - * @returns null if this room has no predecessor. Otherwise, returns - * the roomId, last eventId and viaServers of the predecessor room. - * - * If msc3946ProcessDynamicPredecessor is true, use m.predecessor events - * as well as m.room.create events to find predecessors. - * - * Note: if an m.predecessor event is used, eventId may be undefined - * since last_known_event_id is optional. - * - * Note: viaServers may be undefined, and will definitely be undefined if - * this predecessor comes from a RoomCreate event (rather than a - * RoomPredecessor, which has the optional via_servers property). - */ - findPredecessor(msc3946ProcessDynamicPredecessor = false) { - // Note: the tests for this function are against Room.findPredecessor, - // which just calls through to here. - - if (msc3946ProcessDynamicPredecessor) { - const predecessorEvent = this.getStateEvents(_event.EventType.RoomPredecessor, ""); - if (predecessorEvent) { - const content = predecessorEvent.getContent(); - const roomId = content.predecessor_room_id; - let eventId = content.last_known_event_id; - if (typeof eventId !== "string") { - eventId = undefined; - } - let viaServers = content.via_servers; - if (!Array.isArray(viaServers)) { - viaServers = undefined; - } - if (typeof roomId === "string") { - return { - roomId, - eventId, - viaServers - }; - } - } - } - const createEvent = this.getStateEvents(_event.EventType.RoomCreate, ""); - if (createEvent) { - const predecessor = createEvent.getContent()["predecessor"]; - if (predecessor) { - const roomId = predecessor["room_id"]; - if (typeof roomId === "string") { - let eventId = predecessor["event_id"]; - if (typeof eventId !== "string" || eventId === "") { - eventId = undefined; - } - return { - roomId, - eventId - }; - } - } - } - return null; - } - updateThirdPartyTokenCache(memberEvent) { - if (!memberEvent.getContent().third_party_invite) { - return; - } - const token = (memberEvent.getContent().third_party_invite.signed || {}).token; - if (!token) { - return; - } - const threePidInvite = this.getStateEvents(_event.EventType.RoomThirdPartyInvite, token); - if (!threePidInvite) { - return; - } - this.tokenToInvite[token] = memberEvent; - } - updateDisplayNameCache(userId, displayName) { - const oldName = this.userIdsToDisplayNames[userId]; - delete this.userIdsToDisplayNames[userId]; - if (oldName) { - // Remove the old name from the cache. - // We clobber the user_id > name lookup but the name -> [user_id] lookup - // means we need to remove that user ID from that array rather than nuking - // the lot. - const strippedOldName = utils.removeHiddenChars(oldName); - const existingUserIds = this.displayNameToUserIds.get(strippedOldName); - if (existingUserIds) { - // remove this user ID from this array - const filteredUserIDs = existingUserIds.filter(id => id !== userId); - this.displayNameToUserIds.set(strippedOldName, filteredUserIDs); - } - } - this.userIdsToDisplayNames[userId] = displayName; - const strippedDisplayname = displayName && utils.removeHiddenChars(displayName); - // an empty stripped displayname (undefined/'') will be set to MXID in room-member.js - if (strippedDisplayname) { - var _this$displayNameToUs2; - const arr = (_this$displayNameToUs2 = this.displayNameToUserIds.get(strippedDisplayname)) !== null && _this$displayNameToUs2 !== void 0 ? _this$displayNameToUs2 : []; - arr.push(userId); - this.displayNameToUserIds.set(strippedDisplayname, arr); - } - } -} -exports.RoomState = RoomState; -//# sourceMappingURL=room-state.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js.map deleted file mode 100644 index 60c587e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-state.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-state.js","names":["_roomMember","require","_logger","utils","_interopRequireWildcard","_event","_event2","_partials","_typedEventEmitter","_beacon","_ReEmitter","_beacon2","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","OobStatus","RoomStateEvent","exports","RoomState","TypedEventEmitter","constructor","roomId","oobMemberFlags","status","NotStarted","_defineProperty2","TypedReEmitter","Map","updateModifiedTime","getJoinedMemberCount","summaryJoinedMemberCount","joinedMemberCount","getMembers","reduce","count","m","membership","setJoinedMemberCount","getInvitedMemberCount","summaryInvitedMemberCount","invitedMemberCount","setInvitedMemberCount","values","members","getMembersExcept","excludedIds","filter","includes","userId","getMember","getSentinelMember","sentinel","sentinels","undefined","RoomMember","member","events","setMembershipEvent","getStateEvents","eventType","stateKey","Array","from","event","hasLiveBeacons","_this$liveBeaconIds","liveBeaconIds","length","_liveBeaconIds","clone","copy","forEach","eventsByStateKey","setStateEvents","Finished","isOutOfBand","_copy$getMember","markOutOfBand","setUnknownStateEvents","unknownStateEvents","getType","getStateKey","stateEvents","markerFoundOptions","getRoomId","isState","M_BEACON_INFO","matches","setBeacon","lastStateEvent","getStateEventMatching","setStateEvent","EventType","_event$getContent$dis","updateDisplayNameCache","getContent","displayname","updateThirdPartyTokenCache","emit","Events","onBeaconLivenessChange","avatar_url","getPrevContent","getOrCreateMember","updateMember","Members","RoomPowerLevels","oldLastModified","getLastModifiedTime","setPowerLevelEvent","UNSTABLE_MSC2716_MARKER","Marker","Update","processBeaconEvents","matrixClient","beacons","size","beaconByEventIdDict","dict","beacon","beaconInfoId","processBeaconRelation","beaconInfoEventId","M_BEACON","addLocations","_event$getRelation","relatedToEventId","getRelation","event_id","isEncrypted","decryptEventIfNeeded","isDecryptionFailure","once","MatrixEventEvent","Decrypted","NewMember","beaconIdentifier","getBeaconInfoIdentifier","isRedacted","_event$getRedactionEv","getRedactionEvent","redacts","destroy","delete","update","Beacon","reEmitter","reEmit","BeaconEvent","New","Destroy","LivenessChange","on","bind","identifier","isLive","map","BeaconLiveness","_this$events$get$get","_this$events$get","pwrLvlEvent","needsOutOfBandMembers","outOfBandMembersReady","markOutOfBandMembersStarted","InProgress","markOutOfBandMembersFailed","clearOutOfBandMembers","keys","logger","log","setOutOfBandMembers","e","setOutOfBandMember","stateEvent","existingMember","name","setTypingEvent","getInviteForThreePidToken","token","tokenToInvite","modified","Date","now","getUserIdsWithDisplayName","displayName","_this$displayNameToUs","displayNameToUserIds","removeHiddenChars","maySendRedactionForEvent","mxEvent","canRedact","maySendEvent","RoomRedaction","getSender","hasSufficientPowerLevelFor","powerLevel","action","powerLevelsEvent","powerLevels","requiredLevel","isNumber","maySendMessage","maySendEventOfType","RoomMessage","mayClientSendStateEvent","stateEventType","cli","isGuest","credentials","maySendStateEvent","state","eventsLevels","stateDefault","eventsDefault","Number","isSafeInteger","state_default","userPowerLevel","users","users_default","events_default","mayTriggerNotifOfType","notifLevelKey","notifLevel","notifications","getJoinRule","_joinRuleEvent$getCon","joinRuleEvent","RoomJoinRules","joinRuleContent","JoinRule","Invite","getHistoryVisibility","_historyVisibilityEve","historyVisibilityEvent","RoomHistoryVisibility","historyVisibilityContent","HistoryVisibility","Shared","getGuestAccess","_guestAccessEvent$get","guestAccessEvent","RoomGuestAccess","guestAccessContent","GuestAccess","Forbidden","findPredecessor","msc3946ProcessDynamicPredecessor","predecessorEvent","RoomPredecessor","content","predecessor_room_id","eventId","last_known_event_id","viaServers","via_servers","isArray","createEvent","RoomCreate","predecessor","memberEvent","third_party_invite","signed","threePidInvite","RoomThirdPartyInvite","oldName","userIdsToDisplayNames","strippedOldName","existingUserIds","filteredUserIDs","id","strippedDisplayname","_this$displayNameToUs2","arr","push"],"sources":["../../src/models/room-state.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { RoomMember } from \"./room-member\";\nimport { logger } from \"../logger\";\nimport * as utils from \"../utils\";\nimport { EventType, UNSTABLE_MSC2716_MARKER } from \"../@types/event\";\nimport { IEvent, MatrixEvent, MatrixEventEvent } from \"./event\";\nimport { MatrixClient } from \"../client\";\nimport { GuestAccess, HistoryVisibility, IJoinRuleEventContent, JoinRule } from \"../@types/partials\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\nimport { Beacon, BeaconEvent, BeaconEventHandlerMap, getBeaconInfoIdentifier, BeaconIdentifier } from \"./beacon\";\nimport { TypedReEmitter } from \"../ReEmitter\";\nimport { M_BEACON, M_BEACON_INFO } from \"../@types/beacon\";\n\nexport interface IMarkerFoundOptions {\n /** Whether the timeline was empty before the marker event arrived in the\n * room. This could be happen in a variety of cases:\n * 1. From the initial sync\n * 2. It's the first state we're seeing after joining the room\n * 3. Or whether it's coming from `syncFromCache`\n *\n * A marker event refers to `UNSTABLE_MSC2716_MARKER` and indicates that\n * history was imported somewhere back in time. It specifically points to an\n * MSC2716 insertion event where the history was imported at. Marker events\n * are sent as state events so they are easily discoverable by clients and\n * homeservers and don't get lost in timeline gaps.\n */\n timelineWasEmpty?: boolean;\n}\n\n// possible statuses for out-of-band member loading\nenum OobStatus {\n NotStarted,\n InProgress,\n Finished,\n}\n\nexport interface IPowerLevelsContent {\n users?: Record;\n events?: Record;\n // eslint-disable-next-line camelcase\n users_default?: number;\n // eslint-disable-next-line camelcase\n events_default?: number;\n // eslint-disable-next-line camelcase\n state_default?: number;\n ban?: number;\n kick?: number;\n redact?: number;\n}\n\nexport enum RoomStateEvent {\n Events = \"RoomState.events\",\n Members = \"RoomState.members\",\n NewMember = \"RoomState.newMember\",\n Update = \"RoomState.update\", // signals batches of updates without specificity\n BeaconLiveness = \"RoomState.BeaconLiveness\",\n Marker = \"RoomState.Marker\",\n}\n\nexport type RoomStateEventHandlerMap = {\n /**\n * Fires whenever the event dictionary in room state is updated.\n * @param event - The matrix event which caused this event to fire.\n * @param state - The room state whose RoomState.events dictionary\n * was updated.\n * @param prevEvent - The event being replaced by the new state, if\n * known. Note that this can differ from `getPrevContent()` on the new state event\n * as this is the store's view of the last state, not the previous state provided\n * by the server.\n * @example\n * ```\n * matrixClient.on(\"RoomState.events\", function(event, state, prevEvent){\n * var newStateEvent = event;\n * });\n * ```\n */\n [RoomStateEvent.Events]: (event: MatrixEvent, state: RoomState, lastStateEvent: MatrixEvent | null) => void;\n /**\n * Fires whenever a member in the members dictionary is updated in any way.\n * @param event - The matrix event which caused this event to fire.\n * @param state - The room state whose RoomState.members dictionary\n * was updated.\n * @param member - The room member that was updated.\n * @example\n * ```\n * matrixClient.on(\"RoomState.members\", function(event, state, member){\n * var newMembershipState = member.membership;\n * });\n * ```\n */\n [RoomStateEvent.Members]: (event: MatrixEvent, state: RoomState, member: RoomMember) => void;\n /**\n * Fires whenever a member is added to the members dictionary. The RoomMember\n * will not be fully populated yet (e.g. no membership state) but will already\n * be available in the members dictionary.\n * @param event - The matrix event which caused this event to fire.\n * @param state - The room state whose RoomState.members dictionary\n * was updated with a new entry.\n * @param member - The room member that was added.\n * @example\n * ```\n * matrixClient.on(\"RoomState.newMember\", function(event, state, member){\n * // add event listeners on 'member'\n * });\n * ```\n */\n [RoomStateEvent.NewMember]: (event: MatrixEvent, state: RoomState, member: RoomMember) => void;\n [RoomStateEvent.Update]: (state: RoomState) => void;\n [RoomStateEvent.BeaconLiveness]: (state: RoomState, hasLiveBeacons: boolean) => void;\n [RoomStateEvent.Marker]: (event: MatrixEvent, setStateOptions?: IMarkerFoundOptions) => void;\n [BeaconEvent.New]: (event: MatrixEvent, beacon: Beacon) => void;\n};\n\ntype EmittedEvents = RoomStateEvent | BeaconEvent;\ntype EventHandlerMap = RoomStateEventHandlerMap & BeaconEventHandlerMap;\n\nexport class RoomState extends TypedEventEmitter {\n public readonly reEmitter = new TypedReEmitter(this);\n private sentinels: Record = {}; // userId: RoomMember\n // stores fuzzy matches to a list of userIDs (applies utils.removeHiddenChars to keys)\n private displayNameToUserIds = new Map();\n private userIdsToDisplayNames: Record = {};\n private tokenToInvite: Record = {}; // 3pid invite state_key to m.room.member invite\n private joinedMemberCount: number | null = null; // cache of the number of joined members\n // joined members count from summary api\n // once set, we know the server supports the summary api\n // and we should only trust that\n // we could also only trust that before OOB members\n // are loaded but doesn't seem worth the hassle atm\n private summaryJoinedMemberCount: number | null = null;\n // same for invited member count\n private invitedMemberCount: number | null = null;\n private summaryInvitedMemberCount: number | null = null;\n private modified = -1;\n\n // XXX: Should be read-only\n // The room member dictionary, keyed on the user's ID.\n public members: Record = {}; // userId: RoomMember\n // The state events dictionary, keyed on the event type and then the state_key value.\n public events = new Map>(); // Map>\n // The pagination token for this state.\n public paginationToken: string | null = null;\n\n public readonly beacons = new Map();\n private _liveBeaconIds: BeaconIdentifier[] = [];\n\n /**\n * Construct room state.\n *\n * Room State represents the state of the room at a given point.\n * It can be mutated by adding state events to it.\n * There are two types of room member associated with a state event:\n * normal member objects (accessed via getMember/getMembers) which mutate\n * with the state to represent the current state of that room/user, e.g.\n * the object returned by `getMember('@bob:example.com')` will mutate to\n * get a different display name if Bob later changes his display name\n * in the room.\n * There are also 'sentinel' members (accessed via getSentinelMember).\n * These also represent the state of room members at the point in time\n * represented by the RoomState object, but unlike objects from getMember,\n * sentinel objects will always represent the room state as at the time\n * getSentinelMember was called, so if Bob subsequently changes his display\n * name, a room member object previously acquired with getSentinelMember\n * will still have his old display name. Calling getSentinelMember again\n * after the display name change will return a new RoomMember object\n * with Bob's new display name.\n *\n * @param roomId - Optional. The ID of the room which has this state.\n * If none is specified it just tracks paginationTokens, useful for notifTimelineSet\n * @param oobMemberFlags - Optional. The state of loading out of bound members.\n * As the timeline might get reset while they are loading, this state needs to be inherited\n * and shared when the room state is cloned for the new timeline.\n * This should only be passed from clone.\n */\n public constructor(public readonly roomId: string, private oobMemberFlags = { status: OobStatus.NotStarted }) {\n super();\n this.updateModifiedTime();\n }\n\n /**\n * Returns the number of joined members in this room\n * This method caches the result.\n * @returns The number of members in this room whose membership is 'join'\n */\n public getJoinedMemberCount(): number {\n if (this.summaryJoinedMemberCount !== null) {\n return this.summaryJoinedMemberCount;\n }\n if (this.joinedMemberCount === null) {\n this.joinedMemberCount = this.getMembers().reduce((count, m) => {\n return m.membership === \"join\" ? count + 1 : count;\n }, 0);\n }\n return this.joinedMemberCount;\n }\n\n /**\n * Set the joined member count explicitly (like from summary part of the sync response)\n * @param count - the amount of joined members\n */\n public setJoinedMemberCount(count: number): void {\n this.summaryJoinedMemberCount = count;\n }\n\n /**\n * Returns the number of invited members in this room\n * @returns The number of members in this room whose membership is 'invite'\n */\n public getInvitedMemberCount(): number {\n if (this.summaryInvitedMemberCount !== null) {\n return this.summaryInvitedMemberCount;\n }\n if (this.invitedMemberCount === null) {\n this.invitedMemberCount = this.getMembers().reduce((count, m) => {\n return m.membership === \"invite\" ? count + 1 : count;\n }, 0);\n }\n return this.invitedMemberCount;\n }\n\n /**\n * Set the amount of invited members in this room\n * @param count - the amount of invited members\n */\n public setInvitedMemberCount(count: number): void {\n this.summaryInvitedMemberCount = count;\n }\n\n /**\n * Get all RoomMembers in this room.\n * @returns A list of RoomMembers.\n */\n public getMembers(): RoomMember[] {\n return Object.values(this.members);\n }\n\n /**\n * Get all RoomMembers in this room, excluding the user IDs provided.\n * @param excludedIds - The user IDs to exclude.\n * @returns A list of RoomMembers.\n */\n public getMembersExcept(excludedIds: string[]): RoomMember[] {\n return this.getMembers().filter((m) => !excludedIds.includes(m.userId));\n }\n\n /**\n * Get a room member by their user ID.\n * @param userId - The room member's user ID.\n * @returns The member or null if they do not exist.\n */\n public getMember(userId: string): RoomMember | null {\n return this.members[userId] || null;\n }\n\n /**\n * Get a room member whose properties will not change with this room state. You\n * typically want this if you want to attach a RoomMember to a MatrixEvent which\n * may no longer be represented correctly by Room.currentState or Room.oldState.\n * The term 'sentinel' refers to the fact that this RoomMember is an unchanging\n * guardian for state at this particular point in time.\n * @param userId - The room member's user ID.\n * @returns The member or null if they do not exist.\n */\n public getSentinelMember(userId: string): RoomMember | null {\n if (!userId) return null;\n let sentinel = this.sentinels[userId];\n\n if (sentinel === undefined) {\n sentinel = new RoomMember(this.roomId, userId);\n const member = this.members[userId];\n if (member?.events.member) {\n sentinel.setMembershipEvent(member.events.member, this);\n }\n this.sentinels[userId] = sentinel;\n }\n return sentinel;\n }\n\n /**\n * Get state events from the state of the room.\n * @param eventType - The event type of the state event.\n * @param stateKey - Optional. The state_key of the state event. If\n * this is `undefined` then all matching state events will be\n * returned.\n * @returns A list of events if state_key was\n * `undefined`, else a single event (or null if no match found).\n */\n public getStateEvents(eventType: EventType | string): MatrixEvent[];\n public getStateEvents(eventType: EventType | string, stateKey: string): MatrixEvent | null;\n public getStateEvents(eventType: EventType | string, stateKey?: string): MatrixEvent[] | MatrixEvent | null {\n if (!this.events.has(eventType)) {\n // no match\n return stateKey === undefined ? [] : null;\n }\n if (stateKey === undefined) {\n // return all values\n return Array.from(this.events.get(eventType)!.values());\n }\n const event = this.events.get(eventType)!.get(stateKey);\n return event ? event : null;\n }\n\n public get hasLiveBeacons(): boolean {\n return !!this.liveBeaconIds?.length;\n }\n\n public get liveBeaconIds(): BeaconIdentifier[] {\n return this._liveBeaconIds;\n }\n\n /**\n * Creates a copy of this room state so that mutations to either won't affect the other.\n * @returns the copy of the room state\n */\n public clone(): RoomState {\n const copy = new RoomState(this.roomId, this.oobMemberFlags);\n\n // Ugly hack: because setStateEvents will mark\n // members as susperseding future out of bound members\n // if loading is in progress (through oobMemberFlags)\n // since these are not new members, we're merely copying them\n // set the status to not started\n // after copying, we set back the status\n const status = this.oobMemberFlags.status;\n this.oobMemberFlags.status = OobStatus.NotStarted;\n\n Array.from(this.events.values()).forEach((eventsByStateKey) => {\n copy.setStateEvents(Array.from(eventsByStateKey.values()));\n });\n\n // Ugly hack: see above\n this.oobMemberFlags.status = status;\n\n if (this.summaryInvitedMemberCount !== null) {\n copy.setInvitedMemberCount(this.getInvitedMemberCount());\n }\n if (this.summaryJoinedMemberCount !== null) {\n copy.setJoinedMemberCount(this.getJoinedMemberCount());\n }\n\n // copy out of band flags if needed\n if (this.oobMemberFlags.status == OobStatus.Finished) {\n // copy markOutOfBand flags\n this.getMembers().forEach((member) => {\n if (member.isOutOfBand()) {\n copy.getMember(member.userId)?.markOutOfBand();\n }\n });\n }\n\n return copy;\n }\n\n /**\n * Add previously unknown state events.\n * When lazy loading members while back-paginating,\n * the relevant room state for the timeline chunk at the end\n * of the chunk can be set with this method.\n * @param events - state events to prepend\n */\n public setUnknownStateEvents(events: MatrixEvent[]): void {\n const unknownStateEvents = events.filter((event) => {\n return !this.events.has(event.getType()) || !this.events.get(event.getType())!.has(event.getStateKey()!);\n });\n\n this.setStateEvents(unknownStateEvents);\n }\n\n /**\n * Add an array of one or more state MatrixEvents, overwriting any existing\n * state with the same `{type, stateKey}` tuple. Will fire \"RoomState.events\"\n * for every event added. May fire \"RoomState.members\" if there are\n * `m.room.member` events. May fire \"RoomStateEvent.Marker\" if there are\n * `UNSTABLE_MSC2716_MARKER` events.\n * @param stateEvents - a list of state events for this room.\n *\n * @remarks\n * Fires {@link RoomStateEvent.Members}\n * Fires {@link RoomStateEvent.NewMember}\n * Fires {@link RoomStateEvent.Events}\n * Fires {@link RoomStateEvent.Marker}\n */\n public setStateEvents(stateEvents: MatrixEvent[], markerFoundOptions?: IMarkerFoundOptions): void {\n this.updateModifiedTime();\n\n // update the core event dict\n stateEvents.forEach((event) => {\n if (event.getRoomId() !== this.roomId || !event.isState()) return;\n\n if (M_BEACON_INFO.matches(event.getType())) {\n this.setBeacon(event);\n }\n\n const lastStateEvent = this.getStateEventMatching(event);\n this.setStateEvent(event);\n if (event.getType() === EventType.RoomMember) {\n this.updateDisplayNameCache(event.getStateKey()!, event.getContent().displayname ?? \"\");\n this.updateThirdPartyTokenCache(event);\n }\n this.emit(RoomStateEvent.Events, event, this, lastStateEvent);\n });\n\n this.onBeaconLivenessChange();\n // update higher level data structures. This needs to be done AFTER the\n // core event dict as these structures may depend on other state events in\n // the given array (e.g. disambiguating display names in one go to do both\n // clashing names rather than progressively which only catches 1 of them).\n stateEvents.forEach((event) => {\n if (event.getRoomId() !== this.roomId || !event.isState()) return;\n\n if (event.getType() === EventType.RoomMember) {\n const userId = event.getStateKey()!;\n\n // leave events apparently elide the displayname or avatar_url,\n // so let's fake one up so that we don't leak user ids\n // into the timeline\n if (event.getContent().membership === \"leave\" || event.getContent().membership === \"ban\") {\n event.getContent().avatar_url = event.getContent().avatar_url || event.getPrevContent().avatar_url;\n event.getContent().displayname =\n event.getContent().displayname || event.getPrevContent().displayname;\n }\n\n const member = this.getOrCreateMember(userId, event);\n member.setMembershipEvent(event, this);\n this.updateMember(member);\n this.emit(RoomStateEvent.Members, event, this, member);\n } else if (event.getType() === EventType.RoomPowerLevels) {\n // events with unknown state keys should be ignored\n // and should not aggregate onto members power levels\n if (event.getStateKey() !== \"\") {\n return;\n }\n const members = Object.values(this.members);\n members.forEach((member) => {\n // We only propagate `RoomState.members` event if the\n // power levels has been changed\n // large room suffer from large re-rendering especially when not needed\n const oldLastModified = member.getLastModifiedTime();\n member.setPowerLevelEvent(event);\n if (oldLastModified !== member.getLastModifiedTime()) {\n this.emit(RoomStateEvent.Members, event, this, member);\n }\n });\n\n // assume all our sentinels are now out-of-date\n this.sentinels = {};\n } else if (UNSTABLE_MSC2716_MARKER.matches(event.getType())) {\n this.emit(RoomStateEvent.Marker, event, markerFoundOptions);\n }\n });\n\n this.emit(RoomStateEvent.Update, this);\n }\n\n public async processBeaconEvents(events: MatrixEvent[], matrixClient: MatrixClient): Promise {\n if (\n !events.length ||\n // discard locations if we have no beacons\n !this.beacons.size\n ) {\n return;\n }\n\n const beaconByEventIdDict = [...this.beacons.values()].reduce>((dict, beacon) => {\n dict[beacon.beaconInfoId] = beacon;\n return dict;\n }, {});\n\n const processBeaconRelation = (beaconInfoEventId: string, event: MatrixEvent): void => {\n if (!M_BEACON.matches(event.getType())) {\n return;\n }\n\n const beacon = beaconByEventIdDict[beaconInfoEventId];\n\n if (beacon) {\n beacon.addLocations([event]);\n }\n };\n\n for (const event of events) {\n const relatedToEventId = event.getRelation()?.event_id;\n // not related to a beacon we know about; discard\n if (!relatedToEventId || !beaconByEventIdDict[relatedToEventId]) return;\n if (!M_BEACON.matches(event.getType()) && !event.isEncrypted()) return;\n\n try {\n await matrixClient.decryptEventIfNeeded(event);\n processBeaconRelation(relatedToEventId, event);\n } catch {\n if (event.isDecryptionFailure()) {\n // add an event listener for once the event is decrypted.\n event.once(MatrixEventEvent.Decrypted, async () => {\n processBeaconRelation(relatedToEventId, event);\n });\n }\n }\n }\n }\n\n /**\n * Looks up a member by the given userId, and if it doesn't exist,\n * create it and emit the `RoomState.newMember` event.\n * This method makes sure the member is added to the members dictionary\n * before emitting, as this is done from setStateEvents and setOutOfBandMember.\n * @param userId - the id of the user to look up\n * @param event - the membership event for the (new) member. Used to emit.\n * @returns the member, existing or newly created.\n *\n * @remarks\n * Fires {@link RoomStateEvent.NewMember}\n */\n private getOrCreateMember(userId: string, event: MatrixEvent): RoomMember {\n let member = this.members[userId];\n if (!member) {\n member = new RoomMember(this.roomId, userId);\n // add member to members before emitting any events,\n // as event handlers often lookup the member\n this.members[userId] = member;\n this.emit(RoomStateEvent.NewMember, event, this, member);\n }\n return member;\n }\n\n private setStateEvent(event: MatrixEvent): void {\n if (!this.events.has(event.getType())) {\n this.events.set(event.getType(), new Map());\n }\n this.events.get(event.getType())!.set(event.getStateKey()!, event);\n }\n\n /**\n * @experimental\n */\n private setBeacon(event: MatrixEvent): void {\n const beaconIdentifier = getBeaconInfoIdentifier(event);\n\n if (this.beacons.has(beaconIdentifier)) {\n const beacon = this.beacons.get(beaconIdentifier)!;\n\n if (event.isRedacted()) {\n if (beacon.beaconInfoId === (event.getRedactionEvent())?.redacts) {\n beacon.destroy();\n this.beacons.delete(beaconIdentifier);\n }\n return;\n }\n\n return beacon.update(event);\n }\n\n if (event.isRedacted()) {\n return;\n }\n\n const beacon = new Beacon(event);\n\n this.reEmitter.reEmit(beacon, [\n BeaconEvent.New,\n BeaconEvent.Update,\n BeaconEvent.Destroy,\n BeaconEvent.LivenessChange,\n ]);\n\n this.emit(BeaconEvent.New, event, beacon);\n beacon.on(BeaconEvent.LivenessChange, this.onBeaconLivenessChange.bind(this));\n beacon.on(BeaconEvent.Destroy, this.onBeaconLivenessChange.bind(this));\n\n this.beacons.set(beacon.identifier, beacon);\n }\n\n /**\n * @experimental\n * Check liveness of room beacons\n * emit RoomStateEvent.BeaconLiveness event\n */\n private onBeaconLivenessChange(): void {\n this._liveBeaconIds = Array.from(this.beacons.values())\n .filter((beacon) => beacon.isLive)\n .map((beacon) => beacon.identifier);\n\n this.emit(RoomStateEvent.BeaconLiveness, this, this.hasLiveBeacons);\n }\n\n private getStateEventMatching(event: MatrixEvent): MatrixEvent | null {\n return this.events.get(event.getType())?.get(event.getStateKey()!) ?? null;\n }\n\n private updateMember(member: RoomMember): void {\n // this member may have a power level already, so set it.\n const pwrLvlEvent = this.getStateEvents(EventType.RoomPowerLevels, \"\");\n if (pwrLvlEvent) {\n member.setPowerLevelEvent(pwrLvlEvent);\n }\n\n // blow away the sentinel which is now outdated\n delete this.sentinels[member.userId];\n\n this.members[member.userId] = member;\n this.joinedMemberCount = null;\n this.invitedMemberCount = null;\n }\n\n /**\n * Get the out-of-band members loading state, whether loading is needed or not.\n * Note that loading might be in progress and hence isn't needed.\n * @returns whether or not the members of this room need to be loaded\n */\n public needsOutOfBandMembers(): boolean {\n return this.oobMemberFlags.status === OobStatus.NotStarted;\n }\n\n /**\n * Check if loading of out-of-band-members has completed\n *\n * @returns true if the full membership list of this room has been loaded. False if it is not started or is in\n * progress.\n */\n public outOfBandMembersReady(): boolean {\n return this.oobMemberFlags.status === OobStatus.Finished;\n }\n\n /**\n * Mark this room state as waiting for out-of-band members,\n * ensuring it doesn't ask for them to be requested again\n * through needsOutOfBandMembers\n */\n public markOutOfBandMembersStarted(): void {\n if (this.oobMemberFlags.status !== OobStatus.NotStarted) {\n return;\n }\n this.oobMemberFlags.status = OobStatus.InProgress;\n }\n\n /**\n * Mark this room state as having failed to fetch out-of-band members\n */\n public markOutOfBandMembersFailed(): void {\n if (this.oobMemberFlags.status !== OobStatus.InProgress) {\n return;\n }\n this.oobMemberFlags.status = OobStatus.NotStarted;\n }\n\n /**\n * Clears the loaded out-of-band members\n */\n public clearOutOfBandMembers(): void {\n let count = 0;\n Object.keys(this.members).forEach((userId) => {\n const member = this.members[userId];\n if (member.isOutOfBand()) {\n ++count;\n delete this.members[userId];\n }\n });\n logger.log(`LL: RoomState removed ${count} members...`);\n this.oobMemberFlags.status = OobStatus.NotStarted;\n }\n\n /**\n * Sets the loaded out-of-band members.\n * @param stateEvents - array of membership state events\n */\n public setOutOfBandMembers(stateEvents: MatrixEvent[]): void {\n logger.log(`LL: RoomState about to set ${stateEvents.length} OOB members ...`);\n if (this.oobMemberFlags.status !== OobStatus.InProgress) {\n return;\n }\n logger.log(`LL: RoomState put in finished state ...`);\n this.oobMemberFlags.status = OobStatus.Finished;\n stateEvents.forEach((e) => this.setOutOfBandMember(e));\n this.emit(RoomStateEvent.Update, this);\n }\n\n /**\n * Sets a single out of band member, used by both setOutOfBandMembers and clone\n * @param stateEvent - membership state event\n */\n private setOutOfBandMember(stateEvent: MatrixEvent): void {\n if (stateEvent.getType() !== EventType.RoomMember) {\n return;\n }\n const userId = stateEvent.getStateKey()!;\n const existingMember = this.getMember(userId);\n // never replace members received as part of the sync\n if (existingMember && !existingMember.isOutOfBand()) {\n return;\n }\n\n const member = this.getOrCreateMember(userId, stateEvent);\n member.setMembershipEvent(stateEvent, this);\n // needed to know which members need to be stored seperately\n // as they are not part of the sync accumulator\n // this is cleared by setMembershipEvent so when it's updated through /sync\n member.markOutOfBand();\n\n this.updateDisplayNameCache(member.userId, member.name);\n\n this.setStateEvent(stateEvent);\n this.updateMember(member);\n this.emit(RoomStateEvent.Members, stateEvent, this, member);\n }\n\n /**\n * Set the current typing event for this room.\n * @param event - The typing event\n */\n public setTypingEvent(event: MatrixEvent): void {\n Object.values(this.members).forEach(function (member) {\n member.setTypingEvent(event);\n });\n }\n\n /**\n * Get the m.room.member event which has the given third party invite token.\n *\n * @param token - The token\n * @returns The m.room.member event or null\n */\n public getInviteForThreePidToken(token: string): MatrixEvent | null {\n return this.tokenToInvite[token] || null;\n }\n\n /**\n * Update the last modified time to the current time.\n */\n private updateModifiedTime(): void {\n this.modified = Date.now();\n }\n\n /**\n * Get the timestamp when this room state was last updated. This timestamp is\n * updated when this object has received new state events.\n * @returns The timestamp\n */\n public getLastModifiedTime(): number {\n return this.modified;\n }\n\n /**\n * Get user IDs with the specified or similar display names.\n * @param displayName - The display name to get user IDs from.\n * @returns An array of user IDs or an empty array.\n */\n public getUserIdsWithDisplayName(displayName: string): string[] {\n return this.displayNameToUserIds.get(utils.removeHiddenChars(displayName)) ?? [];\n }\n\n /**\n * Returns true if userId is in room, event is not redacted and either sender of\n * mxEvent or has power level sufficient to redact events other than their own.\n * @param mxEvent - The event to test permission for\n * @param userId - The user ID of the user to test permission for\n * @returns true if the given used ID can redact given event\n */\n public maySendRedactionForEvent(mxEvent: MatrixEvent, userId: string): boolean {\n const member = this.getMember(userId);\n if (!member || member.membership === \"leave\") return false;\n\n if (mxEvent.status || mxEvent.isRedacted()) return false;\n\n // The user may have been the sender, but they can't redact their own message\n // if redactions are blocked.\n const canRedact = this.maySendEvent(EventType.RoomRedaction, userId);\n if (mxEvent.getSender() === userId) return canRedact;\n\n return this.hasSufficientPowerLevelFor(\"redact\", member.powerLevel);\n }\n\n /**\n * Returns true if the given power level is sufficient for action\n * @param action - The type of power level to check\n * @param powerLevel - The power level of the member\n * @returns true if the given power level is sufficient\n */\n public hasSufficientPowerLevelFor(action: \"ban\" | \"kick\" | \"redact\", powerLevel: number): boolean {\n const powerLevelsEvent = this.getStateEvents(EventType.RoomPowerLevels, \"\");\n\n let powerLevels: IPowerLevelsContent = {};\n if (powerLevelsEvent) {\n powerLevels = powerLevelsEvent.getContent();\n }\n\n let requiredLevel = 50;\n if (utils.isNumber(powerLevels[action])) {\n requiredLevel = powerLevels[action]!;\n }\n\n return powerLevel >= requiredLevel;\n }\n\n /**\n * Short-form for maySendEvent('m.room.message', userId)\n * @param userId - The user ID of the user to test permission for\n * @returns true if the given user ID should be permitted to send\n * message events into the given room.\n */\n public maySendMessage(userId: string): boolean {\n return this.maySendEventOfType(EventType.RoomMessage, userId, false);\n }\n\n /**\n * Returns true if the given user ID has permission to send a normal\n * event of type `eventType` into this room.\n * @param eventType - The type of event to test\n * @param userId - The user ID of the user to test permission for\n * @returns true if the given user ID should be permitted to send\n * the given type of event into this room,\n * according to the room's state.\n */\n public maySendEvent(eventType: EventType | string, userId: string): boolean {\n return this.maySendEventOfType(eventType, userId, false);\n }\n\n /**\n * Returns true if the given MatrixClient has permission to send a state\n * event of type `stateEventType` into this room.\n * @param stateEventType - The type of state events to test\n * @param cli - The client to test permission for\n * @returns true if the given client should be permitted to send\n * the given type of state event into this room,\n * according to the room's state.\n */\n public mayClientSendStateEvent(stateEventType: EventType | string, cli: MatrixClient): boolean {\n if (cli.isGuest() || !cli.credentials.userId) {\n return false;\n }\n return this.maySendStateEvent(stateEventType, cli.credentials.userId);\n }\n\n /**\n * Returns true if the given user ID has permission to send a state\n * event of type `stateEventType` into this room.\n * @param stateEventType - The type of state events to test\n * @param userId - The user ID of the user to test permission for\n * @returns true if the given user ID should be permitted to send\n * the given type of state event into this room,\n * according to the room's state.\n */\n public maySendStateEvent(stateEventType: EventType | string, userId: string): boolean {\n return this.maySendEventOfType(stateEventType, userId, true);\n }\n\n /**\n * Returns true if the given user ID has permission to send a normal or state\n * event of type `eventType` into this room.\n * @param eventType - The type of event to test\n * @param userId - The user ID of the user to test permission for\n * @param state - If true, tests if the user may send a state\n event of this type. Otherwise tests whether\n they may send a regular event.\n * @returns true if the given user ID should be permitted to send\n * the given type of event into this room,\n * according to the room's state.\n */\n private maySendEventOfType(eventType: EventType | string, userId: string, state: boolean): boolean {\n const powerLevelsEvent = this.getStateEvents(EventType.RoomPowerLevels, \"\");\n\n let powerLevels: IPowerLevelsContent;\n let eventsLevels: Record = {};\n\n let stateDefault = 0;\n let eventsDefault = 0;\n let powerLevel = 0;\n if (powerLevelsEvent) {\n powerLevels = powerLevelsEvent.getContent();\n eventsLevels = powerLevels.events || {};\n\n if (Number.isSafeInteger(powerLevels.state_default)) {\n stateDefault = powerLevels.state_default!;\n } else {\n stateDefault = 50;\n }\n\n const userPowerLevel = powerLevels.users && powerLevels.users[userId];\n if (Number.isSafeInteger(userPowerLevel)) {\n powerLevel = userPowerLevel!;\n } else if (Number.isSafeInteger(powerLevels.users_default)) {\n powerLevel = powerLevels.users_default!;\n }\n\n if (Number.isSafeInteger(powerLevels.events_default)) {\n eventsDefault = powerLevels.events_default!;\n }\n }\n\n let requiredLevel = state ? stateDefault : eventsDefault;\n if (Number.isSafeInteger(eventsLevels[eventType])) {\n requiredLevel = eventsLevels[eventType];\n }\n return powerLevel >= requiredLevel;\n }\n\n /**\n * Returns true if the given user ID has permission to trigger notification\n * of type `notifLevelKey`\n * @param notifLevelKey - The level of notification to test (eg. 'room')\n * @param userId - The user ID of the user to test permission for\n * @returns true if the given user ID has permission to trigger a\n * notification of this type.\n */\n public mayTriggerNotifOfType(notifLevelKey: string, userId: string): boolean {\n const member = this.getMember(userId);\n if (!member) {\n return false;\n }\n\n const powerLevelsEvent = this.getStateEvents(EventType.RoomPowerLevels, \"\");\n\n let notifLevel = 50;\n if (\n powerLevelsEvent &&\n powerLevelsEvent.getContent() &&\n powerLevelsEvent.getContent().notifications &&\n utils.isNumber(powerLevelsEvent.getContent().notifications[notifLevelKey])\n ) {\n notifLevel = powerLevelsEvent.getContent().notifications[notifLevelKey];\n }\n\n return member.powerLevel >= notifLevel;\n }\n\n /**\n * Returns the join rule based on the m.room.join_rule state event, defaulting to `invite`.\n * @returns the join_rule applied to this room\n */\n public getJoinRule(): JoinRule {\n const joinRuleEvent = this.getStateEvents(EventType.RoomJoinRules, \"\");\n const joinRuleContent: Partial = joinRuleEvent?.getContent() ?? {};\n return joinRuleContent[\"join_rule\"] || JoinRule.Invite;\n }\n\n /**\n * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`.\n * @returns the history_visibility applied to this room\n */\n public getHistoryVisibility(): HistoryVisibility {\n const historyVisibilityEvent = this.getStateEvents(EventType.RoomHistoryVisibility, \"\");\n const historyVisibilityContent = historyVisibilityEvent?.getContent() ?? {};\n return historyVisibilityContent[\"history_visibility\"] || HistoryVisibility.Shared;\n }\n\n /**\n * Returns the guest access based on the m.room.guest_access state event, defaulting to `shared`.\n * @returns the guest_access applied to this room\n */\n public getGuestAccess(): GuestAccess {\n const guestAccessEvent = this.getStateEvents(EventType.RoomGuestAccess, \"\");\n const guestAccessContent = guestAccessEvent?.getContent() ?? {};\n return guestAccessContent[\"guest_access\"] || GuestAccess.Forbidden;\n }\n\n /**\n * Find the predecessor room based on this room state.\n *\n * @param msc3946ProcessDynamicPredecessor - if true, look for an\n * m.room.predecessor state event and use it if found (MSC3946).\n * @returns null if this room has no predecessor. Otherwise, returns\n * the roomId, last eventId and viaServers of the predecessor room.\n *\n * If msc3946ProcessDynamicPredecessor is true, use m.predecessor events\n * as well as m.room.create events to find predecessors.\n *\n * Note: if an m.predecessor event is used, eventId may be undefined\n * since last_known_event_id is optional.\n *\n * Note: viaServers may be undefined, and will definitely be undefined if\n * this predecessor comes from a RoomCreate event (rather than a\n * RoomPredecessor, which has the optional via_servers property).\n */\n public findPredecessor(\n msc3946ProcessDynamicPredecessor = false,\n ): { roomId: string; eventId?: string; viaServers?: string[] } | null {\n // Note: the tests for this function are against Room.findPredecessor,\n // which just calls through to here.\n\n if (msc3946ProcessDynamicPredecessor) {\n const predecessorEvent = this.getStateEvents(EventType.RoomPredecessor, \"\");\n if (predecessorEvent) {\n const content = predecessorEvent.getContent<{\n predecessor_room_id: string;\n last_known_event_id?: string;\n via_servers?: string[];\n }>();\n const roomId = content.predecessor_room_id;\n let eventId = content.last_known_event_id;\n if (typeof eventId !== \"string\") {\n eventId = undefined;\n }\n let viaServers = content.via_servers;\n if (!Array.isArray(viaServers)) {\n viaServers = undefined;\n }\n if (typeof roomId === \"string\") {\n return { roomId, eventId, viaServers };\n }\n }\n }\n\n const createEvent = this.getStateEvents(EventType.RoomCreate, \"\");\n if (createEvent) {\n const predecessor = createEvent.getContent<{\n predecessor?: Partial<{\n room_id: string;\n event_id: string;\n }>;\n }>()[\"predecessor\"];\n if (predecessor) {\n const roomId = predecessor[\"room_id\"];\n if (typeof roomId === \"string\") {\n let eventId = predecessor[\"event_id\"];\n if (typeof eventId !== \"string\" || eventId === \"\") {\n eventId = undefined;\n }\n return { roomId, eventId };\n }\n }\n }\n return null;\n }\n\n private updateThirdPartyTokenCache(memberEvent: MatrixEvent): void {\n if (!memberEvent.getContent().third_party_invite) {\n return;\n }\n const token = (memberEvent.getContent().third_party_invite.signed || {}).token;\n if (!token) {\n return;\n }\n const threePidInvite = this.getStateEvents(EventType.RoomThirdPartyInvite, token);\n if (!threePidInvite) {\n return;\n }\n this.tokenToInvite[token] = memberEvent;\n }\n\n private updateDisplayNameCache(userId: string, displayName: string): void {\n const oldName = this.userIdsToDisplayNames[userId];\n delete this.userIdsToDisplayNames[userId];\n if (oldName) {\n // Remove the old name from the cache.\n // We clobber the user_id > name lookup but the name -> [user_id] lookup\n // means we need to remove that user ID from that array rather than nuking\n // the lot.\n const strippedOldName = utils.removeHiddenChars(oldName);\n\n const existingUserIds = this.displayNameToUserIds.get(strippedOldName);\n if (existingUserIds) {\n // remove this user ID from this array\n const filteredUserIDs = existingUserIds.filter((id) => id !== userId);\n this.displayNameToUserIds.set(strippedOldName, filteredUserIDs);\n }\n }\n\n this.userIdsToDisplayNames[userId] = displayName;\n\n const strippedDisplayname = displayName && utils.removeHiddenChars(displayName);\n // an empty stripped displayname (undefined/'') will be set to MXID in room-member.js\n if (strippedDisplayname) {\n const arr = this.displayNameToUserIds.get(strippedDisplayname) ?? [];\n arr.push(userId);\n this.displayNameToUserIds.set(strippedDisplayname, arr);\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts deleted file mode 100644 index 32f2df4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts +++ /dev/null @@ -1,29 +0,0 @@ -export interface IRoomSummary { - "m.heroes": string[]; - "m.joined_member_count"?: number; - "m.invited_member_count"?: number; -} -interface IInfo { - /** The title of the room (e.g. `m.room.name`) */ - title: string; - /** The description of the room (e.g. `m.room.topic`) */ - desc?: string; - /** The number of joined users. */ - numMembers?: number; - /** The list of aliases for this room. */ - aliases?: string[]; - /** The timestamp for this room. */ - timestamp?: number; -} -/** - * Construct a new Room Summary. A summary can be used for display on a recent - * list, without having to load the entire room list into memory. - * @param roomId - Required. The ID of this room. - * @param info - Optional. The summary info. Additional keys are supported. - */ -export declare class RoomSummary { - readonly roomId: string; - constructor(roomId: string, info?: IInfo); -} -export {}; -//# sourceMappingURL=room-summary.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts.map deleted file mode 100644 index 8febcab..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-summary.d.ts","sourceRoot":"","sources":["../../src/models/room-summary.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,YAAY;IACzB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,wBAAwB,CAAC,EAAE,MAAM,CAAC;CACrC;AAED,UAAU,KAAK;IACX,iDAAiD;IACjD,KAAK,EAAE,MAAM,CAAC;IACd,wDAAwD;IACxD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,kCAAkC;IAClC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,yCAAyC;IACzC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,mCAAmC;IACnC,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;;;;GAKG;AACH,qBAAa,WAAW;aACe,MAAM,EAAE,MAAM;gBAAd,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,KAAK;CAClE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js deleted file mode 100644 index b0f89ab..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js +++ /dev/null @@ -1,35 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomSummary = void 0; -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * Construct a new Room Summary. A summary can be used for display on a recent - * list, without having to load the entire room list into memory. - * @param roomId - Required. The ID of this room. - * @param info - Optional. The summary info. Additional keys are supported. - */ -class RoomSummary { - constructor(roomId, info) { - this.roomId = roomId; - } -} -exports.RoomSummary = RoomSummary; -//# sourceMappingURL=room-summary.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js.map deleted file mode 100644 index a334eb1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room-summary.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-summary.js","names":["RoomSummary","constructor","roomId","info","exports"],"sources":["../../src/models/room-summary.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport interface IRoomSummary {\n \"m.heroes\": string[];\n \"m.joined_member_count\"?: number;\n \"m.invited_member_count\"?: number;\n}\n\ninterface IInfo {\n /** The title of the room (e.g. `m.room.name`) */\n title: string;\n /** The description of the room (e.g. `m.room.topic`) */\n desc?: string;\n /** The number of joined users. */\n numMembers?: number;\n /** The list of aliases for this room. */\n aliases?: string[];\n /** The timestamp for this room. */\n timestamp?: number;\n}\n\n/**\n * Construct a new Room Summary. A summary can be used for display on a recent\n * list, without having to load the entire room list into memory.\n * @param roomId - Required. The ID of this room.\n * @param info - Optional. The summary info. Additional keys are supported.\n */\nexport class RoomSummary {\n public constructor(public readonly roomId: string, info?: IInfo) {}\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAqBA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMA,WAAW,CAAC;EACdC,WAAWA,CAAiBC,MAAc,EAAEC,IAAY,EAAE;IAAA,KAA9BD,MAAc,GAAdA,MAAc;EAAiB;AACtE;AAACE,OAAA,CAAAJ,WAAA,GAAAA,WAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts deleted file mode 100644 index 438ce42..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts +++ /dev/null @@ -1,1087 +0,0 @@ -import { EventTimelineSet, DuplicateStrategy, IAddLiveEventOptions, EventTimelineSetHandlerMap } from "./event-timeline-set"; -import { EventTimeline } from "./event-timeline"; -import { MatrixEvent, MatrixEventEvent, MatrixEventHandlerMap } from "./event"; -import { EventStatus } from "./event-status"; -import { RoomMember } from "./room-member"; -import { IRoomSummary, RoomSummary } from "./room-summary"; -import { TypedReEmitter } from "../ReEmitter"; -import { EventType, RoomType } from "../@types/event"; -import { MatrixClient, PendingEventOrdering } from "../client"; -import { GuestAccess, HistoryVisibility, JoinRule, ResizeMethod } from "../@types/partials"; -import { Filter } from "../filter"; -import { RoomState, RoomStateEvent, RoomStateEventHandlerMap } from "./room-state"; -import { BeaconEvent, BeaconEventHandlerMap } from "./beacon"; -import { Thread, ThreadEvent, EventHandlerMap as ThreadHandlerMap } from "./thread"; -import { CachedReceiptStructure, Receipt } from "../@types/read_receipts"; -import { RelationsContainer } from "./relations-container"; -import { ReadReceipt } from "./read-receipt"; -import { Poll, PollEvent } from "./poll"; -export declare const KNOWN_SAFE_ROOM_VERSION = "9"; -interface IOpts { - /** - * Controls where pending messages appear in a room's timeline. - * If "chronological", messages will appear in the timeline when the call to `sendEvent` was made. - * If "detached", pending messages will appear in a separate list, - * accessible via {@link Room#getPendingEvents}. - * Default: "chronological". - */ - pendingEventOrdering?: PendingEventOrdering; - /** - * Set to true to enable improved timeline support. - */ - timelineSupport?: boolean; - lazyLoadMembers?: boolean; -} -export interface IRecommendedVersion { - version: string; - needsUpgrade: boolean; - urgent: boolean; -} -export type NotificationCount = Partial>; -export declare enum NotificationCountType { - Highlight = "highlight", - Total = "total" -} -export interface ICreateFilterOpts { - prepopulateTimeline?: boolean; - useSyncEvents?: boolean; - pendingEvents?: boolean; -} -export declare enum RoomEvent { - MyMembership = "Room.myMembership", - Tags = "Room.tags", - AccountData = "Room.accountData", - Receipt = "Room.receipt", - Name = "Room.name", - Redaction = "Room.redaction", - RedactionCancelled = "Room.redactionCancelled", - LocalEchoUpdated = "Room.localEchoUpdated", - Timeline = "Room.timeline", - TimelineReset = "Room.timelineReset", - TimelineRefresh = "Room.TimelineRefresh", - OldStateUpdated = "Room.OldStateUpdated", - CurrentStateUpdated = "Room.CurrentStateUpdated", - HistoryImportedWithinTimeline = "Room.historyImportedWithinTimeline", - UnreadNotifications = "Room.UnreadNotifications" -} -export type RoomEmittedEvents = RoomEvent | RoomStateEvent.Events | RoomStateEvent.Members | RoomStateEvent.NewMember | RoomStateEvent.Update | RoomStateEvent.Marker | ThreadEvent.New | ThreadEvent.Update | ThreadEvent.NewReply | ThreadEvent.Delete | MatrixEventEvent.BeforeRedaction | BeaconEvent.New | BeaconEvent.Update | BeaconEvent.Destroy | BeaconEvent.LivenessChange | PollEvent.New; -export type RoomEventHandlerMap = { - /** - * Fires when the logged in user's membership in the room is updated. - * - * @param room - The room in which the membership has been updated - * @param membership - The new membership value - * @param prevMembership - The previous membership value - */ - [RoomEvent.MyMembership]: (room: Room, membership: string, prevMembership?: string) => void; - /** - * Fires whenever a room's tags are updated. - * @param event - The tags event - * @param room - The room whose Room.tags was updated. - * @example - * ``` - * matrixClient.on("Room.tags", function(event, room){ - * var newTags = event.getContent().tags; - * if (newTags["favourite"]) showStar(room); - * }); - * ``` - */ - [RoomEvent.Tags]: (event: MatrixEvent, room: Room) => void; - /** - * Fires whenever a room's account_data is updated. - * @param event - The account_data event - * @param room - The room whose account_data was updated. - * @param prevEvent - The event being replaced by - * the new account data, if known. - * @example - * ``` - * matrixClient.on("Room.accountData", function(event, room, oldEvent){ - * if (event.getType() === "m.room.colorscheme") { - * applyColorScheme(event.getContents()); - * } - * }); - * ``` - */ - [RoomEvent.AccountData]: (event: MatrixEvent, room: Room, lastEvent?: MatrixEvent) => void; - /** - * Fires whenever a receipt is received for a room - * @param event - The receipt event - * @param room - The room whose receipts was updated. - * @example - * ``` - * matrixClient.on("Room.receipt", function(event, room){ - * var receiptContent = event.getContent(); - * }); - * ``` - */ - [RoomEvent.Receipt]: (event: MatrixEvent, room: Room) => void; - /** - * Fires whenever the name of a room is updated. - * @param room - The room whose Room.name was updated. - * @example - * ``` - * matrixClient.on("Room.name", function(room){ - * var newName = room.name; - * }); - * ``` - */ - [RoomEvent.Name]: (room: Room) => void; - /** - * Fires when an event we had previously received is redacted. - * - * (Note this is *not* fired when the redaction happens before we receive the - * event). - * - * @param event - The matrix redaction event - * @param room - The room containing the redacted event - */ - [RoomEvent.Redaction]: (event: MatrixEvent, room: Room) => void; - /** - * Fires when an event that was previously redacted isn't anymore. - * This happens when the redaction couldn't be sent and - * was subsequently cancelled by the user. Redactions have a local echo - * which is undone in this scenario. - * - * @param event - The matrix redaction event that was cancelled. - * @param room - The room containing the unredacted event - */ - [RoomEvent.RedactionCancelled]: (event: MatrixEvent, room: Room) => void; - /** - * Fires when the status of a transmitted event is updated. - * - *

When an event is first transmitted, a temporary copy of the event is - * inserted into the timeline, with a temporary event id, and a status of - * 'SENDING'. - * - *

Once the echo comes back from the server, the content of the event - * (MatrixEvent.event) is replaced by the complete event from the homeserver, - * thus updating its event id, as well as server-generated fields such as the - * timestamp. Its status is set to null. - * - *

Once the /send request completes, if the remote echo has not already - * arrived, the event is updated with a new event id and the status is set to - * 'SENT'. The server-generated fields are of course not updated yet. - * - *

If the /send fails, In this case, the event's status is set to - * 'NOT_SENT'. If it is later resent, the process starts again, setting the - * status to 'SENDING'. Alternatively, the message may be cancelled, which - * removes the event from the room, and sets the status to 'CANCELLED'. - * - *

This event is raised to reflect each of the transitions above. - * - * @param event - The matrix event which has been updated - * - * @param room - The room containing the redacted event - * - * @param oldEventId - The previous event id (the temporary event id, - * except when updating a successfully-sent event when its echo arrives) - * - * @param oldStatus - The previous event status. - */ - [RoomEvent.LocalEchoUpdated]: (event: MatrixEvent, room: Room, oldEventId?: string, oldStatus?: EventStatus | null) => void; - [RoomEvent.OldStateUpdated]: (room: Room, previousRoomState: RoomState, roomState: RoomState) => void; - [RoomEvent.CurrentStateUpdated]: (room: Room, previousRoomState: RoomState, roomState: RoomState) => void; - [RoomEvent.HistoryImportedWithinTimeline]: (markerEvent: MatrixEvent, room: Room) => void; - [RoomEvent.UnreadNotifications]: (unreadNotifications?: NotificationCount, threadId?: string) => void; - [RoomEvent.TimelineRefresh]: (room: Room, eventTimelineSet: EventTimelineSet) => void; - [ThreadEvent.New]: (thread: Thread, toStartOfTimeline: boolean) => void; - /** - * Fires when a new poll instance is added to the room state - * @param poll - the new poll - */ - [PollEvent.New]: (poll: Poll) => void; -} & Pick & EventTimelineSetHandlerMap & Pick & Pick & Pick; -export declare class Room extends ReadReceipt { - readonly roomId: string; - readonly client: MatrixClient; - readonly myUserId: string; - private readonly opts; - readonly reEmitter: TypedReEmitter; - private txnToEvent; - private notificationCounts; - private readonly threadNotifications; - readonly cachedThreadReadReceipts: Map; - private oldestThreadedReceiptTs; - /** - * A record of the latest unthread receipts per user - * This is useful in determining whether a user has read a thread or not - */ - private unthreadedReceipts; - private readonly timelineSets; - readonly polls: Map; - readonly threadsTimelineSets: EventTimelineSet[]; - private readonly filteredTimelineSets; - private timelineNeedsRefresh; - private readonly pendingEventList?; - private blacklistUnverifiedDevices?; - private selfMembership?; - private summaryHeroes; - private getTypeWarning; - private getVersionWarning; - private membersPromise?; - /** - * The human-readable display name for this room. - */ - name: string; - /** - * The un-homoglyphed name for this room. - */ - normalizedName: string; - /** - * Dict of room tags; the keys are the tag name and the values - * are any metadata associated with the tag - e.g. `{ "fav" : { order: 1 } }` - */ - tags: Record>; - /** - * accountData Dict of per-room account_data events; the keys are the - * event type and the values are the events. - */ - accountData: Map; - /** - * The room summary. - */ - summary: RoomSummary | null; - /** - * The live event timeline for this room, with the oldest event at index 0. - * Present for backwards compatibility - prefer getLiveTimeline().getEvents() - */ - timeline: MatrixEvent[]; - /** - * oldState The state of the room at the time of the oldest - * event in the live timeline. Present for backwards compatibility - - * prefer getLiveTimeline().getState(EventTimeline.BACKWARDS). - */ - oldState: RoomState; - /** - * currentState The state of the room at the time of the - * newest event in the timeline. Present for backwards compatibility - - * prefer getLiveTimeline().getState(EventTimeline.FORWARDS). - */ - currentState: RoomState; - readonly relations: RelationsContainer; - /** - * A collection of events known by the client - * This is not a comprehensive list of the threads that exist in this room - */ - private threads; - lastThread?: Thread; - /** - * A mapping of eventId to all visibility changes to apply - * to the event, by chronological order, as per - * https://github.com/matrix-org/matrix-doc/pull/3531 - * - * # Invariants - * - * - within each list, all events are classed by - * chronological order; - * - all events are events such that - * `asVisibilityEvent()` returns a non-null `IVisibilityChange`; - * - within each list with key `eventId`, all events - * are in relation to `eventId`. - * - * @experimental - */ - private visibilityEvents; - /** - * Construct a new Room. - * - *

For a room, we store an ordered sequence of timelines, which may or may not - * be continuous. Each timeline lists a series of events, as well as tracking - * the room state at the start and the end of the timeline. It also tracks - * forward and backward pagination tokens, as well as containing links to the - * next timeline in the sequence. - * - *

There is one special timeline - the 'live' timeline, which represents the - * timeline to which events are being added in real-time as they are received - * from the /sync API. Note that you should not retain references to this - * timeline - even if it is the current timeline right now, it may not remain - * so if the server gives us a timeline gap in /sync. - * - *

In order that we can find events from their ids later, we also maintain a - * map from event_id to timeline and index. - * - * @param roomId - Required. The ID of this room. - * @param client - Required. The client, used to lazy load members. - * @param myUserId - Required. The ID of the syncing user. - * @param opts - Configuration options - */ - constructor(roomId: string, client: MatrixClient, myUserId: string, opts?: IOpts); - private threadTimelineSetsPromise; - createThreadsTimelineSets(): Promise<[EventTimelineSet, EventTimelineSet] | null>; - /** - * Bulk decrypt critical events in a room - * - * Critical events represents the minimal set of events to decrypt - * for a typical UI to function properly - * - * - Last event of every room (to generate likely message preview) - * - All events up to the read receipt (to calculate an accurate notification count) - * - * @returns Signals when all events have been decrypted - */ - decryptCriticalEvents(): Promise; - /** - * Bulk decrypt events in a room - * - * @returns Signals when all events have been decrypted - */ - decryptAllEvents(): Promise; - /** - * Gets the creator of the room - * @returns The creator of the room, or null if it could not be determined - */ - getCreator(): string | null; - /** - * Gets the version of the room - * @returns The version of the room, or null if it could not be determined - */ - getVersion(): string; - /** - * Determines whether this room needs to be upgraded to a new version - * @returns What version the room should be upgraded to, or null if - * the room does not require upgrading at this time. - * @deprecated Use #getRecommendedVersion() instead - */ - shouldUpgradeToVersion(): string | null; - /** - * Determines the recommended room version for the room. This returns an - * object with 3 properties: `version` as the new version the - * room should be upgraded to (may be the same as the current version); - * `needsUpgrade` to indicate if the room actually can be - * upgraded (ie: does the current version not match?); and `urgent` - * to indicate if the new version patches a vulnerability in a previous - * version. - * @returns - * Resolves to the version the room should be upgraded to. - */ - getRecommendedVersion(): Promise; - private checkVersionAgainstCapability; - /** - * Determines whether the given user is permitted to perform a room upgrade - * @param userId - The ID of the user to test against - * @returns True if the given user is permitted to upgrade the room - */ - userMayUpgradeRoom(userId: string): boolean; - /** - * Get the list of pending sent events for this room - * - * @returns A list of the sent events - * waiting for remote echo. - * - * @throws If `opts.pendingEventOrdering` was not 'detached' - */ - getPendingEvents(): MatrixEvent[]; - /** - * Removes a pending event for this room - * - * @returns True if an element was removed. - */ - removePendingEvent(eventId: string): boolean; - /** - * Check whether the pending event list contains a given event by ID. - * If pending event ordering is not "detached" then this returns false. - * - * @param eventId - The event ID to check for. - */ - hasPendingEvent(eventId: string): boolean; - /** - * Get a specific event from the pending event list, if configured, null otherwise. - * - * @param eventId - The event ID to check for. - */ - getPendingEvent(eventId: string): MatrixEvent | null; - /** - * Get the live unfiltered timeline for this room. - * - * @returns live timeline - */ - getLiveTimeline(): EventTimeline; - /** - * Get the timestamp of the last message in the room - * - * @returns the timestamp of the last message in the room - */ - getLastActiveTimestamp(): number; - /** - * @returns the membership type (join | leave | invite) for the logged in user - */ - getMyMembership(): string; - /** - * If this room is a DM we're invited to, - * try to find out who invited us - * @returns user id of the inviter - */ - getDMInviter(): string | undefined; - /** - * Assuming this room is a DM room, tries to guess with which user. - * @returns user id of the other member (could be syncing user) - */ - guessDMUserId(): string; - getAvatarFallbackMember(): RoomMember | undefined; - /** - * Sets the membership this room was received as during sync - * @param membership - join | leave | invite - */ - updateMyMembership(membership: string): void; - private loadMembersFromServer; - private loadMembers; - /** - * Check if loading of out-of-band-members has completed - * - * @returns true if the full membership list of this room has been loaded (including if lazy-loading is disabled). - * False if the load is not started or is in progress. - */ - membersLoaded(): boolean; - /** - * Preloads the member list in case lazy loading - * of memberships is in use. Can be called multiple times, - * it will only preload once. - * @returns when preloading is done and - * accessing the members on the room will take - * all members in the room into account - */ - loadMembersIfNeeded(): Promise; - /** - * Removes the lazily loaded members from storage if needed - */ - clearLoadedMembersIfNeeded(): Promise; - /** - * called when sync receives this room in the leave section - * to do cleanup after leaving a room. Possibly called multiple times. - */ - private cleanupAfterLeaving; - /** - * Empty out the current live timeline and re-request it. This is used when - * historical messages are imported into the room via MSC2716 `/batch_send` - * because the client may already have that section of the timeline loaded. - * We need to force the client to throw away their current timeline so that - * when they back paginate over the area again with the historical messages - * in between, it grabs the newly imported messages. We can listen for - * `UNSTABLE_MSC2716_MARKER`, in order to tell when historical messages are ready - * to be discovered in the room and the timeline needs a refresh. The SDK - * emits a `RoomEvent.HistoryImportedWithinTimeline` event when we detect a - * valid marker and can check the needs refresh status via - * `room.getTimelineNeedsRefresh()`. - */ - refreshLiveTimeline(): Promise; - /** - * Reset the live timeline of all timelineSets, and start new ones. - * - *

This is used when /sync returns a 'limited' timeline. - * - * @param backPaginationToken - token for back-paginating the new timeline - * @param forwardPaginationToken - token for forward-paginating the old live timeline, - * if absent or null, all timelines are reset, removing old ones (including the previous live - * timeline which would otherwise be unable to paginate forwards without this token). - * Removing just the old live timeline whilst preserving previous ones is not supported. - */ - resetLiveTimeline(backPaginationToken?: string | null, forwardPaginationToken?: string | null): void; - /** - * Fix up this.timeline, this.oldState and this.currentState - * - * @internal - */ - private fixUpLegacyTimelineFields; - /** - * Returns whether there are any devices in the room that are unverified - * - * Note: Callers should first check if crypto is enabled on this device. If it is - * disabled, then we aren't tracking room devices at all, so we can't answer this, and an - * error will be thrown. - * - * @returns the result - */ - hasUnverifiedDevices(): Promise; - /** - * Return the timeline sets for this room. - * @returns array of timeline sets for this room - */ - getTimelineSets(): EventTimelineSet[]; - /** - * Helper to return the main unfiltered timeline set for this room - * @returns room's unfiltered timeline set - */ - getUnfilteredTimelineSet(): EventTimelineSet; - /** - * Get the timeline which contains the given event from the unfiltered set, if any - * - * @param eventId - event ID to look for - * @returns timeline containing - * the given event, or null if unknown - */ - getTimelineForEvent(eventId: string): EventTimeline | null; - /** - * Add a new timeline to this room's unfiltered timeline set - * - * @returns newly-created timeline - */ - addTimeline(): EventTimeline; - /** - * Whether the timeline needs to be refreshed in order to pull in new - * historical messages that were imported. - * @param value - The value to set - */ - setTimelineNeedsRefresh(value: boolean): void; - /** - * Whether the timeline needs to be refreshed in order to pull in new - * historical messages that were imported. - * @returns . - */ - getTimelineNeedsRefresh(): boolean; - /** - * Get an event which is stored in our unfiltered timeline set, or in a thread - * - * @param eventId - event ID to look for - * @returns the given event, or undefined if unknown - */ - findEventById(eventId: string): MatrixEvent | undefined; - /** - * Get one of the notification counts for this room - * @param type - The type of notification count to get. default: 'total' - * @returns The notification count, or undefined if there is no count - * for this type. - */ - getUnreadNotificationCount(type?: NotificationCountType): number; - /** - * Get the notification for the event context (room or thread timeline) - */ - getUnreadCountForEventContext(type: NotificationCountType | undefined, event: MatrixEvent): number; - /** - * Get one of the notification counts for this room - * @param type - The type of notification count to get. default: 'total' - * @returns The notification count, or undefined if there is no count - * for this type. - */ - getRoomUnreadNotificationCount(type?: NotificationCountType): number; - /** - * Get one of the notification counts for a thread - * @param threadId - the root event ID - * @param type - The type of notification count to get. default: 'total' - * @returns The notification count, or undefined if there is no count - * for this type. - */ - getThreadUnreadNotificationCount(threadId: string, type?: NotificationCountType): number; - /** - * Checks if the current room has unread thread notifications - * @returns - */ - hasThreadUnreadNotification(): boolean; - /** - * Swet one of the notification count for a thread - * @param threadId - the root event ID - * @param type - The type of notification count to get. default: 'total' - * @returns - */ - setThreadUnreadNotificationCount(threadId: string, type: NotificationCountType, count: number): void; - /** - * @returns the notification count type for all the threads in the room - */ - get threadsAggregateNotificationType(): NotificationCountType | null; - /** - * Resets the thread notifications for this room - */ - resetThreadUnreadNotificationCount(notificationsToKeep?: string[]): void; - /** - * Set one of the notification counts for this room - * @param type - The type of notification count to set. - * @param count - The new count - */ - setUnreadNotificationCount(type: NotificationCountType, count: number): void; - setUnread(type: NotificationCountType, count: number): void; - setSummary(summary: IRoomSummary): void; - /** - * Whether to send encrypted messages to devices within this room. - * @param value - true to blacklist unverified devices, null - * to use the global value for this room. - */ - setBlacklistUnverifiedDevices(value: boolean): void; - /** - * Whether to send encrypted messages to devices within this room. - * @returns true if blacklisting unverified devices, null - * if the global value should be used for this room. - */ - getBlacklistUnverifiedDevices(): boolean | null; - /** - * Get the avatar URL for a room if one was set. - * @param baseUrl - The homeserver base URL. See - * {@link MatrixClient#getHomeserverUrl}. - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDefault - True to allow an identicon for this room if an - * avatar URL wasn't explicitly set. Default: true. (Deprecated) - * @returns the avatar URL or null. - */ - getAvatarUrl(baseUrl: string, width: number, height: number, resizeMethod: ResizeMethod, allowDefault?: boolean): string | null; - /** - * Get the mxc avatar url for the room, if one was set. - * @returns the mxc avatar url or falsy - */ - getMxcAvatarUrl(): string | null; - /** - * Get this room's canonical alias - * The alias returned by this function may not necessarily - * still point to this room. - * @returns The room's canonical alias, or null if there is none - */ - getCanonicalAlias(): string | null; - /** - * Get this room's alternative aliases - * @returns The room's alternative aliases, or an empty array - */ - getAltAliases(): string[]; - /** - * Add events to a timeline - * - *

Will fire "Room.timeline" for each event added. - * - * @param events - A list of events to add. - * - * @param toStartOfTimeline - True to add these events to the start - * (oldest) instead of the end (newest) of the timeline. If true, the oldest - * event will be the last element of 'events'. - * - * @param timeline - timeline to - * add events to. - * - * @param paginationToken - token for the next batch of events - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - addEventsToTimeline(events: MatrixEvent[], toStartOfTimeline: boolean, timeline: EventTimeline, paginationToken?: string): void; - /** - * Get the instance of the thread associated with the current event - * @param eventId - the ID of the current event - * @returns a thread instance if known - */ - getThread(eventId: string): Thread | null; - /** - * Get all the known threads in the room - */ - getThreads(): Thread[]; - /** - * Get a member from the current room state. - * @param userId - The user ID of the member. - * @returns The member or `null`. - */ - getMember(userId: string): RoomMember | null; - /** - * Get all currently loaded members from the current - * room state. - * @returns Room members - */ - getMembers(): RoomMember[]; - /** - * Get a list of members whose membership state is "join". - * @returns A list of currently joined members. - */ - getJoinedMembers(): RoomMember[]; - /** - * Returns the number of joined members in this room - * This method caches the result. - * This is a wrapper around the method of the same name in roomState, returning - * its result for the room's current state. - * @returns The number of members in this room whose membership is 'join' - */ - getJoinedMemberCount(): number; - /** - * Returns the number of invited members in this room - * @returns The number of members in this room whose membership is 'invite' - */ - getInvitedMemberCount(): number; - /** - * Returns the number of invited + joined members in this room - * @returns The number of members in this room whose membership is 'invite' or 'join' - */ - getInvitedAndJoinedMemberCount(): number; - /** - * Get a list of members with given membership state. - * @param membership - The membership state. - * @returns A list of members with the given membership state. - */ - getMembersWithMembership(membership: string): RoomMember[]; - /** - * Get a list of members we should be encrypting for in this room - * @returns A list of members who - * we should encrypt messages for in this room. - */ - getEncryptionTargetMembers(): Promise; - /** - * Determine whether we should encrypt messages for invited users in this room - * @returns if we should encrypt messages for invited users - */ - shouldEncryptForInvitedMembers(): boolean; - /** - * Get the default room name (i.e. what a given user would see if the - * room had no m.room.name) - * @param userId - The userId from whose perspective we want - * to calculate the default name - * @returns The default room name - */ - getDefaultRoomName(userId: string): string; - /** - * Check if the given user_id has the given membership state. - * @param userId - The user ID to check. - * @param membership - The membership e.g. `'join'` - * @returns True if this user_id has the given membership state. - */ - hasMembershipState(userId: string, membership: string): boolean; - /** - * Add a timelineSet for this room with the given filter - * @param filter - The filter to be applied to this timelineSet - * @param opts - Configuration options - * @returns The timelineSet - */ - getOrCreateFilteredTimelineSet(filter: Filter, { prepopulateTimeline, useSyncEvents, pendingEvents }?: ICreateFilterOpts): EventTimelineSet; - private getThreadListFilter; - private createThreadTimelineSet; - private threadsReady; - /** - * Takes the given thread root events and creates threads for them. - */ - processThreadRoots(events: MatrixEvent[], toStartOfTimeline: boolean): void; - /** - * Fetch the bare minimum of room threads required for the thread list to work reliably. - * With server support that means fetching one page. - * Without server support that means fetching as much at once as the server allows us to. - */ - fetchRoomThreads(): Promise; - processPollEvents(events: MatrixEvent[]): Promise; - /** - * Fetch a single page of threadlist messages for the specific thread filter - * @internal - */ - private fetchRoomThreadList; - private onThreadNewReply; - private onThreadDelete; - /** - * Forget the timelineSet for this room with the given filter - * - * @param filter - the filter whose timelineSet is to be forgotten - */ - removeFilteredTimelineSet(filter: Filter): void; - eventShouldLiveIn(event: MatrixEvent, events?: MatrixEvent[], roots?: Set): { - shouldLiveInRoom: boolean; - shouldLiveInThread: boolean; - threadId?: string; - }; - findThreadForEvent(event?: MatrixEvent): Thread | null; - private addThreadedEvents; - /** - * Adds events to a thread's timeline. Will fire "Thread.update" - */ - processThreadedEvents(events: MatrixEvent[], toStartOfTimeline: boolean): void; - private updateThreadRootEvents; - private updateThreadRootEvent; - createThread(threadId: string, rootEvent: MatrixEvent | undefined, events: MatrixEvent[] | undefined, toStartOfTimeline: boolean): Thread; - private applyRedaction; - private processLiveEvent; - /** - * Add an event to the end of this room's live timelines. Will fire - * "Room.timeline". - * - * @param event - Event to be added - * @param addLiveEventOptions - addLiveEvent options - * @internal - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - private addLiveEvent; - /** - * Add a pending outgoing event to this room. - * - *

The event is added to either the pendingEventList, or the live timeline, - * depending on the setting of opts.pendingEventOrdering. - * - *

This is an internal method, intended for use by MatrixClient. - * - * @param event - The event to add. - * - * @param txnId - Transaction id for this outgoing event - * - * @throws if the event doesn't have status SENDING, or we aren't given a - * unique transaction id. - * - * @remarks - * Fires {@link RoomEvent.LocalEchoUpdated} - */ - addPendingEvent(event: MatrixEvent, txnId: string): void; - /** - * Persists all pending events to local storage - * - * If the current room is encrypted only encrypted events will be persisted - * all messages that are not yet encrypted will be discarded - * - * This is because the flow of EVENT_STATUS transition is - * `queued => sending => encrypting => sending => sent` - * - * Steps 3 and 4 are skipped for unencrypted room. - * It is better to discard an unencrypted message rather than persisting - * it locally for everyone to read - */ - private savePendingEvents; - /** - * Used to aggregate the local echo for a relation, and also - * for re-applying a relation after it's redaction has been cancelled, - * as the local echo for the redaction of the relation would have - * un-aggregated the relation. Note that this is different from regular messages, - * which are just kept detached for their local echo. - * - * Also note that live events are aggregated in the live EventTimelineSet. - * @param event - the relation event that needs to be aggregated. - */ - private aggregateNonLiveRelation; - getEventForTxnId(txnId: string): MatrixEvent | undefined; - /** - * Deal with the echo of a message we sent. - * - *

We move the event to the live timeline if it isn't there already, and - * update it. - * - * @param remoteEvent - The event received from - * /sync - * @param localEvent - The local echo, which - * should be either in the pendingEventList or the timeline. - * - * @internal - * - * @remarks - * Fires {@link RoomEvent.LocalEchoUpdated} - */ - handleRemoteEcho(remoteEvent: MatrixEvent, localEvent: MatrixEvent): void; - /** - * Update the status / event id on a pending event, to reflect its transmission - * progress. - * - *

This is an internal method. - * - * @param event - local echo event - * @param newStatus - status to assign - * @param newEventId - new event id to assign. Ignored unless newStatus == EventStatus.SENT. - * - * @remarks - * Fires {@link RoomEvent.LocalEchoUpdated} - */ - updatePendingEvent(event: MatrixEvent, newStatus: EventStatus, newEventId?: string): void; - private revertRedactionLocalEcho; - /** - * Add some events to this room. This can include state events, message - * events and typing notifications. These events are treated as "live" so - * they will go to the end of the timeline. - * - * @param events - A list of events to add. - * @param addLiveEventOptions - addLiveEvent options - * @throws If `duplicateStrategy` is not falsey, 'replace' or 'ignore'. - */ - addLiveEvents(events: MatrixEvent[], addLiveEventOptions?: IAddLiveEventOptions): void; - /** - * @deprecated In favor of the overload with `IAddLiveEventOptions` - */ - addLiveEvents(events: MatrixEvent[], duplicateStrategy?: DuplicateStrategy, fromCache?: boolean): void; - partitionThreadedEvents(events: MatrixEvent[]): [timelineEvents: MatrixEvent[], threadedEvents: MatrixEvent[]]; - /** - * Given some events, find the IDs of all the thread roots that are referred to by them. - */ - private findThreadRoots; - /** - * Add a receipt event to the room. - * @param event - The m.receipt event. - * @param synthetic - True if this event is implicit. - */ - addReceipt(event: MatrixEvent, synthetic?: boolean): void; - /** - * Adds/handles ephemeral events such as typing notifications and read receipts. - * @param events - A list of events to process - */ - addEphemeralEvents(events: MatrixEvent[]): void; - /** - * Removes events from this room. - * @param eventIds - A list of eventIds to remove. - */ - removeEvents(eventIds: string[]): void; - /** - * Removes a single event from this room. - * - * @param eventId - The id of the event to remove - * - * @returns true if the event was removed from any of the room's timeline sets - */ - removeEvent(eventId: string): boolean; - /** - * Recalculate various aspects of the room, including the room name and - * room summary. Call this any time the room's current state is modified. - * May fire "Room.name" if the room name is updated. - * - * @remarks - * Fires {@link RoomEvent.Name} - */ - recalculate(): void; - /** - * Update the room-tag event for the room. The previous one is overwritten. - * @param event - the m.tag event - */ - addTags(event: MatrixEvent): void; - /** - * Update the account_data events for this room, overwriting events of the same type. - * @param events - an array of account_data events to add - */ - addAccountData(events: MatrixEvent[]): void; - /** - * Access account_data event of given event type for this room - * @param type - the type of account_data event to be accessed - * @returns the account_data event in question - */ - getAccountData(type: EventType | string): MatrixEvent | undefined; - /** - * Returns whether the syncing user has permission to send a message in the room - * @returns true if the user should be permitted to send - * message events into the room. - */ - maySendMessage(): boolean; - /** - * Returns whether the given user has permissions to issue an invite for this room. - * @param userId - the ID of the Matrix user to check permissions for - * @returns true if the user should be permitted to issue invites for this room. - */ - canInvite(userId: string): boolean; - /** - * Returns the join rule based on the m.room.join_rule state event, defaulting to `invite`. - * @returns the join_rule applied to this room - */ - getJoinRule(): JoinRule; - /** - * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`. - * @returns the history_visibility applied to this room - */ - getHistoryVisibility(): HistoryVisibility; - /** - * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`. - * @returns the history_visibility applied to this room - */ - getGuestAccess(): GuestAccess; - /** - * Returns the type of the room from the `m.room.create` event content or undefined if none is set - * @returns the type of the room. - */ - getType(): RoomType | string | undefined; - /** - * Returns whether the room is a space-room as defined by MSC1772. - * @returns true if the room's type is RoomType.Space - */ - isSpaceRoom(): boolean; - /** - * Returns whether the room is a call-room as defined by MSC3417. - * @returns true if the room's type is RoomType.UnstableCall - */ - isCallRoom(): boolean; - /** - * Returns whether the room is a video room. - * @returns true if the room's type is RoomType.ElementVideo - */ - isElementVideoRoom(): boolean; - /** - * Find the predecessor of this room. - * - * @param msc3946ProcessDynamicPredecessor - if true, look for an - * m.room.predecessor state event and use it if found (MSC3946). - * @returns null if this room has no predecessor. Otherwise, returns - * the roomId, last eventId and viaServers of the predecessor room. - * - * If msc3946ProcessDynamicPredecessor is true, use m.predecessor events - * as well as m.room.create events to find predecessors. - * - * Note: if an m.predecessor event is used, eventId may be undefined - * since last_known_event_id is optional. - * - * Note: viaServers may be undefined, and will definitely be undefined if - * this predecessor comes from a RoomCreate event (rather than a - * RoomPredecessor, which has the optional via_servers property). - */ - findPredecessor(msc3946ProcessDynamicPredecessor?: boolean): { - roomId: string; - eventId?: string; - viaServers?: string[]; - } | null; - private roomNameGenerator; - /** - * This is an internal method. Calculates the name of the room from the current - * room state. - * @param userId - The client's user ID. Used to filter room members - * correctly. - * @param ignoreRoomNameEvent - Return the implicit room name that we'd see if there - * was no m.room.name event. - * @returns The calculated room name. - */ - private calculateRoomName; - /** - * When we receive a new visibility change event: - * - * - store this visibility change alongside the timeline, in case we - * later need to apply it to an event that we haven't received yet; - * - if we have already received the event whose visibility has changed, - * patch it to reflect the visibility change and inform listeners. - */ - private applyNewVisibilityEvent; - private redactVisibilityChangeEvent; - /** - * When we receive an event whose visibility has been altered by - * a (more recent) visibility change event, patch the event in - * place so that clients now not to display it. - * - * @param event - Any matrix event. If this event has at least one a - * pending visibility change event, apply the latest visibility - * change event. - */ - private applyPendingVisibilityEvents; - /** - * Find when a client has gained thread capabilities by inspecting the oldest - * threaded receipt - * @returns the timestamp of the oldest threaded receipt - */ - getOldestThreadedReceiptTs(): number; - /** - * Returns the most recent unthreaded receipt for a given user - * @param userId - the MxID of the User - * @returns an unthreaded Receipt. Can be undefined if receipts have been disabled - * or a user chooses to use private read receipts (or we have simply not received - * a receipt from this user yet). - */ - getLastUnthreadedReceiptFor(userId: string): Receipt | undefined; - /** - * This issue should also be addressed on synapse's side and is tracked as part - * of https://github.com/matrix-org/synapse/issues/14837 - * - * - * We consider a room fully read if the current user has sent - * the last event in the live timeline of that context and if the read receipt - * we have on record matches. - * This also detects all unread threads and applies the same logic to those - * contexts - */ - fixupNotifications(userId: string): void; -} -export declare enum RoomNameType { - EmptyRoom = 0, - Generated = 1, - Actual = 2 -} -export interface EmptyRoomNameState { - type: RoomNameType.EmptyRoom; - oldName?: string; -} -export interface GeneratedRoomNameState { - type: RoomNameType.Generated; - subtype?: "Inviting"; - names: string[]; - count: number; -} -export interface ActualRoomNameState { - type: RoomNameType.Actual; - name: string; -} -export type RoomNameState = EmptyRoomNameState | GeneratedRoomNameState | ActualRoomNameState; -export {}; -//# sourceMappingURL=room.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts.map deleted file mode 100644 index ce49a21..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room.d.ts","sourceRoot":"","sources":["../../src/models/room.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js deleted file mode 100644 index 46dd7de..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js +++ /dev/null @@ -1,2979 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomNameType = exports.RoomEvent = exports.Room = exports.NotificationCountType = exports.KNOWN_SAFE_ROOM_VERSION = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _matrixEventsSdk = require("matrix-events-sdk"); -var _eventTimelineSet = require("./event-timeline-set"); -var _eventTimeline = require("./event-timeline"); -var _contentRepo = require("../content-repo"); -var utils = _interopRequireWildcard(require("../utils")); -var _event = require("./event"); -var _eventStatus = require("./event-status"); -var _roomMember = require("./room-member"); -var _roomSummary = require("./room-summary"); -var _logger = require("../logger"); -var _ReEmitter = require("../ReEmitter"); -var _event2 = require("../@types/event"); -var _client = require("../client"); -var _filter = require("../filter"); -var _roomState = require("./room-state"); -var _beacon = require("./beacon"); -var _thread = require("./thread"); -var _read_receipts = require("../@types/read_receipts"); -var _relationsContainer = require("./relations-container"); -var _readReceipt = require("./read-receipt"); -var _poll = require("./poll"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -// These constants are used as sane defaults when the homeserver doesn't support -// the m.room_versions capability. In practice, KNOWN_SAFE_ROOM_VERSION should be -// the same as the common default room version whereas SAFE_ROOM_VERSIONS are the -// room versions which are considered okay for people to run without being asked -// to upgrade (ie: "stable"). Eventually, we should remove these when all homeservers -// return an m.room_versions capability. -const KNOWN_SAFE_ROOM_VERSION = "9"; -exports.KNOWN_SAFE_ROOM_VERSION = KNOWN_SAFE_ROOM_VERSION; -const SAFE_ROOM_VERSIONS = ["1", "2", "3", "4", "5", "6", "7", "8", "9"]; -// When inserting a visibility event affecting event `eventId`, we -// need to scan through existing visibility events for `eventId`. -// In theory, this could take an unlimited amount of time if: -// -// - the visibility event was sent by a moderator; and -// - `eventId` already has many visibility changes (usually, it should -// be 2 or less); and -// - for some reason, the visibility changes are received out of order -// (usually, this shouldn't happen at all). -// -// For this reason, we limit the number of events to scan through, -// expecting that a broken visibility change for a single event in -// an extremely uncommon case (possibly a DoS) is a small -// price to pay to keep matrix-js-sdk responsive. -const MAX_NUMBER_OF_VISIBILITY_EVENTS_TO_SCAN_THROUGH = 30; -let NotificationCountType; -exports.NotificationCountType = NotificationCountType; -(function (NotificationCountType) { - NotificationCountType["Highlight"] = "highlight"; - NotificationCountType["Total"] = "total"; -})(NotificationCountType || (exports.NotificationCountType = NotificationCountType = {})); -let RoomEvent; -exports.RoomEvent = RoomEvent; -(function (RoomEvent) { - RoomEvent["MyMembership"] = "Room.myMembership"; - RoomEvent["Tags"] = "Room.tags"; - RoomEvent["AccountData"] = "Room.accountData"; - RoomEvent["Receipt"] = "Room.receipt"; - RoomEvent["Name"] = "Room.name"; - RoomEvent["Redaction"] = "Room.redaction"; - RoomEvent["RedactionCancelled"] = "Room.redactionCancelled"; - RoomEvent["LocalEchoUpdated"] = "Room.localEchoUpdated"; - RoomEvent["Timeline"] = "Room.timeline"; - RoomEvent["TimelineReset"] = "Room.timelineReset"; - RoomEvent["TimelineRefresh"] = "Room.TimelineRefresh"; - RoomEvent["OldStateUpdated"] = "Room.OldStateUpdated"; - RoomEvent["CurrentStateUpdated"] = "Room.CurrentStateUpdated"; - RoomEvent["HistoryImportedWithinTimeline"] = "Room.historyImportedWithinTimeline"; - RoomEvent["UnreadNotifications"] = "Room.UnreadNotifications"; -})(RoomEvent || (exports.RoomEvent = RoomEvent = {})); -class Room extends _readReceipt.ReadReceipt { - // Pending in-flight requests { string: MatrixEvent } - - // Useful to know at what point the current user has started using threads in this room - - /** - * A record of the latest unthread receipts per user - * This is useful in determining whether a user has read a thread or not - */ - - // any filtered timeline sets we're maintaining for this room - // filter_id: timelineSet - - // read by megolm via getter; boolean value - null indicates "use global value" - - // flags to stop logspam about missing m.room.create events - - // XXX: These should be read-only - /** - * The human-readable display name for this room. - */ - - /** - * The un-homoglyphed name for this room. - */ - - /** - * Dict of room tags; the keys are the tag name and the values - * are any metadata associated with the tag - e.g. `{ "fav" : { order: 1 } }` - */ - // $tagName: { $metadata: $value } - /** - * accountData Dict of per-room account_data events; the keys are the - * event type and the values are the events. - */ - // $eventType: $event - /** - * The room summary. - */ - - // legacy fields - /** - * The live event timeline for this room, with the oldest event at index 0. - * Present for backwards compatibility - prefer getLiveTimeline().getEvents() - */ - - /** - * oldState The state of the room at the time of the oldest - * event in the live timeline. Present for backwards compatibility - - * prefer getLiveTimeline().getState(EventTimeline.BACKWARDS). - */ - - /** - * currentState The state of the room at the time of the - * newest event in the timeline. Present for backwards compatibility - - * prefer getLiveTimeline().getState(EventTimeline.FORWARDS). - */ - - /** - * A collection of events known by the client - * This is not a comprehensive list of the threads that exist in this room - */ - - /** - * A mapping of eventId to all visibility changes to apply - * to the event, by chronological order, as per - * https://github.com/matrix-org/matrix-doc/pull/3531 - * - * # Invariants - * - * - within each list, all events are classed by - * chronological order; - * - all events are events such that - * `asVisibilityEvent()` returns a non-null `IVisibilityChange`; - * - within each list with key `eventId`, all events - * are in relation to `eventId`. - * - * @experimental - */ - - /** - * Construct a new Room. - * - *

For a room, we store an ordered sequence of timelines, which may or may not - * be continuous. Each timeline lists a series of events, as well as tracking - * the room state at the start and the end of the timeline. It also tracks - * forward and backward pagination tokens, as well as containing links to the - * next timeline in the sequence. - * - *

There is one special timeline - the 'live' timeline, which represents the - * timeline to which events are being added in real-time as they are received - * from the /sync API. Note that you should not retain references to this - * timeline - even if it is the current timeline right now, it may not remain - * so if the server gives us a timeline gap in /sync. - * - *

In order that we can find events from their ids later, we also maintain a - * map from event_id to timeline and index. - * - * @param roomId - Required. The ID of this room. - * @param client - Required. The client, used to lazy load members. - * @param myUserId - Required. The ID of the syncing user. - * @param opts - Configuration options - */ - constructor(roomId, client, myUserId, opts = {}) { - super(); - // In some cases, we add listeners for every displayed Matrix event, so it's - // common to have quite a few more than the default limit. - this.roomId = roomId; - this.client = client; - this.myUserId = myUserId; - this.opts = opts; - (0, _defineProperty2.default)(this, "reEmitter", void 0); - (0, _defineProperty2.default)(this, "txnToEvent", new Map()); - (0, _defineProperty2.default)(this, "notificationCounts", {}); - (0, _defineProperty2.default)(this, "threadNotifications", new Map()); - (0, _defineProperty2.default)(this, "cachedThreadReadReceipts", new Map()); - (0, _defineProperty2.default)(this, "oldestThreadedReceiptTs", Infinity); - (0, _defineProperty2.default)(this, "unthreadedReceipts", new Map()); - (0, _defineProperty2.default)(this, "timelineSets", void 0); - (0, _defineProperty2.default)(this, "polls", new Map()); - (0, _defineProperty2.default)(this, "threadsTimelineSets", []); - (0, _defineProperty2.default)(this, "filteredTimelineSets", {}); - (0, _defineProperty2.default)(this, "timelineNeedsRefresh", false); - (0, _defineProperty2.default)(this, "pendingEventList", void 0); - (0, _defineProperty2.default)(this, "blacklistUnverifiedDevices", void 0); - (0, _defineProperty2.default)(this, "selfMembership", void 0); - (0, _defineProperty2.default)(this, "summaryHeroes", null); - (0, _defineProperty2.default)(this, "getTypeWarning", false); - (0, _defineProperty2.default)(this, "getVersionWarning", false); - (0, _defineProperty2.default)(this, "membersPromise", void 0); - (0, _defineProperty2.default)(this, "name", void 0); - (0, _defineProperty2.default)(this, "normalizedName", void 0); - (0, _defineProperty2.default)(this, "tags", {}); - (0, _defineProperty2.default)(this, "accountData", new Map()); - (0, _defineProperty2.default)(this, "summary", null); - (0, _defineProperty2.default)(this, "timeline", void 0); - (0, _defineProperty2.default)(this, "oldState", void 0); - (0, _defineProperty2.default)(this, "currentState", void 0); - (0, _defineProperty2.default)(this, "relations", new _relationsContainer.RelationsContainer(this.client, this)); - (0, _defineProperty2.default)(this, "threads", new Map()); - (0, _defineProperty2.default)(this, "lastThread", void 0); - (0, _defineProperty2.default)(this, "visibilityEvents", new Map()); - (0, _defineProperty2.default)(this, "threadTimelineSetsPromise", null); - (0, _defineProperty2.default)(this, "threadsReady", false); - (0, _defineProperty2.default)(this, "updateThreadRootEvents", (thread, toStartOfTimeline, recreateEvent) => { - if (thread.length) { - var _this$threadsTimeline; - this.updateThreadRootEvent((_this$threadsTimeline = this.threadsTimelineSets) === null || _this$threadsTimeline === void 0 ? void 0 : _this$threadsTimeline[0], thread, toStartOfTimeline, recreateEvent); - if (thread.hasCurrentUserParticipated) { - var _this$threadsTimeline2; - this.updateThreadRootEvent((_this$threadsTimeline2 = this.threadsTimelineSets) === null || _this$threadsTimeline2 === void 0 ? void 0 : _this$threadsTimeline2[1], thread, toStartOfTimeline, recreateEvent); - } - } - }); - (0, _defineProperty2.default)(this, "updateThreadRootEvent", (timelineSet, thread, toStartOfTimeline, recreateEvent) => { - if (timelineSet && thread.rootEvent) { - if (recreateEvent) { - timelineSet.removeEvent(thread.id); - } - if (_thread.Thread.hasServerSideSupport) { - timelineSet.addLiveEvent(thread.rootEvent, { - duplicateStrategy: _eventTimelineSet.DuplicateStrategy.Replace, - fromCache: false, - roomState: this.currentState - }); - } else { - timelineSet.addEventToTimeline(thread.rootEvent, timelineSet.getLiveTimeline(), { - toStartOfTimeline - }); - } - } - }); - (0, _defineProperty2.default)(this, "applyRedaction", event => { - if (event.isRedaction()) { - const redactId = event.event.redacts; - - // if we know about this event, redact its contents now. - const redactedEvent = redactId ? this.findEventById(redactId) : undefined; - if (redactedEvent) { - redactedEvent.makeRedacted(event); - - // If this is in the current state, replace it with the redacted version - if (redactedEvent.isState()) { - const currentStateEvent = this.currentState.getStateEvents(redactedEvent.getType(), redactedEvent.getStateKey()); - if ((currentStateEvent === null || currentStateEvent === void 0 ? void 0 : currentStateEvent.getId()) === redactedEvent.getId()) { - this.currentState.setStateEvents([redactedEvent]); - } - } - this.emit(RoomEvent.Redaction, event, this); - - // TODO: we stash user displaynames (among other things) in - // RoomMember objects which are then attached to other events - // (in the sender and target fields). We should get those - // RoomMember objects to update themselves when the events that - // they are based on are changed. - - // Remove any visibility change on this event. - this.visibilityEvents.delete(redactId); - - // If this event is a visibility change event, remove it from the - // list of visibility changes and update any event affected by it. - if (redactedEvent.isVisibilityEvent()) { - this.redactVisibilityChangeEvent(event); - } - } - - // FIXME: apply redactions to notification list - - // NB: We continue to add the redaction event to the timeline so - // clients can say "so and so redacted an event" if they wish to. Also - // this may be needed to trigger an update. - } - }); - this.setMaxListeners(100); - this.reEmitter = new _ReEmitter.TypedReEmitter(this); - opts.pendingEventOrdering = opts.pendingEventOrdering || _client.PendingEventOrdering.Chronological; - this.name = roomId; - this.normalizedName = roomId; - - // all our per-room timeline sets. the first one is the unfiltered ones; - // the subsequent ones are the filtered ones in no particular order. - this.timelineSets = [new _eventTimelineSet.EventTimelineSet(this, opts)]; - this.reEmitter.reEmit(this.getUnfilteredTimelineSet(), [RoomEvent.Timeline, RoomEvent.TimelineReset]); - this.fixUpLegacyTimelineFields(); - if (this.opts.pendingEventOrdering === _client.PendingEventOrdering.Detached) { - this.pendingEventList = []; - this.client.store.getPendingEvents(this.roomId).then(events => { - const mapper = this.client.getEventMapper({ - toDevice: false, - decrypt: false - }); - events.forEach(async serializedEvent => { - const event = mapper(serializedEvent); - await client.decryptEventIfNeeded(event); - event.setStatus(_eventStatus.EventStatus.NOT_SENT); - this.addPendingEvent(event, event.getTxnId()); - }); - }); - } - - // awaited by getEncryptionTargetMembers while room members are loading - if (!this.opts.lazyLoadMembers) { - this.membersPromise = Promise.resolve(false); - } else { - this.membersPromise = undefined; - } - } - async createThreadsTimelineSets() { - var _this$client; - if (this.threadTimelineSetsPromise) { - return this.threadTimelineSetsPromise; - } - if ((_this$client = this.client) !== null && _this$client !== void 0 && _this$client.supportsThreads()) { - try { - this.threadTimelineSetsPromise = Promise.all([this.createThreadTimelineSet(), this.createThreadTimelineSet(_thread.ThreadFilterType.My)]); - const timelineSets = await this.threadTimelineSetsPromise; - this.threadsTimelineSets.push(...timelineSets); - return timelineSets; - } catch (e) { - this.threadTimelineSetsPromise = null; - return null; - } - } - return null; - } - - /** - * Bulk decrypt critical events in a room - * - * Critical events represents the minimal set of events to decrypt - * for a typical UI to function properly - * - * - Last event of every room (to generate likely message preview) - * - All events up to the read receipt (to calculate an accurate notification count) - * - * @returns Signals when all events have been decrypted - */ - async decryptCriticalEvents() { - if (!this.client.isCryptoEnabled()) return; - const readReceiptEventId = this.getEventReadUpTo(this.client.getUserId(), true); - const events = this.getLiveTimeline().getEvents(); - const readReceiptTimelineIndex = events.findIndex(matrixEvent => { - return matrixEvent.event.event_id === readReceiptEventId; - }); - const decryptionPromises = events.slice(readReceiptTimelineIndex).reverse().map(event => this.client.decryptEventIfNeeded(event, { - isRetry: true - })); - await Promise.allSettled(decryptionPromises); - } - - /** - * Bulk decrypt events in a room - * - * @returns Signals when all events have been decrypted - */ - async decryptAllEvents() { - if (!this.client.isCryptoEnabled()) return; - const decryptionPromises = this.getUnfilteredTimelineSet().getLiveTimeline().getEvents().slice(0) // copy before reversing - .reverse().map(event => this.client.decryptEventIfNeeded(event, { - isRetry: true - })); - await Promise.allSettled(decryptionPromises); - } - - /** - * Gets the creator of the room - * @returns The creator of the room, or null if it could not be determined - */ - getCreator() { - var _createEvent$getConte; - const createEvent = this.currentState.getStateEvents(_event2.EventType.RoomCreate, ""); - return (_createEvent$getConte = createEvent === null || createEvent === void 0 ? void 0 : createEvent.getContent()["creator"]) !== null && _createEvent$getConte !== void 0 ? _createEvent$getConte : null; - } - - /** - * Gets the version of the room - * @returns The version of the room, or null if it could not be determined - */ - getVersion() { - var _createEvent$getConte2; - const createEvent = this.currentState.getStateEvents(_event2.EventType.RoomCreate, ""); - if (!createEvent) { - if (!this.getVersionWarning) { - _logger.logger.warn("[getVersion] Room " + this.roomId + " does not have an m.room.create event"); - this.getVersionWarning = true; - } - return "1"; - } - return (_createEvent$getConte2 = createEvent.getContent()["room_version"]) !== null && _createEvent$getConte2 !== void 0 ? _createEvent$getConte2 : "1"; - } - - /** - * Determines whether this room needs to be upgraded to a new version - * @returns What version the room should be upgraded to, or null if - * the room does not require upgrading at this time. - * @deprecated Use #getRecommendedVersion() instead - */ - shouldUpgradeToVersion() { - // TODO: Remove this function. - // This makes assumptions about which versions are safe, and can easily - // be wrong. Instead, people are encouraged to use getRecommendedVersion - // which determines a safer value. This function doesn't use that function - // because this is not async-capable, and to avoid breaking the contract - // we're deprecating this. - - if (!SAFE_ROOM_VERSIONS.includes(this.getVersion())) { - return KNOWN_SAFE_ROOM_VERSION; - } - return null; - } - - /** - * Determines the recommended room version for the room. This returns an - * object with 3 properties: `version` as the new version the - * room should be upgraded to (may be the same as the current version); - * `needsUpgrade` to indicate if the room actually can be - * upgraded (ie: does the current version not match?); and `urgent` - * to indicate if the new version patches a vulnerability in a previous - * version. - * @returns - * Resolves to the version the room should be upgraded to. - */ - async getRecommendedVersion() { - const capabilities = await this.client.getCapabilities(); - let versionCap = capabilities["m.room_versions"]; - if (!versionCap) { - versionCap = { - default: KNOWN_SAFE_ROOM_VERSION, - available: {} - }; - for (const safeVer of SAFE_ROOM_VERSIONS) { - versionCap.available[safeVer] = _client.RoomVersionStability.Stable; - } - } - let result = this.checkVersionAgainstCapability(versionCap); - if (result.urgent && result.needsUpgrade) { - // Something doesn't feel right: we shouldn't need to update - // because the version we're on should be in the protocol's - // namespace. This usually means that the server was updated - // before the client was, making us think the newest possible - // room version is not stable. As a solution, we'll refresh - // the capability we're using to determine this. - _logger.logger.warn("Refreshing room version capability because the server looks " + "to be supporting a newer room version we don't know about."); - const caps = await this.client.getCapabilities(true); - versionCap = caps["m.room_versions"]; - if (!versionCap) { - _logger.logger.warn("No room version capability - assuming upgrade required."); - return result; - } else { - result = this.checkVersionAgainstCapability(versionCap); - } - } - return result; - } - checkVersionAgainstCapability(versionCap) { - const currentVersion = this.getVersion(); - _logger.logger.log(`[${this.roomId}] Current version: ${currentVersion}`); - _logger.logger.log(`[${this.roomId}] Version capability: `, versionCap); - const result = { - version: currentVersion, - needsUpgrade: false, - urgent: false - }; - - // If the room is on the default version then nothing needs to change - if (currentVersion === versionCap.default) return result; - const stableVersions = Object.keys(versionCap.available).filter(v => versionCap.available[v] === "stable"); - - // Check if the room is on an unstable version. We determine urgency based - // off the version being in the Matrix spec namespace or not (if the version - // is in the current namespace and unstable, the room is probably vulnerable). - if (!stableVersions.includes(currentVersion)) { - result.version = versionCap.default; - result.needsUpgrade = true; - result.urgent = !!this.getVersion().match(/^[0-9]+[0-9.]*$/g); - if (result.urgent) { - _logger.logger.warn(`URGENT upgrade required on ${this.roomId}`); - } else { - _logger.logger.warn(`Non-urgent upgrade required on ${this.roomId}`); - } - return result; - } - - // The room is on a stable, but non-default, version by this point. - // No upgrade needed. - return result; - } - - /** - * Determines whether the given user is permitted to perform a room upgrade - * @param userId - The ID of the user to test against - * @returns True if the given user is permitted to upgrade the room - */ - userMayUpgradeRoom(userId) { - return this.currentState.maySendStateEvent(_event2.EventType.RoomTombstone, userId); - } - - /** - * Get the list of pending sent events for this room - * - * @returns A list of the sent events - * waiting for remote echo. - * - * @throws If `opts.pendingEventOrdering` was not 'detached' - */ - getPendingEvents() { - if (!this.pendingEventList) { - throw new Error("Cannot call getPendingEvents with pendingEventOrdering == " + this.opts.pendingEventOrdering); - } - return this.pendingEventList; - } - - /** - * Removes a pending event for this room - * - * @returns True if an element was removed. - */ - removePendingEvent(eventId) { - if (!this.pendingEventList) { - throw new Error("Cannot call removePendingEvent with pendingEventOrdering == " + this.opts.pendingEventOrdering); - } - const removed = utils.removeElement(this.pendingEventList, function (ev) { - return ev.getId() == eventId; - }, false); - this.savePendingEvents(); - return removed; - } - - /** - * Check whether the pending event list contains a given event by ID. - * If pending event ordering is not "detached" then this returns false. - * - * @param eventId - The event ID to check for. - */ - hasPendingEvent(eventId) { - var _this$pendingEventLis, _this$pendingEventLis2; - return (_this$pendingEventLis = (_this$pendingEventLis2 = this.pendingEventList) === null || _this$pendingEventLis2 === void 0 ? void 0 : _this$pendingEventLis2.some(event => event.getId() === eventId)) !== null && _this$pendingEventLis !== void 0 ? _this$pendingEventLis : false; - } - - /** - * Get a specific event from the pending event list, if configured, null otherwise. - * - * @param eventId - The event ID to check for. - */ - getPendingEvent(eventId) { - var _this$pendingEventLis3, _this$pendingEventLis4; - return (_this$pendingEventLis3 = (_this$pendingEventLis4 = this.pendingEventList) === null || _this$pendingEventLis4 === void 0 ? void 0 : _this$pendingEventLis4.find(event => event.getId() === eventId)) !== null && _this$pendingEventLis3 !== void 0 ? _this$pendingEventLis3 : null; - } - - /** - * Get the live unfiltered timeline for this room. - * - * @returns live timeline - */ - getLiveTimeline() { - return this.getUnfilteredTimelineSet().getLiveTimeline(); - } - - /** - * Get the timestamp of the last message in the room - * - * @returns the timestamp of the last message in the room - */ - getLastActiveTimestamp() { - const timeline = this.getLiveTimeline(); - const events = timeline.getEvents(); - if (events.length) { - const lastEvent = events[events.length - 1]; - return lastEvent.getTs(); - } else { - return Number.MIN_SAFE_INTEGER; - } - } - - /** - * @returns the membership type (join | leave | invite) for the logged in user - */ - getMyMembership() { - var _this$selfMembership; - return (_this$selfMembership = this.selfMembership) !== null && _this$selfMembership !== void 0 ? _this$selfMembership : "leave"; - } - - /** - * If this room is a DM we're invited to, - * try to find out who invited us - * @returns user id of the inviter - */ - getDMInviter() { - const me = this.getMember(this.myUserId); - if (me) { - return me.getDMInviter(); - } - if (this.selfMembership === "invite") { - // fall back to summary information - const memberCount = this.getInvitedAndJoinedMemberCount(); - if (memberCount === 2) { - var _this$summaryHeroes; - return (_this$summaryHeroes = this.summaryHeroes) === null || _this$summaryHeroes === void 0 ? void 0 : _this$summaryHeroes[0]; - } - } - } - - /** - * Assuming this room is a DM room, tries to guess with which user. - * @returns user id of the other member (could be syncing user) - */ - guessDMUserId() { - const me = this.getMember(this.myUserId); - if (me) { - const inviterId = me.getDMInviter(); - if (inviterId) { - return inviterId; - } - } - // Remember, we're assuming this room is a DM, so returning the first member we find should be fine - if (Array.isArray(this.summaryHeroes) && this.summaryHeroes.length) { - return this.summaryHeroes[0]; - } - const members = this.currentState.getMembers(); - const anyMember = members.find(m => m.userId !== this.myUserId); - if (anyMember) { - return anyMember.userId; - } - // it really seems like I'm the only user in the room - // so I probably created a room with just me in it - // and marked it as a DM. Ok then - return this.myUserId; - } - getAvatarFallbackMember() { - const memberCount = this.getInvitedAndJoinedMemberCount(); - if (memberCount > 2) { - return; - } - const hasHeroes = Array.isArray(this.summaryHeroes) && this.summaryHeroes.length; - if (hasHeroes) { - const availableMember = this.summaryHeroes.map(userId => { - return this.getMember(userId); - }).find(member => !!member); - if (availableMember) { - return availableMember; - } - } - const members = this.currentState.getMembers(); - // could be different than memberCount - // as this includes left members - if (members.length <= 2) { - const availableMember = members.find(m => { - return m.userId !== this.myUserId; - }); - if (availableMember) { - return availableMember; - } - } - // if all else fails, try falling back to a user, - // and create a one-off member for it - if (hasHeroes) { - const availableUser = this.summaryHeroes.map(userId => { - return this.client.getUser(userId); - }).find(user => !!user); - if (availableUser) { - const member = new _roomMember.RoomMember(this.roomId, availableUser.userId); - member.user = availableUser; - return member; - } - } - } - - /** - * Sets the membership this room was received as during sync - * @param membership - join | leave | invite - */ - updateMyMembership(membership) { - const prevMembership = this.selfMembership; - this.selfMembership = membership; - if (prevMembership !== membership) { - if (membership === "leave") { - this.cleanupAfterLeaving(); - } - this.emit(RoomEvent.MyMembership, this, membership, prevMembership); - } - } - async loadMembersFromServer() { - const lastSyncToken = this.client.store.getSyncToken(); - const response = await this.client.members(this.roomId, undefined, "leave", lastSyncToken !== null && lastSyncToken !== void 0 ? lastSyncToken : undefined); - return response.chunk; - } - async loadMembers() { - // were the members loaded from the server? - let fromServer = false; - let rawMembersEvents = await this.client.store.getOutOfBandMembers(this.roomId); - // If the room is encrypted, we always fetch members from the server at - // least once, in case the latest state wasn't persisted properly. Note - // that this function is only called once (unless loading the members - // fails), since loadMembersIfNeeded always returns this.membersPromise - // if set, which will be the result of the first (successful) call. - if (rawMembersEvents === null || this.client.isCryptoEnabled() && this.client.isRoomEncrypted(this.roomId)) { - fromServer = true; - rawMembersEvents = await this.loadMembersFromServer(); - _logger.logger.log(`LL: got ${rawMembersEvents.length} ` + `members from server for room ${this.roomId}`); - } - const memberEvents = rawMembersEvents.filter(utils.noUnsafeEventProps).map(this.client.getEventMapper()); - return { - memberEvents, - fromServer - }; - } - - /** - * Check if loading of out-of-band-members has completed - * - * @returns true if the full membership list of this room has been loaded (including if lazy-loading is disabled). - * False if the load is not started or is in progress. - */ - membersLoaded() { - if (!this.opts.lazyLoadMembers) { - return true; - } - return this.currentState.outOfBandMembersReady(); - } - - /** - * Preloads the member list in case lazy loading - * of memberships is in use. Can be called multiple times, - * it will only preload once. - * @returns when preloading is done and - * accessing the members on the room will take - * all members in the room into account - */ - loadMembersIfNeeded() { - if (this.membersPromise) { - return this.membersPromise; - } - - // mark the state so that incoming messages while - // the request is in flight get marked as superseding - // the OOB members - this.currentState.markOutOfBandMembersStarted(); - const inMemoryUpdate = this.loadMembers().then(result => { - this.currentState.setOutOfBandMembers(result.memberEvents); - return result.fromServer; - }).catch(err => { - // allow retries on fail - this.membersPromise = undefined; - this.currentState.markOutOfBandMembersFailed(); - throw err; - }); - // update members in storage, but don't wait for it - inMemoryUpdate.then(fromServer => { - if (fromServer) { - const oobMembers = this.currentState.getMembers().filter(m => m.isOutOfBand()).map(m => { - var _m$events$member; - return (_m$events$member = m.events.member) === null || _m$events$member === void 0 ? void 0 : _m$events$member.event; - }); - _logger.logger.log(`LL: telling store to write ${oobMembers.length}` + ` members for room ${this.roomId}`); - const store = this.client.store; - return store.setOutOfBandMembers(this.roomId, oobMembers) - // swallow any IDB error as we don't want to fail - // because of this - .catch(err => { - _logger.logger.log("LL: storing OOB room members failed, oh well", err); - }); - } - }).catch(err => { - // as this is not awaited anywhere, - // at least show the error in the console - _logger.logger.error(err); - }); - this.membersPromise = inMemoryUpdate; - return this.membersPromise; - } - - /** - * Removes the lazily loaded members from storage if needed - */ - async clearLoadedMembersIfNeeded() { - if (this.opts.lazyLoadMembers && this.membersPromise) { - await this.loadMembersIfNeeded(); - await this.client.store.clearOutOfBandMembers(this.roomId); - this.currentState.clearOutOfBandMembers(); - this.membersPromise = undefined; - } - } - - /** - * called when sync receives this room in the leave section - * to do cleanup after leaving a room. Possibly called multiple times. - */ - cleanupAfterLeaving() { - this.clearLoadedMembersIfNeeded().catch(err => { - _logger.logger.error(`error after clearing loaded members from ` + `room ${this.roomId} after leaving`); - _logger.logger.log(err); - }); - } - - /** - * Empty out the current live timeline and re-request it. This is used when - * historical messages are imported into the room via MSC2716 `/batch_send` - * because the client may already have that section of the timeline loaded. - * We need to force the client to throw away their current timeline so that - * when they back paginate over the area again with the historical messages - * in between, it grabs the newly imported messages. We can listen for - * `UNSTABLE_MSC2716_MARKER`, in order to tell when historical messages are ready - * to be discovered in the room and the timeline needs a refresh. The SDK - * emits a `RoomEvent.HistoryImportedWithinTimeline` event when we detect a - * valid marker and can check the needs refresh status via - * `room.getTimelineNeedsRefresh()`. - */ - async refreshLiveTimeline() { - const liveTimelineBefore = this.getLiveTimeline(); - const forwardPaginationToken = liveTimelineBefore.getPaginationToken(_eventTimeline.EventTimeline.FORWARDS); - const backwardPaginationToken = liveTimelineBefore.getPaginationToken(_eventTimeline.EventTimeline.BACKWARDS); - const eventsBefore = liveTimelineBefore.getEvents(); - const mostRecentEventInTimeline = eventsBefore[eventsBefore.length - 1]; - _logger.logger.log(`[refreshLiveTimeline for ${this.roomId}] at ` + `mostRecentEventInTimeline=${mostRecentEventInTimeline && mostRecentEventInTimeline.getId()} ` + `liveTimelineBefore=${liveTimelineBefore.toString()} ` + `forwardPaginationToken=${forwardPaginationToken} ` + `backwardPaginationToken=${backwardPaginationToken}`); - - // Get the main TimelineSet - const timelineSet = this.getUnfilteredTimelineSet(); - let newTimeline; - // If there isn't any event in the timeline, let's go fetch the latest - // event and construct a timeline from it. - // - // This should only really happen if the user ran into an error - // with refreshing the timeline before which left them in a blank - // timeline from `resetLiveTimeline`. - if (!mostRecentEventInTimeline) { - newTimeline = await this.client.getLatestTimeline(timelineSet); - } else { - // Empty out all of `this.timelineSets`. But we also need to keep the - // same `timelineSet` references around so the React code updates - // properly and doesn't ignore the room events we emit because it checks - // that the `timelineSet` references are the same. We need the - // `timelineSet` empty so that the `client.getEventTimeline(...)` call - // later, will call `/context` and create a new timeline instead of - // returning the same one. - this.resetLiveTimeline(null, null); - - // Make the UI timeline show the new blank live timeline we just - // reset so that if the network fails below it's showing the - // accurate state of what we're working with instead of the - // disconnected one in the TimelineWindow which is just hanging - // around by reference. - this.emit(RoomEvent.TimelineRefresh, this, timelineSet); - - // Use `client.getEventTimeline(...)` to construct a new timeline from a - // `/context` response state and events for the most recent event before - // we reset everything. The `timelineSet` we pass in needs to be empty - // in order for this function to call `/context` and generate a new - // timeline. - newTimeline = await this.client.getEventTimeline(timelineSet, mostRecentEventInTimeline.getId()); - } - - // If a racing `/sync` beat us to creating a new timeline, use that - // instead because it's the latest in the room and any new messages in - // the scrollback will include the history. - const liveTimeline = timelineSet.getLiveTimeline(); - if (!liveTimeline || liveTimeline.getPaginationToken(_eventTimeline.Direction.Forward) === null && liveTimeline.getPaginationToken(_eventTimeline.Direction.Backward) === null && liveTimeline.getEvents().length === 0) { - _logger.logger.log(`[refreshLiveTimeline for ${this.roomId}] using our new live timeline`); - // Set the pagination token back to the live sync token (`null`) instead - // of using the `/context` historical token (ex. `t12-13_0_0_0_0_0_0_0_0`) - // so that it matches the next response from `/sync` and we can properly - // continue the timeline. - newTimeline.setPaginationToken(forwardPaginationToken, _eventTimeline.EventTimeline.FORWARDS); - - // Set our new fresh timeline as the live timeline to continue syncing - // forwards and back paginating from. - timelineSet.setLiveTimeline(newTimeline); - // Fixup `this.oldstate` so that `scrollback` has the pagination tokens - // available - this.fixUpLegacyTimelineFields(); - } else { - _logger.logger.log(`[refreshLiveTimeline for ${this.roomId}] \`/sync\` or some other request beat us to creating a new ` + `live timeline after we reset it. We'll use that instead since any events in the scrollback from ` + `this timeline will include the history.`); - } - - // The timeline has now been refreshed ✅ - this.setTimelineNeedsRefresh(false); - - // Emit an event which clients can react to and re-load the timeline - // from the SDK - this.emit(RoomEvent.TimelineRefresh, this, timelineSet); - } - - /** - * Reset the live timeline of all timelineSets, and start new ones. - * - *

This is used when /sync returns a 'limited' timeline. - * - * @param backPaginationToken - token for back-paginating the new timeline - * @param forwardPaginationToken - token for forward-paginating the old live timeline, - * if absent or null, all timelines are reset, removing old ones (including the previous live - * timeline which would otherwise be unable to paginate forwards without this token). - * Removing just the old live timeline whilst preserving previous ones is not supported. - */ - resetLiveTimeline(backPaginationToken, forwardPaginationToken) { - for (const timelineSet of this.timelineSets) { - timelineSet.resetLiveTimeline(backPaginationToken !== null && backPaginationToken !== void 0 ? backPaginationToken : undefined, forwardPaginationToken !== null && forwardPaginationToken !== void 0 ? forwardPaginationToken : undefined); - } - for (const thread of this.threads.values()) { - thread.resetLiveTimeline(backPaginationToken, forwardPaginationToken); - } - this.fixUpLegacyTimelineFields(); - } - - /** - * Fix up this.timeline, this.oldState and this.currentState - * - * @internal - */ - fixUpLegacyTimelineFields() { - const previousOldState = this.oldState; - const previousCurrentState = this.currentState; - - // maintain this.timeline as a reference to the live timeline, - // and this.oldState and this.currentState as references to the - // state at the start and end of that timeline. These are more - // for backwards-compatibility than anything else. - this.timeline = this.getLiveTimeline().getEvents(); - this.oldState = this.getLiveTimeline().getState(_eventTimeline.EventTimeline.BACKWARDS); - this.currentState = this.getLiveTimeline().getState(_eventTimeline.EventTimeline.FORWARDS); - - // Let people know to register new listeners for the new state - // references. The reference won't necessarily change every time so only - // emit when we see a change. - if (previousOldState !== this.oldState) { - this.emit(RoomEvent.OldStateUpdated, this, previousOldState, this.oldState); - } - if (previousCurrentState !== this.currentState) { - this.emit(RoomEvent.CurrentStateUpdated, this, previousCurrentState, this.currentState); - - // Re-emit various events on the current room state - // TODO: If currentState really only exists for backwards - // compatibility, shouldn't we be doing this some other way? - this.reEmitter.stopReEmitting(previousCurrentState, [_roomState.RoomStateEvent.Events, _roomState.RoomStateEvent.Members, _roomState.RoomStateEvent.NewMember, _roomState.RoomStateEvent.Update, _roomState.RoomStateEvent.Marker, _beacon.BeaconEvent.New, _beacon.BeaconEvent.Update, _beacon.BeaconEvent.Destroy, _beacon.BeaconEvent.LivenessChange]); - this.reEmitter.reEmit(this.currentState, [_roomState.RoomStateEvent.Events, _roomState.RoomStateEvent.Members, _roomState.RoomStateEvent.NewMember, _roomState.RoomStateEvent.Update, _roomState.RoomStateEvent.Marker, _beacon.BeaconEvent.New, _beacon.BeaconEvent.Update, _beacon.BeaconEvent.Destroy, _beacon.BeaconEvent.LivenessChange]); - } - } - - /** - * Returns whether there are any devices in the room that are unverified - * - * Note: Callers should first check if crypto is enabled on this device. If it is - * disabled, then we aren't tracking room devices at all, so we can't answer this, and an - * error will be thrown. - * - * @returns the result - */ - async hasUnverifiedDevices() { - if (!this.client.isRoomEncrypted(this.roomId)) { - return false; - } - const e2eMembers = await this.getEncryptionTargetMembers(); - for (const member of e2eMembers) { - const devices = this.client.getStoredDevicesForUser(member.userId); - if (devices.some(device => device.isUnverified())) { - return true; - } - } - return false; - } - - /** - * Return the timeline sets for this room. - * @returns array of timeline sets for this room - */ - getTimelineSets() { - return this.timelineSets; - } - - /** - * Helper to return the main unfiltered timeline set for this room - * @returns room's unfiltered timeline set - */ - getUnfilteredTimelineSet() { - return this.timelineSets[0]; - } - - /** - * Get the timeline which contains the given event from the unfiltered set, if any - * - * @param eventId - event ID to look for - * @returns timeline containing - * the given event, or null if unknown - */ - getTimelineForEvent(eventId) { - const event = this.findEventById(eventId); - const thread = this.findThreadForEvent(event); - if (thread) { - return thread.timelineSet.getTimelineForEvent(eventId); - } else { - return this.getUnfilteredTimelineSet().getTimelineForEvent(eventId); - } - } - - /** - * Add a new timeline to this room's unfiltered timeline set - * - * @returns newly-created timeline - */ - addTimeline() { - return this.getUnfilteredTimelineSet().addTimeline(); - } - - /** - * Whether the timeline needs to be refreshed in order to pull in new - * historical messages that were imported. - * @param value - The value to set - */ - setTimelineNeedsRefresh(value) { - this.timelineNeedsRefresh = value; - } - - /** - * Whether the timeline needs to be refreshed in order to pull in new - * historical messages that were imported. - * @returns . - */ - getTimelineNeedsRefresh() { - return this.timelineNeedsRefresh; - } - - /** - * Get an event which is stored in our unfiltered timeline set, or in a thread - * - * @param eventId - event ID to look for - * @returns the given event, or undefined if unknown - */ - findEventById(eventId) { - let event = this.getUnfilteredTimelineSet().findEventById(eventId); - if (!event) { - const threads = this.getThreads(); - for (let i = 0; i < threads.length; i++) { - const thread = threads[i]; - event = thread.findEventById(eventId); - if (event) { - return event; - } - } - } - return event; - } - - /** - * Get one of the notification counts for this room - * @param type - The type of notification count to get. default: 'total' - * @returns The notification count, or undefined if there is no count - * for this type. - */ - getUnreadNotificationCount(type = NotificationCountType.Total) { - let count = this.getRoomUnreadNotificationCount(type); - for (const threadNotification of this.threadNotifications.values()) { - var _threadNotification$t; - count += (_threadNotification$t = threadNotification[type]) !== null && _threadNotification$t !== void 0 ? _threadNotification$t : 0; - } - return count; - } - - /** - * Get the notification for the event context (room or thread timeline) - */ - getUnreadCountForEventContext(type = NotificationCountType.Total, event) { - var _ref; - const isThreadEvent = !!event.threadRootId && !event.isThreadRoot; - return (_ref = isThreadEvent ? this.getThreadUnreadNotificationCount(event.threadRootId, type) : this.getRoomUnreadNotificationCount(type)) !== null && _ref !== void 0 ? _ref : 0; - } - - /** - * Get one of the notification counts for this room - * @param type - The type of notification count to get. default: 'total' - * @returns The notification count, or undefined if there is no count - * for this type. - */ - getRoomUnreadNotificationCount(type = NotificationCountType.Total) { - var _this$notificationCou; - return (_this$notificationCou = this.notificationCounts[type]) !== null && _this$notificationCou !== void 0 ? _this$notificationCou : 0; - } - - /** - * Get one of the notification counts for a thread - * @param threadId - the root event ID - * @param type - The type of notification count to get. default: 'total' - * @returns The notification count, or undefined if there is no count - * for this type. - */ - getThreadUnreadNotificationCount(threadId, type = NotificationCountType.Total) { - var _this$threadNotificat, _this$threadNotificat2; - return (_this$threadNotificat = (_this$threadNotificat2 = this.threadNotifications.get(threadId)) === null || _this$threadNotificat2 === void 0 ? void 0 : _this$threadNotificat2[type]) !== null && _this$threadNotificat !== void 0 ? _this$threadNotificat : 0; - } - - /** - * Checks if the current room has unread thread notifications - * @returns - */ - hasThreadUnreadNotification() { - for (const notification of this.threadNotifications.values()) { - var _notification$highlig, _notification$total; - if (((_notification$highlig = notification.highlight) !== null && _notification$highlig !== void 0 ? _notification$highlig : 0) > 0 || ((_notification$total = notification.total) !== null && _notification$total !== void 0 ? _notification$total : 0) > 0) { - return true; - } - } - return false; - } - - /** - * Swet one of the notification count for a thread - * @param threadId - the root event ID - * @param type - The type of notification count to get. default: 'total' - * @returns - */ - setThreadUnreadNotificationCount(threadId, type, count) { - var _this$threadNotificat3, _this$threadNotificat4; - const notification = _objectSpread({ - highlight: (_this$threadNotificat3 = this.threadNotifications.get(threadId)) === null || _this$threadNotificat3 === void 0 ? void 0 : _this$threadNotificat3.highlight, - total: (_this$threadNotificat4 = this.threadNotifications.get(threadId)) === null || _this$threadNotificat4 === void 0 ? void 0 : _this$threadNotificat4.total - }, { - [type]: count - }); - this.threadNotifications.set(threadId, notification); - this.emit(RoomEvent.UnreadNotifications, notification, threadId); - } - - /** - * @returns the notification count type for all the threads in the room - */ - get threadsAggregateNotificationType() { - let type = null; - for (const threadNotification of this.threadNotifications.values()) { - var _threadNotification$h, _threadNotification$t2; - if (((_threadNotification$h = threadNotification.highlight) !== null && _threadNotification$h !== void 0 ? _threadNotification$h : 0) > 0) { - return NotificationCountType.Highlight; - } else if (((_threadNotification$t2 = threadNotification.total) !== null && _threadNotification$t2 !== void 0 ? _threadNotification$t2 : 0) > 0 && !type) { - type = NotificationCountType.Total; - } - } - return type; - } - - /** - * Resets the thread notifications for this room - */ - resetThreadUnreadNotificationCount(notificationsToKeep) { - if (notificationsToKeep) { - for (const [threadId] of this.threadNotifications) { - if (!notificationsToKeep.includes(threadId)) { - this.threadNotifications.delete(threadId); - } - } - } else { - this.threadNotifications.clear(); - } - this.emit(RoomEvent.UnreadNotifications); - } - - /** - * Set one of the notification counts for this room - * @param type - The type of notification count to set. - * @param count - The new count - */ - setUnreadNotificationCount(type, count) { - this.notificationCounts[type] = count; - this.emit(RoomEvent.UnreadNotifications, this.notificationCounts); - } - setUnread(type, count) { - return this.setUnreadNotificationCount(type, count); - } - setSummary(summary) { - const heroes = summary["m.heroes"]; - const joinedCount = summary["m.joined_member_count"]; - const invitedCount = summary["m.invited_member_count"]; - if (Number.isInteger(joinedCount)) { - this.currentState.setJoinedMemberCount(joinedCount); - } - if (Number.isInteger(invitedCount)) { - this.currentState.setInvitedMemberCount(invitedCount); - } - if (Array.isArray(heroes)) { - // be cautious about trusting server values, - // and make sure heroes doesn't contain our own id - // just to be sure - this.summaryHeroes = heroes.filter(userId => { - return userId !== this.myUserId; - }); - } - } - - /** - * Whether to send encrypted messages to devices within this room. - * @param value - true to blacklist unverified devices, null - * to use the global value for this room. - */ - setBlacklistUnverifiedDevices(value) { - this.blacklistUnverifiedDevices = value; - } - - /** - * Whether to send encrypted messages to devices within this room. - * @returns true if blacklisting unverified devices, null - * if the global value should be used for this room. - */ - getBlacklistUnverifiedDevices() { - if (this.blacklistUnverifiedDevices === undefined) return null; - return this.blacklistUnverifiedDevices; - } - - /** - * Get the avatar URL for a room if one was set. - * @param baseUrl - The homeserver base URL. See - * {@link MatrixClient#getHomeserverUrl}. - * @param width - The desired width of the thumbnail. - * @param height - The desired height of the thumbnail. - * @param resizeMethod - The thumbnail resize method to use, either - * "crop" or "scale". - * @param allowDefault - True to allow an identicon for this room if an - * avatar URL wasn't explicitly set. Default: true. (Deprecated) - * @returns the avatar URL or null. - */ - getAvatarUrl(baseUrl, width, height, resizeMethod, allowDefault = true) { - const roomAvatarEvent = this.currentState.getStateEvents(_event2.EventType.RoomAvatar, ""); - if (!roomAvatarEvent && !allowDefault) { - return null; - } - const mainUrl = roomAvatarEvent ? roomAvatarEvent.getContent().url : null; - if (mainUrl) { - return (0, _contentRepo.getHttpUriForMxc)(baseUrl, mainUrl, width, height, resizeMethod); - } - return null; - } - - /** - * Get the mxc avatar url for the room, if one was set. - * @returns the mxc avatar url or falsy - */ - getMxcAvatarUrl() { - var _this$currentState$ge, _this$currentState$ge2; - return ((_this$currentState$ge = this.currentState.getStateEvents(_event2.EventType.RoomAvatar, "")) === null || _this$currentState$ge === void 0 ? void 0 : (_this$currentState$ge2 = _this$currentState$ge.getContent()) === null || _this$currentState$ge2 === void 0 ? void 0 : _this$currentState$ge2.url) || null; - } - - /** - * Get this room's canonical alias - * The alias returned by this function may not necessarily - * still point to this room. - * @returns The room's canonical alias, or null if there is none - */ - getCanonicalAlias() { - const canonicalAlias = this.currentState.getStateEvents(_event2.EventType.RoomCanonicalAlias, ""); - if (canonicalAlias) { - return canonicalAlias.getContent().alias || null; - } - return null; - } - - /** - * Get this room's alternative aliases - * @returns The room's alternative aliases, or an empty array - */ - getAltAliases() { - const canonicalAlias = this.currentState.getStateEvents(_event2.EventType.RoomCanonicalAlias, ""); - if (canonicalAlias) { - return canonicalAlias.getContent().alt_aliases || []; - } - return []; - } - - /** - * Add events to a timeline - * - *

Will fire "Room.timeline" for each event added. - * - * @param events - A list of events to add. - * - * @param toStartOfTimeline - True to add these events to the start - * (oldest) instead of the end (newest) of the timeline. If true, the oldest - * event will be the last element of 'events'. - * - * @param timeline - timeline to - * add events to. - * - * @param paginationToken - token for the next batch of events - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - addEventsToTimeline(events, toStartOfTimeline, timeline, paginationToken) { - timeline.getTimelineSet().addEventsToTimeline(events, toStartOfTimeline, timeline, paginationToken); - } - - /** - * Get the instance of the thread associated with the current event - * @param eventId - the ID of the current event - * @returns a thread instance if known - */ - getThread(eventId) { - var _this$threads$get; - return (_this$threads$get = this.threads.get(eventId)) !== null && _this$threads$get !== void 0 ? _this$threads$get : null; - } - - /** - * Get all the known threads in the room - */ - getThreads() { - return Array.from(this.threads.values()); - } - - /** - * Get a member from the current room state. - * @param userId - The user ID of the member. - * @returns The member or `null`. - */ - getMember(userId) { - return this.currentState.getMember(userId); - } - - /** - * Get all currently loaded members from the current - * room state. - * @returns Room members - */ - getMembers() { - return this.currentState.getMembers(); - } - - /** - * Get a list of members whose membership state is "join". - * @returns A list of currently joined members. - */ - getJoinedMembers() { - return this.getMembersWithMembership("join"); - } - - /** - * Returns the number of joined members in this room - * This method caches the result. - * This is a wrapper around the method of the same name in roomState, returning - * its result for the room's current state. - * @returns The number of members in this room whose membership is 'join' - */ - getJoinedMemberCount() { - return this.currentState.getJoinedMemberCount(); - } - - /** - * Returns the number of invited members in this room - * @returns The number of members in this room whose membership is 'invite' - */ - getInvitedMemberCount() { - return this.currentState.getInvitedMemberCount(); - } - - /** - * Returns the number of invited + joined members in this room - * @returns The number of members in this room whose membership is 'invite' or 'join' - */ - getInvitedAndJoinedMemberCount() { - return this.getInvitedMemberCount() + this.getJoinedMemberCount(); - } - - /** - * Get a list of members with given membership state. - * @param membership - The membership state. - * @returns A list of members with the given membership state. - */ - getMembersWithMembership(membership) { - return this.currentState.getMembers().filter(function (m) { - return m.membership === membership; - }); - } - - /** - * Get a list of members we should be encrypting for in this room - * @returns A list of members who - * we should encrypt messages for in this room. - */ - async getEncryptionTargetMembers() { - await this.loadMembersIfNeeded(); - let members = this.getMembersWithMembership("join"); - if (this.shouldEncryptForInvitedMembers()) { - members = members.concat(this.getMembersWithMembership("invite")); - } - return members; - } - - /** - * Determine whether we should encrypt messages for invited users in this room - * @returns if we should encrypt messages for invited users - */ - shouldEncryptForInvitedMembers() { - var _ev$getContent; - const ev = this.currentState.getStateEvents(_event2.EventType.RoomHistoryVisibility, ""); - return (ev === null || ev === void 0 ? void 0 : (_ev$getContent = ev.getContent()) === null || _ev$getContent === void 0 ? void 0 : _ev$getContent.history_visibility) !== "joined"; - } - - /** - * Get the default room name (i.e. what a given user would see if the - * room had no m.room.name) - * @param userId - The userId from whose perspective we want - * to calculate the default name - * @returns The default room name - */ - getDefaultRoomName(userId) { - return this.calculateRoomName(userId, true); - } - - /** - * Check if the given user_id has the given membership state. - * @param userId - The user ID to check. - * @param membership - The membership e.g. `'join'` - * @returns True if this user_id has the given membership state. - */ - hasMembershipState(userId, membership) { - const member = this.getMember(userId); - if (!member) { - return false; - } - return member.membership === membership; - } - - /** - * Add a timelineSet for this room with the given filter - * @param filter - The filter to be applied to this timelineSet - * @param opts - Configuration options - * @returns The timelineSet - */ - getOrCreateFilteredTimelineSet(filter, { - prepopulateTimeline = true, - useSyncEvents = true, - pendingEvents = true - } = {}) { - if (this.filteredTimelineSets[filter.filterId]) { - return this.filteredTimelineSets[filter.filterId]; - } - const opts = Object.assign({ - filter, - pendingEvents - }, this.opts); - const timelineSet = new _eventTimelineSet.EventTimelineSet(this, opts); - this.reEmitter.reEmit(timelineSet, [RoomEvent.Timeline, RoomEvent.TimelineReset]); - if (useSyncEvents) { - this.filteredTimelineSets[filter.filterId] = timelineSet; - this.timelineSets.push(timelineSet); - } - const unfilteredLiveTimeline = this.getLiveTimeline(); - // Not all filter are possible to replicate client-side only - // When that's the case we do not want to prepopulate from the live timeline - // as we would get incorrect results compared to what the server would send back - if (prepopulateTimeline) { - // populate up the new timelineSet with filtered events from our live - // unfiltered timeline. - // - // XXX: This is risky as our timeline - // may have grown huge and so take a long time to filter. - // see https://github.com/vector-im/vector-web/issues/2109 - - unfilteredLiveTimeline.getEvents().forEach(function (event) { - timelineSet.addLiveEvent(event); - }); - - // find the earliest unfiltered timeline - let timeline = unfilteredLiveTimeline; - while (timeline.getNeighbouringTimeline(_eventTimeline.EventTimeline.BACKWARDS)) { - timeline = timeline.getNeighbouringTimeline(_eventTimeline.EventTimeline.BACKWARDS); - } - timelineSet.getLiveTimeline().setPaginationToken(timeline.getPaginationToken(_eventTimeline.EventTimeline.BACKWARDS), _eventTimeline.EventTimeline.BACKWARDS); - } else if (useSyncEvents) { - const livePaginationToken = unfilteredLiveTimeline.getPaginationToken(_eventTimeline.Direction.Forward); - timelineSet.getLiveTimeline().setPaginationToken(livePaginationToken, _eventTimeline.Direction.Backward); - } - - // alternatively, we could try to do something like this to try and re-paginate - // in the filtered events from nothing, but Mark says it's an abuse of the API - // to do so: - // - // timelineSet.resetLiveTimeline( - // unfilteredLiveTimeline.getPaginationToken(EventTimeline.FORWARDS) - // ); - - return timelineSet; - } - async getThreadListFilter(filterType = _thread.ThreadFilterType.All) { - const myUserId = this.client.getUserId(); - const filter = new _filter.Filter(myUserId); - const definition = { - room: { - timeline: { - [_thread.FILTER_RELATED_BY_REL_TYPES.name]: [_thread.THREAD_RELATION_TYPE.name] - } - } - }; - if (filterType === _thread.ThreadFilterType.My) { - definition.room.timeline[_thread.FILTER_RELATED_BY_SENDERS.name] = [myUserId]; - } - filter.setDefinition(definition); - const filterId = await this.client.getOrCreateFilter(`THREAD_PANEL_${this.roomId}_${filterType}`, filter); - filter.filterId = filterId; - return filter; - } - async createThreadTimelineSet(filterType) { - let timelineSet; - if (_thread.Thread.hasServerSideListSupport) { - timelineSet = new _eventTimelineSet.EventTimelineSet(this, _objectSpread(_objectSpread({}, this.opts), {}, { - pendingEvents: false - }), undefined, undefined, filterType !== null && filterType !== void 0 ? filterType : _thread.ThreadFilterType.All); - this.reEmitter.reEmit(timelineSet, [RoomEvent.Timeline, RoomEvent.TimelineReset]); - } else if (_thread.Thread.hasServerSideSupport) { - const filter = await this.getThreadListFilter(filterType); - timelineSet = this.getOrCreateFilteredTimelineSet(filter, { - prepopulateTimeline: false, - useSyncEvents: false, - pendingEvents: false - }); - } else { - timelineSet = new _eventTimelineSet.EventTimelineSet(this, { - pendingEvents: false - }); - Array.from(this.threads).forEach(([, thread]) => { - if (thread.length === 0) return; - const currentUserParticipated = thread.timeline.some(event => { - return event.getSender() === this.client.getUserId(); - }); - if (filterType !== _thread.ThreadFilterType.My || currentUserParticipated) { - timelineSet.getLiveTimeline().addEvent(thread.rootEvent, { - toStartOfTimeline: false - }); - } - }); - } - return timelineSet; - } - /** - * Takes the given thread root events and creates threads for them. - */ - processThreadRoots(events, toStartOfTimeline) { - for (const rootEvent of events) { - _eventTimeline.EventTimeline.setEventMetadata(rootEvent, this.currentState, toStartOfTimeline); - if (!this.getThread(rootEvent.getId())) { - this.createThread(rootEvent.getId(), rootEvent, [], toStartOfTimeline); - } - } - } - - /** - * Fetch the bare minimum of room threads required for the thread list to work reliably. - * With server support that means fetching one page. - * Without server support that means fetching as much at once as the server allows us to. - */ - async fetchRoomThreads() { - if (this.threadsReady || !this.client.supportsThreads()) { - return; - } - if (_thread.Thread.hasServerSideListSupport) { - await Promise.all([this.fetchRoomThreadList(_thread.ThreadFilterType.All), this.fetchRoomThreadList(_thread.ThreadFilterType.My)]); - } else { - const allThreadsFilter = await this.getThreadListFilter(); - const { - chunk: events - } = await this.client.createMessagesRequest(this.roomId, "", Number.MAX_SAFE_INTEGER, _eventTimeline.Direction.Backward, allThreadsFilter); - if (!events.length) return; - - // Sorted by last_reply origin_server_ts - const threadRoots = events.map(this.client.getEventMapper()).sort((eventA, eventB) => { - /** - * `origin_server_ts` in a decentralised world is far from ideal - * but for lack of any better, we will have to use this - * Long term the sorting should be handled by homeservers and this - * is only meant as a short term patch - */ - const threadAMetadata = eventA.getServerAggregatedRelation(_thread.THREAD_RELATION_TYPE.name); - const threadBMetadata = eventB.getServerAggregatedRelation(_thread.THREAD_RELATION_TYPE.name); - return threadAMetadata.latest_event.origin_server_ts - threadBMetadata.latest_event.origin_server_ts; - }); - let latestMyThreadsRootEvent; - const roomState = this.getLiveTimeline().getState(_eventTimeline.EventTimeline.FORWARDS); - for (const rootEvent of threadRoots) { - var _this$threadsTimeline3; - const opts = { - duplicateStrategy: _eventTimelineSet.DuplicateStrategy.Ignore, - fromCache: false, - roomState - }; - (_this$threadsTimeline3 = this.threadsTimelineSets[0]) === null || _this$threadsTimeline3 === void 0 ? void 0 : _this$threadsTimeline3.addLiveEvent(rootEvent, opts); - const threadRelationship = rootEvent.getServerAggregatedRelation(_thread.THREAD_RELATION_TYPE.name); - if (threadRelationship !== null && threadRelationship !== void 0 && threadRelationship.current_user_participated) { - var _this$threadsTimeline4; - (_this$threadsTimeline4 = this.threadsTimelineSets[1]) === null || _this$threadsTimeline4 === void 0 ? void 0 : _this$threadsTimeline4.addLiveEvent(rootEvent, opts); - latestMyThreadsRootEvent = rootEvent; - } - } - this.processThreadRoots(threadRoots, true); - this.client.decryptEventIfNeeded(threadRoots[threadRoots.length - 1]); - if (latestMyThreadsRootEvent) { - this.client.decryptEventIfNeeded(latestMyThreadsRootEvent); - } - } - this.on(_thread.ThreadEvent.NewReply, this.onThreadNewReply); - this.on(_thread.ThreadEvent.Delete, this.onThreadDelete); - this.threadsReady = true; - } - async processPollEvents(events) { - const processPollStartEvent = event => { - if (!_matrixEventsSdk.M_POLL_START.matches(event.getType())) return; - try { - const poll = new _poll.Poll(event, this.client, this); - this.polls.set(event.getId(), poll); - this.emit(_poll.PollEvent.New, poll); - } catch {} - // poll creation can fail for malformed poll start events - }; - - const processPollRelationEvent = event => { - const relationEventId = event.relationEventId; - if (relationEventId && this.polls.has(relationEventId)) { - const poll = this.polls.get(relationEventId); - poll === null || poll === void 0 ? void 0 : poll.onNewRelation(event); - } - }; - const processPollEvent = event => { - processPollStartEvent(event); - processPollRelationEvent(event); - }; - for (const event of events) { - try { - await this.client.decryptEventIfNeeded(event); - processPollEvent(event); - } catch {} - } - } - - /** - * Fetch a single page of threadlist messages for the specific thread filter - * @internal - */ - async fetchRoomThreadList(filter) { - const timelineSet = filter === _thread.ThreadFilterType.My ? this.threadsTimelineSets[1] : this.threadsTimelineSets[0]; - const { - chunk: events, - end - } = await this.client.createThreadListMessagesRequest(this.roomId, null, undefined, _eventTimeline.Direction.Backward, timelineSet.threadListType, timelineSet.getFilter()); - timelineSet.getLiveTimeline().setPaginationToken(end !== null && end !== void 0 ? end : null, _eventTimeline.Direction.Backward); - if (!events.length) return; - const matrixEvents = events.map(this.client.getEventMapper()); - this.processThreadRoots(matrixEvents, true); - const roomState = this.getLiveTimeline().getState(_eventTimeline.EventTimeline.FORWARDS); - for (const rootEvent of matrixEvents) { - timelineSet.addLiveEvent(rootEvent, { - duplicateStrategy: _eventTimelineSet.DuplicateStrategy.Replace, - fromCache: false, - roomState - }); - } - } - onThreadNewReply(thread) { - this.updateThreadRootEvents(thread, false, true); - } - onThreadDelete(thread) { - var _timeline$getEvents; - this.threads.delete(thread.id); - const timeline = this.getTimelineForEvent(thread.id); - const roomEvent = timeline === null || timeline === void 0 ? void 0 : (_timeline$getEvents = timeline.getEvents()) === null || _timeline$getEvents === void 0 ? void 0 : _timeline$getEvents.find(it => it.getId() === thread.id); - if (roomEvent) { - thread.clearEventMetadata(roomEvent); - } else { - _logger.logger.debug("onThreadDelete: Could not find root event in room timeline"); - } - for (const timelineSet of this.threadsTimelineSets) { - timelineSet.removeEvent(thread.id); - } - } - - /** - * Forget the timelineSet for this room with the given filter - * - * @param filter - the filter whose timelineSet is to be forgotten - */ - removeFilteredTimelineSet(filter) { - const timelineSet = this.filteredTimelineSets[filter.filterId]; - delete this.filteredTimelineSets[filter.filterId]; - const i = this.timelineSets.indexOf(timelineSet); - if (i > -1) { - this.timelineSets.splice(i, 1); - } - } - eventShouldLiveIn(event, events, roots) { - var _this$client2; - if (!((_this$client2 = this.client) !== null && _this$client2 !== void 0 && _this$client2.supportsThreads())) { - return { - shouldLiveInRoom: true, - shouldLiveInThread: false - }; - } - - // A thread root is always shown in both timelines - if (event.isThreadRoot || roots !== null && roots !== void 0 && roots.has(event.getId())) { - return { - shouldLiveInRoom: true, - shouldLiveInThread: true, - threadId: event.getId() - }; - } - - // A thread relation is always only shown in a thread - if (event.isRelation(_thread.THREAD_RELATION_TYPE.name)) { - return { - shouldLiveInRoom: false, - shouldLiveInThread: true, - threadId: event.threadRootId - }; - } - const parentEventId = event.getAssociatedId(); - let parentEvent; - if (parentEventId) { - var _this$findEventById; - parentEvent = (_this$findEventById = this.findEventById(parentEventId)) !== null && _this$findEventById !== void 0 ? _this$findEventById : events === null || events === void 0 ? void 0 : events.find(e => e.getId() === parentEventId); - } - - // Treat relations and redactions as extensions of their parents so evaluate parentEvent instead - if (parentEvent && (event.isRelation() || event.isRedaction())) { - return this.eventShouldLiveIn(parentEvent, events, roots); - } - - // Edge case where we know the event is a relation but don't have the parentEvent - if (roots !== null && roots !== void 0 && roots.has(event.relationEventId)) { - return { - shouldLiveInRoom: true, - shouldLiveInThread: true, - threadId: event.relationEventId - }; - } - - // We've exhausted all scenarios, can safely assume that this event should live in the room timeline only - return { - shouldLiveInRoom: true, - shouldLiveInThread: false - }; - } - findThreadForEvent(event) { - if (!event) return null; - const { - threadId - } = this.eventShouldLiveIn(event); - return threadId ? this.getThread(threadId) : null; - } - addThreadedEvents(threadId, events, toStartOfTimeline = false) { - let thread = this.getThread(threadId); - if (!thread) { - var _this$findEventById2; - const rootEvent = (_this$findEventById2 = this.findEventById(threadId)) !== null && _this$findEventById2 !== void 0 ? _this$findEventById2 : events.find(e => e.getId() === threadId); - thread = this.createThread(threadId, rootEvent, events, toStartOfTimeline); - } - thread.addEvents(events, toStartOfTimeline); - } - - /** - * Adds events to a thread's timeline. Will fire "Thread.update" - */ - processThreadedEvents(events, toStartOfTimeline) { - events.forEach(this.applyRedaction); - const eventsByThread = {}; - for (const event of events) { - var _eventsByThread; - const { - threadId, - shouldLiveInThread - } = this.eventShouldLiveIn(event); - if (shouldLiveInThread && !eventsByThread[threadId]) { - eventsByThread[threadId] = []; - } - (_eventsByThread = eventsByThread[threadId]) === null || _eventsByThread === void 0 ? void 0 : _eventsByThread.push(event); - } - Object.entries(eventsByThread).map(([threadId, threadEvents]) => this.addThreadedEvents(threadId, threadEvents, toStartOfTimeline)); - } - createThread(threadId, rootEvent, events = [], toStartOfTimeline) { - var _this$cachedThreadRea, _this$lastThread, _this$lastThread$root; - if (this.threads.has(threadId)) { - return this.threads.get(threadId); - } - if (rootEvent) { - const relatedEvents = this.relations.getAllChildEventsForEvent(rootEvent.getId()); - if (relatedEvents !== null && relatedEvents !== void 0 && relatedEvents.length) { - // Include all relations of the root event, given it'll be visible in both timelines, - // except `m.replace` as that will already be applied atop the event using `MatrixEvent::makeReplaced` - events = events.concat(relatedEvents.filter(e => !e.isRelation(_event2.RelationType.Replace))); - } - } - const thread = new _thread.Thread(threadId, rootEvent, { - room: this, - client: this.client, - pendingEventOrdering: this.opts.pendingEventOrdering, - receipts: (_this$cachedThreadRea = this.cachedThreadReadReceipts.get(threadId)) !== null && _this$cachedThreadRea !== void 0 ? _this$cachedThreadRea : [] - }); - - // All read receipts should now come down from sync, we do not need to keep - // a reference to the cached receipts anymore. - this.cachedThreadReadReceipts.delete(threadId); - - // If we managed to create a thread and figure out its `id` then we can use it - // This has to happen before thread.addEvents, because that adds events to the eventtimeline, and the - // eventtimeline sometimes looks up thread information via the room. - this.threads.set(thread.id, thread); - - // This is necessary to be able to jump to events in threads: - // If we jump to an event in a thread where neither the event, nor the root, - // nor any thread event are loaded yet, we'll load the event as well as the thread root, create the thread, - // and pass the event through this. - thread.addEvents(events, false); - this.reEmitter.reEmit(thread, [_thread.ThreadEvent.Delete, _thread.ThreadEvent.Update, _thread.ThreadEvent.NewReply, RoomEvent.Timeline, RoomEvent.TimelineReset]); - const isNewer = ((_this$lastThread = this.lastThread) === null || _this$lastThread === void 0 ? void 0 : _this$lastThread.rootEvent) && (rootEvent === null || rootEvent === void 0 ? void 0 : rootEvent.localTimestamp) && ((_this$lastThread$root = this.lastThread.rootEvent) === null || _this$lastThread$root === void 0 ? void 0 : _this$lastThread$root.localTimestamp) < (rootEvent === null || rootEvent === void 0 ? void 0 : rootEvent.localTimestamp); - if (!this.lastThread || isNewer) { - this.lastThread = thread; - } - if (this.threadsReady) { - this.updateThreadRootEvents(thread, toStartOfTimeline, false); - } - this.emit(_thread.ThreadEvent.New, thread, toStartOfTimeline); - return thread; - } - processLiveEvent(event) { - this.applyRedaction(event); - - // Implement MSC3531: hiding messages. - if (event.isVisibilityEvent()) { - // This event changes the visibility of another event, record - // the visibility change, inform clients if necessary. - this.applyNewVisibilityEvent(event); - } - // If any pending visibility change is waiting for this (older) event, - this.applyPendingVisibilityEvents(event); - - // Sliding Sync modifications: - // The proxy cannot guarantee every sent event will have a transaction_id field, so we need - // to check the event ID against the list of pending events if there is no transaction ID - // field. Only do this for events sent by us though as it's potentially expensive to loop - // the pending events map. - const txnId = event.getUnsigned().transaction_id; - if (!txnId && event.getSender() === this.myUserId) { - // check the txn map for a matching event ID - for (const [tid, localEvent] of this.txnToEvent) { - if (localEvent.getId() === event.getId()) { - _logger.logger.debug("processLiveEvent: found sent event without txn ID: ", tid, event.getId()); - // update the unsigned field so we can re-use the same codepaths - const unsigned = event.getUnsigned(); - unsigned.transaction_id = tid; - event.setUnsigned(unsigned); - break; - } - } - } - } - - /** - * Add an event to the end of this room's live timelines. Will fire - * "Room.timeline". - * - * @param event - Event to be added - * @param addLiveEventOptions - addLiveEvent options - * @internal - * - * @remarks - * Fires {@link RoomEvent.Timeline} - */ - addLiveEvent(event, addLiveEventOptions) { - const { - duplicateStrategy, - timelineWasEmpty, - fromCache - } = addLiveEventOptions; - - // add to our timeline sets - for (const timelineSet of this.timelineSets) { - timelineSet.addLiveEvent(event, { - duplicateStrategy, - fromCache, - timelineWasEmpty - }); - } - - // synthesize and inject implicit read receipts - // Done after adding the event because otherwise the app would get a read receipt - // pointing to an event that wasn't yet in the timeline - // Don't synthesize RR for m.room.redaction as this causes the RR to go missing. - if (event.sender && event.getType() !== _event2.EventType.RoomRedaction) { - this.addReceipt((0, _readReceipt.synthesizeReceipt)(event.sender.userId, event, _read_receipts.ReceiptType.Read), true); - - // Any live events from a user could be taken as implicit - // presence information: evidence that they are currently active. - // ...except in a world where we use 'user.currentlyActive' to reduce - // presence spam, this isn't very useful - we'll get a transition when - // they are no longer currently active anyway. So don't bother to - // reset the lastActiveAgo and lastPresenceTs from the RoomState's user. - } - } - - /** - * Add a pending outgoing event to this room. - * - *

The event is added to either the pendingEventList, or the live timeline, - * depending on the setting of opts.pendingEventOrdering. - * - *

This is an internal method, intended for use by MatrixClient. - * - * @param event - The event to add. - * - * @param txnId - Transaction id for this outgoing event - * - * @throws if the event doesn't have status SENDING, or we aren't given a - * unique transaction id. - * - * @remarks - * Fires {@link RoomEvent.LocalEchoUpdated} - */ - addPendingEvent(event, txnId) { - if (event.status !== _eventStatus.EventStatus.SENDING && event.status !== _eventStatus.EventStatus.NOT_SENT) { - throw new Error("addPendingEvent called on an event with status " + event.status); - } - if (this.txnToEvent.get(txnId)) { - throw new Error("addPendingEvent called on an event with known txnId " + txnId); - } - - // call setEventMetadata to set up event.sender etc - // as event is shared over all timelineSets, we set up its metadata based - // on the unfiltered timelineSet. - _eventTimeline.EventTimeline.setEventMetadata(event, this.getLiveTimeline().getState(_eventTimeline.EventTimeline.FORWARDS), false); - this.txnToEvent.set(txnId, event); - if (this.pendingEventList) { - if (this.pendingEventList.some(e => e.status === _eventStatus.EventStatus.NOT_SENT)) { - _logger.logger.warn("Setting event as NOT_SENT due to messages in the same state"); - event.setStatus(_eventStatus.EventStatus.NOT_SENT); - } - this.pendingEventList.push(event); - this.savePendingEvents(); - if (event.isRelation()) { - // For pending events, add them to the relations collection immediately. - // (The alternate case below already covers this as part of adding to - // the timeline set.) - this.aggregateNonLiveRelation(event); - } - if (event.isRedaction()) { - const redactId = event.event.redacts; - let redactedEvent = this.pendingEventList.find(e => e.getId() === redactId); - if (!redactedEvent && redactId) { - redactedEvent = this.findEventById(redactId); - } - if (redactedEvent) { - redactedEvent.markLocallyRedacted(event); - this.emit(RoomEvent.Redaction, event, this); - } - } - } else { - for (const timelineSet of this.timelineSets) { - if (timelineSet.getFilter()) { - if (timelineSet.getFilter().filterRoomTimeline([event]).length) { - timelineSet.addEventToTimeline(event, timelineSet.getLiveTimeline(), { - toStartOfTimeline: false - }); - } - } else { - timelineSet.addEventToTimeline(event, timelineSet.getLiveTimeline(), { - toStartOfTimeline: false - }); - } - } - } - this.emit(RoomEvent.LocalEchoUpdated, event, this); - } - - /** - * Persists all pending events to local storage - * - * If the current room is encrypted only encrypted events will be persisted - * all messages that are not yet encrypted will be discarded - * - * This is because the flow of EVENT_STATUS transition is - * `queued => sending => encrypting => sending => sent` - * - * Steps 3 and 4 are skipped for unencrypted room. - * It is better to discard an unencrypted message rather than persisting - * it locally for everyone to read - */ - savePendingEvents() { - if (this.pendingEventList) { - const pendingEvents = this.pendingEventList.map(event => { - return _objectSpread(_objectSpread({}, event.event), {}, { - txn_id: event.getTxnId() - }); - }).filter(event => { - // Filter out the unencrypted messages if the room is encrypted - const isEventEncrypted = event.type === _event2.EventType.RoomMessageEncrypted; - const isRoomEncrypted = this.client.isRoomEncrypted(this.roomId); - return isEventEncrypted || !isRoomEncrypted; - }); - this.client.store.setPendingEvents(this.roomId, pendingEvents); - } - } - - /** - * Used to aggregate the local echo for a relation, and also - * for re-applying a relation after it's redaction has been cancelled, - * as the local echo for the redaction of the relation would have - * un-aggregated the relation. Note that this is different from regular messages, - * which are just kept detached for their local echo. - * - * Also note that live events are aggregated in the live EventTimelineSet. - * @param event - the relation event that needs to be aggregated. - */ - aggregateNonLiveRelation(event) { - this.relations.aggregateChildEvent(event); - } - getEventForTxnId(txnId) { - return this.txnToEvent.get(txnId); - } - - /** - * Deal with the echo of a message we sent. - * - *

We move the event to the live timeline if it isn't there already, and - * update it. - * - * @param remoteEvent - The event received from - * /sync - * @param localEvent - The local echo, which - * should be either in the pendingEventList or the timeline. - * - * @internal - * - * @remarks - * Fires {@link RoomEvent.LocalEchoUpdated} - */ - handleRemoteEcho(remoteEvent, localEvent) { - const oldEventId = localEvent.getId(); - const newEventId = remoteEvent.getId(); - const oldStatus = localEvent.status; - _logger.logger.debug(`Got remote echo for event ${oldEventId} -> ${newEventId} old status ${oldStatus}`); - - // no longer pending - this.txnToEvent.delete(remoteEvent.getUnsigned().transaction_id); - - // if it's in the pending list, remove it - if (this.pendingEventList) { - this.removePendingEvent(oldEventId); - } - - // replace the event source (this will preserve the plaintext payload if - // any, which is good, because we don't want to try decoding it again). - localEvent.handleRemoteEcho(remoteEvent.event); - const { - shouldLiveInRoom, - threadId - } = this.eventShouldLiveIn(remoteEvent); - const thread = threadId ? this.getThread(threadId) : null; - thread === null || thread === void 0 ? void 0 : thread.setEventMetadata(localEvent); - thread === null || thread === void 0 ? void 0 : thread.timelineSet.handleRemoteEcho(localEvent, oldEventId, newEventId); - if (shouldLiveInRoom) { - for (const timelineSet of this.timelineSets) { - // if it's already in the timeline, update the timeline map. If it's not, add it. - timelineSet.handleRemoteEcho(localEvent, oldEventId, newEventId); - } - } - this.emit(RoomEvent.LocalEchoUpdated, localEvent, this, oldEventId, oldStatus); - } - - /** - * Update the status / event id on a pending event, to reflect its transmission - * progress. - * - *

This is an internal method. - * - * @param event - local echo event - * @param newStatus - status to assign - * @param newEventId - new event id to assign. Ignored unless newStatus == EventStatus.SENT. - * - * @remarks - * Fires {@link RoomEvent.LocalEchoUpdated} - */ - updatePendingEvent(event, newStatus, newEventId) { - _logger.logger.log(`setting pendingEvent status to ${newStatus} in ${event.getRoomId()} ` + `event ID ${event.getId()} -> ${newEventId}`); - - // if the message was sent, we expect an event id - if (newStatus == _eventStatus.EventStatus.SENT && !newEventId) { - throw new Error("updatePendingEvent called with status=SENT, but no new event id"); - } - - // SENT races against /sync, so we have to special-case it. - if (newStatus == _eventStatus.EventStatus.SENT) { - const timeline = this.getTimelineForEvent(newEventId); - if (timeline) { - // we've already received the event via the event stream. - // nothing more to do here, assuming the transaction ID was correctly matched. - // Let's check that. - const remoteEvent = this.findEventById(newEventId); - const remoteTxnId = remoteEvent === null || remoteEvent === void 0 ? void 0 : remoteEvent.getUnsigned().transaction_id; - if (!remoteTxnId && remoteEvent) { - // This code path is mostly relevant for the Sliding Sync proxy. - // The remote event did not contain a transaction ID, so we did not handle - // the remote echo yet. Handle it now. - const unsigned = remoteEvent.getUnsigned(); - unsigned.transaction_id = event.getTxnId(); - remoteEvent.setUnsigned(unsigned); - // the remote event is _already_ in the timeline, so we need to remove it so - // we can convert the local event into the final event. - this.removeEvent(remoteEvent.getId()); - this.handleRemoteEcho(remoteEvent, event); - } - return; - } - } - const oldStatus = event.status; - const oldEventId = event.getId(); - if (!oldStatus) { - throw new Error("updatePendingEventStatus called on an event which is not a local echo."); - } - const allowed = ALLOWED_TRANSITIONS[oldStatus]; - if (!(allowed !== null && allowed !== void 0 && allowed.includes(newStatus))) { - throw new Error(`Invalid EventStatus transition ${oldStatus}->${newStatus}`); - } - event.setStatus(newStatus); - if (newStatus == _eventStatus.EventStatus.SENT) { - // update the event id - event.replaceLocalEventId(newEventId); - const { - shouldLiveInRoom, - threadId - } = this.eventShouldLiveIn(event); - const thread = threadId ? this.getThread(threadId) : undefined; - thread === null || thread === void 0 ? void 0 : thread.setEventMetadata(event); - thread === null || thread === void 0 ? void 0 : thread.timelineSet.replaceEventId(oldEventId, newEventId); - if (shouldLiveInRoom) { - // if the event was already in the timeline (which will be the case if - // opts.pendingEventOrdering==chronological), we need to update the - // timeline map. - for (const timelineSet of this.timelineSets) { - timelineSet.replaceEventId(oldEventId, newEventId); - } - } - } else if (newStatus == _eventStatus.EventStatus.CANCELLED) { - // remove it from the pending event list, or the timeline. - if (this.pendingEventList) { - const removedEvent = this.getPendingEvent(oldEventId); - this.removePendingEvent(oldEventId); - if (removedEvent !== null && removedEvent !== void 0 && removedEvent.isRedaction()) { - this.revertRedactionLocalEcho(removedEvent); - } - } - this.removeEvent(oldEventId); - } - this.savePendingEvents(); - this.emit(RoomEvent.LocalEchoUpdated, event, this, oldEventId, oldStatus); - } - revertRedactionLocalEcho(redactionEvent) { - const redactId = redactionEvent.event.redacts; - if (!redactId) { - return; - } - const redactedEvent = this.getUnfilteredTimelineSet().findEventById(redactId); - if (redactedEvent) { - redactedEvent.unmarkLocallyRedacted(); - // re-render after undoing redaction - this.emit(RoomEvent.RedactionCancelled, redactionEvent, this); - // reapply relation now redaction failed - if (redactedEvent.isRelation()) { - this.aggregateNonLiveRelation(redactedEvent); - } - } - } - - /** - * Add some events to this room. This can include state events, message - * events and typing notifications. These events are treated as "live" so - * they will go to the end of the timeline. - * - * @param events - A list of events to add. - * @param addLiveEventOptions - addLiveEvent options - * @throws If `duplicateStrategy` is not falsey, 'replace' or 'ignore'. - */ - - addLiveEvents(events, duplicateStrategyOrOpts, fromCache = false) { - let duplicateStrategy = duplicateStrategyOrOpts; - let timelineWasEmpty = false; - if (typeof duplicateStrategyOrOpts === "object") { - ({ - duplicateStrategy, - fromCache = false, - /* roomState, (not used here) */ - timelineWasEmpty - } = duplicateStrategyOrOpts); - } else if (duplicateStrategyOrOpts !== undefined) { - // Deprecation warning - // FIXME: Remove after 2023-06-01 (technical debt) - _logger.logger.warn("Overload deprecated: " + "`Room.addLiveEvents(events, duplicateStrategy?, fromCache?)` " + "is deprecated in favor of the overload with `Room.addLiveEvents(events, IAddLiveEventOptions)`"); - } - if (duplicateStrategy && ["replace", "ignore"].indexOf(duplicateStrategy) === -1) { - throw new Error("duplicateStrategy MUST be either 'replace' or 'ignore'"); - } - - // sanity check that the live timeline is still live - for (let i = 0; i < this.timelineSets.length; i++) { - const liveTimeline = this.timelineSets[i].getLiveTimeline(); - if (liveTimeline.getPaginationToken(_eventTimeline.EventTimeline.FORWARDS)) { - throw new Error("live timeline " + i + " is no longer live - it has a pagination token " + "(" + liveTimeline.getPaginationToken(_eventTimeline.EventTimeline.FORWARDS) + ")"); - } - if (liveTimeline.getNeighbouringTimeline(_eventTimeline.EventTimeline.FORWARDS)) { - throw new Error(`live timeline ${i} is no longer live - it has a neighbouring timeline`); - } - } - const threadRoots = this.findThreadRoots(events); - const eventsByThread = {}; - const options = { - duplicateStrategy, - fromCache, - timelineWasEmpty - }; - for (const event of events) { - var _eventsByThread2; - // TODO: We should have a filter to say "only add state event types X Y Z to the timeline". - this.processLiveEvent(event); - if (event.getUnsigned().transaction_id) { - const existingEvent = this.txnToEvent.get(event.getUnsigned().transaction_id); - if (existingEvent) { - // remote echo of an event we sent earlier - this.handleRemoteEcho(event, existingEvent); - continue; // we can skip adding the event to the timeline sets, it is already there - } - } - - const { - shouldLiveInRoom, - shouldLiveInThread, - threadId - } = this.eventShouldLiveIn(event, events, threadRoots); - if (shouldLiveInThread && !eventsByThread[threadId !== null && threadId !== void 0 ? threadId : ""]) { - eventsByThread[threadId !== null && threadId !== void 0 ? threadId : ""] = []; - } - (_eventsByThread2 = eventsByThread[threadId !== null && threadId !== void 0 ? threadId : ""]) === null || _eventsByThread2 === void 0 ? void 0 : _eventsByThread2.push(event); - if (shouldLiveInRoom) { - this.addLiveEvent(event, options); - } - } - Object.entries(eventsByThread).forEach(([threadId, threadEvents]) => { - this.addThreadedEvents(threadId, threadEvents, false); - }); - } - partitionThreadedEvents(events) { - // Indices to the events array, for readability - const ROOM = 0; - const THREAD = 1; - if (this.client.supportsThreads()) { - const threadRoots = this.findThreadRoots(events); - return events.reduce((memo, event) => { - const { - shouldLiveInRoom, - shouldLiveInThread, - threadId - } = this.eventShouldLiveIn(event, events, threadRoots); - if (shouldLiveInRoom) { - memo[ROOM].push(event); - } - if (shouldLiveInThread) { - event.setThreadId(threadId !== null && threadId !== void 0 ? threadId : ""); - memo[THREAD].push(event); - } - return memo; - }, [[], []]); - } else { - // When `experimentalThreadSupport` is disabled treat all events as timelineEvents - return [events, []]; - } - } - - /** - * Given some events, find the IDs of all the thread roots that are referred to by them. - */ - findThreadRoots(events) { - const threadRoots = new Set(); - for (const event of events) { - if (event.isRelation(_thread.THREAD_RELATION_TYPE.name)) { - var _event$relationEventI; - threadRoots.add((_event$relationEventI = event.relationEventId) !== null && _event$relationEventI !== void 0 ? _event$relationEventI : ""); - } - } - return threadRoots; - } - - /** - * Add a receipt event to the room. - * @param event - The m.receipt event. - * @param synthetic - True if this event is implicit. - */ - addReceipt(event, synthetic = false) { - const content = event.getContent(); - Object.keys(content).forEach(eventId => { - Object.keys(content[eventId]).forEach(receiptType => { - Object.keys(content[eventId][receiptType]).forEach(userId => { - var _receipt$thread_id, _this$unthreadedRecei, _this$unthreadedRecei2; - const receipt = content[eventId][receiptType][userId]; - const receiptForMainTimeline = !receipt.thread_id || receipt.thread_id === _read_receipts.MAIN_ROOM_TIMELINE; - const receiptDestination = receiptForMainTimeline ? this : this.threads.get((_receipt$thread_id = receipt.thread_id) !== null && _receipt$thread_id !== void 0 ? _receipt$thread_id : ""); - if (receiptDestination) { - receiptDestination.addReceiptToStructure(eventId, receiptType, userId, receipt, synthetic); - - // If the read receipt sent for the logged in user matches - // the last event of the live timeline, then we know for a fact - // that the user has read that message. - // We can mark the room as read and not wait for the local echo - // from synapse - // This needs to be done after the initial sync as we do not want this - // logic to run whilst the room is being initialised - if (this.client.isInitialSyncComplete() && userId === this.client.getUserId()) { - const lastEvent = receiptDestination.timeline[receiptDestination.timeline.length - 1]; - if (lastEvent && eventId === lastEvent.getId() && userId === lastEvent.getSender()) { - receiptDestination.setUnread(NotificationCountType.Total, 0); - receiptDestination.setUnread(NotificationCountType.Highlight, 0); - } - } - } else { - var _this$cachedThreadRea2; - // The thread does not exist locally, keep the read receipt - // in a cache locally, and re-apply the `addReceipt` logic - // when the thread is created - this.cachedThreadReadReceipts.set(receipt.thread_id, [...((_this$cachedThreadRea2 = this.cachedThreadReadReceipts.get(receipt.thread_id)) !== null && _this$cachedThreadRea2 !== void 0 ? _this$cachedThreadRea2 : []), { - eventId, - receiptType, - userId, - receipt, - synthetic - }]); - } - const me = this.client.getUserId(); - // Track the time of the current user's oldest threaded receipt in the room. - if (userId === me && !receiptForMainTimeline && receipt.ts < this.oldestThreadedReceiptTs) { - this.oldestThreadedReceiptTs = receipt.ts; - } - - // Track each user's unthreaded read receipt. - if (!receipt.thread_id && receipt.ts > ((_this$unthreadedRecei = (_this$unthreadedRecei2 = this.unthreadedReceipts.get(userId)) === null || _this$unthreadedRecei2 === void 0 ? void 0 : _this$unthreadedRecei2.ts) !== null && _this$unthreadedRecei !== void 0 ? _this$unthreadedRecei : 0)) { - this.unthreadedReceipts.set(userId, receipt); - } - }); - }); - }); - - // send events after we've regenerated the structure & cache, otherwise things that - // listened for the event would read stale data. - this.emit(RoomEvent.Receipt, event, this); - } - - /** - * Adds/handles ephemeral events such as typing notifications and read receipts. - * @param events - A list of events to process - */ - addEphemeralEvents(events) { - for (const event of events) { - if (event.getType() === _event2.EventType.Typing) { - this.currentState.setTypingEvent(event); - } else if (event.getType() === _event2.EventType.Receipt) { - this.addReceipt(event); - } // else ignore - life is too short for us to care about these events - } - } - - /** - * Removes events from this room. - * @param eventIds - A list of eventIds to remove. - */ - removeEvents(eventIds) { - for (const eventId of eventIds) { - this.removeEvent(eventId); - } - } - - /** - * Removes a single event from this room. - * - * @param eventId - The id of the event to remove - * - * @returns true if the event was removed from any of the room's timeline sets - */ - removeEvent(eventId) { - let removedAny = false; - for (const timelineSet of this.timelineSets) { - const removed = timelineSet.removeEvent(eventId); - if (removed) { - if (removed.isRedaction()) { - this.revertRedactionLocalEcho(removed); - } - removedAny = true; - } - } - return removedAny; - } - - /** - * Recalculate various aspects of the room, including the room name and - * room summary. Call this any time the room's current state is modified. - * May fire "Room.name" if the room name is updated. - * - * @remarks - * Fires {@link RoomEvent.Name} - */ - recalculate() { - // set fake stripped state events if this is an invite room so logic remains - // consistent elsewhere. - const membershipEvent = this.currentState.getStateEvents(_event2.EventType.RoomMember, this.myUserId); - if (membershipEvent) { - const membership = membershipEvent.getContent().membership; - this.updateMyMembership(membership); - if (membership === "invite") { - const strippedStateEvents = membershipEvent.getUnsigned().invite_room_state || []; - strippedStateEvents.forEach(strippedEvent => { - const existingEvent = this.currentState.getStateEvents(strippedEvent.type, strippedEvent.state_key); - if (!existingEvent) { - // set the fake stripped event instead - this.currentState.setStateEvents([new _event.MatrixEvent({ - type: strippedEvent.type, - state_key: strippedEvent.state_key, - content: strippedEvent.content, - event_id: "$fake" + Date.now(), - room_id: this.roomId, - user_id: this.myUserId // technically a lie - })]); - } - }); - } - } - - const oldName = this.name; - this.name = this.calculateRoomName(this.myUserId); - this.normalizedName = (0, utils.normalize)(this.name); - this.summary = new _roomSummary.RoomSummary(this.roomId, { - title: this.name - }); - if (oldName !== this.name) { - this.emit(RoomEvent.Name, this); - } - } - - /** - * Update the room-tag event for the room. The previous one is overwritten. - * @param event - the m.tag event - */ - addTags(event) { - // event content looks like: - // content: { - // tags: { - // $tagName: { $metadata: $value }, - // $tagName: { $metadata: $value }, - // } - // } - - // XXX: do we need to deep copy here? - this.tags = event.getContent().tags || {}; - - // XXX: we could do a deep-comparison to see if the tags have really - // changed - but do we want to bother? - this.emit(RoomEvent.Tags, event, this); - } - - /** - * Update the account_data events for this room, overwriting events of the same type. - * @param events - an array of account_data events to add - */ - addAccountData(events) { - for (const event of events) { - if (event.getType() === "m.tag") { - this.addTags(event); - } - const eventType = event.getType(); - const lastEvent = this.accountData.get(eventType); - this.accountData.set(eventType, event); - this.emit(RoomEvent.AccountData, event, this, lastEvent); - } - } - - /** - * Access account_data event of given event type for this room - * @param type - the type of account_data event to be accessed - * @returns the account_data event in question - */ - getAccountData(type) { - return this.accountData.get(type); - } - - /** - * Returns whether the syncing user has permission to send a message in the room - * @returns true if the user should be permitted to send - * message events into the room. - */ - maySendMessage() { - return this.getMyMembership() === "join" && (this.client.isRoomEncrypted(this.roomId) ? this.currentState.maySendEvent(_event2.EventType.RoomMessageEncrypted, this.myUserId) : this.currentState.maySendEvent(_event2.EventType.RoomMessage, this.myUserId)); - } - - /** - * Returns whether the given user has permissions to issue an invite for this room. - * @param userId - the ID of the Matrix user to check permissions for - * @returns true if the user should be permitted to issue invites for this room. - */ - canInvite(userId) { - let canInvite = this.getMyMembership() === "join"; - const powerLevelsEvent = this.currentState.getStateEvents(_event2.EventType.RoomPowerLevels, ""); - const powerLevels = powerLevelsEvent && powerLevelsEvent.getContent(); - const me = this.getMember(userId); - if (powerLevels && me && powerLevels.invite > me.powerLevel) { - canInvite = false; - } - return canInvite; - } - - /** - * Returns the join rule based on the m.room.join_rule state event, defaulting to `invite`. - * @returns the join_rule applied to this room - */ - getJoinRule() { - return this.currentState.getJoinRule(); - } - - /** - * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`. - * @returns the history_visibility applied to this room - */ - getHistoryVisibility() { - return this.currentState.getHistoryVisibility(); - } - - /** - * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`. - * @returns the history_visibility applied to this room - */ - getGuestAccess() { - return this.currentState.getGuestAccess(); - } - - /** - * Returns the type of the room from the `m.room.create` event content or undefined if none is set - * @returns the type of the room. - */ - getType() { - const createEvent = this.currentState.getStateEvents(_event2.EventType.RoomCreate, ""); - if (!createEvent) { - if (!this.getTypeWarning) { - _logger.logger.warn("[getType] Room " + this.roomId + " does not have an m.room.create event"); - this.getTypeWarning = true; - } - return undefined; - } - return createEvent.getContent()[_event2.RoomCreateTypeField]; - } - - /** - * Returns whether the room is a space-room as defined by MSC1772. - * @returns true if the room's type is RoomType.Space - */ - isSpaceRoom() { - return this.getType() === _event2.RoomType.Space; - } - - /** - * Returns whether the room is a call-room as defined by MSC3417. - * @returns true if the room's type is RoomType.UnstableCall - */ - isCallRoom() { - return this.getType() === _event2.RoomType.UnstableCall; - } - - /** - * Returns whether the room is a video room. - * @returns true if the room's type is RoomType.ElementVideo - */ - isElementVideoRoom() { - return this.getType() === _event2.RoomType.ElementVideo; - } - - /** - * Find the predecessor of this room. - * - * @param msc3946ProcessDynamicPredecessor - if true, look for an - * m.room.predecessor state event and use it if found (MSC3946). - * @returns null if this room has no predecessor. Otherwise, returns - * the roomId, last eventId and viaServers of the predecessor room. - * - * If msc3946ProcessDynamicPredecessor is true, use m.predecessor events - * as well as m.room.create events to find predecessors. - * - * Note: if an m.predecessor event is used, eventId may be undefined - * since last_known_event_id is optional. - * - * Note: viaServers may be undefined, and will definitely be undefined if - * this predecessor comes from a RoomCreate event (rather than a - * RoomPredecessor, which has the optional via_servers property). - */ - findPredecessor(msc3946ProcessDynamicPredecessor = false) { - const currentState = this.getLiveTimeline().getState(_eventTimeline.EventTimeline.FORWARDS); - if (!currentState) { - return null; - } - return currentState.findPredecessor(msc3946ProcessDynamicPredecessor); - } - roomNameGenerator(state) { - if (this.client.roomNameGenerator) { - const name = this.client.roomNameGenerator(this.roomId, state); - if (name !== null) { - return name; - } - } - switch (state.type) { - case RoomNameType.Actual: - return state.name; - case RoomNameType.Generated: - switch (state.subtype) { - case "Inviting": - return `Inviting ${memberNamesToRoomName(state.names, state.count)}`; - default: - return memberNamesToRoomName(state.names, state.count); - } - case RoomNameType.EmptyRoom: - if (state.oldName) { - return `Empty room (was ${state.oldName})`; - } else { - return "Empty room"; - } - } - } - - /** - * This is an internal method. Calculates the name of the room from the current - * room state. - * @param userId - The client's user ID. Used to filter room members - * correctly. - * @param ignoreRoomNameEvent - Return the implicit room name that we'd see if there - * was no m.room.name event. - * @returns The calculated room name. - */ - calculateRoomName(userId, ignoreRoomNameEvent = false) { - if (!ignoreRoomNameEvent) { - // check for an alias, if any. for now, assume first alias is the - // official one. - const mRoomName = this.currentState.getStateEvents(_event2.EventType.RoomName, ""); - if (mRoomName !== null && mRoomName !== void 0 && mRoomName.getContent().name) { - return this.roomNameGenerator({ - type: RoomNameType.Actual, - name: mRoomName.getContent().name - }); - } - } - const alias = this.getCanonicalAlias(); - if (alias) { - return this.roomNameGenerator({ - type: RoomNameType.Actual, - name: alias - }); - } - const joinedMemberCount = this.currentState.getJoinedMemberCount(); - const invitedMemberCount = this.currentState.getInvitedMemberCount(); - // -1 because these numbers include the syncing user - let inviteJoinCount = joinedMemberCount + invitedMemberCount - 1; - - // get service members (e.g. helper bots) for exclusion - let excludedUserIds = []; - const mFunctionalMembers = this.currentState.getStateEvents(_event2.UNSTABLE_ELEMENT_FUNCTIONAL_USERS.name, ""); - if (Array.isArray(mFunctionalMembers === null || mFunctionalMembers === void 0 ? void 0 : mFunctionalMembers.getContent().service_members)) { - excludedUserIds = mFunctionalMembers.getContent().service_members; - } - - // get members that are NOT ourselves and are actually in the room. - let otherNames = []; - if (this.summaryHeroes) { - // if we have a summary, the member state events should be in the room state - this.summaryHeroes.forEach(userId => { - // filter service members - if (excludedUserIds.includes(userId)) { - inviteJoinCount--; - return; - } - const member = this.getMember(userId); - otherNames.push(member ? member.name : userId); - }); - } else { - let otherMembers = this.currentState.getMembers().filter(m => { - return m.userId !== userId && (m.membership === "invite" || m.membership === "join"); - }); - otherMembers = otherMembers.filter(({ - userId - }) => { - // filter service members - if (excludedUserIds.includes(userId)) { - inviteJoinCount--; - return false; - } - return true; - }); - // make sure members have stable order - otherMembers.sort((a, b) => utils.compare(a.userId, b.userId)); - // only 5 first members, immitate summaryHeroes - otherMembers = otherMembers.slice(0, 5); - otherNames = otherMembers.map(m => m.name); - } - if (inviteJoinCount) { - return this.roomNameGenerator({ - type: RoomNameType.Generated, - names: otherNames, - count: inviteJoinCount - }); - } - const myMembership = this.getMyMembership(); - // if I have created a room and invited people through - // 3rd party invites - if (myMembership == "join") { - const thirdPartyInvites = this.currentState.getStateEvents(_event2.EventType.RoomThirdPartyInvite); - if (thirdPartyInvites !== null && thirdPartyInvites !== void 0 && thirdPartyInvites.length) { - const thirdPartyNames = thirdPartyInvites.map(i => { - return i.getContent().display_name; - }); - return this.roomNameGenerator({ - type: RoomNameType.Generated, - subtype: "Inviting", - names: thirdPartyNames, - count: thirdPartyNames.length + 1 - }); - } - } - - // let's try to figure out who was here before - let leftNames = otherNames; - // if we didn't have heroes, try finding them in the room state - if (!leftNames.length) { - leftNames = this.currentState.getMembers().filter(m => { - return m.userId !== userId && m.membership !== "invite" && m.membership !== "join"; - }).map(m => m.name); - } - let oldName; - if (leftNames.length) { - oldName = this.roomNameGenerator({ - type: RoomNameType.Generated, - names: leftNames, - count: leftNames.length + 1 - }); - } - return this.roomNameGenerator({ - type: RoomNameType.EmptyRoom, - oldName - }); - } - - /** - * When we receive a new visibility change event: - * - * - store this visibility change alongside the timeline, in case we - * later need to apply it to an event that we haven't received yet; - * - if we have already received the event whose visibility has changed, - * patch it to reflect the visibility change and inform listeners. - */ - applyNewVisibilityEvent(event) { - const visibilityChange = event.asVisibilityChange(); - if (!visibilityChange) { - // The event is ill-formed. - return; - } - - // Ignore visibility change events that are not emitted by moderators. - const userId = event.getSender(); - if (!userId) { - return; - } - const isPowerSufficient = _event2.EVENT_VISIBILITY_CHANGE_TYPE.name && this.currentState.maySendStateEvent(_event2.EVENT_VISIBILITY_CHANGE_TYPE.name, userId) || _event2.EVENT_VISIBILITY_CHANGE_TYPE.altName && this.currentState.maySendStateEvent(_event2.EVENT_VISIBILITY_CHANGE_TYPE.altName, userId); - if (!isPowerSufficient) { - // Powerlevel is insufficient. - return; - } - - // Record this change in visibility. - // If the event is not in our timeline and we only receive it later, - // we may need to apply the visibility change at a later date. - - const visibilityEventsOnOriginalEvent = this.visibilityEvents.get(visibilityChange.eventId); - if (visibilityEventsOnOriginalEvent) { - // It would be tempting to simply erase the latest visibility change - // but we need to record all of the changes in case the latest change - // is ever redacted. - // - // In practice, linear scans through `visibilityEvents` should be fast. - // However, to protect against a potential DoS attack, we limit the - // number of iterations in this loop. - let index = visibilityEventsOnOriginalEvent.length - 1; - const min = Math.max(0, visibilityEventsOnOriginalEvent.length - MAX_NUMBER_OF_VISIBILITY_EVENTS_TO_SCAN_THROUGH); - for (; index >= min; --index) { - const target = visibilityEventsOnOriginalEvent[index]; - if (target.getTs() < event.getTs()) { - break; - } - } - if (index === -1) { - visibilityEventsOnOriginalEvent.unshift(event); - } else { - visibilityEventsOnOriginalEvent.splice(index + 1, 0, event); - } - } else { - this.visibilityEvents.set(visibilityChange.eventId, [event]); - } - - // Finally, let's check if the event is already in our timeline. - // If so, we need to patch it and inform listeners. - - const originalEvent = this.findEventById(visibilityChange.eventId); - if (!originalEvent) { - return; - } - originalEvent.applyVisibilityEvent(visibilityChange); - } - redactVisibilityChangeEvent(event) { - // Sanity checks. - if (!event.isVisibilityEvent) { - throw new Error("expected a visibility change event"); - } - const relation = event.getRelation(); - const originalEventId = relation === null || relation === void 0 ? void 0 : relation.event_id; - const visibilityEventsOnOriginalEvent = this.visibilityEvents.get(originalEventId); - if (!visibilityEventsOnOriginalEvent) { - // No visibility changes on the original event. - // In particular, this change event was not recorded, - // most likely because it was ill-formed. - return; - } - const index = visibilityEventsOnOriginalEvent.findIndex(change => change.getId() === event.getId()); - if (index === -1) { - // This change event was not recorded, most likely because - // it was ill-formed. - return; - } - // Remove visibility change. - visibilityEventsOnOriginalEvent.splice(index, 1); - - // If we removed the latest visibility change event, propagate changes. - if (index === visibilityEventsOnOriginalEvent.length) { - const originalEvent = this.findEventById(originalEventId); - if (!originalEvent) { - return; - } - if (index === 0) { - // We have just removed the only visibility change event. - this.visibilityEvents.delete(originalEventId); - originalEvent.applyVisibilityEvent(); - } else { - const newEvent = visibilityEventsOnOriginalEvent[visibilityEventsOnOriginalEvent.length - 1]; - const newVisibility = newEvent.asVisibilityChange(); - if (!newVisibility) { - // Event is ill-formed. - // This breaks our invariant. - throw new Error("at this stage, visibility changes should be well-formed"); - } - originalEvent.applyVisibilityEvent(newVisibility); - } - } - } - - /** - * When we receive an event whose visibility has been altered by - * a (more recent) visibility change event, patch the event in - * place so that clients now not to display it. - * - * @param event - Any matrix event. If this event has at least one a - * pending visibility change event, apply the latest visibility - * change event. - */ - applyPendingVisibilityEvents(event) { - const visibilityEvents = this.visibilityEvents.get(event.getId()); - if (!visibilityEvents || visibilityEvents.length == 0) { - // No pending visibility change in store. - return; - } - const visibilityEvent = visibilityEvents[visibilityEvents.length - 1]; - const visibilityChange = visibilityEvent.asVisibilityChange(); - if (!visibilityChange) { - return; - } - if (visibilityChange.visible) { - // Events are visible by default, no need to apply a visibility change. - // Note that we need to keep the visibility changes in `visibilityEvents`, - // in case we later fetch an older visibility change event that is superseded - // by `visibilityChange`. - } - if (visibilityEvent.getTs() < event.getTs()) { - // Something is wrong, the visibility change cannot happen before the - // event. Presumably an ill-formed event. - return; - } - event.applyVisibilityEvent(visibilityChange); - } - - /** - * Find when a client has gained thread capabilities by inspecting the oldest - * threaded receipt - * @returns the timestamp of the oldest threaded receipt - */ - getOldestThreadedReceiptTs() { - return this.oldestThreadedReceiptTs; - } - - /** - * Returns the most recent unthreaded receipt for a given user - * @param userId - the MxID of the User - * @returns an unthreaded Receipt. Can be undefined if receipts have been disabled - * or a user chooses to use private read receipts (or we have simply not received - * a receipt from this user yet). - */ - getLastUnthreadedReceiptFor(userId) { - return this.unthreadedReceipts.get(userId); - } - - /** - * This issue should also be addressed on synapse's side and is tracked as part - * of https://github.com/matrix-org/synapse/issues/14837 - * - * - * We consider a room fully read if the current user has sent - * the last event in the live timeline of that context and if the read receipt - * we have on record matches. - * This also detects all unread threads and applies the same logic to those - * contexts - */ - fixupNotifications(userId) { - super.fixupNotifications(userId); - const unreadThreads = this.getThreads().filter(thread => this.getThreadUnreadNotificationCount(thread.id, NotificationCountType.Total) > 0); - for (const thread of unreadThreads) { - thread.fixupNotifications(userId); - } - } -} - -// a map from current event status to a list of allowed next statuses -exports.Room = Room; -const ALLOWED_TRANSITIONS = { - [_eventStatus.EventStatus.ENCRYPTING]: [_eventStatus.EventStatus.SENDING, _eventStatus.EventStatus.NOT_SENT, _eventStatus.EventStatus.CANCELLED], - [_eventStatus.EventStatus.SENDING]: [_eventStatus.EventStatus.ENCRYPTING, _eventStatus.EventStatus.QUEUED, _eventStatus.EventStatus.NOT_SENT, _eventStatus.EventStatus.SENT], - [_eventStatus.EventStatus.QUEUED]: [_eventStatus.EventStatus.SENDING, _eventStatus.EventStatus.NOT_SENT, _eventStatus.EventStatus.CANCELLED], - [_eventStatus.EventStatus.SENT]: [], - [_eventStatus.EventStatus.NOT_SENT]: [_eventStatus.EventStatus.SENDING, _eventStatus.EventStatus.QUEUED, _eventStatus.EventStatus.CANCELLED], - [_eventStatus.EventStatus.CANCELLED]: [] -}; -let RoomNameType; -exports.RoomNameType = RoomNameType; -(function (RoomNameType) { - RoomNameType[RoomNameType["EmptyRoom"] = 0] = "EmptyRoom"; - RoomNameType[RoomNameType["Generated"] = 1] = "Generated"; - RoomNameType[RoomNameType["Actual"] = 2] = "Actual"; -})(RoomNameType || (exports.RoomNameType = RoomNameType = {})); -// Can be overriden by IMatrixClientCreateOpts::memberNamesToRoomNameFn -function memberNamesToRoomName(names, count) { - const countWithoutMe = count - 1; - if (!names.length) { - return "Empty room"; - } else if (names.length === 1 && countWithoutMe <= 1) { - return names[0]; - } else if (names.length === 2 && countWithoutMe <= 2) { - return `${names[0]} and ${names[1]}`; - } else { - const plural = countWithoutMe > 1; - if (plural) { - return `${names[0]} and ${countWithoutMe} others`; - } else { - return `${names[0]} and 1 other`; - } - } -} -//# sourceMappingURL=room.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js.map deleted file mode 100644 index 91bda73..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/room.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room.js","names":["_matrixEventsSdk","require","_eventTimelineSet","_eventTimeline","_contentRepo","utils","_interopRequireWildcard","_event","_eventStatus","_roomMember","_roomSummary","_logger","_ReEmitter","_event2","_client","_filter","_roomState","_beacon","_thread","_read_receipts","_relationsContainer","_readReceipt","_poll","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","KNOWN_SAFE_ROOM_VERSION","exports","SAFE_ROOM_VERSIONS","MAX_NUMBER_OF_VISIBILITY_EVENTS_TO_SCAN_THROUGH","NotificationCountType","RoomEvent","Room","ReadReceipt","constructor","roomId","client","myUserId","opts","Map","Infinity","RelationsContainer","thread","toStartOfTimeline","recreateEvent","_this$threadsTimeline","updateThreadRootEvent","threadsTimelineSets","hasCurrentUserParticipated","_this$threadsTimeline2","timelineSet","rootEvent","removeEvent","id","Thread","hasServerSideSupport","addLiveEvent","duplicateStrategy","DuplicateStrategy","Replace","fromCache","roomState","currentState","addEventToTimeline","getLiveTimeline","event","isRedaction","redactId","redacts","redactedEvent","findEventById","undefined","makeRedacted","isState","currentStateEvent","getStateEvents","getType","getStateKey","getId","setStateEvents","emit","Redaction","visibilityEvents","delete","isVisibilityEvent","redactVisibilityChangeEvent","setMaxListeners","reEmitter","TypedReEmitter","pendingEventOrdering","PendingEventOrdering","Chronological","name","normalizedName","timelineSets","EventTimelineSet","reEmit","getUnfilteredTimelineSet","Timeline","TimelineReset","fixUpLegacyTimelineFields","Detached","pendingEventList","store","getPendingEvents","then","events","mapper","getEventMapper","toDevice","decrypt","serializedEvent","decryptEventIfNeeded","setStatus","EventStatus","NOT_SENT","addPendingEvent","getTxnId","lazyLoadMembers","membersPromise","Promise","resolve","createThreadsTimelineSets","_this$client","threadTimelineSetsPromise","supportsThreads","all","createThreadTimelineSet","ThreadFilterType","My","e","decryptCriticalEvents","isCryptoEnabled","readReceiptEventId","getEventReadUpTo","getUserId","getEvents","readReceiptTimelineIndex","findIndex","matrixEvent","event_id","decryptionPromises","slice","reverse","map","isRetry","allSettled","decryptAllEvents","getCreator","_createEvent$getConte","createEvent","EventType","RoomCreate","getContent","getVersion","_createEvent$getConte2","getVersionWarning","logger","warn","shouldUpgradeToVersion","includes","getRecommendedVersion","capabilities","getCapabilities","versionCap","available","safeVer","RoomVersionStability","Stable","result","checkVersionAgainstCapability","urgent","needsUpgrade","caps","currentVersion","log","version","stableVersions","v","match","userMayUpgradeRoom","userId","maySendStateEvent","RoomTombstone","Error","removePendingEvent","eventId","removed","removeElement","ev","savePendingEvents","hasPendingEvent","_this$pendingEventLis","_this$pendingEventLis2","some","getPendingEvent","_this$pendingEventLis3","_this$pendingEventLis4","find","getLastActiveTimestamp","timeline","lastEvent","getTs","Number","MIN_SAFE_INTEGER","getMyMembership","_this$selfMembership","selfMembership","getDMInviter","me","getMember","memberCount","getInvitedAndJoinedMemberCount","_this$summaryHeroes","summaryHeroes","guessDMUserId","inviterId","Array","isArray","members","getMembers","anyMember","m","getAvatarFallbackMember","hasHeroes","availableMember","member","availableUser","getUser","user","RoomMember","updateMyMembership","membership","prevMembership","cleanupAfterLeaving","MyMembership","loadMembersFromServer","lastSyncToken","getSyncToken","response","chunk","loadMembers","fromServer","rawMembersEvents","getOutOfBandMembers","isRoomEncrypted","memberEvents","noUnsafeEventProps","membersLoaded","outOfBandMembersReady","loadMembersIfNeeded","markOutOfBandMembersStarted","inMemoryUpdate","setOutOfBandMembers","catch","err","markOutOfBandMembersFailed","oobMembers","isOutOfBand","_m$events$member","error","clearLoadedMembersIfNeeded","clearOutOfBandMembers","refreshLiveTimeline","liveTimelineBefore","forwardPaginationToken","getPaginationToken","EventTimeline","FORWARDS","backwardPaginationToken","BACKWARDS","eventsBefore","mostRecentEventInTimeline","toString","newTimeline","getLatestTimeline","resetLiveTimeline","TimelineRefresh","getEventTimeline","liveTimeline","Direction","Forward","Backward","setPaginationToken","setLiveTimeline","setTimelineNeedsRefresh","backPaginationToken","threads","values","previousOldState","oldState","previousCurrentState","getState","OldStateUpdated","CurrentStateUpdated","stopReEmitting","RoomStateEvent","Events","Members","NewMember","Update","Marker","BeaconEvent","New","Destroy","LivenessChange","hasUnverifiedDevices","e2eMembers","getEncryptionTargetMembers","devices","getStoredDevicesForUser","device","isUnverified","getTimelineSets","getTimelineForEvent","findThreadForEvent","addTimeline","value","timelineNeedsRefresh","getTimelineNeedsRefresh","getThreads","getUnreadNotificationCount","type","Total","count","getRoomUnreadNotificationCount","threadNotification","threadNotifications","_threadNotification$t","getUnreadCountForEventContext","_ref","isThreadEvent","threadRootId","isThreadRoot","getThreadUnreadNotificationCount","_this$notificationCou","notificationCounts","threadId","_this$threadNotificat","_this$threadNotificat2","hasThreadUnreadNotification","notification","_notification$highlig","_notification$total","highlight","total","setThreadUnreadNotificationCount","_this$threadNotificat3","_this$threadNotificat4","UnreadNotifications","threadsAggregateNotificationType","_threadNotification$h","_threadNotification$t2","Highlight","resetThreadUnreadNotificationCount","notificationsToKeep","clear","setUnreadNotificationCount","setUnread","setSummary","summary","heroes","joinedCount","invitedCount","isInteger","setJoinedMemberCount","setInvitedMemberCount","setBlacklistUnverifiedDevices","blacklistUnverifiedDevices","getBlacklistUnverifiedDevices","getAvatarUrl","baseUrl","width","height","resizeMethod","allowDefault","roomAvatarEvent","RoomAvatar","mainUrl","url","getHttpUriForMxc","getMxcAvatarUrl","_this$currentState$ge","_this$currentState$ge2","getCanonicalAlias","canonicalAlias","RoomCanonicalAlias","alias","getAltAliases","alt_aliases","addEventsToTimeline","paginationToken","getTimelineSet","getThread","_this$threads$get","from","getJoinedMembers","getMembersWithMembership","getJoinedMemberCount","getInvitedMemberCount","shouldEncryptForInvitedMembers","concat","_ev$getContent","RoomHistoryVisibility","history_visibility","getDefaultRoomName","calculateRoomName","hasMembershipState","getOrCreateFilteredTimelineSet","prepopulateTimeline","useSyncEvents","pendingEvents","filteredTimelineSets","filterId","assign","unfilteredLiveTimeline","getNeighbouringTimeline","livePaginationToken","getThreadListFilter","filterType","All","Filter","definition","room","FILTER_RELATED_BY_REL_TYPES","THREAD_RELATION_TYPE","FILTER_RELATED_BY_SENDERS","setDefinition","getOrCreateFilter","hasServerSideListSupport","currentUserParticipated","getSender","addEvent","processThreadRoots","setEventMetadata","createThread","fetchRoomThreads","threadsReady","fetchRoomThreadList","allThreadsFilter","createMessagesRequest","MAX_SAFE_INTEGER","threadRoots","sort","eventA","eventB","threadAMetadata","getServerAggregatedRelation","threadBMetadata","latest_event","origin_server_ts","latestMyThreadsRootEvent","_this$threadsTimeline3","Ignore","threadRelationship","current_user_participated","_this$threadsTimeline4","on","ThreadEvent","NewReply","onThreadNewReply","Delete","onThreadDelete","processPollEvents","processPollStartEvent","M_POLL_START","matches","poll","Poll","polls","PollEvent","processPollRelationEvent","relationEventId","onNewRelation","processPollEvent","end","createThreadListMessagesRequest","threadListType","getFilter","matrixEvents","updateThreadRootEvents","_timeline$getEvents","roomEvent","it","clearEventMetadata","debug","removeFilteredTimelineSet","indexOf","splice","eventShouldLiveIn","roots","_this$client2","shouldLiveInRoom","shouldLiveInThread","isRelation","parentEventId","getAssociatedId","parentEvent","_this$findEventById","addThreadedEvents","_this$findEventById2","addEvents","processThreadedEvents","applyRedaction","eventsByThread","_eventsByThread","entries","threadEvents","_this$cachedThreadRea","_this$lastThread","_this$lastThread$root","relatedEvents","relations","getAllChildEventsForEvent","RelationType","receipts","cachedThreadReadReceipts","isNewer","lastThread","localTimestamp","processLiveEvent","applyNewVisibilityEvent","applyPendingVisibilityEvents","txnId","getUnsigned","transaction_id","tid","localEvent","txnToEvent","unsigned","setUnsigned","addLiveEventOptions","timelineWasEmpty","sender","RoomRedaction","addReceipt","synthesizeReceipt","ReceiptType","Read","status","SENDING","aggregateNonLiveRelation","markLocallyRedacted","filterRoomTimeline","LocalEchoUpdated","txn_id","isEventEncrypted","RoomMessageEncrypted","setPendingEvents","aggregateChildEvent","getEventForTxnId","handleRemoteEcho","remoteEvent","oldEventId","newEventId","oldStatus","updatePendingEvent","newStatus","getRoomId","SENT","remoteTxnId","allowed","ALLOWED_TRANSITIONS","replaceLocalEventId","replaceEventId","CANCELLED","removedEvent","revertRedactionLocalEcho","redactionEvent","unmarkLocallyRedacted","RedactionCancelled","addLiveEvents","duplicateStrategyOrOpts","findThreadRoots","options","_eventsByThread2","existingEvent","partitionThreadedEvents","ROOM","THREAD","reduce","memo","setThreadId","Set","_event$relationEventI","add","synthetic","content","receiptType","_receipt$thread_id","_this$unthreadedRecei","_this$unthreadedRecei2","receipt","receiptForMainTimeline","thread_id","MAIN_ROOM_TIMELINE","receiptDestination","addReceiptToStructure","isInitialSyncComplete","_this$cachedThreadRea2","ts","oldestThreadedReceiptTs","unthreadedReceipts","Receipt","addEphemeralEvents","Typing","setTypingEvent","removeEvents","eventIds","removedAny","recalculate","membershipEvent","strippedStateEvents","invite_room_state","strippedEvent","state_key","MatrixEvent","Date","now","room_id","user_id","oldName","normalize","RoomSummary","title","Name","addTags","tags","Tags","addAccountData","eventType","accountData","AccountData","getAccountData","maySendMessage","maySendEvent","RoomMessage","canInvite","powerLevelsEvent","RoomPowerLevels","powerLevels","invite","powerLevel","getJoinRule","getHistoryVisibility","getGuestAccess","getTypeWarning","RoomCreateTypeField","isSpaceRoom","RoomType","Space","isCallRoom","UnstableCall","isElementVideoRoom","ElementVideo","findPredecessor","msc3946ProcessDynamicPredecessor","roomNameGenerator","state","RoomNameType","Actual","Generated","subtype","memberNamesToRoomName","names","EmptyRoom","ignoreRoomNameEvent","mRoomName","RoomName","joinedMemberCount","invitedMemberCount","inviteJoinCount","excludedUserIds","mFunctionalMembers","UNSTABLE_ELEMENT_FUNCTIONAL_USERS","service_members","otherNames","otherMembers","a","b","compare","myMembership","thirdPartyInvites","RoomThirdPartyInvite","thirdPartyNames","display_name","leftNames","visibilityChange","asVisibilityChange","isPowerSufficient","EVENT_VISIBILITY_CHANGE_TYPE","altName","visibilityEventsOnOriginalEvent","index","min","Math","max","unshift","originalEvent","applyVisibilityEvent","relation","getRelation","originalEventId","change","newEvent","newVisibility","visibilityEvent","visible","getOldestThreadedReceiptTs","getLastUnthreadedReceiptFor","fixupNotifications","unreadThreads","ENCRYPTING","QUEUED","countWithoutMe","plural"],"sources":["../../src/models/room.ts"],"sourcesContent":["/*\nCopyright 2015 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { M_POLL_START, Optional } from \"matrix-events-sdk\";\n\nimport {\n EventTimelineSet,\n DuplicateStrategy,\n IAddLiveEventOptions,\n EventTimelineSetHandlerMap,\n} from \"./event-timeline-set\";\nimport { Direction, EventTimeline } from \"./event-timeline\";\nimport { getHttpUriForMxc } from \"../content-repo\";\nimport * as utils from \"../utils\";\nimport { normalize, noUnsafeEventProps } from \"../utils\";\nimport { IEvent, IThreadBundledRelationship, MatrixEvent, MatrixEventEvent, MatrixEventHandlerMap } from \"./event\";\nimport { EventStatus } from \"./event-status\";\nimport { RoomMember } from \"./room-member\";\nimport { IRoomSummary, RoomSummary } from \"./room-summary\";\nimport { logger } from \"../logger\";\nimport { TypedReEmitter } from \"../ReEmitter\";\nimport {\n EventType,\n RoomCreateTypeField,\n RoomType,\n UNSTABLE_ELEMENT_FUNCTIONAL_USERS,\n EVENT_VISIBILITY_CHANGE_TYPE,\n RelationType,\n} from \"../@types/event\";\nimport { IRoomVersionsCapability, MatrixClient, PendingEventOrdering, RoomVersionStability } from \"../client\";\nimport { GuestAccess, HistoryVisibility, JoinRule, ResizeMethod } from \"../@types/partials\";\nimport { Filter, IFilterDefinition } from \"../filter\";\nimport { RoomState, RoomStateEvent, RoomStateEventHandlerMap } from \"./room-state\";\nimport { BeaconEvent, BeaconEventHandlerMap } from \"./beacon\";\nimport {\n Thread,\n ThreadEvent,\n EventHandlerMap as ThreadHandlerMap,\n FILTER_RELATED_BY_REL_TYPES,\n THREAD_RELATION_TYPE,\n FILTER_RELATED_BY_SENDERS,\n ThreadFilterType,\n} from \"./thread\";\nimport {\n CachedReceiptStructure,\n MAIN_ROOM_TIMELINE,\n Receipt,\n ReceiptContent,\n ReceiptType,\n} from \"../@types/read_receipts\";\nimport { IStateEventWithRoomId } from \"../@types/search\";\nimport { RelationsContainer } from \"./relations-container\";\nimport { ReadReceipt, synthesizeReceipt } from \"./read-receipt\";\nimport { Poll, PollEvent } from \"./poll\";\n\n// These constants are used as sane defaults when the homeserver doesn't support\n// the m.room_versions capability. In practice, KNOWN_SAFE_ROOM_VERSION should be\n// the same as the common default room version whereas SAFE_ROOM_VERSIONS are the\n// room versions which are considered okay for people to run without being asked\n// to upgrade (ie: \"stable\"). Eventually, we should remove these when all homeservers\n// return an m.room_versions capability.\nexport const KNOWN_SAFE_ROOM_VERSION = \"9\";\nconst SAFE_ROOM_VERSIONS = [\"1\", \"2\", \"3\", \"4\", \"5\", \"6\", \"7\", \"8\", \"9\"];\n\ninterface IOpts {\n /**\n * Controls where pending messages appear in a room's timeline.\n * If \"chronological\", messages will appear in the timeline when the call to `sendEvent` was made.\n * If \"detached\", pending messages will appear in a separate list,\n * accessible via {@link Room#getPendingEvents}.\n * Default: \"chronological\".\n */\n pendingEventOrdering?: PendingEventOrdering;\n /**\n * Set to true to enable improved timeline support.\n */\n timelineSupport?: boolean;\n lazyLoadMembers?: boolean;\n}\n\nexport interface IRecommendedVersion {\n version: string;\n needsUpgrade: boolean;\n urgent: boolean;\n}\n\n// When inserting a visibility event affecting event `eventId`, we\n// need to scan through existing visibility events for `eventId`.\n// In theory, this could take an unlimited amount of time if:\n//\n// - the visibility event was sent by a moderator; and\n// - `eventId` already has many visibility changes (usually, it should\n// be 2 or less); and\n// - for some reason, the visibility changes are received out of order\n// (usually, this shouldn't happen at all).\n//\n// For this reason, we limit the number of events to scan through,\n// expecting that a broken visibility change for a single event in\n// an extremely uncommon case (possibly a DoS) is a small\n// price to pay to keep matrix-js-sdk responsive.\nconst MAX_NUMBER_OF_VISIBILITY_EVENTS_TO_SCAN_THROUGH = 30;\n\nexport type NotificationCount = Partial>;\n\nexport enum NotificationCountType {\n Highlight = \"highlight\",\n Total = \"total\",\n}\n\nexport interface ICreateFilterOpts {\n // Populate the filtered timeline with already loaded events in the room\n // timeline. Useful to disable for some filters that can't be achieved by the\n // client in an efficient manner\n prepopulateTimeline?: boolean;\n useSyncEvents?: boolean;\n pendingEvents?: boolean;\n}\n\nexport enum RoomEvent {\n MyMembership = \"Room.myMembership\",\n Tags = \"Room.tags\",\n AccountData = \"Room.accountData\",\n Receipt = \"Room.receipt\",\n Name = \"Room.name\",\n Redaction = \"Room.redaction\",\n RedactionCancelled = \"Room.redactionCancelled\",\n LocalEchoUpdated = \"Room.localEchoUpdated\",\n Timeline = \"Room.timeline\",\n TimelineReset = \"Room.timelineReset\",\n TimelineRefresh = \"Room.TimelineRefresh\",\n OldStateUpdated = \"Room.OldStateUpdated\",\n CurrentStateUpdated = \"Room.CurrentStateUpdated\",\n HistoryImportedWithinTimeline = \"Room.historyImportedWithinTimeline\",\n UnreadNotifications = \"Room.UnreadNotifications\",\n}\n\nexport type RoomEmittedEvents =\n | RoomEvent\n | RoomStateEvent.Events\n | RoomStateEvent.Members\n | RoomStateEvent.NewMember\n | RoomStateEvent.Update\n | RoomStateEvent.Marker\n | ThreadEvent.New\n | ThreadEvent.Update\n | ThreadEvent.NewReply\n | ThreadEvent.Delete\n | MatrixEventEvent.BeforeRedaction\n | BeaconEvent.New\n | BeaconEvent.Update\n | BeaconEvent.Destroy\n | BeaconEvent.LivenessChange\n | PollEvent.New;\n\nexport type RoomEventHandlerMap = {\n /**\n * Fires when the logged in user's membership in the room is updated.\n *\n * @param room - The room in which the membership has been updated\n * @param membership - The new membership value\n * @param prevMembership - The previous membership value\n */\n [RoomEvent.MyMembership]: (room: Room, membership: string, prevMembership?: string) => void;\n /**\n * Fires whenever a room's tags are updated.\n * @param event - The tags event\n * @param room - The room whose Room.tags was updated.\n * @example\n * ```\n * matrixClient.on(\"Room.tags\", function(event, room){\n * var newTags = event.getContent().tags;\n * if (newTags[\"favourite\"]) showStar(room);\n * });\n * ```\n */\n [RoomEvent.Tags]: (event: MatrixEvent, room: Room) => void;\n /**\n * Fires whenever a room's account_data is updated.\n * @param event - The account_data event\n * @param room - The room whose account_data was updated.\n * @param prevEvent - The event being replaced by\n * the new account data, if known.\n * @example\n * ```\n * matrixClient.on(\"Room.accountData\", function(event, room, oldEvent){\n * if (event.getType() === \"m.room.colorscheme\") {\n * applyColorScheme(event.getContents());\n * }\n * });\n * ```\n */\n [RoomEvent.AccountData]: (event: MatrixEvent, room: Room, lastEvent?: MatrixEvent) => void;\n /**\n * Fires whenever a receipt is received for a room\n * @param event - The receipt event\n * @param room - The room whose receipts was updated.\n * @example\n * ```\n * matrixClient.on(\"Room.receipt\", function(event, room){\n * var receiptContent = event.getContent();\n * });\n * ```\n */\n [RoomEvent.Receipt]: (event: MatrixEvent, room: Room) => void;\n /**\n * Fires whenever the name of a room is updated.\n * @param room - The room whose Room.name was updated.\n * @example\n * ```\n * matrixClient.on(\"Room.name\", function(room){\n * var newName = room.name;\n * });\n * ```\n */\n [RoomEvent.Name]: (room: Room) => void;\n /**\n * Fires when an event we had previously received is redacted.\n *\n * (Note this is *not* fired when the redaction happens before we receive the\n * event).\n *\n * @param event - The matrix redaction event\n * @param room - The room containing the redacted event\n */\n [RoomEvent.Redaction]: (event: MatrixEvent, room: Room) => void;\n /**\n * Fires when an event that was previously redacted isn't anymore.\n * This happens when the redaction couldn't be sent and\n * was subsequently cancelled by the user. Redactions have a local echo\n * which is undone in this scenario.\n *\n * @param event - The matrix redaction event that was cancelled.\n * @param room - The room containing the unredacted event\n */\n [RoomEvent.RedactionCancelled]: (event: MatrixEvent, room: Room) => void;\n /**\n * Fires when the status of a transmitted event is updated.\n *\n *

When an event is first transmitted, a temporary copy of the event is\n * inserted into the timeline, with a temporary event id, and a status of\n * 'SENDING'.\n *\n *

Once the echo comes back from the server, the content of the event\n * (MatrixEvent.event) is replaced by the complete event from the homeserver,\n * thus updating its event id, as well as server-generated fields such as the\n * timestamp. Its status is set to null.\n *\n *

Once the /send request completes, if the remote echo has not already\n * arrived, the event is updated with a new event id and the status is set to\n * 'SENT'. The server-generated fields are of course not updated yet.\n *\n *

If the /send fails, In this case, the event's status is set to\n * 'NOT_SENT'. If it is later resent, the process starts again, setting the\n * status to 'SENDING'. Alternatively, the message may be cancelled, which\n * removes the event from the room, and sets the status to 'CANCELLED'.\n *\n *

This event is raised to reflect each of the transitions above.\n *\n * @param event - The matrix event which has been updated\n *\n * @param room - The room containing the redacted event\n *\n * @param oldEventId - The previous event id (the temporary event id,\n * except when updating a successfully-sent event when its echo arrives)\n *\n * @param oldStatus - The previous event status.\n */\n [RoomEvent.LocalEchoUpdated]: (\n event: MatrixEvent,\n room: Room,\n oldEventId?: string,\n oldStatus?: EventStatus | null,\n ) => void;\n [RoomEvent.OldStateUpdated]: (room: Room, previousRoomState: RoomState, roomState: RoomState) => void;\n [RoomEvent.CurrentStateUpdated]: (room: Room, previousRoomState: RoomState, roomState: RoomState) => void;\n [RoomEvent.HistoryImportedWithinTimeline]: (markerEvent: MatrixEvent, room: Room) => void;\n [RoomEvent.UnreadNotifications]: (unreadNotifications?: NotificationCount, threadId?: string) => void;\n [RoomEvent.TimelineRefresh]: (room: Room, eventTimelineSet: EventTimelineSet) => void;\n [ThreadEvent.New]: (thread: Thread, toStartOfTimeline: boolean) => void;\n /**\n * Fires when a new poll instance is added to the room state\n * @param poll - the new poll\n */\n [PollEvent.New]: (poll: Poll) => void;\n} & Pick &\n EventTimelineSetHandlerMap &\n Pick &\n Pick<\n RoomStateEventHandlerMap,\n | RoomStateEvent.Events\n | RoomStateEvent.Members\n | RoomStateEvent.NewMember\n | RoomStateEvent.Update\n | RoomStateEvent.Marker\n | BeaconEvent.New\n > &\n Pick;\n\nexport class Room extends ReadReceipt {\n public readonly reEmitter: TypedReEmitter;\n private txnToEvent: Map = new Map(); // Pending in-flight requests { string: MatrixEvent }\n private notificationCounts: NotificationCount = {};\n private readonly threadNotifications = new Map();\n public readonly cachedThreadReadReceipts = new Map();\n // Useful to know at what point the current user has started using threads in this room\n private oldestThreadedReceiptTs = Infinity;\n /**\n * A record of the latest unthread receipts per user\n * This is useful in determining whether a user has read a thread or not\n */\n private unthreadedReceipts = new Map();\n private readonly timelineSets: EventTimelineSet[];\n public readonly polls: Map = new Map();\n public readonly threadsTimelineSets: EventTimelineSet[] = [];\n // any filtered timeline sets we're maintaining for this room\n private readonly filteredTimelineSets: Record = {}; // filter_id: timelineSet\n private timelineNeedsRefresh = false;\n private readonly pendingEventList?: MatrixEvent[];\n // read by megolm via getter; boolean value - null indicates \"use global value\"\n private blacklistUnverifiedDevices?: boolean;\n private selfMembership?: string;\n private summaryHeroes: string[] | null = null;\n // flags to stop logspam about missing m.room.create events\n private getTypeWarning = false;\n private getVersionWarning = false;\n private membersPromise?: Promise;\n\n // XXX: These should be read-only\n /**\n * The human-readable display name for this room.\n */\n public name: string;\n /**\n * The un-homoglyphed name for this room.\n */\n public normalizedName: string;\n /**\n * Dict of room tags; the keys are the tag name and the values\n * are any metadata associated with the tag - e.g. `{ \"fav\" : { order: 1 } }`\n */\n public tags: Record> = {}; // $tagName: { $metadata: $value }\n /**\n * accountData Dict of per-room account_data events; the keys are the\n * event type and the values are the events.\n */\n public accountData: Map = new Map(); // $eventType: $event\n /**\n * The room summary.\n */\n public summary: RoomSummary | null = null;\n // legacy fields\n /**\n * The live event timeline for this room, with the oldest event at index 0.\n * Present for backwards compatibility - prefer getLiveTimeline().getEvents()\n */\n public timeline!: MatrixEvent[];\n /**\n * oldState The state of the room at the time of the oldest\n * event in the live timeline. Present for backwards compatibility -\n * prefer getLiveTimeline().getState(EventTimeline.BACKWARDS).\n */\n public oldState!: RoomState;\n /**\n * currentState The state of the room at the time of the\n * newest event in the timeline. Present for backwards compatibility -\n * prefer getLiveTimeline().getState(EventTimeline.FORWARDS).\n */\n public currentState!: RoomState;\n public readonly relations = new RelationsContainer(this.client, this);\n\n /**\n * A collection of events known by the client\n * This is not a comprehensive list of the threads that exist in this room\n */\n private threads = new Map();\n public lastThread?: Thread;\n\n /**\n * A mapping of eventId to all visibility changes to apply\n * to the event, by chronological order, as per\n * https://github.com/matrix-org/matrix-doc/pull/3531\n *\n * # Invariants\n *\n * - within each list, all events are classed by\n * chronological order;\n * - all events are events such that\n * `asVisibilityEvent()` returns a non-null `IVisibilityChange`;\n * - within each list with key `eventId`, all events\n * are in relation to `eventId`.\n *\n * @experimental\n */\n private visibilityEvents = new Map();\n\n /**\n * Construct a new Room.\n *\n *

For a room, we store an ordered sequence of timelines, which may or may not\n * be continuous. Each timeline lists a series of events, as well as tracking\n * the room state at the start and the end of the timeline. It also tracks\n * forward and backward pagination tokens, as well as containing links to the\n * next timeline in the sequence.\n *\n *

There is one special timeline - the 'live' timeline, which represents the\n * timeline to which events are being added in real-time as they are received\n * from the /sync API. Note that you should not retain references to this\n * timeline - even if it is the current timeline right now, it may not remain\n * so if the server gives us a timeline gap in /sync.\n *\n *

In order that we can find events from their ids later, we also maintain a\n * map from event_id to timeline and index.\n *\n * @param roomId - Required. The ID of this room.\n * @param client - Required. The client, used to lazy load members.\n * @param myUserId - Required. The ID of the syncing user.\n * @param opts - Configuration options\n */\n public constructor(\n public readonly roomId: string,\n public readonly client: MatrixClient,\n public readonly myUserId: string,\n private readonly opts: IOpts = {},\n ) {\n super();\n // In some cases, we add listeners for every displayed Matrix event, so it's\n // common to have quite a few more than the default limit.\n this.setMaxListeners(100);\n this.reEmitter = new TypedReEmitter(this);\n\n opts.pendingEventOrdering = opts.pendingEventOrdering || PendingEventOrdering.Chronological;\n\n this.name = roomId;\n this.normalizedName = roomId;\n\n // all our per-room timeline sets. the first one is the unfiltered ones;\n // the subsequent ones are the filtered ones in no particular order.\n this.timelineSets = [new EventTimelineSet(this, opts)];\n this.reEmitter.reEmit(this.getUnfilteredTimelineSet(), [RoomEvent.Timeline, RoomEvent.TimelineReset]);\n\n this.fixUpLegacyTimelineFields();\n\n if (this.opts.pendingEventOrdering === PendingEventOrdering.Detached) {\n this.pendingEventList = [];\n this.client.store.getPendingEvents(this.roomId).then((events) => {\n const mapper = this.client.getEventMapper({\n toDevice: false,\n decrypt: false,\n });\n events.forEach(async (serializedEvent: Partial) => {\n const event = mapper(serializedEvent);\n await client.decryptEventIfNeeded(event);\n event.setStatus(EventStatus.NOT_SENT);\n this.addPendingEvent(event, event.getTxnId()!);\n });\n });\n }\n\n // awaited by getEncryptionTargetMembers while room members are loading\n if (!this.opts.lazyLoadMembers) {\n this.membersPromise = Promise.resolve(false);\n } else {\n this.membersPromise = undefined;\n }\n }\n\n private threadTimelineSetsPromise: Promise<[EventTimelineSet, EventTimelineSet]> | null = null;\n public async createThreadsTimelineSets(): Promise<[EventTimelineSet, EventTimelineSet] | null> {\n if (this.threadTimelineSetsPromise) {\n return this.threadTimelineSetsPromise;\n }\n\n if (this.client?.supportsThreads()) {\n try {\n this.threadTimelineSetsPromise = Promise.all([\n this.createThreadTimelineSet(),\n this.createThreadTimelineSet(ThreadFilterType.My),\n ]);\n const timelineSets = await this.threadTimelineSetsPromise;\n this.threadsTimelineSets.push(...timelineSets);\n return timelineSets;\n } catch (e) {\n this.threadTimelineSetsPromise = null;\n return null;\n }\n }\n return null;\n }\n\n /**\n * Bulk decrypt critical events in a room\n *\n * Critical events represents the minimal set of events to decrypt\n * for a typical UI to function properly\n *\n * - Last event of every room (to generate likely message preview)\n * - All events up to the read receipt (to calculate an accurate notification count)\n *\n * @returns Signals when all events have been decrypted\n */\n public async decryptCriticalEvents(): Promise {\n if (!this.client.isCryptoEnabled()) return;\n\n const readReceiptEventId = this.getEventReadUpTo(this.client.getUserId()!, true);\n const events = this.getLiveTimeline().getEvents();\n const readReceiptTimelineIndex = events.findIndex((matrixEvent) => {\n return matrixEvent.event.event_id === readReceiptEventId;\n });\n\n const decryptionPromises = events\n .slice(readReceiptTimelineIndex)\n .reverse()\n .map((event) => this.client.decryptEventIfNeeded(event, { isRetry: true }));\n\n await Promise.allSettled(decryptionPromises);\n }\n\n /**\n * Bulk decrypt events in a room\n *\n * @returns Signals when all events have been decrypted\n */\n public async decryptAllEvents(): Promise {\n if (!this.client.isCryptoEnabled()) return;\n\n const decryptionPromises = this.getUnfilteredTimelineSet()\n .getLiveTimeline()\n .getEvents()\n .slice(0) // copy before reversing\n .reverse()\n .map((event) => this.client.decryptEventIfNeeded(event, { isRetry: true }));\n\n await Promise.allSettled(decryptionPromises);\n }\n\n /**\n * Gets the creator of the room\n * @returns The creator of the room, or null if it could not be determined\n */\n public getCreator(): string | null {\n const createEvent = this.currentState.getStateEvents(EventType.RoomCreate, \"\");\n return createEvent?.getContent()[\"creator\"] ?? null;\n }\n\n /**\n * Gets the version of the room\n * @returns The version of the room, or null if it could not be determined\n */\n public getVersion(): string {\n const createEvent = this.currentState.getStateEvents(EventType.RoomCreate, \"\");\n if (!createEvent) {\n if (!this.getVersionWarning) {\n logger.warn(\"[getVersion] Room \" + this.roomId + \" does not have an m.room.create event\");\n this.getVersionWarning = true;\n }\n return \"1\";\n }\n return createEvent.getContent()[\"room_version\"] ?? \"1\";\n }\n\n /**\n * Determines whether this room needs to be upgraded to a new version\n * @returns What version the room should be upgraded to, or null if\n * the room does not require upgrading at this time.\n * @deprecated Use #getRecommendedVersion() instead\n */\n public shouldUpgradeToVersion(): string | null {\n // TODO: Remove this function.\n // This makes assumptions about which versions are safe, and can easily\n // be wrong. Instead, people are encouraged to use getRecommendedVersion\n // which determines a safer value. This function doesn't use that function\n // because this is not async-capable, and to avoid breaking the contract\n // we're deprecating this.\n\n if (!SAFE_ROOM_VERSIONS.includes(this.getVersion())) {\n return KNOWN_SAFE_ROOM_VERSION;\n }\n\n return null;\n }\n\n /**\n * Determines the recommended room version for the room. This returns an\n * object with 3 properties: `version` as the new version the\n * room should be upgraded to (may be the same as the current version);\n * `needsUpgrade` to indicate if the room actually can be\n * upgraded (ie: does the current version not match?); and `urgent`\n * to indicate if the new version patches a vulnerability in a previous\n * version.\n * @returns\n * Resolves to the version the room should be upgraded to.\n */\n public async getRecommendedVersion(): Promise {\n const capabilities = await this.client.getCapabilities();\n let versionCap = capabilities[\"m.room_versions\"];\n if (!versionCap) {\n versionCap = {\n default: KNOWN_SAFE_ROOM_VERSION,\n available: {},\n };\n for (const safeVer of SAFE_ROOM_VERSIONS) {\n versionCap.available[safeVer] = RoomVersionStability.Stable;\n }\n }\n\n let result = this.checkVersionAgainstCapability(versionCap);\n if (result.urgent && result.needsUpgrade) {\n // Something doesn't feel right: we shouldn't need to update\n // because the version we're on should be in the protocol's\n // namespace. This usually means that the server was updated\n // before the client was, making us think the newest possible\n // room version is not stable. As a solution, we'll refresh\n // the capability we're using to determine this.\n logger.warn(\n \"Refreshing room version capability because the server looks \" +\n \"to be supporting a newer room version we don't know about.\",\n );\n\n const caps = await this.client.getCapabilities(true);\n versionCap = caps[\"m.room_versions\"];\n if (!versionCap) {\n logger.warn(\"No room version capability - assuming upgrade required.\");\n return result;\n } else {\n result = this.checkVersionAgainstCapability(versionCap);\n }\n }\n\n return result;\n }\n\n private checkVersionAgainstCapability(versionCap: IRoomVersionsCapability): IRecommendedVersion {\n const currentVersion = this.getVersion();\n logger.log(`[${this.roomId}] Current version: ${currentVersion}`);\n logger.log(`[${this.roomId}] Version capability: `, versionCap);\n\n const result: IRecommendedVersion = {\n version: currentVersion,\n needsUpgrade: false,\n urgent: false,\n };\n\n // If the room is on the default version then nothing needs to change\n if (currentVersion === versionCap.default) return result;\n\n const stableVersions = Object.keys(versionCap.available).filter((v) => versionCap.available[v] === \"stable\");\n\n // Check if the room is on an unstable version. We determine urgency based\n // off the version being in the Matrix spec namespace or not (if the version\n // is in the current namespace and unstable, the room is probably vulnerable).\n if (!stableVersions.includes(currentVersion)) {\n result.version = versionCap.default;\n result.needsUpgrade = true;\n result.urgent = !!this.getVersion().match(/^[0-9]+[0-9.]*$/g);\n if (result.urgent) {\n logger.warn(`URGENT upgrade required on ${this.roomId}`);\n } else {\n logger.warn(`Non-urgent upgrade required on ${this.roomId}`);\n }\n return result;\n }\n\n // The room is on a stable, but non-default, version by this point.\n // No upgrade needed.\n return result;\n }\n\n /**\n * Determines whether the given user is permitted to perform a room upgrade\n * @param userId - The ID of the user to test against\n * @returns True if the given user is permitted to upgrade the room\n */\n public userMayUpgradeRoom(userId: string): boolean {\n return this.currentState.maySendStateEvent(EventType.RoomTombstone, userId);\n }\n\n /**\n * Get the list of pending sent events for this room\n *\n * @returns A list of the sent events\n * waiting for remote echo.\n *\n * @throws If `opts.pendingEventOrdering` was not 'detached'\n */\n public getPendingEvents(): MatrixEvent[] {\n if (!this.pendingEventList) {\n throw new Error(\n \"Cannot call getPendingEvents with pendingEventOrdering == \" + this.opts.pendingEventOrdering,\n );\n }\n\n return this.pendingEventList;\n }\n\n /**\n * Removes a pending event for this room\n *\n * @returns True if an element was removed.\n */\n public removePendingEvent(eventId: string): boolean {\n if (!this.pendingEventList) {\n throw new Error(\n \"Cannot call removePendingEvent with pendingEventOrdering == \" + this.opts.pendingEventOrdering,\n );\n }\n\n const removed = utils.removeElement(\n this.pendingEventList,\n function (ev) {\n return ev.getId() == eventId;\n },\n false,\n );\n\n this.savePendingEvents();\n\n return removed;\n }\n\n /**\n * Check whether the pending event list contains a given event by ID.\n * If pending event ordering is not \"detached\" then this returns false.\n *\n * @param eventId - The event ID to check for.\n */\n public hasPendingEvent(eventId: string): boolean {\n return this.pendingEventList?.some((event) => event.getId() === eventId) ?? false;\n }\n\n /**\n * Get a specific event from the pending event list, if configured, null otherwise.\n *\n * @param eventId - The event ID to check for.\n */\n public getPendingEvent(eventId: string): MatrixEvent | null {\n return this.pendingEventList?.find((event) => event.getId() === eventId) ?? null;\n }\n\n /**\n * Get the live unfiltered timeline for this room.\n *\n * @returns live timeline\n */\n public getLiveTimeline(): EventTimeline {\n return this.getUnfilteredTimelineSet().getLiveTimeline();\n }\n\n /**\n * Get the timestamp of the last message in the room\n *\n * @returns the timestamp of the last message in the room\n */\n public getLastActiveTimestamp(): number {\n const timeline = this.getLiveTimeline();\n const events = timeline.getEvents();\n if (events.length) {\n const lastEvent = events[events.length - 1];\n return lastEvent.getTs();\n } else {\n return Number.MIN_SAFE_INTEGER;\n }\n }\n\n /**\n * @returns the membership type (join | leave | invite) for the logged in user\n */\n public getMyMembership(): string {\n return this.selfMembership ?? \"leave\";\n }\n\n /**\n * If this room is a DM we're invited to,\n * try to find out who invited us\n * @returns user id of the inviter\n */\n public getDMInviter(): string | undefined {\n const me = this.getMember(this.myUserId);\n if (me) {\n return me.getDMInviter();\n }\n\n if (this.selfMembership === \"invite\") {\n // fall back to summary information\n const memberCount = this.getInvitedAndJoinedMemberCount();\n if (memberCount === 2) {\n return this.summaryHeroes?.[0];\n }\n }\n }\n\n /**\n * Assuming this room is a DM room, tries to guess with which user.\n * @returns user id of the other member (could be syncing user)\n */\n public guessDMUserId(): string {\n const me = this.getMember(this.myUserId);\n if (me) {\n const inviterId = me.getDMInviter();\n if (inviterId) {\n return inviterId;\n }\n }\n // Remember, we're assuming this room is a DM, so returning the first member we find should be fine\n if (Array.isArray(this.summaryHeroes) && this.summaryHeroes.length) {\n return this.summaryHeroes[0];\n }\n const members = this.currentState.getMembers();\n const anyMember = members.find((m) => m.userId !== this.myUserId);\n if (anyMember) {\n return anyMember.userId;\n }\n // it really seems like I'm the only user in the room\n // so I probably created a room with just me in it\n // and marked it as a DM. Ok then\n return this.myUserId;\n }\n\n public getAvatarFallbackMember(): RoomMember | undefined {\n const memberCount = this.getInvitedAndJoinedMemberCount();\n if (memberCount > 2) {\n return;\n }\n const hasHeroes = Array.isArray(this.summaryHeroes) && this.summaryHeroes.length;\n if (hasHeroes) {\n const availableMember = this.summaryHeroes!.map((userId) => {\n return this.getMember(userId);\n }).find((member) => !!member);\n if (availableMember) {\n return availableMember;\n }\n }\n const members = this.currentState.getMembers();\n // could be different than memberCount\n // as this includes left members\n if (members.length <= 2) {\n const availableMember = members.find((m) => {\n return m.userId !== this.myUserId;\n });\n if (availableMember) {\n return availableMember;\n }\n }\n // if all else fails, try falling back to a user,\n // and create a one-off member for it\n if (hasHeroes) {\n const availableUser = this.summaryHeroes!.map((userId) => {\n return this.client.getUser(userId);\n }).find((user) => !!user);\n if (availableUser) {\n const member = new RoomMember(this.roomId, availableUser.userId);\n member.user = availableUser;\n return member;\n }\n }\n }\n\n /**\n * Sets the membership this room was received as during sync\n * @param membership - join | leave | invite\n */\n public updateMyMembership(membership: string): void {\n const prevMembership = this.selfMembership;\n this.selfMembership = membership;\n if (prevMembership !== membership) {\n if (membership === \"leave\") {\n this.cleanupAfterLeaving();\n }\n this.emit(RoomEvent.MyMembership, this, membership, prevMembership);\n }\n }\n\n private async loadMembersFromServer(): Promise {\n const lastSyncToken = this.client.store.getSyncToken();\n const response = await this.client.members(this.roomId, undefined, \"leave\", lastSyncToken ?? undefined);\n return response.chunk;\n }\n\n private async loadMembers(): Promise<{ memberEvents: MatrixEvent[]; fromServer: boolean }> {\n // were the members loaded from the server?\n let fromServer = false;\n let rawMembersEvents = await this.client.store.getOutOfBandMembers(this.roomId);\n // If the room is encrypted, we always fetch members from the server at\n // least once, in case the latest state wasn't persisted properly. Note\n // that this function is only called once (unless loading the members\n // fails), since loadMembersIfNeeded always returns this.membersPromise\n // if set, which will be the result of the first (successful) call.\n if (rawMembersEvents === null || (this.client.isCryptoEnabled() && this.client.isRoomEncrypted(this.roomId))) {\n fromServer = true;\n rawMembersEvents = await this.loadMembersFromServer();\n logger.log(`LL: got ${rawMembersEvents.length} ` + `members from server for room ${this.roomId}`);\n }\n const memberEvents = rawMembersEvents.filter(noUnsafeEventProps).map(this.client.getEventMapper());\n return { memberEvents, fromServer };\n }\n\n /**\n * Check if loading of out-of-band-members has completed\n *\n * @returns true if the full membership list of this room has been loaded (including if lazy-loading is disabled).\n * False if the load is not started or is in progress.\n */\n public membersLoaded(): boolean {\n if (!this.opts.lazyLoadMembers) {\n return true;\n }\n\n return this.currentState.outOfBandMembersReady();\n }\n\n /**\n * Preloads the member list in case lazy loading\n * of memberships is in use. Can be called multiple times,\n * it will only preload once.\n * @returns when preloading is done and\n * accessing the members on the room will take\n * all members in the room into account\n */\n public loadMembersIfNeeded(): Promise {\n if (this.membersPromise) {\n return this.membersPromise;\n }\n\n // mark the state so that incoming messages while\n // the request is in flight get marked as superseding\n // the OOB members\n this.currentState.markOutOfBandMembersStarted();\n\n const inMemoryUpdate = this.loadMembers()\n .then((result) => {\n this.currentState.setOutOfBandMembers(result.memberEvents);\n return result.fromServer;\n })\n .catch((err) => {\n // allow retries on fail\n this.membersPromise = undefined;\n this.currentState.markOutOfBandMembersFailed();\n throw err;\n });\n // update members in storage, but don't wait for it\n inMemoryUpdate\n .then((fromServer) => {\n if (fromServer) {\n const oobMembers = this.currentState\n .getMembers()\n .filter((m) => m.isOutOfBand())\n .map((m) => m.events.member?.event as IStateEventWithRoomId);\n logger.log(`LL: telling store to write ${oobMembers.length}` + ` members for room ${this.roomId}`);\n const store = this.client.store;\n return (\n store\n .setOutOfBandMembers(this.roomId, oobMembers)\n // swallow any IDB error as we don't want to fail\n // because of this\n .catch((err) => {\n logger.log(\"LL: storing OOB room members failed, oh well\", err);\n })\n );\n }\n })\n .catch((err) => {\n // as this is not awaited anywhere,\n // at least show the error in the console\n logger.error(err);\n });\n\n this.membersPromise = inMemoryUpdate;\n\n return this.membersPromise;\n }\n\n /**\n * Removes the lazily loaded members from storage if needed\n */\n public async clearLoadedMembersIfNeeded(): Promise {\n if (this.opts.lazyLoadMembers && this.membersPromise) {\n await this.loadMembersIfNeeded();\n await this.client.store.clearOutOfBandMembers(this.roomId);\n this.currentState.clearOutOfBandMembers();\n this.membersPromise = undefined;\n }\n }\n\n /**\n * called when sync receives this room in the leave section\n * to do cleanup after leaving a room. Possibly called multiple times.\n */\n private cleanupAfterLeaving(): void {\n this.clearLoadedMembersIfNeeded().catch((err) => {\n logger.error(`error after clearing loaded members from ` + `room ${this.roomId} after leaving`);\n logger.log(err);\n });\n }\n\n /**\n * Empty out the current live timeline and re-request it. This is used when\n * historical messages are imported into the room via MSC2716 `/batch_send`\n * because the client may already have that section of the timeline loaded.\n * We need to force the client to throw away their current timeline so that\n * when they back paginate over the area again with the historical messages\n * in between, it grabs the newly imported messages. We can listen for\n * `UNSTABLE_MSC2716_MARKER`, in order to tell when historical messages are ready\n * to be discovered in the room and the timeline needs a refresh. The SDK\n * emits a `RoomEvent.HistoryImportedWithinTimeline` event when we detect a\n * valid marker and can check the needs refresh status via\n * `room.getTimelineNeedsRefresh()`.\n */\n public async refreshLiveTimeline(): Promise {\n const liveTimelineBefore = this.getLiveTimeline();\n const forwardPaginationToken = liveTimelineBefore.getPaginationToken(EventTimeline.FORWARDS);\n const backwardPaginationToken = liveTimelineBefore.getPaginationToken(EventTimeline.BACKWARDS);\n const eventsBefore = liveTimelineBefore.getEvents();\n const mostRecentEventInTimeline = eventsBefore[eventsBefore.length - 1];\n logger.log(\n `[refreshLiveTimeline for ${this.roomId}] at ` +\n `mostRecentEventInTimeline=${mostRecentEventInTimeline && mostRecentEventInTimeline.getId()} ` +\n `liveTimelineBefore=${liveTimelineBefore.toString()} ` +\n `forwardPaginationToken=${forwardPaginationToken} ` +\n `backwardPaginationToken=${backwardPaginationToken}`,\n );\n\n // Get the main TimelineSet\n const timelineSet = this.getUnfilteredTimelineSet();\n\n let newTimeline: Optional;\n // If there isn't any event in the timeline, let's go fetch the latest\n // event and construct a timeline from it.\n //\n // This should only really happen if the user ran into an error\n // with refreshing the timeline before which left them in a blank\n // timeline from `resetLiveTimeline`.\n if (!mostRecentEventInTimeline) {\n newTimeline = await this.client.getLatestTimeline(timelineSet);\n } else {\n // Empty out all of `this.timelineSets`. But we also need to keep the\n // same `timelineSet` references around so the React code updates\n // properly and doesn't ignore the room events we emit because it checks\n // that the `timelineSet` references are the same. We need the\n // `timelineSet` empty so that the `client.getEventTimeline(...)` call\n // later, will call `/context` and create a new timeline instead of\n // returning the same one.\n this.resetLiveTimeline(null, null);\n\n // Make the UI timeline show the new blank live timeline we just\n // reset so that if the network fails below it's showing the\n // accurate state of what we're working with instead of the\n // disconnected one in the TimelineWindow which is just hanging\n // around by reference.\n this.emit(RoomEvent.TimelineRefresh, this, timelineSet);\n\n // Use `client.getEventTimeline(...)` to construct a new timeline from a\n // `/context` response state and events for the most recent event before\n // we reset everything. The `timelineSet` we pass in needs to be empty\n // in order for this function to call `/context` and generate a new\n // timeline.\n newTimeline = await this.client.getEventTimeline(timelineSet, mostRecentEventInTimeline.getId()!);\n }\n\n // If a racing `/sync` beat us to creating a new timeline, use that\n // instead because it's the latest in the room and any new messages in\n // the scrollback will include the history.\n const liveTimeline = timelineSet.getLiveTimeline();\n if (\n !liveTimeline ||\n (liveTimeline.getPaginationToken(Direction.Forward) === null &&\n liveTimeline.getPaginationToken(Direction.Backward) === null &&\n liveTimeline.getEvents().length === 0)\n ) {\n logger.log(`[refreshLiveTimeline for ${this.roomId}] using our new live timeline`);\n // Set the pagination token back to the live sync token (`null`) instead\n // of using the `/context` historical token (ex. `t12-13_0_0_0_0_0_0_0_0`)\n // so that it matches the next response from `/sync` and we can properly\n // continue the timeline.\n newTimeline!.setPaginationToken(forwardPaginationToken, EventTimeline.FORWARDS);\n\n // Set our new fresh timeline as the live timeline to continue syncing\n // forwards and back paginating from.\n timelineSet.setLiveTimeline(newTimeline!);\n // Fixup `this.oldstate` so that `scrollback` has the pagination tokens\n // available\n this.fixUpLegacyTimelineFields();\n } else {\n logger.log(\n `[refreshLiveTimeline for ${this.roomId}] \\`/sync\\` or some other request beat us to creating a new ` +\n `live timeline after we reset it. We'll use that instead since any events in the scrollback from ` +\n `this timeline will include the history.`,\n );\n }\n\n // The timeline has now been refreshed ✅\n this.setTimelineNeedsRefresh(false);\n\n // Emit an event which clients can react to and re-load the timeline\n // from the SDK\n this.emit(RoomEvent.TimelineRefresh, this, timelineSet);\n }\n\n /**\n * Reset the live timeline of all timelineSets, and start new ones.\n *\n *

This is used when /sync returns a 'limited' timeline.\n *\n * @param backPaginationToken - token for back-paginating the new timeline\n * @param forwardPaginationToken - token for forward-paginating the old live timeline,\n * if absent or null, all timelines are reset, removing old ones (including the previous live\n * timeline which would otherwise be unable to paginate forwards without this token).\n * Removing just the old live timeline whilst preserving previous ones is not supported.\n */\n public resetLiveTimeline(backPaginationToken?: string | null, forwardPaginationToken?: string | null): void {\n for (const timelineSet of this.timelineSets) {\n timelineSet.resetLiveTimeline(backPaginationToken ?? undefined, forwardPaginationToken ?? undefined);\n }\n for (const thread of this.threads.values()) {\n thread.resetLiveTimeline(backPaginationToken, forwardPaginationToken);\n }\n\n this.fixUpLegacyTimelineFields();\n }\n\n /**\n * Fix up this.timeline, this.oldState and this.currentState\n *\n * @internal\n */\n private fixUpLegacyTimelineFields(): void {\n const previousOldState = this.oldState;\n const previousCurrentState = this.currentState;\n\n // maintain this.timeline as a reference to the live timeline,\n // and this.oldState and this.currentState as references to the\n // state at the start and end of that timeline. These are more\n // for backwards-compatibility than anything else.\n this.timeline = this.getLiveTimeline().getEvents();\n this.oldState = this.getLiveTimeline().getState(EventTimeline.BACKWARDS)!;\n this.currentState = this.getLiveTimeline().getState(EventTimeline.FORWARDS)!;\n\n // Let people know to register new listeners for the new state\n // references. The reference won't necessarily change every time so only\n // emit when we see a change.\n if (previousOldState !== this.oldState) {\n this.emit(RoomEvent.OldStateUpdated, this, previousOldState, this.oldState);\n }\n\n if (previousCurrentState !== this.currentState) {\n this.emit(RoomEvent.CurrentStateUpdated, this, previousCurrentState, this.currentState);\n\n // Re-emit various events on the current room state\n // TODO: If currentState really only exists for backwards\n // compatibility, shouldn't we be doing this some other way?\n this.reEmitter.stopReEmitting(previousCurrentState, [\n RoomStateEvent.Events,\n RoomStateEvent.Members,\n RoomStateEvent.NewMember,\n RoomStateEvent.Update,\n RoomStateEvent.Marker,\n BeaconEvent.New,\n BeaconEvent.Update,\n BeaconEvent.Destroy,\n BeaconEvent.LivenessChange,\n ]);\n this.reEmitter.reEmit(this.currentState, [\n RoomStateEvent.Events,\n RoomStateEvent.Members,\n RoomStateEvent.NewMember,\n RoomStateEvent.Update,\n RoomStateEvent.Marker,\n BeaconEvent.New,\n BeaconEvent.Update,\n BeaconEvent.Destroy,\n BeaconEvent.LivenessChange,\n ]);\n }\n }\n\n /**\n * Returns whether there are any devices in the room that are unverified\n *\n * Note: Callers should first check if crypto is enabled on this device. If it is\n * disabled, then we aren't tracking room devices at all, so we can't answer this, and an\n * error will be thrown.\n *\n * @returns the result\n */\n public async hasUnverifiedDevices(): Promise {\n if (!this.client.isRoomEncrypted(this.roomId)) {\n return false;\n }\n const e2eMembers = await this.getEncryptionTargetMembers();\n for (const member of e2eMembers) {\n const devices = this.client.getStoredDevicesForUser(member.userId);\n if (devices.some((device) => device.isUnverified())) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Return the timeline sets for this room.\n * @returns array of timeline sets for this room\n */\n public getTimelineSets(): EventTimelineSet[] {\n return this.timelineSets;\n }\n\n /**\n * Helper to return the main unfiltered timeline set for this room\n * @returns room's unfiltered timeline set\n */\n public getUnfilteredTimelineSet(): EventTimelineSet {\n return this.timelineSets[0];\n }\n\n /**\n * Get the timeline which contains the given event from the unfiltered set, if any\n *\n * @param eventId - event ID to look for\n * @returns timeline containing\n * the given event, or null if unknown\n */\n public getTimelineForEvent(eventId: string): EventTimeline | null {\n const event = this.findEventById(eventId);\n const thread = this.findThreadForEvent(event);\n if (thread) {\n return thread.timelineSet.getTimelineForEvent(eventId);\n } else {\n return this.getUnfilteredTimelineSet().getTimelineForEvent(eventId);\n }\n }\n\n /**\n * Add a new timeline to this room's unfiltered timeline set\n *\n * @returns newly-created timeline\n */\n public addTimeline(): EventTimeline {\n return this.getUnfilteredTimelineSet().addTimeline();\n }\n\n /**\n * Whether the timeline needs to be refreshed in order to pull in new\n * historical messages that were imported.\n * @param value - The value to set\n */\n public setTimelineNeedsRefresh(value: boolean): void {\n this.timelineNeedsRefresh = value;\n }\n\n /**\n * Whether the timeline needs to be refreshed in order to pull in new\n * historical messages that were imported.\n * @returns .\n */\n public getTimelineNeedsRefresh(): boolean {\n return this.timelineNeedsRefresh;\n }\n\n /**\n * Get an event which is stored in our unfiltered timeline set, or in a thread\n *\n * @param eventId - event ID to look for\n * @returns the given event, or undefined if unknown\n */\n public findEventById(eventId: string): MatrixEvent | undefined {\n let event = this.getUnfilteredTimelineSet().findEventById(eventId);\n\n if (!event) {\n const threads = this.getThreads();\n for (let i = 0; i < threads.length; i++) {\n const thread = threads[i];\n event = thread.findEventById(eventId);\n if (event) {\n return event;\n }\n }\n }\n\n return event;\n }\n\n /**\n * Get one of the notification counts for this room\n * @param type - The type of notification count to get. default: 'total'\n * @returns The notification count, or undefined if there is no count\n * for this type.\n */\n public getUnreadNotificationCount(type = NotificationCountType.Total): number {\n let count = this.getRoomUnreadNotificationCount(type);\n for (const threadNotification of this.threadNotifications.values()) {\n count += threadNotification[type] ?? 0;\n }\n return count;\n }\n\n /**\n * Get the notification for the event context (room or thread timeline)\n */\n public getUnreadCountForEventContext(type = NotificationCountType.Total, event: MatrixEvent): number {\n const isThreadEvent = !!event.threadRootId && !event.isThreadRoot;\n\n return (\n (isThreadEvent\n ? this.getThreadUnreadNotificationCount(event.threadRootId, type)\n : this.getRoomUnreadNotificationCount(type)) ?? 0\n );\n }\n\n /**\n * Get one of the notification counts for this room\n * @param type - The type of notification count to get. default: 'total'\n * @returns The notification count, or undefined if there is no count\n * for this type.\n */\n public getRoomUnreadNotificationCount(type = NotificationCountType.Total): number {\n return this.notificationCounts[type] ?? 0;\n }\n\n /**\n * Get one of the notification counts for a thread\n * @param threadId - the root event ID\n * @param type - The type of notification count to get. default: 'total'\n * @returns The notification count, or undefined if there is no count\n * for this type.\n */\n public getThreadUnreadNotificationCount(threadId: string, type = NotificationCountType.Total): number {\n return this.threadNotifications.get(threadId)?.[type] ?? 0;\n }\n\n /**\n * Checks if the current room has unread thread notifications\n * @returns\n */\n public hasThreadUnreadNotification(): boolean {\n for (const notification of this.threadNotifications.values()) {\n if ((notification.highlight ?? 0) > 0 || (notification.total ?? 0) > 0) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Swet one of the notification count for a thread\n * @param threadId - the root event ID\n * @param type - The type of notification count to get. default: 'total'\n * @returns\n */\n public setThreadUnreadNotificationCount(threadId: string, type: NotificationCountType, count: number): void {\n const notification: NotificationCount = {\n highlight: this.threadNotifications.get(threadId)?.highlight,\n total: this.threadNotifications.get(threadId)?.total,\n ...{\n [type]: count,\n },\n };\n\n this.threadNotifications.set(threadId, notification);\n\n this.emit(RoomEvent.UnreadNotifications, notification, threadId);\n }\n\n /**\n * @returns the notification count type for all the threads in the room\n */\n public get threadsAggregateNotificationType(): NotificationCountType | null {\n let type: NotificationCountType | null = null;\n for (const threadNotification of this.threadNotifications.values()) {\n if ((threadNotification.highlight ?? 0) > 0) {\n return NotificationCountType.Highlight;\n } else if ((threadNotification.total ?? 0) > 0 && !type) {\n type = NotificationCountType.Total;\n }\n }\n return type;\n }\n\n /**\n * Resets the thread notifications for this room\n */\n public resetThreadUnreadNotificationCount(notificationsToKeep?: string[]): void {\n if (notificationsToKeep) {\n for (const [threadId] of this.threadNotifications) {\n if (!notificationsToKeep.includes(threadId)) {\n this.threadNotifications.delete(threadId);\n }\n }\n } else {\n this.threadNotifications.clear();\n }\n this.emit(RoomEvent.UnreadNotifications);\n }\n\n /**\n * Set one of the notification counts for this room\n * @param type - The type of notification count to set.\n * @param count - The new count\n */\n public setUnreadNotificationCount(type: NotificationCountType, count: number): void {\n this.notificationCounts[type] = count;\n this.emit(RoomEvent.UnreadNotifications, this.notificationCounts);\n }\n\n public setUnread(type: NotificationCountType, count: number): void {\n return this.setUnreadNotificationCount(type, count);\n }\n\n public setSummary(summary: IRoomSummary): void {\n const heroes = summary[\"m.heroes\"];\n const joinedCount = summary[\"m.joined_member_count\"];\n const invitedCount = summary[\"m.invited_member_count\"];\n if (Number.isInteger(joinedCount)) {\n this.currentState.setJoinedMemberCount(joinedCount!);\n }\n if (Number.isInteger(invitedCount)) {\n this.currentState.setInvitedMemberCount(invitedCount!);\n }\n if (Array.isArray(heroes)) {\n // be cautious about trusting server values,\n // and make sure heroes doesn't contain our own id\n // just to be sure\n this.summaryHeroes = heroes.filter((userId) => {\n return userId !== this.myUserId;\n });\n }\n }\n\n /**\n * Whether to send encrypted messages to devices within this room.\n * @param value - true to blacklist unverified devices, null\n * to use the global value for this room.\n */\n public setBlacklistUnverifiedDevices(value: boolean): void {\n this.blacklistUnverifiedDevices = value;\n }\n\n /**\n * Whether to send encrypted messages to devices within this room.\n * @returns true if blacklisting unverified devices, null\n * if the global value should be used for this room.\n */\n public getBlacklistUnverifiedDevices(): boolean | null {\n if (this.blacklistUnverifiedDevices === undefined) return null;\n return this.blacklistUnverifiedDevices;\n }\n\n /**\n * Get the avatar URL for a room if one was set.\n * @param baseUrl - The homeserver base URL. See\n * {@link MatrixClient#getHomeserverUrl}.\n * @param width - The desired width of the thumbnail.\n * @param height - The desired height of the thumbnail.\n * @param resizeMethod - The thumbnail resize method to use, either\n * \"crop\" or \"scale\".\n * @param allowDefault - True to allow an identicon for this room if an\n * avatar URL wasn't explicitly set. Default: true. (Deprecated)\n * @returns the avatar URL or null.\n */\n public getAvatarUrl(\n baseUrl: string,\n width: number,\n height: number,\n resizeMethod: ResizeMethod,\n allowDefault = true,\n ): string | null {\n const roomAvatarEvent = this.currentState.getStateEvents(EventType.RoomAvatar, \"\");\n if (!roomAvatarEvent && !allowDefault) {\n return null;\n }\n\n const mainUrl = roomAvatarEvent ? roomAvatarEvent.getContent().url : null;\n if (mainUrl) {\n return getHttpUriForMxc(baseUrl, mainUrl, width, height, resizeMethod);\n }\n\n return null;\n }\n\n /**\n * Get the mxc avatar url for the room, if one was set.\n * @returns the mxc avatar url or falsy\n */\n public getMxcAvatarUrl(): string | null {\n return this.currentState.getStateEvents(EventType.RoomAvatar, \"\")?.getContent()?.url || null;\n }\n\n /**\n * Get this room's canonical alias\n * The alias returned by this function may not necessarily\n * still point to this room.\n * @returns The room's canonical alias, or null if there is none\n */\n public getCanonicalAlias(): string | null {\n const canonicalAlias = this.currentState.getStateEvents(EventType.RoomCanonicalAlias, \"\");\n if (canonicalAlias) {\n return canonicalAlias.getContent().alias || null;\n }\n return null;\n }\n\n /**\n * Get this room's alternative aliases\n * @returns The room's alternative aliases, or an empty array\n */\n public getAltAliases(): string[] {\n const canonicalAlias = this.currentState.getStateEvents(EventType.RoomCanonicalAlias, \"\");\n if (canonicalAlias) {\n return canonicalAlias.getContent().alt_aliases || [];\n }\n return [];\n }\n\n /**\n * Add events to a timeline\n *\n *

Will fire \"Room.timeline\" for each event added.\n *\n * @param events - A list of events to add.\n *\n * @param toStartOfTimeline - True to add these events to the start\n * (oldest) instead of the end (newest) of the timeline. If true, the oldest\n * event will be the last element of 'events'.\n *\n * @param timeline - timeline to\n * add events to.\n *\n * @param paginationToken - token for the next batch of events\n *\n * @remarks\n * Fires {@link RoomEvent.Timeline}\n */\n public addEventsToTimeline(\n events: MatrixEvent[],\n toStartOfTimeline: boolean,\n timeline: EventTimeline,\n paginationToken?: string,\n ): void {\n timeline.getTimelineSet().addEventsToTimeline(events, toStartOfTimeline, timeline, paginationToken);\n }\n\n /**\n * Get the instance of the thread associated with the current event\n * @param eventId - the ID of the current event\n * @returns a thread instance if known\n */\n public getThread(eventId: string): Thread | null {\n return this.threads.get(eventId) ?? null;\n }\n\n /**\n * Get all the known threads in the room\n */\n public getThreads(): Thread[] {\n return Array.from(this.threads.values());\n }\n\n /**\n * Get a member from the current room state.\n * @param userId - The user ID of the member.\n * @returns The member or `null`.\n */\n public getMember(userId: string): RoomMember | null {\n return this.currentState.getMember(userId);\n }\n\n /**\n * Get all currently loaded members from the current\n * room state.\n * @returns Room members\n */\n public getMembers(): RoomMember[] {\n return this.currentState.getMembers();\n }\n\n /**\n * Get a list of members whose membership state is \"join\".\n * @returns A list of currently joined members.\n */\n public getJoinedMembers(): RoomMember[] {\n return this.getMembersWithMembership(\"join\");\n }\n\n /**\n * Returns the number of joined members in this room\n * This method caches the result.\n * This is a wrapper around the method of the same name in roomState, returning\n * its result for the room's current state.\n * @returns The number of members in this room whose membership is 'join'\n */\n public getJoinedMemberCount(): number {\n return this.currentState.getJoinedMemberCount();\n }\n\n /**\n * Returns the number of invited members in this room\n * @returns The number of members in this room whose membership is 'invite'\n */\n public getInvitedMemberCount(): number {\n return this.currentState.getInvitedMemberCount();\n }\n\n /**\n * Returns the number of invited + joined members in this room\n * @returns The number of members in this room whose membership is 'invite' or 'join'\n */\n public getInvitedAndJoinedMemberCount(): number {\n return this.getInvitedMemberCount() + this.getJoinedMemberCount();\n }\n\n /**\n * Get a list of members with given membership state.\n * @param membership - The membership state.\n * @returns A list of members with the given membership state.\n */\n public getMembersWithMembership(membership: string): RoomMember[] {\n return this.currentState.getMembers().filter(function (m) {\n return m.membership === membership;\n });\n }\n\n /**\n * Get a list of members we should be encrypting for in this room\n * @returns A list of members who\n * we should encrypt messages for in this room.\n */\n public async getEncryptionTargetMembers(): Promise {\n await this.loadMembersIfNeeded();\n let members = this.getMembersWithMembership(\"join\");\n if (this.shouldEncryptForInvitedMembers()) {\n members = members.concat(this.getMembersWithMembership(\"invite\"));\n }\n return members;\n }\n\n /**\n * Determine whether we should encrypt messages for invited users in this room\n * @returns if we should encrypt messages for invited users\n */\n public shouldEncryptForInvitedMembers(): boolean {\n const ev = this.currentState.getStateEvents(EventType.RoomHistoryVisibility, \"\");\n return ev?.getContent()?.history_visibility !== \"joined\";\n }\n\n /**\n * Get the default room name (i.e. what a given user would see if the\n * room had no m.room.name)\n * @param userId - The userId from whose perspective we want\n * to calculate the default name\n * @returns The default room name\n */\n public getDefaultRoomName(userId: string): string {\n return this.calculateRoomName(userId, true);\n }\n\n /**\n * Check if the given user_id has the given membership state.\n * @param userId - The user ID to check.\n * @param membership - The membership e.g. `'join'`\n * @returns True if this user_id has the given membership state.\n */\n public hasMembershipState(userId: string, membership: string): boolean {\n const member = this.getMember(userId);\n if (!member) {\n return false;\n }\n return member.membership === membership;\n }\n\n /**\n * Add a timelineSet for this room with the given filter\n * @param filter - The filter to be applied to this timelineSet\n * @param opts - Configuration options\n * @returns The timelineSet\n */\n public getOrCreateFilteredTimelineSet(\n filter: Filter,\n { prepopulateTimeline = true, useSyncEvents = true, pendingEvents = true }: ICreateFilterOpts = {},\n ): EventTimelineSet {\n if (this.filteredTimelineSets[filter.filterId!]) {\n return this.filteredTimelineSets[filter.filterId!];\n }\n const opts = Object.assign({ filter, pendingEvents }, this.opts);\n const timelineSet = new EventTimelineSet(this, opts);\n this.reEmitter.reEmit(timelineSet, [RoomEvent.Timeline, RoomEvent.TimelineReset]);\n if (useSyncEvents) {\n this.filteredTimelineSets[filter.filterId!] = timelineSet;\n this.timelineSets.push(timelineSet);\n }\n\n const unfilteredLiveTimeline = this.getLiveTimeline();\n // Not all filter are possible to replicate client-side only\n // When that's the case we do not want to prepopulate from the live timeline\n // as we would get incorrect results compared to what the server would send back\n if (prepopulateTimeline) {\n // populate up the new timelineSet with filtered events from our live\n // unfiltered timeline.\n //\n // XXX: This is risky as our timeline\n // may have grown huge and so take a long time to filter.\n // see https://github.com/vector-im/vector-web/issues/2109\n\n unfilteredLiveTimeline.getEvents().forEach(function (event) {\n timelineSet.addLiveEvent(event);\n });\n\n // find the earliest unfiltered timeline\n let timeline = unfilteredLiveTimeline;\n while (timeline.getNeighbouringTimeline(EventTimeline.BACKWARDS)) {\n timeline = timeline.getNeighbouringTimeline(EventTimeline.BACKWARDS)!;\n }\n\n timelineSet\n .getLiveTimeline()\n .setPaginationToken(timeline.getPaginationToken(EventTimeline.BACKWARDS), EventTimeline.BACKWARDS);\n } else if (useSyncEvents) {\n const livePaginationToken = unfilteredLiveTimeline.getPaginationToken(Direction.Forward);\n timelineSet.getLiveTimeline().setPaginationToken(livePaginationToken, Direction.Backward);\n }\n\n // alternatively, we could try to do something like this to try and re-paginate\n // in the filtered events from nothing, but Mark says it's an abuse of the API\n // to do so:\n //\n // timelineSet.resetLiveTimeline(\n // unfilteredLiveTimeline.getPaginationToken(EventTimeline.FORWARDS)\n // );\n\n return timelineSet;\n }\n\n private async getThreadListFilter(filterType = ThreadFilterType.All): Promise {\n const myUserId = this.client.getUserId()!;\n const filter = new Filter(myUserId);\n\n const definition: IFilterDefinition = {\n room: {\n timeline: {\n [FILTER_RELATED_BY_REL_TYPES.name]: [THREAD_RELATION_TYPE.name],\n },\n },\n };\n\n if (filterType === ThreadFilterType.My) {\n definition!.room!.timeline![FILTER_RELATED_BY_SENDERS.name] = [myUserId];\n }\n\n filter.setDefinition(definition);\n const filterId = await this.client.getOrCreateFilter(`THREAD_PANEL_${this.roomId}_${filterType}`, filter);\n\n filter.filterId = filterId;\n\n return filter;\n }\n\n private async createThreadTimelineSet(filterType?: ThreadFilterType): Promise {\n let timelineSet: EventTimelineSet;\n if (Thread.hasServerSideListSupport) {\n timelineSet = new EventTimelineSet(\n this,\n {\n ...this.opts,\n pendingEvents: false,\n },\n undefined,\n undefined,\n filterType ?? ThreadFilterType.All,\n );\n this.reEmitter.reEmit(timelineSet, [RoomEvent.Timeline, RoomEvent.TimelineReset]);\n } else if (Thread.hasServerSideSupport) {\n const filter = await this.getThreadListFilter(filterType);\n\n timelineSet = this.getOrCreateFilteredTimelineSet(filter, {\n prepopulateTimeline: false,\n useSyncEvents: false,\n pendingEvents: false,\n });\n } else {\n timelineSet = new EventTimelineSet(this, {\n pendingEvents: false,\n });\n\n Array.from(this.threads).forEach(([, thread]) => {\n if (thread.length === 0) return;\n const currentUserParticipated = thread.timeline.some((event) => {\n return event.getSender() === this.client.getUserId();\n });\n if (filterType !== ThreadFilterType.My || currentUserParticipated) {\n timelineSet.getLiveTimeline().addEvent(thread.rootEvent!, {\n toStartOfTimeline: false,\n });\n }\n });\n }\n\n return timelineSet;\n }\n\n private threadsReady = false;\n\n /**\n * Takes the given thread root events and creates threads for them.\n */\n public processThreadRoots(events: MatrixEvent[], toStartOfTimeline: boolean): void {\n for (const rootEvent of events) {\n EventTimeline.setEventMetadata(rootEvent, this.currentState, toStartOfTimeline);\n if (!this.getThread(rootEvent.getId()!)) {\n this.createThread(rootEvent.getId()!, rootEvent, [], toStartOfTimeline);\n }\n }\n }\n\n /**\n * Fetch the bare minimum of room threads required for the thread list to work reliably.\n * With server support that means fetching one page.\n * Without server support that means fetching as much at once as the server allows us to.\n */\n public async fetchRoomThreads(): Promise {\n if (this.threadsReady || !this.client.supportsThreads()) {\n return;\n }\n\n if (Thread.hasServerSideListSupport) {\n await Promise.all([\n this.fetchRoomThreadList(ThreadFilterType.All),\n this.fetchRoomThreadList(ThreadFilterType.My),\n ]);\n } else {\n const allThreadsFilter = await this.getThreadListFilter();\n\n const { chunk: events } = await this.client.createMessagesRequest(\n this.roomId,\n \"\",\n Number.MAX_SAFE_INTEGER,\n Direction.Backward,\n allThreadsFilter,\n );\n\n if (!events.length) return;\n\n // Sorted by last_reply origin_server_ts\n const threadRoots = events.map(this.client.getEventMapper()).sort((eventA, eventB) => {\n /**\n * `origin_server_ts` in a decentralised world is far from ideal\n * but for lack of any better, we will have to use this\n * Long term the sorting should be handled by homeservers and this\n * is only meant as a short term patch\n */\n const threadAMetadata = eventA.getServerAggregatedRelation(\n THREAD_RELATION_TYPE.name,\n )!;\n const threadBMetadata = eventB.getServerAggregatedRelation(\n THREAD_RELATION_TYPE.name,\n )!;\n return threadAMetadata.latest_event.origin_server_ts - threadBMetadata.latest_event.origin_server_ts;\n });\n\n let latestMyThreadsRootEvent: MatrixEvent | undefined;\n const roomState = this.getLiveTimeline().getState(EventTimeline.FORWARDS);\n for (const rootEvent of threadRoots) {\n const opts = {\n duplicateStrategy: DuplicateStrategy.Ignore,\n fromCache: false,\n roomState,\n };\n this.threadsTimelineSets[0]?.addLiveEvent(rootEvent, opts);\n\n const threadRelationship = rootEvent.getServerAggregatedRelation(\n THREAD_RELATION_TYPE.name,\n );\n if (threadRelationship?.current_user_participated) {\n this.threadsTimelineSets[1]?.addLiveEvent(rootEvent, opts);\n latestMyThreadsRootEvent = rootEvent;\n }\n }\n\n this.processThreadRoots(threadRoots, true);\n\n this.client.decryptEventIfNeeded(threadRoots[threadRoots.length - 1]);\n if (latestMyThreadsRootEvent) {\n this.client.decryptEventIfNeeded(latestMyThreadsRootEvent);\n }\n }\n\n this.on(ThreadEvent.NewReply, this.onThreadNewReply);\n this.on(ThreadEvent.Delete, this.onThreadDelete);\n this.threadsReady = true;\n }\n\n public async processPollEvents(events: MatrixEvent[]): Promise {\n const processPollStartEvent = (event: MatrixEvent): void => {\n if (!M_POLL_START.matches(event.getType())) return;\n try {\n const poll = new Poll(event, this.client, this);\n this.polls.set(event.getId()!, poll);\n this.emit(PollEvent.New, poll);\n } catch {}\n // poll creation can fail for malformed poll start events\n };\n\n const processPollRelationEvent = (event: MatrixEvent): void => {\n const relationEventId = event.relationEventId;\n if (relationEventId && this.polls.has(relationEventId)) {\n const poll = this.polls.get(relationEventId);\n poll?.onNewRelation(event);\n }\n };\n\n const processPollEvent = (event: MatrixEvent): void => {\n processPollStartEvent(event);\n processPollRelationEvent(event);\n };\n\n for (const event of events) {\n try {\n await this.client.decryptEventIfNeeded(event);\n processPollEvent(event);\n } catch {}\n }\n }\n\n /**\n * Fetch a single page of threadlist messages for the specific thread filter\n * @internal\n */\n private async fetchRoomThreadList(filter?: ThreadFilterType): Promise {\n const timelineSet = filter === ThreadFilterType.My ? this.threadsTimelineSets[1] : this.threadsTimelineSets[0];\n\n const { chunk: events, end } = await this.client.createThreadListMessagesRequest(\n this.roomId,\n null,\n undefined,\n Direction.Backward,\n timelineSet.threadListType,\n timelineSet.getFilter(),\n );\n\n timelineSet.getLiveTimeline().setPaginationToken(end ?? null, Direction.Backward);\n\n if (!events.length) return;\n\n const matrixEvents = events.map(this.client.getEventMapper());\n this.processThreadRoots(matrixEvents, true);\n const roomState = this.getLiveTimeline().getState(EventTimeline.FORWARDS);\n for (const rootEvent of matrixEvents) {\n timelineSet.addLiveEvent(rootEvent, {\n duplicateStrategy: DuplicateStrategy.Replace,\n fromCache: false,\n roomState,\n });\n }\n }\n\n private onThreadNewReply(thread: Thread): void {\n this.updateThreadRootEvents(thread, false, true);\n }\n\n private onThreadDelete(thread: Thread): void {\n this.threads.delete(thread.id);\n\n const timeline = this.getTimelineForEvent(thread.id);\n const roomEvent = timeline?.getEvents()?.find((it) => it.getId() === thread.id);\n if (roomEvent) {\n thread.clearEventMetadata(roomEvent);\n } else {\n logger.debug(\"onThreadDelete: Could not find root event in room timeline\");\n }\n for (const timelineSet of this.threadsTimelineSets) {\n timelineSet.removeEvent(thread.id);\n }\n }\n\n /**\n * Forget the timelineSet for this room with the given filter\n *\n * @param filter - the filter whose timelineSet is to be forgotten\n */\n public removeFilteredTimelineSet(filter: Filter): void {\n const timelineSet = this.filteredTimelineSets[filter.filterId!];\n delete this.filteredTimelineSets[filter.filterId!];\n const i = this.timelineSets.indexOf(timelineSet);\n if (i > -1) {\n this.timelineSets.splice(i, 1);\n }\n }\n\n public eventShouldLiveIn(\n event: MatrixEvent,\n events?: MatrixEvent[],\n roots?: Set,\n ): {\n shouldLiveInRoom: boolean;\n shouldLiveInThread: boolean;\n threadId?: string;\n } {\n if (!this.client?.supportsThreads()) {\n return {\n shouldLiveInRoom: true,\n shouldLiveInThread: false,\n };\n }\n\n // A thread root is always shown in both timelines\n if (event.isThreadRoot || roots?.has(event.getId()!)) {\n return {\n shouldLiveInRoom: true,\n shouldLiveInThread: true,\n threadId: event.getId(),\n };\n }\n\n // A thread relation is always only shown in a thread\n if (event.isRelation(THREAD_RELATION_TYPE.name)) {\n return {\n shouldLiveInRoom: false,\n shouldLiveInThread: true,\n threadId: event.threadRootId,\n };\n }\n\n const parentEventId = event.getAssociatedId();\n let parentEvent: MatrixEvent | undefined;\n if (parentEventId) {\n parentEvent = this.findEventById(parentEventId) ?? events?.find((e) => e.getId() === parentEventId);\n }\n\n // Treat relations and redactions as extensions of their parents so evaluate parentEvent instead\n if (parentEvent && (event.isRelation() || event.isRedaction())) {\n return this.eventShouldLiveIn(parentEvent, events, roots);\n }\n\n // Edge case where we know the event is a relation but don't have the parentEvent\n if (roots?.has(event.relationEventId!)) {\n return {\n shouldLiveInRoom: true,\n shouldLiveInThread: true,\n threadId: event.relationEventId,\n };\n }\n\n // We've exhausted all scenarios, can safely assume that this event should live in the room timeline only\n return {\n shouldLiveInRoom: true,\n shouldLiveInThread: false,\n };\n }\n\n public findThreadForEvent(event?: MatrixEvent): Thread | null {\n if (!event) return null;\n\n const { threadId } = this.eventShouldLiveIn(event);\n return threadId ? this.getThread(threadId) : null;\n }\n\n private addThreadedEvents(threadId: string, events: MatrixEvent[], toStartOfTimeline = false): void {\n let thread = this.getThread(threadId);\n\n if (!thread) {\n const rootEvent = this.findEventById(threadId) ?? events.find((e) => e.getId() === threadId);\n thread = this.createThread(threadId, rootEvent, events, toStartOfTimeline);\n }\n\n thread.addEvents(events, toStartOfTimeline);\n }\n\n /**\n * Adds events to a thread's timeline. Will fire \"Thread.update\"\n */\n public processThreadedEvents(events: MatrixEvent[], toStartOfTimeline: boolean): void {\n events.forEach(this.applyRedaction);\n\n const eventsByThread: { [threadId: string]: MatrixEvent[] } = {};\n for (const event of events) {\n const { threadId, shouldLiveInThread } = this.eventShouldLiveIn(event);\n if (shouldLiveInThread && !eventsByThread[threadId!]) {\n eventsByThread[threadId!] = [];\n }\n eventsByThread[threadId!]?.push(event);\n }\n\n Object.entries(eventsByThread).map(([threadId, threadEvents]) =>\n this.addThreadedEvents(threadId, threadEvents, toStartOfTimeline),\n );\n }\n\n private updateThreadRootEvents = (thread: Thread, toStartOfTimeline: boolean, recreateEvent: boolean): void => {\n if (thread.length) {\n this.updateThreadRootEvent(this.threadsTimelineSets?.[0], thread, toStartOfTimeline, recreateEvent);\n if (thread.hasCurrentUserParticipated) {\n this.updateThreadRootEvent(this.threadsTimelineSets?.[1], thread, toStartOfTimeline, recreateEvent);\n }\n }\n };\n\n private updateThreadRootEvent = (\n timelineSet: Optional,\n thread: Thread,\n toStartOfTimeline: boolean,\n recreateEvent: boolean,\n ): void => {\n if (timelineSet && thread.rootEvent) {\n if (recreateEvent) {\n timelineSet.removeEvent(thread.id);\n }\n if (Thread.hasServerSideSupport) {\n timelineSet.addLiveEvent(thread.rootEvent, {\n duplicateStrategy: DuplicateStrategy.Replace,\n fromCache: false,\n roomState: this.currentState,\n });\n } else {\n timelineSet.addEventToTimeline(thread.rootEvent, timelineSet.getLiveTimeline(), { toStartOfTimeline });\n }\n }\n };\n\n public createThread(\n threadId: string,\n rootEvent: MatrixEvent | undefined,\n events: MatrixEvent[] = [],\n toStartOfTimeline: boolean,\n ): Thread {\n if (this.threads.has(threadId)) {\n return this.threads.get(threadId)!;\n }\n\n if (rootEvent) {\n const relatedEvents = this.relations.getAllChildEventsForEvent(rootEvent.getId()!);\n if (relatedEvents?.length) {\n // Include all relations of the root event, given it'll be visible in both timelines,\n // except `m.replace` as that will already be applied atop the event using `MatrixEvent::makeReplaced`\n events = events.concat(relatedEvents.filter((e) => !e.isRelation(RelationType.Replace)));\n }\n }\n\n const thread = new Thread(threadId, rootEvent, {\n room: this,\n client: this.client,\n pendingEventOrdering: this.opts.pendingEventOrdering,\n receipts: this.cachedThreadReadReceipts.get(threadId) ?? [],\n });\n\n // All read receipts should now come down from sync, we do not need to keep\n // a reference to the cached receipts anymore.\n this.cachedThreadReadReceipts.delete(threadId);\n\n // If we managed to create a thread and figure out its `id` then we can use it\n // This has to happen before thread.addEvents, because that adds events to the eventtimeline, and the\n // eventtimeline sometimes looks up thread information via the room.\n this.threads.set(thread.id, thread);\n\n // This is necessary to be able to jump to events in threads:\n // If we jump to an event in a thread where neither the event, nor the root,\n // nor any thread event are loaded yet, we'll load the event as well as the thread root, create the thread,\n // and pass the event through this.\n thread.addEvents(events, false);\n\n this.reEmitter.reEmit(thread, [\n ThreadEvent.Delete,\n ThreadEvent.Update,\n ThreadEvent.NewReply,\n RoomEvent.Timeline,\n RoomEvent.TimelineReset,\n ]);\n const isNewer =\n this.lastThread?.rootEvent &&\n rootEvent?.localTimestamp &&\n this.lastThread.rootEvent?.localTimestamp < rootEvent?.localTimestamp;\n\n if (!this.lastThread || isNewer) {\n this.lastThread = thread;\n }\n\n if (this.threadsReady) {\n this.updateThreadRootEvents(thread, toStartOfTimeline, false);\n }\n this.emit(ThreadEvent.New, thread, toStartOfTimeline);\n\n return thread;\n }\n\n private applyRedaction = (event: MatrixEvent): void => {\n if (event.isRedaction()) {\n const redactId = event.event.redacts;\n\n // if we know about this event, redact its contents now.\n const redactedEvent = redactId ? this.findEventById(redactId) : undefined;\n if (redactedEvent) {\n redactedEvent.makeRedacted(event);\n\n // If this is in the current state, replace it with the redacted version\n if (redactedEvent.isState()) {\n const currentStateEvent = this.currentState.getStateEvents(\n redactedEvent.getType(),\n redactedEvent.getStateKey()!,\n );\n if (currentStateEvent?.getId() === redactedEvent.getId()) {\n this.currentState.setStateEvents([redactedEvent]);\n }\n }\n\n this.emit(RoomEvent.Redaction, event, this);\n\n // TODO: we stash user displaynames (among other things) in\n // RoomMember objects which are then attached to other events\n // (in the sender and target fields). We should get those\n // RoomMember objects to update themselves when the events that\n // they are based on are changed.\n\n // Remove any visibility change on this event.\n this.visibilityEvents.delete(redactId!);\n\n // If this event is a visibility change event, remove it from the\n // list of visibility changes and update any event affected by it.\n if (redactedEvent.isVisibilityEvent()) {\n this.redactVisibilityChangeEvent(event);\n }\n }\n\n // FIXME: apply redactions to notification list\n\n // NB: We continue to add the redaction event to the timeline so\n // clients can say \"so and so redacted an event\" if they wish to. Also\n // this may be needed to trigger an update.\n }\n };\n\n private processLiveEvent(event: MatrixEvent): void {\n this.applyRedaction(event);\n\n // Implement MSC3531: hiding messages.\n if (event.isVisibilityEvent()) {\n // This event changes the visibility of another event, record\n // the visibility change, inform clients if necessary.\n this.applyNewVisibilityEvent(event);\n }\n // If any pending visibility change is waiting for this (older) event,\n this.applyPendingVisibilityEvents(event);\n\n // Sliding Sync modifications:\n // The proxy cannot guarantee every sent event will have a transaction_id field, so we need\n // to check the event ID against the list of pending events if there is no transaction ID\n // field. Only do this for events sent by us though as it's potentially expensive to loop\n // the pending events map.\n const txnId = event.getUnsigned().transaction_id;\n if (!txnId && event.getSender() === this.myUserId) {\n // check the txn map for a matching event ID\n for (const [tid, localEvent] of this.txnToEvent) {\n if (localEvent.getId() === event.getId()) {\n logger.debug(\"processLiveEvent: found sent event without txn ID: \", tid, event.getId());\n // update the unsigned field so we can re-use the same codepaths\n const unsigned = event.getUnsigned();\n unsigned.transaction_id = tid;\n event.setUnsigned(unsigned);\n break;\n }\n }\n }\n }\n\n /**\n * Add an event to the end of this room's live timelines. Will fire\n * \"Room.timeline\".\n *\n * @param event - Event to be added\n * @param addLiveEventOptions - addLiveEvent options\n * @internal\n *\n * @remarks\n * Fires {@link RoomEvent.Timeline}\n */\n private addLiveEvent(event: MatrixEvent, addLiveEventOptions: IAddLiveEventOptions): void {\n const { duplicateStrategy, timelineWasEmpty, fromCache } = addLiveEventOptions;\n\n // add to our timeline sets\n for (const timelineSet of this.timelineSets) {\n timelineSet.addLiveEvent(event, {\n duplicateStrategy,\n fromCache,\n timelineWasEmpty,\n });\n }\n\n // synthesize and inject implicit read receipts\n // Done after adding the event because otherwise the app would get a read receipt\n // pointing to an event that wasn't yet in the timeline\n // Don't synthesize RR for m.room.redaction as this causes the RR to go missing.\n if (event.sender && event.getType() !== EventType.RoomRedaction) {\n this.addReceipt(synthesizeReceipt(event.sender.userId, event, ReceiptType.Read), true);\n\n // Any live events from a user could be taken as implicit\n // presence information: evidence that they are currently active.\n // ...except in a world where we use 'user.currentlyActive' to reduce\n // presence spam, this isn't very useful - we'll get a transition when\n // they are no longer currently active anyway. So don't bother to\n // reset the lastActiveAgo and lastPresenceTs from the RoomState's user.\n }\n }\n\n /**\n * Add a pending outgoing event to this room.\n *\n *

The event is added to either the pendingEventList, or the live timeline,\n * depending on the setting of opts.pendingEventOrdering.\n *\n *

This is an internal method, intended for use by MatrixClient.\n *\n * @param event - The event to add.\n *\n * @param txnId - Transaction id for this outgoing event\n *\n * @throws if the event doesn't have status SENDING, or we aren't given a\n * unique transaction id.\n *\n * @remarks\n * Fires {@link RoomEvent.LocalEchoUpdated}\n */\n public addPendingEvent(event: MatrixEvent, txnId: string): void {\n if (event.status !== EventStatus.SENDING && event.status !== EventStatus.NOT_SENT) {\n throw new Error(\"addPendingEvent called on an event with status \" + event.status);\n }\n\n if (this.txnToEvent.get(txnId)) {\n throw new Error(\"addPendingEvent called on an event with known txnId \" + txnId);\n }\n\n // call setEventMetadata to set up event.sender etc\n // as event is shared over all timelineSets, we set up its metadata based\n // on the unfiltered timelineSet.\n EventTimeline.setEventMetadata(event, this.getLiveTimeline().getState(EventTimeline.FORWARDS)!, false);\n\n this.txnToEvent.set(txnId, event);\n if (this.pendingEventList) {\n if (this.pendingEventList.some((e) => e.status === EventStatus.NOT_SENT)) {\n logger.warn(\"Setting event as NOT_SENT due to messages in the same state\");\n event.setStatus(EventStatus.NOT_SENT);\n }\n this.pendingEventList.push(event);\n this.savePendingEvents();\n if (event.isRelation()) {\n // For pending events, add them to the relations collection immediately.\n // (The alternate case below already covers this as part of adding to\n // the timeline set.)\n this.aggregateNonLiveRelation(event);\n }\n\n if (event.isRedaction()) {\n const redactId = event.event.redacts;\n let redactedEvent = this.pendingEventList.find((e) => e.getId() === redactId);\n if (!redactedEvent && redactId) {\n redactedEvent = this.findEventById(redactId);\n }\n if (redactedEvent) {\n redactedEvent.markLocallyRedacted(event);\n this.emit(RoomEvent.Redaction, event, this);\n }\n }\n } else {\n for (const timelineSet of this.timelineSets) {\n if (timelineSet.getFilter()) {\n if (timelineSet.getFilter()!.filterRoomTimeline([event]).length) {\n timelineSet.addEventToTimeline(event, timelineSet.getLiveTimeline(), {\n toStartOfTimeline: false,\n });\n }\n } else {\n timelineSet.addEventToTimeline(event, timelineSet.getLiveTimeline(), {\n toStartOfTimeline: false,\n });\n }\n }\n }\n\n this.emit(RoomEvent.LocalEchoUpdated, event, this);\n }\n\n /**\n * Persists all pending events to local storage\n *\n * If the current room is encrypted only encrypted events will be persisted\n * all messages that are not yet encrypted will be discarded\n *\n * This is because the flow of EVENT_STATUS transition is\n * `queued => sending => encrypting => sending => sent`\n *\n * Steps 3 and 4 are skipped for unencrypted room.\n * It is better to discard an unencrypted message rather than persisting\n * it locally for everyone to read\n */\n private savePendingEvents(): void {\n if (this.pendingEventList) {\n const pendingEvents = this.pendingEventList\n .map((event) => {\n return {\n ...event.event,\n txn_id: event.getTxnId(),\n };\n })\n .filter((event) => {\n // Filter out the unencrypted messages if the room is encrypted\n const isEventEncrypted = event.type === EventType.RoomMessageEncrypted;\n const isRoomEncrypted = this.client.isRoomEncrypted(this.roomId);\n return isEventEncrypted || !isRoomEncrypted;\n });\n\n this.client.store.setPendingEvents(this.roomId, pendingEvents);\n }\n }\n\n /**\n * Used to aggregate the local echo for a relation, and also\n * for re-applying a relation after it's redaction has been cancelled,\n * as the local echo for the redaction of the relation would have\n * un-aggregated the relation. Note that this is different from regular messages,\n * which are just kept detached for their local echo.\n *\n * Also note that live events are aggregated in the live EventTimelineSet.\n * @param event - the relation event that needs to be aggregated.\n */\n private aggregateNonLiveRelation(event: MatrixEvent): void {\n this.relations.aggregateChildEvent(event);\n }\n\n public getEventForTxnId(txnId: string): MatrixEvent | undefined {\n return this.txnToEvent.get(txnId);\n }\n\n /**\n * Deal with the echo of a message we sent.\n *\n *

We move the event to the live timeline if it isn't there already, and\n * update it.\n *\n * @param remoteEvent - The event received from\n * /sync\n * @param localEvent - The local echo, which\n * should be either in the pendingEventList or the timeline.\n *\n * @internal\n *\n * @remarks\n * Fires {@link RoomEvent.LocalEchoUpdated}\n */\n public handleRemoteEcho(remoteEvent: MatrixEvent, localEvent: MatrixEvent): void {\n const oldEventId = localEvent.getId()!;\n const newEventId = remoteEvent.getId()!;\n const oldStatus = localEvent.status;\n\n logger.debug(`Got remote echo for event ${oldEventId} -> ${newEventId} old status ${oldStatus}`);\n\n // no longer pending\n this.txnToEvent.delete(remoteEvent.getUnsigned().transaction_id!);\n\n // if it's in the pending list, remove it\n if (this.pendingEventList) {\n this.removePendingEvent(oldEventId);\n }\n\n // replace the event source (this will preserve the plaintext payload if\n // any, which is good, because we don't want to try decoding it again).\n localEvent.handleRemoteEcho(remoteEvent.event);\n\n const { shouldLiveInRoom, threadId } = this.eventShouldLiveIn(remoteEvent);\n const thread = threadId ? this.getThread(threadId) : null;\n thread?.setEventMetadata(localEvent);\n thread?.timelineSet.handleRemoteEcho(localEvent, oldEventId, newEventId);\n\n if (shouldLiveInRoom) {\n for (const timelineSet of this.timelineSets) {\n // if it's already in the timeline, update the timeline map. If it's not, add it.\n timelineSet.handleRemoteEcho(localEvent, oldEventId, newEventId);\n }\n }\n\n this.emit(RoomEvent.LocalEchoUpdated, localEvent, this, oldEventId, oldStatus);\n }\n\n /**\n * Update the status / event id on a pending event, to reflect its transmission\n * progress.\n *\n *

This is an internal method.\n *\n * @param event - local echo event\n * @param newStatus - status to assign\n * @param newEventId - new event id to assign. Ignored unless newStatus == EventStatus.SENT.\n *\n * @remarks\n * Fires {@link RoomEvent.LocalEchoUpdated}\n */\n public updatePendingEvent(event: MatrixEvent, newStatus: EventStatus, newEventId?: string): void {\n logger.log(\n `setting pendingEvent status to ${newStatus} in ${event.getRoomId()} ` +\n `event ID ${event.getId()} -> ${newEventId}`,\n );\n\n // if the message was sent, we expect an event id\n if (newStatus == EventStatus.SENT && !newEventId) {\n throw new Error(\"updatePendingEvent called with status=SENT, but no new event id\");\n }\n\n // SENT races against /sync, so we have to special-case it.\n if (newStatus == EventStatus.SENT) {\n const timeline = this.getTimelineForEvent(newEventId!);\n if (timeline) {\n // we've already received the event via the event stream.\n // nothing more to do here, assuming the transaction ID was correctly matched.\n // Let's check that.\n const remoteEvent = this.findEventById(newEventId!);\n const remoteTxnId = remoteEvent?.getUnsigned().transaction_id;\n if (!remoteTxnId && remoteEvent) {\n // This code path is mostly relevant for the Sliding Sync proxy.\n // The remote event did not contain a transaction ID, so we did not handle\n // the remote echo yet. Handle it now.\n const unsigned = remoteEvent.getUnsigned();\n unsigned.transaction_id = event.getTxnId();\n remoteEvent.setUnsigned(unsigned);\n // the remote event is _already_ in the timeline, so we need to remove it so\n // we can convert the local event into the final event.\n this.removeEvent(remoteEvent.getId()!);\n this.handleRemoteEcho(remoteEvent, event);\n }\n return;\n }\n }\n\n const oldStatus = event.status;\n const oldEventId = event.getId()!;\n\n if (!oldStatus) {\n throw new Error(\"updatePendingEventStatus called on an event which is not a local echo.\");\n }\n\n const allowed = ALLOWED_TRANSITIONS[oldStatus];\n if (!allowed?.includes(newStatus)) {\n throw new Error(`Invalid EventStatus transition ${oldStatus}->${newStatus}`);\n }\n\n event.setStatus(newStatus);\n\n if (newStatus == EventStatus.SENT) {\n // update the event id\n event.replaceLocalEventId(newEventId!);\n\n const { shouldLiveInRoom, threadId } = this.eventShouldLiveIn(event);\n const thread = threadId ? this.getThread(threadId) : undefined;\n thread?.setEventMetadata(event);\n thread?.timelineSet.replaceEventId(oldEventId, newEventId!);\n\n if (shouldLiveInRoom) {\n // if the event was already in the timeline (which will be the case if\n // opts.pendingEventOrdering==chronological), we need to update the\n // timeline map.\n for (const timelineSet of this.timelineSets) {\n timelineSet.replaceEventId(oldEventId, newEventId!);\n }\n }\n } else if (newStatus == EventStatus.CANCELLED) {\n // remove it from the pending event list, or the timeline.\n if (this.pendingEventList) {\n const removedEvent = this.getPendingEvent(oldEventId);\n this.removePendingEvent(oldEventId);\n if (removedEvent?.isRedaction()) {\n this.revertRedactionLocalEcho(removedEvent);\n }\n }\n this.removeEvent(oldEventId);\n }\n this.savePendingEvents();\n\n this.emit(RoomEvent.LocalEchoUpdated, event, this, oldEventId, oldStatus);\n }\n\n private revertRedactionLocalEcho(redactionEvent: MatrixEvent): void {\n const redactId = redactionEvent.event.redacts;\n if (!redactId) {\n return;\n }\n const redactedEvent = this.getUnfilteredTimelineSet().findEventById(redactId);\n if (redactedEvent) {\n redactedEvent.unmarkLocallyRedacted();\n // re-render after undoing redaction\n this.emit(RoomEvent.RedactionCancelled, redactionEvent, this);\n // reapply relation now redaction failed\n if (redactedEvent.isRelation()) {\n this.aggregateNonLiveRelation(redactedEvent);\n }\n }\n }\n\n /**\n * Add some events to this room. This can include state events, message\n * events and typing notifications. These events are treated as \"live\" so\n * they will go to the end of the timeline.\n *\n * @param events - A list of events to add.\n * @param addLiveEventOptions - addLiveEvent options\n * @throws If `duplicateStrategy` is not falsey, 'replace' or 'ignore'.\n */\n public addLiveEvents(events: MatrixEvent[], addLiveEventOptions?: IAddLiveEventOptions): void;\n /**\n * @deprecated In favor of the overload with `IAddLiveEventOptions`\n */\n public addLiveEvents(events: MatrixEvent[], duplicateStrategy?: DuplicateStrategy, fromCache?: boolean): void;\n public addLiveEvents(\n events: MatrixEvent[],\n duplicateStrategyOrOpts?: DuplicateStrategy | IAddLiveEventOptions,\n fromCache = false,\n ): void {\n let duplicateStrategy: DuplicateStrategy | undefined = duplicateStrategyOrOpts as DuplicateStrategy;\n let timelineWasEmpty: boolean | undefined = false;\n if (typeof duplicateStrategyOrOpts === \"object\") {\n ({\n duplicateStrategy,\n fromCache = false,\n /* roomState, (not used here) */\n timelineWasEmpty,\n } = duplicateStrategyOrOpts);\n } else if (duplicateStrategyOrOpts !== undefined) {\n // Deprecation warning\n // FIXME: Remove after 2023-06-01 (technical debt)\n logger.warn(\n \"Overload deprecated: \" +\n \"`Room.addLiveEvents(events, duplicateStrategy?, fromCache?)` \" +\n \"is deprecated in favor of the overload with `Room.addLiveEvents(events, IAddLiveEventOptions)`\",\n );\n }\n\n if (duplicateStrategy && [\"replace\", \"ignore\"].indexOf(duplicateStrategy) === -1) {\n throw new Error(\"duplicateStrategy MUST be either 'replace' or 'ignore'\");\n }\n\n // sanity check that the live timeline is still live\n for (let i = 0; i < this.timelineSets.length; i++) {\n const liveTimeline = this.timelineSets[i].getLiveTimeline();\n if (liveTimeline.getPaginationToken(EventTimeline.FORWARDS)) {\n throw new Error(\n \"live timeline \" +\n i +\n \" is no longer live - it has a pagination token \" +\n \"(\" +\n liveTimeline.getPaginationToken(EventTimeline.FORWARDS) +\n \")\",\n );\n }\n if (liveTimeline.getNeighbouringTimeline(EventTimeline.FORWARDS)) {\n throw new Error(`live timeline ${i} is no longer live - it has a neighbouring timeline`);\n }\n }\n\n const threadRoots = this.findThreadRoots(events);\n const eventsByThread: { [threadId: string]: MatrixEvent[] } = {};\n\n const options: IAddLiveEventOptions = {\n duplicateStrategy,\n fromCache,\n timelineWasEmpty,\n };\n\n for (const event of events) {\n // TODO: We should have a filter to say \"only add state event types X Y Z to the timeline\".\n this.processLiveEvent(event);\n\n if (event.getUnsigned().transaction_id) {\n const existingEvent = this.txnToEvent.get(event.getUnsigned().transaction_id!);\n if (existingEvent) {\n // remote echo of an event we sent earlier\n this.handleRemoteEcho(event, existingEvent);\n continue; // we can skip adding the event to the timeline sets, it is already there\n }\n }\n\n const { shouldLiveInRoom, shouldLiveInThread, threadId } = this.eventShouldLiveIn(\n event,\n events,\n threadRoots,\n );\n\n if (shouldLiveInThread && !eventsByThread[threadId ?? \"\"]) {\n eventsByThread[threadId ?? \"\"] = [];\n }\n eventsByThread[threadId ?? \"\"]?.push(event);\n\n if (shouldLiveInRoom) {\n this.addLiveEvent(event, options);\n }\n }\n\n Object.entries(eventsByThread).forEach(([threadId, threadEvents]) => {\n this.addThreadedEvents(threadId, threadEvents, false);\n });\n }\n\n public partitionThreadedEvents(\n events: MatrixEvent[],\n ): [timelineEvents: MatrixEvent[], threadedEvents: MatrixEvent[]] {\n // Indices to the events array, for readability\n const ROOM = 0;\n const THREAD = 1;\n if (this.client.supportsThreads()) {\n const threadRoots = this.findThreadRoots(events);\n return events.reduce(\n (memo, event: MatrixEvent) => {\n const { shouldLiveInRoom, shouldLiveInThread, threadId } = this.eventShouldLiveIn(\n event,\n events,\n threadRoots,\n );\n\n if (shouldLiveInRoom) {\n memo[ROOM].push(event);\n }\n\n if (shouldLiveInThread) {\n event.setThreadId(threadId ?? \"\");\n memo[THREAD].push(event);\n }\n\n return memo;\n },\n [[] as MatrixEvent[], [] as MatrixEvent[]],\n );\n } else {\n // When `experimentalThreadSupport` is disabled treat all events as timelineEvents\n return [events as MatrixEvent[], [] as MatrixEvent[]];\n }\n }\n\n /**\n * Given some events, find the IDs of all the thread roots that are referred to by them.\n */\n private findThreadRoots(events: MatrixEvent[]): Set {\n const threadRoots = new Set();\n for (const event of events) {\n if (event.isRelation(THREAD_RELATION_TYPE.name)) {\n threadRoots.add(event.relationEventId ?? \"\");\n }\n }\n return threadRoots;\n }\n\n /**\n * Add a receipt event to the room.\n * @param event - The m.receipt event.\n * @param synthetic - True if this event is implicit.\n */\n public addReceipt(event: MatrixEvent, synthetic = false): void {\n const content = event.getContent();\n Object.keys(content).forEach((eventId: string) => {\n Object.keys(content[eventId]).forEach((receiptType: ReceiptType | string) => {\n Object.keys(content[eventId][receiptType]).forEach((userId: string) => {\n const receipt = content[eventId][receiptType][userId] as Receipt;\n const receiptForMainTimeline = !receipt.thread_id || receipt.thread_id === MAIN_ROOM_TIMELINE;\n const receiptDestination: Thread | this | undefined = receiptForMainTimeline\n ? this\n : this.threads.get(receipt.thread_id ?? \"\");\n\n if (receiptDestination) {\n receiptDestination.addReceiptToStructure(\n eventId,\n receiptType as ReceiptType,\n userId,\n receipt,\n synthetic,\n );\n\n // If the read receipt sent for the logged in user matches\n // the last event of the live timeline, then we know for a fact\n // that the user has read that message.\n // We can mark the room as read and not wait for the local echo\n // from synapse\n // This needs to be done after the initial sync as we do not want this\n // logic to run whilst the room is being initialised\n if (this.client.isInitialSyncComplete() && userId === this.client.getUserId()) {\n const lastEvent = receiptDestination.timeline[receiptDestination.timeline.length - 1];\n if (lastEvent && eventId === lastEvent.getId() && userId === lastEvent.getSender()) {\n receiptDestination.setUnread(NotificationCountType.Total, 0);\n receiptDestination.setUnread(NotificationCountType.Highlight, 0);\n }\n }\n } else {\n // The thread does not exist locally, keep the read receipt\n // in a cache locally, and re-apply the `addReceipt` logic\n // when the thread is created\n this.cachedThreadReadReceipts.set(receipt.thread_id!, [\n ...(this.cachedThreadReadReceipts.get(receipt.thread_id!) ?? []),\n { eventId, receiptType, userId, receipt, synthetic },\n ]);\n }\n\n const me = this.client.getUserId();\n // Track the time of the current user's oldest threaded receipt in the room.\n if (userId === me && !receiptForMainTimeline && receipt.ts < this.oldestThreadedReceiptTs) {\n this.oldestThreadedReceiptTs = receipt.ts;\n }\n\n // Track each user's unthreaded read receipt.\n if (!receipt.thread_id && receipt.ts > (this.unthreadedReceipts.get(userId)?.ts ?? 0)) {\n this.unthreadedReceipts.set(userId, receipt);\n }\n });\n });\n });\n\n // send events after we've regenerated the structure & cache, otherwise things that\n // listened for the event would read stale data.\n this.emit(RoomEvent.Receipt, event, this);\n }\n\n /**\n * Adds/handles ephemeral events such as typing notifications and read receipts.\n * @param events - A list of events to process\n */\n public addEphemeralEvents(events: MatrixEvent[]): void {\n for (const event of events) {\n if (event.getType() === EventType.Typing) {\n this.currentState.setTypingEvent(event);\n } else if (event.getType() === EventType.Receipt) {\n this.addReceipt(event);\n } // else ignore - life is too short for us to care about these events\n }\n }\n\n /**\n * Removes events from this room.\n * @param eventIds - A list of eventIds to remove.\n */\n public removeEvents(eventIds: string[]): void {\n for (const eventId of eventIds) {\n this.removeEvent(eventId);\n }\n }\n\n /**\n * Removes a single event from this room.\n *\n * @param eventId - The id of the event to remove\n *\n * @returns true if the event was removed from any of the room's timeline sets\n */\n public removeEvent(eventId: string): boolean {\n let removedAny = false;\n for (const timelineSet of this.timelineSets) {\n const removed = timelineSet.removeEvent(eventId);\n if (removed) {\n if (removed.isRedaction()) {\n this.revertRedactionLocalEcho(removed);\n }\n removedAny = true;\n }\n }\n return removedAny;\n }\n\n /**\n * Recalculate various aspects of the room, including the room name and\n * room summary. Call this any time the room's current state is modified.\n * May fire \"Room.name\" if the room name is updated.\n *\n * @remarks\n * Fires {@link RoomEvent.Name}\n */\n public recalculate(): void {\n // set fake stripped state events if this is an invite room so logic remains\n // consistent elsewhere.\n const membershipEvent = this.currentState.getStateEvents(EventType.RoomMember, this.myUserId);\n if (membershipEvent) {\n const membership = membershipEvent.getContent().membership;\n this.updateMyMembership(membership!);\n\n if (membership === \"invite\") {\n const strippedStateEvents = membershipEvent.getUnsigned().invite_room_state || [];\n strippedStateEvents.forEach((strippedEvent) => {\n const existingEvent = this.currentState.getStateEvents(strippedEvent.type, strippedEvent.state_key);\n if (!existingEvent) {\n // set the fake stripped event instead\n this.currentState.setStateEvents([\n new MatrixEvent({\n type: strippedEvent.type,\n state_key: strippedEvent.state_key,\n content: strippedEvent.content,\n event_id: \"$fake\" + Date.now(),\n room_id: this.roomId,\n user_id: this.myUserId, // technically a lie\n }),\n ]);\n }\n });\n }\n }\n\n const oldName = this.name;\n this.name = this.calculateRoomName(this.myUserId);\n this.normalizedName = normalize(this.name);\n this.summary = new RoomSummary(this.roomId, {\n title: this.name,\n });\n\n if (oldName !== this.name) {\n this.emit(RoomEvent.Name, this);\n }\n }\n\n /**\n * Update the room-tag event for the room. The previous one is overwritten.\n * @param event - the m.tag event\n */\n public addTags(event: MatrixEvent): void {\n // event content looks like:\n // content: {\n // tags: {\n // $tagName: { $metadata: $value },\n // $tagName: { $metadata: $value },\n // }\n // }\n\n // XXX: do we need to deep copy here?\n this.tags = event.getContent().tags || {};\n\n // XXX: we could do a deep-comparison to see if the tags have really\n // changed - but do we want to bother?\n this.emit(RoomEvent.Tags, event, this);\n }\n\n /**\n * Update the account_data events for this room, overwriting events of the same type.\n * @param events - an array of account_data events to add\n */\n public addAccountData(events: MatrixEvent[]): void {\n for (const event of events) {\n if (event.getType() === \"m.tag\") {\n this.addTags(event);\n }\n const eventType = event.getType();\n const lastEvent = this.accountData.get(eventType);\n this.accountData.set(eventType, event);\n this.emit(RoomEvent.AccountData, event, this, lastEvent);\n }\n }\n\n /**\n * Access account_data event of given event type for this room\n * @param type - the type of account_data event to be accessed\n * @returns the account_data event in question\n */\n public getAccountData(type: EventType | string): MatrixEvent | undefined {\n return this.accountData.get(type);\n }\n\n /**\n * Returns whether the syncing user has permission to send a message in the room\n * @returns true if the user should be permitted to send\n * message events into the room.\n */\n public maySendMessage(): boolean {\n return (\n this.getMyMembership() === \"join\" &&\n (this.client.isRoomEncrypted(this.roomId)\n ? this.currentState.maySendEvent(EventType.RoomMessageEncrypted, this.myUserId)\n : this.currentState.maySendEvent(EventType.RoomMessage, this.myUserId))\n );\n }\n\n /**\n * Returns whether the given user has permissions to issue an invite for this room.\n * @param userId - the ID of the Matrix user to check permissions for\n * @returns true if the user should be permitted to issue invites for this room.\n */\n public canInvite(userId: string): boolean {\n let canInvite = this.getMyMembership() === \"join\";\n const powerLevelsEvent = this.currentState.getStateEvents(EventType.RoomPowerLevels, \"\");\n const powerLevels = powerLevelsEvent && powerLevelsEvent.getContent();\n const me = this.getMember(userId);\n if (powerLevels && me && powerLevels.invite > me.powerLevel) {\n canInvite = false;\n }\n return canInvite;\n }\n\n /**\n * Returns the join rule based on the m.room.join_rule state event, defaulting to `invite`.\n * @returns the join_rule applied to this room\n */\n public getJoinRule(): JoinRule {\n return this.currentState.getJoinRule();\n }\n\n /**\n * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`.\n * @returns the history_visibility applied to this room\n */\n public getHistoryVisibility(): HistoryVisibility {\n return this.currentState.getHistoryVisibility();\n }\n\n /**\n * Returns the history visibility based on the m.room.history_visibility state event, defaulting to `shared`.\n * @returns the history_visibility applied to this room\n */\n public getGuestAccess(): GuestAccess {\n return this.currentState.getGuestAccess();\n }\n\n /**\n * Returns the type of the room from the `m.room.create` event content or undefined if none is set\n * @returns the type of the room.\n */\n public getType(): RoomType | string | undefined {\n const createEvent = this.currentState.getStateEvents(EventType.RoomCreate, \"\");\n if (!createEvent) {\n if (!this.getTypeWarning) {\n logger.warn(\"[getType] Room \" + this.roomId + \" does not have an m.room.create event\");\n this.getTypeWarning = true;\n }\n return undefined;\n }\n return createEvent.getContent()[RoomCreateTypeField];\n }\n\n /**\n * Returns whether the room is a space-room as defined by MSC1772.\n * @returns true if the room's type is RoomType.Space\n */\n public isSpaceRoom(): boolean {\n return this.getType() === RoomType.Space;\n }\n\n /**\n * Returns whether the room is a call-room as defined by MSC3417.\n * @returns true if the room's type is RoomType.UnstableCall\n */\n public isCallRoom(): boolean {\n return this.getType() === RoomType.UnstableCall;\n }\n\n /**\n * Returns whether the room is a video room.\n * @returns true if the room's type is RoomType.ElementVideo\n */\n public isElementVideoRoom(): boolean {\n return this.getType() === RoomType.ElementVideo;\n }\n\n /**\n * Find the predecessor of this room.\n *\n * @param msc3946ProcessDynamicPredecessor - if true, look for an\n * m.room.predecessor state event and use it if found (MSC3946).\n * @returns null if this room has no predecessor. Otherwise, returns\n * the roomId, last eventId and viaServers of the predecessor room.\n *\n * If msc3946ProcessDynamicPredecessor is true, use m.predecessor events\n * as well as m.room.create events to find predecessors.\n *\n * Note: if an m.predecessor event is used, eventId may be undefined\n * since last_known_event_id is optional.\n *\n * Note: viaServers may be undefined, and will definitely be undefined if\n * this predecessor comes from a RoomCreate event (rather than a\n * RoomPredecessor, which has the optional via_servers property).\n */\n public findPredecessor(\n msc3946ProcessDynamicPredecessor = false,\n ): { roomId: string; eventId?: string; viaServers?: string[] } | null {\n const currentState = this.getLiveTimeline().getState(EventTimeline.FORWARDS);\n if (!currentState) {\n return null;\n }\n return currentState.findPredecessor(msc3946ProcessDynamicPredecessor);\n }\n\n private roomNameGenerator(state: RoomNameState): string {\n if (this.client.roomNameGenerator) {\n const name = this.client.roomNameGenerator(this.roomId, state);\n if (name !== null) {\n return name;\n }\n }\n\n switch (state.type) {\n case RoomNameType.Actual:\n return state.name;\n case RoomNameType.Generated:\n switch (state.subtype) {\n case \"Inviting\":\n return `Inviting ${memberNamesToRoomName(state.names, state.count)}`;\n default:\n return memberNamesToRoomName(state.names, state.count);\n }\n case RoomNameType.EmptyRoom:\n if (state.oldName) {\n return `Empty room (was ${state.oldName})`;\n } else {\n return \"Empty room\";\n }\n }\n }\n\n /**\n * This is an internal method. Calculates the name of the room from the current\n * room state.\n * @param userId - The client's user ID. Used to filter room members\n * correctly.\n * @param ignoreRoomNameEvent - Return the implicit room name that we'd see if there\n * was no m.room.name event.\n * @returns The calculated room name.\n */\n private calculateRoomName(userId: string, ignoreRoomNameEvent = false): string {\n if (!ignoreRoomNameEvent) {\n // check for an alias, if any. for now, assume first alias is the\n // official one.\n const mRoomName = this.currentState.getStateEvents(EventType.RoomName, \"\");\n if (mRoomName?.getContent().name) {\n return this.roomNameGenerator({\n type: RoomNameType.Actual,\n name: mRoomName.getContent().name,\n });\n }\n }\n\n const alias = this.getCanonicalAlias();\n if (alias) {\n return this.roomNameGenerator({\n type: RoomNameType.Actual,\n name: alias,\n });\n }\n\n const joinedMemberCount = this.currentState.getJoinedMemberCount();\n const invitedMemberCount = this.currentState.getInvitedMemberCount();\n // -1 because these numbers include the syncing user\n let inviteJoinCount = joinedMemberCount + invitedMemberCount - 1;\n\n // get service members (e.g. helper bots) for exclusion\n let excludedUserIds: string[] = [];\n const mFunctionalMembers = this.currentState.getStateEvents(UNSTABLE_ELEMENT_FUNCTIONAL_USERS.name, \"\");\n if (Array.isArray(mFunctionalMembers?.getContent().service_members)) {\n excludedUserIds = mFunctionalMembers!.getContent().service_members;\n }\n\n // get members that are NOT ourselves and are actually in the room.\n let otherNames: string[] = [];\n if (this.summaryHeroes) {\n // if we have a summary, the member state events should be in the room state\n this.summaryHeroes.forEach((userId) => {\n // filter service members\n if (excludedUserIds.includes(userId)) {\n inviteJoinCount--;\n return;\n }\n const member = this.getMember(userId);\n otherNames.push(member ? member.name : userId);\n });\n } else {\n let otherMembers = this.currentState.getMembers().filter((m) => {\n return m.userId !== userId && (m.membership === \"invite\" || m.membership === \"join\");\n });\n otherMembers = otherMembers.filter(({ userId }) => {\n // filter service members\n if (excludedUserIds.includes(userId)) {\n inviteJoinCount--;\n return false;\n }\n return true;\n });\n // make sure members have stable order\n otherMembers.sort((a, b) => utils.compare(a.userId, b.userId));\n // only 5 first members, immitate summaryHeroes\n otherMembers = otherMembers.slice(0, 5);\n otherNames = otherMembers.map((m) => m.name);\n }\n\n if (inviteJoinCount) {\n return this.roomNameGenerator({\n type: RoomNameType.Generated,\n names: otherNames,\n count: inviteJoinCount,\n });\n }\n\n const myMembership = this.getMyMembership();\n // if I have created a room and invited people through\n // 3rd party invites\n if (myMembership == \"join\") {\n const thirdPartyInvites = this.currentState.getStateEvents(EventType.RoomThirdPartyInvite);\n\n if (thirdPartyInvites?.length) {\n const thirdPartyNames = thirdPartyInvites.map((i) => {\n return i.getContent().display_name;\n });\n\n return this.roomNameGenerator({\n type: RoomNameType.Generated,\n subtype: \"Inviting\",\n names: thirdPartyNames,\n count: thirdPartyNames.length + 1,\n });\n }\n }\n\n // let's try to figure out who was here before\n let leftNames = otherNames;\n // if we didn't have heroes, try finding them in the room state\n if (!leftNames.length) {\n leftNames = this.currentState\n .getMembers()\n .filter((m) => {\n return m.userId !== userId && m.membership !== \"invite\" && m.membership !== \"join\";\n })\n .map((m) => m.name);\n }\n\n let oldName: string | undefined;\n if (leftNames.length) {\n oldName = this.roomNameGenerator({\n type: RoomNameType.Generated,\n names: leftNames,\n count: leftNames.length + 1,\n });\n }\n\n return this.roomNameGenerator({\n type: RoomNameType.EmptyRoom,\n oldName,\n });\n }\n\n /**\n * When we receive a new visibility change event:\n *\n * - store this visibility change alongside the timeline, in case we\n * later need to apply it to an event that we haven't received yet;\n * - if we have already received the event whose visibility has changed,\n * patch it to reflect the visibility change and inform listeners.\n */\n private applyNewVisibilityEvent(event: MatrixEvent): void {\n const visibilityChange = event.asVisibilityChange();\n if (!visibilityChange) {\n // The event is ill-formed.\n return;\n }\n\n // Ignore visibility change events that are not emitted by moderators.\n const userId = event.getSender();\n if (!userId) {\n return;\n }\n const isPowerSufficient =\n (EVENT_VISIBILITY_CHANGE_TYPE.name &&\n this.currentState.maySendStateEvent(EVENT_VISIBILITY_CHANGE_TYPE.name, userId)) ||\n (EVENT_VISIBILITY_CHANGE_TYPE.altName &&\n this.currentState.maySendStateEvent(EVENT_VISIBILITY_CHANGE_TYPE.altName, userId));\n if (!isPowerSufficient) {\n // Powerlevel is insufficient.\n return;\n }\n\n // Record this change in visibility.\n // If the event is not in our timeline and we only receive it later,\n // we may need to apply the visibility change at a later date.\n\n const visibilityEventsOnOriginalEvent = this.visibilityEvents.get(visibilityChange.eventId);\n if (visibilityEventsOnOriginalEvent) {\n // It would be tempting to simply erase the latest visibility change\n // but we need to record all of the changes in case the latest change\n // is ever redacted.\n //\n // In practice, linear scans through `visibilityEvents` should be fast.\n // However, to protect against a potential DoS attack, we limit the\n // number of iterations in this loop.\n let index = visibilityEventsOnOriginalEvent.length - 1;\n const min = Math.max(\n 0,\n visibilityEventsOnOriginalEvent.length - MAX_NUMBER_OF_VISIBILITY_EVENTS_TO_SCAN_THROUGH,\n );\n for (; index >= min; --index) {\n const target = visibilityEventsOnOriginalEvent[index];\n if (target.getTs() < event.getTs()) {\n break;\n }\n }\n if (index === -1) {\n visibilityEventsOnOriginalEvent.unshift(event);\n } else {\n visibilityEventsOnOriginalEvent.splice(index + 1, 0, event);\n }\n } else {\n this.visibilityEvents.set(visibilityChange.eventId, [event]);\n }\n\n // Finally, let's check if the event is already in our timeline.\n // If so, we need to patch it and inform listeners.\n\n const originalEvent = this.findEventById(visibilityChange.eventId);\n if (!originalEvent) {\n return;\n }\n originalEvent.applyVisibilityEvent(visibilityChange);\n }\n\n private redactVisibilityChangeEvent(event: MatrixEvent): void {\n // Sanity checks.\n if (!event.isVisibilityEvent) {\n throw new Error(\"expected a visibility change event\");\n }\n const relation = event.getRelation();\n const originalEventId = relation?.event_id;\n const visibilityEventsOnOriginalEvent = this.visibilityEvents.get(originalEventId!);\n if (!visibilityEventsOnOriginalEvent) {\n // No visibility changes on the original event.\n // In particular, this change event was not recorded,\n // most likely because it was ill-formed.\n return;\n }\n const index = visibilityEventsOnOriginalEvent.findIndex((change) => change.getId() === event.getId());\n if (index === -1) {\n // This change event was not recorded, most likely because\n // it was ill-formed.\n return;\n }\n // Remove visibility change.\n visibilityEventsOnOriginalEvent.splice(index, 1);\n\n // If we removed the latest visibility change event, propagate changes.\n if (index === visibilityEventsOnOriginalEvent.length) {\n const originalEvent = this.findEventById(originalEventId!);\n if (!originalEvent) {\n return;\n }\n if (index === 0) {\n // We have just removed the only visibility change event.\n this.visibilityEvents.delete(originalEventId!);\n originalEvent.applyVisibilityEvent();\n } else {\n const newEvent = visibilityEventsOnOriginalEvent[visibilityEventsOnOriginalEvent.length - 1];\n const newVisibility = newEvent.asVisibilityChange();\n if (!newVisibility) {\n // Event is ill-formed.\n // This breaks our invariant.\n throw new Error(\"at this stage, visibility changes should be well-formed\");\n }\n originalEvent.applyVisibilityEvent(newVisibility);\n }\n }\n }\n\n /**\n * When we receive an event whose visibility has been altered by\n * a (more recent) visibility change event, patch the event in\n * place so that clients now not to display it.\n *\n * @param event - Any matrix event. If this event has at least one a\n * pending visibility change event, apply the latest visibility\n * change event.\n */\n private applyPendingVisibilityEvents(event: MatrixEvent): void {\n const visibilityEvents = this.visibilityEvents.get(event.getId()!);\n if (!visibilityEvents || visibilityEvents.length == 0) {\n // No pending visibility change in store.\n return;\n }\n const visibilityEvent = visibilityEvents[visibilityEvents.length - 1];\n const visibilityChange = visibilityEvent.asVisibilityChange();\n if (!visibilityChange) {\n return;\n }\n if (visibilityChange.visible) {\n // Events are visible by default, no need to apply a visibility change.\n // Note that we need to keep the visibility changes in `visibilityEvents`,\n // in case we later fetch an older visibility change event that is superseded\n // by `visibilityChange`.\n }\n if (visibilityEvent.getTs() < event.getTs()) {\n // Something is wrong, the visibility change cannot happen before the\n // event. Presumably an ill-formed event.\n return;\n }\n event.applyVisibilityEvent(visibilityChange);\n }\n\n /**\n * Find when a client has gained thread capabilities by inspecting the oldest\n * threaded receipt\n * @returns the timestamp of the oldest threaded receipt\n */\n public getOldestThreadedReceiptTs(): number {\n return this.oldestThreadedReceiptTs;\n }\n\n /**\n * Returns the most recent unthreaded receipt for a given user\n * @param userId - the MxID of the User\n * @returns an unthreaded Receipt. Can be undefined if receipts have been disabled\n * or a user chooses to use private read receipts (or we have simply not received\n * a receipt from this user yet).\n */\n public getLastUnthreadedReceiptFor(userId: string): Receipt | undefined {\n return this.unthreadedReceipts.get(userId);\n }\n\n /**\n * This issue should also be addressed on synapse's side and is tracked as part\n * of https://github.com/matrix-org/synapse/issues/14837\n *\n *\n * We consider a room fully read if the current user has sent\n * the last event in the live timeline of that context and if the read receipt\n * we have on record matches.\n * This also detects all unread threads and applies the same logic to those\n * contexts\n */\n public fixupNotifications(userId: string): void {\n super.fixupNotifications(userId);\n\n const unreadThreads = this.getThreads().filter(\n (thread) => this.getThreadUnreadNotificationCount(thread.id, NotificationCountType.Total) > 0,\n );\n\n for (const thread of unreadThreads) {\n thread.fixupNotifications(userId);\n }\n }\n}\n\n// a map from current event status to a list of allowed next statuses\nconst ALLOWED_TRANSITIONS: Record = {\n [EventStatus.ENCRYPTING]: [EventStatus.SENDING, EventStatus.NOT_SENT, EventStatus.CANCELLED],\n [EventStatus.SENDING]: [EventStatus.ENCRYPTING, EventStatus.QUEUED, EventStatus.NOT_SENT, EventStatus.SENT],\n [EventStatus.QUEUED]: [EventStatus.SENDING, EventStatus.NOT_SENT, EventStatus.CANCELLED],\n [EventStatus.SENT]: [],\n [EventStatus.NOT_SENT]: [EventStatus.SENDING, EventStatus.QUEUED, EventStatus.CANCELLED],\n [EventStatus.CANCELLED]: [],\n};\n\nexport enum RoomNameType {\n EmptyRoom,\n Generated,\n Actual,\n}\n\nexport interface EmptyRoomNameState {\n type: RoomNameType.EmptyRoom;\n oldName?: string;\n}\n\nexport interface GeneratedRoomNameState {\n type: RoomNameType.Generated;\n subtype?: \"Inviting\";\n names: string[];\n count: number;\n}\n\nexport interface ActualRoomNameState {\n type: RoomNameType.Actual;\n name: string;\n}\n\nexport type RoomNameState = EmptyRoomNameState | GeneratedRoomNameState | ActualRoomNameState;\n\n// Can be overriden by IMatrixClientCreateOpts::memberNamesToRoomNameFn\nfunction memberNamesToRoomName(names: string[], count: number): string {\n const countWithoutMe = count - 1;\n if (!names.length) {\n return \"Empty room\";\n } else if (names.length === 1 && countWithoutMe <= 1) {\n return names[0];\n } else if (names.length === 2 && countWithoutMe <= 2) {\n return `${names[0]} and ${names[1]}`;\n } else {\n const plural = countWithoutMe > 1;\n if (plural) {\n return `${names[0]} and ${countWithoutMe} others`;\n } else {\n return `${names[0]} and 1 other`;\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts deleted file mode 100644 index d39ea0e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts +++ /dev/null @@ -1,20 +0,0 @@ -import { EventContext } from "./event-context"; -import { EventMapper } from "../event-mapper"; -import { ISearchResult } from "../@types/search"; -export declare class SearchResult { - readonly rank: number; - readonly context: EventContext; - /** - * Create a SearchResponse from the response to /search - */ - static fromJson(jsonObj: ISearchResult, eventMapper: EventMapper): SearchResult; - /** - * Construct a new SearchResult - * - * @param rank - where this SearchResult ranks in the results - * @param context - the matching event and its - * context - */ - constructor(rank: number, context: EventContext); -} -//# sourceMappingURL=search-result.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts.map deleted file mode 100644 index 3350dff..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"search-result.d.ts","sourceRoot":"","sources":["../../src/models/search-result.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAkB,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjE,qBAAa,YAAY;aAgCc,IAAI,EAAE,MAAM;aAAkB,OAAO,EAAE,YAAY;IA/BtF;;OAEG;WAEW,QAAQ,CAAC,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,GAAG,YAAY;IAoBtF;;;;;;OAMG;gBACgC,IAAI,EAAE,MAAM,EAAkB,OAAO,EAAE,YAAY;CACzF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js deleted file mode 100644 index 2149486..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js +++ /dev/null @@ -1,59 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SearchResult = void 0; -var _eventContext = require("./event-context"); -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class SearchResult { - /** - * Create a SearchResponse from the response to /search - */ - - static fromJson(jsonObj, eventMapper) { - const jsonContext = jsonObj.context || {}; - let eventsBefore = (jsonContext.events_before || []).map(eventMapper); - let eventsAfter = (jsonContext.events_after || []).map(eventMapper); - const context = new _eventContext.EventContext(eventMapper(jsonObj.result)); - - // Filter out any contextual events which do not correspond to the same timeline (thread or room) - const threadRootId = context.ourEvent.threadRootId; - eventsBefore = eventsBefore.filter(e => e.threadRootId === threadRootId); - eventsAfter = eventsAfter.filter(e => e.threadRootId === threadRootId); - context.setPaginateToken(jsonContext.start, true); - context.addEvents(eventsBefore, true); - context.addEvents(eventsAfter, false); - context.setPaginateToken(jsonContext.end, false); - return new SearchResult(jsonObj.rank, context); - } - - /** - * Construct a new SearchResult - * - * @param rank - where this SearchResult ranks in the results - * @param context - the matching event and its - * context - */ - constructor(rank, context) { - this.rank = rank; - this.context = context; - } -} -exports.SearchResult = SearchResult; -//# sourceMappingURL=search-result.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js.map deleted file mode 100644 index bc18102..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/search-result.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"search-result.js","names":["_eventContext","require","SearchResult","fromJson","jsonObj","eventMapper","jsonContext","context","eventsBefore","events_before","map","eventsAfter","events_after","EventContext","result","threadRootId","ourEvent","filter","e","setPaginateToken","start","addEvents","end","rank","constructor","exports"],"sources":["../../src/models/search-result.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EventContext } from \"./event-context\";\nimport { EventMapper } from \"../event-mapper\";\nimport { IResultContext, ISearchResult } from \"../@types/search\";\n\nexport class SearchResult {\n /**\n * Create a SearchResponse from the response to /search\n */\n\n public static fromJson(jsonObj: ISearchResult, eventMapper: EventMapper): SearchResult {\n const jsonContext = jsonObj.context || ({} as IResultContext);\n let eventsBefore = (jsonContext.events_before || []).map(eventMapper);\n let eventsAfter = (jsonContext.events_after || []).map(eventMapper);\n\n const context = new EventContext(eventMapper(jsonObj.result));\n\n // Filter out any contextual events which do not correspond to the same timeline (thread or room)\n const threadRootId = context.ourEvent.threadRootId;\n eventsBefore = eventsBefore.filter((e) => e.threadRootId === threadRootId);\n eventsAfter = eventsAfter.filter((e) => e.threadRootId === threadRootId);\n\n context.setPaginateToken(jsonContext.start, true);\n context.addEvents(eventsBefore, true);\n context.addEvents(eventsAfter, false);\n context.setPaginateToken(jsonContext.end, false);\n\n return new SearchResult(jsonObj.rank, context);\n }\n\n /**\n * Construct a new SearchResult\n *\n * @param rank - where this SearchResult ranks in the results\n * @param context - the matching event and its\n * context\n */\n public constructor(public readonly rank: number, public readonly context: EventContext) {}\n}\n"],"mappings":";;;;;;AAgBA,IAAAA,aAAA,GAAAC,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAMO,MAAMC,YAAY,CAAC;EACtB;AACJ;AACA;;EAEI,OAAcC,QAAQA,CAACC,OAAsB,EAAEC,WAAwB,EAAgB;IACnF,MAAMC,WAAW,GAAGF,OAAO,CAACG,OAAO,IAAK,CAAC,CAAoB;IAC7D,IAAIC,YAAY,GAAG,CAACF,WAAW,CAACG,aAAa,IAAI,EAAE,EAAEC,GAAG,CAACL,WAAW,CAAC;IACrE,IAAIM,WAAW,GAAG,CAACL,WAAW,CAACM,YAAY,IAAI,EAAE,EAAEF,GAAG,CAACL,WAAW,CAAC;IAEnE,MAAME,OAAO,GAAG,IAAIM,0BAAY,CAACR,WAAW,CAACD,OAAO,CAACU,MAAM,CAAC,CAAC;;IAE7D;IACA,MAAMC,YAAY,GAAGR,OAAO,CAACS,QAAQ,CAACD,YAAY;IAClDP,YAAY,GAAGA,YAAY,CAACS,MAAM,CAAEC,CAAC,IAAKA,CAAC,CAACH,YAAY,KAAKA,YAAY,CAAC;IAC1EJ,WAAW,GAAGA,WAAW,CAACM,MAAM,CAAEC,CAAC,IAAKA,CAAC,CAACH,YAAY,KAAKA,YAAY,CAAC;IAExER,OAAO,CAACY,gBAAgB,CAACb,WAAW,CAACc,KAAK,EAAE,IAAI,CAAC;IACjDb,OAAO,CAACc,SAAS,CAACb,YAAY,EAAE,IAAI,CAAC;IACrCD,OAAO,CAACc,SAAS,CAACV,WAAW,EAAE,KAAK,CAAC;IACrCJ,OAAO,CAACY,gBAAgB,CAACb,WAAW,CAACgB,GAAG,EAAE,KAAK,CAAC;IAEhD,OAAO,IAAIpB,YAAY,CAACE,OAAO,CAACmB,IAAI,EAAEhB,OAAO,CAAC;EAClD;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;EACWiB,WAAWA,CAAiBD,IAAY,EAAkBhB,OAAqB,EAAE;IAAA,KAArDgB,IAAY,GAAZA,IAAY;IAAA,KAAkBhB,OAAqB,GAArBA,OAAqB;EAAG;AAC7F;AAACkB,OAAA,CAAAvB,YAAA,GAAAA,YAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts deleted file mode 100644 index df26baf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts +++ /dev/null @@ -1,175 +0,0 @@ -import { Optional } from "matrix-events-sdk"; -import { MatrixClient, PendingEventOrdering } from "../client"; -import { MatrixEvent } from "./event"; -import { EventTimeline } from "./event-timeline"; -import { EventTimelineSet, EventTimelineSetHandlerMap } from "./event-timeline-set"; -import { NotificationCountType, Room, RoomEvent } from "./room"; -import { RoomState } from "./room-state"; -import { ServerControlledNamespacedValue } from "../NamespacedValue"; -import { ReadReceipt } from "./read-receipt"; -import { CachedReceiptStructure } from "../@types/read_receipts"; -export declare enum ThreadEvent { - New = "Thread.new", - Update = "Thread.update", - NewReply = "Thread.newReply", - ViewThread = "Thread.viewThread", - Delete = "Thread.delete" -} -type EmittedEvents = Exclude | RoomEvent.Timeline | RoomEvent.TimelineReset; -export type EventHandlerMap = { - [ThreadEvent.Update]: (thread: Thread) => void; - [ThreadEvent.NewReply]: (thread: Thread, event: MatrixEvent) => void; - [ThreadEvent.ViewThread]: () => void; - [ThreadEvent.Delete]: (thread: Thread) => void; -} & EventTimelineSetHandlerMap; -interface IThreadOpts { - room: Room; - client: MatrixClient; - pendingEventOrdering?: PendingEventOrdering; - receipts?: CachedReceiptStructure[]; -} -export declare enum FeatureSupport { - None = 0, - Experimental = 1, - Stable = 2 -} -export declare function determineFeatureSupport(stable: boolean, unstable: boolean): FeatureSupport; -export declare class Thread extends ReadReceipt { - readonly id: string; - rootEvent: MatrixEvent | undefined; - static hasServerSideSupport: FeatureSupport; - static hasServerSideListSupport: FeatureSupport; - static hasServerSideFwdPaginationSupport: FeatureSupport; - /** - * A reference to all the events ID at the bottom of the threads - */ - readonly timelineSet: EventTimelineSet; - timeline: MatrixEvent[]; - private _currentUserParticipated; - private reEmitter; - private lastEvent; - private replyCount; - private lastPendingEvent; - private pendingReplyCount; - readonly room: Room; - readonly client: MatrixClient; - private readonly pendingEventOrdering; - initialEventsFetched: boolean; - /** - * An array of events to add to the timeline once the thread has been initialised - * with server suppport. - */ - replayEvents: MatrixEvent[] | null; - constructor(id: string, rootEvent: MatrixEvent | undefined, opts: IThreadOpts); - private fetchRootEvent; - static setServerSideSupport(status: FeatureSupport): void; - static setServerSideListSupport(status: FeatureSupport): void; - static setServerSideFwdPaginationSupport(status: FeatureSupport): void; - private onBeforeRedaction; - private onRedaction; - private onTimelineEvent; - private onLocalEcho; - private onEcho; - get roomState(): RoomState; - private addEventToTimeline; - addEvents(events: MatrixEvent[], toStartOfTimeline: boolean): void; - /** - * Add an event to the thread and updates - * the tail/root references if needed - * Will fire "Thread.update" - * @param event - The event to add - * @param toStartOfTimeline - whether the event is being added - * to the start (and not the end) of the timeline. - * @param emit - whether to emit the Update event if the thread was updated or not. - */ - addEvent(event: MatrixEvent, toStartOfTimeline: boolean, emit?: boolean): Promise; - processEvent(event: Optional): Promise; - /** - * Processes the receipts that were caught during initial sync - * When clients become aware of a thread, they try to retrieve those read receipts - * and apply them to the current thread - * @param receipts - A collection of the receipts cached from initial sync - */ - private processReceipts; - private getRootEventBundledRelationship; - private processRootEvent; - private updatePendingReplyCount; - /** - * Reset the live timeline of all timelineSets, and start new ones. - * - *

This is used when /sync returns a 'limited' timeline. 'Limited' means that there's a gap between the messages - * /sync returned, and the last known message in our timeline. In such a case, our live timeline isn't live anymore - * and has to be replaced by a new one. To make sure we can continue paginating our timelines correctly, we have to - * set new pagination tokens on the old and the new timeline. - * - * @param backPaginationToken - token for back-paginating the new timeline - * @param forwardPaginationToken - token for forward-paginating the old live timeline, - * if absent or null, all timelines are reset, removing old ones (including the previous live - * timeline which would otherwise be unable to paginate forwards without this token). - * Removing just the old live timeline whilst preserving previous ones is not supported. - */ - resetLiveTimeline(backPaginationToken?: string | null, forwardPaginationToken?: string | null): Promise; - private updateThreadMetadata; - private fetchEditsWhereNeeded; - setEventMetadata(event: Optional): void; - clearEventMetadata(event: Optional): void; - /** - * Finds an event by ID in the current thread - */ - findEventById(eventId: string): MatrixEvent | undefined; - /** - * Return last reply to the thread, if known. - */ - lastReply(matches?: (ev: MatrixEvent) => boolean): MatrixEvent | null; - get roomId(): string; - /** - * The number of messages in the thread - * Only count rel_type=m.thread as we want to - * exclude annotations from that number - */ - get length(): number; - /** - * A getter for the last event of the thread. - * This might be a synthesized event, if so, it will not emit any events to listeners. - */ - get replyToEvent(): Optional; - get events(): MatrixEvent[]; - has(eventId: string): boolean; - get hasCurrentUserParticipated(): boolean; - get liveTimeline(): EventTimeline; - getUnfilteredTimelineSet(): EventTimelineSet; - addReceipt(event: MatrixEvent, synthetic: boolean): void; - /** - * Get the ID of the event that a given user has read up to within this thread, - * or null if we have received no read receipt (at all) from them. - * @param userId - The user ID to get read receipt event ID for - * @param ignoreSynthesized - If true, return only receipts that have been - * sent by the server, not implicit ones generated - * by the JS SDK. - * @returns ID of the latest event that the given user has read, or null. - */ - getEventReadUpTo(userId: string, ignoreSynthesized?: boolean): string | null; - /** - * Determine if the given user has read a particular event. - * - * It is invalid to call this method with an event that is not part of this thread. - * - * This is not a definitive check as it only checks the events that have been - * loaded client-side at the time of execution. - * @param userId - The user ID to check the read state of. - * @param eventId - The event ID to check if the user read. - * @returns True if the user has read the event, false otherwise. - */ - hasUserReadEvent(userId: string, eventId: string): boolean; - setUnread(type: NotificationCountType, count: number): void; -} -export declare const FILTER_RELATED_BY_SENDERS: ServerControlledNamespacedValue<"related_by_senders", "io.element.relation_senders">; -export declare const FILTER_RELATED_BY_REL_TYPES: ServerControlledNamespacedValue<"related_by_rel_types", "io.element.relation_types">; -export declare const THREAD_RELATION_TYPE: ServerControlledNamespacedValue<"m.thread", "io.element.thread">; -export declare enum ThreadFilterType { - "My" = 0, - "All" = 1 -} -export declare function threadFilterTypeToFilter(type: ThreadFilterType | null): "all" | "participated"; -export {}; -//# sourceMappingURL=thread.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts.map deleted file mode 100644 index 5cb2c6a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"thread.d.ts","sourceRoot":"","sources":["../../src/models/thread.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js deleted file mode 100644 index bc47b2e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js +++ /dev/null @@ -1,581 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ThreadFilterType = exports.ThreadEvent = exports.Thread = exports.THREAD_RELATION_TYPE = exports.FeatureSupport = exports.FILTER_RELATED_BY_SENDERS = exports.FILTER_RELATED_BY_REL_TYPES = void 0; -exports.determineFeatureSupport = determineFeatureSupport; -exports.threadFilterTypeToFilter = threadFilterTypeToFilter; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _client = require("../client"); -var _ReEmitter = require("../ReEmitter"); -var _event = require("../@types/event"); -var _event2 = require("./event"); -var _eventTimeline = require("./event-timeline"); -var _eventTimelineSet = require("./event-timeline-set"); -var _room = require("./room"); -var _NamespacedValue = require("../NamespacedValue"); -var _logger = require("../logger"); -var _readReceipt = require("./read-receipt"); -var _read_receipts = require("../@types/read_receipts"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -let ThreadEvent; -exports.ThreadEvent = ThreadEvent; -(function (ThreadEvent) { - ThreadEvent["New"] = "Thread.new"; - ThreadEvent["Update"] = "Thread.update"; - ThreadEvent["NewReply"] = "Thread.newReply"; - ThreadEvent["ViewThread"] = "Thread.viewThread"; - ThreadEvent["Delete"] = "Thread.delete"; -})(ThreadEvent || (exports.ThreadEvent = ThreadEvent = {})); -let FeatureSupport; -exports.FeatureSupport = FeatureSupport; -(function (FeatureSupport) { - FeatureSupport[FeatureSupport["None"] = 0] = "None"; - FeatureSupport[FeatureSupport["Experimental"] = 1] = "Experimental"; - FeatureSupport[FeatureSupport["Stable"] = 2] = "Stable"; -})(FeatureSupport || (exports.FeatureSupport = FeatureSupport = {})); -function determineFeatureSupport(stable, unstable) { - if (stable) { - return FeatureSupport.Stable; - } else if (unstable) { - return FeatureSupport.Experimental; - } else { - return FeatureSupport.None; - } -} -class Thread extends _readReceipt.ReadReceipt { - /** - * A reference to all the events ID at the bottom of the threads - */ - - /** - * An array of events to add to the timeline once the thread has been initialised - * with server suppport. - */ - - constructor(id, rootEvent, opts) { - var _opts$pendingEventOrd; - super(); - this.id = id; - this.rootEvent = rootEvent; - (0, _defineProperty2.default)(this, "timelineSet", void 0); - (0, _defineProperty2.default)(this, "timeline", []); - (0, _defineProperty2.default)(this, "_currentUserParticipated", false); - (0, _defineProperty2.default)(this, "reEmitter", void 0); - (0, _defineProperty2.default)(this, "lastEvent", void 0); - (0, _defineProperty2.default)(this, "replyCount", 0); - (0, _defineProperty2.default)(this, "lastPendingEvent", void 0); - (0, _defineProperty2.default)(this, "pendingReplyCount", 0); - (0, _defineProperty2.default)(this, "room", void 0); - (0, _defineProperty2.default)(this, "client", void 0); - (0, _defineProperty2.default)(this, "pendingEventOrdering", void 0); - (0, _defineProperty2.default)(this, "initialEventsFetched", !Thread.hasServerSideSupport); - (0, _defineProperty2.default)(this, "replayEvents", []); - (0, _defineProperty2.default)(this, "onBeforeRedaction", (event, redaction) => { - if (event !== null && event !== void 0 && event.isRelation(THREAD_RELATION_TYPE.name) && this.room.eventShouldLiveIn(event).threadId === this.id && event.getId() !== this.id && - // the root event isn't counted in the length so ignore this redaction - !redaction.status // only respect it when it succeeds - ) { - this.replyCount--; - this.updatePendingReplyCount(); - this.emit(ThreadEvent.Update, this); - } - }); - (0, _defineProperty2.default)(this, "onRedaction", async event => { - if (event.threadRootId !== this.id) return; // ignore redactions for other timelines - if (this.replyCount <= 0) { - for (const threadEvent of this.timeline) { - this.clearEventMetadata(threadEvent); - } - this.lastEvent = this.rootEvent; - this._currentUserParticipated = false; - this.emit(ThreadEvent.Delete, this); - } else { - await this.updateThreadMetadata(); - } - }); - (0, _defineProperty2.default)(this, "onTimelineEvent", (event, room, toStartOfTimeline) => { - // Add a synthesized receipt when paginating forward in the timeline - if (!toStartOfTimeline) { - room.addLocalEchoReceipt(event.getSender(), event, _read_receipts.ReceiptType.Read); - } - this.onEcho(event, toStartOfTimeline !== null && toStartOfTimeline !== void 0 ? toStartOfTimeline : false); - }); - (0, _defineProperty2.default)(this, "onLocalEcho", event => { - this.onEcho(event, false); - }); - (0, _defineProperty2.default)(this, "onEcho", async (event, toStartOfTimeline) => { - if (event.threadRootId !== this.id) return; // ignore echoes for other timelines - if (this.lastEvent === event) return; // ignore duplicate events - await this.updateThreadMetadata(); - if (!event.isRelation(THREAD_RELATION_TYPE.name)) return; // don't send a new reply event for reactions or edits - if (toStartOfTimeline) return; // ignore messages added to the start of the timeline - this.emit(ThreadEvent.NewReply, this, event); - }); - if (!(opts !== null && opts !== void 0 && opts.room)) { - // Logging/debugging for https://github.com/vector-im/element-web/issues/22141 - // Hope is that we end up with a more obvious stack trace. - throw new Error("element-web#22141: A thread requires a room in order to function"); - } - this.room = opts.room; - this.client = opts.client; - this.pendingEventOrdering = (_opts$pendingEventOrd = opts.pendingEventOrdering) !== null && _opts$pendingEventOrd !== void 0 ? _opts$pendingEventOrd : _client.PendingEventOrdering.Chronological; - this.timelineSet = new _eventTimelineSet.EventTimelineSet(this.room, { - timelineSupport: true, - pendingEvents: true - }, this.client, this); - this.reEmitter = new _ReEmitter.TypedReEmitter(this); - this.reEmitter.reEmit(this.timelineSet, [_room.RoomEvent.Timeline, _room.RoomEvent.TimelineReset]); - this.room.on(_event2.MatrixEventEvent.BeforeRedaction, this.onBeforeRedaction); - this.room.on(_room.RoomEvent.Redaction, this.onRedaction); - this.room.on(_room.RoomEvent.LocalEchoUpdated, this.onLocalEcho); - this.timelineSet.on(_room.RoomEvent.Timeline, this.onTimelineEvent); - this.processReceipts(opts.receipts); - - // even if this thread is thought to be originating from this client, we initialise it as we may be in a - // gappy sync and a thread around this event may already exist. - this.updateThreadMetadata(); - this.setEventMetadata(this.rootEvent); - } - async fetchRootEvent() { - this.rootEvent = this.room.findEventById(this.id); - // If the rootEvent does not exist in the local stores, then fetch it from the server. - try { - const eventData = await this.client.fetchRoomEvent(this.roomId, this.id); - const mapper = this.client.getEventMapper(); - this.rootEvent = mapper(eventData); // will merge with existing event object if such is known - } catch (e) { - _logger.logger.error("Failed to fetch thread root to construct thread with", e); - } - await this.processEvent(this.rootEvent); - } - static setServerSideSupport(status) { - Thread.hasServerSideSupport = status; - if (status !== FeatureSupport.Stable) { - FILTER_RELATED_BY_SENDERS.setPreferUnstable(true); - FILTER_RELATED_BY_REL_TYPES.setPreferUnstable(true); - THREAD_RELATION_TYPE.setPreferUnstable(true); - } - } - static setServerSideListSupport(status) { - Thread.hasServerSideListSupport = status; - } - static setServerSideFwdPaginationSupport(status) { - Thread.hasServerSideFwdPaginationSupport = status; - } - get roomState() { - return this.room.getLiveTimeline().getState(_eventTimeline.EventTimeline.FORWARDS); - } - addEventToTimeline(event, toStartOfTimeline) { - if (!this.findEventById(event.getId())) { - this.timelineSet.addEventToTimeline(event, this.liveTimeline, { - toStartOfTimeline, - fromCache: false, - roomState: this.roomState - }); - this.timeline = this.events; - } - } - addEvents(events, toStartOfTimeline) { - events.forEach(ev => this.addEvent(ev, toStartOfTimeline, false)); - this.updateThreadMetadata(); - } - - /** - * Add an event to the thread and updates - * the tail/root references if needed - * Will fire "Thread.update" - * @param event - The event to add - * @param toStartOfTimeline - whether the event is being added - * to the start (and not the end) of the timeline. - * @param emit - whether to emit the Update event if the thread was updated or not. - */ - async addEvent(event, toStartOfTimeline, emit = true) { - this.setEventMetadata(event); - const lastReply = this.lastReply(); - const isNewestReply = !lastReply || event.localTimestamp >= lastReply.localTimestamp; - - // Add all incoming events to the thread's timeline set when there's no server support - if (!Thread.hasServerSideSupport) { - // all the relevant membership info to hydrate events with a sender - // is held in the main room timeline - // We want to fetch the room state from there and pass it down to this thread - // timeline set to let it reconcile an event with its relevant RoomMember - this.addEventToTimeline(event, toStartOfTimeline); - this.client.decryptEventIfNeeded(event, {}); - } else if (!toStartOfTimeline && this.initialEventsFetched && isNewestReply) { - this.addEventToTimeline(event, false); - this.fetchEditsWhereNeeded(event); - } else if (event.isRelation(_event.RelationType.Annotation) || event.isRelation(_event.RelationType.Replace)) { - var _this$timelineSet$rel, _this$timelineSet$rel2; - if (!this.initialEventsFetched) { - var _this$replayEvents; - /** - * A thread can be fully discovered via a single sync response - * And when that's the case we still ask the server to do an initialisation - * as it's the safest to ensure we have everything. - * However when we are in that scenario we might loose annotation or edits - * - * This fix keeps a reference to those events and replay them once the thread - * has been initialised properly. - */ - (_this$replayEvents = this.replayEvents) === null || _this$replayEvents === void 0 ? void 0 : _this$replayEvents.push(event); - } else { - this.addEventToTimeline(event, toStartOfTimeline); - } - // Apply annotations and replace relations to the relations of the timeline only - (_this$timelineSet$rel = this.timelineSet.relations) === null || _this$timelineSet$rel === void 0 ? void 0 : _this$timelineSet$rel.aggregateParentEvent(event); - (_this$timelineSet$rel2 = this.timelineSet.relations) === null || _this$timelineSet$rel2 === void 0 ? void 0 : _this$timelineSet$rel2.aggregateChildEvent(event, this.timelineSet); - return; - } - - // If no thread support exists we want to count all thread relation - // added as a reply. We can't rely on the bundled relationships count - if ((!Thread.hasServerSideSupport || !this.rootEvent) && event.isRelation(THREAD_RELATION_TYPE.name)) { - this.replyCount++; - } - if (emit) { - this.emit(ThreadEvent.NewReply, this, event); - this.updateThreadMetadata(); - } - } - async processEvent(event) { - if (event) { - this.setEventMetadata(event); - await this.fetchEditsWhereNeeded(event); - } - this.timeline = this.events; - } - - /** - * Processes the receipts that were caught during initial sync - * When clients become aware of a thread, they try to retrieve those read receipts - * and apply them to the current thread - * @param receipts - A collection of the receipts cached from initial sync - */ - processReceipts(receipts = []) { - for (const { - eventId, - receiptType, - userId, - receipt, - synthetic - } of receipts) { - this.addReceiptToStructure(eventId, receiptType, userId, receipt, synthetic); - } - } - getRootEventBundledRelationship(rootEvent = this.rootEvent) { - return rootEvent === null || rootEvent === void 0 ? void 0 : rootEvent.getServerAggregatedRelation(THREAD_RELATION_TYPE.name); - } - async processRootEvent() { - const bundledRelationship = this.getRootEventBundledRelationship(); - if (Thread.hasServerSideSupport && bundledRelationship) { - this.replyCount = bundledRelationship.count; - this._currentUserParticipated = !!bundledRelationship.current_user_participated; - const mapper = this.client.getEventMapper(); - // re-insert roomId - this.lastEvent = mapper(_objectSpread(_objectSpread({}, bundledRelationship.latest_event), {}, { - room_id: this.roomId - })); - this.updatePendingReplyCount(); - await this.processEvent(this.lastEvent); - } - } - updatePendingReplyCount() { - const unfilteredPendingEvents = this.pendingEventOrdering === _client.PendingEventOrdering.Detached ? this.room.getPendingEvents() : this.events; - const pendingEvents = unfilteredPendingEvents.filter(ev => { - var _this$lastEvent; - return ev.threadRootId === this.id && ev.isRelation(THREAD_RELATION_TYPE.name) && ev.status !== null && ev.getId() !== ((_this$lastEvent = this.lastEvent) === null || _this$lastEvent === void 0 ? void 0 : _this$lastEvent.getId()); - }); - this.lastPendingEvent = pendingEvents.length ? pendingEvents[pendingEvents.length - 1] : undefined; - this.pendingReplyCount = pendingEvents.length; - } - - /** - * Reset the live timeline of all timelineSets, and start new ones. - * - *

This is used when /sync returns a 'limited' timeline. 'Limited' means that there's a gap between the messages - * /sync returned, and the last known message in our timeline. In such a case, our live timeline isn't live anymore - * and has to be replaced by a new one. To make sure we can continue paginating our timelines correctly, we have to - * set new pagination tokens on the old and the new timeline. - * - * @param backPaginationToken - token for back-paginating the new timeline - * @param forwardPaginationToken - token for forward-paginating the old live timeline, - * if absent or null, all timelines are reset, removing old ones (including the previous live - * timeline which would otherwise be unable to paginate forwards without this token). - * Removing just the old live timeline whilst preserving previous ones is not supported. - */ - async resetLiveTimeline(backPaginationToken, forwardPaginationToken) { - const oldLive = this.liveTimeline; - this.timelineSet.resetLiveTimeline(backPaginationToken !== null && backPaginationToken !== void 0 ? backPaginationToken : undefined, forwardPaginationToken !== null && forwardPaginationToken !== void 0 ? forwardPaginationToken : undefined); - const newLive = this.liveTimeline; - - // FIXME: Remove the following as soon as https://github.com/matrix-org/synapse/issues/14830 is resolved. - // - // The pagination API for thread timelines currently can't handle the type of pagination tokens returned by sync - // - // To make this work anyway, we'll have to transform them into one of the types that the API can handle. - // One option is passing the tokens to /messages, which can handle sync tokens, and returns the right format. - // /messages does not return new tokens on requests with a limit of 0. - // This means our timelines might overlap a slight bit, but that's not an issue, as we deduplicate messages - // anyway. - - let newBackward; - let oldForward; - if (backPaginationToken) { - const res = await this.client.createMessagesRequest(this.roomId, backPaginationToken, 1, _eventTimeline.Direction.Forward); - newBackward = res.end; - } - if (forwardPaginationToken) { - const res = await this.client.createMessagesRequest(this.roomId, forwardPaginationToken, 1, _eventTimeline.Direction.Backward); - oldForward = res.start; - } - // Only replace the token if we don't have paginated away from this position already. This situation doesn't - // occur today, but if the above issue is resolved, we'd have to go down this path. - if (forwardPaginationToken && oldLive.getPaginationToken(_eventTimeline.Direction.Forward) === forwardPaginationToken) { - var _oldForward; - oldLive.setPaginationToken((_oldForward = oldForward) !== null && _oldForward !== void 0 ? _oldForward : null, _eventTimeline.Direction.Forward); - } - if (backPaginationToken && newLive.getPaginationToken(_eventTimeline.Direction.Backward) === backPaginationToken) { - var _newBackward; - newLive.setPaginationToken((_newBackward = newBackward) !== null && _newBackward !== void 0 ? _newBackward : null, _eventTimeline.Direction.Backward); - } - } - async updateThreadMetadata() { - this.updatePendingReplyCount(); - if (Thread.hasServerSideSupport) { - // Ensure we show *something* as soon as possible, we'll update it as soon as we get better data, but we - // don't want the thread preview to be empty if we can avoid it - if (!this.initialEventsFetched) { - await this.processRootEvent(); - } - await this.fetchRootEvent(); - } - await this.processRootEvent(); - if (!this.initialEventsFetched) { - this.initialEventsFetched = true; - // fetch initial event to allow proper pagination - try { - // if the thread has regular events, this will just load the last reply. - // if the thread is newly created, this will load the root event. - if (this.replyCount === 0 && this.rootEvent) { - this.timelineSet.addEventsToTimeline([this.rootEvent], true, this.liveTimeline, null); - this.liveTimeline.setPaginationToken(null, _eventTimeline.Direction.Backward); - } else { - await this.client.paginateEventTimeline(this.liveTimeline, { - backwards: true, - limit: Math.max(1, this.length) - }); - } - for (const event of this.replayEvents) { - this.addEvent(event, false); - } - this.replayEvents = null; - // just to make sure that, if we've created a timeline window for this thread before the thread itself - // existed (e.g. when creating a new thread), we'll make sure the panel is force refreshed correctly. - this.emit(_room.RoomEvent.TimelineReset, this.room, this.timelineSet, true); - } catch (e) { - _logger.logger.error("Failed to load start of newly created thread: ", e); - this.initialEventsFetched = false; - } - } - this.emit(ThreadEvent.Update, this); - } - - // XXX: Workaround for https://github.com/matrix-org/matrix-spec-proposals/pull/2676/files#r827240084 - async fetchEditsWhereNeeded(...events) { - return Promise.all(events.filter(e => e.isEncrypted()).map(event => { - if (event.isRelation()) return; // skip - relations don't get edits - return this.client.relations(this.roomId, event.getId(), _event.RelationType.Replace, event.getType(), { - limit: 1 - }).then(relations => { - if (relations.events.length) { - event.makeReplaced(relations.events[0]); - } - }).catch(e => { - _logger.logger.error("Failed to load edits for encrypted thread event", e); - }); - })); - } - setEventMetadata(event) { - if (event) { - _eventTimeline.EventTimeline.setEventMetadata(event, this.roomState, false); - event.setThread(this); - } - } - clearEventMetadata(event) { - if (event) { - var _event$event, _event$event$unsigned, _event$event$unsigned2; - event.setThread(undefined); - (_event$event = event.event) === null || _event$event === void 0 ? true : (_event$event$unsigned = _event$event.unsigned) === null || _event$event$unsigned === void 0 ? true : (_event$event$unsigned2 = _event$event$unsigned["m.relations"]) === null || _event$event$unsigned2 === void 0 ? true : delete _event$event$unsigned2[THREAD_RELATION_TYPE.name]; - } - } - - /** - * Finds an event by ID in the current thread - */ - findEventById(eventId) { - return this.timelineSet.findEventById(eventId); - } - - /** - * Return last reply to the thread, if known. - */ - lastReply(matches = () => true) { - for (let i = this.timeline.length - 1; i >= 0; i--) { - const event = this.timeline[i]; - if (matches(event)) { - return event; - } - } - return null; - } - get roomId() { - return this.room.roomId; - } - - /** - * The number of messages in the thread - * Only count rel_type=m.thread as we want to - * exclude annotations from that number - */ - get length() { - return this.replyCount + this.pendingReplyCount; - } - - /** - * A getter for the last event of the thread. - * This might be a synthesized event, if so, it will not emit any events to listeners. - */ - get replyToEvent() { - var _ref, _this$lastPendingEven; - return (_ref = (_this$lastPendingEven = this.lastPendingEvent) !== null && _this$lastPendingEven !== void 0 ? _this$lastPendingEven : this.lastEvent) !== null && _ref !== void 0 ? _ref : this.lastReply(); - } - get events() { - return this.liveTimeline.getEvents(); - } - has(eventId) { - return this.timelineSet.findEventById(eventId) instanceof _event2.MatrixEvent; - } - get hasCurrentUserParticipated() { - return this._currentUserParticipated; - } - get liveTimeline() { - return this.timelineSet.getLiveTimeline(); - } - getUnfilteredTimelineSet() { - return this.timelineSet; - } - addReceipt(event, synthetic) { - throw new Error("Unsupported function on the thread model"); - } - - /** - * Get the ID of the event that a given user has read up to within this thread, - * or null if we have received no read receipt (at all) from them. - * @param userId - The user ID to get read receipt event ID for - * @param ignoreSynthesized - If true, return only receipts that have been - * sent by the server, not implicit ones generated - * by the JS SDK. - * @returns ID of the latest event that the given user has read, or null. - */ - getEventReadUpTo(userId, ignoreSynthesized) { - const isCurrentUser = userId === this.client.getUserId(); - const lastReply = this.timeline[this.timeline.length - 1]; - if (isCurrentUser && lastReply) { - // If the last activity in a thread is prior to the first threaded read receipt - // sent in the room (suggesting that it was sent before the user started - // using a client that supported threaded read receipts), we want to - // consider this thread as read. - const beforeFirstThreadedReceipt = lastReply.getTs() < this.room.getOldestThreadedReceiptTs(); - const lastReplyId = lastReply.getId(); - // Some unsent events do not have an ID, we do not want to consider them read - if (beforeFirstThreadedReceipt && lastReplyId) { - return lastReplyId; - } - } - const readUpToId = super.getEventReadUpTo(userId, ignoreSynthesized); - - // Check whether the unthreaded read receipt for that user is more recent - // than the read receipt inside that thread. - if (lastReply) { - const unthreadedReceipt = this.room.getLastUnthreadedReceiptFor(userId); - if (!unthreadedReceipt) { - return readUpToId; - } - for (let i = ((_this$timeline = this.timeline) === null || _this$timeline === void 0 ? void 0 : _this$timeline.length) - 1; i >= 0; --i) { - var _this$timeline, _ev$getId; - const ev = this.timeline[i]; - // If we encounter the `readUpToId` we do not need to look further - // there is no "more recent" unthreaded read receipt - if (ev.getId() === readUpToId) return readUpToId; - - // Inspecting events from most recent to oldest, we're checking - // whether an unthreaded read receipt is more recent that the current event. - // We usually prefer relying on the order of the DAG but in this scenario - // it is not possible and we have to rely on timestamp - if (ev.getTs() < unthreadedReceipt.ts) return (_ev$getId = ev.getId()) !== null && _ev$getId !== void 0 ? _ev$getId : readUpToId; - } - } - return readUpToId; - } - - /** - * Determine if the given user has read a particular event. - * - * It is invalid to call this method with an event that is not part of this thread. - * - * This is not a definitive check as it only checks the events that have been - * loaded client-side at the time of execution. - * @param userId - The user ID to check the read state of. - * @param eventId - The event ID to check if the user read. - * @returns True if the user has read the event, false otherwise. - */ - hasUserReadEvent(userId, eventId) { - if (userId === this.client.getUserId()) { - var _this$lastReply$getTs, _this$lastReply, _this$room$getLastUnt, _this$room$getLastUnt2, _this$lastReply$getTs2, _this$lastReply2; - // Consider an event read if it's part of a thread that is before the - // first threaded receipt sent in that room. It is likely that it is - // part of a thread that was created before MSC3771 was implemented. - // Or before the last unthreaded receipt for the logged in user - const beforeFirstThreadedReceipt = ((_this$lastReply$getTs = (_this$lastReply = this.lastReply()) === null || _this$lastReply === void 0 ? void 0 : _this$lastReply.getTs()) !== null && _this$lastReply$getTs !== void 0 ? _this$lastReply$getTs : 0) < this.room.getOldestThreadedReceiptTs(); - const unthreadedReceiptTs = (_this$room$getLastUnt = (_this$room$getLastUnt2 = this.room.getLastUnthreadedReceiptFor(userId)) === null || _this$room$getLastUnt2 === void 0 ? void 0 : _this$room$getLastUnt2.ts) !== null && _this$room$getLastUnt !== void 0 ? _this$room$getLastUnt : 0; - const beforeLastUnthreadedReceipt = ((_this$lastReply$getTs2 = this === null || this === void 0 ? void 0 : (_this$lastReply2 = this.lastReply()) === null || _this$lastReply2 === void 0 ? void 0 : _this$lastReply2.getTs()) !== null && _this$lastReply$getTs2 !== void 0 ? _this$lastReply$getTs2 : 0) < unthreadedReceiptTs; - if (beforeFirstThreadedReceipt || beforeLastUnthreadedReceipt) { - return true; - } - } - return super.hasUserReadEvent(userId, eventId); - } - setUnread(type, count) { - return this.room.setThreadUnreadNotificationCount(this.id, type, count); - } -} -exports.Thread = Thread; -(0, _defineProperty2.default)(Thread, "hasServerSideSupport", FeatureSupport.None); -(0, _defineProperty2.default)(Thread, "hasServerSideListSupport", FeatureSupport.None); -(0, _defineProperty2.default)(Thread, "hasServerSideFwdPaginationSupport", FeatureSupport.None); -const FILTER_RELATED_BY_SENDERS = new _NamespacedValue.ServerControlledNamespacedValue("related_by_senders", "io.element.relation_senders"); -exports.FILTER_RELATED_BY_SENDERS = FILTER_RELATED_BY_SENDERS; -const FILTER_RELATED_BY_REL_TYPES = new _NamespacedValue.ServerControlledNamespacedValue("related_by_rel_types", "io.element.relation_types"); -exports.FILTER_RELATED_BY_REL_TYPES = FILTER_RELATED_BY_REL_TYPES; -const THREAD_RELATION_TYPE = new _NamespacedValue.ServerControlledNamespacedValue("m.thread", "io.element.thread"); -exports.THREAD_RELATION_TYPE = THREAD_RELATION_TYPE; -let ThreadFilterType; -exports.ThreadFilterType = ThreadFilterType; -(function (ThreadFilterType) { - ThreadFilterType[ThreadFilterType["My"] = 0] = "My"; - ThreadFilterType[ThreadFilterType["All"] = 1] = "All"; -})(ThreadFilterType || (exports.ThreadFilterType = ThreadFilterType = {})); -function threadFilterTypeToFilter(type) { - switch (type) { - case ThreadFilterType.My: - return "participated"; - default: - return "all"; - } -} -//# sourceMappingURL=thread.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js.map deleted file mode 100644 index 75f50b5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/thread.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"thread.js","names":["_client","require","_ReEmitter","_event","_event2","_eventTimeline","_eventTimelineSet","_room","_NamespacedValue","_logger","_readReceipt","_read_receipts","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","ThreadEvent","exports","FeatureSupport","determineFeatureSupport","stable","unstable","Stable","Experimental","None","Thread","ReadReceipt","constructor","id","rootEvent","opts","_opts$pendingEventOrd","hasServerSideSupport","event","redaction","isRelation","THREAD_RELATION_TYPE","name","room","eventShouldLiveIn","threadId","getId","status","replyCount","updatePendingReplyCount","emit","Update","threadRootId","threadEvent","timeline","clearEventMetadata","lastEvent","_currentUserParticipated","Delete","updateThreadMetadata","toStartOfTimeline","addLocalEchoReceipt","getSender","ReceiptType","Read","onEcho","NewReply","Error","client","pendingEventOrdering","PendingEventOrdering","Chronological","timelineSet","EventTimelineSet","timelineSupport","pendingEvents","reEmitter","TypedReEmitter","reEmit","RoomEvent","Timeline","TimelineReset","on","MatrixEventEvent","BeforeRedaction","onBeforeRedaction","Redaction","onRedaction","LocalEchoUpdated","onLocalEcho","onTimelineEvent","processReceipts","receipts","setEventMetadata","fetchRootEvent","findEventById","eventData","fetchRoomEvent","roomId","mapper","getEventMapper","e","logger","error","processEvent","setServerSideSupport","FILTER_RELATED_BY_SENDERS","setPreferUnstable","FILTER_RELATED_BY_REL_TYPES","setServerSideListSupport","hasServerSideListSupport","setServerSideFwdPaginationSupport","hasServerSideFwdPaginationSupport","roomState","getLiveTimeline","getState","EventTimeline","FORWARDS","addEventToTimeline","liveTimeline","fromCache","events","addEvents","ev","addEvent","lastReply","isNewestReply","localTimestamp","decryptEventIfNeeded","initialEventsFetched","fetchEditsWhereNeeded","RelationType","Annotation","Replace","_this$timelineSet$rel","_this$timelineSet$rel2","_this$replayEvents","replayEvents","relations","aggregateParentEvent","aggregateChildEvent","eventId","receiptType","userId","receipt","synthetic","addReceiptToStructure","getRootEventBundledRelationship","getServerAggregatedRelation","processRootEvent","bundledRelationship","count","current_user_participated","latest_event","room_id","unfilteredPendingEvents","Detached","getPendingEvents","_this$lastEvent","lastPendingEvent","undefined","pendingReplyCount","resetLiveTimeline","backPaginationToken","forwardPaginationToken","oldLive","newLive","newBackward","oldForward","res","createMessagesRequest","Direction","Forward","end","Backward","start","getPaginationToken","_oldForward","setPaginationToken","_newBackward","addEventsToTimeline","paginateEventTimeline","backwards","limit","Math","max","Promise","all","isEncrypted","map","getType","then","makeReplaced","catch","setThread","_event$event","_event$event$unsigned","_event$event$unsigned2","unsigned","matches","replyToEvent","_ref","_this$lastPendingEven","getEvents","has","MatrixEvent","hasCurrentUserParticipated","getUnfilteredTimelineSet","addReceipt","getEventReadUpTo","ignoreSynthesized","isCurrentUser","getUserId","beforeFirstThreadedReceipt","getTs","getOldestThreadedReceiptTs","lastReplyId","readUpToId","unthreadedReceipt","getLastUnthreadedReceiptFor","_this$timeline","_ev$getId","ts","hasUserReadEvent","_this$lastReply$getTs","_this$lastReply","_this$room$getLastUnt","_this$room$getLastUnt2","_this$lastReply$getTs2","_this$lastReply2","unthreadedReceiptTs","beforeLastUnthreadedReceipt","setUnread","type","setThreadUnreadNotificationCount","ServerControlledNamespacedValue","ThreadFilterType","threadFilterTypeToFilter","My"],"sources":["../../src/models/thread.ts"],"sourcesContent":["/*\nCopyright 2021 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Optional } from \"matrix-events-sdk\";\n\nimport { MatrixClient, PendingEventOrdering } from \"../client\";\nimport { TypedReEmitter } from \"../ReEmitter\";\nimport { RelationType } from \"../@types/event\";\nimport { IThreadBundledRelationship, MatrixEvent, MatrixEventEvent } from \"./event\";\nimport { Direction, EventTimeline } from \"./event-timeline\";\nimport { EventTimelineSet, EventTimelineSetHandlerMap } from \"./event-timeline-set\";\nimport { NotificationCountType, Room, RoomEvent } from \"./room\";\nimport { RoomState } from \"./room-state\";\nimport { ServerControlledNamespacedValue } from \"../NamespacedValue\";\nimport { logger } from \"../logger\";\nimport { ReadReceipt } from \"./read-receipt\";\nimport { CachedReceiptStructure, ReceiptType } from \"../@types/read_receipts\";\n\nexport enum ThreadEvent {\n New = \"Thread.new\",\n Update = \"Thread.update\",\n NewReply = \"Thread.newReply\",\n ViewThread = \"Thread.viewThread\",\n Delete = \"Thread.delete\",\n}\n\ntype EmittedEvents = Exclude | RoomEvent.Timeline | RoomEvent.TimelineReset;\n\nexport type EventHandlerMap = {\n [ThreadEvent.Update]: (thread: Thread) => void;\n [ThreadEvent.NewReply]: (thread: Thread, event: MatrixEvent) => void;\n [ThreadEvent.ViewThread]: () => void;\n [ThreadEvent.Delete]: (thread: Thread) => void;\n} & EventTimelineSetHandlerMap;\n\ninterface IThreadOpts {\n room: Room;\n client: MatrixClient;\n pendingEventOrdering?: PendingEventOrdering;\n receipts?: CachedReceiptStructure[];\n}\n\nexport enum FeatureSupport {\n None = 0,\n Experimental = 1,\n Stable = 2,\n}\n\nexport function determineFeatureSupport(stable: boolean, unstable: boolean): FeatureSupport {\n if (stable) {\n return FeatureSupport.Stable;\n } else if (unstable) {\n return FeatureSupport.Experimental;\n } else {\n return FeatureSupport.None;\n }\n}\n\nexport class Thread extends ReadReceipt {\n public static hasServerSideSupport = FeatureSupport.None;\n public static hasServerSideListSupport = FeatureSupport.None;\n public static hasServerSideFwdPaginationSupport = FeatureSupport.None;\n\n /**\n * A reference to all the events ID at the bottom of the threads\n */\n public readonly timelineSet: EventTimelineSet;\n public timeline: MatrixEvent[] = [];\n\n private _currentUserParticipated = false;\n\n private reEmitter: TypedReEmitter;\n\n private lastEvent: MatrixEvent | undefined;\n private replyCount = 0;\n private lastPendingEvent: MatrixEvent | undefined;\n private pendingReplyCount = 0;\n\n public readonly room: Room;\n public readonly client: MatrixClient;\n private readonly pendingEventOrdering: PendingEventOrdering;\n\n public initialEventsFetched = !Thread.hasServerSideSupport;\n /**\n * An array of events to add to the timeline once the thread has been initialised\n * with server suppport.\n */\n public replayEvents: MatrixEvent[] | null = [];\n\n public constructor(public readonly id: string, public rootEvent: MatrixEvent | undefined, opts: IThreadOpts) {\n super();\n\n if (!opts?.room) {\n // Logging/debugging for https://github.com/vector-im/element-web/issues/22141\n // Hope is that we end up with a more obvious stack trace.\n throw new Error(\"element-web#22141: A thread requires a room in order to function\");\n }\n\n this.room = opts.room;\n this.client = opts.client;\n this.pendingEventOrdering = opts.pendingEventOrdering ?? PendingEventOrdering.Chronological;\n this.timelineSet = new EventTimelineSet(\n this.room,\n {\n timelineSupport: true,\n pendingEvents: true,\n },\n this.client,\n this,\n );\n this.reEmitter = new TypedReEmitter(this);\n\n this.reEmitter.reEmit(this.timelineSet, [RoomEvent.Timeline, RoomEvent.TimelineReset]);\n\n this.room.on(MatrixEventEvent.BeforeRedaction, this.onBeforeRedaction);\n this.room.on(RoomEvent.Redaction, this.onRedaction);\n this.room.on(RoomEvent.LocalEchoUpdated, this.onLocalEcho);\n this.timelineSet.on(RoomEvent.Timeline, this.onTimelineEvent);\n\n this.processReceipts(opts.receipts);\n\n // even if this thread is thought to be originating from this client, we initialise it as we may be in a\n // gappy sync and a thread around this event may already exist.\n this.updateThreadMetadata();\n this.setEventMetadata(this.rootEvent);\n }\n\n private async fetchRootEvent(): Promise {\n this.rootEvent = this.room.findEventById(this.id);\n // If the rootEvent does not exist in the local stores, then fetch it from the server.\n try {\n const eventData = await this.client.fetchRoomEvent(this.roomId, this.id);\n const mapper = this.client.getEventMapper();\n this.rootEvent = mapper(eventData); // will merge with existing event object if such is known\n } catch (e) {\n logger.error(\"Failed to fetch thread root to construct thread with\", e);\n }\n await this.processEvent(this.rootEvent);\n }\n\n public static setServerSideSupport(status: FeatureSupport): void {\n Thread.hasServerSideSupport = status;\n if (status !== FeatureSupport.Stable) {\n FILTER_RELATED_BY_SENDERS.setPreferUnstable(true);\n FILTER_RELATED_BY_REL_TYPES.setPreferUnstable(true);\n THREAD_RELATION_TYPE.setPreferUnstable(true);\n }\n }\n\n public static setServerSideListSupport(status: FeatureSupport): void {\n Thread.hasServerSideListSupport = status;\n }\n\n public static setServerSideFwdPaginationSupport(status: FeatureSupport): void {\n Thread.hasServerSideFwdPaginationSupport = status;\n }\n\n private onBeforeRedaction = (event: MatrixEvent, redaction: MatrixEvent): void => {\n if (\n event?.isRelation(THREAD_RELATION_TYPE.name) &&\n this.room.eventShouldLiveIn(event).threadId === this.id &&\n event.getId() !== this.id && // the root event isn't counted in the length so ignore this redaction\n !redaction.status // only respect it when it succeeds\n ) {\n this.replyCount--;\n this.updatePendingReplyCount();\n this.emit(ThreadEvent.Update, this);\n }\n };\n\n private onRedaction = async (event: MatrixEvent): Promise => {\n if (event.threadRootId !== this.id) return; // ignore redactions for other timelines\n if (this.replyCount <= 0) {\n for (const threadEvent of this.timeline) {\n this.clearEventMetadata(threadEvent);\n }\n this.lastEvent = this.rootEvent;\n this._currentUserParticipated = false;\n this.emit(ThreadEvent.Delete, this);\n } else {\n await this.updateThreadMetadata();\n }\n };\n\n private onTimelineEvent = (\n event: MatrixEvent,\n room: Room | undefined,\n toStartOfTimeline: boolean | undefined,\n ): void => {\n // Add a synthesized receipt when paginating forward in the timeline\n if (!toStartOfTimeline) {\n room!.addLocalEchoReceipt(event.getSender()!, event, ReceiptType.Read);\n }\n this.onEcho(event, toStartOfTimeline ?? false);\n };\n\n private onLocalEcho = (event: MatrixEvent): void => {\n this.onEcho(event, false);\n };\n\n private onEcho = async (event: MatrixEvent, toStartOfTimeline: boolean): Promise => {\n if (event.threadRootId !== this.id) return; // ignore echoes for other timelines\n if (this.lastEvent === event) return; // ignore duplicate events\n await this.updateThreadMetadata();\n if (!event.isRelation(THREAD_RELATION_TYPE.name)) return; // don't send a new reply event for reactions or edits\n if (toStartOfTimeline) return; // ignore messages added to the start of the timeline\n this.emit(ThreadEvent.NewReply, this, event);\n };\n\n public get roomState(): RoomState {\n return this.room.getLiveTimeline().getState(EventTimeline.FORWARDS)!;\n }\n\n private addEventToTimeline(event: MatrixEvent, toStartOfTimeline: boolean): void {\n if (!this.findEventById(event.getId()!)) {\n this.timelineSet.addEventToTimeline(event, this.liveTimeline, {\n toStartOfTimeline,\n fromCache: false,\n roomState: this.roomState,\n });\n this.timeline = this.events;\n }\n }\n\n public addEvents(events: MatrixEvent[], toStartOfTimeline: boolean): void {\n events.forEach((ev) => this.addEvent(ev, toStartOfTimeline, false));\n this.updateThreadMetadata();\n }\n\n /**\n * Add an event to the thread and updates\n * the tail/root references if needed\n * Will fire \"Thread.update\"\n * @param event - The event to add\n * @param toStartOfTimeline - whether the event is being added\n * to the start (and not the end) of the timeline.\n * @param emit - whether to emit the Update event if the thread was updated or not.\n */\n public async addEvent(event: MatrixEvent, toStartOfTimeline: boolean, emit = true): Promise {\n this.setEventMetadata(event);\n\n const lastReply = this.lastReply();\n const isNewestReply = !lastReply || event.localTimestamp >= lastReply!.localTimestamp;\n\n // Add all incoming events to the thread's timeline set when there's no server support\n if (!Thread.hasServerSideSupport) {\n // all the relevant membership info to hydrate events with a sender\n // is held in the main room timeline\n // We want to fetch the room state from there and pass it down to this thread\n // timeline set to let it reconcile an event with its relevant RoomMember\n this.addEventToTimeline(event, toStartOfTimeline);\n\n this.client.decryptEventIfNeeded(event, {});\n } else if (!toStartOfTimeline && this.initialEventsFetched && isNewestReply) {\n this.addEventToTimeline(event, false);\n this.fetchEditsWhereNeeded(event);\n } else if (event.isRelation(RelationType.Annotation) || event.isRelation(RelationType.Replace)) {\n if (!this.initialEventsFetched) {\n /**\n * A thread can be fully discovered via a single sync response\n * And when that's the case we still ask the server to do an initialisation\n * as it's the safest to ensure we have everything.\n * However when we are in that scenario we might loose annotation or edits\n *\n * This fix keeps a reference to those events and replay them once the thread\n * has been initialised properly.\n */\n this.replayEvents?.push(event);\n } else {\n this.addEventToTimeline(event, toStartOfTimeline);\n }\n // Apply annotations and replace relations to the relations of the timeline only\n this.timelineSet.relations?.aggregateParentEvent(event);\n this.timelineSet.relations?.aggregateChildEvent(event, this.timelineSet);\n return;\n }\n\n // If no thread support exists we want to count all thread relation\n // added as a reply. We can't rely on the bundled relationships count\n if ((!Thread.hasServerSideSupport || !this.rootEvent) && event.isRelation(THREAD_RELATION_TYPE.name)) {\n this.replyCount++;\n }\n\n if (emit) {\n this.emit(ThreadEvent.NewReply, this, event);\n this.updateThreadMetadata();\n }\n }\n\n public async processEvent(event: Optional): Promise {\n if (event) {\n this.setEventMetadata(event);\n await this.fetchEditsWhereNeeded(event);\n }\n this.timeline = this.events;\n }\n\n /**\n * Processes the receipts that were caught during initial sync\n * When clients become aware of a thread, they try to retrieve those read receipts\n * and apply them to the current thread\n * @param receipts - A collection of the receipts cached from initial sync\n */\n private processReceipts(receipts: CachedReceiptStructure[] = []): void {\n for (const { eventId, receiptType, userId, receipt, synthetic } of receipts) {\n this.addReceiptToStructure(eventId, receiptType as ReceiptType, userId, receipt, synthetic);\n }\n }\n\n private getRootEventBundledRelationship(rootEvent = this.rootEvent): IThreadBundledRelationship | undefined {\n return rootEvent?.getServerAggregatedRelation(THREAD_RELATION_TYPE.name);\n }\n\n private async processRootEvent(): Promise {\n const bundledRelationship = this.getRootEventBundledRelationship();\n if (Thread.hasServerSideSupport && bundledRelationship) {\n this.replyCount = bundledRelationship.count;\n this._currentUserParticipated = !!bundledRelationship.current_user_participated;\n\n const mapper = this.client.getEventMapper();\n // re-insert roomId\n this.lastEvent = mapper({\n ...bundledRelationship.latest_event,\n room_id: this.roomId,\n });\n this.updatePendingReplyCount();\n await this.processEvent(this.lastEvent);\n }\n }\n\n private updatePendingReplyCount(): void {\n const unfilteredPendingEvents =\n this.pendingEventOrdering === PendingEventOrdering.Detached ? this.room.getPendingEvents() : this.events;\n const pendingEvents = unfilteredPendingEvents.filter(\n (ev) =>\n ev.threadRootId === this.id &&\n ev.isRelation(THREAD_RELATION_TYPE.name) &&\n ev.status !== null &&\n ev.getId() !== this.lastEvent?.getId(),\n );\n this.lastPendingEvent = pendingEvents.length ? pendingEvents[pendingEvents.length - 1] : undefined;\n this.pendingReplyCount = pendingEvents.length;\n }\n\n /**\n * Reset the live timeline of all timelineSets, and start new ones.\n *\n *

This is used when /sync returns a 'limited' timeline. 'Limited' means that there's a gap between the messages\n * /sync returned, and the last known message in our timeline. In such a case, our live timeline isn't live anymore\n * and has to be replaced by a new one. To make sure we can continue paginating our timelines correctly, we have to\n * set new pagination tokens on the old and the new timeline.\n *\n * @param backPaginationToken - token for back-paginating the new timeline\n * @param forwardPaginationToken - token for forward-paginating the old live timeline,\n * if absent or null, all timelines are reset, removing old ones (including the previous live\n * timeline which would otherwise be unable to paginate forwards without this token).\n * Removing just the old live timeline whilst preserving previous ones is not supported.\n */\n public async resetLiveTimeline(\n backPaginationToken?: string | null,\n forwardPaginationToken?: string | null,\n ): Promise {\n const oldLive = this.liveTimeline;\n this.timelineSet.resetLiveTimeline(backPaginationToken ?? undefined, forwardPaginationToken ?? undefined);\n const newLive = this.liveTimeline;\n\n // FIXME: Remove the following as soon as https://github.com/matrix-org/synapse/issues/14830 is resolved.\n //\n // The pagination API for thread timelines currently can't handle the type of pagination tokens returned by sync\n //\n // To make this work anyway, we'll have to transform them into one of the types that the API can handle.\n // One option is passing the tokens to /messages, which can handle sync tokens, and returns the right format.\n // /messages does not return new tokens on requests with a limit of 0.\n // This means our timelines might overlap a slight bit, but that's not an issue, as we deduplicate messages\n // anyway.\n\n let newBackward: string | undefined;\n let oldForward: string | undefined;\n if (backPaginationToken) {\n const res = await this.client.createMessagesRequest(this.roomId, backPaginationToken, 1, Direction.Forward);\n newBackward = res.end;\n }\n if (forwardPaginationToken) {\n const res = await this.client.createMessagesRequest(\n this.roomId,\n forwardPaginationToken,\n 1,\n Direction.Backward,\n );\n oldForward = res.start;\n }\n // Only replace the token if we don't have paginated away from this position already. This situation doesn't\n // occur today, but if the above issue is resolved, we'd have to go down this path.\n if (forwardPaginationToken && oldLive.getPaginationToken(Direction.Forward) === forwardPaginationToken) {\n oldLive.setPaginationToken(oldForward ?? null, Direction.Forward);\n }\n if (backPaginationToken && newLive.getPaginationToken(Direction.Backward) === backPaginationToken) {\n newLive.setPaginationToken(newBackward ?? null, Direction.Backward);\n }\n }\n\n private async updateThreadMetadata(): Promise {\n this.updatePendingReplyCount();\n\n if (Thread.hasServerSideSupport) {\n // Ensure we show *something* as soon as possible, we'll update it as soon as we get better data, but we\n // don't want the thread preview to be empty if we can avoid it\n if (!this.initialEventsFetched) {\n await this.processRootEvent();\n }\n await this.fetchRootEvent();\n }\n await this.processRootEvent();\n\n if (!this.initialEventsFetched) {\n this.initialEventsFetched = true;\n // fetch initial event to allow proper pagination\n try {\n // if the thread has regular events, this will just load the last reply.\n // if the thread is newly created, this will load the root event.\n if (this.replyCount === 0 && this.rootEvent) {\n this.timelineSet.addEventsToTimeline([this.rootEvent], true, this.liveTimeline, null);\n this.liveTimeline.setPaginationToken(null, Direction.Backward);\n } else {\n await this.client.paginateEventTimeline(this.liveTimeline, {\n backwards: true,\n limit: Math.max(1, this.length),\n });\n }\n for (const event of this.replayEvents!) {\n this.addEvent(event, false);\n }\n this.replayEvents = null;\n // just to make sure that, if we've created a timeline window for this thread before the thread itself\n // existed (e.g. when creating a new thread), we'll make sure the panel is force refreshed correctly.\n this.emit(RoomEvent.TimelineReset, this.room, this.timelineSet, true);\n } catch (e) {\n logger.error(\"Failed to load start of newly created thread: \", e);\n this.initialEventsFetched = false;\n }\n }\n\n this.emit(ThreadEvent.Update, this);\n }\n\n // XXX: Workaround for https://github.com/matrix-org/matrix-spec-proposals/pull/2676/files#r827240084\n private async fetchEditsWhereNeeded(...events: MatrixEvent[]): Promise {\n return Promise.all(\n events\n .filter((e) => e.isEncrypted())\n .map((event: MatrixEvent) => {\n if (event.isRelation()) return; // skip - relations don't get edits\n return this.client\n .relations(this.roomId, event.getId()!, RelationType.Replace, event.getType(), {\n limit: 1,\n })\n .then((relations) => {\n if (relations.events.length) {\n event.makeReplaced(relations.events[0]);\n }\n })\n .catch((e) => {\n logger.error(\"Failed to load edits for encrypted thread event\", e);\n });\n }),\n );\n }\n\n public setEventMetadata(event: Optional): void {\n if (event) {\n EventTimeline.setEventMetadata(event, this.roomState, false);\n event.setThread(this);\n }\n }\n\n public clearEventMetadata(event: Optional): void {\n if (event) {\n event.setThread(undefined);\n delete event.event?.unsigned?.[\"m.relations\"]?.[THREAD_RELATION_TYPE.name];\n }\n }\n\n /**\n * Finds an event by ID in the current thread\n */\n public findEventById(eventId: string): MatrixEvent | undefined {\n return this.timelineSet.findEventById(eventId);\n }\n\n /**\n * Return last reply to the thread, if known.\n */\n public lastReply(matches: (ev: MatrixEvent) => boolean = (): boolean => true): MatrixEvent | null {\n for (let i = this.timeline.length - 1; i >= 0; i--) {\n const event = this.timeline[i];\n if (matches(event)) {\n return event;\n }\n }\n return null;\n }\n\n public get roomId(): string {\n return this.room.roomId;\n }\n\n /**\n * The number of messages in the thread\n * Only count rel_type=m.thread as we want to\n * exclude annotations from that number\n */\n public get length(): number {\n return this.replyCount + this.pendingReplyCount;\n }\n\n /**\n * A getter for the last event of the thread.\n * This might be a synthesized event, if so, it will not emit any events to listeners.\n */\n public get replyToEvent(): Optional {\n return this.lastPendingEvent ?? this.lastEvent ?? this.lastReply();\n }\n\n public get events(): MatrixEvent[] {\n return this.liveTimeline.getEvents();\n }\n\n public has(eventId: string): boolean {\n return this.timelineSet.findEventById(eventId) instanceof MatrixEvent;\n }\n\n public get hasCurrentUserParticipated(): boolean {\n return this._currentUserParticipated;\n }\n\n public get liveTimeline(): EventTimeline {\n return this.timelineSet.getLiveTimeline();\n }\n\n public getUnfilteredTimelineSet(): EventTimelineSet {\n return this.timelineSet;\n }\n\n public addReceipt(event: MatrixEvent, synthetic: boolean): void {\n throw new Error(\"Unsupported function on the thread model\");\n }\n\n /**\n * Get the ID of the event that a given user has read up to within this thread,\n * or null if we have received no read receipt (at all) from them.\n * @param userId - The user ID to get read receipt event ID for\n * @param ignoreSynthesized - If true, return only receipts that have been\n * sent by the server, not implicit ones generated\n * by the JS SDK.\n * @returns ID of the latest event that the given user has read, or null.\n */\n public getEventReadUpTo(userId: string, ignoreSynthesized?: boolean): string | null {\n const isCurrentUser = userId === this.client.getUserId();\n const lastReply = this.timeline[this.timeline.length - 1];\n if (isCurrentUser && lastReply) {\n // If the last activity in a thread is prior to the first threaded read receipt\n // sent in the room (suggesting that it was sent before the user started\n // using a client that supported threaded read receipts), we want to\n // consider this thread as read.\n const beforeFirstThreadedReceipt = lastReply.getTs() < this.room.getOldestThreadedReceiptTs();\n const lastReplyId = lastReply.getId();\n // Some unsent events do not have an ID, we do not want to consider them read\n if (beforeFirstThreadedReceipt && lastReplyId) {\n return lastReplyId;\n }\n }\n\n const readUpToId = super.getEventReadUpTo(userId, ignoreSynthesized);\n\n // Check whether the unthreaded read receipt for that user is more recent\n // than the read receipt inside that thread.\n if (lastReply) {\n const unthreadedReceipt = this.room.getLastUnthreadedReceiptFor(userId);\n if (!unthreadedReceipt) {\n return readUpToId;\n }\n\n for (let i = this.timeline?.length - 1; i >= 0; --i) {\n const ev = this.timeline[i];\n // If we encounter the `readUpToId` we do not need to look further\n // there is no \"more recent\" unthreaded read receipt\n if (ev.getId() === readUpToId) return readUpToId;\n\n // Inspecting events from most recent to oldest, we're checking\n // whether an unthreaded read receipt is more recent that the current event.\n // We usually prefer relying on the order of the DAG but in this scenario\n // it is not possible and we have to rely on timestamp\n if (ev.getTs() < unthreadedReceipt.ts) return ev.getId() ?? readUpToId;\n }\n }\n\n return readUpToId;\n }\n\n /**\n * Determine if the given user has read a particular event.\n *\n * It is invalid to call this method with an event that is not part of this thread.\n *\n * This is not a definitive check as it only checks the events that have been\n * loaded client-side at the time of execution.\n * @param userId - The user ID to check the read state of.\n * @param eventId - The event ID to check if the user read.\n * @returns True if the user has read the event, false otherwise.\n */\n public hasUserReadEvent(userId: string, eventId: string): boolean {\n if (userId === this.client.getUserId()) {\n // Consider an event read if it's part of a thread that is before the\n // first threaded receipt sent in that room. It is likely that it is\n // part of a thread that was created before MSC3771 was implemented.\n // Or before the last unthreaded receipt for the logged in user\n const beforeFirstThreadedReceipt =\n (this.lastReply()?.getTs() ?? 0) < this.room.getOldestThreadedReceiptTs();\n const unthreadedReceiptTs = this.room.getLastUnthreadedReceiptFor(userId)?.ts ?? 0;\n const beforeLastUnthreadedReceipt = (this?.lastReply()?.getTs() ?? 0) < unthreadedReceiptTs;\n if (beforeFirstThreadedReceipt || beforeLastUnthreadedReceipt) {\n return true;\n }\n }\n\n return super.hasUserReadEvent(userId, eventId);\n }\n\n public setUnread(type: NotificationCountType, count: number): void {\n return this.room.setThreadUnreadNotificationCount(this.id, type, count);\n }\n}\n\nexport const FILTER_RELATED_BY_SENDERS = new ServerControlledNamespacedValue(\n \"related_by_senders\",\n \"io.element.relation_senders\",\n);\nexport const FILTER_RELATED_BY_REL_TYPES = new ServerControlledNamespacedValue(\n \"related_by_rel_types\",\n \"io.element.relation_types\",\n);\nexport const THREAD_RELATION_TYPE = new ServerControlledNamespacedValue(\"m.thread\", \"io.element.thread\");\n\nexport enum ThreadFilterType {\n \"My\",\n \"All\",\n}\n\nexport function threadFilterTypeToFilter(type: ThreadFilterType | null): \"all\" | \"participated\" {\n switch (type) {\n case ThreadFilterType.My:\n return \"participated\";\n default:\n return \"all\";\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts deleted file mode 100644 index f6fd85c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts +++ /dev/null @@ -1,39 +0,0 @@ -/// -import { EventEmitter } from "events"; -export declare enum EventEmitterEvents { - NewListener = "newListener", - RemoveListener = "removeListener", - Error = "error" -} -type AnyListener = (...args: any) => any; -export type ListenerMap = { - [eventName in E]: AnyListener; -}; -type EventEmitterEventListener = (eventName: string, listener: AnyListener) => void; -type EventEmitterErrorListener = (error: Error) => void; -export type Listener, T extends E | EventEmitterEvents> = T extends E ? A[T] : T extends EventEmitterEvents ? EventEmitterErrorListener : EventEmitterEventListener; -/** - * Typed Event Emitter class which can act as a Base Model for all our model - * and communication events. - * This makes it much easier for us to distinguish between events, as we now need - * to properly type this, so that our events are not stringly-based and prone - * to silly typos. - */ -export declare class TypedEventEmitter, SuperclassArguments extends ListenerMap = Arguments> extends EventEmitter { - addListener(event: T, listener: Listener): this; - emit(event: T, ...args: Parameters): boolean; - emit(event: T, ...args: Parameters): boolean; - eventNames(): (Events | EventEmitterEvents)[]; - listenerCount(event: Events | EventEmitterEvents): number; - listeners(event: Events | EventEmitterEvents): ReturnType; - off(event: T, listener: Listener): this; - on(event: T, listener: Listener): this; - once(event: T, listener: Listener): this; - prependListener(event: T, listener: Listener): this; - prependOnceListener(event: T, listener: Listener): this; - removeAllListeners(event?: Events | EventEmitterEvents): this; - removeListener(event: T, listener: Listener): this; - rawListeners(event: Events | EventEmitterEvents): ReturnType; -} -export {}; -//# sourceMappingURL=typed-event-emitter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts.map deleted file mode 100644 index 5ac98df..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"typed-event-emitter.d.ts","sourceRoot":"","sources":["../../src/models/typed-event-emitter.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js deleted file mode 100644 index 57fa136..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js +++ /dev/null @@ -1,80 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TypedEventEmitter = exports.EventEmitterEvents = void 0; -var _events = require("events"); -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -// eslint-disable-next-line no-restricted-imports -let EventEmitterEvents; -exports.EventEmitterEvents = EventEmitterEvents; -(function (EventEmitterEvents) { - EventEmitterEvents["NewListener"] = "newListener"; - EventEmitterEvents["RemoveListener"] = "removeListener"; - EventEmitterEvents["Error"] = "error"; -})(EventEmitterEvents || (exports.EventEmitterEvents = EventEmitterEvents = {})); -/** - * Typed Event Emitter class which can act as a Base Model for all our model - * and communication events. - * This makes it much easier for us to distinguish between events, as we now need - * to properly type this, so that our events are not stringly-based and prone - * to silly typos. - */ -class TypedEventEmitter extends _events.EventEmitter { - addListener(event, listener) { - return super.addListener(event, listener); - } - emit(event, ...args) { - return super.emit(event, ...args); - } - eventNames() { - return super.eventNames(); - } - listenerCount(event) { - return super.listenerCount(event); - } - listeners(event) { - return super.listeners(event); - } - off(event, listener) { - return super.off(event, listener); - } - on(event, listener) { - return super.on(event, listener); - } - once(event, listener) { - return super.once(event, listener); - } - prependListener(event, listener) { - return super.prependListener(event, listener); - } - prependOnceListener(event, listener) { - return super.prependOnceListener(event, listener); - } - removeAllListeners(event) { - return super.removeAllListeners(event); - } - removeListener(event, listener) { - return super.removeListener(event, listener); - } - rawListeners(event) { - return super.rawListeners(event); - } -} -exports.TypedEventEmitter = TypedEventEmitter; -//# sourceMappingURL=typed-event-emitter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js.map deleted file mode 100644 index bf1770d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/typed-event-emitter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"typed-event-emitter.js","names":["_events","require","EventEmitterEvents","exports","TypedEventEmitter","EventEmitter","addListener","event","listener","emit","args","eventNames","listenerCount","listeners","off","on","once","prependListener","prependOnceListener","removeAllListeners","removeListener","rawListeners"],"sources":["../../src/models/typed-event-emitter.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n// eslint-disable-next-line no-restricted-imports\nimport { EventEmitter } from \"events\";\n\nexport enum EventEmitterEvents {\n NewListener = \"newListener\",\n RemoveListener = \"removeListener\",\n Error = \"error\",\n}\n\ntype AnyListener = (...args: any) => any;\nexport type ListenerMap = { [eventName in E]: AnyListener };\ntype EventEmitterEventListener = (eventName: string, listener: AnyListener) => void;\ntype EventEmitterErrorListener = (error: Error) => void;\n\nexport type Listener, T extends E | EventEmitterEvents> = T extends E\n ? A[T]\n : T extends EventEmitterEvents\n ? EventEmitterErrorListener\n : EventEmitterEventListener;\n\n/**\n * Typed Event Emitter class which can act as a Base Model for all our model\n * and communication events.\n * This makes it much easier for us to distinguish between events, as we now need\n * to properly type this, so that our events are not stringly-based and prone\n * to silly typos.\n */\nexport class TypedEventEmitter<\n Events extends string,\n Arguments extends ListenerMap,\n SuperclassArguments extends ListenerMap = Arguments,\n> extends EventEmitter {\n public addListener(\n event: T,\n listener: Listener,\n ): this {\n return super.addListener(event, listener);\n }\n\n public emit(event: T, ...args: Parameters): boolean;\n public emit(event: T, ...args: Parameters): boolean;\n public emit(event: T, ...args: any[]): boolean {\n return super.emit(event, ...args);\n }\n\n public eventNames(): (Events | EventEmitterEvents)[] {\n return super.eventNames() as Array;\n }\n\n public listenerCount(event: Events | EventEmitterEvents): number {\n return super.listenerCount(event);\n }\n\n public listeners(event: Events | EventEmitterEvents): ReturnType {\n return super.listeners(event);\n }\n\n public off(event: T, listener: Listener): this {\n return super.off(event, listener);\n }\n\n public on(event: T, listener: Listener): this {\n return super.on(event, listener);\n }\n\n public once(event: T, listener: Listener): this {\n return super.once(event, listener);\n }\n\n public prependListener(\n event: T,\n listener: Listener,\n ): this {\n return super.prependListener(event, listener);\n }\n\n public prependOnceListener(\n event: T,\n listener: Listener,\n ): this {\n return super.prependOnceListener(event, listener);\n }\n\n public removeAllListeners(event?: Events | EventEmitterEvents): this {\n return super.removeAllListeners(event);\n }\n\n public removeListener(\n event: T,\n listener: Listener,\n ): this {\n return super.removeListener(event, listener);\n }\n\n public rawListeners(event: Events | EventEmitterEvents): ReturnType {\n return super.rawListeners(event);\n }\n}\n"],"mappings":";;;;;;AAiBA,IAAAA,OAAA,GAAAC,OAAA;AAjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA,IAGYC,kBAAkB;AAAAC,OAAA,CAAAD,kBAAA,GAAAA,kBAAA;AAAA,WAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;AAAA,GAAlBA,kBAAkB,KAAAC,OAAA,CAAAD,kBAAA,GAAlBA,kBAAkB;AAiB9B;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAME,iBAAiB,SAIpBC,oBAAY,CAAC;EACZC,WAAWA,CACdC,KAAQ,EACRC,QAAwC,EACpC;IACJ,OAAO,KAAK,CAACF,WAAW,CAACC,KAAK,EAAEC,QAAQ,CAAC;EAC7C;EAIOC,IAAIA,CAAmBF,KAAQ,EAAE,GAAGG,IAAW,EAAW;IAC7D,OAAO,KAAK,CAACD,IAAI,CAACF,KAAK,EAAE,GAAGG,IAAI,CAAC;EACrC;EAEOC,UAAUA,CAAA,EAAoC;IACjD,OAAO,KAAK,CAACA,UAAU,EAAE;EAC7B;EAEOC,aAAaA,CAACL,KAAkC,EAAU;IAC7D,OAAO,KAAK,CAACK,aAAa,CAACL,KAAK,CAAC;EACrC;EAEOM,SAASA,CAACN,KAAkC,EAAyC;IACxF,OAAO,KAAK,CAACM,SAAS,CAACN,KAAK,CAAC;EACjC;EAEOO,GAAGA,CAAwCP,KAAQ,EAAEC,QAAwC,EAAQ;IACxG,OAAO,KAAK,CAACM,GAAG,CAACP,KAAK,EAAEC,QAAQ,CAAC;EACrC;EAEOO,EAAEA,CAAwCR,KAAQ,EAAEC,QAAwC,EAAQ;IACvG,OAAO,KAAK,CAACO,EAAE,CAACR,KAAK,EAAEC,QAAQ,CAAC;EACpC;EAEOQ,IAAIA,CAAwCT,KAAQ,EAAEC,QAAwC,EAAQ;IACzG,OAAO,KAAK,CAACQ,IAAI,CAACT,KAAK,EAAEC,QAAQ,CAAC;EACtC;EAEOS,eAAeA,CAClBV,KAAQ,EACRC,QAAwC,EACpC;IACJ,OAAO,KAAK,CAACS,eAAe,CAACV,KAAK,EAAEC,QAAQ,CAAC;EACjD;EAEOU,mBAAmBA,CACtBX,KAAQ,EACRC,QAAwC,EACpC;IACJ,OAAO,KAAK,CAACU,mBAAmB,CAACX,KAAK,EAAEC,QAAQ,CAAC;EACrD;EAEOW,kBAAkBA,CAACZ,KAAmC,EAAQ;IACjE,OAAO,KAAK,CAACY,kBAAkB,CAACZ,KAAK,CAAC;EAC1C;EAEOa,cAAcA,CACjBb,KAAQ,EACRC,QAAwC,EACpC;IACJ,OAAO,KAAK,CAACY,cAAc,CAACb,KAAK,EAAEC,QAAQ,CAAC;EAChD;EAEOa,YAAYA,CAACd,KAAkC,EAA4C;IAC9F,OAAO,KAAK,CAACc,YAAY,CAACd,KAAK,CAAC;EACpC;AACJ;AAACJ,OAAA,CAAAC,iBAAA,GAAAA,iBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts deleted file mode 100644 index 7dbfc5b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts +++ /dev/null @@ -1,185 +0,0 @@ -import { MatrixEvent } from "./event"; -import { TypedEventEmitter } from "./typed-event-emitter"; -export declare enum UserEvent { - DisplayName = "User.displayName", - AvatarUrl = "User.avatarUrl", - Presence = "User.presence", - CurrentlyActive = "User.currentlyActive", - LastPresenceTs = "User.lastPresenceTs" -} -export type UserEventHandlerMap = { - /** - * Fires whenever any user's display name changes. - * @param event - The matrix event which caused this event to fire. - * @param user - The user whose User.displayName changed. - * @example - * ``` - * matrixClient.on("User.displayName", function(event, user){ - * var newName = user.displayName; - * }); - * ``` - */ - [UserEvent.DisplayName]: (event: MatrixEvent | undefined, user: User) => void; - /** - * Fires whenever any user's avatar URL changes. - * @param event - The matrix event which caused this event to fire. - * @param user - The user whose User.avatarUrl changed. - * @example - * ``` - * matrixClient.on("User.avatarUrl", function(event, user){ - * var newUrl = user.avatarUrl; - * }); - * ``` - */ - [UserEvent.AvatarUrl]: (event: MatrixEvent | undefined, user: User) => void; - /** - * Fires whenever any user's presence changes. - * @param event - The matrix event which caused this event to fire. - * @param user - The user whose User.presence changed. - * @example - * ``` - * matrixClient.on("User.presence", function(event, user){ - * var newPresence = user.presence; - * }); - * ``` - */ - [UserEvent.Presence]: (event: MatrixEvent | undefined, user: User) => void; - /** - * Fires whenever any user's currentlyActive changes. - * @param event - The matrix event which caused this event to fire. - * @param user - The user whose User.currentlyActive changed. - * @example - * ``` - * matrixClient.on("User.currentlyActive", function(event, user){ - * var newCurrentlyActive = user.currentlyActive; - * }); - * ``` - */ - [UserEvent.CurrentlyActive]: (event: MatrixEvent | undefined, user: User) => void; - /** - * Fires whenever any user's lastPresenceTs changes, - * ie. whenever any presence event is received for a user. - * @param event - The matrix event which caused this event to fire. - * @param user - The user whose User.lastPresenceTs changed. - * @example - * ``` - * matrixClient.on("User.lastPresenceTs", function(event, user){ - * var newlastPresenceTs = user.lastPresenceTs; - * }); - * ``` - */ - [UserEvent.LastPresenceTs]: (event: MatrixEvent | undefined, user: User) => void; -}; -export declare class User extends TypedEventEmitter { - readonly userId: string; - private modified; - /** - * The 'displayname' of the user if known. - * @privateRemarks - * Should be read-only - */ - displayName?: string; - rawDisplayName?: string; - /** - * The 'avatar_url' of the user if known. - * @privateRemarks - * Should be read-only - */ - avatarUrl?: string; - /** - * The presence status message if known. - * @privateRemarks - * Should be read-only - */ - presenceStatusMsg?: string; - /** - * The presence enum if known. - * @privateRemarks - * Should be read-only - */ - presence: string; - /** - * Timestamp (ms since the epoch) for when we last received presence data for this user. - * We can subtract lastActiveAgo from this to approximate an absolute value for when a user was last active. - * @privateRemarks - * Should be read-only - */ - lastActiveAgo: number; - /** - * The time elapsed in ms since the user interacted proactively with the server, - * or we saw a message from the user - * @privateRemarks - * Should be read-only - */ - lastPresenceTs: number; - /** - * Whether we should consider lastActiveAgo to be an approximation - * and that the user should be seen as active 'now' - * @privateRemarks - * Should be read-only - */ - currentlyActive: boolean; - /** - * The events describing this user. - * @privateRemarks - * Should be read-only - */ - events: { - /** The m.presence event for this user. */ - presence?: MatrixEvent; - profile?: MatrixEvent; - }; - /** - * Construct a new User. A User must have an ID and can optionally have extra information associated with it. - * @param userId - Required. The ID of this user. - */ - constructor(userId: string); - /** - * Update this User with the given presence event. May fire "User.presence", - * "User.avatarUrl" and/or "User.displayName" if this event updates this user's - * properties. - * @param event - The `m.presence` event. - * - * @remarks - * Fires {@link UserEvent.Presence} - * Fires {@link UserEvent.DisplayName} - * Fires {@link UserEvent.AvatarUrl} - */ - setPresenceEvent(event: MatrixEvent): void; - /** - * Manually set this user's display name. No event is emitted in response to this - * as there is no underlying MatrixEvent to emit with. - * @param name - The new display name. - */ - setDisplayName(name: string): void; - /** - * Manually set this user's non-disambiguated display name. No event is emitted - * in response to this as there is no underlying MatrixEvent to emit with. - * @param name - The new display name. - */ - setRawDisplayName(name?: string): void; - /** - * Manually set this user's avatar URL. No event is emitted in response to this - * as there is no underlying MatrixEvent to emit with. - * @param url - The new avatar URL. - */ - setAvatarUrl(url?: string): void; - /** - * Update the last modified time to the current time. - */ - private updateModifiedTime; - /** - * Get the timestamp when this User was last updated. This timestamp is - * updated when this User receives a new Presence event which has updated a - * property on this object. It is updated before firing events. - * @returns The timestamp - */ - getLastModifiedTime(): number; - /** - * Get the absolute timestamp when this User was last known active on the server. - * It is *NOT* accurate if this.currentlyActive is true. - * @returns The timestamp - */ - getLastActiveTs(): number; -} -//# sourceMappingURL=user.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts.map deleted file mode 100644 index a21f2c0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../src/models/user.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,oBAAY,SAAS;IACjB,WAAW,qBAAqB;IAChC,SAAS,mBAAmB;IAC5B,QAAQ,kBAAkB;IAC1B,eAAe,yBAAyB;IACxC,cAAc,wBAAwB;CACzC;AAED,MAAM,MAAM,mBAAmB,GAAG;IAC9B;;;;;;;;;;OAUG;IACH,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAC9E;;;;;;;;;;OAUG;IACH,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAC5E;;;;;;;;;;OAUG;IACH,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAC3E;;;;;;;;;;OAUG;IACH,CAAC,SAAS,CAAC,eAAe,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAClF;;;;;;;;;;;OAWG;IACH,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;CACpF,CAAC;AAEF,qBAAa,IAAK,SAAQ,iBAAiB,CAAC,SAAS,EAAE,mBAAmB,CAAC;aAgEpC,MAAM,EAAE,MAAM;IA/DjD,OAAO,CAAC,QAAQ,CAAM;IAEtB;;;;OAIG;IACI,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,MAAM,CAAC;IAC/B;;;;OAIG;IACI,SAAS,CAAC,EAAE,MAAM,CAAC;IAC1B;;;;OAIG;IACI,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAClC;;;;OAIG;IACI,QAAQ,SAAa;IAC5B;;;;;OAKG;IACI,aAAa,SAAK;IACzB;;;;;OAKG;IACI,cAAc,SAAK;IAC1B;;;;;OAKG;IACI,eAAe,UAAS;IAC/B;;;;OAIG;IACI,MAAM,EAAE;QACX,0CAA0C;QAC1C,QAAQ,CAAC,EAAE,WAAW,CAAC;QACvB,OAAO,CAAC,EAAE,WAAW,CAAC;KACzB,CAAM;IAEP;;;OAGG;gBACgC,MAAM,EAAE,MAAM;IAOjD;;;;;;;;;;OAUG;IACI,gBAAgB,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI;IA+CjD;;;;OAIG;IACI,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAQzC;;;;OAIG;IACI,iBAAiB,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI;IAI7C;;;;OAIG;IACI,YAAY,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI;IAQvC;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAI1B;;;;;OAKG;IACI,mBAAmB,IAAI,MAAM;IAIpC;;;;OAIG;IACI,eAAe,IAAI,MAAM;CAGnC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js deleted file mode 100644 index ba78068..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js +++ /dev/null @@ -1,220 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.UserEvent = exports.User = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _typedEventEmitter = require("./typed-event-emitter"); -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let UserEvent; -exports.UserEvent = UserEvent; -(function (UserEvent) { - UserEvent["DisplayName"] = "User.displayName"; - UserEvent["AvatarUrl"] = "User.avatarUrl"; - UserEvent["Presence"] = "User.presence"; - UserEvent["CurrentlyActive"] = "User.currentlyActive"; - UserEvent["LastPresenceTs"] = "User.lastPresenceTs"; -})(UserEvent || (exports.UserEvent = UserEvent = {})); -class User extends _typedEventEmitter.TypedEventEmitter { - /** - * The 'displayname' of the user if known. - * @privateRemarks - * Should be read-only - */ - - /** - * The 'avatar_url' of the user if known. - * @privateRemarks - * Should be read-only - */ - - /** - * The presence status message if known. - * @privateRemarks - * Should be read-only - */ - - /** - * The presence enum if known. - * @privateRemarks - * Should be read-only - */ - - /** - * Timestamp (ms since the epoch) for when we last received presence data for this user. - * We can subtract lastActiveAgo from this to approximate an absolute value for when a user was last active. - * @privateRemarks - * Should be read-only - */ - - /** - * The time elapsed in ms since the user interacted proactively with the server, - * or we saw a message from the user - * @privateRemarks - * Should be read-only - */ - - /** - * Whether we should consider lastActiveAgo to be an approximation - * and that the user should be seen as active 'now' - * @privateRemarks - * Should be read-only - */ - - /** - * The events describing this user. - * @privateRemarks - * Should be read-only - */ - - /** - * Construct a new User. A User must have an ID and can optionally have extra information associated with it. - * @param userId - Required. The ID of this user. - */ - constructor(userId) { - super(); - this.userId = userId; - (0, _defineProperty2.default)(this, "modified", -1); - (0, _defineProperty2.default)(this, "displayName", void 0); - (0, _defineProperty2.default)(this, "rawDisplayName", void 0); - (0, _defineProperty2.default)(this, "avatarUrl", void 0); - (0, _defineProperty2.default)(this, "presenceStatusMsg", void 0); - (0, _defineProperty2.default)(this, "presence", "offline"); - (0, _defineProperty2.default)(this, "lastActiveAgo", 0); - (0, _defineProperty2.default)(this, "lastPresenceTs", 0); - (0, _defineProperty2.default)(this, "currentlyActive", false); - (0, _defineProperty2.default)(this, "events", {}); - this.displayName = userId; - this.rawDisplayName = userId; - this.updateModifiedTime(); - } - - /** - * Update this User with the given presence event. May fire "User.presence", - * "User.avatarUrl" and/or "User.displayName" if this event updates this user's - * properties. - * @param event - The `m.presence` event. - * - * @remarks - * Fires {@link UserEvent.Presence} - * Fires {@link UserEvent.DisplayName} - * Fires {@link UserEvent.AvatarUrl} - */ - setPresenceEvent(event) { - if (event.getType() !== "m.presence") { - return; - } - const firstFire = this.events.presence === null; - this.events.presence = event; - const eventsToFire = []; - if (event.getContent().presence !== this.presence || firstFire) { - eventsToFire.push(UserEvent.Presence); - } - if (event.getContent().avatar_url && event.getContent().avatar_url !== this.avatarUrl) { - eventsToFire.push(UserEvent.AvatarUrl); - } - if (event.getContent().displayname && event.getContent().displayname !== this.displayName) { - eventsToFire.push(UserEvent.DisplayName); - } - if (event.getContent().currently_active !== undefined && event.getContent().currently_active !== this.currentlyActive) { - eventsToFire.push(UserEvent.CurrentlyActive); - } - this.presence = event.getContent().presence; - eventsToFire.push(UserEvent.LastPresenceTs); - if (event.getContent().status_msg) { - this.presenceStatusMsg = event.getContent().status_msg; - } - if (event.getContent().displayname) { - this.displayName = event.getContent().displayname; - } - if (event.getContent().avatar_url) { - this.avatarUrl = event.getContent().avatar_url; - } - this.lastActiveAgo = event.getContent().last_active_ago; - this.lastPresenceTs = Date.now(); - this.currentlyActive = event.getContent().currently_active; - this.updateModifiedTime(); - for (const eventToFire of eventsToFire) { - this.emit(eventToFire, event, this); - } - } - - /** - * Manually set this user's display name. No event is emitted in response to this - * as there is no underlying MatrixEvent to emit with. - * @param name - The new display name. - */ - setDisplayName(name) { - const oldName = this.displayName; - this.displayName = name; - if (name !== oldName) { - this.updateModifiedTime(); - } - } - - /** - * Manually set this user's non-disambiguated display name. No event is emitted - * in response to this as there is no underlying MatrixEvent to emit with. - * @param name - The new display name. - */ - setRawDisplayName(name) { - this.rawDisplayName = name; - } - - /** - * Manually set this user's avatar URL. No event is emitted in response to this - * as there is no underlying MatrixEvent to emit with. - * @param url - The new avatar URL. - */ - setAvatarUrl(url) { - const oldUrl = this.avatarUrl; - this.avatarUrl = url; - if (url !== oldUrl) { - this.updateModifiedTime(); - } - } - - /** - * Update the last modified time to the current time. - */ - updateModifiedTime() { - this.modified = Date.now(); - } - - /** - * Get the timestamp when this User was last updated. This timestamp is - * updated when this User receives a new Presence event which has updated a - * property on this object. It is updated before firing events. - * @returns The timestamp - */ - getLastModifiedTime() { - return this.modified; - } - - /** - * Get the absolute timestamp when this User was last known active on the server. - * It is *NOT* accurate if this.currentlyActive is true. - * @returns The timestamp - */ - getLastActiveTs() { - return this.lastPresenceTs - this.lastActiveAgo; - } -} -exports.User = User; -//# sourceMappingURL=user.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js.map deleted file mode 100644 index fbc10e5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/models/user.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"user.js","names":["_typedEventEmitter","require","UserEvent","exports","User","TypedEventEmitter","constructor","userId","_defineProperty2","default","displayName","rawDisplayName","updateModifiedTime","setPresenceEvent","event","getType","firstFire","events","presence","eventsToFire","getContent","push","Presence","avatar_url","avatarUrl","AvatarUrl","displayname","DisplayName","currently_active","undefined","currentlyActive","CurrentlyActive","LastPresenceTs","status_msg","presenceStatusMsg","lastActiveAgo","last_active_ago","lastPresenceTs","Date","now","eventToFire","emit","setDisplayName","name","oldName","setRawDisplayName","setAvatarUrl","url","oldUrl","modified","getLastModifiedTime","getLastActiveTs"],"sources":["../../src/models/user.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixEvent } from \"./event\";\nimport { TypedEventEmitter } from \"./typed-event-emitter\";\n\nexport enum UserEvent {\n DisplayName = \"User.displayName\",\n AvatarUrl = \"User.avatarUrl\",\n Presence = \"User.presence\",\n CurrentlyActive = \"User.currentlyActive\",\n LastPresenceTs = \"User.lastPresenceTs\",\n}\n\nexport type UserEventHandlerMap = {\n /**\n * Fires whenever any user's display name changes.\n * @param event - The matrix event which caused this event to fire.\n * @param user - The user whose User.displayName changed.\n * @example\n * ```\n * matrixClient.on(\"User.displayName\", function(event, user){\n * var newName = user.displayName;\n * });\n * ```\n */\n [UserEvent.DisplayName]: (event: MatrixEvent | undefined, user: User) => void;\n /**\n * Fires whenever any user's avatar URL changes.\n * @param event - The matrix event which caused this event to fire.\n * @param user - The user whose User.avatarUrl changed.\n * @example\n * ```\n * matrixClient.on(\"User.avatarUrl\", function(event, user){\n * var newUrl = user.avatarUrl;\n * });\n * ```\n */\n [UserEvent.AvatarUrl]: (event: MatrixEvent | undefined, user: User) => void;\n /**\n * Fires whenever any user's presence changes.\n * @param event - The matrix event which caused this event to fire.\n * @param user - The user whose User.presence changed.\n * @example\n * ```\n * matrixClient.on(\"User.presence\", function(event, user){\n * var newPresence = user.presence;\n * });\n * ```\n */\n [UserEvent.Presence]: (event: MatrixEvent | undefined, user: User) => void;\n /**\n * Fires whenever any user's currentlyActive changes.\n * @param event - The matrix event which caused this event to fire.\n * @param user - The user whose User.currentlyActive changed.\n * @example\n * ```\n * matrixClient.on(\"User.currentlyActive\", function(event, user){\n * var newCurrentlyActive = user.currentlyActive;\n * });\n * ```\n */\n [UserEvent.CurrentlyActive]: (event: MatrixEvent | undefined, user: User) => void;\n /**\n * Fires whenever any user's lastPresenceTs changes,\n * ie. whenever any presence event is received for a user.\n * @param event - The matrix event which caused this event to fire.\n * @param user - The user whose User.lastPresenceTs changed.\n * @example\n * ```\n * matrixClient.on(\"User.lastPresenceTs\", function(event, user){\n * var newlastPresenceTs = user.lastPresenceTs;\n * });\n * ```\n */\n [UserEvent.LastPresenceTs]: (event: MatrixEvent | undefined, user: User) => void;\n};\n\nexport class User extends TypedEventEmitter {\n private modified = -1;\n\n /**\n * The 'displayname' of the user if known.\n * @privateRemarks\n * Should be read-only\n */\n public displayName?: string;\n public rawDisplayName?: string;\n /**\n * The 'avatar_url' of the user if known.\n * @privateRemarks\n * Should be read-only\n */\n public avatarUrl?: string;\n /**\n * The presence status message if known.\n * @privateRemarks\n * Should be read-only\n */\n public presenceStatusMsg?: string;\n /**\n * The presence enum if known.\n * @privateRemarks\n * Should be read-only\n */\n public presence = \"offline\";\n /**\n * Timestamp (ms since the epoch) for when we last received presence data for this user.\n * We can subtract lastActiveAgo from this to approximate an absolute value for when a user was last active.\n * @privateRemarks\n * Should be read-only\n */\n public lastActiveAgo = 0;\n /**\n * The time elapsed in ms since the user interacted proactively with the server,\n * or we saw a message from the user\n * @privateRemarks\n * Should be read-only\n */\n public lastPresenceTs = 0;\n /**\n * Whether we should consider lastActiveAgo to be an approximation\n * and that the user should be seen as active 'now'\n * @privateRemarks\n * Should be read-only\n */\n public currentlyActive = false;\n /**\n * The events describing this user.\n * @privateRemarks\n * Should be read-only\n */\n public events: {\n /** The m.presence event for this user. */\n presence?: MatrixEvent;\n profile?: MatrixEvent;\n } = {};\n\n /**\n * Construct a new User. A User must have an ID and can optionally have extra information associated with it.\n * @param userId - Required. The ID of this user.\n */\n public constructor(public readonly userId: string) {\n super();\n this.displayName = userId;\n this.rawDisplayName = userId;\n this.updateModifiedTime();\n }\n\n /**\n * Update this User with the given presence event. May fire \"User.presence\",\n * \"User.avatarUrl\" and/or \"User.displayName\" if this event updates this user's\n * properties.\n * @param event - The `m.presence` event.\n *\n * @remarks\n * Fires {@link UserEvent.Presence}\n * Fires {@link UserEvent.DisplayName}\n * Fires {@link UserEvent.AvatarUrl}\n */\n public setPresenceEvent(event: MatrixEvent): void {\n if (event.getType() !== \"m.presence\") {\n return;\n }\n const firstFire = this.events.presence === null;\n this.events.presence = event;\n\n const eventsToFire: UserEvent[] = [];\n if (event.getContent().presence !== this.presence || firstFire) {\n eventsToFire.push(UserEvent.Presence);\n }\n if (event.getContent().avatar_url && event.getContent().avatar_url !== this.avatarUrl) {\n eventsToFire.push(UserEvent.AvatarUrl);\n }\n if (event.getContent().displayname && event.getContent().displayname !== this.displayName) {\n eventsToFire.push(UserEvent.DisplayName);\n }\n if (\n event.getContent().currently_active !== undefined &&\n event.getContent().currently_active !== this.currentlyActive\n ) {\n eventsToFire.push(UserEvent.CurrentlyActive);\n }\n\n this.presence = event.getContent().presence;\n eventsToFire.push(UserEvent.LastPresenceTs);\n\n if (event.getContent().status_msg) {\n this.presenceStatusMsg = event.getContent().status_msg;\n }\n if (event.getContent().displayname) {\n this.displayName = event.getContent().displayname;\n }\n if (event.getContent().avatar_url) {\n this.avatarUrl = event.getContent().avatar_url;\n }\n this.lastActiveAgo = event.getContent().last_active_ago;\n this.lastPresenceTs = Date.now();\n this.currentlyActive = event.getContent().currently_active;\n\n this.updateModifiedTime();\n\n for (const eventToFire of eventsToFire) {\n this.emit(eventToFire, event, this);\n }\n }\n\n /**\n * Manually set this user's display name. No event is emitted in response to this\n * as there is no underlying MatrixEvent to emit with.\n * @param name - The new display name.\n */\n public setDisplayName(name: string): void {\n const oldName = this.displayName;\n this.displayName = name;\n if (name !== oldName) {\n this.updateModifiedTime();\n }\n }\n\n /**\n * Manually set this user's non-disambiguated display name. No event is emitted\n * in response to this as there is no underlying MatrixEvent to emit with.\n * @param name - The new display name.\n */\n public setRawDisplayName(name?: string): void {\n this.rawDisplayName = name;\n }\n\n /**\n * Manually set this user's avatar URL. No event is emitted in response to this\n * as there is no underlying MatrixEvent to emit with.\n * @param url - The new avatar URL.\n */\n public setAvatarUrl(url?: string): void {\n const oldUrl = this.avatarUrl;\n this.avatarUrl = url;\n if (url !== oldUrl) {\n this.updateModifiedTime();\n }\n }\n\n /**\n * Update the last modified time to the current time.\n */\n private updateModifiedTime(): void {\n this.modified = Date.now();\n }\n\n /**\n * Get the timestamp when this User was last updated. This timestamp is\n * updated when this User receives a new Presence event which has updated a\n * property on this object. It is updated before firing events.\n * @returns The timestamp\n */\n public getLastModifiedTime(): number {\n return this.modified;\n }\n\n /**\n * Get the absolute timestamp when this User was last known active on the server.\n * It is *NOT* accurate if this.currentlyActive is true.\n * @returns The timestamp\n */\n public getLastActiveTs(): number {\n return this.lastPresenceTs - this.lastActiveAgo;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts deleted file mode 100644 index c0d6ed5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts +++ /dev/null @@ -1,124 +0,0 @@ -import { MatrixClient } from "./client"; -import { MatrixEvent } from "./models/event"; -import { IPushRule, IPushRules, PushRuleAction, PushRuleKind, TweakName } from "./@types/PushRules"; -export interface IActionsObject { - /** Whether this event should notify the user or not. */ - notify: boolean; - /** How this event should be notified. */ - tweaks: Partial>; -} -export declare class PushProcessor { - private readonly client; - /** - * Construct a Push Processor. - * @param client - The Matrix client object to use - */ - constructor(client: MatrixClient); - /** - * Maps the original key from the push rules to a list of property names - * after unescaping. - */ - private readonly parsedKeys; - /** - * Convert a list of actions into a object with the actions as keys and their values - * @example - * eg. `[ 'notify', { set_tweak: 'sound', value: 'default' } ]` - * becomes `{ notify: true, tweaks: { sound: 'default' } }` - * @param actionList - The actions list - * - * @returns A object with key 'notify' (true or false) and an object of actions - */ - static actionListToActionsObject(actionList: PushRuleAction[]): IActionsObject; - /** - * Rewrites conditions on a client's push rules to match the defaults - * where applicable. Useful for upgrading push rules to more strict - * conditions when the server is falling behind on defaults. - * @param incomingRules - The client's existing push rules - * @param userId - The Matrix ID of the client. - * @returns The rewritten rules - */ - static rewriteDefaultRules(incomingRules: IPushRules, userId?: string | undefined): IPushRules; - /** - * Pre-caches the parsed keys for push rules and cleans out any obsolete cache - * entries. Should be called after push rules are updated. - * @param newRules - The new push rules. - */ - updateCachedPushRuleKeys(newRules: IPushRules): void; - private static cachedGlobToRegex; - private matchingRuleFromKindSet; - private templateRuleToRaw; - private eventFulfillsCondition; - private eventFulfillsSenderNotifPermCondition; - private eventFulfillsRoomMemberCountCondition; - private eventFulfillsDisplayNameCondition; - /** - * Check whether the given event matches the push rule condition by fetching - * the property from the event and comparing against the condition's glob-based - * pattern. - * @param cond - The push rule condition to check for a match. - * @param ev - The event to check for a match. - */ - private eventFulfillsEventMatchCondition; - /** - * Check whether the given event matches the push rule condition by fetching - * the property from the event and comparing exactly against the condition's - * value. - * @param cond - The push rule condition to check for a match. - * @param ev - The event to check for a match. - */ - private eventFulfillsEventPropertyIsCondition; - /** - * Check whether the given event matches the push rule condition by fetching - * the property from the event and comparing exactly against the condition's - * value. - * @param cond - The push rule condition to check for a match. - * @param ev - The event to check for a match. - */ - private eventFulfillsEventPropertyContains; - private eventFulfillsCallStartedCondition; - private createCachedRegex; - /** - * Parse the key into the separate fields to search by splitting on - * unescaped ".", and then removing any escape characters. - * - * @param str - The key of the push rule condition: a dotted field. - * @returns The unescaped parts to fetch. - * @internal - */ - static partsForDottedKey(str: string): string[]; - /** - * For a dotted field and event, fetch the value at that position, if one - * exists. - * - * @param key - The key of the push rule condition: a dotted field to fetch. - * @param ev - The matrix event to fetch the field from. - * @returns The value at the dotted path given by key. - */ - private valueForDottedKey; - private matchingRuleForEventWithRulesets; - private pushActionsForEventAndRulesets; - ruleMatchesEvent(rule: Partial & Pick, ev: MatrixEvent): boolean; - /** - * Get the user's push actions for the given event - */ - actionsForEvent(ev: MatrixEvent): IActionsObject; - /** - * Get one of the users push rules by its ID - * - * @param ruleId - The ID of the rule to search for - * @returns The push rule, or null if no such rule was found - */ - getPushRuleById(ruleId: string): IPushRule | null; - /** - * Get one of the users push rules by its ID - * - * @param ruleId - The ID of the rule to search for - * @returns rule The push rule, or null if no such rule was found - * @returns kind - The PushRuleKind of the rule to search for - */ - getPushRuleAndKindById(ruleId: string): { - rule: IPushRule; - kind: PushRuleKind; - } | null; -} -//# sourceMappingURL=pushprocessor.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts.map deleted file mode 100644 index 311967b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"pushprocessor.d.ts","sourceRoot":"","sources":["../src/pushprocessor.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EASH,SAAS,EACT,UAAU,EAGV,cAAc,EAGd,YAAY,EAGZ,SAAS,EACZ,MAAM,oBAAoB,CAAC;AAwG5B,MAAM,WAAW,cAAc;IAC3B,wDAAwD;IACxD,MAAM,EAAE,OAAO,CAAC;IAChB,yCAAyC;IACzC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC;CAC3C;AAED,qBAAa,aAAa;IAKH,OAAO,CAAC,QAAQ,CAAC,MAAM;IAJ1C;;;OAGG;gBACiC,MAAM,EAAE,YAAY;IAExD;;;OAGG;IACH,OAAO,CAAC,QAAQ,CAAC,UAAU,CAA+B;IAE1D;;;;;;;;OAQG;WACW,yBAAyB,CAAC,UAAU,EAAE,cAAc,EAAE,GAAG,cAAc;IAerF;;;;;;;OAOG;WACW,mBAAmB,CAAC,aAAa,EAAE,UAAU,EAAE,MAAM,GAAE,MAAM,GAAG,SAAqB,GAAG,UAAU;IA8DhH;;;;OAIG;IACI,wBAAwB,CAAC,QAAQ,EAAE,UAAU,GAAG,IAAI;IA0C3D,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAA8B;IAE9D,OAAO,CAAC,uBAAuB;IA4B/B,OAAO,CAAC,iBAAiB;IAgDzB,OAAO,CAAC,sBAAsB;IAyB9B,OAAO,CAAC,qCAAqC;IAoB7C,OAAO,CAAC,qCAAqC;IAsC7C,OAAO,CAAC,iCAAiC;IAuBzC;;;;;;OAMG;IACH,OAAO,CAAC,gCAAgC;IA6BxC;;;;;;OAMG;IACH,OAAO,CAAC,qCAAqC;IAO7C;;;;;;OAMG;IACH,OAAO,CAAC,kCAAkC;IAW1C,OAAO,CAAC,iCAAiC;IAczC,OAAO,CAAC,iBAAiB;IAWzB;;;;;;;OAOG;WACW,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,EAAE;IAkDtD;;;;;;;OAOG;IACH,OAAO,CAAC,iBAAiB;IAsCzB,OAAO,CAAC,gCAAgC;IAWxC,OAAO,CAAC,8BAA8B;IAkB/B,gBAAgB,CAAC,IAAI,EAAE,OAAO,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC,EAAE,EAAE,EAAE,WAAW,GAAG,OAAO;IAe3G;;OAEG;IACI,eAAe,CAAC,EAAE,EAAE,WAAW,GAAG,cAAc;IAIvD;;;;;OAKG;IACI,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAKxD;;;;;;OAMG;IACI,sBAAsB,CAAC,MAAM,EAAE,MAAM,GAAG;QAAE,IAAI,EAAE,SAAS,CAAC;QAAC,IAAI,EAAE,YAAY,CAAA;KAAE,GAAG,IAAI;CAchG"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js deleted file mode 100644 index 75e9c24..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js +++ /dev/null @@ -1,660 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.PushProcessor = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _utils = require("./utils"); -var _logger = require("./logger"); -var _PushRules = require("./@types/PushRules"); -var _event = require("./@types/event"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -const RULEKINDS_IN_ORDER = [_PushRules.PushRuleKind.Override, _PushRules.PushRuleKind.ContentSpecific, _PushRules.PushRuleKind.RoomSpecific, _PushRules.PushRuleKind.SenderSpecific, _PushRules.PushRuleKind.Underride]; - -// The default override rules to apply to the push rules that arrive from the server. -// We do this for two reasons: -// 1. Synapse is unlikely to send us the push rule in an incremental sync - see -// https://github.com/matrix-org/synapse/pull/4867#issuecomment-481446072 for -// more details. -// 2. We often want to start using push rules ahead of the server supporting them, -// and so we can put them here. -const DEFAULT_OVERRIDE_RULES = [{ - // For homeservers which don't support MSC2153 yet - rule_id: ".m.rule.reaction", - default: true, - enabled: true, - conditions: [{ - kind: _PushRules.ConditionKind.EventMatch, - key: "type", - pattern: "m.reaction" - }], - actions: [_PushRules.PushRuleActionName.DontNotify] -}, { - rule_id: _PushRules.RuleId.IsUserMention, - default: true, - enabled: true, - conditions: [{ - kind: _PushRules.ConditionKind.EventPropertyContains, - key: "content.org\\.matrix\\.msc3952\\.mentions.user_ids", - value: "" // The user ID is dynamically added in rewriteDefaultRules. - }], - - actions: [_PushRules.PushRuleActionName.Notify, { - set_tweak: _PushRules.TweakName.Highlight - }] -}, { - rule_id: _PushRules.RuleId.IsRoomMention, - default: true, - enabled: true, - conditions: [{ - kind: _PushRules.ConditionKind.EventPropertyIs, - key: "content.org\\.matrix\\.msc3952\\.mentions.room", - value: true - }, { - kind: _PushRules.ConditionKind.SenderNotificationPermission, - key: "room" - }], - actions: [_PushRules.PushRuleActionName.Notify, { - set_tweak: _PushRules.TweakName.Highlight - }] -}, { - // For homeservers which don't support MSC3786 yet - rule_id: ".org.matrix.msc3786.rule.room.server_acl", - default: true, - enabled: true, - conditions: [{ - kind: _PushRules.ConditionKind.EventMatch, - key: "type", - pattern: _event.EventType.RoomServerAcl - }, { - kind: _PushRules.ConditionKind.EventMatch, - key: "state_key", - pattern: "" - }], - actions: [] -}]; -const DEFAULT_UNDERRIDE_RULES = [{ - // For homeservers which don't support MSC3914 yet - rule_id: ".org.matrix.msc3914.rule.room.call", - default: true, - enabled: true, - conditions: [{ - kind: _PushRules.ConditionKind.EventMatch, - key: "type", - pattern: "org.matrix.msc3401.call" - }, { - kind: _PushRules.ConditionKind.CallStarted - }], - actions: [_PushRules.PushRuleActionName.Notify, { - set_tweak: _PushRules.TweakName.Sound, - value: "default" - }] -}]; -class PushProcessor { - /** - * Construct a Push Processor. - * @param client - The Matrix client object to use - */ - constructor(client) { - this.client = client; - (0, _defineProperty2.default)(this, "parsedKeys", new Map()); - } - - /** - * Maps the original key from the push rules to a list of property names - * after unescaping. - */ - - /** - * Convert a list of actions into a object with the actions as keys and their values - * @example - * eg. `[ 'notify', { set_tweak: 'sound', value: 'default' } ]` - * becomes `{ notify: true, tweaks: { sound: 'default' } }` - * @param actionList - The actions list - * - * @returns A object with key 'notify' (true or false) and an object of actions - */ - static actionListToActionsObject(actionList) { - const actionObj = { - notify: false, - tweaks: {} - }; - for (const action of actionList) { - if (action === _PushRules.PushRuleActionName.Notify) { - actionObj.notify = true; - } else if (typeof action === "object") { - if (action.value === undefined) { - action.value = true; - } - actionObj.tweaks[action.set_tweak] = action.value; - } - } - return actionObj; - } - - /** - * Rewrites conditions on a client's push rules to match the defaults - * where applicable. Useful for upgrading push rules to more strict - * conditions when the server is falling behind on defaults. - * @param incomingRules - The client's existing push rules - * @param userId - The Matrix ID of the client. - * @returns The rewritten rules - */ - static rewriteDefaultRules(incomingRules, userId = undefined) { - var _newRules$global$unde; - let newRules = JSON.parse(JSON.stringify(incomingRules)); // deep clone - - // These lines are mostly to make the tests happy. We shouldn't run into these - // properties missing in practice. - if (!newRules) newRules = {}; - if (!newRules.global) newRules.global = {}; - if (!newRules.global.override) newRules.global.override = []; - if (!newRules.global.underride) newRules.global.underride = []; - - // Merge the client-level defaults with the ones from the server - const globalOverrides = newRules.global.override; - for (const originalOverride of DEFAULT_OVERRIDE_RULES) { - const existingRule = globalOverrides.find(r => r.rule_id === originalOverride.rule_id); - - // Dynamically add the user ID as the value for the is_user_mention rule. - let override; - if (originalOverride.rule_id === _PushRules.RuleId.IsUserMention) { - // If the user ID wasn't provided, skip the rule. - if (!userId) { - continue; - } - override = JSON.parse(JSON.stringify(originalOverride)); // deep clone - override.conditions[0].value = userId; - } else { - override = originalOverride; - } - if (existingRule) { - // Copy over the actions, default, and conditions. Don't touch the user's preference. - existingRule.default = override.default; - existingRule.conditions = override.conditions; - existingRule.actions = override.actions; - } else { - // Add the rule - const ruleId = override.rule_id; - _logger.logger.warn(`Adding default global override for ${ruleId}`); - globalOverrides.push(override); - } - } - const globalUnderrides = (_newRules$global$unde = newRules.global.underride) !== null && _newRules$global$unde !== void 0 ? _newRules$global$unde : []; - for (const underride of DEFAULT_UNDERRIDE_RULES) { - const existingRule = globalUnderrides.find(r => r.rule_id === underride.rule_id); - if (existingRule) { - // Copy over the actions, default, and conditions. Don't touch the user's preference. - existingRule.default = underride.default; - existingRule.conditions = underride.conditions; - existingRule.actions = underride.actions; - } else { - // Add the rule - const ruleId = underride.rule_id; - _logger.logger.warn(`Adding default global underride for ${ruleId}`); - globalUnderrides.push(underride); - } - } - return newRules; - } - - /** - * Pre-caches the parsed keys for push rules and cleans out any obsolete cache - * entries. Should be called after push rules are updated. - * @param newRules - The new push rules. - */ - updateCachedPushRuleKeys(newRules) { - // These lines are mostly to make the tests happy. We shouldn't run into these - // properties missing in practice. - if (!newRules) newRules = {}; - if (!newRules.global) newRules.global = {}; - if (!newRules.global.override) newRules.global.override = []; - if (!newRules.global.room) newRules.global.room = []; - if (!newRules.global.sender) newRules.global.sender = []; - if (!newRules.global.underride) newRules.global.underride = []; - - // Process the 'key' property on event_match conditions pre-cache the - // values and clean-out any unused values. - const toRemoveKeys = new Set(this.parsedKeys.keys()); - for (const ruleset of [newRules.global.override, newRules.global.room, newRules.global.sender, newRules.global.underride]) { - for (const rule of ruleset) { - if (!rule.conditions) { - continue; - } - for (const condition of rule.conditions) { - if (condition.kind !== _PushRules.ConditionKind.EventMatch) { - continue; - } - - // Ensure we keep this key. - toRemoveKeys.delete(condition.key); - - // Pre-process the key. - this.parsedKeys.set(condition.key, PushProcessor.partsForDottedKey(condition.key)); - } - } - } - // Any keys that were previously cached, but are no longer needed should - // be removed. - toRemoveKeys.forEach(k => this.parsedKeys.delete(k)); - } - // $glob: RegExp - - matchingRuleFromKindSet(ev, kindset) { - for (const kind of RULEKINDS_IN_ORDER) { - const ruleset = kindset[kind]; - if (!ruleset) { - continue; - } - for (const rule of ruleset) { - if (!rule.enabled) { - continue; - } - const rawrule = this.templateRuleToRaw(kind, rule); - if (!rawrule) { - continue; - } - if (this.ruleMatchesEvent(rawrule, ev)) { - return _objectSpread(_objectSpread({}, rule), {}, { - kind - }); - } - } - } - return null; - } - templateRuleToRaw(kind, tprule) { - const rawrule = { - rule_id: tprule.rule_id, - actions: tprule.actions, - conditions: [] - }; - switch (kind) { - case _PushRules.PushRuleKind.Underride: - case _PushRules.PushRuleKind.Override: - rawrule.conditions = tprule.conditions; - break; - case _PushRules.PushRuleKind.RoomSpecific: - if (!tprule.rule_id) { - return null; - } - rawrule.conditions.push({ - kind: _PushRules.ConditionKind.EventMatch, - key: "room_id", - value: tprule.rule_id - }); - break; - case _PushRules.PushRuleKind.SenderSpecific: - if (!tprule.rule_id) { - return null; - } - rawrule.conditions.push({ - kind: _PushRules.ConditionKind.EventMatch, - key: "user_id", - value: tprule.rule_id - }); - break; - case _PushRules.PushRuleKind.ContentSpecific: - if (!tprule.pattern) { - return null; - } - rawrule.conditions.push({ - kind: _PushRules.ConditionKind.EventMatch, - key: "content.body", - pattern: tprule.pattern - }); - break; - } - return rawrule; - } - eventFulfillsCondition(cond, ev) { - switch (cond.kind) { - case _PushRules.ConditionKind.EventMatch: - return this.eventFulfillsEventMatchCondition(cond, ev); - case _PushRules.ConditionKind.EventPropertyIs: - return this.eventFulfillsEventPropertyIsCondition(cond, ev); - case _PushRules.ConditionKind.EventPropertyContains: - return this.eventFulfillsEventPropertyContains(cond, ev); - case _PushRules.ConditionKind.ContainsDisplayName: - return this.eventFulfillsDisplayNameCondition(cond, ev); - case _PushRules.ConditionKind.RoomMemberCount: - return this.eventFulfillsRoomMemberCountCondition(cond, ev); - case _PushRules.ConditionKind.SenderNotificationPermission: - return this.eventFulfillsSenderNotifPermCondition(cond, ev); - case _PushRules.ConditionKind.CallStarted: - case _PushRules.ConditionKind.CallStartedPrefix: - return this.eventFulfillsCallStartedCondition(cond, ev); - } - - // unknown conditions: we previously matched all unknown conditions, - // but given that rules can be added to the base rules on a server, - // it's probably better to not match unknown conditions. - return false; - } - eventFulfillsSenderNotifPermCondition(cond, ev) { - const notifLevelKey = cond["key"]; - if (!notifLevelKey) { - return false; - } - const room = this.client.getRoom(ev.getRoomId()); - if (!(room !== null && room !== void 0 && room.currentState)) { - return false; - } - - // Note that this should not be the current state of the room but the state at - // the point the event is in the DAG. Unfortunately the js-sdk does not store - // this. - return room.currentState.mayTriggerNotifOfType(notifLevelKey, ev.getSender()); - } - eventFulfillsRoomMemberCountCondition(cond, ev) { - if (!cond.is) { - return false; - } - const room = this.client.getRoom(ev.getRoomId()); - if (!room || !room.currentState || !room.currentState.members) { - return false; - } - const memberCount = room.currentState.getJoinedMemberCount(); - const m = cond.is.match(/^([=<>]*)(\d*)$/); - if (!m) { - return false; - } - const ineq = m[1]; - const rhs = parseInt(m[2]); - if (isNaN(rhs)) { - return false; - } - switch (ineq) { - case "": - case "==": - return memberCount == rhs; - case "<": - return memberCount < rhs; - case ">": - return memberCount > rhs; - case "<=": - return memberCount <= rhs; - case ">=": - return memberCount >= rhs; - default: - return false; - } - } - eventFulfillsDisplayNameCondition(cond, ev) { - var _room$currentState; - let content = ev.getContent(); - if (ev.isEncrypted() && ev.getClearContent()) { - content = ev.getClearContent(); - } - if (!content || !content.body || typeof content.body != "string") { - return false; - } - const room = this.client.getRoom(ev.getRoomId()); - const member = room === null || room === void 0 ? void 0 : (_room$currentState = room.currentState) === null || _room$currentState === void 0 ? void 0 : _room$currentState.getMember(this.client.credentials.userId); - if (!member) { - return false; - } - const displayName = member.name; - - // N.B. we can't use \b as it chokes on unicode. however \W seems to be okay - // as shorthand for [^0-9A-Za-z_]. - const pat = new RegExp("(^|\\W)" + (0, _utils.escapeRegExp)(displayName) + "(\\W|$)", "i"); - return content.body.search(pat) > -1; - } - - /** - * Check whether the given event matches the push rule condition by fetching - * the property from the event and comparing against the condition's glob-based - * pattern. - * @param cond - The push rule condition to check for a match. - * @param ev - The event to check for a match. - */ - eventFulfillsEventMatchCondition(cond, ev) { - if (!cond.key) { - return false; - } - const val = this.valueForDottedKey(cond.key, ev); - if (typeof val !== "string") { - return false; - } - - // XXX This does not match in a case-insensitive manner. - // - // See https://spec.matrix.org/v1.5/client-server-api/#conditions-1 - if (cond.value) { - return cond.value === val; - } - if (typeof cond.pattern !== "string") { - return false; - } - const regex = cond.key === "content.body" ? this.createCachedRegex("(^|\\W)", cond.pattern, "(\\W|$)") : this.createCachedRegex("^", cond.pattern, "$"); - return !!val.match(regex); - } - - /** - * Check whether the given event matches the push rule condition by fetching - * the property from the event and comparing exactly against the condition's - * value. - * @param cond - The push rule condition to check for a match. - * @param ev - The event to check for a match. - */ - eventFulfillsEventPropertyIsCondition(cond, ev) { - if (!cond.key || cond.value === undefined) { - return false; - } - return cond.value === this.valueForDottedKey(cond.key, ev); - } - - /** - * Check whether the given event matches the push rule condition by fetching - * the property from the event and comparing exactly against the condition's - * value. - * @param cond - The push rule condition to check for a match. - * @param ev - The event to check for a match. - */ - eventFulfillsEventPropertyContains(cond, ev) { - if (!cond.key || cond.value === undefined) { - return false; - } - const val = this.valueForDottedKey(cond.key, ev); - if (!Array.isArray(val)) { - return false; - } - return val.includes(cond.value); - } - eventFulfillsCallStartedCondition(_cond, ev) { - // Since servers don't support properly sending push notification - // about MSC3401 call events, we do the handling ourselves - return ["m.ring", "m.prompt"].includes(ev.getContent()["m.intent"]) && !("m.terminated" in ev.getContent()) && (ev.getPrevContent()["m.terminated"] !== ev.getContent()["m.terminated"] || (0, _utils.deepCompare)(ev.getPrevContent(), {})); - } - createCachedRegex(prefix, glob, suffix) { - if (PushProcessor.cachedGlobToRegex[glob]) { - return PushProcessor.cachedGlobToRegex[glob]; - } - PushProcessor.cachedGlobToRegex[glob] = new RegExp(prefix + (0, _utils.globToRegexp)(glob) + suffix, "i") // Case insensitive - ; - - return PushProcessor.cachedGlobToRegex[glob]; - } - - /** - * Parse the key into the separate fields to search by splitting on - * unescaped ".", and then removing any escape characters. - * - * @param str - The key of the push rule condition: a dotted field. - * @returns The unescaped parts to fetch. - * @internal - */ - static partsForDottedKey(str) { - const result = []; - - // The current field and whether the previous character was the escape - // character (a backslash). - let part = ""; - let escaped = false; - - // Iterate over each character, and decide whether to append to the current - // part (following the escape rules) or to start a new part (based on the - // field separator). - for (const c of str) { - // If the previous character was the escape character (a backslash) - // then decide what to append to the current part. - if (escaped) { - if (c === "\\" || c === ".") { - // An escaped backslash or dot just gets added. - part += c; - } else { - // A character that shouldn't be escaped gets the backslash prepended. - part += "\\" + c; - } - // This always resets being escaped. - escaped = false; - continue; - } - if (c == ".") { - // The field separator creates a new part. - result.push(part); - part = ""; - } else if (c == "\\") { - // A backslash adds no characters, but starts an escape sequence. - escaped = true; - } else { - // Otherwise, just add the current character. - part += c; - } - } - - // Ensure the final part is included. If there's an open escape sequence - // it should be included. - if (escaped) { - part += "\\"; - } - result.push(part); - return result; - } - - /** - * For a dotted field and event, fetch the value at that position, if one - * exists. - * - * @param key - The key of the push rule condition: a dotted field to fetch. - * @param ev - The matrix event to fetch the field from. - * @returns The value at the dotted path given by key. - */ - valueForDottedKey(key, ev) { - // The key should already have been parsed via updateCachedPushRuleKeys, - // but if it hasn't (maybe via an old consumer of the SDK which hasn't - // been updated?) then lazily calculate it here. - let parts = this.parsedKeys.get(key); - if (parts === undefined) { - parts = PushProcessor.partsForDottedKey(key); - this.parsedKeys.set(key, parts); - } - let val; - - // special-case the first component to deal with encrypted messages - const firstPart = parts[0]; - let currentIndex = 0; - if (firstPart === "content") { - val = ev.getContent(); - ++currentIndex; - } else if (firstPart === "type") { - val = ev.getType(); - ++currentIndex; - } else { - // use the raw event for any other fields - val = ev.event; - } - for (; currentIndex < parts.length; ++currentIndex) { - // The previous iteration resulted in null or undefined, bail (and - // avoid the type error of attempting to retrieve a property). - if ((0, _utils.isNullOrUndefined)(val)) { - return undefined; - } - const thisPart = parts[currentIndex]; - val = val[thisPart]; - } - return val; - } - matchingRuleForEventWithRulesets(ev, rulesets) { - if (!rulesets) { - return null; - } - if (ev.getSender() === this.client.credentials.userId) { - return null; - } - return this.matchingRuleFromKindSet(ev, rulesets.global); - } - pushActionsForEventAndRulesets(ev, rulesets) { - const rule = this.matchingRuleForEventWithRulesets(ev, rulesets); - if (!rule) { - return {}; - } - const actionObj = PushProcessor.actionListToActionsObject(rule.actions); - - // Some actions are implicit in some situations: we add those here - if (actionObj.tweaks.highlight === undefined) { - // if it isn't specified, highlight if it's a content - // rule but otherwise not - actionObj.tweaks.highlight = rule.kind == _PushRules.PushRuleKind.ContentSpecific; - } - return actionObj; - } - ruleMatchesEvent(rule, ev) { - var _rule$conditions; - // Disable the deprecated mentions push rules if the new mentions property exists. - if (this.client.supportsIntentionalMentions() && ev.getContent()["org.matrix.msc3952.mentions"] !== undefined && (rule.rule_id === _PushRules.RuleId.ContainsUserName || rule.rule_id === _PushRules.RuleId.ContainsDisplayName || rule.rule_id === _PushRules.RuleId.AtRoomNotification)) { - return false; - } - return !((_rule$conditions = rule.conditions) !== null && _rule$conditions !== void 0 && _rule$conditions.some(cond => !this.eventFulfillsCondition(cond, ev))); - } - - /** - * Get the user's push actions for the given event - */ - actionsForEvent(ev) { - return this.pushActionsForEventAndRulesets(ev, this.client.pushRules); - } - - /** - * Get one of the users push rules by its ID - * - * @param ruleId - The ID of the rule to search for - * @returns The push rule, or null if no such rule was found - */ - getPushRuleById(ruleId) { - var _result$rule; - const result = this.getPushRuleAndKindById(ruleId); - return (_result$rule = result === null || result === void 0 ? void 0 : result.rule) !== null && _result$rule !== void 0 ? _result$rule : null; - } - - /** - * Get one of the users push rules by its ID - * - * @param ruleId - The ID of the rule to search for - * @returns rule The push rule, or null if no such rule was found - * @returns kind - The PushRuleKind of the rule to search for - */ - getPushRuleAndKindById(ruleId) { - for (const scope of ["global"]) { - var _this$client$pushRule; - if (((_this$client$pushRule = this.client.pushRules) === null || _this$client$pushRule === void 0 ? void 0 : _this$client$pushRule[scope]) === undefined) continue; - for (const kind of RULEKINDS_IN_ORDER) { - if (this.client.pushRules[scope][kind] === undefined) continue; - for (const rule of this.client.pushRules[scope][kind]) { - if (rule.rule_id === ruleId) return { - rule, - kind - }; - } - } - } - return null; - } -} -exports.PushProcessor = PushProcessor; -(0, _defineProperty2.default)(PushProcessor, "cachedGlobToRegex", {}); -//# sourceMappingURL=pushprocessor.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js.map deleted file mode 100644 index f1e39a6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/pushprocessor.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"pushprocessor.js","names":["_utils","require","_logger","_PushRules","_event","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","RULEKINDS_IN_ORDER","PushRuleKind","Override","ContentSpecific","RoomSpecific","SenderSpecific","Underride","DEFAULT_OVERRIDE_RULES","rule_id","enabled","conditions","kind","ConditionKind","EventMatch","pattern","actions","PushRuleActionName","DontNotify","RuleId","IsUserMention","EventPropertyContains","value","Notify","set_tweak","TweakName","Highlight","IsRoomMention","EventPropertyIs","SenderNotificationPermission","EventType","RoomServerAcl","DEFAULT_UNDERRIDE_RULES","CallStarted","Sound","PushProcessor","constructor","client","Map","actionListToActionsObject","actionList","actionObj","notify","tweaks","action","undefined","rewriteDefaultRules","incomingRules","userId","_newRules$global$unde","newRules","JSON","parse","stringify","global","override","underride","globalOverrides","originalOverride","existingRule","find","r","ruleId","logger","warn","globalUnderrides","updateCachedPushRuleKeys","room","sender","toRemoveKeys","Set","parsedKeys","ruleset","rule","condition","delete","set","partsForDottedKey","k","matchingRuleFromKindSet","ev","kindset","rawrule","templateRuleToRaw","ruleMatchesEvent","tprule","eventFulfillsCondition","cond","eventFulfillsEventMatchCondition","eventFulfillsEventPropertyIsCondition","eventFulfillsEventPropertyContains","ContainsDisplayName","eventFulfillsDisplayNameCondition","RoomMemberCount","eventFulfillsRoomMemberCountCondition","eventFulfillsSenderNotifPermCondition","CallStartedPrefix","eventFulfillsCallStartedCondition","notifLevelKey","getRoom","getRoomId","currentState","mayTriggerNotifOfType","getSender","is","members","memberCount","getJoinedMemberCount","m","match","ineq","rhs","parseInt","isNaN","_room$currentState","content","getContent","isEncrypted","getClearContent","body","member","getMember","credentials","displayName","name","pat","RegExp","escapeRegExp","search","val","valueForDottedKey","regex","createCachedRegex","Array","isArray","includes","_cond","getPrevContent","deepCompare","prefix","glob","suffix","cachedGlobToRegex","globToRegexp","str","result","part","escaped","c","parts","get","firstPart","currentIndex","getType","event","isNullOrUndefined","thisPart","matchingRuleForEventWithRulesets","rulesets","pushActionsForEventAndRulesets","highlight","_rule$conditions","supportsIntentionalMentions","ContainsUserName","AtRoomNotification","some","actionsForEvent","pushRules","getPushRuleById","_result$rule","getPushRuleAndKindById","scope","_this$client$pushRule","exports"],"sources":["../src/pushprocessor.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { deepCompare, escapeRegExp, globToRegexp, isNullOrUndefined } from \"./utils\";\nimport { logger } from \"./logger\";\nimport { MatrixClient } from \"./client\";\nimport { MatrixEvent } from \"./models/event\";\nimport {\n ConditionKind,\n IAnnotatedPushRule,\n ICallStartedCondition,\n ICallStartedPrefixCondition,\n IContainsDisplayNameCondition,\n IEventMatchCondition,\n IEventPropertyIsCondition,\n IEventPropertyContainsCondition,\n IPushRule,\n IPushRules,\n IRoomMemberCountCondition,\n ISenderNotificationPermissionCondition,\n PushRuleAction,\n PushRuleActionName,\n PushRuleCondition,\n PushRuleKind,\n PushRuleSet,\n RuleId,\n TweakName,\n} from \"./@types/PushRules\";\nimport { EventType } from \"./@types/event\";\n\nconst RULEKINDS_IN_ORDER = [\n PushRuleKind.Override,\n PushRuleKind.ContentSpecific,\n PushRuleKind.RoomSpecific,\n PushRuleKind.SenderSpecific,\n PushRuleKind.Underride,\n];\n\n// The default override rules to apply to the push rules that arrive from the server.\n// We do this for two reasons:\n// 1. Synapse is unlikely to send us the push rule in an incremental sync - see\n// https://github.com/matrix-org/synapse/pull/4867#issuecomment-481446072 for\n// more details.\n// 2. We often want to start using push rules ahead of the server supporting them,\n// and so we can put them here.\nconst DEFAULT_OVERRIDE_RULES: IPushRule[] = [\n {\n // For homeservers which don't support MSC2153 yet\n rule_id: \".m.rule.reaction\",\n default: true,\n enabled: true,\n conditions: [\n {\n kind: ConditionKind.EventMatch,\n key: \"type\",\n pattern: \"m.reaction\",\n },\n ],\n actions: [PushRuleActionName.DontNotify],\n },\n {\n rule_id: RuleId.IsUserMention,\n default: true,\n enabled: true,\n conditions: [\n {\n kind: ConditionKind.EventPropertyContains,\n key: \"content.org\\\\.matrix\\\\.msc3952\\\\.mentions.user_ids\",\n value: \"\", // The user ID is dynamically added in rewriteDefaultRules.\n },\n ],\n actions: [PushRuleActionName.Notify, { set_tweak: TweakName.Highlight }],\n },\n {\n rule_id: RuleId.IsRoomMention,\n default: true,\n enabled: true,\n conditions: [\n {\n kind: ConditionKind.EventPropertyIs,\n key: \"content.org\\\\.matrix\\\\.msc3952\\\\.mentions.room\",\n value: true,\n },\n {\n kind: ConditionKind.SenderNotificationPermission,\n key: \"room\",\n },\n ],\n actions: [PushRuleActionName.Notify, { set_tweak: TweakName.Highlight }],\n },\n {\n // For homeservers which don't support MSC3786 yet\n rule_id: \".org.matrix.msc3786.rule.room.server_acl\",\n default: true,\n enabled: true,\n conditions: [\n {\n kind: ConditionKind.EventMatch,\n key: \"type\",\n pattern: EventType.RoomServerAcl,\n },\n {\n kind: ConditionKind.EventMatch,\n key: \"state_key\",\n pattern: \"\",\n },\n ],\n actions: [],\n },\n];\n\nconst DEFAULT_UNDERRIDE_RULES: IPushRule[] = [\n {\n // For homeservers which don't support MSC3914 yet\n rule_id: \".org.matrix.msc3914.rule.room.call\",\n default: true,\n enabled: true,\n conditions: [\n {\n kind: ConditionKind.EventMatch,\n key: \"type\",\n pattern: \"org.matrix.msc3401.call\",\n },\n {\n kind: ConditionKind.CallStarted,\n },\n ],\n actions: [PushRuleActionName.Notify, { set_tweak: TweakName.Sound, value: \"default\" }],\n },\n];\n\nexport interface IActionsObject {\n /** Whether this event should notify the user or not. */\n notify: boolean;\n /** How this event should be notified. */\n tweaks: Partial>;\n}\n\nexport class PushProcessor {\n /**\n * Construct a Push Processor.\n * @param client - The Matrix client object to use\n */\n public constructor(private readonly client: MatrixClient) {}\n\n /**\n * Maps the original key from the push rules to a list of property names\n * after unescaping.\n */\n private readonly parsedKeys = new Map();\n\n /**\n * Convert a list of actions into a object with the actions as keys and their values\n * @example\n * eg. `[ 'notify', { set_tweak: 'sound', value: 'default' } ]`\n * becomes `{ notify: true, tweaks: { sound: 'default' } }`\n * @param actionList - The actions list\n *\n * @returns A object with key 'notify' (true or false) and an object of actions\n */\n public static actionListToActionsObject(actionList: PushRuleAction[]): IActionsObject {\n const actionObj: IActionsObject = { notify: false, tweaks: {} };\n for (const action of actionList) {\n if (action === PushRuleActionName.Notify) {\n actionObj.notify = true;\n } else if (typeof action === \"object\") {\n if (action.value === undefined) {\n action.value = true;\n }\n actionObj.tweaks[action.set_tweak] = action.value;\n }\n }\n return actionObj;\n }\n\n /**\n * Rewrites conditions on a client's push rules to match the defaults\n * where applicable. Useful for upgrading push rules to more strict\n * conditions when the server is falling behind on defaults.\n * @param incomingRules - The client's existing push rules\n * @param userId - The Matrix ID of the client.\n * @returns The rewritten rules\n */\n public static rewriteDefaultRules(incomingRules: IPushRules, userId: string | undefined = undefined): IPushRules {\n let newRules: IPushRules = JSON.parse(JSON.stringify(incomingRules)); // deep clone\n\n // These lines are mostly to make the tests happy. We shouldn't run into these\n // properties missing in practice.\n if (!newRules) newRules = {} as IPushRules;\n if (!newRules.global) newRules.global = {} as PushRuleSet;\n if (!newRules.global.override) newRules.global.override = [];\n if (!newRules.global.underride) newRules.global.underride = [];\n\n // Merge the client-level defaults with the ones from the server\n const globalOverrides = newRules.global.override;\n for (const originalOverride of DEFAULT_OVERRIDE_RULES) {\n const existingRule = globalOverrides.find((r) => r.rule_id === originalOverride.rule_id);\n\n // Dynamically add the user ID as the value for the is_user_mention rule.\n let override: IPushRule;\n if (originalOverride.rule_id === RuleId.IsUserMention) {\n // If the user ID wasn't provided, skip the rule.\n if (!userId) {\n continue;\n }\n\n override = JSON.parse(JSON.stringify(originalOverride)); // deep clone\n override.conditions![0].value = userId;\n } else {\n override = originalOverride;\n }\n\n if (existingRule) {\n // Copy over the actions, default, and conditions. Don't touch the user's preference.\n existingRule.default = override.default;\n existingRule.conditions = override.conditions;\n existingRule.actions = override.actions;\n } else {\n // Add the rule\n const ruleId = override.rule_id;\n logger.warn(`Adding default global override for ${ruleId}`);\n globalOverrides.push(override);\n }\n }\n\n const globalUnderrides = newRules.global.underride ?? [];\n for (const underride of DEFAULT_UNDERRIDE_RULES) {\n const existingRule = globalUnderrides.find((r) => r.rule_id === underride.rule_id);\n\n if (existingRule) {\n // Copy over the actions, default, and conditions. Don't touch the user's preference.\n existingRule.default = underride.default;\n existingRule.conditions = underride.conditions;\n existingRule.actions = underride.actions;\n } else {\n // Add the rule\n const ruleId = underride.rule_id;\n logger.warn(`Adding default global underride for ${ruleId}`);\n globalUnderrides.push(underride);\n }\n }\n\n return newRules;\n }\n\n /**\n * Pre-caches the parsed keys for push rules and cleans out any obsolete cache\n * entries. Should be called after push rules are updated.\n * @param newRules - The new push rules.\n */\n public updateCachedPushRuleKeys(newRules: IPushRules): void {\n // These lines are mostly to make the tests happy. We shouldn't run into these\n // properties missing in practice.\n if (!newRules) newRules = {} as IPushRules;\n if (!newRules.global) newRules.global = {} as PushRuleSet;\n if (!newRules.global.override) newRules.global.override = [];\n if (!newRules.global.room) newRules.global.room = [];\n if (!newRules.global.sender) newRules.global.sender = [];\n if (!newRules.global.underride) newRules.global.underride = [];\n\n // Process the 'key' property on event_match conditions pre-cache the\n // values and clean-out any unused values.\n const toRemoveKeys = new Set(this.parsedKeys.keys());\n for (const ruleset of [\n newRules.global.override,\n newRules.global.room,\n newRules.global.sender,\n newRules.global.underride,\n ]) {\n for (const rule of ruleset) {\n if (!rule.conditions) {\n continue;\n }\n\n for (const condition of rule.conditions) {\n if (condition.kind !== ConditionKind.EventMatch) {\n continue;\n }\n\n // Ensure we keep this key.\n toRemoveKeys.delete(condition.key);\n\n // Pre-process the key.\n this.parsedKeys.set(condition.key, PushProcessor.partsForDottedKey(condition.key));\n }\n }\n }\n // Any keys that were previously cached, but are no longer needed should\n // be removed.\n toRemoveKeys.forEach((k) => this.parsedKeys.delete(k));\n }\n\n private static cachedGlobToRegex: Record = {}; // $glob: RegExp\n\n private matchingRuleFromKindSet(ev: MatrixEvent, kindset: PushRuleSet): IAnnotatedPushRule | null {\n for (const kind of RULEKINDS_IN_ORDER) {\n const ruleset = kindset[kind];\n if (!ruleset) {\n continue;\n }\n\n for (const rule of ruleset) {\n if (!rule.enabled) {\n continue;\n }\n\n const rawrule = this.templateRuleToRaw(kind, rule);\n if (!rawrule) {\n continue;\n }\n\n if (this.ruleMatchesEvent(rawrule, ev)) {\n return {\n ...rule,\n kind,\n };\n }\n }\n }\n return null;\n }\n\n private templateRuleToRaw(\n kind: PushRuleKind,\n tprule: IPushRule,\n ): Pick | null {\n const rawrule: Pick = {\n rule_id: tprule.rule_id,\n actions: tprule.actions,\n conditions: [],\n };\n switch (kind) {\n case PushRuleKind.Underride:\n case PushRuleKind.Override:\n rawrule.conditions = tprule.conditions;\n break;\n case PushRuleKind.RoomSpecific:\n if (!tprule.rule_id) {\n return null;\n }\n rawrule.conditions!.push({\n kind: ConditionKind.EventMatch,\n key: \"room_id\",\n value: tprule.rule_id,\n });\n break;\n case PushRuleKind.SenderSpecific:\n if (!tprule.rule_id) {\n return null;\n }\n rawrule.conditions!.push({\n kind: ConditionKind.EventMatch,\n key: \"user_id\",\n value: tprule.rule_id,\n });\n break;\n case PushRuleKind.ContentSpecific:\n if (!tprule.pattern) {\n return null;\n }\n rawrule.conditions!.push({\n kind: ConditionKind.EventMatch,\n key: \"content.body\",\n pattern: tprule.pattern,\n });\n break;\n }\n return rawrule;\n }\n\n private eventFulfillsCondition(cond: PushRuleCondition, ev: MatrixEvent): boolean {\n switch (cond.kind) {\n case ConditionKind.EventMatch:\n return this.eventFulfillsEventMatchCondition(cond, ev);\n case ConditionKind.EventPropertyIs:\n return this.eventFulfillsEventPropertyIsCondition(cond, ev);\n case ConditionKind.EventPropertyContains:\n return this.eventFulfillsEventPropertyContains(cond, ev);\n case ConditionKind.ContainsDisplayName:\n return this.eventFulfillsDisplayNameCondition(cond, ev);\n case ConditionKind.RoomMemberCount:\n return this.eventFulfillsRoomMemberCountCondition(cond, ev);\n case ConditionKind.SenderNotificationPermission:\n return this.eventFulfillsSenderNotifPermCondition(cond, ev);\n case ConditionKind.CallStarted:\n case ConditionKind.CallStartedPrefix:\n return this.eventFulfillsCallStartedCondition(cond, ev);\n }\n\n // unknown conditions: we previously matched all unknown conditions,\n // but given that rules can be added to the base rules on a server,\n // it's probably better to not match unknown conditions.\n return false;\n }\n\n private eventFulfillsSenderNotifPermCondition(\n cond: ISenderNotificationPermissionCondition,\n ev: MatrixEvent,\n ): boolean {\n const notifLevelKey = cond[\"key\"];\n if (!notifLevelKey) {\n return false;\n }\n\n const room = this.client.getRoom(ev.getRoomId());\n if (!room?.currentState) {\n return false;\n }\n\n // Note that this should not be the current state of the room but the state at\n // the point the event is in the DAG. Unfortunately the js-sdk does not store\n // this.\n return room.currentState.mayTriggerNotifOfType(notifLevelKey, ev.getSender()!);\n }\n\n private eventFulfillsRoomMemberCountCondition(cond: IRoomMemberCountCondition, ev: MatrixEvent): boolean {\n if (!cond.is) {\n return false;\n }\n\n const room = this.client.getRoom(ev.getRoomId());\n if (!room || !room.currentState || !room.currentState.members) {\n return false;\n }\n\n const memberCount = room.currentState.getJoinedMemberCount();\n\n const m = cond.is.match(/^([=<>]*)(\\d*)$/);\n if (!m) {\n return false;\n }\n const ineq = m[1];\n const rhs = parseInt(m[2]);\n if (isNaN(rhs)) {\n return false;\n }\n switch (ineq) {\n case \"\":\n case \"==\":\n return memberCount == rhs;\n case \"<\":\n return memberCount < rhs;\n case \">\":\n return memberCount > rhs;\n case \"<=\":\n return memberCount <= rhs;\n case \">=\":\n return memberCount >= rhs;\n default:\n return false;\n }\n }\n\n private eventFulfillsDisplayNameCondition(cond: IContainsDisplayNameCondition, ev: MatrixEvent): boolean {\n let content = ev.getContent();\n if (ev.isEncrypted() && ev.getClearContent()) {\n content = ev.getClearContent()!;\n }\n if (!content || !content.body || typeof content.body != \"string\") {\n return false;\n }\n\n const room = this.client.getRoom(ev.getRoomId());\n const member = room?.currentState?.getMember(this.client.credentials.userId!);\n if (!member) {\n return false;\n }\n\n const displayName = member.name;\n\n // N.B. we can't use \\b as it chokes on unicode. however \\W seems to be okay\n // as shorthand for [^0-9A-Za-z_].\n const pat = new RegExp(\"(^|\\\\W)\" + escapeRegExp(displayName) + \"(\\\\W|$)\", \"i\");\n return content.body.search(pat) > -1;\n }\n\n /**\n * Check whether the given event matches the push rule condition by fetching\n * the property from the event and comparing against the condition's glob-based\n * pattern.\n * @param cond - The push rule condition to check for a match.\n * @param ev - The event to check for a match.\n */\n private eventFulfillsEventMatchCondition(cond: IEventMatchCondition, ev: MatrixEvent): boolean {\n if (!cond.key) {\n return false;\n }\n\n const val = this.valueForDottedKey(cond.key, ev);\n if (typeof val !== \"string\") {\n return false;\n }\n\n // XXX This does not match in a case-insensitive manner.\n //\n // See https://spec.matrix.org/v1.5/client-server-api/#conditions-1\n if (cond.value) {\n return cond.value === val;\n }\n\n if (typeof cond.pattern !== \"string\") {\n return false;\n }\n\n const regex =\n cond.key === \"content.body\"\n ? this.createCachedRegex(\"(^|\\\\W)\", cond.pattern, \"(\\\\W|$)\")\n : this.createCachedRegex(\"^\", cond.pattern, \"$\");\n\n return !!val.match(regex);\n }\n\n /**\n * Check whether the given event matches the push rule condition by fetching\n * the property from the event and comparing exactly against the condition's\n * value.\n * @param cond - The push rule condition to check for a match.\n * @param ev - The event to check for a match.\n */\n private eventFulfillsEventPropertyIsCondition(cond: IEventPropertyIsCondition, ev: MatrixEvent): boolean {\n if (!cond.key || cond.value === undefined) {\n return false;\n }\n return cond.value === this.valueForDottedKey(cond.key, ev);\n }\n\n /**\n * Check whether the given event matches the push rule condition by fetching\n * the property from the event and comparing exactly against the condition's\n * value.\n * @param cond - The push rule condition to check for a match.\n * @param ev - The event to check for a match.\n */\n private eventFulfillsEventPropertyContains(cond: IEventPropertyContainsCondition, ev: MatrixEvent): boolean {\n if (!cond.key || cond.value === undefined) {\n return false;\n }\n const val = this.valueForDottedKey(cond.key, ev);\n if (!Array.isArray(val)) {\n return false;\n }\n return val.includes(cond.value);\n }\n\n private eventFulfillsCallStartedCondition(\n _cond: ICallStartedCondition | ICallStartedPrefixCondition,\n ev: MatrixEvent,\n ): boolean {\n // Since servers don't support properly sending push notification\n // about MSC3401 call events, we do the handling ourselves\n return (\n [\"m.ring\", \"m.prompt\"].includes(ev.getContent()[\"m.intent\"]) &&\n !(\"m.terminated\" in ev.getContent()) &&\n (ev.getPrevContent()[\"m.terminated\"] !== ev.getContent()[\"m.terminated\"] ||\n deepCompare(ev.getPrevContent(), {}))\n );\n }\n\n private createCachedRegex(prefix: string, glob: string, suffix: string): RegExp {\n if (PushProcessor.cachedGlobToRegex[glob]) {\n return PushProcessor.cachedGlobToRegex[glob];\n }\n PushProcessor.cachedGlobToRegex[glob] = new RegExp(\n prefix + globToRegexp(glob) + suffix,\n \"i\", // Case insensitive\n );\n return PushProcessor.cachedGlobToRegex[glob];\n }\n\n /**\n * Parse the key into the separate fields to search by splitting on\n * unescaped \".\", and then removing any escape characters.\n *\n * @param str - The key of the push rule condition: a dotted field.\n * @returns The unescaped parts to fetch.\n * @internal\n */\n public static partsForDottedKey(str: string): string[] {\n const result = [];\n\n // The current field and whether the previous character was the escape\n // character (a backslash).\n let part = \"\";\n let escaped = false;\n\n // Iterate over each character, and decide whether to append to the current\n // part (following the escape rules) or to start a new part (based on the\n // field separator).\n for (const c of str) {\n // If the previous character was the escape character (a backslash)\n // then decide what to append to the current part.\n if (escaped) {\n if (c === \"\\\\\" || c === \".\") {\n // An escaped backslash or dot just gets added.\n part += c;\n } else {\n // A character that shouldn't be escaped gets the backslash prepended.\n part += \"\\\\\" + c;\n }\n // This always resets being escaped.\n escaped = false;\n continue;\n }\n\n if (c == \".\") {\n // The field separator creates a new part.\n result.push(part);\n part = \"\";\n } else if (c == \"\\\\\") {\n // A backslash adds no characters, but starts an escape sequence.\n escaped = true;\n } else {\n // Otherwise, just add the current character.\n part += c;\n }\n }\n\n // Ensure the final part is included. If there's an open escape sequence\n // it should be included.\n if (escaped) {\n part += \"\\\\\";\n }\n result.push(part);\n\n return result;\n }\n\n /**\n * For a dotted field and event, fetch the value at that position, if one\n * exists.\n *\n * @param key - The key of the push rule condition: a dotted field to fetch.\n * @param ev - The matrix event to fetch the field from.\n * @returns The value at the dotted path given by key.\n */\n private valueForDottedKey(key: string, ev: MatrixEvent): any {\n // The key should already have been parsed via updateCachedPushRuleKeys,\n // but if it hasn't (maybe via an old consumer of the SDK which hasn't\n // been updated?) then lazily calculate it here.\n let parts = this.parsedKeys.get(key);\n if (parts === undefined) {\n parts = PushProcessor.partsForDottedKey(key);\n this.parsedKeys.set(key, parts);\n }\n let val: any;\n\n // special-case the first component to deal with encrypted messages\n const firstPart = parts[0];\n let currentIndex = 0;\n if (firstPart === \"content\") {\n val = ev.getContent();\n ++currentIndex;\n } else if (firstPart === \"type\") {\n val = ev.getType();\n ++currentIndex;\n } else {\n // use the raw event for any other fields\n val = ev.event;\n }\n\n for (; currentIndex < parts.length; ++currentIndex) {\n // The previous iteration resulted in null or undefined, bail (and\n // avoid the type error of attempting to retrieve a property).\n if (isNullOrUndefined(val)) {\n return undefined;\n }\n\n const thisPart = parts[currentIndex];\n val = val[thisPart];\n }\n return val;\n }\n\n private matchingRuleForEventWithRulesets(ev: MatrixEvent, rulesets?: IPushRules): IAnnotatedPushRule | null {\n if (!rulesets) {\n return null;\n }\n if (ev.getSender() === this.client.credentials.userId) {\n return null;\n }\n\n return this.matchingRuleFromKindSet(ev, rulesets.global);\n }\n\n private pushActionsForEventAndRulesets(ev: MatrixEvent, rulesets?: IPushRules): IActionsObject {\n const rule = this.matchingRuleForEventWithRulesets(ev, rulesets);\n if (!rule) {\n return {} as IActionsObject;\n }\n\n const actionObj = PushProcessor.actionListToActionsObject(rule.actions);\n\n // Some actions are implicit in some situations: we add those here\n if (actionObj.tweaks.highlight === undefined) {\n // if it isn't specified, highlight if it's a content\n // rule but otherwise not\n actionObj.tweaks.highlight = rule.kind == PushRuleKind.ContentSpecific;\n }\n\n return actionObj;\n }\n\n public ruleMatchesEvent(rule: Partial & Pick, ev: MatrixEvent): boolean {\n // Disable the deprecated mentions push rules if the new mentions property exists.\n if (\n this.client.supportsIntentionalMentions() &&\n ev.getContent()[\"org.matrix.msc3952.mentions\"] !== undefined &&\n (rule.rule_id === RuleId.ContainsUserName ||\n rule.rule_id === RuleId.ContainsDisplayName ||\n rule.rule_id === RuleId.AtRoomNotification)\n ) {\n return false;\n }\n\n return !rule.conditions?.some((cond) => !this.eventFulfillsCondition(cond, ev));\n }\n\n /**\n * Get the user's push actions for the given event\n */\n public actionsForEvent(ev: MatrixEvent): IActionsObject {\n return this.pushActionsForEventAndRulesets(ev, this.client.pushRules);\n }\n\n /**\n * Get one of the users push rules by its ID\n *\n * @param ruleId - The ID of the rule to search for\n * @returns The push rule, or null if no such rule was found\n */\n public getPushRuleById(ruleId: string): IPushRule | null {\n const result = this.getPushRuleAndKindById(ruleId);\n return result?.rule ?? null;\n }\n\n /**\n * Get one of the users push rules by its ID\n *\n * @param ruleId - The ID of the rule to search for\n * @returns rule The push rule, or null if no such rule was found\n * @returns kind - The PushRuleKind of the rule to search for\n */\n public getPushRuleAndKindById(ruleId: string): { rule: IPushRule; kind: PushRuleKind } | null {\n for (const scope of [\"global\"] as const) {\n if (this.client.pushRules?.[scope] === undefined) continue;\n\n for (const kind of RULEKINDS_IN_ORDER) {\n if (this.client.pushRules[scope][kind] === undefined) continue;\n\n for (const rule of this.client.pushRules[scope][kind]!) {\n if (rule.rule_id === ruleId) return { rule, kind };\n }\n }\n }\n return null;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts deleted file mode 100644 index 18ed51d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -export declare function randomString(len: number): string; -export declare function randomLowercaseString(len: number): string; -export declare function randomUppercaseString(len: number): string; -//# sourceMappingURL=randomstring.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts.map deleted file mode 100644 index dd22633..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"randomstring.d.ts","sourceRoot":"","sources":["../src/randomstring.ts"],"names":[],"mappings":"AAqBA,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEhD;AAED,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEzD;AAED,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEzD"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js deleted file mode 100644 index 81aa654..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js +++ /dev/null @@ -1,45 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.randomLowercaseString = randomLowercaseString; -exports.randomString = randomString; -exports.randomUppercaseString = randomUppercaseString; -/* -Copyright 2018 New Vector Ltd -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const LOWERCASE = "abcdefghijklmnopqrstuvwxyz"; -const UPPERCASE = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; -const DIGITS = "0123456789"; -function randomString(len) { - return randomStringFrom(len, UPPERCASE + LOWERCASE + DIGITS); -} -function randomLowercaseString(len) { - return randomStringFrom(len, LOWERCASE); -} -function randomUppercaseString(len) { - return randomStringFrom(len, UPPERCASE); -} -function randomStringFrom(len, chars) { - let ret = ""; - for (let i = 0; i < len; ++i) { - ret += chars.charAt(Math.floor(Math.random() * chars.length)); - } - return ret; -} -//# sourceMappingURL=randomstring.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js.map deleted file mode 100644 index 2115af8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/randomstring.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"randomstring.js","names":["LOWERCASE","UPPERCASE","DIGITS","randomString","len","randomStringFrom","randomLowercaseString","randomUppercaseString","chars","ret","i","charAt","Math","floor","random","length"],"sources":["../src/randomstring.ts"],"sourcesContent":["/*\nCopyright 2018 New Vector Ltd\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nconst LOWERCASE = \"abcdefghijklmnopqrstuvwxyz\";\nconst UPPERCASE = \"ABCDEFGHIJKLMNOPQRSTUVWXYZ\";\nconst DIGITS = \"0123456789\";\n\nexport function randomString(len: number): string {\n return randomStringFrom(len, UPPERCASE + LOWERCASE + DIGITS);\n}\n\nexport function randomLowercaseString(len: number): string {\n return randomStringFrom(len, LOWERCASE);\n}\n\nexport function randomUppercaseString(len: number): string {\n return randomStringFrom(len, UPPERCASE);\n}\n\nfunction randomStringFrom(len: number, chars: string): string {\n let ret = \"\";\n\n for (let i = 0; i < len; ++i) {\n ret += chars.charAt(Math.floor(Math.random() * chars.length));\n }\n\n return ret;\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,MAAMA,SAAS,GAAG,4BAA4B;AAC9C,MAAMC,SAAS,GAAG,4BAA4B;AAC9C,MAAMC,MAAM,GAAG,YAAY;AAEpB,SAASC,YAAYA,CAACC,GAAW,EAAU;EAC9C,OAAOC,gBAAgB,CAACD,GAAG,EAAEH,SAAS,GAAGD,SAAS,GAAGE,MAAM,CAAC;AAChE;AAEO,SAASI,qBAAqBA,CAACF,GAAW,EAAU;EACvD,OAAOC,gBAAgB,CAACD,GAAG,EAAEJ,SAAS,CAAC;AAC3C;AAEO,SAASO,qBAAqBA,CAACH,GAAW,EAAU;EACvD,OAAOC,gBAAgB,CAACD,GAAG,EAAEH,SAAS,CAAC;AAC3C;AAEA,SAASI,gBAAgBA,CAACD,GAAW,EAAEI,KAAa,EAAU;EAC1D,IAAIC,GAAG,GAAG,EAAE;EAEZ,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGN,GAAG,EAAE,EAAEM,CAAC,EAAE;IAC1BD,GAAG,IAAID,KAAK,CAACG,MAAM,CAACC,IAAI,CAACC,KAAK,CAACD,IAAI,CAACE,MAAM,EAAE,GAAGN,KAAK,CAACO,MAAM,CAAC,CAAC;EACjE;EAEA,OAAON,GAAG;AACd"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts deleted file mode 100644 index e2d4f45..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts +++ /dev/null @@ -1,18 +0,0 @@ -/** - * reimplementation of window.setTimeout, which will call the callback if - * the wallclock time goes past the deadline. - * - * @param func - callback to be called after a delay - * @param delayMs - number of milliseconds to delay by - * - * @returns an identifier for this callback, which may be passed into - * clearTimeout later. - */ -export declare function setTimeout(func: (...params: any[]) => void, delayMs: number, ...params: any[]): number; -/** - * reimplementation of window.clearTimeout, which mirrors setTimeout - * - * @param key - result from an earlier setTimeout call - */ -export declare function clearTimeout(key: number): void; -//# sourceMappingURL=realtime-callbacks.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts.map deleted file mode 100644 index cf4abc4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"realtime-callbacks.d.ts","sourceRoot":"","sources":["../src/realtime-callbacks.ts"],"names":[],"mappings":"AAqDA;;;;;;;;;GASG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,CAAC,GAAG,MAAM,EAAE,GAAG,EAAE,KAAK,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,CAyBtG;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAmB9C"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js deleted file mode 100644 index ef63620..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js +++ /dev/null @@ -1,180 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.clearTimeout = clearTimeout; -exports.setTimeout = setTimeout; -var _logger = require("./logger"); -/* -Copyright 2016 OpenMarket Ltd -Copyright 2019 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/* A re-implementation of the javascript callback functions (setTimeout, - * clearTimeout; setInterval and clearInterval are not yet implemented) which - * try to improve handling of large clock jumps (as seen when - * suspending/resuming the system). - * - * In particular, if a timeout would have fired while the system was suspended, - * it will instead fire as soon as possible after resume. - */ - -// we schedule a callback at least this often, to check if we've missed out on -// some wall-clock time due to being suspended. -const TIMER_CHECK_PERIOD_MS = 1000; - -// counter, for making up ids to return from setTimeout -let count = 0; - -// the key for our callback with the real global.setTimeout -let realCallbackKey; -// a sorted list of the callbacks to be run. -// each is an object with keys [runAt, func, params, key]. -const callbackList = []; - -// var debuglog = logger.log.bind(logger); -/* istanbul ignore next */ -const debuglog = function (...params) {}; - -/** - * reimplementation of window.setTimeout, which will call the callback if - * the wallclock time goes past the deadline. - * - * @param func - callback to be called after a delay - * @param delayMs - number of milliseconds to delay by - * - * @returns an identifier for this callback, which may be passed into - * clearTimeout later. - */ -function setTimeout(func, delayMs, ...params) { - delayMs = delayMs || 0; - if (delayMs < 0) { - delayMs = 0; - } - const runAt = Date.now() + delayMs; - const key = count++; - debuglog("setTimeout: scheduling cb", key, "at", runAt, "(delay", delayMs, ")"); - const data = { - runAt: runAt, - func: func, - params: params, - key: key - }; - - // figure out where it goes in the list - const idx = binarySearch(callbackList, function (el) { - return el.runAt - runAt; - }); - callbackList.splice(idx, 0, data); - scheduleRealCallback(); - return key; -} - -/** - * reimplementation of window.clearTimeout, which mirrors setTimeout - * - * @param key - result from an earlier setTimeout call - */ -function clearTimeout(key) { - if (callbackList.length === 0) { - return; - } - - // remove the element from the list - let i; - for (i = 0; i < callbackList.length; i++) { - const cb = callbackList[i]; - if (cb.key == key) { - callbackList.splice(i, 1); - break; - } - } - - // iff it was the first one in the list, reschedule our callback. - if (i === 0) { - scheduleRealCallback(); - } -} - -// use the real global.setTimeout to schedule a callback to runCallbacks. -function scheduleRealCallback() { - if (realCallbackKey) { - global.clearTimeout(realCallbackKey); - } - const first = callbackList[0]; - if (!first) { - debuglog("scheduleRealCallback: no more callbacks, not rescheduling"); - return; - } - const timestamp = Date.now(); - const delayMs = Math.min(first.runAt - timestamp, TIMER_CHECK_PERIOD_MS); - debuglog("scheduleRealCallback: now:", timestamp, "delay:", delayMs); - realCallbackKey = global.setTimeout(runCallbacks, delayMs); -} -function runCallbacks() { - const timestamp = Date.now(); - debuglog("runCallbacks: now:", timestamp); - - // get the list of things to call - const callbacksToRun = []; - // eslint-disable-next-line - while (true) { - const first = callbackList[0]; - if (!first || first.runAt > timestamp) { - break; - } - const cb = callbackList.shift(); - debuglog("runCallbacks: popping", cb.key); - callbacksToRun.push(cb); - } - - // reschedule the real callback before running our functions, to - // keep the codepaths the same whether or not our functions - // register their own setTimeouts. - scheduleRealCallback(); - for (const cb of callbacksToRun) { - try { - cb.func.apply(global, cb.params); - } catch (e) { - _logger.logger.error("Uncaught exception in callback function", e); - } - } -} - -/* search in a sorted array. - * - * returns the index of the last element for which func returns - * greater than zero, or array.length if no such element exists. - */ -function binarySearch(array, func) { - // min is inclusive, max exclusive. - let min = 0; - let max = array.length; - while (min < max) { - const mid = min + max >> 1; - const res = func(array[mid]); - if (res > 0) { - // the element at 'mid' is too big; set it as the new max. - max = mid; - } else { - // the element at 'mid' is too small. 'min' is inclusive, so +1. - min = mid + 1; - } - } - // presumably, min==max now. - return min; -} -//# sourceMappingURL=realtime-callbacks.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js.map deleted file mode 100644 index 7da5e38..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/realtime-callbacks.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"realtime-callbacks.js","names":["_logger","require","TIMER_CHECK_PERIOD_MS","count","realCallbackKey","callbackList","debuglog","params","setTimeout","func","delayMs","runAt","Date","now","key","data","idx","binarySearch","el","splice","scheduleRealCallback","clearTimeout","length","i","cb","global","first","timestamp","Math","min","runCallbacks","callbacksToRun","shift","push","apply","e","logger","error","array","max","mid","res"],"sources":["../src/realtime-callbacks.ts"],"sourcesContent":["/*\nCopyright 2016 OpenMarket Ltd\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/* A re-implementation of the javascript callback functions (setTimeout,\n * clearTimeout; setInterval and clearInterval are not yet implemented) which\n * try to improve handling of large clock jumps (as seen when\n * suspending/resuming the system).\n *\n * In particular, if a timeout would have fired while the system was suspended,\n * it will instead fire as soon as possible after resume.\n */\n\nimport { logger } from \"./logger\";\n\n// we schedule a callback at least this often, to check if we've missed out on\n// some wall-clock time due to being suspended.\nconst TIMER_CHECK_PERIOD_MS = 1000;\n\n// counter, for making up ids to return from setTimeout\nlet count = 0;\n\n// the key for our callback with the real global.setTimeout\nlet realCallbackKey: NodeJS.Timeout | number;\n\ntype Callback = {\n runAt: number;\n func: (...params: any[]) => void;\n params: any[];\n key: number;\n};\n\n// a sorted list of the callbacks to be run.\n// each is an object with keys [runAt, func, params, key].\nconst callbackList: Callback[] = [];\n\n// var debuglog = logger.log.bind(logger);\n/* istanbul ignore next */\nconst debuglog = function (...params: any[]): void {};\n\n/**\n * reimplementation of window.setTimeout, which will call the callback if\n * the wallclock time goes past the deadline.\n *\n * @param func - callback to be called after a delay\n * @param delayMs - number of milliseconds to delay by\n *\n * @returns an identifier for this callback, which may be passed into\n * clearTimeout later.\n */\nexport function setTimeout(func: (...params: any[]) => void, delayMs: number, ...params: any[]): number {\n delayMs = delayMs || 0;\n if (delayMs < 0) {\n delayMs = 0;\n }\n\n const runAt = Date.now() + delayMs;\n const key = count++;\n debuglog(\"setTimeout: scheduling cb\", key, \"at\", runAt, \"(delay\", delayMs, \")\");\n const data = {\n runAt: runAt,\n func: func,\n params: params,\n key: key,\n };\n\n // figure out where it goes in the list\n const idx = binarySearch(callbackList, function (el) {\n return el.runAt - runAt;\n });\n\n callbackList.splice(idx, 0, data);\n scheduleRealCallback();\n\n return key;\n}\n\n/**\n * reimplementation of window.clearTimeout, which mirrors setTimeout\n *\n * @param key - result from an earlier setTimeout call\n */\nexport function clearTimeout(key: number): void {\n if (callbackList.length === 0) {\n return;\n }\n\n // remove the element from the list\n let i: number;\n for (i = 0; i < callbackList.length; i++) {\n const cb = callbackList[i];\n if (cb.key == key) {\n callbackList.splice(i, 1);\n break;\n }\n }\n\n // iff it was the first one in the list, reschedule our callback.\n if (i === 0) {\n scheduleRealCallback();\n }\n}\n\n// use the real global.setTimeout to schedule a callback to runCallbacks.\nfunction scheduleRealCallback(): void {\n if (realCallbackKey) {\n global.clearTimeout(realCallbackKey as NodeJS.Timeout);\n }\n\n const first = callbackList[0];\n\n if (!first) {\n debuglog(\"scheduleRealCallback: no more callbacks, not rescheduling\");\n return;\n }\n\n const timestamp = Date.now();\n const delayMs = Math.min(first.runAt - timestamp, TIMER_CHECK_PERIOD_MS);\n\n debuglog(\"scheduleRealCallback: now:\", timestamp, \"delay:\", delayMs);\n realCallbackKey = global.setTimeout(runCallbacks, delayMs);\n}\n\nfunction runCallbacks(): void {\n const timestamp = Date.now();\n debuglog(\"runCallbacks: now:\", timestamp);\n\n // get the list of things to call\n const callbacksToRun: Callback[] = [];\n // eslint-disable-next-line\n while (true) {\n const first = callbackList[0];\n if (!first || first.runAt > timestamp) {\n break;\n }\n const cb = callbackList.shift()!;\n debuglog(\"runCallbacks: popping\", cb.key);\n callbacksToRun.push(cb);\n }\n\n // reschedule the real callback before running our functions, to\n // keep the codepaths the same whether or not our functions\n // register their own setTimeouts.\n scheduleRealCallback();\n\n for (const cb of callbacksToRun) {\n try {\n cb.func.apply(global, cb.params);\n } catch (e) {\n logger.error(\"Uncaught exception in callback function\", e);\n }\n }\n}\n\n/* search in a sorted array.\n *\n * returns the index of the last element for which func returns\n * greater than zero, or array.length if no such element exists.\n */\nfunction binarySearch(array: T[], func: (v: T) => number): number {\n // min is inclusive, max exclusive.\n let min = 0;\n let max = array.length;\n\n while (min < max) {\n const mid = (min + max) >> 1;\n const res = func(array[mid]);\n if (res > 0) {\n // the element at 'mid' is too big; set it as the new max.\n max = mid;\n } else {\n // the element at 'mid' is too small. 'min' is inclusive, so +1.\n min = mid + 1;\n }\n }\n // presumably, min==max now.\n return min;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts deleted file mode 100644 index c536bd5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts +++ /dev/null @@ -1,74 +0,0 @@ -import { RendezvousChannel, RendezvousFailureListener, RendezvousFailureReason, RendezvousIntent } from "."; -import { MatrixClient } from "../client"; -import { CrossSigningInfo } from "../crypto/CrossSigning"; -import { DeviceInfo } from "../crypto/deviceinfo"; -declare enum PayloadType { - Start = "m.login.start", - Finish = "m.login.finish", - Progress = "m.login.progress" -} -declare enum Outcome { - Success = "success", - Failure = "failure", - Verified = "verified", - Declined = "declined", - Unsupported = "unsupported" -} -export interface MSC3906RendezvousPayload { - type: PayloadType; - intent?: RendezvousIntent; - outcome?: Outcome; - device_id?: string; - device_key?: string; - verifying_device_id?: string; - verifying_device_key?: string; - master_key?: string; - protocols?: string[]; - protocol?: string; - login_token?: string; - homeserver?: string; -} -/** - * Implements MSC3906 to allow a user to sign in on a new device using QR code. - * This implementation only supports generating a QR code on a device that is already signed in. - * Note that this is UNSTABLE and may have breaking changes without notice. - */ -export declare class MSC3906Rendezvous { - private channel; - private client; - onFailure?: RendezvousFailureListener | undefined; - private newDeviceId?; - private newDeviceKey?; - private ourIntent; - private _code?; - /** - * @param channel - The secure channel used for communication - * @param client - The Matrix client in used on the device already logged in - * @param onFailure - Callback for when the rendezvous fails - */ - constructor(channel: RendezvousChannel, client: MatrixClient, onFailure?: RendezvousFailureListener | undefined); - /** - * Returns the code representing the rendezvous suitable for rendering in a QR code or undefined if not generated yet. - */ - get code(): string | undefined; - /** - * Generate the code including doing partial set up of the channel where required. - */ - generateCode(): Promise; - startAfterShowingCode(): Promise; - private receive; - private send; - declineLoginOnExistingDevice(): Promise; - approveLoginOnExistingDevice(loginToken: string): Promise; - private verifyAndCrossSignDevice; - /** - * Verify the device and cross-sign it. - * @param timeout - time in milliseconds to wait for device to come online - * @returns the new device info if the device was verified - */ - verifyNewDeviceOnExistingDevice(timeout?: number): Promise; - cancel(reason: RendezvousFailureReason): Promise; - close(): Promise; -} -export {}; -//# sourceMappingURL=MSC3906Rendezvous.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts.map deleted file mode 100644 index 28c19a8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3906Rendezvous.d.ts","sourceRoot":"","sources":["../../src/rendezvous/MSC3906Rendezvous.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,iBAAiB,EAAE,yBAAyB,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,GAAG,CAAC;AAC5G,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAKlD,aAAK,WAAW;IACZ,KAAK,kBAAkB;IACvB,MAAM,mBAAmB;IACzB,QAAQ,qBAAqB;CAChC;AAED,aAAK,OAAO;IACR,OAAO,YAAY;IACnB,OAAO,YAAY;IACnB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,WAAW,gBAAgB;CAC9B;AAED,MAAM,WAAW,wBAAwB;IACrC,IAAI,EAAE,WAAW,CAAC;IAClB,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACvB;AAID;;;;GAIG;AACH,qBAAa,iBAAiB;IAYtB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,MAAM;IACP,SAAS,CAAC;IAbrB,OAAO,CAAC,WAAW,CAAC,CAAS;IAC7B,OAAO,CAAC,YAAY,CAAC,CAAS;IAC9B,OAAO,CAAC,SAAS,CAA2E;IAC5F,OAAO,CAAC,KAAK,CAAC,CAAS;IAEvB;;;;OAIG;gBAES,OAAO,EAAE,iBAAiB,CAAC,wBAAwB,CAAC,EACpD,MAAM,EAAE,YAAY,EACrB,SAAS,CAAC,uCAA2B;IAGhD;;OAEG;IACH,IAAW,IAAI,IAAI,MAAM,GAAG,SAAS,CAEpC;IAED;;OAEG;IACU,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ7B,qBAAqB,IAAI,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;YA4CnD,OAAO;YAIP,IAAI;IAIL,4BAA4B,IAAI,OAAO,CAAC,IAAI,CAAC;IAK7C,4BAA4B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;YAqB5E,wBAAwB;IAsCtC;;;;OAIG;IACU,+BAA+B,CACxC,OAAO,SAAY,GACpB,OAAO,CAAC,UAAU,GAAG,gBAAgB,GAAG,SAAS,CAAC;IAmCxC,MAAM,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;IAKtD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAGtC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js deleted file mode 100644 index e5bd99e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js +++ /dev/null @@ -1,235 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MSC3906Rendezvous = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _matrixEventsSdk = require("matrix-events-sdk"); -var _ = require("."); -var _feature = require("../feature"); -var _logger = require("../logger"); -var _utils = require("../utils"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -var PayloadType; -(function (PayloadType) { - PayloadType["Start"] = "m.login.start"; - PayloadType["Finish"] = "m.login.finish"; - PayloadType["Progress"] = "m.login.progress"; -})(PayloadType || (PayloadType = {})); -var Outcome; -(function (Outcome) { - Outcome["Success"] = "success"; - Outcome["Failure"] = "failure"; - Outcome["Verified"] = "verified"; - Outcome["Declined"] = "declined"; - Outcome["Unsupported"] = "unsupported"; -})(Outcome || (Outcome = {})); -const LOGIN_TOKEN_PROTOCOL = new _matrixEventsSdk.UnstableValue("login_token", "org.matrix.msc3906.login_token"); - -/** - * Implements MSC3906 to allow a user to sign in on a new device using QR code. - * This implementation only supports generating a QR code on a device that is already signed in. - * Note that this is UNSTABLE and may have breaking changes without notice. - */ -class MSC3906Rendezvous { - /** - * @param channel - The secure channel used for communication - * @param client - The Matrix client in used on the device already logged in - * @param onFailure - Callback for when the rendezvous fails - */ - constructor(channel, client, onFailure) { - this.channel = channel; - this.client = client; - this.onFailure = onFailure; - (0, _defineProperty2.default)(this, "newDeviceId", void 0); - (0, _defineProperty2.default)(this, "newDeviceKey", void 0); - (0, _defineProperty2.default)(this, "ourIntent", _.RendezvousIntent.RECIPROCATE_LOGIN_ON_EXISTING_DEVICE); - (0, _defineProperty2.default)(this, "_code", void 0); - } - - /** - * Returns the code representing the rendezvous suitable for rendering in a QR code or undefined if not generated yet. - */ - get code() { - return this._code; - } - - /** - * Generate the code including doing partial set up of the channel where required. - */ - async generateCode() { - if (this._code) { - return; - } - this._code = JSON.stringify(await this.channel.generateCode(this.ourIntent)); - } - async startAfterShowingCode() { - const checksum = await this.channel.connect(); - _logger.logger.info(`Connected to secure channel with checksum: ${checksum} our intent is ${this.ourIntent}`); - const features = await (0, _feature.buildFeatureSupportMap)(await this.client.getVersions()); - // determine available protocols - if (features.get(_feature.Feature.LoginTokenRequest) === _feature.ServerSupport.Unsupported) { - _logger.logger.info("Server doesn't support MSC3882"); - await this.send({ - type: PayloadType.Finish, - outcome: Outcome.Unsupported - }); - await this.cancel(_.RendezvousFailureReason.HomeserverLacksSupport); - return undefined; - } - await this.send({ - type: PayloadType.Progress, - protocols: [LOGIN_TOKEN_PROTOCOL.name] - }); - _logger.logger.info("Waiting for other device to chose protocol"); - const { - type, - protocol, - outcome - } = await this.receive(); - if (type === PayloadType.Finish) { - // new device decided not to complete - switch (outcome !== null && outcome !== void 0 ? outcome : "") { - case "unsupported": - await this.cancel(_.RendezvousFailureReason.UnsupportedAlgorithm); - break; - default: - await this.cancel(_.RendezvousFailureReason.Unknown); - } - return undefined; - } - if (type !== PayloadType.Progress) { - await this.cancel(_.RendezvousFailureReason.Unknown); - return undefined; - } - if (!protocol || !LOGIN_TOKEN_PROTOCOL.matches(protocol)) { - await this.cancel(_.RendezvousFailureReason.UnsupportedAlgorithm); - return undefined; - } - return checksum; - } - async receive() { - return await this.channel.receive(); - } - async send(payload) { - await this.channel.send(payload); - } - async declineLoginOnExistingDevice() { - _logger.logger.info("User declined sign in"); - await this.send({ - type: PayloadType.Finish, - outcome: Outcome.Declined - }); - } - async approveLoginOnExistingDevice(loginToken) { - // eslint-disable-next-line camelcase - await this.send({ - type: PayloadType.Progress, - login_token: loginToken, - homeserver: this.client.baseUrl - }); - _logger.logger.info("Waiting for outcome"); - const res = await this.receive(); - if (!res) { - return undefined; - } - const { - outcome, - device_id: deviceId, - device_key: deviceKey - } = res; - if (outcome !== "success") { - throw new Error("Linking failed"); - } - this.newDeviceId = deviceId; - this.newDeviceKey = deviceKey; - return deviceId; - } - async verifyAndCrossSignDevice(deviceInfo) { - if (!this.client.crypto) { - throw new Error("Crypto not available on client"); - } - if (!this.newDeviceId) { - throw new Error("No new device ID set"); - } - - // check that keys received from the server for the new device match those received from the device itself - if (deviceInfo.getFingerprint() !== this.newDeviceKey) { - throw new Error(`New device has different keys than expected: ${this.newDeviceKey} vs ${deviceInfo.getFingerprint()}`); - } - const userId = this.client.getUserId(); - if (!userId) { - throw new Error("No user ID set"); - } - // mark the device as verified locally + cross sign - _logger.logger.info(`Marking device ${this.newDeviceId} as verified`); - const info = await this.client.crypto.setDeviceVerification(userId, this.newDeviceId, true, false, true); - const masterPublicKey = this.client.crypto.crossSigningInfo.getId("master"); - await this.send({ - type: PayloadType.Finish, - outcome: Outcome.Verified, - verifying_device_id: this.client.getDeviceId(), - verifying_device_key: this.client.getDeviceEd25519Key(), - master_key: masterPublicKey - }); - return info; - } - - /** - * Verify the device and cross-sign it. - * @param timeout - time in milliseconds to wait for device to come online - * @returns the new device info if the device was verified - */ - async verifyNewDeviceOnExistingDevice(timeout = 10 * 1000) { - if (!this.newDeviceId) { - throw new Error("No new device to sign"); - } - if (!this.newDeviceKey) { - _logger.logger.info("No new device key to sign"); - return undefined; - } - if (!this.client.crypto) { - throw new Error("Crypto not available on client"); - } - const userId = this.client.getUserId(); - if (!userId) { - throw new Error("No user ID set"); - } - let deviceInfo = this.client.crypto.getStoredDevice(userId, this.newDeviceId); - if (!deviceInfo) { - _logger.logger.info("Going to wait for new device to be online"); - await (0, _utils.sleep)(timeout); - deviceInfo = this.client.crypto.getStoredDevice(userId, this.newDeviceId); - } - if (deviceInfo) { - return await this.verifyAndCrossSignDevice(deviceInfo); - } - throw new Error("Device not online within timeout"); - } - async cancel(reason) { - var _this$onFailure; - (_this$onFailure = this.onFailure) === null || _this$onFailure === void 0 ? void 0 : _this$onFailure.call(this, reason); - await this.channel.cancel(reason); - } - async close() { - await this.channel.close(); - } -} -exports.MSC3906Rendezvous = MSC3906Rendezvous; -//# sourceMappingURL=MSC3906Rendezvous.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js.map deleted file mode 100644 index 4c0b657..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/MSC3906Rendezvous.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3906Rendezvous.js","names":["_matrixEventsSdk","require","_","_feature","_logger","_utils","PayloadType","Outcome","LOGIN_TOKEN_PROTOCOL","UnstableValue","MSC3906Rendezvous","constructor","channel","client","onFailure","_defineProperty2","default","RendezvousIntent","RECIPROCATE_LOGIN_ON_EXISTING_DEVICE","code","_code","generateCode","JSON","stringify","ourIntent","startAfterShowingCode","checksum","connect","logger","info","features","buildFeatureSupportMap","getVersions","get","Feature","LoginTokenRequest","ServerSupport","Unsupported","send","type","Finish","outcome","cancel","RendezvousFailureReason","HomeserverLacksSupport","undefined","Progress","protocols","name","protocol","receive","UnsupportedAlgorithm","Unknown","matches","payload","declineLoginOnExistingDevice","Declined","approveLoginOnExistingDevice","loginToken","login_token","homeserver","baseUrl","res","device_id","deviceId","device_key","deviceKey","Error","newDeviceId","newDeviceKey","verifyAndCrossSignDevice","deviceInfo","crypto","getFingerprint","userId","getUserId","setDeviceVerification","masterPublicKey","crossSigningInfo","getId","Verified","verifying_device_id","getDeviceId","verifying_device_key","getDeviceEd25519Key","master_key","verifyNewDeviceOnExistingDevice","timeout","getStoredDevice","sleep","reason","_this$onFailure","call","close","exports"],"sources":["../../src/rendezvous/MSC3906Rendezvous.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { UnstableValue } from \"matrix-events-sdk\";\n\nimport { RendezvousChannel, RendezvousFailureListener, RendezvousFailureReason, RendezvousIntent } from \".\";\nimport { MatrixClient } from \"../client\";\nimport { CrossSigningInfo } from \"../crypto/CrossSigning\";\nimport { DeviceInfo } from \"../crypto/deviceinfo\";\nimport { buildFeatureSupportMap, Feature, ServerSupport } from \"../feature\";\nimport { logger } from \"../logger\";\nimport { sleep } from \"../utils\";\n\nenum PayloadType {\n Start = \"m.login.start\",\n Finish = \"m.login.finish\",\n Progress = \"m.login.progress\",\n}\n\nenum Outcome {\n Success = \"success\",\n Failure = \"failure\",\n Verified = \"verified\",\n Declined = \"declined\",\n Unsupported = \"unsupported\",\n}\n\nexport interface MSC3906RendezvousPayload {\n type: PayloadType;\n intent?: RendezvousIntent;\n outcome?: Outcome;\n device_id?: string;\n device_key?: string;\n verifying_device_id?: string;\n verifying_device_key?: string;\n master_key?: string;\n protocols?: string[];\n protocol?: string;\n login_token?: string;\n homeserver?: string;\n}\n\nconst LOGIN_TOKEN_PROTOCOL = new UnstableValue(\"login_token\", \"org.matrix.msc3906.login_token\");\n\n/**\n * Implements MSC3906 to allow a user to sign in on a new device using QR code.\n * This implementation only supports generating a QR code on a device that is already signed in.\n * Note that this is UNSTABLE and may have breaking changes without notice.\n */\nexport class MSC3906Rendezvous {\n private newDeviceId?: string;\n private newDeviceKey?: string;\n private ourIntent: RendezvousIntent = RendezvousIntent.RECIPROCATE_LOGIN_ON_EXISTING_DEVICE;\n private _code?: string;\n\n /**\n * @param channel - The secure channel used for communication\n * @param client - The Matrix client in used on the device already logged in\n * @param onFailure - Callback for when the rendezvous fails\n */\n public constructor(\n private channel: RendezvousChannel,\n private client: MatrixClient,\n public onFailure?: RendezvousFailureListener,\n ) {}\n\n /**\n * Returns the code representing the rendezvous suitable for rendering in a QR code or undefined if not generated yet.\n */\n public get code(): string | undefined {\n return this._code;\n }\n\n /**\n * Generate the code including doing partial set up of the channel where required.\n */\n public async generateCode(): Promise {\n if (this._code) {\n return;\n }\n\n this._code = JSON.stringify(await this.channel.generateCode(this.ourIntent));\n }\n\n public async startAfterShowingCode(): Promise {\n const checksum = await this.channel.connect();\n\n logger.info(`Connected to secure channel with checksum: ${checksum} our intent is ${this.ourIntent}`);\n\n const features = await buildFeatureSupportMap(await this.client.getVersions());\n // determine available protocols\n if (features.get(Feature.LoginTokenRequest) === ServerSupport.Unsupported) {\n logger.info(\"Server doesn't support MSC3882\");\n await this.send({ type: PayloadType.Finish, outcome: Outcome.Unsupported });\n await this.cancel(RendezvousFailureReason.HomeserverLacksSupport);\n return undefined;\n }\n\n await this.send({ type: PayloadType.Progress, protocols: [LOGIN_TOKEN_PROTOCOL.name] });\n\n logger.info(\"Waiting for other device to chose protocol\");\n const { type, protocol, outcome } = await this.receive();\n\n if (type === PayloadType.Finish) {\n // new device decided not to complete\n switch (outcome ?? \"\") {\n case \"unsupported\":\n await this.cancel(RendezvousFailureReason.UnsupportedAlgorithm);\n break;\n default:\n await this.cancel(RendezvousFailureReason.Unknown);\n }\n return undefined;\n }\n\n if (type !== PayloadType.Progress) {\n await this.cancel(RendezvousFailureReason.Unknown);\n return undefined;\n }\n\n if (!protocol || !LOGIN_TOKEN_PROTOCOL.matches(protocol)) {\n await this.cancel(RendezvousFailureReason.UnsupportedAlgorithm);\n return undefined;\n }\n\n return checksum;\n }\n\n private async receive(): Promise {\n return (await this.channel.receive()) as MSC3906RendezvousPayload;\n }\n\n private async send(payload: MSC3906RendezvousPayload): Promise {\n await this.channel.send(payload);\n }\n\n public async declineLoginOnExistingDevice(): Promise {\n logger.info(\"User declined sign in\");\n await this.send({ type: PayloadType.Finish, outcome: Outcome.Declined });\n }\n\n public async approveLoginOnExistingDevice(loginToken: string): Promise {\n // eslint-disable-next-line camelcase\n await this.send({ type: PayloadType.Progress, login_token: loginToken, homeserver: this.client.baseUrl });\n\n logger.info(\"Waiting for outcome\");\n const res = await this.receive();\n if (!res) {\n return undefined;\n }\n const { outcome, device_id: deviceId, device_key: deviceKey } = res;\n\n if (outcome !== \"success\") {\n throw new Error(\"Linking failed\");\n }\n\n this.newDeviceId = deviceId;\n this.newDeviceKey = deviceKey;\n\n return deviceId;\n }\n\n private async verifyAndCrossSignDevice(deviceInfo: DeviceInfo): Promise {\n if (!this.client.crypto) {\n throw new Error(\"Crypto not available on client\");\n }\n\n if (!this.newDeviceId) {\n throw new Error(\"No new device ID set\");\n }\n\n // check that keys received from the server for the new device match those received from the device itself\n if (deviceInfo.getFingerprint() !== this.newDeviceKey) {\n throw new Error(\n `New device has different keys than expected: ${this.newDeviceKey} vs ${deviceInfo.getFingerprint()}`,\n );\n }\n\n const userId = this.client.getUserId();\n\n if (!userId) {\n throw new Error(\"No user ID set\");\n }\n // mark the device as verified locally + cross sign\n logger.info(`Marking device ${this.newDeviceId} as verified`);\n const info = await this.client.crypto.setDeviceVerification(userId, this.newDeviceId, true, false, true);\n\n const masterPublicKey = this.client.crypto.crossSigningInfo.getId(\"master\")!;\n\n await this.send({\n type: PayloadType.Finish,\n outcome: Outcome.Verified,\n verifying_device_id: this.client.getDeviceId()!,\n verifying_device_key: this.client.getDeviceEd25519Key()!,\n master_key: masterPublicKey,\n });\n\n return info;\n }\n\n /**\n * Verify the device and cross-sign it.\n * @param timeout - time in milliseconds to wait for device to come online\n * @returns the new device info if the device was verified\n */\n public async verifyNewDeviceOnExistingDevice(\n timeout = 10 * 1000,\n ): Promise {\n if (!this.newDeviceId) {\n throw new Error(\"No new device to sign\");\n }\n\n if (!this.newDeviceKey) {\n logger.info(\"No new device key to sign\");\n return undefined;\n }\n\n if (!this.client.crypto) {\n throw new Error(\"Crypto not available on client\");\n }\n\n const userId = this.client.getUserId();\n\n if (!userId) {\n throw new Error(\"No user ID set\");\n }\n\n let deviceInfo = this.client.crypto.getStoredDevice(userId, this.newDeviceId);\n\n if (!deviceInfo) {\n logger.info(\"Going to wait for new device to be online\");\n await sleep(timeout);\n deviceInfo = this.client.crypto.getStoredDevice(userId, this.newDeviceId);\n }\n\n if (deviceInfo) {\n return await this.verifyAndCrossSignDevice(deviceInfo);\n }\n\n throw new Error(\"Device not online within timeout\");\n }\n\n public async cancel(reason: RendezvousFailureReason): Promise {\n this.onFailure?.(reason);\n await this.channel.cancel(reason);\n }\n\n public async close(): Promise {\n await this.channel.close();\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts deleted file mode 100644 index b125779..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts +++ /dev/null @@ -1,27 +0,0 @@ -import { RendezvousCode, RendezvousIntent, RendezvousFailureReason } from "."; -export interface RendezvousChannel { - /** - * @returns the checksum/confirmation digits to be shown to the user - */ - connect(): Promise; - /** - * Send a payload via the channel. - * @param data - payload to send - */ - send(data: T): Promise; - /** - * Receive a payload from the channel. - * @returns the received payload - */ - receive(): Promise | undefined>; - /** - * Close the channel and clear up any resources. - */ - close(): Promise; - /** - * @returns a representation of the channel that can be encoded in a QR or similar - */ - generateCode(intent: RendezvousIntent): Promise; - cancel(reason: RendezvousFailureReason): Promise; -} -//# sourceMappingURL=RendezvousChannel.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts.map deleted file mode 100644 index c24d602..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousChannel.d.ts","sourceRoot":"","sources":["../../src/rendezvous/RendezvousChannel.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,MAAM,GAAG,CAAC;AAE9E,MAAM,WAAW,iBAAiB,CAAC,CAAC;IAChC;;OAEG;IACH,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;IAE3B;;;OAGG;IACH,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE7B;;;OAGG;IACH,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IAE3C;;OAEG;IACH,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvB;;OAEG;IACH,YAAY,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;IAEhE,MAAM,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js deleted file mode 100644 index 9715e7f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=RendezvousChannel.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js.map deleted file mode 100644 index f6f0112..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousChannel.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousChannel.js","names":[],"sources":["../../src/rendezvous/RendezvousChannel.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { RendezvousCode, RendezvousIntent, RendezvousFailureReason } from \".\";\n\nexport interface RendezvousChannel {\n /**\n * @returns the checksum/confirmation digits to be shown to the user\n */\n connect(): Promise;\n\n /**\n * Send a payload via the channel.\n * @param data - payload to send\n */\n send(data: T): Promise;\n\n /**\n * Receive a payload from the channel.\n * @returns the received payload\n */\n receive(): Promise | undefined>;\n\n /**\n * Close the channel and clear up any resources.\n */\n close(): Promise;\n\n /**\n * @returns a representation of the channel that can be encoded in a QR or similar\n */\n generateCode(intent: RendezvousIntent): Promise;\n\n cancel(reason: RendezvousFailureReason): Promise;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts deleted file mode 100644 index 3b3dbe2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import { RendezvousTransportDetails, RendezvousIntent } from "."; -export interface RendezvousCode { - intent: RendezvousIntent; - rendezvous?: { - transport: RendezvousTransportDetails; - algorithm: string; - }; -} -//# sourceMappingURL=RendezvousCode.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts.map deleted file mode 100644 index 78b8eea..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousCode.d.ts","sourceRoot":"","sources":["../../src/rendezvous/RendezvousCode.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,0BAA0B,EAAE,gBAAgB,EAAE,MAAM,GAAG,CAAC;AAEjE,MAAM,WAAW,cAAc;IAC3B,MAAM,EAAE,gBAAgB,CAAC;IACzB,UAAU,CAAC,EAAE;QACT,SAAS,EAAE,0BAA0B,CAAC;QACtC,SAAS,EAAE,MAAM,CAAC;KACrB,CAAC;CACL"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js deleted file mode 100644 index 1f58551..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=RendezvousCode.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js.map deleted file mode 100644 index 2bea3dc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousCode.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousCode.js","names":[],"sources":["../../src/rendezvous/RendezvousCode.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { RendezvousTransportDetails, RendezvousIntent } from \".\";\n\nexport interface RendezvousCode {\n intent: RendezvousIntent;\n rendezvous?: {\n transport: RendezvousTransportDetails;\n algorithm: string;\n };\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts deleted file mode 100644 index a0d58b7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts +++ /dev/null @@ -1,6 +0,0 @@ -import { RendezvousFailureReason } from "."; -export declare class RendezvousError extends Error { - readonly code: RendezvousFailureReason; - constructor(message: string, code: RendezvousFailureReason); -} -//# sourceMappingURL=RendezvousError.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts.map deleted file mode 100644 index 74e1cbe..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousError.d.ts","sourceRoot":"","sources":["../../src/rendezvous/RendezvousError.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,uBAAuB,EAAE,MAAM,GAAG,CAAC;AAE5C,qBAAa,eAAgB,SAAQ,KAAK;aACc,IAAI,EAAE,uBAAuB;gBAA9D,OAAO,EAAE,MAAM,EAAkB,IAAI,EAAE,uBAAuB;CAGpF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js deleted file mode 100644 index 426c882..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js +++ /dev/null @@ -1,30 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RendezvousError = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class RendezvousError extends Error { - constructor(message, code) { - super(message); - this.code = code; - } -} -exports.RendezvousError = RendezvousError; -//# sourceMappingURL=RendezvousError.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js.map deleted file mode 100644 index afb990b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousError.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousError.js","names":["RendezvousError","Error","constructor","message","code","exports"],"sources":["../../src/rendezvous/RendezvousError.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { RendezvousFailureReason } from \".\";\n\nexport class RendezvousError extends Error {\n public constructor(message: string, public readonly code: RendezvousFailureReason) {\n super(message);\n }\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIO,MAAMA,eAAe,SAASC,KAAK,CAAC;EAChCC,WAAWA,CAACC,OAAe,EAAkBC,IAA6B,EAAE;IAC/E,KAAK,CAACD,OAAO,CAAC;IAAC,KADiCC,IAA6B,GAA7BA,IAA6B;EAEjF;AACJ;AAACC,OAAA,CAAAL,eAAA,GAAAA,eAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts deleted file mode 100644 index 76aba78..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -export type RendezvousFailureListener = (reason: RendezvousFailureReason) => void; -export declare enum RendezvousFailureReason { - UserDeclined = "user_declined", - OtherDeviceNotSignedIn = "other_device_not_signed_in", - OtherDeviceAlreadySignedIn = "other_device_already_signed_in", - Unknown = "unknown", - Expired = "expired", - UserCancelled = "user_cancelled", - InvalidCode = "invalid_code", - UnsupportedAlgorithm = "unsupported_algorithm", - DataMismatch = "data_mismatch", - UnsupportedTransport = "unsupported_transport", - HomeserverLacksSupport = "homeserver_lacks_support" -} -//# sourceMappingURL=RendezvousFailureReason.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts.map deleted file mode 100644 index 5f508ea..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousFailureReason.d.ts","sourceRoot":"","sources":["../../src/rendezvous/RendezvousFailureReason.ts"],"names":[],"mappings":"AAgBA,MAAM,MAAM,yBAAyB,GAAG,CAAC,MAAM,EAAE,uBAAuB,KAAK,IAAI,CAAC;AAElF,oBAAY,uBAAuB;IAC/B,YAAY,kBAAkB;IAC9B,sBAAsB,+BAA+B;IACrD,0BAA0B,mCAAmC;IAC7D,OAAO,YAAY;IACnB,OAAO,YAAY;IACnB,aAAa,mBAAmB;IAChC,WAAW,iBAAiB;IAC5B,oBAAoB,0BAA0B;IAC9C,YAAY,kBAAkB;IAC9B,oBAAoB,0BAA0B;IAC9C,sBAAsB,6BAA6B;CACtD"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js deleted file mode 100644 index 78a23bf..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js +++ /dev/null @@ -1,37 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RendezvousFailureReason = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let RendezvousFailureReason; -exports.RendezvousFailureReason = RendezvousFailureReason; -(function (RendezvousFailureReason) { - RendezvousFailureReason["UserDeclined"] = "user_declined"; - RendezvousFailureReason["OtherDeviceNotSignedIn"] = "other_device_not_signed_in"; - RendezvousFailureReason["OtherDeviceAlreadySignedIn"] = "other_device_already_signed_in"; - RendezvousFailureReason["Unknown"] = "unknown"; - RendezvousFailureReason["Expired"] = "expired"; - RendezvousFailureReason["UserCancelled"] = "user_cancelled"; - RendezvousFailureReason["InvalidCode"] = "invalid_code"; - RendezvousFailureReason["UnsupportedAlgorithm"] = "unsupported_algorithm"; - RendezvousFailureReason["DataMismatch"] = "data_mismatch"; - RendezvousFailureReason["UnsupportedTransport"] = "unsupported_transport"; - RendezvousFailureReason["HomeserverLacksSupport"] = "homeserver_lacks_support"; -})(RendezvousFailureReason || (exports.RendezvousFailureReason = RendezvousFailureReason = {})); -//# sourceMappingURL=RendezvousFailureReason.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js.map deleted file mode 100644 index 5a815b7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousFailureReason.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousFailureReason.js","names":["RendezvousFailureReason","exports"],"sources":["../../src/rendezvous/RendezvousFailureReason.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport type RendezvousFailureListener = (reason: RendezvousFailureReason) => void;\n\nexport enum RendezvousFailureReason {\n UserDeclined = \"user_declined\",\n OtherDeviceNotSignedIn = \"other_device_not_signed_in\",\n OtherDeviceAlreadySignedIn = \"other_device_already_signed_in\",\n Unknown = \"unknown\",\n Expired = \"expired\",\n UserCancelled = \"user_cancelled\",\n InvalidCode = \"invalid_code\",\n UnsupportedAlgorithm = \"unsupported_algorithm\",\n DataMismatch = \"data_mismatch\",\n UnsupportedTransport = \"unsupported_transport\",\n HomeserverLacksSupport = \"homeserver_lacks_support\",\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAkBYA,uBAAuB;AAAAC,OAAA,CAAAD,uBAAA,GAAAA,uBAAA;AAAA,WAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;EAAvBA,uBAAuB;AAAA,GAAvBA,uBAAuB,KAAAC,OAAA,CAAAD,uBAAA,GAAvBA,uBAAuB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts deleted file mode 100644 index 4ac5d22..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -export declare enum RendezvousIntent { - LOGIN_ON_NEW_DEVICE = "login.start", - RECIPROCATE_LOGIN_ON_EXISTING_DEVICE = "login.reciprocate" -} -//# sourceMappingURL=RendezvousIntent.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts.map deleted file mode 100644 index 55f5952..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousIntent.d.ts","sourceRoot":"","sources":["../../src/rendezvous/RendezvousIntent.ts"],"names":[],"mappings":"AAgBA,oBAAY,gBAAgB;IACxB,mBAAmB,gBAAgB;IACnC,oCAAoC,sBAAsB;CAC7D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js deleted file mode 100644 index 5ea56dd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RendezvousIntent = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let RendezvousIntent; -exports.RendezvousIntent = RendezvousIntent; -(function (RendezvousIntent) { - RendezvousIntent["LOGIN_ON_NEW_DEVICE"] = "login.start"; - RendezvousIntent["RECIPROCATE_LOGIN_ON_EXISTING_DEVICE"] = "login.reciprocate"; -})(RendezvousIntent || (exports.RendezvousIntent = RendezvousIntent = {})); -//# sourceMappingURL=RendezvousIntent.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js.map deleted file mode 100644 index 78cd14f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousIntent.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousIntent.js","names":["RendezvousIntent","exports"],"sources":["../../src/rendezvous/RendezvousIntent.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport enum RendezvousIntent {\n LOGIN_ON_NEW_DEVICE = \"login.start\",\n RECIPROCATE_LOGIN_ON_EXISTING_DEVICE = \"login.reciprocate\",\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAgBYA,gBAAgB;AAAAC,OAAA,CAAAD,gBAAA,GAAAA,gBAAA;AAAA,WAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;AAAA,GAAhBA,gBAAgB,KAAAC,OAAA,CAAAD,gBAAA,GAAhBA,gBAAgB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts deleted file mode 100644 index ddc2a4d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts +++ /dev/null @@ -1,36 +0,0 @@ -import { RendezvousFailureListener, RendezvousFailureReason } from "."; -export interface RendezvousTransportDetails { - type: string; -} -/** - * Interface representing a generic rendezvous transport. - */ -export interface RendezvousTransport { - /** - * Ready state of the transport. This is set to true when the transport is ready to be used. - */ - readonly ready: boolean; - /** - * Listener for cancellation events. This is called when the rendezvous is cancelled or fails. - */ - onFailure?: RendezvousFailureListener; - /** - * @returns the transport details that can be encoded in a QR or similar - */ - details(): Promise; - /** - * Send data via the transport. - * @param data - the data itself - */ - send(data: T): Promise; - /** - * Receive data from the transport. - */ - receive(): Promise | undefined>; - /** - * Cancel the rendezvous. This will call `onCancelled()` if it is set. - * @param reason - the reason for the cancellation/failure - */ - cancel(reason: RendezvousFailureReason): Promise; -} -//# sourceMappingURL=RendezvousTransport.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts.map deleted file mode 100644 index 21f263c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousTransport.d.ts","sourceRoot":"","sources":["../../src/rendezvous/RendezvousTransport.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,yBAAyB,EAAE,uBAAuB,EAAE,MAAM,GAAG,CAAC;AAEvE,MAAM,WAAW,0BAA0B;IACvC,IAAI,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB,CAAC,CAAC;IAClC;;OAEG;IACH,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC;IAExB;;OAEG;IACH,SAAS,CAAC,EAAE,yBAAyB,CAAC;IAEtC;;OAEG;IACH,OAAO,IAAI,OAAO,CAAC,0BAA0B,CAAC,CAAC;IAE/C;;;OAGG;IACH,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE7B;;OAEG;IACH,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IAE3C;;;OAGG;IACH,MAAM,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js deleted file mode 100644 index 026d012..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=RendezvousTransport.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js.map deleted file mode 100644 index 4839035..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/RendezvousTransport.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RendezvousTransport.js","names":[],"sources":["../../src/rendezvous/RendezvousTransport.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { RendezvousFailureListener, RendezvousFailureReason } from \".\";\n\nexport interface RendezvousTransportDetails {\n type: string;\n}\n\n/**\n * Interface representing a generic rendezvous transport.\n */\nexport interface RendezvousTransport {\n /**\n * Ready state of the transport. This is set to true when the transport is ready to be used.\n */\n readonly ready: boolean;\n\n /**\n * Listener for cancellation events. This is called when the rendezvous is cancelled or fails.\n */\n onFailure?: RendezvousFailureListener;\n\n /**\n * @returns the transport details that can be encoded in a QR or similar\n */\n details(): Promise;\n\n /**\n * Send data via the transport.\n * @param data - the data itself\n */\n send(data: T): Promise;\n\n /**\n * Receive data from the transport.\n */\n receive(): Promise | undefined>;\n\n /**\n * Cancel the rendezvous. This will call `onCancelled()` if it is set.\n * @param reason - the reason for the cancellation/failure\n */\n cancel(reason: RendezvousFailureReason): Promise;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts deleted file mode 100644 index 06a9a36..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts +++ /dev/null @@ -1,44 +0,0 @@ -import { RendezvousCode, RendezvousIntent, RendezvousChannel, RendezvousTransportDetails, RendezvousTransport, RendezvousFailureReason } from ".."; -import { UnstableValue } from "../../NamespacedValue"; -declare const ECDH_V2: UnstableValue<"m.rendezvous.v2.curve25519-aes-sha256", "org.matrix.msc3903.rendezvous.v2.curve25519-aes-sha256">; -export interface ECDHv2RendezvousCode extends RendezvousCode { - rendezvous: { - transport: RendezvousTransportDetails; - algorithm: typeof ECDH_V2.name | typeof ECDH_V2.altName; - key: string; - }; -} -export type MSC3903ECDHPayload = PlainTextPayload | EncryptedPayload; -export interface PlainTextPayload { - algorithm: typeof ECDH_V2.name | typeof ECDH_V2.altName; - key?: string; -} -export interface EncryptedPayload { - iv: string; - ciphertext: string; -} -/** - * Implementation of the unstable [MSC3903](https://github.com/matrix-org/matrix-spec-proposals/pull/3903) - * X25519/ECDH key agreement based secure rendezvous channel. - * Note that this is UNSTABLE and may have breaking changes without notice. - */ -export declare class MSC3903ECDHv2RendezvousChannel implements RendezvousChannel { - private transport; - private theirPublicKey?; - onFailure?: ((reason: RendezvousFailureReason) => void) | undefined; - private olmSAS?; - private ourPublicKey; - private aesKey?; - private connected; - constructor(transport: RendezvousTransport, theirPublicKey?: Uint8Array | undefined, onFailure?: ((reason: RendezvousFailureReason) => void) | undefined); - generateCode(intent: RendezvousIntent): Promise; - connect(): Promise; - private encrypt; - send(payload: T): Promise; - private decrypt; - receive(): Promise | undefined>; - close(): Promise; - cancel(reason: RendezvousFailureReason): Promise; -} -export {}; -//# sourceMappingURL=MSC3903ECDHv2RendezvousChannel.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts.map deleted file mode 100644 index f23ad42..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3903ECDHv2RendezvousChannel.d.ts","sourceRoot":"","sources":["../../../src/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.ts"],"names":[],"mappings":"AAkBA,OAAO,EAEH,cAAc,EACd,gBAAgB,EAChB,iBAAiB,EACjB,0BAA0B,EAC1B,mBAAmB,EACnB,uBAAuB,EAC1B,MAAM,IAAI,CAAC;AAIZ,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAEtD,QAAA,MAAM,OAAO,kHAGZ,CAAC;AAEF,MAAM,WAAW,oBAAqB,SAAQ,cAAc;IACxD,UAAU,EAAE;QACR,SAAS,EAAE,0BAA0B,CAAC;QACtC,SAAS,EAAE,OAAO,OAAO,CAAC,IAAI,GAAG,OAAO,OAAO,CAAC,OAAO,CAAC;QACxD,GAAG,EAAE,MAAM,CAAC;KACf,CAAC;CACL;AAED,MAAM,MAAM,kBAAkB,GAAG,gBAAgB,GAAG,gBAAgB,CAAC;AAErE,MAAM,WAAW,gBAAgB;IAC7B,SAAS,EAAE,OAAO,OAAO,CAAC,IAAI,GAAG,OAAO,OAAO,CAAC,OAAO,CAAC;IACxD,GAAG,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,gBAAgB;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,UAAU,EAAE,MAAM,CAAC;CACtB;AAYD;;;;GAIG;AACH,qBAAa,8BAA8B,CAAC,CAAC,CAAE,YAAW,iBAAiB,CAAC,CAAC,CAAC;IAOtE,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,cAAc,CAAC;IAChB,SAAS,CAAC,YAAW,uBAAuB,KAAK,IAAI;IARhE,OAAO,CAAC,MAAM,CAAC,CAAM;IACrB,OAAO,CAAC,YAAY,CAAa;IACjC,OAAO,CAAC,MAAM,CAAC,CAAY;IAC3B,OAAO,CAAC,SAAS,CAAS;gBAGd,SAAS,EAAE,mBAAmB,CAAC,kBAAkB,CAAC,EAClD,cAAc,CAAC,wBAAY,EAC5B,SAAS,CAAC,YAAW,uBAAuB,KAAK,IAAI,aAAA;IAMnD,YAAY,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAmBrE,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;YAwDzB,OAAO;IA0BR,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;YAY9B,OAAO;IAwBR,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;IAoB1C,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAOtB,MAAM,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;CAOtE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js deleted file mode 100644 index 775257b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js +++ /dev/null @@ -1,196 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MSC3903ECDHv2RendezvousChannel = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _ = require(".."); -var _olmlib = require("../../crypto/olmlib"); -var _crypto = require("../../crypto/crypto"); -var _SASDecimal = require("../../crypto/verification/SASDecimal"); -var _NamespacedValue = require("../../NamespacedValue"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const ECDH_V2 = new _NamespacedValue.UnstableValue("m.rendezvous.v2.curve25519-aes-sha256", "org.matrix.msc3903.rendezvous.v2.curve25519-aes-sha256"); -async function importKey(key) { - if (!_crypto.subtleCrypto) { - throw new Error("Web Crypto is not available"); - } - const imported = _crypto.subtleCrypto.importKey("raw", key, { - name: "AES-GCM" - }, false, ["encrypt", "decrypt"]); - return imported; -} - -/** - * Implementation of the unstable [MSC3903](https://github.com/matrix-org/matrix-spec-proposals/pull/3903) - * X25519/ECDH key agreement based secure rendezvous channel. - * Note that this is UNSTABLE and may have breaking changes without notice. - */ -class MSC3903ECDHv2RendezvousChannel { - constructor(transport, theirPublicKey, onFailure) { - this.transport = transport; - this.theirPublicKey = theirPublicKey; - this.onFailure = onFailure; - (0, _defineProperty2.default)(this, "olmSAS", void 0); - (0, _defineProperty2.default)(this, "ourPublicKey", void 0); - (0, _defineProperty2.default)(this, "aesKey", void 0); - (0, _defineProperty2.default)(this, "connected", false); - this.olmSAS = new global.Olm.SAS(); - this.ourPublicKey = (0, _olmlib.decodeBase64)(this.olmSAS.get_pubkey()); - } - async generateCode(intent) { - if (this.transport.ready) { - throw new Error("Code already generated"); - } - await this.transport.send({ - algorithm: ECDH_V2.name - }); - const rendezvous = { - rendezvous: { - algorithm: ECDH_V2.name, - key: (0, _olmlib.encodeUnpaddedBase64)(this.ourPublicKey), - transport: await this.transport.details() - }, - intent - }; - return rendezvous; - } - async connect() { - if (this.connected) { - throw new Error("Channel already connected"); - } - if (!this.olmSAS) { - throw new Error("Channel closed"); - } - const isInitiator = !this.theirPublicKey; - if (isInitiator) { - // wait for the other side to send us their public key - const rawRes = await this.transport.receive(); - if (!rawRes) { - throw new Error("No response from other device"); - } - const res = rawRes; - const { - key, - algorithm - } = res; - if (!algorithm || !ECDH_V2.matches(algorithm) || !key) { - throw new _.RendezvousError("Unsupported algorithm: " + algorithm, _.RendezvousFailureReason.UnsupportedAlgorithm); - } - this.theirPublicKey = (0, _olmlib.decodeBase64)(key); - } else { - // send our public key unencrypted - await this.transport.send({ - algorithm: ECDH_V2.name, - key: (0, _olmlib.encodeUnpaddedBase64)(this.ourPublicKey) - }); - } - this.connected = true; - this.olmSAS.set_their_key((0, _olmlib.encodeUnpaddedBase64)(this.theirPublicKey)); - const initiatorKey = isInitiator ? this.ourPublicKey : this.theirPublicKey; - const recipientKey = isInitiator ? this.theirPublicKey : this.ourPublicKey; - let aesInfo = ECDH_V2.name; - aesInfo += `|${(0, _olmlib.encodeUnpaddedBase64)(initiatorKey)}`; - aesInfo += `|${(0, _olmlib.encodeUnpaddedBase64)(recipientKey)}`; - const aesKeyBytes = this.olmSAS.generate_bytes(aesInfo, 32); - this.aesKey = await importKey(aesKeyBytes); - - // blank the bytes out to make sure not kept in memory - aesKeyBytes.fill(0); - const rawChecksum = this.olmSAS.generate_bytes(aesInfo, 5); - return (0, _SASDecimal.generateDecimalSas)(Array.from(rawChecksum)).join("-"); - } - async encrypt(data) { - if (!_crypto.subtleCrypto) { - throw new Error("Web Crypto is not available"); - } - const iv = new Uint8Array(32); - _crypto.crypto.getRandomValues(iv); - const encodedData = new _crypto.TextEncoder().encode(JSON.stringify(data)); - const ciphertext = await _crypto.subtleCrypto.encrypt({ - name: "AES-GCM", - iv, - tagLength: 128 - }, this.aesKey, encodedData); - return { - iv: (0, _olmlib.encodeUnpaddedBase64)(iv), - ciphertext: (0, _olmlib.encodeUnpaddedBase64)(ciphertext) - }; - } - async send(payload) { - if (!this.olmSAS) { - throw new Error("Channel closed"); - } - if (!this.aesKey) { - throw new Error("Shared secret not set up"); - } - return this.transport.send(await this.encrypt(payload)); - } - async decrypt({ - iv, - ciphertext - }) { - if (!ciphertext || !iv) { - throw new Error("Missing ciphertext and/or iv"); - } - const ciphertextBytes = (0, _olmlib.decodeBase64)(ciphertext); - if (!_crypto.subtleCrypto) { - throw new Error("Web Crypto is not available"); - } - const plaintext = await _crypto.subtleCrypto.decrypt({ - name: "AES-GCM", - iv: (0, _olmlib.decodeBase64)(iv), - tagLength: 128 - }, this.aesKey, ciphertextBytes); - return JSON.parse(new TextDecoder().decode(new Uint8Array(plaintext))); - } - async receive() { - if (!this.olmSAS) { - throw new Error("Channel closed"); - } - if (!this.aesKey) { - throw new Error("Shared secret not set up"); - } - const rawData = await this.transport.receive(); - if (!rawData) { - return undefined; - } - const data = rawData; - if (data.ciphertext && data.iv) { - return this.decrypt(data); - } - throw new Error("Data received but no ciphertext"); - } - async close() { - if (this.olmSAS) { - this.olmSAS.free(); - this.olmSAS = undefined; - } - } - async cancel(reason) { - try { - await this.transport.cancel(reason); - } finally { - await this.close(); - } - } -} -exports.MSC3903ECDHv2RendezvousChannel = MSC3903ECDHv2RendezvousChannel; -//# sourceMappingURL=MSC3903ECDHv2RendezvousChannel.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js.map deleted file mode 100644 index e1ec1d9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3903ECDHv2RendezvousChannel.js","names":["_","require","_olmlib","_crypto","_SASDecimal","_NamespacedValue","ECDH_V2","UnstableValue","importKey","key","subtleCrypto","Error","imported","name","MSC3903ECDHv2RendezvousChannel","constructor","transport","theirPublicKey","onFailure","_defineProperty2","default","olmSAS","global","Olm","SAS","ourPublicKey","decodeBase64","get_pubkey","generateCode","intent","ready","send","algorithm","rendezvous","encodeUnpaddedBase64","details","connect","connected","isInitiator","rawRes","receive","res","matches","RendezvousError","RendezvousFailureReason","UnsupportedAlgorithm","set_their_key","initiatorKey","recipientKey","aesInfo","aesKeyBytes","generate_bytes","aesKey","fill","rawChecksum","generateDecimalSas","Array","from","join","encrypt","data","iv","Uint8Array","crypto","getRandomValues","encodedData","TextEncoder","encode","JSON","stringify","ciphertext","tagLength","payload","decrypt","ciphertextBytes","plaintext","parse","TextDecoder","decode","rawData","undefined","close","free","cancel","reason","exports"],"sources":["../../../src/rendezvous/channels/MSC3903ECDHv2RendezvousChannel.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { SAS } from \"@matrix-org/olm\";\n\nimport {\n RendezvousError,\n RendezvousCode,\n RendezvousIntent,\n RendezvousChannel,\n RendezvousTransportDetails,\n RendezvousTransport,\n RendezvousFailureReason,\n} from \"..\";\nimport { encodeUnpaddedBase64, decodeBase64 } from \"../../crypto/olmlib\";\nimport { crypto, subtleCrypto, TextEncoder } from \"../../crypto/crypto\";\nimport { generateDecimalSas } from \"../../crypto/verification/SASDecimal\";\nimport { UnstableValue } from \"../../NamespacedValue\";\n\nconst ECDH_V2 = new UnstableValue(\n \"m.rendezvous.v2.curve25519-aes-sha256\",\n \"org.matrix.msc3903.rendezvous.v2.curve25519-aes-sha256\",\n);\n\nexport interface ECDHv2RendezvousCode extends RendezvousCode {\n rendezvous: {\n transport: RendezvousTransportDetails;\n algorithm: typeof ECDH_V2.name | typeof ECDH_V2.altName;\n key: string;\n };\n}\n\nexport type MSC3903ECDHPayload = PlainTextPayload | EncryptedPayload;\n\nexport interface PlainTextPayload {\n algorithm: typeof ECDH_V2.name | typeof ECDH_V2.altName;\n key?: string;\n}\n\nexport interface EncryptedPayload {\n iv: string;\n ciphertext: string;\n}\n\nasync function importKey(key: Uint8Array): Promise {\n if (!subtleCrypto) {\n throw new Error(\"Web Crypto is not available\");\n }\n\n const imported = subtleCrypto.importKey(\"raw\", key, { name: \"AES-GCM\" }, false, [\"encrypt\", \"decrypt\"]);\n\n return imported;\n}\n\n/**\n * Implementation of the unstable [MSC3903](https://github.com/matrix-org/matrix-spec-proposals/pull/3903)\n * X25519/ECDH key agreement based secure rendezvous channel.\n * Note that this is UNSTABLE and may have breaking changes without notice.\n */\nexport class MSC3903ECDHv2RendezvousChannel implements RendezvousChannel {\n private olmSAS?: SAS;\n private ourPublicKey: Uint8Array;\n private aesKey?: CryptoKey;\n private connected = false;\n\n public constructor(\n private transport: RendezvousTransport,\n private theirPublicKey?: Uint8Array,\n public onFailure?: (reason: RendezvousFailureReason) => void,\n ) {\n this.olmSAS = new global.Olm.SAS();\n this.ourPublicKey = decodeBase64(this.olmSAS.get_pubkey());\n }\n\n public async generateCode(intent: RendezvousIntent): Promise {\n if (this.transport.ready) {\n throw new Error(\"Code already generated\");\n }\n\n await this.transport.send({ algorithm: ECDH_V2.name });\n\n const rendezvous: ECDHv2RendezvousCode = {\n rendezvous: {\n algorithm: ECDH_V2.name,\n key: encodeUnpaddedBase64(this.ourPublicKey),\n transport: await this.transport.details(),\n },\n intent,\n };\n\n return rendezvous;\n }\n\n public async connect(): Promise {\n if (this.connected) {\n throw new Error(\"Channel already connected\");\n }\n\n if (!this.olmSAS) {\n throw new Error(\"Channel closed\");\n }\n\n const isInitiator = !this.theirPublicKey;\n\n if (isInitiator) {\n // wait for the other side to send us their public key\n const rawRes = await this.transport.receive();\n if (!rawRes) {\n throw new Error(\"No response from other device\");\n }\n const res = rawRes as Partial;\n const { key, algorithm } = res;\n if (!algorithm || !ECDH_V2.matches(algorithm) || !key) {\n throw new RendezvousError(\n \"Unsupported algorithm: \" + algorithm,\n RendezvousFailureReason.UnsupportedAlgorithm,\n );\n }\n\n this.theirPublicKey = decodeBase64(key);\n } else {\n // send our public key unencrypted\n await this.transport.send({\n algorithm: ECDH_V2.name,\n key: encodeUnpaddedBase64(this.ourPublicKey),\n });\n }\n\n this.connected = true;\n\n this.olmSAS.set_their_key(encodeUnpaddedBase64(this.theirPublicKey!));\n\n const initiatorKey = isInitiator ? this.ourPublicKey : this.theirPublicKey!;\n const recipientKey = isInitiator ? this.theirPublicKey! : this.ourPublicKey;\n let aesInfo = ECDH_V2.name;\n aesInfo += `|${encodeUnpaddedBase64(initiatorKey)}`;\n aesInfo += `|${encodeUnpaddedBase64(recipientKey)}`;\n\n const aesKeyBytes = this.olmSAS.generate_bytes(aesInfo, 32);\n\n this.aesKey = await importKey(aesKeyBytes);\n\n // blank the bytes out to make sure not kept in memory\n aesKeyBytes.fill(0);\n\n const rawChecksum = this.olmSAS.generate_bytes(aesInfo, 5);\n return generateDecimalSas(Array.from(rawChecksum)).join(\"-\");\n }\n\n private async encrypt(data: T): Promise {\n if (!subtleCrypto) {\n throw new Error(\"Web Crypto is not available\");\n }\n\n const iv = new Uint8Array(32);\n crypto.getRandomValues(iv);\n\n const encodedData = new TextEncoder().encode(JSON.stringify(data));\n\n const ciphertext = await subtleCrypto.encrypt(\n {\n name: \"AES-GCM\",\n iv,\n tagLength: 128,\n },\n this.aesKey as CryptoKey,\n encodedData,\n );\n\n return {\n iv: encodeUnpaddedBase64(iv),\n ciphertext: encodeUnpaddedBase64(ciphertext),\n };\n }\n\n public async send(payload: T): Promise {\n if (!this.olmSAS) {\n throw new Error(\"Channel closed\");\n }\n\n if (!this.aesKey) {\n throw new Error(\"Shared secret not set up\");\n }\n\n return this.transport.send(await this.encrypt(payload));\n }\n\n private async decrypt({ iv, ciphertext }: EncryptedPayload): Promise> {\n if (!ciphertext || !iv) {\n throw new Error(\"Missing ciphertext and/or iv\");\n }\n\n const ciphertextBytes = decodeBase64(ciphertext);\n\n if (!subtleCrypto) {\n throw new Error(\"Web Crypto is not available\");\n }\n\n const plaintext = await subtleCrypto.decrypt(\n {\n name: \"AES-GCM\",\n iv: decodeBase64(iv),\n tagLength: 128,\n },\n this.aesKey as CryptoKey,\n ciphertextBytes,\n );\n\n return JSON.parse(new TextDecoder().decode(new Uint8Array(plaintext)));\n }\n\n public async receive(): Promise | undefined> {\n if (!this.olmSAS) {\n throw new Error(\"Channel closed\");\n }\n if (!this.aesKey) {\n throw new Error(\"Shared secret not set up\");\n }\n\n const rawData = await this.transport.receive();\n if (!rawData) {\n return undefined;\n }\n const data = rawData as Partial;\n if (data.ciphertext && data.iv) {\n return this.decrypt(data as EncryptedPayload);\n }\n\n throw new Error(\"Data received but no ciphertext\");\n }\n\n public async close(): Promise {\n if (this.olmSAS) {\n this.olmSAS.free();\n this.olmSAS = undefined;\n }\n }\n\n public async cancel(reason: RendezvousFailureReason): Promise {\n try {\n await this.transport.cancel(reason);\n } finally {\n await this.close();\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts deleted file mode 100644 index 04a448a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -export * from "./MSC3903ECDHv2RendezvousChannel"; -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts.map deleted file mode 100644 index 5bbb544..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/rendezvous/channels/index.ts"],"names":[],"mappings":"AAgBA,cAAc,kCAAkC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js deleted file mode 100644 index 0c20fc0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js +++ /dev/null @@ -1,17 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -var _MSC3903ECDHv2RendezvousChannel = require("./MSC3903ECDHv2RendezvousChannel"); -Object.keys(_MSC3903ECDHv2RendezvousChannel).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _MSC3903ECDHv2RendezvousChannel[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _MSC3903ECDHv2RendezvousChannel[key]; - } - }); -}); -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js.map deleted file mode 100644 index da2c50a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/channels/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["_MSC3903ECDHv2RendezvousChannel","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["../../../src/rendezvous/channels/index.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport * from \"./MSC3903ECDHv2RendezvousChannel\";\n"],"mappings":";;;;;AAgBA,IAAAA,+BAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,+BAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,+BAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,+BAAA,CAAAK,GAAA;IAAA;EAAA;AAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts deleted file mode 100644 index eb32638..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts +++ /dev/null @@ -1,8 +0,0 @@ -export * from "./MSC3906Rendezvous"; -export * from "./RendezvousChannel"; -export * from "./RendezvousCode"; -export * from "./RendezvousError"; -export * from "./RendezvousFailureReason"; -export * from "./RendezvousIntent"; -export * from "./RendezvousTransport"; -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts.map deleted file mode 100644 index b1efe4b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/rendezvous/index.ts"],"names":[],"mappings":"AAgBA,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js deleted file mode 100644 index 2c6212c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js +++ /dev/null @@ -1,83 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -var _MSC3906Rendezvous = require("./MSC3906Rendezvous"); -Object.keys(_MSC3906Rendezvous).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _MSC3906Rendezvous[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _MSC3906Rendezvous[key]; - } - }); -}); -var _RendezvousChannel = require("./RendezvousChannel"); -Object.keys(_RendezvousChannel).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _RendezvousChannel[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _RendezvousChannel[key]; - } - }); -}); -var _RendezvousCode = require("./RendezvousCode"); -Object.keys(_RendezvousCode).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _RendezvousCode[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _RendezvousCode[key]; - } - }); -}); -var _RendezvousError = require("./RendezvousError"); -Object.keys(_RendezvousError).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _RendezvousError[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _RendezvousError[key]; - } - }); -}); -var _RendezvousFailureReason = require("./RendezvousFailureReason"); -Object.keys(_RendezvousFailureReason).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _RendezvousFailureReason[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _RendezvousFailureReason[key]; - } - }); -}); -var _RendezvousIntent = require("./RendezvousIntent"); -Object.keys(_RendezvousIntent).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _RendezvousIntent[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _RendezvousIntent[key]; - } - }); -}); -var _RendezvousTransport = require("./RendezvousTransport"); -Object.keys(_RendezvousTransport).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _RendezvousTransport[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _RendezvousTransport[key]; - } - }); -}); -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js.map deleted file mode 100644 index c51b1bb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["_MSC3906Rendezvous","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get","_RendezvousChannel","_RendezvousCode","_RendezvousError","_RendezvousFailureReason","_RendezvousIntent","_RendezvousTransport"],"sources":["../../src/rendezvous/index.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport * from \"./MSC3906Rendezvous\";\nexport * from \"./RendezvousChannel\";\nexport * from \"./RendezvousCode\";\nexport * from \"./RendezvousError\";\nexport * from \"./RendezvousFailureReason\";\nexport * from \"./RendezvousIntent\";\nexport * from \"./RendezvousTransport\";\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts deleted file mode 100644 index 4e3aee7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts +++ /dev/null @@ -1,35 +0,0 @@ -import { RendezvousFailureListener, RendezvousFailureReason, RendezvousTransport, RendezvousTransportDetails } from ".."; -import { MatrixClient } from "../../matrix"; -export interface MSC3886SimpleHttpRendezvousTransportDetails extends RendezvousTransportDetails { - uri: string; -} -/** - * Implementation of the unstable [MSC3886](https://github.com/matrix-org/matrix-spec-proposals/pull/3886) - * simple HTTP rendezvous protocol. - * Note that this is UNSTABLE and may have breaking changes without notice. - */ -export declare class MSC3886SimpleHttpRendezvousTransport implements RendezvousTransport { - private uri?; - private etag?; - private expiresAt?; - private client; - private fallbackRzServer?; - private fetchFn?; - private cancelled; - private _ready; - onFailure?: RendezvousFailureListener; - constructor({ onFailure, client, fallbackRzServer, fetchFn, }: { - fetchFn?: typeof global.fetch; - onFailure?: RendezvousFailureListener; - client: MatrixClient; - fallbackRzServer?: string; - }); - get ready(): boolean; - details(): Promise; - private fetch; - private getPostEndpoint; - send(data: T): Promise; - receive(): Promise | undefined>; - cancel(reason: RendezvousFailureReason): Promise; -} -//# sourceMappingURL=MSC3886SimpleHttpRendezvousTransport.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts.map deleted file mode 100644 index 2203a15..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3886SimpleHttpRendezvousTransport.d.ts","sourceRoot":"","sources":["../../../src/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.ts"],"names":[],"mappings":"AAoBA,OAAO,EACH,yBAAyB,EACzB,uBAAuB,EACvB,mBAAmB,EACnB,0BAA0B,EAC7B,MAAM,IAAI,CAAC;AACZ,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAK5C,MAAM,WAAW,2CAA4C,SAAQ,0BAA0B;IAC3F,GAAG,EAAE,MAAM,CAAC;CACf;AAED;;;;GAIG;AACH,qBAAa,oCAAoC,CAAC,CAAC,SAAS,EAAE,CAAE,YAAW,mBAAmB,CAAC,CAAC,CAAC;IAC7F,OAAO,CAAC,GAAG,CAAC,CAAS;IACrB,OAAO,CAAC,IAAI,CAAC,CAAS;IACtB,OAAO,CAAC,SAAS,CAAC,CAAO;IACzB,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,gBAAgB,CAAC,CAAS;IAClC,OAAO,CAAC,OAAO,CAAC,CAAsB;IACtC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,MAAM,CAAS;IAChB,SAAS,CAAC,EAAE,yBAAyB,CAAC;gBAE1B,EACf,SAAS,EACT,MAAM,EACN,gBAAgB,EAChB,OAAO,GACV,EAAE;QACC,OAAO,CAAC,EAAE,OAAO,MAAM,CAAC,KAAK,CAAC;QAC9B,SAAS,CAAC,EAAE,yBAAyB,CAAC;QACtC,MAAM,EAAE,YAAY,CAAC;QACrB,gBAAgB,CAAC,EAAE,MAAM,CAAC;KAC7B;IAOD,IAAW,KAAK,IAAI,OAAO,CAE1B;IAEY,OAAO,IAAI,OAAO,CAAC,2CAA2C,CAAC;IAW5E,OAAO,CAAC,KAAK;YAOC,eAAe;IAYhB,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAwC5B,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;IAiC1C,MAAM,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC;CAiBtE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js deleted file mode 100644 index d9d5059..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js +++ /dev/null @@ -1,183 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MSC3886SimpleHttpRendezvousTransport = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _matrixEventsSdk = require("matrix-events-sdk"); -var _logger = require("../../logger"); -var _utils = require("../../utils"); -var _ = require(".."); -var _httpApi = require("../../http-api"); -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const TYPE = new _matrixEventsSdk.UnstableValue("http.v1", "org.matrix.msc3886.http.v1"); -/** - * Implementation of the unstable [MSC3886](https://github.com/matrix-org/matrix-spec-proposals/pull/3886) - * simple HTTP rendezvous protocol. - * Note that this is UNSTABLE and may have breaking changes without notice. - */ -class MSC3886SimpleHttpRendezvousTransport { - constructor({ - onFailure, - client, - fallbackRzServer, - fetchFn - }) { - (0, _defineProperty2.default)(this, "uri", void 0); - (0, _defineProperty2.default)(this, "etag", void 0); - (0, _defineProperty2.default)(this, "expiresAt", void 0); - (0, _defineProperty2.default)(this, "client", void 0); - (0, _defineProperty2.default)(this, "fallbackRzServer", void 0); - (0, _defineProperty2.default)(this, "fetchFn", void 0); - (0, _defineProperty2.default)(this, "cancelled", false); - (0, _defineProperty2.default)(this, "_ready", false); - (0, _defineProperty2.default)(this, "onFailure", void 0); - this.fetchFn = fetchFn; - this.onFailure = onFailure; - this.client = client; - this.fallbackRzServer = fallbackRzServer; - } - get ready() { - return this._ready; - } - async details() { - if (!this.uri) { - throw new Error("Rendezvous not set up"); - } - return { - type: TYPE.name, - uri: this.uri - }; - } - fetch(resource, options) { - if (this.fetchFn) { - return this.fetchFn(resource, options); - } - return global.fetch(resource, options); - } - async getPostEndpoint() { - try { - if (await this.client.doesServerSupportUnstableFeature("org.matrix.msc3886")) { - return `${this.client.baseUrl}${_httpApi.ClientPrefix.Unstable}/org.matrix.msc3886/rendezvous`; - } - } catch (err) { - _logger.logger.warn("Failed to get unstable features", err); - } - return this.fallbackRzServer; - } - async send(data) { - var _this$uri, _res$headers$get; - if (this.cancelled) { - return; - } - const method = this.uri ? "PUT" : "POST"; - const uri = (_this$uri = this.uri) !== null && _this$uri !== void 0 ? _this$uri : await this.getPostEndpoint(); - if (!uri) { - throw new Error("Invalid rendezvous URI"); - } - const headers = { - "content-type": "application/json" - }; - if (this.etag) { - headers["if-match"] = this.etag; - } - const res = await this.fetch(uri, { - method, - headers, - body: JSON.stringify(data) - }); - if (res.status === 404) { - return this.cancel(_.RendezvousFailureReason.Unknown); - } - this.etag = (_res$headers$get = res.headers.get("etag")) !== null && _res$headers$get !== void 0 ? _res$headers$get : undefined; - if (method === "POST") { - var _res$url; - const location = res.headers.get("location"); - if (!location) { - throw new Error("No rendezvous URI given"); - } - const expires = res.headers.get("expires"); - if (expires) { - this.expiresAt = new Date(expires); - } - // we would usually expect the final `url` to be set by a proper fetch implementation. - // however, if a polyfill based on XHR is used it won't be set, we we use existing URI as fallback - const baseUrl = (_res$url = res.url) !== null && _res$url !== void 0 ? _res$url : uri; - // resolve location header which could be relative or absolute - this.uri = new URL(location, `${baseUrl}${baseUrl.endsWith("/") ? "" : "/"}`).href; - this._ready = true; - } - } - async receive() { - if (!this.uri) { - throw new Error("Rendezvous not set up"); - } - // eslint-disable-next-line no-constant-condition - while (true) { - if (this.cancelled) { - return undefined; - } - const headers = {}; - if (this.etag) { - headers["if-none-match"] = this.etag; - } - const poll = await this.fetch(this.uri, { - method: "GET", - headers - }); - if (poll.status === 404) { - this.cancel(_.RendezvousFailureReason.Unknown); - return undefined; - } - - // rely on server expiring the channel rather than checking ourselves - - if (poll.headers.get("content-type") !== "application/json") { - var _poll$headers$get; - this.etag = (_poll$headers$get = poll.headers.get("etag")) !== null && _poll$headers$get !== void 0 ? _poll$headers$get : undefined; - } else if (poll.status === 200) { - var _poll$headers$get2; - this.etag = (_poll$headers$get2 = poll.headers.get("etag")) !== null && _poll$headers$get2 !== void 0 ? _poll$headers$get2 : undefined; - return poll.json(); - } - await (0, _utils.sleep)(1000); - } - } - async cancel(reason) { - var _this$onFailure; - if (reason === _.RendezvousFailureReason.Unknown && this.expiresAt && this.expiresAt.getTime() < Date.now()) { - reason = _.RendezvousFailureReason.Expired; - } - this.cancelled = true; - this._ready = false; - (_this$onFailure = this.onFailure) === null || _this$onFailure === void 0 ? void 0 : _this$onFailure.call(this, reason); - if (this.uri && reason === _.RendezvousFailureReason.UserDeclined) { - try { - await this.fetch(this.uri, { - method: "DELETE" - }); - } catch (e) { - _logger.logger.warn(e); - } - } - } -} -exports.MSC3886SimpleHttpRendezvousTransport = MSC3886SimpleHttpRendezvousTransport; -//# sourceMappingURL=MSC3886SimpleHttpRendezvousTransport.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js.map deleted file mode 100644 index 62bb8ac..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"MSC3886SimpleHttpRendezvousTransport.js","names":["_matrixEventsSdk","require","_logger","_utils","_","_httpApi","TYPE","UnstableValue","MSC3886SimpleHttpRendezvousTransport","constructor","onFailure","client","fallbackRzServer","fetchFn","_defineProperty2","default","ready","_ready","details","uri","Error","type","name","fetch","resource","options","global","getPostEndpoint","doesServerSupportUnstableFeature","baseUrl","ClientPrefix","Unstable","err","logger","warn","send","data","_this$uri","_res$headers$get","cancelled","method","headers","etag","res","body","JSON","stringify","status","cancel","RendezvousFailureReason","Unknown","get","undefined","_res$url","location","expires","expiresAt","Date","url","URL","endsWith","href","receive","poll","_poll$headers$get","_poll$headers$get2","json","sleep","reason","_this$onFailure","getTime","now","Expired","call","UserDeclined","e","exports"],"sources":["../../../src/rendezvous/transports/MSC3886SimpleHttpRendezvousTransport.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { UnstableValue } from \"matrix-events-sdk\";\n\nimport { logger } from \"../../logger\";\nimport { sleep } from \"../../utils\";\nimport {\n RendezvousFailureListener,\n RendezvousFailureReason,\n RendezvousTransport,\n RendezvousTransportDetails,\n} from \"..\";\nimport { MatrixClient } from \"../../matrix\";\nimport { ClientPrefix } from \"../../http-api\";\n\nconst TYPE = new UnstableValue(\"http.v1\", \"org.matrix.msc3886.http.v1\");\n\nexport interface MSC3886SimpleHttpRendezvousTransportDetails extends RendezvousTransportDetails {\n uri: string;\n}\n\n/**\n * Implementation of the unstable [MSC3886](https://github.com/matrix-org/matrix-spec-proposals/pull/3886)\n * simple HTTP rendezvous protocol.\n * Note that this is UNSTABLE and may have breaking changes without notice.\n */\nexport class MSC3886SimpleHttpRendezvousTransport implements RendezvousTransport {\n private uri?: string;\n private etag?: string;\n private expiresAt?: Date;\n private client: MatrixClient;\n private fallbackRzServer?: string;\n private fetchFn?: typeof global.fetch;\n private cancelled = false;\n private _ready = false;\n public onFailure?: RendezvousFailureListener;\n\n public constructor({\n onFailure,\n client,\n fallbackRzServer,\n fetchFn,\n }: {\n fetchFn?: typeof global.fetch;\n onFailure?: RendezvousFailureListener;\n client: MatrixClient;\n fallbackRzServer?: string;\n }) {\n this.fetchFn = fetchFn;\n this.onFailure = onFailure;\n this.client = client;\n this.fallbackRzServer = fallbackRzServer;\n }\n\n public get ready(): boolean {\n return this._ready;\n }\n\n public async details(): Promise {\n if (!this.uri) {\n throw new Error(\"Rendezvous not set up\");\n }\n\n return {\n type: TYPE.name,\n uri: this.uri,\n };\n }\n\n private fetch(resource: URL | string, options?: RequestInit): ReturnType {\n if (this.fetchFn) {\n return this.fetchFn(resource, options);\n }\n return global.fetch(resource, options);\n }\n\n private async getPostEndpoint(): Promise {\n try {\n if (await this.client.doesServerSupportUnstableFeature(\"org.matrix.msc3886\")) {\n return `${this.client.baseUrl}${ClientPrefix.Unstable}/org.matrix.msc3886/rendezvous`;\n }\n } catch (err) {\n logger.warn(\"Failed to get unstable features\", err);\n }\n\n return this.fallbackRzServer;\n }\n\n public async send(data: T): Promise {\n if (this.cancelled) {\n return;\n }\n const method = this.uri ? \"PUT\" : \"POST\";\n const uri = this.uri ?? (await this.getPostEndpoint());\n\n if (!uri) {\n throw new Error(\"Invalid rendezvous URI\");\n }\n\n const headers: Record = { \"content-type\": \"application/json\" };\n if (this.etag) {\n headers[\"if-match\"] = this.etag;\n }\n\n const res = await this.fetch(uri, { method, headers, body: JSON.stringify(data) });\n if (res.status === 404) {\n return this.cancel(RendezvousFailureReason.Unknown);\n }\n this.etag = res.headers.get(\"etag\") ?? undefined;\n\n if (method === \"POST\") {\n const location = res.headers.get(\"location\");\n if (!location) {\n throw new Error(\"No rendezvous URI given\");\n }\n const expires = res.headers.get(\"expires\");\n if (expires) {\n this.expiresAt = new Date(expires);\n }\n // we would usually expect the final `url` to be set by a proper fetch implementation.\n // however, if a polyfill based on XHR is used it won't be set, we we use existing URI as fallback\n const baseUrl = res.url ?? uri;\n // resolve location header which could be relative or absolute\n this.uri = new URL(location, `${baseUrl}${baseUrl.endsWith(\"/\") ? \"\" : \"/\"}`).href;\n this._ready = true;\n }\n }\n\n public async receive(): Promise | undefined> {\n if (!this.uri) {\n throw new Error(\"Rendezvous not set up\");\n }\n // eslint-disable-next-line no-constant-condition\n while (true) {\n if (this.cancelled) {\n return undefined;\n }\n\n const headers: Record = {};\n if (this.etag) {\n headers[\"if-none-match\"] = this.etag;\n }\n const poll = await this.fetch(this.uri, { method: \"GET\", headers });\n\n if (poll.status === 404) {\n this.cancel(RendezvousFailureReason.Unknown);\n return undefined;\n }\n\n // rely on server expiring the channel rather than checking ourselves\n\n if (poll.headers.get(\"content-type\") !== \"application/json\") {\n this.etag = poll.headers.get(\"etag\") ?? undefined;\n } else if (poll.status === 200) {\n this.etag = poll.headers.get(\"etag\") ?? undefined;\n return poll.json();\n }\n await sleep(1000);\n }\n }\n\n public async cancel(reason: RendezvousFailureReason): Promise {\n if (reason === RendezvousFailureReason.Unknown && this.expiresAt && this.expiresAt.getTime() < Date.now()) {\n reason = RendezvousFailureReason.Expired;\n }\n\n this.cancelled = true;\n this._ready = false;\n this.onFailure?.(reason);\n\n if (this.uri && reason === RendezvousFailureReason.UserDeclined) {\n try {\n await this.fetch(this.uri, { method: \"DELETE\" });\n } catch (e) {\n logger.warn(e);\n }\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts deleted file mode 100644 index 45d4836..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -export * from "./MSC3886SimpleHttpRendezvousTransport"; -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts.map deleted file mode 100644 index 98e0fb5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/rendezvous/transports/index.ts"],"names":[],"mappings":"AAgBA,cAAc,wCAAwC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js deleted file mode 100644 index ab887ba..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js +++ /dev/null @@ -1,17 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -var _MSC3886SimpleHttpRendezvousTransport = require("./MSC3886SimpleHttpRendezvousTransport"); -Object.keys(_MSC3886SimpleHttpRendezvousTransport).forEach(function (key) { - if (key === "default" || key === "__esModule") return; - if (key in exports && exports[key] === _MSC3886SimpleHttpRendezvousTransport[key]) return; - Object.defineProperty(exports, key, { - enumerable: true, - get: function () { - return _MSC3886SimpleHttpRendezvousTransport[key]; - } - }); -}); -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js.map deleted file mode 100644 index fd93d4a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rendezvous/transports/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["_MSC3886SimpleHttpRendezvousTransport","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["../../../src/rendezvous/transports/index.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport * from \"./MSC3886SimpleHttpRendezvousTransport\";\n"],"mappings":";;;;;AAgBA,IAAAA,qCAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,qCAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,qCAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,qCAAA,CAAAK,GAAA;IAAA;EAAA;AAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts deleted file mode 100644 index 7e9d07d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts +++ /dev/null @@ -1,35 +0,0 @@ -import { Room } from "./models/room"; -import { IHierarchyRoom, IHierarchyRelation } from "./@types/spaces"; -export declare class RoomHierarchy { - readonly root: Room; - private readonly pageSize?; - private readonly maxDepth?; - private readonly suggestedOnly; - readonly viaMap: Map>; - readonly backRefs: Map; - readonly roomMap: Map; - private loadRequest?; - private nextBatch?; - private _rooms?; - private serverSupportError?; - /** - * Construct a new RoomHierarchy - * - * A RoomHierarchy instance allows you to easily make use of the /hierarchy API and paginate it. - * - * @param root - the root of this hierarchy - * @param pageSize - the maximum number of rooms to return per page, can be overridden per load request. - * @param maxDepth - the maximum depth to traverse the hierarchy to - * @param suggestedOnly - whether to only return rooms with suggested=true. - */ - constructor(root: Room, pageSize?: number | undefined, maxDepth?: number | undefined, suggestedOnly?: boolean); - get noSupport(): boolean; - get canLoadMore(): boolean; - get loading(): boolean; - get rooms(): IHierarchyRoom[] | undefined; - load(pageSize?: number | undefined): Promise; - getRelation(parentId: string, childId: string): IHierarchyRelation | undefined; - isSuggested(parentId: string, childId: string): boolean | undefined; - removeRelation(parentId: string, childId: string): void; -} -//# sourceMappingURL=room-hierarchy.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts.map deleted file mode 100644 index 0fbe1ec..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-hierarchy.d.ts","sourceRoot":"","sources":["../src/room-hierarchy.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAKrE,qBAAa,aAAa;aAuBF,IAAI,EAAE,IAAI;IAC1B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAC1B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAC1B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAxBlC,SAAgB,MAAM,2BAAkC;IAExD,SAAgB,QAAQ,wBAA+B;IAEvD,SAAgB,OAAO,8BAAqC;IAC5D,OAAO,CAAC,WAAW,CAAC,CAA+C;IACnE,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,MAAM,CAAC,CAAmB;IAClC,OAAO,CAAC,kBAAkB,CAAC,CAAQ;IAEnC;;;;;;;;;OASG;gBAEiB,IAAI,EAAE,IAAI,EACT,QAAQ,CAAC,oBAAQ,EACjB,QAAQ,CAAC,oBAAQ,EACjB,aAAa,UAAQ;IAG1C,IAAW,SAAS,IAAI,OAAO,CAE9B;IAED,IAAW,WAAW,IAAI,OAAO,CAEhC;IAED,IAAW,OAAO,IAAI,OAAO,CAE5B;IAED,IAAW,KAAK,IAAI,cAAc,EAAE,GAAG,SAAS,CAE/C;IAEY,IAAI,CAAC,QAAQ,qBAAgB,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;IA2D/D,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,kBAAkB,GAAG,SAAS;IAI9E,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;IAKnE,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;CAgBjE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js deleted file mode 100644 index dae7d4c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js +++ /dev/null @@ -1,140 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomHierarchy = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _event = require("./@types/event"); -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class RoomHierarchy { - // Map from room id to list of servers which are listed as a via somewhere in the loaded hierarchy - - // Map from room id to list of rooms which claim this room as their child - - // Map from room id to object - - /** - * Construct a new RoomHierarchy - * - * A RoomHierarchy instance allows you to easily make use of the /hierarchy API and paginate it. - * - * @param root - the root of this hierarchy - * @param pageSize - the maximum number of rooms to return per page, can be overridden per load request. - * @param maxDepth - the maximum depth to traverse the hierarchy to - * @param suggestedOnly - whether to only return rooms with suggested=true. - */ - constructor(root, pageSize, maxDepth, suggestedOnly = false) { - this.root = root; - this.pageSize = pageSize; - this.maxDepth = maxDepth; - this.suggestedOnly = suggestedOnly; - (0, _defineProperty2.default)(this, "viaMap", new Map()); - (0, _defineProperty2.default)(this, "backRefs", new Map()); - (0, _defineProperty2.default)(this, "roomMap", new Map()); - (0, _defineProperty2.default)(this, "loadRequest", void 0); - (0, _defineProperty2.default)(this, "nextBatch", void 0); - (0, _defineProperty2.default)(this, "_rooms", void 0); - (0, _defineProperty2.default)(this, "serverSupportError", void 0); - } - get noSupport() { - return !!this.serverSupportError; - } - get canLoadMore() { - return !!this.serverSupportError || !!this.nextBatch || !this._rooms; - } - get loading() { - return !!this.loadRequest; - } - get rooms() { - return this._rooms; - } - async load(pageSize = this.pageSize) { - if (this.loadRequest) return this.loadRequest.then(r => r.rooms); - this.loadRequest = this.root.client.getRoomHierarchy(this.root.roomId, pageSize, this.maxDepth, this.suggestedOnly, this.nextBatch); - let rooms; - try { - ({ - rooms, - next_batch: this.nextBatch - } = await this.loadRequest); - } catch (e) { - if (e.errcode === "M_UNRECOGNIZED") { - this.serverSupportError = e; - } else { - throw e; - } - return []; - } finally { - this.loadRequest = undefined; - } - if (this._rooms) { - this._rooms = this._rooms.concat(rooms); - } else { - this._rooms = rooms; - } - rooms.forEach(room => { - this.roomMap.set(room.room_id, room); - room.children_state.forEach(ev => { - if (ev.type !== _event.EventType.SpaceChild) return; - const childRoomId = ev.state_key; - - // track backrefs for quicker hierarchy navigation - if (!this.backRefs.has(childRoomId)) { - this.backRefs.set(childRoomId, []); - } - this.backRefs.get(childRoomId).push(room.room_id); - - // fill viaMap - if (Array.isArray(ev.content.via)) { - if (!this.viaMap.has(childRoomId)) { - this.viaMap.set(childRoomId, new Set()); - } - const vias = this.viaMap.get(childRoomId); - ev.content.via.forEach(via => vias.add(via)); - } - }); - }); - return rooms; - } - getRelation(parentId, childId) { - var _this$roomMap$get; - return (_this$roomMap$get = this.roomMap.get(parentId)) === null || _this$roomMap$get === void 0 ? void 0 : _this$roomMap$get.children_state.find(e => e.state_key === childId); - } - isSuggested(parentId, childId) { - var _this$getRelation; - return (_this$getRelation = this.getRelation(parentId, childId)) === null || _this$getRelation === void 0 ? void 0 : _this$getRelation.content.suggested; - } - - // locally remove a relation as a form of local echo - removeRelation(parentId, childId) { - const backRefs = this.backRefs.get(childId); - if ((backRefs === null || backRefs === void 0 ? void 0 : backRefs.length) === 1) { - this.backRefs.delete(childId); - } else if (backRefs !== null && backRefs !== void 0 && backRefs.length) { - this.backRefs.set(childId, backRefs.filter(ref => ref !== parentId)); - } - const room = this.roomMap.get(parentId); - if (room) { - room.children_state = room.children_state.filter(ev => ev.state_key !== childId); - } - } -} -exports.RoomHierarchy = RoomHierarchy; -//# sourceMappingURL=room-hierarchy.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js.map deleted file mode 100644 index 08e4a9c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/room-hierarchy.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"room-hierarchy.js","names":["_event","require","RoomHierarchy","constructor","root","pageSize","maxDepth","suggestedOnly","_defineProperty2","default","Map","noSupport","serverSupportError","canLoadMore","nextBatch","_rooms","loading","loadRequest","rooms","load","then","r","client","getRoomHierarchy","roomId","next_batch","e","errcode","undefined","concat","forEach","room","roomMap","set","room_id","children_state","ev","type","EventType","SpaceChild","childRoomId","state_key","backRefs","has","get","push","Array","isArray","content","via","viaMap","Set","vias","add","getRelation","parentId","childId","_this$roomMap$get","find","isSuggested","_this$getRelation","suggested","removeRelation","length","delete","filter","ref","exports"],"sources":["../src/room-hierarchy.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Room } from \"./models/room\";\nimport { IHierarchyRoom, IHierarchyRelation } from \"./@types/spaces\";\nimport { MatrixClient } from \"./client\";\nimport { EventType } from \"./@types/event\";\nimport { MatrixError } from \"./http-api\";\n\nexport class RoomHierarchy {\n // Map from room id to list of servers which are listed as a via somewhere in the loaded hierarchy\n public readonly viaMap = new Map>();\n // Map from room id to list of rooms which claim this room as their child\n public readonly backRefs = new Map();\n // Map from room id to object\n public readonly roomMap = new Map();\n private loadRequest?: ReturnType;\n private nextBatch?: string;\n private _rooms?: IHierarchyRoom[];\n private serverSupportError?: Error;\n\n /**\n * Construct a new RoomHierarchy\n *\n * A RoomHierarchy instance allows you to easily make use of the /hierarchy API and paginate it.\n *\n * @param root - the root of this hierarchy\n * @param pageSize - the maximum number of rooms to return per page, can be overridden per load request.\n * @param maxDepth - the maximum depth to traverse the hierarchy to\n * @param suggestedOnly - whether to only return rooms with suggested=true.\n */\n public constructor(\n public readonly root: Room,\n private readonly pageSize?: number,\n private readonly maxDepth?: number,\n private readonly suggestedOnly = false,\n ) {}\n\n public get noSupport(): boolean {\n return !!this.serverSupportError;\n }\n\n public get canLoadMore(): boolean {\n return !!this.serverSupportError || !!this.nextBatch || !this._rooms;\n }\n\n public get loading(): boolean {\n return !!this.loadRequest;\n }\n\n public get rooms(): IHierarchyRoom[] | undefined {\n return this._rooms;\n }\n\n public async load(pageSize = this.pageSize): Promise {\n if (this.loadRequest) return this.loadRequest.then((r) => r.rooms);\n\n this.loadRequest = this.root.client.getRoomHierarchy(\n this.root.roomId,\n pageSize,\n this.maxDepth,\n this.suggestedOnly,\n this.nextBatch,\n );\n\n let rooms: IHierarchyRoom[];\n try {\n ({ rooms, next_batch: this.nextBatch } = await this.loadRequest);\n } catch (e) {\n if ((e).errcode === \"M_UNRECOGNIZED\") {\n this.serverSupportError = e;\n } else {\n throw e;\n }\n\n return [];\n } finally {\n this.loadRequest = undefined;\n }\n\n if (this._rooms) {\n this._rooms = this._rooms.concat(rooms);\n } else {\n this._rooms = rooms;\n }\n\n rooms.forEach((room) => {\n this.roomMap.set(room.room_id, room);\n\n room.children_state.forEach((ev) => {\n if (ev.type !== EventType.SpaceChild) return;\n const childRoomId = ev.state_key;\n\n // track backrefs for quicker hierarchy navigation\n if (!this.backRefs.has(childRoomId)) {\n this.backRefs.set(childRoomId, []);\n }\n this.backRefs.get(childRoomId)!.push(room.room_id);\n\n // fill viaMap\n if (Array.isArray(ev.content.via)) {\n if (!this.viaMap.has(childRoomId)) {\n this.viaMap.set(childRoomId, new Set());\n }\n const vias = this.viaMap.get(childRoomId)!;\n ev.content.via.forEach((via) => vias.add(via));\n }\n });\n });\n\n return rooms;\n }\n\n public getRelation(parentId: string, childId: string): IHierarchyRelation | undefined {\n return this.roomMap.get(parentId)?.children_state.find((e) => e.state_key === childId);\n }\n\n public isSuggested(parentId: string, childId: string): boolean | undefined {\n return this.getRelation(parentId, childId)?.content.suggested;\n }\n\n // locally remove a relation as a form of local echo\n public removeRelation(parentId: string, childId: string): void {\n const backRefs = this.backRefs.get(childId);\n if (backRefs?.length === 1) {\n this.backRefs.delete(childId);\n } else if (backRefs?.length) {\n this.backRefs.set(\n childId,\n backRefs.filter((ref) => ref !== parentId),\n );\n }\n\n const room = this.roomMap.get(parentId);\n if (room) {\n room.children_state = room.children_state.filter((ev) => ev.state_key !== childId);\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts deleted file mode 100644 index 023b36b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts +++ /dev/null @@ -1,30 +0,0 @@ -import { OlmMachine, UserId } from "@matrix-org/matrix-sdk-crypto-js"; -import { OutgoingRequestProcessor } from "./OutgoingRequestProcessor"; -/** - * KeyClaimManager: linearises calls to OlmMachine.getMissingSessions to avoid races - * - * We have one of these per `RustCrypto` (and hence per `MatrixClient`). - */ -export declare class KeyClaimManager { - private readonly olmMachine; - private readonly outgoingRequestProcessor; - private currentClaimPromise; - private stopped; - constructor(olmMachine: OlmMachine, outgoingRequestProcessor: OutgoingRequestProcessor); - /** - * Tell the KeyClaimManager to immediately stop processing requests. - * - * Any further calls, and any still in the queue, will fail with an error. - */ - stop(): void; - /** - * Given a list of users, attempt to ensure that we have Olm Sessions active with each of their devices - * - * If we don't have an active olm session, we will claim a one-time key and start one. - * - * @param userList - list of userIDs to claim - */ - ensureSessionsForUsers(userList: Array): Promise; - private ensureSessionsForUsersInner; -} -//# sourceMappingURL=KeyClaimManager.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts.map deleted file mode 100644 index 6bca2ce..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"KeyClaimManager.d.ts","sourceRoot":"","sources":["../../src/rust-crypto/KeyClaimManager.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,kCAAkC,CAAC;AAEtE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAEtE;;;;GAIG;AACH,qBAAa,eAAe;IAKpB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,wBAAwB;IAL7C,OAAO,CAAC,mBAAmB,CAAgB;IAC3C,OAAO,CAAC,OAAO,CAAS;gBAGH,UAAU,EAAE,UAAU,EACtB,wBAAwB,EAAE,wBAAwB;IAKvE;;;;OAIG;IACI,IAAI,IAAI,IAAI;IAInB;;;;;;OAMG;IACI,sBAAsB,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;YAcvD,2BAA2B;CAU5C"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js deleted file mode 100644 index 6565745..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js +++ /dev/null @@ -1,78 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.KeyClaimManager = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * KeyClaimManager: linearises calls to OlmMachine.getMissingSessions to avoid races - * - * We have one of these per `RustCrypto` (and hence per `MatrixClient`). - */ -class KeyClaimManager { - constructor(olmMachine, outgoingRequestProcessor) { - this.olmMachine = olmMachine; - this.outgoingRequestProcessor = outgoingRequestProcessor; - (0, _defineProperty2.default)(this, "currentClaimPromise", void 0); - (0, _defineProperty2.default)(this, "stopped", false); - this.currentClaimPromise = Promise.resolve(); - } - - /** - * Tell the KeyClaimManager to immediately stop processing requests. - * - * Any further calls, and any still in the queue, will fail with an error. - */ - stop() { - this.stopped = true; - } - - /** - * Given a list of users, attempt to ensure that we have Olm Sessions active with each of their devices - * - * If we don't have an active olm session, we will claim a one-time key and start one. - * - * @param userList - list of userIDs to claim - */ - ensureSessionsForUsers(userList) { - // The Rust-SDK requires that we only have one getMissingSessions process in flight at once. This little dance - // ensures that, by only having one call to ensureSessionsForUsersInner active at once (and making them - // queue up in order). - const prom = this.currentClaimPromise.catch(() => { - // any errors in the previous claim will have been reported already, so there is nothing to do here. - // we just throw away the error and start anew. - }).then(() => this.ensureSessionsForUsersInner(userList)); - this.currentClaimPromise = prom; - return prom; - } - async ensureSessionsForUsersInner(userList) { - // bail out quickly if we've been stopped. - if (this.stopped) { - throw new Error(`Cannot ensure Olm sessions: shutting down`); - } - const claimRequest = await this.olmMachine.getMissingSessions(userList); - if (claimRequest) { - await this.outgoingRequestProcessor.makeOutgoingRequest(claimRequest); - } - } -} -exports.KeyClaimManager = KeyClaimManager; -//# sourceMappingURL=KeyClaimManager.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js.map deleted file mode 100644 index d3d4786..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/KeyClaimManager.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"KeyClaimManager.js","names":["KeyClaimManager","constructor","olmMachine","outgoingRequestProcessor","_defineProperty2","default","currentClaimPromise","Promise","resolve","stop","stopped","ensureSessionsForUsers","userList","prom","catch","then","ensureSessionsForUsersInner","Error","claimRequest","getMissingSessions","makeOutgoingRequest","exports"],"sources":["../../src/rust-crypto/KeyClaimManager.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { OlmMachine, UserId } from \"@matrix-org/matrix-sdk-crypto-js\";\n\nimport { OutgoingRequestProcessor } from \"./OutgoingRequestProcessor\";\n\n/**\n * KeyClaimManager: linearises calls to OlmMachine.getMissingSessions to avoid races\n *\n * We have one of these per `RustCrypto` (and hence per `MatrixClient`).\n */\nexport class KeyClaimManager {\n private currentClaimPromise: Promise;\n private stopped = false;\n\n public constructor(\n private readonly olmMachine: OlmMachine,\n private readonly outgoingRequestProcessor: OutgoingRequestProcessor,\n ) {\n this.currentClaimPromise = Promise.resolve();\n }\n\n /**\n * Tell the KeyClaimManager to immediately stop processing requests.\n *\n * Any further calls, and any still in the queue, will fail with an error.\n */\n public stop(): void {\n this.stopped = true;\n }\n\n /**\n * Given a list of users, attempt to ensure that we have Olm Sessions active with each of their devices\n *\n * If we don't have an active olm session, we will claim a one-time key and start one.\n *\n * @param userList - list of userIDs to claim\n */\n public ensureSessionsForUsers(userList: Array): Promise {\n // The Rust-SDK requires that we only have one getMissingSessions process in flight at once. This little dance\n // ensures that, by only having one call to ensureSessionsForUsersInner active at once (and making them\n // queue up in order).\n const prom = this.currentClaimPromise\n .catch(() => {\n // any errors in the previous claim will have been reported already, so there is nothing to do here.\n // we just throw away the error and start anew.\n })\n .then(() => this.ensureSessionsForUsersInner(userList));\n this.currentClaimPromise = prom;\n return prom;\n }\n\n private async ensureSessionsForUsersInner(userList: Array): Promise {\n // bail out quickly if we've been stopped.\n if (this.stopped) {\n throw new Error(`Cannot ensure Olm sessions: shutting down`);\n }\n const claimRequest = await this.olmMachine.getMissingSessions(userList);\n if (claimRequest) {\n await this.outgoingRequestProcessor.makeOutgoingRequest(claimRequest);\n }\n }\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAMA;AACA;AACA;AACA;AACA;AACO,MAAMA,eAAe,CAAC;EAIlBC,WAAWA,CACGC,UAAsB,EACtBC,wBAAkD,EACrE;IAAA,KAFmBD,UAAsB,GAAtBA,UAAsB;IAAA,KACtBC,wBAAkD,GAAlDA,wBAAkD;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,mBAJrD,KAAK;IAMnB,IAAI,CAACC,mBAAmB,GAAGC,OAAO,CAACC,OAAO,EAAE;EAChD;;EAEA;AACJ;AACA;AACA;AACA;EACWC,IAAIA,CAAA,EAAS;IAChB,IAAI,CAACC,OAAO,GAAG,IAAI;EACvB;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;EACWC,sBAAsBA,CAACC,QAAuB,EAAiB;IAClE;IACA;IACA;IACA,MAAMC,IAAI,GAAG,IAAI,CAACP,mBAAmB,CAChCQ,KAAK,CAAC,MAAM;MACT;MACA;IAAA,CACH,CAAC,CACDC,IAAI,CAAC,MAAM,IAAI,CAACC,2BAA2B,CAACJ,QAAQ,CAAC,CAAC;IAC3D,IAAI,CAACN,mBAAmB,GAAGO,IAAI;IAC/B,OAAOA,IAAI;EACf;EAEA,MAAcG,2BAA2BA,CAACJ,QAAuB,EAAiB;IAC9E;IACA,IAAI,IAAI,CAACF,OAAO,EAAE;MACd,MAAM,IAAIO,KAAK,CAAE,2CAA0C,CAAC;IAChE;IACA,MAAMC,YAAY,GAAG,MAAM,IAAI,CAAChB,UAAU,CAACiB,kBAAkB,CAACP,QAAQ,CAAC;IACvE,IAAIM,YAAY,EAAE;MACd,MAAM,IAAI,CAACf,wBAAwB,CAACiB,mBAAmB,CAACF,YAAY,CAAC;IACzE;EACJ;AACJ;AAACG,OAAA,CAAArB,eAAA,GAAAA,eAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts deleted file mode 100644 index d588f1b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts +++ /dev/null @@ -1,29 +0,0 @@ -import { OlmMachine } from "@matrix-org/matrix-sdk-crypto-js"; -import { IHttpOpts, MatrixHttpApi } from "../http-api"; -/** - * Common interface for all the request types returned by `OlmMachine.outgoingRequests`. - */ -export interface OutgoingRequest { - readonly id: string | undefined; - readonly type: number; -} -/** - * OutgoingRequestManager: turns `OutgoingRequest`s from the rust sdk into HTTP requests - * - * We have one of these per `RustCrypto` (and hence per `MatrixClient`), not that it does anything terribly complicated. - * It's responsible for: - * - * * holding the reference to the `MatrixHttpApi` - * * turning `OutgoingRequest`s from the rust backend into HTTP requests, and sending them - * * sending the results of such requests back to the rust backend. - */ -export declare class OutgoingRequestProcessor { - private readonly olmMachine; - private readonly http; - constructor(olmMachine: OlmMachine, http: MatrixHttpApi); - makeOutgoingRequest(msg: OutgoingRequest): Promise; - private rawJsonRequest; -} -//# sourceMappingURL=OutgoingRequestProcessor.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts.map deleted file mode 100644 index cdbc218..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"OutgoingRequestProcessor.d.ts","sourceRoot":"","sources":["../../src/rust-crypto/OutgoingRequestProcessor.ts"],"names":[],"mappings":"AAgBA,OAAO,EACH,UAAU,EAQb,MAAM,kCAAkC,CAAC;AAG1C,OAAO,EAAE,SAAS,EAAE,aAAa,EAAU,MAAM,aAAa,CAAC;AAG/D;;GAEG;AACH,MAAM,WAAW,eAAe;IAC5B,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,CAAC;IAChC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;CACzB;AAED;;;;;;;;;GASG;AACH,qBAAa,wBAAwB;IAE7B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,IAAI;gBADJ,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,aAAa,CAAC,SAAS,GAAG;QAAE,QAAQ,EAAE,IAAI,CAAA;KAAE,CAAC;IAG3D,mBAAmB,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;YAoCvD,cAAc;CAwB/B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js deleted file mode 100644 index b8d1387..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js +++ /dev/null @@ -1,94 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.OutgoingRequestProcessor = void 0; -var _matrixSdkCryptoJs = require("@matrix-org/matrix-sdk-crypto-js"); -var _logger = require("../logger"); -var _httpApi = require("../http-api"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * OutgoingRequestManager: turns `OutgoingRequest`s from the rust sdk into HTTP requests - * - * We have one of these per `RustCrypto` (and hence per `MatrixClient`), not that it does anything terribly complicated. - * It's responsible for: - * - * * holding the reference to the `MatrixHttpApi` - * * turning `OutgoingRequest`s from the rust backend into HTTP requests, and sending them - * * sending the results of such requests back to the rust backend. - */ -class OutgoingRequestProcessor { - constructor(olmMachine, http) { - this.olmMachine = olmMachine; - this.http = http; - } - async makeOutgoingRequest(msg) { - let resp; - - /* refer https://docs.rs/matrix-sdk-crypto/0.6.0/matrix_sdk_crypto/requests/enum.OutgoingRequests.html - * for the complete list of request types - */ - if (msg instanceof _matrixSdkCryptoJs.KeysUploadRequest) { - resp = await this.rawJsonRequest(_httpApi.Method.Post, "/_matrix/client/v3/keys/upload", {}, msg.body); - } else if (msg instanceof _matrixSdkCryptoJs.KeysQueryRequest) { - resp = await this.rawJsonRequest(_httpApi.Method.Post, "/_matrix/client/v3/keys/query", {}, msg.body); - } else if (msg instanceof _matrixSdkCryptoJs.KeysClaimRequest) { - resp = await this.rawJsonRequest(_httpApi.Method.Post, "/_matrix/client/v3/keys/claim", {}, msg.body); - } else if (msg instanceof _matrixSdkCryptoJs.SignatureUploadRequest) { - resp = await this.rawJsonRequest(_httpApi.Method.Post, "/_matrix/client/v3/keys/signatures/upload", {}, msg.body); - } else if (msg instanceof _matrixSdkCryptoJs.KeysBackupRequest) { - resp = await this.rawJsonRequest(_httpApi.Method.Put, "/_matrix/client/v3/room_keys/keys", {}, msg.body); - } else if (msg instanceof _matrixSdkCryptoJs.ToDeviceRequest) { - const path = `/_matrix/client/v3/sendToDevice/${encodeURIComponent(msg.event_type)}/` + encodeURIComponent(msg.txn_id); - resp = await this.rawJsonRequest(_httpApi.Method.Put, path, {}, msg.body); - } else if (msg instanceof _matrixSdkCryptoJs.RoomMessageRequest) { - const path = `/_matrix/client/v3/room/${encodeURIComponent(msg.room_id)}/send/` + `${encodeURIComponent(msg.event_type)}/${encodeURIComponent(msg.txn_id)}`; - resp = await this.rawJsonRequest(_httpApi.Method.Put, path, {}, msg.body); - } else { - _logger.logger.warn("Unsupported outgoing message", Object.getPrototypeOf(msg)); - resp = ""; - } - if (msg.id) { - await this.olmMachine.markRequestAsSent(msg.id, msg.type, resp); - } - } - async rawJsonRequest(method, path, queryParams, body) { - const opts = { - // inhibit the JSON stringification and parsing within HttpApi. - json: false, - // nevertheless, we are sending, and accept, JSON. - headers: { - "Content-Type": "application/json", - "Accept": "application/json" - }, - // we use the full prefix - prefix: "" - }; - try { - const response = await this.http.authedRequest(method, path, queryParams, body, opts); - _logger.logger.info(`rust-crypto: successfully made HTTP request: ${method} ${path}`); - return response; - } catch (e) { - _logger.logger.warn(`rust-crypto: error making HTTP request: ${method} ${path}: ${e}`); - throw e; - } - } -} -exports.OutgoingRequestProcessor = OutgoingRequestProcessor; -//# sourceMappingURL=OutgoingRequestProcessor.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js.map deleted file mode 100644 index 16beb60..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/OutgoingRequestProcessor.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"OutgoingRequestProcessor.js","names":["_matrixSdkCryptoJs","require","_logger","_httpApi","OutgoingRequestProcessor","constructor","olmMachine","http","makeOutgoingRequest","msg","resp","KeysUploadRequest","rawJsonRequest","Method","Post","body","KeysQueryRequest","KeysClaimRequest","SignatureUploadRequest","KeysBackupRequest","Put","ToDeviceRequest","path","encodeURIComponent","event_type","txn_id","RoomMessageRequest","room_id","logger","warn","Object","getPrototypeOf","id","markRequestAsSent","type","method","queryParams","opts","json","headers","prefix","response","authedRequest","info","e","exports"],"sources":["../../src/rust-crypto/OutgoingRequestProcessor.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport {\n OlmMachine,\n KeysBackupRequest,\n KeysClaimRequest,\n KeysQueryRequest,\n KeysUploadRequest,\n RoomMessageRequest,\n SignatureUploadRequest,\n ToDeviceRequest,\n} from \"@matrix-org/matrix-sdk-crypto-js\";\n\nimport { logger } from \"../logger\";\nimport { IHttpOpts, MatrixHttpApi, Method } from \"../http-api\";\nimport { QueryDict } from \"../utils\";\n\n/**\n * Common interface for all the request types returned by `OlmMachine.outgoingRequests`.\n */\nexport interface OutgoingRequest {\n readonly id: string | undefined;\n readonly type: number;\n}\n\n/**\n * OutgoingRequestManager: turns `OutgoingRequest`s from the rust sdk into HTTP requests\n *\n * We have one of these per `RustCrypto` (and hence per `MatrixClient`), not that it does anything terribly complicated.\n * It's responsible for:\n *\n * * holding the reference to the `MatrixHttpApi`\n * * turning `OutgoingRequest`s from the rust backend into HTTP requests, and sending them\n * * sending the results of such requests back to the rust backend.\n */\nexport class OutgoingRequestProcessor {\n public constructor(\n private readonly olmMachine: OlmMachine,\n private readonly http: MatrixHttpApi,\n ) {}\n\n public async makeOutgoingRequest(msg: OutgoingRequest): Promise {\n let resp: string;\n\n /* refer https://docs.rs/matrix-sdk-crypto/0.6.0/matrix_sdk_crypto/requests/enum.OutgoingRequests.html\n * for the complete list of request types\n */\n if (msg instanceof KeysUploadRequest) {\n resp = await this.rawJsonRequest(Method.Post, \"/_matrix/client/v3/keys/upload\", {}, msg.body);\n } else if (msg instanceof KeysQueryRequest) {\n resp = await this.rawJsonRequest(Method.Post, \"/_matrix/client/v3/keys/query\", {}, msg.body);\n } else if (msg instanceof KeysClaimRequest) {\n resp = await this.rawJsonRequest(Method.Post, \"/_matrix/client/v3/keys/claim\", {}, msg.body);\n } else if (msg instanceof SignatureUploadRequest) {\n resp = await this.rawJsonRequest(Method.Post, \"/_matrix/client/v3/keys/signatures/upload\", {}, msg.body);\n } else if (msg instanceof KeysBackupRequest) {\n resp = await this.rawJsonRequest(Method.Put, \"/_matrix/client/v3/room_keys/keys\", {}, msg.body);\n } else if (msg instanceof ToDeviceRequest) {\n const path =\n `/_matrix/client/v3/sendToDevice/${encodeURIComponent(msg.event_type)}/` +\n encodeURIComponent(msg.txn_id);\n resp = await this.rawJsonRequest(Method.Put, path, {}, msg.body);\n } else if (msg instanceof RoomMessageRequest) {\n const path =\n `/_matrix/client/v3/room/${encodeURIComponent(msg.room_id)}/send/` +\n `${encodeURIComponent(msg.event_type)}/${encodeURIComponent(msg.txn_id)}`;\n resp = await this.rawJsonRequest(Method.Put, path, {}, msg.body);\n } else {\n logger.warn(\"Unsupported outgoing message\", Object.getPrototypeOf(msg));\n resp = \"\";\n }\n\n if (msg.id) {\n await this.olmMachine.markRequestAsSent(msg.id, msg.type, resp);\n }\n }\n\n private async rawJsonRequest(method: Method, path: string, queryParams: QueryDict, body: string): Promise {\n const opts = {\n // inhibit the JSON stringification and parsing within HttpApi.\n json: false,\n\n // nevertheless, we are sending, and accept, JSON.\n headers: {\n \"Content-Type\": \"application/json\",\n \"Accept\": \"application/json\",\n },\n\n // we use the full prefix\n prefix: \"\",\n };\n\n try {\n const response = await this.http.authedRequest(method, path, queryParams, body, opts);\n logger.info(`rust-crypto: successfully made HTTP request: ${method} ${path}`);\n return response;\n } catch (e) {\n logger.warn(`rust-crypto: error making HTTP request: ${method} ${path}: ${e}`);\n throw e;\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts deleted file mode 100644 index f9f68dc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts +++ /dev/null @@ -1,57 +0,0 @@ -import { OlmMachine } from "@matrix-org/matrix-sdk-crypto-js"; -import { IContent, MatrixEvent } from "../models/event"; -import { Room } from "../models/room"; -import { KeyClaimManager } from "./KeyClaimManager"; -import { RoomMember } from "../models/room-member"; -import { OutgoingRequestProcessor } from "./OutgoingRequestProcessor"; -/** - * RoomEncryptor: responsible for encrypting messages to a given room - */ -export declare class RoomEncryptor { - private readonly olmMachine; - private readonly keyClaimManager; - private readonly outgoingRequestProcessor; - private readonly room; - private encryptionSettings; - private readonly prefixedLogger; - /** - * @param olmMachine - The rust-sdk's OlmMachine - * @param keyClaimManager - Our KeyClaimManager, which manages the queue of one-time-key claim requests - * @param room - The room we want to encrypt for - * @param encryptionSettings - body of the m.room.encryption event currently in force in this room - */ - constructor(olmMachine: OlmMachine, keyClaimManager: KeyClaimManager, outgoingRequestProcessor: OutgoingRequestProcessor, room: Room, encryptionSettings: IContent); - /** - * Handle a new `m.room.encryption` event in this room - * - * @param config - The content of the encryption event - */ - onCryptoEvent(config: IContent): void; - /** - * Handle a new `m.room.member` event in this room - * - * @param member - new membership state - */ - onRoomMembership(member: RoomMember): void; - /** - * Prepare to encrypt events in this room. - * - * This ensures that we have a megolm session ready to use and that we have shared its key with all the devices - * in the room. - */ - ensureEncryptionSession(): Promise; - /** - * Discard any existing group session for this room - */ - forceDiscardSession(): Promise; - /** - * Encrypt an event for this room - * - * This will ensure that we have a megolm session for this room, share it with the devices in the room, and - * then encrypt the event using the session. - * - * @param event - Event to be encrypted. - */ - encryptEvent(event: MatrixEvent): Promise; -} -//# sourceMappingURL=RoomEncryptor.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts.map deleted file mode 100644 index 52b231e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RoomEncryptor.d.ts","sourceRoot":"","sources":["../../src/rust-crypto/RoomEncryptor.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAsB,UAAU,EAAkB,MAAM,kCAAkC,CAAC;AAGlG,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACxD,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAEtC,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAEtE;;GAEG;AACH,qBAAa,aAAa;IAUlB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,wBAAwB;IACzC,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,kBAAkB;IAb9B,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAEhD;;;;;OAKG;gBAEkB,UAAU,EAAE,UAAU,EACtB,eAAe,EAAE,eAAe,EAChC,wBAAwB,EAAE,wBAAwB,EAClD,IAAI,EAAE,IAAI,EACnB,kBAAkB,EAAE,QAAQ;IAKxC;;;;OAIG;IACI,aAAa,CAAC,MAAM,EAAE,QAAQ,GAAG,IAAI;IAM5C;;;;OAIG;IACI,gBAAgB,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IAejD;;;;;OAKG;IACU,uBAAuB,IAAI,OAAO,CAAC,IAAI,CAAC;IAiCrD;;OAEG;IACU,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAOjD;;;;;;;OAOG;IACU,YAAY,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAgB/D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js deleted file mode 100644 index c805fe7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js +++ /dev/null @@ -1,126 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RoomEncryptor = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _matrixSdkCryptoJs = require("@matrix-org/matrix-sdk-crypto-js"); -var _event = require("../@types/event"); -var _logger = require("../logger"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * RoomEncryptor: responsible for encrypting messages to a given room - */ -class RoomEncryptor { - /** - * @param olmMachine - The rust-sdk's OlmMachine - * @param keyClaimManager - Our KeyClaimManager, which manages the queue of one-time-key claim requests - * @param room - The room we want to encrypt for - * @param encryptionSettings - body of the m.room.encryption event currently in force in this room - */ - constructor(olmMachine, keyClaimManager, outgoingRequestProcessor, room, encryptionSettings) { - this.olmMachine = olmMachine; - this.keyClaimManager = keyClaimManager; - this.outgoingRequestProcessor = outgoingRequestProcessor; - this.room = room; - this.encryptionSettings = encryptionSettings; - (0, _defineProperty2.default)(this, "prefixedLogger", void 0); - this.prefixedLogger = _logger.logger.withPrefix(`[${room.roomId} encryption]`); - } - - /** - * Handle a new `m.room.encryption` event in this room - * - * @param config - The content of the encryption event - */ - onCryptoEvent(config) { - if (JSON.stringify(this.encryptionSettings) != JSON.stringify(config)) { - this.prefixedLogger.error(`Ignoring m.room.encryption event which requests a change of config`); - } - } - - /** - * Handle a new `m.room.member` event in this room - * - * @param member - new membership state - */ - onRoomMembership(member) { - this.prefixedLogger.debug(`${member.membership} event for ${member.userId}`); - if (member.membership == "join" || member.membership == "invite" && this.room.shouldEncryptForInvitedMembers()) { - // make sure we are tracking the deviceList for this user - this.prefixedLogger.debug(`starting to track devices for: ${member.userId}`); - this.olmMachine.updateTrackedUsers([new _matrixSdkCryptoJs.UserId(member.userId)]); - } - - // TODO: handle leaves (including our own) - } - - /** - * Prepare to encrypt events in this room. - * - * This ensures that we have a megolm session ready to use and that we have shared its key with all the devices - * in the room. - */ - async ensureEncryptionSession() { - if (this.encryptionSettings.algorithm !== "m.megolm.v1.aes-sha2") { - throw new Error(`Cannot encrypt in ${this.room.roomId} for unsupported algorithm '${this.encryptionSettings.algorithm}'`); - } - const members = await this.room.getEncryptionTargetMembers(); - this.prefixedLogger.debug(`Encrypting for users (shouldEncryptForInvitedMembers: ${this.room.shouldEncryptForInvitedMembers()}):`, members.map(u => `${u.userId} (${u.membership})`)); - const userList = members.map(u => new _matrixSdkCryptoJs.UserId(u.userId)); - await this.keyClaimManager.ensureSessionsForUsers(userList); - this.prefixedLogger.debug("Sessions for users are ready; now sharing room key"); - const rustEncryptionSettings = new _matrixSdkCryptoJs.EncryptionSettings(); - /* FIXME historyVisibility, rotation, etc */ - - const shareMessages = await this.olmMachine.shareRoomKey(new _matrixSdkCryptoJs.RoomId(this.room.roomId), userList, rustEncryptionSettings); - if (shareMessages) { - for (const m of shareMessages) { - await this.outgoingRequestProcessor.makeOutgoingRequest(m); - } - } - } - - /** - * Discard any existing group session for this room - */ - async forceDiscardSession() { - const r = await this.olmMachine.invalidateGroupSession(new _matrixSdkCryptoJs.RoomId(this.room.roomId)); - if (r) { - this.prefixedLogger.info("Discarded existing group session"); - } - } - - /** - * Encrypt an event for this room - * - * This will ensure that we have a megolm session for this room, share it with the devices in the room, and - * then encrypt the event using the session. - * - * @param event - Event to be encrypted. - */ - async encryptEvent(event) { - await this.ensureEncryptionSession(); - const encryptedContent = await this.olmMachine.encryptRoomEvent(new _matrixSdkCryptoJs.RoomId(this.room.roomId), event.getType(), JSON.stringify(event.getContent())); - event.makeEncrypted(_event.EventType.RoomMessageEncrypted, JSON.parse(encryptedContent), this.olmMachine.identityKeys.curve25519.toBase64(), this.olmMachine.identityKeys.ed25519.toBase64()); - } -} -exports.RoomEncryptor = RoomEncryptor; -//# sourceMappingURL=RoomEncryptor.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js.map deleted file mode 100644 index aaa2afc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/RoomEncryptor.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"RoomEncryptor.js","names":["_matrixSdkCryptoJs","require","_event","_logger","RoomEncryptor","constructor","olmMachine","keyClaimManager","outgoingRequestProcessor","room","encryptionSettings","_defineProperty2","default","prefixedLogger","logger","withPrefix","roomId","onCryptoEvent","config","JSON","stringify","error","onRoomMembership","member","debug","membership","userId","shouldEncryptForInvitedMembers","updateTrackedUsers","UserId","ensureEncryptionSession","algorithm","Error","members","getEncryptionTargetMembers","map","u","userList","ensureSessionsForUsers","rustEncryptionSettings","EncryptionSettings","shareMessages","shareRoomKey","RoomId","m","makeOutgoingRequest","forceDiscardSession","r","invalidateGroupSession","info","encryptEvent","event","encryptedContent","encryptRoomEvent","getType","getContent","makeEncrypted","EventType","RoomMessageEncrypted","parse","identityKeys","curve25519","toBase64","ed25519","exports"],"sources":["../../src/rust-crypto/RoomEncryptor.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EncryptionSettings, OlmMachine, RoomId, UserId } from \"@matrix-org/matrix-sdk-crypto-js\";\n\nimport { EventType } from \"../@types/event\";\nimport { IContent, MatrixEvent } from \"../models/event\";\nimport { Room } from \"../models/room\";\nimport { logger, PrefixedLogger } from \"../logger\";\nimport { KeyClaimManager } from \"./KeyClaimManager\";\nimport { RoomMember } from \"../models/room-member\";\nimport { OutgoingRequestProcessor } from \"./OutgoingRequestProcessor\";\n\n/**\n * RoomEncryptor: responsible for encrypting messages to a given room\n */\nexport class RoomEncryptor {\n private readonly prefixedLogger: PrefixedLogger;\n\n /**\n * @param olmMachine - The rust-sdk's OlmMachine\n * @param keyClaimManager - Our KeyClaimManager, which manages the queue of one-time-key claim requests\n * @param room - The room we want to encrypt for\n * @param encryptionSettings - body of the m.room.encryption event currently in force in this room\n */\n public constructor(\n private readonly olmMachine: OlmMachine,\n private readonly keyClaimManager: KeyClaimManager,\n private readonly outgoingRequestProcessor: OutgoingRequestProcessor,\n private readonly room: Room,\n private encryptionSettings: IContent,\n ) {\n this.prefixedLogger = logger.withPrefix(`[${room.roomId} encryption]`);\n }\n\n /**\n * Handle a new `m.room.encryption` event in this room\n *\n * @param config - The content of the encryption event\n */\n public onCryptoEvent(config: IContent): void {\n if (JSON.stringify(this.encryptionSettings) != JSON.stringify(config)) {\n this.prefixedLogger.error(`Ignoring m.room.encryption event which requests a change of config`);\n }\n }\n\n /**\n * Handle a new `m.room.member` event in this room\n *\n * @param member - new membership state\n */\n public onRoomMembership(member: RoomMember): void {\n this.prefixedLogger.debug(`${member.membership} event for ${member.userId}`);\n\n if (\n member.membership == \"join\" ||\n (member.membership == \"invite\" && this.room.shouldEncryptForInvitedMembers())\n ) {\n // make sure we are tracking the deviceList for this user\n this.prefixedLogger.debug(`starting to track devices for: ${member.userId}`);\n this.olmMachine.updateTrackedUsers([new UserId(member.userId)]);\n }\n\n // TODO: handle leaves (including our own)\n }\n\n /**\n * Prepare to encrypt events in this room.\n *\n * This ensures that we have a megolm session ready to use and that we have shared its key with all the devices\n * in the room.\n */\n public async ensureEncryptionSession(): Promise {\n if (this.encryptionSettings.algorithm !== \"m.megolm.v1.aes-sha2\") {\n throw new Error(\n `Cannot encrypt in ${this.room.roomId} for unsupported algorithm '${this.encryptionSettings.algorithm}'`,\n );\n }\n\n const members = await this.room.getEncryptionTargetMembers();\n this.prefixedLogger.debug(\n `Encrypting for users (shouldEncryptForInvitedMembers: ${this.room.shouldEncryptForInvitedMembers()}):`,\n members.map((u) => `${u.userId} (${u.membership})`),\n );\n\n const userList = members.map((u) => new UserId(u.userId));\n await this.keyClaimManager.ensureSessionsForUsers(userList);\n\n this.prefixedLogger.debug(\"Sessions for users are ready; now sharing room key\");\n\n const rustEncryptionSettings = new EncryptionSettings();\n /* FIXME historyVisibility, rotation, etc */\n\n const shareMessages = await this.olmMachine.shareRoomKey(\n new RoomId(this.room.roomId),\n userList,\n rustEncryptionSettings,\n );\n if (shareMessages) {\n for (const m of shareMessages) {\n await this.outgoingRequestProcessor.makeOutgoingRequest(m);\n }\n }\n }\n\n /**\n * Discard any existing group session for this room\n */\n public async forceDiscardSession(): Promise {\n const r = await this.olmMachine.invalidateGroupSession(new RoomId(this.room.roomId));\n if (r) {\n this.prefixedLogger.info(\"Discarded existing group session\");\n }\n }\n\n /**\n * Encrypt an event for this room\n *\n * This will ensure that we have a megolm session for this room, share it with the devices in the room, and\n * then encrypt the event using the session.\n *\n * @param event - Event to be encrypted.\n */\n public async encryptEvent(event: MatrixEvent): Promise {\n await this.ensureEncryptionSession();\n\n const encryptedContent = await this.olmMachine.encryptRoomEvent(\n new RoomId(this.room.roomId),\n event.getType(),\n JSON.stringify(event.getContent()),\n );\n\n event.makeEncrypted(\n EventType.RoomMessageEncrypted,\n JSON.parse(encryptedContent),\n this.olmMachine.identityKeys.curve25519.toBase64(),\n this.olmMachine.identityKeys.ed25519.toBase64(),\n );\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts deleted file mode 100644 index 43de354..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -import { IHttpOpts, MatrixHttpApi } from "../http-api"; -export declare function initRustCrypto(_http: MatrixHttpApi, _userId: string, _deviceId: string): Promise; -//# sourceMappingURL=browserify-index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts.map deleted file mode 100644 index ac98bf2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"browserify-index.d.ts","sourceRoot":"","sources":["../../src/rust-crypto/browserify-index.ts"],"names":[],"mappings":"AAsBA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEvD,wBAAsB,cAAc,CAChC,KAAK,EAAE,aAAa,CAAC,SAAS,GAAG;IAAE,QAAQ,EAAE,IAAI,CAAA;CAAE,CAAC,EACpD,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,GAClB,OAAO,CAAC,MAAM,CAAC,CAEjB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js deleted file mode 100644 index 4608108..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js +++ /dev/null @@ -1,32 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.initRustCrypto = initRustCrypto; -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/* This file replaces rust-crypto/index.ts when the js-sdk is being built for browserify. - * - * It is a stub, so that we do not import the whole of the base64'ed wasm artifact into the browserify bundle. - * It deliberately does nothing except raise an exception. - */ - -async function initRustCrypto(_http, _userId, _deviceId) { - throw new Error("Rust crypto is not supported under browserify."); -} -//# sourceMappingURL=browserify-index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js.map deleted file mode 100644 index 0f2c31c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/browserify-index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"browserify-index.js","names":["initRustCrypto","_http","_userId","_deviceId","Error"],"sources":["../../src/rust-crypto/browserify-index.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/* This file replaces rust-crypto/index.ts when the js-sdk is being built for browserify.\n *\n * It is a stub, so that we do not import the whole of the base64'ed wasm artifact into the browserify bundle.\n * It deliberately does nothing except raise an exception.\n */\n\nimport { IHttpOpts, MatrixHttpApi } from \"../http-api\";\n\nexport async function initRustCrypto(\n _http: MatrixHttpApi,\n _userId: string,\n _deviceId: string,\n): Promise {\n throw new Error(\"Rust crypto is not supported under browserify.\");\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAIO,eAAeA,cAAcA,CAChCC,KAAoD,EACpDC,OAAe,EACfC,SAAiB,EACF;EACf,MAAM,IAAIC,KAAK,CAAC,gDAAgD,CAAC;AACrE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts deleted file mode 100644 index 7f68385..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts +++ /dev/null @@ -1,3 +0,0 @@ -/** The prefix used on indexeddbs created by rust-crypto */ -export declare const RUST_SDK_STORE_PREFIX = "matrix-js-sdk"; -//# sourceMappingURL=constants.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts.map deleted file mode 100644 index 91c78cc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../src/rust-crypto/constants.ts"],"names":[],"mappings":"AAgBA,2DAA2D;AAC3D,eAAO,MAAM,qBAAqB,kBAAkB,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js deleted file mode 100644 index 75bd09e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js +++ /dev/null @@ -1,26 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RUST_SDK_STORE_PREFIX = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** The prefix used on indexeddbs created by rust-crypto */ -const RUST_SDK_STORE_PREFIX = "matrix-js-sdk"; -exports.RUST_SDK_STORE_PREFIX = RUST_SDK_STORE_PREFIX; -//# sourceMappingURL=constants.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js.map deleted file mode 100644 index 0533885..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/constants.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"constants.js","names":["RUST_SDK_STORE_PREFIX","exports"],"sources":["../../src/rust-crypto/constants.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/** The prefix used on indexeddbs created by rust-crypto */\nexport const RUST_SDK_STORE_PREFIX = \"matrix-js-sdk\";\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACO,MAAMA,qBAAqB,GAAG,eAAe;AAACC,OAAA,CAAAD,qBAAA,GAAAA,qBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts deleted file mode 100644 index 64fe34f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts +++ /dev/null @@ -1,6 +0,0 @@ -import { RustCrypto } from "./rust-crypto"; -import { IHttpOpts, MatrixHttpApi } from "../http-api"; -export declare function initRustCrypto(http: MatrixHttpApi, userId: string, deviceId: string): Promise; -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts.map deleted file mode 100644 index c1ff61e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/rust-crypto/index.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAG3C,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEvD,wBAAsB,cAAc,CAChC,IAAI,EAAE,aAAa,CAAC,SAAS,GAAG;IAAE,QAAQ,EAAE,IAAI,CAAA;CAAE,CAAC,EACnD,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,GACjB,OAAO,CAAC,UAAU,CAAC,CAiBrB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js deleted file mode 100644 index b5618fd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js +++ /dev/null @@ -1,45 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.initRustCrypto = initRustCrypto; -var RustSdkCryptoJs = _interopRequireWildcard(require("@matrix-org/matrix-sdk-crypto-js")); -var _rustCrypto = require("./rust-crypto"); -var _logger = require("../logger"); -var _constants = require("./constants"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -async function initRustCrypto(http, userId, deviceId) { - // initialise the rust matrix-sdk-crypto-js, if it hasn't already been done - await RustSdkCryptoJs.initAsync(); - - // enable tracing in the rust-sdk - new RustSdkCryptoJs.Tracing(RustSdkCryptoJs.LoggerLevel.Trace).turnOn(); - const u = new RustSdkCryptoJs.UserId(userId); - const d = new RustSdkCryptoJs.DeviceId(deviceId); - _logger.logger.info("Init OlmMachine"); - - // TODO: use the pickle key for the passphrase - const olmMachine = await RustSdkCryptoJs.OlmMachine.initialize(u, d, _constants.RUST_SDK_STORE_PREFIX, "test pass"); - const rustCrypto = new _rustCrypto.RustCrypto(olmMachine, http, userId, deviceId); - _logger.logger.info("Completed rust crypto-sdk setup"); - return rustCrypto; -} -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js.map deleted file mode 100644 index 22ee888..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":["RustSdkCryptoJs","_interopRequireWildcard","require","_rustCrypto","_logger","_constants","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","initRustCrypto","http","userId","deviceId","initAsync","Tracing","LoggerLevel","Trace","turnOn","u","UserId","d","DeviceId","logger","info","olmMachine","OlmMachine","initialize","RUST_SDK_STORE_PREFIX","rustCrypto","RustCrypto"],"sources":["../../src/rust-crypto/index.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as RustSdkCryptoJs from \"@matrix-org/matrix-sdk-crypto-js\";\n\nimport { RustCrypto } from \"./rust-crypto\";\nimport { logger } from \"../logger\";\nimport { RUST_SDK_STORE_PREFIX } from \"./constants\";\nimport { IHttpOpts, MatrixHttpApi } from \"../http-api\";\n\nexport async function initRustCrypto(\n http: MatrixHttpApi,\n userId: string,\n deviceId: string,\n): Promise {\n // initialise the rust matrix-sdk-crypto-js, if it hasn't already been done\n await RustSdkCryptoJs.initAsync();\n\n // enable tracing in the rust-sdk\n new RustSdkCryptoJs.Tracing(RustSdkCryptoJs.LoggerLevel.Trace).turnOn();\n\n const u = new RustSdkCryptoJs.UserId(userId);\n const d = new RustSdkCryptoJs.DeviceId(deviceId);\n logger.info(\"Init OlmMachine\");\n\n // TODO: use the pickle key for the passphrase\n const olmMachine = await RustSdkCryptoJs.OlmMachine.initialize(u, d, RUST_SDK_STORE_PREFIX, \"test pass\");\n const rustCrypto = new RustCrypto(olmMachine, http, userId, deviceId);\n\n logger.info(\"Completed rust crypto-sdk setup\");\n return rustCrypto;\n}\n"],"mappings":";;;;;;AAgBA,IAAAA,eAAA,GAAAC,uBAAA,CAAAC,OAAA;AAEA,IAAAC,WAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,UAAA,GAAAH,OAAA;AAAoD,SAAAI,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAN,wBAAAU,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAE,GAAA,CAAAL,GAAA,SAAAM,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAX,GAAA,QAAAW,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAd,GAAA,EAAAW,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAV,GAAA,EAAAW,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAX,GAAA,CAAAW,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAhB,GAAA,EAAAM,MAAA,YAAAA,MAAA;AApBpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AASO,eAAeW,cAAcA,CAChCC,IAAmD,EACnDC,MAAc,EACdC,QAAgB,EACG;EACnB;EACA,MAAM/B,eAAe,CAACgC,SAAS,EAAE;;EAEjC;EACA,IAAIhC,eAAe,CAACiC,OAAO,CAACjC,eAAe,CAACkC,WAAW,CAACC,KAAK,CAAC,CAACC,MAAM,EAAE;EAEvE,MAAMC,CAAC,GAAG,IAAIrC,eAAe,CAACsC,MAAM,CAACR,MAAM,CAAC;EAC5C,MAAMS,CAAC,GAAG,IAAIvC,eAAe,CAACwC,QAAQ,CAACT,QAAQ,CAAC;EAChDU,cAAM,CAACC,IAAI,CAAC,iBAAiB,CAAC;;EAE9B;EACA,MAAMC,UAAU,GAAG,MAAM3C,eAAe,CAAC4C,UAAU,CAACC,UAAU,CAACR,CAAC,EAAEE,CAAC,EAAEO,gCAAqB,EAAE,WAAW,CAAC;EACxG,MAAMC,UAAU,GAAG,IAAIC,sBAAU,CAACL,UAAU,EAAEd,IAAI,EAAEC,MAAM,EAAEC,QAAQ,CAAC;EAErEU,cAAM,CAACC,IAAI,CAAC,iCAAiC,CAAC;EAC9C,OAAOK,UAAU;AACrB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts deleted file mode 100644 index fe94fdc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts +++ /dev/null @@ -1,87 +0,0 @@ -import * as RustSdkCryptoJs from "@matrix-org/matrix-sdk-crypto-js"; -import type { IEventDecryptionResult, IMegolmSessionData } from "../@types/crypto"; -import type { IToDeviceEvent } from "../sync-accumulator"; -import type { IEncryptedEventInfo } from "../crypto/api"; -import { MatrixEvent } from "../models/event"; -import { Room } from "../models/room"; -import { RoomMember } from "../models/room-member"; -import { CryptoBackend, OnSyncCompletedData } from "../common-crypto/CryptoBackend"; -import { IHttpOpts, MatrixHttpApi } from "../http-api"; -import { DeviceTrustLevel, UserTrustLevel } from "../crypto/CrossSigning"; -/** - * An implementation of {@link CryptoBackend} using the Rust matrix-sdk-crypto. - */ -export declare class RustCrypto implements CryptoBackend { - private readonly olmMachine; - globalErrorOnUnknownDevices: boolean; - /** whether {@link stop} has been called */ - private stopped; - /** whether {@link outgoingRequestLoop} is currently running */ - private outgoingRequestLoopRunning; - /** mapping of roomId → encryptor class */ - private roomEncryptors; - private keyClaimManager; - private outgoingRequestProcessor; - constructor(olmMachine: RustSdkCryptoJs.OlmMachine, http: MatrixHttpApi, _userId: string, _deviceId: string); - stop(): void; - encryptEvent(event: MatrixEvent, _room: Room): Promise; - decryptEvent(event: MatrixEvent): Promise; - getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo; - checkUserTrust(userId: string): UserTrustLevel; - checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel; - globalBlacklistUnverifiedDevices: boolean; - userHasCrossSigningKeys(): Promise; - prepareToEncrypt(room: Room): void; - forceDiscardSession(roomId: string): Promise; - exportRoomKeys(): Promise; - /** - * Apply sync changes to the olm machine - * @param events - the received to-device messages - * @param oneTimeKeysCounts - the received one time key counts - * @param unusedFallbackKeys - the received unused fallback keys - * @returns A list of preprocessed to-device messages. - */ - private receiveSyncChanges; - /** called by the sync loop to preprocess incoming to-device messages - * - * @param events - the received to-device messages - * @returns A list of preprocessed to-device messages. - */ - preprocessToDeviceMessages(events: IToDeviceEvent[]): Promise; - /** called by the sync loop to preprocess one time key counts - * - * @param oneTimeKeysCounts - the received one time key counts - * @returns A list of preprocessed to-device messages. - */ - preprocessOneTimeKeyCounts(oneTimeKeysCounts: Map): Promise; - /** called by the sync loop to preprocess unused fallback keys - * - * @param unusedFallbackKeys - the received unused fallback keys - * @returns A list of preprocessed to-device messages. - */ - preprocessUnusedFallbackKeys(unusedFallbackKeys: Set): Promise; - /** called by the sync loop on m.room.encrypted events - * - * @param room - in which the event was received - * @param event - encryption event to be processed - */ - onCryptoEvent(room: Room, event: MatrixEvent): Promise; - /** called by the sync loop after processing each sync. - * - * TODO: figure out something equivalent for sliding sync. - * - * @param syncState - information on the completed sync. - */ - onSyncCompleted(syncState: OnSyncCompletedData): void; - /** called by the MatrixClient on a room membership event - * - * @param event - The matrix event which caused this event to fire. - * @param member - The member whose RoomMember.membership changed. - * @param oldMembership - The previous membership state. Null if it's a new member. - */ - onRoomMembership(event: MatrixEvent, member: RoomMember, oldMembership?: string): void; - private outgoingRequestLoop; -} -//# sourceMappingURL=rust-crypto.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts.map deleted file mode 100644 index b550e06..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"rust-crypto.d.ts","sourceRoot":"","sources":["../../src/rust-crypto/rust-crypto.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,eAAe,MAAM,kCAAkC,CAAC;AAEpE,OAAO,KAAK,EAAE,sBAAsB,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACnF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AACtC,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AAEpF,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAK1E;;GAEG;AACH,qBAAa,UAAW,YAAW,aAAa;IAgBxC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAfxB,2BAA2B,UAAS;IAE3C,2CAA2C;IAC3C,OAAO,CAAC,OAAO,CAAS;IAExB,+DAA+D;IAC/D,OAAO,CAAC,0BAA0B,CAAS;IAE3C,0CAA0C;IAC1C,OAAO,CAAC,cAAc,CAAqC;IAE3D,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,wBAAwB,CAA2B;gBAGtC,UAAU,EAAE,eAAe,CAAC,UAAU,EACvD,IAAI,EAAE,aAAa,CAAC,SAAS,GAAG;QAAE,QAAQ,EAAE,IAAI,CAAA;KAAE,CAAC,EACnD,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM;IAYd,IAAI,IAAI,IAAI;IAgBN,YAAY,CAAC,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAW5D,YAAY,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,sBAAsB,CAAC;IA6BvE,sBAAsB,CAAC,KAAK,EAAE,WAAW,GAAG,mBAAmB;IAkB/D,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc;IAK9C,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,gBAAgB;IAWpE,gCAAgC,UAAS;IAEnC,uBAAuB,IAAI,OAAO,CAAC,OAAO,CAAC;IAKjD,gBAAgB,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI;IAQlC,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI5C,cAAc,IAAI,OAAO,CAAC,kBAAkB,EAAE,CAAC;IAW5D;;;;;;OAMG;YACW,kBAAkB;IAoBhC;;;;OAIG;IACI,0BAA0B,CAAC,MAAM,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;IAMtF;;;;OAIG;IACU,0BAA0B,CAAC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAI9F;;;;OAIG;IACU,4BAA4B,CAAC,kBAAkB,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAIzF;;;;OAIG;IACU,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAyBzE;;;;;OAKG;IACI,eAAe,CAAC,SAAS,EAAE,mBAAmB,GAAG,IAAI;IAY5D;;;;;OAKG;IACI,gBAAgB,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,UAAU,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;YAe/E,mBAAmB;CAsBpC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js deleted file mode 100644 index 4faf66b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js +++ /dev/null @@ -1,301 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RustCrypto = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var RustSdkCryptoJs = _interopRequireWildcard(require("@matrix-org/matrix-sdk-crypto-js")); -var _logger = require("../logger"); -var _CrossSigning = require("../crypto/CrossSigning"); -var _RoomEncryptor = require("./RoomEncryptor"); -var _OutgoingRequestProcessor = require("./OutgoingRequestProcessor"); -var _KeyClaimManager = require("./KeyClaimManager"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * An implementation of {@link CryptoBackend} using the Rust matrix-sdk-crypto. - */ -class RustCrypto { - /** whether {@link stop} has been called */ - - /** whether {@link outgoingRequestLoop} is currently running */ - - /** mapping of roomId → encryptor class */ - - constructor(olmMachine, http, _userId, _deviceId) { - this.olmMachine = olmMachine; - (0, _defineProperty2.default)(this, "globalErrorOnUnknownDevices", false); - (0, _defineProperty2.default)(this, "stopped", false); - (0, _defineProperty2.default)(this, "outgoingRequestLoopRunning", false); - (0, _defineProperty2.default)(this, "roomEncryptors", {}); - (0, _defineProperty2.default)(this, "keyClaimManager", void 0); - (0, _defineProperty2.default)(this, "outgoingRequestProcessor", void 0); - (0, _defineProperty2.default)(this, "globalBlacklistUnverifiedDevices", false); - this.outgoingRequestProcessor = new _OutgoingRequestProcessor.OutgoingRequestProcessor(olmMachine, http); - this.keyClaimManager = new _KeyClaimManager.KeyClaimManager(olmMachine, this.outgoingRequestProcessor); - } - - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - // - // CryptoBackend implementation - // - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - - stop() { - // stop() may be called multiple times, but attempting to close() the OlmMachine twice - // will cause an error. - if (this.stopped) { - return; - } - this.stopped = true; - this.keyClaimManager.stop(); - - // make sure we close() the OlmMachine; doing so means that all the Rust objects will be - // cleaned up; in particular, the indexeddb connections will be closed, which means they - // can then be deleted. - this.olmMachine.close(); - } - async encryptEvent(event, _room) { - const roomId = event.getRoomId(); - const encryptor = this.roomEncryptors[roomId]; - if (!encryptor) { - throw new Error(`Cannot encrypt event in unconfigured room ${roomId}`); - } - await encryptor.encryptEvent(event); - } - async decryptEvent(event) { - const roomId = event.getRoomId(); - if (!roomId) { - // presumably, a to-device message. These are normally decrypted in preprocessToDeviceMessages - // so the fact it has come back here suggests that decryption failed. - // - // once we drop support for the libolm crypto implementation, we can stop passing to-device messages - // through decryptEvent and hence get rid of this case. - throw new Error("to-device event was not decrypted in preprocessToDeviceMessages"); - } - const res = await this.olmMachine.decryptRoomEvent(JSON.stringify({ - event_id: event.getId(), - type: event.getWireType(), - sender: event.getSender(), - state_key: event.getStateKey(), - content: event.getWireContent(), - origin_server_ts: event.getTs() - }), new RustSdkCryptoJs.RoomId(event.getRoomId())); - return { - clearEvent: JSON.parse(res.event), - claimedEd25519Key: res.senderClaimedEd25519Key, - senderCurve25519Key: res.senderCurve25519Key, - forwardingCurve25519KeyChain: res.forwardingCurve25519KeyChain - }; - } - getEventEncryptionInfo(event) { - var _event$getSenderKey; - // TODO: make this work properly. Or better, replace it. - - const ret = {}; - ret.senderKey = (_event$getSenderKey = event.getSenderKey()) !== null && _event$getSenderKey !== void 0 ? _event$getSenderKey : undefined; - ret.algorithm = event.getWireContent().algorithm; - if (!ret.senderKey || !ret.algorithm) { - ret.encrypted = false; - return ret; - } - ret.encrypted = true; - ret.authenticated = true; - ret.mismatchedSender = true; - return ret; - } - checkUserTrust(userId) { - // TODO - return new _CrossSigning.UserTrustLevel(false, false, false); - } - checkDeviceTrust(userId, deviceId) { - // TODO - return new _CrossSigning.DeviceTrustLevel(false, false, false, false); - } - - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - // - // CryptoApi implementation - // - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - - async userHasCrossSigningKeys() { - // TODO - return false; - } - prepareToEncrypt(room) { - const encryptor = this.roomEncryptors[room.roomId]; - if (encryptor) { - encryptor.ensureEncryptionSession(); - } - } - forceDiscardSession(roomId) { - var _this$roomEncryptors$; - return (_this$roomEncryptors$ = this.roomEncryptors[roomId]) === null || _this$roomEncryptors$ === void 0 ? void 0 : _this$roomEncryptors$.forceDiscardSession(); - } - async exportRoomKeys() { - // TODO - return []; - } - - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - // - // SyncCryptoCallbacks implementation - // - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - - /** - * Apply sync changes to the olm machine - * @param events - the received to-device messages - * @param oneTimeKeysCounts - the received one time key counts - * @param unusedFallbackKeys - the received unused fallback keys - * @returns A list of preprocessed to-device messages. - */ - async receiveSyncChanges({ - events, - oneTimeKeysCounts = new Map(), - unusedFallbackKeys = new Set() - }) { - const result = await this.olmMachine.receiveSyncChanges(events ? JSON.stringify(events) : "[]", new RustSdkCryptoJs.DeviceLists(), oneTimeKeysCounts, unusedFallbackKeys); - - // receiveSyncChanges returns a JSON-encoded list of decrypted to-device messages. - return JSON.parse(result); - } - - /** called by the sync loop to preprocess incoming to-device messages - * - * @param events - the received to-device messages - * @returns A list of preprocessed to-device messages. - */ - preprocessToDeviceMessages(events) { - // send the received to-device messages into receiveSyncChanges. We have no info on device-list changes, - // one-time-keys, or fallback keys, so just pass empty data. - return this.receiveSyncChanges({ - events - }); - } - - /** called by the sync loop to preprocess one time key counts - * - * @param oneTimeKeysCounts - the received one time key counts - * @returns A list of preprocessed to-device messages. - */ - async preprocessOneTimeKeyCounts(oneTimeKeysCounts) { - await this.receiveSyncChanges({ - oneTimeKeysCounts - }); - } - - /** called by the sync loop to preprocess unused fallback keys - * - * @param unusedFallbackKeys - the received unused fallback keys - * @returns A list of preprocessed to-device messages. - */ - async preprocessUnusedFallbackKeys(unusedFallbackKeys) { - await this.receiveSyncChanges({ - unusedFallbackKeys - }); - } - - /** called by the sync loop on m.room.encrypted events - * - * @param room - in which the event was received - * @param event - encryption event to be processed - */ - async onCryptoEvent(room, event) { - const config = event.getContent(); - const existingEncryptor = this.roomEncryptors[room.roomId]; - if (existingEncryptor) { - existingEncryptor.onCryptoEvent(config); - } else { - this.roomEncryptors[room.roomId] = new _RoomEncryptor.RoomEncryptor(this.olmMachine, this.keyClaimManager, this.outgoingRequestProcessor, room, config); - } - - // start tracking devices for any users already known to be in this room. - const members = await room.getEncryptionTargetMembers(); - _logger.logger.debug(`[${room.roomId} encryption] starting to track devices for: `, members.map(u => `${u.userId} (${u.membership})`)); - await this.olmMachine.updateTrackedUsers(members.map(u => new RustSdkCryptoJs.UserId(u.userId))); - } - - /** called by the sync loop after processing each sync. - * - * TODO: figure out something equivalent for sliding sync. - * - * @param syncState - information on the completed sync. - */ - onSyncCompleted(syncState) { - // Processing the /sync may have produced new outgoing requests which need sending, so kick off the outgoing - // request loop, if it's not already running. - this.outgoingRequestLoop(); - } - - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - // - // Other public functions - // - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - - /** called by the MatrixClient on a room membership event - * - * @param event - The matrix event which caused this event to fire. - * @param member - The member whose RoomMember.membership changed. - * @param oldMembership - The previous membership state. Null if it's a new member. - */ - onRoomMembership(event, member, oldMembership) { - const enc = this.roomEncryptors[event.getRoomId()]; - if (!enc) { - // not encrypting in this room - return; - } - enc.onRoomMembership(member); - } - - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - // - // Outgoing requests - // - /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - - async outgoingRequestLoop() { - if (this.outgoingRequestLoopRunning) { - return; - } - this.outgoingRequestLoopRunning = true; - try { - while (!this.stopped) { - const outgoingRequests = await this.olmMachine.outgoingRequests(); - if (outgoingRequests.length == 0 || this.stopped) { - // no more messages to send (or we have been told to stop): exit the loop - return; - } - for (const msg of outgoingRequests) { - await this.outgoingRequestProcessor.makeOutgoingRequest(msg); - } - } - } catch (e) { - _logger.logger.error("Error processing outgoing-message requests from rust crypto-sdk", e); - } finally { - this.outgoingRequestLoopRunning = false; - } - } -} -exports.RustCrypto = RustCrypto; -//# sourceMappingURL=rust-crypto.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js.map deleted file mode 100644 index 18bf6af..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/rust-crypto/rust-crypto.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"rust-crypto.js","names":["RustSdkCryptoJs","_interopRequireWildcard","require","_logger","_CrossSigning","_RoomEncryptor","_OutgoingRequestProcessor","_KeyClaimManager","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","RustCrypto","constructor","olmMachine","http","_userId","_deviceId","_defineProperty2","outgoingRequestProcessor","OutgoingRequestProcessor","keyClaimManager","KeyClaimManager","stop","stopped","close","encryptEvent","event","_room","roomId","getRoomId","encryptor","roomEncryptors","Error","decryptEvent","res","decryptRoomEvent","JSON","stringify","event_id","getId","type","getWireType","sender","getSender","state_key","getStateKey","content","getWireContent","origin_server_ts","getTs","RoomId","clearEvent","parse","claimedEd25519Key","senderClaimedEd25519Key","senderCurve25519Key","forwardingCurve25519KeyChain","getEventEncryptionInfo","_event$getSenderKey","ret","senderKey","getSenderKey","undefined","algorithm","encrypted","authenticated","mismatchedSender","checkUserTrust","userId","UserTrustLevel","checkDeviceTrust","deviceId","DeviceTrustLevel","userHasCrossSigningKeys","prepareToEncrypt","room","ensureEncryptionSession","forceDiscardSession","_this$roomEncryptors$","exportRoomKeys","receiveSyncChanges","events","oneTimeKeysCounts","Map","unusedFallbackKeys","Set","result","DeviceLists","preprocessToDeviceMessages","preprocessOneTimeKeyCounts","preprocessUnusedFallbackKeys","onCryptoEvent","config","getContent","existingEncryptor","RoomEncryptor","members","getEncryptionTargetMembers","logger","debug","map","u","membership","updateTrackedUsers","UserId","onSyncCompleted","syncState","outgoingRequestLoop","onRoomMembership","member","oldMembership","enc","outgoingRequestLoopRunning","outgoingRequests","length","msg","makeOutgoingRequest","e","error","exports"],"sources":["../../src/rust-crypto/rust-crypto.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport * as RustSdkCryptoJs from \"@matrix-org/matrix-sdk-crypto-js\";\n\nimport type { IEventDecryptionResult, IMegolmSessionData } from \"../@types/crypto\";\nimport type { IToDeviceEvent } from \"../sync-accumulator\";\nimport type { IEncryptedEventInfo } from \"../crypto/api\";\nimport { MatrixEvent } from \"../models/event\";\nimport { Room } from \"../models/room\";\nimport { RoomMember } from \"../models/room-member\";\nimport { CryptoBackend, OnSyncCompletedData } from \"../common-crypto/CryptoBackend\";\nimport { logger } from \"../logger\";\nimport { IHttpOpts, MatrixHttpApi } from \"../http-api\";\nimport { DeviceTrustLevel, UserTrustLevel } from \"../crypto/CrossSigning\";\nimport { RoomEncryptor } from \"./RoomEncryptor\";\nimport { OutgoingRequest, OutgoingRequestProcessor } from \"./OutgoingRequestProcessor\";\nimport { KeyClaimManager } from \"./KeyClaimManager\";\n\n/**\n * An implementation of {@link CryptoBackend} using the Rust matrix-sdk-crypto.\n */\nexport class RustCrypto implements CryptoBackend {\n public globalErrorOnUnknownDevices = false;\n\n /** whether {@link stop} has been called */\n private stopped = false;\n\n /** whether {@link outgoingRequestLoop} is currently running */\n private outgoingRequestLoopRunning = false;\n\n /** mapping of roomId → encryptor class */\n private roomEncryptors: Record = {};\n\n private keyClaimManager: KeyClaimManager;\n private outgoingRequestProcessor: OutgoingRequestProcessor;\n\n public constructor(\n private readonly olmMachine: RustSdkCryptoJs.OlmMachine,\n http: MatrixHttpApi,\n _userId: string,\n _deviceId: string,\n ) {\n this.outgoingRequestProcessor = new OutgoingRequestProcessor(olmMachine, http);\n this.keyClaimManager = new KeyClaimManager(olmMachine, this.outgoingRequestProcessor);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n //\n // CryptoBackend implementation\n //\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n public stop(): void {\n // stop() may be called multiple times, but attempting to close() the OlmMachine twice\n // will cause an error.\n if (this.stopped) {\n return;\n }\n this.stopped = true;\n\n this.keyClaimManager.stop();\n\n // make sure we close() the OlmMachine; doing so means that all the Rust objects will be\n // cleaned up; in particular, the indexeddb connections will be closed, which means they\n // can then be deleted.\n this.olmMachine.close();\n }\n\n public async encryptEvent(event: MatrixEvent, _room: Room): Promise {\n const roomId = event.getRoomId()!;\n const encryptor = this.roomEncryptors[roomId];\n\n if (!encryptor) {\n throw new Error(`Cannot encrypt event in unconfigured room ${roomId}`);\n }\n\n await encryptor.encryptEvent(event);\n }\n\n public async decryptEvent(event: MatrixEvent): Promise {\n const roomId = event.getRoomId();\n if (!roomId) {\n // presumably, a to-device message. These are normally decrypted in preprocessToDeviceMessages\n // so the fact it has come back here suggests that decryption failed.\n //\n // once we drop support for the libolm crypto implementation, we can stop passing to-device messages\n // through decryptEvent and hence get rid of this case.\n throw new Error(\"to-device event was not decrypted in preprocessToDeviceMessages\");\n }\n const res = (await this.olmMachine.decryptRoomEvent(\n JSON.stringify({\n event_id: event.getId(),\n type: event.getWireType(),\n sender: event.getSender(),\n state_key: event.getStateKey(),\n content: event.getWireContent(),\n origin_server_ts: event.getTs(),\n }),\n new RustSdkCryptoJs.RoomId(event.getRoomId()!),\n )) as RustSdkCryptoJs.DecryptedRoomEvent;\n return {\n clearEvent: JSON.parse(res.event),\n claimedEd25519Key: res.senderClaimedEd25519Key,\n senderCurve25519Key: res.senderCurve25519Key,\n forwardingCurve25519KeyChain: res.forwardingCurve25519KeyChain,\n };\n }\n\n public getEventEncryptionInfo(event: MatrixEvent): IEncryptedEventInfo {\n // TODO: make this work properly. Or better, replace it.\n\n const ret: Partial = {};\n\n ret.senderKey = event.getSenderKey() ?? undefined;\n ret.algorithm = event.getWireContent().algorithm;\n\n if (!ret.senderKey || !ret.algorithm) {\n ret.encrypted = false;\n return ret as IEncryptedEventInfo;\n }\n ret.encrypted = true;\n ret.authenticated = true;\n ret.mismatchedSender = true;\n return ret as IEncryptedEventInfo;\n }\n\n public checkUserTrust(userId: string): UserTrustLevel {\n // TODO\n return new UserTrustLevel(false, false, false);\n }\n\n public checkDeviceTrust(userId: string, deviceId: string): DeviceTrustLevel {\n // TODO\n return new DeviceTrustLevel(false, false, false, false);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n //\n // CryptoApi implementation\n //\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n public globalBlacklistUnverifiedDevices = false;\n\n public async userHasCrossSigningKeys(): Promise {\n // TODO\n return false;\n }\n\n public prepareToEncrypt(room: Room): void {\n const encryptor = this.roomEncryptors[room.roomId];\n\n if (encryptor) {\n encryptor.ensureEncryptionSession();\n }\n }\n\n public forceDiscardSession(roomId: string): Promise {\n return this.roomEncryptors[roomId]?.forceDiscardSession();\n }\n\n public async exportRoomKeys(): Promise {\n // TODO\n return [];\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n //\n // SyncCryptoCallbacks implementation\n //\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n /**\n * Apply sync changes to the olm machine\n * @param events - the received to-device messages\n * @param oneTimeKeysCounts - the received one time key counts\n * @param unusedFallbackKeys - the received unused fallback keys\n * @returns A list of preprocessed to-device messages.\n */\n private async receiveSyncChanges({\n events,\n oneTimeKeysCounts = new Map(),\n unusedFallbackKeys = new Set(),\n }: {\n events?: IToDeviceEvent[];\n oneTimeKeysCounts?: Map;\n unusedFallbackKeys?: Set;\n }): Promise {\n const result = await this.olmMachine.receiveSyncChanges(\n events ? JSON.stringify(events) : \"[]\",\n new RustSdkCryptoJs.DeviceLists(),\n oneTimeKeysCounts,\n unusedFallbackKeys,\n );\n\n // receiveSyncChanges returns a JSON-encoded list of decrypted to-device messages.\n return JSON.parse(result);\n }\n\n /** called by the sync loop to preprocess incoming to-device messages\n *\n * @param events - the received to-device messages\n * @returns A list of preprocessed to-device messages.\n */\n public preprocessToDeviceMessages(events: IToDeviceEvent[]): Promise {\n // send the received to-device messages into receiveSyncChanges. We have no info on device-list changes,\n // one-time-keys, or fallback keys, so just pass empty data.\n return this.receiveSyncChanges({ events });\n }\n\n /** called by the sync loop to preprocess one time key counts\n *\n * @param oneTimeKeysCounts - the received one time key counts\n * @returns A list of preprocessed to-device messages.\n */\n public async preprocessOneTimeKeyCounts(oneTimeKeysCounts: Map): Promise {\n await this.receiveSyncChanges({ oneTimeKeysCounts });\n }\n\n /** called by the sync loop to preprocess unused fallback keys\n *\n * @param unusedFallbackKeys - the received unused fallback keys\n * @returns A list of preprocessed to-device messages.\n */\n public async preprocessUnusedFallbackKeys(unusedFallbackKeys: Set): Promise {\n await this.receiveSyncChanges({ unusedFallbackKeys });\n }\n\n /** called by the sync loop on m.room.encrypted events\n *\n * @param room - in which the event was received\n * @param event - encryption event to be processed\n */\n public async onCryptoEvent(room: Room, event: MatrixEvent): Promise {\n const config = event.getContent();\n\n const existingEncryptor = this.roomEncryptors[room.roomId];\n if (existingEncryptor) {\n existingEncryptor.onCryptoEvent(config);\n } else {\n this.roomEncryptors[room.roomId] = new RoomEncryptor(\n this.olmMachine,\n this.keyClaimManager,\n this.outgoingRequestProcessor,\n room,\n config,\n );\n }\n\n // start tracking devices for any users already known to be in this room.\n const members = await room.getEncryptionTargetMembers();\n logger.debug(\n `[${room.roomId} encryption] starting to track devices for: `,\n members.map((u) => `${u.userId} (${u.membership})`),\n );\n await this.olmMachine.updateTrackedUsers(members.map((u) => new RustSdkCryptoJs.UserId(u.userId)));\n }\n\n /** called by the sync loop after processing each sync.\n *\n * TODO: figure out something equivalent for sliding sync.\n *\n * @param syncState - information on the completed sync.\n */\n public onSyncCompleted(syncState: OnSyncCompletedData): void {\n // Processing the /sync may have produced new outgoing requests which need sending, so kick off the outgoing\n // request loop, if it's not already running.\n this.outgoingRequestLoop();\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n //\n // Other public functions\n //\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n /** called by the MatrixClient on a room membership event\n *\n * @param event - The matrix event which caused this event to fire.\n * @param member - The member whose RoomMember.membership changed.\n * @param oldMembership - The previous membership state. Null if it's a new member.\n */\n public onRoomMembership(event: MatrixEvent, member: RoomMember, oldMembership?: string): void {\n const enc = this.roomEncryptors[event.getRoomId()!];\n if (!enc) {\n // not encrypting in this room\n return;\n }\n enc.onRoomMembership(member);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n //\n // Outgoing requests\n //\n ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n\n private async outgoingRequestLoop(): Promise {\n if (this.outgoingRequestLoopRunning) {\n return;\n }\n this.outgoingRequestLoopRunning = true;\n try {\n while (!this.stopped) {\n const outgoingRequests: Object[] = await this.olmMachine.outgoingRequests();\n if (outgoingRequests.length == 0 || this.stopped) {\n // no more messages to send (or we have been told to stop): exit the loop\n return;\n }\n for (const msg of outgoingRequests) {\n await this.outgoingRequestProcessor.makeOutgoingRequest(msg as OutgoingRequest);\n }\n }\n } catch (e) {\n logger.error(\"Error processing outgoing-message requests from rust crypto-sdk\", e);\n } finally {\n this.outgoingRequestLoopRunning = false;\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts deleted file mode 100644 index 8e3215d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts +++ /dev/null @@ -1,135 +0,0 @@ -import { MatrixEvent } from "./models/event"; -import { MatrixError } from "./http-api"; -import { ISendEventResponse } from "./@types/requests"; -/** - * The function to invoke to process (send) events in the queue. - * @param event - The event to send. - * @returns Resolved/rejected depending on the outcome of the request. - */ -type ProcessFunction = (event: MatrixEvent) => Promise; -export declare class MatrixScheduler { - /** - * The retry algorithm to apply when retrying events. To stop retrying, return - * `-1`. If this event was part of a queue, it will be removed from - * the queue. - * @param event - The event being retried. - * @param attempts - The number of failed attempts. This will always be \>= 1. - * @param err - The most recent error message received when trying - * to send this event. - * @returns The number of milliseconds to wait before trying again. If - * this is 0, the request will be immediately retried. If this is - * `-1`, the event will be marked as - * {@link EventStatus.NOT_SENT} and will not be retried. - */ - readonly retryAlgorithm: typeof MatrixScheduler.RETRY_BACKOFF_RATELIMIT; - /** - * The queuing algorithm to apply to events. This function must be idempotent as - * it may be called multiple times with the same event. All queues created are - * serviced in a FIFO manner. To send the event ASAP, return `null` - * which will not put this event in a queue. Events that fail to send that form - * part of a queue will be removed from the queue and the next event in the - * queue will be sent. - * @param event - The event to be sent. - * @returns The name of the queue to put the event into. If a queue with - * this name does not exist, it will be created. If this is `null`, - * the event is not put into a queue and will be sent concurrently. - */ - readonly queueAlgorithm: typeof MatrixScheduler.QUEUE_MESSAGES; - /** - * Retries events up to 4 times using exponential backoff. This produces wait - * times of 2, 4, 8, and 16 seconds (30s total) after which we give up. If the - * failure was due to a rate limited request, the time specified in the error is - * waited before being retried. - * @param attempts - Number of attempts that have been made, including the one that just failed (ie. starting at 1) - * @see retryAlgorithm - */ - static RETRY_BACKOFF_RATELIMIT(event: MatrixEvent | null, attempts: number, err: MatrixError): number; - /** - * Queues `m.room.message` events and lets other events continue - * concurrently. - * @see queueAlgorithm - */ - static QUEUE_MESSAGES(event: MatrixEvent): string | null; - private readonly queues; - private activeQueues; - private procFn; - /** - * Construct a scheduler for Matrix. Requires - * {@link MatrixScheduler#setProcessFunction} to be provided - * with a way of processing events. - * @param retryAlgorithm - Optional. The retry - * algorithm to apply when determining when to try to send an event again. - * Defaults to {@link MatrixScheduler.RETRY_BACKOFF_RATELIMIT}. - * @param queueAlgorithm - Optional. The queuing - * algorithm to apply when determining which events should be sent before the - * given event. Defaults to {@link MatrixScheduler.QUEUE_MESSAGES}. - */ - constructor( - /** - * The retry algorithm to apply when retrying events. To stop retrying, return - * `-1`. If this event was part of a queue, it will be removed from - * the queue. - * @param event - The event being retried. - * @param attempts - The number of failed attempts. This will always be \>= 1. - * @param err - The most recent error message received when trying - * to send this event. - * @returns The number of milliseconds to wait before trying again. If - * this is 0, the request will be immediately retried. If this is - * `-1`, the event will be marked as - * {@link EventStatus.NOT_SENT} and will not be retried. - */ - retryAlgorithm?: typeof MatrixScheduler.RETRY_BACKOFF_RATELIMIT, - /** - * The queuing algorithm to apply to events. This function must be idempotent as - * it may be called multiple times with the same event. All queues created are - * serviced in a FIFO manner. To send the event ASAP, return `null` - * which will not put this event in a queue. Events that fail to send that form - * part of a queue will be removed from the queue and the next event in the - * queue will be sent. - * @param event - The event to be sent. - * @returns The name of the queue to put the event into. If a queue with - * this name does not exist, it will be created. If this is `null`, - * the event is not put into a queue and will be sent concurrently. - */ - queueAlgorithm?: typeof MatrixScheduler.QUEUE_MESSAGES); - /** - * Retrieve a queue based on an event. The event provided does not need to be in - * the queue. - * @param event - An event to get the queue for. - * @returns A shallow copy of events in the queue or null. - * Modifying this array will not modify the list itself. Modifying events in - * this array will modify the underlying event in the queue. - * @see MatrixScheduler.removeEventFromQueue To remove an event from the queue. - */ - getQueueForEvent(event: MatrixEvent): MatrixEvent[] | null; - /** - * Remove this event from the queue. The event is equal to another event if they - * have the same ID returned from event.getId(). - * @param event - The event to remove. - * @returns True if this event was removed. - */ - removeEventFromQueue(event: MatrixEvent): boolean; - /** - * Set the process function. Required for events in the queue to be processed. - * If set after events have been added to the queue, this will immediately start - * processing them. - * @param fn - The function that can process events - * in the queue. - */ - setProcessFunction(fn: ProcessFunction): void; - /** - * Queue an event if it is required and start processing queues. - * @param event - The event that may be queued. - * @returns A promise if the event was queued, which will be - * resolved or rejected in due time, else null. - */ - queueEvent(event: MatrixEvent): Promise | null; - private startProcessingQueues; - private processQueue; - private disableQueue; - private clearQueue; - private peekNextEvent; - private removeNextEvent; -} -export {}; -//# sourceMappingURL=scheduler.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts.map deleted file mode 100644 index 392f811..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"scheduler.d.ts","sourceRoot":"","sources":["../src/scheduler.ts"],"names":[],"mappings":"AAsBA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7C,OAAO,EAAmB,WAAW,EAAE,MAAM,YAAY,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAUvD;;;;GAIG;AACH,KAAK,eAAe,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;AAG7D,qBAAa,eAAe,CAAC,CAAC,GAAG,kBAAkB;IAyE3C;;;;;;;;;;;;OAYG;aACa,cAAc;IAC9B;;;;;;;;;;;OAWG;aACa,cAAc;IAlGlC;;;;;;;OAOG;WAEW,uBAAuB,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,GAAG,MAAM;IA0B5G;;;;OAIG;WAEW,cAAc,CAAC,KAAK,EAAE,WAAW,GAAG,MAAM,GAAG,IAAI;IAe/D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwC;IAC/D,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,MAAM,CAAmC;IAEjD;;;;;;;;;;OAUG;;IAEC;;;;;;;;;;;;OAYG;IACa,cAAc,iDAA0C;IACxE;;;;;;;;;;;OAWG;IACa,cAAc,wCAAiC;IAGnE;;;;;;;;OAQG;IACI,gBAAgB,CAAC,KAAK,EAAE,WAAW,GAAG,WAAW,EAAE,GAAG,IAAI;IAUjE;;;;;OAKG;IACI,oBAAoB,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO;IAkBxD;;;;;;OAMG;IACI,kBAAkB,CAAC,EAAE,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI;IAKvD;;;;;OAKG;IACI,UAAU,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI;IAoBxD,OAAO,CAAC,qBAAqB;IAgB7B,OAAO,CAAC,YAAY,CAiDlB;IAEF,OAAO,CAAC,YAAY;IASpB,OAAO,CAAC,UAAU;IASlB,OAAO,CAAC,aAAa;IAQrB,OAAO,CAAC,eAAe;CAO1B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js deleted file mode 100644 index e657316..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js +++ /dev/null @@ -1,314 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MatrixScheduler = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var utils = _interopRequireWildcard(require("./utils")); -var _logger = require("./logger"); -var _event = require("./@types/event"); -var _httpApi = require("./http-api"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * This is an internal module which manages queuing, scheduling and retrying - * of requests. - */ - -const DEBUG = false; // set true to enable console logging. - -// eslint-disable-next-line camelcase -class MatrixScheduler { - /** - * Retries events up to 4 times using exponential backoff. This produces wait - * times of 2, 4, 8, and 16 seconds (30s total) after which we give up. If the - * failure was due to a rate limited request, the time specified in the error is - * waited before being retried. - * @param attempts - Number of attempts that have been made, including the one that just failed (ie. starting at 1) - * @see retryAlgorithm - */ - // eslint-disable-next-line @typescript-eslint/naming-convention - static RETRY_BACKOFF_RATELIMIT(event, attempts, err) { - if (err.httpStatus === 400 || err.httpStatus === 403 || err.httpStatus === 401) { - // client error; no amount of retrying with save you now. - return -1; - } - if (err instanceof _httpApi.ConnectionError) { - return -1; - } - - // if event that we are trying to send is too large in any way then retrying won't help - if (err.name === "M_TOO_LARGE") { - return -1; - } - if (err.name === "M_LIMIT_EXCEEDED") { - const waitTime = err.data.retry_after_ms; - if (waitTime > 0) { - return waitTime; - } - } - if (attempts > 4) { - return -1; // give up - } - - return 1000 * Math.pow(2, attempts); - } - - /** - * Queues `m.room.message` events and lets other events continue - * concurrently. - * @see queueAlgorithm - */ - // eslint-disable-next-line @typescript-eslint/naming-convention - static QUEUE_MESSAGES(event) { - // enqueue messages or events that associate with another event (redactions and relations) - if (event.getType() === _event.EventType.RoomMessage || event.hasAssociation()) { - // put these events in the 'message' queue. - return "message"; - } - // allow all other events continue concurrently. - return null; - } - - // queueName: [{ - // event: MatrixEvent, // event to send - // defer: Deferred, // defer to resolve/reject at the END of the retries - // attempts: Number // number of times we've called processFn - // }, ...] - - /** - * Construct a scheduler for Matrix. Requires - * {@link MatrixScheduler#setProcessFunction} to be provided - * with a way of processing events. - * @param retryAlgorithm - Optional. The retry - * algorithm to apply when determining when to try to send an event again. - * Defaults to {@link MatrixScheduler.RETRY_BACKOFF_RATELIMIT}. - * @param queueAlgorithm - Optional. The queuing - * algorithm to apply when determining which events should be sent before the - * given event. Defaults to {@link MatrixScheduler.QUEUE_MESSAGES}. - */ - constructor( - /** - * The retry algorithm to apply when retrying events. To stop retrying, return - * `-1`. If this event was part of a queue, it will be removed from - * the queue. - * @param event - The event being retried. - * @param attempts - The number of failed attempts. This will always be \>= 1. - * @param err - The most recent error message received when trying - * to send this event. - * @returns The number of milliseconds to wait before trying again. If - * this is 0, the request will be immediately retried. If this is - * `-1`, the event will be marked as - * {@link EventStatus.NOT_SENT} and will not be retried. - */ - retryAlgorithm = MatrixScheduler.RETRY_BACKOFF_RATELIMIT, - /** - * The queuing algorithm to apply to events. This function must be idempotent as - * it may be called multiple times with the same event. All queues created are - * serviced in a FIFO manner. To send the event ASAP, return `null` - * which will not put this event in a queue. Events that fail to send that form - * part of a queue will be removed from the queue and the next event in the - * queue will be sent. - * @param event - The event to be sent. - * @returns The name of the queue to put the event into. If a queue with - * this name does not exist, it will be created. If this is `null`, - * the event is not put into a queue and will be sent concurrently. - */ - queueAlgorithm = MatrixScheduler.QUEUE_MESSAGES) { - this.retryAlgorithm = retryAlgorithm; - this.queueAlgorithm = queueAlgorithm; - (0, _defineProperty2.default)(this, "queues", {}); - (0, _defineProperty2.default)(this, "activeQueues", []); - (0, _defineProperty2.default)(this, "procFn", null); - (0, _defineProperty2.default)(this, "processQueue", queueName => { - // get head of queue - const obj = this.peekNextEvent(queueName); - if (!obj) { - this.disableQueue(queueName); - return; - } - debuglog("Queue '%s' has %s pending events", queueName, this.queues[queueName].length); - // fire the process function and if it resolves, resolve the deferred. Else - // invoke the retry algorithm. - - // First wait for a resolved promise, so the resolve handlers for - // the deferred of the previously sent event can run. - // This way enqueued relations/redactions to enqueued events can receive - // the remove id of their target before being sent. - Promise.resolve().then(() => { - return this.procFn(obj.event); - }).then(res => { - // remove this from the queue - this.removeNextEvent(queueName); - debuglog("Queue '%s' sent event %s", queueName, obj.event.getId()); - obj.defer.resolve(res); - // keep processing - this.processQueue(queueName); - }, err => { - obj.attempts += 1; - // ask the retry algorithm when/if we should try again - const waitTimeMs = this.retryAlgorithm(obj.event, obj.attempts, err); - debuglog("retry(%s) err=%s event_id=%s waitTime=%s", obj.attempts, err, obj.event.getId(), waitTimeMs); - if (waitTimeMs === -1) { - // give up (you quitter!) - debuglog("Queue '%s' giving up on event %s", queueName, obj.event.getId()); - // remove this from the queue - this.clearQueue(queueName, err); - } else { - setTimeout(this.processQueue, waitTimeMs, queueName); - } - }); - }); - } - - /** - * Retrieve a queue based on an event. The event provided does not need to be in - * the queue. - * @param event - An event to get the queue for. - * @returns A shallow copy of events in the queue or null. - * Modifying this array will not modify the list itself. Modifying events in - * this array will modify the underlying event in the queue. - * @see MatrixScheduler.removeEventFromQueue To remove an event from the queue. - */ - getQueueForEvent(event) { - const name = this.queueAlgorithm(event); - if (!name || !this.queues[name]) { - return null; - } - return this.queues[name].map(function (obj) { - return obj.event; - }); - } - - /** - * Remove this event from the queue. The event is equal to another event if they - * have the same ID returned from event.getId(). - * @param event - The event to remove. - * @returns True if this event was removed. - */ - removeEventFromQueue(event) { - const name = this.queueAlgorithm(event); - if (!name || !this.queues[name]) { - return false; - } - let removed = false; - utils.removeElement(this.queues[name], element => { - if (element.event.getId() === event.getId()) { - // XXX we should probably reject the promise? - // https://github.com/matrix-org/matrix-js-sdk/issues/496 - removed = true; - return true; - } - return false; - }); - return removed; - } - - /** - * Set the process function. Required for events in the queue to be processed. - * If set after events have been added to the queue, this will immediately start - * processing them. - * @param fn - The function that can process events - * in the queue. - */ - setProcessFunction(fn) { - this.procFn = fn; - this.startProcessingQueues(); - } - - /** - * Queue an event if it is required and start processing queues. - * @param event - The event that may be queued. - * @returns A promise if the event was queued, which will be - * resolved or rejected in due time, else null. - */ - queueEvent(event) { - const queueName = this.queueAlgorithm(event); - if (!queueName) { - return null; - } - // add the event to the queue and make a deferred for it. - if (!this.queues[queueName]) { - this.queues[queueName] = []; - } - const defer = utils.defer(); - this.queues[queueName].push({ - event: event, - defer: defer, - attempts: 0 - }); - debuglog("Queue algorithm dumped event %s into queue '%s'", event.getId(), queueName); - this.startProcessingQueues(); - return defer.promise; - } - startProcessingQueues() { - if (!this.procFn) return; - // for each inactive queue with events in them - Object.keys(this.queues).filter(queueName => { - return this.activeQueues.indexOf(queueName) === -1 && this.queues[queueName].length > 0; - }).forEach(queueName => { - // mark the queue as active - this.activeQueues.push(queueName); - // begin processing the head of the queue - debuglog("Spinning up queue: '%s'", queueName); - this.processQueue(queueName); - }); - } - disableQueue(queueName) { - // queue is empty. Mark as inactive and stop recursing. - const index = this.activeQueues.indexOf(queueName); - if (index >= 0) { - this.activeQueues.splice(index, 1); - } - debuglog("Stopping queue '%s' as it is now empty", queueName); - } - clearQueue(queueName, err) { - debuglog("clearing queue '%s'", queueName); - let obj; - while (obj = this.removeNextEvent(queueName)) { - obj.defer.reject(err); - } - this.disableQueue(queueName); - } - peekNextEvent(queueName) { - const queue = this.queues[queueName]; - if (!Array.isArray(queue)) { - return undefined; - } - return queue[0]; - } - removeNextEvent(queueName) { - const queue = this.queues[queueName]; - if (!Array.isArray(queue)) { - return undefined; - } - return queue.shift(); - } -} - -/* istanbul ignore next */ -exports.MatrixScheduler = MatrixScheduler; -function debuglog(...args) { - if (DEBUG) { - _logger.logger.log(...args); - } -} -//# sourceMappingURL=scheduler.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js.map deleted file mode 100644 index 81107e3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/scheduler.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"scheduler.js","names":["utils","_interopRequireWildcard","require","_logger","_event","_httpApi","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","DEBUG","MatrixScheduler","RETRY_BACKOFF_RATELIMIT","event","attempts","err","httpStatus","ConnectionError","name","waitTime","data","retry_after_ms","Math","pow","QUEUE_MESSAGES","getType","EventType","RoomMessage","hasAssociation","constructor","retryAlgorithm","queueAlgorithm","_defineProperty2","queueName","peekNextEvent","disableQueue","debuglog","queues","length","Promise","resolve","then","procFn","res","removeNextEvent","getId","defer","processQueue","waitTimeMs","clearQueue","setTimeout","getQueueForEvent","map","removeEventFromQueue","removed","removeElement","element","setProcessFunction","fn","startProcessingQueues","queueEvent","push","promise","keys","filter","activeQueues","indexOf","forEach","index","splice","reject","queue","Array","isArray","undefined","shift","exports","args","logger","log"],"sources":["../src/scheduler.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module which manages queuing, scheduling and retrying\n * of requests.\n */\nimport * as utils from \"./utils\";\nimport { logger } from \"./logger\";\nimport { MatrixEvent } from \"./models/event\";\nimport { EventType } from \"./@types/event\";\nimport { IDeferred } from \"./utils\";\nimport { ConnectionError, MatrixError } from \"./http-api\";\nimport { ISendEventResponse } from \"./@types/requests\";\n\nconst DEBUG = false; // set true to enable console logging.\n\ninterface IQueueEntry {\n event: MatrixEvent;\n defer: IDeferred;\n attempts: number;\n}\n\n/**\n * The function to invoke to process (send) events in the queue.\n * @param event - The event to send.\n * @returns Resolved/rejected depending on the outcome of the request.\n */\ntype ProcessFunction = (event: MatrixEvent) => Promise;\n\n// eslint-disable-next-line camelcase\nexport class MatrixScheduler {\n /**\n * Retries events up to 4 times using exponential backoff. This produces wait\n * times of 2, 4, 8, and 16 seconds (30s total) after which we give up. If the\n * failure was due to a rate limited request, the time specified in the error is\n * waited before being retried.\n * @param attempts - Number of attempts that have been made, including the one that just failed (ie. starting at 1)\n * @see retryAlgorithm\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n public static RETRY_BACKOFF_RATELIMIT(event: MatrixEvent | null, attempts: number, err: MatrixError): number {\n if (err.httpStatus === 400 || err.httpStatus === 403 || err.httpStatus === 401) {\n // client error; no amount of retrying with save you now.\n return -1;\n }\n if (err instanceof ConnectionError) {\n return -1;\n }\n\n // if event that we are trying to send is too large in any way then retrying won't help\n if (err.name === \"M_TOO_LARGE\") {\n return -1;\n }\n\n if (err.name === \"M_LIMIT_EXCEEDED\") {\n const waitTime = err.data.retry_after_ms;\n if (waitTime > 0) {\n return waitTime;\n }\n }\n if (attempts > 4) {\n return -1; // give up\n }\n return 1000 * Math.pow(2, attempts);\n }\n\n /**\n * Queues `m.room.message` events and lets other events continue\n * concurrently.\n * @see queueAlgorithm\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n public static QUEUE_MESSAGES(event: MatrixEvent): string | null {\n // enqueue messages or events that associate with another event (redactions and relations)\n if (event.getType() === EventType.RoomMessage || event.hasAssociation()) {\n // put these events in the 'message' queue.\n return \"message\";\n }\n // allow all other events continue concurrently.\n return null;\n }\n\n // queueName: [{\n // event: MatrixEvent, // event to send\n // defer: Deferred, // defer to resolve/reject at the END of the retries\n // attempts: Number // number of times we've called processFn\n // }, ...]\n private readonly queues: Record[]> = {};\n private activeQueues: string[] = [];\n private procFn: ProcessFunction | null = null;\n\n /**\n * Construct a scheduler for Matrix. Requires\n * {@link MatrixScheduler#setProcessFunction} to be provided\n * with a way of processing events.\n * @param retryAlgorithm - Optional. The retry\n * algorithm to apply when determining when to try to send an event again.\n * Defaults to {@link MatrixScheduler.RETRY_BACKOFF_RATELIMIT}.\n * @param queueAlgorithm - Optional. The queuing\n * algorithm to apply when determining which events should be sent before the\n * given event. Defaults to {@link MatrixScheduler.QUEUE_MESSAGES}.\n */\n public constructor(\n /**\n * The retry algorithm to apply when retrying events. To stop retrying, return\n * `-1`. If this event was part of a queue, it will be removed from\n * the queue.\n * @param event - The event being retried.\n * @param attempts - The number of failed attempts. This will always be \\>= 1.\n * @param err - The most recent error message received when trying\n * to send this event.\n * @returns The number of milliseconds to wait before trying again. If\n * this is 0, the request will be immediately retried. If this is\n * `-1`, the event will be marked as\n * {@link EventStatus.NOT_SENT} and will not be retried.\n */\n public readonly retryAlgorithm = MatrixScheduler.RETRY_BACKOFF_RATELIMIT,\n /**\n * The queuing algorithm to apply to events. This function must be idempotent as\n * it may be called multiple times with the same event. All queues created are\n * serviced in a FIFO manner. To send the event ASAP, return `null`\n * which will not put this event in a queue. Events that fail to send that form\n * part of a queue will be removed from the queue and the next event in the\n * queue will be sent.\n * @param event - The event to be sent.\n * @returns The name of the queue to put the event into. If a queue with\n * this name does not exist, it will be created. If this is `null`,\n * the event is not put into a queue and will be sent concurrently.\n */\n public readonly queueAlgorithm = MatrixScheduler.QUEUE_MESSAGES,\n ) {}\n\n /**\n * Retrieve a queue based on an event. The event provided does not need to be in\n * the queue.\n * @param event - An event to get the queue for.\n * @returns A shallow copy of events in the queue or null.\n * Modifying this array will not modify the list itself. Modifying events in\n * this array will modify the underlying event in the queue.\n * @see MatrixScheduler.removeEventFromQueue To remove an event from the queue.\n */\n public getQueueForEvent(event: MatrixEvent): MatrixEvent[] | null {\n const name = this.queueAlgorithm(event);\n if (!name || !this.queues[name]) {\n return null;\n }\n return this.queues[name].map(function (obj) {\n return obj.event;\n });\n }\n\n /**\n * Remove this event from the queue. The event is equal to another event if they\n * have the same ID returned from event.getId().\n * @param event - The event to remove.\n * @returns True if this event was removed.\n */\n public removeEventFromQueue(event: MatrixEvent): boolean {\n const name = this.queueAlgorithm(event);\n if (!name || !this.queues[name]) {\n return false;\n }\n let removed = false;\n utils.removeElement(this.queues[name], (element) => {\n if (element.event.getId() === event.getId()) {\n // XXX we should probably reject the promise?\n // https://github.com/matrix-org/matrix-js-sdk/issues/496\n removed = true;\n return true;\n }\n return false;\n });\n return removed;\n }\n\n /**\n * Set the process function. Required for events in the queue to be processed.\n * If set after events have been added to the queue, this will immediately start\n * processing them.\n * @param fn - The function that can process events\n * in the queue.\n */\n public setProcessFunction(fn: ProcessFunction): void {\n this.procFn = fn;\n this.startProcessingQueues();\n }\n\n /**\n * Queue an event if it is required and start processing queues.\n * @param event - The event that may be queued.\n * @returns A promise if the event was queued, which will be\n * resolved or rejected in due time, else null.\n */\n public queueEvent(event: MatrixEvent): Promise | null {\n const queueName = this.queueAlgorithm(event);\n if (!queueName) {\n return null;\n }\n // add the event to the queue and make a deferred for it.\n if (!this.queues[queueName]) {\n this.queues[queueName] = [];\n }\n const defer = utils.defer();\n this.queues[queueName].push({\n event: event,\n defer: defer,\n attempts: 0,\n });\n debuglog(\"Queue algorithm dumped event %s into queue '%s'\", event.getId(), queueName);\n this.startProcessingQueues();\n return defer.promise;\n }\n\n private startProcessingQueues(): void {\n if (!this.procFn) return;\n // for each inactive queue with events in them\n Object.keys(this.queues)\n .filter((queueName) => {\n return this.activeQueues.indexOf(queueName) === -1 && this.queues[queueName].length > 0;\n })\n .forEach((queueName) => {\n // mark the queue as active\n this.activeQueues.push(queueName);\n // begin processing the head of the queue\n debuglog(\"Spinning up queue: '%s'\", queueName);\n this.processQueue(queueName);\n });\n }\n\n private processQueue = (queueName: string): void => {\n // get head of queue\n const obj = this.peekNextEvent(queueName);\n if (!obj) {\n this.disableQueue(queueName);\n return;\n }\n debuglog(\"Queue '%s' has %s pending events\", queueName, this.queues[queueName].length);\n // fire the process function and if it resolves, resolve the deferred. Else\n // invoke the retry algorithm.\n\n // First wait for a resolved promise, so the resolve handlers for\n // the deferred of the previously sent event can run.\n // This way enqueued relations/redactions to enqueued events can receive\n // the remove id of their target before being sent.\n Promise.resolve()\n .then(() => {\n return this.procFn!(obj.event);\n })\n .then(\n (res) => {\n // remove this from the queue\n this.removeNextEvent(queueName);\n debuglog(\"Queue '%s' sent event %s\", queueName, obj.event.getId());\n obj.defer.resolve(res);\n // keep processing\n this.processQueue(queueName);\n },\n (err) => {\n obj.attempts += 1;\n // ask the retry algorithm when/if we should try again\n const waitTimeMs = this.retryAlgorithm(obj.event, obj.attempts, err);\n debuglog(\n \"retry(%s) err=%s event_id=%s waitTime=%s\",\n obj.attempts,\n err,\n obj.event.getId(),\n waitTimeMs,\n );\n if (waitTimeMs === -1) {\n // give up (you quitter!)\n debuglog(\"Queue '%s' giving up on event %s\", queueName, obj.event.getId());\n // remove this from the queue\n this.clearQueue(queueName, err);\n } else {\n setTimeout(this.processQueue, waitTimeMs, queueName);\n }\n },\n );\n };\n\n private disableQueue(queueName: string): void {\n // queue is empty. Mark as inactive and stop recursing.\n const index = this.activeQueues.indexOf(queueName);\n if (index >= 0) {\n this.activeQueues.splice(index, 1);\n }\n debuglog(\"Stopping queue '%s' as it is now empty\", queueName);\n }\n\n private clearQueue(queueName: string, err: unknown): void {\n debuglog(\"clearing queue '%s'\", queueName);\n let obj: IQueueEntry | undefined;\n while ((obj = this.removeNextEvent(queueName))) {\n obj.defer.reject(err);\n }\n this.disableQueue(queueName);\n }\n\n private peekNextEvent(queueName: string): IQueueEntry | undefined {\n const queue = this.queues[queueName];\n if (!Array.isArray(queue)) {\n return undefined;\n }\n return queue[0];\n }\n\n private removeNextEvent(queueName: string): IQueueEntry | undefined {\n const queue = this.queues[queueName];\n if (!Array.isArray(queue)) {\n return undefined;\n }\n return queue.shift();\n }\n}\n\n/* istanbul ignore next */\nfunction debuglog(...args: any[]): void {\n if (DEBUG) {\n logger.log(...args);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts deleted file mode 100644 index 9f6af3e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts +++ /dev/null @@ -1,55 +0,0 @@ -/** - * Implementation of server-side secret storage - * - * @see https://spec.matrix.org/v1.6/client-server-api/#storage - */ -/** - * Common base interface for Secret Storage Keys. - * - * The common properties for all encryption keys used in server-side secret storage. - * - * @see https://spec.matrix.org/v1.6/client-server-api/#key-storage - */ -export interface SecretStorageKeyDescriptionCommon { - /** A human-readable name for this key. */ - name: string; - /** The encryption algorithm used with this key. */ - algorithm: string; - /** Information for deriving this key from a passphrase. */ - passphrase: PassphraseInfo; -} -/** - * Properties for a SSSS key using the `m.secret_storage.v1.aes-hmac-sha2` algorithm. - * - * Corresponds to `AesHmacSha2KeyDescription` in the specification. - * - * @see https://spec.matrix.org/v1.6/client-server-api/#msecret_storagev1aes-hmac-sha2 - */ -export interface SecretStorageKeyDescriptionAesV1 extends SecretStorageKeyDescriptionCommon { - /** The 16-byte AES initialization vector, encoded as base64. */ - iv: string; - /** The MAC of the result of encrypting 32 bytes of 0, encoded as base64. */ - mac: string; -} -/** - * Union type for secret storage keys. - * - * For now, this is only {@link SecretStorageKeyDescriptionAesV1}, but other interfaces may be added in future. - */ -export type SecretStorageKeyDescription = SecretStorageKeyDescriptionAesV1; -/** - * Information on how to generate the key from a passphrase. - * - * @see https://spec.matrix.org/v1.6/client-server-api/#deriving-keys-from-passphrases - */ -export interface PassphraseInfo { - /** The algorithm to be used to derive the key. */ - algorithm: "m.pbkdf2"; - /** The number of PBKDF2 iterations to use. */ - iterations: number; - /** The salt to be used for PBKDF2. */ - salt: string; - /** The number of bits to generate. Defaults to 256. */ - bits?: number; -} -//# sourceMappingURL=secret-storage.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts.map deleted file mode 100644 index 9397c46..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"secret-storage.d.ts","sourceRoot":"","sources":["../src/secret-storage.ts"],"names":[],"mappings":"AAgBA;;;;GAIG;AAEH;;;;;;GAMG;AACH,MAAM,WAAW,iCAAiC;IAC9C,0CAA0C;IAE1C,IAAI,EAAE,MAAM,CAAC;IAEb,mDAAmD;IACnD,SAAS,EAAE,MAAM,CAAC;IAElB,2DAA2D;IAE3D,UAAU,EAAE,cAAc,CAAC;CAC9B;AAED;;;;;;GAMG;AACH,MAAM,WAAW,gCAAiC,SAAQ,iCAAiC;IAOvF,gEAAgE;IAChE,EAAE,EAAE,MAAM,CAAC;IAEX,4EAA4E;IAC5E,GAAG,EAAE,MAAM,CAAC;CACf;AAED;;;;GAIG;AACH,MAAM,MAAM,2BAA2B,GAAG,gCAAgC,CAAC;AAE3E;;;;GAIG;AACH,MAAM,WAAW,cAAc;IAC3B,kDAAkD;IAClD,SAAS,EAAE,UAAU,CAAC;IAEtB,8CAA8C;IAC9C,UAAU,EAAE,MAAM,CAAC;IAEnB,sCAAsC;IACtC,IAAI,EAAE,MAAM,CAAC;IAEb,uDAAuD;IACvD,IAAI,CAAC,EAAE,MAAM,CAAC;CACjB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js deleted file mode 100644 index a9f64ec..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=secret-storage.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js.map deleted file mode 100644 index cd03b3f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/secret-storage.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"secret-storage.js","names":[],"sources":["../src/secret-storage.ts"],"sourcesContent":["/*\nCopyright 2021-2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * Implementation of server-side secret storage\n *\n * @see https://spec.matrix.org/v1.6/client-server-api/#storage\n */\n\n/**\n * Common base interface for Secret Storage Keys.\n *\n * The common properties for all encryption keys used in server-side secret storage.\n *\n * @see https://spec.matrix.org/v1.6/client-server-api/#key-storage\n */\nexport interface SecretStorageKeyDescriptionCommon {\n /** A human-readable name for this key. */\n // XXX: according to the spec, this is optional\n name: string;\n\n /** The encryption algorithm used with this key. */\n algorithm: string;\n\n /** Information for deriving this key from a passphrase. */\n // XXX: according to the spec, this is optional\n passphrase: PassphraseInfo;\n}\n\n/**\n * Properties for a SSSS key using the `m.secret_storage.v1.aes-hmac-sha2` algorithm.\n *\n * Corresponds to `AesHmacSha2KeyDescription` in the specification.\n *\n * @see https://spec.matrix.org/v1.6/client-server-api/#msecret_storagev1aes-hmac-sha2\n */\nexport interface SecretStorageKeyDescriptionAesV1 extends SecretStorageKeyDescriptionCommon {\n // XXX: strictly speaking, we should be able to enforce the algorithm here. But\n // this interface ends up being incorrectly used where other algorithms are in use (notably\n // in device-dehydration support), and unpicking that is too much like hard work\n // at the moment.\n // algorithm: \"m.secret_storage.v1.aes-hmac-sha2\";\n\n /** The 16-byte AES initialization vector, encoded as base64. */\n iv: string;\n\n /** The MAC of the result of encrypting 32 bytes of 0, encoded as base64. */\n mac: string;\n}\n\n/**\n * Union type for secret storage keys.\n *\n * For now, this is only {@link SecretStorageKeyDescriptionAesV1}, but other interfaces may be added in future.\n */\nexport type SecretStorageKeyDescription = SecretStorageKeyDescriptionAesV1;\n\n/**\n * Information on how to generate the key from a passphrase.\n *\n * @see https://spec.matrix.org/v1.6/client-server-api/#deriving-keys-from-passphrases\n */\nexport interface PassphraseInfo {\n /** The algorithm to be used to derive the key. */\n algorithm: \"m.pbkdf2\";\n\n /** The number of PBKDF2 iterations to use. */\n iterations: number;\n\n /** The salt to be used for PBKDF2. */\n salt: string;\n\n /** The number of bits to generate. Defaults to 256. */\n bits?: number;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts deleted file mode 100644 index 22de390..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -export declare enum SERVICE_TYPES { - IS = "SERVICE_TYPE_IS", - IM = "SERVICE_TYPE_IM" -} -//# sourceMappingURL=service-types.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts.map deleted file mode 100644 index 98ac0a7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"service-types.d.ts","sourceRoot":"","sources":["../src/service-types.ts"],"names":[],"mappings":"AAgBA,oBAAY,aAAa;IACrB,EAAE,oBAAoB;IACtB,EAAE,oBAAoB;CACzB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js deleted file mode 100644 index 6e52ba7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SERVICE_TYPES = void 0; -/* -Copyright 2019 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let SERVICE_TYPES; // An integration manager -exports.SERVICE_TYPES = SERVICE_TYPES; -(function (SERVICE_TYPES) { - SERVICE_TYPES["IS"] = "SERVICE_TYPE_IS"; - SERVICE_TYPES["IM"] = "SERVICE_TYPE_IM"; -})(SERVICE_TYPES || (exports.SERVICE_TYPES = SERVICE_TYPES = {})); -//# sourceMappingURL=service-types.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js.map deleted file mode 100644 index e59c274..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/service-types.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"service-types.js","names":["SERVICE_TYPES","exports"],"sources":["../src/service-types.ts"],"sourcesContent":["/*\nCopyright 2019 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport enum SERVICE_TYPES {\n IS = \"SERVICE_TYPE_IS\", // An identity server\n IM = \"SERVICE_TYPE_IM\", // An integration manager\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAgBYA,aAAa,EAEG;AAAAC,OAAA,CAAAD,aAAA,GAAAA,aAAA;AAAA,WAFhBA,aAAa;EAAbA,aAAa;EAAbA,aAAa;AAAA,GAAbA,aAAa,KAAAC,OAAA,CAAAD,aAAA,GAAbA,aAAa"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts deleted file mode 100644 index 78a7b02..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts +++ /dev/null @@ -1,102 +0,0 @@ -import { Room } from "./models/room"; -import { IStoredClientOpts, MatrixClient } from "./client"; -import { ISyncStateData, SyncState, SyncApiOptions } from "./sync"; -import { MatrixEvent } from "./models/event"; -import { SlidingSync } from "./sliding-sync"; -/** - * A copy of SyncApi such that it can be used as a drop-in replacement for sync v2. For the actual - * sliding sync API, see sliding-sync.ts or the class SlidingSync. - */ -export declare class SlidingSyncSdk { - private readonly slidingSync; - private readonly client; - private readonly opts; - private readonly syncOpts; - private syncState; - private syncStateData?; - private lastPos; - private failCount; - private notifEvents; - constructor(slidingSync: SlidingSync, client: MatrixClient, opts?: IStoredClientOpts, syncOpts?: SyncApiOptions); - private onRoomData; - private onLifecycle; - /** - * Sync rooms the user has left. - * @returns Resolved when they've been added to the store. - */ - syncLeftRooms(): Promise; - /** - * Peek into a room. This will result in the room in question being synced so it - * is accessible via getRooms(). Live updates for the room will be provided. - * @param roomId - The room ID to peek into. - * @returns A promise which resolves once the room has been added to the - * store. - */ - peek(_roomId: string): Promise; - /** - * Stop polling for updates in the peeked room. NOPs if there is no room being - * peeked. - */ - stopPeeking(): void; - /** - * Returns the current state of this sync object - * @see MatrixClient#event:"sync" - */ - getSyncState(): SyncState | null; - /** - * Returns the additional data object associated with - * the current sync state, or null if there is no - * such data. - * Sync errors, if available, are put in the 'error' key of - * this object. - */ - getSyncStateData(): ISyncStateData | null; - createRoom(roomId: string): Room; - private registerStateListeners; - private shouldAbortSync; - private processRoomData; - /** - * Injects events into a room's model. - * @param stateEventList - A list of state events. This is the state - * at the *START* of the timeline list if it is supplied. - * @param timelineEventList - A list of timeline events. Lower index - * is earlier in time. Higher index is later. - * @param numLive - the number of events in timelineEventList which just happened, - * supplied from the server. - */ - injectRoomEvents(room: Room, stateEventList: MatrixEvent[], timelineEventList?: MatrixEvent[], numLive?: number): void; - private resolveInvites; - retryImmediately(): boolean; - /** - * Main entry point. Blocks until stop() is called. - */ - sync(): Promise; - /** - * Stops the sync object from syncing. - */ - stop(): void; - /** - * Sets the sync state and emits an event to say so - * @param newState - The new state string - * @param data - Object of additional data to emit in the event - */ - private updateSyncState; - /** - * Takes a list of timelineEvents and adds and adds to notifEvents - * as appropriate. - * This must be called after the room the events belong to has been stored. - * - * @param timelineEventList - A list of timeline events. Lower index - * is earlier in time. Higher index is later. - */ - private addNotifications; - /** - * Purge any events in the notifEvents array. Used after a /sync has been complete. - * This should not be called at a per-room scope (e.g in onRoomData) because otherwise the ordering - * will be messed up e.g room A gets a bing, room B gets a newer bing, but both in the same /sync - * response. If we purge at a per-room scope then we could process room B before room A leading to - * room B appearing earlier in the notifications timeline, even though it has the higher origin_server_ts. - */ - private purgeNotifications; -} -//# sourceMappingURL=sliding-sync-sdk.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts.map deleted file mode 100644 index 728df2f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sliding-sync-sdk.d.ts","sourceRoot":"","sources":["../src/sliding-sync-sdk.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAyB,IAAI,EAAa,MAAM,eAAe,CAAC;AAIvE,OAAO,EAAe,iBAAiB,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxE,OAAO,EACH,cAAc,EACd,SAAS,EAET,cAAc,EAGjB,MAAM,QAAQ,CAAC;AAChB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAI7C,OAAO,EAKH,WAAW,EAGd,MAAM,gBAAgB,CAAC;AAoTxB;;;GAGG;AACH,qBAAa,cAAc;IAUnB,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAV3B,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAoB;IACzC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAiB;IAC1C,OAAO,CAAC,SAAS,CAA0B;IAC3C,OAAO,CAAC,aAAa,CAAC,CAAiB;IACvC,OAAO,CAAC,OAAO,CAAuB;IACtC,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,WAAW,CAAqB;gBAGnB,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,YAAY,EACrC,IAAI,CAAC,EAAE,iBAAiB,EACxB,QAAQ,CAAC,EAAE,cAAc;IAyB7B,OAAO,CAAC,UAAU;IAYlB,OAAO,CAAC,WAAW;IAgDnB;;;OAGG;IACU,aAAa,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IAI7C;;;;;;OAMG;IACU,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIjD;;;OAGG;IACI,WAAW,IAAI,IAAI;IAI1B;;;OAGG;IACI,YAAY,IAAI,SAAS,GAAG,IAAI;IAIvC;;;;;;OAMG;IACI,gBAAgB,IAAI,cAAc,GAAG,IAAI;IAMzC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAwBvC,OAAO,CAAC,sBAAsB;IA8B9B,OAAO,CAAC,eAAe;YAWT,eAAe;IA6L7B;;;;;;;;OAQG;IACI,gBAAgB,CACnB,IAAI,EAAE,IAAI,EACV,cAAc,EAAE,WAAW,EAAE,EAC7B,iBAAiB,CAAC,EAAE,WAAW,EAAE,EACjC,OAAO,CAAC,EAAE,MAAM,GACjB,IAAI;IA0EP,OAAO,CAAC,cAAc;IA2Cf,gBAAgB,IAAI,OAAO;IAIlC;;OAEG;IACU,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAwBlC;;OAEG;IACI,IAAI,IAAI,IAAI;IAKnB;;;;OAIG;IACH,OAAO,CAAC,eAAe;IAOvB;;;;;;;OAOG;IACH,OAAO,CAAC,gBAAgB;IAaxB;;;;;;OAMG;IACH,OAAO,CAAC,kBAAkB;CAS7B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js deleted file mode 100644 index 715187e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js +++ /dev/null @@ -1,881 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SlidingSyncSdk = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _room = require("./models/room"); -var _logger = require("./logger"); -var utils = _interopRequireWildcard(require("./utils")); -var _eventTimeline = require("./models/event-timeline"); -var _client = require("./client"); -var _sync = require("./sync"); -var _httpApi = require("./http-api"); -var _slidingSync = require("./sliding-sync"); -var _event = require("./@types/event"); -var _roomState = require("./models/room-state"); -var _roomMember = require("./models/room-member"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// Number of consecutive failed syncs that will lead to a syncState of ERROR as opposed -// to RECONNECTING. This is needed to inform the client of server issues when the -// keepAlive is successful but the server /sync fails. -const FAILED_SYNC_ERROR_THRESHOLD = 3; -class ExtensionE2EE { - constructor(crypto) { - this.crypto = crypto; - } - name() { - return "e2ee"; - } - when() { - return _slidingSync.ExtensionState.PreProcess; - } - onRequest(isInitial) { - if (!isInitial) { - return undefined; - } - return { - enabled: true // this is sticky so only send it on the initial request - }; - } - - async onResponse(data) { - // Handle device list updates - if (data["device_lists"]) { - await this.crypto.handleDeviceListChanges({ - oldSyncToken: "yep" // XXX need to do this so the device list changes get processed :( - }, data["device_lists"]); - } - - // Handle one_time_keys_count - if (data["device_one_time_keys_count"]) { - const currentCount = data["device_one_time_keys_count"].signed_curve25519 || 0; - this.crypto.updateOneTimeKeyCount(currentCount); - } - if (data["device_unused_fallback_key_types"] || data["org.matrix.msc2732.device_unused_fallback_key_types"]) { - // The presence of device_unused_fallback_key_types indicates that the - // server supports fallback keys. If there's no unused - // signed_curve25519 fallback key we need a new one. - const unusedFallbackKeys = data["device_unused_fallback_key_types"] || data["org.matrix.msc2732.device_unused_fallback_key_types"]; - this.crypto.setNeedsNewFallback(Array.isArray(unusedFallbackKeys) && !unusedFallbackKeys.includes("signed_curve25519")); - } - this.crypto.onSyncCompleted({}); - } -} -class ExtensionToDevice { - constructor(client, cryptoCallbacks) { - this.client = client; - this.cryptoCallbacks = cryptoCallbacks; - (0, _defineProperty2.default)(this, "nextBatch", null); - } - name() { - return "to_device"; - } - when() { - return _slidingSync.ExtensionState.PreProcess; - } - onRequest(isInitial) { - const extReq = { - since: this.nextBatch !== null ? this.nextBatch : undefined - }; - if (isInitial) { - extReq["limit"] = 100; - extReq["enabled"] = true; - } - return extReq; - } - async onResponse(data) { - const cancelledKeyVerificationTxns = []; - let events = data["events"] || []; - if (events.length > 0 && this.cryptoCallbacks) { - events = await this.cryptoCallbacks.preprocessToDeviceMessages(events); - } - events.map(this.client.getEventMapper()).map(toDeviceEvent => { - // map is a cheap inline forEach - // We want to flag m.key.verification.start events as cancelled - // if there's an accompanying m.key.verification.cancel event, so - // we pull out the transaction IDs from the cancellation events - // so we can flag the verification events as cancelled in the loop - // below. - if (toDeviceEvent.getType() === "m.key.verification.cancel") { - const txnId = toDeviceEvent.getContent()["transaction_id"]; - if (txnId) { - cancelledKeyVerificationTxns.push(txnId); - } - } - - // as mentioned above, .map is a cheap inline forEach, so return - // the unmodified event. - return toDeviceEvent; - }).forEach(toDeviceEvent => { - const content = toDeviceEvent.getContent(); - if (toDeviceEvent.getType() == "m.room.message" && content.msgtype == "m.bad.encrypted") { - // the mapper already logged a warning. - _logger.logger.log("Ignoring undecryptable to-device event from " + toDeviceEvent.getSender()); - return; - } - if (toDeviceEvent.getType() === "m.key.verification.start" || toDeviceEvent.getType() === "m.key.verification.request") { - const txnId = content["transaction_id"]; - if (cancelledKeyVerificationTxns.includes(txnId)) { - toDeviceEvent.flagCancelled(); - } - } - this.client.emit(_client.ClientEvent.ToDeviceEvent, toDeviceEvent); - }); - this.nextBatch = data.next_batch; - } -} -class ExtensionAccountData { - constructor(client) { - this.client = client; - } - name() { - return "account_data"; - } - when() { - return _slidingSync.ExtensionState.PostProcess; - } - onRequest(isInitial) { - if (!isInitial) { - return undefined; - } - return { - enabled: true - }; - } - onResponse(data) { - if (data.global && data.global.length > 0) { - this.processGlobalAccountData(data.global); - } - for (const roomId in data.rooms) { - const accountDataEvents = mapEvents(this.client, roomId, data.rooms[roomId]); - const room = this.client.getRoom(roomId); - if (!room) { - _logger.logger.warn("got account data for room but room doesn't exist on client:", roomId); - continue; - } - room.addAccountData(accountDataEvents); - accountDataEvents.forEach(e => { - this.client.emit(_client.ClientEvent.Event, e); - }); - } - } - processGlobalAccountData(globalAccountData) { - const events = mapEvents(this.client, undefined, globalAccountData); - const prevEventsMap = events.reduce((m, c) => { - m[c.getType()] = this.client.store.getAccountData(c.getType()); - return m; - }, {}); - this.client.store.storeAccountDataEvents(events); - events.forEach(accountDataEvent => { - // Honour push rules that come down the sync stream but also - // honour push rules that were previously cached. Base rules - // will be updated when we receive push rules via getPushRules - // (see sync) before syncing over the network. - if (accountDataEvent.getType() === _event.EventType.PushRules) { - const rules = accountDataEvent.getContent(); - this.client.setPushRules(rules); - } - const prevEvent = prevEventsMap[accountDataEvent.getType()]; - this.client.emit(_client.ClientEvent.AccountData, accountDataEvent, prevEvent); - return accountDataEvent; - }); - } -} -class ExtensionTyping { - constructor(client) { - this.client = client; - } - name() { - return "typing"; - } - when() { - return _slidingSync.ExtensionState.PostProcess; - } - onRequest(isInitial) { - if (!isInitial) { - return undefined; // don't send a JSON object for subsequent requests, we don't need to. - } - - return { - enabled: true - }; - } - onResponse(data) { - if (!(data !== null && data !== void 0 && data.rooms)) { - return; - } - for (const roomId in data.rooms) { - processEphemeralEvents(this.client, roomId, [data.rooms[roomId]]); - } - } -} -class ExtensionReceipts { - constructor(client) { - this.client = client; - } - name() { - return "receipts"; - } - when() { - return _slidingSync.ExtensionState.PostProcess; - } - onRequest(isInitial) { - if (isInitial) { - return { - enabled: true - }; - } - return undefined; // don't send a JSON object for subsequent requests, we don't need to. - } - - onResponse(data) { - if (!(data !== null && data !== void 0 && data.rooms)) { - return; - } - for (const roomId in data.rooms) { - processEphemeralEvents(this.client, roomId, [data.rooms[roomId]]); - } - } -} - -/** - * A copy of SyncApi such that it can be used as a drop-in replacement for sync v2. For the actual - * sliding sync API, see sliding-sync.ts or the class SlidingSync. - */ -class SlidingSyncSdk { - // accumulator of sync events in the current sync response - - constructor(slidingSync, client, opts, syncOpts) { - this.slidingSync = slidingSync; - this.client = client; - (0, _defineProperty2.default)(this, "opts", void 0); - (0, _defineProperty2.default)(this, "syncOpts", void 0); - (0, _defineProperty2.default)(this, "syncState", null); - (0, _defineProperty2.default)(this, "syncStateData", void 0); - (0, _defineProperty2.default)(this, "lastPos", null); - (0, _defineProperty2.default)(this, "failCount", 0); - (0, _defineProperty2.default)(this, "notifEvents", []); - this.opts = (0, _sync.defaultClientOpts)(opts); - this.syncOpts = (0, _sync.defaultSyncApiOpts)(syncOpts); - if (client.getNotifTimelineSet()) { - client.reEmitter.reEmit(client.getNotifTimelineSet(), [_room.RoomEvent.Timeline, _room.RoomEvent.TimelineReset]); - } - this.slidingSync.on(_slidingSync.SlidingSyncEvent.Lifecycle, this.onLifecycle.bind(this)); - this.slidingSync.on(_slidingSync.SlidingSyncEvent.RoomData, this.onRoomData.bind(this)); - const extensions = [new ExtensionToDevice(this.client, this.syncOpts.cryptoCallbacks), new ExtensionAccountData(this.client), new ExtensionTyping(this.client), new ExtensionReceipts(this.client)]; - if (this.syncOpts.crypto) { - extensions.push(new ExtensionE2EE(this.syncOpts.crypto)); - } - extensions.forEach(ext => { - this.slidingSync.registerExtension(ext); - }); - } - onRoomData(roomId, roomData) { - let room = this.client.store.getRoom(roomId); - if (!room) { - if (!roomData.initial) { - _logger.logger.debug("initial flag not set but no stored room exists for room ", roomId, roomData); - return; - } - room = (0, _sync._createAndReEmitRoom)(this.client, roomId, this.opts); - } - this.processRoomData(this.client, room, roomData); - } - onLifecycle(state, resp, err) { - if (err) { - _logger.logger.debug("onLifecycle", state, err); - } - switch (state) { - case _slidingSync.SlidingSyncState.Complete: - this.purgeNotifications(); - if (!resp) { - break; - } - // Element won't stop showing the initial loading spinner unless we fire SyncState.Prepared - if (!this.lastPos) { - this.updateSyncState(_sync.SyncState.Prepared, { - oldSyncToken: undefined, - nextSyncToken: resp.pos, - catchingUp: false, - fromCache: false - }); - } - // Conversely, Element won't show the room list unless there is at least 1x SyncState.Syncing - // so hence for the very first sync we will fire prepared then immediately syncing. - this.updateSyncState(_sync.SyncState.Syncing, { - oldSyncToken: this.lastPos, - nextSyncToken: resp.pos, - catchingUp: false, - fromCache: false - }); - this.lastPos = resp.pos; - break; - case _slidingSync.SlidingSyncState.RequestFinished: - if (err) { - this.failCount += 1; - this.updateSyncState(this.failCount > FAILED_SYNC_ERROR_THRESHOLD ? _sync.SyncState.Error : _sync.SyncState.Reconnecting, { - error: new _httpApi.MatrixError(err) - }); - if (this.shouldAbortSync(new _httpApi.MatrixError(err))) { - return; // shouldAbortSync actually stops syncing too so we don't need to do anything. - } - } else { - this.failCount = 0; - } - break; - } - } - - /** - * Sync rooms the user has left. - * @returns Resolved when they've been added to the store. - */ - async syncLeftRooms() { - return []; // TODO - } - - /** - * Peek into a room. This will result in the room in question being synced so it - * is accessible via getRooms(). Live updates for the room will be provided. - * @param roomId - The room ID to peek into. - * @returns A promise which resolves once the room has been added to the - * store. - */ - async peek(_roomId) { - return null; // TODO - } - - /** - * Stop polling for updates in the peeked room. NOPs if there is no room being - * peeked. - */ - stopPeeking() { - // TODO - } - - /** - * Returns the current state of this sync object - * @see MatrixClient#event:"sync" - */ - getSyncState() { - return this.syncState; - } - - /** - * Returns the additional data object associated with - * the current sync state, or null if there is no - * such data. - * Sync errors, if available, are put in the 'error' key of - * this object. - */ - getSyncStateData() { - var _this$syncStateData; - return (_this$syncStateData = this.syncStateData) !== null && _this$syncStateData !== void 0 ? _this$syncStateData : null; - } - - // Helper functions which set up JS SDK structs are below and are identical to the sync v2 counterparts - - createRoom(roomId) { - // XXX cargoculted from sync.ts - const { - timelineSupport - } = this.client; - const room = new _room.Room(roomId, this.client, this.client.getUserId(), { - lazyLoadMembers: this.opts.lazyLoadMembers, - pendingEventOrdering: this.opts.pendingEventOrdering, - timelineSupport - }); - this.client.reEmitter.reEmit(room, [_room.RoomEvent.Name, _room.RoomEvent.Redaction, _room.RoomEvent.RedactionCancelled, _room.RoomEvent.Receipt, _room.RoomEvent.Tags, _room.RoomEvent.LocalEchoUpdated, _room.RoomEvent.AccountData, _room.RoomEvent.MyMembership, _room.RoomEvent.Timeline, _room.RoomEvent.TimelineReset]); - this.registerStateListeners(room); - return room; - } - registerStateListeners(room) { - // XXX cargoculted from sync.ts - // we need to also re-emit room state and room member events, so hook it up - // to the client now. We need to add a listener for RoomState.members in - // order to hook them correctly. - this.client.reEmitter.reEmit(room.currentState, [_roomState.RoomStateEvent.Events, _roomState.RoomStateEvent.Members, _roomState.RoomStateEvent.NewMember, _roomState.RoomStateEvent.Update]); - room.currentState.on(_roomState.RoomStateEvent.NewMember, (event, state, member) => { - var _this$client$getUser; - member.user = (_this$client$getUser = this.client.getUser(member.userId)) !== null && _this$client$getUser !== void 0 ? _this$client$getUser : undefined; - this.client.reEmitter.reEmit(member, [_roomMember.RoomMemberEvent.Name, _roomMember.RoomMemberEvent.Typing, _roomMember.RoomMemberEvent.PowerLevel, _roomMember.RoomMemberEvent.Membership]); - }); - } - - /* - private deregisterStateListeners(room: Room): void { // XXX cargoculted from sync.ts - // could do with a better way of achieving this. - room.currentState.removeAllListeners(RoomStateEvent.Events); - room.currentState.removeAllListeners(RoomStateEvent.Members); - room.currentState.removeAllListeners(RoomStateEvent.NewMember); - } */ - - shouldAbortSync(error) { - if (error.errcode === "M_UNKNOWN_TOKEN") { - // The logout already happened, we just need to stop. - _logger.logger.warn("Token no longer valid - assuming logout"); - this.stop(); - this.updateSyncState(_sync.SyncState.Error, { - error - }); - return true; - } - return false; - } - async processRoomData(client, room, roomData) { - roomData = ensureNameEvent(client, room.roomId, roomData); - const stateEvents = mapEvents(this.client, room.roomId, roomData.required_state); - // Prevent events from being decrypted ahead of time - // this helps large account to speed up faster - // room::decryptCriticalEvent is in charge of decrypting all the events - // required for a client to function properly - let timelineEvents = mapEvents(this.client, room.roomId, roomData.timeline, false); - const ephemeralEvents = []; // TODO this.mapSyncEventsFormat(joinObj.ephemeral); - - // TODO: handle threaded / beacon events - - if (roomData.initial) { - // we should not know about any of these timeline entries if this is a genuinely new room. - // If we do, then we've effectively done scrollback (e.g requesting timeline_limit: 1 for - // this room, then timeline_limit: 50). - const knownEvents = new Set(); - room.getLiveTimeline().getEvents().forEach(e => { - knownEvents.add(e.getId()); - }); - // all unknown events BEFORE a known event must be scrollback e.g: - // D E <-- what we know - // A B C D E F <-- what we just received - // means: - // A B C <-- scrollback - // D E <-- dupes - // F <-- new event - // We bucket events based on if we have seen a known event yet. - const oldEvents = []; - const newEvents = []; - let seenKnownEvent = false; - for (let i = timelineEvents.length - 1; i >= 0; i--) { - const recvEvent = timelineEvents[i]; - if (knownEvents.has(recvEvent.getId())) { - seenKnownEvent = true; - continue; // don't include this event, it's a dupe - } - - if (seenKnownEvent) { - // old -> new - oldEvents.push(recvEvent); - } else { - // old -> new - newEvents.unshift(recvEvent); - } - } - timelineEvents = newEvents; - if (oldEvents.length > 0) { - // old events are scrollback, insert them now - room.addEventsToTimeline(oldEvents, true, room.getLiveTimeline(), roomData.prev_batch); - } - } - const encrypted = this.client.isRoomEncrypted(room.roomId); - // we do this first so it's correct when any of the events fire - if (roomData.notification_count != null) { - room.setUnreadNotificationCount(_room.NotificationCountType.Total, roomData.notification_count); - } - if (roomData.highlight_count != null) { - // We track unread notifications ourselves in encrypted rooms, so don't - // bother setting it here. We trust our calculations better than the - // server's for this case, and therefore will assume that our non-zero - // count is accurate. - if (!encrypted || encrypted && room.getUnreadNotificationCount(_room.NotificationCountType.Highlight) <= 0) { - room.setUnreadNotificationCount(_room.NotificationCountType.Highlight, roomData.highlight_count); - } - } - if (Number.isInteger(roomData.invited_count)) { - room.currentState.setInvitedMemberCount(roomData.invited_count); - } - if (Number.isInteger(roomData.joined_count)) { - room.currentState.setJoinedMemberCount(roomData.joined_count); - } - if (roomData.invite_state) { - const inviteStateEvents = mapEvents(this.client, room.roomId, roomData.invite_state); - this.injectRoomEvents(room, inviteStateEvents); - if (roomData.initial) { - room.recalculate(); - this.client.store.storeRoom(room); - this.client.emit(_client.ClientEvent.Room, room); - } - inviteStateEvents.forEach(e => { - this.client.emit(_client.ClientEvent.Event, e); - }); - room.updateMyMembership("invite"); - return; - } - if (roomData.initial) { - var _roomData$prev_batch; - // set the back-pagination token. Do this *before* adding any - // events so that clients can start back-paginating. - room.getLiveTimeline().setPaginationToken((_roomData$prev_batch = roomData.prev_batch) !== null && _roomData$prev_batch !== void 0 ? _roomData$prev_batch : null, _eventTimeline.EventTimeline.BACKWARDS); - } - - /* TODO - else if (roomData.limited) { - let limited = true; - // we've got a limited sync, so we *probably* have a gap in the - // timeline, so should reset. But we might have been peeking or - // paginating and already have some of the events, in which - // case we just want to append any subsequent events to the end - // of the existing timeline. - // - // This is particularly important in the case that we already have - // *all* of the events in the timeline - in that case, if we reset - // the timeline, we'll end up with an entirely empty timeline, - // which we'll try to paginate but not get any new events (which - // will stop us linking the empty timeline into the chain). - // - for (let i = timelineEvents.length - 1; i >= 0; i--) { - const eventId = timelineEvents[i].getId(); - if (room.getTimelineForEvent(eventId)) { - logger.debug("Already have event " + eventId + " in limited " + - "sync - not resetting"); - limited = false; - // we might still be missing some of the events before i; - // we don't want to be adding them to the end of the - // timeline because that would put them out of order. - timelineEvents.splice(0, i); - // XXX: there's a problem here if the skipped part of the - // timeline modifies the state set in stateEvents, because - // we'll end up using the state from stateEvents rather - // than the later state from timelineEvents. We probably - // need to wind stateEvents forward over the events we're - // skipping. - break; - } - } - if (limited) { - room.resetLiveTimeline( - roomData.prev_batch, - null, // TODO this.syncOpts.canResetEntireTimeline(room.roomId) ? null : syncEventData.oldSyncToken, - ); - // We have to assume any gap in any timeline is - // reason to stop incrementally tracking notifications and - // reset the timeline. - this.client.resetNotifTimelineSet(); - this.registerStateListeners(room); - } - } */ - - this.injectRoomEvents(room, stateEvents, timelineEvents, roomData.num_live); - - // we deliberately don't add ephemeral events to the timeline - room.addEphemeralEvents(ephemeralEvents); - - // local fields must be set before any async calls because call site assumes - // synchronous execution prior to emitting SlidingSyncState.Complete - room.updateMyMembership("join"); - room.recalculate(); - if (roomData.initial) { - client.store.storeRoom(room); - client.emit(_client.ClientEvent.Room, room); - } - - // check if any timeline events should bing and add them to the notifEvents array: - // we'll purge this once we've fully processed the sync response - this.addNotifications(timelineEvents); - const processRoomEvent = async e => { - client.emit(_client.ClientEvent.Event, e); - if (e.isState() && e.getType() == _event.EventType.RoomEncryption && this.syncOpts.cryptoCallbacks) { - await this.syncOpts.cryptoCallbacks.onCryptoEvent(room, e); - } - }; - await utils.promiseMapSeries(stateEvents, processRoomEvent); - await utils.promiseMapSeries(timelineEvents, processRoomEvent); - ephemeralEvents.forEach(function (e) { - client.emit(_client.ClientEvent.Event, e); - }); - - // Decrypt only the last message in all rooms to make sure we can generate a preview - // And decrypt all events after the recorded read receipt to ensure an accurate - // notification count - room.decryptCriticalEvents(); - } - - /** - * Injects events into a room's model. - * @param stateEventList - A list of state events. This is the state - * at the *START* of the timeline list if it is supplied. - * @param timelineEventList - A list of timeline events. Lower index - * is earlier in time. Higher index is later. - * @param numLive - the number of events in timelineEventList which just happened, - * supplied from the server. - */ - injectRoomEvents(room, stateEventList, timelineEventList, numLive) { - timelineEventList = timelineEventList || []; - stateEventList = stateEventList || []; - numLive = numLive || 0; - - // If there are no events in the timeline yet, initialise it with - // the given state events - const liveTimeline = room.getLiveTimeline(); - const timelineWasEmpty = liveTimeline.getEvents().length == 0; - if (timelineWasEmpty) { - // Passing these events into initialiseState will freeze them, so we need - // to compute and cache the push actions for them now, otherwise sync dies - // with an attempt to assign to read only property. - // XXX: This is pretty horrible and is assuming all sorts of behaviour from - // these functions that it shouldn't be. We should probably either store the - // push actions cache elsewhere so we can freeze MatrixEvents, or otherwise - // find some solution where MatrixEvents are immutable but allow for a cache - // field. - for (const ev of stateEventList) { - this.client.getPushActionsForEvent(ev); - } - liveTimeline.initialiseState(stateEventList); - } - - // If the timeline wasn't empty, we process the state events here: they're - // defined as updates to the state before the start of the timeline, so this - // starts to roll the state forward. - // XXX: That's what we *should* do, but this can happen if we were previously - // peeking in a room, in which case we obviously do *not* want to add the - // state events here onto the end of the timeline. Historically, the js-sdk - // has just set these new state events on the old and new state. This seems - // very wrong because there could be events in the timeline that diverge the - // state, in which case this is going to leave things out of sync. However, - // for now I think it;s best to behave the same as the code has done previously. - if (!timelineWasEmpty) { - // XXX: As above, don't do this... - //room.addLiveEvents(stateEventList || []); - // Do this instead... - room.oldState.setStateEvents(stateEventList); - room.currentState.setStateEvents(stateEventList); - } - - // the timeline is broken into 'live' events which just happened and normal timeline events - // which are still to be appended to the end of the live timeline but happened a while ago. - // The live events are marked as fromCache=false to ensure that downstream components know - // this is a live event, not historical (from a remote server cache). - - let liveTimelineEvents = []; - if (numLive > 0) { - // last numLive events are live - liveTimelineEvents = timelineEventList.slice(-1 * numLive); - // everything else is not live - timelineEventList = timelineEventList.slice(0, -1 * liveTimelineEvents.length); - } - - // execute the timeline events. This will continue to diverge the current state - // if the timeline has any state events in it. - // This also needs to be done before running push rules on the events as they need - // to be decorated with sender etc. - room.addLiveEvents(timelineEventList, { - fromCache: true - }); - if (liveTimelineEvents.length > 0) { - room.addLiveEvents(liveTimelineEvents, { - fromCache: false - }); - } - room.recalculate(); - - // resolve invites now we have set the latest state - this.resolveInvites(room); - } - resolveInvites(room) { - if (!room || !this.opts.resolveInvitesToProfiles) { - return; - } - const client = this.client; - // For each invited room member we want to give them a displayname/avatar url - // if they have one (the m.room.member invites don't contain this). - room.getMembersWithMembership("invite").forEach(function (member) { - if (member.requestedProfileInfo) return; - member.requestedProfileInfo = true; - // try to get a cached copy first. - const user = client.getUser(member.userId); - let promise; - if (user) { - promise = Promise.resolve({ - avatar_url: user.avatarUrl, - displayname: user.displayName - }); - } else { - promise = client.getProfileInfo(member.userId); - } - promise.then(function (info) { - // slightly naughty by doctoring the invite event but this means all - // the code paths remain the same between invite/join display name stuff - // which is a worthy trade-off for some minor pollution. - const inviteEvent = member.events.member; - if (inviteEvent.getContent().membership !== "invite") { - // between resolving and now they have since joined, so don't clobber - return; - } - inviteEvent.getContent().avatar_url = info.avatar_url; - inviteEvent.getContent().displayname = info.displayname; - // fire listeners - member.setMembershipEvent(inviteEvent, room.currentState); - }, function (_err) { - // OH WELL. - }); - }); - } - retryImmediately() { - return true; - } - - /** - * Main entry point. Blocks until stop() is called. - */ - async sync() { - _logger.logger.debug("Sliding sync init loop"); - - // 1) We need to get push rules so we can check if events should bing as we get - // them from /sync. - while (!this.client.isGuest()) { - try { - _logger.logger.debug("Getting push rules..."); - const result = await this.client.getPushRules(); - _logger.logger.debug("Got push rules"); - this.client.pushRules = result; - break; - } catch (err) { - _logger.logger.error("Getting push rules failed", err); - if (this.shouldAbortSync(err)) { - return; - } - } - } - - // start syncing - await this.slidingSync.start(); - } - - /** - * Stops the sync object from syncing. - */ - stop() { - _logger.logger.debug("SyncApi.stop"); - this.slidingSync.stop(); - } - - /** - * Sets the sync state and emits an event to say so - * @param newState - The new state string - * @param data - Object of additional data to emit in the event - */ - updateSyncState(newState, data) { - const old = this.syncState; - this.syncState = newState; - this.syncStateData = data; - this.client.emit(_client.ClientEvent.Sync, this.syncState, old, data); - } - - /** - * Takes a list of timelineEvents and adds and adds to notifEvents - * as appropriate. - * This must be called after the room the events belong to has been stored. - * - * @param timelineEventList - A list of timeline events. Lower index - * is earlier in time. Higher index is later. - */ - addNotifications(timelineEventList) { - // gather our notifications into this.notifEvents - if (!this.client.getNotifTimelineSet()) { - return; - } - for (const timelineEvent of timelineEventList) { - const pushActions = this.client.getPushActionsForEvent(timelineEvent); - if (pushActions && pushActions.notify && pushActions.tweaks && pushActions.tweaks.highlight) { - this.notifEvents.push(timelineEvent); - } - } - } - - /** - * Purge any events in the notifEvents array. Used after a /sync has been complete. - * This should not be called at a per-room scope (e.g in onRoomData) because otherwise the ordering - * will be messed up e.g room A gets a bing, room B gets a newer bing, but both in the same /sync - * response. If we purge at a per-room scope then we could process room B before room A leading to - * room B appearing earlier in the notifications timeline, even though it has the higher origin_server_ts. - */ - purgeNotifications() { - this.notifEvents.sort(function (a, b) { - return a.getTs() - b.getTs(); - }); - this.notifEvents.forEach(event => { - var _this$client$getNotif; - (_this$client$getNotif = this.client.getNotifTimelineSet()) === null || _this$client$getNotif === void 0 ? void 0 : _this$client$getNotif.addLiveEvent(event); - }); - this.notifEvents = []; - } -} -exports.SlidingSyncSdk = SlidingSyncSdk; -function ensureNameEvent(client, roomId, roomData) { - // make sure m.room.name is in required_state if there is a name, replacing anything previously - // there if need be. This ensures clients transparently 'calculate' the right room name. Native - // sliding sync clients should just read the "name" field. - if (!roomData.name) { - return roomData; - } - for (const stateEvent of roomData.required_state) { - if (stateEvent.type === _event.EventType.RoomName && stateEvent.state_key === "") { - stateEvent.content = { - name: roomData.name - }; - return roomData; - } - } - roomData.required_state.push({ - event_id: "$fake-sliding-sync-name-event-" + roomId, - state_key: "", - type: _event.EventType.RoomName, - content: { - name: roomData.name - }, - sender: client.getUserId(), - origin_server_ts: new Date().getTime() - }); - return roomData; -} -// Helper functions which set up JS SDK structs are below and are identical to the sync v2 counterparts, -// just outside the class. -function mapEvents(client, roomId, events, decrypt = true) { - const mapper = client.getEventMapper({ - decrypt - }); - return events.map(function (e) { - e.room_id = roomId; - return mapper(e); - }); -} -function processEphemeralEvents(client, roomId, ephEvents) { - const ephemeralEvents = mapEvents(client, roomId, ephEvents); - const room = client.getRoom(roomId); - if (!room) { - _logger.logger.warn("got ephemeral events for room but room doesn't exist on client:", roomId); - return; - } - room.addEphemeralEvents(ephemeralEvents); - ephemeralEvents.forEach(e => { - client.emit(_client.ClientEvent.Event, e); - }); -} -//# sourceMappingURL=sliding-sync-sdk.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js.map deleted file mode 100644 index 2a39573..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync-sdk.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sliding-sync-sdk.js","names":["_room","require","_logger","utils","_interopRequireWildcard","_eventTimeline","_client","_sync","_httpApi","_slidingSync","_event","_roomState","_roomMember","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","FAILED_SYNC_ERROR_THRESHOLD","ExtensionE2EE","constructor","crypto","name","when","ExtensionState","PreProcess","onRequest","isInitial","undefined","enabled","onResponse","data","handleDeviceListChanges","oldSyncToken","currentCount","signed_curve25519","updateOneTimeKeyCount","unusedFallbackKeys","setNeedsNewFallback","Array","isArray","includes","onSyncCompleted","ExtensionToDevice","client","cryptoCallbacks","_defineProperty2","extReq","since","nextBatch","cancelledKeyVerificationTxns","events","length","preprocessToDeviceMessages","map","getEventMapper","toDeviceEvent","getType","txnId","getContent","push","forEach","content","msgtype","logger","log","getSender","flagCancelled","emit","ClientEvent","ToDeviceEvent","next_batch","ExtensionAccountData","PostProcess","global","processGlobalAccountData","roomId","rooms","accountDataEvents","mapEvents","room","getRoom","warn","addAccountData","e","Event","globalAccountData","prevEventsMap","reduce","m","c","store","getAccountData","storeAccountDataEvents","accountDataEvent","EventType","PushRules","rules","setPushRules","prevEvent","AccountData","ExtensionTyping","processEphemeralEvents","ExtensionReceipts","SlidingSyncSdk","slidingSync","opts","syncOpts","defaultClientOpts","defaultSyncApiOpts","getNotifTimelineSet","reEmitter","reEmit","RoomEvent","Timeline","TimelineReset","on","SlidingSyncEvent","Lifecycle","onLifecycle","bind","RoomData","onRoomData","extensions","ext","registerExtension","roomData","initial","debug","_createAndReEmitRoom","processRoomData","state","resp","err","SlidingSyncState","Complete","purgeNotifications","lastPos","updateSyncState","SyncState","Prepared","nextSyncToken","pos","catchingUp","fromCache","Syncing","RequestFinished","failCount","Error","Reconnecting","error","MatrixError","shouldAbortSync","syncLeftRooms","peek","_roomId","stopPeeking","getSyncState","syncState","getSyncStateData","_this$syncStateData","syncStateData","createRoom","timelineSupport","Room","getUserId","lazyLoadMembers","pendingEventOrdering","Name","Redaction","RedactionCancelled","Receipt","Tags","LocalEchoUpdated","MyMembership","registerStateListeners","currentState","RoomStateEvent","Events","Members","NewMember","Update","event","member","_this$client$getUser","user","getUser","userId","RoomMemberEvent","Typing","PowerLevel","Membership","errcode","stop","ensureNameEvent","stateEvents","required_state","timelineEvents","timeline","ephemeralEvents","knownEvents","Set","getLiveTimeline","getEvents","add","getId","oldEvents","newEvents","seenKnownEvent","i","recvEvent","unshift","addEventsToTimeline","prev_batch","encrypted","isRoomEncrypted","notification_count","setUnreadNotificationCount","NotificationCountType","Total","highlight_count","getUnreadNotificationCount","Highlight","Number","isInteger","invited_count","setInvitedMemberCount","joined_count","setJoinedMemberCount","invite_state","inviteStateEvents","injectRoomEvents","recalculate","storeRoom","updateMyMembership","_roomData$prev_batch","setPaginationToken","EventTimeline","BACKWARDS","num_live","addEphemeralEvents","addNotifications","processRoomEvent","isState","RoomEncryption","onCryptoEvent","promiseMapSeries","decryptCriticalEvents","stateEventList","timelineEventList","numLive","liveTimeline","timelineWasEmpty","ev","getPushActionsForEvent","initialiseState","oldState","setStateEvents","liveTimelineEvents","slice","addLiveEvents","resolveInvites","resolveInvitesToProfiles","getMembersWithMembership","requestedProfileInfo","promise","Promise","resolve","avatar_url","avatarUrl","displayname","displayName","getProfileInfo","then","info","inviteEvent","membership","setMembershipEvent","_err","retryImmediately","sync","isGuest","result","getPushRules","pushRules","start","newState","old","Sync","timelineEvent","pushActions","notify","tweaks","highlight","notifEvents","sort","a","b","getTs","_this$client$getNotif","addLiveEvent","exports","stateEvent","type","RoomName","state_key","event_id","sender","origin_server_ts","Date","getTime","decrypt","mapper","room_id","ephEvents"],"sources":["../src/sliding-sync-sdk.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport type { SyncCryptoCallbacks } from \"./common-crypto/CryptoBackend\";\nimport { NotificationCountType, Room, RoomEvent } from \"./models/room\";\nimport { logger } from \"./logger\";\nimport * as utils from \"./utils\";\nimport { EventTimeline } from \"./models/event-timeline\";\nimport { ClientEvent, IStoredClientOpts, MatrixClient } from \"./client\";\nimport {\n ISyncStateData,\n SyncState,\n _createAndReEmitRoom,\n SyncApiOptions,\n defaultClientOpts,\n defaultSyncApiOpts,\n} from \"./sync\";\nimport { MatrixEvent } from \"./models/event\";\nimport { Crypto } from \"./crypto\";\nimport { IMinimalEvent, IRoomEvent, IStateEvent, IStrippedState, ISyncResponse } from \"./sync-accumulator\";\nimport { MatrixError } from \"./http-api\";\nimport {\n Extension,\n ExtensionState,\n MSC3575RoomData,\n MSC3575SlidingSyncResponse,\n SlidingSync,\n SlidingSyncEvent,\n SlidingSyncState,\n} from \"./sliding-sync\";\nimport { EventType } from \"./@types/event\";\nimport { IPushRules } from \"./@types/PushRules\";\nimport { RoomStateEvent } from \"./models/room-state\";\nimport { RoomMemberEvent } from \"./models/room-member\";\n\n// Number of consecutive failed syncs that will lead to a syncState of ERROR as opposed\n// to RECONNECTING. This is needed to inform the client of server issues when the\n// keepAlive is successful but the server /sync fails.\nconst FAILED_SYNC_ERROR_THRESHOLD = 3;\n\ntype ExtensionE2EERequest = {\n enabled: boolean;\n};\n\ntype ExtensionE2EEResponse = Pick<\n ISyncResponse,\n | \"device_lists\"\n | \"device_one_time_keys_count\"\n | \"device_unused_fallback_key_types\"\n | \"org.matrix.msc2732.device_unused_fallback_key_types\"\n>;\n\nclass ExtensionE2EE implements Extension {\n public constructor(private readonly crypto: Crypto) {}\n\n public name(): string {\n return \"e2ee\";\n }\n\n public when(): ExtensionState {\n return ExtensionState.PreProcess;\n }\n\n public onRequest(isInitial: boolean): ExtensionE2EERequest | undefined {\n if (!isInitial) {\n return undefined;\n }\n return {\n enabled: true, // this is sticky so only send it on the initial request\n };\n }\n\n public async onResponse(data: ExtensionE2EEResponse): Promise {\n // Handle device list updates\n if (data[\"device_lists\"]) {\n await this.crypto.handleDeviceListChanges(\n {\n oldSyncToken: \"yep\", // XXX need to do this so the device list changes get processed :(\n },\n data[\"device_lists\"],\n );\n }\n\n // Handle one_time_keys_count\n if (data[\"device_one_time_keys_count\"]) {\n const currentCount = data[\"device_one_time_keys_count\"].signed_curve25519 || 0;\n this.crypto.updateOneTimeKeyCount(currentCount);\n }\n if (data[\"device_unused_fallback_key_types\"] || data[\"org.matrix.msc2732.device_unused_fallback_key_types\"]) {\n // The presence of device_unused_fallback_key_types indicates that the\n // server supports fallback keys. If there's no unused\n // signed_curve25519 fallback key we need a new one.\n const unusedFallbackKeys =\n data[\"device_unused_fallback_key_types\"] || data[\"org.matrix.msc2732.device_unused_fallback_key_types\"];\n this.crypto.setNeedsNewFallback(\n Array.isArray(unusedFallbackKeys) && !unusedFallbackKeys.includes(\"signed_curve25519\"),\n );\n }\n this.crypto.onSyncCompleted({});\n }\n}\n\ntype ExtensionToDeviceRequest = {\n since?: string;\n limit?: number;\n enabled?: boolean;\n};\n\ntype ExtensionToDeviceResponse = {\n events: Required[\"to_device\"][\"events\"];\n next_batch: string | null;\n};\n\nclass ExtensionToDevice implements Extension {\n private nextBatch: string | null = null;\n\n public constructor(private readonly client: MatrixClient, private readonly cryptoCallbacks?: SyncCryptoCallbacks) {}\n\n public name(): string {\n return \"to_device\";\n }\n\n public when(): ExtensionState {\n return ExtensionState.PreProcess;\n }\n\n public onRequest(isInitial: boolean): ExtensionToDeviceRequest {\n const extReq: ExtensionToDeviceRequest = {\n since: this.nextBatch !== null ? this.nextBatch : undefined,\n };\n if (isInitial) {\n extReq[\"limit\"] = 100;\n extReq[\"enabled\"] = true;\n }\n return extReq;\n }\n\n public async onResponse(data: ExtensionToDeviceResponse): Promise {\n const cancelledKeyVerificationTxns: string[] = [];\n let events = data[\"events\"] || [];\n if (events.length > 0 && this.cryptoCallbacks) {\n events = await this.cryptoCallbacks.preprocessToDeviceMessages(events);\n }\n events\n .map(this.client.getEventMapper())\n .map((toDeviceEvent) => {\n // map is a cheap inline forEach\n // We want to flag m.key.verification.start events as cancelled\n // if there's an accompanying m.key.verification.cancel event, so\n // we pull out the transaction IDs from the cancellation events\n // so we can flag the verification events as cancelled in the loop\n // below.\n if (toDeviceEvent.getType() === \"m.key.verification.cancel\") {\n const txnId: string | undefined = toDeviceEvent.getContent()[\"transaction_id\"];\n if (txnId) {\n cancelledKeyVerificationTxns.push(txnId);\n }\n }\n\n // as mentioned above, .map is a cheap inline forEach, so return\n // the unmodified event.\n return toDeviceEvent;\n })\n .forEach((toDeviceEvent) => {\n const content = toDeviceEvent.getContent();\n if (toDeviceEvent.getType() == \"m.room.message\" && content.msgtype == \"m.bad.encrypted\") {\n // the mapper already logged a warning.\n logger.log(\"Ignoring undecryptable to-device event from \" + toDeviceEvent.getSender());\n return;\n }\n\n if (\n toDeviceEvent.getType() === \"m.key.verification.start\" ||\n toDeviceEvent.getType() === \"m.key.verification.request\"\n ) {\n const txnId = content[\"transaction_id\"];\n if (cancelledKeyVerificationTxns.includes(txnId)) {\n toDeviceEvent.flagCancelled();\n }\n }\n\n this.client.emit(ClientEvent.ToDeviceEvent, toDeviceEvent);\n });\n\n this.nextBatch = data.next_batch;\n }\n}\n\ntype ExtensionAccountDataRequest = {\n enabled: boolean;\n};\n\ntype ExtensionAccountDataResponse = {\n global: IMinimalEvent[];\n rooms: Record;\n};\n\nclass ExtensionAccountData implements Extension {\n public constructor(private readonly client: MatrixClient) {}\n\n public name(): string {\n return \"account_data\";\n }\n\n public when(): ExtensionState {\n return ExtensionState.PostProcess;\n }\n\n public onRequest(isInitial: boolean): ExtensionAccountDataRequest | undefined {\n if (!isInitial) {\n return undefined;\n }\n return {\n enabled: true,\n };\n }\n\n public onResponse(data: ExtensionAccountDataResponse): void {\n if (data.global && data.global.length > 0) {\n this.processGlobalAccountData(data.global);\n }\n\n for (const roomId in data.rooms) {\n const accountDataEvents = mapEvents(this.client, roomId, data.rooms[roomId]);\n const room = this.client.getRoom(roomId);\n if (!room) {\n logger.warn(\"got account data for room but room doesn't exist on client:\", roomId);\n continue;\n }\n room.addAccountData(accountDataEvents);\n accountDataEvents.forEach((e) => {\n this.client.emit(ClientEvent.Event, e);\n });\n }\n }\n\n private processGlobalAccountData(globalAccountData: IMinimalEvent[]): void {\n const events = mapEvents(this.client, undefined, globalAccountData);\n const prevEventsMap = events.reduce>((m, c) => {\n m[c.getType()] = this.client.store.getAccountData(c.getType());\n return m;\n }, {});\n this.client.store.storeAccountDataEvents(events);\n events.forEach((accountDataEvent) => {\n // Honour push rules that come down the sync stream but also\n // honour push rules that were previously cached. Base rules\n // will be updated when we receive push rules via getPushRules\n // (see sync) before syncing over the network.\n if (accountDataEvent.getType() === EventType.PushRules) {\n const rules = accountDataEvent.getContent();\n this.client.setPushRules(rules);\n }\n const prevEvent = prevEventsMap[accountDataEvent.getType()];\n this.client.emit(ClientEvent.AccountData, accountDataEvent, prevEvent);\n return accountDataEvent;\n });\n }\n}\n\ntype ExtensionTypingRequest = {\n enabled: boolean;\n};\n\ntype ExtensionTypingResponse = {\n rooms: Record;\n};\n\nclass ExtensionTyping implements Extension {\n public constructor(private readonly client: MatrixClient) {}\n\n public name(): string {\n return \"typing\";\n }\n\n public when(): ExtensionState {\n return ExtensionState.PostProcess;\n }\n\n public onRequest(isInitial: boolean): ExtensionTypingRequest | undefined {\n if (!isInitial) {\n return undefined; // don't send a JSON object for subsequent requests, we don't need to.\n }\n return {\n enabled: true,\n };\n }\n\n public onResponse(data: ExtensionTypingResponse): void {\n if (!data?.rooms) {\n return;\n }\n\n for (const roomId in data.rooms) {\n processEphemeralEvents(this.client, roomId, [data.rooms[roomId]]);\n }\n }\n}\n\ntype ExtensionReceiptsRequest = {\n enabled: boolean;\n};\n\ntype ExtensionReceiptsResponse = {\n rooms: Record;\n};\n\nclass ExtensionReceipts implements Extension {\n public constructor(private readonly client: MatrixClient) {}\n\n public name(): string {\n return \"receipts\";\n }\n\n public when(): ExtensionState {\n return ExtensionState.PostProcess;\n }\n\n public onRequest(isInitial: boolean): ExtensionReceiptsRequest | undefined {\n if (isInitial) {\n return {\n enabled: true,\n };\n }\n return undefined; // don't send a JSON object for subsequent requests, we don't need to.\n }\n\n public onResponse(data: ExtensionReceiptsResponse): void {\n if (!data?.rooms) {\n return;\n }\n\n for (const roomId in data.rooms) {\n processEphemeralEvents(this.client, roomId, [data.rooms[roomId]]);\n }\n }\n}\n\n/**\n * A copy of SyncApi such that it can be used as a drop-in replacement for sync v2. For the actual\n * sliding sync API, see sliding-sync.ts or the class SlidingSync.\n */\nexport class SlidingSyncSdk {\n private readonly opts: IStoredClientOpts;\n private readonly syncOpts: SyncApiOptions;\n private syncState: SyncState | null = null;\n private syncStateData?: ISyncStateData;\n private lastPos: string | null = null;\n private failCount = 0;\n private notifEvents: MatrixEvent[] = []; // accumulator of sync events in the current sync response\n\n public constructor(\n private readonly slidingSync: SlidingSync,\n private readonly client: MatrixClient,\n opts?: IStoredClientOpts,\n syncOpts?: SyncApiOptions,\n ) {\n this.opts = defaultClientOpts(opts);\n this.syncOpts = defaultSyncApiOpts(syncOpts);\n\n if (client.getNotifTimelineSet()) {\n client.reEmitter.reEmit(client.getNotifTimelineSet()!, [RoomEvent.Timeline, RoomEvent.TimelineReset]);\n }\n\n this.slidingSync.on(SlidingSyncEvent.Lifecycle, this.onLifecycle.bind(this));\n this.slidingSync.on(SlidingSyncEvent.RoomData, this.onRoomData.bind(this));\n const extensions: Extension[] = [\n new ExtensionToDevice(this.client, this.syncOpts.cryptoCallbacks),\n new ExtensionAccountData(this.client),\n new ExtensionTyping(this.client),\n new ExtensionReceipts(this.client),\n ];\n if (this.syncOpts.crypto) {\n extensions.push(new ExtensionE2EE(this.syncOpts.crypto));\n }\n extensions.forEach((ext) => {\n this.slidingSync.registerExtension(ext);\n });\n }\n\n private onRoomData(roomId: string, roomData: MSC3575RoomData): void {\n let room = this.client.store.getRoom(roomId);\n if (!room) {\n if (!roomData.initial) {\n logger.debug(\"initial flag not set but no stored room exists for room \", roomId, roomData);\n return;\n }\n room = _createAndReEmitRoom(this.client, roomId, this.opts);\n }\n this.processRoomData(this.client, room, roomData);\n }\n\n private onLifecycle(state: SlidingSyncState, resp: MSC3575SlidingSyncResponse | null, err?: Error): void {\n if (err) {\n logger.debug(\"onLifecycle\", state, err);\n }\n switch (state) {\n case SlidingSyncState.Complete:\n this.purgeNotifications();\n if (!resp) {\n break;\n }\n // Element won't stop showing the initial loading spinner unless we fire SyncState.Prepared\n if (!this.lastPos) {\n this.updateSyncState(SyncState.Prepared, {\n oldSyncToken: undefined,\n nextSyncToken: resp.pos,\n catchingUp: false,\n fromCache: false,\n });\n }\n // Conversely, Element won't show the room list unless there is at least 1x SyncState.Syncing\n // so hence for the very first sync we will fire prepared then immediately syncing.\n this.updateSyncState(SyncState.Syncing, {\n oldSyncToken: this.lastPos!,\n nextSyncToken: resp.pos,\n catchingUp: false,\n fromCache: false,\n });\n this.lastPos = resp.pos;\n break;\n case SlidingSyncState.RequestFinished:\n if (err) {\n this.failCount += 1;\n this.updateSyncState(\n this.failCount > FAILED_SYNC_ERROR_THRESHOLD ? SyncState.Error : SyncState.Reconnecting,\n {\n error: new MatrixError(err),\n },\n );\n if (this.shouldAbortSync(new MatrixError(err))) {\n return; // shouldAbortSync actually stops syncing too so we don't need to do anything.\n }\n } else {\n this.failCount = 0;\n }\n break;\n }\n }\n\n /**\n * Sync rooms the user has left.\n * @returns Resolved when they've been added to the store.\n */\n public async syncLeftRooms(): Promise {\n return []; // TODO\n }\n\n /**\n * Peek into a room. This will result in the room in question being synced so it\n * is accessible via getRooms(). Live updates for the room will be provided.\n * @param roomId - The room ID to peek into.\n * @returns A promise which resolves once the room has been added to the\n * store.\n */\n public async peek(_roomId: string): Promise {\n return null!; // TODO\n }\n\n /**\n * Stop polling for updates in the peeked room. NOPs if there is no room being\n * peeked.\n */\n public stopPeeking(): void {\n // TODO\n }\n\n /**\n * Returns the current state of this sync object\n * @see MatrixClient#event:\"sync\"\n */\n public getSyncState(): SyncState | null {\n return this.syncState;\n }\n\n /**\n * Returns the additional data object associated with\n * the current sync state, or null if there is no\n * such data.\n * Sync errors, if available, are put in the 'error' key of\n * this object.\n */\n public getSyncStateData(): ISyncStateData | null {\n return this.syncStateData ?? null;\n }\n\n // Helper functions which set up JS SDK structs are below and are identical to the sync v2 counterparts\n\n public createRoom(roomId: string): Room {\n // XXX cargoculted from sync.ts\n const { timelineSupport } = this.client;\n const room = new Room(roomId, this.client, this.client.getUserId()!, {\n lazyLoadMembers: this.opts.lazyLoadMembers,\n pendingEventOrdering: this.opts.pendingEventOrdering,\n timelineSupport,\n });\n this.client.reEmitter.reEmit(room, [\n RoomEvent.Name,\n RoomEvent.Redaction,\n RoomEvent.RedactionCancelled,\n RoomEvent.Receipt,\n RoomEvent.Tags,\n RoomEvent.LocalEchoUpdated,\n RoomEvent.AccountData,\n RoomEvent.MyMembership,\n RoomEvent.Timeline,\n RoomEvent.TimelineReset,\n ]);\n this.registerStateListeners(room);\n return room;\n }\n\n private registerStateListeners(room: Room): void {\n // XXX cargoculted from sync.ts\n // we need to also re-emit room state and room member events, so hook it up\n // to the client now. We need to add a listener for RoomState.members in\n // order to hook them correctly.\n this.client.reEmitter.reEmit(room.currentState, [\n RoomStateEvent.Events,\n RoomStateEvent.Members,\n RoomStateEvent.NewMember,\n RoomStateEvent.Update,\n ]);\n room.currentState.on(RoomStateEvent.NewMember, (event, state, member) => {\n member.user = this.client.getUser(member.userId) ?? undefined;\n this.client.reEmitter.reEmit(member, [\n RoomMemberEvent.Name,\n RoomMemberEvent.Typing,\n RoomMemberEvent.PowerLevel,\n RoomMemberEvent.Membership,\n ]);\n });\n }\n\n /*\n private deregisterStateListeners(room: Room): void { // XXX cargoculted from sync.ts\n // could do with a better way of achieving this.\n room.currentState.removeAllListeners(RoomStateEvent.Events);\n room.currentState.removeAllListeners(RoomStateEvent.Members);\n room.currentState.removeAllListeners(RoomStateEvent.NewMember);\n } */\n\n private shouldAbortSync(error: MatrixError): boolean {\n if (error.errcode === \"M_UNKNOWN_TOKEN\") {\n // The logout already happened, we just need to stop.\n logger.warn(\"Token no longer valid - assuming logout\");\n this.stop();\n this.updateSyncState(SyncState.Error, { error });\n return true;\n }\n return false;\n }\n\n private async processRoomData(client: MatrixClient, room: Room, roomData: MSC3575RoomData): Promise {\n roomData = ensureNameEvent(client, room.roomId, roomData);\n const stateEvents = mapEvents(this.client, room.roomId, roomData.required_state);\n // Prevent events from being decrypted ahead of time\n // this helps large account to speed up faster\n // room::decryptCriticalEvent is in charge of decrypting all the events\n // required for a client to function properly\n let timelineEvents = mapEvents(this.client, room.roomId, roomData.timeline, false);\n const ephemeralEvents: MatrixEvent[] = []; // TODO this.mapSyncEventsFormat(joinObj.ephemeral);\n\n // TODO: handle threaded / beacon events\n\n if (roomData.initial) {\n // we should not know about any of these timeline entries if this is a genuinely new room.\n // If we do, then we've effectively done scrollback (e.g requesting timeline_limit: 1 for\n // this room, then timeline_limit: 50).\n const knownEvents = new Set();\n room.getLiveTimeline()\n .getEvents()\n .forEach((e) => {\n knownEvents.add(e.getId()!);\n });\n // all unknown events BEFORE a known event must be scrollback e.g:\n // D E <-- what we know\n // A B C D E F <-- what we just received\n // means:\n // A B C <-- scrollback\n // D E <-- dupes\n // F <-- new event\n // We bucket events based on if we have seen a known event yet.\n const oldEvents: MatrixEvent[] = [];\n const newEvents: MatrixEvent[] = [];\n let seenKnownEvent = false;\n for (let i = timelineEvents.length - 1; i >= 0; i--) {\n const recvEvent = timelineEvents[i];\n if (knownEvents.has(recvEvent.getId()!)) {\n seenKnownEvent = true;\n continue; // don't include this event, it's a dupe\n }\n if (seenKnownEvent) {\n // old -> new\n oldEvents.push(recvEvent);\n } else {\n // old -> new\n newEvents.unshift(recvEvent);\n }\n }\n timelineEvents = newEvents;\n if (oldEvents.length > 0) {\n // old events are scrollback, insert them now\n room.addEventsToTimeline(oldEvents, true, room.getLiveTimeline(), roomData.prev_batch);\n }\n }\n\n const encrypted = this.client.isRoomEncrypted(room.roomId);\n // we do this first so it's correct when any of the events fire\n if (roomData.notification_count != null) {\n room.setUnreadNotificationCount(NotificationCountType.Total, roomData.notification_count);\n }\n\n if (roomData.highlight_count != null) {\n // We track unread notifications ourselves in encrypted rooms, so don't\n // bother setting it here. We trust our calculations better than the\n // server's for this case, and therefore will assume that our non-zero\n // count is accurate.\n if (!encrypted || (encrypted && room.getUnreadNotificationCount(NotificationCountType.Highlight) <= 0)) {\n room.setUnreadNotificationCount(NotificationCountType.Highlight, roomData.highlight_count);\n }\n }\n\n if (Number.isInteger(roomData.invited_count)) {\n room.currentState.setInvitedMemberCount(roomData.invited_count!);\n }\n if (Number.isInteger(roomData.joined_count)) {\n room.currentState.setJoinedMemberCount(roomData.joined_count!);\n }\n\n if (roomData.invite_state) {\n const inviteStateEvents = mapEvents(this.client, room.roomId, roomData.invite_state);\n this.injectRoomEvents(room, inviteStateEvents);\n if (roomData.initial) {\n room.recalculate();\n this.client.store.storeRoom(room);\n this.client.emit(ClientEvent.Room, room);\n }\n inviteStateEvents.forEach((e) => {\n this.client.emit(ClientEvent.Event, e);\n });\n room.updateMyMembership(\"invite\");\n return;\n }\n\n if (roomData.initial) {\n // set the back-pagination token. Do this *before* adding any\n // events so that clients can start back-paginating.\n room.getLiveTimeline().setPaginationToken(roomData.prev_batch ?? null, EventTimeline.BACKWARDS);\n }\n\n /* TODO\n else if (roomData.limited) {\n\n let limited = true;\n\n // we've got a limited sync, so we *probably* have a gap in the\n // timeline, so should reset. But we might have been peeking or\n // paginating and already have some of the events, in which\n // case we just want to append any subsequent events to the end\n // of the existing timeline.\n //\n // This is particularly important in the case that we already have\n // *all* of the events in the timeline - in that case, if we reset\n // the timeline, we'll end up with an entirely empty timeline,\n // which we'll try to paginate but not get any new events (which\n // will stop us linking the empty timeline into the chain).\n //\n for (let i = timelineEvents.length - 1; i >= 0; i--) {\n const eventId = timelineEvents[i].getId();\n if (room.getTimelineForEvent(eventId)) {\n logger.debug(\"Already have event \" + eventId + \" in limited \" +\n \"sync - not resetting\");\n limited = false;\n\n // we might still be missing some of the events before i;\n // we don't want to be adding them to the end of the\n // timeline because that would put them out of order.\n timelineEvents.splice(0, i);\n\n // XXX: there's a problem here if the skipped part of the\n // timeline modifies the state set in stateEvents, because\n // we'll end up using the state from stateEvents rather\n // than the later state from timelineEvents. We probably\n // need to wind stateEvents forward over the events we're\n // skipping.\n break;\n }\n }\n\n if (limited) {\n room.resetLiveTimeline(\n roomData.prev_batch,\n null, // TODO this.syncOpts.canResetEntireTimeline(room.roomId) ? null : syncEventData.oldSyncToken,\n );\n\n // We have to assume any gap in any timeline is\n // reason to stop incrementally tracking notifications and\n // reset the timeline.\n this.client.resetNotifTimelineSet();\n this.registerStateListeners(room);\n }\n } */\n\n this.injectRoomEvents(room, stateEvents, timelineEvents, roomData.num_live);\n\n // we deliberately don't add ephemeral events to the timeline\n room.addEphemeralEvents(ephemeralEvents);\n\n // local fields must be set before any async calls because call site assumes\n // synchronous execution prior to emitting SlidingSyncState.Complete\n room.updateMyMembership(\"join\");\n\n room.recalculate();\n if (roomData.initial) {\n client.store.storeRoom(room);\n client.emit(ClientEvent.Room, room);\n }\n\n // check if any timeline events should bing and add them to the notifEvents array:\n // we'll purge this once we've fully processed the sync response\n this.addNotifications(timelineEvents);\n\n const processRoomEvent = async (e: MatrixEvent): Promise => {\n client.emit(ClientEvent.Event, e);\n if (e.isState() && e.getType() == EventType.RoomEncryption && this.syncOpts.cryptoCallbacks) {\n await this.syncOpts.cryptoCallbacks.onCryptoEvent(room, e);\n }\n };\n\n await utils.promiseMapSeries(stateEvents, processRoomEvent);\n await utils.promiseMapSeries(timelineEvents, processRoomEvent);\n ephemeralEvents.forEach(function (e) {\n client.emit(ClientEvent.Event, e);\n });\n\n // Decrypt only the last message in all rooms to make sure we can generate a preview\n // And decrypt all events after the recorded read receipt to ensure an accurate\n // notification count\n room.decryptCriticalEvents();\n }\n\n /**\n * Injects events into a room's model.\n * @param stateEventList - A list of state events. This is the state\n * at the *START* of the timeline list if it is supplied.\n * @param timelineEventList - A list of timeline events. Lower index\n * is earlier in time. Higher index is later.\n * @param numLive - the number of events in timelineEventList which just happened,\n * supplied from the server.\n */\n public injectRoomEvents(\n room: Room,\n stateEventList: MatrixEvent[],\n timelineEventList?: MatrixEvent[],\n numLive?: number,\n ): void {\n timelineEventList = timelineEventList || [];\n stateEventList = stateEventList || [];\n numLive = numLive || 0;\n\n // If there are no events in the timeline yet, initialise it with\n // the given state events\n const liveTimeline = room.getLiveTimeline();\n const timelineWasEmpty = liveTimeline.getEvents().length == 0;\n if (timelineWasEmpty) {\n // Passing these events into initialiseState will freeze them, so we need\n // to compute and cache the push actions for them now, otherwise sync dies\n // with an attempt to assign to read only property.\n // XXX: This is pretty horrible and is assuming all sorts of behaviour from\n // these functions that it shouldn't be. We should probably either store the\n // push actions cache elsewhere so we can freeze MatrixEvents, or otherwise\n // find some solution where MatrixEvents are immutable but allow for a cache\n // field.\n for (const ev of stateEventList) {\n this.client.getPushActionsForEvent(ev);\n }\n liveTimeline.initialiseState(stateEventList);\n }\n\n // If the timeline wasn't empty, we process the state events here: they're\n // defined as updates to the state before the start of the timeline, so this\n // starts to roll the state forward.\n // XXX: That's what we *should* do, but this can happen if we were previously\n // peeking in a room, in which case we obviously do *not* want to add the\n // state events here onto the end of the timeline. Historically, the js-sdk\n // has just set these new state events on the old and new state. This seems\n // very wrong because there could be events in the timeline that diverge the\n // state, in which case this is going to leave things out of sync. However,\n // for now I think it;s best to behave the same as the code has done previously.\n if (!timelineWasEmpty) {\n // XXX: As above, don't do this...\n //room.addLiveEvents(stateEventList || []);\n // Do this instead...\n room.oldState.setStateEvents(stateEventList);\n room.currentState.setStateEvents(stateEventList);\n }\n\n // the timeline is broken into 'live' events which just happened and normal timeline events\n // which are still to be appended to the end of the live timeline but happened a while ago.\n // The live events are marked as fromCache=false to ensure that downstream components know\n // this is a live event, not historical (from a remote server cache).\n\n let liveTimelineEvents: MatrixEvent[] = [];\n if (numLive > 0) {\n // last numLive events are live\n liveTimelineEvents = timelineEventList.slice(-1 * numLive);\n // everything else is not live\n timelineEventList = timelineEventList.slice(0, -1 * liveTimelineEvents.length);\n }\n\n // execute the timeline events. This will continue to diverge the current state\n // if the timeline has any state events in it.\n // This also needs to be done before running push rules on the events as they need\n // to be decorated with sender etc.\n room.addLiveEvents(timelineEventList, {\n fromCache: true,\n });\n if (liveTimelineEvents.length > 0) {\n room.addLiveEvents(liveTimelineEvents, {\n fromCache: false,\n });\n }\n\n room.recalculate();\n\n // resolve invites now we have set the latest state\n this.resolveInvites(room);\n }\n\n private resolveInvites(room: Room): void {\n if (!room || !this.opts.resolveInvitesToProfiles) {\n return;\n }\n const client = this.client;\n // For each invited room member we want to give them a displayname/avatar url\n // if they have one (the m.room.member invites don't contain this).\n room.getMembersWithMembership(\"invite\").forEach(function (member) {\n if (member.requestedProfileInfo) return;\n member.requestedProfileInfo = true;\n // try to get a cached copy first.\n const user = client.getUser(member.userId);\n let promise: ReturnType;\n if (user) {\n promise = Promise.resolve({\n avatar_url: user.avatarUrl,\n displayname: user.displayName,\n });\n } else {\n promise = client.getProfileInfo(member.userId);\n }\n promise.then(\n function (info) {\n // slightly naughty by doctoring the invite event but this means all\n // the code paths remain the same between invite/join display name stuff\n // which is a worthy trade-off for some minor pollution.\n const inviteEvent = member.events.member!;\n if (inviteEvent.getContent().membership !== \"invite\") {\n // between resolving and now they have since joined, so don't clobber\n return;\n }\n inviteEvent.getContent().avatar_url = info.avatar_url;\n inviteEvent.getContent().displayname = info.displayname;\n // fire listeners\n member.setMembershipEvent(inviteEvent, room.currentState);\n },\n function (_err) {\n // OH WELL.\n },\n );\n });\n }\n\n public retryImmediately(): boolean {\n return true;\n }\n\n /**\n * Main entry point. Blocks until stop() is called.\n */\n public async sync(): Promise {\n logger.debug(\"Sliding sync init loop\");\n\n // 1) We need to get push rules so we can check if events should bing as we get\n // them from /sync.\n while (!this.client.isGuest()) {\n try {\n logger.debug(\"Getting push rules...\");\n const result = await this.client.getPushRules();\n logger.debug(\"Got push rules\");\n this.client.pushRules = result;\n break;\n } catch (err) {\n logger.error(\"Getting push rules failed\", err);\n if (this.shouldAbortSync(err)) {\n return;\n }\n }\n }\n\n // start syncing\n await this.slidingSync.start();\n }\n\n /**\n * Stops the sync object from syncing.\n */\n public stop(): void {\n logger.debug(\"SyncApi.stop\");\n this.slidingSync.stop();\n }\n\n /**\n * Sets the sync state and emits an event to say so\n * @param newState - The new state string\n * @param data - Object of additional data to emit in the event\n */\n private updateSyncState(newState: SyncState, data?: ISyncStateData): void {\n const old = this.syncState;\n this.syncState = newState;\n this.syncStateData = data;\n this.client.emit(ClientEvent.Sync, this.syncState, old, data);\n }\n\n /**\n * Takes a list of timelineEvents and adds and adds to notifEvents\n * as appropriate.\n * This must be called after the room the events belong to has been stored.\n *\n * @param timelineEventList - A list of timeline events. Lower index\n * is earlier in time. Higher index is later.\n */\n private addNotifications(timelineEventList: MatrixEvent[]): void {\n // gather our notifications into this.notifEvents\n if (!this.client.getNotifTimelineSet()) {\n return;\n }\n for (const timelineEvent of timelineEventList) {\n const pushActions = this.client.getPushActionsForEvent(timelineEvent);\n if (pushActions && pushActions.notify && pushActions.tweaks && pushActions.tweaks.highlight) {\n this.notifEvents.push(timelineEvent);\n }\n }\n }\n\n /**\n * Purge any events in the notifEvents array. Used after a /sync has been complete.\n * This should not be called at a per-room scope (e.g in onRoomData) because otherwise the ordering\n * will be messed up e.g room A gets a bing, room B gets a newer bing, but both in the same /sync\n * response. If we purge at a per-room scope then we could process room B before room A leading to\n * room B appearing earlier in the notifications timeline, even though it has the higher origin_server_ts.\n */\n private purgeNotifications(): void {\n this.notifEvents.sort(function (a, b) {\n return a.getTs() - b.getTs();\n });\n this.notifEvents.forEach((event) => {\n this.client.getNotifTimelineSet()?.addLiveEvent(event);\n });\n this.notifEvents = [];\n }\n}\n\nfunction ensureNameEvent(client: MatrixClient, roomId: string, roomData: MSC3575RoomData): MSC3575RoomData {\n // make sure m.room.name is in required_state if there is a name, replacing anything previously\n // there if need be. This ensures clients transparently 'calculate' the right room name. Native\n // sliding sync clients should just read the \"name\" field.\n if (!roomData.name) {\n return roomData;\n }\n for (const stateEvent of roomData.required_state) {\n if (stateEvent.type === EventType.RoomName && stateEvent.state_key === \"\") {\n stateEvent.content = {\n name: roomData.name,\n };\n return roomData;\n }\n }\n roomData.required_state.push({\n event_id: \"$fake-sliding-sync-name-event-\" + roomId,\n state_key: \"\",\n type: EventType.RoomName,\n content: {\n name: roomData.name,\n },\n sender: client.getUserId()!,\n origin_server_ts: new Date().getTime(),\n });\n return roomData;\n}\n\ntype TaggedEvent = (IStrippedState | IRoomEvent | IStateEvent | IMinimalEvent) & { room_id?: string };\n\n// Helper functions which set up JS SDK structs are below and are identical to the sync v2 counterparts,\n// just outside the class.\nfunction mapEvents(client: MatrixClient, roomId: string | undefined, events: object[], decrypt = true): MatrixEvent[] {\n const mapper = client.getEventMapper({ decrypt });\n return (events as TaggedEvent[]).map(function (e) {\n e.room_id = roomId;\n return mapper(e);\n });\n}\n\nfunction processEphemeralEvents(client: MatrixClient, roomId: string, ephEvents: IMinimalEvent[]): void {\n const ephemeralEvents = mapEvents(client, roomId, ephEvents);\n const room = client.getRoom(roomId);\n if (!room) {\n logger.warn(\"got ephemeral events for room but room doesn't exist on client:\", roomId);\n return;\n }\n room.addEphemeralEvents(ephemeralEvents);\n ephemeralEvents.forEach((e) => {\n client.emit(ClientEvent.Event, e);\n });\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts deleted file mode 100644 index e4eface..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts +++ /dev/null @@ -1,343 +0,0 @@ -import { MatrixClient } from "./client"; -import { IRoomEvent, IStateEvent } from "./sync-accumulator"; -import { TypedEventEmitter } from "./models/typed-event-emitter"; -export declare const MSC3575_WILDCARD = "*"; -export declare const MSC3575_STATE_KEY_ME = "$ME"; -export declare const MSC3575_STATE_KEY_LAZY = "$LAZY"; -/** - * Represents a subscription to a room or set of rooms. Controls which events are returned. - */ -export interface MSC3575RoomSubscription { - required_state?: string[][]; - timeline_limit?: number; - include_old_rooms?: MSC3575RoomSubscription; -} -/** - * Controls which rooms are returned in a given list. - */ -export interface MSC3575Filter { - is_dm?: boolean; - is_encrypted?: boolean; - is_invite?: boolean; - room_name_like?: string; - room_types?: string[]; - not_room_types?: string[]; - spaces?: string[]; - tags?: string[]; - not_tags?: string[]; -} -/** - * Represents a list subscription. - */ -export interface MSC3575List extends MSC3575RoomSubscription { - ranges: number[][]; - sort?: string[]; - filters?: MSC3575Filter; - slow_get_all_rooms?: boolean; -} -/** - * A complete Sliding Sync request. - */ -export interface MSC3575SlidingSyncRequest { - lists?: Record; - unsubscribe_rooms?: string[]; - room_subscriptions?: Record; - extensions?: object; - txn_id?: string; - pos?: string; - timeout?: number; - clientTimeout?: number; -} -export interface MSC3575RoomData { - name: string; - required_state: IStateEvent[]; - timeline: (IRoomEvent | IStateEvent)[]; - notification_count?: number; - highlight_count?: number; - joined_count?: number; - invited_count?: number; - invite_state?: IStateEvent[]; - initial?: boolean; - limited?: boolean; - is_dm?: boolean; - prev_batch?: string; - num_live?: number; -} -interface ListResponse { - count: number; - ops: Operation[]; -} -interface BaseOperation { - op: string; -} -interface DeleteOperation extends BaseOperation { - op: "DELETE"; - index: number; -} -interface InsertOperation extends BaseOperation { - op: "INSERT"; - index: number; - room_id: string; -} -interface InvalidateOperation extends BaseOperation { - op: "INVALIDATE"; - range: [number, number]; -} -interface SyncOperation extends BaseOperation { - op: "SYNC"; - range: [number, number]; - room_ids: string[]; -} -type Operation = DeleteOperation | InsertOperation | InvalidateOperation | SyncOperation; -/** - * A complete Sliding Sync response - */ -export interface MSC3575SlidingSyncResponse { - pos: string; - txn_id?: string; - lists: Record; - rooms: Record; - extensions: Record; -} -export declare enum SlidingSyncState { - /** - * Fired by SlidingSyncEvent.Lifecycle event immediately before processing the response. - */ - RequestFinished = "FINISHED", - /** - * Fired by SlidingSyncEvent.Lifecycle event immediately after all room data listeners have been - * invoked, but before list listeners. - */ - Complete = "COMPLETE" -} -/** - * When onResponse extensions should be invoked: before or after processing the main response. - */ -export declare enum ExtensionState { - PreProcess = "ExtState.PreProcess", - PostProcess = "ExtState.PostProcess" -} -/** - * An interface that must be satisfied to register extensions - */ -export interface Extension { - /** - * The extension name to go under 'extensions' in the request body. - * @returns The JSON key. - */ - name(): string; - /** - * A function which is called when the request JSON is being formed. - * Returns the data to insert under this key. - * @param isInitial - True when this is part of the initial request (send sticky params) - * @returns The request JSON to send. - */ - onRequest(isInitial: boolean): Req | undefined; - /** - * A function which is called when there is response JSON under this extension. - * @param data - The response JSON under the extension name. - */ - onResponse(data: Res): void; - /** - * Controls when onResponse should be called. - * @returns The state when it should be called. - */ - when(): ExtensionState; -} -/** - * Events which can be fired by the SlidingSync class. These are designed to provide different levels - * of information when processing sync responses. - * - RoomData: concerns rooms, useful for SlidingSyncSdk to update its knowledge of rooms. - * - Lifecycle: concerns callbacks at various well-defined points in the sync process. - * - List: concerns lists, useful for UI layers to re-render room lists. - * Specifically, the order of event invocation is: - * - Lifecycle (state=RequestFinished) - * - RoomData (N times) - * - Lifecycle (state=Complete) - * - List (at most once per list) - */ -export declare enum SlidingSyncEvent { - /** - * This event fires when there are updates for a room. Fired as and when rooms are encountered - * in the response. - */ - RoomData = "SlidingSync.RoomData", - /** - * This event fires at various points in the /sync loop lifecycle. - * - SlidingSyncState.RequestFinished: Fires after we receive a valid response but before the - * response has been processed. Perform any pre-process steps here. If there was a problem syncing, - * `err` will be set (e.g network errors). - * - SlidingSyncState.Complete: Fires after all SlidingSyncEvent.RoomData have been fired but before - * SlidingSyncEvent.List. - */ - Lifecycle = "SlidingSync.Lifecycle", - /** - * This event fires whenever there has been a change to this list index. It fires exactly once - * per list, even if there were multiple operations for the list. - * It fires AFTER Lifecycle and RoomData events. - */ - List = "SlidingSync.List" -} -export type SlidingSyncEventHandlerMap = { - [SlidingSyncEvent.RoomData]: (roomId: string, roomData: MSC3575RoomData) => void; - [SlidingSyncEvent.Lifecycle]: (state: SlidingSyncState, resp: MSC3575SlidingSyncResponse | null, err?: Error) => void; - [SlidingSyncEvent.List]: (listKey: string, joinedCount: number, roomIndexToRoomId: Record) => void; -}; -/** - * SlidingSync is a high-level data structure which controls the majority of sliding sync. - * It has no hooks into JS SDK except for needing a MatrixClient to perform the HTTP request. - * This means this class (and everything it uses) can be used in isolation from JS SDK if needed. - * To hook this up with the JS SDK, you need to use SlidingSyncSdk. - */ -export declare class SlidingSync extends TypedEventEmitter { - private readonly proxyBaseUrl; - private roomSubscriptionInfo; - private readonly client; - private readonly timeoutMS; - private lists; - private listModifiedCount; - private terminated; - private needsResend; - private txnId; - private txnIdDefers; - private extensions; - private desiredRoomSubscriptions; - private confirmedRoomSubscriptions; - private customSubscriptions; - private roomIdToCustomSubscription; - private pendingReq?; - private abortController?; - /** - * Create a new sliding sync instance - * @param proxyBaseUrl - The base URL of the sliding sync proxy - * @param lists - The lists to use for sliding sync. - * @param roomSubscriptionInfo - The params to use for room subscriptions. - * @param client - The client to use for /sync calls. - * @param timeoutMS - The number of milliseconds to wait for a response. - */ - constructor(proxyBaseUrl: string, lists: Map, roomSubscriptionInfo: MSC3575RoomSubscription, client: MatrixClient, timeoutMS: number); - /** - * Add a custom room subscription, referred to by an arbitrary name. If a subscription with this - * name already exists, it is replaced. No requests are sent by calling this method. - * @param name - The name of the subscription. Only used to reference this subscription in - * useCustomSubscription. - * @param sub - The subscription information. - */ - addCustomSubscription(name: string, sub: MSC3575RoomSubscription): void; - /** - * Use a custom subscription previously added via addCustomSubscription. No requests are sent - * by calling this method. Use modifyRoomSubscriptions to resend subscription information. - * @param roomId - The room to use the subscription in. - * @param name - The name of the subscription. If this name is unknown, the default subscription - * will be used. - */ - useCustomSubscription(roomId: string, name: string): void; - /** - * Get the room index data for a list. - * @param key - The list key - * @returns The list data which contains the rooms in this list - */ - getListData(key: string): { - joinedCount: number; - roomIndexToRoomId: Record; - } | null; - /** - * Get the full request list parameters for a list index. This function is provided for callers to use - * in conjunction with setList to update fields on an existing list. - * @param key - The list key to get the params for. - * @returns A copy of the list params or undefined. - */ - getListParams(key: string): MSC3575List | null; - /** - * Set new ranges for an existing list. Calling this function when _only_ the ranges have changed - * is more efficient than calling setList(index,list) as this function won't resend sticky params, - * whereas setList always will. - * @param key - The list key to modify - * @param ranges - The new ranges to apply. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - setListRanges(key: string, ranges: number[][]): Promise; - /** - * Add or replace a list. Calling this function will interrupt the /sync request to resend new - * lists. - * @param key - The key to modify - * @param list - The new list parameters. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - setList(key: string, list: MSC3575List): Promise; - /** - * Get the room subscriptions for the sync API. - * @returns A copy of the desired room subscriptions. - */ - getRoomSubscriptions(): Set; - /** - * Modify the room subscriptions for the sync API. Calling this function will interrupt the - * /sync request to resend new subscriptions. If the /sync stream has not started, this will - * prepare the room subscriptions for when start() is called. - * @param s - The new desired room subscriptions. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - modifyRoomSubscriptions(s: Set): Promise; - /** - * Modify which events to retrieve for room subscriptions. Invalidates all room subscriptions - * such that they will be sent up afresh. - * @param rs - The new room subscription fields to fetch. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - modifyRoomSubscriptionInfo(rs: MSC3575RoomSubscription): Promise; - /** - * Register an extension to send with the /sync request. - * @param ext - The extension to register. - */ - registerExtension(ext: Extension): void; - private getExtensionRequest; - private onPreExtensionsResponse; - private onPostExtensionsResponse; - /** - * Invoke all attached room data listeners. - * @param roomId - The room which received some data. - * @param roomData - The raw sliding sync response JSON. - */ - private invokeRoomDataListeners; - /** - * Invoke all attached lifecycle listeners. - * @param state - The Lifecycle state - * @param resp - The raw sync response JSON - * @param err - Any error that occurred when making the request e.g. network errors. - */ - private invokeLifecycleListeners; - private shiftRight; - private shiftLeft; - private removeEntry; - private addEntry; - private processListOps; - /** - * Resend a Sliding Sync request. Used when something has changed in the request. Resolves with - * the transaction ID of this request on success. Rejects with the transaction ID of this request - * on failure. - */ - resend(): Promise; - private resolveTransactionDefers; - /** - * Stop syncing with the server. - */ - stop(): void; - /** - * Re-setup this connection e.g in the event of an expired session. - */ - private resetup; - /** - * Start syncing with the server. Blocks until stopped. - */ - start(): Promise; -} -export {}; -//# sourceMappingURL=sliding-sync.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts.map deleted file mode 100644 index dc6d1e6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sliding-sync.d.ts","sourceRoot":"","sources":["../src/sliding-sync.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js deleted file mode 100644 index c94f166..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js +++ /dev/null @@ -1,776 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SlidingSyncState = exports.SlidingSyncEvent = exports.SlidingSync = exports.MSC3575_WILDCARD = exports.MSC3575_STATE_KEY_ME = exports.MSC3575_STATE_KEY_LAZY = exports.ExtensionState = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("./logger"); -var _typedEventEmitter = require("./models/typed-event-emitter"); -var _utils = require("./utils"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -// /sync requests allow you to set a timeout= but the request may continue -// beyond that and wedge forever, so we need to track how long we are willing -// to keep open the connection. This constant is *ADDED* to the timeout= value -// to determine the max time we're willing to wait. -const BUFFER_PERIOD_MS = 10 * 1000; -const MSC3575_WILDCARD = "*"; -exports.MSC3575_WILDCARD = MSC3575_WILDCARD; -const MSC3575_STATE_KEY_ME = "$ME"; -exports.MSC3575_STATE_KEY_ME = MSC3575_STATE_KEY_ME; -const MSC3575_STATE_KEY_LAZY = "$LAZY"; - -/** - * Represents a subscription to a room or set of rooms. Controls which events are returned. - */ -exports.MSC3575_STATE_KEY_LAZY = MSC3575_STATE_KEY_LAZY; -let SlidingSyncState; -/** - * Internal Class. SlidingList represents a single list in sliding sync. The list can have filters, - * multiple sliding windows, and maintains the index-\>room_id mapping. - */ -exports.SlidingSyncState = SlidingSyncState; -(function (SlidingSyncState) { - SlidingSyncState["RequestFinished"] = "FINISHED"; - SlidingSyncState["Complete"] = "COMPLETE"; -})(SlidingSyncState || (exports.SlidingSyncState = SlidingSyncState = {})); -class SlidingList { - // returned data - - /** - * Construct a new sliding list. - * @param list - The range, sort and filter values to use for this list. - */ - constructor(list) { - (0, _defineProperty2.default)(this, "list", void 0); - (0, _defineProperty2.default)(this, "isModified", void 0); - (0, _defineProperty2.default)(this, "roomIndexToRoomId", {}); - (0, _defineProperty2.default)(this, "joinedCount", 0); - this.replaceList(list); - } - - /** - * Mark this list as modified or not. Modified lists will return sticky params with calls to getList. - * This is useful for the first time the list is sent, or if the list has changed in some way. - * @param modified - True to mark this list as modified so all sticky parameters will be re-sent. - */ - setModified(modified) { - this.isModified = modified; - } - - /** - * Update the list range for this list. Does not affect modified status as list ranges are non-sticky. - * @param newRanges - The new ranges for the list - */ - updateListRange(newRanges) { - this.list.ranges = JSON.parse(JSON.stringify(newRanges)); - } - - /** - * Replace list parameters. All fields will be replaced with the new list parameters. - * @param list - The new list parameters - */ - replaceList(list) { - list.filters = list.filters || {}; - list.ranges = list.ranges || []; - this.list = JSON.parse(JSON.stringify(list)); - this.isModified = true; - - // reset values as the join count may be very different (if filters changed) including the rooms - // (e.g. sort orders or sliding window ranges changed) - - // the constantly changing sliding window ranges. Not an array for performance reasons - // E.g. tracking ranges 0-99, 500-599, we don't want to have a 600 element array - this.roomIndexToRoomId = {}; - // the total number of joined rooms according to the server, always >= len(roomIndexToRoomId) - this.joinedCount = 0; - } - - /** - * Return a copy of the list suitable for a request body. - * @param forceIncludeAllParams - True to forcibly include all params even if the list - * hasn't been modified. Callers may want to do this if they are modifying the list prior to calling - * updateList. - */ - getList(forceIncludeAllParams) { - let list = { - ranges: JSON.parse(JSON.stringify(this.list.ranges)) - }; - if (this.isModified || forceIncludeAllParams) { - list = JSON.parse(JSON.stringify(this.list)); - } - return list; - } - - /** - * Check if a given index is within the list range. This is required even though the /sync API - * provides explicit updates with index positions because of the following situation: - * 0 1 2 3 4 5 6 7 8 indexes - * a b c d e f COMMANDS: SYNC 0 2 a b c; SYNC 6 8 d e f; - * a b c d _ f COMMAND: DELETE 7; - * e a b c d f COMMAND: INSERT 0 e; - * c=3 is wrong as we are not tracking it, ergo we need to see if `i` is in range else drop it - * @param i - The index to check - * @returns True if the index is within a sliding window - */ - isIndexInRange(i) { - for (const r of this.list.ranges) { - if (r[0] <= i && i <= r[1]) { - return true; - } - } - return false; - } -} - -/** - * When onResponse extensions should be invoked: before or after processing the main response. - */ -let ExtensionState; -/** - * An interface that must be satisfied to register extensions - */ -exports.ExtensionState = ExtensionState; -(function (ExtensionState) { - ExtensionState["PreProcess"] = "ExtState.PreProcess"; - ExtensionState["PostProcess"] = "ExtState.PostProcess"; -})(ExtensionState || (exports.ExtensionState = ExtensionState = {})); -/** - * Events which can be fired by the SlidingSync class. These are designed to provide different levels - * of information when processing sync responses. - * - RoomData: concerns rooms, useful for SlidingSyncSdk to update its knowledge of rooms. - * - Lifecycle: concerns callbacks at various well-defined points in the sync process. - * - List: concerns lists, useful for UI layers to re-render room lists. - * Specifically, the order of event invocation is: - * - Lifecycle (state=RequestFinished) - * - RoomData (N times) - * - Lifecycle (state=Complete) - * - List (at most once per list) - */ -let SlidingSyncEvent; -exports.SlidingSyncEvent = SlidingSyncEvent; -(function (SlidingSyncEvent) { - SlidingSyncEvent["RoomData"] = "SlidingSync.RoomData"; - SlidingSyncEvent["Lifecycle"] = "SlidingSync.Lifecycle"; - SlidingSyncEvent["List"] = "SlidingSync.List"; -})(SlidingSyncEvent || (exports.SlidingSyncEvent = SlidingSyncEvent = {})); -/** - * SlidingSync is a high-level data structure which controls the majority of sliding sync. - * It has no hooks into JS SDK except for needing a MatrixClient to perform the HTTP request. - * This means this class (and everything it uses) can be used in isolation from JS SDK if needed. - * To hook this up with the JS SDK, you need to use SlidingSyncSdk. - */ -class SlidingSync extends _typedEventEmitter.TypedEventEmitter { - // flag set when resend() is called because we cannot rely on detecting AbortError in JS SDK :( - - // the txn_id to send with the next request. - - // a list (in chronological order of when they were sent) of objects containing the txn ID and - // a defer to resolve/reject depending on whether they were successfully sent or not. - - // map of extension name to req/resp handler - - // the *desired* room subscriptions - - // map of custom subscription name to the subscription - - // map of room ID to custom subscription name - - /** - * Create a new sliding sync instance - * @param proxyBaseUrl - The base URL of the sliding sync proxy - * @param lists - The lists to use for sliding sync. - * @param roomSubscriptionInfo - The params to use for room subscriptions. - * @param client - The client to use for /sync calls. - * @param timeoutMS - The number of milliseconds to wait for a response. - */ - constructor(proxyBaseUrl, lists, roomSubscriptionInfo, client, timeoutMS) { - super(); - this.proxyBaseUrl = proxyBaseUrl; - this.roomSubscriptionInfo = roomSubscriptionInfo; - this.client = client; - this.timeoutMS = timeoutMS; - (0, _defineProperty2.default)(this, "lists", void 0); - (0, _defineProperty2.default)(this, "listModifiedCount", 0); - (0, _defineProperty2.default)(this, "terminated", false); - (0, _defineProperty2.default)(this, "needsResend", false); - (0, _defineProperty2.default)(this, "txnId", null); - (0, _defineProperty2.default)(this, "txnIdDefers", []); - (0, _defineProperty2.default)(this, "extensions", {}); - (0, _defineProperty2.default)(this, "desiredRoomSubscriptions", new Set()); - (0, _defineProperty2.default)(this, "confirmedRoomSubscriptions", new Set()); - (0, _defineProperty2.default)(this, "customSubscriptions", new Map()); - (0, _defineProperty2.default)(this, "roomIdToCustomSubscription", new Map()); - (0, _defineProperty2.default)(this, "pendingReq", void 0); - (0, _defineProperty2.default)(this, "abortController", void 0); - this.lists = new Map(); - lists.forEach((list, key) => { - this.lists.set(key, new SlidingList(list)); - }); - } - - /** - * Add a custom room subscription, referred to by an arbitrary name. If a subscription with this - * name already exists, it is replaced. No requests are sent by calling this method. - * @param name - The name of the subscription. Only used to reference this subscription in - * useCustomSubscription. - * @param sub - The subscription information. - */ - addCustomSubscription(name, sub) { - if (this.customSubscriptions.has(name)) { - _logger.logger.warn(`addCustomSubscription: ${name} already exists as a custom subscription, ignoring.`); - return; - } - this.customSubscriptions.set(name, sub); - } - - /** - * Use a custom subscription previously added via addCustomSubscription. No requests are sent - * by calling this method. Use modifyRoomSubscriptions to resend subscription information. - * @param roomId - The room to use the subscription in. - * @param name - The name of the subscription. If this name is unknown, the default subscription - * will be used. - */ - useCustomSubscription(roomId, name) { - // We already know about this custom subscription, as it is immutable, - // we don't need to unconfirm the subscription. - if (this.roomIdToCustomSubscription.get(roomId) === name) { - return; - } - this.roomIdToCustomSubscription.set(roomId, name); - // unconfirm this subscription so a resend() will send it up afresh. - this.confirmedRoomSubscriptions.delete(roomId); - } - - /** - * Get the room index data for a list. - * @param key - The list key - * @returns The list data which contains the rooms in this list - */ - getListData(key) { - const data = this.lists.get(key); - if (!data) { - return null; - } - return { - joinedCount: data.joinedCount, - roomIndexToRoomId: Object.assign({}, data.roomIndexToRoomId) - }; - } - - /** - * Get the full request list parameters for a list index. This function is provided for callers to use - * in conjunction with setList to update fields on an existing list. - * @param key - The list key to get the params for. - * @returns A copy of the list params or undefined. - */ - getListParams(key) { - const params = this.lists.get(key); - if (!params) { - return null; - } - return params.getList(true); - } - - /** - * Set new ranges for an existing list. Calling this function when _only_ the ranges have changed - * is more efficient than calling setList(index,list) as this function won't resend sticky params, - * whereas setList always will. - * @param key - The list key to modify - * @param ranges - The new ranges to apply. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - setListRanges(key, ranges) { - const list = this.lists.get(key); - if (!list) { - return Promise.reject(new Error("no list with key " + key)); - } - list.updateListRange(ranges); - return this.resend(); - } - - /** - * Add or replace a list. Calling this function will interrupt the /sync request to resend new - * lists. - * @param key - The key to modify - * @param list - The new list parameters. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - setList(key, list) { - const existingList = this.lists.get(key); - if (existingList) { - existingList.replaceList(list); - this.lists.set(key, existingList); - } else { - this.lists.set(key, new SlidingList(list)); - } - this.listModifiedCount += 1; - return this.resend(); - } - - /** - * Get the room subscriptions for the sync API. - * @returns A copy of the desired room subscriptions. - */ - getRoomSubscriptions() { - return new Set(Array.from(this.desiredRoomSubscriptions)); - } - - /** - * Modify the room subscriptions for the sync API. Calling this function will interrupt the - * /sync request to resend new subscriptions. If the /sync stream has not started, this will - * prepare the room subscriptions for when start() is called. - * @param s - The new desired room subscriptions. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - modifyRoomSubscriptions(s) { - this.desiredRoomSubscriptions = s; - return this.resend(); - } - - /** - * Modify which events to retrieve for room subscriptions. Invalidates all room subscriptions - * such that they will be sent up afresh. - * @param rs - The new room subscription fields to fetch. - * @returns A promise which resolves to the transaction ID when it has been received down sync - * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled - * immediately after sending, in which case the action will be applied in the subsequent request) - */ - modifyRoomSubscriptionInfo(rs) { - this.roomSubscriptionInfo = rs; - this.confirmedRoomSubscriptions = new Set(); - return this.resend(); - } - - /** - * Register an extension to send with the /sync request. - * @param ext - The extension to register. - */ - registerExtension(ext) { - if (this.extensions[ext.name()]) { - throw new Error(`registerExtension: ${ext.name()} already exists as an extension`); - } - this.extensions[ext.name()] = ext; - } - getExtensionRequest(isInitial) { - const ext = {}; - Object.keys(this.extensions).forEach(extName => { - ext[extName] = this.extensions[extName].onRequest(isInitial); - }); - return ext; - } - onPreExtensionsResponse(ext) { - Object.keys(ext).forEach(extName => { - if (this.extensions[extName].when() == ExtensionState.PreProcess) { - this.extensions[extName].onResponse(ext[extName]); - } - }); - } - onPostExtensionsResponse(ext) { - Object.keys(ext).forEach(extName => { - if (this.extensions[extName].when() == ExtensionState.PostProcess) { - this.extensions[extName].onResponse(ext[extName]); - } - }); - } - - /** - * Invoke all attached room data listeners. - * @param roomId - The room which received some data. - * @param roomData - The raw sliding sync response JSON. - */ - invokeRoomDataListeners(roomId, roomData) { - if (!roomData.required_state) { - roomData.required_state = []; - } - if (!roomData.timeline) { - roomData.timeline = []; - } - this.emit(SlidingSyncEvent.RoomData, roomId, roomData); - } - - /** - * Invoke all attached lifecycle listeners. - * @param state - The Lifecycle state - * @param resp - The raw sync response JSON - * @param err - Any error that occurred when making the request e.g. network errors. - */ - invokeLifecycleListeners(state, resp, err) { - this.emit(SlidingSyncEvent.Lifecycle, state, resp, err); - } - shiftRight(listKey, hi, low) { - const list = this.lists.get(listKey); - if (!list) { - return; - } - // l h - // 0,1,2,3,4 <- before - // 0,1,2,2,3 <- after, hi is deleted and low is duplicated - for (let i = hi; i > low; i--) { - if (list.isIndexInRange(i)) { - list.roomIndexToRoomId[i] = list.roomIndexToRoomId[i - 1]; - } - } - } - shiftLeft(listKey, hi, low) { - const list = this.lists.get(listKey); - if (!list) { - return; - } - // l h - // 0,1,2,3,4 <- before - // 0,1,3,4,4 <- after, low is deleted and hi is duplicated - for (let i = low; i < hi; i++) { - if (list.isIndexInRange(i)) { - list.roomIndexToRoomId[i] = list.roomIndexToRoomId[i + 1]; - } - } - } - removeEntry(listKey, index) { - const list = this.lists.get(listKey); - if (!list) { - return; - } - // work out the max index - let max = -1; - for (const n in list.roomIndexToRoomId) { - if (Number(n) > max) { - max = Number(n); - } - } - if (max < 0 || index > max) { - return; - } - // Everything higher than the gap needs to be shifted left. - this.shiftLeft(listKey, max, index); - delete list.roomIndexToRoomId[max]; - } - addEntry(listKey, index) { - const list = this.lists.get(listKey); - if (!list) { - return; - } - // work out the max index - let max = -1; - for (const n in list.roomIndexToRoomId) { - if (Number(n) > max) { - max = Number(n); - } - } - if (max < 0 || index > max) { - return; - } - // Everything higher than the gap needs to be shifted right, +1 so we don't delete the highest element - this.shiftRight(listKey, max + 1, index); - } - processListOps(list, listKey) { - let gapIndex = -1; - const listData = this.lists.get(listKey); - if (!listData) { - return; - } - list.ops.forEach(op => { - if (!listData) { - return; - } - switch (op.op) { - case "DELETE": - { - _logger.logger.debug("DELETE", listKey, op.index, ";"); - delete listData.roomIndexToRoomId[op.index]; - if (gapIndex !== -1) { - // we already have a DELETE operation to process, so process it. - this.removeEntry(listKey, gapIndex); - } - gapIndex = op.index; - break; - } - case "INSERT": - { - _logger.logger.debug("INSERT", listKey, op.index, op.room_id, ";"); - if (listData.roomIndexToRoomId[op.index]) { - // something is in this space, shift items out of the way - if (gapIndex < 0) { - // we haven't been told where to shift from, so make way for a new room entry. - this.addEntry(listKey, op.index); - } else if (gapIndex > op.index) { - // the gap is further down the list, shift every element to the right - // starting at the gap so we can just shift each element in turn: - // [A,B,C,_] gapIndex=3, op.index=0 - // [A,B,C,C] i=3 - // [A,B,B,C] i=2 - // [A,A,B,C] i=1 - // Terminate. We'll assign into op.index next. - this.shiftRight(listKey, gapIndex, op.index); - } else if (gapIndex < op.index) { - // the gap is further up the list, shift every element to the left - // starting at the gap so we can just shift each element in turn - this.shiftLeft(listKey, op.index, gapIndex); - } - } - // forget the gap, we don't need it anymore. This is outside the check for - // a room being present in this index position because INSERTs always universally - // forget the gap, not conditionally based on the presence of a room in the INSERT - // position. Without this, DELETE 0; INSERT 0; would do the wrong thing. - gapIndex = -1; - listData.roomIndexToRoomId[op.index] = op.room_id; - break; - } - case "INVALIDATE": - { - const startIndex = op.range[0]; - for (let i = startIndex; i <= op.range[1]; i++) { - delete listData.roomIndexToRoomId[i]; - } - _logger.logger.debug("INVALIDATE", listKey, op.range[0], op.range[1], ";"); - break; - } - case "SYNC": - { - const startIndex = op.range[0]; - for (let i = startIndex; i <= op.range[1]; i++) { - const roomId = op.room_ids[i - startIndex]; - if (!roomId) { - break; // we are at the end of list - } - - listData.roomIndexToRoomId[i] = roomId; - } - _logger.logger.debug("SYNC", listKey, op.range[0], op.range[1], (op.room_ids || []).join(" "), ";"); - break; - } - } - }); - if (gapIndex !== -1) { - // we already have a DELETE operation to process, so process it - // Everything higher than the gap needs to be shifted left. - this.removeEntry(listKey, gapIndex); - } - } - - /** - * Resend a Sliding Sync request. Used when something has changed in the request. Resolves with - * the transaction ID of this request on success. Rejects with the transaction ID of this request - * on failure. - */ - resend() { - var _this$abortController; - if (this.needsResend && this.txnIdDefers.length > 0) { - // we already have a resend queued, so just return the same promise - return this.txnIdDefers[this.txnIdDefers.length - 1].promise; - } - this.needsResend = true; - this.txnId = this.client.makeTxnId(); - const d = (0, _utils.defer)(); - this.txnIdDefers.push(_objectSpread(_objectSpread({}, d), {}, { - txnId: this.txnId - })); - (_this$abortController = this.abortController) === null || _this$abortController === void 0 ? void 0 : _this$abortController.abort(); - this.abortController = new AbortController(); - return d.promise; - } - resolveTransactionDefers(txnId) { - if (!txnId) { - return; - } - // find the matching index - let txnIndex = -1; - for (let i = 0; i < this.txnIdDefers.length; i++) { - if (this.txnIdDefers[i].txnId === txnId) { - txnIndex = i; - break; - } - } - if (txnIndex === -1) { - // this shouldn't happen; we shouldn't be seeing txn_ids for things we don't know about, - // whine about it. - _logger.logger.warn(`resolveTransactionDefers: seen ${txnId} but it isn't a pending txn, ignoring.`); - return; - } - // This list is sorted in time, so if the input txnId ACKs in the middle of this array, - // then everything before it that hasn't been ACKed yet never will and we should reject them. - for (let i = 0; i < txnIndex; i++) { - this.txnIdDefers[i].reject(this.txnIdDefers[i].txnId); - } - this.txnIdDefers[txnIndex].resolve(txnId); - // clear out settled promises, including the one we resolved. - this.txnIdDefers = this.txnIdDefers.slice(txnIndex + 1); - } - - /** - * Stop syncing with the server. - */ - stop() { - var _this$abortController2; - this.terminated = true; - (_this$abortController2 = this.abortController) === null || _this$abortController2 === void 0 ? void 0 : _this$abortController2.abort(); - // remove all listeners so things can be GC'd - this.removeAllListeners(SlidingSyncEvent.Lifecycle); - this.removeAllListeners(SlidingSyncEvent.List); - this.removeAllListeners(SlidingSyncEvent.RoomData); - } - - /** - * Re-setup this connection e.g in the event of an expired session. - */ - resetup() { - var _this$abortController3; - _logger.logger.warn("SlidingSync: resetting connection info"); - // any pending txn ID defers will be forgotten already by the server, so clear them out - this.txnIdDefers.forEach(d => { - d.reject(d.txnId); - }); - this.txnIdDefers = []; - // resend sticky params and de-confirm all subscriptions - this.lists.forEach(l => { - l.setModified(true); - }); - this.confirmedRoomSubscriptions = new Set(); // leave desired ones alone though! - // reset the connection as we might be wedged - this.needsResend = true; - (_this$abortController3 = this.abortController) === null || _this$abortController3 === void 0 ? void 0 : _this$abortController3.abort(); - this.abortController = new AbortController(); - } - - /** - * Start syncing with the server. Blocks until stopped. - */ - async start() { - this.abortController = new AbortController(); - let currentPos; - while (!this.terminated) { - this.needsResend = false; - let doNotUpdateList = false; - let resp; - try { - const listModifiedCount = this.listModifiedCount; - const reqLists = {}; - this.lists.forEach((l, key) => { - reqLists[key] = l.getList(false); - }); - const reqBody = { - lists: reqLists, - pos: currentPos, - timeout: this.timeoutMS, - clientTimeout: this.timeoutMS + BUFFER_PERIOD_MS, - extensions: this.getExtensionRequest(currentPos === undefined) - }; - // check if we are (un)subscribing to a room and modify request this one time for it - const newSubscriptions = difference(this.desiredRoomSubscriptions, this.confirmedRoomSubscriptions); - const unsubscriptions = difference(this.confirmedRoomSubscriptions, this.desiredRoomSubscriptions); - if (unsubscriptions.size > 0) { - reqBody.unsubscribe_rooms = Array.from(unsubscriptions); - } - if (newSubscriptions.size > 0) { - reqBody.room_subscriptions = {}; - for (const roomId of newSubscriptions) { - const customSubName = this.roomIdToCustomSubscription.get(roomId); - let sub = this.roomSubscriptionInfo; - if (customSubName && this.customSubscriptions.has(customSubName)) { - sub = this.customSubscriptions.get(customSubName); - } - reqBody.room_subscriptions[roomId] = sub; - } - } - if (this.txnId) { - reqBody.txn_id = this.txnId; - this.txnId = null; - } - this.pendingReq = this.client.slidingSync(reqBody, this.proxyBaseUrl, this.abortController.signal); - resp = await this.pendingReq; - currentPos = resp.pos; - // update what we think we're subscribed to. - for (const roomId of newSubscriptions) { - this.confirmedRoomSubscriptions.add(roomId); - } - for (const roomId of unsubscriptions) { - this.confirmedRoomSubscriptions.delete(roomId); - } - if (listModifiedCount !== this.listModifiedCount) { - // the lists have been modified whilst we were waiting for 'await' to return, but the abort() - // call did nothing. It is NOT SAFE to modify the list array now. We'll process the response but - // not update list pointers. - _logger.logger.debug("list modified during await call, not updating list"); - doNotUpdateList = true; - } - // mark all these lists as having been sent as sticky so we don't keep sending sticky params - this.lists.forEach(l => { - l.setModified(false); - }); - // set default empty values so we don't need to null check - resp.lists = resp.lists || {}; - resp.rooms = resp.rooms || {}; - resp.extensions = resp.extensions || {}; - Object.keys(resp.lists).forEach(key => { - const list = this.lists.get(key); - if (!list || !resp) { - return; - } - list.joinedCount = resp.lists[key].count; - }); - this.invokeLifecycleListeners(SlidingSyncState.RequestFinished, resp); - } catch (err) { - if (err.httpStatus) { - this.invokeLifecycleListeners(SlidingSyncState.RequestFinished, null, err); - if (err.httpStatus === 400) { - // session probably expired TODO: assign an errcode - // so drop state and re-request - this.resetup(); - currentPos = undefined; - await (0, _utils.sleep)(50); // in case the 400 was for something else; don't tightloop - continue; - } // else fallthrough to generic error handling - } else if (this.needsResend || err.name === "AbortError") { - continue; // don't sleep as we caused this error by abort()ing the request. - } - - _logger.logger.error(err); - await (0, _utils.sleep)(5000); - } - if (!resp) { - continue; - } - this.onPreExtensionsResponse(resp.extensions); - Object.keys(resp.rooms).forEach(roomId => { - this.invokeRoomDataListeners(roomId, resp.rooms[roomId]); - }); - const listKeysWithUpdates = new Set(); - if (!doNotUpdateList) { - for (const [key, list] of Object.entries(resp.lists)) { - list.ops = list.ops || []; - if (list.ops.length > 0) { - listKeysWithUpdates.add(key); - } - this.processListOps(list, key); - } - } - this.invokeLifecycleListeners(SlidingSyncState.Complete, resp); - this.onPostExtensionsResponse(resp.extensions); - listKeysWithUpdates.forEach(listKey => { - const list = this.lists.get(listKey); - if (!list) { - return; - } - this.emit(SlidingSyncEvent.List, listKey, list.joinedCount, Object.assign({}, list.roomIndexToRoomId)); - }); - this.resolveTransactionDefers(resp.txn_id); - } - } -} -exports.SlidingSync = SlidingSync; -const difference = (setA, setB) => { - const diff = new Set(setA); - for (const elem of setB) { - diff.delete(elem); - } - return diff; -}; -//# sourceMappingURL=sliding-sync.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js.map deleted file mode 100644 index 3290acb..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sliding-sync.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sliding-sync.js","names":["_logger","require","_typedEventEmitter","_utils","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","BUFFER_PERIOD_MS","MSC3575_WILDCARD","exports","MSC3575_STATE_KEY_ME","MSC3575_STATE_KEY_LAZY","SlidingSyncState","SlidingList","constructor","list","replaceList","setModified","modified","isModified","updateListRange","newRanges","ranges","JSON","parse","stringify","filters","roomIndexToRoomId","joinedCount","getList","forceIncludeAllParams","isIndexInRange","r","ExtensionState","SlidingSyncEvent","SlidingSync","TypedEventEmitter","proxyBaseUrl","lists","roomSubscriptionInfo","client","timeoutMS","Set","Map","set","addCustomSubscription","name","sub","customSubscriptions","has","logger","warn","useCustomSubscription","roomId","roomIdToCustomSubscription","get","confirmedRoomSubscriptions","delete","getListData","data","assign","getListParams","params","setListRanges","Promise","reject","Error","resend","setList","existingList","listModifiedCount","getRoomSubscriptions","Array","from","desiredRoomSubscriptions","modifyRoomSubscriptions","s","modifyRoomSubscriptionInfo","rs","registerExtension","ext","extensions","getExtensionRequest","isInitial","extName","onRequest","onPreExtensionsResponse","when","PreProcess","onResponse","onPostExtensionsResponse","PostProcess","invokeRoomDataListeners","roomData","required_state","timeline","emit","RoomData","invokeLifecycleListeners","state","resp","err","Lifecycle","shiftRight","listKey","hi","low","shiftLeft","removeEntry","index","max","n","Number","addEntry","processListOps","gapIndex","listData","ops","op","debug","room_id","startIndex","range","room_ids","join","_this$abortController","needsResend","txnIdDefers","promise","txnId","makeTxnId","d","defer","abortController","abort","AbortController","resolveTransactionDefers","txnIndex","resolve","slice","stop","_this$abortController2","terminated","removeAllListeners","List","resetup","_this$abortController3","l","start","currentPos","doNotUpdateList","reqLists","reqBody","pos","timeout","clientTimeout","undefined","newSubscriptions","difference","unsubscriptions","size","unsubscribe_rooms","room_subscriptions","customSubName","txn_id","pendingReq","slidingSync","signal","add","rooms","count","RequestFinished","httpStatus","sleep","error","listKeysWithUpdates","entries","Complete","setA","setB","diff","elem"],"sources":["../src/sliding-sync.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"./logger\";\nimport { MatrixClient } from \"./client\";\nimport { IRoomEvent, IStateEvent } from \"./sync-accumulator\";\nimport { TypedEventEmitter } from \"./models/typed-event-emitter\";\nimport { sleep, IDeferred, defer } from \"./utils\";\nimport { HTTPError } from \"./http-api\";\n\n// /sync requests allow you to set a timeout= but the request may continue\n// beyond that and wedge forever, so we need to track how long we are willing\n// to keep open the connection. This constant is *ADDED* to the timeout= value\n// to determine the max time we're willing to wait.\nconst BUFFER_PERIOD_MS = 10 * 1000;\n\nexport const MSC3575_WILDCARD = \"*\";\nexport const MSC3575_STATE_KEY_ME = \"$ME\";\nexport const MSC3575_STATE_KEY_LAZY = \"$LAZY\";\n\n/**\n * Represents a subscription to a room or set of rooms. Controls which events are returned.\n */\nexport interface MSC3575RoomSubscription {\n required_state?: string[][];\n timeline_limit?: number;\n include_old_rooms?: MSC3575RoomSubscription;\n}\n\n/**\n * Controls which rooms are returned in a given list.\n */\nexport interface MSC3575Filter {\n is_dm?: boolean;\n is_encrypted?: boolean;\n is_invite?: boolean;\n room_name_like?: string;\n room_types?: string[];\n not_room_types?: string[];\n spaces?: string[];\n tags?: string[];\n not_tags?: string[];\n}\n\n/**\n * Represents a list subscription.\n */\nexport interface MSC3575List extends MSC3575RoomSubscription {\n ranges: number[][];\n sort?: string[];\n filters?: MSC3575Filter;\n slow_get_all_rooms?: boolean;\n}\n\n/**\n * A complete Sliding Sync request.\n */\nexport interface MSC3575SlidingSyncRequest {\n // json body params\n lists?: Record;\n unsubscribe_rooms?: string[];\n room_subscriptions?: Record;\n extensions?: object;\n txn_id?: string;\n\n // query params\n pos?: string;\n timeout?: number;\n clientTimeout?: number;\n}\n\nexport interface MSC3575RoomData {\n name: string;\n required_state: IStateEvent[];\n timeline: (IRoomEvent | IStateEvent)[];\n notification_count?: number;\n highlight_count?: number;\n joined_count?: number;\n invited_count?: number;\n invite_state?: IStateEvent[];\n initial?: boolean;\n limited?: boolean;\n is_dm?: boolean;\n prev_batch?: string;\n num_live?: number;\n}\n\ninterface ListResponse {\n count: number;\n ops: Operation[];\n}\n\ninterface BaseOperation {\n op: string;\n}\n\ninterface DeleteOperation extends BaseOperation {\n op: \"DELETE\";\n index: number;\n}\n\ninterface InsertOperation extends BaseOperation {\n op: \"INSERT\";\n index: number;\n room_id: string;\n}\n\ninterface InvalidateOperation extends BaseOperation {\n op: \"INVALIDATE\";\n range: [number, number];\n}\n\ninterface SyncOperation extends BaseOperation {\n op: \"SYNC\";\n range: [number, number];\n room_ids: string[];\n}\n\ntype Operation = DeleteOperation | InsertOperation | InvalidateOperation | SyncOperation;\n\n/**\n * A complete Sliding Sync response\n */\nexport interface MSC3575SlidingSyncResponse {\n pos: string;\n txn_id?: string;\n lists: Record;\n rooms: Record;\n extensions: Record;\n}\n\nexport enum SlidingSyncState {\n /**\n * Fired by SlidingSyncEvent.Lifecycle event immediately before processing the response.\n */\n RequestFinished = \"FINISHED\",\n /**\n * Fired by SlidingSyncEvent.Lifecycle event immediately after all room data listeners have been\n * invoked, but before list listeners.\n */\n Complete = \"COMPLETE\",\n}\n\n/**\n * Internal Class. SlidingList represents a single list in sliding sync. The list can have filters,\n * multiple sliding windows, and maintains the index-\\>room_id mapping.\n */\nclass SlidingList {\n private list!: MSC3575List;\n private isModified?: boolean;\n\n // returned data\n public roomIndexToRoomId: Record = {};\n public joinedCount = 0;\n\n /**\n * Construct a new sliding list.\n * @param list - The range, sort and filter values to use for this list.\n */\n public constructor(list: MSC3575List) {\n this.replaceList(list);\n }\n\n /**\n * Mark this list as modified or not. Modified lists will return sticky params with calls to getList.\n * This is useful for the first time the list is sent, or if the list has changed in some way.\n * @param modified - True to mark this list as modified so all sticky parameters will be re-sent.\n */\n public setModified(modified: boolean): void {\n this.isModified = modified;\n }\n\n /**\n * Update the list range for this list. Does not affect modified status as list ranges are non-sticky.\n * @param newRanges - The new ranges for the list\n */\n public updateListRange(newRanges: number[][]): void {\n this.list.ranges = JSON.parse(JSON.stringify(newRanges));\n }\n\n /**\n * Replace list parameters. All fields will be replaced with the new list parameters.\n * @param list - The new list parameters\n */\n public replaceList(list: MSC3575List): void {\n list.filters = list.filters || {};\n list.ranges = list.ranges || [];\n this.list = JSON.parse(JSON.stringify(list));\n this.isModified = true;\n\n // reset values as the join count may be very different (if filters changed) including the rooms\n // (e.g. sort orders or sliding window ranges changed)\n\n // the constantly changing sliding window ranges. Not an array for performance reasons\n // E.g. tracking ranges 0-99, 500-599, we don't want to have a 600 element array\n this.roomIndexToRoomId = {};\n // the total number of joined rooms according to the server, always >= len(roomIndexToRoomId)\n this.joinedCount = 0;\n }\n\n /**\n * Return a copy of the list suitable for a request body.\n * @param forceIncludeAllParams - True to forcibly include all params even if the list\n * hasn't been modified. Callers may want to do this if they are modifying the list prior to calling\n * updateList.\n */\n public getList(forceIncludeAllParams: boolean): MSC3575List {\n let list = {\n ranges: JSON.parse(JSON.stringify(this.list.ranges)),\n };\n if (this.isModified || forceIncludeAllParams) {\n list = JSON.parse(JSON.stringify(this.list));\n }\n return list;\n }\n\n /**\n * Check if a given index is within the list range. This is required even though the /sync API\n * provides explicit updates with index positions because of the following situation:\n * 0 1 2 3 4 5 6 7 8 indexes\n * a b c d e f COMMANDS: SYNC 0 2 a b c; SYNC 6 8 d e f;\n * a b c d _ f COMMAND: DELETE 7;\n * e a b c d f COMMAND: INSERT 0 e;\n * c=3 is wrong as we are not tracking it, ergo we need to see if `i` is in range else drop it\n * @param i - The index to check\n * @returns True if the index is within a sliding window\n */\n public isIndexInRange(i: number): boolean {\n for (const r of this.list.ranges) {\n if (r[0] <= i && i <= r[1]) {\n return true;\n }\n }\n return false;\n }\n}\n\n/**\n * When onResponse extensions should be invoked: before or after processing the main response.\n */\nexport enum ExtensionState {\n // Call onResponse before processing the response body. This is useful when your extension is\n // preparing the ground for the response body e.g. processing to-device messages before the\n // encrypted event arrives.\n PreProcess = \"ExtState.PreProcess\",\n // Call onResponse after processing the response body. This is useful when your extension is\n // decorating data from the client, and you rely on MatrixClient.getRoom returning the Room object\n // e.g. room account data.\n PostProcess = \"ExtState.PostProcess\",\n}\n\n/**\n * An interface that must be satisfied to register extensions\n */\nexport interface Extension {\n /**\n * The extension name to go under 'extensions' in the request body.\n * @returns The JSON key.\n */\n name(): string;\n /**\n * A function which is called when the request JSON is being formed.\n * Returns the data to insert under this key.\n * @param isInitial - True when this is part of the initial request (send sticky params)\n * @returns The request JSON to send.\n */\n onRequest(isInitial: boolean): Req | undefined;\n /**\n * A function which is called when there is response JSON under this extension.\n * @param data - The response JSON under the extension name.\n */\n onResponse(data: Res): void;\n /**\n * Controls when onResponse should be called.\n * @returns The state when it should be called.\n */\n when(): ExtensionState;\n}\n\n/**\n * Events which can be fired by the SlidingSync class. These are designed to provide different levels\n * of information when processing sync responses.\n * - RoomData: concerns rooms, useful for SlidingSyncSdk to update its knowledge of rooms.\n * - Lifecycle: concerns callbacks at various well-defined points in the sync process.\n * - List: concerns lists, useful for UI layers to re-render room lists.\n * Specifically, the order of event invocation is:\n * - Lifecycle (state=RequestFinished)\n * - RoomData (N times)\n * - Lifecycle (state=Complete)\n * - List (at most once per list)\n */\nexport enum SlidingSyncEvent {\n /**\n * This event fires when there are updates for a room. Fired as and when rooms are encountered\n * in the response.\n */\n RoomData = \"SlidingSync.RoomData\",\n /**\n * This event fires at various points in the /sync loop lifecycle.\n * - SlidingSyncState.RequestFinished: Fires after we receive a valid response but before the\n * response has been processed. Perform any pre-process steps here. If there was a problem syncing,\n * `err` will be set (e.g network errors).\n * - SlidingSyncState.Complete: Fires after all SlidingSyncEvent.RoomData have been fired but before\n * SlidingSyncEvent.List.\n */\n Lifecycle = \"SlidingSync.Lifecycle\",\n /**\n * This event fires whenever there has been a change to this list index. It fires exactly once\n * per list, even if there were multiple operations for the list.\n * It fires AFTER Lifecycle and RoomData events.\n */\n List = \"SlidingSync.List\",\n}\n\nexport type SlidingSyncEventHandlerMap = {\n [SlidingSyncEvent.RoomData]: (roomId: string, roomData: MSC3575RoomData) => void;\n [SlidingSyncEvent.Lifecycle]: (\n state: SlidingSyncState,\n resp: MSC3575SlidingSyncResponse | null,\n err?: Error,\n ) => void;\n [SlidingSyncEvent.List]: (listKey: string, joinedCount: number, roomIndexToRoomId: Record) => void;\n};\n\n/**\n * SlidingSync is a high-level data structure which controls the majority of sliding sync.\n * It has no hooks into JS SDK except for needing a MatrixClient to perform the HTTP request.\n * This means this class (and everything it uses) can be used in isolation from JS SDK if needed.\n * To hook this up with the JS SDK, you need to use SlidingSyncSdk.\n */\nexport class SlidingSync extends TypedEventEmitter {\n private lists: Map;\n private listModifiedCount = 0;\n private terminated = false;\n // flag set when resend() is called because we cannot rely on detecting AbortError in JS SDK :(\n private needsResend = false;\n // the txn_id to send with the next request.\n private txnId: string | null = null;\n // a list (in chronological order of when they were sent) of objects containing the txn ID and\n // a defer to resolve/reject depending on whether they were successfully sent or not.\n private txnIdDefers: (IDeferred & { txnId: string })[] = [];\n // map of extension name to req/resp handler\n private extensions: Record> = {};\n\n private desiredRoomSubscriptions = new Set(); // the *desired* room subscriptions\n private confirmedRoomSubscriptions = new Set();\n\n // map of custom subscription name to the subscription\n private customSubscriptions: Map = new Map();\n // map of room ID to custom subscription name\n private roomIdToCustomSubscription: Map = new Map();\n\n private pendingReq?: Promise;\n private abortController?: AbortController;\n\n /**\n * Create a new sliding sync instance\n * @param proxyBaseUrl - The base URL of the sliding sync proxy\n * @param lists - The lists to use for sliding sync.\n * @param roomSubscriptionInfo - The params to use for room subscriptions.\n * @param client - The client to use for /sync calls.\n * @param timeoutMS - The number of milliseconds to wait for a response.\n */\n public constructor(\n private readonly proxyBaseUrl: string,\n lists: Map,\n private roomSubscriptionInfo: MSC3575RoomSubscription,\n private readonly client: MatrixClient,\n private readonly timeoutMS: number,\n ) {\n super();\n this.lists = new Map();\n lists.forEach((list, key) => {\n this.lists.set(key, new SlidingList(list));\n });\n }\n\n /**\n * Add a custom room subscription, referred to by an arbitrary name. If a subscription with this\n * name already exists, it is replaced. No requests are sent by calling this method.\n * @param name - The name of the subscription. Only used to reference this subscription in\n * useCustomSubscription.\n * @param sub - The subscription information.\n */\n public addCustomSubscription(name: string, sub: MSC3575RoomSubscription): void {\n if (this.customSubscriptions.has(name)) {\n logger.warn(`addCustomSubscription: ${name} already exists as a custom subscription, ignoring.`);\n return;\n }\n this.customSubscriptions.set(name, sub);\n }\n\n /**\n * Use a custom subscription previously added via addCustomSubscription. No requests are sent\n * by calling this method. Use modifyRoomSubscriptions to resend subscription information.\n * @param roomId - The room to use the subscription in.\n * @param name - The name of the subscription. If this name is unknown, the default subscription\n * will be used.\n */\n public useCustomSubscription(roomId: string, name: string): void {\n // We already know about this custom subscription, as it is immutable,\n // we don't need to unconfirm the subscription.\n if (this.roomIdToCustomSubscription.get(roomId) === name) {\n return;\n }\n this.roomIdToCustomSubscription.set(roomId, name);\n // unconfirm this subscription so a resend() will send it up afresh.\n this.confirmedRoomSubscriptions.delete(roomId);\n }\n\n /**\n * Get the room index data for a list.\n * @param key - The list key\n * @returns The list data which contains the rooms in this list\n */\n public getListData(key: string): { joinedCount: number; roomIndexToRoomId: Record } | null {\n const data = this.lists.get(key);\n if (!data) {\n return null;\n }\n return {\n joinedCount: data.joinedCount,\n roomIndexToRoomId: Object.assign({}, data.roomIndexToRoomId),\n };\n }\n\n /**\n * Get the full request list parameters for a list index. This function is provided for callers to use\n * in conjunction with setList to update fields on an existing list.\n * @param key - The list key to get the params for.\n * @returns A copy of the list params or undefined.\n */\n public getListParams(key: string): MSC3575List | null {\n const params = this.lists.get(key);\n if (!params) {\n return null;\n }\n return params.getList(true);\n }\n\n /**\n * Set new ranges for an existing list. Calling this function when _only_ the ranges have changed\n * is more efficient than calling setList(index,list) as this function won't resend sticky params,\n * whereas setList always will.\n * @param key - The list key to modify\n * @param ranges - The new ranges to apply.\n * @returns A promise which resolves to the transaction ID when it has been received down sync\n * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled\n * immediately after sending, in which case the action will be applied in the subsequent request)\n */\n public setListRanges(key: string, ranges: number[][]): Promise {\n const list = this.lists.get(key);\n if (!list) {\n return Promise.reject(new Error(\"no list with key \" + key));\n }\n list.updateListRange(ranges);\n return this.resend();\n }\n\n /**\n * Add or replace a list. Calling this function will interrupt the /sync request to resend new\n * lists.\n * @param key - The key to modify\n * @param list - The new list parameters.\n * @returns A promise which resolves to the transaction ID when it has been received down sync\n * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled\n * immediately after sending, in which case the action will be applied in the subsequent request)\n */\n public setList(key: string, list: MSC3575List): Promise {\n const existingList = this.lists.get(key);\n if (existingList) {\n existingList.replaceList(list);\n this.lists.set(key, existingList);\n } else {\n this.lists.set(key, new SlidingList(list));\n }\n this.listModifiedCount += 1;\n return this.resend();\n }\n\n /**\n * Get the room subscriptions for the sync API.\n * @returns A copy of the desired room subscriptions.\n */\n public getRoomSubscriptions(): Set {\n return new Set(Array.from(this.desiredRoomSubscriptions));\n }\n\n /**\n * Modify the room subscriptions for the sync API. Calling this function will interrupt the\n * /sync request to resend new subscriptions. If the /sync stream has not started, this will\n * prepare the room subscriptions for when start() is called.\n * @param s - The new desired room subscriptions.\n * @returns A promise which resolves to the transaction ID when it has been received down sync\n * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled\n * immediately after sending, in which case the action will be applied in the subsequent request)\n */\n public modifyRoomSubscriptions(s: Set): Promise {\n this.desiredRoomSubscriptions = s;\n return this.resend();\n }\n\n /**\n * Modify which events to retrieve for room subscriptions. Invalidates all room subscriptions\n * such that they will be sent up afresh.\n * @param rs - The new room subscription fields to fetch.\n * @returns A promise which resolves to the transaction ID when it has been received down sync\n * (or rejects with the transaction ID if the action was not applied e.g the request was cancelled\n * immediately after sending, in which case the action will be applied in the subsequent request)\n */\n public modifyRoomSubscriptionInfo(rs: MSC3575RoomSubscription): Promise {\n this.roomSubscriptionInfo = rs;\n this.confirmedRoomSubscriptions = new Set();\n return this.resend();\n }\n\n /**\n * Register an extension to send with the /sync request.\n * @param ext - The extension to register.\n */\n public registerExtension(ext: Extension): void {\n if (this.extensions[ext.name()]) {\n throw new Error(`registerExtension: ${ext.name()} already exists as an extension`);\n }\n this.extensions[ext.name()] = ext;\n }\n\n private getExtensionRequest(isInitial: boolean): Record {\n const ext: Record = {};\n Object.keys(this.extensions).forEach((extName) => {\n ext[extName] = this.extensions[extName].onRequest(isInitial);\n });\n return ext;\n }\n\n private onPreExtensionsResponse(ext: Record): void {\n Object.keys(ext).forEach((extName) => {\n if (this.extensions[extName].when() == ExtensionState.PreProcess) {\n this.extensions[extName].onResponse(ext[extName]);\n }\n });\n }\n\n private onPostExtensionsResponse(ext: Record): void {\n Object.keys(ext).forEach((extName) => {\n if (this.extensions[extName].when() == ExtensionState.PostProcess) {\n this.extensions[extName].onResponse(ext[extName]);\n }\n });\n }\n\n /**\n * Invoke all attached room data listeners.\n * @param roomId - The room which received some data.\n * @param roomData - The raw sliding sync response JSON.\n */\n private invokeRoomDataListeners(roomId: string, roomData: MSC3575RoomData): void {\n if (!roomData.required_state) {\n roomData.required_state = [];\n }\n if (!roomData.timeline) {\n roomData.timeline = [];\n }\n this.emit(SlidingSyncEvent.RoomData, roomId, roomData);\n }\n\n /**\n * Invoke all attached lifecycle listeners.\n * @param state - The Lifecycle state\n * @param resp - The raw sync response JSON\n * @param err - Any error that occurred when making the request e.g. network errors.\n */\n private invokeLifecycleListeners(\n state: SlidingSyncState,\n resp: MSC3575SlidingSyncResponse | null,\n err?: Error,\n ): void {\n this.emit(SlidingSyncEvent.Lifecycle, state, resp, err);\n }\n\n private shiftRight(listKey: string, hi: number, low: number): void {\n const list = this.lists.get(listKey);\n if (!list) {\n return;\n }\n // l h\n // 0,1,2,3,4 <- before\n // 0,1,2,2,3 <- after, hi is deleted and low is duplicated\n for (let i = hi; i > low; i--) {\n if (list.isIndexInRange(i)) {\n list.roomIndexToRoomId[i] = list.roomIndexToRoomId[i - 1];\n }\n }\n }\n\n private shiftLeft(listKey: string, hi: number, low: number): void {\n const list = this.lists.get(listKey);\n if (!list) {\n return;\n }\n // l h\n // 0,1,2,3,4 <- before\n // 0,1,3,4,4 <- after, low is deleted and hi is duplicated\n for (let i = low; i < hi; i++) {\n if (list.isIndexInRange(i)) {\n list.roomIndexToRoomId[i] = list.roomIndexToRoomId[i + 1];\n }\n }\n }\n\n private removeEntry(listKey: string, index: number): void {\n const list = this.lists.get(listKey);\n if (!list) {\n return;\n }\n // work out the max index\n let max = -1;\n for (const n in list.roomIndexToRoomId) {\n if (Number(n) > max) {\n max = Number(n);\n }\n }\n if (max < 0 || index > max) {\n return;\n }\n // Everything higher than the gap needs to be shifted left.\n this.shiftLeft(listKey, max, index);\n delete list.roomIndexToRoomId[max];\n }\n\n private addEntry(listKey: string, index: number): void {\n const list = this.lists.get(listKey);\n if (!list) {\n return;\n }\n // work out the max index\n let max = -1;\n for (const n in list.roomIndexToRoomId) {\n if (Number(n) > max) {\n max = Number(n);\n }\n }\n if (max < 0 || index > max) {\n return;\n }\n // Everything higher than the gap needs to be shifted right, +1 so we don't delete the highest element\n this.shiftRight(listKey, max + 1, index);\n }\n\n private processListOps(list: ListResponse, listKey: string): void {\n let gapIndex = -1;\n const listData = this.lists.get(listKey);\n if (!listData) {\n return;\n }\n list.ops.forEach((op: Operation) => {\n if (!listData) {\n return;\n }\n switch (op.op) {\n case \"DELETE\": {\n logger.debug(\"DELETE\", listKey, op.index, \";\");\n delete listData.roomIndexToRoomId[op.index];\n if (gapIndex !== -1) {\n // we already have a DELETE operation to process, so process it.\n this.removeEntry(listKey, gapIndex);\n }\n gapIndex = op.index;\n break;\n }\n case \"INSERT\": {\n logger.debug(\"INSERT\", listKey, op.index, op.room_id, \";\");\n if (listData.roomIndexToRoomId[op.index]) {\n // something is in this space, shift items out of the way\n if (gapIndex < 0) {\n // we haven't been told where to shift from, so make way for a new room entry.\n this.addEntry(listKey, op.index);\n } else if (gapIndex > op.index) {\n // the gap is further down the list, shift every element to the right\n // starting at the gap so we can just shift each element in turn:\n // [A,B,C,_] gapIndex=3, op.index=0\n // [A,B,C,C] i=3\n // [A,B,B,C] i=2\n // [A,A,B,C] i=1\n // Terminate. We'll assign into op.index next.\n this.shiftRight(listKey, gapIndex, op.index);\n } else if (gapIndex < op.index) {\n // the gap is further up the list, shift every element to the left\n // starting at the gap so we can just shift each element in turn\n this.shiftLeft(listKey, op.index, gapIndex);\n }\n }\n // forget the gap, we don't need it anymore. This is outside the check for\n // a room being present in this index position because INSERTs always universally\n // forget the gap, not conditionally based on the presence of a room in the INSERT\n // position. Without this, DELETE 0; INSERT 0; would do the wrong thing.\n gapIndex = -1;\n listData.roomIndexToRoomId[op.index] = op.room_id;\n break;\n }\n case \"INVALIDATE\": {\n const startIndex = op.range[0];\n for (let i = startIndex; i <= op.range[1]; i++) {\n delete listData.roomIndexToRoomId[i];\n }\n logger.debug(\"INVALIDATE\", listKey, op.range[0], op.range[1], \";\");\n break;\n }\n case \"SYNC\": {\n const startIndex = op.range[0];\n for (let i = startIndex; i <= op.range[1]; i++) {\n const roomId = op.room_ids[i - startIndex];\n if (!roomId) {\n break; // we are at the end of list\n }\n listData.roomIndexToRoomId[i] = roomId;\n }\n logger.debug(\"SYNC\", listKey, op.range[0], op.range[1], (op.room_ids || []).join(\" \"), \";\");\n break;\n }\n }\n });\n if (gapIndex !== -1) {\n // we already have a DELETE operation to process, so process it\n // Everything higher than the gap needs to be shifted left.\n this.removeEntry(listKey, gapIndex);\n }\n }\n\n /**\n * Resend a Sliding Sync request. Used when something has changed in the request. Resolves with\n * the transaction ID of this request on success. Rejects with the transaction ID of this request\n * on failure.\n */\n public resend(): Promise {\n if (this.needsResend && this.txnIdDefers.length > 0) {\n // we already have a resend queued, so just return the same promise\n return this.txnIdDefers[this.txnIdDefers.length - 1].promise;\n }\n this.needsResend = true;\n this.txnId = this.client.makeTxnId();\n const d = defer();\n this.txnIdDefers.push({\n ...d,\n txnId: this.txnId,\n });\n this.abortController?.abort();\n this.abortController = new AbortController();\n return d.promise;\n }\n\n private resolveTransactionDefers(txnId?: string): void {\n if (!txnId) {\n return;\n }\n // find the matching index\n let txnIndex = -1;\n for (let i = 0; i < this.txnIdDefers.length; i++) {\n if (this.txnIdDefers[i].txnId === txnId) {\n txnIndex = i;\n break;\n }\n }\n if (txnIndex === -1) {\n // this shouldn't happen; we shouldn't be seeing txn_ids for things we don't know about,\n // whine about it.\n logger.warn(`resolveTransactionDefers: seen ${txnId} but it isn't a pending txn, ignoring.`);\n return;\n }\n // This list is sorted in time, so if the input txnId ACKs in the middle of this array,\n // then everything before it that hasn't been ACKed yet never will and we should reject them.\n for (let i = 0; i < txnIndex; i++) {\n this.txnIdDefers[i].reject(this.txnIdDefers[i].txnId);\n }\n this.txnIdDefers[txnIndex].resolve(txnId);\n // clear out settled promises, including the one we resolved.\n this.txnIdDefers = this.txnIdDefers.slice(txnIndex + 1);\n }\n\n /**\n * Stop syncing with the server.\n */\n public stop(): void {\n this.terminated = true;\n this.abortController?.abort();\n // remove all listeners so things can be GC'd\n this.removeAllListeners(SlidingSyncEvent.Lifecycle);\n this.removeAllListeners(SlidingSyncEvent.List);\n this.removeAllListeners(SlidingSyncEvent.RoomData);\n }\n\n /**\n * Re-setup this connection e.g in the event of an expired session.\n */\n private resetup(): void {\n logger.warn(\"SlidingSync: resetting connection info\");\n // any pending txn ID defers will be forgotten already by the server, so clear them out\n this.txnIdDefers.forEach((d) => {\n d.reject(d.txnId);\n });\n this.txnIdDefers = [];\n // resend sticky params and de-confirm all subscriptions\n this.lists.forEach((l) => {\n l.setModified(true);\n });\n this.confirmedRoomSubscriptions = new Set(); // leave desired ones alone though!\n // reset the connection as we might be wedged\n this.needsResend = true;\n this.abortController?.abort();\n this.abortController = new AbortController();\n }\n\n /**\n * Start syncing with the server. Blocks until stopped.\n */\n public async start(): Promise {\n this.abortController = new AbortController();\n\n let currentPos: string | undefined;\n while (!this.terminated) {\n this.needsResend = false;\n let doNotUpdateList = false;\n let resp: MSC3575SlidingSyncResponse | undefined;\n try {\n const listModifiedCount = this.listModifiedCount;\n const reqLists: Record = {};\n this.lists.forEach((l: SlidingList, key: string) => {\n reqLists[key] = l.getList(false);\n });\n const reqBody: MSC3575SlidingSyncRequest = {\n lists: reqLists,\n pos: currentPos,\n timeout: this.timeoutMS,\n clientTimeout: this.timeoutMS + BUFFER_PERIOD_MS,\n extensions: this.getExtensionRequest(currentPos === undefined),\n };\n // check if we are (un)subscribing to a room and modify request this one time for it\n const newSubscriptions = difference(this.desiredRoomSubscriptions, this.confirmedRoomSubscriptions);\n const unsubscriptions = difference(this.confirmedRoomSubscriptions, this.desiredRoomSubscriptions);\n if (unsubscriptions.size > 0) {\n reqBody.unsubscribe_rooms = Array.from(unsubscriptions);\n }\n if (newSubscriptions.size > 0) {\n reqBody.room_subscriptions = {};\n for (const roomId of newSubscriptions) {\n const customSubName = this.roomIdToCustomSubscription.get(roomId);\n let sub = this.roomSubscriptionInfo;\n if (customSubName && this.customSubscriptions.has(customSubName)) {\n sub = this.customSubscriptions.get(customSubName)!;\n }\n reqBody.room_subscriptions[roomId] = sub;\n }\n }\n if (this.txnId) {\n reqBody.txn_id = this.txnId;\n this.txnId = null;\n }\n this.pendingReq = this.client.slidingSync(reqBody, this.proxyBaseUrl, this.abortController.signal);\n resp = await this.pendingReq;\n currentPos = resp.pos;\n // update what we think we're subscribed to.\n for (const roomId of newSubscriptions) {\n this.confirmedRoomSubscriptions.add(roomId);\n }\n for (const roomId of unsubscriptions) {\n this.confirmedRoomSubscriptions.delete(roomId);\n }\n if (listModifiedCount !== this.listModifiedCount) {\n // the lists have been modified whilst we were waiting for 'await' to return, but the abort()\n // call did nothing. It is NOT SAFE to modify the list array now. We'll process the response but\n // not update list pointers.\n logger.debug(\"list modified during await call, not updating list\");\n doNotUpdateList = true;\n }\n // mark all these lists as having been sent as sticky so we don't keep sending sticky params\n this.lists.forEach((l) => {\n l.setModified(false);\n });\n // set default empty values so we don't need to null check\n resp.lists = resp.lists || {};\n resp.rooms = resp.rooms || {};\n resp.extensions = resp.extensions || {};\n Object.keys(resp.lists).forEach((key: string) => {\n const list = this.lists.get(key);\n if (!list || !resp) {\n return;\n }\n list.joinedCount = resp.lists[key].count;\n });\n this.invokeLifecycleListeners(SlidingSyncState.RequestFinished, resp);\n } catch (err) {\n if ((err).httpStatus) {\n this.invokeLifecycleListeners(SlidingSyncState.RequestFinished, null, err);\n if ((err).httpStatus === 400) {\n // session probably expired TODO: assign an errcode\n // so drop state and re-request\n this.resetup();\n currentPos = undefined;\n await sleep(50); // in case the 400 was for something else; don't tightloop\n continue;\n } // else fallthrough to generic error handling\n } else if (this.needsResend || (err).name === \"AbortError\") {\n continue; // don't sleep as we caused this error by abort()ing the request.\n }\n logger.error(err);\n await sleep(5000);\n }\n if (!resp) {\n continue;\n }\n this.onPreExtensionsResponse(resp.extensions);\n\n Object.keys(resp.rooms).forEach((roomId) => {\n this.invokeRoomDataListeners(roomId, resp!.rooms[roomId]);\n });\n\n const listKeysWithUpdates: Set = new Set();\n if (!doNotUpdateList) {\n for (const [key, list] of Object.entries(resp.lists)) {\n list.ops = list.ops || [];\n if (list.ops.length > 0) {\n listKeysWithUpdates.add(key);\n }\n this.processListOps(list, key);\n }\n }\n this.invokeLifecycleListeners(SlidingSyncState.Complete, resp);\n this.onPostExtensionsResponse(resp.extensions);\n listKeysWithUpdates.forEach((listKey: string) => {\n const list = this.lists.get(listKey);\n if (!list) {\n return;\n }\n this.emit(SlidingSyncEvent.List, listKey, list.joinedCount, Object.assign({}, list.roomIndexToRoomId));\n });\n\n this.resolveTransactionDefers(resp.txn_id);\n }\n }\n}\n\nconst difference = (setA: Set, setB: Set): Set => {\n const diff = new Set(setA);\n for (const elem of setB) {\n diff.delete(elem);\n }\n return diff;\n};\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts deleted file mode 100644 index 5e45739..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts +++ /dev/null @@ -1,191 +0,0 @@ -import { EventType } from "../@types/event"; -import { Room } from "../models/room"; -import { User } from "../models/user"; -import { IEvent, MatrixEvent } from "../models/event"; -import { Filter } from "../filter"; -import { RoomSummary } from "../models/room-summary"; -import { IMinimalEvent, IRooms, ISyncResponse } from "../sync-accumulator"; -import { IStartClientOpts } from "../client"; -import { IStateEventWithRoomId } from "../@types/search"; -import { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from "../models/ToDeviceMessage"; -import { EventEmitterEvents } from "../models/typed-event-emitter"; -export interface ISavedSync { - nextBatch: string; - roomsData: IRooms; - accountData: IMinimalEvent[]; -} -/** - * A store for most of the data js-sdk needs to store, apart from crypto data - */ -export interface IStore { - readonly accountData: Map; - on?: (event: EventEmitterEvents | "degraded" | "closed", handler: (...args: any[]) => void) => void; - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated(): Promise; - /** - * Get the sync token. - */ - getSyncToken(): string | null; - /** - * Set the sync token. - */ - setSyncToken(token: string): void; - /** - * Store the given room. - * @param room - The room to be stored. All properties must be stored. - */ - storeRoom(room: Room): void; - /** - * Retrieve a room by its' room ID. - * @param roomId - The room ID. - * @returns The room or null. - */ - getRoom(roomId: string): Room | null; - /** - * Retrieve all known rooms. - * @returns A list of rooms, which may be empty. - */ - getRooms(): Room[]; - /** - * Permanently delete a room. - */ - removeRoom(roomId: string): void; - /** - * Retrieve a summary of all the rooms. - * @returns A summary of each room. - */ - getRoomSummaries(): RoomSummary[]; - /** - * Store a User. - * @param user - The user to store. - */ - storeUser(user: User): void; - /** - * Retrieve a User by its' user ID. - * @param userId - The user ID. - * @returns The user or null. - */ - getUser(userId: string): User | null; - /** - * Retrieve all known users. - * @returns A list of users, which may be empty. - */ - getUsers(): User[]; - /** - * Retrieve scrollback for this room. - * @param room - The matrix room - * @param limit - The max number of old events to retrieve. - * @returns An array of objects which will be at most 'limit' - * length and at least 0. The objects are the raw event JSON. - */ - scrollback(room: Room, limit: number): MatrixEvent[]; - /** - * Store events for a room. - * @param room - The room to store events for. - * @param events - The events to store. - * @param token - The token associated with these events. - * @param toStart - True if these are paginated results. - */ - storeEvents(room: Room, events: MatrixEvent[], token: string | null, toStart: boolean): void; - /** - * Store a filter. - */ - storeFilter(filter: Filter): void; - /** - * Retrieve a filter. - * @returns A filter or null. - */ - getFilter(userId: string, filterId: string): Filter | null; - /** - * Retrieve a filter ID with the given name. - * @param filterName - The filter name. - * @returns The filter ID or null. - */ - getFilterIdByName(filterName: string): string | null; - /** - * Set a filter name to ID mapping. - */ - setFilterIdByName(filterName: string, filterId?: string): void; - /** - * Store user-scoped account data events - * @param events - The events to store. - */ - storeAccountDataEvents(events: MatrixEvent[]): void; - /** - * Get account data event by event type - * @param eventType - The event type being queried - */ - getAccountData(eventType: EventType | string): MatrixEvent | undefined; - /** - * setSyncData does nothing as there is no backing data store. - * - * @param syncData - The sync data - * @returns An immediately resolved promise. - */ - setSyncData(syncData: ISyncResponse): Promise; - /** - * We never want to save because we have nothing to save to. - * - * @returns If the store wants to save - */ - wantsSave(): boolean; - /** - * Save does nothing as there is no backing data store. - */ - save(force?: boolean): void; - /** - * Startup does nothing. - * @returns An immediately resolved promise. - */ - startup(): Promise; - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync(): Promise; - /** - * @returns If there is a saved sync, the nextBatch token - * for this sync, otherwise null. - */ - getSavedSyncToken(): Promise; - /** - * Delete all data from this store. Does nothing since this store - * doesn't store anything. - * @returns An immediately resolved promise. - */ - deleteAllData(): Promise; - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers(roomId: string): Promise; - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - * @returns when all members have been stored - */ - setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise; - clearOutOfBandMembers(roomId: string): Promise; - getClientOptions(): Promise; - storeClientOptions(options: IStartClientOpts): Promise; - getPendingEvents(roomId: string): Promise[]>; - setPendingEvents(roomId: string, events: Partial[]): Promise; - /** - * Stores batches of outgoing to-device messages - */ - saveToDeviceBatches(batch: ToDeviceBatchWithTxnId[]): Promise; - /** - * Fetches the oldest batch of to-device messages in the queue - */ - getOldestToDeviceBatch(): Promise; - /** - * Removes a specific batch of to-device messages from the queue - */ - removeToDeviceBatch(id: number): Promise; -} -//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts.map deleted file mode 100644 index 91540d2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/store/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js deleted file mode 100644 index 951c783..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js.map deleted file mode 100644 index 5c2a9a3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","names":[],"sources":["../../src/store/index.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { EventType } from \"../@types/event\";\nimport { Room } from \"../models/room\";\nimport { User } from \"../models/user\";\nimport { IEvent, MatrixEvent } from \"../models/event\";\nimport { Filter } from \"../filter\";\nimport { RoomSummary } from \"../models/room-summary\";\nimport { IMinimalEvent, IRooms, ISyncResponse } from \"../sync-accumulator\";\nimport { IStartClientOpts } from \"../client\";\nimport { IStateEventWithRoomId } from \"../@types/search\";\nimport { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from \"../models/ToDeviceMessage\";\nimport { EventEmitterEvents } from \"../models/typed-event-emitter\";\n\nexport interface ISavedSync {\n nextBatch: string;\n roomsData: IRooms;\n accountData: IMinimalEvent[];\n}\n\n/**\n * A store for most of the data js-sdk needs to store, apart from crypto data\n */\nexport interface IStore {\n readonly accountData: Map; // type : content\n\n // XXX: The indexeddb store exposes a non-standard emitter for:\n // \"degraded\" event for when it falls back to being a memory store due to errors.\n // \"closed\" event for when the database closes unexpectedly\n on?: (event: EventEmitterEvents | \"degraded\" | \"closed\", handler: (...args: any[]) => void) => void;\n\n /** @returns whether or not the database was newly created in this session. */\n isNewlyCreated(): Promise;\n\n /**\n * Get the sync token.\n */\n getSyncToken(): string | null;\n\n /**\n * Set the sync token.\n */\n setSyncToken(token: string): void;\n\n /**\n * Store the given room.\n * @param room - The room to be stored. All properties must be stored.\n */\n storeRoom(room: Room): void;\n\n /**\n * Retrieve a room by its' room ID.\n * @param roomId - The room ID.\n * @returns The room or null.\n */\n getRoom(roomId: string): Room | null;\n\n /**\n * Retrieve all known rooms.\n * @returns A list of rooms, which may be empty.\n */\n getRooms(): Room[];\n\n /**\n * Permanently delete a room.\n */\n removeRoom(roomId: string): void;\n\n /**\n * Retrieve a summary of all the rooms.\n * @returns A summary of each room.\n */\n getRoomSummaries(): RoomSummary[];\n\n /**\n * Store a User.\n * @param user - The user to store.\n */\n storeUser(user: User): void;\n\n /**\n * Retrieve a User by its' user ID.\n * @param userId - The user ID.\n * @returns The user or null.\n */\n getUser(userId: string): User | null;\n\n /**\n * Retrieve all known users.\n * @returns A list of users, which may be empty.\n */\n getUsers(): User[];\n\n /**\n * Retrieve scrollback for this room.\n * @param room - The matrix room\n * @param limit - The max number of old events to retrieve.\n * @returns An array of objects which will be at most 'limit'\n * length and at least 0. The objects are the raw event JSON.\n */\n scrollback(room: Room, limit: number): MatrixEvent[];\n\n /**\n * Store events for a room.\n * @param room - The room to store events for.\n * @param events - The events to store.\n * @param token - The token associated with these events.\n * @param toStart - True if these are paginated results.\n */\n storeEvents(room: Room, events: MatrixEvent[], token: string | null, toStart: boolean): void;\n\n /**\n * Store a filter.\n */\n storeFilter(filter: Filter): void;\n\n /**\n * Retrieve a filter.\n * @returns A filter or null.\n */\n getFilter(userId: string, filterId: string): Filter | null;\n\n /**\n * Retrieve a filter ID with the given name.\n * @param filterName - The filter name.\n * @returns The filter ID or null.\n */\n getFilterIdByName(filterName: string): string | null;\n\n /**\n * Set a filter name to ID mapping.\n */\n setFilterIdByName(filterName: string, filterId?: string): void;\n\n /**\n * Store user-scoped account data events\n * @param events - The events to store.\n */\n storeAccountDataEvents(events: MatrixEvent[]): void;\n\n /**\n * Get account data event by event type\n * @param eventType - The event type being queried\n */\n getAccountData(eventType: EventType | string): MatrixEvent | undefined;\n\n /**\n * setSyncData does nothing as there is no backing data store.\n *\n * @param syncData - The sync data\n * @returns An immediately resolved promise.\n */\n setSyncData(syncData: ISyncResponse): Promise;\n\n /**\n * We never want to save because we have nothing to save to.\n *\n * @returns If the store wants to save\n */\n wantsSave(): boolean;\n\n /**\n * Save does nothing as there is no backing data store.\n */\n save(force?: boolean): void;\n\n /**\n * Startup does nothing.\n * @returns An immediately resolved promise.\n */\n startup(): Promise;\n\n /**\n * @returns Promise which resolves with a sync response to restore the\n * client state to where it was at the last save, or null if there\n * is no saved sync data.\n */\n getSavedSync(): Promise;\n\n /**\n * @returns If there is a saved sync, the nextBatch token\n * for this sync, otherwise null.\n */\n getSavedSyncToken(): Promise;\n\n /**\n * Delete all data from this store. Does nothing since this store\n * doesn't store anything.\n * @returns An immediately resolved promise.\n */\n deleteAllData(): Promise;\n\n /**\n * Returns the out-of-band membership events for this room that\n * were previously loaded.\n * @returns the events, potentially an empty array if OOB loading didn't yield any new members\n * @returns in case the members for this room haven't been stored yet\n */\n getOutOfBandMembers(roomId: string): Promise;\n\n /**\n * Stores the out-of-band membership events for this room. Note that\n * it still makes sense to store an empty array as the OOB status for the room is\n * marked as fetched, and getOutOfBandMembers will return an empty array instead of null\n * @param membershipEvents - the membership events to store\n * @returns when all members have been stored\n */\n setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise;\n\n clearOutOfBandMembers(roomId: string): Promise;\n\n getClientOptions(): Promise;\n\n storeClientOptions(options: IStartClientOpts): Promise;\n\n getPendingEvents(roomId: string): Promise[]>;\n\n setPendingEvents(roomId: string, events: Partial[]): Promise;\n\n /**\n * Stores batches of outgoing to-device messages\n */\n saveToDeviceBatches(batch: ToDeviceBatchWithTxnId[]): Promise;\n\n /**\n * Fetches the oldest batch of to-device messages in the queue\n */\n getOldestToDeviceBatch(): Promise;\n\n /**\n * Removes a specific batch of to-device messages from the queue\n */\n removeToDeviceBatch(id: number): Promise;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts deleted file mode 100644 index d0cefc5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts +++ /dev/null @@ -1,23 +0,0 @@ -import { ISavedSync } from "./index"; -import { IEvent, IStateEventWithRoomId, IStoredClientOpts, ISyncResponse } from "../matrix"; -import { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from "../models/ToDeviceMessage"; -export interface IIndexedDBBackend { - connect(onClose?: () => void): Promise; - syncToDatabase(userTuples: UserTuple[]): Promise; - isNewlyCreated(): Promise; - setSyncData(syncData: ISyncResponse): Promise; - getSavedSync(): Promise; - getNextBatchToken(): Promise; - clearDatabase(): Promise; - getOutOfBandMembers(roomId: string): Promise; - setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise; - clearOutOfBandMembers(roomId: string): Promise; - getUserPresenceEvents(): Promise; - getClientOptions(): Promise; - storeClientOptions(options: IStoredClientOpts): Promise; - saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise; - getOldestToDeviceBatch(): Promise; - removeToDeviceBatch(id: number): Promise; -} -export type UserTuple = [userId: string, presenceEvent: Partial]; -//# sourceMappingURL=indexeddb-backend.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts.map deleted file mode 100644 index 4d4b679..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-backend.d.ts","sourceRoot":"","sources":["../../src/store/indexeddb-backend.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC5F,OAAO,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAEzF,MAAM,WAAW,iBAAiB;IAC9B,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7C,cAAc,CAAC,UAAU,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACvD,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IACnC,WAAW,CAAC,QAAQ,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpD,YAAY,IAAI,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IAC3C,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;IACrC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,EAAE,GAAG,IAAI,CAAC,CAAC;IAC7E,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9F,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,qBAAqB,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;IAC9C,gBAAgB,IAAI,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CAAC;IAC3D,kBAAkB,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9D,mBAAmB,CAAC,OAAO,EAAE,sBAAsB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACtE,sBAAsB,IAAI,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC,CAAC;IAC/D,mBAAmB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAClD;AAED,MAAM,MAAM,SAAS,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js deleted file mode 100644 index aeb3a9a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=indexeddb-backend.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js.map deleted file mode 100644 index 250db4a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-backend.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-backend.js","names":[],"sources":["../../src/store/indexeddb-backend.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ISavedSync } from \"./index\";\nimport { IEvent, IStateEventWithRoomId, IStoredClientOpts, ISyncResponse } from \"../matrix\";\nimport { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from \"../models/ToDeviceMessage\";\n\nexport interface IIndexedDBBackend {\n connect(onClose?: () => void): Promise;\n syncToDatabase(userTuples: UserTuple[]): Promise;\n isNewlyCreated(): Promise;\n setSyncData(syncData: ISyncResponse): Promise;\n getSavedSync(): Promise;\n getNextBatchToken(): Promise;\n clearDatabase(): Promise;\n getOutOfBandMembers(roomId: string): Promise;\n setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise;\n clearOutOfBandMembers(roomId: string): Promise;\n getUserPresenceEvents(): Promise;\n getClientOptions(): Promise;\n storeClientOptions(options: IStoredClientOpts): Promise;\n saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise;\n getOldestToDeviceBatch(): Promise;\n removeToDeviceBatch(id: number): Promise;\n}\n\nexport type UserTuple = [userId: string, presenceEvent: Partial];\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts deleted file mode 100644 index 56fa177..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts +++ /dev/null @@ -1,128 +0,0 @@ -import { ISyncResponse } from "../sync-accumulator"; -import { IStateEventWithRoomId, IStoredClientOpts } from "../matrix"; -import { ISavedSync } from "./index"; -import { IIndexedDBBackend, UserTuple } from "./indexeddb-backend"; -import { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from "../models/ToDeviceMessage"; -export declare class LocalIndexedDBStoreBackend implements IIndexedDBBackend { - private readonly indexedDB; - static exists(indexedDB: IDBFactory, dbName: string): Promise; - private readonly dbName; - private readonly syncAccumulator; - private db?; - private disconnected; - private _isNewlyCreated; - private syncToDatabasePromise?; - private pendingUserPresenceData; - /** - * Does the actual reading from and writing to the indexeddb - * - * Construct a new Indexed Database store backend. This requires a call to - * `connect()` before this store can be used. - * @param indexedDB - The Indexed DB interface e.g - * `window.indexedDB` - * @param dbName - Optional database name. The same name must be used - * to open the same database. - */ - constructor(indexedDB: IDBFactory, dbName?: string); - /** - * Attempt to connect to the database. This can fail if the user does not - * grant permission. - * @returns Promise which resolves if successfully connected. - */ - connect(onClose?: () => void): Promise; - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated(): Promise; - /** - * Having connected, load initial data from the database and prepare for use - * @returns Promise which resolves on success - */ - private init; - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers(roomId: string): Promise; - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - */ - setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise; - clearOutOfBandMembers(roomId: string): Promise; - /** - * Clear the entire database. This should be used when logging out of a client - * to prevent mixing data between accounts. - * @returns Resolved when the database is cleared. - */ - clearDatabase(): Promise; - /** - * @param copy - If false, the data returned is from internal - * buffers and must not be mutated. Otherwise, a copy is made before - * returning such that the data can be safely mutated. Default: true. - * - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync(copy?: boolean): Promise; - getNextBatchToken(): Promise; - setSyncData(syncData: ISyncResponse): Promise; - /** - * Sync users and all accumulated sync data to the database. - * If a previous sync is in flight, the new data will be added to the - * next sync and the current sync's promise will be returned. - * @param userTuples - The user tuples - * @returns Promise which resolves if the data was persisted. - */ - syncToDatabase(userTuples: UserTuple[]): Promise; - private doSyncToDatabase; - /** - * Persist rooms /sync data along with the next batch token. - * @param nextBatch - The next_batch /sync value. - * @param roomsData - The 'rooms' /sync data from a SyncAccumulator - * @returns Promise which resolves if the data was persisted. - */ - private persistSyncData; - /** - * Persist a list of account data events. Events with the same 'type' will - * be replaced. - * @param accountData - An array of raw user-scoped account data events - * @returns Promise which resolves if the events were persisted. - */ - private persistAccountData; - /** - * Persist a list of [user id, presence event] they are for. - * Users with the same 'userId' will be replaced. - * Presence events should be the event in its raw form (not the Event - * object) - * @param tuples - An array of [userid, event] tuples - * @returns Promise which resolves if the users were persisted. - */ - private persistUserPresenceEvents; - /** - * Load all user presence events from the database. This is not cached. - * FIXME: It would probably be more sensible to store the events in the - * sync. - * @returns A list of presence events in their raw form. - */ - getUserPresenceEvents(): Promise; - /** - * Load all the account data events from the database. This is not cached. - * @returns A list of raw global account events. - */ - private loadAccountData; - /** - * Load the sync data from the database. - * @returns An object with "roomsData" and "nextBatch" keys. - */ - private loadSyncData; - getClientOptions(): Promise; - storeClientOptions(options: IStoredClientOpts): Promise; - saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise; - getOldestToDeviceBatch(): Promise; - removeToDeviceBatch(id: number): Promise; -} -//# sourceMappingURL=indexeddb-local-backend.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts.map deleted file mode 100644 index a0bb8fe..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-local-backend.d.ts","sourceRoot":"","sources":["../../src/store/indexeddb-local-backend.ts"],"names":[],"mappings":"AAgBA,OAAO,EAA4B,aAAa,EAAmB,MAAM,qBAAqB,CAAC;AAI/F,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AACrE,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAkGzF,qBAAa,0BAA2B,YAAW,iBAAiB;IAwB7C,OAAO,CAAC,QAAQ,CAAC,SAAS;WAvB/B,MAAM,CAAC,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAK7E,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAkB;IAClD,OAAO,CAAC,EAAE,CAAC,CAAc;IACzB,OAAO,CAAC,YAAY,CAAQ;IAC5B,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,qBAAqB,CAAC,CAAgB;IAC9C,OAAO,CAAC,uBAAuB,CAAmB;IAElD;;;;;;;;;OASG;gBACiC,SAAS,EAAE,UAAU,EAAE,MAAM,SAAY;IAK7E;;;;OAIG;IACI,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAkDnD,8EAA8E;IACvE,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC;IAIzC;;;OAGG;IACH,OAAO,CAAC,IAAI;IAgBZ;;;;;OAKG;IACI,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,EAAE,GAAG,IAAI,CAAC;IA0CnF;;;;;OAKG;IACU,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAsB7F,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAgCjE;;;;OAIG;IACI,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAwBrC;;;;;;;;OAQG;IACI,YAAY,CAAC,IAAI,UAAO,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAYrD,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC;IAIpC,WAAW,CAAC,QAAQ,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAM1D;;;;;;OAMG;IACU,cAAc,CAAC,UAAU,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;YAWrD,gBAAgB;IAa9B;;;;;OAKG;IACH,OAAO,CAAC,eAAe;IAgBvB;;;;;OAKG;IACH,OAAO,CAAC,kBAAkB;IAW1B;;;;;;;OAOG;IACH,OAAO,CAAC,yBAAyB;IAcjC;;;;;OAKG;IACI,qBAAqB,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAUpD;;;OAGG;IACH,OAAO,CAAC,eAAe;IAcvB;;;OAGG;IACH,OAAO,CAAC,YAAY;IAiBb,gBAAgB,IAAI,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC;IAUpD,kBAAkB,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAU7D,mBAAmB,CAAC,OAAO,EAAE,sBAAsB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IASrE,sBAAsB,IAAI,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC;IAgB9D,mBAAmB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAM9D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js deleted file mode 100644 index ebedef3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js +++ /dev/null @@ -1,568 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.LocalIndexedDBStoreBackend = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _syncAccumulator = require("../sync-accumulator"); -var utils = _interopRequireWildcard(require("../utils")); -var IndexedDBHelpers = _interopRequireWildcard(require("../indexeddb-helpers")); -var _logger = require("../logger"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -/* -Copyright 2017 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const DB_MIGRATIONS = [db => { - // Make user store, clobber based on user ID. (userId property of User objects) - db.createObjectStore("users", { - keyPath: ["userId"] - }); - - // Make account data store, clobber based on event type. - // (event.type property of MatrixEvent objects) - db.createObjectStore("accountData", { - keyPath: ["type"] - }); - - // Make /sync store (sync tokens, room data, etc), always clobber (const key). - db.createObjectStore("sync", { - keyPath: ["clobber"] - }); -}, db => { - const oobMembersStore = db.createObjectStore("oob_membership_events", { - keyPath: ["room_id", "state_key"] - }); - oobMembersStore.createIndex("room", "room_id"); -}, db => { - db.createObjectStore("client_options", { - keyPath: ["clobber"] - }); -}, db => { - db.createObjectStore("to_device_queue", { - autoIncrement: true - }); -} -// Expand as needed. -]; - -const VERSION = DB_MIGRATIONS.length; - -/** - * Helper method to collect results from a Cursor and promiseify it. - * @param store - The store to perform openCursor on. - * @param keyRange - Optional key range to apply on the cursor. - * @param resultMapper - A function which is repeatedly called with a - * Cursor. - * Return the data you want to keep. - * @returns Promise which resolves to an array of whatever you returned from - * resultMapper. - */ -function selectQuery(store, keyRange, resultMapper) { - const query = store.openCursor(keyRange); - return new Promise((resolve, reject) => { - const results = []; - query.onerror = () => { - reject(new Error("Query failed: " + query.error)); - }; - // collect results - query.onsuccess = () => { - const cursor = query.result; - if (!cursor) { - resolve(results); - return; // end of results - } - - results.push(resultMapper(cursor)); - cursor.continue(); - }; - }); -} -function txnAsPromise(txn) { - return new Promise((resolve, reject) => { - txn.oncomplete = function (event) { - resolve(event); - }; - txn.onerror = function () { - reject(txn.error); - }; - }); -} -function reqAsEventPromise(req) { - return new Promise((resolve, reject) => { - req.onsuccess = function (event) { - resolve(event); - }; - req.onerror = function () { - reject(req.error); - }; - }); -} -function reqAsPromise(req) { - return new Promise((resolve, reject) => { - req.onsuccess = () => resolve(req); - req.onerror = err => reject(err); - }); -} -function reqAsCursorPromise(req) { - return reqAsEventPromise(req).then(event => req.result); -} -class LocalIndexedDBStoreBackend { - static exists(indexedDB, dbName) { - dbName = "matrix-js-sdk:" + (dbName || "default"); - return IndexedDBHelpers.exists(indexedDB, dbName); - } - /** - * Does the actual reading from and writing to the indexeddb - * - * Construct a new Indexed Database store backend. This requires a call to - * `connect()` before this store can be used. - * @param indexedDB - The Indexed DB interface e.g - * `window.indexedDB` - * @param dbName - Optional database name. The same name must be used - * to open the same database. - */ - constructor(indexedDB, dbName = "default") { - this.indexedDB = indexedDB; - (0, _defineProperty2.default)(this, "dbName", void 0); - (0, _defineProperty2.default)(this, "syncAccumulator", void 0); - (0, _defineProperty2.default)(this, "db", void 0); - (0, _defineProperty2.default)(this, "disconnected", true); - (0, _defineProperty2.default)(this, "_isNewlyCreated", false); - (0, _defineProperty2.default)(this, "syncToDatabasePromise", void 0); - (0, _defineProperty2.default)(this, "pendingUserPresenceData", []); - this.dbName = "matrix-js-sdk:" + dbName; - this.syncAccumulator = new _syncAccumulator.SyncAccumulator(); - } - - /** - * Attempt to connect to the database. This can fail if the user does not - * grant permission. - * @returns Promise which resolves if successfully connected. - */ - connect(onClose) { - if (!this.disconnected) { - _logger.logger.log(`LocalIndexedDBStoreBackend.connect: already connected or connecting`); - return Promise.resolve(); - } - this.disconnected = false; - _logger.logger.log(`LocalIndexedDBStoreBackend.connect: connecting...`); - const req = this.indexedDB.open(this.dbName, VERSION); - req.onupgradeneeded = ev => { - const db = req.result; - const oldVersion = ev.oldVersion; - _logger.logger.log(`LocalIndexedDBStoreBackend.connect: upgrading from ${oldVersion}`); - if (oldVersion < 1) { - // The database did not previously exist - this._isNewlyCreated = true; - } - DB_MIGRATIONS.forEach((migration, index) => { - if (oldVersion <= index) migration(db); - }); - }; - req.onblocked = () => { - _logger.logger.log(`can't yet open LocalIndexedDBStoreBackend because it is open elsewhere`); - }; - _logger.logger.log(`LocalIndexedDBStoreBackend.connect: awaiting connection...`); - return reqAsEventPromise(req).then(async () => { - _logger.logger.log(`LocalIndexedDBStoreBackend.connect: connected`); - this.db = req.result; - - // add a poorly-named listener for when deleteDatabase is called - // so we can close our db connections. - this.db.onversionchange = () => { - var _this$db; - (_this$db = this.db) === null || _this$db === void 0 ? void 0 : _this$db.close(); // this does not call onclose - this.disconnected = true; - this.db = undefined; - onClose === null || onClose === void 0 ? void 0 : onClose(); - }; - this.db.onclose = () => { - this.disconnected = true; - this.db = undefined; - onClose === null || onClose === void 0 ? void 0 : onClose(); - }; - await this.init(); - }); - } - - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated() { - return Promise.resolve(this._isNewlyCreated); - } - - /** - * Having connected, load initial data from the database and prepare for use - * @returns Promise which resolves on success - */ - init() { - return Promise.all([this.loadAccountData(), this.loadSyncData()]).then(([accountData, syncData]) => { - _logger.logger.log(`LocalIndexedDBStoreBackend: loaded initial data`); - this.syncAccumulator.accumulate({ - next_batch: syncData.nextBatch, - rooms: syncData.roomsData, - account_data: { - events: accountData - } - }, true); - }); - } - - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers(roomId) { - return new Promise((resolve, reject) => { - const tx = this.db.transaction(["oob_membership_events"], "readonly"); - const store = tx.objectStore("oob_membership_events"); - const roomIndex = store.index("room"); - const range = IDBKeyRange.only(roomId); - const request = roomIndex.openCursor(range); - const membershipEvents = []; - // did we encounter the oob_written marker object - // amongst the results? That means OOB member - // loading already happened for this room - // but there were no members to persist as they - // were all known already - let oobWritten = false; - request.onsuccess = () => { - const cursor = request.result; - if (!cursor) { - // Unknown room - if (!membershipEvents.length && !oobWritten) { - return resolve(null); - } - return resolve(membershipEvents); - } - const record = cursor.value; - if (record.oob_written) { - oobWritten = true; - } else { - membershipEvents.push(record); - } - cursor.continue(); - }; - request.onerror = err => { - reject(err); - }; - }).then(events => { - _logger.logger.log(`LL: got ${events === null || events === void 0 ? void 0 : events.length} membershipEvents from storage for room ${roomId} ...`); - return events; - }); - } - - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - */ - async setOutOfBandMembers(roomId, membershipEvents) { - _logger.logger.log(`LL: backend about to store ${membershipEvents.length}` + ` members for ${roomId}`); - const tx = this.db.transaction(["oob_membership_events"], "readwrite"); - const store = tx.objectStore("oob_membership_events"); - membershipEvents.forEach(e => { - store.put(e); - }); - // aside from all the events, we also write a marker object to the store - // to mark the fact that OOB members have been written for this room. - // It's possible that 0 members need to be written as all where previously know - // but we still need to know whether to return null or [] from getOutOfBandMembers - // where null means out of band members haven't been stored yet for this room - const markerObject = { - room_id: roomId, - oob_written: true, - state_key: 0 - }; - store.put(markerObject); - await txnAsPromise(tx); - _logger.logger.log(`LL: backend done storing for ${roomId}!`); - } - async clearOutOfBandMembers(roomId) { - // the approach to delete all members for a room - // is to get the min and max state key from the index - // for that room, and then delete between those - // keys in the store. - // this should be way faster than deleting every member - // individually for a large room. - const readTx = this.db.transaction(["oob_membership_events"], "readonly"); - const store = readTx.objectStore("oob_membership_events"); - const roomIndex = store.index("room"); - const roomRange = IDBKeyRange.only(roomId); - const minStateKeyProm = reqAsCursorPromise(roomIndex.openKeyCursor(roomRange, "next")).then(cursor => (cursor === null || cursor === void 0 ? void 0 : cursor.primaryKey)[1]); - const maxStateKeyProm = reqAsCursorPromise(roomIndex.openKeyCursor(roomRange, "prev")).then(cursor => (cursor === null || cursor === void 0 ? void 0 : cursor.primaryKey)[1]); - const [minStateKey, maxStateKey] = await Promise.all([minStateKeyProm, maxStateKeyProm]); - const writeTx = this.db.transaction(["oob_membership_events"], "readwrite"); - const writeStore = writeTx.objectStore("oob_membership_events"); - const membersKeyRange = IDBKeyRange.bound([roomId, minStateKey], [roomId, maxStateKey]); - _logger.logger.log(`LL: Deleting all users + marker in storage for room ${roomId}, with key range:`, [roomId, minStateKey], [roomId, maxStateKey]); - await reqAsPromise(writeStore.delete(membersKeyRange)); - } - - /** - * Clear the entire database. This should be used when logging out of a client - * to prevent mixing data between accounts. - * @returns Resolved when the database is cleared. - */ - clearDatabase() { - return new Promise(resolve => { - _logger.logger.log(`Removing indexeddb instance: ${this.dbName}`); - const req = this.indexedDB.deleteDatabase(this.dbName); - req.onblocked = () => { - _logger.logger.log(`can't yet delete indexeddb ${this.dbName} because it is open elsewhere`); - }; - req.onerror = () => { - // in firefox, with indexedDB disabled, this fails with a - // DOMError. We treat this as non-fatal, so that we can still - // use the app. - _logger.logger.warn(`unable to delete js-sdk store indexeddb: ${req.error}`); - resolve(); - }; - req.onsuccess = () => { - _logger.logger.log(`Removed indexeddb instance: ${this.dbName}`); - resolve(); - }; - }); - } - - /** - * @param copy - If false, the data returned is from internal - * buffers and must not be mutated. Otherwise, a copy is made before - * returning such that the data can be safely mutated. Default: true. - * - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync(copy = true) { - const data = this.syncAccumulator.getJSON(); - if (!data.nextBatch) return Promise.resolve(null); - if (copy) { - // We must deep copy the stored data so that the /sync processing code doesn't - // corrupt the internal state of the sync accumulator (it adds non-clonable keys) - return Promise.resolve(utils.deepCopy(data)); - } else { - return Promise.resolve(data); - } - } - getNextBatchToken() { - return Promise.resolve(this.syncAccumulator.getNextBatchToken()); - } - setSyncData(syncData) { - return Promise.resolve().then(() => { - this.syncAccumulator.accumulate(syncData); - }); - } - - /** - * Sync users and all accumulated sync data to the database. - * If a previous sync is in flight, the new data will be added to the - * next sync and the current sync's promise will be returned. - * @param userTuples - The user tuples - * @returns Promise which resolves if the data was persisted. - */ - async syncToDatabase(userTuples) { - if (this.syncToDatabasePromise) { - _logger.logger.warn("Skipping syncToDatabase() as persist already in flight"); - this.pendingUserPresenceData.push(...userTuples); - return this.syncToDatabasePromise; - } - userTuples.unshift(...this.pendingUserPresenceData); - this.syncToDatabasePromise = this.doSyncToDatabase(userTuples); - return this.syncToDatabasePromise; - } - async doSyncToDatabase(userTuples) { - try { - const syncData = this.syncAccumulator.getJSON(true); - await Promise.all([this.persistUserPresenceEvents(userTuples), this.persistAccountData(syncData.accountData), this.persistSyncData(syncData.nextBatch, syncData.roomsData)]); - } finally { - this.syncToDatabasePromise = undefined; - } - } - - /** - * Persist rooms /sync data along with the next batch token. - * @param nextBatch - The next_batch /sync value. - * @param roomsData - The 'rooms' /sync data from a SyncAccumulator - * @returns Promise which resolves if the data was persisted. - */ - persistSyncData(nextBatch, roomsData) { - _logger.logger.log("Persisting sync data up to", nextBatch); - return utils.promiseTry(() => { - const txn = this.db.transaction(["sync"], "readwrite"); - const store = txn.objectStore("sync"); - store.put({ - clobber: "-", - // constant key so will always clobber - nextBatch, - roomsData - }); // put == UPSERT - return txnAsPromise(txn).then(() => { - _logger.logger.log("Persisted sync data up to", nextBatch); - }); - }); - } - - /** - * Persist a list of account data events. Events with the same 'type' will - * be replaced. - * @param accountData - An array of raw user-scoped account data events - * @returns Promise which resolves if the events were persisted. - */ - persistAccountData(accountData) { - return utils.promiseTry(() => { - const txn = this.db.transaction(["accountData"], "readwrite"); - const store = txn.objectStore("accountData"); - for (const event of accountData) { - store.put(event); // put == UPSERT - } - - return txnAsPromise(txn).then(); - }); - } - - /** - * Persist a list of [user id, presence event] they are for. - * Users with the same 'userId' will be replaced. - * Presence events should be the event in its raw form (not the Event - * object) - * @param tuples - An array of [userid, event] tuples - * @returns Promise which resolves if the users were persisted. - */ - persistUserPresenceEvents(tuples) { - return utils.promiseTry(() => { - const txn = this.db.transaction(["users"], "readwrite"); - const store = txn.objectStore("users"); - for (const tuple of tuples) { - store.put({ - userId: tuple[0], - event: tuple[1] - }); // put == UPSERT - } - - return txnAsPromise(txn).then(); - }); - } - - /** - * Load all user presence events from the database. This is not cached. - * FIXME: It would probably be more sensible to store the events in the - * sync. - * @returns A list of presence events in their raw form. - */ - getUserPresenceEvents() { - return utils.promiseTry(() => { - const txn = this.db.transaction(["users"], "readonly"); - const store = txn.objectStore("users"); - return selectQuery(store, undefined, cursor => { - return [cursor.value.userId, cursor.value.event]; - }); - }); - } - - /** - * Load all the account data events from the database. This is not cached. - * @returns A list of raw global account events. - */ - loadAccountData() { - _logger.logger.log(`LocalIndexedDBStoreBackend: loading account data...`); - return utils.promiseTry(() => { - const txn = this.db.transaction(["accountData"], "readonly"); - const store = txn.objectStore("accountData"); - return selectQuery(store, undefined, cursor => { - return cursor.value; - }).then(result => { - _logger.logger.log(`LocalIndexedDBStoreBackend: loaded account data`); - return result; - }); - }); - } - - /** - * Load the sync data from the database. - * @returns An object with "roomsData" and "nextBatch" keys. - */ - loadSyncData() { - _logger.logger.log(`LocalIndexedDBStoreBackend: loading sync data...`); - return utils.promiseTry(() => { - const txn = this.db.transaction(["sync"], "readonly"); - const store = txn.objectStore("sync"); - return selectQuery(store, undefined, cursor => { - return cursor.value; - }).then(results => { - _logger.logger.log(`LocalIndexedDBStoreBackend: loaded sync data`); - if (results.length > 1) { - _logger.logger.warn("loadSyncData: More than 1 sync row found."); - } - return results.length > 0 ? results[0] : {}; - }); - }); - } - getClientOptions() { - return Promise.resolve().then(() => { - const txn = this.db.transaction(["client_options"], "readonly"); - const store = txn.objectStore("client_options"); - return selectQuery(store, undefined, cursor => { - var _cursor$value; - return (_cursor$value = cursor.value) === null || _cursor$value === void 0 ? void 0 : _cursor$value.options; - }).then(results => results[0]); - }); - } - async storeClientOptions(options) { - const txn = this.db.transaction(["client_options"], "readwrite"); - const store = txn.objectStore("client_options"); - store.put({ - clobber: "-", - // constant key so will always clobber - options: options - }); // put == UPSERT - await txnAsPromise(txn); - } - async saveToDeviceBatches(batches) { - const txn = this.db.transaction(["to_device_queue"], "readwrite"); - const store = txn.objectStore("to_device_queue"); - for (const batch of batches) { - store.add(batch); - } - await txnAsPromise(txn); - } - async getOldestToDeviceBatch() { - const txn = this.db.transaction(["to_device_queue"], "readonly"); - const store = txn.objectStore("to_device_queue"); - const cursor = await reqAsCursorPromise(store.openCursor()); - if (!cursor) return null; - const resultBatch = cursor.value; - return { - id: cursor.key, - txnId: resultBatch.txnId, - eventType: resultBatch.eventType, - batch: resultBatch.batch - }; - } - async removeToDeviceBatch(id) { - const txn = this.db.transaction(["to_device_queue"], "readwrite"); - const store = txn.objectStore("to_device_queue"); - store.delete(id); - await txnAsPromise(txn); - } -} -exports.LocalIndexedDBStoreBackend = LocalIndexedDBStoreBackend; -//# sourceMappingURL=indexeddb-local-backend.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js.map deleted file mode 100644 index ae1d65b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-local-backend.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-local-backend.js","names":["_syncAccumulator","require","utils","_interopRequireWildcard","IndexedDBHelpers","_logger","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","DB_MIGRATIONS","db","createObjectStore","keyPath","oobMembersStore","createIndex","autoIncrement","VERSION","length","selectQuery","store","keyRange","resultMapper","query","openCursor","Promise","resolve","reject","results","onerror","Error","error","onsuccess","cursor","result","push","continue","txnAsPromise","txn","oncomplete","event","reqAsEventPromise","req","reqAsPromise","err","reqAsCursorPromise","then","LocalIndexedDBStoreBackend","exists","indexedDB","dbName","constructor","_defineProperty2","syncAccumulator","SyncAccumulator","connect","onClose","disconnected","logger","log","open","onupgradeneeded","ev","oldVersion","_isNewlyCreated","forEach","migration","index","onblocked","onversionchange","_this$db","close","undefined","onclose","init","isNewlyCreated","all","loadAccountData","loadSyncData","accountData","syncData","accumulate","next_batch","nextBatch","rooms","roomsData","account_data","events","getOutOfBandMembers","roomId","tx","transaction","objectStore","roomIndex","range","IDBKeyRange","only","request","membershipEvents","oobWritten","record","value","oob_written","setOutOfBandMembers","e","put","markerObject","room_id","state_key","clearOutOfBandMembers","readTx","roomRange","minStateKeyProm","openKeyCursor","primaryKey","maxStateKeyProm","minStateKey","maxStateKey","writeTx","writeStore","membersKeyRange","bound","delete","clearDatabase","deleteDatabase","warn","getSavedSync","copy","data","getJSON","deepCopy","getNextBatchToken","setSyncData","syncToDatabase","userTuples","syncToDatabasePromise","pendingUserPresenceData","unshift","doSyncToDatabase","persistUserPresenceEvents","persistAccountData","persistSyncData","promiseTry","clobber","tuples","tuple","userId","getUserPresenceEvents","getClientOptions","_cursor$value","options","storeClientOptions","saveToDeviceBatches","batches","batch","add","getOldestToDeviceBatch","resultBatch","id","txnId","eventType","removeToDeviceBatch","exports"],"sources":["../../src/store/indexeddb-local-backend.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IMinimalEvent, ISyncData, ISyncResponse, SyncAccumulator } from \"../sync-accumulator\";\nimport * as utils from \"../utils\";\nimport * as IndexedDBHelpers from \"../indexeddb-helpers\";\nimport { logger } from \"../logger\";\nimport { IStateEventWithRoomId, IStoredClientOpts } from \"../matrix\";\nimport { ISavedSync } from \"./index\";\nimport { IIndexedDBBackend, UserTuple } from \"./indexeddb-backend\";\nimport { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from \"../models/ToDeviceMessage\";\n\ntype DbMigration = (db: IDBDatabase) => void;\nconst DB_MIGRATIONS: DbMigration[] = [\n (db): void => {\n // Make user store, clobber based on user ID. (userId property of User objects)\n db.createObjectStore(\"users\", { keyPath: [\"userId\"] });\n\n // Make account data store, clobber based on event type.\n // (event.type property of MatrixEvent objects)\n db.createObjectStore(\"accountData\", { keyPath: [\"type\"] });\n\n // Make /sync store (sync tokens, room data, etc), always clobber (const key).\n db.createObjectStore(\"sync\", { keyPath: [\"clobber\"] });\n },\n (db): void => {\n const oobMembersStore = db.createObjectStore(\"oob_membership_events\", {\n keyPath: [\"room_id\", \"state_key\"],\n });\n oobMembersStore.createIndex(\"room\", \"room_id\");\n },\n (db): void => {\n db.createObjectStore(\"client_options\", { keyPath: [\"clobber\"] });\n },\n (db): void => {\n db.createObjectStore(\"to_device_queue\", { autoIncrement: true });\n },\n // Expand as needed.\n];\nconst VERSION = DB_MIGRATIONS.length;\n\n/**\n * Helper method to collect results from a Cursor and promiseify it.\n * @param store - The store to perform openCursor on.\n * @param keyRange - Optional key range to apply on the cursor.\n * @param resultMapper - A function which is repeatedly called with a\n * Cursor.\n * Return the data you want to keep.\n * @returns Promise which resolves to an array of whatever you returned from\n * resultMapper.\n */\nfunction selectQuery(\n store: IDBObjectStore,\n keyRange: IDBKeyRange | IDBValidKey | undefined,\n resultMapper: (cursor: IDBCursorWithValue) => T,\n): Promise {\n const query = store.openCursor(keyRange);\n return new Promise((resolve, reject) => {\n const results: T[] = [];\n query.onerror = (): void => {\n reject(new Error(\"Query failed: \" + query.error));\n };\n // collect results\n query.onsuccess = (): void => {\n const cursor = query.result;\n if (!cursor) {\n resolve(results);\n return; // end of results\n }\n results.push(resultMapper(cursor));\n cursor.continue();\n };\n });\n}\n\nfunction txnAsPromise(txn: IDBTransaction): Promise {\n return new Promise((resolve, reject) => {\n txn.oncomplete = function (event): void {\n resolve(event);\n };\n txn.onerror = function (): void {\n reject(txn.error);\n };\n });\n}\n\nfunction reqAsEventPromise(req: IDBRequest): Promise {\n return new Promise((resolve, reject) => {\n req.onsuccess = function (event): void {\n resolve(event);\n };\n req.onerror = function (): void {\n reject(req.error);\n };\n });\n}\n\nfunction reqAsPromise(req: IDBRequest): Promise {\n return new Promise((resolve, reject) => {\n req.onsuccess = (): void => resolve(req);\n req.onerror = (err): void => reject(err);\n });\n}\n\nfunction reqAsCursorPromise(req: IDBRequest): Promise {\n return reqAsEventPromise(req).then((event) => req.result);\n}\n\nexport class LocalIndexedDBStoreBackend implements IIndexedDBBackend {\n public static exists(indexedDB: IDBFactory, dbName: string): Promise {\n dbName = \"matrix-js-sdk:\" + (dbName || \"default\");\n return IndexedDBHelpers.exists(indexedDB, dbName);\n }\n\n private readonly dbName: string;\n private readonly syncAccumulator: SyncAccumulator;\n private db?: IDBDatabase;\n private disconnected = true;\n private _isNewlyCreated = false;\n private syncToDatabasePromise?: Promise;\n private pendingUserPresenceData: UserTuple[] = [];\n\n /**\n * Does the actual reading from and writing to the indexeddb\n *\n * Construct a new Indexed Database store backend. This requires a call to\n * `connect()` before this store can be used.\n * @param indexedDB - The Indexed DB interface e.g\n * `window.indexedDB`\n * @param dbName - Optional database name. The same name must be used\n * to open the same database.\n */\n public constructor(private readonly indexedDB: IDBFactory, dbName = \"default\") {\n this.dbName = \"matrix-js-sdk:\" + dbName;\n this.syncAccumulator = new SyncAccumulator();\n }\n\n /**\n * Attempt to connect to the database. This can fail if the user does not\n * grant permission.\n * @returns Promise which resolves if successfully connected.\n */\n public connect(onClose?: () => void): Promise {\n if (!this.disconnected) {\n logger.log(`LocalIndexedDBStoreBackend.connect: already connected or connecting`);\n return Promise.resolve();\n }\n\n this.disconnected = false;\n\n logger.log(`LocalIndexedDBStoreBackend.connect: connecting...`);\n const req = this.indexedDB.open(this.dbName, VERSION);\n req.onupgradeneeded = (ev): void => {\n const db = req.result;\n const oldVersion = ev.oldVersion;\n logger.log(`LocalIndexedDBStoreBackend.connect: upgrading from ${oldVersion}`);\n if (oldVersion < 1) {\n // The database did not previously exist\n this._isNewlyCreated = true;\n }\n DB_MIGRATIONS.forEach((migration, index) => {\n if (oldVersion <= index) migration(db);\n });\n };\n\n req.onblocked = (): void => {\n logger.log(`can't yet open LocalIndexedDBStoreBackend because it is open elsewhere`);\n };\n\n logger.log(`LocalIndexedDBStoreBackend.connect: awaiting connection...`);\n return reqAsEventPromise(req).then(async () => {\n logger.log(`LocalIndexedDBStoreBackend.connect: connected`);\n this.db = req.result;\n\n // add a poorly-named listener for when deleteDatabase is called\n // so we can close our db connections.\n this.db.onversionchange = (): void => {\n this.db?.close(); // this does not call onclose\n this.disconnected = true;\n this.db = undefined;\n onClose?.();\n };\n this.db.onclose = (): void => {\n this.disconnected = true;\n this.db = undefined;\n onClose?.();\n };\n\n await this.init();\n });\n }\n\n /** @returns whether or not the database was newly created in this session. */\n public isNewlyCreated(): Promise {\n return Promise.resolve(this._isNewlyCreated);\n }\n\n /**\n * Having connected, load initial data from the database and prepare for use\n * @returns Promise which resolves on success\n */\n private init(): Promise {\n return Promise.all([this.loadAccountData(), this.loadSyncData()]).then(([accountData, syncData]) => {\n logger.log(`LocalIndexedDBStoreBackend: loaded initial data`);\n this.syncAccumulator.accumulate(\n {\n next_batch: syncData.nextBatch,\n rooms: syncData.roomsData,\n account_data: {\n events: accountData,\n },\n },\n true,\n );\n });\n }\n\n /**\n * Returns the out-of-band membership events for this room that\n * were previously loaded.\n * @returns the events, potentially an empty array if OOB loading didn't yield any new members\n * @returns in case the members for this room haven't been stored yet\n */\n public getOutOfBandMembers(roomId: string): Promise {\n return new Promise((resolve, reject) => {\n const tx = this.db!.transaction([\"oob_membership_events\"], \"readonly\");\n const store = tx.objectStore(\"oob_membership_events\");\n const roomIndex = store.index(\"room\");\n const range = IDBKeyRange.only(roomId);\n const request = roomIndex.openCursor(range);\n\n const membershipEvents: IStateEventWithRoomId[] = [];\n // did we encounter the oob_written marker object\n // amongst the results? That means OOB member\n // loading already happened for this room\n // but there were no members to persist as they\n // were all known already\n let oobWritten = false;\n\n request.onsuccess = (): void => {\n const cursor = request.result;\n if (!cursor) {\n // Unknown room\n if (!membershipEvents.length && !oobWritten) {\n return resolve(null);\n }\n return resolve(membershipEvents);\n }\n const record = cursor.value;\n if (record.oob_written) {\n oobWritten = true;\n } else {\n membershipEvents.push(record);\n }\n cursor.continue();\n };\n request.onerror = (err): void => {\n reject(err);\n };\n }).then((events) => {\n logger.log(`LL: got ${events?.length} membershipEvents from storage for room ${roomId} ...`);\n return events;\n });\n }\n\n /**\n * Stores the out-of-band membership events for this room. Note that\n * it still makes sense to store an empty array as the OOB status for the room is\n * marked as fetched, and getOutOfBandMembers will return an empty array instead of null\n * @param membershipEvents - the membership events to store\n */\n public async setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise {\n logger.log(`LL: backend about to store ${membershipEvents.length}` + ` members for ${roomId}`);\n const tx = this.db!.transaction([\"oob_membership_events\"], \"readwrite\");\n const store = tx.objectStore(\"oob_membership_events\");\n membershipEvents.forEach((e) => {\n store.put(e);\n });\n // aside from all the events, we also write a marker object to the store\n // to mark the fact that OOB members have been written for this room.\n // It's possible that 0 members need to be written as all where previously know\n // but we still need to know whether to return null or [] from getOutOfBandMembers\n // where null means out of band members haven't been stored yet for this room\n const markerObject = {\n room_id: roomId,\n oob_written: true,\n state_key: 0,\n };\n store.put(markerObject);\n await txnAsPromise(tx);\n logger.log(`LL: backend done storing for ${roomId}!`);\n }\n\n public async clearOutOfBandMembers(roomId: string): Promise {\n // the approach to delete all members for a room\n // is to get the min and max state key from the index\n // for that room, and then delete between those\n // keys in the store.\n // this should be way faster than deleting every member\n // individually for a large room.\n const readTx = this.db!.transaction([\"oob_membership_events\"], \"readonly\");\n const store = readTx.objectStore(\"oob_membership_events\");\n const roomIndex = store.index(\"room\");\n const roomRange = IDBKeyRange.only(roomId);\n\n const minStateKeyProm = reqAsCursorPromise(roomIndex.openKeyCursor(roomRange, \"next\")).then(\n (cursor) => (cursor?.primaryKey)[1],\n );\n const maxStateKeyProm = reqAsCursorPromise(roomIndex.openKeyCursor(roomRange, \"prev\")).then(\n (cursor) => (cursor?.primaryKey)[1],\n );\n const [minStateKey, maxStateKey] = await Promise.all([minStateKeyProm, maxStateKeyProm]);\n\n const writeTx = this.db!.transaction([\"oob_membership_events\"], \"readwrite\");\n const writeStore = writeTx.objectStore(\"oob_membership_events\");\n const membersKeyRange = IDBKeyRange.bound([roomId, minStateKey], [roomId, maxStateKey]);\n\n logger.log(\n `LL: Deleting all users + marker in storage for room ${roomId}, with key range:`,\n [roomId, minStateKey],\n [roomId, maxStateKey],\n );\n await reqAsPromise(writeStore.delete(membersKeyRange));\n }\n\n /**\n * Clear the entire database. This should be used when logging out of a client\n * to prevent mixing data between accounts.\n * @returns Resolved when the database is cleared.\n */\n public clearDatabase(): Promise {\n return new Promise((resolve) => {\n logger.log(`Removing indexeddb instance: ${this.dbName}`);\n const req = this.indexedDB.deleteDatabase(this.dbName);\n\n req.onblocked = (): void => {\n logger.log(`can't yet delete indexeddb ${this.dbName} because it is open elsewhere`);\n };\n\n req.onerror = (): void => {\n // in firefox, with indexedDB disabled, this fails with a\n // DOMError. We treat this as non-fatal, so that we can still\n // use the app.\n logger.warn(`unable to delete js-sdk store indexeddb: ${req.error}`);\n resolve();\n };\n\n req.onsuccess = (): void => {\n logger.log(`Removed indexeddb instance: ${this.dbName}`);\n resolve();\n };\n });\n }\n\n /**\n * @param copy - If false, the data returned is from internal\n * buffers and must not be mutated. Otherwise, a copy is made before\n * returning such that the data can be safely mutated. Default: true.\n *\n * @returns Promise which resolves with a sync response to restore the\n * client state to where it was at the last save, or null if there\n * is no saved sync data.\n */\n public getSavedSync(copy = true): Promise {\n const data = this.syncAccumulator.getJSON();\n if (!data.nextBatch) return Promise.resolve(null);\n if (copy) {\n // We must deep copy the stored data so that the /sync processing code doesn't\n // corrupt the internal state of the sync accumulator (it adds non-clonable keys)\n return Promise.resolve(utils.deepCopy(data));\n } else {\n return Promise.resolve(data);\n }\n }\n\n public getNextBatchToken(): Promise {\n return Promise.resolve(this.syncAccumulator.getNextBatchToken());\n }\n\n public setSyncData(syncData: ISyncResponse): Promise {\n return Promise.resolve().then(() => {\n this.syncAccumulator.accumulate(syncData);\n });\n }\n\n /**\n * Sync users and all accumulated sync data to the database.\n * If a previous sync is in flight, the new data will be added to the\n * next sync and the current sync's promise will be returned.\n * @param userTuples - The user tuples\n * @returns Promise which resolves if the data was persisted.\n */\n public async syncToDatabase(userTuples: UserTuple[]): Promise {\n if (this.syncToDatabasePromise) {\n logger.warn(\"Skipping syncToDatabase() as persist already in flight\");\n this.pendingUserPresenceData.push(...userTuples);\n return this.syncToDatabasePromise;\n }\n userTuples.unshift(...this.pendingUserPresenceData);\n this.syncToDatabasePromise = this.doSyncToDatabase(userTuples);\n return this.syncToDatabasePromise;\n }\n\n private async doSyncToDatabase(userTuples: UserTuple[]): Promise {\n try {\n const syncData = this.syncAccumulator.getJSON(true);\n await Promise.all([\n this.persistUserPresenceEvents(userTuples),\n this.persistAccountData(syncData.accountData),\n this.persistSyncData(syncData.nextBatch, syncData.roomsData),\n ]);\n } finally {\n this.syncToDatabasePromise = undefined;\n }\n }\n\n /**\n * Persist rooms /sync data along with the next batch token.\n * @param nextBatch - The next_batch /sync value.\n * @param roomsData - The 'rooms' /sync data from a SyncAccumulator\n * @returns Promise which resolves if the data was persisted.\n */\n private persistSyncData(nextBatch: string, roomsData: ISyncResponse[\"rooms\"]): Promise {\n logger.log(\"Persisting sync data up to\", nextBatch);\n return utils.promiseTry(() => {\n const txn = this.db!.transaction([\"sync\"], \"readwrite\");\n const store = txn.objectStore(\"sync\");\n store.put({\n clobber: \"-\", // constant key so will always clobber\n nextBatch,\n roomsData,\n }); // put == UPSERT\n return txnAsPromise(txn).then(() => {\n logger.log(\"Persisted sync data up to\", nextBatch);\n });\n });\n }\n\n /**\n * Persist a list of account data events. Events with the same 'type' will\n * be replaced.\n * @param accountData - An array of raw user-scoped account data events\n * @returns Promise which resolves if the events were persisted.\n */\n private persistAccountData(accountData: IMinimalEvent[]): Promise {\n return utils.promiseTry(() => {\n const txn = this.db!.transaction([\"accountData\"], \"readwrite\");\n const store = txn.objectStore(\"accountData\");\n for (const event of accountData) {\n store.put(event); // put == UPSERT\n }\n return txnAsPromise(txn).then();\n });\n }\n\n /**\n * Persist a list of [user id, presence event] they are for.\n * Users with the same 'userId' will be replaced.\n * Presence events should be the event in its raw form (not the Event\n * object)\n * @param tuples - An array of [userid, event] tuples\n * @returns Promise which resolves if the users were persisted.\n */\n private persistUserPresenceEvents(tuples: UserTuple[]): Promise {\n return utils.promiseTry(() => {\n const txn = this.db!.transaction([\"users\"], \"readwrite\");\n const store = txn.objectStore(\"users\");\n for (const tuple of tuples) {\n store.put({\n userId: tuple[0],\n event: tuple[1],\n }); // put == UPSERT\n }\n return txnAsPromise(txn).then();\n });\n }\n\n /**\n * Load all user presence events from the database. This is not cached.\n * FIXME: It would probably be more sensible to store the events in the\n * sync.\n * @returns A list of presence events in their raw form.\n */\n public getUserPresenceEvents(): Promise {\n return utils.promiseTry(() => {\n const txn = this.db!.transaction([\"users\"], \"readonly\");\n const store = txn.objectStore(\"users\");\n return selectQuery(store, undefined, (cursor) => {\n return [cursor.value.userId, cursor.value.event];\n });\n });\n }\n\n /**\n * Load all the account data events from the database. This is not cached.\n * @returns A list of raw global account events.\n */\n private loadAccountData(): Promise {\n logger.log(`LocalIndexedDBStoreBackend: loading account data...`);\n return utils.promiseTry(() => {\n const txn = this.db!.transaction([\"accountData\"], \"readonly\");\n const store = txn.objectStore(\"accountData\");\n return selectQuery(store, undefined, (cursor) => {\n return cursor.value;\n }).then((result: IMinimalEvent[]) => {\n logger.log(`LocalIndexedDBStoreBackend: loaded account data`);\n return result;\n });\n });\n }\n\n /**\n * Load the sync data from the database.\n * @returns An object with \"roomsData\" and \"nextBatch\" keys.\n */\n private loadSyncData(): Promise {\n logger.log(`LocalIndexedDBStoreBackend: loading sync data...`);\n return utils.promiseTry(() => {\n const txn = this.db!.transaction([\"sync\"], \"readonly\");\n const store = txn.objectStore(\"sync\");\n return selectQuery(store, undefined, (cursor) => {\n return cursor.value;\n }).then((results: ISyncData[]) => {\n logger.log(`LocalIndexedDBStoreBackend: loaded sync data`);\n if (results.length > 1) {\n logger.warn(\"loadSyncData: More than 1 sync row found.\");\n }\n return results.length > 0 ? results[0] : ({} as ISyncData);\n });\n });\n }\n\n public getClientOptions(): Promise {\n return Promise.resolve().then(() => {\n const txn = this.db!.transaction([\"client_options\"], \"readonly\");\n const store = txn.objectStore(\"client_options\");\n return selectQuery(store, undefined, (cursor) => {\n return cursor.value?.options;\n }).then((results) => results[0]);\n });\n }\n\n public async storeClientOptions(options: IStoredClientOpts): Promise {\n const txn = this.db!.transaction([\"client_options\"], \"readwrite\");\n const store = txn.objectStore(\"client_options\");\n store.put({\n clobber: \"-\", // constant key so will always clobber\n options: options,\n }); // put == UPSERT\n await txnAsPromise(txn);\n }\n\n public async saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise {\n const txn = this.db!.transaction([\"to_device_queue\"], \"readwrite\");\n const store = txn.objectStore(\"to_device_queue\");\n for (const batch of batches) {\n store.add(batch);\n }\n await txnAsPromise(txn);\n }\n\n public async getOldestToDeviceBatch(): Promise {\n const txn = this.db!.transaction([\"to_device_queue\"], \"readonly\");\n const store = txn.objectStore(\"to_device_queue\");\n const cursor = await reqAsCursorPromise(store.openCursor());\n if (!cursor) return null;\n\n const resultBatch = cursor.value as ToDeviceBatchWithTxnId;\n\n return {\n id: cursor.key as number,\n txnId: resultBatch.txnId,\n eventType: resultBatch.eventType,\n batch: resultBatch.batch,\n };\n }\n\n public async removeToDeviceBatch(id: number): Promise {\n const txn = this.db!.transaction([\"to_device_queue\"], \"readwrite\");\n const store = txn.objectStore(\"to_device_queue\");\n store.delete(id);\n await txnAsPromise(txn);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts deleted file mode 100644 index 1661f27..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts +++ /dev/null @@ -1,78 +0,0 @@ -import { ISavedSync } from "./index"; -import { IStoredClientOpts } from "../client"; -import { IStateEventWithRoomId, ISyncResponse } from "../matrix"; -import { IIndexedDBBackend, UserTuple } from "./indexeddb-backend"; -import { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from "../models/ToDeviceMessage"; -export declare class RemoteIndexedDBStoreBackend implements IIndexedDBBackend { - private readonly workerFactory; - private readonly dbName?; - private worker?; - private nextSeq; - private inFlight; - private startPromise?; - private onClose; - /** - * An IndexedDB store backend where the actual backend sits in a web - * worker. - * - * Construct a new Indexed Database store backend. This requires a call to - * `connect()` before this store can be used. - * @param workerFactory - Factory which produces a Worker - * @param dbName - Optional database name. The same name must be used - * to open the same database. - */ - constructor(workerFactory: () => Worker, dbName?: string | undefined); - /** - * Attempt to connect to the database. This can fail if the user does not - * grant permission. - * @returns Promise which resolves if successfully connected. - */ - connect(onClose?: () => void): Promise; - /** - * Clear the entire database. This should be used when logging out of a client - * to prevent mixing data between accounts. - * @returns Resolved when the database is cleared. - */ - clearDatabase(): Promise; - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated(): Promise; - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync(): Promise; - getNextBatchToken(): Promise; - setSyncData(syncData: ISyncResponse): Promise; - syncToDatabase(userTuples: UserTuple[]): Promise; - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers(roomId: string): Promise; - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - * @returns when all members have been stored - */ - setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise; - clearOutOfBandMembers(roomId: string): Promise; - getClientOptions(): Promise; - storeClientOptions(options: IStoredClientOpts): Promise; - /** - * Load all user presence events from the database. This is not cached. - * @returns A list of presence events in their raw form. - */ - getUserPresenceEvents(): Promise; - saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise; - getOldestToDeviceBatch(): Promise; - removeToDeviceBatch(id: number): Promise; - private ensureStarted; - private doCmd; - private onWorkerMessage; -} -//# sourceMappingURL=indexeddb-remote-backend.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts.map deleted file mode 100644 index 0758468..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-remote-backend.d.ts","sourceRoot":"","sources":["../../src/store/indexeddb-remote-backend.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAEzF,qBAAa,2BAA4B,YAAW,iBAAiB;IAqB9C,OAAO,CAAC,QAAQ,CAAC,aAAa;IAAgB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;IApBzF,OAAO,CAAC,MAAM,CAAC,CAAS;IACxB,OAAO,CAAC,OAAO,CAAK;IAEpB,OAAO,CAAC,QAAQ,CAAsC;IAGtD,OAAO,CAAC,YAAY,CAAC,CAAgB;IAErC,OAAO,CAAC,OAAO;IAEf;;;;;;;;;OASG;gBACiC,aAAa,EAAE,MAAM,MAAM,EAAmB,MAAM,CAAC,oBAAQ;IAEjG;;;;OAIG;IACI,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;;;OAIG;IACI,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAIrC,8EAA8E;IACvE,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC;IAIzC;;;;OAIG;IACI,YAAY,IAAI,OAAO,CAAC,UAAU,CAAC;IAInC,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC;IAIpC,WAAW,CAAC,QAAQ,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAInD,cAAc,CAAC,UAAU,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;;OAKG;IACI,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,EAAE,GAAG,IAAI,CAAC;IAInF;;;;;;OAMG;IACI,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7F,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpD,gBAAgB,IAAI,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC;IAI1D,kBAAkB,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;OAGG;IACI,qBAAqB,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAIvC,mBAAmB,CAAC,OAAO,EAAE,sBAAsB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAIrE,sBAAsB,IAAI,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC;IAI9D,mBAAmB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI3D,OAAO,CAAC,aAAa;IAarB,OAAO,CAAC,KAAK;IAeb,OAAO,CAAC,eAAe,CA4BrB;CACL"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js deleted file mode 100644 index 702d6ac..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js +++ /dev/null @@ -1,199 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.RemoteIndexedDBStoreBackend = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../logger"); -var _utils = require("../utils"); -/* -Copyright 2017 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class RemoteIndexedDBStoreBackend { - // The currently in-flight requests to the actual backend - // seq: promise - // Once we start connecting, we keep the promise and re-use it - // if we try to connect again - - // Callback for when the IndexedDB gets closed unexpectedly - - /** - * An IndexedDB store backend where the actual backend sits in a web - * worker. - * - * Construct a new Indexed Database store backend. This requires a call to - * `connect()` before this store can be used. - * @param workerFactory - Factory which produces a Worker - * @param dbName - Optional database name. The same name must be used - * to open the same database. - */ - constructor(workerFactory, dbName) { - this.workerFactory = workerFactory; - this.dbName = dbName; - (0, _defineProperty2.default)(this, "worker", void 0); - (0, _defineProperty2.default)(this, "nextSeq", 0); - (0, _defineProperty2.default)(this, "inFlight", {}); - (0, _defineProperty2.default)(this, "startPromise", void 0); - (0, _defineProperty2.default)(this, "onWorkerMessage", ev => { - const msg = ev.data; - if (msg.command == "closed") { - var _this$onClose; - (_this$onClose = this.onClose) === null || _this$onClose === void 0 ? void 0 : _this$onClose.call(this); - } else if (msg.command == "cmd_success" || msg.command == "cmd_fail") { - if (msg.seq === undefined) { - _logger.logger.error("Got reply from worker with no seq"); - return; - } - const def = this.inFlight[msg.seq]; - if (def === undefined) { - _logger.logger.error("Got reply for unknown seq " + msg.seq); - return; - } - delete this.inFlight[msg.seq]; - if (msg.command == "cmd_success") { - def.resolve(msg.result); - } else { - const error = new Error(msg.error.message); - error.name = msg.error.name; - def.reject(error); - } - } else { - _logger.logger.warn("Unrecognised message from worker: ", msg); - } - }); - } - - /** - * Attempt to connect to the database. This can fail if the user does not - * grant permission. - * @returns Promise which resolves if successfully connected. - */ - connect(onClose) { - this.onClose = onClose; - return this.ensureStarted().then(() => this.doCmd("connect")); - } - - /** - * Clear the entire database. This should be used when logging out of a client - * to prevent mixing data between accounts. - * @returns Resolved when the database is cleared. - */ - clearDatabase() { - return this.ensureStarted().then(() => this.doCmd("clearDatabase")); - } - - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated() { - return this.doCmd("isNewlyCreated"); - } - - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync() { - return this.doCmd("getSavedSync"); - } - getNextBatchToken() { - return this.doCmd("getNextBatchToken"); - } - setSyncData(syncData) { - return this.doCmd("setSyncData", [syncData]); - } - syncToDatabase(userTuples) { - return this.doCmd("syncToDatabase", [userTuples]); - } - - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers(roomId) { - return this.doCmd("getOutOfBandMembers", [roomId]); - } - - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - * @returns when all members have been stored - */ - setOutOfBandMembers(roomId, membershipEvents) { - return this.doCmd("setOutOfBandMembers", [roomId, membershipEvents]); - } - clearOutOfBandMembers(roomId) { - return this.doCmd("clearOutOfBandMembers", [roomId]); - } - getClientOptions() { - return this.doCmd("getClientOptions"); - } - storeClientOptions(options) { - return this.doCmd("storeClientOptions", [options]); - } - - /** - * Load all user presence events from the database. This is not cached. - * @returns A list of presence events in their raw form. - */ - getUserPresenceEvents() { - return this.doCmd("getUserPresenceEvents"); - } - async saveToDeviceBatches(batches) { - return this.doCmd("saveToDeviceBatches", [batches]); - } - async getOldestToDeviceBatch() { - return this.doCmd("getOldestToDeviceBatch"); - } - async removeToDeviceBatch(id) { - return this.doCmd("removeToDeviceBatch", [id]); - } - ensureStarted() { - if (!this.startPromise) { - this.worker = this.workerFactory(); - this.worker.onmessage = this.onWorkerMessage; - - // tell the worker the db name. - this.startPromise = this.doCmd("setupWorker", [this.dbName]).then(() => { - _logger.logger.log("IndexedDB worker is ready"); - }); - } - return this.startPromise; - } - doCmd(command, args) { - // wrap in a q so if the postMessage throws, - // the promise automatically gets rejected - return Promise.resolve().then(() => { - var _this$worker; - const seq = this.nextSeq++; - const def = (0, _utils.defer)(); - this.inFlight[seq] = def; - (_this$worker = this.worker) === null || _this$worker === void 0 ? void 0 : _this$worker.postMessage({ - command, - seq, - args - }); - return def.promise; - }); - } -} -exports.RemoteIndexedDBStoreBackend = RemoteIndexedDBStoreBackend; -//# sourceMappingURL=indexeddb-remote-backend.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js.map deleted file mode 100644 index be65138..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-remote-backend.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-remote-backend.js","names":["_logger","require","_utils","RemoteIndexedDBStoreBackend","constructor","workerFactory","dbName","_defineProperty2","default","ev","msg","data","command","_this$onClose","onClose","call","seq","undefined","logger","error","def","inFlight","resolve","result","Error","message","name","reject","warn","connect","ensureStarted","then","doCmd","clearDatabase","isNewlyCreated","getSavedSync","getNextBatchToken","setSyncData","syncData","syncToDatabase","userTuples","getOutOfBandMembers","roomId","setOutOfBandMembers","membershipEvents","clearOutOfBandMembers","getClientOptions","storeClientOptions","options","getUserPresenceEvents","saveToDeviceBatches","batches","getOldestToDeviceBatch","removeToDeviceBatch","id","startPromise","worker","onmessage","onWorkerMessage","log","args","Promise","_this$worker","nextSeq","defer","postMessage","promise","exports"],"sources":["../../src/store/indexeddb-remote-backend.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../logger\";\nimport { defer, IDeferred } from \"../utils\";\nimport { ISavedSync } from \"./index\";\nimport { IStoredClientOpts } from \"../client\";\nimport { IStateEventWithRoomId, ISyncResponse } from \"../matrix\";\nimport { IIndexedDBBackend, UserTuple } from \"./indexeddb-backend\";\nimport { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from \"../models/ToDeviceMessage\";\n\nexport class RemoteIndexedDBStoreBackend implements IIndexedDBBackend {\n private worker?: Worker;\n private nextSeq = 0;\n // The currently in-flight requests to the actual backend\n private inFlight: Record> = {}; // seq: promise\n // Once we start connecting, we keep the promise and re-use it\n // if we try to connect again\n private startPromise?: Promise;\n // Callback for when the IndexedDB gets closed unexpectedly\n private onClose?(): void;\n\n /**\n * An IndexedDB store backend where the actual backend sits in a web\n * worker.\n *\n * Construct a new Indexed Database store backend. This requires a call to\n * `connect()` before this store can be used.\n * @param workerFactory - Factory which produces a Worker\n * @param dbName - Optional database name. The same name must be used\n * to open the same database.\n */\n public constructor(private readonly workerFactory: () => Worker, private readonly dbName?: string) {}\n\n /**\n * Attempt to connect to the database. This can fail if the user does not\n * grant permission.\n * @returns Promise which resolves if successfully connected.\n */\n public connect(onClose?: () => void): Promise {\n this.onClose = onClose;\n return this.ensureStarted().then(() => this.doCmd(\"connect\"));\n }\n\n /**\n * Clear the entire database. This should be used when logging out of a client\n * to prevent mixing data between accounts.\n * @returns Resolved when the database is cleared.\n */\n public clearDatabase(): Promise {\n return this.ensureStarted().then(() => this.doCmd(\"clearDatabase\"));\n }\n\n /** @returns whether or not the database was newly created in this session. */\n public isNewlyCreated(): Promise {\n return this.doCmd(\"isNewlyCreated\");\n }\n\n /**\n * @returns Promise which resolves with a sync response to restore the\n * client state to where it was at the last save, or null if there\n * is no saved sync data.\n */\n public getSavedSync(): Promise {\n return this.doCmd(\"getSavedSync\");\n }\n\n public getNextBatchToken(): Promise {\n return this.doCmd(\"getNextBatchToken\");\n }\n\n public setSyncData(syncData: ISyncResponse): Promise {\n return this.doCmd(\"setSyncData\", [syncData]);\n }\n\n public syncToDatabase(userTuples: UserTuple[]): Promise {\n return this.doCmd(\"syncToDatabase\", [userTuples]);\n }\n\n /**\n * Returns the out-of-band membership events for this room that\n * were previously loaded.\n * @returns the events, potentially an empty array if OOB loading didn't yield any new members\n * @returns in case the members for this room haven't been stored yet\n */\n public getOutOfBandMembers(roomId: string): Promise {\n return this.doCmd(\"getOutOfBandMembers\", [roomId]);\n }\n\n /**\n * Stores the out-of-band membership events for this room. Note that\n * it still makes sense to store an empty array as the OOB status for the room is\n * marked as fetched, and getOutOfBandMembers will return an empty array instead of null\n * @param membershipEvents - the membership events to store\n * @returns when all members have been stored\n */\n public setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise {\n return this.doCmd(\"setOutOfBandMembers\", [roomId, membershipEvents]);\n }\n\n public clearOutOfBandMembers(roomId: string): Promise {\n return this.doCmd(\"clearOutOfBandMembers\", [roomId]);\n }\n\n public getClientOptions(): Promise {\n return this.doCmd(\"getClientOptions\");\n }\n\n public storeClientOptions(options: IStoredClientOpts): Promise {\n return this.doCmd(\"storeClientOptions\", [options]);\n }\n\n /**\n * Load all user presence events from the database. This is not cached.\n * @returns A list of presence events in their raw form.\n */\n public getUserPresenceEvents(): Promise {\n return this.doCmd(\"getUserPresenceEvents\");\n }\n\n public async saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise {\n return this.doCmd(\"saveToDeviceBatches\", [batches]);\n }\n\n public async getOldestToDeviceBatch(): Promise {\n return this.doCmd(\"getOldestToDeviceBatch\");\n }\n\n public async removeToDeviceBatch(id: number): Promise {\n return this.doCmd(\"removeToDeviceBatch\", [id]);\n }\n\n private ensureStarted(): Promise {\n if (!this.startPromise) {\n this.worker = this.workerFactory();\n this.worker.onmessage = this.onWorkerMessage;\n\n // tell the worker the db name.\n this.startPromise = this.doCmd(\"setupWorker\", [this.dbName]).then(() => {\n logger.log(\"IndexedDB worker is ready\");\n });\n }\n return this.startPromise;\n }\n\n private doCmd(command: string, args?: any): Promise {\n // wrap in a q so if the postMessage throws,\n // the promise automatically gets rejected\n return Promise.resolve().then(() => {\n const seq = this.nextSeq++;\n const def = defer();\n\n this.inFlight[seq] = def;\n\n this.worker?.postMessage({ command, seq, args });\n\n return def.promise;\n });\n }\n\n private onWorkerMessage = (ev: MessageEvent): void => {\n const msg = ev.data;\n\n if (msg.command == \"closed\") {\n this.onClose?.();\n } else if (msg.command == \"cmd_success\" || msg.command == \"cmd_fail\") {\n if (msg.seq === undefined) {\n logger.error(\"Got reply from worker with no seq\");\n return;\n }\n\n const def = this.inFlight[msg.seq];\n if (def === undefined) {\n logger.error(\"Got reply for unknown seq \" + msg.seq);\n return;\n }\n delete this.inFlight[msg.seq];\n\n if (msg.command == \"cmd_success\") {\n def.resolve(msg.result);\n } else {\n const error = new Error(msg.error.message);\n error.name = msg.error.name;\n def.reject(error);\n }\n } else {\n logger.warn(\"Unrecognised message from worker: \", msg);\n }\n };\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts deleted file mode 100644 index ebe093f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts +++ /dev/null @@ -1,35 +0,0 @@ -/** - * This class lives in the webworker and drives a LocalIndexedDBStoreBackend - * controlled by messages from the main process. - * - * @example - * It should be instantiated by a web worker script provided by the application - * in a script, for example: - * ``` - * import {IndexedDBStoreWorker} from 'matrix-js-sdk/lib/indexeddb-worker.js'; - * const remoteWorker = new IndexedDBStoreWorker(postMessage); - * onmessage = remoteWorker.onMessage; - * ``` - * - * Note that it is advisable to import this class by referencing the file directly to - * avoid a dependency on the whole js-sdk. - * - */ -export declare class IndexedDBStoreWorker { - private readonly postMessage; - private backend?; - /** - * @param postMessage - The web worker postMessage function that - * should be used to communicate back to the main script. - */ - constructor(postMessage: InstanceType["postMessage"]); - private onClose; - /** - * Passes a message event from the main script into the class. This method - * can be directly assigned to the web worker `onmessage` variable. - * - * @param ev - The message event - */ - onMessage: (ev: MessageEvent) => void; -} -//# sourceMappingURL=indexeddb-store-worker.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts.map deleted file mode 100644 index 5ffb470..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-store-worker.d.ts","sourceRoot":"","sources":["../../src/store/indexeddb-store-worker.ts"],"names":[],"mappings":"AAyBA;;;;;;;;;;;;;;;;GAgBG;AACH,qBAAa,oBAAoB;IAOV,OAAO,CAAC,QAAQ,CAAC,WAAW;IAN/C,OAAO,CAAC,OAAO,CAAC,CAA6B;IAE7C;;;OAGG;gBACiC,WAAW,EAAE,YAAY,CAAC,OAAO,MAAM,CAAC,CAAC,aAAa,CAAC;IAE3F,OAAO,CAAC,OAAO,CAIb;IAEF;;;;;OAKG;IACI,SAAS,OAAQ,YAAY,KAAG,IAAI,CA4FzC;CACL"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js deleted file mode 100644 index 2032b67..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js +++ /dev/null @@ -1,148 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.IndexedDBStoreWorker = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _indexeddbLocalBackend = require("./indexeddb-local-backend"); -var _logger = require("../logger"); -/* -Copyright 2017 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * This class lives in the webworker and drives a LocalIndexedDBStoreBackend - * controlled by messages from the main process. - * - * @example - * It should be instantiated by a web worker script provided by the application - * in a script, for example: - * ``` - * import {IndexedDBStoreWorker} from 'matrix-js-sdk/lib/indexeddb-worker.js'; - * const remoteWorker = new IndexedDBStoreWorker(postMessage); - * onmessage = remoteWorker.onMessage; - * ``` - * - * Note that it is advisable to import this class by referencing the file directly to - * avoid a dependency on the whole js-sdk. - * - */ -class IndexedDBStoreWorker { - /** - * @param postMessage - The web worker postMessage function that - * should be used to communicate back to the main script. - */ - constructor(postMessage) { - this.postMessage = postMessage; - (0, _defineProperty2.default)(this, "backend", void 0); - (0, _defineProperty2.default)(this, "onClose", () => { - this.postMessage.call(null, { - command: "closed" - }); - }); - (0, _defineProperty2.default)(this, "onMessage", ev => { - var _this$backend, _this$backend2, _this$backend3, _this$backend4, _this$backend5, _this$backend6, _this$backend7, _this$backend8, _this$backend9, _this$backend10, _this$backend11, _this$backend12, _this$backend13, _this$backend14, _this$backend15, _this$backend16; - const msg = ev.data; - let prom; - switch (msg.command) { - case "setupWorker": - // this is the 'indexedDB' global (where global != window - // because it's a web worker and there is no window). - this.backend = new _indexeddbLocalBackend.LocalIndexedDBStoreBackend(indexedDB, msg.args[0]); - prom = Promise.resolve(); - break; - case "connect": - prom = (_this$backend = this.backend) === null || _this$backend === void 0 ? void 0 : _this$backend.connect(this.onClose); - break; - case "isNewlyCreated": - prom = (_this$backend2 = this.backend) === null || _this$backend2 === void 0 ? void 0 : _this$backend2.isNewlyCreated(); - break; - case "clearDatabase": - prom = (_this$backend3 = this.backend) === null || _this$backend3 === void 0 ? void 0 : _this$backend3.clearDatabase(); - break; - case "getSavedSync": - prom = (_this$backend4 = this.backend) === null || _this$backend4 === void 0 ? void 0 : _this$backend4.getSavedSync(false); - break; - case "setSyncData": - prom = (_this$backend5 = this.backend) === null || _this$backend5 === void 0 ? void 0 : _this$backend5.setSyncData(msg.args[0]); - break; - case "syncToDatabase": - prom = (_this$backend6 = this.backend) === null || _this$backend6 === void 0 ? void 0 : _this$backend6.syncToDatabase(msg.args[0]); - break; - case "getUserPresenceEvents": - prom = (_this$backend7 = this.backend) === null || _this$backend7 === void 0 ? void 0 : _this$backend7.getUserPresenceEvents(); - break; - case "getNextBatchToken": - prom = (_this$backend8 = this.backend) === null || _this$backend8 === void 0 ? void 0 : _this$backend8.getNextBatchToken(); - break; - case "getOutOfBandMembers": - prom = (_this$backend9 = this.backend) === null || _this$backend9 === void 0 ? void 0 : _this$backend9.getOutOfBandMembers(msg.args[0]); - break; - case "clearOutOfBandMembers": - prom = (_this$backend10 = this.backend) === null || _this$backend10 === void 0 ? void 0 : _this$backend10.clearOutOfBandMembers(msg.args[0]); - break; - case "setOutOfBandMembers": - prom = (_this$backend11 = this.backend) === null || _this$backend11 === void 0 ? void 0 : _this$backend11.setOutOfBandMembers(msg.args[0], msg.args[1]); - break; - case "getClientOptions": - prom = (_this$backend12 = this.backend) === null || _this$backend12 === void 0 ? void 0 : _this$backend12.getClientOptions(); - break; - case "storeClientOptions": - prom = (_this$backend13 = this.backend) === null || _this$backend13 === void 0 ? void 0 : _this$backend13.storeClientOptions(msg.args[0]); - break; - case "saveToDeviceBatches": - prom = (_this$backend14 = this.backend) === null || _this$backend14 === void 0 ? void 0 : _this$backend14.saveToDeviceBatches(msg.args[0]); - break; - case "getOldestToDeviceBatch": - prom = (_this$backend15 = this.backend) === null || _this$backend15 === void 0 ? void 0 : _this$backend15.getOldestToDeviceBatch(); - break; - case "removeToDeviceBatch": - prom = (_this$backend16 = this.backend) === null || _this$backend16 === void 0 ? void 0 : _this$backend16.removeToDeviceBatch(msg.args[0]); - break; - } - if (prom === undefined) { - this.postMessage({ - command: "cmd_fail", - seq: msg.seq, - // Can't be an Error because they're not structured cloneable - error: "Unrecognised command" - }); - return; - } - prom.then(ret => { - this.postMessage.call(null, { - command: "cmd_success", - seq: msg.seq, - result: ret - }); - }, err => { - _logger.logger.error("Error running command: " + msg.command, err); - this.postMessage.call(null, { - command: "cmd_fail", - seq: msg.seq, - // Just send a string because Error objects aren't cloneable - error: { - message: err.message, - name: err.name - } - }); - }); - }); - } -} -exports.IndexedDBStoreWorker = IndexedDBStoreWorker; -//# sourceMappingURL=indexeddb-store-worker.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js.map deleted file mode 100644 index 3eca38f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb-store-worker.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb-store-worker.js","names":["_indexeddbLocalBackend","require","_logger","IndexedDBStoreWorker","constructor","postMessage","_defineProperty2","default","call","command","ev","_this$backend","_this$backend2","_this$backend3","_this$backend4","_this$backend5","_this$backend6","_this$backend7","_this$backend8","_this$backend9","_this$backend10","_this$backend11","_this$backend12","_this$backend13","_this$backend14","_this$backend15","_this$backend16","msg","data","prom","backend","LocalIndexedDBStoreBackend","indexedDB","args","Promise","resolve","connect","onClose","isNewlyCreated","clearDatabase","getSavedSync","setSyncData","syncToDatabase","getUserPresenceEvents","getNextBatchToken","getOutOfBandMembers","clearOutOfBandMembers","setOutOfBandMembers","getClientOptions","storeClientOptions","saveToDeviceBatches","getOldestToDeviceBatch","removeToDeviceBatch","undefined","seq","error","then","ret","result","err","logger","message","name","exports"],"sources":["../../src/store/indexeddb-store-worker.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { LocalIndexedDBStoreBackend } from \"./indexeddb-local-backend\";\nimport { logger } from \"../logger\";\n\ninterface ICmd {\n command: string;\n seq: number;\n args: any[];\n}\n\n/**\n * This class lives in the webworker and drives a LocalIndexedDBStoreBackend\n * controlled by messages from the main process.\n *\n * @example\n * It should be instantiated by a web worker script provided by the application\n * in a script, for example:\n * ```\n * import {IndexedDBStoreWorker} from 'matrix-js-sdk/lib/indexeddb-worker.js';\n * const remoteWorker = new IndexedDBStoreWorker(postMessage);\n * onmessage = remoteWorker.onMessage;\n * ```\n *\n * Note that it is advisable to import this class by referencing the file directly to\n * avoid a dependency on the whole js-sdk.\n *\n */\nexport class IndexedDBStoreWorker {\n private backend?: LocalIndexedDBStoreBackend;\n\n /**\n * @param postMessage - The web worker postMessage function that\n * should be used to communicate back to the main script.\n */\n public constructor(private readonly postMessage: InstanceType[\"postMessage\"]) {}\n\n private onClose = (): void => {\n this.postMessage.call(null, {\n command: \"closed\",\n });\n };\n\n /**\n * Passes a message event from the main script into the class. This method\n * can be directly assigned to the web worker `onmessage` variable.\n *\n * @param ev - The message event\n */\n public onMessage = (ev: MessageEvent): void => {\n const msg: ICmd = ev.data;\n let prom: Promise | undefined;\n\n switch (msg.command) {\n case \"setupWorker\":\n // this is the 'indexedDB' global (where global != window\n // because it's a web worker and there is no window).\n this.backend = new LocalIndexedDBStoreBackend(indexedDB, msg.args[0]);\n prom = Promise.resolve();\n break;\n case \"connect\":\n prom = this.backend?.connect(this.onClose);\n break;\n case \"isNewlyCreated\":\n prom = this.backend?.isNewlyCreated();\n break;\n case \"clearDatabase\":\n prom = this.backend?.clearDatabase();\n break;\n case \"getSavedSync\":\n prom = this.backend?.getSavedSync(false);\n break;\n case \"setSyncData\":\n prom = this.backend?.setSyncData(msg.args[0]);\n break;\n case \"syncToDatabase\":\n prom = this.backend?.syncToDatabase(msg.args[0]);\n break;\n case \"getUserPresenceEvents\":\n prom = this.backend?.getUserPresenceEvents();\n break;\n case \"getNextBatchToken\":\n prom = this.backend?.getNextBatchToken();\n break;\n case \"getOutOfBandMembers\":\n prom = this.backend?.getOutOfBandMembers(msg.args[0]);\n break;\n case \"clearOutOfBandMembers\":\n prom = this.backend?.clearOutOfBandMembers(msg.args[0]);\n break;\n case \"setOutOfBandMembers\":\n prom = this.backend?.setOutOfBandMembers(msg.args[0], msg.args[1]);\n break;\n case \"getClientOptions\":\n prom = this.backend?.getClientOptions();\n break;\n case \"storeClientOptions\":\n prom = this.backend?.storeClientOptions(msg.args[0]);\n break;\n case \"saveToDeviceBatches\":\n prom = this.backend?.saveToDeviceBatches(msg.args[0]);\n break;\n case \"getOldestToDeviceBatch\":\n prom = this.backend?.getOldestToDeviceBatch();\n break;\n case \"removeToDeviceBatch\":\n prom = this.backend?.removeToDeviceBatch(msg.args[0]);\n break;\n }\n\n if (prom === undefined) {\n this.postMessage({\n command: \"cmd_fail\",\n seq: msg.seq,\n // Can't be an Error because they're not structured cloneable\n error: \"Unrecognised command\",\n });\n return;\n }\n\n prom.then(\n (ret) => {\n this.postMessage.call(null, {\n command: \"cmd_success\",\n seq: msg.seq,\n result: ret,\n });\n },\n (err) => {\n logger.error(\"Error running command: \" + msg.command, err);\n this.postMessage.call(null, {\n command: \"cmd_fail\",\n seq: msg.seq,\n // Just send a string because Error objects aren't cloneable\n error: {\n message: err.message,\n name: err.name,\n },\n });\n },\n );\n };\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts deleted file mode 100644 index 5a52787..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts +++ /dev/null @@ -1,144 +0,0 @@ -import { MemoryStore, IOpts as IBaseOpts } from "./memory"; -import { IEvent } from "../models/event"; -import { ISavedSync } from "./index"; -import { IIndexedDBBackend } from "./indexeddb-backend"; -import { ISyncResponse } from "../sync-accumulator"; -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { IStateEventWithRoomId } from "../@types/search"; -import { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from "../models/ToDeviceMessage"; -import { IStoredClientOpts } from "../client"; -interface IOpts extends IBaseOpts { - /** The Indexed DB interface e.g. `window.indexedDB` */ - indexedDB: IDBFactory; - /** Optional database name. The same name must be used to open the same database. */ - dbName?: string; - /** Optional factory to spin up a Worker to execute the IDB transactions within. */ - workerFactory?: () => Worker; -} -type EventHandlerMap = { - degraded: (e: Error) => void; - closed: () => void; -}; -export declare class IndexedDBStore extends MemoryStore { - static exists(indexedDB: IDBFactory, dbName: string): Promise; - /** - * The backend instance. - * Call through to this API if you need to perform specific indexeddb actions like deleting the database. - */ - readonly backend: IIndexedDBBackend; - private startedUp; - private syncTs; - private userModifiedMap; - private emitter; - /** - * Construct a new Indexed Database store, which extends MemoryStore. - * - * This store functions like a MemoryStore except it periodically persists - * the contents of the store to an IndexedDB backend. - * - * All data is still kept in-memory but can be loaded from disk by calling - * `startup()`. This can make startup times quicker as a complete - * sync from the server is not required. This does not reduce memory usage as all - * the data is eagerly fetched when `startup()` is called. - * ``` - * let opts = { indexedDB: window.indexedDB, localStorage: window.localStorage }; - * let store = new IndexedDBStore(opts); - * await store.startup(); // load from indexed db - * let client = sdk.createClient({ - * store: store, - * }); - * client.startClient(); - * client.on("sync", function(state, prevState, data) { - * if (state === "PREPARED") { - * console.log("Started up, now with go faster stripes!"); - * } - * }); - * ``` - * - * @param opts - Options object. - */ - constructor(opts: IOpts); - on: (event: T, listener: import("../models/typed-event-emitter").Listener) => TypedEventEmitter; - /** - * @returns Resolved when loaded from indexed db. - */ - startup(): Promise; - private onClose; - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync: DegradableFn<[], ISavedSync | null>; - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated: DegradableFn<[], boolean>; - /** - * @returns If there is a saved sync, the nextBatch token - * for this sync, otherwise null. - */ - getSavedSyncToken: DegradableFn<[], string | null>; - /** - * Delete all data from this store. - * @returns Promise which resolves if the data was deleted from the database. - */ - deleteAllData: DegradableFn<[], void>; - /** - * Whether this store would like to save its data - * Note that obviously whether the store wants to save or - * not could change between calling this function and calling - * save(). - * - * @returns True if calling save() will actually save - * (at the time this function is called). - */ - wantsSave(): boolean; - /** - * Possibly write data to the database. - * - * @param force - True to force a save to happen - * @returns Promise resolves after the write completes - * (or immediately if no write is performed) - */ - save(force?: boolean): Promise; - private reallySave; - setSyncData: DegradableFn<[syncData: ISyncResponse], void>; - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers: DegradableFn<[roomId: string], IStateEventWithRoomId[] | null>; - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - * @returns when all members have been stored - */ - setOutOfBandMembers: DegradableFn<[roomId: string, membershipEvents: IStateEventWithRoomId[]], void>; - clearOutOfBandMembers: DegradableFn<[roomId: string], void>; - getClientOptions: DegradableFn<[], IStoredClientOpts | undefined>; - storeClientOptions: DegradableFn<[options: IStoredClientOpts], void>; - /** - * All member functions of `IndexedDBStore` that access the backend use this wrapper to - * watch for failures after initial store startup, including `QuotaExceededError` as - * free disk space changes, etc. - * - * When IndexedDB fails via any of these paths, we degrade this back to a `MemoryStore` - * in place so that the current operation and all future ones are in-memory only. - * - * @param func - The degradable work to do. - * @param fallback - The method name for fallback. - * @returns A wrapped member function. - */ - private degradable; - getPendingEvents(roomId: string): Promise[]>; - setPendingEvents(roomId: string, events: Partial[]): Promise; - saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise; - getOldestToDeviceBatch(): Promise; - removeToDeviceBatch(id: number): Promise; -} -type DegradableFn, T> = (...args: A) => Promise; -export {}; -//# sourceMappingURL=indexeddb.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts.map deleted file mode 100644 index 3806a04..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb.d.ts","sourceRoot":"","sources":["../../src/store/indexeddb.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js deleted file mode 100644 index e799e17..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js +++ /dev/null @@ -1,295 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.IndexedDBStore = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _memory = require("./memory"); -var _indexeddbLocalBackend = require("./indexeddb-local-backend"); -var _indexeddbRemoteBackend = require("./indexeddb-remote-backend"); -var _user = require("../models/user"); -var _event = require("../models/event"); -var _logger = require("../logger"); -var _typedEventEmitter = require("../models/typed-event-emitter"); -/* -Copyright 2017 - 2021 Vector Creations Ltd - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/* eslint-disable @babel/no-invalid-this */ - -/** - * This is an internal module. See {@link IndexedDBStore} for the public class. - */ - -// If this value is too small we'll be writing very often which will cause -// noticeable stop-the-world pauses. If this value is too big we'll be writing -// so infrequently that the /sync size gets bigger on reload. Writing more -// often does not affect the length of the pause since the entire /sync -// response is persisted each time. -const WRITE_DELAY_MS = 1000 * 60 * 5; // once every 5 minutes - -class IndexedDBStore extends _memory.MemoryStore { - static exists(indexedDB, dbName) { - return _indexeddbLocalBackend.LocalIndexedDBStoreBackend.exists(indexedDB, dbName); - } - - /** - * The backend instance. - * Call through to this API if you need to perform specific indexeddb actions like deleting the database. - */ - - /** - * Construct a new Indexed Database store, which extends MemoryStore. - * - * This store functions like a MemoryStore except it periodically persists - * the contents of the store to an IndexedDB backend. - * - * All data is still kept in-memory but can be loaded from disk by calling - * `startup()`. This can make startup times quicker as a complete - * sync from the server is not required. This does not reduce memory usage as all - * the data is eagerly fetched when `startup()` is called. - * ``` - * let opts = { indexedDB: window.indexedDB, localStorage: window.localStorage }; - * let store = new IndexedDBStore(opts); - * await store.startup(); // load from indexed db - * let client = sdk.createClient({ - * store: store, - * }); - * client.startClient(); - * client.on("sync", function(state, prevState, data) { - * if (state === "PREPARED") { - * console.log("Started up, now with go faster stripes!"); - * } - * }); - * ``` - * - * @param opts - Options object. - */ - constructor(opts) { - super(opts); - (0, _defineProperty2.default)(this, "backend", void 0); - (0, _defineProperty2.default)(this, "startedUp", false); - (0, _defineProperty2.default)(this, "syncTs", 0); - (0, _defineProperty2.default)(this, "userModifiedMap", {}); - (0, _defineProperty2.default)(this, "emitter", new _typedEventEmitter.TypedEventEmitter()); - (0, _defineProperty2.default)(this, "on", this.emitter.on.bind(this.emitter)); - (0, _defineProperty2.default)(this, "onClose", () => { - this.emitter.emit("closed"); - }); - (0, _defineProperty2.default)(this, "getSavedSync", this.degradable(() => { - return this.backend.getSavedSync(); - }, "getSavedSync")); - (0, _defineProperty2.default)(this, "isNewlyCreated", this.degradable(() => { - return this.backend.isNewlyCreated(); - }, "isNewlyCreated")); - (0, _defineProperty2.default)(this, "getSavedSyncToken", this.degradable(() => { - return this.backend.getNextBatchToken(); - }, "getSavedSyncToken")); - (0, _defineProperty2.default)(this, "deleteAllData", this.degradable(() => { - super.deleteAllData(); - return this.backend.clearDatabase().then(() => { - _logger.logger.log("Deleted indexeddb data."); - }, err => { - _logger.logger.error(`Failed to delete indexeddb data: ${err}`); - throw err; - }); - })); - (0, _defineProperty2.default)(this, "reallySave", this.degradable(() => { - this.syncTs = Date.now(); // set now to guard against multi-writes - - // work out changed users (this doesn't handle deletions but you - // can't 'delete' users as they are just presence events). - const userTuples = []; - for (const u of this.getUsers()) { - if (this.userModifiedMap[u.userId] === u.getLastModifiedTime()) continue; - if (!u.events.presence) continue; - userTuples.push([u.userId, u.events.presence.event]); - - // note that we've saved this version of the user - this.userModifiedMap[u.userId] = u.getLastModifiedTime(); - } - return this.backend.syncToDatabase(userTuples); - })); - (0, _defineProperty2.default)(this, "setSyncData", this.degradable(syncData => { - return this.backend.setSyncData(syncData); - }, "setSyncData")); - (0, _defineProperty2.default)(this, "getOutOfBandMembers", this.degradable(roomId => { - return this.backend.getOutOfBandMembers(roomId); - }, "getOutOfBandMembers")); - (0, _defineProperty2.default)(this, "setOutOfBandMembers", this.degradable((roomId, membershipEvents) => { - super.setOutOfBandMembers(roomId, membershipEvents); - return this.backend.setOutOfBandMembers(roomId, membershipEvents); - }, "setOutOfBandMembers")); - (0, _defineProperty2.default)(this, "clearOutOfBandMembers", this.degradable(roomId => { - super.clearOutOfBandMembers(roomId); - return this.backend.clearOutOfBandMembers(roomId); - }, "clearOutOfBandMembers")); - (0, _defineProperty2.default)(this, "getClientOptions", this.degradable(() => { - return this.backend.getClientOptions(); - }, "getClientOptions")); - (0, _defineProperty2.default)(this, "storeClientOptions", this.degradable(options => { - super.storeClientOptions(options); - return this.backend.storeClientOptions(options); - }, "storeClientOptions")); - if (!opts.indexedDB) { - throw new Error("Missing required option: indexedDB"); - } - if (opts.workerFactory) { - this.backend = new _indexeddbRemoteBackend.RemoteIndexedDBStoreBackend(opts.workerFactory, opts.dbName); - } else { - this.backend = new _indexeddbLocalBackend.LocalIndexedDBStoreBackend(opts.indexedDB, opts.dbName); - } - } - /** - * @returns Resolved when loaded from indexed db. - */ - startup() { - if (this.startedUp) { - _logger.logger.log(`IndexedDBStore.startup: already started`); - return Promise.resolve(); - } - _logger.logger.log(`IndexedDBStore.startup: connecting to backend`); - return this.backend.connect(this.onClose).then(() => { - _logger.logger.log(`IndexedDBStore.startup: loading presence events`); - return this.backend.getUserPresenceEvents(); - }).then(userPresenceEvents => { - _logger.logger.log(`IndexedDBStore.startup: processing presence events`); - userPresenceEvents.forEach(([userId, rawEvent]) => { - const u = new _user.User(userId); - if (rawEvent) { - u.setPresenceEvent(new _event.MatrixEvent(rawEvent)); - } - this.userModifiedMap[u.userId] = u.getLastModifiedTime(); - this.storeUser(u); - }); - this.startedUp = true; - }); - } - /** - * Whether this store would like to save its data - * Note that obviously whether the store wants to save or - * not could change between calling this function and calling - * save(). - * - * @returns True if calling save() will actually save - * (at the time this function is called). - */ - wantsSave() { - const now = Date.now(); - return now - this.syncTs > WRITE_DELAY_MS; - } - - /** - * Possibly write data to the database. - * - * @param force - True to force a save to happen - * @returns Promise resolves after the write completes - * (or immediately if no write is performed) - */ - save(force = false) { - if (force || this.wantsSave()) { - return this.reallySave(); - } - return Promise.resolve(); - } - /** - * All member functions of `IndexedDBStore` that access the backend use this wrapper to - * watch for failures after initial store startup, including `QuotaExceededError` as - * free disk space changes, etc. - * - * When IndexedDB fails via any of these paths, we degrade this back to a `MemoryStore` - * in place so that the current operation and all future ones are in-memory only. - * - * @param func - The degradable work to do. - * @param fallback - The method name for fallback. - * @returns A wrapped member function. - */ - degradable(func, fallback) { - const fallbackFn = fallback ? super[fallback] : null; - return async (...args) => { - try { - return await func.call(this, ...args); - } catch (e) { - _logger.logger.error("IndexedDBStore failure, degrading to MemoryStore", e); - this.emitter.emit("degraded", e); - try { - // We try to delete IndexedDB after degrading since this store is only a - // cache (the app will still function correctly without the data). - // It's possible that deleting repair IndexedDB for the next app load, - // potentially by making a little more space available. - _logger.logger.log("IndexedDBStore trying to delete degraded data"); - await this.backend.clearDatabase(); - _logger.logger.log("IndexedDBStore delete after degrading succeeded"); - } catch (e) { - _logger.logger.warn("IndexedDBStore delete after degrading failed", e); - } - // Degrade the store from being an instance of `IndexedDBStore` to instead be - // an instance of `MemoryStore` so that future API calls use the memory path - // directly and skip IndexedDB entirely. This should be safe as - // `IndexedDBStore` already extends from `MemoryStore`, so we are making the - // store become its parent type in a way. The mutator methods of - // `IndexedDBStore` also maintain the state that `MemoryStore` uses (many are - // not overridden at all). - if (fallbackFn) { - return fallbackFn.call(this, ...args); - } - } - }; - } - - // XXX: ideally these would be stored in indexeddb as part of the room but, - // we don't store rooms as such and instead accumulate entire sync responses atm. - async getPendingEvents(roomId) { - if (!this.localStorage) return super.getPendingEvents(roomId); - const serialized = this.localStorage.getItem(pendingEventsKey(roomId)); - if (serialized) { - try { - return JSON.parse(serialized); - } catch (e) { - _logger.logger.error("Could not parse persisted pending events", e); - } - } - return []; - } - async setPendingEvents(roomId, events) { - if (!this.localStorage) return super.setPendingEvents(roomId, events); - if (events.length > 0) { - this.localStorage.setItem(pendingEventsKey(roomId), JSON.stringify(events)); - } else { - this.localStorage.removeItem(pendingEventsKey(roomId)); - } - } - saveToDeviceBatches(batches) { - return this.backend.saveToDeviceBatches(batches); - } - getOldestToDeviceBatch() { - return this.backend.getOldestToDeviceBatch(); - } - removeToDeviceBatch(id) { - return this.backend.removeToDeviceBatch(id); - } -} - -/** - * @param roomId - ID of the current room - * @returns Storage key to retrieve pending events - */ -exports.IndexedDBStore = IndexedDBStore; -function pendingEventsKey(roomId) { - return `mx_pending_events_${roomId}`; -} -//# sourceMappingURL=indexeddb.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js.map deleted file mode 100644 index fc38f3a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/indexeddb.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"indexeddb.js","names":["_memory","require","_indexeddbLocalBackend","_indexeddbRemoteBackend","_user","_event","_logger","_typedEventEmitter","WRITE_DELAY_MS","IndexedDBStore","MemoryStore","exists","indexedDB","dbName","LocalIndexedDBStoreBackend","constructor","opts","_defineProperty2","default","TypedEventEmitter","emitter","on","bind","emit","degradable","backend","getSavedSync","isNewlyCreated","getNextBatchToken","deleteAllData","clearDatabase","then","logger","log","err","error","syncTs","Date","now","userTuples","u","getUsers","userModifiedMap","userId","getLastModifiedTime","events","presence","push","event","syncToDatabase","syncData","setSyncData","roomId","getOutOfBandMembers","membershipEvents","setOutOfBandMembers","clearOutOfBandMembers","getClientOptions","options","storeClientOptions","Error","workerFactory","RemoteIndexedDBStoreBackend","startup","startedUp","Promise","resolve","connect","onClose","getUserPresenceEvents","userPresenceEvents","forEach","rawEvent","User","setPresenceEvent","MatrixEvent","storeUser","wantsSave","save","force","reallySave","func","fallback","fallbackFn","args","call","e","warn","getPendingEvents","localStorage","serialized","getItem","pendingEventsKey","JSON","parse","setPendingEvents","length","setItem","stringify","removeItem","saveToDeviceBatches","batches","getOldestToDeviceBatch","removeToDeviceBatch","id","exports"],"sources":["../../src/store/indexeddb.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 Vector Creations Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/* eslint-disable @babel/no-invalid-this */\n\nimport { MemoryStore, IOpts as IBaseOpts } from \"./memory\";\nimport { LocalIndexedDBStoreBackend } from \"./indexeddb-local-backend\";\nimport { RemoteIndexedDBStoreBackend } from \"./indexeddb-remote-backend\";\nimport { User } from \"../models/user\";\nimport { IEvent, MatrixEvent } from \"../models/event\";\nimport { logger } from \"../logger\";\nimport { ISavedSync } from \"./index\";\nimport { IIndexedDBBackend } from \"./indexeddb-backend\";\nimport { ISyncResponse } from \"../sync-accumulator\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { IStateEventWithRoomId } from \"../@types/search\";\nimport { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from \"../models/ToDeviceMessage\";\nimport { IStoredClientOpts } from \"../client\";\n\n/**\n * This is an internal module. See {@link IndexedDBStore} for the public class.\n */\n\n// If this value is too small we'll be writing very often which will cause\n// noticeable stop-the-world pauses. If this value is too big we'll be writing\n// so infrequently that the /sync size gets bigger on reload. Writing more\n// often does not affect the length of the pause since the entire /sync\n// response is persisted each time.\nconst WRITE_DELAY_MS = 1000 * 60 * 5; // once every 5 minutes\n\ninterface IOpts extends IBaseOpts {\n /** The Indexed DB interface e.g. `window.indexedDB` */\n indexedDB: IDBFactory;\n /** Optional database name. The same name must be used to open the same database. */\n dbName?: string;\n /** Optional factory to spin up a Worker to execute the IDB transactions within. */\n workerFactory?: () => Worker;\n}\n\ntype EventHandlerMap = {\n // Fired when an IDB command fails on a degradable path, and the store falls back to MemoryStore\n // This signals the potential for data volatility.\n degraded: (e: Error) => void;\n // Fired when the IndexedDB gets closed unexpectedly, for example, if the underlying storage is removed or\n // if the user clears the database in the browser's history preferences.\n closed: () => void;\n};\n\nexport class IndexedDBStore extends MemoryStore {\n public static exists(indexedDB: IDBFactory, dbName: string): Promise {\n return LocalIndexedDBStoreBackend.exists(indexedDB, dbName);\n }\n\n /**\n * The backend instance.\n * Call through to this API if you need to perform specific indexeddb actions like deleting the database.\n */\n public readonly backend: IIndexedDBBackend;\n\n private startedUp = false;\n private syncTs = 0;\n // Records the last-modified-time of each user at the last point we saved\n // the database, such that we can derive the set if users that have been\n // modified since we last saved.\n private userModifiedMap: Record = {}; // user_id : timestamp\n private emitter = new TypedEventEmitter();\n\n /**\n * Construct a new Indexed Database store, which extends MemoryStore.\n *\n * This store functions like a MemoryStore except it periodically persists\n * the contents of the store to an IndexedDB backend.\n *\n * All data is still kept in-memory but can be loaded from disk by calling\n * `startup()`. This can make startup times quicker as a complete\n * sync from the server is not required. This does not reduce memory usage as all\n * the data is eagerly fetched when `startup()` is called.\n * ```\n * let opts = { indexedDB: window.indexedDB, localStorage: window.localStorage };\n * let store = new IndexedDBStore(opts);\n * await store.startup(); // load from indexed db\n * let client = sdk.createClient({\n * store: store,\n * });\n * client.startClient();\n * client.on(\"sync\", function(state, prevState, data) {\n * if (state === \"PREPARED\") {\n * console.log(\"Started up, now with go faster stripes!\");\n * }\n * });\n * ```\n *\n * @param opts - Options object.\n */\n public constructor(opts: IOpts) {\n super(opts);\n\n if (!opts.indexedDB) {\n throw new Error(\"Missing required option: indexedDB\");\n }\n\n if (opts.workerFactory) {\n this.backend = new RemoteIndexedDBStoreBackend(opts.workerFactory, opts.dbName);\n } else {\n this.backend = new LocalIndexedDBStoreBackend(opts.indexedDB, opts.dbName);\n }\n }\n\n public on = this.emitter.on.bind(this.emitter);\n\n /**\n * @returns Resolved when loaded from indexed db.\n */\n public startup(): Promise {\n if (this.startedUp) {\n logger.log(`IndexedDBStore.startup: already started`);\n return Promise.resolve();\n }\n\n logger.log(`IndexedDBStore.startup: connecting to backend`);\n return this.backend\n .connect(this.onClose)\n .then(() => {\n logger.log(`IndexedDBStore.startup: loading presence events`);\n return this.backend.getUserPresenceEvents();\n })\n .then((userPresenceEvents) => {\n logger.log(`IndexedDBStore.startup: processing presence events`);\n userPresenceEvents.forEach(([userId, rawEvent]) => {\n const u = new User(userId);\n if (rawEvent) {\n u.setPresenceEvent(new MatrixEvent(rawEvent));\n }\n this.userModifiedMap[u.userId] = u.getLastModifiedTime();\n this.storeUser(u);\n });\n this.startedUp = true;\n });\n }\n\n private onClose = (): void => {\n this.emitter.emit(\"closed\");\n };\n\n /**\n * @returns Promise which resolves with a sync response to restore the\n * client state to where it was at the last save, or null if there\n * is no saved sync data.\n */\n public getSavedSync = this.degradable((): Promise => {\n return this.backend.getSavedSync();\n }, \"getSavedSync\");\n\n /** @returns whether or not the database was newly created in this session. */\n public isNewlyCreated = this.degradable((): Promise => {\n return this.backend.isNewlyCreated();\n }, \"isNewlyCreated\");\n\n /**\n * @returns If there is a saved sync, the nextBatch token\n * for this sync, otherwise null.\n */\n public getSavedSyncToken = this.degradable((): Promise => {\n return this.backend.getNextBatchToken();\n }, \"getSavedSyncToken\");\n\n /**\n * Delete all data from this store.\n * @returns Promise which resolves if the data was deleted from the database.\n */\n public deleteAllData = this.degradable((): Promise => {\n super.deleteAllData();\n return this.backend.clearDatabase().then(\n () => {\n logger.log(\"Deleted indexeddb data.\");\n },\n (err) => {\n logger.error(`Failed to delete indexeddb data: ${err}`);\n throw err;\n },\n );\n });\n\n /**\n * Whether this store would like to save its data\n * Note that obviously whether the store wants to save or\n * not could change between calling this function and calling\n * save().\n *\n * @returns True if calling save() will actually save\n * (at the time this function is called).\n */\n public wantsSave(): boolean {\n const now = Date.now();\n return now - this.syncTs > WRITE_DELAY_MS;\n }\n\n /**\n * Possibly write data to the database.\n *\n * @param force - True to force a save to happen\n * @returns Promise resolves after the write completes\n * (or immediately if no write is performed)\n */\n public save(force = false): Promise {\n if (force || this.wantsSave()) {\n return this.reallySave();\n }\n return Promise.resolve();\n }\n\n private reallySave = this.degradable((): Promise => {\n this.syncTs = Date.now(); // set now to guard against multi-writes\n\n // work out changed users (this doesn't handle deletions but you\n // can't 'delete' users as they are just presence events).\n const userTuples: [userId: string, presenceEvent: Partial][] = [];\n for (const u of this.getUsers()) {\n if (this.userModifiedMap[u.userId] === u.getLastModifiedTime()) continue;\n if (!u.events.presence) continue;\n\n userTuples.push([u.userId, u.events.presence.event]);\n\n // note that we've saved this version of the user\n this.userModifiedMap[u.userId] = u.getLastModifiedTime();\n }\n\n return this.backend.syncToDatabase(userTuples);\n });\n\n public setSyncData = this.degradable((syncData: ISyncResponse): Promise => {\n return this.backend.setSyncData(syncData);\n }, \"setSyncData\");\n\n /**\n * Returns the out-of-band membership events for this room that\n * were previously loaded.\n * @returns the events, potentially an empty array if OOB loading didn't yield any new members\n * @returns in case the members for this room haven't been stored yet\n */\n public getOutOfBandMembers = this.degradable((roomId: string): Promise => {\n return this.backend.getOutOfBandMembers(roomId);\n }, \"getOutOfBandMembers\");\n\n /**\n * Stores the out-of-band membership events for this room. Note that\n * it still makes sense to store an empty array as the OOB status for the room is\n * marked as fetched, and getOutOfBandMembers will return an empty array instead of null\n * @param membershipEvents - the membership events to store\n * @returns when all members have been stored\n */\n public setOutOfBandMembers = this.degradable(\n (roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise => {\n super.setOutOfBandMembers(roomId, membershipEvents);\n return this.backend.setOutOfBandMembers(roomId, membershipEvents);\n },\n \"setOutOfBandMembers\",\n );\n\n public clearOutOfBandMembers = this.degradable((roomId: string) => {\n super.clearOutOfBandMembers(roomId);\n return this.backend.clearOutOfBandMembers(roomId);\n }, \"clearOutOfBandMembers\");\n\n public getClientOptions = this.degradable((): Promise => {\n return this.backend.getClientOptions();\n }, \"getClientOptions\");\n\n public storeClientOptions = this.degradable((options: IStoredClientOpts): Promise => {\n super.storeClientOptions(options);\n return this.backend.storeClientOptions(options);\n }, \"storeClientOptions\");\n\n /**\n * All member functions of `IndexedDBStore` that access the backend use this wrapper to\n * watch for failures after initial store startup, including `QuotaExceededError` as\n * free disk space changes, etc.\n *\n * When IndexedDB fails via any of these paths, we degrade this back to a `MemoryStore`\n * in place so that the current operation and all future ones are in-memory only.\n *\n * @param func - The degradable work to do.\n * @param fallback - The method name for fallback.\n * @returns A wrapped member function.\n */\n private degradable, R = void>(\n func: DegradableFn,\n fallback?: keyof MemoryStore,\n ): DegradableFn {\n const fallbackFn = fallback ? (super[fallback] as Function) : null;\n\n return async (...args) => {\n try {\n return await func.call(this, ...args);\n } catch (e) {\n logger.error(\"IndexedDBStore failure, degrading to MemoryStore\", e);\n this.emitter.emit(\"degraded\", e as Error);\n try {\n // We try to delete IndexedDB after degrading since this store is only a\n // cache (the app will still function correctly without the data).\n // It's possible that deleting repair IndexedDB for the next app load,\n // potentially by making a little more space available.\n logger.log(\"IndexedDBStore trying to delete degraded data\");\n await this.backend.clearDatabase();\n logger.log(\"IndexedDBStore delete after degrading succeeded\");\n } catch (e) {\n logger.warn(\"IndexedDBStore delete after degrading failed\", e);\n }\n // Degrade the store from being an instance of `IndexedDBStore` to instead be\n // an instance of `MemoryStore` so that future API calls use the memory path\n // directly and skip IndexedDB entirely. This should be safe as\n // `IndexedDBStore` already extends from `MemoryStore`, so we are making the\n // store become its parent type in a way. The mutator methods of\n // `IndexedDBStore` also maintain the state that `MemoryStore` uses (many are\n // not overridden at all).\n if (fallbackFn) {\n return fallbackFn.call(this, ...args);\n }\n }\n };\n }\n\n // XXX: ideally these would be stored in indexeddb as part of the room but,\n // we don't store rooms as such and instead accumulate entire sync responses atm.\n public async getPendingEvents(roomId: string): Promise[]> {\n if (!this.localStorage) return super.getPendingEvents(roomId);\n\n const serialized = this.localStorage.getItem(pendingEventsKey(roomId));\n if (serialized) {\n try {\n return JSON.parse(serialized);\n } catch (e) {\n logger.error(\"Could not parse persisted pending events\", e);\n }\n }\n return [];\n }\n\n public async setPendingEvents(roomId: string, events: Partial[]): Promise {\n if (!this.localStorage) return super.setPendingEvents(roomId, events);\n\n if (events.length > 0) {\n this.localStorage.setItem(pendingEventsKey(roomId), JSON.stringify(events));\n } else {\n this.localStorage.removeItem(pendingEventsKey(roomId));\n }\n }\n\n public saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise {\n return this.backend.saveToDeviceBatches(batches);\n }\n\n public getOldestToDeviceBatch(): Promise {\n return this.backend.getOldestToDeviceBatch();\n }\n\n public removeToDeviceBatch(id: number): Promise {\n return this.backend.removeToDeviceBatch(id);\n }\n}\n\n/**\n * @param roomId - ID of the current room\n * @returns Storage key to retrieve pending events\n */\nfunction pendingEventsKey(roomId: string): string {\n return `mx_pending_events_${roomId}`;\n}\n\ntype DegradableFn, T> = (...args: A) => Promise;\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts deleted file mode 100644 index 99a61e2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts +++ /dev/null @@ -1,30 +0,0 @@ -import { TypedEventEmitter } from "../models/typed-event-emitter"; -export declare enum LocalStorageErrors { - Global = "Global", - SetItemError = "setItem", - GetItemError = "getItem", - RemoveItemError = "removeItem", - ClearError = "clear", - QuotaExceededError = "QuotaExceededError" -} -type EventHandlerMap = { - [LocalStorageErrors.Global]: (error: Error) => void; - [LocalStorageErrors.SetItemError]: (error: Error) => void; - [LocalStorageErrors.GetItemError]: (error: Error) => void; - [LocalStorageErrors.RemoveItemError]: (error: Error) => void; - [LocalStorageErrors.ClearError]: (error: Error) => void; - [LocalStorageErrors.QuotaExceededError]: (error: Error) => void; -}; -/** - * Used in element-web as a temporary hack to handle all the localStorage errors on the highest level possible - * As of 15.11.2021 (DD/MM/YYYY) we're not properly handling local storage exceptions anywhere. - * This store, as an event emitter, is used to re-emit local storage exceptions so that we can handle them - * and show some kind of a "It's dead Jim" modal to the users, telling them that hey, - * maybe you should check out your disk, as it's probably dying and your session may die with it. - * See: https://github.com/vector-im/element-web/issues/18423 - */ -declare class LocalStorageErrorsEventsEmitter extends TypedEventEmitter { -} -export declare const localStorageErrorsEventsEmitter: LocalStorageErrorsEventsEmitter; -export {}; -//# sourceMappingURL=local-storage-events-emitter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts.map deleted file mode 100644 index ddf2602..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"local-storage-events-emitter.d.ts","sourceRoot":"","sources":["../../src/store/local-storage-events-emitter.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,oBAAY,kBAAkB;IAC1B,MAAM,WAAW;IACjB,YAAY,YAAY;IACxB,YAAY,YAAY;IACxB,eAAe,eAAe;IAC9B,UAAU,UAAU;IACpB,kBAAkB,uBAAuB;CAC5C;AAED,KAAK,eAAe,GAAG;IACnB,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACpD,CAAC,kBAAkB,CAAC,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAC1D,CAAC,kBAAkB,CAAC,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAC1D,CAAC,kBAAkB,CAAC,eAAe,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAC7D,CAAC,kBAAkB,CAAC,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACxD,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;CACnE,CAAC;AAEF;;;;;;;GAOG;AACH,cAAM,+BAAgC,SAAQ,iBAAiB,CAAC,kBAAkB,EAAE,eAAe,CAAC;CAAG;AACvG,eAAO,MAAM,+BAA+B,iCAAwC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js deleted file mode 100644 index 8a474ac..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js +++ /dev/null @@ -1,44 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.localStorageErrorsEventsEmitter = exports.LocalStorageErrors = void 0; -var _typedEventEmitter = require("../models/typed-event-emitter"); -/* -Copyright 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let LocalStorageErrors; -exports.LocalStorageErrors = LocalStorageErrors; -(function (LocalStorageErrors) { - LocalStorageErrors["Global"] = "Global"; - LocalStorageErrors["SetItemError"] = "setItem"; - LocalStorageErrors["GetItemError"] = "getItem"; - LocalStorageErrors["RemoveItemError"] = "removeItem"; - LocalStorageErrors["ClearError"] = "clear"; - LocalStorageErrors["QuotaExceededError"] = "QuotaExceededError"; -})(LocalStorageErrors || (exports.LocalStorageErrors = LocalStorageErrors = {})); -/** - * Used in element-web as a temporary hack to handle all the localStorage errors on the highest level possible - * As of 15.11.2021 (DD/MM/YYYY) we're not properly handling local storage exceptions anywhere. - * This store, as an event emitter, is used to re-emit local storage exceptions so that we can handle them - * and show some kind of a "It's dead Jim" modal to the users, telling them that hey, - * maybe you should check out your disk, as it's probably dying and your session may die with it. - * See: https://github.com/vector-im/element-web/issues/18423 - */ -class LocalStorageErrorsEventsEmitter extends _typedEventEmitter.TypedEventEmitter {} -const localStorageErrorsEventsEmitter = new LocalStorageErrorsEventsEmitter(); -exports.localStorageErrorsEventsEmitter = localStorageErrorsEventsEmitter; -//# sourceMappingURL=local-storage-events-emitter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js.map deleted file mode 100644 index d128195..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/local-storage-events-emitter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"local-storage-events-emitter.js","names":["_typedEventEmitter","require","LocalStorageErrors","exports","LocalStorageErrorsEventsEmitter","TypedEventEmitter","localStorageErrorsEventsEmitter"],"sources":["../../src/store/local-storage-events-emitter.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\n\nexport enum LocalStorageErrors {\n Global = \"Global\",\n SetItemError = \"setItem\",\n GetItemError = \"getItem\",\n RemoveItemError = \"removeItem\",\n ClearError = \"clear\",\n QuotaExceededError = \"QuotaExceededError\",\n}\n\ntype EventHandlerMap = {\n [LocalStorageErrors.Global]: (error: Error) => void;\n [LocalStorageErrors.SetItemError]: (error: Error) => void;\n [LocalStorageErrors.GetItemError]: (error: Error) => void;\n [LocalStorageErrors.RemoveItemError]: (error: Error) => void;\n [LocalStorageErrors.ClearError]: (error: Error) => void;\n [LocalStorageErrors.QuotaExceededError]: (error: Error) => void;\n};\n\n/**\n * Used in element-web as a temporary hack to handle all the localStorage errors on the highest level possible\n * As of 15.11.2021 (DD/MM/YYYY) we're not properly handling local storage exceptions anywhere.\n * This store, as an event emitter, is used to re-emit local storage exceptions so that we can handle them\n * and show some kind of a \"It's dead Jim\" modal to the users, telling them that hey,\n * maybe you should check out your disk, as it's probably dying and your session may die with it.\n * See: https://github.com/vector-im/element-web/issues/18423\n */\nclass LocalStorageErrorsEventsEmitter extends TypedEventEmitter {}\nexport const localStorageErrorsEventsEmitter = new LocalStorageErrorsEventsEmitter();\n"],"mappings":";;;;;;AAgBA,IAAAA,kBAAA,GAAAC,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAkBYC,kBAAkB;AAAAC,OAAA,CAAAD,kBAAA,GAAAA,kBAAA;AAAA,WAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;EAAlBA,kBAAkB;AAAA,GAAlBA,kBAAkB,KAAAC,OAAA,CAAAD,kBAAA,GAAlBA,kBAAkB;AAkB9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAME,+BAA+B,SAASC,oCAAiB,CAAsC;AAC9F,MAAMC,+BAA+B,GAAG,IAAIF,+BAA+B,EAAE;AAACD,OAAA,CAAAG,+BAAA,GAAAA,+BAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts deleted file mode 100644 index 1daaada..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts +++ /dev/null @@ -1,206 +0,0 @@ -/** - * This is an internal module. See {@link MemoryStore} for the public class. - */ -import { EventType } from "../@types/event"; -import { Room } from "../models/room"; -import { User } from "../models/user"; -import { IEvent, MatrixEvent } from "../models/event"; -import { Filter } from "../filter"; -import { ISavedSync, IStore } from "./index"; -import { RoomSummary } from "../models/room-summary"; -import { ISyncResponse } from "../sync-accumulator"; -import { IStateEventWithRoomId } from "../@types/search"; -import { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from "../models/ToDeviceMessage"; -import { IStoredClientOpts } from "../client"; -export interface IOpts { - /** The local storage instance to persist some forms of data such as tokens. Rooms will NOT be stored. */ - localStorage?: Storage; -} -export declare class MemoryStore implements IStore { - private rooms; - private users; - private syncToken; - private filters; - accountData: Map; - protected readonly localStorage?: Storage; - private oobMembers; - private pendingEvents; - private clientOptions?; - private pendingToDeviceBatches; - private nextToDeviceBatchId; - /** - * Construct a new in-memory data store for the Matrix Client. - * @param opts - Config options - */ - constructor(opts?: IOpts); - /** - * Retrieve the token to stream from. - * @returns The token or null. - */ - getSyncToken(): string | null; - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated(): Promise; - /** - * Set the token to stream from. - * @param token - The token to stream from. - */ - setSyncToken(token: string): void; - /** - * Store the given room. - * @param room - The room to be stored. All properties must be stored. - */ - storeRoom(room: Room): void; - /** - * Called when a room member in a room being tracked by this store has been - * updated. - */ - private onRoomMember; - /** - * Retrieve a room by its' room ID. - * @param roomId - The room ID. - * @returns The room or null. - */ - getRoom(roomId: string): Room | null; - /** - * Retrieve all known rooms. - * @returns A list of rooms, which may be empty. - */ - getRooms(): Room[]; - /** - * Permanently delete a room. - */ - removeRoom(roomId: string): void; - /** - * Retrieve a summary of all the rooms. - * @returns A summary of each room. - */ - getRoomSummaries(): RoomSummary[]; - /** - * Store a User. - * @param user - The user to store. - */ - storeUser(user: User): void; - /** - * Retrieve a User by its' user ID. - * @param userId - The user ID. - * @returns The user or null. - */ - getUser(userId: string): User | null; - /** - * Retrieve all known users. - * @returns A list of users, which may be empty. - */ - getUsers(): User[]; - /** - * Retrieve scrollback for this room. - * @param room - The matrix room - * @param limit - The max number of old events to retrieve. - * @returns An array of objects which will be at most 'limit' - * length and at least 0. The objects are the raw event JSON. - */ - scrollback(room: Room, limit: number): MatrixEvent[]; - /** - * Store events for a room. The events have already been added to the timeline - * @param room - The room to store events for. - * @param events - The events to store. - * @param token - The token associated with these events. - * @param toStart - True if these are paginated results. - */ - storeEvents(room: Room, events: MatrixEvent[], token: string | null, toStart: boolean): void; - /** - * Store a filter. - */ - storeFilter(filter: Filter): void; - /** - * Retrieve a filter. - * @returns A filter or null. - */ - getFilter(userId: string, filterId: string): Filter | null; - /** - * Retrieve a filter ID with the given name. - * @param filterName - The filter name. - * @returns The filter ID or null. - */ - getFilterIdByName(filterName: string): string | null; - /** - * Set a filter name to ID mapping. - */ - setFilterIdByName(filterName: string, filterId?: string): void; - /** - * Store user-scoped account data events. - * N.B. that account data only allows a single event per type, so multiple - * events with the same type will replace each other. - * @param events - The events to store. - */ - storeAccountDataEvents(events: MatrixEvent[]): void; - /** - * Get account data event by event type - * @param eventType - The event type being queried - * @returns the user account_data event of given type, if any - */ - getAccountData(eventType: EventType | string): MatrixEvent | undefined; - /** - * setSyncData does nothing as there is no backing data store. - * - * @param syncData - The sync data - * @returns An immediately resolved promise. - */ - setSyncData(syncData: ISyncResponse): Promise; - /** - * We never want to save becase we have nothing to save to. - * - * @returns If the store wants to save - */ - wantsSave(): boolean; - /** - * Save does nothing as there is no backing data store. - * @param force - True to force a save (but the memory - * store still can't save anything) - */ - save(force: boolean): void; - /** - * Startup does nothing as this store doesn't require starting up. - * @returns An immediately resolved promise. - */ - startup(): Promise; - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync(): Promise; - /** - * @returns If there is a saved sync, the nextBatch token - * for this sync, otherwise null. - */ - getSavedSyncToken(): Promise; - /** - * Delete all data from this store. - * @returns An immediately resolved promise. - */ - deleteAllData(): Promise; - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers(roomId: string): Promise; - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - * @returns when all members have been stored - */ - setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise; - clearOutOfBandMembers(roomId: string): Promise; - getClientOptions(): Promise; - storeClientOptions(options: IStoredClientOpts): Promise; - getPendingEvents(roomId: string): Promise[]>; - setPendingEvents(roomId: string, events: Partial[]): Promise; - saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise; - getOldestToDeviceBatch(): Promise; - removeToDeviceBatch(id: number): Promise; -} -//# sourceMappingURL=memory.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts.map deleted file mode 100644 index 03a6d73..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"memory.d.ts","sourceRoot":"","sources":["../../src/store/memory.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js deleted file mode 100644 index 452897e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js +++ /dev/null @@ -1,425 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MemoryStore = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _user = require("../models/user"); -var _roomState = require("../models/room-state"); -var _utils = require("../utils"); -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * This is an internal module. See {@link MemoryStore} for the public class. - */ - -function isValidFilterId(filterId) { - const isValidStr = typeof filterId === "string" && !!filterId && filterId !== "undefined" && - // exclude these as we've serialized undefined in localStorage before - filterId !== "null"; - return isValidStr || typeof filterId === "number"; -} -class MemoryStore { - // roomId: Room - // userId: User - - // userId: { - // filterId: Filter - // } - - // type: content - - // roomId: [member events] - - /** - * Construct a new in-memory data store for the Matrix Client. - * @param opts - Config options - */ - constructor(opts = {}) { - (0, _defineProperty2.default)(this, "rooms", {}); - (0, _defineProperty2.default)(this, "users", {}); - (0, _defineProperty2.default)(this, "syncToken", null); - (0, _defineProperty2.default)(this, "filters", new _utils.MapWithDefault(() => new Map())); - (0, _defineProperty2.default)(this, "accountData", new Map()); - (0, _defineProperty2.default)(this, "localStorage", void 0); - (0, _defineProperty2.default)(this, "oobMembers", new Map()); - (0, _defineProperty2.default)(this, "pendingEvents", {}); - (0, _defineProperty2.default)(this, "clientOptions", void 0); - (0, _defineProperty2.default)(this, "pendingToDeviceBatches", []); - (0, _defineProperty2.default)(this, "nextToDeviceBatchId", 0); - (0, _defineProperty2.default)(this, "onRoomMember", (event, state, member) => { - if (member.membership === "invite") { - // We do NOT add invited members because people love to typo user IDs - // which would then show up in these lists (!) - return; - } - const user = this.users[member.userId] || new _user.User(member.userId); - if (member.name) { - user.setDisplayName(member.name); - if (member.events.member) { - user.setRawDisplayName(member.events.member.getDirectionalContent().displayname); - } - } - if (member.events.member && member.events.member.getContent().avatar_url) { - user.setAvatarUrl(member.events.member.getContent().avatar_url); - } - this.users[user.userId] = user; - }); - this.localStorage = opts.localStorage; - } - - /** - * Retrieve the token to stream from. - * @returns The token or null. - */ - getSyncToken() { - return this.syncToken; - } - - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated() { - return Promise.resolve(true); - } - - /** - * Set the token to stream from. - * @param token - The token to stream from. - */ - setSyncToken(token) { - this.syncToken = token; - } - - /** - * Store the given room. - * @param room - The room to be stored. All properties must be stored. - */ - storeRoom(room) { - this.rooms[room.roomId] = room; - // add listeners for room member changes so we can keep the room member - // map up-to-date. - room.currentState.on(_roomState.RoomStateEvent.Members, this.onRoomMember); - // add existing members - room.currentState.getMembers().forEach(m => { - this.onRoomMember(null, room.currentState, m); - }); - } - - /** - * Called when a room member in a room being tracked by this store has been - * updated. - */ - - /** - * Retrieve a room by its' room ID. - * @param roomId - The room ID. - * @returns The room or null. - */ - getRoom(roomId) { - return this.rooms[roomId] || null; - } - - /** - * Retrieve all known rooms. - * @returns A list of rooms, which may be empty. - */ - getRooms() { - return Object.values(this.rooms); - } - - /** - * Permanently delete a room. - */ - removeRoom(roomId) { - if (this.rooms[roomId]) { - this.rooms[roomId].currentState.removeListener(_roomState.RoomStateEvent.Members, this.onRoomMember); - } - delete this.rooms[roomId]; - } - - /** - * Retrieve a summary of all the rooms. - * @returns A summary of each room. - */ - getRoomSummaries() { - return Object.values(this.rooms).map(function (room) { - return room.summary; - }); - } - - /** - * Store a User. - * @param user - The user to store. - */ - storeUser(user) { - this.users[user.userId] = user; - } - - /** - * Retrieve a User by its' user ID. - * @param userId - The user ID. - * @returns The user or null. - */ - getUser(userId) { - return this.users[userId] || null; - } - - /** - * Retrieve all known users. - * @returns A list of users, which may be empty. - */ - getUsers() { - return Object.values(this.users); - } - - /** - * Retrieve scrollback for this room. - * @param room - The matrix room - * @param limit - The max number of old events to retrieve. - * @returns An array of objects which will be at most 'limit' - * length and at least 0. The objects are the raw event JSON. - */ - scrollback(room, limit) { - return []; - } - - /** - * Store events for a room. The events have already been added to the timeline - * @param room - The room to store events for. - * @param events - The events to store. - * @param token - The token associated with these events. - * @param toStart - True if these are paginated results. - */ - storeEvents(room, events, token, toStart) { - // no-op because they've already been added to the room instance. - } - - /** - * Store a filter. - */ - storeFilter(filter) { - if (!(filter !== null && filter !== void 0 && filter.userId) || !(filter !== null && filter !== void 0 && filter.filterId)) return; - this.filters.getOrCreate(filter.userId).set(filter.filterId, filter); - } - - /** - * Retrieve a filter. - * @returns A filter or null. - */ - getFilter(userId, filterId) { - var _this$filters$get; - return ((_this$filters$get = this.filters.get(userId)) === null || _this$filters$get === void 0 ? void 0 : _this$filters$get.get(filterId)) || null; - } - - /** - * Retrieve a filter ID with the given name. - * @param filterName - The filter name. - * @returns The filter ID or null. - */ - getFilterIdByName(filterName) { - if (!this.localStorage) { - return null; - } - const key = "mxjssdk_memory_filter_" + filterName; - // XXX Storage.getItem doesn't throw ... - // or are we using something different - // than window.localStorage in some cases - // that does throw? - // that would be very naughty - try { - const value = this.localStorage.getItem(key); - if (isValidFilterId(value)) { - return value; - } - } catch (e) {} - return null; - } - - /** - * Set a filter name to ID mapping. - */ - setFilterIdByName(filterName, filterId) { - if (!this.localStorage) { - return; - } - const key = "mxjssdk_memory_filter_" + filterName; - try { - if (isValidFilterId(filterId)) { - this.localStorage.setItem(key, filterId); - } else { - this.localStorage.removeItem(key); - } - } catch (e) {} - } - - /** - * Store user-scoped account data events. - * N.B. that account data only allows a single event per type, so multiple - * events with the same type will replace each other. - * @param events - The events to store. - */ - storeAccountDataEvents(events) { - events.forEach(event => { - // MSC3391: an event with content of {} should be interpreted as deleted - const isDeleted = !Object.keys(event.getContent()).length; - if (isDeleted) { - this.accountData.delete(event.getType()); - } else { - this.accountData.set(event.getType(), event); - } - }); - } - - /** - * Get account data event by event type - * @param eventType - The event type being queried - * @returns the user account_data event of given type, if any - */ - getAccountData(eventType) { - return this.accountData.get(eventType); - } - - /** - * setSyncData does nothing as there is no backing data store. - * - * @param syncData - The sync data - * @returns An immediately resolved promise. - */ - setSyncData(syncData) { - return Promise.resolve(); - } - - /** - * We never want to save becase we have nothing to save to. - * - * @returns If the store wants to save - */ - wantsSave() { - return false; - } - - /** - * Save does nothing as there is no backing data store. - * @param force - True to force a save (but the memory - * store still can't save anything) - */ - save(force) {} - - /** - * Startup does nothing as this store doesn't require starting up. - * @returns An immediately resolved promise. - */ - startup() { - return Promise.resolve(); - } - - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync() { - return Promise.resolve(null); - } - - /** - * @returns If there is a saved sync, the nextBatch token - * for this sync, otherwise null. - */ - getSavedSyncToken() { - return Promise.resolve(null); - } - - /** - * Delete all data from this store. - * @returns An immediately resolved promise. - */ - deleteAllData() { - this.rooms = { - // roomId: Room - }; - this.users = { - // userId: User - }; - this.syncToken = null; - this.filters = new _utils.MapWithDefault(() => new Map()); - this.accountData = new Map(); // type : content - return Promise.resolve(); - } - - /** - * Returns the out-of-band membership events for this room that - * were previously loaded. - * @returns the events, potentially an empty array if OOB loading didn't yield any new members - * @returns in case the members for this room haven't been stored yet - */ - getOutOfBandMembers(roomId) { - return Promise.resolve(this.oobMembers.get(roomId) || null); - } - - /** - * Stores the out-of-band membership events for this room. Note that - * it still makes sense to store an empty array as the OOB status for the room is - * marked as fetched, and getOutOfBandMembers will return an empty array instead of null - * @param membershipEvents - the membership events to store - * @returns when all members have been stored - */ - setOutOfBandMembers(roomId, membershipEvents) { - this.oobMembers.set(roomId, membershipEvents); - return Promise.resolve(); - } - clearOutOfBandMembers(roomId) { - this.oobMembers.delete(roomId); - return Promise.resolve(); - } - getClientOptions() { - return Promise.resolve(this.clientOptions); - } - storeClientOptions(options) { - this.clientOptions = Object.assign({}, options); - return Promise.resolve(); - } - async getPendingEvents(roomId) { - var _this$pendingEvents$r; - return (_this$pendingEvents$r = this.pendingEvents[roomId]) !== null && _this$pendingEvents$r !== void 0 ? _this$pendingEvents$r : []; - } - async setPendingEvents(roomId, events) { - this.pendingEvents[roomId] = events; - } - saveToDeviceBatches(batches) { - for (const batch of batches) { - this.pendingToDeviceBatches.push({ - id: this.nextToDeviceBatchId++, - eventType: batch.eventType, - txnId: batch.txnId, - batch: batch.batch - }); - } - return Promise.resolve(); - } - async getOldestToDeviceBatch() { - if (this.pendingToDeviceBatches.length === 0) return null; - return this.pendingToDeviceBatches[0]; - } - removeToDeviceBatch(id) { - this.pendingToDeviceBatches = this.pendingToDeviceBatches.filter(batch => batch.id !== id); - return Promise.resolve(); - } -} -exports.MemoryStore = MemoryStore; -//# sourceMappingURL=memory.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js.map deleted file mode 100644 index becc757..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/memory.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"memory.js","names":["_user","require","_roomState","_utils","isValidFilterId","filterId","isValidStr","MemoryStore","constructor","opts","_defineProperty2","default","MapWithDefault","Map","event","state","member","membership","user","users","userId","User","name","setDisplayName","events","setRawDisplayName","getDirectionalContent","displayname","getContent","avatar_url","setAvatarUrl","localStorage","getSyncToken","syncToken","isNewlyCreated","Promise","resolve","setSyncToken","token","storeRoom","room","rooms","roomId","currentState","on","RoomStateEvent","Members","onRoomMember","getMembers","forEach","m","getRoom","getRooms","Object","values","removeRoom","removeListener","getRoomSummaries","map","summary","storeUser","getUser","getUsers","scrollback","limit","storeEvents","toStart","storeFilter","filter","filters","getOrCreate","set","getFilter","_this$filters$get","get","getFilterIdByName","filterName","key","value","getItem","e","setFilterIdByName","setItem","removeItem","storeAccountDataEvents","isDeleted","keys","length","accountData","delete","getType","getAccountData","eventType","setSyncData","syncData","wantsSave","save","force","startup","getSavedSync","getSavedSyncToken","deleteAllData","getOutOfBandMembers","oobMembers","setOutOfBandMembers","membershipEvents","clearOutOfBandMembers","getClientOptions","clientOptions","storeClientOptions","options","assign","getPendingEvents","_this$pendingEvents$r","pendingEvents","setPendingEvents","saveToDeviceBatches","batches","batch","pendingToDeviceBatches","push","id","nextToDeviceBatchId","txnId","getOldestToDeviceBatch","removeToDeviceBatch","exports"],"sources":["../../src/store/memory.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module. See {@link MemoryStore} for the public class.\n */\n\nimport { EventType } from \"../@types/event\";\nimport { Room } from \"../models/room\";\nimport { User } from \"../models/user\";\nimport { IEvent, MatrixEvent } from \"../models/event\";\nimport { RoomState, RoomStateEvent } from \"../models/room-state\";\nimport { RoomMember } from \"../models/room-member\";\nimport { Filter } from \"../filter\";\nimport { ISavedSync, IStore } from \"./index\";\nimport { RoomSummary } from \"../models/room-summary\";\nimport { ISyncResponse } from \"../sync-accumulator\";\nimport { IStateEventWithRoomId } from \"../@types/search\";\nimport { IndexedToDeviceBatch, ToDeviceBatchWithTxnId } from \"../models/ToDeviceMessage\";\nimport { IStoredClientOpts } from \"../client\";\nimport { MapWithDefault } from \"../utils\";\n\nfunction isValidFilterId(filterId?: string | number | null): boolean {\n const isValidStr =\n typeof filterId === \"string\" &&\n !!filterId &&\n filterId !== \"undefined\" && // exclude these as we've serialized undefined in localStorage before\n filterId !== \"null\";\n\n return isValidStr || typeof filterId === \"number\";\n}\n\nexport interface IOpts {\n /** The local storage instance to persist some forms of data such as tokens. Rooms will NOT be stored. */\n localStorage?: Storage;\n}\n\nexport class MemoryStore implements IStore {\n private rooms: Record = {}; // roomId: Room\n private users: Record = {}; // userId: User\n private syncToken: string | null = null;\n // userId: {\n // filterId: Filter\n // }\n private filters: MapWithDefault> = new MapWithDefault(() => new Map());\n public accountData: Map = new Map(); // type: content\n protected readonly localStorage?: Storage;\n private oobMembers: Map = new Map(); // roomId: [member events]\n private pendingEvents: { [roomId: string]: Partial[] } = {};\n private clientOptions?: IStoredClientOpts;\n private pendingToDeviceBatches: IndexedToDeviceBatch[] = [];\n private nextToDeviceBatchId = 0;\n\n /**\n * Construct a new in-memory data store for the Matrix Client.\n * @param opts - Config options\n */\n public constructor(opts: IOpts = {}) {\n this.localStorage = opts.localStorage;\n }\n\n /**\n * Retrieve the token to stream from.\n * @returns The token or null.\n */\n public getSyncToken(): string | null {\n return this.syncToken;\n }\n\n /** @returns whether or not the database was newly created in this session. */\n public isNewlyCreated(): Promise {\n return Promise.resolve(true);\n }\n\n /**\n * Set the token to stream from.\n * @param token - The token to stream from.\n */\n public setSyncToken(token: string): void {\n this.syncToken = token;\n }\n\n /**\n * Store the given room.\n * @param room - The room to be stored. All properties must be stored.\n */\n public storeRoom(room: Room): void {\n this.rooms[room.roomId] = room;\n // add listeners for room member changes so we can keep the room member\n // map up-to-date.\n room.currentState.on(RoomStateEvent.Members, this.onRoomMember);\n // add existing members\n room.currentState.getMembers().forEach((m) => {\n this.onRoomMember(null, room.currentState, m);\n });\n }\n\n /**\n * Called when a room member in a room being tracked by this store has been\n * updated.\n */\n private onRoomMember = (event: MatrixEvent | null, state: RoomState, member: RoomMember): void => {\n if (member.membership === \"invite\") {\n // We do NOT add invited members because people love to typo user IDs\n // which would then show up in these lists (!)\n return;\n }\n\n const user = this.users[member.userId] || new User(member.userId);\n if (member.name) {\n user.setDisplayName(member.name);\n if (member.events.member) {\n user.setRawDisplayName(member.events.member.getDirectionalContent().displayname);\n }\n }\n if (member.events.member && member.events.member.getContent().avatar_url) {\n user.setAvatarUrl(member.events.member.getContent().avatar_url);\n }\n this.users[user.userId] = user;\n };\n\n /**\n * Retrieve a room by its' room ID.\n * @param roomId - The room ID.\n * @returns The room or null.\n */\n public getRoom(roomId: string): Room | null {\n return this.rooms[roomId] || null;\n }\n\n /**\n * Retrieve all known rooms.\n * @returns A list of rooms, which may be empty.\n */\n public getRooms(): Room[] {\n return Object.values(this.rooms);\n }\n\n /**\n * Permanently delete a room.\n */\n public removeRoom(roomId: string): void {\n if (this.rooms[roomId]) {\n this.rooms[roomId].currentState.removeListener(RoomStateEvent.Members, this.onRoomMember);\n }\n delete this.rooms[roomId];\n }\n\n /**\n * Retrieve a summary of all the rooms.\n * @returns A summary of each room.\n */\n public getRoomSummaries(): RoomSummary[] {\n return Object.values(this.rooms).map(function (room) {\n return room.summary!;\n });\n }\n\n /**\n * Store a User.\n * @param user - The user to store.\n */\n public storeUser(user: User): void {\n this.users[user.userId] = user;\n }\n\n /**\n * Retrieve a User by its' user ID.\n * @param userId - The user ID.\n * @returns The user or null.\n */\n public getUser(userId: string): User | null {\n return this.users[userId] || null;\n }\n\n /**\n * Retrieve all known users.\n * @returns A list of users, which may be empty.\n */\n public getUsers(): User[] {\n return Object.values(this.users);\n }\n\n /**\n * Retrieve scrollback for this room.\n * @param room - The matrix room\n * @param limit - The max number of old events to retrieve.\n * @returns An array of objects which will be at most 'limit'\n * length and at least 0. The objects are the raw event JSON.\n */\n public scrollback(room: Room, limit: number): MatrixEvent[] {\n return [];\n }\n\n /**\n * Store events for a room. The events have already been added to the timeline\n * @param room - The room to store events for.\n * @param events - The events to store.\n * @param token - The token associated with these events.\n * @param toStart - True if these are paginated results.\n */\n public storeEvents(room: Room, events: MatrixEvent[], token: string | null, toStart: boolean): void {\n // no-op because they've already been added to the room instance.\n }\n\n /**\n * Store a filter.\n */\n public storeFilter(filter: Filter): void {\n if (!filter?.userId || !filter?.filterId) return;\n this.filters.getOrCreate(filter.userId).set(filter.filterId, filter);\n }\n\n /**\n * Retrieve a filter.\n * @returns A filter or null.\n */\n public getFilter(userId: string, filterId: string): Filter | null {\n return this.filters.get(userId)?.get(filterId) || null;\n }\n\n /**\n * Retrieve a filter ID with the given name.\n * @param filterName - The filter name.\n * @returns The filter ID or null.\n */\n public getFilterIdByName(filterName: string): string | null {\n if (!this.localStorage) {\n return null;\n }\n const key = \"mxjssdk_memory_filter_\" + filterName;\n // XXX Storage.getItem doesn't throw ...\n // or are we using something different\n // than window.localStorage in some cases\n // that does throw?\n // that would be very naughty\n try {\n const value = this.localStorage.getItem(key);\n if (isValidFilterId(value)) {\n return value;\n }\n } catch (e) {}\n return null;\n }\n\n /**\n * Set a filter name to ID mapping.\n */\n public setFilterIdByName(filterName: string, filterId?: string): void {\n if (!this.localStorage) {\n return;\n }\n const key = \"mxjssdk_memory_filter_\" + filterName;\n try {\n if (isValidFilterId(filterId)) {\n this.localStorage.setItem(key, filterId!);\n } else {\n this.localStorage.removeItem(key);\n }\n } catch (e) {}\n }\n\n /**\n * Store user-scoped account data events.\n * N.B. that account data only allows a single event per type, so multiple\n * events with the same type will replace each other.\n * @param events - The events to store.\n */\n public storeAccountDataEvents(events: MatrixEvent[]): void {\n events.forEach((event) => {\n // MSC3391: an event with content of {} should be interpreted as deleted\n const isDeleted = !Object.keys(event.getContent()).length;\n if (isDeleted) {\n this.accountData.delete(event.getType());\n } else {\n this.accountData.set(event.getType(), event);\n }\n });\n }\n\n /**\n * Get account data event by event type\n * @param eventType - The event type being queried\n * @returns the user account_data event of given type, if any\n */\n public getAccountData(eventType: EventType | string): MatrixEvent | undefined {\n return this.accountData.get(eventType);\n }\n\n /**\n * setSyncData does nothing as there is no backing data store.\n *\n * @param syncData - The sync data\n * @returns An immediately resolved promise.\n */\n public setSyncData(syncData: ISyncResponse): Promise {\n return Promise.resolve();\n }\n\n /**\n * We never want to save becase we have nothing to save to.\n *\n * @returns If the store wants to save\n */\n public wantsSave(): boolean {\n return false;\n }\n\n /**\n * Save does nothing as there is no backing data store.\n * @param force - True to force a save (but the memory\n * store still can't save anything)\n */\n public save(force: boolean): void {}\n\n /**\n * Startup does nothing as this store doesn't require starting up.\n * @returns An immediately resolved promise.\n */\n public startup(): Promise {\n return Promise.resolve();\n }\n\n /**\n * @returns Promise which resolves with a sync response to restore the\n * client state to where it was at the last save, or null if there\n * is no saved sync data.\n */\n public getSavedSync(): Promise {\n return Promise.resolve(null);\n }\n\n /**\n * @returns If there is a saved sync, the nextBatch token\n * for this sync, otherwise null.\n */\n public getSavedSyncToken(): Promise {\n return Promise.resolve(null);\n }\n\n /**\n * Delete all data from this store.\n * @returns An immediately resolved promise.\n */\n public deleteAllData(): Promise {\n this.rooms = {\n // roomId: Room\n };\n this.users = {\n // userId: User\n };\n this.syncToken = null;\n this.filters = new MapWithDefault(() => new Map());\n this.accountData = new Map(); // type : content\n return Promise.resolve();\n }\n\n /**\n * Returns the out-of-band membership events for this room that\n * were previously loaded.\n * @returns the events, potentially an empty array if OOB loading didn't yield any new members\n * @returns in case the members for this room haven't been stored yet\n */\n public getOutOfBandMembers(roomId: string): Promise {\n return Promise.resolve(this.oobMembers.get(roomId) || null);\n }\n\n /**\n * Stores the out-of-band membership events for this room. Note that\n * it still makes sense to store an empty array as the OOB status for the room is\n * marked as fetched, and getOutOfBandMembers will return an empty array instead of null\n * @param membershipEvents - the membership events to store\n * @returns when all members have been stored\n */\n public setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise {\n this.oobMembers.set(roomId, membershipEvents);\n return Promise.resolve();\n }\n\n public clearOutOfBandMembers(roomId: string): Promise {\n this.oobMembers.delete(roomId);\n return Promise.resolve();\n }\n\n public getClientOptions(): Promise {\n return Promise.resolve(this.clientOptions);\n }\n\n public storeClientOptions(options: IStoredClientOpts): Promise {\n this.clientOptions = Object.assign({}, options);\n return Promise.resolve();\n }\n\n public async getPendingEvents(roomId: string): Promise[]> {\n return this.pendingEvents[roomId] ?? [];\n }\n\n public async setPendingEvents(roomId: string, events: Partial[]): Promise {\n this.pendingEvents[roomId] = events;\n }\n\n public saveToDeviceBatches(batches: ToDeviceBatchWithTxnId[]): Promise {\n for (const batch of batches) {\n this.pendingToDeviceBatches.push({\n id: this.nextToDeviceBatchId++,\n eventType: batch.eventType,\n txnId: batch.txnId,\n batch: batch.batch,\n });\n }\n return Promise.resolve();\n }\n\n public async getOldestToDeviceBatch(): Promise {\n if (this.pendingToDeviceBatches.length === 0) return null;\n return this.pendingToDeviceBatches[0];\n }\n\n public removeToDeviceBatch(id: number): Promise {\n this.pendingToDeviceBatches = this.pendingToDeviceBatches.filter((batch) => batch.id !== id);\n return Promise.resolve();\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts deleted file mode 100644 index 8ba1498..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts +++ /dev/null @@ -1,156 +0,0 @@ -/** - * This is an internal module. - */ -import { EventType } from "../@types/event"; -import { Room } from "../models/room"; -import { User } from "../models/user"; -import { IEvent, MatrixEvent } from "../models/event"; -import { Filter } from "../filter"; -import { ISavedSync, IStore } from "./index"; -import { RoomSummary } from "../models/room-summary"; -import { ISyncResponse } from "../sync-accumulator"; -import { IStateEventWithRoomId } from "../@types/search"; -import { IndexedToDeviceBatch, ToDeviceBatch } from "../models/ToDeviceMessage"; -import { IStoredClientOpts } from "../client"; -/** - * Construct a stub store. This does no-ops on most store methods. - */ -export declare class StubStore implements IStore { - readonly accountData: Map; - private fromToken; - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated(): Promise; - /** - * Get the sync token. - */ - getSyncToken(): string | null; - /** - * Set the sync token. - */ - setSyncToken(token: string): void; - /** - * No-op. - */ - storeRoom(room: Room): void; - /** - * No-op. - */ - getRoom(roomId: string): Room | null; - /** - * No-op. - * @returns An empty array. - */ - getRooms(): Room[]; - /** - * Permanently delete a room. - */ - removeRoom(roomId: string): void; - /** - * No-op. - * @returns An empty array. - */ - getRoomSummaries(): RoomSummary[]; - /** - * No-op. - */ - storeUser(user: User): void; - /** - * No-op. - */ - getUser(userId: string): User | null; - /** - * No-op. - */ - getUsers(): User[]; - /** - * No-op. - */ - scrollback(room: Room, limit: number): MatrixEvent[]; - /** - * Store events for a room. - * @param room - The room to store events for. - * @param events - The events to store. - * @param token - The token associated with these events. - * @param toStart - True if these are paginated results. - */ - storeEvents(room: Room, events: MatrixEvent[], token: string | null, toStart: boolean): void; - /** - * Store a filter. - */ - storeFilter(filter: Filter): void; - /** - * Retrieve a filter. - * @returns A filter or null. - */ - getFilter(userId: string, filterId: string): Filter | null; - /** - * Retrieve a filter ID with the given name. - * @param filterName - The filter name. - * @returns The filter ID or null. - */ - getFilterIdByName(filterName: string): string | null; - /** - * Set a filter name to ID mapping. - */ - setFilterIdByName(filterName: string, filterId?: string): void; - /** - * Store user-scoped account data events - * @param events - The events to store. - */ - storeAccountDataEvents(events: MatrixEvent[]): void; - /** - * Get account data event by event type - * @param eventType - The event type being queried - */ - getAccountData(eventType: EventType | string): MatrixEvent | undefined; - /** - * setSyncData does nothing as there is no backing data store. - * - * @param syncData - The sync data - * @returns An immediately resolved promise. - */ - setSyncData(syncData: ISyncResponse): Promise; - /** - * We never want to save because we have nothing to save to. - * - * @returns If the store wants to save - */ - wantsSave(): boolean; - /** - * Save does nothing as there is no backing data store. - */ - save(): void; - /** - * Startup does nothing. - * @returns An immediately resolved promise. - */ - startup(): Promise; - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync(): Promise; - /** - * @returns If there is a saved sync, the nextBatch token - * for this sync, otherwise null. - */ - getSavedSyncToken(): Promise; - /** - * Delete all data from this store. Does nothing since this store - * doesn't store anything. - * @returns An immediately resolved promise. - */ - deleteAllData(): Promise; - getOutOfBandMembers(): Promise; - setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise; - clearOutOfBandMembers(): Promise; - getClientOptions(): Promise; - storeClientOptions(options: IStoredClientOpts): Promise; - getPendingEvents(roomId: string): Promise[]>; - setPendingEvents(roomId: string, events: Partial[]): Promise; - saveToDeviceBatches(batch: ToDeviceBatch[]): Promise; - getOldestToDeviceBatch(): Promise; - removeToDeviceBatch(id: number): Promise; -} -//# sourceMappingURL=stub.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts.map deleted file mode 100644 index c5c9ad8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"stub.d.ts","sourceRoot":"","sources":["../../src/store/stub.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js deleted file mode 100644 index fc3624f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js +++ /dev/null @@ -1,256 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.StubStore = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2015 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * This is an internal module. - */ - -/** - * Construct a stub store. This does no-ops on most store methods. - */ -class StubStore { - constructor() { - (0, _defineProperty2.default)(this, "accountData", new Map()); - (0, _defineProperty2.default)(this, "fromToken", null); - } - /** @returns whether or not the database was newly created in this session. */ - isNewlyCreated() { - return Promise.resolve(true); - } - - /** - * Get the sync token. - */ - getSyncToken() { - return this.fromToken; - } - - /** - * Set the sync token. - */ - setSyncToken(token) { - this.fromToken = token; - } - - /** - * No-op. - */ - storeRoom(room) {} - - /** - * No-op. - */ - getRoom(roomId) { - return null; - } - - /** - * No-op. - * @returns An empty array. - */ - getRooms() { - return []; - } - - /** - * Permanently delete a room. - */ - removeRoom(roomId) { - return; - } - - /** - * No-op. - * @returns An empty array. - */ - getRoomSummaries() { - return []; - } - - /** - * No-op. - */ - storeUser(user) {} - - /** - * No-op. - */ - getUser(userId) { - return null; - } - - /** - * No-op. - */ - getUsers() { - return []; - } - - /** - * No-op. - */ - scrollback(room, limit) { - return []; - } - - /** - * Store events for a room. - * @param room - The room to store events for. - * @param events - The events to store. - * @param token - The token associated with these events. - * @param toStart - True if these are paginated results. - */ - storeEvents(room, events, token, toStart) {} - - /** - * Store a filter. - */ - storeFilter(filter) {} - - /** - * Retrieve a filter. - * @returns A filter or null. - */ - getFilter(userId, filterId) { - return null; - } - - /** - * Retrieve a filter ID with the given name. - * @param filterName - The filter name. - * @returns The filter ID or null. - */ - getFilterIdByName(filterName) { - return null; - } - - /** - * Set a filter name to ID mapping. - */ - setFilterIdByName(filterName, filterId) {} - - /** - * Store user-scoped account data events - * @param events - The events to store. - */ - storeAccountDataEvents(events) {} - - /** - * Get account data event by event type - * @param eventType - The event type being queried - */ - getAccountData(eventType) { - return undefined; - } - - /** - * setSyncData does nothing as there is no backing data store. - * - * @param syncData - The sync data - * @returns An immediately resolved promise. - */ - setSyncData(syncData) { - return Promise.resolve(); - } - - /** - * We never want to save because we have nothing to save to. - * - * @returns If the store wants to save - */ - wantsSave() { - return false; - } - - /** - * Save does nothing as there is no backing data store. - */ - save() {} - - /** - * Startup does nothing. - * @returns An immediately resolved promise. - */ - startup() { - return Promise.resolve(); - } - - /** - * @returns Promise which resolves with a sync response to restore the - * client state to where it was at the last save, or null if there - * is no saved sync data. - */ - getSavedSync() { - return Promise.resolve(null); - } - - /** - * @returns If there is a saved sync, the nextBatch token - * for this sync, otherwise null. - */ - getSavedSyncToken() { - return Promise.resolve(null); - } - - /** - * Delete all data from this store. Does nothing since this store - * doesn't store anything. - * @returns An immediately resolved promise. - */ - deleteAllData() { - return Promise.resolve(); - } - getOutOfBandMembers() { - return Promise.resolve(null); - } - setOutOfBandMembers(roomId, membershipEvents) { - return Promise.resolve(); - } - clearOutOfBandMembers() { - return Promise.resolve(); - } - getClientOptions() { - return Promise.resolve(undefined); - } - storeClientOptions(options) { - return Promise.resolve(); - } - async getPendingEvents(roomId) { - return []; - } - setPendingEvents(roomId, events) { - return Promise.resolve(); - } - async saveToDeviceBatches(batch) { - return Promise.resolve(); - } - getOldestToDeviceBatch() { - return Promise.resolve(null); - } - async removeToDeviceBatch(id) { - return Promise.resolve(); - } -} -exports.StubStore = StubStore; -//# sourceMappingURL=stub.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js.map deleted file mode 100644 index 066de64..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/store/stub.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"stub.js","names":["StubStore","constructor","_defineProperty2","default","Map","isNewlyCreated","Promise","resolve","getSyncToken","fromToken","setSyncToken","token","storeRoom","room","getRoom","roomId","getRooms","removeRoom","getRoomSummaries","storeUser","user","getUser","userId","getUsers","scrollback","limit","storeEvents","events","toStart","storeFilter","filter","getFilter","filterId","getFilterIdByName","filterName","setFilterIdByName","storeAccountDataEvents","getAccountData","eventType","undefined","setSyncData","syncData","wantsSave","save","startup","getSavedSync","getSavedSyncToken","deleteAllData","getOutOfBandMembers","setOutOfBandMembers","membershipEvents","clearOutOfBandMembers","getClientOptions","storeClientOptions","options","getPendingEvents","setPendingEvents","saveToDeviceBatches","batch","getOldestToDeviceBatch","removeToDeviceBatch","id","exports"],"sources":["../../src/store/stub.ts"],"sourcesContent":["/*\nCopyright 2015 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module.\n */\n\nimport { EventType } from \"../@types/event\";\nimport { Room } from \"../models/room\";\nimport { User } from \"../models/user\";\nimport { IEvent, MatrixEvent } from \"../models/event\";\nimport { Filter } from \"../filter\";\nimport { ISavedSync, IStore } from \"./index\";\nimport { RoomSummary } from \"../models/room-summary\";\nimport { ISyncResponse } from \"../sync-accumulator\";\nimport { IStateEventWithRoomId } from \"../@types/search\";\nimport { IndexedToDeviceBatch, ToDeviceBatch } from \"../models/ToDeviceMessage\";\nimport { IStoredClientOpts } from \"../client\";\n\n/**\n * Construct a stub store. This does no-ops on most store methods.\n */\nexport class StubStore implements IStore {\n public readonly accountData = new Map(); // stub\n private fromToken: string | null = null;\n\n /** @returns whether or not the database was newly created in this session. */\n public isNewlyCreated(): Promise {\n return Promise.resolve(true);\n }\n\n /**\n * Get the sync token.\n */\n public getSyncToken(): string | null {\n return this.fromToken;\n }\n\n /**\n * Set the sync token.\n */\n public setSyncToken(token: string): void {\n this.fromToken = token;\n }\n\n /**\n * No-op.\n */\n public storeRoom(room: Room): void {}\n\n /**\n * No-op.\n */\n public getRoom(roomId: string): Room | null {\n return null;\n }\n\n /**\n * No-op.\n * @returns An empty array.\n */\n public getRooms(): Room[] {\n return [];\n }\n\n /**\n * Permanently delete a room.\n */\n public removeRoom(roomId: string): void {\n return;\n }\n\n /**\n * No-op.\n * @returns An empty array.\n */\n public getRoomSummaries(): RoomSummary[] {\n return [];\n }\n\n /**\n * No-op.\n */\n public storeUser(user: User): void {}\n\n /**\n * No-op.\n */\n public getUser(userId: string): User | null {\n return null;\n }\n\n /**\n * No-op.\n */\n public getUsers(): User[] {\n return [];\n }\n\n /**\n * No-op.\n */\n public scrollback(room: Room, limit: number): MatrixEvent[] {\n return [];\n }\n\n /**\n * Store events for a room.\n * @param room - The room to store events for.\n * @param events - The events to store.\n * @param token - The token associated with these events.\n * @param toStart - True if these are paginated results.\n */\n public storeEvents(room: Room, events: MatrixEvent[], token: string | null, toStart: boolean): void {}\n\n /**\n * Store a filter.\n */\n public storeFilter(filter: Filter): void {}\n\n /**\n * Retrieve a filter.\n * @returns A filter or null.\n */\n public getFilter(userId: string, filterId: string): Filter | null {\n return null;\n }\n\n /**\n * Retrieve a filter ID with the given name.\n * @param filterName - The filter name.\n * @returns The filter ID or null.\n */\n public getFilterIdByName(filterName: string): string | null {\n return null;\n }\n\n /**\n * Set a filter name to ID mapping.\n */\n public setFilterIdByName(filterName: string, filterId?: string): void {}\n\n /**\n * Store user-scoped account data events\n * @param events - The events to store.\n */\n public storeAccountDataEvents(events: MatrixEvent[]): void {}\n\n /**\n * Get account data event by event type\n * @param eventType - The event type being queried\n */\n public getAccountData(eventType: EventType | string): MatrixEvent | undefined {\n return undefined;\n }\n\n /**\n * setSyncData does nothing as there is no backing data store.\n *\n * @param syncData - The sync data\n * @returns An immediately resolved promise.\n */\n public setSyncData(syncData: ISyncResponse): Promise {\n return Promise.resolve();\n }\n\n /**\n * We never want to save because we have nothing to save to.\n *\n * @returns If the store wants to save\n */\n public wantsSave(): boolean {\n return false;\n }\n\n /**\n * Save does nothing as there is no backing data store.\n */\n public save(): void {}\n\n /**\n * Startup does nothing.\n * @returns An immediately resolved promise.\n */\n public startup(): Promise {\n return Promise.resolve();\n }\n\n /**\n * @returns Promise which resolves with a sync response to restore the\n * client state to where it was at the last save, or null if there\n * is no saved sync data.\n */\n public getSavedSync(): Promise {\n return Promise.resolve(null);\n }\n\n /**\n * @returns If there is a saved sync, the nextBatch token\n * for this sync, otherwise null.\n */\n public getSavedSyncToken(): Promise {\n return Promise.resolve(null);\n }\n\n /**\n * Delete all data from this store. Does nothing since this store\n * doesn't store anything.\n * @returns An immediately resolved promise.\n */\n public deleteAllData(): Promise {\n return Promise.resolve();\n }\n\n public getOutOfBandMembers(): Promise {\n return Promise.resolve(null);\n }\n\n public setOutOfBandMembers(roomId: string, membershipEvents: IStateEventWithRoomId[]): Promise {\n return Promise.resolve();\n }\n\n public clearOutOfBandMembers(): Promise {\n return Promise.resolve();\n }\n\n public getClientOptions(): Promise {\n return Promise.resolve(undefined);\n }\n\n public storeClientOptions(options: IStoredClientOpts): Promise {\n return Promise.resolve();\n }\n\n public async getPendingEvents(roomId: string): Promise[]> {\n return [];\n }\n\n public setPendingEvents(roomId: string, events: Partial[]): Promise {\n return Promise.resolve();\n }\n\n public async saveToDeviceBatches(batch: ToDeviceBatch[]): Promise {\n return Promise.resolve();\n }\n\n public getOldestToDeviceBatch(): Promise {\n return Promise.resolve(null);\n }\n\n public async removeToDeviceBatch(id: number): Promise {\n return Promise.resolve();\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts deleted file mode 100644 index 4974ce9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts +++ /dev/null @@ -1,163 +0,0 @@ -import { IContent, IUnsigned } from "./models/event"; -import { IRoomSummary } from "./models/room-summary"; -import { EventType } from "./@types/event"; -interface IOpts { - /** - * The ideal maximum number of timeline entries to keep in the sync response. - * This is best-effort, as clients do not always have a back-pagination token for each event, - * so it's possible there may be slightly *less* than this value. There will never be more. - * This cannot be 0 or else it makes it impossible to scroll back in a room. - * Default: 50. - */ - maxTimelineEntries?: number; -} -export interface IMinimalEvent { - content: IContent; - type: EventType | string; - unsigned?: IUnsigned; -} -export interface IEphemeral { - events: IMinimalEvent[]; -} -interface UnreadNotificationCounts { - highlight_count?: number; - notification_count?: number; -} -export interface IRoomEvent extends IMinimalEvent { - event_id: string; - sender: string; - origin_server_ts: number; - /** @deprecated - legacy field */ - age?: number; -} -export interface IStateEvent extends IRoomEvent { - prev_content?: IContent; - state_key: string; -} -interface IState { - events: IStateEvent[]; -} -export interface ITimeline { - events: Array; - limited?: boolean; - prev_batch: string | null; -} -export interface IJoinedRoom { - "summary": IRoomSummary; - "state": IState; - "timeline": ITimeline; - "ephemeral": IEphemeral; - "account_data": IAccountData; - "unread_notifications": UnreadNotificationCounts; - "unread_thread_notifications"?: Record; - "org.matrix.msc3773.unread_thread_notifications"?: Record; -} -export interface IStrippedState { - content: IContent; - state_key: string; - type: EventType | string; - sender: string; -} -export interface IInviteState { - events: IStrippedState[]; -} -export interface IInvitedRoom { - invite_state: IInviteState; -} -export interface ILeftRoom { - state: IState; - timeline: ITimeline; - account_data: IAccountData; -} -export interface IRooms { - [Category.Join]: Record; - [Category.Invite]: Record; - [Category.Leave]: Record; -} -interface IPresence { - events: IMinimalEvent[]; -} -interface IAccountData { - events: IMinimalEvent[]; -} -export interface IToDeviceEvent { - content: IContent; - sender: string; - type: string; -} -interface IToDevice { - events: IToDeviceEvent[]; -} -interface IDeviceLists { - changed?: string[]; - left?: string[]; -} -export interface ISyncResponse { - "next_batch": string; - "rooms": IRooms; - "presence"?: IPresence; - "account_data": IAccountData; - "to_device"?: IToDevice; - "device_lists"?: IDeviceLists; - "device_one_time_keys_count"?: Record; - "device_unused_fallback_key_types"?: string[]; - "org.matrix.msc2732.device_unused_fallback_key_types"?: string[]; -} -export declare enum Category { - Invite = "invite", - Leave = "leave", - Join = "join" -} -export interface ISyncData { - nextBatch: string; - accountData: IMinimalEvent[]; - roomsData: IRooms; -} -/** - * The purpose of this class is to accumulate /sync responses such that a - * complete "initial" JSON response can be returned which accurately represents - * the sum total of the /sync responses accumulated to date. It only handles - * room data: that is, everything under the "rooms" top-level key. - * - * This class is used when persisting room data so a complete /sync response can - * be loaded from disk and incremental syncs can be performed on the server, - * rather than asking the server to do an initial sync on startup. - */ -export declare class SyncAccumulator { - private readonly opts; - private accountData; - private inviteRooms; - private joinRooms; - private nextBatch; - constructor(opts?: IOpts); - accumulate(syncResponse: ISyncResponse, fromDatabase?: boolean): void; - private accumulateAccountData; - /** - * Accumulate incremental /sync room data. - * @param syncResponse - the complete /sync JSON - * @param fromDatabase - True if the sync response is one saved to the database - */ - private accumulateRooms; - private accumulateRoom; - private accumulateInviteState; - private accumulateJoinState; - /** - * Return everything under the 'rooms' key from a /sync response which - * represents all room data that should be stored. This should be paired - * with the sync token which represents the most recent /sync response - * provided to accumulate(). - * @param forDatabase - True to generate a sync to be saved to storage - * @returns An object with a "nextBatch", "roomsData" and "accountData" - * keys. - * The "nextBatch" key is a string which represents at what point in the - * /sync stream the accumulator reached. This token should be used when - * restarting a /sync stream at startup. Failure to do so can lead to missing - * events. The "roomsData" key is an Object which represents the entire - * /sync response from the 'rooms' key onwards. The "accountData" key is - * a list of raw events which represent global account data. - */ - getJSON(forDatabase?: boolean): ISyncData; - getNextBatchToken(): string; -} -export {}; -//# sourceMappingURL=sync-accumulator.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts.map deleted file mode 100644 index 415e114..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sync-accumulator.d.ts","sourceRoot":"","sources":["../src/sync-accumulator.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js deleted file mode 100644 index 2ab0ccc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js +++ /dev/null @@ -1,519 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SyncAccumulator = exports.Category = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("./logger"); -var _utils = require("./utils"); -var _event = require("./@types/event"); -var _read_receipts = require("./@types/read_receipts"); -var _sync = require("./@types/sync"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -/* eslint-enable camelcase */ -let Category; -exports.Category = Category; -(function (Category) { - Category["Invite"] = "invite"; - Category["Leave"] = "leave"; - Category["Join"] = "join"; -})(Category || (exports.Category = Category = {})); -function isTaggedEvent(event) { - return "_localTs" in event && event["_localTs"] !== undefined; -} - -/** - * The purpose of this class is to accumulate /sync responses such that a - * complete "initial" JSON response can be returned which accurately represents - * the sum total of the /sync responses accumulated to date. It only handles - * room data: that is, everything under the "rooms" top-level key. - * - * This class is used when persisting room data so a complete /sync response can - * be loaded from disk and incremental syncs can be performed on the server, - * rather than asking the server to do an initial sync on startup. - */ -class SyncAccumulator { - // $event_type: Object - // $roomId: { ... sync 'invite' json data ... } - - // the /sync token which corresponds to the last time rooms were - // accumulated. We remember this so that any caller can obtain a - // coherent /sync response and know at what point they should be - // streaming from without losing events. - - constructor(opts = {}) { - this.opts = opts; - (0, _defineProperty2.default)(this, "accountData", {}); - (0, _defineProperty2.default)(this, "inviteRooms", {}); - (0, _defineProperty2.default)(this, "joinRooms", {}); - (0, _defineProperty2.default)(this, "nextBatch", null); - this.opts.maxTimelineEntries = this.opts.maxTimelineEntries || 50; - } - accumulate(syncResponse, fromDatabase = false) { - this.accumulateRooms(syncResponse, fromDatabase); - this.accumulateAccountData(syncResponse); - this.nextBatch = syncResponse.next_batch; - } - accumulateAccountData(syncResponse) { - if (!syncResponse.account_data || !syncResponse.account_data.events) { - return; - } - // Clobbers based on event type. - syncResponse.account_data.events.forEach(e => { - this.accountData[e.type] = e; - }); - } - - /** - * Accumulate incremental /sync room data. - * @param syncResponse - the complete /sync JSON - * @param fromDatabase - True if the sync response is one saved to the database - */ - accumulateRooms(syncResponse, fromDatabase = false) { - if (!syncResponse.rooms) { - return; - } - if (syncResponse.rooms.invite) { - Object.keys(syncResponse.rooms.invite).forEach(roomId => { - this.accumulateRoom(roomId, Category.Invite, syncResponse.rooms.invite[roomId], fromDatabase); - }); - } - if (syncResponse.rooms.join) { - Object.keys(syncResponse.rooms.join).forEach(roomId => { - this.accumulateRoom(roomId, Category.Join, syncResponse.rooms.join[roomId], fromDatabase); - }); - } - if (syncResponse.rooms.leave) { - Object.keys(syncResponse.rooms.leave).forEach(roomId => { - this.accumulateRoom(roomId, Category.Leave, syncResponse.rooms.leave[roomId], fromDatabase); - }); - } - } - accumulateRoom(roomId, category, data, fromDatabase = false) { - // Valid /sync state transitions - // +--------+ <======+ 1: Accept an invite - // +== | INVITE | | (5) 2: Leave a room - // | +--------+ =====+ | 3: Join a public room previously - // |(1) (4) | | left (handle as if new room) - // V (2) V | 4: Reject an invite - // +------+ ========> +--------+ 5: Invite to a room previously - // | JOIN | (3) | LEAVE* | left (handle as if new room) - // +------+ <======== +--------+ - // - // * equivalent to "no state" - switch (category) { - case Category.Invite: - // (5) - this.accumulateInviteState(roomId, data); - break; - case Category.Join: - if (this.inviteRooms[roomId]) { - // (1) - // was previously invite, now join. We expect /sync to give - // the entire state and timeline on 'join', so delete previous - // invite state - delete this.inviteRooms[roomId]; - } - // (3) - this.accumulateJoinState(roomId, data, fromDatabase); - break; - case Category.Leave: - if (this.inviteRooms[roomId]) { - // (4) - delete this.inviteRooms[roomId]; - } else { - // (2) - delete this.joinRooms[roomId]; - } - break; - default: - _logger.logger.error("Unknown cateogory: ", category); - } - } - accumulateInviteState(roomId, data) { - if (!data.invite_state || !data.invite_state.events) { - // no new data - return; - } - if (!this.inviteRooms[roomId]) { - this.inviteRooms[roomId] = { - invite_state: data.invite_state - }; - return; - } - // accumulate extra keys for invite->invite transitions - // clobber based on event type / state key - // We expect invite_state to be small, so just loop over the events - const currentData = this.inviteRooms[roomId]; - data.invite_state.events.forEach(e => { - let hasAdded = false; - for (let i = 0; i < currentData.invite_state.events.length; i++) { - const current = currentData.invite_state.events[i]; - if (current.type === e.type && current.state_key == e.state_key) { - currentData.invite_state.events[i] = e; // update - hasAdded = true; - } - } - if (!hasAdded) { - currentData.invite_state.events.push(e); - } - }); - } - - // Accumulate timeline and state events in a room. - accumulateJoinState(roomId, data, fromDatabase = false) { - var _ref, _data, _data$ephemeral, _data$ephemeral$event, _data$state, _data$state$events, _data$timeline, _data$timeline$events; - // We expect this function to be called a lot (every /sync) so we want - // this to be fast. /sync stores events in an array but we often want - // to clobber based on type/state_key. Rather than convert arrays to - // maps all the time, just keep private maps which contain - // the actual current accumulated sync state, and array-ify it when - // getJSON() is called. - - // State resolution: - // The 'state' key is the delta from the previous sync (or start of time - // if no token was supplied), to the START of the timeline. To obtain - // the current state, we need to "roll forward" state by reading the - // timeline. We want to store the current state so we can drop events - // out the end of the timeline based on opts.maxTimelineEntries. - // - // 'state' 'timeline' current state - // |-------x<======================>x - // T I M E - // - // When getJSON() is called, we 'roll back' the current state by the - // number of entries in the timeline to work out what 'state' should be. - - // Back-pagination: - // On an initial /sync, the server provides a back-pagination token for - // the start of the timeline. When /sync deltas come down, they also - // include back-pagination tokens for the start of the timeline. This - // means not all events in the timeline have back-pagination tokens, as - // it is only the ones at the START of the timeline which have them. - // In order for us to have a valid timeline (and back-pagination token - // to match), we need to make sure that when we remove old timeline - // events, that we roll forward to an event which has a back-pagination - // token. This means we can't keep a strict sliding-window based on - // opts.maxTimelineEntries, and we may have a few less. We should never - // have more though, provided that the /sync limit is less than or equal - // to opts.maxTimelineEntries. - - if (!this.joinRooms[roomId]) { - // Create truly empty objects so event types of 'hasOwnProperty' and co - // don't cause this code to break. - this.joinRooms[roomId] = { - _currentState: Object.create(null), - _timeline: [], - _accountData: Object.create(null), - _unreadNotifications: {}, - _unreadThreadNotifications: {}, - _summary: {}, - _readReceipts: {}, - _threadReadReceipts: {} - }; - } - const currentData = this.joinRooms[roomId]; - if (data.account_data && data.account_data.events) { - // clobber based on type - data.account_data.events.forEach(e => { - currentData._accountData[e.type] = e; - }); - } - - // these probably clobber, spec is unclear. - if (data.unread_notifications) { - currentData._unreadNotifications = data.unread_notifications; - } - currentData._unreadThreadNotifications = (_ref = (_data = data[_sync.UNREAD_THREAD_NOTIFICATIONS.stable]) !== null && _data !== void 0 ? _data : data[_sync.UNREAD_THREAD_NOTIFICATIONS.unstable]) !== null && _ref !== void 0 ? _ref : undefined; - if (data.summary) { - const HEROES_KEY = "m.heroes"; - const INVITED_COUNT_KEY = "m.invited_member_count"; - const JOINED_COUNT_KEY = "m.joined_member_count"; - const acc = currentData._summary; - const sum = data.summary; - acc[HEROES_KEY] = sum[HEROES_KEY] || acc[HEROES_KEY]; - acc[JOINED_COUNT_KEY] = sum[JOINED_COUNT_KEY] || acc[JOINED_COUNT_KEY]; - acc[INVITED_COUNT_KEY] = sum[INVITED_COUNT_KEY] || acc[INVITED_COUNT_KEY]; - } - (_data$ephemeral = data.ephemeral) === null || _data$ephemeral === void 0 ? void 0 : (_data$ephemeral$event = _data$ephemeral.events) === null || _data$ephemeral$event === void 0 ? void 0 : _data$ephemeral$event.forEach(e => { - // We purposefully do not persist m.typing events. - // Technically you could refresh a browser before the timer on a - // typing event is up, so it'll look like you aren't typing when - // you really still are. However, the alternative is worse. If - // we do persist typing events, it will look like people are - // typing forever until someone really does start typing (which - // will prompt Synapse to send down an actual m.typing event to - // clobber the one we persisted). - if (e.type !== _event.EventType.Receipt || !e.content) { - // This means we'll drop unknown ephemeral events but that - // seems okay. - return; - } - // Handle m.receipt events. They clobber based on: - // (user_id, receipt_type) - // but they are keyed in the event as: - // content:{ $event_id: { $receipt_type: { $user_id: {json} }}} - // so store them in the former so we can accumulate receipt deltas - // quickly and efficiently (we expect a lot of them). Fold the - // receipt type into the key name since we only have 1 at the - // moment (m.read) and nested JSON objects are slower and more - // of a hassle to work with. We'll inflate this back out when - // getJSON() is called. - Object.keys(e.content).forEach(eventId => { - Object.entries(e.content[eventId]).forEach(([key, value]) => { - if (!(0, _utils.isSupportedReceiptType)(key)) return; - for (const userId of Object.keys(value)) { - const data = e.content[eventId][key][userId]; - const receipt = { - data: e.content[eventId][key][userId], - type: key, - eventId: eventId - }; - if (!data.thread_id || data.thread_id === _read_receipts.MAIN_ROOM_TIMELINE) { - currentData._readReceipts[userId] = receipt; - } else { - var _currentData$_threadR; - currentData._threadReadReceipts = _objectSpread(_objectSpread({}, currentData._threadReadReceipts), {}, { - [data.thread_id]: _objectSpread(_objectSpread({}, (_currentData$_threadR = currentData._threadReadReceipts[data.thread_id]) !== null && _currentData$_threadR !== void 0 ? _currentData$_threadR : {}), {}, { - [userId]: receipt - }) - }); - } - } - }); - }); - }); - - // if we got a limited sync, we need to remove all timeline entries or else - // we will have gaps in the timeline. - if (data.timeline && data.timeline.limited) { - currentData._timeline = []; - } - - // Work out the current state. The deltas need to be applied in the order: - // - existing state which didn't come down /sync. - // - State events under the 'state' key. - // - State events in the 'timeline'. - (_data$state = data.state) === null || _data$state === void 0 ? void 0 : (_data$state$events = _data$state.events) === null || _data$state$events === void 0 ? void 0 : _data$state$events.forEach(e => { - setState(currentData._currentState, e); - }); - (_data$timeline = data.timeline) === null || _data$timeline === void 0 ? void 0 : (_data$timeline$events = _data$timeline.events) === null || _data$timeline$events === void 0 ? void 0 : _data$timeline$events.forEach((e, index) => { - var _data$timeline$prev_b; - // this nops if 'e' isn't a state event - setState(currentData._currentState, e); - // append the event to the timeline. The back-pagination token - // corresponds to the first event in the timeline - let transformedEvent; - if (!fromDatabase) { - transformedEvent = Object.assign({}, e); - if (transformedEvent.unsigned !== undefined) { - transformedEvent.unsigned = Object.assign({}, transformedEvent.unsigned); - } - const age = e.unsigned ? e.unsigned.age : e.age; - if (age !== undefined) transformedEvent._localTs = Date.now() - age; - } else { - transformedEvent = e; - } - currentData._timeline.push({ - event: transformedEvent, - token: index === 0 ? (_data$timeline$prev_b = data.timeline.prev_batch) !== null && _data$timeline$prev_b !== void 0 ? _data$timeline$prev_b : null : null - }); - }); - - // attempt to prune the timeline by jumping between events which have - // pagination tokens. - if (currentData._timeline.length > this.opts.maxTimelineEntries) { - const startIndex = currentData._timeline.length - this.opts.maxTimelineEntries; - for (let i = startIndex; i < currentData._timeline.length; i++) { - if (currentData._timeline[i].token) { - // keep all events after this, including this one - currentData._timeline = currentData._timeline.slice(i, currentData._timeline.length); - break; - } - } - } - } - - /** - * Return everything under the 'rooms' key from a /sync response which - * represents all room data that should be stored. This should be paired - * with the sync token which represents the most recent /sync response - * provided to accumulate(). - * @param forDatabase - True to generate a sync to be saved to storage - * @returns An object with a "nextBatch", "roomsData" and "accountData" - * keys. - * The "nextBatch" key is a string which represents at what point in the - * /sync stream the accumulator reached. This token should be used when - * restarting a /sync stream at startup. Failure to do so can lead to missing - * events. The "roomsData" key is an Object which represents the entire - * /sync response from the 'rooms' key onwards. The "accountData" key is - * a list of raw events which represent global account data. - */ - getJSON(forDatabase = false) { - const data = { - join: {}, - invite: {}, - // always empty. This is set by /sync when a room was previously - // in 'invite' or 'join'. On fresh startup, the client won't know - // about any previous room being in 'invite' or 'join' so we can - // just omit mentioning it at all, even if it has previously come - // down /sync. - // The notable exception is when a client is kicked or banned: - // we may want to hold onto that room so the client can clearly see - // why their room has disappeared. We don't persist it though because - // it is unclear *when* we can safely remove the room from the DB. - // Instead, we assume that if you're loading from the DB, you've - // refreshed the page, which means you've seen the kick/ban already. - leave: {} - }; - Object.keys(this.inviteRooms).forEach(roomId => { - data.invite[roomId] = this.inviteRooms[roomId]; - }); - Object.keys(this.joinRooms).forEach(roomId => { - const roomData = this.joinRooms[roomId]; - const roomJson = { - ephemeral: { - events: [] - }, - account_data: { - events: [] - }, - state: { - events: [] - }, - timeline: { - events: [], - prev_batch: null - }, - unread_notifications: roomData._unreadNotifications, - unread_thread_notifications: roomData._unreadThreadNotifications, - summary: roomData._summary - }; - // Add account data - Object.keys(roomData._accountData).forEach(evType => { - roomJson.account_data.events.push(roomData._accountData[evType]); - }); - - // Add receipt data - const receiptEvent = { - type: _event.EventType.Receipt, - room_id: roomId, - content: { - // $event_id: { "m.read": { $user_id: $json } } - } - }; - const receiptEventContent = new _utils.MapWithDefault(() => new _utils.MapWithDefault(() => new Map())); - for (const [userId, receiptData] of Object.entries(roomData._readReceipts)) { - receiptEventContent.getOrCreate(receiptData.eventId).getOrCreate(receiptData.type).set(userId, receiptData.data); - } - for (const threadReceipts of Object.values(roomData._threadReadReceipts)) { - for (const [userId, receiptData] of Object.entries(threadReceipts)) { - receiptEventContent.getOrCreate(receiptData.eventId).getOrCreate(receiptData.type).set(userId, receiptData.data); - } - } - receiptEvent.content = (0, _utils.recursiveMapToObject)(receiptEventContent); - - // add only if we have some receipt data - if (receiptEventContent.size > 0) { - roomJson.ephemeral.events.push(receiptEvent); - } - - // Add timeline data - roomData._timeline.forEach(msgData => { - if (!roomJson.timeline.prev_batch) { - // the first event we add to the timeline MUST match up to - // the prev_batch token. - if (!msgData.token) { - return; // this shouldn't happen as we prune constantly. - } - - roomJson.timeline.prev_batch = msgData.token; - } - let transformedEvent; - if (!forDatabase && isTaggedEvent(msgData.event)) { - // This means we have to copy each event, so we can fix it up to - // set a correct 'age' parameter whilst keeping the local timestamp - // on our stored event. If this turns out to be a bottleneck, it could - // be optimised either by doing this in the main process after the data - // has been structured-cloned to go between the worker & main process, - // or special-casing data from saved syncs to read the local timestamp - // directly rather than turning it into age to then immediately be - // transformed back again into a local timestamp. - transformedEvent = Object.assign({}, msgData.event); - if (transformedEvent.unsigned !== undefined) { - transformedEvent.unsigned = Object.assign({}, transformedEvent.unsigned); - } - delete transformedEvent._localTs; - transformedEvent.unsigned = transformedEvent.unsigned || {}; - transformedEvent.unsigned.age = Date.now() - msgData.event._localTs; - } else { - transformedEvent = msgData.event; - } - roomJson.timeline.events.push(transformedEvent); - }); - - // Add state data: roll back current state to the start of timeline, - // by "reverse clobbering" from the end of the timeline to the start. - // Convert maps back into arrays. - const rollBackState = Object.create(null); - for (let i = roomJson.timeline.events.length - 1; i >= 0; i--) { - const timelineEvent = roomJson.timeline.events[i]; - if (timelineEvent.state_key === null || timelineEvent.state_key === undefined) { - continue; // not a state event - } - // since we're going back in time, we need to use the previous - // state value else we'll break causality. We don't have the - // complete previous state event, so we need to create one. - const prevStateEvent = (0, _utils.deepCopy)(timelineEvent); - if (prevStateEvent.unsigned) { - if (prevStateEvent.unsigned.prev_content) { - prevStateEvent.content = prevStateEvent.unsigned.prev_content; - } - if (prevStateEvent.unsigned.prev_sender) { - prevStateEvent.sender = prevStateEvent.unsigned.prev_sender; - } - } - setState(rollBackState, prevStateEvent); - } - Object.keys(roomData._currentState).forEach(evType => { - Object.keys(roomData._currentState[evType]).forEach(stateKey => { - let ev = roomData._currentState[evType][stateKey]; - if (rollBackState[evType] && rollBackState[evType][stateKey]) { - // use the reverse clobbered event instead. - ev = rollBackState[evType][stateKey]; - } - roomJson.state.events.push(ev); - }); - }); - data.join[roomId] = roomJson; - }); - - // Add account data - const accData = []; - Object.keys(this.accountData).forEach(evType => { - accData.push(this.accountData[evType]); - }); - return { - nextBatch: this.nextBatch, - roomsData: data, - accountData: accData - }; - } - getNextBatchToken() { - return this.nextBatch; - } -} -exports.SyncAccumulator = SyncAccumulator; -function setState(eventMap, event) { - if (event.state_key === null || event.state_key === undefined || !event.type) { - return; - } - if (!eventMap[event.type]) { - eventMap[event.type] = Object.create(null); - } - eventMap[event.type][event.state_key] = event; -} -//# sourceMappingURL=sync-accumulator.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js.map deleted file mode 100644 index 9ebf409..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync-accumulator.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sync-accumulator.js","names":["_logger","require","_utils","_event","_read_receipts","_sync","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","Category","exports","isTaggedEvent","event","undefined","SyncAccumulator","constructor","opts","maxTimelineEntries","accumulate","syncResponse","fromDatabase","accumulateRooms","accumulateAccountData","nextBatch","next_batch","account_data","events","e","accountData","type","rooms","invite","roomId","accumulateRoom","Invite","join","Join","leave","Leave","category","data","accumulateInviteState","inviteRooms","accumulateJoinState","joinRooms","logger","error","invite_state","currentData","hasAdded","current","state_key","_ref","_data","_data$ephemeral","_data$ephemeral$event","_data$state","_data$state$events","_data$timeline","_data$timeline$events","_currentState","create","_timeline","_accountData","_unreadNotifications","_unreadThreadNotifications","_summary","_readReceipts","_threadReadReceipts","unread_notifications","UNREAD_THREAD_NOTIFICATIONS","stable","unstable","summary","HEROES_KEY","INVITED_COUNT_KEY","JOINED_COUNT_KEY","acc","sum","ephemeral","EventType","Receipt","content","eventId","entries","value","isSupportedReceiptType","userId","receipt","thread_id","MAIN_ROOM_TIMELINE","_currentData$_threadR","timeline","limited","state","setState","index","_data$timeline$prev_b","transformedEvent","assign","unsigned","age","_localTs","Date","now","token","prev_batch","startIndex","slice","getJSON","forDatabase","roomData","roomJson","unread_thread_notifications","evType","receiptEvent","room_id","receiptEventContent","MapWithDefault","Map","receiptData","getOrCreate","set","threadReceipts","values","recursiveMapToObject","size","msgData","rollBackState","timelineEvent","prevStateEvent","deepCopy","prev_content","prev_sender","sender","stateKey","ev","accData","roomsData","getNextBatchToken","eventMap"],"sources":["../src/sync-accumulator.ts"],"sourcesContent":["/*\nCopyright 2017 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module. See {@link SyncAccumulator} for the public class.\n */\n\nimport { logger } from \"./logger\";\nimport { deepCopy, isSupportedReceiptType, MapWithDefault, recursiveMapToObject } from \"./utils\";\nimport { IContent, IUnsigned } from \"./models/event\";\nimport { IRoomSummary } from \"./models/room-summary\";\nimport { EventType } from \"./@types/event\";\nimport { MAIN_ROOM_TIMELINE, ReceiptContent, ReceiptType } from \"./@types/read_receipts\";\nimport { UNREAD_THREAD_NOTIFICATIONS } from \"./@types/sync\";\n\ninterface IOpts {\n /**\n * The ideal maximum number of timeline entries to keep in the sync response.\n * This is best-effort, as clients do not always have a back-pagination token for each event,\n * so it's possible there may be slightly *less* than this value. There will never be more.\n * This cannot be 0 or else it makes it impossible to scroll back in a room.\n * Default: 50.\n */\n maxTimelineEntries?: number;\n}\n\nexport interface IMinimalEvent {\n content: IContent;\n type: EventType | string;\n unsigned?: IUnsigned;\n}\n\nexport interface IEphemeral {\n events: IMinimalEvent[];\n}\n\n/* eslint-disable camelcase */\ninterface UnreadNotificationCounts {\n highlight_count?: number;\n notification_count?: number;\n}\n\nexport interface IRoomEvent extends IMinimalEvent {\n event_id: string;\n sender: string;\n origin_server_ts: number;\n /** @deprecated - legacy field */\n age?: number;\n}\n\nexport interface IStateEvent extends IRoomEvent {\n prev_content?: IContent;\n state_key: string;\n}\n\ninterface IState {\n events: IStateEvent[];\n}\n\nexport interface ITimeline {\n events: Array;\n limited?: boolean;\n prev_batch: string | null;\n}\n\nexport interface IJoinedRoom {\n \"summary\": IRoomSummary;\n \"state\": IState;\n \"timeline\": ITimeline;\n \"ephemeral\": IEphemeral;\n \"account_data\": IAccountData;\n \"unread_notifications\": UnreadNotificationCounts;\n \"unread_thread_notifications\"?: Record;\n \"org.matrix.msc3773.unread_thread_notifications\"?: Record;\n}\n\nexport interface IStrippedState {\n content: IContent;\n state_key: string;\n type: EventType | string;\n sender: string;\n}\n\nexport interface IInviteState {\n events: IStrippedState[];\n}\n\nexport interface IInvitedRoom {\n invite_state: IInviteState;\n}\n\nexport interface ILeftRoom {\n state: IState;\n timeline: ITimeline;\n account_data: IAccountData;\n}\n\nexport interface IRooms {\n [Category.Join]: Record;\n [Category.Invite]: Record;\n [Category.Leave]: Record;\n}\n\ninterface IPresence {\n events: IMinimalEvent[];\n}\n\ninterface IAccountData {\n events: IMinimalEvent[];\n}\n\nexport interface IToDeviceEvent {\n content: IContent;\n sender: string;\n type: string;\n}\n\ninterface IToDevice {\n events: IToDeviceEvent[];\n}\n\ninterface IDeviceLists {\n changed?: string[];\n left?: string[];\n}\n\nexport interface ISyncResponse {\n \"next_batch\": string;\n \"rooms\": IRooms;\n \"presence\"?: IPresence;\n \"account_data\": IAccountData;\n \"to_device\"?: IToDevice;\n \"device_lists\"?: IDeviceLists;\n \"device_one_time_keys_count\"?: Record;\n\n \"device_unused_fallback_key_types\"?: string[];\n \"org.matrix.msc2732.device_unused_fallback_key_types\"?: string[];\n}\n/* eslint-enable camelcase */\n\nexport enum Category {\n Invite = \"invite\",\n Leave = \"leave\",\n Join = \"join\",\n}\n\ninterface IRoom {\n _currentState: { [eventType: string]: { [stateKey: string]: IStateEvent } };\n _timeline: {\n event: IRoomEvent | IStateEvent;\n token: string | null;\n }[];\n _summary: Partial;\n _accountData: { [eventType: string]: IMinimalEvent };\n _unreadNotifications: Partial;\n _unreadThreadNotifications?: Record>;\n _readReceipts: {\n [userId: string]: {\n data: IMinimalEvent;\n type: ReceiptType;\n eventId: string;\n };\n };\n _threadReadReceipts: {\n [threadId: string]: {\n [userId: string]: {\n data: IMinimalEvent;\n type: ReceiptType;\n eventId: string;\n };\n };\n };\n}\n\nexport interface ISyncData {\n nextBatch: string;\n accountData: IMinimalEvent[];\n roomsData: IRooms;\n}\n\ntype TaggedEvent = IRoomEvent & { _localTs?: number };\n\nfunction isTaggedEvent(event: IRoomEvent): event is TaggedEvent {\n return \"_localTs\" in event && event[\"_localTs\"] !== undefined;\n}\n\n/**\n * The purpose of this class is to accumulate /sync responses such that a\n * complete \"initial\" JSON response can be returned which accurately represents\n * the sum total of the /sync responses accumulated to date. It only handles\n * room data: that is, everything under the \"rooms\" top-level key.\n *\n * This class is used when persisting room data so a complete /sync response can\n * be loaded from disk and incremental syncs can be performed on the server,\n * rather than asking the server to do an initial sync on startup.\n */\nexport class SyncAccumulator {\n private accountData: Record = {}; // $event_type: Object\n private inviteRooms: Record = {}; // $roomId: { ... sync 'invite' json data ... }\n private joinRooms: { [roomId: string]: IRoom } = {};\n // the /sync token which corresponds to the last time rooms were\n // accumulated. We remember this so that any caller can obtain a\n // coherent /sync response and know at what point they should be\n // streaming from without losing events.\n private nextBatch: string | null = null;\n\n public constructor(private readonly opts: IOpts = {}) {\n this.opts.maxTimelineEntries = this.opts.maxTimelineEntries || 50;\n }\n\n public accumulate(syncResponse: ISyncResponse, fromDatabase = false): void {\n this.accumulateRooms(syncResponse, fromDatabase);\n this.accumulateAccountData(syncResponse);\n this.nextBatch = syncResponse.next_batch;\n }\n\n private accumulateAccountData(syncResponse: ISyncResponse): void {\n if (!syncResponse.account_data || !syncResponse.account_data.events) {\n return;\n }\n // Clobbers based on event type.\n syncResponse.account_data.events.forEach((e) => {\n this.accountData[e.type] = e;\n });\n }\n\n /**\n * Accumulate incremental /sync room data.\n * @param syncResponse - the complete /sync JSON\n * @param fromDatabase - True if the sync response is one saved to the database\n */\n private accumulateRooms(syncResponse: ISyncResponse, fromDatabase = false): void {\n if (!syncResponse.rooms) {\n return;\n }\n if (syncResponse.rooms.invite) {\n Object.keys(syncResponse.rooms.invite).forEach((roomId) => {\n this.accumulateRoom(roomId, Category.Invite, syncResponse.rooms.invite[roomId], fromDatabase);\n });\n }\n if (syncResponse.rooms.join) {\n Object.keys(syncResponse.rooms.join).forEach((roomId) => {\n this.accumulateRoom(roomId, Category.Join, syncResponse.rooms.join[roomId], fromDatabase);\n });\n }\n if (syncResponse.rooms.leave) {\n Object.keys(syncResponse.rooms.leave).forEach((roomId) => {\n this.accumulateRoom(roomId, Category.Leave, syncResponse.rooms.leave[roomId], fromDatabase);\n });\n }\n }\n\n private accumulateRoom(roomId: string, category: Category.Invite, data: IInvitedRoom, fromDatabase: boolean): void;\n private accumulateRoom(roomId: string, category: Category.Join, data: IJoinedRoom, fromDatabase: boolean): void;\n private accumulateRoom(roomId: string, category: Category.Leave, data: ILeftRoom, fromDatabase: boolean): void;\n private accumulateRoom(roomId: string, category: Category, data: any, fromDatabase = false): void {\n // Valid /sync state transitions\n // +--------+ <======+ 1: Accept an invite\n // +== | INVITE | | (5) 2: Leave a room\n // | +--------+ =====+ | 3: Join a public room previously\n // |(1) (4) | | left (handle as if new room)\n // V (2) V | 4: Reject an invite\n // +------+ ========> +--------+ 5: Invite to a room previously\n // | JOIN | (3) | LEAVE* | left (handle as if new room)\n // +------+ <======== +--------+\n //\n // * equivalent to \"no state\"\n switch (category) {\n case Category.Invite: // (5)\n this.accumulateInviteState(roomId, data as IInvitedRoom);\n break;\n\n case Category.Join:\n if (this.inviteRooms[roomId]) {\n // (1)\n // was previously invite, now join. We expect /sync to give\n // the entire state and timeline on 'join', so delete previous\n // invite state\n delete this.inviteRooms[roomId];\n }\n // (3)\n this.accumulateJoinState(roomId, data as IJoinedRoom, fromDatabase);\n break;\n\n case Category.Leave:\n if (this.inviteRooms[roomId]) {\n // (4)\n delete this.inviteRooms[roomId];\n } else {\n // (2)\n delete this.joinRooms[roomId];\n }\n break;\n\n default:\n logger.error(\"Unknown cateogory: \", category);\n }\n }\n\n private accumulateInviteState(roomId: string, data: IInvitedRoom): void {\n if (!data.invite_state || !data.invite_state.events) {\n // no new data\n return;\n }\n if (!this.inviteRooms[roomId]) {\n this.inviteRooms[roomId] = {\n invite_state: data.invite_state,\n };\n return;\n }\n // accumulate extra keys for invite->invite transitions\n // clobber based on event type / state key\n // We expect invite_state to be small, so just loop over the events\n const currentData = this.inviteRooms[roomId];\n data.invite_state.events.forEach((e) => {\n let hasAdded = false;\n for (let i = 0; i < currentData.invite_state.events.length; i++) {\n const current = currentData.invite_state.events[i];\n if (current.type === e.type && current.state_key == e.state_key) {\n currentData.invite_state.events[i] = e; // update\n hasAdded = true;\n }\n }\n if (!hasAdded) {\n currentData.invite_state.events.push(e);\n }\n });\n }\n\n // Accumulate timeline and state events in a room.\n private accumulateJoinState(roomId: string, data: IJoinedRoom, fromDatabase = false): void {\n // We expect this function to be called a lot (every /sync) so we want\n // this to be fast. /sync stores events in an array but we often want\n // to clobber based on type/state_key. Rather than convert arrays to\n // maps all the time, just keep private maps which contain\n // the actual current accumulated sync state, and array-ify it when\n // getJSON() is called.\n\n // State resolution:\n // The 'state' key is the delta from the previous sync (or start of time\n // if no token was supplied), to the START of the timeline. To obtain\n // the current state, we need to \"roll forward\" state by reading the\n // timeline. We want to store the current state so we can drop events\n // out the end of the timeline based on opts.maxTimelineEntries.\n //\n // 'state' 'timeline' current state\n // |-------x<======================>x\n // T I M E\n //\n // When getJSON() is called, we 'roll back' the current state by the\n // number of entries in the timeline to work out what 'state' should be.\n\n // Back-pagination:\n // On an initial /sync, the server provides a back-pagination token for\n // the start of the timeline. When /sync deltas come down, they also\n // include back-pagination tokens for the start of the timeline. This\n // means not all events in the timeline have back-pagination tokens, as\n // it is only the ones at the START of the timeline which have them.\n // In order for us to have a valid timeline (and back-pagination token\n // to match), we need to make sure that when we remove old timeline\n // events, that we roll forward to an event which has a back-pagination\n // token. This means we can't keep a strict sliding-window based on\n // opts.maxTimelineEntries, and we may have a few less. We should never\n // have more though, provided that the /sync limit is less than or equal\n // to opts.maxTimelineEntries.\n\n if (!this.joinRooms[roomId]) {\n // Create truly empty objects so event types of 'hasOwnProperty' and co\n // don't cause this code to break.\n this.joinRooms[roomId] = {\n _currentState: Object.create(null),\n _timeline: [],\n _accountData: Object.create(null),\n _unreadNotifications: {},\n _unreadThreadNotifications: {},\n _summary: {},\n _readReceipts: {},\n _threadReadReceipts: {},\n };\n }\n const currentData = this.joinRooms[roomId];\n\n if (data.account_data && data.account_data.events) {\n // clobber based on type\n data.account_data.events.forEach((e) => {\n currentData._accountData[e.type] = e;\n });\n }\n\n // these probably clobber, spec is unclear.\n if (data.unread_notifications) {\n currentData._unreadNotifications = data.unread_notifications;\n }\n currentData._unreadThreadNotifications =\n data[UNREAD_THREAD_NOTIFICATIONS.stable!] ?? data[UNREAD_THREAD_NOTIFICATIONS.unstable!] ?? undefined;\n\n if (data.summary) {\n const HEROES_KEY = \"m.heroes\";\n const INVITED_COUNT_KEY = \"m.invited_member_count\";\n const JOINED_COUNT_KEY = \"m.joined_member_count\";\n\n const acc = currentData._summary;\n const sum = data.summary;\n acc[HEROES_KEY] = sum[HEROES_KEY] || acc[HEROES_KEY];\n acc[JOINED_COUNT_KEY] = sum[JOINED_COUNT_KEY] || acc[JOINED_COUNT_KEY];\n acc[INVITED_COUNT_KEY] = sum[INVITED_COUNT_KEY] || acc[INVITED_COUNT_KEY];\n }\n\n data.ephemeral?.events?.forEach((e) => {\n // We purposefully do not persist m.typing events.\n // Technically you could refresh a browser before the timer on a\n // typing event is up, so it'll look like you aren't typing when\n // you really still are. However, the alternative is worse. If\n // we do persist typing events, it will look like people are\n // typing forever until someone really does start typing (which\n // will prompt Synapse to send down an actual m.typing event to\n // clobber the one we persisted).\n if (e.type !== EventType.Receipt || !e.content) {\n // This means we'll drop unknown ephemeral events but that\n // seems okay.\n return;\n }\n // Handle m.receipt events. They clobber based on:\n // (user_id, receipt_type)\n // but they are keyed in the event as:\n // content:{ $event_id: { $receipt_type: { $user_id: {json} }}}\n // so store them in the former so we can accumulate receipt deltas\n // quickly and efficiently (we expect a lot of them). Fold the\n // receipt type into the key name since we only have 1 at the\n // moment (m.read) and nested JSON objects are slower and more\n // of a hassle to work with. We'll inflate this back out when\n // getJSON() is called.\n Object.keys(e.content).forEach((eventId) => {\n Object.entries(e.content[eventId]).forEach(([key, value]) => {\n if (!isSupportedReceiptType(key)) return;\n\n for (const userId of Object.keys(value)) {\n const data = e.content[eventId][key][userId];\n\n const receipt = {\n data: e.content[eventId][key][userId],\n type: key as ReceiptType,\n eventId: eventId,\n };\n\n if (!data.thread_id || data.thread_id === MAIN_ROOM_TIMELINE) {\n currentData._readReceipts[userId] = receipt;\n } else {\n currentData._threadReadReceipts = {\n ...currentData._threadReadReceipts,\n [data.thread_id]: {\n ...(currentData._threadReadReceipts[data.thread_id] ?? {}),\n [userId]: receipt,\n },\n };\n }\n }\n });\n });\n });\n\n // if we got a limited sync, we need to remove all timeline entries or else\n // we will have gaps in the timeline.\n if (data.timeline && data.timeline.limited) {\n currentData._timeline = [];\n }\n\n // Work out the current state. The deltas need to be applied in the order:\n // - existing state which didn't come down /sync.\n // - State events under the 'state' key.\n // - State events in the 'timeline'.\n data.state?.events?.forEach((e) => {\n setState(currentData._currentState, e);\n });\n data.timeline?.events?.forEach((e, index) => {\n // this nops if 'e' isn't a state event\n setState(currentData._currentState, e);\n // append the event to the timeline. The back-pagination token\n // corresponds to the first event in the timeline\n let transformedEvent: TaggedEvent;\n if (!fromDatabase) {\n transformedEvent = Object.assign({}, e);\n if (transformedEvent.unsigned !== undefined) {\n transformedEvent.unsigned = Object.assign({}, transformedEvent.unsigned);\n }\n const age = e.unsigned ? e.unsigned.age : e.age;\n if (age !== undefined) transformedEvent._localTs = Date.now() - age;\n } else {\n transformedEvent = e;\n }\n\n currentData._timeline.push({\n event: transformedEvent,\n token: index === 0 ? data.timeline.prev_batch ?? null : null,\n });\n });\n\n // attempt to prune the timeline by jumping between events which have\n // pagination tokens.\n if (currentData._timeline.length > this.opts.maxTimelineEntries!) {\n const startIndex = currentData._timeline.length - this.opts.maxTimelineEntries!;\n for (let i = startIndex; i < currentData._timeline.length; i++) {\n if (currentData._timeline[i].token) {\n // keep all events after this, including this one\n currentData._timeline = currentData._timeline.slice(i, currentData._timeline.length);\n break;\n }\n }\n }\n }\n\n /**\n * Return everything under the 'rooms' key from a /sync response which\n * represents all room data that should be stored. This should be paired\n * with the sync token which represents the most recent /sync response\n * provided to accumulate().\n * @param forDatabase - True to generate a sync to be saved to storage\n * @returns An object with a \"nextBatch\", \"roomsData\" and \"accountData\"\n * keys.\n * The \"nextBatch\" key is a string which represents at what point in the\n * /sync stream the accumulator reached. This token should be used when\n * restarting a /sync stream at startup. Failure to do so can lead to missing\n * events. The \"roomsData\" key is an Object which represents the entire\n * /sync response from the 'rooms' key onwards. The \"accountData\" key is\n * a list of raw events which represent global account data.\n */\n public getJSON(forDatabase = false): ISyncData {\n const data: IRooms = {\n join: {},\n invite: {},\n // always empty. This is set by /sync when a room was previously\n // in 'invite' or 'join'. On fresh startup, the client won't know\n // about any previous room being in 'invite' or 'join' so we can\n // just omit mentioning it at all, even if it has previously come\n // down /sync.\n // The notable exception is when a client is kicked or banned:\n // we may want to hold onto that room so the client can clearly see\n // why their room has disappeared. We don't persist it though because\n // it is unclear *when* we can safely remove the room from the DB.\n // Instead, we assume that if you're loading from the DB, you've\n // refreshed the page, which means you've seen the kick/ban already.\n leave: {},\n };\n Object.keys(this.inviteRooms).forEach((roomId) => {\n data.invite[roomId] = this.inviteRooms[roomId];\n });\n Object.keys(this.joinRooms).forEach((roomId) => {\n const roomData = this.joinRooms[roomId];\n const roomJson: IJoinedRoom = {\n ephemeral: { events: [] },\n account_data: { events: [] },\n state: { events: [] },\n timeline: {\n events: [],\n prev_batch: null,\n },\n unread_notifications: roomData._unreadNotifications,\n unread_thread_notifications: roomData._unreadThreadNotifications,\n summary: roomData._summary as IRoomSummary,\n };\n // Add account data\n Object.keys(roomData._accountData).forEach((evType) => {\n roomJson.account_data.events.push(roomData._accountData[evType]);\n });\n\n // Add receipt data\n const receiptEvent = {\n type: EventType.Receipt,\n room_id: roomId,\n content: {\n // $event_id: { \"m.read\": { $user_id: $json } }\n } as IContent,\n };\n\n const receiptEventContent: MapWithDefault<\n string,\n MapWithDefault>\n > = new MapWithDefault(() => new MapWithDefault(() => new Map()));\n\n for (const [userId, receiptData] of Object.entries(roomData._readReceipts)) {\n receiptEventContent\n .getOrCreate(receiptData.eventId)\n .getOrCreate(receiptData.type)\n .set(userId, receiptData.data);\n }\n\n for (const threadReceipts of Object.values(roomData._threadReadReceipts)) {\n for (const [userId, receiptData] of Object.entries(threadReceipts)) {\n receiptEventContent\n .getOrCreate(receiptData.eventId)\n .getOrCreate(receiptData.type)\n .set(userId, receiptData.data);\n }\n }\n\n receiptEvent.content = recursiveMapToObject(receiptEventContent);\n\n // add only if we have some receipt data\n if (receiptEventContent.size > 0) {\n roomJson.ephemeral.events.push(receiptEvent as IMinimalEvent);\n }\n\n // Add timeline data\n roomData._timeline.forEach((msgData) => {\n if (!roomJson.timeline.prev_batch) {\n // the first event we add to the timeline MUST match up to\n // the prev_batch token.\n if (!msgData.token) {\n return; // this shouldn't happen as we prune constantly.\n }\n roomJson.timeline.prev_batch = msgData.token;\n }\n\n let transformedEvent: (IRoomEvent | IStateEvent) & { _localTs?: number };\n if (!forDatabase && isTaggedEvent(msgData.event)) {\n // This means we have to copy each event, so we can fix it up to\n // set a correct 'age' parameter whilst keeping the local timestamp\n // on our stored event. If this turns out to be a bottleneck, it could\n // be optimised either by doing this in the main process after the data\n // has been structured-cloned to go between the worker & main process,\n // or special-casing data from saved syncs to read the local timestamp\n // directly rather than turning it into age to then immediately be\n // transformed back again into a local timestamp.\n transformedEvent = Object.assign({}, msgData.event);\n if (transformedEvent.unsigned !== undefined) {\n transformedEvent.unsigned = Object.assign({}, transformedEvent.unsigned);\n }\n delete transformedEvent._localTs;\n transformedEvent.unsigned = transformedEvent.unsigned || {};\n transformedEvent.unsigned.age = Date.now() - msgData.event._localTs!;\n } else {\n transformedEvent = msgData.event;\n }\n roomJson.timeline.events.push(transformedEvent);\n });\n\n // Add state data: roll back current state to the start of timeline,\n // by \"reverse clobbering\" from the end of the timeline to the start.\n // Convert maps back into arrays.\n const rollBackState = Object.create(null);\n for (let i = roomJson.timeline.events.length - 1; i >= 0; i--) {\n const timelineEvent = roomJson.timeline.events[i];\n if (\n (timelineEvent as IStateEvent).state_key === null ||\n (timelineEvent as IStateEvent).state_key === undefined\n ) {\n continue; // not a state event\n }\n // since we're going back in time, we need to use the previous\n // state value else we'll break causality. We don't have the\n // complete previous state event, so we need to create one.\n const prevStateEvent = deepCopy(timelineEvent);\n if (prevStateEvent.unsigned) {\n if (prevStateEvent.unsigned.prev_content) {\n prevStateEvent.content = prevStateEvent.unsigned.prev_content;\n }\n if (prevStateEvent.unsigned.prev_sender) {\n prevStateEvent.sender = prevStateEvent.unsigned.prev_sender;\n }\n }\n setState(rollBackState, prevStateEvent);\n }\n Object.keys(roomData._currentState).forEach((evType) => {\n Object.keys(roomData._currentState[evType]).forEach((stateKey) => {\n let ev = roomData._currentState[evType][stateKey];\n if (rollBackState[evType] && rollBackState[evType][stateKey]) {\n // use the reverse clobbered event instead.\n ev = rollBackState[evType][stateKey];\n }\n roomJson.state.events.push(ev);\n });\n });\n data.join[roomId] = roomJson;\n });\n\n // Add account data\n const accData: IMinimalEvent[] = [];\n Object.keys(this.accountData).forEach((evType) => {\n accData.push(this.accountData[evType]);\n });\n\n return {\n nextBatch: this.nextBatch!,\n roomsData: data,\n accountData: accData,\n };\n }\n\n public getNextBatchToken(): string {\n return this.nextBatch!;\n }\n}\n\nfunction setState(eventMap: Record>, event: IRoomEvent | IStateEvent): void {\n if ((event as IStateEvent).state_key === null || (event as IStateEvent).state_key === undefined || !event.type) {\n return;\n }\n if (!eventMap[event.type]) {\n eventMap[event.type] = Object.create(null);\n }\n eventMap[event.type][(event as IStateEvent).state_key] = event as IStateEvent;\n}\n"],"mappings":";;;;;;;;AAoBA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AAGA,IAAAE,MAAA,GAAAF,OAAA;AACA,IAAAG,cAAA,GAAAH,OAAA;AACA,IAAAI,KAAA,GAAAJ,OAAA;AAA4D,SAAAK,QAAAC,MAAA,EAAAC,cAAA,QAAAC,IAAA,GAAAC,MAAA,CAAAD,IAAA,CAAAF,MAAA,OAAAG,MAAA,CAAAC,qBAAA,QAAAC,OAAA,GAAAF,MAAA,CAAAC,qBAAA,CAAAJ,MAAA,GAAAC,cAAA,KAAAI,OAAA,GAAAA,OAAA,CAAAC,MAAA,WAAAC,GAAA,WAAAJ,MAAA,CAAAK,wBAAA,CAAAR,MAAA,EAAAO,GAAA,EAAAE,UAAA,OAAAP,IAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,IAAA,EAAAG,OAAA,YAAAH,IAAA;AAAA,SAAAU,cAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,WAAAF,SAAA,CAAAD,CAAA,IAAAC,SAAA,CAAAD,CAAA,QAAAA,CAAA,OAAAf,OAAA,CAAAI,MAAA,CAAAc,MAAA,OAAAC,OAAA,WAAAC,GAAA,QAAAC,gBAAA,CAAAC,OAAA,EAAAR,MAAA,EAAAM,GAAA,EAAAF,MAAA,CAAAE,GAAA,SAAAhB,MAAA,CAAAmB,yBAAA,GAAAnB,MAAA,CAAAoB,gBAAA,CAAAV,MAAA,EAAAV,MAAA,CAAAmB,yBAAA,CAAAL,MAAA,KAAAlB,OAAA,CAAAI,MAAA,CAAAc,MAAA,GAAAC,OAAA,WAAAC,GAAA,IAAAhB,MAAA,CAAAqB,cAAA,CAAAX,MAAA,EAAAM,GAAA,EAAAhB,MAAA,CAAAK,wBAAA,CAAAS,MAAA,EAAAE,GAAA,iBAAAN,MAAA;AA6H5D;AAAA,IAEYY,QAAQ;AAAAC,OAAA,CAAAD,QAAA,GAAAA,QAAA;AAAA,WAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;AAAA,GAARA,QAAQ,KAAAC,OAAA,CAAAD,QAAA,GAARA,QAAQ;AA0CpB,SAASE,aAAaA,CAACC,KAAiB,EAAwB;EAC5D,OAAO,UAAU,IAAIA,KAAK,IAAIA,KAAK,CAAC,UAAU,CAAC,KAAKC,SAAS;AACjE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMC,eAAe,CAAC;EACgC;EACD;;EAExD;EACA;EACA;EACA;;EAGOC,WAAWA,CAAkBC,IAAW,GAAG,CAAC,CAAC,EAAE;IAAA,KAAlBA,IAAW,GAAXA,IAAW;IAAA,IAAAZ,gBAAA,CAAAC,OAAA,uBATM,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,uBACH,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,qBACL,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,qBAKhB,IAAI;IAGnC,IAAI,CAACW,IAAI,CAACC,kBAAkB,GAAG,IAAI,CAACD,IAAI,CAACC,kBAAkB,IAAI,EAAE;EACrE;EAEOC,UAAUA,CAACC,YAA2B,EAAEC,YAAY,GAAG,KAAK,EAAQ;IACvE,IAAI,CAACC,eAAe,CAACF,YAAY,EAAEC,YAAY,CAAC;IAChD,IAAI,CAACE,qBAAqB,CAACH,YAAY,CAAC;IACxC,IAAI,CAACI,SAAS,GAAGJ,YAAY,CAACK,UAAU;EAC5C;EAEQF,qBAAqBA,CAACH,YAA2B,EAAQ;IAC7D,IAAI,CAACA,YAAY,CAACM,YAAY,IAAI,CAACN,YAAY,CAACM,YAAY,CAACC,MAAM,EAAE;MACjE;IACJ;IACA;IACAP,YAAY,CAACM,YAAY,CAACC,MAAM,CAACxB,OAAO,CAAEyB,CAAC,IAAK;MAC5C,IAAI,CAACC,WAAW,CAACD,CAAC,CAACE,IAAI,CAAC,GAAGF,CAAC;IAChC,CAAC,CAAC;EACN;;EAEA;AACJ;AACA;AACA;AACA;EACYN,eAAeA,CAACF,YAA2B,EAAEC,YAAY,GAAG,KAAK,EAAQ;IAC7E,IAAI,CAACD,YAAY,CAACW,KAAK,EAAE;MACrB;IACJ;IACA,IAAIX,YAAY,CAACW,KAAK,CAACC,MAAM,EAAE;MAC3B5C,MAAM,CAACD,IAAI,CAACiC,YAAY,CAACW,KAAK,CAACC,MAAM,CAAC,CAAC7B,OAAO,CAAE8B,MAAM,IAAK;QACvD,IAAI,CAACC,cAAc,CAACD,MAAM,EAAEvB,QAAQ,CAACyB,MAAM,EAAEf,YAAY,CAACW,KAAK,CAACC,MAAM,CAACC,MAAM,CAAC,EAAEZ,YAAY,CAAC;MACjG,CAAC,CAAC;IACN;IACA,IAAID,YAAY,CAACW,KAAK,CAACK,IAAI,EAAE;MACzBhD,MAAM,CAACD,IAAI,CAACiC,YAAY,CAACW,KAAK,CAACK,IAAI,CAAC,CAACjC,OAAO,CAAE8B,MAAM,IAAK;QACrD,IAAI,CAACC,cAAc,CAACD,MAAM,EAAEvB,QAAQ,CAAC2B,IAAI,EAAEjB,YAAY,CAACW,KAAK,CAACK,IAAI,CAACH,MAAM,CAAC,EAAEZ,YAAY,CAAC;MAC7F,CAAC,CAAC;IACN;IACA,IAAID,YAAY,CAACW,KAAK,CAACO,KAAK,EAAE;MAC1BlD,MAAM,CAACD,IAAI,CAACiC,YAAY,CAACW,KAAK,CAACO,KAAK,CAAC,CAACnC,OAAO,CAAE8B,MAAM,IAAK;QACtD,IAAI,CAACC,cAAc,CAACD,MAAM,EAAEvB,QAAQ,CAAC6B,KAAK,EAAEnB,YAAY,CAACW,KAAK,CAACO,KAAK,CAACL,MAAM,CAAC,EAAEZ,YAAY,CAAC;MAC/F,CAAC,CAAC;IACN;EACJ;EAKQa,cAAcA,CAACD,MAAc,EAAEO,QAAkB,EAAEC,IAAS,EAAEpB,YAAY,GAAG,KAAK,EAAQ;IAC9F;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA,QAAQmB,QAAQ;MACZ,KAAK9B,QAAQ,CAACyB,MAAM;QAAE;QAClB,IAAI,CAACO,qBAAqB,CAACT,MAAM,EAAEQ,IAAI,CAAiB;QACxD;MAEJ,KAAK/B,QAAQ,CAAC2B,IAAI;QACd,IAAI,IAAI,CAACM,WAAW,CAACV,MAAM,CAAC,EAAE;UAC1B;UACA;UACA;UACA;UACA,OAAO,IAAI,CAACU,WAAW,CAACV,MAAM,CAAC;QACnC;QACA;QACA,IAAI,CAACW,mBAAmB,CAACX,MAAM,EAAEQ,IAAI,EAAiBpB,YAAY,CAAC;QACnE;MAEJ,KAAKX,QAAQ,CAAC6B,KAAK;QACf,IAAI,IAAI,CAACI,WAAW,CAACV,MAAM,CAAC,EAAE;UAC1B;UACA,OAAO,IAAI,CAACU,WAAW,CAACV,MAAM,CAAC;QACnC,CAAC,MAAM;UACH;UACA,OAAO,IAAI,CAACY,SAAS,CAACZ,MAAM,CAAC;QACjC;QACA;MAEJ;QACIa,cAAM,CAACC,KAAK,CAAC,qBAAqB,EAAEP,QAAQ,CAAC;IAAC;EAE1D;EAEQE,qBAAqBA,CAACT,MAAc,EAAEQ,IAAkB,EAAQ;IACpE,IAAI,CAACA,IAAI,CAACO,YAAY,IAAI,CAACP,IAAI,CAACO,YAAY,CAACrB,MAAM,EAAE;MACjD;MACA;IACJ;IACA,IAAI,CAAC,IAAI,CAACgB,WAAW,CAACV,MAAM,CAAC,EAAE;MAC3B,IAAI,CAACU,WAAW,CAACV,MAAM,CAAC,GAAG;QACvBe,YAAY,EAAEP,IAAI,CAACO;MACvB,CAAC;MACD;IACJ;IACA;IACA;IACA;IACA,MAAMC,WAAW,GAAG,IAAI,CAACN,WAAW,CAACV,MAAM,CAAC;IAC5CQ,IAAI,CAACO,YAAY,CAACrB,MAAM,CAACxB,OAAO,CAAEyB,CAAC,IAAK;MACpC,IAAIsB,QAAQ,GAAG,KAAK;MACpB,KAAK,IAAInD,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGkD,WAAW,CAACD,YAAY,CAACrB,MAAM,CAAC1B,MAAM,EAAEF,CAAC,EAAE,EAAE;QAC7D,MAAMoD,OAAO,GAAGF,WAAW,CAACD,YAAY,CAACrB,MAAM,CAAC5B,CAAC,CAAC;QAClD,IAAIoD,OAAO,CAACrB,IAAI,KAAKF,CAAC,CAACE,IAAI,IAAIqB,OAAO,CAACC,SAAS,IAAIxB,CAAC,CAACwB,SAAS,EAAE;UAC7DH,WAAW,CAACD,YAAY,CAACrB,MAAM,CAAC5B,CAAC,CAAC,GAAG6B,CAAC,CAAC,CAAC;UACxCsB,QAAQ,GAAG,IAAI;QACnB;MACJ;MACA,IAAI,CAACA,QAAQ,EAAE;QACXD,WAAW,CAACD,YAAY,CAACrB,MAAM,CAAChC,IAAI,CAACiC,CAAC,CAAC;MAC3C;IACJ,CAAC,CAAC;EACN;;EAEA;EACQgB,mBAAmBA,CAACX,MAAc,EAAEQ,IAAiB,EAAEpB,YAAY,GAAG,KAAK,EAAQ;IAAA,IAAAgC,IAAA,EAAAC,KAAA,EAAAC,eAAA,EAAAC,qBAAA,EAAAC,WAAA,EAAAC,kBAAA,EAAAC,cAAA,EAAAC,qBAAA;IACvF;IACA;IACA;IACA;IACA;IACA;;IAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;;IAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;;IAEA,IAAI,CAAC,IAAI,CAACf,SAAS,CAACZ,MAAM,CAAC,EAAE;MACzB;MACA;MACA,IAAI,CAACY,SAAS,CAACZ,MAAM,CAAC,GAAG;QACrB4B,aAAa,EAAEzE,MAAM,CAAC0E,MAAM,CAAC,IAAI,CAAC;QAClCC,SAAS,EAAE,EAAE;QACbC,YAAY,EAAE5E,MAAM,CAAC0E,MAAM,CAAC,IAAI,CAAC;QACjCG,oBAAoB,EAAE,CAAC,CAAC;QACxBC,0BAA0B,EAAE,CAAC,CAAC;QAC9BC,QAAQ,EAAE,CAAC,CAAC;QACZC,aAAa,EAAE,CAAC,CAAC;QACjBC,mBAAmB,EAAE,CAAC;MAC1B,CAAC;IACL;IACA,MAAMpB,WAAW,GAAG,IAAI,CAACJ,SAAS,CAACZ,MAAM,CAAC;IAE1C,IAAIQ,IAAI,CAACf,YAAY,IAAIe,IAAI,CAACf,YAAY,CAACC,MAAM,EAAE;MAC/C;MACAc,IAAI,CAACf,YAAY,CAACC,MAAM,CAACxB,OAAO,CAAEyB,CAAC,IAAK;QACpCqB,WAAW,CAACe,YAAY,CAACpC,CAAC,CAACE,IAAI,CAAC,GAAGF,CAAC;MACxC,CAAC,CAAC;IACN;;IAEA;IACA,IAAIa,IAAI,CAAC6B,oBAAoB,EAAE;MAC3BrB,WAAW,CAACgB,oBAAoB,GAAGxB,IAAI,CAAC6B,oBAAoB;IAChE;IACArB,WAAW,CAACiB,0BAA0B,IAAAb,IAAA,IAAAC,KAAA,GAClCb,IAAI,CAAC8B,iCAA2B,CAACC,MAAM,CAAE,cAAAlB,KAAA,cAAAA,KAAA,GAAIb,IAAI,CAAC8B,iCAA2B,CAACE,QAAQ,CAAE,cAAApB,IAAA,cAAAA,IAAA,GAAIvC,SAAS;IAEzG,IAAI2B,IAAI,CAACiC,OAAO,EAAE;MACd,MAAMC,UAAU,GAAG,UAAU;MAC7B,MAAMC,iBAAiB,GAAG,wBAAwB;MAClD,MAAMC,gBAAgB,GAAG,uBAAuB;MAEhD,MAAMC,GAAG,GAAG7B,WAAW,CAACkB,QAAQ;MAChC,MAAMY,GAAG,GAAGtC,IAAI,CAACiC,OAAO;MACxBI,GAAG,CAACH,UAAU,CAAC,GAAGI,GAAG,CAACJ,UAAU,CAAC,IAAIG,GAAG,CAACH,UAAU,CAAC;MACpDG,GAAG,CAACD,gBAAgB,CAAC,GAAGE,GAAG,CAACF,gBAAgB,CAAC,IAAIC,GAAG,CAACD,gBAAgB,CAAC;MACtEC,GAAG,CAACF,iBAAiB,CAAC,GAAGG,GAAG,CAACH,iBAAiB,CAAC,IAAIE,GAAG,CAACF,iBAAiB,CAAC;IAC7E;IAEA,CAAArB,eAAA,GAAAd,IAAI,CAACuC,SAAS,cAAAzB,eAAA,wBAAAC,qBAAA,GAAdD,eAAA,CAAgB5B,MAAM,cAAA6B,qBAAA,uBAAtBA,qBAAA,CAAwBrD,OAAO,CAAEyB,CAAC,IAAK;MACnC;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA,IAAIA,CAAC,CAACE,IAAI,KAAKmD,gBAAS,CAACC,OAAO,IAAI,CAACtD,CAAC,CAACuD,OAAO,EAAE;QAC5C;QACA;QACA;MACJ;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA/F,MAAM,CAACD,IAAI,CAACyC,CAAC,CAACuD,OAAO,CAAC,CAAChF,OAAO,CAAEiF,OAAO,IAAK;QACxChG,MAAM,CAACiG,OAAO,CAAiBzD,CAAC,CAACuD,OAAO,CAACC,OAAO,CAAC,CAAC,CAACjF,OAAO,CAAC,CAAC,CAACC,GAAG,EAAEkF,KAAK,CAAC,KAAK;UACzE,IAAI,CAAC,IAAAC,6BAAsB,EAACnF,GAAG,CAAC,EAAE;UAElC,KAAK,MAAMoF,MAAM,IAAIpG,MAAM,CAACD,IAAI,CAACmG,KAAK,CAAC,EAAE;YACrC,MAAM7C,IAAI,GAAGb,CAAC,CAACuD,OAAO,CAACC,OAAO,CAAC,CAAChF,GAAG,CAAC,CAACoF,MAAM,CAAC;YAE5C,MAAMC,OAAO,GAAG;cACZhD,IAAI,EAAEb,CAAC,CAACuD,OAAO,CAACC,OAAO,CAAC,CAAChF,GAAG,CAAC,CAACoF,MAAM,CAAC;cACrC1D,IAAI,EAAE1B,GAAkB;cACxBgF,OAAO,EAAEA;YACb,CAAC;YAED,IAAI,CAAC3C,IAAI,CAACiD,SAAS,IAAIjD,IAAI,CAACiD,SAAS,KAAKC,iCAAkB,EAAE;cAC1D1C,WAAW,CAACmB,aAAa,CAACoB,MAAM,CAAC,GAAGC,OAAO;YAC/C,CAAC,MAAM;cAAA,IAAAG,qBAAA;cACH3C,WAAW,CAACoB,mBAAmB,GAAAxE,aAAA,CAAAA,aAAA,KACxBoD,WAAW,CAACoB,mBAAmB;gBAClC,CAAC5B,IAAI,CAACiD,SAAS,GAAA7F,aAAA,CAAAA,aAAA,MAAA+F,qBAAA,GACP3C,WAAW,CAACoB,mBAAmB,CAAC5B,IAAI,CAACiD,SAAS,CAAC,cAAAE,qBAAA,cAAAA,qBAAA,GAAI,CAAC,CAAC;kBACzD,CAACJ,MAAM,GAAGC;gBAAO;cACpB,EACJ;YACL;UACJ;QACJ,CAAC,CAAC;MACN,CAAC,CAAC;IACN,CAAC,CAAC;;IAEF;IACA;IACA,IAAIhD,IAAI,CAACoD,QAAQ,IAAIpD,IAAI,CAACoD,QAAQ,CAACC,OAAO,EAAE;MACxC7C,WAAW,CAACc,SAAS,GAAG,EAAE;IAC9B;;IAEA;IACA;IACA;IACA;IACA,CAAAN,WAAA,GAAAhB,IAAI,CAACsD,KAAK,cAAAtC,WAAA,wBAAAC,kBAAA,GAAVD,WAAA,CAAY9B,MAAM,cAAA+B,kBAAA,uBAAlBA,kBAAA,CAAoBvD,OAAO,CAAEyB,CAAC,IAAK;MAC/BoE,QAAQ,CAAC/C,WAAW,CAACY,aAAa,EAAEjC,CAAC,CAAC;IAC1C,CAAC,CAAC;IACF,CAAA+B,cAAA,GAAAlB,IAAI,CAACoD,QAAQ,cAAAlC,cAAA,wBAAAC,qBAAA,GAAbD,cAAA,CAAehC,MAAM,cAAAiC,qBAAA,uBAArBA,qBAAA,CAAuBzD,OAAO,CAAC,CAACyB,CAAC,EAAEqE,KAAK,KAAK;MAAA,IAAAC,qBAAA;MACzC;MACAF,QAAQ,CAAC/C,WAAW,CAACY,aAAa,EAAEjC,CAAC,CAAC;MACtC;MACA;MACA,IAAIuE,gBAA6B;MACjC,IAAI,CAAC9E,YAAY,EAAE;QACf8E,gBAAgB,GAAG/G,MAAM,CAACgH,MAAM,CAAC,CAAC,CAAC,EAAExE,CAAC,CAAC;QACvC,IAAIuE,gBAAgB,CAACE,QAAQ,KAAKvF,SAAS,EAAE;UACzCqF,gBAAgB,CAACE,QAAQ,GAAGjH,MAAM,CAACgH,MAAM,CAAC,CAAC,CAAC,EAAED,gBAAgB,CAACE,QAAQ,CAAC;QAC5E;QACA,MAAMC,GAAG,GAAG1E,CAAC,CAACyE,QAAQ,GAAGzE,CAAC,CAACyE,QAAQ,CAACC,GAAG,GAAG1E,CAAC,CAAC0E,GAAG;QAC/C,IAAIA,GAAG,KAAKxF,SAAS,EAAEqF,gBAAgB,CAACI,QAAQ,GAAGC,IAAI,CAACC,GAAG,EAAE,GAAGH,GAAG;MACvE,CAAC,MAAM;QACHH,gBAAgB,GAAGvE,CAAC;MACxB;MAEAqB,WAAW,CAACc,SAAS,CAACpE,IAAI,CAAC;QACvBkB,KAAK,EAAEsF,gBAAgB;QACvBO,KAAK,EAAET,KAAK,KAAK,CAAC,IAAAC,qBAAA,GAAGzD,IAAI,CAACoD,QAAQ,CAACc,UAAU,cAAAT,qBAAA,cAAAA,qBAAA,GAAI,IAAI,GAAG;MAC5D,CAAC,CAAC;IACN,CAAC,CAAC;;IAEF;IACA;IACA,IAAIjD,WAAW,CAACc,SAAS,CAAC9D,MAAM,GAAG,IAAI,CAACgB,IAAI,CAACC,kBAAmB,EAAE;MAC9D,MAAM0F,UAAU,GAAG3D,WAAW,CAACc,SAAS,CAAC9D,MAAM,GAAG,IAAI,CAACgB,IAAI,CAACC,kBAAmB;MAC/E,KAAK,IAAInB,CAAC,GAAG6G,UAAU,EAAE7G,CAAC,GAAGkD,WAAW,CAACc,SAAS,CAAC9D,MAAM,EAAEF,CAAC,EAAE,EAAE;QAC5D,IAAIkD,WAAW,CAACc,SAAS,CAAChE,CAAC,CAAC,CAAC2G,KAAK,EAAE;UAChC;UACAzD,WAAW,CAACc,SAAS,GAAGd,WAAW,CAACc,SAAS,CAAC8C,KAAK,CAAC9G,CAAC,EAAEkD,WAAW,CAACc,SAAS,CAAC9D,MAAM,CAAC;UACpF;QACJ;MACJ;IACJ;EACJ;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACW6G,OAAOA,CAACC,WAAW,GAAG,KAAK,EAAa;IAC3C,MAAMtE,IAAY,GAAG;MACjBL,IAAI,EAAE,CAAC,CAAC;MACRJ,MAAM,EAAE,CAAC,CAAC;MACV;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACAM,KAAK,EAAE,CAAC;IACZ,CAAC;IACDlD,MAAM,CAACD,IAAI,CAAC,IAAI,CAACwD,WAAW,CAAC,CAACxC,OAAO,CAAE8B,MAAM,IAAK;MAC9CQ,IAAI,CAACT,MAAM,CAACC,MAAM,CAAC,GAAG,IAAI,CAACU,WAAW,CAACV,MAAM,CAAC;IAClD,CAAC,CAAC;IACF7C,MAAM,CAACD,IAAI,CAAC,IAAI,CAAC0D,SAAS,CAAC,CAAC1C,OAAO,CAAE8B,MAAM,IAAK;MAC5C,MAAM+E,QAAQ,GAAG,IAAI,CAACnE,SAAS,CAACZ,MAAM,CAAC;MACvC,MAAMgF,QAAqB,GAAG;QAC1BjC,SAAS,EAAE;UAAErD,MAAM,EAAE;QAAG,CAAC;QACzBD,YAAY,EAAE;UAAEC,MAAM,EAAE;QAAG,CAAC;QAC5BoE,KAAK,EAAE;UAAEpE,MAAM,EAAE;QAAG,CAAC;QACrBkE,QAAQ,EAAE;UACNlE,MAAM,EAAE,EAAE;UACVgF,UAAU,EAAE;QAChB,CAAC;QACDrC,oBAAoB,EAAE0C,QAAQ,CAAC/C,oBAAoB;QACnDiD,2BAA2B,EAAEF,QAAQ,CAAC9C,0BAA0B;QAChEQ,OAAO,EAAEsC,QAAQ,CAAC7C;MACtB,CAAC;MACD;MACA/E,MAAM,CAACD,IAAI,CAAC6H,QAAQ,CAAChD,YAAY,CAAC,CAAC7D,OAAO,CAAEgH,MAAM,IAAK;QACnDF,QAAQ,CAACvF,YAAY,CAACC,MAAM,CAAChC,IAAI,CAACqH,QAAQ,CAAChD,YAAY,CAACmD,MAAM,CAAC,CAAC;MACpE,CAAC,CAAC;;MAEF;MACA,MAAMC,YAAY,GAAG;QACjBtF,IAAI,EAAEmD,gBAAS,CAACC,OAAO;QACvBmC,OAAO,EAAEpF,MAAM;QACfkD,OAAO,EAAE;UACL;QAAA;MAER,CAAC;MAED,MAAMmC,mBAGL,GAAG,IAAIC,qBAAc,CAAC,MAAM,IAAIA,qBAAc,CAAC,MAAM,IAAIC,GAAG,EAAE,CAAC,CAAC;MAEjE,KAAK,MAAM,CAAChC,MAAM,EAAEiC,WAAW,CAAC,IAAIrI,MAAM,CAACiG,OAAO,CAAC2B,QAAQ,CAAC5C,aAAa,CAAC,EAAE;QACxEkD,mBAAmB,CACdI,WAAW,CAACD,WAAW,CAACrC,OAAO,CAAC,CAChCsC,WAAW,CAACD,WAAW,CAAC3F,IAAI,CAAC,CAC7B6F,GAAG,CAACnC,MAAM,EAAEiC,WAAW,CAAChF,IAAI,CAAC;MACtC;MAEA,KAAK,MAAMmF,cAAc,IAAIxI,MAAM,CAACyI,MAAM,CAACb,QAAQ,CAAC3C,mBAAmB,CAAC,EAAE;QACtE,KAAK,MAAM,CAACmB,MAAM,EAAEiC,WAAW,CAAC,IAAIrI,MAAM,CAACiG,OAAO,CAACuC,cAAc,CAAC,EAAE;UAChEN,mBAAmB,CACdI,WAAW,CAACD,WAAW,CAACrC,OAAO,CAAC,CAChCsC,WAAW,CAACD,WAAW,CAAC3F,IAAI,CAAC,CAC7B6F,GAAG,CAACnC,MAAM,EAAEiC,WAAW,CAAChF,IAAI,CAAC;QACtC;MACJ;MAEA2E,YAAY,CAACjC,OAAO,GAAG,IAAA2C,2BAAoB,EAACR,mBAAmB,CAAC;;MAEhE;MACA,IAAIA,mBAAmB,CAACS,IAAI,GAAG,CAAC,EAAE;QAC9Bd,QAAQ,CAACjC,SAAS,CAACrD,MAAM,CAAChC,IAAI,CAACyH,YAAY,CAAkB;MACjE;;MAEA;MACAJ,QAAQ,CAACjD,SAAS,CAAC5D,OAAO,CAAE6H,OAAO,IAAK;QACpC,IAAI,CAACf,QAAQ,CAACpB,QAAQ,CAACc,UAAU,EAAE;UAC/B;UACA;UACA,IAAI,CAACqB,OAAO,CAACtB,KAAK,EAAE;YAChB,OAAO,CAAC;UACZ;;UACAO,QAAQ,CAACpB,QAAQ,CAACc,UAAU,GAAGqB,OAAO,CAACtB,KAAK;QAChD;QAEA,IAAIP,gBAAoE;QACxE,IAAI,CAACY,WAAW,IAAInG,aAAa,CAACoH,OAAO,CAACnH,KAAK,CAAC,EAAE;UAC9C;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACAsF,gBAAgB,GAAG/G,MAAM,CAACgH,MAAM,CAAC,CAAC,CAAC,EAAE4B,OAAO,CAACnH,KAAK,CAAC;UACnD,IAAIsF,gBAAgB,CAACE,QAAQ,KAAKvF,SAAS,EAAE;YACzCqF,gBAAgB,CAACE,QAAQ,GAAGjH,MAAM,CAACgH,MAAM,CAAC,CAAC,CAAC,EAAED,gBAAgB,CAACE,QAAQ,CAAC;UAC5E;UACA,OAAOF,gBAAgB,CAACI,QAAQ;UAChCJ,gBAAgB,CAACE,QAAQ,GAAGF,gBAAgB,CAACE,QAAQ,IAAI,CAAC,CAAC;UAC3DF,gBAAgB,CAACE,QAAQ,CAACC,GAAG,GAAGE,IAAI,CAACC,GAAG,EAAE,GAAGuB,OAAO,CAACnH,KAAK,CAAC0F,QAAS;QACxE,CAAC,MAAM;UACHJ,gBAAgB,GAAG6B,OAAO,CAACnH,KAAK;QACpC;QACAoG,QAAQ,CAACpB,QAAQ,CAAClE,MAAM,CAAChC,IAAI,CAACwG,gBAAgB,CAAC;MACnD,CAAC,CAAC;;MAEF;MACA;MACA;MACA,MAAM8B,aAAa,GAAG7I,MAAM,CAAC0E,MAAM,CAAC,IAAI,CAAC;MACzC,KAAK,IAAI/D,CAAC,GAAGkH,QAAQ,CAACpB,QAAQ,CAAClE,MAAM,CAAC1B,MAAM,GAAG,CAAC,EAAEF,CAAC,IAAI,CAAC,EAAEA,CAAC,EAAE,EAAE;QAC3D,MAAMmI,aAAa,GAAGjB,QAAQ,CAACpB,QAAQ,CAAClE,MAAM,CAAC5B,CAAC,CAAC;QACjD,IACKmI,aAAa,CAAiB9E,SAAS,KAAK,IAAI,IAChD8E,aAAa,CAAiB9E,SAAS,KAAKtC,SAAS,EACxD;UACE,SAAS,CAAC;QACd;QACA;QACA;QACA;QACA,MAAMqH,cAAc,GAAG,IAAAC,eAAQ,EAACF,aAAa,CAAC;QAC9C,IAAIC,cAAc,CAAC9B,QAAQ,EAAE;UACzB,IAAI8B,cAAc,CAAC9B,QAAQ,CAACgC,YAAY,EAAE;YACtCF,cAAc,CAAChD,OAAO,GAAGgD,cAAc,CAAC9B,QAAQ,CAACgC,YAAY;UACjE;UACA,IAAIF,cAAc,CAAC9B,QAAQ,CAACiC,WAAW,EAAE;YACrCH,cAAc,CAACI,MAAM,GAAGJ,cAAc,CAAC9B,QAAQ,CAACiC,WAAW;UAC/D;QACJ;QACAtC,QAAQ,CAACiC,aAAa,EAAEE,cAAc,CAAC;MAC3C;MACA/I,MAAM,CAACD,IAAI,CAAC6H,QAAQ,CAACnD,aAAa,CAAC,CAAC1D,OAAO,CAAEgH,MAAM,IAAK;QACpD/H,MAAM,CAACD,IAAI,CAAC6H,QAAQ,CAACnD,aAAa,CAACsD,MAAM,CAAC,CAAC,CAAChH,OAAO,CAAEqI,QAAQ,IAAK;UAC9D,IAAIC,EAAE,GAAGzB,QAAQ,CAACnD,aAAa,CAACsD,MAAM,CAAC,CAACqB,QAAQ,CAAC;UACjD,IAAIP,aAAa,CAACd,MAAM,CAAC,IAAIc,aAAa,CAACd,MAAM,CAAC,CAACqB,QAAQ,CAAC,EAAE;YAC1D;YACAC,EAAE,GAAGR,aAAa,CAACd,MAAM,CAAC,CAACqB,QAAQ,CAAC;UACxC;UACAvB,QAAQ,CAAClB,KAAK,CAACpE,MAAM,CAAChC,IAAI,CAAC8I,EAAE,CAAC;QAClC,CAAC,CAAC;MACN,CAAC,CAAC;MACFhG,IAAI,CAACL,IAAI,CAACH,MAAM,CAAC,GAAGgF,QAAQ;IAChC,CAAC,CAAC;;IAEF;IACA,MAAMyB,OAAwB,GAAG,EAAE;IACnCtJ,MAAM,CAACD,IAAI,CAAC,IAAI,CAAC0C,WAAW,CAAC,CAAC1B,OAAO,CAAEgH,MAAM,IAAK;MAC9CuB,OAAO,CAAC/I,IAAI,CAAC,IAAI,CAACkC,WAAW,CAACsF,MAAM,CAAC,CAAC;IAC1C,CAAC,CAAC;IAEF,OAAO;MACH3F,SAAS,EAAE,IAAI,CAACA,SAAU;MAC1BmH,SAAS,EAAElG,IAAI;MACfZ,WAAW,EAAE6G;IACjB,CAAC;EACL;EAEOE,iBAAiBA,CAAA,EAAW;IAC/B,OAAO,IAAI,CAACpH,SAAS;EACzB;AACJ;AAACb,OAAA,CAAAI,eAAA,GAAAA,eAAA;AAED,SAASiF,QAAQA,CAAC6C,QAAqD,EAAEhI,KAA+B,EAAQ;EAC5G,IAAKA,KAAK,CAAiBuC,SAAS,KAAK,IAAI,IAAKvC,KAAK,CAAiBuC,SAAS,KAAKtC,SAAS,IAAI,CAACD,KAAK,CAACiB,IAAI,EAAE;IAC5G;EACJ;EACA,IAAI,CAAC+G,QAAQ,CAAChI,KAAK,CAACiB,IAAI,CAAC,EAAE;IACvB+G,QAAQ,CAAChI,KAAK,CAACiB,IAAI,CAAC,GAAG1C,MAAM,CAAC0E,MAAM,CAAC,IAAI,CAAC;EAC9C;EACA+E,QAAQ,CAAChI,KAAK,CAACiB,IAAI,CAAC,CAAEjB,KAAK,CAAiBuC,SAAS,CAAC,GAAGvC,KAAoB;AACjF"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts deleted file mode 100644 index 4d24504..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts +++ /dev/null @@ -1,250 +0,0 @@ -import type { SyncCryptoCallbacks } from "./common-crypto/CryptoBackend"; -import { Room } from "./models/room"; -import { IStoredClientOpts, MatrixClient, ResetTimelineCallback } from "./client"; -import { MatrixEvent } from "./models/event"; -import { Crypto } from "./crypto"; -export declare enum SyncState { - /** Emitted after we try to sync more than `FAILED_SYNC_ERROR_THRESHOLD` - * times and are still failing. Or when we enounter a hard error like the - * token being invalid. */ - Error = "ERROR", - /** Emitted after the first sync events are ready (this could even be sync - * events from the cache) */ - Prepared = "PREPARED", - /** Emitted when the sync loop is no longer running */ - Stopped = "STOPPED", - /** Emitted after each sync request happens */ - Syncing = "SYNCING", - /** Emitted after a connectivity error and we're ready to start syncing again */ - Catchup = "CATCHUP", - /** Emitted for each time we try reconnecting. Will switch to `Error` after - * we reach the `FAILED_SYNC_ERROR_THRESHOLD` - */ - Reconnecting = "RECONNECTING" -} -/** - * Options passed into the constructor of SyncApi by MatrixClient - */ -export interface SyncApiOptions { - /** - * Crypto manager - * - * @deprecated in favour of cryptoCallbacks - */ - crypto?: Crypto; - /** - * If crypto is enabled on our client, callbacks into the crypto module - */ - cryptoCallbacks?: SyncCryptoCallbacks; - /** - * A function which is called - * with a room ID and returns a boolean. It should return 'true' if the SDK can - * SAFELY remove events from this room. It may not be safe to remove events if - * there are other references to the timelines for this room. - */ - canResetEntireTimeline?: ResetTimelineCallback; -} -export interface ISyncStateData { - /** - * The matrix error if `state=ERROR`. - */ - error?: Error; - /** - * The 'since' token passed to /sync. - * `null` for the first successful sync since this client was - * started. Only present if `state=PREPARED` or - * `state=SYNCING`. - */ - oldSyncToken?: string; - /** - * The 'next_batch' result from /sync, which - * will become the 'since' token for the next call to /sync. Only present if - * `state=PREPARED or state=SYNCING`. - */ - nextSyncToken?: string; - /** - * True if we are working our way through a - * backlog of events after connecting. Only present if `state=SYNCING`. - */ - catchingUp?: boolean; - fromCache?: boolean; -} -/** add default settings to an IStoredClientOpts */ -export declare function defaultClientOpts(opts?: IStoredClientOpts): IStoredClientOpts; -export declare function defaultSyncApiOpts(syncOpts?: SyncApiOptions): SyncApiOptions; -export declare class SyncApi { - private readonly client; - private readonly opts; - private readonly syncOpts; - private _peekRoom; - private currentSyncRequest?; - private abortController?; - private syncState; - private syncStateData?; - private catchingUp; - private running; - private keepAliveTimer?; - private connectionReturnedDefer?; - private notifEvents; - private failedSyncCount; - private storeIsInvalid; - /** - * Construct an entity which is able to sync with a homeserver. - * @param client - The matrix client instance to use. - * @param opts - client config options - * @param syncOpts - sync-specific options passed by the client - * @internal - */ - constructor(client: MatrixClient, opts?: IStoredClientOpts, syncOpts?: SyncApiOptions); - createRoom(roomId: string): Room; - /** When we see the marker state change in the room, we know there is some - * new historical messages imported by MSC2716 `/batch_send` somewhere in - * the room and we need to throw away the timeline to make sure the - * historical messages are shown when we paginate `/messages` again. - * @param room - The room where the marker event was sent - * @param markerEvent - The new marker event - * @param setStateOptions - When `timelineWasEmpty` is set - * as `true`, the given marker event will be ignored - */ - private onMarkerStateEvent; - /** - * Sync rooms the user has left. - * @returns Resolved when they've been added to the store. - */ - syncLeftRooms(): Promise; - /** - * Peek into a room. This will result in the room in question being synced so it - * is accessible via getRooms(). Live updates for the room will be provided. - * @param roomId - The room ID to peek into. - * @returns A promise which resolves once the room has been added to the - * store. - */ - peek(roomId: string): Promise; - /** - * Stop polling for updates in the peeked room. NOPs if there is no room being - * peeked. - */ - stopPeeking(): void; - /** - * Do a peek room poll. - * @param token - from= token - */ - private peekPoll; - /** - * Returns the current state of this sync object - * @see MatrixClient#event:"sync" - */ - getSyncState(): SyncState | null; - /** - * Returns the additional data object associated with - * the current sync state, or null if there is no - * such data. - * Sync errors, if available, are put in the 'error' key of - * this object. - */ - getSyncStateData(): ISyncStateData | null; - recoverFromSyncStartupError(savedSyncPromise: Promise | undefined, error: Error): Promise; - /** - * Is the lazy loading option different than in previous session? - * @param lazyLoadMembers - current options for lazy loading - * @returns whether or not the option has changed compared to the previous session */ - private wasLazyLoadingToggled; - private shouldAbortSync; - private getPushRules; - private buildDefaultFilter; - private checkLazyLoadStatus; - private getFilter; - private savedSyncPromise?; - /** - * Main entry point - */ - sync(): Promise; - /** - * Stops the sync object from syncing. - */ - stop(): void; - /** - * Retry a backed off syncing request immediately. This should only be used when - * the user explicitly attempts to retry their lost connection. - * @returns True if this resulted in a request being retried. - */ - retryImmediately(): boolean; - /** - * Process a single set of cached sync data. - * @param savedSync - a saved sync that was persisted by a store. This - * should have been acquired via client.store.getSavedSync(). - */ - private syncFromCache; - /** - * Invoke me to do /sync calls - */ - private doSync; - private doSyncRequest; - private getSyncParams; - private onSyncError; - /** - * Process data returned from a sync response and propagate it - * into the model objects - * - * @param syncEventData - Object containing sync tokens associated with this sync - * @param data - The response from /sync - */ - private processSyncResponse; - /** - * Starts polling the connectivity check endpoint - * @param delay - How long to delay until the first poll. - * defaults to a short, randomised interval (to prevent - * tight-looping if /versions succeeds but /sync etc. fail). - * @returns which resolves once the connection returns - */ - private startKeepAlives; - /** - * Make a dummy call to /_matrix/client/versions, to see if the HS is - * reachable. - * - * On failure, schedules a call back to itself. On success, resolves - * this.connectionReturnedDefer. - * - * @param connDidFail - True if a connectivity failure has been detected. Optional. - */ - private pokeKeepAlive; - private mapSyncResponseToRoomArray; - private mapSyncEventsFormat; - /** - */ - private resolveInvites; - /** - * Injects events into a room's model. - * @param stateEventList - A list of state events. This is the state - * at the *START* of the timeline list if it is supplied. - * @param timelineEventList - A list of timeline events, including threaded. Lower index - * is earlier in time. Higher index is later. - * @param fromCache - whether the sync response came from cache - */ - injectRoomEvents(room: Room, stateEventList: MatrixEvent[], timelineEventList?: MatrixEvent[], fromCache?: boolean): Promise; - /** - * Takes a list of timelineEvents and adds and adds to notifEvents - * as appropriate. - * This must be called after the room the events belong to has been stored. - * - * @param timelineEventList - A list of timeline events. Lower index - * is earlier in time. Higher index is later. - */ - private processEventsForNotifs; - private getGuestFilter; - /** - * Sets the sync state and emits an event to say so - * @param newState - The new state string - * @param data - Object of additional data to emit in the event - */ - private updateSyncState; - /** - * Event handler for the 'online' event - * This event is generally unreliable and precise behaviour - * varies between browsers, so we poll for connectivity too, - * but this might help us reconnect a little faster. - */ - private onOnline; -} -export declare function _createAndReEmitRoom(client: MatrixClient, roomId: string, opts: Partial): Room; -//# sourceMappingURL=sync.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts.map deleted file mode 100644 index f9969a5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../src/sync.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js deleted file mode 100644 index 7532031..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js +++ /dev/null @@ -1,1607 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SyncState = exports.SyncApi = void 0; -exports._createAndReEmitRoom = _createAndReEmitRoom; -exports.defaultClientOpts = defaultClientOpts; -exports.defaultSyncApiOpts = defaultSyncApiOpts; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _user = require("./models/user"); -var _room = require("./models/room"); -var utils = _interopRequireWildcard(require("./utils")); -var _filter = require("./filter"); -var _eventTimeline = require("./models/event-timeline"); -var _logger = require("./logger"); -var _errors = require("./errors"); -var _client = require("./client"); -var _httpApi = require("./http-api"); -var _event = require("./@types/event"); -var _roomState = require("./models/room-state"); -var _roomMember = require("./models/room-member"); -var _beacon = require("./models/beacon"); -var _sync = require("./@types/sync"); -var _feature = require("./feature"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -const DEBUG = true; - -// /sync requests allow you to set a timeout= but the request may continue -// beyond that and wedge forever, so we need to track how long we are willing -// to keep open the connection. This constant is *ADDED* to the timeout= value -// to determine the max time we're willing to wait. -const BUFFER_PERIOD_MS = 80 * 1000; - -// Number of consecutive failed syncs that will lead to a syncState of ERROR as opposed -// to RECONNECTING. This is needed to inform the client of server issues when the -// keepAlive is successful but the server /sync fails. -const FAILED_SYNC_ERROR_THRESHOLD = 3; -let SyncState; // Room versions where "insertion", "batch", and "marker" events are controlled -// by power-levels. MSC2716 is supported in existing room versions but they -// should only have special meaning when the room creator sends them. -exports.SyncState = SyncState; -(function (SyncState) { - SyncState["Error"] = "ERROR"; - SyncState["Prepared"] = "PREPARED"; - SyncState["Stopped"] = "STOPPED"; - SyncState["Syncing"] = "SYNCING"; - SyncState["Catchup"] = "CATCHUP"; - SyncState["Reconnecting"] = "RECONNECTING"; -})(SyncState || (exports.SyncState = SyncState = {})); -const MSC2716_ROOM_VERSIONS = ["org.matrix.msc2716v3"]; -function getFilterName(userId, suffix) { - // scope this on the user ID because people may login on many accounts - // and they all need to be stored! - return `FILTER_SYNC_${userId}` + (suffix ? "_" + suffix : ""); -} - -/* istanbul ignore next */ -function debuglog(...params) { - if (!DEBUG) return; - _logger.logger.log(...params); -} - -/** - * Options passed into the constructor of SyncApi by MatrixClient - */ -var SetPresence; -(function (SetPresence) { - SetPresence["Offline"] = "offline"; - SetPresence["Online"] = "online"; - SetPresence["Unavailable"] = "unavailable"; -})(SetPresence || (SetPresence = {})); -/** add default settings to an IStoredClientOpts */ -function defaultClientOpts(opts) { - return _objectSpread({ - initialSyncLimit: 8, - resolveInvitesToProfiles: false, - pollTimeout: 30 * 1000, - pendingEventOrdering: _client.PendingEventOrdering.Chronological, - threadSupport: false - }, opts); -} -function defaultSyncApiOpts(syncOpts) { - return _objectSpread({ - canResetEntireTimeline: _roomId => false - }, syncOpts); -} -class SyncApi { - // additional data (eg. error object for failed sync) - - // accumulator of sync events in the current sync response - // Number of consecutive failed /sync requests - // flag set if the store needs to be cleared before we can start - - /** - * Construct an entity which is able to sync with a homeserver. - * @param client - The matrix client instance to use. - * @param opts - client config options - * @param syncOpts - sync-specific options passed by the client - * @internal - */ - constructor(client, opts, syncOpts) { - this.client = client; - (0, _defineProperty2.default)(this, "opts", void 0); - (0, _defineProperty2.default)(this, "syncOpts", void 0); - (0, _defineProperty2.default)(this, "_peekRoom", null); - (0, _defineProperty2.default)(this, "currentSyncRequest", void 0); - (0, _defineProperty2.default)(this, "abortController", void 0); - (0, _defineProperty2.default)(this, "syncState", null); - (0, _defineProperty2.default)(this, "syncStateData", void 0); - (0, _defineProperty2.default)(this, "catchingUp", false); - (0, _defineProperty2.default)(this, "running", false); - (0, _defineProperty2.default)(this, "keepAliveTimer", void 0); - (0, _defineProperty2.default)(this, "connectionReturnedDefer", void 0); - (0, _defineProperty2.default)(this, "notifEvents", []); - (0, _defineProperty2.default)(this, "failedSyncCount", 0); - (0, _defineProperty2.default)(this, "storeIsInvalid", false); - (0, _defineProperty2.default)(this, "getPushRules", async () => { - try { - debuglog("Getting push rules..."); - const result = await this.client.getPushRules(); - debuglog("Got push rules"); - this.client.pushRules = result; - } catch (err) { - _logger.logger.error("Getting push rules failed", err); - if (this.shouldAbortSync(err)) return; - // wait for saved sync to complete before doing anything else, - // otherwise the sync state will end up being incorrect - debuglog("Waiting for saved sync before retrying push rules..."); - await this.recoverFromSyncStartupError(this.savedSyncPromise, err); - return this.getPushRules(); // try again - } - }); - (0, _defineProperty2.default)(this, "buildDefaultFilter", () => { - const filter = new _filter.Filter(this.client.credentials.userId); - if (this.client.canSupport.get(_feature.Feature.ThreadUnreadNotifications) !== _feature.ServerSupport.Unsupported) { - filter.setUnreadThreadNotifications(true); - } - return filter; - }); - (0, _defineProperty2.default)(this, "checkLazyLoadStatus", async () => { - debuglog("Checking lazy load status..."); - if (this.opts.lazyLoadMembers && this.client.isGuest()) { - this.opts.lazyLoadMembers = false; - } - if (this.opts.lazyLoadMembers) { - debuglog("Checking server lazy load support..."); - const supported = await this.client.doesServerSupportLazyLoading(); - if (supported) { - debuglog("Enabling lazy load on sync filter..."); - if (!this.opts.filter) { - this.opts.filter = this.buildDefaultFilter(); - } - this.opts.filter.setLazyLoadMembers(true); - } else { - debuglog("LL: lazy loading requested but not supported " + "by server, so disabling"); - this.opts.lazyLoadMembers = false; - } - } - // need to vape the store when enabling LL and wasn't enabled before - debuglog("Checking whether lazy loading has changed in store..."); - const shouldClear = await this.wasLazyLoadingToggled(this.opts.lazyLoadMembers); - if (shouldClear) { - this.storeIsInvalid = true; - const error = new _errors.InvalidStoreError(_errors.InvalidStoreState.ToggledLazyLoading, !!this.opts.lazyLoadMembers); - this.updateSyncState(SyncState.Error, { - error - }); - // bail out of the sync loop now: the app needs to respond to this error. - // we leave the state as 'ERROR' which isn't great since this normally means - // we're retrying. The client must be stopped before clearing the stores anyway - // so the app should stop the client, clear the store and start it again. - _logger.logger.warn("InvalidStoreError: store is not usable: stopping sync."); - return; - } - if (this.opts.lazyLoadMembers) { - var _this$syncOpts$crypto; - (_this$syncOpts$crypto = this.syncOpts.crypto) === null || _this$syncOpts$crypto === void 0 ? void 0 : _this$syncOpts$crypto.enableLazyLoading(); - } - try { - debuglog("Storing client options..."); - await this.client.storeClientOptions(); - debuglog("Stored client options"); - } catch (err) { - _logger.logger.error("Storing client options failed", err); - throw err; - } - }); - (0, _defineProperty2.default)(this, "getFilter", async () => { - debuglog("Getting filter..."); - let filter; - if (this.opts.filter) { - filter = this.opts.filter; - } else { - filter = this.buildDefaultFilter(); - } - let filterId; - try { - filterId = await this.client.getOrCreateFilter(getFilterName(this.client.credentials.userId), filter); - } catch (err) { - _logger.logger.error("Getting filter failed", err); - if (this.shouldAbortSync(err)) return {}; - // wait for saved sync to complete before doing anything else, - // otherwise the sync state will end up being incorrect - debuglog("Waiting for saved sync before retrying filter..."); - await this.recoverFromSyncStartupError(this.savedSyncPromise, err); - return this.getFilter(); // try again - } - - return { - filter, - filterId - }; - }); - (0, _defineProperty2.default)(this, "savedSyncPromise", void 0); - (0, _defineProperty2.default)(this, "onOnline", () => { - debuglog("Browser thinks we are back online"); - this.startKeepAlives(0); - }); - this.opts = defaultClientOpts(opts); - this.syncOpts = defaultSyncApiOpts(syncOpts); - if (client.getNotifTimelineSet()) { - client.reEmitter.reEmit(client.getNotifTimelineSet(), [_room.RoomEvent.Timeline, _room.RoomEvent.TimelineReset]); - } - } - createRoom(roomId) { - const room = _createAndReEmitRoom(this.client, roomId, this.opts); - room.on(_roomState.RoomStateEvent.Marker, (markerEvent, markerFoundOptions) => { - this.onMarkerStateEvent(room, markerEvent, markerFoundOptions); - }); - return room; - } - - /** When we see the marker state change in the room, we know there is some - * new historical messages imported by MSC2716 `/batch_send` somewhere in - * the room and we need to throw away the timeline to make sure the - * historical messages are shown when we paginate `/messages` again. - * @param room - The room where the marker event was sent - * @param markerEvent - The new marker event - * @param setStateOptions - When `timelineWasEmpty` is set - * as `true`, the given marker event will be ignored - */ - onMarkerStateEvent(room, markerEvent, { - timelineWasEmpty - } = {}) { - // We don't need to refresh the timeline if it was empty before the - // marker arrived. This could be happen in a variety of cases: - // 1. From the initial sync - // 2. If it's from the first state we're seeing after joining the room - // 3. Or whether it's coming from `syncFromCache` - if (timelineWasEmpty) { - _logger.logger.debug(`MarkerState: Ignoring markerEventId=${markerEvent.getId()} in roomId=${room.roomId} ` + `because the timeline was empty before the marker arrived which means there is nothing to refresh.`); - return; - } - const isValidMsc2716Event = - // Check whether the room version directly supports MSC2716, in - // which case, "marker" events are already auth'ed by - // power_levels - MSC2716_ROOM_VERSIONS.includes(room.getVersion()) || - // MSC2716 is also supported in all existing room versions but - // special meaning should only be given to "insertion", "batch", - // and "marker" events when they come from the room creator - markerEvent.getSender() === room.getCreator(); - - // It would be nice if we could also specifically tell whether the - // historical messages actually affected the locally cached client - // timeline or not. The problem is we can't see the prev_events of - // the base insertion event that the marker was pointing to because - // prev_events aren't available in the client API's. In most cases, - // the history won't be in people's locally cached timelines in the - // client, so we don't need to bother everyone about refreshing - // their timeline. This works for a v1 though and there are use - // cases like initially bootstrapping your bridged room where people - // are likely to encounter the historical messages affecting their - // current timeline (think someone signing up for Beeper and - // importing their Whatsapp history). - if (isValidMsc2716Event) { - // Saw new marker event, let's let the clients know they should - // refresh the timeline. - _logger.logger.debug(`MarkerState: Timeline needs to be refreshed because ` + `a new markerEventId=${markerEvent.getId()} was sent in roomId=${room.roomId}`); - room.setTimelineNeedsRefresh(true); - room.emit(_room.RoomEvent.HistoryImportedWithinTimeline, markerEvent, room); - } else { - _logger.logger.debug(`MarkerState: Ignoring markerEventId=${markerEvent.getId()} in roomId=${room.roomId} because ` + `MSC2716 is not supported in the room version or for any room version, the marker wasn't sent ` + `by the room creator.`); - } - } - - /** - * Sync rooms the user has left. - * @returns Resolved when they've been added to the store. - */ - async syncLeftRooms() { - var _data$rooms; - const client = this.client; - - // grab a filter with limit=1 and include_leave=true - const filter = new _filter.Filter(this.client.credentials.userId); - filter.setTimelineLimit(1); - filter.setIncludeLeaveRooms(true); - const localTimeoutMs = this.opts.pollTimeout + BUFFER_PERIOD_MS; - const filterId = await client.getOrCreateFilter(getFilterName(client.credentials.userId, "LEFT_ROOMS"), filter); - const qps = { - timeout: 0, - // don't want to block since this is a single isolated req - filter: filterId - }; - const data = await client.http.authedRequest(_httpApi.Method.Get, "/sync", qps, undefined, { - localTimeoutMs - }); - let leaveRooms = []; - if ((_data$rooms = data.rooms) !== null && _data$rooms !== void 0 && _data$rooms.leave) { - leaveRooms = this.mapSyncResponseToRoomArray(data.rooms.leave); - } - const rooms = await Promise.all(leaveRooms.map(async leaveObj => { - const room = leaveObj.room; - if (!leaveObj.isBrandNewRoom) { - // the intention behind syncLeftRooms is to add in rooms which were - // *omitted* from the initial /sync. Rooms the user were joined to - // but then left whilst the app is running will appear in this list - // and we do not want to bother with them since they will have the - // current state already (and may get dupe messages if we add - // yet more timeline events!), so skip them. - // NB: When we persist rooms to localStorage this will be more - // complicated... - return; - } - leaveObj.timeline = leaveObj.timeline || { - prev_batch: null, - events: [] - }; - const events = this.mapSyncEventsFormat(leaveObj.timeline, room); - const stateEvents = this.mapSyncEventsFormat(leaveObj.state, room); - - // set the back-pagination token. Do this *before* adding any - // events so that clients can start back-paginating. - room.getLiveTimeline().setPaginationToken(leaveObj.timeline.prev_batch, _eventTimeline.EventTimeline.BACKWARDS); - await this.injectRoomEvents(room, stateEvents, events); - room.recalculate(); - client.store.storeRoom(room); - client.emit(_client.ClientEvent.Room, room); - this.processEventsForNotifs(room, events); - return room; - })); - return rooms.filter(Boolean); - } - - /** - * Peek into a room. This will result in the room in question being synced so it - * is accessible via getRooms(). Live updates for the room will be provided. - * @param roomId - The room ID to peek into. - * @returns A promise which resolves once the room has been added to the - * store. - */ - peek(roomId) { - var _this$_peekRoom; - if (((_this$_peekRoom = this._peekRoom) === null || _this$_peekRoom === void 0 ? void 0 : _this$_peekRoom.roomId) === roomId) { - return Promise.resolve(this._peekRoom); - } - const client = this.client; - this._peekRoom = this.createRoom(roomId); - return this.client.roomInitialSync(roomId, 20).then(response => { - // make sure things are init'd - response.messages = response.messages || { - chunk: [] - }; - response.messages.chunk = response.messages.chunk || []; - response.state = response.state || []; - - // FIXME: Mostly duplicated from injectRoomEvents but not entirely - // because "state" in this API is at the BEGINNING of the chunk - const oldStateEvents = utils.deepCopy(response.state).map(client.getEventMapper()); - const stateEvents = response.state.map(client.getEventMapper()); - const messages = response.messages.chunk.map(client.getEventMapper()); - - // XXX: copypasted from /sync until we kill off this minging v1 API stuff) - // handle presence events (User objects) - if (Array.isArray(response.presence)) { - response.presence.map(client.getEventMapper()).forEach(function (presenceEvent) { - let user = client.store.getUser(presenceEvent.getContent().user_id); - if (user) { - user.setPresenceEvent(presenceEvent); - } else { - user = createNewUser(client, presenceEvent.getContent().user_id); - user.setPresenceEvent(presenceEvent); - client.store.storeUser(user); - } - client.emit(_client.ClientEvent.Event, presenceEvent); - }); - } - - // set the pagination token before adding the events in case people - // fire off pagination requests in response to the Room.timeline - // events. - if (response.messages.start) { - this._peekRoom.oldState.paginationToken = response.messages.start; - } - - // set the state of the room to as it was after the timeline executes - this._peekRoom.oldState.setStateEvents(oldStateEvents); - this._peekRoom.currentState.setStateEvents(stateEvents); - this.resolveInvites(this._peekRoom); - this._peekRoom.recalculate(); - - // roll backwards to diverge old state. addEventsToTimeline - // will overwrite the pagination token, so make sure it overwrites - // it with the right thing. - this._peekRoom.addEventsToTimeline(messages.reverse(), true, this._peekRoom.getLiveTimeline(), response.messages.start); - client.store.storeRoom(this._peekRoom); - client.emit(_client.ClientEvent.Room, this._peekRoom); - this.peekPoll(this._peekRoom); - return this._peekRoom; - }); - } - - /** - * Stop polling for updates in the peeked room. NOPs if there is no room being - * peeked. - */ - stopPeeking() { - this._peekRoom = null; - } - - /** - * Do a peek room poll. - * @param token - from= token - */ - peekPoll(peekRoom, token) { - var _this$abortController; - if (this._peekRoom !== peekRoom) { - debuglog("Stopped peeking in room %s", peekRoom.roomId); - return; - } - - // FIXME: gut wrenching; hard-coded timeout values - this.client.http.authedRequest(_httpApi.Method.Get, "/events", { - room_id: peekRoom.roomId, - timeout: String(30 * 1000), - from: token - }, undefined, { - localTimeoutMs: 50 * 1000, - abortSignal: (_this$abortController = this.abortController) === null || _this$abortController === void 0 ? void 0 : _this$abortController.signal - }).then(res => { - if (this._peekRoom !== peekRoom) { - debuglog("Stopped peeking in room %s", peekRoom.roomId); - return; - } - // We have a problem that we get presence both from /events and /sync - // however, /sync only returns presence for users in rooms - // you're actually joined to. - // in order to be sure to get presence for all of the users in the - // peeked room, we handle presence explicitly here. This may result - // in duplicate presence events firing for some users, which is a - // performance drain, but such is life. - // XXX: copypasted from /sync until we can kill this minging v1 stuff. - - res.chunk.filter(function (e) { - return e.type === "m.presence"; - }).map(this.client.getEventMapper()).forEach(presenceEvent => { - let user = this.client.store.getUser(presenceEvent.getContent().user_id); - if (user) { - user.setPresenceEvent(presenceEvent); - } else { - user = createNewUser(this.client, presenceEvent.getContent().user_id); - user.setPresenceEvent(presenceEvent); - this.client.store.storeUser(user); - } - this.client.emit(_client.ClientEvent.Event, presenceEvent); - }); - - // strip out events which aren't for the given room_id (e.g presence) - // and also ephemeral events (which we're assuming is anything without - // and event ID because the /events API doesn't separate them). - const events = res.chunk.filter(function (e) { - return e.room_id === peekRoom.roomId && e.event_id; - }).map(this.client.getEventMapper()); - peekRoom.addLiveEvents(events); - this.peekPoll(peekRoom, res.end); - }, err => { - _logger.logger.error("[%s] Peek poll failed: %s", peekRoom.roomId, err); - setTimeout(() => { - this.peekPoll(peekRoom, token); - }, 30 * 1000); - }); - } - - /** - * Returns the current state of this sync object - * @see MatrixClient#event:"sync" - */ - getSyncState() { - return this.syncState; - } - - /** - * Returns the additional data object associated with - * the current sync state, or null if there is no - * such data. - * Sync errors, if available, are put in the 'error' key of - * this object. - */ - getSyncStateData() { - var _this$syncStateData; - return (_this$syncStateData = this.syncStateData) !== null && _this$syncStateData !== void 0 ? _this$syncStateData : null; - } - async recoverFromSyncStartupError(savedSyncPromise, error) { - // Wait for the saved sync to complete - we send the pushrules and filter requests - // before the saved sync has finished so they can run in parallel, but only process - // the results after the saved sync is done. Equivalently, we wait for it to finish - // before reporting failures from these functions. - await savedSyncPromise; - const keepaliveProm = this.startKeepAlives(); - this.updateSyncState(SyncState.Error, { - error - }); - await keepaliveProm; - } - - /** - * Is the lazy loading option different than in previous session? - * @param lazyLoadMembers - current options for lazy loading - * @returns whether or not the option has changed compared to the previous session */ - async wasLazyLoadingToggled(lazyLoadMembers = false) { - // assume it was turned off before - // if we don't know any better - let lazyLoadMembersBefore = false; - const isStoreNewlyCreated = await this.client.store.isNewlyCreated(); - if (!isStoreNewlyCreated) { - const prevClientOptions = await this.client.store.getClientOptions(); - if (prevClientOptions) { - lazyLoadMembersBefore = !!prevClientOptions.lazyLoadMembers; - } - return lazyLoadMembersBefore !== lazyLoadMembers; - } - return false; - } - shouldAbortSync(error) { - if (error.errcode === "M_UNKNOWN_TOKEN") { - // The logout already happened, we just need to stop. - _logger.logger.warn("Token no longer valid - assuming logout"); - this.stop(); - this.updateSyncState(SyncState.Error, { - error - }); - return true; - } - return false; - } - /** - * Main entry point - */ - async sync() { - var _global$window, _global$window$addEve; - this.running = true; - this.abortController = new AbortController(); - (_global$window = global.window) === null || _global$window === void 0 ? void 0 : (_global$window$addEve = _global$window.addEventListener) === null || _global$window$addEve === void 0 ? void 0 : _global$window$addEve.call(_global$window, "online", this.onOnline, false); - if (this.client.isGuest()) { - // no push rules for guests, no access to POST filter for guests. - return this.doSync({}); - } - - // Pull the saved sync token out first, before the worker starts sending - // all the sync data which could take a while. This will let us send our - // first incremental sync request before we've processed our saved data. - debuglog("Getting saved sync token..."); - const savedSyncTokenPromise = this.client.store.getSavedSyncToken().then(tok => { - debuglog("Got saved sync token"); - return tok; - }); - this.savedSyncPromise = this.client.store.getSavedSync().then(savedSync => { - debuglog(`Got reply from saved sync, exists? ${!!savedSync}`); - if (savedSync) { - return this.syncFromCache(savedSync); - } - }).catch(err => { - _logger.logger.error("Getting saved sync failed", err); - }); - - // We need to do one-off checks before we can begin the /sync loop. - // These are: - // 1) We need to get push rules so we can check if events should bing as we get - // them from /sync. - // 2) We need to get/create a filter which we can use for /sync. - // 3) We need to check the lazy loading option matches what was used in the - // stored sync. If it doesn't, we can't use the stored sync. - - // Now start the first incremental sync request: this can also - // take a while so if we set it going now, we can wait for it - // to finish while we process our saved sync data. - await this.getPushRules(); - await this.checkLazyLoadStatus(); - const { - filterId, - filter - } = await this.getFilter(); - if (!filter) return; // bail, getFilter failed - - // reset the notifications timeline to prepare it to paginate from - // the current point in time. - // The right solution would be to tie /sync pagination tokens into - // /notifications API somehow. - this.client.resetNotifTimelineSet(); - if (!this.currentSyncRequest) { - let firstSyncFilter = filterId; - const savedSyncToken = await savedSyncTokenPromise; - if (savedSyncToken) { - debuglog("Sending first sync request..."); - } else { - debuglog("Sending initial sync request..."); - const initialFilter = this.buildDefaultFilter(); - initialFilter.setDefinition(filter.getDefinition()); - initialFilter.setTimelineLimit(this.opts.initialSyncLimit); - // Use an inline filter, no point uploading it for a single usage - firstSyncFilter = JSON.stringify(initialFilter.getDefinition()); - } - - // Send this first sync request here so we can then wait for the saved - // sync data to finish processing before we process the results of this one. - this.currentSyncRequest = this.doSyncRequest({ - filter: firstSyncFilter - }, savedSyncToken); - } - - // Now wait for the saved sync to finish... - debuglog("Waiting for saved sync before starting sync processing..."); - await this.savedSyncPromise; - // process the first sync request and continue syncing with the normal filterId - return this.doSync({ - filter: filterId - }); - } - - /** - * Stops the sync object from syncing. - */ - stop() { - var _global$window2, _global$window2$remov, _this$abortController2; - debuglog("SyncApi.stop"); - // It is necessary to check for the existance of - // global.window AND global.window.removeEventListener. - // Some platforms (e.g. React Native) register global.window, - // but do not have global.window.removeEventListener. - (_global$window2 = global.window) === null || _global$window2 === void 0 ? void 0 : (_global$window2$remov = _global$window2.removeEventListener) === null || _global$window2$remov === void 0 ? void 0 : _global$window2$remov.call(_global$window2, "online", this.onOnline, false); - this.running = false; - (_this$abortController2 = this.abortController) === null || _this$abortController2 === void 0 ? void 0 : _this$abortController2.abort(); - if (this.keepAliveTimer) { - clearTimeout(this.keepAliveTimer); - this.keepAliveTimer = undefined; - } - } - - /** - * Retry a backed off syncing request immediately. This should only be used when - * the user explicitly attempts to retry their lost connection. - * @returns True if this resulted in a request being retried. - */ - retryImmediately() { - if (!this.connectionReturnedDefer) { - return false; - } - this.startKeepAlives(0); - return true; - } - /** - * Process a single set of cached sync data. - * @param savedSync - a saved sync that was persisted by a store. This - * should have been acquired via client.store.getSavedSync(). - */ - async syncFromCache(savedSync) { - debuglog("sync(): not doing HTTP hit, instead returning stored /sync data"); - const nextSyncToken = savedSync.nextBatch; - - // Set sync token for future incremental syncing - this.client.store.setSyncToken(nextSyncToken); - - // No previous sync, set old token to null - const syncEventData = { - nextSyncToken, - catchingUp: false, - fromCache: true - }; - const data = { - next_batch: nextSyncToken, - rooms: savedSync.roomsData, - account_data: { - events: savedSync.accountData - } - }; - try { - await this.processSyncResponse(syncEventData, data); - } catch (e) { - _logger.logger.error("Error processing cached sync", e); - } - - // Don't emit a prepared if we've bailed because the store is invalid: - // in this case the client will not be usable until stopped & restarted - // so this would be useless and misleading. - if (!this.storeIsInvalid) { - this.updateSyncState(SyncState.Prepared, syncEventData); - } - } - - /** - * Invoke me to do /sync calls - */ - async doSync(syncOptions) { - while (this.running) { - const syncToken = this.client.store.getSyncToken(); - let data; - try { - if (!this.currentSyncRequest) { - this.currentSyncRequest = this.doSyncRequest(syncOptions, syncToken); - } - data = await this.currentSyncRequest; - } catch (e) { - const abort = await this.onSyncError(e); - if (abort) return; - continue; - } finally { - this.currentSyncRequest = undefined; - } - - // set the sync token NOW *before* processing the events. We do this so - // if something barfs on an event we can skip it rather than constantly - // polling with the same token. - this.client.store.setSyncToken(data.next_batch); - - // Reset after a successful sync - this.failedSyncCount = 0; - await this.client.store.setSyncData(data); - const syncEventData = { - oldSyncToken: syncToken !== null && syncToken !== void 0 ? syncToken : undefined, - nextSyncToken: data.next_batch, - catchingUp: this.catchingUp - }; - if (this.syncOpts.crypto) { - // tell the crypto module we're about to process a sync - // response - await this.syncOpts.crypto.onSyncWillProcess(syncEventData); - } - try { - await this.processSyncResponse(syncEventData, data); - } catch (e) { - // log the exception with stack if we have it, else fall back - // to the plain description - _logger.logger.error("Caught /sync error", e); - - // Emit the exception for client handling - this.client.emit(_client.ClientEvent.SyncUnexpectedError, e); - } - - // update this as it may have changed - syncEventData.catchingUp = this.catchingUp; - - // emit synced events - if (!syncOptions.hasSyncedBefore) { - this.updateSyncState(SyncState.Prepared, syncEventData); - syncOptions.hasSyncedBefore = true; - } - - // tell the crypto module to do its processing. It may block (to do a - // /keys/changes request). - if (this.syncOpts.cryptoCallbacks) { - await this.syncOpts.cryptoCallbacks.onSyncCompleted(syncEventData); - } - - // keep emitting SYNCING -> SYNCING for clients who want to do bulk updates - this.updateSyncState(SyncState.Syncing, syncEventData); - if (this.client.store.wantsSave()) { - // We always save the device list (if it's dirty) before saving the sync data: - // this means we know the saved device list data is at least as fresh as the - // stored sync data which means we don't have to worry that we may have missed - // device changes. We can also skip the delay since we're not calling this very - // frequently (and we don't really want to delay the sync for it). - if (this.syncOpts.crypto) { - await this.syncOpts.crypto.saveDeviceList(0); - } - - // tell databases that everything is now in a consistent state and can be saved. - this.client.store.save(); - } - } - if (!this.running) { - debuglog("Sync no longer running: exiting."); - if (this.connectionReturnedDefer) { - this.connectionReturnedDefer.reject(); - this.connectionReturnedDefer = undefined; - } - this.updateSyncState(SyncState.Stopped); - } - } - doSyncRequest(syncOptions, syncToken) { - var _this$abortController3; - const qps = this.getSyncParams(syncOptions, syncToken); - return this.client.http.authedRequest(_httpApi.Method.Get, "/sync", qps, undefined, { - localTimeoutMs: qps.timeout + BUFFER_PERIOD_MS, - abortSignal: (_this$abortController3 = this.abortController) === null || _this$abortController3 === void 0 ? void 0 : _this$abortController3.signal - }); - } - getSyncParams(syncOptions, syncToken) { - let timeout = this.opts.pollTimeout; - if (this.getSyncState() !== SyncState.Syncing || this.catchingUp) { - // unless we are happily syncing already, we want the server to return - // as quickly as possible, even if there are no events queued. This - // serves two purposes: - // - // * When the connection dies, we want to know asap when it comes back, - // so that we can hide the error from the user. (We don't want to - // have to wait for an event or a timeout). - // - // * We want to know if the server has any to_device messages queued up - // for us. We do that by calling it with a zero timeout until it - // doesn't give us any more to_device messages. - this.catchingUp = true; - timeout = 0; - } - let filter = syncOptions.filter; - if (this.client.isGuest() && !filter) { - filter = this.getGuestFilter(); - } - const qps = { - filter, - timeout - }; - if (this.opts.disablePresence) { - qps.set_presence = SetPresence.Offline; - } - if (syncToken) { - qps.since = syncToken; - } else { - // use a cachebuster for initialsyncs, to make sure that - // we don't get a stale sync - // (https://github.com/vector-im/vector-web/issues/1354) - qps._cacheBuster = Date.now(); - } - if ([SyncState.Reconnecting, SyncState.Error].includes(this.getSyncState())) { - // we think the connection is dead. If it comes back up, we won't know - // about it till /sync returns. If the timeout= is high, this could - // be a long time. Set it to 0 when doing retries so we don't have to wait - // for an event or a timeout before emiting the SYNCING event. - qps.timeout = 0; - } - return qps; - } - async onSyncError(err) { - if (!this.running) { - debuglog("Sync no longer running: exiting"); - if (this.connectionReturnedDefer) { - this.connectionReturnedDefer.reject(); - this.connectionReturnedDefer = undefined; - } - this.updateSyncState(SyncState.Stopped); - return true; // abort - } - - _logger.logger.error("/sync error %s", err); - if (this.shouldAbortSync(err)) { - return true; // abort - } - - this.failedSyncCount++; - _logger.logger.log("Number of consecutive failed sync requests:", this.failedSyncCount); - debuglog("Starting keep-alive"); - // Note that we do *not* mark the sync connection as - // lost yet: we only do this if a keepalive poke - // fails, since long lived HTTP connections will - // go away sometimes and we shouldn't treat this as - // erroneous. We set the state to 'reconnecting' - // instead, so that clients can observe this state - // if they wish. - const keepAlivePromise = this.startKeepAlives(); - this.currentSyncRequest = undefined; - // Transition from RECONNECTING to ERROR after a given number of failed syncs - this.updateSyncState(this.failedSyncCount >= FAILED_SYNC_ERROR_THRESHOLD ? SyncState.Error : SyncState.Reconnecting, { - error: err - }); - const connDidFail = await keepAlivePromise; - - // Only emit CATCHUP if we detected a connectivity error: if we didn't, - // it's quite likely the sync will fail again for the same reason and we - // want to stay in ERROR rather than keep flip-flopping between ERROR - // and CATCHUP. - if (connDidFail && this.getSyncState() === SyncState.Error) { - this.updateSyncState(SyncState.Catchup, { - catchingUp: true - }); - } - return false; - } - - /** - * Process data returned from a sync response and propagate it - * into the model objects - * - * @param syncEventData - Object containing sync tokens associated with this sync - * @param data - The response from /sync - */ - async processSyncResponse(syncEventData, data) { - var _data$presence, _data$account_data; - const client = this.client; - - // data looks like: - // { - // next_batch: $token, - // presence: { events: [] }, - // account_data: { events: [] }, - // device_lists: { changed: ["@user:server", ... ]}, - // to_device: { events: [] }, - // device_one_time_keys_count: { signed_curve25519: 42 }, - // rooms: { - // invite: { - // $roomid: { - // invite_state: { events: [] } - // } - // }, - // join: { - // $roomid: { - // state: { events: [] }, - // timeline: { events: [], prev_batch: $token, limited: true }, - // ephemeral: { events: [] }, - // summary: { - // m.heroes: [ $user_id ], - // m.joined_member_count: $count, - // m.invited_member_count: $count - // }, - // account_data: { events: [] }, - // unread_notifications: { - // highlight_count: 0, - // notification_count: 0, - // } - // } - // }, - // leave: { - // $roomid: { - // state: { events: [] }, - // timeline: { events: [], prev_batch: $token } - // } - // } - // } - // } - - // TODO-arch: - // - Each event we pass through needs to be emitted via 'event', can we - // do this in one place? - // - The isBrandNewRoom boilerplate is boilerplatey. - - // handle presence events (User objects) - if (Array.isArray((_data$presence = data.presence) === null || _data$presence === void 0 ? void 0 : _data$presence.events)) { - data.presence.events.filter(utils.noUnsafeEventProps).map(client.getEventMapper()).forEach(function (presenceEvent) { - let user = client.store.getUser(presenceEvent.getSender()); - if (user) { - user.setPresenceEvent(presenceEvent); - } else { - user = createNewUser(client, presenceEvent.getSender()); - user.setPresenceEvent(presenceEvent); - client.store.storeUser(user); - } - client.emit(_client.ClientEvent.Event, presenceEvent); - }); - } - - // handle non-room account_data - if (Array.isArray((_data$account_data = data.account_data) === null || _data$account_data === void 0 ? void 0 : _data$account_data.events)) { - const events = data.account_data.events.filter(utils.noUnsafeEventProps).map(client.getEventMapper()); - const prevEventsMap = events.reduce((m, c) => { - m[c.getType()] = client.store.getAccountData(c.getType()); - return m; - }, {}); - client.store.storeAccountDataEvents(events); - events.forEach(function (accountDataEvent) { - // Honour push rules that come down the sync stream but also - // honour push rules that were previously cached. Base rules - // will be updated when we receive push rules via getPushRules - // (see sync) before syncing over the network. - if (accountDataEvent.getType() === _event.EventType.PushRules) { - const rules = accountDataEvent.getContent(); - client.setPushRules(rules); - } - const prevEvent = prevEventsMap[accountDataEvent.getType()]; - client.emit(_client.ClientEvent.AccountData, accountDataEvent, prevEvent); - return accountDataEvent; - }); - } - - // handle to-device events - if (data.to_device && Array.isArray(data.to_device.events) && data.to_device.events.length > 0) { - let toDeviceMessages = data.to_device.events.filter(utils.noUnsafeEventProps); - if (this.syncOpts.cryptoCallbacks) { - toDeviceMessages = await this.syncOpts.cryptoCallbacks.preprocessToDeviceMessages(toDeviceMessages); - } - const cancelledKeyVerificationTxns = []; - toDeviceMessages.map(client.getEventMapper({ - toDevice: true - })).map(toDeviceEvent => { - // map is a cheap inline forEach - // We want to flag m.key.verification.start events as cancelled - // if there's an accompanying m.key.verification.cancel event, so - // we pull out the transaction IDs from the cancellation events - // so we can flag the verification events as cancelled in the loop - // below. - if (toDeviceEvent.getType() === "m.key.verification.cancel") { - const txnId = toDeviceEvent.getContent()["transaction_id"]; - if (txnId) { - cancelledKeyVerificationTxns.push(txnId); - } - } - - // as mentioned above, .map is a cheap inline forEach, so return - // the unmodified event. - return toDeviceEvent; - }).forEach(function (toDeviceEvent) { - const content = toDeviceEvent.getContent(); - if (toDeviceEvent.getType() == "m.room.message" && content.msgtype == "m.bad.encrypted") { - // the mapper already logged a warning. - _logger.logger.log("Ignoring undecryptable to-device event from " + toDeviceEvent.getSender()); - return; - } - if (toDeviceEvent.getType() === "m.key.verification.start" || toDeviceEvent.getType() === "m.key.verification.request") { - const txnId = content["transaction_id"]; - if (cancelledKeyVerificationTxns.includes(txnId)) { - toDeviceEvent.flagCancelled(); - } - } - client.emit(_client.ClientEvent.ToDeviceEvent, toDeviceEvent); - }); - } else { - // no more to-device events: we can stop polling with a short timeout. - this.catchingUp = false; - } - - // the returned json structure is a bit crap, so make it into a - // nicer form (array) after applying sanity to make sure we don't fail - // on missing keys (on the off chance) - let inviteRooms = []; - let joinRooms = []; - let leaveRooms = []; - if (data.rooms) { - if (data.rooms.invite) { - inviteRooms = this.mapSyncResponseToRoomArray(data.rooms.invite); - } - if (data.rooms.join) { - joinRooms = this.mapSyncResponseToRoomArray(data.rooms.join); - } - if (data.rooms.leave) { - leaveRooms = this.mapSyncResponseToRoomArray(data.rooms.leave); - } - } - this.notifEvents = []; - - // Handle invites - await utils.promiseMapSeries(inviteRooms, async inviteObj => { - var _room$currentState$ge; - const room = inviteObj.room; - const stateEvents = this.mapSyncEventsFormat(inviteObj.invite_state, room); - await this.injectRoomEvents(room, stateEvents); - const inviter = (_room$currentState$ge = room.currentState.getStateEvents(_event.EventType.RoomMember, client.getUserId())) === null || _room$currentState$ge === void 0 ? void 0 : _room$currentState$ge.getSender(); - const crypto = client.crypto; - if (crypto) { - const parkedHistory = await crypto.cryptoStore.takeParkedSharedHistory(room.roomId); - for (const parked of parkedHistory) { - if (parked.senderId === inviter) { - await crypto.olmDevice.addInboundGroupSession(room.roomId, parked.senderKey, parked.forwardingCurve25519KeyChain, parked.sessionId, parked.sessionKey, parked.keysClaimed, true, { - sharedHistory: true, - untrusted: true - }); - } - } - } - if (inviteObj.isBrandNewRoom) { - room.recalculate(); - client.store.storeRoom(room); - client.emit(_client.ClientEvent.Room, room); - } else { - // Update room state for invite->reject->invite cycles - room.recalculate(); - } - stateEvents.forEach(function (e) { - client.emit(_client.ClientEvent.Event, e); - }); - }); - - // Handle joins - await utils.promiseMapSeries(joinRooms, async joinObj => { - var _joinObj$UNREAD_THREA; - const room = joinObj.room; - const stateEvents = this.mapSyncEventsFormat(joinObj.state, room); - // Prevent events from being decrypted ahead of time - // this helps large account to speed up faster - // room::decryptCriticalEvent is in charge of decrypting all the events - // required for a client to function properly - const events = this.mapSyncEventsFormat(joinObj.timeline, room, false); - const ephemeralEvents = this.mapSyncEventsFormat(joinObj.ephemeral); - const accountDataEvents = this.mapSyncEventsFormat(joinObj.account_data); - const encrypted = client.isRoomEncrypted(room.roomId); - // We store the server-provided value first so it's correct when any of the events fire. - if (joinObj.unread_notifications) { - /** - * We track unread notifications ourselves in encrypted rooms, so don't - * bother setting it here. We trust our calculations better than the - * server's for this case, and therefore will assume that our non-zero - * count is accurate. - * - * @see import("./client").fixNotificationCountOnDecryption - */ - if (!encrypted || joinObj.unread_notifications.notification_count === 0) { - var _joinObj$unread_notif; - // In an encrypted room, if the room has notifications enabled then it's typical for - // the server to flag all new messages as notifying. However, some push rules calculate - // events as ignored based on their event contents (e.g. ignoring msgtype=m.notice messages) - // so we want to calculate this figure on the client in all cases. - room.setUnreadNotificationCount(_room.NotificationCountType.Total, (_joinObj$unread_notif = joinObj.unread_notifications.notification_count) !== null && _joinObj$unread_notif !== void 0 ? _joinObj$unread_notif : 0); - } - if (!encrypted || room.getUnreadNotificationCount(_room.NotificationCountType.Highlight) <= 0) { - var _joinObj$unread_notif2; - // If the locally stored highlight count is zero, use the server provided value. - room.setUnreadNotificationCount(_room.NotificationCountType.Highlight, (_joinObj$unread_notif2 = joinObj.unread_notifications.highlight_count) !== null && _joinObj$unread_notif2 !== void 0 ? _joinObj$unread_notif2 : 0); - } - } - const unreadThreadNotifications = (_joinObj$UNREAD_THREA = joinObj[_sync.UNREAD_THREAD_NOTIFICATIONS.name]) !== null && _joinObj$UNREAD_THREA !== void 0 ? _joinObj$UNREAD_THREA : joinObj[_sync.UNREAD_THREAD_NOTIFICATIONS.altName]; - if (unreadThreadNotifications) { - // Only partially reset unread notification - // We want to keep the client-generated count. Particularly important - // for encrypted room that refresh their notification count on event - // decryption - room.resetThreadUnreadNotificationCount(Object.keys(unreadThreadNotifications)); - for (const [threadId, unreadNotification] of Object.entries(unreadThreadNotifications)) { - if (!encrypted || unreadNotification.notification_count === 0) { - var _unreadNotification$n; - room.setThreadUnreadNotificationCount(threadId, _room.NotificationCountType.Total, (_unreadNotification$n = unreadNotification.notification_count) !== null && _unreadNotification$n !== void 0 ? _unreadNotification$n : 0); - } - const hasNoNotifications = room.getThreadUnreadNotificationCount(threadId, _room.NotificationCountType.Highlight) <= 0; - if (!encrypted || encrypted && hasNoNotifications) { - var _unreadNotification$h; - room.setThreadUnreadNotificationCount(threadId, _room.NotificationCountType.Highlight, (_unreadNotification$h = unreadNotification.highlight_count) !== null && _unreadNotification$h !== void 0 ? _unreadNotification$h : 0); - } - } - } else { - room.resetThreadUnreadNotificationCount(); - } - joinObj.timeline = joinObj.timeline || {}; - if (joinObj.isBrandNewRoom) { - // set the back-pagination token. Do this *before* adding any - // events so that clients can start back-paginating. - if (joinObj.timeline.prev_batch !== null) { - room.getLiveTimeline().setPaginationToken(joinObj.timeline.prev_batch, _eventTimeline.EventTimeline.BACKWARDS); - } - } else if (joinObj.timeline.limited) { - let limited = true; - - // we've got a limited sync, so we *probably* have a gap in the - // timeline, so should reset. But we might have been peeking or - // paginating and already have some of the events, in which - // case we just want to append any subsequent events to the end - // of the existing timeline. - // - // This is particularly important in the case that we already have - // *all* of the events in the timeline - in that case, if we reset - // the timeline, we'll end up with an entirely empty timeline, - // which we'll try to paginate but not get any new events (which - // will stop us linking the empty timeline into the chain). - // - for (let i = events.length - 1; i >= 0; i--) { - const eventId = events[i].getId(); - if (room.getTimelineForEvent(eventId)) { - debuglog(`Already have event ${eventId} in limited sync - not resetting`); - limited = false; - - // we might still be missing some of the events before i; - // we don't want to be adding them to the end of the - // timeline because that would put them out of order. - events.splice(0, i); - - // XXX: there's a problem here if the skipped part of the - // timeline modifies the state set in stateEvents, because - // we'll end up using the state from stateEvents rather - // than the later state from timelineEvents. We probably - // need to wind stateEvents forward over the events we're - // skipping. - - break; - } - } - if (limited) { - var _syncEventData$oldSyn; - room.resetLiveTimeline(joinObj.timeline.prev_batch, this.syncOpts.canResetEntireTimeline(room.roomId) ? null : (_syncEventData$oldSyn = syncEventData.oldSyncToken) !== null && _syncEventData$oldSyn !== void 0 ? _syncEventData$oldSyn : null); - - // We have to assume any gap in any timeline is - // reason to stop incrementally tracking notifications and - // reset the timeline. - client.resetNotifTimelineSet(); - } - } - - // process any crypto events *before* emitting the RoomStateEvent events. This - // avoids a race condition if the application tries to send a message after the - // state event is processed, but before crypto is enabled, which then causes the - // crypto layer to complain. - if (this.syncOpts.cryptoCallbacks) { - for (const e of stateEvents.concat(events)) { - if (e.isState() && e.getType() === _event.EventType.RoomEncryption && e.getStateKey() === "") { - await this.syncOpts.cryptoCallbacks.onCryptoEvent(room, e); - } - } - } - try { - await this.injectRoomEvents(room, stateEvents, events, syncEventData.fromCache); - } catch (e) { - _logger.logger.error(`Failed to process events on room ${room.roomId}:`, e); - } - - // set summary after processing events, - // because it will trigger a name calculation - // which needs the room state to be up to date - if (joinObj.summary) { - room.setSummary(joinObj.summary); - } - - // we deliberately don't add ephemeral events to the timeline - room.addEphemeralEvents(ephemeralEvents); - - // we deliberately don't add accountData to the timeline - room.addAccountData(accountDataEvents); - room.recalculate(); - if (joinObj.isBrandNewRoom) { - client.store.storeRoom(room); - client.emit(_client.ClientEvent.Room, room); - } - this.processEventsForNotifs(room, events); - const emitEvent = e => client.emit(_client.ClientEvent.Event, e); - stateEvents.forEach(emitEvent); - events.forEach(emitEvent); - ephemeralEvents.forEach(emitEvent); - accountDataEvents.forEach(emitEvent); - - // Decrypt only the last message in all rooms to make sure we can generate a preview - // And decrypt all events after the recorded read receipt to ensure an accurate - // notification count - room.decryptCriticalEvents(); - }); - - // Handle leaves (e.g. kicked rooms) - await utils.promiseMapSeries(leaveRooms, async leaveObj => { - const room = leaveObj.room; - const stateEvents = this.mapSyncEventsFormat(leaveObj.state, room); - const events = this.mapSyncEventsFormat(leaveObj.timeline, room); - const accountDataEvents = this.mapSyncEventsFormat(leaveObj.account_data); - await this.injectRoomEvents(room, stateEvents, events); - room.addAccountData(accountDataEvents); - room.recalculate(); - if (leaveObj.isBrandNewRoom) { - client.store.storeRoom(room); - client.emit(_client.ClientEvent.Room, room); - } - this.processEventsForNotifs(room, events); - stateEvents.forEach(function (e) { - client.emit(_client.ClientEvent.Event, e); - }); - events.forEach(function (e) { - client.emit(_client.ClientEvent.Event, e); - }); - accountDataEvents.forEach(function (e) { - client.emit(_client.ClientEvent.Event, e); - }); - }); - - // update the notification timeline, if appropriate. - // we only do this for live events, as otherwise we can't order them sanely - // in the timeline relative to ones paginated in by /notifications. - // XXX: we could fix this by making EventTimeline support chronological - // ordering... but it doesn't, right now. - if (syncEventData.oldSyncToken && this.notifEvents.length) { - this.notifEvents.sort(function (a, b) { - return a.getTs() - b.getTs(); - }); - this.notifEvents.forEach(function (event) { - var _client$getNotifTimel; - (_client$getNotifTimel = client.getNotifTimelineSet()) === null || _client$getNotifTimel === void 0 ? void 0 : _client$getNotifTimel.addLiveEvent(event); - }); - } - - // Handle device list updates - if (data.device_lists) { - if (this.syncOpts.crypto) { - await this.syncOpts.crypto.handleDeviceListChanges(syncEventData, data.device_lists); - } else { - // FIXME if we *don't* have a crypto module, we still need to - // invalidate the device lists. But that would require a - // substantial bit of rework :/. - } - } - - // Handle one_time_keys_count - if (data.device_one_time_keys_count) { - var _this$syncOpts$crypto2; - const map = new Map(Object.entries(data.device_one_time_keys_count)); - (_this$syncOpts$crypto2 = this.syncOpts.cryptoCallbacks) === null || _this$syncOpts$crypto2 === void 0 ? void 0 : _this$syncOpts$crypto2.preprocessOneTimeKeyCounts(map); - } - if (data.device_unused_fallback_key_types || data["org.matrix.msc2732.device_unused_fallback_key_types"]) { - var _this$syncOpts$crypto3; - // The presence of device_unused_fallback_key_types indicates that the - // server supports fallback keys. If there's no unused - // signed_curve25519 fallback key we need a new one. - const unusedFallbackKeys = data.device_unused_fallback_key_types || data["org.matrix.msc2732.device_unused_fallback_key_types"]; - (_this$syncOpts$crypto3 = this.syncOpts.cryptoCallbacks) === null || _this$syncOpts$crypto3 === void 0 ? void 0 : _this$syncOpts$crypto3.preprocessUnusedFallbackKeys(new Set(unusedFallbackKeys || null)); - } - } - - /** - * Starts polling the connectivity check endpoint - * @param delay - How long to delay until the first poll. - * defaults to a short, randomised interval (to prevent - * tight-looping if /versions succeeds but /sync etc. fail). - * @returns which resolves once the connection returns - */ - startKeepAlives(delay) { - if (delay === undefined) { - delay = 2000 + Math.floor(Math.random() * 5000); - } - if (this.keepAliveTimer !== null) { - clearTimeout(this.keepAliveTimer); - } - if (delay > 0) { - this.keepAliveTimer = setTimeout(this.pokeKeepAlive.bind(this), delay); - } else { - this.pokeKeepAlive(); - } - if (!this.connectionReturnedDefer) { - this.connectionReturnedDefer = utils.defer(); - } - return this.connectionReturnedDefer.promise; - } - - /** - * Make a dummy call to /_matrix/client/versions, to see if the HS is - * reachable. - * - * On failure, schedules a call back to itself. On success, resolves - * this.connectionReturnedDefer. - * - * @param connDidFail - True if a connectivity failure has been detected. Optional. - */ - pokeKeepAlive(connDidFail = false) { - var _this$abortController4; - const success = () => { - clearTimeout(this.keepAliveTimer); - if (this.connectionReturnedDefer) { - this.connectionReturnedDefer.resolve(connDidFail); - this.connectionReturnedDefer = undefined; - } - }; - this.client.http.request(_httpApi.Method.Get, "/_matrix/client/versions", undefined, - // queryParams - undefined, - // data - { - prefix: "", - localTimeoutMs: 15 * 1000, - abortSignal: (_this$abortController4 = this.abortController) === null || _this$abortController4 === void 0 ? void 0 : _this$abortController4.signal - }).then(() => { - success(); - }, err => { - if (err.httpStatus == 400 || err.httpStatus == 404) { - // treat this as a success because the server probably just doesn't - // support /versions: point is, we're getting a response. - // We wait a short time though, just in case somehow the server - // is in a mode where it 400s /versions responses and sync etc. - // responses fail, this will mean we don't hammer in a loop. - this.keepAliveTimer = setTimeout(success, 2000); - } else { - connDidFail = true; - this.keepAliveTimer = setTimeout(this.pokeKeepAlive.bind(this, connDidFail), 5000 + Math.floor(Math.random() * 5000)); - // A keepalive has failed, so we emit the - // error state (whether or not this is the - // first failure). - // Note we do this after setting the timer: - // this lets the unit tests advance the mock - // clock when they get the error. - this.updateSyncState(SyncState.Error, { - error: err - }); - } - }); - } - mapSyncResponseToRoomArray(obj) { - // Maps { roomid: {stuff}, roomid: {stuff} } - // to - // [{stuff+Room+isBrandNewRoom}, {stuff+Room+isBrandNewRoom}] - const client = this.client; - return Object.keys(obj).filter(k => !(0, utils.unsafeProp)(k)).map(roomId => { - const arrObj = obj[roomId]; - let room = client.store.getRoom(roomId); - let isBrandNewRoom = false; - if (!room) { - room = this.createRoom(roomId); - isBrandNewRoom = true; - } - arrObj.room = room; - arrObj.isBrandNewRoom = isBrandNewRoom; - return arrObj; - }); - } - mapSyncEventsFormat(obj, room, decrypt = true) { - if (!obj || !Array.isArray(obj.events)) { - return []; - } - const mapper = this.client.getEventMapper({ - decrypt - }); - return obj.events.filter(utils.noUnsafeEventProps).map(function (e) { - if (room) { - e.room_id = room.roomId; - } - return mapper(e); - }); - } - - /** - */ - resolveInvites(room) { - if (!room || !this.opts.resolveInvitesToProfiles) { - return; - } - const client = this.client; - // For each invited room member we want to give them a displayname/avatar url - // if they have one (the m.room.member invites don't contain this). - room.getMembersWithMembership("invite").forEach(function (member) { - if (member.requestedProfileInfo) return; - member.requestedProfileInfo = true; - // try to get a cached copy first. - const user = client.getUser(member.userId); - let promise; - if (user) { - promise = Promise.resolve({ - avatar_url: user.avatarUrl, - displayname: user.displayName - }); - } else { - promise = client.getProfileInfo(member.userId); - } - promise.then(function (info) { - // slightly naughty by doctoring the invite event but this means all - // the code paths remain the same between invite/join display name stuff - // which is a worthy trade-off for some minor pollution. - const inviteEvent = member.events.member; - if ((inviteEvent === null || inviteEvent === void 0 ? void 0 : inviteEvent.getContent().membership) !== "invite") { - // between resolving and now they have since joined, so don't clobber - return; - } - inviteEvent.getContent().avatar_url = info.avatar_url; - inviteEvent.getContent().displayname = info.displayname; - // fire listeners - member.setMembershipEvent(inviteEvent, room.currentState); - }, function (err) { - // OH WELL. - }); - }); - } - - /** - * Injects events into a room's model. - * @param stateEventList - A list of state events. This is the state - * at the *START* of the timeline list if it is supplied. - * @param timelineEventList - A list of timeline events, including threaded. Lower index - * is earlier in time. Higher index is later. - * @param fromCache - whether the sync response came from cache - */ - async injectRoomEvents(room, stateEventList, timelineEventList, fromCache = false) { - // If there are no events in the timeline yet, initialise it with - // the given state events - const liveTimeline = room.getLiveTimeline(); - const timelineWasEmpty = liveTimeline.getEvents().length == 0; - if (timelineWasEmpty) { - // Passing these events into initialiseState will freeze them, so we need - // to compute and cache the push actions for them now, otherwise sync dies - // with an attempt to assign to read only property. - // XXX: This is pretty horrible and is assuming all sorts of behaviour from - // these functions that it shouldn't be. We should probably either store the - // push actions cache elsewhere so we can freeze MatrixEvents, or otherwise - // find some solution where MatrixEvents are immutable but allow for a cache - // field. - for (const ev of stateEventList) { - this.client.getPushActionsForEvent(ev); - } - liveTimeline.initialiseState(stateEventList, { - timelineWasEmpty - }); - } - this.resolveInvites(room); - - // recalculate the room name at this point as adding events to the timeline - // may make notifications appear which should have the right name. - // XXX: This looks suspect: we'll end up recalculating the room once here - // and then again after adding events (processSyncResponse calls it after - // calling us) even if no state events were added. It also means that if - // one of the room events in timelineEventList is something that needs - // a recalculation (like m.room.name) we won't recalculate until we've - // finished adding all the events, which will cause the notification to have - // the old room name rather than the new one. - room.recalculate(); - - // If the timeline wasn't empty, we process the state events here: they're - // defined as updates to the state before the start of the timeline, so this - // starts to roll the state forward. - // XXX: That's what we *should* do, but this can happen if we were previously - // peeking in a room, in which case we obviously do *not* want to add the - // state events here onto the end of the timeline. Historically, the js-sdk - // has just set these new state events on the old and new state. This seems - // very wrong because there could be events in the timeline that diverge the - // state, in which case this is going to leave things out of sync. However, - // for now I think it;s best to behave the same as the code has done previously. - if (!timelineWasEmpty) { - // XXX: As above, don't do this... - //room.addLiveEvents(stateEventList || []); - // Do this instead... - room.oldState.setStateEvents(stateEventList || []); - room.currentState.setStateEvents(stateEventList || []); - } - - // Execute the timeline events. This will continue to diverge the current state - // if the timeline has any state events in it. - // This also needs to be done before running push rules on the events as they need - // to be decorated with sender etc. - room.addLiveEvents(timelineEventList || [], { - fromCache, - timelineWasEmpty - }); - this.client.processBeaconEvents(room, timelineEventList); - } - - /** - * Takes a list of timelineEvents and adds and adds to notifEvents - * as appropriate. - * This must be called after the room the events belong to has been stored. - * - * @param timelineEventList - A list of timeline events. Lower index - * is earlier in time. Higher index is later. - */ - processEventsForNotifs(room, timelineEventList) { - // gather our notifications into this.notifEvents - if (this.client.getNotifTimelineSet()) { - for (const event of timelineEventList) { - var _pushActions$tweaks; - const pushActions = this.client.getPushActionsForEvent(event); - if (pushActions !== null && pushActions !== void 0 && pushActions.notify && (_pushActions$tweaks = pushActions.tweaks) !== null && _pushActions$tweaks !== void 0 && _pushActions$tweaks.highlight) { - this.notifEvents.push(event); - } - } - } - } - getGuestFilter() { - // Dev note: This used to be conditional to return a filter of 20 events maximum, but - // the condition never went to the other branch. This is now hardcoded. - return "{}"; - } - - /** - * Sets the sync state and emits an event to say so - * @param newState - The new state string - * @param data - Object of additional data to emit in the event - */ - updateSyncState(newState, data) { - const old = this.syncState; - this.syncState = newState; - this.syncStateData = data; - this.client.emit(_client.ClientEvent.Sync, this.syncState, old, data); - } - - /** - * Event handler for the 'online' event - * This event is generally unreliable and precise behaviour - * varies between browsers, so we poll for connectivity too, - * but this might help us reconnect a little faster. - */ -} -exports.SyncApi = SyncApi; -function createNewUser(client, userId) { - const user = new _user.User(userId); - client.reEmitter.reEmit(user, [_user.UserEvent.AvatarUrl, _user.UserEvent.DisplayName, _user.UserEvent.Presence, _user.UserEvent.CurrentlyActive, _user.UserEvent.LastPresenceTs]); - return user; -} - -// /!\ This function is not intended for public use! It's only exported from -// here in order to share some common logic with sliding-sync-sdk.ts. -function _createAndReEmitRoom(client, roomId, opts) { - const { - timelineSupport - } = client; - const room = new _room.Room(roomId, client, client.getUserId(), { - lazyLoadMembers: opts.lazyLoadMembers, - pendingEventOrdering: opts.pendingEventOrdering, - timelineSupport - }); - client.reEmitter.reEmit(room, [_room.RoomEvent.Name, _room.RoomEvent.Redaction, _room.RoomEvent.RedactionCancelled, _room.RoomEvent.Receipt, _room.RoomEvent.Tags, _room.RoomEvent.LocalEchoUpdated, _room.RoomEvent.AccountData, _room.RoomEvent.MyMembership, _room.RoomEvent.Timeline, _room.RoomEvent.TimelineReset, _roomState.RoomStateEvent.Events, _roomState.RoomStateEvent.Members, _roomState.RoomStateEvent.NewMember, _roomState.RoomStateEvent.Update, _beacon.BeaconEvent.New, _beacon.BeaconEvent.Update, _beacon.BeaconEvent.Destroy, _beacon.BeaconEvent.LivenessChange]); - - // We need to add a listener for RoomState.members in order to hook them - // correctly. - room.on(_roomState.RoomStateEvent.NewMember, (event, state, member) => { - var _client$getUser; - member.user = (_client$getUser = client.getUser(member.userId)) !== null && _client$getUser !== void 0 ? _client$getUser : undefined; - client.reEmitter.reEmit(member, [_roomMember.RoomMemberEvent.Name, _roomMember.RoomMemberEvent.Typing, _roomMember.RoomMemberEvent.PowerLevel, _roomMember.RoomMemberEvent.Membership]); - }); - return room; -} -//# sourceMappingURL=sync.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js.map deleted file mode 100644 index 62c996e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/sync.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sync.js","names":["_user","require","_room","utils","_interopRequireWildcard","_filter","_eventTimeline","_logger","_errors","_client","_httpApi","_event","_roomState","_roomMember","_beacon","_sync","_feature","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","DEBUG","BUFFER_PERIOD_MS","FAILED_SYNC_ERROR_THRESHOLD","SyncState","exports","MSC2716_ROOM_VERSIONS","getFilterName","userId","suffix","debuglog","params","logger","log","SetPresence","defaultClientOpts","opts","initialSyncLimit","resolveInvitesToProfiles","pollTimeout","pendingEventOrdering","PendingEventOrdering","Chronological","threadSupport","defaultSyncApiOpts","syncOpts","canResetEntireTimeline","_roomId","SyncApi","constructor","client","result","getPushRules","pushRules","err","error","shouldAbortSync","recoverFromSyncStartupError","savedSyncPromise","Filter","credentials","canSupport","Feature","ThreadUnreadNotifications","ServerSupport","Unsupported","setUnreadThreadNotifications","lazyLoadMembers","isGuest","supported","doesServerSupportLazyLoading","buildDefaultFilter","setLazyLoadMembers","shouldClear","wasLazyLoadingToggled","storeIsInvalid","InvalidStoreError","InvalidStoreState","ToggledLazyLoading","updateSyncState","Error","warn","_this$syncOpts$crypto","crypto","enableLazyLoading","storeClientOptions","filterId","getOrCreateFilter","getFilter","startKeepAlives","getNotifTimelineSet","reEmitter","reEmit","RoomEvent","Timeline","TimelineReset","createRoom","roomId","room","_createAndReEmitRoom","on","RoomStateEvent","Marker","markerEvent","markerFoundOptions","onMarkerStateEvent","timelineWasEmpty","debug","getId","isValidMsc2716Event","includes","getVersion","getSender","getCreator","setTimelineNeedsRefresh","emit","HistoryImportedWithinTimeline","syncLeftRooms","_data$rooms","setTimelineLimit","setIncludeLeaveRooms","localTimeoutMs","qps","timeout","data","http","authedRequest","Method","Get","undefined","leaveRooms","rooms","leave","mapSyncResponseToRoomArray","Promise","all","map","leaveObj","isBrandNewRoom","timeline","prev_batch","events","mapSyncEventsFormat","stateEvents","state","getLiveTimeline","setPaginationToken","EventTimeline","BACKWARDS","injectRoomEvents","recalculate","store","storeRoom","ClientEvent","Room","processEventsForNotifs","Boolean","peek","_this$_peekRoom","_peekRoom","resolve","roomInitialSync","then","response","messages","chunk","oldStateEvents","deepCopy","getEventMapper","Array","isArray","presence","presenceEvent","user","getUser","getContent","user_id","setPresenceEvent","createNewUser","storeUser","Event","start","oldState","paginationToken","setStateEvents","currentState","resolveInvites","addEventsToTimeline","reverse","peekPoll","stopPeeking","peekRoom","token","_this$abortController","room_id","String","from","abortSignal","abortController","signal","res","e","type","event_id","addLiveEvents","end","setTimeout","getSyncState","syncState","getSyncStateData","_this$syncStateData","syncStateData","keepaliveProm","lazyLoadMembersBefore","isStoreNewlyCreated","isNewlyCreated","prevClientOptions","getClientOptions","errcode","stop","sync","_global$window","_global$window$addEve","running","AbortController","global","window","addEventListener","onOnline","doSync","savedSyncTokenPromise","getSavedSyncToken","tok","getSavedSync","savedSync","syncFromCache","catch","checkLazyLoadStatus","resetNotifTimelineSet","currentSyncRequest","firstSyncFilter","savedSyncToken","initialFilter","setDefinition","getDefinition","JSON","stringify","doSyncRequest","_global$window2","_global$window2$remov","_this$abortController2","removeEventListener","abort","keepAliveTimer","clearTimeout","retryImmediately","connectionReturnedDefer","nextSyncToken","nextBatch","setSyncToken","syncEventData","catchingUp","fromCache","next_batch","roomsData","account_data","accountData","processSyncResponse","Prepared","syncOptions","syncToken","getSyncToken","onSyncError","failedSyncCount","setSyncData","oldSyncToken","onSyncWillProcess","SyncUnexpectedError","hasSyncedBefore","cryptoCallbacks","onSyncCompleted","Syncing","wantsSave","saveDeviceList","save","reject","Stopped","_this$abortController3","getSyncParams","getGuestFilter","disablePresence","set_presence","Offline","since","_cacheBuster","Date","now","Reconnecting","keepAlivePromise","connDidFail","Catchup","_data$presence","_data$account_data","noUnsafeEventProps","prevEventsMap","reduce","m","c","getType","getAccountData","storeAccountDataEvents","accountDataEvent","EventType","PushRules","rules","setPushRules","prevEvent","AccountData","to_device","toDeviceMessages","preprocessToDeviceMessages","cancelledKeyVerificationTxns","toDevice","toDeviceEvent","txnId","content","msgtype","flagCancelled","ToDeviceEvent","inviteRooms","joinRooms","invite","join","notifEvents","promiseMapSeries","inviteObj","_room$currentState$ge","invite_state","inviter","getStateEvents","RoomMember","getUserId","parkedHistory","cryptoStore","takeParkedSharedHistory","parked","senderId","olmDevice","addInboundGroupSession","senderKey","forwardingCurve25519KeyChain","sessionId","sessionKey","keysClaimed","sharedHistory","untrusted","joinObj","_joinObj$UNREAD_THREA","ephemeralEvents","ephemeral","accountDataEvents","encrypted","isRoomEncrypted","unread_notifications","notification_count","_joinObj$unread_notif","setUnreadNotificationCount","NotificationCountType","Total","getUnreadNotificationCount","Highlight","_joinObj$unread_notif2","highlight_count","unreadThreadNotifications","UNREAD_THREAD_NOTIFICATIONS","name","altName","resetThreadUnreadNotificationCount","threadId","unreadNotification","entries","_unreadNotification$n","setThreadUnreadNotificationCount","hasNoNotifications","getThreadUnreadNotificationCount","_unreadNotification$h","limited","eventId","getTimelineForEvent","splice","_syncEventData$oldSyn","resetLiveTimeline","concat","isState","RoomEncryption","getStateKey","onCryptoEvent","summary","setSummary","addEphemeralEvents","addAccountData","emitEvent","decryptCriticalEvents","sort","a","b","getTs","event","_client$getNotifTimel","addLiveEvent","device_lists","handleDeviceListChanges","device_one_time_keys_count","_this$syncOpts$crypto2","Map","preprocessOneTimeKeyCounts","device_unused_fallback_key_types","_this$syncOpts$crypto3","unusedFallbackKeys","preprocessUnusedFallbackKeys","Set","delay","Math","floor","random","pokeKeepAlive","bind","defer","promise","_this$abortController4","success","request","prefix","httpStatus","k","unsafeProp","arrObj","getRoom","decrypt","mapper","getMembersWithMembership","member","requestedProfileInfo","avatar_url","avatarUrl","displayname","displayName","getProfileInfo","info","inviteEvent","membership","setMembershipEvent","stateEventList","timelineEventList","liveTimeline","getEvents","ev","getPushActionsForEvent","initialiseState","processBeaconEvents","_pushActions$tweaks","pushActions","notify","tweaks","highlight","newState","old","Sync","User","UserEvent","AvatarUrl","DisplayName","Presence","CurrentlyActive","LastPresenceTs","timelineSupport","Name","Redaction","RedactionCancelled","Receipt","Tags","LocalEchoUpdated","MyMembership","Events","Members","NewMember","Update","BeaconEvent","New","Destroy","LivenessChange","_client$getUser","RoomMemberEvent","Typing","PowerLevel","Membership"],"sources":["../src/sync.ts"],"sourcesContent":["/*\nCopyright 2015 - 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/*\n * TODO:\n * This class mainly serves to take all the syncing logic out of client.js and\n * into a separate file. It's all very fluid, and this class gut wrenches a lot\n * of MatrixClient props (e.g. http). Given we want to support WebSockets as\n * an alternative syncing API, we may want to have a proper syncing interface\n * for HTTP and WS at some point.\n */\n\nimport { Optional } from \"matrix-events-sdk\";\n\nimport type { SyncCryptoCallbacks } from \"./common-crypto/CryptoBackend\";\nimport { User, UserEvent } from \"./models/user\";\nimport { NotificationCountType, Room, RoomEvent } from \"./models/room\";\nimport * as utils from \"./utils\";\nimport { IDeferred, noUnsafeEventProps, unsafeProp } from \"./utils\";\nimport { Filter } from \"./filter\";\nimport { EventTimeline } from \"./models/event-timeline\";\nimport { logger } from \"./logger\";\nimport { InvalidStoreError, InvalidStoreState } from \"./errors\";\nimport { ClientEvent, IStoredClientOpts, MatrixClient, PendingEventOrdering, ResetTimelineCallback } from \"./client\";\nimport {\n IEphemeral,\n IInvitedRoom,\n IInviteState,\n IJoinedRoom,\n ILeftRoom,\n IMinimalEvent,\n IRoomEvent,\n IStateEvent,\n IStrippedState,\n ISyncResponse,\n ITimeline,\n IToDeviceEvent,\n} from \"./sync-accumulator\";\nimport { MatrixEvent } from \"./models/event\";\nimport { MatrixError, Method } from \"./http-api\";\nimport { ISavedSync } from \"./store\";\nimport { EventType } from \"./@types/event\";\nimport { IPushRules } from \"./@types/PushRules\";\nimport { RoomStateEvent, IMarkerFoundOptions } from \"./models/room-state\";\nimport { RoomMemberEvent } from \"./models/room-member\";\nimport { BeaconEvent } from \"./models/beacon\";\nimport { IEventsResponse } from \"./@types/requests\";\nimport { UNREAD_THREAD_NOTIFICATIONS } from \"./@types/sync\";\nimport { Feature, ServerSupport } from \"./feature\";\nimport { Crypto } from \"./crypto\";\n\nconst DEBUG = true;\n\n// /sync requests allow you to set a timeout= but the request may continue\n// beyond that and wedge forever, so we need to track how long we are willing\n// to keep open the connection. This constant is *ADDED* to the timeout= value\n// to determine the max time we're willing to wait.\nconst BUFFER_PERIOD_MS = 80 * 1000;\n\n// Number of consecutive failed syncs that will lead to a syncState of ERROR as opposed\n// to RECONNECTING. This is needed to inform the client of server issues when the\n// keepAlive is successful but the server /sync fails.\nconst FAILED_SYNC_ERROR_THRESHOLD = 3;\n\nexport enum SyncState {\n /** Emitted after we try to sync more than `FAILED_SYNC_ERROR_THRESHOLD`\n * times and are still failing. Or when we enounter a hard error like the\n * token being invalid. */\n Error = \"ERROR\",\n /** Emitted after the first sync events are ready (this could even be sync\n * events from the cache) */\n Prepared = \"PREPARED\",\n /** Emitted when the sync loop is no longer running */\n Stopped = \"STOPPED\",\n /** Emitted after each sync request happens */\n Syncing = \"SYNCING\",\n /** Emitted after a connectivity error and we're ready to start syncing again */\n Catchup = \"CATCHUP\",\n /** Emitted for each time we try reconnecting. Will switch to `Error` after\n * we reach the `FAILED_SYNC_ERROR_THRESHOLD`\n */\n Reconnecting = \"RECONNECTING\",\n}\n\n// Room versions where \"insertion\", \"batch\", and \"marker\" events are controlled\n// by power-levels. MSC2716 is supported in existing room versions but they\n// should only have special meaning when the room creator sends them.\nconst MSC2716_ROOM_VERSIONS = [\"org.matrix.msc2716v3\"];\n\nfunction getFilterName(userId: string, suffix?: string): string {\n // scope this on the user ID because people may login on many accounts\n // and they all need to be stored!\n return `FILTER_SYNC_${userId}` + (suffix ? \"_\" + suffix : \"\");\n}\n\n/* istanbul ignore next */\nfunction debuglog(...params: any[]): void {\n if (!DEBUG) return;\n logger.log(...params);\n}\n\n/**\n * Options passed into the constructor of SyncApi by MatrixClient\n */\nexport interface SyncApiOptions {\n /**\n * Crypto manager\n *\n * @deprecated in favour of cryptoCallbacks\n */\n crypto?: Crypto;\n\n /**\n * If crypto is enabled on our client, callbacks into the crypto module\n */\n cryptoCallbacks?: SyncCryptoCallbacks;\n\n /**\n * A function which is called\n * with a room ID and returns a boolean. It should return 'true' if the SDK can\n * SAFELY remove events from this room. It may not be safe to remove events if\n * there are other references to the timelines for this room.\n */\n canResetEntireTimeline?: ResetTimelineCallback;\n}\n\ninterface ISyncOptions {\n filter?: string;\n hasSyncedBefore?: boolean;\n}\n\nexport interface ISyncStateData {\n /**\n * The matrix error if `state=ERROR`.\n */\n error?: Error;\n /**\n * The 'since' token passed to /sync.\n * `null` for the first successful sync since this client was\n * started. Only present if `state=PREPARED` or\n * `state=SYNCING`.\n */\n oldSyncToken?: string;\n /**\n * The 'next_batch' result from /sync, which\n * will become the 'since' token for the next call to /sync. Only present if\n * `state=PREPARED or state=SYNCING`.\n */\n nextSyncToken?: string;\n /**\n * True if we are working our way through a\n * backlog of events after connecting. Only present if `state=SYNCING`.\n */\n catchingUp?: boolean;\n fromCache?: boolean;\n}\n\nenum SetPresence {\n Offline = \"offline\",\n Online = \"online\",\n Unavailable = \"unavailable\",\n}\n\ninterface ISyncParams {\n filter?: string;\n timeout: number;\n since?: string;\n // eslint-disable-next-line camelcase\n full_state?: boolean;\n // eslint-disable-next-line camelcase\n set_presence?: SetPresence;\n _cacheBuster?: string | number; // not part of the API itself\n}\n\ntype WrappedRoom = T & {\n room: Room;\n isBrandNewRoom: boolean;\n};\n\n/** add default settings to an IStoredClientOpts */\nexport function defaultClientOpts(opts?: IStoredClientOpts): IStoredClientOpts {\n return {\n initialSyncLimit: 8,\n resolveInvitesToProfiles: false,\n pollTimeout: 30 * 1000,\n pendingEventOrdering: PendingEventOrdering.Chronological,\n threadSupport: false,\n ...opts,\n };\n}\n\nexport function defaultSyncApiOpts(syncOpts?: SyncApiOptions): SyncApiOptions {\n return {\n canResetEntireTimeline: (_roomId): boolean => false,\n ...syncOpts,\n };\n}\n\nexport class SyncApi {\n private readonly opts: IStoredClientOpts;\n private readonly syncOpts: SyncApiOptions;\n\n private _peekRoom: Optional = null;\n private currentSyncRequest?: Promise;\n private abortController?: AbortController;\n private syncState: SyncState | null = null;\n private syncStateData?: ISyncStateData; // additional data (eg. error object for failed sync)\n private catchingUp = false;\n private running = false;\n private keepAliveTimer?: ReturnType;\n private connectionReturnedDefer?: IDeferred;\n private notifEvents: MatrixEvent[] = []; // accumulator of sync events in the current sync response\n private failedSyncCount = 0; // Number of consecutive failed /sync requests\n private storeIsInvalid = false; // flag set if the store needs to be cleared before we can start\n\n /**\n * Construct an entity which is able to sync with a homeserver.\n * @param client - The matrix client instance to use.\n * @param opts - client config options\n * @param syncOpts - sync-specific options passed by the client\n * @internal\n */\n public constructor(private readonly client: MatrixClient, opts?: IStoredClientOpts, syncOpts?: SyncApiOptions) {\n this.opts = defaultClientOpts(opts);\n this.syncOpts = defaultSyncApiOpts(syncOpts);\n\n if (client.getNotifTimelineSet()) {\n client.reEmitter.reEmit(client.getNotifTimelineSet()!, [RoomEvent.Timeline, RoomEvent.TimelineReset]);\n }\n }\n\n public createRoom(roomId: string): Room {\n const room = _createAndReEmitRoom(this.client, roomId, this.opts);\n\n room.on(RoomStateEvent.Marker, (markerEvent, markerFoundOptions) => {\n this.onMarkerStateEvent(room, markerEvent, markerFoundOptions);\n });\n\n return room;\n }\n\n /** When we see the marker state change in the room, we know there is some\n * new historical messages imported by MSC2716 `/batch_send` somewhere in\n * the room and we need to throw away the timeline to make sure the\n * historical messages are shown when we paginate `/messages` again.\n * @param room - The room where the marker event was sent\n * @param markerEvent - The new marker event\n * @param setStateOptions - When `timelineWasEmpty` is set\n * as `true`, the given marker event will be ignored\n */\n private onMarkerStateEvent(\n room: Room,\n markerEvent: MatrixEvent,\n { timelineWasEmpty }: IMarkerFoundOptions = {},\n ): void {\n // We don't need to refresh the timeline if it was empty before the\n // marker arrived. This could be happen in a variety of cases:\n // 1. From the initial sync\n // 2. If it's from the first state we're seeing after joining the room\n // 3. Or whether it's coming from `syncFromCache`\n if (timelineWasEmpty) {\n logger.debug(\n `MarkerState: Ignoring markerEventId=${markerEvent.getId()} in roomId=${room.roomId} ` +\n `because the timeline was empty before the marker arrived which means there is nothing to refresh.`,\n );\n return;\n }\n\n const isValidMsc2716Event =\n // Check whether the room version directly supports MSC2716, in\n // which case, \"marker\" events are already auth'ed by\n // power_levels\n MSC2716_ROOM_VERSIONS.includes(room.getVersion()) ||\n // MSC2716 is also supported in all existing room versions but\n // special meaning should only be given to \"insertion\", \"batch\",\n // and \"marker\" events when they come from the room creator\n markerEvent.getSender() === room.getCreator();\n\n // It would be nice if we could also specifically tell whether the\n // historical messages actually affected the locally cached client\n // timeline or not. The problem is we can't see the prev_events of\n // the base insertion event that the marker was pointing to because\n // prev_events aren't available in the client API's. In most cases,\n // the history won't be in people's locally cached timelines in the\n // client, so we don't need to bother everyone about refreshing\n // their timeline. This works for a v1 though and there are use\n // cases like initially bootstrapping your bridged room where people\n // are likely to encounter the historical messages affecting their\n // current timeline (think someone signing up for Beeper and\n // importing their Whatsapp history).\n if (isValidMsc2716Event) {\n // Saw new marker event, let's let the clients know they should\n // refresh the timeline.\n logger.debug(\n `MarkerState: Timeline needs to be refreshed because ` +\n `a new markerEventId=${markerEvent.getId()} was sent in roomId=${room.roomId}`,\n );\n room.setTimelineNeedsRefresh(true);\n room.emit(RoomEvent.HistoryImportedWithinTimeline, markerEvent, room);\n } else {\n logger.debug(\n `MarkerState: Ignoring markerEventId=${markerEvent.getId()} in roomId=${room.roomId} because ` +\n `MSC2716 is not supported in the room version or for any room version, the marker wasn't sent ` +\n `by the room creator.`,\n );\n }\n }\n\n /**\n * Sync rooms the user has left.\n * @returns Resolved when they've been added to the store.\n */\n public async syncLeftRooms(): Promise {\n const client = this.client;\n\n // grab a filter with limit=1 and include_leave=true\n const filter = new Filter(this.client.credentials.userId);\n filter.setTimelineLimit(1);\n filter.setIncludeLeaveRooms(true);\n\n const localTimeoutMs = this.opts.pollTimeout! + BUFFER_PERIOD_MS;\n\n const filterId = await client.getOrCreateFilter(\n getFilterName(client.credentials.userId!, \"LEFT_ROOMS\"),\n filter,\n );\n\n const qps: ISyncParams = {\n timeout: 0, // don't want to block since this is a single isolated req\n filter: filterId,\n };\n\n const data = await client.http.authedRequest(Method.Get, \"/sync\", qps as any, undefined, {\n localTimeoutMs,\n });\n\n let leaveRooms: WrappedRoom[] = [];\n if (data.rooms?.leave) {\n leaveRooms = this.mapSyncResponseToRoomArray(data.rooms.leave);\n }\n\n const rooms = await Promise.all(\n leaveRooms.map(async (leaveObj) => {\n const room = leaveObj.room;\n if (!leaveObj.isBrandNewRoom) {\n // the intention behind syncLeftRooms is to add in rooms which were\n // *omitted* from the initial /sync. Rooms the user were joined to\n // but then left whilst the app is running will appear in this list\n // and we do not want to bother with them since they will have the\n // current state already (and may get dupe messages if we add\n // yet more timeline events!), so skip them.\n // NB: When we persist rooms to localStorage this will be more\n // complicated...\n return;\n }\n leaveObj.timeline = leaveObj.timeline || {\n prev_batch: null,\n events: [],\n };\n const events = this.mapSyncEventsFormat(leaveObj.timeline, room);\n\n const stateEvents = this.mapSyncEventsFormat(leaveObj.state, room);\n\n // set the back-pagination token. Do this *before* adding any\n // events so that clients can start back-paginating.\n room.getLiveTimeline().setPaginationToken(leaveObj.timeline.prev_batch, EventTimeline.BACKWARDS);\n\n await this.injectRoomEvents(room, stateEvents, events);\n\n room.recalculate();\n client.store.storeRoom(room);\n client.emit(ClientEvent.Room, room);\n\n this.processEventsForNotifs(room, events);\n return room;\n }),\n );\n\n return rooms.filter(Boolean) as Room[];\n }\n\n /**\n * Peek into a room. This will result in the room in question being synced so it\n * is accessible via getRooms(). Live updates for the room will be provided.\n * @param roomId - The room ID to peek into.\n * @returns A promise which resolves once the room has been added to the\n * store.\n */\n public peek(roomId: string): Promise {\n if (this._peekRoom?.roomId === roomId) {\n return Promise.resolve(this._peekRoom);\n }\n\n const client = this.client;\n this._peekRoom = this.createRoom(roomId);\n return this.client.roomInitialSync(roomId, 20).then((response) => {\n // make sure things are init'd\n response.messages = response.messages || { chunk: [] };\n response.messages.chunk = response.messages.chunk || [];\n response.state = response.state || [];\n\n // FIXME: Mostly duplicated from injectRoomEvents but not entirely\n // because \"state\" in this API is at the BEGINNING of the chunk\n const oldStateEvents = utils.deepCopy(response.state).map(client.getEventMapper());\n const stateEvents = response.state.map(client.getEventMapper());\n const messages = response.messages.chunk.map(client.getEventMapper());\n\n // XXX: copypasted from /sync until we kill off this minging v1 API stuff)\n // handle presence events (User objects)\n if (Array.isArray(response.presence)) {\n response.presence.map(client.getEventMapper()).forEach(function (presenceEvent) {\n let user = client.store.getUser(presenceEvent.getContent().user_id);\n if (user) {\n user.setPresenceEvent(presenceEvent);\n } else {\n user = createNewUser(client, presenceEvent.getContent().user_id);\n user.setPresenceEvent(presenceEvent);\n client.store.storeUser(user);\n }\n client.emit(ClientEvent.Event, presenceEvent);\n });\n }\n\n // set the pagination token before adding the events in case people\n // fire off pagination requests in response to the Room.timeline\n // events.\n if (response.messages.start) {\n this._peekRoom!.oldState.paginationToken = response.messages.start;\n }\n\n // set the state of the room to as it was after the timeline executes\n this._peekRoom!.oldState.setStateEvents(oldStateEvents);\n this._peekRoom!.currentState.setStateEvents(stateEvents);\n\n this.resolveInvites(this._peekRoom!);\n this._peekRoom!.recalculate();\n\n // roll backwards to diverge old state. addEventsToTimeline\n // will overwrite the pagination token, so make sure it overwrites\n // it with the right thing.\n this._peekRoom!.addEventsToTimeline(\n messages.reverse(),\n true,\n this._peekRoom!.getLiveTimeline(),\n response.messages.start,\n );\n\n client.store.storeRoom(this._peekRoom!);\n client.emit(ClientEvent.Room, this._peekRoom!);\n\n this.peekPoll(this._peekRoom!);\n return this._peekRoom!;\n });\n }\n\n /**\n * Stop polling for updates in the peeked room. NOPs if there is no room being\n * peeked.\n */\n public stopPeeking(): void {\n this._peekRoom = null;\n }\n\n /**\n * Do a peek room poll.\n * @param token - from= token\n */\n private peekPoll(peekRoom: Room, token?: string): void {\n if (this._peekRoom !== peekRoom) {\n debuglog(\"Stopped peeking in room %s\", peekRoom.roomId);\n return;\n }\n\n // FIXME: gut wrenching; hard-coded timeout values\n this.client.http\n .authedRequest(\n Method.Get,\n \"/events\",\n {\n room_id: peekRoom.roomId,\n timeout: String(30 * 1000),\n from: token,\n },\n undefined,\n {\n localTimeoutMs: 50 * 1000,\n abortSignal: this.abortController?.signal,\n },\n )\n .then(\n (res) => {\n if (this._peekRoom !== peekRoom) {\n debuglog(\"Stopped peeking in room %s\", peekRoom.roomId);\n return;\n }\n // We have a problem that we get presence both from /events and /sync\n // however, /sync only returns presence for users in rooms\n // you're actually joined to.\n // in order to be sure to get presence for all of the users in the\n // peeked room, we handle presence explicitly here. This may result\n // in duplicate presence events firing for some users, which is a\n // performance drain, but such is life.\n // XXX: copypasted from /sync until we can kill this minging v1 stuff.\n\n res.chunk\n .filter(function (e) {\n return e.type === \"m.presence\";\n })\n .map(this.client.getEventMapper())\n .forEach((presenceEvent) => {\n let user = this.client.store.getUser(presenceEvent.getContent().user_id);\n if (user) {\n user.setPresenceEvent(presenceEvent);\n } else {\n user = createNewUser(this.client, presenceEvent.getContent().user_id);\n user.setPresenceEvent(presenceEvent);\n this.client.store.storeUser(user);\n }\n this.client.emit(ClientEvent.Event, presenceEvent);\n });\n\n // strip out events which aren't for the given room_id (e.g presence)\n // and also ephemeral events (which we're assuming is anything without\n // and event ID because the /events API doesn't separate them).\n const events = res.chunk\n .filter(function (e) {\n return e.room_id === peekRoom.roomId && e.event_id;\n })\n .map(this.client.getEventMapper());\n\n peekRoom.addLiveEvents(events);\n this.peekPoll(peekRoom, res.end);\n },\n (err) => {\n logger.error(\"[%s] Peek poll failed: %s\", peekRoom.roomId, err);\n setTimeout(() => {\n this.peekPoll(peekRoom, token);\n }, 30 * 1000);\n },\n );\n }\n\n /**\n * Returns the current state of this sync object\n * @see MatrixClient#event:\"sync\"\n */\n public getSyncState(): SyncState | null {\n return this.syncState;\n }\n\n /**\n * Returns the additional data object associated with\n * the current sync state, or null if there is no\n * such data.\n * Sync errors, if available, are put in the 'error' key of\n * this object.\n */\n public getSyncStateData(): ISyncStateData | null {\n return this.syncStateData ?? null;\n }\n\n public async recoverFromSyncStartupError(savedSyncPromise: Promise | undefined, error: Error): Promise {\n // Wait for the saved sync to complete - we send the pushrules and filter requests\n // before the saved sync has finished so they can run in parallel, but only process\n // the results after the saved sync is done. Equivalently, we wait for it to finish\n // before reporting failures from these functions.\n await savedSyncPromise;\n const keepaliveProm = this.startKeepAlives();\n this.updateSyncState(SyncState.Error, { error });\n await keepaliveProm;\n }\n\n /**\n * Is the lazy loading option different than in previous session?\n * @param lazyLoadMembers - current options for lazy loading\n * @returns whether or not the option has changed compared to the previous session */\n private async wasLazyLoadingToggled(lazyLoadMembers = false): Promise {\n // assume it was turned off before\n // if we don't know any better\n let lazyLoadMembersBefore = false;\n const isStoreNewlyCreated = await this.client.store.isNewlyCreated();\n if (!isStoreNewlyCreated) {\n const prevClientOptions = await this.client.store.getClientOptions();\n if (prevClientOptions) {\n lazyLoadMembersBefore = !!prevClientOptions.lazyLoadMembers;\n }\n return lazyLoadMembersBefore !== lazyLoadMembers;\n }\n return false;\n }\n\n private shouldAbortSync(error: MatrixError): boolean {\n if (error.errcode === \"M_UNKNOWN_TOKEN\") {\n // The logout already happened, we just need to stop.\n logger.warn(\"Token no longer valid - assuming logout\");\n this.stop();\n this.updateSyncState(SyncState.Error, { error });\n return true;\n }\n return false;\n }\n\n private getPushRules = async (): Promise => {\n try {\n debuglog(\"Getting push rules...\");\n const result = await this.client.getPushRules();\n debuglog(\"Got push rules\");\n\n this.client.pushRules = result;\n } catch (err) {\n logger.error(\"Getting push rules failed\", err);\n if (this.shouldAbortSync(err)) return;\n // wait for saved sync to complete before doing anything else,\n // otherwise the sync state will end up being incorrect\n debuglog(\"Waiting for saved sync before retrying push rules...\");\n await this.recoverFromSyncStartupError(this.savedSyncPromise, err);\n return this.getPushRules(); // try again\n }\n };\n\n private buildDefaultFilter = (): Filter => {\n const filter = new Filter(this.client.credentials.userId);\n if (this.client.canSupport.get(Feature.ThreadUnreadNotifications) !== ServerSupport.Unsupported) {\n filter.setUnreadThreadNotifications(true);\n }\n return filter;\n };\n\n private checkLazyLoadStatus = async (): Promise => {\n debuglog(\"Checking lazy load status...\");\n if (this.opts.lazyLoadMembers && this.client.isGuest()) {\n this.opts.lazyLoadMembers = false;\n }\n if (this.opts.lazyLoadMembers) {\n debuglog(\"Checking server lazy load support...\");\n const supported = await this.client.doesServerSupportLazyLoading();\n if (supported) {\n debuglog(\"Enabling lazy load on sync filter...\");\n if (!this.opts.filter) {\n this.opts.filter = this.buildDefaultFilter();\n }\n this.opts.filter.setLazyLoadMembers(true);\n } else {\n debuglog(\"LL: lazy loading requested but not supported \" + \"by server, so disabling\");\n this.opts.lazyLoadMembers = false;\n }\n }\n // need to vape the store when enabling LL and wasn't enabled before\n debuglog(\"Checking whether lazy loading has changed in store...\");\n const shouldClear = await this.wasLazyLoadingToggled(this.opts.lazyLoadMembers);\n if (shouldClear) {\n this.storeIsInvalid = true;\n const error = new InvalidStoreError(InvalidStoreState.ToggledLazyLoading, !!this.opts.lazyLoadMembers);\n this.updateSyncState(SyncState.Error, { error });\n // bail out of the sync loop now: the app needs to respond to this error.\n // we leave the state as 'ERROR' which isn't great since this normally means\n // we're retrying. The client must be stopped before clearing the stores anyway\n // so the app should stop the client, clear the store and start it again.\n logger.warn(\"InvalidStoreError: store is not usable: stopping sync.\");\n return;\n }\n if (this.opts.lazyLoadMembers) {\n this.syncOpts.crypto?.enableLazyLoading();\n }\n try {\n debuglog(\"Storing client options...\");\n await this.client.storeClientOptions();\n debuglog(\"Stored client options\");\n } catch (err) {\n logger.error(\"Storing client options failed\", err);\n throw err;\n }\n };\n\n private getFilter = async (): Promise<{\n filterId?: string;\n filter?: Filter;\n }> => {\n debuglog(\"Getting filter...\");\n let filter: Filter;\n if (this.opts.filter) {\n filter = this.opts.filter;\n } else {\n filter = this.buildDefaultFilter();\n }\n\n let filterId: string;\n try {\n filterId = await this.client.getOrCreateFilter(getFilterName(this.client.credentials.userId!), filter);\n } catch (err) {\n logger.error(\"Getting filter failed\", err);\n if (this.shouldAbortSync(err)) return {};\n // wait for saved sync to complete before doing anything else,\n // otherwise the sync state will end up being incorrect\n debuglog(\"Waiting for saved sync before retrying filter...\");\n await this.recoverFromSyncStartupError(this.savedSyncPromise, err);\n return this.getFilter(); // try again\n }\n return { filter, filterId };\n };\n\n private savedSyncPromise?: Promise;\n\n /**\n * Main entry point\n */\n public async sync(): Promise {\n this.running = true;\n this.abortController = new AbortController();\n\n global.window?.addEventListener?.(\"online\", this.onOnline, false);\n\n if (this.client.isGuest()) {\n // no push rules for guests, no access to POST filter for guests.\n return this.doSync({});\n }\n\n // Pull the saved sync token out first, before the worker starts sending\n // all the sync data which could take a while. This will let us send our\n // first incremental sync request before we've processed our saved data.\n debuglog(\"Getting saved sync token...\");\n const savedSyncTokenPromise = this.client.store.getSavedSyncToken().then((tok) => {\n debuglog(\"Got saved sync token\");\n return tok;\n });\n\n this.savedSyncPromise = this.client.store\n .getSavedSync()\n .then((savedSync) => {\n debuglog(`Got reply from saved sync, exists? ${!!savedSync}`);\n if (savedSync) {\n return this.syncFromCache(savedSync);\n }\n })\n .catch((err) => {\n logger.error(\"Getting saved sync failed\", err);\n });\n\n // We need to do one-off checks before we can begin the /sync loop.\n // These are:\n // 1) We need to get push rules so we can check if events should bing as we get\n // them from /sync.\n // 2) We need to get/create a filter which we can use for /sync.\n // 3) We need to check the lazy loading option matches what was used in the\n // stored sync. If it doesn't, we can't use the stored sync.\n\n // Now start the first incremental sync request: this can also\n // take a while so if we set it going now, we can wait for it\n // to finish while we process our saved sync data.\n await this.getPushRules();\n await this.checkLazyLoadStatus();\n const { filterId, filter } = await this.getFilter();\n if (!filter) return; // bail, getFilter failed\n\n // reset the notifications timeline to prepare it to paginate from\n // the current point in time.\n // The right solution would be to tie /sync pagination tokens into\n // /notifications API somehow.\n this.client.resetNotifTimelineSet();\n\n if (!this.currentSyncRequest) {\n let firstSyncFilter = filterId;\n const savedSyncToken = await savedSyncTokenPromise;\n\n if (savedSyncToken) {\n debuglog(\"Sending first sync request...\");\n } else {\n debuglog(\"Sending initial sync request...\");\n const initialFilter = this.buildDefaultFilter();\n initialFilter.setDefinition(filter.getDefinition());\n initialFilter.setTimelineLimit(this.opts.initialSyncLimit!);\n // Use an inline filter, no point uploading it for a single usage\n firstSyncFilter = JSON.stringify(initialFilter.getDefinition());\n }\n\n // Send this first sync request here so we can then wait for the saved\n // sync data to finish processing before we process the results of this one.\n this.currentSyncRequest = this.doSyncRequest({ filter: firstSyncFilter }, savedSyncToken);\n }\n\n // Now wait for the saved sync to finish...\n debuglog(\"Waiting for saved sync before starting sync processing...\");\n await this.savedSyncPromise;\n // process the first sync request and continue syncing with the normal filterId\n return this.doSync({ filter: filterId });\n }\n\n /**\n * Stops the sync object from syncing.\n */\n public stop(): void {\n debuglog(\"SyncApi.stop\");\n // It is necessary to check for the existance of\n // global.window AND global.window.removeEventListener.\n // Some platforms (e.g. React Native) register global.window,\n // but do not have global.window.removeEventListener.\n global.window?.removeEventListener?.(\"online\", this.onOnline, false);\n this.running = false;\n this.abortController?.abort();\n if (this.keepAliveTimer) {\n clearTimeout(this.keepAliveTimer);\n this.keepAliveTimer = undefined;\n }\n }\n\n /**\n * Retry a backed off syncing request immediately. This should only be used when\n * the user explicitly attempts to retry their lost connection.\n * @returns True if this resulted in a request being retried.\n */\n public retryImmediately(): boolean {\n if (!this.connectionReturnedDefer) {\n return false;\n }\n this.startKeepAlives(0);\n return true;\n }\n /**\n * Process a single set of cached sync data.\n * @param savedSync - a saved sync that was persisted by a store. This\n * should have been acquired via client.store.getSavedSync().\n */\n private async syncFromCache(savedSync: ISavedSync): Promise {\n debuglog(\"sync(): not doing HTTP hit, instead returning stored /sync data\");\n\n const nextSyncToken = savedSync.nextBatch;\n\n // Set sync token for future incremental syncing\n this.client.store.setSyncToken(nextSyncToken);\n\n // No previous sync, set old token to null\n const syncEventData: ISyncStateData = {\n nextSyncToken,\n catchingUp: false,\n fromCache: true,\n };\n\n const data: ISyncResponse = {\n next_batch: nextSyncToken,\n rooms: savedSync.roomsData,\n account_data: {\n events: savedSync.accountData,\n },\n };\n\n try {\n await this.processSyncResponse(syncEventData, data);\n } catch (e) {\n logger.error(\"Error processing cached sync\", e);\n }\n\n // Don't emit a prepared if we've bailed because the store is invalid:\n // in this case the client will not be usable until stopped & restarted\n // so this would be useless and misleading.\n if (!this.storeIsInvalid) {\n this.updateSyncState(SyncState.Prepared, syncEventData);\n }\n }\n\n /**\n * Invoke me to do /sync calls\n */\n private async doSync(syncOptions: ISyncOptions): Promise {\n while (this.running) {\n const syncToken = this.client.store.getSyncToken();\n\n let data: ISyncResponse;\n try {\n if (!this.currentSyncRequest) {\n this.currentSyncRequest = this.doSyncRequest(syncOptions, syncToken);\n }\n data = await this.currentSyncRequest;\n } catch (e) {\n const abort = await this.onSyncError(e);\n if (abort) return;\n continue;\n } finally {\n this.currentSyncRequest = undefined;\n }\n\n // set the sync token NOW *before* processing the events. We do this so\n // if something barfs on an event we can skip it rather than constantly\n // polling with the same token.\n this.client.store.setSyncToken(data.next_batch);\n\n // Reset after a successful sync\n this.failedSyncCount = 0;\n\n await this.client.store.setSyncData(data);\n\n const syncEventData = {\n oldSyncToken: syncToken ?? undefined,\n nextSyncToken: data.next_batch,\n catchingUp: this.catchingUp,\n };\n\n if (this.syncOpts.crypto) {\n // tell the crypto module we're about to process a sync\n // response\n await this.syncOpts.crypto.onSyncWillProcess(syncEventData);\n }\n\n try {\n await this.processSyncResponse(syncEventData, data);\n } catch (e) {\n // log the exception with stack if we have it, else fall back\n // to the plain description\n logger.error(\"Caught /sync error\", e);\n\n // Emit the exception for client handling\n this.client.emit(ClientEvent.SyncUnexpectedError, e);\n }\n\n // update this as it may have changed\n syncEventData.catchingUp = this.catchingUp;\n\n // emit synced events\n if (!syncOptions.hasSyncedBefore) {\n this.updateSyncState(SyncState.Prepared, syncEventData);\n syncOptions.hasSyncedBefore = true;\n }\n\n // tell the crypto module to do its processing. It may block (to do a\n // /keys/changes request).\n if (this.syncOpts.cryptoCallbacks) {\n await this.syncOpts.cryptoCallbacks.onSyncCompleted(syncEventData);\n }\n\n // keep emitting SYNCING -> SYNCING for clients who want to do bulk updates\n this.updateSyncState(SyncState.Syncing, syncEventData);\n\n if (this.client.store.wantsSave()) {\n // We always save the device list (if it's dirty) before saving the sync data:\n // this means we know the saved device list data is at least as fresh as the\n // stored sync data which means we don't have to worry that we may have missed\n // device changes. We can also skip the delay since we're not calling this very\n // frequently (and we don't really want to delay the sync for it).\n if (this.syncOpts.crypto) {\n await this.syncOpts.crypto.saveDeviceList(0);\n }\n\n // tell databases that everything is now in a consistent state and can be saved.\n this.client.store.save();\n }\n }\n\n if (!this.running) {\n debuglog(\"Sync no longer running: exiting.\");\n if (this.connectionReturnedDefer) {\n this.connectionReturnedDefer.reject();\n this.connectionReturnedDefer = undefined;\n }\n this.updateSyncState(SyncState.Stopped);\n }\n }\n\n private doSyncRequest(syncOptions: ISyncOptions, syncToken: string | null): Promise {\n const qps = this.getSyncParams(syncOptions, syncToken);\n return this.client.http.authedRequest(Method.Get, \"/sync\", qps as any, undefined, {\n localTimeoutMs: qps.timeout + BUFFER_PERIOD_MS,\n abortSignal: this.abortController?.signal,\n });\n }\n\n private getSyncParams(syncOptions: ISyncOptions, syncToken: string | null): ISyncParams {\n let timeout = this.opts.pollTimeout!;\n\n if (this.getSyncState() !== SyncState.Syncing || this.catchingUp) {\n // unless we are happily syncing already, we want the server to return\n // as quickly as possible, even if there are no events queued. This\n // serves two purposes:\n //\n // * When the connection dies, we want to know asap when it comes back,\n // so that we can hide the error from the user. (We don't want to\n // have to wait for an event or a timeout).\n //\n // * We want to know if the server has any to_device messages queued up\n // for us. We do that by calling it with a zero timeout until it\n // doesn't give us any more to_device messages.\n this.catchingUp = true;\n timeout = 0;\n }\n\n let filter = syncOptions.filter;\n if (this.client.isGuest() && !filter) {\n filter = this.getGuestFilter();\n }\n\n const qps: ISyncParams = { filter, timeout };\n\n if (this.opts.disablePresence) {\n qps.set_presence = SetPresence.Offline;\n }\n\n if (syncToken) {\n qps.since = syncToken;\n } else {\n // use a cachebuster for initialsyncs, to make sure that\n // we don't get a stale sync\n // (https://github.com/vector-im/vector-web/issues/1354)\n qps._cacheBuster = Date.now();\n }\n\n if ([SyncState.Reconnecting, SyncState.Error].includes(this.getSyncState()!)) {\n // we think the connection is dead. If it comes back up, we won't know\n // about it till /sync returns. If the timeout= is high, this could\n // be a long time. Set it to 0 when doing retries so we don't have to wait\n // for an event or a timeout before emiting the SYNCING event.\n qps.timeout = 0;\n }\n\n return qps;\n }\n\n private async onSyncError(err: MatrixError): Promise {\n if (!this.running) {\n debuglog(\"Sync no longer running: exiting\");\n if (this.connectionReturnedDefer) {\n this.connectionReturnedDefer.reject();\n this.connectionReturnedDefer = undefined;\n }\n this.updateSyncState(SyncState.Stopped);\n return true; // abort\n }\n\n logger.error(\"/sync error %s\", err);\n\n if (this.shouldAbortSync(err)) {\n return true; // abort\n }\n\n this.failedSyncCount++;\n logger.log(\"Number of consecutive failed sync requests:\", this.failedSyncCount);\n\n debuglog(\"Starting keep-alive\");\n // Note that we do *not* mark the sync connection as\n // lost yet: we only do this if a keepalive poke\n // fails, since long lived HTTP connections will\n // go away sometimes and we shouldn't treat this as\n // erroneous. We set the state to 'reconnecting'\n // instead, so that clients can observe this state\n // if they wish.\n const keepAlivePromise = this.startKeepAlives();\n\n this.currentSyncRequest = undefined;\n // Transition from RECONNECTING to ERROR after a given number of failed syncs\n this.updateSyncState(\n this.failedSyncCount >= FAILED_SYNC_ERROR_THRESHOLD ? SyncState.Error : SyncState.Reconnecting,\n { error: err },\n );\n\n const connDidFail = await keepAlivePromise;\n\n // Only emit CATCHUP if we detected a connectivity error: if we didn't,\n // it's quite likely the sync will fail again for the same reason and we\n // want to stay in ERROR rather than keep flip-flopping between ERROR\n // and CATCHUP.\n if (connDidFail && this.getSyncState() === SyncState.Error) {\n this.updateSyncState(SyncState.Catchup, {\n catchingUp: true,\n });\n }\n return false;\n }\n\n /**\n * Process data returned from a sync response and propagate it\n * into the model objects\n *\n * @param syncEventData - Object containing sync tokens associated with this sync\n * @param data - The response from /sync\n */\n private async processSyncResponse(syncEventData: ISyncStateData, data: ISyncResponse): Promise {\n const client = this.client;\n\n // data looks like:\n // {\n // next_batch: $token,\n // presence: { events: [] },\n // account_data: { events: [] },\n // device_lists: { changed: [\"@user:server\", ... ]},\n // to_device: { events: [] },\n // device_one_time_keys_count: { signed_curve25519: 42 },\n // rooms: {\n // invite: {\n // $roomid: {\n // invite_state: { events: [] }\n // }\n // },\n // join: {\n // $roomid: {\n // state: { events: [] },\n // timeline: { events: [], prev_batch: $token, limited: true },\n // ephemeral: { events: [] },\n // summary: {\n // m.heroes: [ $user_id ],\n // m.joined_member_count: $count,\n // m.invited_member_count: $count\n // },\n // account_data: { events: [] },\n // unread_notifications: {\n // highlight_count: 0,\n // notification_count: 0,\n // }\n // }\n // },\n // leave: {\n // $roomid: {\n // state: { events: [] },\n // timeline: { events: [], prev_batch: $token }\n // }\n // }\n // }\n // }\n\n // TODO-arch:\n // - Each event we pass through needs to be emitted via 'event', can we\n // do this in one place?\n // - The isBrandNewRoom boilerplate is boilerplatey.\n\n // handle presence events (User objects)\n if (Array.isArray(data.presence?.events)) {\n data.presence!.events.filter(noUnsafeEventProps)\n .map(client.getEventMapper())\n .forEach(function (presenceEvent) {\n let user = client.store.getUser(presenceEvent.getSender()!);\n if (user) {\n user.setPresenceEvent(presenceEvent);\n } else {\n user = createNewUser(client, presenceEvent.getSender()!);\n user.setPresenceEvent(presenceEvent);\n client.store.storeUser(user);\n }\n client.emit(ClientEvent.Event, presenceEvent);\n });\n }\n\n // handle non-room account_data\n if (Array.isArray(data.account_data?.events)) {\n const events = data.account_data.events.filter(noUnsafeEventProps).map(client.getEventMapper());\n const prevEventsMap = events.reduce>((m, c) => {\n m[c.getType()!] = client.store.getAccountData(c.getType());\n return m;\n }, {});\n client.store.storeAccountDataEvents(events);\n events.forEach(function (accountDataEvent) {\n // Honour push rules that come down the sync stream but also\n // honour push rules that were previously cached. Base rules\n // will be updated when we receive push rules via getPushRules\n // (see sync) before syncing over the network.\n if (accountDataEvent.getType() === EventType.PushRules) {\n const rules = accountDataEvent.getContent();\n client.setPushRules(rules);\n }\n const prevEvent = prevEventsMap[accountDataEvent.getType()!];\n client.emit(ClientEvent.AccountData, accountDataEvent, prevEvent);\n return accountDataEvent;\n });\n }\n\n // handle to-device events\n if (data.to_device && Array.isArray(data.to_device.events) && data.to_device.events.length > 0) {\n let toDeviceMessages: IToDeviceEvent[] = data.to_device.events.filter(noUnsafeEventProps);\n\n if (this.syncOpts.cryptoCallbacks) {\n toDeviceMessages = await this.syncOpts.cryptoCallbacks.preprocessToDeviceMessages(toDeviceMessages);\n }\n\n const cancelledKeyVerificationTxns: string[] = [];\n toDeviceMessages\n .map(client.getEventMapper({ toDevice: true }))\n .map((toDeviceEvent) => {\n // map is a cheap inline forEach\n // We want to flag m.key.verification.start events as cancelled\n // if there's an accompanying m.key.verification.cancel event, so\n // we pull out the transaction IDs from the cancellation events\n // so we can flag the verification events as cancelled in the loop\n // below.\n if (toDeviceEvent.getType() === \"m.key.verification.cancel\") {\n const txnId: string = toDeviceEvent.getContent()[\"transaction_id\"];\n if (txnId) {\n cancelledKeyVerificationTxns.push(txnId);\n }\n }\n\n // as mentioned above, .map is a cheap inline forEach, so return\n // the unmodified event.\n return toDeviceEvent;\n })\n .forEach(function (toDeviceEvent) {\n const content = toDeviceEvent.getContent();\n if (toDeviceEvent.getType() == \"m.room.message\" && content.msgtype == \"m.bad.encrypted\") {\n // the mapper already logged a warning.\n logger.log(\"Ignoring undecryptable to-device event from \" + toDeviceEvent.getSender());\n return;\n }\n\n if (\n toDeviceEvent.getType() === \"m.key.verification.start\" ||\n toDeviceEvent.getType() === \"m.key.verification.request\"\n ) {\n const txnId = content[\"transaction_id\"];\n if (cancelledKeyVerificationTxns.includes(txnId)) {\n toDeviceEvent.flagCancelled();\n }\n }\n\n client.emit(ClientEvent.ToDeviceEvent, toDeviceEvent);\n });\n } else {\n // no more to-device events: we can stop polling with a short timeout.\n this.catchingUp = false;\n }\n\n // the returned json structure is a bit crap, so make it into a\n // nicer form (array) after applying sanity to make sure we don't fail\n // on missing keys (on the off chance)\n let inviteRooms: WrappedRoom[] = [];\n let joinRooms: WrappedRoom[] = [];\n let leaveRooms: WrappedRoom[] = [];\n\n if (data.rooms) {\n if (data.rooms.invite) {\n inviteRooms = this.mapSyncResponseToRoomArray(data.rooms.invite);\n }\n if (data.rooms.join) {\n joinRooms = this.mapSyncResponseToRoomArray(data.rooms.join);\n }\n if (data.rooms.leave) {\n leaveRooms = this.mapSyncResponseToRoomArray(data.rooms.leave);\n }\n }\n\n this.notifEvents = [];\n\n // Handle invites\n await utils.promiseMapSeries(inviteRooms, async (inviteObj) => {\n const room = inviteObj.room;\n const stateEvents = this.mapSyncEventsFormat(inviteObj.invite_state, room);\n\n await this.injectRoomEvents(room, stateEvents);\n\n const inviter = room.currentState.getStateEvents(EventType.RoomMember, client.getUserId()!)?.getSender();\n\n const crypto = client.crypto;\n if (crypto) {\n const parkedHistory = await crypto.cryptoStore.takeParkedSharedHistory(room.roomId);\n for (const parked of parkedHistory) {\n if (parked.senderId === inviter) {\n await crypto.olmDevice.addInboundGroupSession(\n room.roomId,\n parked.senderKey,\n parked.forwardingCurve25519KeyChain,\n parked.sessionId,\n parked.sessionKey,\n parked.keysClaimed,\n true,\n { sharedHistory: true, untrusted: true },\n );\n }\n }\n }\n\n if (inviteObj.isBrandNewRoom) {\n room.recalculate();\n client.store.storeRoom(room);\n client.emit(ClientEvent.Room, room);\n } else {\n // Update room state for invite->reject->invite cycles\n room.recalculate();\n }\n stateEvents.forEach(function (e) {\n client.emit(ClientEvent.Event, e);\n });\n });\n\n // Handle joins\n await utils.promiseMapSeries(joinRooms, async (joinObj) => {\n const room = joinObj.room;\n const stateEvents = this.mapSyncEventsFormat(joinObj.state, room);\n // Prevent events from being decrypted ahead of time\n // this helps large account to speed up faster\n // room::decryptCriticalEvent is in charge of decrypting all the events\n // required for a client to function properly\n const events = this.mapSyncEventsFormat(joinObj.timeline, room, false);\n const ephemeralEvents = this.mapSyncEventsFormat(joinObj.ephemeral);\n const accountDataEvents = this.mapSyncEventsFormat(joinObj.account_data);\n\n const encrypted = client.isRoomEncrypted(room.roomId);\n // We store the server-provided value first so it's correct when any of the events fire.\n if (joinObj.unread_notifications) {\n /**\n * We track unread notifications ourselves in encrypted rooms, so don't\n * bother setting it here. We trust our calculations better than the\n * server's for this case, and therefore will assume that our non-zero\n * count is accurate.\n *\n * @see import(\"./client\").fixNotificationCountOnDecryption\n */\n if (!encrypted || joinObj.unread_notifications.notification_count === 0) {\n // In an encrypted room, if the room has notifications enabled then it's typical for\n // the server to flag all new messages as notifying. However, some push rules calculate\n // events as ignored based on their event contents (e.g. ignoring msgtype=m.notice messages)\n // so we want to calculate this figure on the client in all cases.\n room.setUnreadNotificationCount(\n NotificationCountType.Total,\n joinObj.unread_notifications.notification_count ?? 0,\n );\n }\n\n if (!encrypted || room.getUnreadNotificationCount(NotificationCountType.Highlight) <= 0) {\n // If the locally stored highlight count is zero, use the server provided value.\n room.setUnreadNotificationCount(\n NotificationCountType.Highlight,\n joinObj.unread_notifications.highlight_count ?? 0,\n );\n }\n }\n\n const unreadThreadNotifications =\n joinObj[UNREAD_THREAD_NOTIFICATIONS.name] ?? joinObj[UNREAD_THREAD_NOTIFICATIONS.altName!];\n if (unreadThreadNotifications) {\n // Only partially reset unread notification\n // We want to keep the client-generated count. Particularly important\n // for encrypted room that refresh their notification count on event\n // decryption\n room.resetThreadUnreadNotificationCount(Object.keys(unreadThreadNotifications));\n for (const [threadId, unreadNotification] of Object.entries(unreadThreadNotifications)) {\n if (!encrypted || unreadNotification.notification_count === 0) {\n room.setThreadUnreadNotificationCount(\n threadId,\n NotificationCountType.Total,\n unreadNotification.notification_count ?? 0,\n );\n }\n\n const hasNoNotifications =\n room.getThreadUnreadNotificationCount(threadId, NotificationCountType.Highlight) <= 0;\n if (!encrypted || (encrypted && hasNoNotifications)) {\n room.setThreadUnreadNotificationCount(\n threadId,\n NotificationCountType.Highlight,\n unreadNotification.highlight_count ?? 0,\n );\n }\n }\n } else {\n room.resetThreadUnreadNotificationCount();\n }\n\n joinObj.timeline = joinObj.timeline || ({} as ITimeline);\n\n if (joinObj.isBrandNewRoom) {\n // set the back-pagination token. Do this *before* adding any\n // events so that clients can start back-paginating.\n if (joinObj.timeline.prev_batch !== null) {\n room.getLiveTimeline().setPaginationToken(joinObj.timeline.prev_batch, EventTimeline.BACKWARDS);\n }\n } else if (joinObj.timeline.limited) {\n let limited = true;\n\n // we've got a limited sync, so we *probably* have a gap in the\n // timeline, so should reset. But we might have been peeking or\n // paginating and already have some of the events, in which\n // case we just want to append any subsequent events to the end\n // of the existing timeline.\n //\n // This is particularly important in the case that we already have\n // *all* of the events in the timeline - in that case, if we reset\n // the timeline, we'll end up with an entirely empty timeline,\n // which we'll try to paginate but not get any new events (which\n // will stop us linking the empty timeline into the chain).\n //\n for (let i = events.length - 1; i >= 0; i--) {\n const eventId = events[i].getId()!;\n if (room.getTimelineForEvent(eventId)) {\n debuglog(`Already have event ${eventId} in limited sync - not resetting`);\n limited = false;\n\n // we might still be missing some of the events before i;\n // we don't want to be adding them to the end of the\n // timeline because that would put them out of order.\n events.splice(0, i);\n\n // XXX: there's a problem here if the skipped part of the\n // timeline modifies the state set in stateEvents, because\n // we'll end up using the state from stateEvents rather\n // than the later state from timelineEvents. We probably\n // need to wind stateEvents forward over the events we're\n // skipping.\n\n break;\n }\n }\n\n if (limited) {\n room.resetLiveTimeline(\n joinObj.timeline.prev_batch,\n this.syncOpts.canResetEntireTimeline!(room.roomId) ? null : syncEventData.oldSyncToken ?? null,\n );\n\n // We have to assume any gap in any timeline is\n // reason to stop incrementally tracking notifications and\n // reset the timeline.\n client.resetNotifTimelineSet();\n }\n }\n\n // process any crypto events *before* emitting the RoomStateEvent events. This\n // avoids a race condition if the application tries to send a message after the\n // state event is processed, but before crypto is enabled, which then causes the\n // crypto layer to complain.\n if (this.syncOpts.cryptoCallbacks) {\n for (const e of stateEvents.concat(events)) {\n if (e.isState() && e.getType() === EventType.RoomEncryption && e.getStateKey() === \"\") {\n await this.syncOpts.cryptoCallbacks.onCryptoEvent(room, e);\n }\n }\n }\n\n try {\n await this.injectRoomEvents(room, stateEvents, events, syncEventData.fromCache);\n } catch (e) {\n logger.error(`Failed to process events on room ${room.roomId}:`, e);\n }\n\n // set summary after processing events,\n // because it will trigger a name calculation\n // which needs the room state to be up to date\n if (joinObj.summary) {\n room.setSummary(joinObj.summary);\n }\n\n // we deliberately don't add ephemeral events to the timeline\n room.addEphemeralEvents(ephemeralEvents);\n\n // we deliberately don't add accountData to the timeline\n room.addAccountData(accountDataEvents);\n\n room.recalculate();\n if (joinObj.isBrandNewRoom) {\n client.store.storeRoom(room);\n client.emit(ClientEvent.Room, room);\n }\n\n this.processEventsForNotifs(room, events);\n\n const emitEvent = (e: MatrixEvent): boolean => client.emit(ClientEvent.Event, e);\n stateEvents.forEach(emitEvent);\n events.forEach(emitEvent);\n ephemeralEvents.forEach(emitEvent);\n accountDataEvents.forEach(emitEvent);\n\n // Decrypt only the last message in all rooms to make sure we can generate a preview\n // And decrypt all events after the recorded read receipt to ensure an accurate\n // notification count\n room.decryptCriticalEvents();\n });\n\n // Handle leaves (e.g. kicked rooms)\n await utils.promiseMapSeries(leaveRooms, async (leaveObj) => {\n const room = leaveObj.room;\n const stateEvents = this.mapSyncEventsFormat(leaveObj.state, room);\n const events = this.mapSyncEventsFormat(leaveObj.timeline, room);\n const accountDataEvents = this.mapSyncEventsFormat(leaveObj.account_data);\n\n await this.injectRoomEvents(room, stateEvents, events);\n room.addAccountData(accountDataEvents);\n\n room.recalculate();\n if (leaveObj.isBrandNewRoom) {\n client.store.storeRoom(room);\n client.emit(ClientEvent.Room, room);\n }\n\n this.processEventsForNotifs(room, events);\n\n stateEvents.forEach(function (e) {\n client.emit(ClientEvent.Event, e);\n });\n events.forEach(function (e) {\n client.emit(ClientEvent.Event, e);\n });\n accountDataEvents.forEach(function (e) {\n client.emit(ClientEvent.Event, e);\n });\n });\n\n // update the notification timeline, if appropriate.\n // we only do this for live events, as otherwise we can't order them sanely\n // in the timeline relative to ones paginated in by /notifications.\n // XXX: we could fix this by making EventTimeline support chronological\n // ordering... but it doesn't, right now.\n if (syncEventData.oldSyncToken && this.notifEvents.length) {\n this.notifEvents.sort(function (a, b) {\n return a.getTs() - b.getTs();\n });\n this.notifEvents.forEach(function (event) {\n client.getNotifTimelineSet()?.addLiveEvent(event);\n });\n }\n\n // Handle device list updates\n if (data.device_lists) {\n if (this.syncOpts.crypto) {\n await this.syncOpts.crypto.handleDeviceListChanges(syncEventData, data.device_lists);\n } else {\n // FIXME if we *don't* have a crypto module, we still need to\n // invalidate the device lists. But that would require a\n // substantial bit of rework :/.\n }\n }\n\n // Handle one_time_keys_count\n if (data.device_one_time_keys_count) {\n const map = new Map(Object.entries(data.device_one_time_keys_count));\n this.syncOpts.cryptoCallbacks?.preprocessOneTimeKeyCounts(map);\n }\n if (data.device_unused_fallback_key_types || data[\"org.matrix.msc2732.device_unused_fallback_key_types\"]) {\n // The presence of device_unused_fallback_key_types indicates that the\n // server supports fallback keys. If there's no unused\n // signed_curve25519 fallback key we need a new one.\n const unusedFallbackKeys =\n data.device_unused_fallback_key_types || data[\"org.matrix.msc2732.device_unused_fallback_key_types\"];\n this.syncOpts.cryptoCallbacks?.preprocessUnusedFallbackKeys(new Set(unusedFallbackKeys || null));\n }\n }\n\n /**\n * Starts polling the connectivity check endpoint\n * @param delay - How long to delay until the first poll.\n * defaults to a short, randomised interval (to prevent\n * tight-looping if /versions succeeds but /sync etc. fail).\n * @returns which resolves once the connection returns\n */\n private startKeepAlives(delay?: number): Promise {\n if (delay === undefined) {\n delay = 2000 + Math.floor(Math.random() * 5000);\n }\n\n if (this.keepAliveTimer !== null) {\n clearTimeout(this.keepAliveTimer);\n }\n if (delay > 0) {\n this.keepAliveTimer = setTimeout(this.pokeKeepAlive.bind(this), delay);\n } else {\n this.pokeKeepAlive();\n }\n if (!this.connectionReturnedDefer) {\n this.connectionReturnedDefer = utils.defer();\n }\n return this.connectionReturnedDefer.promise;\n }\n\n /**\n * Make a dummy call to /_matrix/client/versions, to see if the HS is\n * reachable.\n *\n * On failure, schedules a call back to itself. On success, resolves\n * this.connectionReturnedDefer.\n *\n * @param connDidFail - True if a connectivity failure has been detected. Optional.\n */\n private pokeKeepAlive(connDidFail = false): void {\n const success = (): void => {\n clearTimeout(this.keepAliveTimer);\n if (this.connectionReturnedDefer) {\n this.connectionReturnedDefer.resolve(connDidFail);\n this.connectionReturnedDefer = undefined;\n }\n };\n\n this.client.http\n .request(\n Method.Get,\n \"/_matrix/client/versions\",\n undefined, // queryParams\n undefined, // data\n {\n prefix: \"\",\n localTimeoutMs: 15 * 1000,\n abortSignal: this.abortController?.signal,\n },\n )\n .then(\n () => {\n success();\n },\n (err) => {\n if (err.httpStatus == 400 || err.httpStatus == 404) {\n // treat this as a success because the server probably just doesn't\n // support /versions: point is, we're getting a response.\n // We wait a short time though, just in case somehow the server\n // is in a mode where it 400s /versions responses and sync etc.\n // responses fail, this will mean we don't hammer in a loop.\n this.keepAliveTimer = setTimeout(success, 2000);\n } else {\n connDidFail = true;\n this.keepAliveTimer = setTimeout(\n this.pokeKeepAlive.bind(this, connDidFail),\n 5000 + Math.floor(Math.random() * 5000),\n );\n // A keepalive has failed, so we emit the\n // error state (whether or not this is the\n // first failure).\n // Note we do this after setting the timer:\n // this lets the unit tests advance the mock\n // clock when they get the error.\n this.updateSyncState(SyncState.Error, { error: err });\n }\n },\n );\n }\n\n private mapSyncResponseToRoomArray(\n obj: Record,\n ): Array> {\n // Maps { roomid: {stuff}, roomid: {stuff} }\n // to\n // [{stuff+Room+isBrandNewRoom}, {stuff+Room+isBrandNewRoom}]\n const client = this.client;\n return Object.keys(obj)\n .filter((k) => !unsafeProp(k))\n .map((roomId) => {\n const arrObj = obj[roomId] as T & { room: Room; isBrandNewRoom: boolean };\n let room = client.store.getRoom(roomId);\n let isBrandNewRoom = false;\n if (!room) {\n room = this.createRoom(roomId);\n isBrandNewRoom = true;\n }\n arrObj.room = room;\n arrObj.isBrandNewRoom = isBrandNewRoom;\n return arrObj;\n });\n }\n\n private mapSyncEventsFormat(\n obj: IInviteState | ITimeline | IEphemeral,\n room?: Room,\n decrypt = true,\n ): MatrixEvent[] {\n if (!obj || !Array.isArray(obj.events)) {\n return [];\n }\n const mapper = this.client.getEventMapper({ decrypt });\n type TaggedEvent = (IStrippedState | IRoomEvent | IStateEvent | IMinimalEvent) & { room_id?: string };\n return (obj.events as TaggedEvent[]).filter(noUnsafeEventProps).map(function (e) {\n if (room) {\n e.room_id = room.roomId;\n }\n return mapper(e);\n });\n }\n\n /**\n */\n private resolveInvites(room: Room): void {\n if (!room || !this.opts.resolveInvitesToProfiles) {\n return;\n }\n const client = this.client;\n // For each invited room member we want to give them a displayname/avatar url\n // if they have one (the m.room.member invites don't contain this).\n room.getMembersWithMembership(\"invite\").forEach(function (member) {\n if (member.requestedProfileInfo) return;\n member.requestedProfileInfo = true;\n // try to get a cached copy first.\n const user = client.getUser(member.userId);\n let promise;\n if (user) {\n promise = Promise.resolve({\n avatar_url: user.avatarUrl,\n displayname: user.displayName,\n });\n } else {\n promise = client.getProfileInfo(member.userId);\n }\n promise.then(\n function (info) {\n // slightly naughty by doctoring the invite event but this means all\n // the code paths remain the same between invite/join display name stuff\n // which is a worthy trade-off for some minor pollution.\n const inviteEvent = member.events.member;\n if (inviteEvent?.getContent().membership !== \"invite\") {\n // between resolving and now they have since joined, so don't clobber\n return;\n }\n inviteEvent.getContent().avatar_url = info.avatar_url;\n inviteEvent.getContent().displayname = info.displayname;\n // fire listeners\n member.setMembershipEvent(inviteEvent, room.currentState);\n },\n function (err) {\n // OH WELL.\n },\n );\n });\n }\n\n /**\n * Injects events into a room's model.\n * @param stateEventList - A list of state events. This is the state\n * at the *START* of the timeline list if it is supplied.\n * @param timelineEventList - A list of timeline events, including threaded. Lower index\n * is earlier in time. Higher index is later.\n * @param fromCache - whether the sync response came from cache\n */\n public async injectRoomEvents(\n room: Room,\n stateEventList: MatrixEvent[],\n timelineEventList?: MatrixEvent[],\n fromCache = false,\n ): Promise {\n // If there are no events in the timeline yet, initialise it with\n // the given state events\n const liveTimeline = room.getLiveTimeline();\n const timelineWasEmpty = liveTimeline.getEvents().length == 0;\n if (timelineWasEmpty) {\n // Passing these events into initialiseState will freeze them, so we need\n // to compute and cache the push actions for them now, otherwise sync dies\n // with an attempt to assign to read only property.\n // XXX: This is pretty horrible and is assuming all sorts of behaviour from\n // these functions that it shouldn't be. We should probably either store the\n // push actions cache elsewhere so we can freeze MatrixEvents, or otherwise\n // find some solution where MatrixEvents are immutable but allow for a cache\n // field.\n for (const ev of stateEventList) {\n this.client.getPushActionsForEvent(ev);\n }\n liveTimeline.initialiseState(stateEventList, {\n timelineWasEmpty,\n });\n }\n\n this.resolveInvites(room);\n\n // recalculate the room name at this point as adding events to the timeline\n // may make notifications appear which should have the right name.\n // XXX: This looks suspect: we'll end up recalculating the room once here\n // and then again after adding events (processSyncResponse calls it after\n // calling us) even if no state events were added. It also means that if\n // one of the room events in timelineEventList is something that needs\n // a recalculation (like m.room.name) we won't recalculate until we've\n // finished adding all the events, which will cause the notification to have\n // the old room name rather than the new one.\n room.recalculate();\n\n // If the timeline wasn't empty, we process the state events here: they're\n // defined as updates to the state before the start of the timeline, so this\n // starts to roll the state forward.\n // XXX: That's what we *should* do, but this can happen if we were previously\n // peeking in a room, in which case we obviously do *not* want to add the\n // state events here onto the end of the timeline. Historically, the js-sdk\n // has just set these new state events on the old and new state. This seems\n // very wrong because there could be events in the timeline that diverge the\n // state, in which case this is going to leave things out of sync. However,\n // for now I think it;s best to behave the same as the code has done previously.\n if (!timelineWasEmpty) {\n // XXX: As above, don't do this...\n //room.addLiveEvents(stateEventList || []);\n // Do this instead...\n room.oldState.setStateEvents(stateEventList || []);\n room.currentState.setStateEvents(stateEventList || []);\n }\n\n // Execute the timeline events. This will continue to diverge the current state\n // if the timeline has any state events in it.\n // This also needs to be done before running push rules on the events as they need\n // to be decorated with sender etc.\n room.addLiveEvents(timelineEventList || [], {\n fromCache,\n timelineWasEmpty,\n });\n this.client.processBeaconEvents(room, timelineEventList);\n }\n\n /**\n * Takes a list of timelineEvents and adds and adds to notifEvents\n * as appropriate.\n * This must be called after the room the events belong to has been stored.\n *\n * @param timelineEventList - A list of timeline events. Lower index\n * is earlier in time. Higher index is later.\n */\n private processEventsForNotifs(room: Room, timelineEventList: MatrixEvent[]): void {\n // gather our notifications into this.notifEvents\n if (this.client.getNotifTimelineSet()) {\n for (const event of timelineEventList) {\n const pushActions = this.client.getPushActionsForEvent(event);\n if (pushActions?.notify && pushActions.tweaks?.highlight) {\n this.notifEvents.push(event);\n }\n }\n }\n }\n\n private getGuestFilter(): string {\n // Dev note: This used to be conditional to return a filter of 20 events maximum, but\n // the condition never went to the other branch. This is now hardcoded.\n return \"{}\";\n }\n\n /**\n * Sets the sync state and emits an event to say so\n * @param newState - The new state string\n * @param data - Object of additional data to emit in the event\n */\n private updateSyncState(newState: SyncState, data?: ISyncStateData): void {\n const old = this.syncState;\n this.syncState = newState;\n this.syncStateData = data;\n this.client.emit(ClientEvent.Sync, this.syncState, old, data);\n }\n\n /**\n * Event handler for the 'online' event\n * This event is generally unreliable and precise behaviour\n * varies between browsers, so we poll for connectivity too,\n * but this might help us reconnect a little faster.\n */\n private onOnline = (): void => {\n debuglog(\"Browser thinks we are back online\");\n this.startKeepAlives(0);\n };\n}\n\nfunction createNewUser(client: MatrixClient, userId: string): User {\n const user = new User(userId);\n client.reEmitter.reEmit(user, [\n UserEvent.AvatarUrl,\n UserEvent.DisplayName,\n UserEvent.Presence,\n UserEvent.CurrentlyActive,\n UserEvent.LastPresenceTs,\n ]);\n return user;\n}\n\n// /!\\ This function is not intended for public use! It's only exported from\n// here in order to share some common logic with sliding-sync-sdk.ts.\nexport function _createAndReEmitRoom(client: MatrixClient, roomId: string, opts: Partial): Room {\n const { timelineSupport } = client;\n\n const room = new Room(roomId, client, client.getUserId()!, {\n lazyLoadMembers: opts.lazyLoadMembers,\n pendingEventOrdering: opts.pendingEventOrdering,\n timelineSupport,\n });\n\n client.reEmitter.reEmit(room, [\n RoomEvent.Name,\n RoomEvent.Redaction,\n RoomEvent.RedactionCancelled,\n RoomEvent.Receipt,\n RoomEvent.Tags,\n RoomEvent.LocalEchoUpdated,\n RoomEvent.AccountData,\n RoomEvent.MyMembership,\n RoomEvent.Timeline,\n RoomEvent.TimelineReset,\n RoomStateEvent.Events,\n RoomStateEvent.Members,\n RoomStateEvent.NewMember,\n RoomStateEvent.Update,\n BeaconEvent.New,\n BeaconEvent.Update,\n BeaconEvent.Destroy,\n BeaconEvent.LivenessChange,\n ]);\n\n // We need to add a listener for RoomState.members in order to hook them\n // correctly.\n room.on(RoomStateEvent.NewMember, (event, state, member) => {\n member.user = client.getUser(member.userId) ?? undefined;\n client.reEmitter.reEmit(member, [\n RoomMemberEvent.Name,\n RoomMemberEvent.Typing,\n RoomMemberEvent.PowerLevel,\n RoomMemberEvent.Membership,\n ]);\n });\n\n return room;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts deleted file mode 100644 index 46a9fb0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts +++ /dev/null @@ -1,158 +0,0 @@ -import { Direction, EventTimeline } from "./models/event-timeline"; -import { MatrixClient } from "./client"; -import { EventTimelineSet } from "./models/event-timeline-set"; -import { MatrixEvent } from "./models/event"; -interface IOpts { - /** - * Maximum number of events to keep in the window. If more events are retrieved via pagination requests, - * excess events will be dropped from the other end of the window. - */ - windowLimit?: number; -} -export declare class TimelineWindow { - private readonly client; - private readonly timelineSet; - private readonly windowLimit; - private start?; - private end?; - private eventCount; - /** - * Construct a TimelineWindow. - * - *

This abstracts the separate timelines in a Matrix {@link Room} into a single iterable thing. - * It keeps track of the start and endpoints of the window, which can be advanced with the help - * of pagination requests. - * - *

Before the window is useful, it must be initialised by calling {@link TimelineWindow#load}. - * - *

Note that the window will not automatically extend itself when new events - * are received from /sync; you should arrange to call {@link TimelineWindow#paginate} - * on {@link RoomEvent.Timeline} events. - * - * @param client - MatrixClient to be used for context/pagination - * requests. - * - * @param timelineSet - The timelineSet to track - * - * @param opts - Configuration options for this window - */ - constructor(client: MatrixClient, timelineSet: EventTimelineSet, opts?: IOpts); - /** - * Initialise the window to point at a given event, or the live timeline - * - * @param initialEventId - If given, the window will contain the - * given event - * @param initialWindowSize - Size of the initial window - */ - load(initialEventId?: string, initialWindowSize?: number): Promise; - /** - * Get the TimelineIndex of the window in the given direction. - * - * @param direction - EventTimeline.BACKWARDS to get the TimelineIndex - * at the start of the window; EventTimeline.FORWARDS to get the TimelineIndex at - * the end. - * - * @returns The requested timeline index if one exists, null - * otherwise. - */ - getTimelineIndex(direction: Direction): TimelineIndex | null; - /** - * Try to extend the window using events that are already in the underlying - * TimelineIndex. - * - * @param direction - EventTimeline.BACKWARDS to try extending it - * backwards; EventTimeline.FORWARDS to try extending it forwards. - * @param size - number of events to try to extend by. - * - * @returns true if the window was extended, false otherwise. - */ - extend(direction: Direction, size: number): boolean; - /** - * Check if this window can be extended - * - *

This returns true if we either have more events, or if we have a - * pagination token which means we can paginate in that direction. It does not - * necessarily mean that there are more events available in that direction at - * this time. - * - * @param direction - EventTimeline.BACKWARDS to check if we can - * paginate backwards; EventTimeline.FORWARDS to check if we can go forwards - * - * @returns true if we can paginate in the given direction - */ - canPaginate(direction: Direction): boolean; - /** - * Attempt to extend the window - * - * @param direction - EventTimeline.BACKWARDS to extend the window - * backwards (towards older events); EventTimeline.FORWARDS to go forwards. - * - * @param size - number of events to try to extend by. If fewer than this - * number are immediately available, then we return immediately rather than - * making an API call. - * - * @param makeRequest - whether we should make API calls to - * fetch further events if we don't have any at all. (This has no effect if - * the room already knows about additional events in the relevant direction, - * even if there are fewer than 'size' of them, as we will just return those - * we already know about.) - * - * @param requestLimit - limit for the number of API requests we - * should make. - * - * @returns Promise which resolves to a boolean which is true if more events - * were successfully retrieved. - */ - paginate(direction: Direction, size: number, makeRequest?: boolean, requestLimit?: number): Promise; - /** - * Remove `delta` events from the start or end of the timeline. - * - * @param delta - number of events to remove from the timeline - * @param startOfTimeline - if events should be removed from the start - * of the timeline. - */ - unpaginate(delta: number, startOfTimeline: boolean): void; - /** - * Get a list of the events currently in the window - * - * @returns the events in the window - */ - getEvents(): MatrixEvent[]; -} -/** - * A thing which contains a timeline reference, and an index into it. - * @internal - */ -export declare class TimelineIndex { - timeline: EventTimeline; - index: number; - pendingPaginate?: Promise; - constructor(timeline: EventTimeline, index: number); - /** - * @returns the minimum possible value for the index in the current - * timeline - */ - minIndex(): number; - /** - * @returns the maximum possible value for the index in the current - * timeline (exclusive - ie, it actually returns one more than the index - * of the last element). - */ - maxIndex(): number; - /** - * Try move the index forward, or into the neighbouring timeline - * - * @param delta - number of events to advance by - * @returns number of events successfully advanced by - */ - advance(delta: number): number; - /** - * Try move the index backwards, or into the neighbouring timeline - * - * @param delta - number of events to retreat by - * @returns number of events successfully retreated by - */ - retreat(delta: number): number; -} -export {}; -//# sourceMappingURL=timeline-window.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts.map deleted file mode 100644 index 63a6541..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"timeline-window.d.ts","sourceRoot":"","sources":["../src/timeline-window.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAEnE,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAoB7C,UAAU,KAAK;IACX;;;OAGG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,qBAAa,cAAc;IA+BnB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,WAAW;IA/BhC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IAKrC,OAAO,CAAC,KAAK,CAAC,CAAgB;IAC9B,OAAO,CAAC,GAAG,CAAC,CAAgB;IAC5B,OAAO,CAAC,UAAU,CAAK;IAEvB;;;;;;;;;;;;;;;;;;;OAmBG;gBAEkB,MAAM,EAAE,YAAY,EACpB,WAAW,EAAE,gBAAgB,EAC9C,IAAI,GAAE,KAAU;IAKpB;;;;;;OAMG;IACI,IAAI,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,iBAAiB,SAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IA2C3E;;;;;;;;;OASG;IACI,gBAAgB,CAAC,SAAS,EAAE,SAAS,GAAG,aAAa,GAAG,IAAI;IAUnE;;;;;;;;;OASG;IACI,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO;IAwB1D;;;;;;;;;;;;OAYG;IACI,WAAW,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO;IAuBjD;;;;;;;;;;;;;;;;;;;;;OAqBG;IACU,QAAQ,CACjB,SAAS,EAAE,SAAS,EACpB,IAAI,EAAE,MAAM,EACZ,WAAW,UAAO,EAClB,YAAY,SAA8B,GAC3C,OAAO,CAAC,OAAO,CAAC;IAkEnB;;;;;;OAMG;IACI,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,OAAO,GAAG,IAAI;IA4BhE;;;;OAIG;IACI,SAAS,IAAI,WAAW,EAAE;CA8CpC;AAED;;;GAGG;AACH,qBAAa,aAAa;IAII,QAAQ,EAAE,aAAa;IAAS,KAAK,EAAE,MAAM;IAHhE,eAAe,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;gBAGhB,QAAQ,EAAE,aAAa,EAAS,KAAK,EAAE,MAAM;IAEvE;;;OAGG;IACI,QAAQ,IAAI,MAAM;IAIzB;;;;OAIG;IACI,QAAQ,IAAI,MAAM;IAIzB;;;;;OAKG;IACI,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAuDrC;;;;;OAKG;IACI,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;CAGxC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js deleted file mode 100644 index cc7f455..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js +++ /dev/null @@ -1,468 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TimelineWindow = exports.TimelineIndex = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _eventTimeline = require("./models/event-timeline"); -var _logger = require("./logger"); -/* -Copyright 2016 - 2021 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -/** - * @internal - */ -const DEBUG = false; - -/** - * @internal - */ -/* istanbul ignore next */ -const debuglog = DEBUG ? _logger.logger.log.bind(_logger.logger) : function () {}; - -/** - * the number of times we ask the server for more events before giving up - * - * @internal - */ -const DEFAULT_PAGINATE_LOOP_LIMIT = 5; -class TimelineWindow { - // these will be TimelineIndex objects; they delineate the 'start' and - // 'end' of the window. - // - // start.index is inclusive; end.index is exclusive. - - /** - * Construct a TimelineWindow. - * - *

This abstracts the separate timelines in a Matrix {@link Room} into a single iterable thing. - * It keeps track of the start and endpoints of the window, which can be advanced with the help - * of pagination requests. - * - *

Before the window is useful, it must be initialised by calling {@link TimelineWindow#load}. - * - *

Note that the window will not automatically extend itself when new events - * are received from /sync; you should arrange to call {@link TimelineWindow#paginate} - * on {@link RoomEvent.Timeline} events. - * - * @param client - MatrixClient to be used for context/pagination - * requests. - * - * @param timelineSet - The timelineSet to track - * - * @param opts - Configuration options for this window - */ - constructor(client, timelineSet, opts = {}) { - this.client = client; - this.timelineSet = timelineSet; - (0, _defineProperty2.default)(this, "windowLimit", void 0); - (0, _defineProperty2.default)(this, "start", void 0); - (0, _defineProperty2.default)(this, "end", void 0); - (0, _defineProperty2.default)(this, "eventCount", 0); - this.windowLimit = opts.windowLimit || 1000; - } - - /** - * Initialise the window to point at a given event, or the live timeline - * - * @param initialEventId - If given, the window will contain the - * given event - * @param initialWindowSize - Size of the initial window - */ - load(initialEventId, initialWindowSize = 20) { - // given an EventTimeline, find the event we were looking for, and initialise our - // fields so that the event in question is in the middle of the window. - const initFields = timeline => { - if (!timeline) { - throw new Error("No timeline given to initFields"); - } - let eventIndex; - const events = timeline.getEvents(); - if (!initialEventId) { - // we were looking for the live timeline: initialise to the end - eventIndex = events.length; - } else { - eventIndex = events.findIndex(e => e.getId() === initialEventId); - if (eventIndex < 0) { - throw new Error("getEventTimeline result didn't include requested event"); - } - } - const endIndex = Math.min(events.length, eventIndex + Math.ceil(initialWindowSize / 2)); - const startIndex = Math.max(0, endIndex - initialWindowSize); - this.start = new TimelineIndex(timeline, startIndex - timeline.getBaseIndex()); - this.end = new TimelineIndex(timeline, endIndex - timeline.getBaseIndex()); - this.eventCount = endIndex - startIndex; - }; - - // We avoid delaying the resolution of the promise by a reactor tick if we already have the data we need, - // which is important to keep room-switching feeling snappy. - if (this.timelineSet.getTimelineForEvent(initialEventId)) { - initFields(this.timelineSet.getTimelineForEvent(initialEventId)); - return Promise.resolve(); - } else if (initialEventId) { - return this.client.getEventTimeline(this.timelineSet, initialEventId).then(initFields); - } else { - initFields(this.timelineSet.getLiveTimeline()); - return Promise.resolve(); - } - } - - /** - * Get the TimelineIndex of the window in the given direction. - * - * @param direction - EventTimeline.BACKWARDS to get the TimelineIndex - * at the start of the window; EventTimeline.FORWARDS to get the TimelineIndex at - * the end. - * - * @returns The requested timeline index if one exists, null - * otherwise. - */ - getTimelineIndex(direction) { - if (direction == _eventTimeline.EventTimeline.BACKWARDS) { - var _this$start; - return (_this$start = this.start) !== null && _this$start !== void 0 ? _this$start : null; - } else if (direction == _eventTimeline.EventTimeline.FORWARDS) { - var _this$end; - return (_this$end = this.end) !== null && _this$end !== void 0 ? _this$end : null; - } else { - throw new Error("Invalid direction '" + direction + "'"); - } - } - - /** - * Try to extend the window using events that are already in the underlying - * TimelineIndex. - * - * @param direction - EventTimeline.BACKWARDS to try extending it - * backwards; EventTimeline.FORWARDS to try extending it forwards. - * @param size - number of events to try to extend by. - * - * @returns true if the window was extended, false otherwise. - */ - extend(direction, size) { - const tl = this.getTimelineIndex(direction); - if (!tl) { - debuglog("TimelineWindow: no timeline yet"); - return false; - } - const count = direction == _eventTimeline.EventTimeline.BACKWARDS ? tl.retreat(size) : tl.advance(size); - if (count) { - this.eventCount += count; - debuglog("TimelineWindow: increased cap by " + count + " (now " + this.eventCount + ")"); - // remove some events from the other end, if necessary - const excess = this.eventCount - this.windowLimit; - if (excess > 0) { - this.unpaginate(excess, direction != _eventTimeline.EventTimeline.BACKWARDS); - } - return true; - } - return false; - } - - /** - * Check if this window can be extended - * - *

This returns true if we either have more events, or if we have a - * pagination token which means we can paginate in that direction. It does not - * necessarily mean that there are more events available in that direction at - * this time. - * - * @param direction - EventTimeline.BACKWARDS to check if we can - * paginate backwards; EventTimeline.FORWARDS to check if we can go forwards - * - * @returns true if we can paginate in the given direction - */ - canPaginate(direction) { - const tl = this.getTimelineIndex(direction); - if (!tl) { - debuglog("TimelineWindow: no timeline yet"); - return false; - } - if (direction == _eventTimeline.EventTimeline.BACKWARDS) { - if (tl.index > tl.minIndex()) { - return true; - } - } else { - if (tl.index < tl.maxIndex()) { - return true; - } - } - const hasNeighbouringTimeline = tl.timeline.getNeighbouringTimeline(direction); - const paginationToken = tl.timeline.getPaginationToken(direction); - return Boolean(hasNeighbouringTimeline) || Boolean(paginationToken); - } - - /** - * Attempt to extend the window - * - * @param direction - EventTimeline.BACKWARDS to extend the window - * backwards (towards older events); EventTimeline.FORWARDS to go forwards. - * - * @param size - number of events to try to extend by. If fewer than this - * number are immediately available, then we return immediately rather than - * making an API call. - * - * @param makeRequest - whether we should make API calls to - * fetch further events if we don't have any at all. (This has no effect if - * the room already knows about additional events in the relevant direction, - * even if there are fewer than 'size' of them, as we will just return those - * we already know about.) - * - * @param requestLimit - limit for the number of API requests we - * should make. - * - * @returns Promise which resolves to a boolean which is true if more events - * were successfully retrieved. - */ - async paginate(direction, size, makeRequest = true, requestLimit = DEFAULT_PAGINATE_LOOP_LIMIT) { - // Either wind back the message cap (if there are enough events in the - // timeline to do so), or fire off a pagination request. - const tl = this.getTimelineIndex(direction); - if (!tl) { - debuglog("TimelineWindow: no timeline yet"); - return false; - } - if (tl.pendingPaginate) { - return tl.pendingPaginate; - } - - // try moving the cap - if (this.extend(direction, size)) { - return true; - } - if (!makeRequest || requestLimit === 0) { - // todo: should we return something different to indicate that there - // might be more events out there, but we haven't found them yet? - return false; - } - - // try making a pagination request - const token = tl.timeline.getPaginationToken(direction); - if (!token) { - debuglog("TimelineWindow: no token"); - return false; - } - debuglog("TimelineWindow: starting request"); - const prom = this.client.paginateEventTimeline(tl.timeline, { - backwards: direction == _eventTimeline.EventTimeline.BACKWARDS, - limit: size - }).finally(function () { - tl.pendingPaginate = undefined; - }).then(r => { - debuglog("TimelineWindow: request completed with result " + r); - if (!r) { - return this.paginate(direction, size, false, 0); - } - - // recurse to advance the index into the results. - // - // If we don't get any new events, we want to make sure we keep asking - // the server for events for as long as we have a valid pagination - // token. In particular, we want to know if we've actually hit the - // start of the timeline, or if we just happened to know about all of - // the events thanks to https://matrix.org/jira/browse/SYN-645. - // - // On the other hand, we necessarily want to wait forever for the - // server to make its mind up about whether there are other events, - // because it gives a bad user experience - // (https://github.com/vector-im/vector-web/issues/1204). - return this.paginate(direction, size, true, requestLimit - 1); - }); - tl.pendingPaginate = prom; - return prom; - } - - /** - * Remove `delta` events from the start or end of the timeline. - * - * @param delta - number of events to remove from the timeline - * @param startOfTimeline - if events should be removed from the start - * of the timeline. - */ - unpaginate(delta, startOfTimeline) { - const tl = startOfTimeline ? this.start : this.end; - if (!tl) { - throw new Error(`Attempting to unpaginate startOfTimeline=${startOfTimeline} but don't have this direction`); - } - - // sanity-check the delta - if (delta > this.eventCount || delta < 0) { - throw new Error(`Attemting to unpaginate ${delta} events, but only have ${this.eventCount} in the timeline`); - } - while (delta > 0) { - const count = startOfTimeline ? tl.advance(delta) : tl.retreat(delta); - if (count <= 0) { - // sadness. This shouldn't be possible. - throw new Error("Unable to unpaginate any further, but still have " + this.eventCount + " events"); - } - delta -= count; - this.eventCount -= count; - debuglog("TimelineWindow.unpaginate: dropped " + count + " (now " + this.eventCount + ")"); - } - } - - /** - * Get a list of the events currently in the window - * - * @returns the events in the window - */ - getEvents() { - if (!this.start) { - // not yet loaded - return []; - } - const result = []; - - // iterate through each timeline between this.start and this.end - // (inclusive). - let timeline = this.start.timeline; - // eslint-disable-next-line no-constant-condition - while (true) { - var _this$end2, _this$end3; - const events = timeline.getEvents(); - - // For the first timeline in the chain, we want to start at - // this.start.index. For the last timeline in the chain, we want to - // stop before this.end.index. Otherwise, we want to copy all of the - // events in the timeline. - // - // (Note that both this.start.index and this.end.index are relative - // to their respective timelines' BaseIndex). - // - let startIndex = 0; - let endIndex = events.length; - if (timeline === this.start.timeline) { - startIndex = this.start.index + timeline.getBaseIndex(); - } - if (timeline === ((_this$end2 = this.end) === null || _this$end2 === void 0 ? void 0 : _this$end2.timeline)) { - endIndex = this.end.index + timeline.getBaseIndex(); - } - for (let i = startIndex; i < endIndex; i++) { - result.push(events[i]); - } - - // if we're not done, iterate to the next timeline. - if (timeline === ((_this$end3 = this.end) === null || _this$end3 === void 0 ? void 0 : _this$end3.timeline)) { - break; - } else { - timeline = timeline.getNeighbouringTimeline(_eventTimeline.EventTimeline.FORWARDS); - } - } - return result; - } -} - -/** - * A thing which contains a timeline reference, and an index into it. - * @internal - */ -exports.TimelineWindow = TimelineWindow; -class TimelineIndex { - // index: the indexes are relative to BaseIndex, so could well be negative. - constructor(timeline, index) { - this.timeline = timeline; - this.index = index; - (0, _defineProperty2.default)(this, "pendingPaginate", void 0); - } - - /** - * @returns the minimum possible value for the index in the current - * timeline - */ - minIndex() { - return this.timeline.getBaseIndex() * -1; - } - - /** - * @returns the maximum possible value for the index in the current - * timeline (exclusive - ie, it actually returns one more than the index - * of the last element). - */ - maxIndex() { - return this.timeline.getEvents().length - this.timeline.getBaseIndex(); - } - - /** - * Try move the index forward, or into the neighbouring timeline - * - * @param delta - number of events to advance by - * @returns number of events successfully advanced by - */ - advance(delta) { - if (!delta) { - return 0; - } - - // first try moving the index in the current timeline. See if there is room - // to do so. - let cappedDelta; - if (delta < 0) { - // we want to wind the index backwards. - // - // (this.minIndex() - this.index) is a negative number whose magnitude - // is the amount of room we have to wind back the index in the current - // timeline. We cap delta to this quantity. - cappedDelta = Math.max(delta, this.minIndex() - this.index); - if (cappedDelta < 0) { - this.index += cappedDelta; - return cappedDelta; - } - } else { - // we want to wind the index forwards. - // - // (this.maxIndex() - this.index) is a (positive) number whose magnitude - // is the amount of room we have to wind forward the index in the current - // timeline. We cap delta to this quantity. - cappedDelta = Math.min(delta, this.maxIndex() - this.index); - if (cappedDelta > 0) { - this.index += cappedDelta; - return cappedDelta; - } - } - - // the index is already at the start/end of the current timeline. - // - // next see if there is a neighbouring timeline to switch to. - const neighbour = this.timeline.getNeighbouringTimeline(delta < 0 ? _eventTimeline.EventTimeline.BACKWARDS : _eventTimeline.EventTimeline.FORWARDS); - if (neighbour) { - this.timeline = neighbour; - if (delta < 0) { - this.index = this.maxIndex(); - } else { - this.index = this.minIndex(); - } - debuglog("paginate: switched to new neighbour"); - - // recurse, using the next timeline - return this.advance(delta); - } - return 0; - } - - /** - * Try move the index backwards, or into the neighbouring timeline - * - * @param delta - number of events to retreat by - * @returns number of events successfully retreated by - */ - retreat(delta) { - return this.advance(delta * -1) * -1; - } -} -exports.TimelineIndex = TimelineIndex; -//# sourceMappingURL=timeline-window.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js.map deleted file mode 100644 index 8913ed0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/timeline-window.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"timeline-window.js","names":["_eventTimeline","require","_logger","DEBUG","debuglog","logger","log","bind","DEFAULT_PAGINATE_LOOP_LIMIT","TimelineWindow","constructor","client","timelineSet","opts","_defineProperty2","default","windowLimit","load","initialEventId","initialWindowSize","initFields","timeline","Error","eventIndex","events","getEvents","length","findIndex","e","getId","endIndex","Math","min","ceil","startIndex","max","start","TimelineIndex","getBaseIndex","end","eventCount","getTimelineForEvent","Promise","resolve","getEventTimeline","then","getLiveTimeline","getTimelineIndex","direction","EventTimeline","BACKWARDS","_this$start","FORWARDS","_this$end","extend","size","tl","count","retreat","advance","excess","unpaginate","canPaginate","index","minIndex","maxIndex","hasNeighbouringTimeline","getNeighbouringTimeline","paginationToken","getPaginationToken","Boolean","paginate","makeRequest","requestLimit","pendingPaginate","token","prom","paginateEventTimeline","backwards","limit","finally","undefined","r","delta","startOfTimeline","result","_this$end2","_this$end3","i","push","exports","cappedDelta","neighbour"],"sources":["../src/timeline-window.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { Optional } from \"matrix-events-sdk\";\n\nimport { Direction, EventTimeline } from \"./models/event-timeline\";\nimport { logger } from \"./logger\";\nimport { MatrixClient } from \"./client\";\nimport { EventTimelineSet } from \"./models/event-timeline-set\";\nimport { MatrixEvent } from \"./models/event\";\n\n/**\n * @internal\n */\nconst DEBUG = false;\n\n/**\n * @internal\n */\n/* istanbul ignore next */\nconst debuglog = DEBUG ? logger.log.bind(logger) : function (): void {};\n\n/**\n * the number of times we ask the server for more events before giving up\n *\n * @internal\n */\nconst DEFAULT_PAGINATE_LOOP_LIMIT = 5;\n\ninterface IOpts {\n /**\n * Maximum number of events to keep in the window. If more events are retrieved via pagination requests,\n * excess events will be dropped from the other end of the window.\n */\n windowLimit?: number;\n}\n\nexport class TimelineWindow {\n private readonly windowLimit: number;\n // these will be TimelineIndex objects; they delineate the 'start' and\n // 'end' of the window.\n //\n // start.index is inclusive; end.index is exclusive.\n private start?: TimelineIndex;\n private end?: TimelineIndex;\n private eventCount = 0;\n\n /**\n * Construct a TimelineWindow.\n *\n *

This abstracts the separate timelines in a Matrix {@link Room} into a single iterable thing.\n * It keeps track of the start and endpoints of the window, which can be advanced with the help\n * of pagination requests.\n *\n *

Before the window is useful, it must be initialised by calling {@link TimelineWindow#load}.\n *\n *

Note that the window will not automatically extend itself when new events\n * are received from /sync; you should arrange to call {@link TimelineWindow#paginate}\n * on {@link RoomEvent.Timeline} events.\n *\n * @param client - MatrixClient to be used for context/pagination\n * requests.\n *\n * @param timelineSet - The timelineSet to track\n *\n * @param opts - Configuration options for this window\n */\n public constructor(\n private readonly client: MatrixClient,\n private readonly timelineSet: EventTimelineSet,\n opts: IOpts = {},\n ) {\n this.windowLimit = opts.windowLimit || 1000;\n }\n\n /**\n * Initialise the window to point at a given event, or the live timeline\n *\n * @param initialEventId - If given, the window will contain the\n * given event\n * @param initialWindowSize - Size of the initial window\n */\n public load(initialEventId?: string, initialWindowSize = 20): Promise {\n // given an EventTimeline, find the event we were looking for, and initialise our\n // fields so that the event in question is in the middle of the window.\n const initFields = (timeline: Optional): void => {\n if (!timeline) {\n throw new Error(\"No timeline given to initFields\");\n }\n\n let eventIndex: number;\n\n const events = timeline.getEvents();\n\n if (!initialEventId) {\n // we were looking for the live timeline: initialise to the end\n eventIndex = events.length;\n } else {\n eventIndex = events.findIndex((e) => e.getId() === initialEventId);\n\n if (eventIndex < 0) {\n throw new Error(\"getEventTimeline result didn't include requested event\");\n }\n }\n\n const endIndex = Math.min(events.length, eventIndex + Math.ceil(initialWindowSize / 2));\n const startIndex = Math.max(0, endIndex - initialWindowSize);\n this.start = new TimelineIndex(timeline, startIndex - timeline.getBaseIndex());\n this.end = new TimelineIndex(timeline, endIndex - timeline.getBaseIndex());\n this.eventCount = endIndex - startIndex;\n };\n\n // We avoid delaying the resolution of the promise by a reactor tick if we already have the data we need,\n // which is important to keep room-switching feeling snappy.\n if (this.timelineSet.getTimelineForEvent(initialEventId)) {\n initFields(this.timelineSet.getTimelineForEvent(initialEventId));\n return Promise.resolve();\n } else if (initialEventId) {\n return this.client.getEventTimeline(this.timelineSet, initialEventId).then(initFields);\n } else {\n initFields(this.timelineSet.getLiveTimeline());\n return Promise.resolve();\n }\n }\n\n /**\n * Get the TimelineIndex of the window in the given direction.\n *\n * @param direction - EventTimeline.BACKWARDS to get the TimelineIndex\n * at the start of the window; EventTimeline.FORWARDS to get the TimelineIndex at\n * the end.\n *\n * @returns The requested timeline index if one exists, null\n * otherwise.\n */\n public getTimelineIndex(direction: Direction): TimelineIndex | null {\n if (direction == EventTimeline.BACKWARDS) {\n return this.start ?? null;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.end ?? null;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Try to extend the window using events that are already in the underlying\n * TimelineIndex.\n *\n * @param direction - EventTimeline.BACKWARDS to try extending it\n * backwards; EventTimeline.FORWARDS to try extending it forwards.\n * @param size - number of events to try to extend by.\n *\n * @returns true if the window was extended, false otherwise.\n */\n public extend(direction: Direction, size: number): boolean {\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n const count = direction == EventTimeline.BACKWARDS ? tl.retreat(size) : tl.advance(size);\n\n if (count) {\n this.eventCount += count;\n debuglog(\"TimelineWindow: increased cap by \" + count + \" (now \" + this.eventCount + \")\");\n // remove some events from the other end, if necessary\n const excess = this.eventCount - this.windowLimit;\n if (excess > 0) {\n this.unpaginate(excess, direction != EventTimeline.BACKWARDS);\n }\n return true;\n }\n\n return false;\n }\n\n /**\n * Check if this window can be extended\n *\n *

This returns true if we either have more events, or if we have a\n * pagination token which means we can paginate in that direction. It does not\n * necessarily mean that there are more events available in that direction at\n * this time.\n *\n * @param direction - EventTimeline.BACKWARDS to check if we can\n * paginate backwards; EventTimeline.FORWARDS to check if we can go forwards\n *\n * @returns true if we can paginate in the given direction\n */\n public canPaginate(direction: Direction): boolean {\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n if (direction == EventTimeline.BACKWARDS) {\n if (tl.index > tl.minIndex()) {\n return true;\n }\n } else {\n if (tl.index < tl.maxIndex()) {\n return true;\n }\n }\n\n const hasNeighbouringTimeline = tl.timeline.getNeighbouringTimeline(direction);\n const paginationToken = tl.timeline.getPaginationToken(direction);\n return Boolean(hasNeighbouringTimeline) || Boolean(paginationToken);\n }\n\n /**\n * Attempt to extend the window\n *\n * @param direction - EventTimeline.BACKWARDS to extend the window\n * backwards (towards older events); EventTimeline.FORWARDS to go forwards.\n *\n * @param size - number of events to try to extend by. If fewer than this\n * number are immediately available, then we return immediately rather than\n * making an API call.\n *\n * @param makeRequest - whether we should make API calls to\n * fetch further events if we don't have any at all. (This has no effect if\n * the room already knows about additional events in the relevant direction,\n * even if there are fewer than 'size' of them, as we will just return those\n * we already know about.)\n *\n * @param requestLimit - limit for the number of API requests we\n * should make.\n *\n * @returns Promise which resolves to a boolean which is true if more events\n * were successfully retrieved.\n */\n public async paginate(\n direction: Direction,\n size: number,\n makeRequest = true,\n requestLimit = DEFAULT_PAGINATE_LOOP_LIMIT,\n ): Promise {\n // Either wind back the message cap (if there are enough events in the\n // timeline to do so), or fire off a pagination request.\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n if (tl.pendingPaginate) {\n return tl.pendingPaginate;\n }\n\n // try moving the cap\n if (this.extend(direction, size)) {\n return true;\n }\n\n if (!makeRequest || requestLimit === 0) {\n // todo: should we return something different to indicate that there\n // might be more events out there, but we haven't found them yet?\n return false;\n }\n\n // try making a pagination request\n const token = tl.timeline.getPaginationToken(direction);\n if (!token) {\n debuglog(\"TimelineWindow: no token\");\n return false;\n }\n\n debuglog(\"TimelineWindow: starting request\");\n\n const prom = this.client\n .paginateEventTimeline(tl.timeline, {\n backwards: direction == EventTimeline.BACKWARDS,\n limit: size,\n })\n .finally(function () {\n tl.pendingPaginate = undefined;\n })\n .then((r) => {\n debuglog(\"TimelineWindow: request completed with result \" + r);\n if (!r) {\n return this.paginate(direction, size, false, 0);\n }\n\n // recurse to advance the index into the results.\n //\n // If we don't get any new events, we want to make sure we keep asking\n // the server for events for as long as we have a valid pagination\n // token. In particular, we want to know if we've actually hit the\n // start of the timeline, or if we just happened to know about all of\n // the events thanks to https://matrix.org/jira/browse/SYN-645.\n //\n // On the other hand, we necessarily want to wait forever for the\n // server to make its mind up about whether there are other events,\n // because it gives a bad user experience\n // (https://github.com/vector-im/vector-web/issues/1204).\n return this.paginate(direction, size, true, requestLimit - 1);\n });\n tl.pendingPaginate = prom;\n return prom;\n }\n\n /**\n * Remove `delta` events from the start or end of the timeline.\n *\n * @param delta - number of events to remove from the timeline\n * @param startOfTimeline - if events should be removed from the start\n * of the timeline.\n */\n public unpaginate(delta: number, startOfTimeline: boolean): void {\n const tl = startOfTimeline ? this.start : this.end;\n if (!tl) {\n throw new Error(\n `Attempting to unpaginate startOfTimeline=${startOfTimeline} but don't have this direction`,\n );\n }\n\n // sanity-check the delta\n if (delta > this.eventCount || delta < 0) {\n throw new Error(\n `Attemting to unpaginate ${delta} events, but only have ${this.eventCount} in the timeline`,\n );\n }\n\n while (delta > 0) {\n const count = startOfTimeline ? tl.advance(delta) : tl.retreat(delta);\n if (count <= 0) {\n // sadness. This shouldn't be possible.\n throw new Error(\"Unable to unpaginate any further, but still have \" + this.eventCount + \" events\");\n }\n\n delta -= count;\n this.eventCount -= count;\n debuglog(\"TimelineWindow.unpaginate: dropped \" + count + \" (now \" + this.eventCount + \")\");\n }\n }\n\n /**\n * Get a list of the events currently in the window\n *\n * @returns the events in the window\n */\n public getEvents(): MatrixEvent[] {\n if (!this.start) {\n // not yet loaded\n return [];\n }\n\n const result: MatrixEvent[] = [];\n\n // iterate through each timeline between this.start and this.end\n // (inclusive).\n let timeline = this.start.timeline;\n // eslint-disable-next-line no-constant-condition\n while (true) {\n const events = timeline.getEvents();\n\n // For the first timeline in the chain, we want to start at\n // this.start.index. For the last timeline in the chain, we want to\n // stop before this.end.index. Otherwise, we want to copy all of the\n // events in the timeline.\n //\n // (Note that both this.start.index and this.end.index are relative\n // to their respective timelines' BaseIndex).\n //\n let startIndex = 0;\n let endIndex = events.length;\n if (timeline === this.start.timeline) {\n startIndex = this.start.index + timeline.getBaseIndex();\n }\n if (timeline === this.end?.timeline) {\n endIndex = this.end.index + timeline.getBaseIndex();\n }\n\n for (let i = startIndex; i < endIndex; i++) {\n result.push(events[i]);\n }\n\n // if we're not done, iterate to the next timeline.\n if (timeline === this.end?.timeline) {\n break;\n } else {\n timeline = timeline.getNeighbouringTimeline(EventTimeline.FORWARDS)!;\n }\n }\n\n return result;\n }\n}\n\n/**\n * A thing which contains a timeline reference, and an index into it.\n * @internal\n */\nexport class TimelineIndex {\n public pendingPaginate?: Promise;\n\n // index: the indexes are relative to BaseIndex, so could well be negative.\n public constructor(public timeline: EventTimeline, public index: number) {}\n\n /**\n * @returns the minimum possible value for the index in the current\n * timeline\n */\n public minIndex(): number {\n return this.timeline.getBaseIndex() * -1;\n }\n\n /**\n * @returns the maximum possible value for the index in the current\n * timeline (exclusive - ie, it actually returns one more than the index\n * of the last element).\n */\n public maxIndex(): number {\n return this.timeline.getEvents().length - this.timeline.getBaseIndex();\n }\n\n /**\n * Try move the index forward, or into the neighbouring timeline\n *\n * @param delta - number of events to advance by\n * @returns number of events successfully advanced by\n */\n public advance(delta: number): number {\n if (!delta) {\n return 0;\n }\n\n // first try moving the index in the current timeline. See if there is room\n // to do so.\n let cappedDelta;\n if (delta < 0) {\n // we want to wind the index backwards.\n //\n // (this.minIndex() - this.index) is a negative number whose magnitude\n // is the amount of room we have to wind back the index in the current\n // timeline. We cap delta to this quantity.\n cappedDelta = Math.max(delta, this.minIndex() - this.index);\n if (cappedDelta < 0) {\n this.index += cappedDelta;\n return cappedDelta;\n }\n } else {\n // we want to wind the index forwards.\n //\n // (this.maxIndex() - this.index) is a (positive) number whose magnitude\n // is the amount of room we have to wind forward the index in the current\n // timeline. We cap delta to this quantity.\n cappedDelta = Math.min(delta, this.maxIndex() - this.index);\n if (cappedDelta > 0) {\n this.index += cappedDelta;\n return cappedDelta;\n }\n }\n\n // the index is already at the start/end of the current timeline.\n //\n // next see if there is a neighbouring timeline to switch to.\n const neighbour = this.timeline.getNeighbouringTimeline(\n delta < 0 ? EventTimeline.BACKWARDS : EventTimeline.FORWARDS,\n );\n if (neighbour) {\n this.timeline = neighbour;\n if (delta < 0) {\n this.index = this.maxIndex();\n } else {\n this.index = this.minIndex();\n }\n\n debuglog(\"paginate: switched to new neighbour\");\n\n // recurse, using the next timeline\n return this.advance(delta);\n }\n\n return 0;\n }\n\n /**\n * Try move the index backwards, or into the neighbouring timeline\n *\n * @param delta - number of events to retreat by\n * @returns number of events successfully retreated by\n */\n public retreat(delta: number): number {\n return this.advance(delta * -1) * -1;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts deleted file mode 100644 index 1043fe8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts +++ /dev/null @@ -1,255 +0,0 @@ -import { Optional } from "matrix-events-sdk"; -import { IEvent, MatrixEvent } from "./models/event"; -/** - * Internalises a string, reusing a known pointer or storing the pointer - * if needed for future strings. - * @param str - The string to internalise. - * @returns The internalised string. - */ -export declare function internaliseString(str: string): string; -/** - * Encode a dictionary of query parameters. - * Omits any undefined/null values. - * @param params - A dict of key/values to encode e.g. - * `{"foo": "bar", "baz": "taz"}` - * @returns The encoded string e.g. foo=bar&baz=taz - */ -export declare function encodeParams(params: QueryDict, urlSearchParams?: URLSearchParams): URLSearchParams; -export type QueryDict = Record; -/** - * Replace a stable parameter with the unstable naming for params - */ -export declare function replaceParam(stable: string, unstable: string, dict: QueryDict): QueryDict; -/** - * Decode a query string in `application/x-www-form-urlencoded` format. - * @param query - A query string to decode e.g. - * foo=bar&via=server1&server2 - * @returns The decoded object, if any keys occurred multiple times - * then the value will be an array of strings, else it will be an array. - * This behaviour matches Node's qs.parse but is built on URLSearchParams - * for native web compatibility - */ -export declare function decodeParams(query: string): Record; -/** - * Encodes a URI according to a set of template variables. Variables will be - * passed through encodeURIComponent. - * @param pathTemplate - The path with template variables e.g. '/foo/$bar'. - * @param variables - The key/value pairs to replace the template - * variables with. E.g. `{ "$bar": "baz" }`. - * @returns The result of replacing all template variables e.g. '/foo/baz'. - */ -export declare function encodeUri(pathTemplate: string, variables: Record>): string; -/** - * The removeElement() method removes the first element in the array that - * satisfies (returns true) the provided testing function. - * @param array - The array. - * @param fn - Function to execute on each value in the array, with the - * function signature `fn(element, index, array)`. Return true to - * remove this element and break. - * @param reverse - True to search in reverse order. - * @returns True if an element was removed. - */ -export declare function removeElement(array: T[], fn: (t: T, i?: number, a?: T[]) => boolean, reverse?: boolean): boolean; -/** - * Checks if the given thing is a function. - * @param value - The thing to check. - * @returns True if it is a function. - */ -export declare function isFunction(value: any): boolean; -/** - * Checks that the given object has the specified keys. - * @param obj - The object to check. - * @param keys - The list of keys that 'obj' must have. - * @throws If the object is missing keys. - */ -export declare function checkObjectHasKeys(obj: object, keys: string[]): void; -/** - * Deep copy the given object. The object MUST NOT have circular references and - * MUST NOT have functions. - * @param obj - The object to deep copy. - * @returns A copy of the object without any references to the original. - */ -export declare function deepCopy(obj: T): T; -/** - * Compare two objects for equality. The objects MUST NOT have circular references. - * - * @param x - The first object to compare. - * @param y - The second object to compare. - * - * @returns true if the two objects are equal - */ -export declare function deepCompare(x: any, y: any): boolean; -/** - * Creates an array of object properties/values (entries) then - * sorts the result by key, recursively. The input object must - * ensure it does not have loops. If the input is not an object - * then it will be returned as-is. - * @param obj - The object to get entries of - * @returns The entries, sorted by key. - */ -export declare function deepSortedObjectEntries(obj: any): [string, any][]; -/** - * Returns whether the given value is a finite number without type-coercion - * - * @param value - the value to test - * @returns whether or not value is a finite number without type-coercion - */ -export declare function isNumber(value: any): value is number; -/** - * Removes zero width chars, diacritics and whitespace from the string - * Also applies an unhomoglyph on the string, to prevent similar looking chars - * @param str - the string to remove hidden characters from - * @returns a string with the hidden characters removed - */ -export declare function removeHiddenChars(str: string): string; -/** - * Removes the direction override characters from a string - * @returns string with chars removed - */ -export declare function removeDirectionOverrideChars(str: string): string; -export declare function normalize(str: string): string; -export declare function escapeRegExp(string: string): string; -export declare function globToRegexp(glob: string, extended?: boolean): string; -export declare function ensureNoTrailingSlash(url: string): string; -export declare function ensureNoTrailingSlash(url: undefined): undefined; -export declare function ensureNoTrailingSlash(url?: string): string | undefined; -/** - * Returns a promise which resolves with a given value after the given number of ms - */ -export declare function sleep(ms: number, value?: T): Promise; -/** - * Promise/async version of {@link setImmediate}. - */ -export declare function immediate(): Promise; -export declare function isNullOrUndefined(val: any): boolean; -export interface IDeferred { - resolve: (value: T | Promise) => void; - reject: (reason?: any) => void; - promise: Promise; -} -export declare function defer(): IDeferred; -export declare function promiseMapSeries(promises: Array>, fn: (t: T) => Promise | undefined): Promise; -export declare function promiseTry(fn: () => T | Promise): Promise; -export declare function chunkPromises(fns: (() => Promise)[], chunkSize: number): Promise; -/** - * Retries the function until it succeeds or is interrupted. The given function must return - * a promise which throws/rejects on error, otherwise the retry will assume the request - * succeeded. The promise chain returned will contain the successful promise. The given function - * should always return a new promise. - * @param promiseFn - The function to call to get a fresh promise instance. Takes an - * attempt count as an argument, for logging/debugging purposes. - * @returns The promise for the retried operation. - */ -export declare function simpleRetryOperation(promiseFn: (attempt: number) => Promise): Promise; -/** - * The default alphabet used by string averaging in this SDK. This matches - * all usefully printable ASCII characters (0x20-0x7E, inclusive). - */ -export declare const DEFAULT_ALPHABET: string; -/** - * Pads a string using the given alphabet as a base. The returned string will be - * padded at the end with the first character in the alphabet. - * - * This is intended for use with string averaging. - * @param s - The string to pad. - * @param n - The length to pad to. - * @param alphabet - The alphabet to use as a single string. - * @returns The padded string. - */ -export declare function alphabetPad(s: string, n: number, alphabet?: string): string; -/** - * Converts a baseN number to a string, where N is the alphabet's length. - * - * This is intended for use with string averaging. - * @param n - The baseN number. - * @param alphabet - The alphabet to use as a single string. - * @returns The baseN number encoded as a string from the alphabet. - */ -export declare function baseToString(n: bigint, alphabet?: string): string; -/** - * Converts a string to a baseN number, where N is the alphabet's length. - * - * This is intended for use with string averaging. - * @param s - The string to convert to a number. - * @param alphabet - The alphabet to use as a single string. - * @returns The baseN number. - */ -export declare function stringToBase(s: string, alphabet?: string): bigint; -/** - * Averages two strings, returning the midpoint between them. This is accomplished by - * converting both to baseN numbers (where N is the alphabet's length) then averaging - * those before re-encoding as a string. - * @param a - The first string. - * @param b - The second string. - * @param alphabet - The alphabet to use as a single string. - * @returns The midpoint between the strings, as a string. - */ -export declare function averageBetweenStrings(a: string, b: string, alphabet?: string): string; -/** - * Finds the next string using the alphabet provided. This is done by converting the - * string to a baseN number, where N is the alphabet's length, then adding 1 before - * converting back to a string. - * @param s - The string to start at. - * @param alphabet - The alphabet to use as a single string. - * @returns The string which follows the input string. - */ -export declare function nextString(s: string, alphabet?: string): string; -/** - * Finds the previous string using the alphabet provided. This is done by converting the - * string to a baseN number, where N is the alphabet's length, then subtracting 1 before - * converting back to a string. - * @param s - The string to start at. - * @param alphabet - The alphabet to use as a single string. - * @returns The string which precedes the input string. - */ -export declare function prevString(s: string, alphabet?: string): string; -/** - * Compares strings lexicographically as a sort-safe function. - * @param a - The first (reference) string. - * @param b - The second (compare) string. - * @returns Negative if the reference string is before the compare string; - * positive if the reference string is after; and zero if equal. - */ -export declare function lexicographicCompare(a: string, b: string): number; -/** - * Performant language-sensitive string comparison - * @param a - the first string to compare - * @param b - the second string to compare - */ -export declare function compare(a: string, b: string): number; -/** - * This function is similar to Object.assign() but it assigns recursively and - * allows you to ignore nullish values from the source - * - * @returns the target object - */ -export declare function recursivelyAssign>(target: T1, source: T2, ignoreNullish?: boolean): T1 & T2; -/** - * Sort events by their content m.ts property - * Latest timestamp first - */ -export declare function sortEventsByLatestContentTimestamp(left: MatrixEvent, right: MatrixEvent): number; -export declare function isSupportedReceiptType(receiptType: string): boolean; -/** - * Determines whether two maps are equal. - * @param eq - The equivalence relation to compare values by. Defaults to strict equality. - */ -export declare function mapsEqual(x: Map, y: Map, eq?: (v1: V, v2: V) => boolean): boolean; -/** - * Recursively converts Maps to plain objects. - * Also supports sub-lists of Maps. - */ -export declare function recursiveMapToObject(map: Map): any; -export declare function unsafeProp(prop: K): boolean; -export declare function safeSet(obj: Record, prop: K, value: any): void; -export declare function noUnsafeEventProps(event: Partial): boolean; -export declare class MapWithDefault extends Map { - private createDefault; - constructor(createDefault: () => V); - /** - * Returns the value if the key already exists. - * If not, it creates a new value under that key using the ctor callback and returns it. - */ - getOrCreate(key: K): V; -} -//# sourceMappingURL=utils.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts.map deleted file mode 100644 index 52c2ff2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js deleted file mode 100644 index 1022ee4..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js +++ /dev/null @@ -1,742 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MapWithDefault = exports.DEFAULT_ALPHABET = void 0; -exports.alphabetPad = alphabetPad; -exports.averageBetweenStrings = averageBetweenStrings; -exports.baseToString = baseToString; -exports.checkObjectHasKeys = checkObjectHasKeys; -exports.chunkPromises = chunkPromises; -exports.compare = compare; -exports.decodeParams = decodeParams; -exports.deepCompare = deepCompare; -exports.deepCopy = deepCopy; -exports.deepSortedObjectEntries = deepSortedObjectEntries; -exports.defer = defer; -exports.encodeParams = encodeParams; -exports.encodeUri = encodeUri; -exports.ensureNoTrailingSlash = ensureNoTrailingSlash; -exports.escapeRegExp = escapeRegExp; -exports.globToRegexp = globToRegexp; -exports.immediate = immediate; -exports.internaliseString = internaliseString; -exports.isFunction = isFunction; -exports.isNullOrUndefined = isNullOrUndefined; -exports.isNumber = isNumber; -exports.isSupportedReceiptType = isSupportedReceiptType; -exports.lexicographicCompare = lexicographicCompare; -exports.mapsEqual = mapsEqual; -exports.nextString = nextString; -exports.noUnsafeEventProps = noUnsafeEventProps; -exports.normalize = normalize; -exports.prevString = prevString; -exports.promiseMapSeries = promiseMapSeries; -exports.promiseTry = promiseTry; -exports.recursiveMapToObject = recursiveMapToObject; -exports.recursivelyAssign = recursivelyAssign; -exports.removeDirectionOverrideChars = removeDirectionOverrideChars; -exports.removeElement = removeElement; -exports.removeHiddenChars = removeHiddenChars; -exports.replaceParam = replaceParam; -exports.safeSet = safeSet; -exports.simpleRetryOperation = simpleRetryOperation; -exports.sleep = sleep; -exports.sortEventsByLatestContentTimestamp = sortEventsByLatestContentTimestamp; -exports.stringToBase = stringToBase; -exports.unsafeProp = unsafeProp; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _unhomoglyph = _interopRequireDefault(require("unhomoglyph")); -var _pRetry = _interopRequireDefault(require("p-retry")); -var _location = require("./@types/location"); -var _read_receipts = require("./@types/read_receipts"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -const interns = new Map(); - -/** - * Internalises a string, reusing a known pointer or storing the pointer - * if needed for future strings. - * @param str - The string to internalise. - * @returns The internalised string. - */ -function internaliseString(str) { - // Unwrap strings before entering the map, if we somehow got a wrapped - // string as our input. This should only happen from tests. - if (str instanceof String) { - str = str.toString(); - } - - // Check the map to see if we can store the value - if (!interns.has(str)) { - interns.set(str, str); - } - - // Return any cached string reference - return interns.get(str); -} - -/** - * Encode a dictionary of query parameters. - * Omits any undefined/null values. - * @param params - A dict of key/values to encode e.g. - * `{"foo": "bar", "baz": "taz"}` - * @returns The encoded string e.g. foo=bar&baz=taz - */ -function encodeParams(params, urlSearchParams) { - const searchParams = urlSearchParams !== null && urlSearchParams !== void 0 ? urlSearchParams : new URLSearchParams(); - for (const [key, val] of Object.entries(params)) { - if (val !== undefined && val !== null) { - if (Array.isArray(val)) { - val.forEach(v => { - searchParams.append(key, String(v)); - }); - } else { - searchParams.append(key, String(val)); - } - } - } - return searchParams; -} -/** - * Replace a stable parameter with the unstable naming for params - */ -function replaceParam(stable, unstable, dict) { - const result = _objectSpread(_objectSpread({}, dict), {}, { - [unstable]: dict[stable] - }); - delete result[stable]; - return result; -} - -/** - * Decode a query string in `application/x-www-form-urlencoded` format. - * @param query - A query string to decode e.g. - * foo=bar&via=server1&server2 - * @returns The decoded object, if any keys occurred multiple times - * then the value will be an array of strings, else it will be an array. - * This behaviour matches Node's qs.parse but is built on URLSearchParams - * for native web compatibility - */ -function decodeParams(query) { - const o = {}; - const params = new URLSearchParams(query); - for (const key of params.keys()) { - const val = params.getAll(key); - o[key] = val.length === 1 ? val[0] : val; - } - return o; -} - -/** - * Encodes a URI according to a set of template variables. Variables will be - * passed through encodeURIComponent. - * @param pathTemplate - The path with template variables e.g. '/foo/$bar'. - * @param variables - The key/value pairs to replace the template - * variables with. E.g. `{ "$bar": "baz" }`. - * @returns The result of replacing all template variables e.g. '/foo/baz'. - */ -function encodeUri(pathTemplate, variables) { - for (const key in variables) { - if (!variables.hasOwnProperty(key)) { - continue; - } - const value = variables[key]; - if (value === undefined || value === null) { - continue; - } - pathTemplate = pathTemplate.replace(key, encodeURIComponent(value)); - } - return pathTemplate; -} - -/** - * The removeElement() method removes the first element in the array that - * satisfies (returns true) the provided testing function. - * @param array - The array. - * @param fn - Function to execute on each value in the array, with the - * function signature `fn(element, index, array)`. Return true to - * remove this element and break. - * @param reverse - True to search in reverse order. - * @returns True if an element was removed. - */ -function removeElement(array, fn, reverse) { - let i; - if (reverse) { - for (i = array.length - 1; i >= 0; i--) { - if (fn(array[i], i, array)) { - array.splice(i, 1); - return true; - } - } - } else { - for (i = 0; i < array.length; i++) { - if (fn(array[i], i, array)) { - array.splice(i, 1); - return true; - } - } - } - return false; -} - -/** - * Checks if the given thing is a function. - * @param value - The thing to check. - * @returns True if it is a function. - */ -function isFunction(value) { - return Object.prototype.toString.call(value) === "[object Function]"; -} - -/** - * Checks that the given object has the specified keys. - * @param obj - The object to check. - * @param keys - The list of keys that 'obj' must have. - * @throws If the object is missing keys. - */ -// note using 'keys' here would shadow the 'keys' function defined above -function checkObjectHasKeys(obj, keys) { - for (const key of keys) { - if (!obj.hasOwnProperty(key)) { - throw new Error("Missing required key: " + key); - } - } -} - -/** - * Deep copy the given object. The object MUST NOT have circular references and - * MUST NOT have functions. - * @param obj - The object to deep copy. - * @returns A copy of the object without any references to the original. - */ -function deepCopy(obj) { - return JSON.parse(JSON.stringify(obj)); -} - -/** - * Compare two objects for equality. The objects MUST NOT have circular references. - * - * @param x - The first object to compare. - * @param y - The second object to compare. - * - * @returns true if the two objects are equal - */ -function deepCompare(x, y) { - // Inspired by - // http://stackoverflow.com/questions/1068834/object-comparison-in-javascript#1144249 - - // Compare primitives and functions. - // Also check if both arguments link to the same object. - if (x === y) { - return true; - } - if (typeof x !== typeof y) { - return false; - } - - // special-case NaN (since NaN !== NaN) - if (typeof x === "number" && isNaN(x) && isNaN(y)) { - return true; - } - - // special-case null (since typeof null == 'object', but null.constructor - // throws) - if (x === null || y === null) { - return x === y; - } - - // everything else is either an unequal primitive, or an object - if (!(x instanceof Object)) { - return false; - } - - // check they are the same type of object - if (x.constructor !== y.constructor || x.prototype !== y.prototype) { - return false; - } - - // special-casing for some special types of object - if (x instanceof RegExp || x instanceof Date) { - return x.toString() === y.toString(); - } - - // the object algorithm works for Array, but it's sub-optimal. - if (Array.isArray(x)) { - if (x.length !== y.length) { - return false; - } - for (let i = 0; i < x.length; i++) { - if (!deepCompare(x[i], y[i])) { - return false; - } - } - } else { - // check that all of y's direct keys are in x - for (const p in y) { - if (y.hasOwnProperty(p) !== x.hasOwnProperty(p)) { - return false; - } - } - - // finally, compare each of x's keys with y - for (const p in x) { - if (y.hasOwnProperty(p) !== x.hasOwnProperty(p) || !deepCompare(x[p], y[p])) { - return false; - } - } - } - return true; -} - -// Dev note: This returns an array of tuples, but jsdoc doesn't like that. https://github.com/jsdoc/jsdoc/issues/1703 -/** - * Creates an array of object properties/values (entries) then - * sorts the result by key, recursively. The input object must - * ensure it does not have loops. If the input is not an object - * then it will be returned as-is. - * @param obj - The object to get entries of - * @returns The entries, sorted by key. - */ -function deepSortedObjectEntries(obj) { - if (typeof obj !== "object") return obj; - - // Apparently these are object types... - if (obj === null || obj === undefined || Array.isArray(obj)) return obj; - const pairs = []; - for (const [k, v] of Object.entries(obj)) { - pairs.push([k, deepSortedObjectEntries(v)]); - } - - // lexicographicCompare is faster than localeCompare, so let's use that. - pairs.sort((a, b) => lexicographicCompare(a[0], b[0])); - return pairs; -} - -/** - * Returns whether the given value is a finite number without type-coercion - * - * @param value - the value to test - * @returns whether or not value is a finite number without type-coercion - */ -function isNumber(value) { - return typeof value === "number" && isFinite(value); -} - -/** - * Removes zero width chars, diacritics and whitespace from the string - * Also applies an unhomoglyph on the string, to prevent similar looking chars - * @param str - the string to remove hidden characters from - * @returns a string with the hidden characters removed - */ -function removeHiddenChars(str) { - if (typeof str === "string") { - return (0, _unhomoglyph.default)(str.normalize("NFD").replace(removeHiddenCharsRegex, "")); - } - return ""; -} - -/** - * Removes the direction override characters from a string - * @returns string with chars removed - */ -function removeDirectionOverrideChars(str) { - if (typeof str === "string") { - return str.replace(/[\u202d-\u202e]/g, ""); - } - return ""; -} -function normalize(str) { - // Note: we have to match the filter with the removeHiddenChars() because the - // function strips spaces and other characters (M becomes RN for example, in lowercase). - return removeHiddenChars(str.toLowerCase()) - // Strip all punctuation - .replace(/[\\'!"#$%&()*+,\-./:;<=>?@[\]^_`{|}~\u2000-\u206f\u2e00-\u2e7f]/g, "") - // We also doubly convert to lowercase to work around oddities of the library. - .toLowerCase(); -} - -// Regex matching bunch of unicode control characters and otherwise misleading/invisible characters. -// Includes: -// various width spaces U+2000 - U+200D -// LTR and RTL marks U+200E and U+200F -// LTR/RTL and other directional formatting marks U+202A - U+202F -// Arabic Letter RTL mark U+061C -// Combining characters U+0300 - U+036F -// Zero width no-break space (BOM) U+FEFF -// Blank/invisible characters (U2800, U2062-U2063) -// eslint-disable-next-line no-misleading-character-class -const removeHiddenCharsRegex = /[\u2000-\u200F\u202A-\u202F\u0300-\u036F\uFEFF\u061C\u2800\u2062-\u2063\s]/g; -function escapeRegExp(string) { - return string.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); -} -function globToRegexp(glob, extended = false) { - // From - // https://github.com/matrix-org/synapse/blob/abbee6b29be80a77e05730707602f3bbfc3f38cb/synapse/push/__init__.py#L132 - // Because micromatch is about 130KB with dependencies, - // and minimatch is not much better. - const replacements = [[/\\\*/g, ".*"], [/\?/g, "."]]; - if (!extended) { - replacements.push([/\\\[(!|)(.*)\\]/g, (_match, neg, pat) => ["[", neg ? "^" : "", pat.replace(/\\-/, "-"), "]"].join("")]); - } - return replacements.reduce( - // https://github.com/microsoft/TypeScript/issues/30134 - (pat, args) => args ? pat.replace(args[0], args[1]) : pat, escapeRegExp(glob)); -} -function ensureNoTrailingSlash(url) { - if (url !== null && url !== void 0 && url.endsWith("/")) { - return url.slice(0, -1); - } else { - return url; - } -} - -/** - * Returns a promise which resolves with a given value after the given number of ms - */ -function sleep(ms, value) { - return new Promise(resolve => { - setTimeout(resolve, ms, value); - }); -} - -/** - * Promise/async version of {@link setImmediate}. - */ -function immediate() { - return new Promise(setImmediate); -} -function isNullOrUndefined(val) { - return val === null || val === undefined; -} -// Returns a Deferred -function defer() { - let resolve; - let reject; - const promise = new Promise((_resolve, _reject) => { - resolve = _resolve; - reject = _reject; - }); - return { - resolve, - reject, - promise - }; -} -async function promiseMapSeries(promises, fn // if async we don't care about the type as we only await resolution -) { - for (const o of promises) { - await fn(await o); - } -} -function promiseTry(fn) { - return Promise.resolve(fn()); -} - -// Creates and awaits all promises, running no more than `chunkSize` at the same time -async function chunkPromises(fns, chunkSize) { - const results = []; - for (let i = 0; i < fns.length; i += chunkSize) { - results.push(...(await Promise.all(fns.slice(i, i + chunkSize).map(fn => fn())))); - } - return results; -} - -/** - * Retries the function until it succeeds or is interrupted. The given function must return - * a promise which throws/rejects on error, otherwise the retry will assume the request - * succeeded. The promise chain returned will contain the successful promise. The given function - * should always return a new promise. - * @param promiseFn - The function to call to get a fresh promise instance. Takes an - * attempt count as an argument, for logging/debugging purposes. - * @returns The promise for the retried operation. - */ -function simpleRetryOperation(promiseFn) { - return (0, _pRetry.default)(attempt => { - return promiseFn(attempt); - }, { - forever: true, - factor: 2, - minTimeout: 3000, - // ms - maxTimeout: 15000 // ms - }); -} - -// String averaging inspired by https://stackoverflow.com/a/2510816 -// Dev note: We make the alphabet a string because it's easier to write syntactically -// than arrays. Thankfully, strings implement the useful parts of the Array interface -// anyhow. - -/** - * The default alphabet used by string averaging in this SDK. This matches - * all usefully printable ASCII characters (0x20-0x7E, inclusive). - */ -const DEFAULT_ALPHABET = (() => { - let str = ""; - for (let c = 0x20; c <= 0x7e; c++) { - str += String.fromCharCode(c); - } - return str; -})(); - -/** - * Pads a string using the given alphabet as a base. The returned string will be - * padded at the end with the first character in the alphabet. - * - * This is intended for use with string averaging. - * @param s - The string to pad. - * @param n - The length to pad to. - * @param alphabet - The alphabet to use as a single string. - * @returns The padded string. - */ -exports.DEFAULT_ALPHABET = DEFAULT_ALPHABET; -function alphabetPad(s, n, alphabet = DEFAULT_ALPHABET) { - return s.padEnd(n, alphabet[0]); -} - -/** - * Converts a baseN number to a string, where N is the alphabet's length. - * - * This is intended for use with string averaging. - * @param n - The baseN number. - * @param alphabet - The alphabet to use as a single string. - * @returns The baseN number encoded as a string from the alphabet. - */ -function baseToString(n, alphabet = DEFAULT_ALPHABET) { - // Developer note: the stringToBase() function offsets the character set by 1 so that repeated - // characters (ie: "aaaaaa" in a..z) don't come out as zero. We have to reverse this here as - // otherwise we'll be wrong in our conversion. Undoing a +1 before an exponent isn't very fun - // though, so we rely on a lengthy amount of `x - 1` and integer division rules to reach a - // sane state. This also means we have to do rollover detection: see below. - - const len = BigInt(alphabet.length); - if (n <= len) { - var _alphabet; - return (_alphabet = alphabet[Number(n) - 1]) !== null && _alphabet !== void 0 ? _alphabet : ""; - } - let d = n / len; - let r = Number(n % len) - 1; - - // Rollover detection: if the remainder is negative, it means that the string needs - // to roll over by 1 character downwards (ie: in a..z, the previous to "aaa" would be - // "zz"). - if (r < 0) { - d -= BigInt(Math.abs(r)); // abs() is just to be clear what we're doing. Could also `+= r`. - r = Number(len) - 1; - } - return baseToString(d, alphabet) + alphabet[r]; -} - -/** - * Converts a string to a baseN number, where N is the alphabet's length. - * - * This is intended for use with string averaging. - * @param s - The string to convert to a number. - * @param alphabet - The alphabet to use as a single string. - * @returns The baseN number. - */ -function stringToBase(s, alphabet = DEFAULT_ALPHABET) { - const len = BigInt(alphabet.length); - - // In our conversion to baseN we do a couple performance optimizations to avoid using - // excess CPU and such. To create baseN numbers, the input string needs to be reversed - // so the exponents stack up appropriately, as the last character in the unreversed - // string has less impact than the first character (in "abc" the A is a lot more important - // for lexicographic sorts). We also do a trick with the character codes to optimize the - // alphabet lookup, avoiding an index scan of `alphabet.indexOf(reversedStr[i])` - we know - // that the alphabet and (theoretically) the input string are constrained on character sets - // and thus can do simple subtraction to end up with the same result. - - // Developer caution: we carefully cast to BigInt here to avoid losing precision. We cannot - // rely on Math.pow() (for example) to be capable of handling our insane numbers. - - let result = BigInt(0); - for (let i = s.length - 1, j = BigInt(0); i >= 0; i--, j++) { - const charIndex = s.charCodeAt(i) - alphabet.charCodeAt(0); - - // We add 1 to the char index to offset the whole numbering scheme. We unpack this in - // the baseToString() function. - result += BigInt(1 + charIndex) * len ** j; - } - return result; -} - -/** - * Averages two strings, returning the midpoint between them. This is accomplished by - * converting both to baseN numbers (where N is the alphabet's length) then averaging - * those before re-encoding as a string. - * @param a - The first string. - * @param b - The second string. - * @param alphabet - The alphabet to use as a single string. - * @returns The midpoint between the strings, as a string. - */ -function averageBetweenStrings(a, b, alphabet = DEFAULT_ALPHABET) { - const padN = Math.max(a.length, b.length); - const baseA = stringToBase(alphabetPad(a, padN, alphabet), alphabet); - const baseB = stringToBase(alphabetPad(b, padN, alphabet), alphabet); - const avg = (baseA + baseB) / BigInt(2); - - // Detect integer division conflicts. This happens when two numbers are divided too close so - // we lose a .5 precision. We need to add a padding character in these cases. - if (avg === baseA || avg == baseB) { - return baseToString(avg, alphabet) + alphabet[0]; - } - return baseToString(avg, alphabet); -} - -/** - * Finds the next string using the alphabet provided. This is done by converting the - * string to a baseN number, where N is the alphabet's length, then adding 1 before - * converting back to a string. - * @param s - The string to start at. - * @param alphabet - The alphabet to use as a single string. - * @returns The string which follows the input string. - */ -function nextString(s, alphabet = DEFAULT_ALPHABET) { - return baseToString(stringToBase(s, alphabet) + BigInt(1), alphabet); -} - -/** - * Finds the previous string using the alphabet provided. This is done by converting the - * string to a baseN number, where N is the alphabet's length, then subtracting 1 before - * converting back to a string. - * @param s - The string to start at. - * @param alphabet - The alphabet to use as a single string. - * @returns The string which precedes the input string. - */ -function prevString(s, alphabet = DEFAULT_ALPHABET) { - return baseToString(stringToBase(s, alphabet) - BigInt(1), alphabet); -} - -/** - * Compares strings lexicographically as a sort-safe function. - * @param a - The first (reference) string. - * @param b - The second (compare) string. - * @returns Negative if the reference string is before the compare string; - * positive if the reference string is after; and zero if equal. - */ -function lexicographicCompare(a, b) { - // Dev note: this exists because I'm sad that you can use math operators on strings, so I've - // hidden the operation in this function. - if (a < b) { - return -1; - } else if (a > b) { - return 1; - } else { - return 0; - } -} -const collator = new Intl.Collator(); -/** - * Performant language-sensitive string comparison - * @param a - the first string to compare - * @param b - the second string to compare - */ -function compare(a, b) { - return collator.compare(a, b); -} - -/** - * This function is similar to Object.assign() but it assigns recursively and - * allows you to ignore nullish values from the source - * - * @returns the target object - */ -function recursivelyAssign(target, source, ignoreNullish = false) { - for (const [sourceKey, sourceValue] of Object.entries(source)) { - if (target[sourceKey] instanceof Object && sourceValue) { - recursivelyAssign(target[sourceKey], sourceValue); - continue; - } - if (sourceValue !== null && sourceValue !== undefined || !ignoreNullish) { - target[sourceKey] = sourceValue; - continue; - } - } - return target; -} -function getContentTimestampWithFallback(event) { - var _M_TIMESTAMP$findIn; - return (_M_TIMESTAMP$findIn = _location.M_TIMESTAMP.findIn(event.getContent())) !== null && _M_TIMESTAMP$findIn !== void 0 ? _M_TIMESTAMP$findIn : -1; -} - -/** - * Sort events by their content m.ts property - * Latest timestamp first - */ -function sortEventsByLatestContentTimestamp(left, right) { - return getContentTimestampWithFallback(right) - getContentTimestampWithFallback(left); -} -function isSupportedReceiptType(receiptType) { - return [_read_receipts.ReceiptType.Read, _read_receipts.ReceiptType.ReadPrivate].includes(receiptType); -} - -/** - * Determines whether two maps are equal. - * @param eq - The equivalence relation to compare values by. Defaults to strict equality. - */ -function mapsEqual(x, y, eq = (v1, v2) => v1 === v2) { - if (x.size !== y.size) return false; - for (const [k, v1] of x) { - const v2 = y.get(k); - if (v2 === undefined || !eq(v1, v2)) return false; - } - return true; -} -function processMapToObjectValue(value) { - if (value instanceof Map) { - // Value is a Map. Recursively map it to an object. - return recursiveMapToObject(value); - } else if (Array.isArray(value)) { - // Value is an Array. Recursively map the value (e.g. to cover Array of Arrays). - return value.map(v => processMapToObjectValue(v)); - } else { - return value; - } -} - -/** - * Recursively converts Maps to plain objects. - * Also supports sub-lists of Maps. - */ -function recursiveMapToObject(map) { - const targetMap = new Map(); - for (const [key, value] of map) { - targetMap.set(key, processMapToObjectValue(value)); - } - return Object.fromEntries(targetMap.entries()); -} -function unsafeProp(prop) { - return prop === "__proto__" || prop === "prototype" || prop === "constructor"; -} -function safeSet(obj, prop, value) { - if (unsafeProp(prop)) { - throw new Error("Trying to modify prototype or constructor"); - } - obj[prop] = value; -} -function noUnsafeEventProps(event) { - return !(unsafeProp(event.room_id) || unsafeProp(event.sender) || unsafeProp(event.user_id) || unsafeProp(event.event_id)); -} -class MapWithDefault extends Map { - constructor(createDefault) { - super(); - this.createDefault = createDefault; - } - - /** - * Returns the value if the key already exists. - * If not, it creates a new value under that key using the ctor callback and returns it. - */ - getOrCreate(key) { - if (!this.has(key)) { - this.set(key, this.createDefault()); - } - return this.get(key); - } -} -exports.MapWithDefault = MapWithDefault; -//# sourceMappingURL=utils.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js.map deleted file mode 100644 index 977916b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/utils.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"utils.js","names":["_unhomoglyph","_interopRequireDefault","require","_pRetry","_location","_read_receipts","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","interns","Map","internaliseString","str","String","toString","has","set","get","encodeParams","params","urlSearchParams","searchParams","URLSearchParams","val","entries","undefined","Array","isArray","v","append","replaceParam","stable","unstable","dict","result","decodeParams","query","o","getAll","encodeUri","pathTemplate","variables","hasOwnProperty","value","replace","encodeURIComponent","removeElement","array","fn","reverse","splice","isFunction","prototype","call","checkObjectHasKeys","obj","Error","deepCopy","JSON","parse","stringify","deepCompare","x","y","isNaN","constructor","RegExp","Date","p","deepSortedObjectEntries","pairs","k","sort","a","b","lexicographicCompare","isNumber","isFinite","removeHiddenChars","unhomoglyph","normalize","removeHiddenCharsRegex","removeDirectionOverrideChars","toLowerCase","escapeRegExp","string","globToRegexp","glob","extended","replacements","_match","neg","pat","join","reduce","args","ensureNoTrailingSlash","url","endsWith","slice","sleep","ms","Promise","resolve","setTimeout","immediate","setImmediate","isNullOrUndefined","defer","reject","promise","_resolve","_reject","promiseMapSeries","promises","promiseTry","chunkPromises","fns","chunkSize","results","all","map","simpleRetryOperation","promiseFn","promiseRetry","attempt","forever","factor","minTimeout","maxTimeout","DEFAULT_ALPHABET","c","fromCharCode","exports","alphabetPad","s","n","alphabet","padEnd","baseToString","len","BigInt","_alphabet","Number","d","r","Math","abs","stringToBase","j","charIndex","charCodeAt","averageBetweenStrings","padN","max","baseA","baseB","avg","nextString","prevString","collator","Intl","Collator","compare","recursivelyAssign","ignoreNullish","sourceKey","sourceValue","getContentTimestampWithFallback","event","_M_TIMESTAMP$findIn","M_TIMESTAMP","findIn","getContent","sortEventsByLatestContentTimestamp","left","right","isSupportedReceiptType","receiptType","ReceiptType","Read","ReadPrivate","includes","mapsEqual","eq","v1","v2","size","processMapToObjectValue","recursiveMapToObject","targetMap","fromEntries","unsafeProp","prop","safeSet","noUnsafeEventProps","room_id","sender","user_id","event_id","MapWithDefault","createDefault","getOrCreate"],"sources":["../src/utils.ts"],"sourcesContent":["/*\nCopyright 2015, 2016, 2019, 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module.\n */\n\nimport unhomoglyph from \"unhomoglyph\";\nimport promiseRetry from \"p-retry\";\nimport { Optional } from \"matrix-events-sdk\";\n\nimport { IEvent, MatrixEvent } from \"./models/event\";\nimport { M_TIMESTAMP } from \"./@types/location\";\nimport { ReceiptType } from \"./@types/read_receipts\";\n\nconst interns = new Map();\n\n/**\n * Internalises a string, reusing a known pointer or storing the pointer\n * if needed for future strings.\n * @param str - The string to internalise.\n * @returns The internalised string.\n */\nexport function internaliseString(str: string): string {\n // Unwrap strings before entering the map, if we somehow got a wrapped\n // string as our input. This should only happen from tests.\n if ((str as unknown) instanceof String) {\n str = str.toString();\n }\n\n // Check the map to see if we can store the value\n if (!interns.has(str)) {\n interns.set(str, str);\n }\n\n // Return any cached string reference\n return interns.get(str)!;\n}\n\n/**\n * Encode a dictionary of query parameters.\n * Omits any undefined/null values.\n * @param params - A dict of key/values to encode e.g.\n * `{\"foo\": \"bar\", \"baz\": \"taz\"}`\n * @returns The encoded string e.g. foo=bar&baz=taz\n */\nexport function encodeParams(params: QueryDict, urlSearchParams?: URLSearchParams): URLSearchParams {\n const searchParams = urlSearchParams ?? new URLSearchParams();\n for (const [key, val] of Object.entries(params)) {\n if (val !== undefined && val !== null) {\n if (Array.isArray(val)) {\n val.forEach((v) => {\n searchParams.append(key, String(v));\n });\n } else {\n searchParams.append(key, String(val));\n }\n }\n }\n return searchParams;\n}\n\nexport type QueryDict = Record;\n\n/**\n * Replace a stable parameter with the unstable naming for params\n */\nexport function replaceParam(stable: string, unstable: string, dict: QueryDict): QueryDict {\n const result = {\n ...dict,\n [unstable]: dict[stable],\n };\n delete result[stable];\n return result;\n}\n\n/**\n * Decode a query string in `application/x-www-form-urlencoded` format.\n * @param query - A query string to decode e.g.\n * foo=bar&via=server1&server2\n * @returns The decoded object, if any keys occurred multiple times\n * then the value will be an array of strings, else it will be an array.\n * This behaviour matches Node's qs.parse but is built on URLSearchParams\n * for native web compatibility\n */\nexport function decodeParams(query: string): Record {\n const o: Record = {};\n const params = new URLSearchParams(query);\n for (const key of params.keys()) {\n const val = params.getAll(key);\n o[key] = val.length === 1 ? val[0] : val;\n }\n return o;\n}\n\n/**\n * Encodes a URI according to a set of template variables. Variables will be\n * passed through encodeURIComponent.\n * @param pathTemplate - The path with template variables e.g. '/foo/$bar'.\n * @param variables - The key/value pairs to replace the template\n * variables with. E.g. `{ \"$bar\": \"baz\" }`.\n * @returns The result of replacing all template variables e.g. '/foo/baz'.\n */\nexport function encodeUri(pathTemplate: string, variables: Record>): string {\n for (const key in variables) {\n if (!variables.hasOwnProperty(key)) {\n continue;\n }\n const value = variables[key];\n if (value === undefined || value === null) {\n continue;\n }\n pathTemplate = pathTemplate.replace(key, encodeURIComponent(value));\n }\n return pathTemplate;\n}\n\n/**\n * The removeElement() method removes the first element in the array that\n * satisfies (returns true) the provided testing function.\n * @param array - The array.\n * @param fn - Function to execute on each value in the array, with the\n * function signature `fn(element, index, array)`. Return true to\n * remove this element and break.\n * @param reverse - True to search in reverse order.\n * @returns True if an element was removed.\n */\nexport function removeElement(array: T[], fn: (t: T, i?: number, a?: T[]) => boolean, reverse?: boolean): boolean {\n let i: number;\n if (reverse) {\n for (i = array.length - 1; i >= 0; i--) {\n if (fn(array[i], i, array)) {\n array.splice(i, 1);\n return true;\n }\n }\n } else {\n for (i = 0; i < array.length; i++) {\n if (fn(array[i], i, array)) {\n array.splice(i, 1);\n return true;\n }\n }\n }\n return false;\n}\n\n/**\n * Checks if the given thing is a function.\n * @param value - The thing to check.\n * @returns True if it is a function.\n */\nexport function isFunction(value: any): boolean {\n return Object.prototype.toString.call(value) === \"[object Function]\";\n}\n\n/**\n * Checks that the given object has the specified keys.\n * @param obj - The object to check.\n * @param keys - The list of keys that 'obj' must have.\n * @throws If the object is missing keys.\n */\n// note using 'keys' here would shadow the 'keys' function defined above\nexport function checkObjectHasKeys(obj: object, keys: string[]): void {\n for (const key of keys) {\n if (!obj.hasOwnProperty(key)) {\n throw new Error(\"Missing required key: \" + key);\n }\n }\n}\n\n/**\n * Deep copy the given object. The object MUST NOT have circular references and\n * MUST NOT have functions.\n * @param obj - The object to deep copy.\n * @returns A copy of the object without any references to the original.\n */\nexport function deepCopy(obj: T): T {\n return JSON.parse(JSON.stringify(obj));\n}\n\n/**\n * Compare two objects for equality. The objects MUST NOT have circular references.\n *\n * @param x - The first object to compare.\n * @param y - The second object to compare.\n *\n * @returns true if the two objects are equal\n */\nexport function deepCompare(x: any, y: any): boolean {\n // Inspired by\n // http://stackoverflow.com/questions/1068834/object-comparison-in-javascript#1144249\n\n // Compare primitives and functions.\n // Also check if both arguments link to the same object.\n if (x === y) {\n return true;\n }\n\n if (typeof x !== typeof y) {\n return false;\n }\n\n // special-case NaN (since NaN !== NaN)\n if (typeof x === \"number\" && isNaN(x) && isNaN(y)) {\n return true;\n }\n\n // special-case null (since typeof null == 'object', but null.constructor\n // throws)\n if (x === null || y === null) {\n return x === y;\n }\n\n // everything else is either an unequal primitive, or an object\n if (!(x instanceof Object)) {\n return false;\n }\n\n // check they are the same type of object\n if (x.constructor !== y.constructor || x.prototype !== y.prototype) {\n return false;\n }\n\n // special-casing for some special types of object\n if (x instanceof RegExp || x instanceof Date) {\n return x.toString() === y.toString();\n }\n\n // the object algorithm works for Array, but it's sub-optimal.\n if (Array.isArray(x)) {\n if (x.length !== y.length) {\n return false;\n }\n\n for (let i = 0; i < x.length; i++) {\n if (!deepCompare(x[i], y[i])) {\n return false;\n }\n }\n } else {\n // check that all of y's direct keys are in x\n for (const p in y) {\n if (y.hasOwnProperty(p) !== x.hasOwnProperty(p)) {\n return false;\n }\n }\n\n // finally, compare each of x's keys with y\n for (const p in x) {\n if (y.hasOwnProperty(p) !== x.hasOwnProperty(p) || !deepCompare(x[p], y[p])) {\n return false;\n }\n }\n }\n return true;\n}\n\n// Dev note: This returns an array of tuples, but jsdoc doesn't like that. https://github.com/jsdoc/jsdoc/issues/1703\n/**\n * Creates an array of object properties/values (entries) then\n * sorts the result by key, recursively. The input object must\n * ensure it does not have loops. If the input is not an object\n * then it will be returned as-is.\n * @param obj - The object to get entries of\n * @returns The entries, sorted by key.\n */\nexport function deepSortedObjectEntries(obj: any): [string, any][] {\n if (typeof obj !== \"object\") return obj;\n\n // Apparently these are object types...\n if (obj === null || obj === undefined || Array.isArray(obj)) return obj;\n\n const pairs: [string, any][] = [];\n for (const [k, v] of Object.entries(obj)) {\n pairs.push([k, deepSortedObjectEntries(v)]);\n }\n\n // lexicographicCompare is faster than localeCompare, so let's use that.\n pairs.sort((a, b) => lexicographicCompare(a[0], b[0]));\n\n return pairs;\n}\n\n/**\n * Returns whether the given value is a finite number without type-coercion\n *\n * @param value - the value to test\n * @returns whether or not value is a finite number without type-coercion\n */\nexport function isNumber(value: any): value is number {\n return typeof value === \"number\" && isFinite(value);\n}\n\n/**\n * Removes zero width chars, diacritics and whitespace from the string\n * Also applies an unhomoglyph on the string, to prevent similar looking chars\n * @param str - the string to remove hidden characters from\n * @returns a string with the hidden characters removed\n */\nexport function removeHiddenChars(str: string): string {\n if (typeof str === \"string\") {\n return unhomoglyph(str.normalize(\"NFD\").replace(removeHiddenCharsRegex, \"\"));\n }\n return \"\";\n}\n\n/**\n * Removes the direction override characters from a string\n * @returns string with chars removed\n */\nexport function removeDirectionOverrideChars(str: string): string {\n if (typeof str === \"string\") {\n return str.replace(/[\\u202d-\\u202e]/g, \"\");\n }\n return \"\";\n}\n\nexport function normalize(str: string): string {\n // Note: we have to match the filter with the removeHiddenChars() because the\n // function strips spaces and other characters (M becomes RN for example, in lowercase).\n return (\n removeHiddenChars(str.toLowerCase())\n // Strip all punctuation\n .replace(/[\\\\'!\"#$%&()*+,\\-./:;<=>?@[\\]^_`{|}~\\u2000-\\u206f\\u2e00-\\u2e7f]/g, \"\")\n // We also doubly convert to lowercase to work around oddities of the library.\n .toLowerCase()\n );\n}\n\n// Regex matching bunch of unicode control characters and otherwise misleading/invisible characters.\n// Includes:\n// various width spaces U+2000 - U+200D\n// LTR and RTL marks U+200E and U+200F\n// LTR/RTL and other directional formatting marks U+202A - U+202F\n// Arabic Letter RTL mark U+061C\n// Combining characters U+0300 - U+036F\n// Zero width no-break space (BOM) U+FEFF\n// Blank/invisible characters (U2800, U2062-U2063)\n// eslint-disable-next-line no-misleading-character-class\nconst removeHiddenCharsRegex = /[\\u2000-\\u200F\\u202A-\\u202F\\u0300-\\u036F\\uFEFF\\u061C\\u2800\\u2062-\\u2063\\s]/g;\n\nexport function escapeRegExp(string: string): string {\n return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\nexport function globToRegexp(glob: string, extended = false): string {\n // From\n // https://github.com/matrix-org/synapse/blob/abbee6b29be80a77e05730707602f3bbfc3f38cb/synapse/push/__init__.py#L132\n // Because micromatch is about 130KB with dependencies,\n // and minimatch is not much better.\n const replacements: [RegExp, string | ((substring: string, ...args: any[]) => string)][] = [\n [/\\\\\\*/g, \".*\"],\n [/\\?/g, \".\"],\n ];\n if (!extended) {\n replacements.push([\n /\\\\\\[(!|)(.*)\\\\]/g,\n (_match: string, neg: string, pat: string): string =>\n [\"[\", neg ? \"^\" : \"\", pat.replace(/\\\\-/, \"-\"), \"]\"].join(\"\"),\n ]);\n }\n return replacements.reduce(\n // https://github.com/microsoft/TypeScript/issues/30134\n (pat, args) => (args ? pat.replace(args[0], args[1] as any) : pat),\n escapeRegExp(glob),\n );\n}\n\nexport function ensureNoTrailingSlash(url: string): string;\nexport function ensureNoTrailingSlash(url: undefined): undefined;\nexport function ensureNoTrailingSlash(url?: string): string | undefined;\nexport function ensureNoTrailingSlash(url?: string): string | undefined {\n if (url?.endsWith(\"/\")) {\n return url.slice(0, -1);\n } else {\n return url;\n }\n}\n\n/**\n * Returns a promise which resolves with a given value after the given number of ms\n */\nexport function sleep(ms: number, value?: T): Promise {\n return new Promise((resolve) => {\n setTimeout(resolve, ms, value);\n });\n}\n\n/**\n * Promise/async version of {@link setImmediate}.\n */\nexport function immediate(): Promise {\n return new Promise(setImmediate);\n}\n\nexport function isNullOrUndefined(val: any): boolean {\n return val === null || val === undefined;\n}\n\nexport interface IDeferred {\n resolve: (value: T | Promise) => void;\n reject: (reason?: any) => void;\n promise: Promise;\n}\n\n// Returns a Deferred\nexport function defer(): IDeferred {\n let resolve!: IDeferred[\"resolve\"];\n let reject!: IDeferred[\"reject\"];\n\n const promise = new Promise((_resolve, _reject) => {\n resolve = _resolve;\n reject = _reject;\n });\n\n return { resolve, reject, promise };\n}\n\nexport async function promiseMapSeries(\n promises: Array>,\n fn: (t: T) => Promise | undefined, // if async we don't care about the type as we only await resolution\n): Promise {\n for (const o of promises) {\n await fn(await o);\n }\n}\n\nexport function promiseTry(fn: () => T | Promise): Promise {\n return Promise.resolve(fn());\n}\n\n// Creates and awaits all promises, running no more than `chunkSize` at the same time\nexport async function chunkPromises(fns: (() => Promise)[], chunkSize: number): Promise {\n const results: T[] = [];\n for (let i = 0; i < fns.length; i += chunkSize) {\n results.push(...(await Promise.all(fns.slice(i, i + chunkSize).map((fn) => fn()))));\n }\n return results;\n}\n\n/**\n * Retries the function until it succeeds or is interrupted. The given function must return\n * a promise which throws/rejects on error, otherwise the retry will assume the request\n * succeeded. The promise chain returned will contain the successful promise. The given function\n * should always return a new promise.\n * @param promiseFn - The function to call to get a fresh promise instance. Takes an\n * attempt count as an argument, for logging/debugging purposes.\n * @returns The promise for the retried operation.\n */\nexport function simpleRetryOperation(promiseFn: (attempt: number) => Promise): Promise {\n return promiseRetry(\n (attempt: number) => {\n return promiseFn(attempt);\n },\n {\n forever: true,\n factor: 2,\n minTimeout: 3000, // ms\n maxTimeout: 15000, // ms\n },\n );\n}\n\n// String averaging inspired by https://stackoverflow.com/a/2510816\n// Dev note: We make the alphabet a string because it's easier to write syntactically\n// than arrays. Thankfully, strings implement the useful parts of the Array interface\n// anyhow.\n\n/**\n * The default alphabet used by string averaging in this SDK. This matches\n * all usefully printable ASCII characters (0x20-0x7E, inclusive).\n */\nexport const DEFAULT_ALPHABET = ((): string => {\n let str = \"\";\n for (let c = 0x20; c <= 0x7e; c++) {\n str += String.fromCharCode(c);\n }\n return str;\n})();\n\n/**\n * Pads a string using the given alphabet as a base. The returned string will be\n * padded at the end with the first character in the alphabet.\n *\n * This is intended for use with string averaging.\n * @param s - The string to pad.\n * @param n - The length to pad to.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The padded string.\n */\nexport function alphabetPad(s: string, n: number, alphabet = DEFAULT_ALPHABET): string {\n return s.padEnd(n, alphabet[0]);\n}\n\n/**\n * Converts a baseN number to a string, where N is the alphabet's length.\n *\n * This is intended for use with string averaging.\n * @param n - The baseN number.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The baseN number encoded as a string from the alphabet.\n */\nexport function baseToString(n: bigint, alphabet = DEFAULT_ALPHABET): string {\n // Developer note: the stringToBase() function offsets the character set by 1 so that repeated\n // characters (ie: \"aaaaaa\" in a..z) don't come out as zero. We have to reverse this here as\n // otherwise we'll be wrong in our conversion. Undoing a +1 before an exponent isn't very fun\n // though, so we rely on a lengthy amount of `x - 1` and integer division rules to reach a\n // sane state. This also means we have to do rollover detection: see below.\n\n const len = BigInt(alphabet.length);\n if (n <= len) {\n return alphabet[Number(n) - 1] ?? \"\";\n }\n\n let d = n / len;\n let r = Number(n % len) - 1;\n\n // Rollover detection: if the remainder is negative, it means that the string needs\n // to roll over by 1 character downwards (ie: in a..z, the previous to \"aaa\" would be\n // \"zz\").\n if (r < 0) {\n d -= BigInt(Math.abs(r)); // abs() is just to be clear what we're doing. Could also `+= r`.\n r = Number(len) - 1;\n }\n\n return baseToString(d, alphabet) + alphabet[r];\n}\n\n/**\n * Converts a string to a baseN number, where N is the alphabet's length.\n *\n * This is intended for use with string averaging.\n * @param s - The string to convert to a number.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The baseN number.\n */\nexport function stringToBase(s: string, alphabet = DEFAULT_ALPHABET): bigint {\n const len = BigInt(alphabet.length);\n\n // In our conversion to baseN we do a couple performance optimizations to avoid using\n // excess CPU and such. To create baseN numbers, the input string needs to be reversed\n // so the exponents stack up appropriately, as the last character in the unreversed\n // string has less impact than the first character (in \"abc\" the A is a lot more important\n // for lexicographic sorts). We also do a trick with the character codes to optimize the\n // alphabet lookup, avoiding an index scan of `alphabet.indexOf(reversedStr[i])` - we know\n // that the alphabet and (theoretically) the input string are constrained on character sets\n // and thus can do simple subtraction to end up with the same result.\n\n // Developer caution: we carefully cast to BigInt here to avoid losing precision. We cannot\n // rely on Math.pow() (for example) to be capable of handling our insane numbers.\n\n let result = BigInt(0);\n for (let i = s.length - 1, j = BigInt(0); i >= 0; i--, j++) {\n const charIndex = s.charCodeAt(i) - alphabet.charCodeAt(0);\n\n // We add 1 to the char index to offset the whole numbering scheme. We unpack this in\n // the baseToString() function.\n result += BigInt(1 + charIndex) * len ** j;\n }\n return result;\n}\n\n/**\n * Averages two strings, returning the midpoint between them. This is accomplished by\n * converting both to baseN numbers (where N is the alphabet's length) then averaging\n * those before re-encoding as a string.\n * @param a - The first string.\n * @param b - The second string.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The midpoint between the strings, as a string.\n */\nexport function averageBetweenStrings(a: string, b: string, alphabet = DEFAULT_ALPHABET): string {\n const padN = Math.max(a.length, b.length);\n const baseA = stringToBase(alphabetPad(a, padN, alphabet), alphabet);\n const baseB = stringToBase(alphabetPad(b, padN, alphabet), alphabet);\n const avg = (baseA + baseB) / BigInt(2);\n\n // Detect integer division conflicts. This happens when two numbers are divided too close so\n // we lose a .5 precision. We need to add a padding character in these cases.\n if (avg === baseA || avg == baseB) {\n return baseToString(avg, alphabet) + alphabet[0];\n }\n\n return baseToString(avg, alphabet);\n}\n\n/**\n * Finds the next string using the alphabet provided. This is done by converting the\n * string to a baseN number, where N is the alphabet's length, then adding 1 before\n * converting back to a string.\n * @param s - The string to start at.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The string which follows the input string.\n */\nexport function nextString(s: string, alphabet = DEFAULT_ALPHABET): string {\n return baseToString(stringToBase(s, alphabet) + BigInt(1), alphabet);\n}\n\n/**\n * Finds the previous string using the alphabet provided. This is done by converting the\n * string to a baseN number, where N is the alphabet's length, then subtracting 1 before\n * converting back to a string.\n * @param s - The string to start at.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The string which precedes the input string.\n */\nexport function prevString(s: string, alphabet = DEFAULT_ALPHABET): string {\n return baseToString(stringToBase(s, alphabet) - BigInt(1), alphabet);\n}\n\n/**\n * Compares strings lexicographically as a sort-safe function.\n * @param a - The first (reference) string.\n * @param b - The second (compare) string.\n * @returns Negative if the reference string is before the compare string;\n * positive if the reference string is after; and zero if equal.\n */\nexport function lexicographicCompare(a: string, b: string): number {\n // Dev note: this exists because I'm sad that you can use math operators on strings, so I've\n // hidden the operation in this function.\n if (a < b) {\n return -1;\n } else if (a > b) {\n return 1;\n } else {\n return 0;\n }\n}\n\nconst collator = new Intl.Collator();\n/**\n * Performant language-sensitive string comparison\n * @param a - the first string to compare\n * @param b - the second string to compare\n */\nexport function compare(a: string, b: string): number {\n return collator.compare(a, b);\n}\n\n/**\n * This function is similar to Object.assign() but it assigns recursively and\n * allows you to ignore nullish values from the source\n *\n * @returns the target object\n */\nexport function recursivelyAssign>(\n target: T1,\n source: T2,\n ignoreNullish = false,\n): T1 & T2 {\n for (const [sourceKey, sourceValue] of Object.entries(source)) {\n if (target[sourceKey] instanceof Object && sourceValue) {\n recursivelyAssign(target[sourceKey], sourceValue);\n continue;\n }\n if ((sourceValue !== null && sourceValue !== undefined) || !ignoreNullish) {\n target[sourceKey as keyof T1] = sourceValue;\n continue;\n }\n }\n return target as T1 & T2;\n}\n\nfunction getContentTimestampWithFallback(event: MatrixEvent): number {\n return M_TIMESTAMP.findIn(event.getContent()) ?? -1;\n}\n\n/**\n * Sort events by their content m.ts property\n * Latest timestamp first\n */\nexport function sortEventsByLatestContentTimestamp(left: MatrixEvent, right: MatrixEvent): number {\n return getContentTimestampWithFallback(right) - getContentTimestampWithFallback(left);\n}\n\nexport function isSupportedReceiptType(receiptType: string): boolean {\n return [ReceiptType.Read, ReceiptType.ReadPrivate].includes(receiptType as ReceiptType);\n}\n\n/**\n * Determines whether two maps are equal.\n * @param eq - The equivalence relation to compare values by. Defaults to strict equality.\n */\nexport function mapsEqual(x: Map, y: Map, eq = (v1: V, v2: V): boolean => v1 === v2): boolean {\n if (x.size !== y.size) return false;\n for (const [k, v1] of x) {\n const v2 = y.get(k);\n if (v2 === undefined || !eq(v1, v2)) return false;\n }\n return true;\n}\n\nfunction processMapToObjectValue(value: any): any {\n if (value instanceof Map) {\n // Value is a Map. Recursively map it to an object.\n return recursiveMapToObject(value);\n } else if (Array.isArray(value)) {\n // Value is an Array. Recursively map the value (e.g. to cover Array of Arrays).\n return value.map((v) => processMapToObjectValue(v));\n } else {\n return value;\n }\n}\n\n/**\n * Recursively converts Maps to plain objects.\n * Also supports sub-lists of Maps.\n */\nexport function recursiveMapToObject(map: Map): any {\n const targetMap = new Map();\n\n for (const [key, value] of map) {\n targetMap.set(key, processMapToObjectValue(value));\n }\n\n return Object.fromEntries(targetMap.entries());\n}\n\nexport function unsafeProp(prop: K): boolean {\n return prop === \"__proto__\" || prop === \"prototype\" || prop === \"constructor\";\n}\n\nexport function safeSet(obj: Record, prop: K, value: any): void {\n if (unsafeProp(prop)) {\n throw new Error(\"Trying to modify prototype or constructor\");\n }\n\n obj[prop] = value;\n}\n\nexport function noUnsafeEventProps(event: Partial): boolean {\n return !(\n unsafeProp(event.room_id) ||\n unsafeProp(event.sender) ||\n unsafeProp(event.user_id) ||\n unsafeProp(event.event_id)\n );\n}\n\nexport class MapWithDefault extends Map {\n public constructor(private createDefault: () => V) {\n super();\n }\n\n /**\n * Returns the value if the key already exists.\n * If not, it creates a new value under that key using the ctor callback and returns it.\n */\n public getOrCreate(key: K): V {\n if (!this.has(key)) {\n this.set(key, this.createDefault());\n }\n\n return this.get(key)!;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts deleted file mode 100644 index 3c1d344..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -/** - * Acquires a reference to the shared AudioContext. - * It's highly recommended to reuse this AudioContext rather than creating your - * own, because multiple AudioContexts can be problematic in some browsers. - * Make sure to call releaseContext when you're done using it. - * @returns The shared AudioContext - */ -export declare const acquireContext: () => AudioContext; -/** - * Signals that one of the references to the shared AudioContext has been - * released, allowing the context and associated hardware resources to be - * cleaned up if nothing else is using it. - */ -export declare const releaseContext: () => void; -//# sourceMappingURL=audioContext.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts.map deleted file mode 100644 index dd32fcd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"audioContext.d.ts","sourceRoot":"","sources":["../../src/webrtc/audioContext.ts"],"names":[],"mappings":"AAmBA;;;;;;GAMG;AACH,eAAO,MAAM,cAAc,QAAO,YAIjC,CAAC;AAEF;;;;GAIG;AACH,eAAO,MAAM,cAAc,QAAO,IAMjC,CAAC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js deleted file mode 100644 index a950ad5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js +++ /dev/null @@ -1,54 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.releaseContext = exports.acquireContext = void 0; -/* -Copyright 2022 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -let audioContext = null; -let refCount = 0; - -/** - * Acquires a reference to the shared AudioContext. - * It's highly recommended to reuse this AudioContext rather than creating your - * own, because multiple AudioContexts can be problematic in some browsers. - * Make sure to call releaseContext when you're done using it. - * @returns The shared AudioContext - */ -const acquireContext = () => { - if (audioContext === null) audioContext = new AudioContext(); - refCount++; - return audioContext; -}; - -/** - * Signals that one of the references to the shared AudioContext has been - * released, allowing the context and associated hardware resources to be - * cleaned up if nothing else is using it. - */ -exports.acquireContext = acquireContext; -const releaseContext = () => { - refCount--; - if (refCount === 0) { - var _audioContext; - (_audioContext = audioContext) === null || _audioContext === void 0 ? void 0 : _audioContext.close(); - audioContext = null; - } -}; -exports.releaseContext = releaseContext; -//# sourceMappingURL=audioContext.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js.map deleted file mode 100644 index f146db3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/audioContext.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"audioContext.js","names":["audioContext","refCount","acquireContext","AudioContext","exports","releaseContext","_audioContext","close"],"sources":["../../src/webrtc/audioContext.ts"],"sourcesContent":["/*\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nlet audioContext: AudioContext | null = null;\nlet refCount = 0;\n\n/**\n * Acquires a reference to the shared AudioContext.\n * It's highly recommended to reuse this AudioContext rather than creating your\n * own, because multiple AudioContexts can be problematic in some browsers.\n * Make sure to call releaseContext when you're done using it.\n * @returns The shared AudioContext\n */\nexport const acquireContext = (): AudioContext => {\n if (audioContext === null) audioContext = new AudioContext();\n refCount++;\n return audioContext;\n};\n\n/**\n * Signals that one of the references to the shared AudioContext has been\n * released, allowing the context and associated hardware resources to be\n * cleaned up if nothing else is using it.\n */\nexport const releaseContext = (): void => {\n refCount--;\n if (refCount === 0) {\n audioContext?.close();\n audioContext = null;\n }\n};\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,IAAIA,YAAiC,GAAG,IAAI;AAC5C,IAAIC,QAAQ,GAAG,CAAC;;AAEhB;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMC,cAAc,GAAGA,CAAA,KAAoB;EAC9C,IAAIF,YAAY,KAAK,IAAI,EAAEA,YAAY,GAAG,IAAIG,YAAY,EAAE;EAC5DF,QAAQ,EAAE;EACV,OAAOD,YAAY;AACvB,CAAC;;AAED;AACA;AACA;AACA;AACA;AAJAI,OAAA,CAAAF,cAAA,GAAAA,cAAA;AAKO,MAAMG,cAAc,GAAGA,CAAA,KAAY;EACtCJ,QAAQ,EAAE;EACV,IAAIA,QAAQ,KAAK,CAAC,EAAE;IAAA,IAAAK,aAAA;IAChB,CAAAA,aAAA,GAAAN,YAAY,cAAAM,aAAA,uBAAZA,aAAA,CAAcC,KAAK,EAAE;IACrBP,YAAY,GAAG,IAAI;EACvB;AACJ,CAAC;AAACI,OAAA,CAAAC,cAAA,GAAAA,cAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts deleted file mode 100644 index de1dc28..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts +++ /dev/null @@ -1,551 +0,0 @@ -import { MatrixEvent } from "../models/event"; -import { RoomMember } from "../models/room-member"; -import { MCallAnswer, MCallHangupReject } from "./callEventTypes"; -import { CallFeed } from "./callFeed"; -import { MatrixClient } from "../client"; -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { IScreensharingOpts } from "./mediaHandler"; -import { GroupCallStats } from "./stats/groupCallStats"; -interface CallOpts { - roomId: string; - invitee?: string; - client: MatrixClient; - /** - * Whether relay through TURN should be forced. - * @deprecated use opts.forceTURN when creating the matrix client - * since it's only possible to set this option on outbound calls. - */ - forceTURN?: boolean; - turnServers?: Array; - opponentDeviceId?: string; - opponentSessionId?: string; - groupCallId?: string; -} -interface TurnServer { - urls: Array; - username?: string; - password?: string; - ttl?: number; -} -interface AssertedIdentity { - id: string; - displayName: string; -} -export declare enum CallState { - Fledgling = "fledgling", - InviteSent = "invite_sent", - WaitLocalMedia = "wait_local_media", - CreateOffer = "create_offer", - CreateAnswer = "create_answer", - Connecting = "connecting", - Connected = "connected", - Ringing = "ringing", - Ended = "ended" -} -export declare enum CallType { - Voice = "voice", - Video = "video" -} -export declare enum CallDirection { - Inbound = "inbound", - Outbound = "outbound" -} -export declare enum CallParty { - Local = "local", - Remote = "remote" -} -export declare enum CallEvent { - Hangup = "hangup", - State = "state", - Error = "error", - Replaced = "replaced", - LocalHoldUnhold = "local_hold_unhold", - RemoteHoldUnhold = "remote_hold_unhold", - HoldUnhold = "hold_unhold", - FeedsChanged = "feeds_changed", - AssertedIdentityChanged = "asserted_identity_changed", - LengthChanged = "length_changed", - DataChannel = "datachannel", - SendVoipEvent = "send_voip_event" -} -export declare enum CallErrorCode { - /** The user chose to end the call */ - UserHangup = "user_hangup", - /** An error code when the local client failed to create an offer. */ - LocalOfferFailed = "local_offer_failed", - /** - * An error code when there is no local mic/camera to use. This may be because - * the hardware isn't plugged in, or the user has explicitly denied access. - */ - NoUserMedia = "no_user_media", - /** - * Error code used when a call event failed to send - * because unknown devices were present in the room - */ - UnknownDevices = "unknown_devices", - /** - * Error code used when we fail to send the invite - * for some reason other than there being unknown devices - */ - SendInvite = "send_invite", - /** - * An answer could not be created - */ - CreateAnswer = "create_answer", - /** - * An offer could not be created - */ - CreateOffer = "create_offer", - /** - * Error code used when we fail to send the answer - * for some reason other than there being unknown devices - */ - SendAnswer = "send_answer", - /** - * The session description from the other side could not be set - */ - SetRemoteDescription = "set_remote_description", - /** - * The session description from this side could not be set - */ - SetLocalDescription = "set_local_description", - /** - * A different device answered the call - */ - AnsweredElsewhere = "answered_elsewhere", - /** - * No media connection could be established to the other party - */ - IceFailed = "ice_failed", - /** - * The invite timed out whilst waiting for an answer - */ - InviteTimeout = "invite_timeout", - /** - * The call was replaced by another call - */ - Replaced = "replaced", - /** - * Signalling for the call could not be sent (other than the initial invite) - */ - SignallingFailed = "signalling_timeout", - /** - * The remote party is busy - */ - UserBusy = "user_busy", - /** - * We transferred the call off to somewhere else - */ - Transferred = "transferred", - /** - * A call from the same user was found with a new session id - */ - NewSession = "new_session" -} -export declare class CallError extends Error { - readonly code: string; - constructor(code: CallErrorCode, msg: string, err: Error); -} -export declare function genCallID(): string; -export interface VoipEvent { - type: "toDevice" | "sendEvent"; - eventType: string; - userId?: string; - opponentDeviceId?: string; - roomId?: string; - content: Record; -} -/** - * These now all have the call object as an argument. Why? Well, to know which call a given event is - * about you have three options: - * 1. Use a closure as the callback that remembers what call it's listening to. This can be - * a pain because you need to pass the listener function again when you remove the listener, - * which might be somewhere else. - * 2. Use not-very-well-known fact that EventEmitter sets 'this' to the emitter object in the - * callback. This doesn't really play well with modern Typescript and eslint and doesn't work - * with our pattern of re-emitting events. - * 3. Pass the object in question as an argument to the callback. - * - * Now that we have group calls which have to deal with multiple call objects, this will - * become more important, and I think methods 1 and 2 are just going to cause issues. - */ -export type CallEventHandlerMap = { - [CallEvent.DataChannel]: (channel: RTCDataChannel, call: MatrixCall) => void; - [CallEvent.FeedsChanged]: (feeds: CallFeed[], call: MatrixCall) => void; - [CallEvent.Replaced]: (newCall: MatrixCall, oldCall: MatrixCall) => void; - [CallEvent.Error]: (error: CallError, call: MatrixCall) => void; - [CallEvent.RemoteHoldUnhold]: (onHold: boolean, call: MatrixCall) => void; - [CallEvent.LocalHoldUnhold]: (onHold: boolean, call: MatrixCall) => void; - [CallEvent.LengthChanged]: (length: number, call: MatrixCall) => void; - [CallEvent.State]: (state: CallState, oldState: CallState, call: MatrixCall) => void; - [CallEvent.Hangup]: (call: MatrixCall) => void; - [CallEvent.AssertedIdentityChanged]: (call: MatrixCall) => void; - [CallEvent.HoldUnhold]: (onHold: boolean) => void; - [CallEvent.SendVoipEvent]: (event: VoipEvent, call: MatrixCall) => void; -}; -export declare class MatrixCall extends TypedEventEmitter { - roomId: string; - callId: string; - invitee?: string; - hangupParty?: CallParty; - hangupReason?: string; - direction?: CallDirection; - ourPartyId: string; - peerConn?: RTCPeerConnection; - toDeviceSeq: number; - isPtt: boolean; - private _state; - private readonly client; - private readonly forceTURN?; - private readonly turnServers; - private candidateSendQueue; - private candidateSendTries; - private candidatesEnded; - private feeds; - private transceivers; - private inviteOrAnswerSent; - private waitForLocalAVStream; - private successor?; - private opponentMember?; - private opponentVersion?; - private opponentPartyId; - private opponentCaps?; - private iceDisconnectedTimeout?; - private inviteTimeout?; - private readonly removeTrackListeners; - private remoteOnHold; - private callStatsAtEnd?; - private makingOffer; - private ignoreOffer; - private responsePromiseChain?; - private remoteCandidateBuffer; - private remoteAssertedIdentity?; - private remoteSDPStreamMetadata?; - private callLengthInterval?; - private callStartTime?; - private opponentDeviceId?; - private opponentDeviceInfo?; - private opponentSessionId?; - groupCallId?: string; - private stopVideoTrackTimer?; - private readonly isOnlyDataChannelAllowed; - private stats; - /** - * Construct a new Matrix Call. - * @param opts - Config options. - */ - constructor(opts: CallOpts); - /** - * Place a voice call to this room. - * @throws If you have not specified a listener for 'error' events. - */ - placeVoiceCall(): Promise; - /** - * Place a video call to this room. - * @throws If you have not specified a listener for 'error' events. - */ - placeVideoCall(): Promise; - /** - * Create a datachannel using this call's peer connection. - * @param label - A human readable label for this datachannel - * @param options - An object providing configuration options for the data channel. - */ - createDataChannel(label: string, options: RTCDataChannelInit | undefined): RTCDataChannel; - getOpponentMember(): RoomMember | undefined; - getOpponentDeviceId(): string | undefined; - getOpponentSessionId(): string | undefined; - opponentCanBeTransferred(): boolean; - opponentSupportsDTMF(): boolean; - getRemoteAssertedIdentity(): AssertedIdentity | undefined; - get state(): CallState; - private set state(value); - get type(): CallType; - get hasLocalUserMediaVideoTrack(): boolean; - get hasRemoteUserMediaVideoTrack(): boolean; - get hasLocalUserMediaAudioTrack(): boolean; - get hasRemoteUserMediaAudioTrack(): boolean; - private get hasUserMediaAudioSender(); - private get hasUserMediaVideoSender(); - get localUsermediaFeed(): CallFeed | undefined; - get localScreensharingFeed(): CallFeed | undefined; - get localUsermediaStream(): MediaStream | undefined; - get localScreensharingStream(): MediaStream | undefined; - get remoteUsermediaFeed(): CallFeed | undefined; - get remoteScreensharingFeed(): CallFeed | undefined; - get remoteUsermediaStream(): MediaStream | undefined; - get remoteScreensharingStream(): MediaStream | undefined; - private getFeedByStreamId; - /** - * Returns an array of all CallFeeds - * @returns CallFeeds - */ - getFeeds(): Array; - /** - * Returns an array of all local CallFeeds - * @returns local CallFeeds - */ - getLocalFeeds(): Array; - /** - * Returns an array of all remote CallFeeds - * @returns remote CallFeeds - */ - getRemoteFeeds(): Array; - private initOpponentCrypto; - /** - * Generates and returns localSDPStreamMetadata - * @returns localSDPStreamMetadata - */ - private getLocalSDPStreamMetadata; - /** - * Returns true if there are no incoming feeds, - * otherwise returns false - * @returns no incoming feeds - */ - noIncomingFeeds(): boolean; - private pushRemoteFeed; - /** - * This method is used ONLY if the other client doesn't support sending SDPStreamMetadata - */ - private pushRemoteFeedWithoutMetadata; - private pushNewLocalFeed; - /** - * Pushes supplied feed to the call - * @param callFeed - to push - * @param addToPeerConnection - whether to add the tracks to the peer connection - */ - pushLocalFeed(callFeed: CallFeed, addToPeerConnection?: boolean): void; - /** - * Removes local call feed from the call and its tracks from the peer - * connection - * @param callFeed - to remove - */ - removeLocalFeed(callFeed: CallFeed): void; - private deleteAllFeeds; - private deleteFeedByStream; - private deleteFeed; - getCurrentCallStats(): Promise; - private collectCallStats; - /** - * Configure this call from an invite event. Used by MatrixClient. - * @param event - The m.call.invite event - */ - initWithInvite(event: MatrixEvent): Promise; - /** - * Configure this call from a hangup or reject event. Used by MatrixClient. - * @param event - The m.call.hangup event - */ - initWithHangup(event: MatrixEvent): void; - private shouldAnswerWithMediaType; - /** - * Answer a call. - */ - answer(audio?: boolean, video?: boolean): Promise; - answerWithCallFeeds(callFeeds: CallFeed[]): void; - /** - * Replace this call with a new call, e.g. for glare resolution. Used by - * MatrixClient. - * @param newCall - The new call. - */ - replacedBy(newCall: MatrixCall): void; - /** - * Hangup a call. - * @param reason - The reason why the call is being hung up. - * @param suppressEvent - True to suppress emitting an event. - */ - hangup(reason: CallErrorCode, suppressEvent: boolean): void; - /** - * Reject a call - * This used to be done by calling hangup, but is a separate method and protocol - * event as of MSC2746. - */ - reject(): void; - /** - * Adds an audio and/or video track - upgrades the call - * @param audio - should add an audio track - * @param video - should add an video track - */ - private upgradeCall; - /** - * Returns true if this.remoteSDPStreamMetadata is defined, otherwise returns false - * @returns can screenshare - */ - opponentSupportsSDPStreamMetadata(): boolean; - /** - * If there is a screensharing stream returns true, otherwise returns false - * @returns is screensharing - */ - isScreensharing(): boolean; - /** - * Starts/stops screensharing - * @param enabled - the desired screensharing state - * @param desktopCapturerSourceId - optional id of the desktop capturer source to use - * @returns new screensharing state - */ - setScreensharingEnabled(enabled: boolean, opts?: IScreensharingOpts): Promise; - /** - * Starts/stops screensharing - * Should be used ONLY if the opponent doesn't support SDPStreamMetadata - * @param enabled - the desired screensharing state - * @param desktopCapturerSourceId - optional id of the desktop capturer source to use - * @returns new screensharing state - */ - private setScreensharingEnabledWithoutMetadataSupport; - /** - * Replaces/adds the tracks from the passed stream to the localUsermediaStream - * @param stream - to use a replacement for the local usermedia stream - */ - updateLocalUsermediaStream(stream: MediaStream, forceAudio?: boolean, forceVideo?: boolean): Promise; - /** - * Set whether our outbound video should be muted or not. - * @param muted - True to mute the outbound video. - * @returns the new mute state - */ - setLocalVideoMuted(muted: boolean): Promise; - /** - * Check if local video is muted. - * - * If there are multiple video tracks, all of the tracks need to be muted - * for this to return true. This means if there are no video tracks, this will - * return true. - * @returns True if the local preview video is muted, else false - * (including if the call is not set up yet). - */ - isLocalVideoMuted(): boolean; - /** - * Set whether the microphone should be muted or not. - * @param muted - True to mute the mic. - * @returns the new mute state - */ - setMicrophoneMuted(muted: boolean): Promise; - /** - * Check if the microphone is muted. - * - * If there are multiple audio tracks, all of the tracks need to be muted - * for this to return true. This means if there are no audio tracks, this will - * return true. - * @returns True if the mic is muted, else false (including if the call - * is not set up yet). - */ - isMicrophoneMuted(): boolean; - /** - * @returns true if we have put the party on the other side of the call on hold - * (that is, we are signalling to them that we are not listening) - */ - isRemoteOnHold(): boolean; - setRemoteOnHold(onHold: boolean): void; - /** - * Indicates whether we are 'on hold' to the remote party (ie. if true, - * they cannot hear us). - * @returns true if the other party has put us on hold - */ - isLocalOnHold(): boolean; - /** - * Sends a DTMF digit to the other party - * @param digit - The digit (nb. string - '#' and '*' are dtmf too) - */ - sendDtmfDigit(digit: string): void; - private updateMuteStatus; - sendMetadataUpdate(): Promise; - private gotCallFeedsForInvite; - private sendAnswer; - private queueGotCallFeedsForAnswer; - private mungeSdp; - private createOffer; - private createAnswer; - private gotCallFeedsForAnswer; - /** - * Internal - */ - private gotLocalIceCandidate; - private onIceGatheringStateChange; - onRemoteIceCandidatesReceived(ev: MatrixEvent): Promise; - /** - * Used by MatrixClient. - */ - onAnswerReceived(event: MatrixEvent): Promise; - onSelectAnswerReceived(event: MatrixEvent): Promise; - onNegotiateReceived(event: MatrixEvent): Promise; - private updateRemoteSDPStreamMetadata; - onSDPStreamMetadataChangedReceived(event: MatrixEvent): void; - onAssertedIdentityReceived(event: MatrixEvent): Promise; - callHasEnded(): boolean; - private queueGotLocalOffer; - private wrappedGotLocalOffer; - private gotLocalOffer; - private getLocalOfferFailed; - private getUserMediaFailed; - private onIceConnectionStateChanged; - private onSignallingStateChanged; - private onTrack; - private onDataChannel; - /** - * This method removes all video/rtx codecs from screensharing video - * transceivers. This is necessary since they can cause problems. Without - * this the following steps should produce an error: - * Chromium calls Firefox - * Firefox answers - * Firefox starts screen-sharing - * Chromium starts screen-sharing - * Call crashes for Chromium with: - * [96685:23:0518/162603.933321:ERROR:webrtc_video_engine.cc(3296)] RTX codec (PT=97) mapped to PT=96 which is not in the codec list. - * [96685:23:0518/162603.933377:ERROR:webrtc_video_engine.cc(1171)] GetChangedRecvParameters called without any video codecs. - * [96685:23:0518/162603.933430:ERROR:sdp_offer_answer.cc(4302)] Failed to set local video description recv parameters for m-section with mid='2'. (INVALID_PARAMETER) - */ - private getRidOfRTXCodecs; - private onNegotiationNeeded; - onHangupReceived: (msg: MCallHangupReject) => void; - onRejectReceived: (msg: MCallHangupReject) => void; - onAnsweredElsewhere: (msg: MCallAnswer) => void; - /** - * @internal - */ - private sendVoipEvent; - /** - * Queue a candidate to be sent - * @param content - The candidate to queue up, or null if candidates have finished being generated - * and end-of-candidates should be signalled - */ - private queueCandidate; - private discardDuplicateCandidates; - transfer(targetUserId: string): Promise; - transferToCall(transferTargetCall: MatrixCall): Promise; - private terminate; - private stopAllMedia; - private checkForErrorListener; - private sendCandidateQueue; - /** - * Place a call to this room. - * @throws if you have not specified a listener for 'error' events. - * @throws if have passed audio=false. - */ - placeCall(audio: boolean, video: boolean): Promise; - /** - * Place a call to this room with call feed. - * @param callFeeds - to use - * @throws if you have not specified a listener for 'error' events. - * @throws if have passed audio=false. - */ - placeCallWithCallFeeds(callFeeds: CallFeed[], requestScreenshareFeed?: boolean): Promise; - private createPeerConnection; - private partyIdMatches; - private chooseOpponent; - private addBufferedIceCandidates; - private addIceCandidates; - get hasPeerConnection(): boolean; - initStats(stats: GroupCallStats, peerId?: string): void; -} -export declare function setTracksEnabled(tracks: Array, enabled: boolean): void; -export declare function supportsMatrixCall(): boolean; -/** - * DEPRECATED - * Use client.createCall() - * - * Create a new Matrix call for the browser. - * @param client - The client instance to use. - * @param roomId - The room the call is in. - * @param options - DEPRECATED optional options map. - * @returns the call or null if the browser doesn't support calling. - */ -export declare function createNewMatrixCall(client: MatrixClient, roomId: string, options?: Pick): MatrixCall | null; -export {}; -//# sourceMappingURL=call.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts.map deleted file mode 100644 index a1d00d6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"call.d.ts","sourceRoot":"","sources":["../../src/webrtc/call.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js deleted file mode 100644 index 45e23ad..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js +++ /dev/null @@ -1,2341 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MatrixCall = exports.CallType = exports.CallState = exports.CallParty = exports.CallEvent = exports.CallErrorCode = exports.CallError = exports.CallDirection = void 0; -exports.createNewMatrixCall = createNewMatrixCall; -exports.genCallID = genCallID; -exports.setTracksEnabled = setTracksEnabled; -exports.supportsMatrixCall = supportsMatrixCall; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _uuid = require("uuid"); -var _sdpTransform = require("sdp-transform"); -var _logger = require("../logger"); -var utils = _interopRequireWildcard(require("../utils")); -var _event = require("../@types/event"); -var _randomstring = require("../randomstring"); -var _callEventTypes = require("./callEventTypes"); -var _callFeed = require("./callFeed"); -var _typedEventEmitter = require("../models/typed-event-emitter"); -var _deviceinfo = require("../crypto/deviceinfo"); -var _groupCall = require("./groupCall"); -var _httpApi = require("../http-api"); -function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } -function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -var MediaType; -(function (MediaType) { - MediaType["AUDIO"] = "audio"; - MediaType["VIDEO"] = "video"; -})(MediaType || (MediaType = {})); -var CodecName; // add more as needed -// Used internally to specify modifications to codec parameters in SDP -(function (CodecName) { - CodecName["OPUS"] = "opus"; -})(CodecName || (CodecName = {})); -let CallState; -exports.CallState = CallState; -(function (CallState) { - CallState["Fledgling"] = "fledgling"; - CallState["InviteSent"] = "invite_sent"; - CallState["WaitLocalMedia"] = "wait_local_media"; - CallState["CreateOffer"] = "create_offer"; - CallState["CreateAnswer"] = "create_answer"; - CallState["Connecting"] = "connecting"; - CallState["Connected"] = "connected"; - CallState["Ringing"] = "ringing"; - CallState["Ended"] = "ended"; -})(CallState || (exports.CallState = CallState = {})); -let CallType; -exports.CallType = CallType; -(function (CallType) { - CallType["Voice"] = "voice"; - CallType["Video"] = "video"; -})(CallType || (exports.CallType = CallType = {})); -let CallDirection; -exports.CallDirection = CallDirection; -(function (CallDirection) { - CallDirection["Inbound"] = "inbound"; - CallDirection["Outbound"] = "outbound"; -})(CallDirection || (exports.CallDirection = CallDirection = {})); -let CallParty; -exports.CallParty = CallParty; -(function (CallParty) { - CallParty["Local"] = "local"; - CallParty["Remote"] = "remote"; -})(CallParty || (exports.CallParty = CallParty = {})); -let CallEvent; -exports.CallEvent = CallEvent; -(function (CallEvent) { - CallEvent["Hangup"] = "hangup"; - CallEvent["State"] = "state"; - CallEvent["Error"] = "error"; - CallEvent["Replaced"] = "replaced"; - CallEvent["LocalHoldUnhold"] = "local_hold_unhold"; - CallEvent["RemoteHoldUnhold"] = "remote_hold_unhold"; - CallEvent["HoldUnhold"] = "hold_unhold"; - CallEvent["FeedsChanged"] = "feeds_changed"; - CallEvent["AssertedIdentityChanged"] = "asserted_identity_changed"; - CallEvent["LengthChanged"] = "length_changed"; - CallEvent["DataChannel"] = "datachannel"; - CallEvent["SendVoipEvent"] = "send_voip_event"; -})(CallEvent || (exports.CallEvent = CallEvent = {})); -let CallErrorCode; -/** - * The version field that we set in m.call.* events - */ -exports.CallErrorCode = CallErrorCode; -(function (CallErrorCode) { - CallErrorCode["UserHangup"] = "user_hangup"; - CallErrorCode["LocalOfferFailed"] = "local_offer_failed"; - CallErrorCode["NoUserMedia"] = "no_user_media"; - CallErrorCode["UnknownDevices"] = "unknown_devices"; - CallErrorCode["SendInvite"] = "send_invite"; - CallErrorCode["CreateAnswer"] = "create_answer"; - CallErrorCode["CreateOffer"] = "create_offer"; - CallErrorCode["SendAnswer"] = "send_answer"; - CallErrorCode["SetRemoteDescription"] = "set_remote_description"; - CallErrorCode["SetLocalDescription"] = "set_local_description"; - CallErrorCode["AnsweredElsewhere"] = "answered_elsewhere"; - CallErrorCode["IceFailed"] = "ice_failed"; - CallErrorCode["InviteTimeout"] = "invite_timeout"; - CallErrorCode["Replaced"] = "replaced"; - CallErrorCode["SignallingFailed"] = "signalling_timeout"; - CallErrorCode["UserBusy"] = "user_busy"; - CallErrorCode["Transferred"] = "transferred"; - CallErrorCode["NewSession"] = "new_session"; -})(CallErrorCode || (exports.CallErrorCode = CallErrorCode = {})); -const VOIP_PROTO_VERSION = "1"; - -/** The fallback ICE server to use for STUN or TURN protocols. */ -const FALLBACK_ICE_SERVER = "stun:turn.matrix.org"; - -/** The length of time a call can be ringing for. */ -const CALL_TIMEOUT_MS = 60 * 1000; // ms -/** The time after which we increment callLength */ -const CALL_LENGTH_INTERVAL = 1000; // ms -/** The time after which we end the call, if ICE got disconnected */ -const ICE_DISCONNECTED_TIMEOUT = 30 * 1000; // ms - -class CallError extends Error { - constructor(code, msg, err) { - // Still don't think there's any way to have proper nested errors - super(msg + ": " + err); - (0, _defineProperty2.default)(this, "code", void 0); - this.code = code; - } -} -exports.CallError = CallError; -function genCallID() { - return Date.now().toString() + (0, _randomstring.randomString)(16); -} -function getCodecParamMods(isPtt) { - const mods = [{ - mediaType: "audio", - codec: "opus", - enableDtx: true, - maxAverageBitrate: isPtt ? 12000 : undefined - }]; - return mods; -} -// generates keys for the map of transceivers -// kind is unfortunately a string rather than MediaType as this is the type of -// track.kind -function getTransceiverKey(purpose, kind) { - return purpose + ":" + kind; -} -class MatrixCall extends _typedEventEmitter.TypedEventEmitter { - // whether this call should have push-to-talk semantics - // This should be set by the consumer on incoming & outgoing calls. - - // A queue for candidates waiting to go out. - // We try to amalgamate candidates into a single candidate message where - // possible - - // our transceivers for each purpose and type of media - - // The party ID of the other side: undefined if we haven't chosen a partner - // yet, null if we have but they didn't send a party ID. - - // The logic of when & if a call is on hold is nontrivial and explained in is*OnHold - // This flag represents whether we want the other party to be on hold - - // the stats for the call at the point it ended. We can't get these after we - // tear the call down, so we just grab a snapshot before we stop the call. - // The typescript definitions have this type as 'any' :( - - // Perfect negotiation state: https://www.w3.org/TR/webrtc/#perfect-negotiation-example - - // If candidates arrive before we've picked an opponent (which, in particular, - // will happen if the opponent sends candidates eagerly before the user answers - // the call) we buffer them up here so we can then add the ones from the party we pick - - // Used to keep the timer for the delay before actually stopping our - // video track after muting (see setLocalVideoMuted) - - // Used to allow connection without Video and Audio. To establish a webrtc connection without media a Data channel is - // needed At the moment this property is true if we allow MatrixClient with isVoipWithNoMediaAllowed = true - - /** - * Construct a new Matrix Call. - * @param opts - Config options. - */ - constructor(opts) { - var _opts$forceTURN; - super(); - (0, _defineProperty2.default)(this, "roomId", void 0); - (0, _defineProperty2.default)(this, "callId", void 0); - (0, _defineProperty2.default)(this, "invitee", void 0); - (0, _defineProperty2.default)(this, "hangupParty", void 0); - (0, _defineProperty2.default)(this, "hangupReason", void 0); - (0, _defineProperty2.default)(this, "direction", void 0); - (0, _defineProperty2.default)(this, "ourPartyId", void 0); - (0, _defineProperty2.default)(this, "peerConn", void 0); - (0, _defineProperty2.default)(this, "toDeviceSeq", 0); - (0, _defineProperty2.default)(this, "isPtt", false); - (0, _defineProperty2.default)(this, "_state", CallState.Fledgling); - (0, _defineProperty2.default)(this, "client", void 0); - (0, _defineProperty2.default)(this, "forceTURN", void 0); - (0, _defineProperty2.default)(this, "turnServers", void 0); - (0, _defineProperty2.default)(this, "candidateSendQueue", []); - (0, _defineProperty2.default)(this, "candidateSendTries", 0); - (0, _defineProperty2.default)(this, "candidatesEnded", false); - (0, _defineProperty2.default)(this, "feeds", []); - (0, _defineProperty2.default)(this, "transceivers", new Map()); - (0, _defineProperty2.default)(this, "inviteOrAnswerSent", false); - (0, _defineProperty2.default)(this, "waitForLocalAVStream", false); - (0, _defineProperty2.default)(this, "successor", void 0); - (0, _defineProperty2.default)(this, "opponentMember", void 0); - (0, _defineProperty2.default)(this, "opponentVersion", void 0); - (0, _defineProperty2.default)(this, "opponentPartyId", void 0); - (0, _defineProperty2.default)(this, "opponentCaps", void 0); - (0, _defineProperty2.default)(this, "iceDisconnectedTimeout", void 0); - (0, _defineProperty2.default)(this, "inviteTimeout", void 0); - (0, _defineProperty2.default)(this, "removeTrackListeners", new Map()); - (0, _defineProperty2.default)(this, "remoteOnHold", false); - (0, _defineProperty2.default)(this, "callStatsAtEnd", void 0); - (0, _defineProperty2.default)(this, "makingOffer", false); - (0, _defineProperty2.default)(this, "ignoreOffer", false); - (0, _defineProperty2.default)(this, "responsePromiseChain", void 0); - (0, _defineProperty2.default)(this, "remoteCandidateBuffer", new Map()); - (0, _defineProperty2.default)(this, "remoteAssertedIdentity", void 0); - (0, _defineProperty2.default)(this, "remoteSDPStreamMetadata", void 0); - (0, _defineProperty2.default)(this, "callLengthInterval", void 0); - (0, _defineProperty2.default)(this, "callStartTime", void 0); - (0, _defineProperty2.default)(this, "opponentDeviceId", void 0); - (0, _defineProperty2.default)(this, "opponentDeviceInfo", void 0); - (0, _defineProperty2.default)(this, "opponentSessionId", void 0); - (0, _defineProperty2.default)(this, "groupCallId", void 0); - (0, _defineProperty2.default)(this, "stopVideoTrackTimer", void 0); - (0, _defineProperty2.default)(this, "isOnlyDataChannelAllowed", void 0); - (0, _defineProperty2.default)(this, "stats", void 0); - (0, _defineProperty2.default)(this, "gotLocalIceCandidate", event => { - if (event.candidate) { - if (this.candidatesEnded) { - _logger.logger.warn(`Call ${this.callId} gotLocalIceCandidate() got candidate after candidates have ended - ignoring!`); - return; - } - _logger.logger.debug(`Call ${this.callId} got local ICE ${event.candidate.sdpMid} ${event.candidate.candidate}`); - if (this.callHasEnded()) return; - - // As with the offer, note we need to make a copy of this object, not - // pass the original: that broke in Chrome ~m43. - if (event.candidate.candidate === "") { - this.queueCandidate(null); - } else { - this.queueCandidate(event.candidate); - } - } - }); - (0, _defineProperty2.default)(this, "onIceGatheringStateChange", event => { - var _this$peerConn; - _logger.logger.debug(`Call ${this.callId} onIceGatheringStateChange() ice gathering state changed to ${this.peerConn.iceGatheringState}`); - if (((_this$peerConn = this.peerConn) === null || _this$peerConn === void 0 ? void 0 : _this$peerConn.iceGatheringState) === "complete") { - this.queueCandidate(null); - } - }); - (0, _defineProperty2.default)(this, "getLocalOfferFailed", err => { - _logger.logger.error(`Call ${this.callId} getLocalOfferFailed() running`, err); - this.emit(CallEvent.Error, new CallError(CallErrorCode.LocalOfferFailed, "Failed to get local offer!", err), this); - this.terminate(CallParty.Local, CallErrorCode.LocalOfferFailed, false); - }); - (0, _defineProperty2.default)(this, "getUserMediaFailed", err => { - if (this.successor) { - this.successor.getUserMediaFailed(err); - return; - } - _logger.logger.warn(`Call ${this.callId} getUserMediaFailed() failed to get user media - ending call`, err); - this.emit(CallEvent.Error, new CallError(CallErrorCode.NoUserMedia, "Couldn't start capturing media! Is your microphone set up and " + "does this app have permission?", err), this); - this.terminate(CallParty.Local, CallErrorCode.NoUserMedia, false); - }); - (0, _defineProperty2.default)(this, "onIceConnectionStateChanged", () => { - var _this$peerConn2, _this$peerConn$iceCon, _this$peerConn3, _this$peerConn4, _this$peerConn6; - if (this.callHasEnded()) { - return; // because ICE can still complete as we're ending the call - } - - _logger.logger.debug(`Call ${this.callId} onIceConnectionStateChanged() running (state=${(_this$peerConn2 = this.peerConn) === null || _this$peerConn2 === void 0 ? void 0 : _this$peerConn2.iceConnectionState})`); - - // ideally we'd consider the call to be connected when we get media but - // chrome doesn't implement any of the 'onstarted' events yet - if (["connected", "completed"].includes((_this$peerConn$iceCon = (_this$peerConn3 = this.peerConn) === null || _this$peerConn3 === void 0 ? void 0 : _this$peerConn3.iceConnectionState) !== null && _this$peerConn$iceCon !== void 0 ? _this$peerConn$iceCon : "")) { - clearTimeout(this.iceDisconnectedTimeout); - this.iceDisconnectedTimeout = undefined; - this.state = CallState.Connected; - if (!this.callLengthInterval && !this.callStartTime) { - this.callStartTime = Date.now(); - this.callLengthInterval = setInterval(() => { - this.emit(CallEvent.LengthChanged, Math.round((Date.now() - this.callStartTime) / 1000), this); - }, CALL_LENGTH_INTERVAL); - } - } else if (((_this$peerConn4 = this.peerConn) === null || _this$peerConn4 === void 0 ? void 0 : _this$peerConn4.iceConnectionState) == "failed") { - var _this$peerConn5; - // Firefox for Android does not yet have support for restartIce() - // (the types say it's always defined though, so we have to cast - // to prevent typescript from warning). - if ((_this$peerConn5 = this.peerConn) !== null && _this$peerConn5 !== void 0 && _this$peerConn5.restartIce) { - this.candidatesEnded = false; - this.peerConn.restartIce(); - } else { - _logger.logger.info(`Call ${this.callId} onIceConnectionStateChanged() hanging up call (ICE failed and no ICE restart method)`); - this.hangup(CallErrorCode.IceFailed, false); - } - } else if (((_this$peerConn6 = this.peerConn) === null || _this$peerConn6 === void 0 ? void 0 : _this$peerConn6.iceConnectionState) == "disconnected") { - this.iceDisconnectedTimeout = setTimeout(() => { - _logger.logger.info(`Call ${this.callId} onIceConnectionStateChanged() hanging up call (ICE disconnected for too long)`); - this.hangup(CallErrorCode.IceFailed, false); - }, ICE_DISCONNECTED_TIMEOUT); - this.state = CallState.Connecting; - } - - // In PTT mode, override feed status to muted when we lose connection to - // the peer, since we don't want to block the line if they're not saying anything. - // Experimenting in Chrome, this happens after 5 or 6 seconds, which is probably - // fast enough. - if (this.isPtt && ["failed", "disconnected"].includes(this.peerConn.iceConnectionState)) { - for (const feed of this.getRemoteFeeds()) { - feed.setAudioVideoMuted(true, true); - } - } - }); - (0, _defineProperty2.default)(this, "onSignallingStateChanged", () => { - var _this$peerConn7; - _logger.logger.debug(`Call ${this.callId} onSignallingStateChanged() running (state=${(_this$peerConn7 = this.peerConn) === null || _this$peerConn7 === void 0 ? void 0 : _this$peerConn7.signalingState})`); - }); - (0, _defineProperty2.default)(this, "onTrack", ev => { - if (ev.streams.length === 0) { - _logger.logger.warn(`Call ${this.callId} onTrack() called with streamless track streamless (kind=${ev.track.kind})`); - return; - } - const stream = ev.streams[0]; - this.pushRemoteFeed(stream); - if (!this.removeTrackListeners.has(stream)) { - const onRemoveTrack = () => { - if (stream.getTracks().length === 0) { - _logger.logger.info(`Call ${this.callId} onTrack() removing track (streamId=${stream.id})`); - this.deleteFeedByStream(stream); - stream.removeEventListener("removetrack", onRemoveTrack); - this.removeTrackListeners.delete(stream); - } - }; - stream.addEventListener("removetrack", onRemoveTrack); - this.removeTrackListeners.set(stream, onRemoveTrack); - } - }); - (0, _defineProperty2.default)(this, "onDataChannel", ev => { - this.emit(CallEvent.DataChannel, ev.channel, this); - }); - (0, _defineProperty2.default)(this, "onNegotiationNeeded", async () => { - _logger.logger.info(`Call ${this.callId} onNegotiationNeeded() negotiation is needed!`); - if (this.state !== CallState.CreateOffer && this.opponentVersion === 0) { - _logger.logger.info(`Call ${this.callId} onNegotiationNeeded() opponent does not support renegotiation: ignoring negotiationneeded event`); - return; - } - this.queueGotLocalOffer(); - }); - (0, _defineProperty2.default)(this, "onHangupReceived", msg => { - _logger.logger.debug(`Call ${this.callId} onHangupReceived() running`); - - // party ID must match (our chosen partner hanging up the call) or be undefined (we haven't chosen - // a partner yet but we're treating the hangup as a reject as per VoIP v0) - if (this.partyIdMatches(msg) || this.state === CallState.Ringing) { - // default reason is user_hangup - this.terminate(CallParty.Remote, msg.reason || CallErrorCode.UserHangup, true); - } else { - _logger.logger.info(`Call ${this.callId} onHangupReceived() ignoring message from party ID ${msg.party_id}: our partner is ${this.opponentPartyId}`); - } - }); - (0, _defineProperty2.default)(this, "onRejectReceived", msg => { - _logger.logger.debug(`Call ${this.callId} onRejectReceived() running`); - - // No need to check party_id for reject because if we'd received either - // an answer or reject, we wouldn't be in state InviteSent - - const shouldTerminate = - // reject events also end the call if it's ringing: it's another of - // our devices rejecting the call. - [CallState.InviteSent, CallState.Ringing].includes(this.state) || - // also if we're in the init state and it's an inbound call, since - // this means we just haven't entered the ringing state yet - this.state === CallState.Fledgling && this.direction === CallDirection.Inbound; - if (shouldTerminate) { - this.terminate(CallParty.Remote, msg.reason || CallErrorCode.UserHangup, true); - } else { - _logger.logger.debug(`Call ${this.callId} onRejectReceived() called in wrong state (state=${this.state})`); - } - }); - (0, _defineProperty2.default)(this, "onAnsweredElsewhere", msg => { - _logger.logger.debug(`Call ${this.callId} onAnsweredElsewhere() running`); - this.terminate(CallParty.Remote, CallErrorCode.AnsweredElsewhere, true); - }); - this.roomId = opts.roomId; - this.invitee = opts.invitee; - this.client = opts.client; - if (!this.client.deviceId) throw new Error("Client must have a device ID to start calls"); - this.forceTURN = (_opts$forceTURN = opts.forceTURN) !== null && _opts$forceTURN !== void 0 ? _opts$forceTURN : false; - this.ourPartyId = this.client.deviceId; - this.opponentDeviceId = opts.opponentDeviceId; - this.opponentSessionId = opts.opponentSessionId; - this.groupCallId = opts.groupCallId; - // Array of Objects with urls, username, credential keys - this.turnServers = opts.turnServers || []; - if (this.turnServers.length === 0 && this.client.isFallbackICEServerAllowed()) { - this.turnServers.push({ - urls: [FALLBACK_ICE_SERVER] - }); - } - for (const server of this.turnServers) { - utils.checkObjectHasKeys(server, ["urls"]); - } - this.callId = genCallID(); - // If the Client provides calls without audio and video we need a datachannel for a webrtc connection - this.isOnlyDataChannelAllowed = this.client.isVoipWithNoMediaAllowed; - } - - /** - * Place a voice call to this room. - * @throws If you have not specified a listener for 'error' events. - */ - async placeVoiceCall() { - await this.placeCall(true, false); - } - - /** - * Place a video call to this room. - * @throws If you have not specified a listener for 'error' events. - */ - async placeVideoCall() { - await this.placeCall(true, true); - } - - /** - * Create a datachannel using this call's peer connection. - * @param label - A human readable label for this datachannel - * @param options - An object providing configuration options for the data channel. - */ - createDataChannel(label, options) { - const dataChannel = this.peerConn.createDataChannel(label, options); - this.emit(CallEvent.DataChannel, dataChannel, this); - return dataChannel; - } - getOpponentMember() { - return this.opponentMember; - } - getOpponentDeviceId() { - return this.opponentDeviceId; - } - getOpponentSessionId() { - return this.opponentSessionId; - } - opponentCanBeTransferred() { - return Boolean(this.opponentCaps && this.opponentCaps["m.call.transferee"]); - } - opponentSupportsDTMF() { - return Boolean(this.opponentCaps && this.opponentCaps["m.call.dtmf"]); - } - getRemoteAssertedIdentity() { - return this.remoteAssertedIdentity; - } - get state() { - return this._state; - } - set state(state) { - const oldState = this._state; - this._state = state; - this.emit(CallEvent.State, state, oldState, this); - } - get type() { - // we may want to look for a video receiver here rather than a track to match the - // sender behaviour, although in practice they should be the same thing - return this.hasUserMediaVideoSender || this.hasRemoteUserMediaVideoTrack ? CallType.Video : CallType.Voice; - } - get hasLocalUserMediaVideoTrack() { - var _this$localUsermediaS; - return !!((_this$localUsermediaS = this.localUsermediaStream) !== null && _this$localUsermediaS !== void 0 && _this$localUsermediaS.getVideoTracks().length); - } - get hasRemoteUserMediaVideoTrack() { - return this.getRemoteFeeds().some(feed => { - var _feed$stream; - return feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Usermedia && ((_feed$stream = feed.stream) === null || _feed$stream === void 0 ? void 0 : _feed$stream.getVideoTracks().length); - }); - } - get hasLocalUserMediaAudioTrack() { - var _this$localUsermediaS2; - return !!((_this$localUsermediaS2 = this.localUsermediaStream) !== null && _this$localUsermediaS2 !== void 0 && _this$localUsermediaS2.getAudioTracks().length); - } - get hasRemoteUserMediaAudioTrack() { - return this.getRemoteFeeds().some(feed => { - var _feed$stream2; - return feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Usermedia && !!((_feed$stream2 = feed.stream) !== null && _feed$stream2 !== void 0 && _feed$stream2.getAudioTracks().length); - }); - } - get hasUserMediaAudioSender() { - var _this$transceivers$ge; - return Boolean((_this$transceivers$ge = this.transceivers.get(getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Usermedia, "audio"))) === null || _this$transceivers$ge === void 0 ? void 0 : _this$transceivers$ge.sender); - } - get hasUserMediaVideoSender() { - var _this$transceivers$ge2; - return Boolean((_this$transceivers$ge2 = this.transceivers.get(getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Usermedia, "video"))) === null || _this$transceivers$ge2 === void 0 ? void 0 : _this$transceivers$ge2.sender); - } - get localUsermediaFeed() { - return this.getLocalFeeds().find(feed => feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Usermedia); - } - get localScreensharingFeed() { - return this.getLocalFeeds().find(feed => feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Screenshare); - } - get localUsermediaStream() { - var _this$localUsermediaF; - return (_this$localUsermediaF = this.localUsermediaFeed) === null || _this$localUsermediaF === void 0 ? void 0 : _this$localUsermediaF.stream; - } - get localScreensharingStream() { - var _this$localScreenshar; - return (_this$localScreenshar = this.localScreensharingFeed) === null || _this$localScreenshar === void 0 ? void 0 : _this$localScreenshar.stream; - } - get remoteUsermediaFeed() { - return this.getRemoteFeeds().find(feed => feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Usermedia); - } - get remoteScreensharingFeed() { - return this.getRemoteFeeds().find(feed => feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Screenshare); - } - get remoteUsermediaStream() { - var _this$remoteUsermedia; - return (_this$remoteUsermedia = this.remoteUsermediaFeed) === null || _this$remoteUsermedia === void 0 ? void 0 : _this$remoteUsermedia.stream; - } - get remoteScreensharingStream() { - var _this$remoteScreensha; - return (_this$remoteScreensha = this.remoteScreensharingFeed) === null || _this$remoteScreensha === void 0 ? void 0 : _this$remoteScreensha.stream; - } - getFeedByStreamId(streamId) { - return this.getFeeds().find(feed => feed.stream.id === streamId); - } - - /** - * Returns an array of all CallFeeds - * @returns CallFeeds - */ - getFeeds() { - return this.feeds; - } - - /** - * Returns an array of all local CallFeeds - * @returns local CallFeeds - */ - getLocalFeeds() { - return this.feeds.filter(feed => feed.isLocal()); - } - - /** - * Returns an array of all remote CallFeeds - * @returns remote CallFeeds - */ - getRemoteFeeds() { - return this.feeds.filter(feed => !feed.isLocal()); - } - async initOpponentCrypto() { - var _this$getOpponentMemb, _deviceInfoMap$get; - if (!this.opponentDeviceId) return; - if (!this.client.getUseE2eForGroupCall()) return; - // It's possible to want E2EE and yet not have the means to manage E2EE - // ourselves (for example if the client is a RoomWidgetClient) - if (!this.client.isCryptoEnabled()) { - // All we know is the device ID - this.opponentDeviceInfo = new _deviceinfo.DeviceInfo(this.opponentDeviceId); - return; - } - // if we've got to this point, we do want to init crypto, so throw if we can't - if (!this.client.crypto) throw new Error("Crypto is not initialised."); - const userId = this.invitee || ((_this$getOpponentMemb = this.getOpponentMember()) === null || _this$getOpponentMemb === void 0 ? void 0 : _this$getOpponentMemb.userId); - if (!userId) throw new Error("Couldn't find opponent user ID to init crypto"); - const deviceInfoMap = await this.client.crypto.deviceList.downloadKeys([userId], false); - this.opponentDeviceInfo = (_deviceInfoMap$get = deviceInfoMap.get(userId)) === null || _deviceInfoMap$get === void 0 ? void 0 : _deviceInfoMap$get.get(this.opponentDeviceId); - if (this.opponentDeviceInfo === undefined) { - throw new _groupCall.GroupCallUnknownDeviceError(userId); - } - } - - /** - * Generates and returns localSDPStreamMetadata - * @returns localSDPStreamMetadata - */ - getLocalSDPStreamMetadata(updateStreamIds = false) { - const metadata = {}; - for (const localFeed of this.getLocalFeeds()) { - if (updateStreamIds) { - localFeed.sdpMetadataStreamId = localFeed.stream.id; - } - metadata[localFeed.sdpMetadataStreamId] = { - purpose: localFeed.purpose, - audio_muted: localFeed.isAudioMuted(), - video_muted: localFeed.isVideoMuted() - }; - } - return metadata; - } - - /** - * Returns true if there are no incoming feeds, - * otherwise returns false - * @returns no incoming feeds - */ - noIncomingFeeds() { - return !this.feeds.some(feed => !feed.isLocal()); - } - pushRemoteFeed(stream) { - // Fallback to old behavior if the other side doesn't support SDPStreamMetadata - if (!this.opponentSupportsSDPStreamMetadata()) { - this.pushRemoteFeedWithoutMetadata(stream); - return; - } - const userId = this.getOpponentMember().userId; - const purpose = this.remoteSDPStreamMetadata[stream.id].purpose; - const audioMuted = this.remoteSDPStreamMetadata[stream.id].audio_muted; - const videoMuted = this.remoteSDPStreamMetadata[stream.id].video_muted; - if (!purpose) { - _logger.logger.warn(`Call ${this.callId} pushRemoteFeed() ignoring stream because we didn't get any metadata about it (streamId=${stream.id})`); - return; - } - if (this.getFeedByStreamId(stream.id)) { - _logger.logger.warn(`Call ${this.callId} pushRemoteFeed() ignoring stream because we already have a feed for it (streamId=${stream.id})`); - return; - } - this.feeds.push(new _callFeed.CallFeed({ - client: this.client, - call: this, - roomId: this.roomId, - userId, - deviceId: this.getOpponentDeviceId(), - stream, - purpose, - audioMuted, - videoMuted - })); - this.emit(CallEvent.FeedsChanged, this.feeds, this); - _logger.logger.info(`Call ${this.callId} pushRemoteFeed() pushed stream (streamId=${stream.id}, active=${stream.active}, purpose=${purpose})`); - } - - /** - * This method is used ONLY if the other client doesn't support sending SDPStreamMetadata - */ - pushRemoteFeedWithoutMetadata(stream) { - var _this$feeds$find; - const userId = this.getOpponentMember().userId; - // We can guess the purpose here since the other client can only send one stream - const purpose = _callEventTypes.SDPStreamMetadataPurpose.Usermedia; - const oldRemoteStream = (_this$feeds$find = this.feeds.find(feed => !feed.isLocal())) === null || _this$feeds$find === void 0 ? void 0 : _this$feeds$find.stream; - - // Note that we check by ID and always set the remote stream: Chrome appears - // to make new stream objects when transceiver directionality is changed and the 'active' - // status of streams change - Dave - // If we already have a stream, check this stream has the same id - if (oldRemoteStream && stream.id !== oldRemoteStream.id) { - _logger.logger.warn(`Call ${this.callId} pushRemoteFeedWithoutMetadata() ignoring new stream because we already have stream (streamId=${stream.id})`); - return; - } - if (this.getFeedByStreamId(stream.id)) { - _logger.logger.warn(`Call ${this.callId} pushRemoteFeedWithoutMetadata() ignoring stream because we already have a feed for it (streamId=${stream.id})`); - return; - } - this.feeds.push(new _callFeed.CallFeed({ - client: this.client, - call: this, - roomId: this.roomId, - audioMuted: false, - videoMuted: false, - userId, - deviceId: this.getOpponentDeviceId(), - stream, - purpose - })); - this.emit(CallEvent.FeedsChanged, this.feeds, this); - _logger.logger.info(`Call ${this.callId} pushRemoteFeedWithoutMetadata() pushed stream (streamId=${stream.id}, active=${stream.active})`); - } - pushNewLocalFeed(stream, purpose, addToPeerConnection = true) { - const userId = this.client.getUserId(); - - // Tracks don't always start off enabled, eg. chrome will give a disabled - // audio track if you ask for user media audio and already had one that - // you'd set to disabled (presumably because it clones them internally). - setTracksEnabled(stream.getAudioTracks(), true); - setTracksEnabled(stream.getVideoTracks(), true); - if (this.getFeedByStreamId(stream.id)) { - _logger.logger.warn(`Call ${this.callId} pushNewLocalFeed() ignoring stream because we already have a feed for it (streamId=${stream.id})`); - return; - } - this.pushLocalFeed(new _callFeed.CallFeed({ - client: this.client, - roomId: this.roomId, - audioMuted: false, - videoMuted: false, - userId, - deviceId: this.getOpponentDeviceId(), - stream, - purpose - }), addToPeerConnection); - } - - /** - * Pushes supplied feed to the call - * @param callFeed - to push - * @param addToPeerConnection - whether to add the tracks to the peer connection - */ - pushLocalFeed(callFeed, addToPeerConnection = true) { - if (this.feeds.some(feed => callFeed.stream.id === feed.stream.id)) { - _logger.logger.info(`Call ${this.callId} pushLocalFeed() ignoring duplicate local stream (streamId=${callFeed.stream.id})`); - return; - } - this.feeds.push(callFeed); - if (addToPeerConnection) { - for (const track of callFeed.stream.getTracks()) { - _logger.logger.info(`Call ${this.callId} pushLocalFeed() adding track to peer connection (id=${track.id}, kind=${track.kind}, streamId=${callFeed.stream.id}, streamPurpose=${callFeed.purpose}, enabled=${track.enabled})`); - const tKey = getTransceiverKey(callFeed.purpose, track.kind); - if (this.transceivers.has(tKey)) { - // we already have a sender, so we re-use it. We try to re-use transceivers as much - // as possible because they can't be removed once added, so otherwise they just - // accumulate which makes the SDP very large very quickly: in fact it only takes - // about 6 video tracks to exceed the maximum size of an Olm-encrypted - // Matrix event. - const transceiver = this.transceivers.get(tKey); - transceiver.sender.replaceTrack(track); - // set the direction to indicate we're going to start sending again - // (this will trigger the re-negotiation) - transceiver.direction = transceiver.direction === "inactive" ? "sendonly" : "sendrecv"; - } else { - // create a new one. We need to use addTrack rather addTransceiver for this because firefox - // doesn't yet implement RTCRTPSender.setStreams() - // (https://bugzilla.mozilla.org/show_bug.cgi?id=1510802) so we'd have no way to group the - // two tracks together into a stream. - const newSender = this.peerConn.addTrack(track, callFeed.stream); - - // now go & fish for the new transceiver - const newTransceiver = this.peerConn.getTransceivers().find(t => t.sender === newSender); - if (newTransceiver) { - this.transceivers.set(tKey, newTransceiver); - } else { - _logger.logger.warn(`Call ${this.callId} pushLocalFeed() didn't find a matching transceiver after adding track!`); - } - } - } - } - _logger.logger.info(`Call ${this.callId} pushLocalFeed() pushed stream (id=${callFeed.stream.id}, active=${callFeed.stream.active}, purpose=${callFeed.purpose})`); - this.emit(CallEvent.FeedsChanged, this.feeds, this); - } - - /** - * Removes local call feed from the call and its tracks from the peer - * connection - * @param callFeed - to remove - */ - removeLocalFeed(callFeed) { - const audioTransceiverKey = getTransceiverKey(callFeed.purpose, "audio"); - const videoTransceiverKey = getTransceiverKey(callFeed.purpose, "video"); - for (const transceiverKey of [audioTransceiverKey, videoTransceiverKey]) { - // this is slightly mixing the track and transceiver API but is basically just shorthand. - // There is no way to actually remove a transceiver, so this just sets it to inactive - // (or recvonly) and replaces the source with nothing. - if (this.transceivers.has(transceiverKey)) { - const transceiver = this.transceivers.get(transceiverKey); - if (transceiver.sender) this.peerConn.removeTrack(transceiver.sender); - } - } - if (callFeed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Screenshare) { - this.client.getMediaHandler().stopScreensharingStream(callFeed.stream); - } - this.deleteFeed(callFeed); - } - deleteAllFeeds() { - for (const feed of this.feeds) { - if (!feed.isLocal() || !this.groupCallId) { - feed.dispose(); - } - } - this.feeds = []; - this.emit(CallEvent.FeedsChanged, this.feeds, this); - } - deleteFeedByStream(stream) { - const feed = this.getFeedByStreamId(stream.id); - if (!feed) { - _logger.logger.warn(`Call ${this.callId} deleteFeedByStream() didn't find the feed to delete (streamId=${stream.id})`); - return; - } - this.deleteFeed(feed); - } - deleteFeed(feed) { - feed.dispose(); - this.feeds.splice(this.feeds.indexOf(feed), 1); - this.emit(CallEvent.FeedsChanged, this.feeds, this); - } - - // The typescript definitions have this type as 'any' :( - async getCurrentCallStats() { - if (this.callHasEnded()) { - return this.callStatsAtEnd; - } - return this.collectCallStats(); - } - async collectCallStats() { - // This happens when the call fails before it starts. - // For example when we fail to get capture sources - if (!this.peerConn) return; - const statsReport = await this.peerConn.getStats(); - const stats = []; - statsReport.forEach(item => { - stats.push(item); - }); - return stats; - } - - /** - * Configure this call from an invite event. Used by MatrixClient. - * @param event - The m.call.invite event - */ - async initWithInvite(event) { - var _this$feeds$find2; - const invite = event.getContent(); - this.direction = CallDirection.Inbound; - - // make sure we have valid turn creds. Unless something's gone wrong, it should - // poll and keep the credentials valid so this should be instant. - const haveTurnCreds = await this.client.checkTurnServers(); - if (!haveTurnCreds) { - _logger.logger.warn(`Call ${this.callId} initWithInvite() failed to get TURN credentials! Proceeding with call anyway...`); - } - const sdpStreamMetadata = invite[_callEventTypes.SDPStreamMetadataKey]; - if (sdpStreamMetadata) { - this.updateRemoteSDPStreamMetadata(sdpStreamMetadata); - } else { - _logger.logger.debug(`Call ${this.callId} initWithInvite() did not get any SDPStreamMetadata! Can not send/receive multiple streams`); - } - this.peerConn = this.createPeerConnection(); - // we must set the party ID before await-ing on anything: the call event - // handler will start giving us more call events (eg. candidates) so if - // we haven't set the party ID, we'll ignore them. - this.chooseOpponent(event); - await this.initOpponentCrypto(); - try { - await this.peerConn.setRemoteDescription(invite.offer); - await this.addBufferedIceCandidates(); - } catch (e) { - _logger.logger.debug(`Call ${this.callId} initWithInvite() failed to set remote description`, e); - this.terminate(CallParty.Local, CallErrorCode.SetRemoteDescription, false); - return; - } - const remoteStream = (_this$feeds$find2 = this.feeds.find(feed => !feed.isLocal())) === null || _this$feeds$find2 === void 0 ? void 0 : _this$feeds$find2.stream; - - // According to previous comments in this file, firefox at some point did not - // add streams until media started arriving on them. Testing latest firefox - // (81 at time of writing), this is no longer a problem, so let's do it the correct way. - // - // For example in case of no media webrtc connections like screen share only call we have to allow webrtc - // connections without remote media. In this case we always use a data channel. At the moment we allow as well - // only data channel as media in the WebRTC connection with this setup here. - if (!this.isOnlyDataChannelAllowed && (!remoteStream || remoteStream.getTracks().length === 0)) { - _logger.logger.error(`Call ${this.callId} initWithInvite() no remote stream or no tracks after setting remote description!`); - this.terminate(CallParty.Local, CallErrorCode.SetRemoteDescription, false); - return; - } - this.state = CallState.Ringing; - if (event.getLocalAge()) { - // Time out the call if it's ringing for too long - const ringingTimer = setTimeout(() => { - if (this.state == CallState.Ringing) { - var _this$stats; - _logger.logger.debug(`Call ${this.callId} initWithInvite() invite has expired. Hanging up.`); - this.hangupParty = CallParty.Remote; // effectively - this.state = CallState.Ended; - this.stopAllMedia(); - if (this.peerConn.signalingState != "closed") { - this.peerConn.close(); - } - (_this$stats = this.stats) === null || _this$stats === void 0 ? void 0 : _this$stats.removeStatsReportGatherer(this.callId); - this.emit(CallEvent.Hangup, this); - } - }, invite.lifetime - event.getLocalAge()); - const onState = state => { - if (state !== CallState.Ringing) { - clearTimeout(ringingTimer); - this.off(CallEvent.State, onState); - } - }; - this.on(CallEvent.State, onState); - } - } - - /** - * Configure this call from a hangup or reject event. Used by MatrixClient. - * @param event - The m.call.hangup event - */ - initWithHangup(event) { - // perverse as it may seem, sometimes we want to instantiate a call with a - // hangup message (because when getting the state of the room on load, events - // come in reverse order and we want to remember that a call has been hung up) - this.state = CallState.Ended; - } - shouldAnswerWithMediaType(wantedValue, valueOfTheOtherSide, type) { - if (wantedValue && !valueOfTheOtherSide) { - // TODO: Figure out how to do this - _logger.logger.warn(`Call ${this.callId} shouldAnswerWithMediaType() unable to answer with ${type} because the other side isn't sending it either.`); - return false; - } else if (!utils.isNullOrUndefined(wantedValue) && wantedValue !== valueOfTheOtherSide && !this.opponentSupportsSDPStreamMetadata()) { - _logger.logger.warn(`Call ${this.callId} shouldAnswerWithMediaType() unable to answer with ${type}=${wantedValue} because the other side doesn't support it. Answering with ${type}=${valueOfTheOtherSide}.`); - return valueOfTheOtherSide; - } - return wantedValue !== null && wantedValue !== void 0 ? wantedValue : valueOfTheOtherSide; - } - - /** - * Answer a call. - */ - async answer(audio, video) { - if (this.inviteOrAnswerSent) return; - // TODO: Figure out how to do this - if (audio === false && video === false) throw new Error("You CANNOT answer a call without media"); - if (!this.localUsermediaStream && !this.waitForLocalAVStream) { - const prevState = this.state; - const answerWithAudio = this.shouldAnswerWithMediaType(audio, this.hasRemoteUserMediaAudioTrack, "audio"); - const answerWithVideo = this.shouldAnswerWithMediaType(video, this.hasRemoteUserMediaVideoTrack, "video"); - this.state = CallState.WaitLocalMedia; - this.waitForLocalAVStream = true; - try { - var _this$client$getDevic; - const stream = await this.client.getMediaHandler().getUserMediaStream(answerWithAudio, answerWithVideo); - this.waitForLocalAVStream = false; - const usermediaFeed = new _callFeed.CallFeed({ - client: this.client, - roomId: this.roomId, - userId: this.client.getUserId(), - deviceId: (_this$client$getDevic = this.client.getDeviceId()) !== null && _this$client$getDevic !== void 0 ? _this$client$getDevic : undefined, - stream, - purpose: _callEventTypes.SDPStreamMetadataPurpose.Usermedia, - audioMuted: false, - videoMuted: false - }); - const feeds = [usermediaFeed]; - if (this.localScreensharingFeed) { - feeds.push(this.localScreensharingFeed); - } - this.answerWithCallFeeds(feeds); - } catch (e) { - if (answerWithVideo) { - // Try to answer without video - _logger.logger.warn(`Call ${this.callId} answer() failed to getUserMedia(), trying to getUserMedia() without video`); - this.state = prevState; - this.waitForLocalAVStream = false; - await this.answer(answerWithAudio, false); - } else { - this.getUserMediaFailed(e); - return; - } - } - } else if (this.waitForLocalAVStream) { - this.state = CallState.WaitLocalMedia; - } - } - answerWithCallFeeds(callFeeds) { - if (this.inviteOrAnswerSent) return; - this.queueGotCallFeedsForAnswer(callFeeds); - } - - /** - * Replace this call with a new call, e.g. for glare resolution. Used by - * MatrixClient. - * @param newCall - The new call. - */ - replacedBy(newCall) { - _logger.logger.debug(`Call ${this.callId} replacedBy() running (newCallId=${newCall.callId})`); - if (this.state === CallState.WaitLocalMedia) { - _logger.logger.debug(`Call ${this.callId} replacedBy() telling new call to wait for local media (newCallId=${newCall.callId})`); - newCall.waitForLocalAVStream = true; - } else if ([CallState.CreateOffer, CallState.InviteSent].includes(this.state)) { - if (newCall.direction === CallDirection.Outbound) { - newCall.queueGotCallFeedsForAnswer([]); - } else { - _logger.logger.debug(`Call ${this.callId} replacedBy() handing local stream to new call(newCallId=${newCall.callId})`); - newCall.queueGotCallFeedsForAnswer(this.getLocalFeeds().map(feed => feed.clone())); - } - } - this.successor = newCall; - this.emit(CallEvent.Replaced, newCall, this); - this.hangup(CallErrorCode.Replaced, true); - } - - /** - * Hangup a call. - * @param reason - The reason why the call is being hung up. - * @param suppressEvent - True to suppress emitting an event. - */ - hangup(reason, suppressEvent) { - if (this.callHasEnded()) return; - _logger.logger.debug(`Call ${this.callId} hangup() ending call (reason=${reason})`); - this.terminate(CallParty.Local, reason, !suppressEvent); - // We don't want to send hangup here if we didn't even get to sending an invite - if ([CallState.Fledgling, CallState.WaitLocalMedia].includes(this.state)) return; - const content = {}; - // Don't send UserHangup reason to older clients - if (this.opponentVersion && this.opponentVersion !== 0 || reason !== CallErrorCode.UserHangup) { - content["reason"] = reason; - } - this.sendVoipEvent(_event.EventType.CallHangup, content); - } - - /** - * Reject a call - * This used to be done by calling hangup, but is a separate method and protocol - * event as of MSC2746. - */ - reject() { - if (this.state !== CallState.Ringing) { - throw Error("Call must be in 'ringing' state to reject!"); - } - if (this.opponentVersion === 0) { - _logger.logger.info(`Call ${this.callId} reject() opponent version is less than 1: sending hangup instead of reject (opponentVersion=${this.opponentVersion})`); - this.hangup(CallErrorCode.UserHangup, true); - return; - } - _logger.logger.debug("Rejecting call: " + this.callId); - this.terminate(CallParty.Local, CallErrorCode.UserHangup, true); - this.sendVoipEvent(_event.EventType.CallReject, {}); - } - - /** - * Adds an audio and/or video track - upgrades the call - * @param audio - should add an audio track - * @param video - should add an video track - */ - async upgradeCall(audio, video) { - // We don't do call downgrades - if (!audio && !video) return; - if (!this.opponentSupportsSDPStreamMetadata()) return; - try { - _logger.logger.debug(`Call ${this.callId} upgradeCall() upgrading call (audio=${audio}, video=${video})`); - const getAudio = audio || this.hasLocalUserMediaAudioTrack; - const getVideo = video || this.hasLocalUserMediaVideoTrack; - - // updateLocalUsermediaStream() will take the tracks, use them as - // replacement and throw the stream away, so it isn't reusable - const stream = await this.client.getMediaHandler().getUserMediaStream(getAudio, getVideo, false); - await this.updateLocalUsermediaStream(stream, audio, video); - } catch (error) { - _logger.logger.error(`Call ${this.callId} upgradeCall() failed to upgrade the call`, error); - this.emit(CallEvent.Error, new CallError(CallErrorCode.NoUserMedia, "Failed to get camera access: ", error), this); - } - } - - /** - * Returns true if this.remoteSDPStreamMetadata is defined, otherwise returns false - * @returns can screenshare - */ - opponentSupportsSDPStreamMetadata() { - return Boolean(this.remoteSDPStreamMetadata); - } - - /** - * If there is a screensharing stream returns true, otherwise returns false - * @returns is screensharing - */ - isScreensharing() { - return Boolean(this.localScreensharingStream); - } - - /** - * Starts/stops screensharing - * @param enabled - the desired screensharing state - * @param desktopCapturerSourceId - optional id of the desktop capturer source to use - * @returns new screensharing state - */ - async setScreensharingEnabled(enabled, opts) { - // Skip if there is nothing to do - if (enabled && this.isScreensharing()) { - _logger.logger.warn(`Call ${this.callId} setScreensharingEnabled() there is already a screensharing stream - there is nothing to do!`); - return true; - } else if (!enabled && !this.isScreensharing()) { - _logger.logger.warn(`Call ${this.callId} setScreensharingEnabled() there already isn't a screensharing stream - there is nothing to do!`); - return false; - } - - // Fallback to replaceTrack() - if (!this.opponentSupportsSDPStreamMetadata()) { - return this.setScreensharingEnabledWithoutMetadataSupport(enabled, opts); - } - _logger.logger.debug(`Call ${this.callId} setScreensharingEnabled() running (enabled=${enabled})`); - if (enabled) { - try { - const stream = await this.client.getMediaHandler().getScreensharingStream(opts); - if (!stream) return false; - this.pushNewLocalFeed(stream, _callEventTypes.SDPStreamMetadataPurpose.Screenshare); - return true; - } catch (err) { - _logger.logger.error(`Call ${this.callId} setScreensharingEnabled() failed to get screen-sharing stream:`, err); - return false; - } - } else { - const audioTransceiver = this.transceivers.get(getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Screenshare, "audio")); - const videoTransceiver = this.transceivers.get(getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Screenshare, "video")); - for (const transceiver of [audioTransceiver, videoTransceiver]) { - // this is slightly mixing the track and transceiver API but is basically just shorthand - // for removing the sender. - if (transceiver && transceiver.sender) this.peerConn.removeTrack(transceiver.sender); - } - this.client.getMediaHandler().stopScreensharingStream(this.localScreensharingStream); - this.deleteFeedByStream(this.localScreensharingStream); - return false; - } - } - - /** - * Starts/stops screensharing - * Should be used ONLY if the opponent doesn't support SDPStreamMetadata - * @param enabled - the desired screensharing state - * @param desktopCapturerSourceId - optional id of the desktop capturer source to use - * @returns new screensharing state - */ - async setScreensharingEnabledWithoutMetadataSupport(enabled, opts) { - _logger.logger.debug(`Call ${this.callId} setScreensharingEnabledWithoutMetadataSupport() running (enabled=${enabled})`); - if (enabled) { - try { - var _this$transceivers$ge3; - const stream = await this.client.getMediaHandler().getScreensharingStream(opts); - if (!stream) return false; - const track = stream.getTracks().find(track => track.kind === "video"); - const sender = (_this$transceivers$ge3 = this.transceivers.get(getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Usermedia, "video"))) === null || _this$transceivers$ge3 === void 0 ? void 0 : _this$transceivers$ge3.sender; - sender === null || sender === void 0 ? void 0 : sender.replaceTrack(track !== null && track !== void 0 ? track : null); - this.pushNewLocalFeed(stream, _callEventTypes.SDPStreamMetadataPurpose.Screenshare, false); - return true; - } catch (err) { - _logger.logger.error(`Call ${this.callId} setScreensharingEnabledWithoutMetadataSupport() failed to get screen-sharing stream:`, err); - return false; - } - } else { - var _this$localUsermediaS3, _this$transceivers$ge4; - const track = (_this$localUsermediaS3 = this.localUsermediaStream) === null || _this$localUsermediaS3 === void 0 ? void 0 : _this$localUsermediaS3.getTracks().find(track => track.kind === "video"); - const sender = (_this$transceivers$ge4 = this.transceivers.get(getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Usermedia, "video"))) === null || _this$transceivers$ge4 === void 0 ? void 0 : _this$transceivers$ge4.sender; - sender === null || sender === void 0 ? void 0 : sender.replaceTrack(track !== null && track !== void 0 ? track : null); - this.client.getMediaHandler().stopScreensharingStream(this.localScreensharingStream); - this.deleteFeedByStream(this.localScreensharingStream); - return false; - } - } - - /** - * Replaces/adds the tracks from the passed stream to the localUsermediaStream - * @param stream - to use a replacement for the local usermedia stream - */ - async updateLocalUsermediaStream(stream, forceAudio = false, forceVideo = false) { - const callFeed = this.localUsermediaFeed; - const audioEnabled = forceAudio || !callFeed.isAudioMuted() && !this.remoteOnHold; - const videoEnabled = forceVideo || !callFeed.isVideoMuted() && !this.remoteOnHold; - _logger.logger.log(`Call ${this.callId} updateLocalUsermediaStream() running (streamId=${stream.id}, audio=${audioEnabled}, video=${videoEnabled})`); - setTracksEnabled(stream.getAudioTracks(), audioEnabled); - setTracksEnabled(stream.getVideoTracks(), videoEnabled); - - // We want to keep the same stream id, so we replace the tracks rather - // than the whole stream. - - // Firstly, we replace the tracks in our localUsermediaStream. - for (const track of this.localUsermediaStream.getTracks()) { - this.localUsermediaStream.removeTrack(track); - track.stop(); - } - for (const track of stream.getTracks()) { - this.localUsermediaStream.addTrack(track); - } - - // Then replace the old tracks, if possible. - for (const track of stream.getTracks()) { - const tKey = getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Usermedia, track.kind); - const transceiver = this.transceivers.get(tKey); - const oldSender = transceiver === null || transceiver === void 0 ? void 0 : transceiver.sender; - let added = false; - if (oldSender) { - try { - _logger.logger.info(`Call ${this.callId} updateLocalUsermediaStream() replacing track (id=${track.id}, kind=${track.kind}, streamId=${stream.id}, streamPurpose=${callFeed.purpose})`); - await oldSender.replaceTrack(track); - // Set the direction to indicate we're going to be sending. - // This is only necessary in the cases where we're upgrading - // the call to video after downgrading it. - transceiver.direction = transceiver.direction === "inactive" ? "sendonly" : "sendrecv"; - added = true; - } catch (error) { - _logger.logger.warn(`Call ${this.callId} updateLocalUsermediaStream() replaceTrack failed: adding new transceiver instead`, error); - } - } - if (!added) { - _logger.logger.info(`Call ${this.callId} updateLocalUsermediaStream() adding track to peer connection (id=${track.id}, kind=${track.kind}, streamId=${stream.id}, streamPurpose=${callFeed.purpose})`); - const newSender = this.peerConn.addTrack(track, this.localUsermediaStream); - const newTransceiver = this.peerConn.getTransceivers().find(t => t.sender === newSender); - if (newTransceiver) { - this.transceivers.set(tKey, newTransceiver); - } else { - _logger.logger.warn(`Call ${this.callId} updateLocalUsermediaStream() couldn't find matching transceiver for newly added track!`); - } - } - } - } - - /** - * Set whether our outbound video should be muted or not. - * @param muted - True to mute the outbound video. - * @returns the new mute state - */ - async setLocalVideoMuted(muted) { - var _this$localUsermediaF3; - _logger.logger.log(`Call ${this.callId} setLocalVideoMuted() running ${muted}`); - - // if we were still thinking about stopping and removing the video - // track: don't, because we want it back. - if (!muted && this.stopVideoTrackTimer !== undefined) { - clearTimeout(this.stopVideoTrackTimer); - this.stopVideoTrackTimer = undefined; - } - if (!(await this.client.getMediaHandler().hasVideoDevice())) { - return this.isLocalVideoMuted(); - } - if (!this.hasUserMediaVideoSender && !muted) { - var _this$localUsermediaF2; - (_this$localUsermediaF2 = this.localUsermediaFeed) === null || _this$localUsermediaF2 === void 0 ? void 0 : _this$localUsermediaF2.setAudioVideoMuted(null, muted); - await this.upgradeCall(false, true); - return this.isLocalVideoMuted(); - } - - // we may not have a video track - if not, re-request usermedia - if (!muted && this.localUsermediaStream.getVideoTracks().length === 0) { - const stream = await this.client.getMediaHandler().getUserMediaStream(true, true); - await this.updateLocalUsermediaStream(stream); - } - (_this$localUsermediaF3 = this.localUsermediaFeed) === null || _this$localUsermediaF3 === void 0 ? void 0 : _this$localUsermediaF3.setAudioVideoMuted(null, muted); - this.updateMuteStatus(); - await this.sendMetadataUpdate(); - - // if we're muting video, set a timeout to stop & remove the video track so we release - // the camera. We wait a short time to do this because when we disable a track, WebRTC - // will send black video for it. If we just stop and remove it straight away, the video - // will just freeze which means that when we unmute video, the other side will briefly - // get a static frame of us from before we muted. This way, the still frame is just black. - // A very small delay is not always enough so the theory here is that it needs to be long - // enough for WebRTC to encode a frame: 120ms should be long enough even if we're only - // doing 10fps. - if (muted) { - this.stopVideoTrackTimer = setTimeout(() => { - for (const t of this.localUsermediaStream.getVideoTracks()) { - t.stop(); - this.localUsermediaStream.removeTrack(t); - } - }, 120); - } - return this.isLocalVideoMuted(); - } - - /** - * Check if local video is muted. - * - * If there are multiple video tracks, all of the tracks need to be muted - * for this to return true. This means if there are no video tracks, this will - * return true. - * @returns True if the local preview video is muted, else false - * (including if the call is not set up yet). - */ - isLocalVideoMuted() { - var _this$localUsermediaF4, _this$localUsermediaF5; - return (_this$localUsermediaF4 = (_this$localUsermediaF5 = this.localUsermediaFeed) === null || _this$localUsermediaF5 === void 0 ? void 0 : _this$localUsermediaF5.isVideoMuted()) !== null && _this$localUsermediaF4 !== void 0 ? _this$localUsermediaF4 : false; - } - - /** - * Set whether the microphone should be muted or not. - * @param muted - True to mute the mic. - * @returns the new mute state - */ - async setMicrophoneMuted(muted) { - var _this$localUsermediaF6; - _logger.logger.log(`Call ${this.callId} setMicrophoneMuted() running ${muted}`); - if (!(await this.client.getMediaHandler().hasAudioDevice())) { - return this.isMicrophoneMuted(); - } - if (!muted && (!this.hasUserMediaAudioSender || !this.hasLocalUserMediaAudioTrack)) { - await this.upgradeCall(true, false); - return this.isMicrophoneMuted(); - } - (_this$localUsermediaF6 = this.localUsermediaFeed) === null || _this$localUsermediaF6 === void 0 ? void 0 : _this$localUsermediaF6.setAudioVideoMuted(muted, null); - this.updateMuteStatus(); - await this.sendMetadataUpdate(); - return this.isMicrophoneMuted(); - } - - /** - * Check if the microphone is muted. - * - * If there are multiple audio tracks, all of the tracks need to be muted - * for this to return true. This means if there are no audio tracks, this will - * return true. - * @returns True if the mic is muted, else false (including if the call - * is not set up yet). - */ - isMicrophoneMuted() { - var _this$localUsermediaF7, _this$localUsermediaF8; - return (_this$localUsermediaF7 = (_this$localUsermediaF8 = this.localUsermediaFeed) === null || _this$localUsermediaF8 === void 0 ? void 0 : _this$localUsermediaF8.isAudioMuted()) !== null && _this$localUsermediaF7 !== void 0 ? _this$localUsermediaF7 : false; - } - - /** - * @returns true if we have put the party on the other side of the call on hold - * (that is, we are signalling to them that we are not listening) - */ - isRemoteOnHold() { - return this.remoteOnHold; - } - setRemoteOnHold(onHold) { - if (this.isRemoteOnHold() === onHold) return; - this.remoteOnHold = onHold; - for (const transceiver of this.peerConn.getTransceivers()) { - // We don't send hold music or anything so we're not actually - // sending anything, but sendrecv is fairly standard for hold and - // it makes it a lot easier to figure out who's put who on hold. - transceiver.direction = onHold ? "sendonly" : "sendrecv"; - } - this.updateMuteStatus(); - this.sendMetadataUpdate(); - this.emit(CallEvent.RemoteHoldUnhold, this.remoteOnHold, this); - } - - /** - * Indicates whether we are 'on hold' to the remote party (ie. if true, - * they cannot hear us). - * @returns true if the other party has put us on hold - */ - isLocalOnHold() { - if (this.state !== CallState.Connected) return false; - let callOnHold = true; - - // We consider a call to be on hold only if *all* the tracks are on hold - // (is this the right thing to do?) - for (const transceiver of this.peerConn.getTransceivers()) { - const trackOnHold = ["inactive", "recvonly"].includes(transceiver.currentDirection); - if (!trackOnHold) callOnHold = false; - } - return callOnHold; - } - - /** - * Sends a DTMF digit to the other party - * @param digit - The digit (nb. string - '#' and '*' are dtmf too) - */ - sendDtmfDigit(digit) { - for (const sender of this.peerConn.getSenders()) { - var _sender$track; - if (((_sender$track = sender.track) === null || _sender$track === void 0 ? void 0 : _sender$track.kind) === "audio" && sender.dtmf) { - sender.dtmf.insertDTMF(digit); - return; - } - } - throw new Error("Unable to find a track to send DTMF on"); - } - updateMuteStatus() { - const micShouldBeMuted = this.isMicrophoneMuted() || this.remoteOnHold; - const vidShouldBeMuted = this.isLocalVideoMuted() || this.remoteOnHold; - _logger.logger.log(`Call ${this.callId} updateMuteStatus stream ${this.localUsermediaStream.id} micShouldBeMuted ${micShouldBeMuted} vidShouldBeMuted ${vidShouldBeMuted}`); - setTracksEnabled(this.localUsermediaStream.getAudioTracks(), !micShouldBeMuted); - setTracksEnabled(this.localUsermediaStream.getVideoTracks(), !vidShouldBeMuted); - } - async sendMetadataUpdate() { - await this.sendVoipEvent(_event.EventType.CallSDPStreamMetadataChangedPrefix, { - [_callEventTypes.SDPStreamMetadataKey]: this.getLocalSDPStreamMetadata() - }); - } - gotCallFeedsForInvite(callFeeds, requestScreenshareFeed = false) { - if (this.successor) { - this.successor.queueGotCallFeedsForAnswer(callFeeds); - return; - } - if (this.callHasEnded()) { - this.stopAllMedia(); - return; - } - for (const feed of callFeeds) { - this.pushLocalFeed(feed); - } - if (requestScreenshareFeed) { - this.peerConn.addTransceiver("video", { - direction: "recvonly" - }); - } - this.state = CallState.CreateOffer; - _logger.logger.debug(`Call ${this.callId} gotUserMediaForInvite() run`); - // Now we wait for the negotiationneeded event - } - - async sendAnswer() { - const answerContent = { - answer: { - sdp: this.peerConn.localDescription.sdp, - // type is now deprecated as of Matrix VoIP v1, but - // required to still be sent for backwards compat - type: this.peerConn.localDescription.type - }, - [_callEventTypes.SDPStreamMetadataKey]: this.getLocalSDPStreamMetadata(true) - }; - answerContent.capabilities = { - "m.call.transferee": this.client.supportsCallTransfer, - "m.call.dtmf": false - }; - - // We have just taken the local description from the peerConn which will - // contain all the local candidates added so far, so we can discard any candidates - // we had queued up because they'll be in the answer. - const discardCount = this.discardDuplicateCandidates(); - _logger.logger.info(`Call ${this.callId} sendAnswer() discarding ${discardCount} candidates that will be sent in answer`); - try { - await this.sendVoipEvent(_event.EventType.CallAnswer, answerContent); - // If this isn't the first time we've tried to send the answer, - // we may have candidates queued up, so send them now. - this.inviteOrAnswerSent = true; - } catch (error) { - // We've failed to answer: back to the ringing state - this.state = CallState.Ringing; - if (error instanceof _httpApi.MatrixError && error.event) this.client.cancelPendingEvent(error.event); - let code = CallErrorCode.SendAnswer; - let message = "Failed to send answer"; - if (error.name == "UnknownDeviceError") { - code = CallErrorCode.UnknownDevices; - message = "Unknown devices present in the room"; - } - this.emit(CallEvent.Error, new CallError(code, message, error), this); - throw error; - } - - // error handler re-throws so this won't happen on error, but - // we don't want the same error handling on the candidate queue - this.sendCandidateQueue(); - } - queueGotCallFeedsForAnswer(callFeeds) { - // Ensure only one negotiate/answer event is being processed at a time. - if (this.responsePromiseChain) { - this.responsePromiseChain = this.responsePromiseChain.then(() => this.gotCallFeedsForAnswer(callFeeds)); - } else { - this.responsePromiseChain = this.gotCallFeedsForAnswer(callFeeds); - } - } - - // Enables DTX (discontinuous transmission) on the given session to reduce - // bandwidth when transmitting silence - mungeSdp(description, mods) { - // The only way to enable DTX at this time is through SDP munging - const sdp = (0, _sdpTransform.parse)(description.sdp); - sdp.media.forEach(media => { - const payloadTypeToCodecMap = new Map(); - const codecToPayloadTypeMap = new Map(); - for (const rtp of media.rtp) { - payloadTypeToCodecMap.set(rtp.payload, rtp.codec); - codecToPayloadTypeMap.set(rtp.codec, rtp.payload); - } - for (const mod of mods) { - if (mod.mediaType !== media.type) continue; - if (!codecToPayloadTypeMap.has(mod.codec)) { - _logger.logger.info(`Call ${this.callId} mungeSdp() ignoring SDP modifications for ${mod.codec} as it's not present.`); - continue; - } - const extraConfig = []; - if (mod.enableDtx !== undefined) { - extraConfig.push(`usedtx=${mod.enableDtx ? "1" : "0"}`); - } - if (mod.maxAverageBitrate !== undefined) { - extraConfig.push(`maxaveragebitrate=${mod.maxAverageBitrate}`); - } - let found = false; - for (const fmtp of media.fmtp) { - if (payloadTypeToCodecMap.get(fmtp.payload) === mod.codec) { - found = true; - fmtp.config += ";" + extraConfig.join(";"); - } - } - if (!found) { - media.fmtp.push({ - payload: codecToPayloadTypeMap.get(mod.codec), - config: extraConfig.join(";") - }); - } - } - }); - description.sdp = (0, _sdpTransform.write)(sdp); - } - async createOffer() { - const offer = await this.peerConn.createOffer(); - this.mungeSdp(offer, getCodecParamMods(this.isPtt)); - return offer; - } - async createAnswer() { - const answer = await this.peerConn.createAnswer(); - this.mungeSdp(answer, getCodecParamMods(this.isPtt)); - return answer; - } - async gotCallFeedsForAnswer(callFeeds) { - if (this.callHasEnded()) return; - this.waitForLocalAVStream = false; - for (const feed of callFeeds) { - this.pushLocalFeed(feed); - } - this.state = CallState.CreateAnswer; - let answer; - try { - this.getRidOfRTXCodecs(); - answer = await this.createAnswer(); - } catch (err) { - _logger.logger.debug(`Call ${this.callId} gotCallFeedsForAnswer() failed to create answer: `, err); - this.terminate(CallParty.Local, CallErrorCode.CreateAnswer, true); - return; - } - try { - await this.peerConn.setLocalDescription(answer); - - // make sure we're still going - if (this.callHasEnded()) return; - this.state = CallState.Connecting; - - // Allow a short time for initial candidates to be gathered - await new Promise(resolve => { - setTimeout(resolve, 200); - }); - - // make sure the call hasn't ended before we continue - if (this.callHasEnded()) return; - this.sendAnswer(); - } catch (err) { - _logger.logger.debug(`Call ${this.callId} gotCallFeedsForAnswer() error setting local description!`, err); - this.terminate(CallParty.Local, CallErrorCode.SetLocalDescription, true); - return; - } - } - - /** - * Internal - */ - - async onRemoteIceCandidatesReceived(ev) { - if (this.callHasEnded()) { - //debuglog("Ignoring remote ICE candidate because call has ended"); - return; - } - const content = ev.getContent(); - const candidates = content.candidates; - if (!candidates) { - _logger.logger.info(`Call ${this.callId} onRemoteIceCandidatesReceived() ignoring candidates event with no candidates!`); - return; - } - const fromPartyId = content.version === 0 ? null : content.party_id || null; - if (this.opponentPartyId === undefined) { - // we haven't picked an opponent yet so save the candidates - if (fromPartyId) { - _logger.logger.info(`Call ${this.callId} onRemoteIceCandidatesReceived() buffering ${candidates.length} candidates until we pick an opponent`); - const bufferedCandidates = this.remoteCandidateBuffer.get(fromPartyId) || []; - bufferedCandidates.push(...candidates); - this.remoteCandidateBuffer.set(fromPartyId, bufferedCandidates); - } - return; - } - if (!this.partyIdMatches(content)) { - _logger.logger.info(`Call ${this.callId} onRemoteIceCandidatesReceived() ignoring candidates from party ID ${content.party_id}: we have chosen party ID ${this.opponentPartyId}`); - return; - } - await this.addIceCandidates(candidates); - } - - /** - * Used by MatrixClient. - */ - async onAnswerReceived(event) { - const content = event.getContent(); - _logger.logger.debug(`Call ${this.callId} onAnswerReceived() running (hangupParty=${content.party_id})`); - if (this.callHasEnded()) { - _logger.logger.debug(`Call ${this.callId} onAnswerReceived() ignoring answer because call has ended`); - return; - } - if (this.opponentPartyId !== undefined) { - _logger.logger.info(`Call ${this.callId} onAnswerReceived() ignoring answer from party ID ${content.party_id}: we already have an answer/reject from ${this.opponentPartyId}`); - return; - } - this.chooseOpponent(event); - await this.addBufferedIceCandidates(); - this.state = CallState.Connecting; - const sdpStreamMetadata = content[_callEventTypes.SDPStreamMetadataKey]; - if (sdpStreamMetadata) { - this.updateRemoteSDPStreamMetadata(sdpStreamMetadata); - } else { - _logger.logger.warn(`Call ${this.callId} onAnswerReceived() did not get any SDPStreamMetadata! Can not send/receive multiple streams`); - } - try { - await this.peerConn.setRemoteDescription(content.answer); - } catch (e) { - _logger.logger.debug(`Call ${this.callId} onAnswerReceived() failed to set remote description`, e); - this.terminate(CallParty.Local, CallErrorCode.SetRemoteDescription, false); - return; - } - - // If the answer we selected has a party_id, send a select_answer event - // We do this after setting the remote description since otherwise we'd block - // call setup on it - if (this.opponentPartyId !== null) { - try { - await this.sendVoipEvent(_event.EventType.CallSelectAnswer, { - selected_party_id: this.opponentPartyId - }); - } catch (err) { - // This isn't fatal, and will just mean that if another party has raced to answer - // the call, they won't know they got rejected, so we carry on & don't retry. - _logger.logger.warn(`Call ${this.callId} onAnswerReceived() failed to send select_answer event`, err); - } - } - } - async onSelectAnswerReceived(event) { - if (this.direction !== CallDirection.Inbound) { - _logger.logger.warn(`Call ${this.callId} onSelectAnswerReceived() got select_answer for an outbound call: ignoring`); - return; - } - const selectedPartyId = event.getContent().selected_party_id; - if (selectedPartyId === undefined || selectedPartyId === null) { - _logger.logger.warn(`Call ${this.callId} onSelectAnswerReceived() got nonsensical select_answer with null/undefined selected_party_id: ignoring`); - return; - } - if (selectedPartyId !== this.ourPartyId) { - _logger.logger.info(`Call ${this.callId} onSelectAnswerReceived() got select_answer for party ID ${selectedPartyId}: we are party ID ${this.ourPartyId}.`); - // The other party has picked somebody else's answer - await this.terminate(CallParty.Remote, CallErrorCode.AnsweredElsewhere, true); - } - } - async onNegotiateReceived(event) { - const content = event.getContent(); - const description = content.description; - if (!description || !description.sdp || !description.type) { - _logger.logger.info(`Call ${this.callId} onNegotiateReceived() ignoring invalid m.call.negotiate event`); - return; - } - // Politeness always follows the direction of the call: in a glare situation, - // we pick either the inbound or outbound call, so one side will always be - // inbound and one outbound - const polite = this.direction === CallDirection.Inbound; - - // Here we follow the perfect negotiation logic from - // https://developer.mozilla.org/en-US/docs/Web/API/WebRTC_API/Perfect_negotiation - const offerCollision = description.type === "offer" && (this.makingOffer || this.peerConn.signalingState !== "stable"); - this.ignoreOffer = !polite && offerCollision; - if (this.ignoreOffer) { - _logger.logger.info(`Call ${this.callId} onNegotiateReceived() ignoring colliding negotiate event because we're impolite`); - return; - } - const prevLocalOnHold = this.isLocalOnHold(); - const sdpStreamMetadata = content[_callEventTypes.SDPStreamMetadataKey]; - if (sdpStreamMetadata) { - this.updateRemoteSDPStreamMetadata(sdpStreamMetadata); - } else { - _logger.logger.warn(`Call ${this.callId} onNegotiateReceived() received negotiation event without SDPStreamMetadata!`); - } - try { - await this.peerConn.setRemoteDescription(description); - if (description.type === "offer") { - var _localDescription; - let answer; - try { - this.getRidOfRTXCodecs(); - answer = await this.createAnswer(); - } catch (err) { - _logger.logger.debug(`Call ${this.callId} onNegotiateReceived() failed to create answer: `, err); - this.terminate(CallParty.Local, CallErrorCode.CreateAnswer, true); - return; - } - await this.peerConn.setLocalDescription(answer); - this.sendVoipEvent(_event.EventType.CallNegotiate, { - description: (_localDescription = this.peerConn.localDescription) === null || _localDescription === void 0 ? void 0 : _localDescription.toJSON(), - [_callEventTypes.SDPStreamMetadataKey]: this.getLocalSDPStreamMetadata(true) - }); - } - } catch (err) { - _logger.logger.warn(`Call ${this.callId} onNegotiateReceived() failed to complete negotiation`, err); - } - const newLocalOnHold = this.isLocalOnHold(); - if (prevLocalOnHold !== newLocalOnHold) { - this.emit(CallEvent.LocalHoldUnhold, newLocalOnHold, this); - // also this one for backwards compat - this.emit(CallEvent.HoldUnhold, newLocalOnHold); - } - } - updateRemoteSDPStreamMetadata(metadata) { - this.remoteSDPStreamMetadata = utils.recursivelyAssign(this.remoteSDPStreamMetadata || {}, metadata, true); - for (const feed of this.getRemoteFeeds()) { - var _streamId; - const streamId = feed.stream.id; - const metadata = this.remoteSDPStreamMetadata[streamId]; - feed.setAudioVideoMuted(metadata === null || metadata === void 0 ? void 0 : metadata.audio_muted, metadata === null || metadata === void 0 ? void 0 : metadata.video_muted); - feed.purpose = (_streamId = this.remoteSDPStreamMetadata[streamId]) === null || _streamId === void 0 ? void 0 : _streamId.purpose; - } - } - onSDPStreamMetadataChangedReceived(event) { - const content = event.getContent(); - const metadata = content[_callEventTypes.SDPStreamMetadataKey]; - this.updateRemoteSDPStreamMetadata(metadata); - } - async onAssertedIdentityReceived(event) { - const content = event.getContent(); - if (!content.asserted_identity) return; - this.remoteAssertedIdentity = { - id: content.asserted_identity.id, - displayName: content.asserted_identity.display_name - }; - this.emit(CallEvent.AssertedIdentityChanged, this); - } - callHasEnded() { - // This exists as workaround to typescript trying to be clever and erroring - // when putting if (this.state === CallState.Ended) return; twice in the same - // function, even though that function is async. - return this.state === CallState.Ended; - } - queueGotLocalOffer() { - // Ensure only one negotiate/answer event is being processed at a time. - if (this.responsePromiseChain) { - this.responsePromiseChain = this.responsePromiseChain.then(() => this.wrappedGotLocalOffer()); - } else { - this.responsePromiseChain = this.wrappedGotLocalOffer(); - } - } - async wrappedGotLocalOffer() { - this.makingOffer = true; - try { - // XXX: in what situations do we believe gotLocalOffer actually throws? It appears - // to handle most of its exceptions itself and terminate the call. I'm not entirely - // sure it would ever throw, so I can't add a test for these lines. - // Also the tense is different between "gotLocalOffer" and "getLocalOfferFailed" so - // it's not entirely clear whether getLocalOfferFailed is just misnamed or whether - // they've been cross-polinated somehow at some point. - await this.gotLocalOffer(); - } catch (e) { - this.getLocalOfferFailed(e); - return; - } finally { - this.makingOffer = false; - } - } - async gotLocalOffer() { - _logger.logger.debug(`Call ${this.callId} gotLocalOffer() running`); - if (this.callHasEnded()) { - _logger.logger.debug(`Call ${this.callId} gotLocalOffer() ignoring newly created offer because the call has ended"`); - return; - } - let offer; - try { - this.getRidOfRTXCodecs(); - offer = await this.createOffer(); - } catch (err) { - _logger.logger.debug(`Call ${this.callId} gotLocalOffer() failed to create offer: `, err); - this.terminate(CallParty.Local, CallErrorCode.CreateOffer, true); - return; - } - try { - await this.peerConn.setLocalDescription(offer); - } catch (err) { - _logger.logger.debug(`Call ${this.callId} gotLocalOffer() error setting local description!`, err); - this.terminate(CallParty.Local, CallErrorCode.SetLocalDescription, true); - return; - } - if (this.peerConn.iceGatheringState === "gathering") { - // Allow a short time for initial candidates to be gathered - await new Promise(resolve => { - setTimeout(resolve, 200); - }); - } - if (this.callHasEnded()) return; - const eventType = this.state === CallState.CreateOffer ? _event.EventType.CallInvite : _event.EventType.CallNegotiate; - const content = { - lifetime: CALL_TIMEOUT_MS - }; - if (eventType === _event.EventType.CallInvite && this.invitee) { - content.invitee = this.invitee; - } - - // clunky because TypeScript can't follow the types through if we use an expression as the key - if (this.state === CallState.CreateOffer) { - var _localDescription2; - content.offer = (_localDescription2 = this.peerConn.localDescription) === null || _localDescription2 === void 0 ? void 0 : _localDescription2.toJSON(); - } else { - var _localDescription3; - content.description = (_localDescription3 = this.peerConn.localDescription) === null || _localDescription3 === void 0 ? void 0 : _localDescription3.toJSON(); - } - content.capabilities = { - "m.call.transferee": this.client.supportsCallTransfer, - "m.call.dtmf": false - }; - content[_callEventTypes.SDPStreamMetadataKey] = this.getLocalSDPStreamMetadata(true); - - // Get rid of any candidates waiting to be sent: they'll be included in the local - // description we just got and will send in the offer. - const discardCount = this.discardDuplicateCandidates(); - _logger.logger.info(`Call ${this.callId} gotLocalOffer() discarding ${discardCount} candidates that will be sent in offer`); - try { - await this.sendVoipEvent(eventType, content); - } catch (error) { - _logger.logger.error(`Call ${this.callId} gotLocalOffer() failed to send invite`, error); - if (error instanceof _httpApi.MatrixError && error.event) this.client.cancelPendingEvent(error.event); - let code = CallErrorCode.SignallingFailed; - let message = "Signalling failed"; - if (this.state === CallState.CreateOffer) { - code = CallErrorCode.SendInvite; - message = "Failed to send invite"; - } - if (error.name == "UnknownDeviceError") { - code = CallErrorCode.UnknownDevices; - message = "Unknown devices present in the room"; - } - this.emit(CallEvent.Error, new CallError(code, message, error), this); - this.terminate(CallParty.Local, code, false); - - // no need to carry on & send the candidate queue, but we also - // don't want to rethrow the error - return; - } - this.sendCandidateQueue(); - if (this.state === CallState.CreateOffer) { - this.inviteOrAnswerSent = true; - this.state = CallState.InviteSent; - this.inviteTimeout = setTimeout(() => { - this.inviteTimeout = undefined; - if (this.state === CallState.InviteSent) { - this.hangup(CallErrorCode.InviteTimeout, false); - } - }, CALL_TIMEOUT_MS); - } - } - /** - * This method removes all video/rtx codecs from screensharing video - * transceivers. This is necessary since they can cause problems. Without - * this the following steps should produce an error: - * Chromium calls Firefox - * Firefox answers - * Firefox starts screen-sharing - * Chromium starts screen-sharing - * Call crashes for Chromium with: - * [96685:23:0518/162603.933321:ERROR:webrtc_video_engine.cc(3296)] RTX codec (PT=97) mapped to PT=96 which is not in the codec list. - * [96685:23:0518/162603.933377:ERROR:webrtc_video_engine.cc(1171)] GetChangedRecvParameters called without any video codecs. - * [96685:23:0518/162603.933430:ERROR:sdp_offer_answer.cc(4302)] Failed to set local video description recv parameters for m-section with mid='2'. (INVALID_PARAMETER) - */ - getRidOfRTXCodecs() { - // RTCRtpReceiver.getCapabilities and RTCRtpSender.getCapabilities don't seem to be supported on FF - if (!RTCRtpReceiver.getCapabilities || !RTCRtpSender.getCapabilities) return; - const recvCodecs = RTCRtpReceiver.getCapabilities("video").codecs; - const sendCodecs = RTCRtpSender.getCapabilities("video").codecs; - const codecs = [...sendCodecs, ...recvCodecs]; - for (const codec of codecs) { - if (codec.mimeType === "video/rtx") { - const rtxCodecIndex = codecs.indexOf(codec); - codecs.splice(rtxCodecIndex, 1); - } - } - const screenshareVideoTransceiver = this.transceivers.get(getTransceiverKey(_callEventTypes.SDPStreamMetadataPurpose.Screenshare, "video")); - if (screenshareVideoTransceiver) screenshareVideoTransceiver.setCodecPreferences(codecs); - } - /** - * @internal - */ - async sendVoipEvent(eventType, content) { - const realContent = Object.assign({}, content, { - version: VOIP_PROTO_VERSION, - call_id: this.callId, - party_id: this.ourPartyId, - conf_id: this.groupCallId - }); - if (this.opponentDeviceId) { - var _this$getOpponentMemb2; - const toDeviceSeq = this.toDeviceSeq++; - const content = _objectSpread(_objectSpread({}, realContent), {}, { - device_id: this.client.deviceId, - sender_session_id: this.client.getSessionId(), - dest_session_id: this.opponentSessionId, - seq: toDeviceSeq, - [_event.ToDeviceMessageId]: (0, _uuid.v4)() - }); - this.emit(CallEvent.SendVoipEvent, { - type: "toDevice", - eventType, - userId: this.invitee || ((_this$getOpponentMemb2 = this.getOpponentMember()) === null || _this$getOpponentMemb2 === void 0 ? void 0 : _this$getOpponentMemb2.userId), - opponentDeviceId: this.opponentDeviceId, - content - }, this); - const userId = this.invitee || this.getOpponentMember().userId; - if (this.client.getUseE2eForGroupCall()) { - if (!this.opponentDeviceInfo) { - _logger.logger.warn(`Call ${this.callId} sendVoipEvent() failed: we do not have opponentDeviceInfo`); - return; - } - await this.client.encryptAndSendToDevices([{ - userId, - deviceInfo: this.opponentDeviceInfo - }], { - type: eventType, - content - }); - } else { - await this.client.sendToDevice(eventType, new Map([[userId, new Map([[this.opponentDeviceId, content]])]])); - } - } else { - var _this$getOpponentMemb3; - this.emit(CallEvent.SendVoipEvent, { - type: "sendEvent", - eventType, - roomId: this.roomId, - content: realContent, - userId: this.invitee || ((_this$getOpponentMemb3 = this.getOpponentMember()) === null || _this$getOpponentMemb3 === void 0 ? void 0 : _this$getOpponentMemb3.userId) - }, this); - await this.client.sendEvent(this.roomId, eventType, realContent); - } - } - - /** - * Queue a candidate to be sent - * @param content - The candidate to queue up, or null if candidates have finished being generated - * and end-of-candidates should be signalled - */ - queueCandidate(content) { - // We partially de-trickle candidates by waiting for `delay` before sending them - // amalgamated, in order to avoid sending too many m.call.candidates events and hitting - // rate limits in Matrix. - // In practice, it'd be better to remove rate limits for m.call.* - - // N.B. this deliberately lets you queue and send blank candidates, which MSC2746 - // currently proposes as the way to indicate that candidate gathering is complete. - // This will hopefully be changed to an explicit rather than implicit notification - // shortly. - if (content) { - this.candidateSendQueue.push(content); - } else { - this.candidatesEnded = true; - } - - // Don't send the ICE candidates yet if the call is in the ringing state: this - // means we tried to pick (ie. started generating candidates) and then failed to - // send the answer and went back to the ringing state. Queue up the candidates - // to send if we successfully send the answer. - // Equally don't send if we haven't yet sent the answer because we can send the - // first batch of candidates along with the answer - if (this.state === CallState.Ringing || !this.inviteOrAnswerSent) return; - - // MSC2746 recommends these values (can be quite long when calling because the - // callee will need a while to answer the call) - const delay = this.direction === CallDirection.Inbound ? 500 : 2000; - if (this.candidateSendTries === 0) { - setTimeout(() => { - this.sendCandidateQueue(); - }, delay); - } - } - - // Discard all non-end-of-candidates messages - // Return the number of candidate messages that were discarded. - // Call this method before sending an invite or answer message - discardDuplicateCandidates() { - let discardCount = 0; - const newQueue = []; - for (let i = 0; i < this.candidateSendQueue.length; i++) { - const candidate = this.candidateSendQueue[i]; - if (candidate.candidate === "") { - newQueue.push(candidate); - } else { - discardCount++; - } - } - this.candidateSendQueue = newQueue; - return discardCount; - } - - /* - * Transfers this call to another user - */ - async transfer(targetUserId) { - // Fetch the target user's global profile info: their room avatar / displayname - // could be different in whatever room we share with them. - const profileInfo = await this.client.getProfileInfo(targetUserId); - const replacementId = genCallID(); - const body = { - replacement_id: genCallID(), - target_user: { - id: targetUserId, - display_name: profileInfo.displayname, - avatar_url: profileInfo.avatar_url - }, - create_call: replacementId - }; - await this.sendVoipEvent(_event.EventType.CallReplaces, body); - await this.terminate(CallParty.Local, CallErrorCode.Transferred, true); - } - - /* - * Transfers this call to the target call, effectively 'joining' the - * two calls (so the remote parties on each call are connected together). - */ - async transferToCall(transferTargetCall) { - var _transferTargetCall$g, _this$getOpponentMemb4; - const targetUserId = (_transferTargetCall$g = transferTargetCall.getOpponentMember()) === null || _transferTargetCall$g === void 0 ? void 0 : _transferTargetCall$g.userId; - const targetProfileInfo = targetUserId ? await this.client.getProfileInfo(targetUserId) : undefined; - const opponentUserId = (_this$getOpponentMemb4 = this.getOpponentMember()) === null || _this$getOpponentMemb4 === void 0 ? void 0 : _this$getOpponentMemb4.userId; - const transfereeProfileInfo = opponentUserId ? await this.client.getProfileInfo(opponentUserId) : undefined; - const newCallId = genCallID(); - const bodyToTransferTarget = { - // the replacements on each side have their own ID, and it's distinct from the - // ID of the new call (but we can use the same function to generate it) - replacement_id: genCallID(), - target_user: { - id: opponentUserId, - display_name: transfereeProfileInfo === null || transfereeProfileInfo === void 0 ? void 0 : transfereeProfileInfo.displayname, - avatar_url: transfereeProfileInfo === null || transfereeProfileInfo === void 0 ? void 0 : transfereeProfileInfo.avatar_url - }, - await_call: newCallId - }; - await transferTargetCall.sendVoipEvent(_event.EventType.CallReplaces, bodyToTransferTarget); - const bodyToTransferee = { - replacement_id: genCallID(), - target_user: { - id: targetUserId, - display_name: targetProfileInfo === null || targetProfileInfo === void 0 ? void 0 : targetProfileInfo.displayname, - avatar_url: targetProfileInfo === null || targetProfileInfo === void 0 ? void 0 : targetProfileInfo.avatar_url - }, - create_call: newCallId - }; - await this.sendVoipEvent(_event.EventType.CallReplaces, bodyToTransferee); - await this.terminate(CallParty.Local, CallErrorCode.Transferred, true); - await transferTargetCall.terminate(CallParty.Local, CallErrorCode.Transferred, true); - } - async terminate(hangupParty, hangupReason, shouldEmit) { - var _this$stats2; - if (this.callHasEnded()) return; - this.hangupParty = hangupParty; - this.hangupReason = hangupReason; - this.state = CallState.Ended; - if (this.inviteTimeout) { - clearTimeout(this.inviteTimeout); - this.inviteTimeout = undefined; - } - if (this.iceDisconnectedTimeout !== undefined) { - clearTimeout(this.iceDisconnectedTimeout); - this.iceDisconnectedTimeout = undefined; - } - if (this.callLengthInterval) { - clearInterval(this.callLengthInterval); - this.callLengthInterval = undefined; - } - if (this.stopVideoTrackTimer !== undefined) { - clearTimeout(this.stopVideoTrackTimer); - this.stopVideoTrackTimer = undefined; - } - for (const [stream, listener] of this.removeTrackListeners) { - stream.removeEventListener("removetrack", listener); - } - this.removeTrackListeners.clear(); - this.callStatsAtEnd = await this.collectCallStats(); - - // Order is important here: first we stopAllMedia() and only then we can deleteAllFeeds() - this.stopAllMedia(); - this.deleteAllFeeds(); - if (this.peerConn && this.peerConn.signalingState !== "closed") { - this.peerConn.close(); - } - (_this$stats2 = this.stats) === null || _this$stats2 === void 0 ? void 0 : _this$stats2.removeStatsReportGatherer(this.callId); - if (shouldEmit) { - this.emit(CallEvent.Hangup, this); - } - this.client.callEventHandler.calls.delete(this.callId); - } - stopAllMedia() { - _logger.logger.debug(`Call ${this.callId} stopAllMedia() running`); - for (const feed of this.feeds) { - // Slightly awkward as local feed need to go via the correct method on - // the MediaHandler so they get removed from MediaHandler (remote tracks - // don't) - // NB. We clone local streams when passing them to individual calls in a group - // call, so we can (and should) stop the clones once we no longer need them: - // the other clones will continue fine. - if (feed.isLocal() && feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Usermedia) { - this.client.getMediaHandler().stopUserMediaStream(feed.stream); - } else if (feed.isLocal() && feed.purpose === _callEventTypes.SDPStreamMetadataPurpose.Screenshare) { - this.client.getMediaHandler().stopScreensharingStream(feed.stream); - } else if (!feed.isLocal()) { - _logger.logger.debug(`Call ${this.callId} stopAllMedia() stopping stream (streamId=${feed.stream.id})`); - for (const track of feed.stream.getTracks()) { - track.stop(); - } - } - } - } - checkForErrorListener() { - if (this.listeners(_typedEventEmitter.EventEmitterEvents.Error).length === 0) { - throw new Error("You MUST attach an error listener using call.on('error', function() {})"); - } - } - async sendCandidateQueue() { - if (this.candidateSendQueue.length === 0 || this.callHasEnded()) { - return; - } - const candidates = this.candidateSendQueue; - this.candidateSendQueue = []; - ++this.candidateSendTries; - const content = { - candidates: candidates.map(candidate => candidate.toJSON()) - }; - if (this.candidatesEnded) { - // If there are no more candidates, signal this by adding an empty string candidate - content.candidates.push({ - candidate: "" - }); - } - _logger.logger.debug(`Call ${this.callId} sendCandidateQueue() attempting to send ${candidates.length} candidates`); - try { - await this.sendVoipEvent(_event.EventType.CallCandidates, content); - // reset our retry count if we have successfully sent our candidates - // otherwise queueCandidate() will refuse to try to flush the queue - this.candidateSendTries = 0; - - // Try to send candidates again just in case we received more candidates while sending. - this.sendCandidateQueue(); - } catch (error) { - // don't retry this event: we'll send another one later as we might - // have more candidates by then. - if (error instanceof _httpApi.MatrixError && error.event) this.client.cancelPendingEvent(error.event); - - // put all the candidates we failed to send back in the queue - this.candidateSendQueue.push(...candidates); - if (this.candidateSendTries > 5) { - _logger.logger.debug(`Call ${this.callId} sendCandidateQueue() failed to send candidates on attempt ${this.candidateSendTries}. Giving up on this call.`, error); - const code = CallErrorCode.SignallingFailed; - const message = "Signalling failed"; - this.emit(CallEvent.Error, new CallError(code, message, error), this); - this.hangup(code, false); - return; - } - const delayMs = 500 * Math.pow(2, this.candidateSendTries); - ++this.candidateSendTries; - _logger.logger.debug(`Call ${this.callId} sendCandidateQueue() failed to send candidates. Retrying in ${delayMs}ms`, error); - setTimeout(() => { - this.sendCandidateQueue(); - }, delayMs); - } - } - - /** - * Place a call to this room. - * @throws if you have not specified a listener for 'error' events. - * @throws if have passed audio=false. - */ - async placeCall(audio, video) { - if (!audio) { - throw new Error("You CANNOT start a call without audio"); - } - this.state = CallState.WaitLocalMedia; - try { - var _this$client$getDevic2; - const stream = await this.client.getMediaHandler().getUserMediaStream(audio, video); - - // make sure all the tracks are enabled (same as pushNewLocalFeed - - // we probably ought to just have one code path for adding streams) - setTracksEnabled(stream.getAudioTracks(), true); - setTracksEnabled(stream.getVideoTracks(), true); - const callFeed = new _callFeed.CallFeed({ - client: this.client, - roomId: this.roomId, - userId: this.client.getUserId(), - deviceId: (_this$client$getDevic2 = this.client.getDeviceId()) !== null && _this$client$getDevic2 !== void 0 ? _this$client$getDevic2 : undefined, - stream, - purpose: _callEventTypes.SDPStreamMetadataPurpose.Usermedia, - audioMuted: false, - videoMuted: false - }); - await this.placeCallWithCallFeeds([callFeed]); - } catch (e) { - this.getUserMediaFailed(e); - return; - } - } - - /** - * Place a call to this room with call feed. - * @param callFeeds - to use - * @throws if you have not specified a listener for 'error' events. - * @throws if have passed audio=false. - */ - async placeCallWithCallFeeds(callFeeds, requestScreenshareFeed = false) { - this.checkForErrorListener(); - this.direction = CallDirection.Outbound; - await this.initOpponentCrypto(); - - // XXX Find a better way to do this - this.client.callEventHandler.calls.set(this.callId, this); - - // make sure we have valid turn creds. Unless something's gone wrong, it should - // poll and keep the credentials valid so this should be instant. - const haveTurnCreds = await this.client.checkTurnServers(); - if (!haveTurnCreds) { - _logger.logger.warn(`Call ${this.callId} placeCallWithCallFeeds() failed to get TURN credentials! Proceeding with call anyway...`); - } - - // create the peer connection now so it can be gathering candidates while we get user - // media (assuming a candidate pool size is configured) - this.peerConn = this.createPeerConnection(); - this.gotCallFeedsForInvite(callFeeds, requestScreenshareFeed); - } - createPeerConnection() { - var _this$stats3; - const pc = new window.RTCPeerConnection({ - iceTransportPolicy: this.forceTURN ? "relay" : undefined, - iceServers: this.turnServers, - iceCandidatePoolSize: this.client.iceCandidatePoolSize, - bundlePolicy: "max-bundle" - }); - - // 'connectionstatechange' would be better, but firefox doesn't implement that. - pc.addEventListener("iceconnectionstatechange", this.onIceConnectionStateChanged); - pc.addEventListener("signalingstatechange", this.onSignallingStateChanged); - pc.addEventListener("icecandidate", this.gotLocalIceCandidate); - pc.addEventListener("icegatheringstatechange", this.onIceGatheringStateChange); - pc.addEventListener("track", this.onTrack); - pc.addEventListener("negotiationneeded", this.onNegotiationNeeded); - pc.addEventListener("datachannel", this.onDataChannel); - (_this$stats3 = this.stats) === null || _this$stats3 === void 0 ? void 0 : _this$stats3.addStatsReportGatherer(this.callId, "unknown", pc); - return pc; - } - partyIdMatches(msg) { - // They must either match or both be absent (in which case opponentPartyId will be null) - // Also we ignore party IDs on the invite/offer if the version is 0, so we must do the same - // here and use null if the version is 0 (woe betide any opponent sending messages in the - // same call with different versions) - const msgPartyId = msg.version === 0 ? null : msg.party_id || null; - return msgPartyId === this.opponentPartyId; - } - - // Commits to an opponent for the call - // ev: An invite or answer event - chooseOpponent(ev) { - var _getMember; - // I choo-choo-choose you - const msg = ev.getContent(); - _logger.logger.debug(`Call ${this.callId} chooseOpponent() running (partyId=${msg.party_id})`); - this.opponentVersion = msg.version; - if (this.opponentVersion === 0) { - // set to null to indicate that we've chosen an opponent, but because - // they're v0 they have no party ID (even if they sent one, we're ignoring it) - this.opponentPartyId = null; - } else { - // set to their party ID, or if they're naughty and didn't send one despite - // not being v0, set it to null to indicate we picked an opponent with no - // party ID - this.opponentPartyId = msg.party_id || null; - } - this.opponentCaps = msg.capabilities || {}; - this.opponentMember = (_getMember = this.client.getRoom(this.roomId).getMember(ev.getSender())) !== null && _getMember !== void 0 ? _getMember : undefined; - } - async addBufferedIceCandidates() { - const bufferedCandidates = this.remoteCandidateBuffer.get(this.opponentPartyId); - if (bufferedCandidates) { - _logger.logger.info(`Call ${this.callId} addBufferedIceCandidates() adding ${bufferedCandidates.length} buffered candidates for opponent ${this.opponentPartyId}`); - await this.addIceCandidates(bufferedCandidates); - } - this.remoteCandidateBuffer.clear(); - } - async addIceCandidates(candidates) { - for (const candidate of candidates) { - if ((candidate.sdpMid === null || candidate.sdpMid === undefined) && (candidate.sdpMLineIndex === null || candidate.sdpMLineIndex === undefined)) { - _logger.logger.debug(`Call ${this.callId} addIceCandidates() got remote ICE end-of-candidates`); - } else { - _logger.logger.debug(`Call ${this.callId} addIceCandidates() got remote ICE candidate (sdpMid=${candidate.sdpMid}, candidate=${candidate.candidate})`); - } - try { - await this.peerConn.addIceCandidate(candidate); - } catch (err) { - if (!this.ignoreOffer) { - _logger.logger.info(`Call ${this.callId} addIceCandidates() failed to add remote ICE candidate`, err); - } - } - } - } - get hasPeerConnection() { - return Boolean(this.peerConn); - } - initStats(stats, peerId = "unknown") { - this.stats = stats; - this.stats.start(); - } -} -exports.MatrixCall = MatrixCall; -function setTracksEnabled(tracks, enabled) { - for (const track of tracks) { - track.enabled = enabled; - } -} -function supportsMatrixCall() { - // typeof prevents Node from erroring on an undefined reference - if (typeof window === "undefined" || typeof document === "undefined") { - // NB. We don't log here as apps try to create a call object as a test for - // whether calls are supported, so we shouldn't fill the logs up. - return false; - } - - // Firefox throws on so little as accessing the RTCPeerConnection when operating in a secure mode. - // There's some information at https://bugzilla.mozilla.org/show_bug.cgi?id=1542616 though the concern - // is that the browser throwing a SecurityError will brick the client creation process. - try { - const supported = Boolean(window.RTCPeerConnection || window.RTCSessionDescription || window.RTCIceCandidate || navigator.mediaDevices); - if (!supported) { - /* istanbul ignore if */ // Adds a lot of noise to test runs, so disable logging there. - if (process.env.NODE_ENV !== "test") { - _logger.logger.error("WebRTC is not supported in this browser / environment"); - } - return false; - } - } catch (e) { - _logger.logger.error("Exception thrown when trying to access WebRTC", e); - return false; - } - return true; -} - -/** - * DEPRECATED - * Use client.createCall() - * - * Create a new Matrix call for the browser. - * @param client - The client instance to use. - * @param roomId - The room the call is in. - * @param options - DEPRECATED optional options map. - * @returns the call or null if the browser doesn't support calling. - */ -function createNewMatrixCall(client, roomId, options) { - if (!supportsMatrixCall()) return null; - const optionsForceTURN = options ? options.forceTURN : false; - const opts = { - client: client, - roomId: roomId, - invitee: options === null || options === void 0 ? void 0 : options.invitee, - turnServers: client.getTurnServers(), - // call level options - forceTURN: client.forceTURN || optionsForceTURN, - opponentDeviceId: options === null || options === void 0 ? void 0 : options.opponentDeviceId, - opponentSessionId: options === null || options === void 0 ? void 0 : options.opponentSessionId, - groupCallId: options === null || options === void 0 ? void 0 : options.groupCallId - }; - const call = new MatrixCall(opts); - client.reEmitter.reEmit(call, Object.values(CallEvent)); - return call; -} -//# sourceMappingURL=call.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js.map deleted file mode 100644 index 955170b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/call.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"call.js","names":["_uuid","require","_sdpTransform","_logger","utils","_interopRequireWildcard","_event","_randomstring","_callEventTypes","_callFeed","_typedEventEmitter","_deviceinfo","_groupCall","_httpApi","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","MediaType","CodecName","CallState","exports","CallType","CallDirection","CallParty","CallEvent","CallErrorCode","VOIP_PROTO_VERSION","FALLBACK_ICE_SERVER","CALL_TIMEOUT_MS","CALL_LENGTH_INTERVAL","ICE_DISCONNECTED_TIMEOUT","CallError","Error","constructor","code","msg","err","genCallID","Date","now","toString","randomString","getCodecParamMods","isPtt","mods","mediaType","codec","enableDtx","maxAverageBitrate","undefined","getTransceiverKey","purpose","kind","MatrixCall","TypedEventEmitter","opts","_opts$forceTURN","Fledgling","Map","event","candidate","candidatesEnded","logger","warn","callId","debug","sdpMid","callHasEnded","queueCandidate","_this$peerConn","peerConn","iceGatheringState","error","emit","LocalOfferFailed","terminate","Local","successor","getUserMediaFailed","NoUserMedia","_this$peerConn2","_this$peerConn$iceCon","_this$peerConn3","_this$peerConn4","_this$peerConn6","iceConnectionState","includes","clearTimeout","iceDisconnectedTimeout","state","Connected","callLengthInterval","callStartTime","setInterval","LengthChanged","Math","round","_this$peerConn5","restartIce","info","hangup","IceFailed","setTimeout","Connecting","feed","getRemoteFeeds","setAudioVideoMuted","_this$peerConn7","signalingState","ev","streams","track","stream","pushRemoteFeed","removeTrackListeners","onRemoveTrack","getTracks","id","deleteFeedByStream","removeEventListener","delete","addEventListener","DataChannel","channel","CreateOffer","opponentVersion","queueGotLocalOffer","partyIdMatches","Ringing","Remote","reason","UserHangup","party_id","opponentPartyId","shouldTerminate","InviteSent","direction","Inbound","AnsweredElsewhere","roomId","invitee","client","deviceId","forceTURN","ourPartyId","opponentDeviceId","opponentSessionId","groupCallId","turnServers","isFallbackICEServerAllowed","urls","server","checkObjectHasKeys","isOnlyDataChannelAllowed","isVoipWithNoMediaAllowed","placeVoiceCall","placeCall","placeVideoCall","createDataChannel","label","options","dataChannel","getOpponentMember","opponentMember","getOpponentDeviceId","getOpponentSessionId","opponentCanBeTransferred","Boolean","opponentCaps","opponentSupportsDTMF","getRemoteAssertedIdentity","remoteAssertedIdentity","_state","oldState","State","type","hasUserMediaVideoSender","hasRemoteUserMediaVideoTrack","Video","Voice","hasLocalUserMediaVideoTrack","_this$localUsermediaS","localUsermediaStream","getVideoTracks","some","_feed$stream","SDPStreamMetadataPurpose","Usermedia","hasLocalUserMediaAudioTrack","_this$localUsermediaS2","getAudioTracks","hasRemoteUserMediaAudioTrack","_feed$stream2","hasUserMediaAudioSender","_this$transceivers$ge","transceivers","sender","_this$transceivers$ge2","localUsermediaFeed","getLocalFeeds","find","localScreensharingFeed","Screenshare","_this$localUsermediaF","localScreensharingStream","_this$localScreenshar","remoteUsermediaFeed","remoteScreensharingFeed","remoteUsermediaStream","_this$remoteUsermedia","remoteScreensharingStream","_this$remoteScreensha","getFeedByStreamId","streamId","getFeeds","feeds","isLocal","initOpponentCrypto","_this$getOpponentMemb","_deviceInfoMap$get","getUseE2eForGroupCall","isCryptoEnabled","opponentDeviceInfo","DeviceInfo","crypto","userId","deviceInfoMap","deviceList","downloadKeys","GroupCallUnknownDeviceError","getLocalSDPStreamMetadata","updateStreamIds","metadata","localFeed","sdpMetadataStreamId","audio_muted","isAudioMuted","video_muted","isVideoMuted","noIncomingFeeds","opponentSupportsSDPStreamMetadata","pushRemoteFeedWithoutMetadata","remoteSDPStreamMetadata","audioMuted","videoMuted","CallFeed","FeedsChanged","active","_this$feeds$find","oldRemoteStream","pushNewLocalFeed","addToPeerConnection","getUserId","setTracksEnabled","pushLocalFeed","callFeed","enabled","tKey","transceiver","replaceTrack","newSender","addTrack","newTransceiver","getTransceivers","t","removeLocalFeed","audioTransceiverKey","videoTransceiverKey","transceiverKey","removeTrack","getMediaHandler","stopScreensharingStream","deleteFeed","deleteAllFeeds","dispose","splice","indexOf","getCurrentCallStats","callStatsAtEnd","collectCallStats","statsReport","getStats","stats","item","initWithInvite","_this$feeds$find2","invite","getContent","haveTurnCreds","checkTurnServers","sdpStreamMetadata","SDPStreamMetadataKey","updateRemoteSDPStreamMetadata","createPeerConnection","chooseOpponent","setRemoteDescription","offer","addBufferedIceCandidates","e","SetRemoteDescription","remoteStream","getLocalAge","ringingTimer","_this$stats","hangupParty","Ended","stopAllMedia","close","removeStatsReportGatherer","Hangup","lifetime","onState","off","on","initWithHangup","shouldAnswerWithMediaType","wantedValue","valueOfTheOtherSide","isNullOrUndefined","answer","audio","video","inviteOrAnswerSent","waitForLocalAVStream","prevState","answerWithAudio","answerWithVideo","WaitLocalMedia","_this$client$getDevic","getUserMediaStream","usermediaFeed","getDeviceId","answerWithCallFeeds","callFeeds","queueGotCallFeedsForAnswer","replacedBy","newCall","Outbound","map","clone","Replaced","suppressEvent","content","sendVoipEvent","EventType","CallHangup","reject","CallReject","upgradeCall","getAudio","getVideo","updateLocalUsermediaStream","isScreensharing","setScreensharingEnabled","setScreensharingEnabledWithoutMetadataSupport","getScreensharingStream","audioTransceiver","videoTransceiver","_this$transceivers$ge3","_this$localUsermediaS3","_this$transceivers$ge4","forceAudio","forceVideo","audioEnabled","remoteOnHold","videoEnabled","log","stop","oldSender","added","setLocalVideoMuted","muted","_this$localUsermediaF3","stopVideoTrackTimer","hasVideoDevice","isLocalVideoMuted","_this$localUsermediaF2","updateMuteStatus","sendMetadataUpdate","_this$localUsermediaF4","_this$localUsermediaF5","setMicrophoneMuted","_this$localUsermediaF6","hasAudioDevice","isMicrophoneMuted","_this$localUsermediaF7","_this$localUsermediaF8","isRemoteOnHold","setRemoteOnHold","onHold","RemoteHoldUnhold","isLocalOnHold","callOnHold","trackOnHold","currentDirection","sendDtmfDigit","digit","getSenders","_sender$track","dtmf","insertDTMF","micShouldBeMuted","vidShouldBeMuted","CallSDPStreamMetadataChangedPrefix","gotCallFeedsForInvite","requestScreenshareFeed","addTransceiver","sendAnswer","answerContent","sdp","localDescription","capabilities","supportsCallTransfer","discardCount","discardDuplicateCandidates","CallAnswer","MatrixError","cancelPendingEvent","SendAnswer","message","name","UnknownDevices","sendCandidateQueue","responsePromiseChain","then","gotCallFeedsForAnswer","mungeSdp","description","parseSdp","media","payloadTypeToCodecMap","codecToPayloadTypeMap","rtp","payload","mod","extraConfig","found","fmtp","config","join","writeSdp","createOffer","createAnswer","CreateAnswer","getRidOfRTXCodecs","setLocalDescription","Promise","resolve","SetLocalDescription","onRemoteIceCandidatesReceived","candidates","fromPartyId","version","bufferedCandidates","remoteCandidateBuffer","addIceCandidates","onAnswerReceived","CallSelectAnswer","selected_party_id","onSelectAnswerReceived","selectedPartyId","onNegotiateReceived","polite","offerCollision","makingOffer","ignoreOffer","prevLocalOnHold","_localDescription","CallNegotiate","toJSON","newLocalOnHold","LocalHoldUnhold","HoldUnhold","recursivelyAssign","_streamId","onSDPStreamMetadataChangedReceived","onAssertedIdentityReceived","asserted_identity","displayName","display_name","AssertedIdentityChanged","wrappedGotLocalOffer","gotLocalOffer","getLocalOfferFailed","eventType","CallInvite","_localDescription2","_localDescription3","SignallingFailed","SendInvite","inviteTimeout","InviteTimeout","RTCRtpReceiver","getCapabilities","RTCRtpSender","recvCodecs","codecs","sendCodecs","mimeType","rtxCodecIndex","screenshareVideoTransceiver","setCodecPreferences","realContent","assign","call_id","conf_id","_this$getOpponentMemb2","toDeviceSeq","device_id","sender_session_id","getSessionId","dest_session_id","seq","ToDeviceMessageId","uuidv4","SendVoipEvent","encryptAndSendToDevices","deviceInfo","sendToDevice","_this$getOpponentMemb3","sendEvent","candidateSendQueue","delay","candidateSendTries","newQueue","transfer","targetUserId","profileInfo","getProfileInfo","replacementId","body","replacement_id","target_user","displayname","avatar_url","create_call","CallReplaces","Transferred","transferToCall","transferTargetCall","_transferTargetCall$g","_this$getOpponentMemb4","targetProfileInfo","opponentUserId","transfereeProfileInfo","newCallId","bodyToTransferTarget","await_call","bodyToTransferee","hangupReason","shouldEmit","_this$stats2","clearInterval","listener","clear","callEventHandler","calls","stopUserMediaStream","checkForErrorListener","listeners","EventEmitterEvents","CallCandidates","delayMs","pow","_this$client$getDevic2","placeCallWithCallFeeds","_this$stats3","pc","window","RTCPeerConnection","iceTransportPolicy","iceServers","iceCandidatePoolSize","bundlePolicy","onIceConnectionStateChanged","onSignallingStateChanged","gotLocalIceCandidate","onIceGatheringStateChange","onTrack","onNegotiationNeeded","onDataChannel","addStatsReportGatherer","msgPartyId","_getMember","getRoom","getMember","getSender","sdpMLineIndex","addIceCandidate","hasPeerConnection","initStats","peerId","start","tracks","supportsMatrixCall","document","supported","RTCSessionDescription","RTCIceCandidate","navigator","mediaDevices","process","env","NODE_ENV","createNewMatrixCall","optionsForceTURN","getTurnServers","reEmitter","reEmit","values"],"sources":["../../src/webrtc/call.ts"],"sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\nCopyright 2017 New Vector Ltd\nCopyright 2019, 2020 The Matrix.org Foundation C.I.C.\nCopyright 2021 - 2022 Šimon Brandner \n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module. See {@link createNewMatrixCall} for the public API.\n */\n\nimport { v4 as uuidv4 } from \"uuid\";\nimport { parse as parseSdp, write as writeSdp } from \"sdp-transform\";\n\nimport { logger } from \"../logger\";\nimport * as utils from \"../utils\";\nimport { IContent, MatrixEvent } from \"../models/event\";\nimport { EventType, ToDeviceMessageId } from \"../@types/event\";\nimport { RoomMember } from \"../models/room-member\";\nimport { randomString } from \"../randomstring\";\nimport {\n MCallReplacesEvent,\n MCallAnswer,\n MCallInviteNegotiate,\n CallCapabilities,\n SDPStreamMetadataPurpose,\n SDPStreamMetadata,\n SDPStreamMetadataKey,\n MCallSDPStreamMetadataChanged,\n MCallSelectAnswer,\n MCAllAssertedIdentity,\n MCallCandidates,\n MCallBase,\n MCallHangupReject,\n} from \"./callEventTypes\";\nimport { CallFeed } from \"./callFeed\";\nimport { MatrixClient } from \"../client\";\nimport { EventEmitterEvents, TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { DeviceInfo } from \"../crypto/deviceinfo\";\nimport { GroupCallUnknownDeviceError } from \"./groupCall\";\nimport { IScreensharingOpts } from \"./mediaHandler\";\nimport { MatrixError } from \"../http-api\";\nimport { GroupCallStats } from \"./stats/groupCallStats\";\n\ninterface CallOpts {\n // The room ID for this call.\n roomId: string;\n invitee?: string;\n // The Matrix Client instance to send events to.\n client: MatrixClient;\n /**\n * Whether relay through TURN should be forced.\n * @deprecated use opts.forceTURN when creating the matrix client\n * since it's only possible to set this option on outbound calls.\n */\n forceTURN?: boolean;\n // A list of TURN servers.\n turnServers?: Array;\n opponentDeviceId?: string;\n opponentSessionId?: string;\n groupCallId?: string;\n}\n\ninterface TurnServer {\n urls: Array;\n username?: string;\n password?: string;\n ttl?: number;\n}\n\ninterface AssertedIdentity {\n id: string;\n displayName: string;\n}\n\nenum MediaType {\n AUDIO = \"audio\",\n VIDEO = \"video\",\n}\n\nenum CodecName {\n OPUS = \"opus\",\n // add more as needed\n}\n\n// Used internally to specify modifications to codec parameters in SDP\ninterface CodecParamsMod {\n mediaType: MediaType;\n codec: CodecName;\n enableDtx?: boolean; // true to enable discontinuous transmission, false to disable, undefined to leave as-is\n maxAverageBitrate?: number; // sets the max average bitrate, or undefined to leave as-is\n}\n\nexport enum CallState {\n Fledgling = \"fledgling\",\n InviteSent = \"invite_sent\",\n WaitLocalMedia = \"wait_local_media\",\n CreateOffer = \"create_offer\",\n CreateAnswer = \"create_answer\",\n Connecting = \"connecting\",\n Connected = \"connected\",\n Ringing = \"ringing\",\n Ended = \"ended\",\n}\n\nexport enum CallType {\n Voice = \"voice\",\n Video = \"video\",\n}\n\nexport enum CallDirection {\n Inbound = \"inbound\",\n Outbound = \"outbound\",\n}\n\nexport enum CallParty {\n Local = \"local\",\n Remote = \"remote\",\n}\n\nexport enum CallEvent {\n Hangup = \"hangup\",\n State = \"state\",\n Error = \"error\",\n Replaced = \"replaced\",\n\n // The value of isLocalOnHold() has changed\n LocalHoldUnhold = \"local_hold_unhold\",\n // The value of isRemoteOnHold() has changed\n RemoteHoldUnhold = \"remote_hold_unhold\",\n // backwards compat alias for LocalHoldUnhold: remove in a major version bump\n HoldUnhold = \"hold_unhold\",\n // Feeds have changed\n FeedsChanged = \"feeds_changed\",\n\n AssertedIdentityChanged = \"asserted_identity_changed\",\n\n LengthChanged = \"length_changed\",\n\n DataChannel = \"datachannel\",\n\n SendVoipEvent = \"send_voip_event\",\n}\n\nexport enum CallErrorCode {\n /** The user chose to end the call */\n UserHangup = \"user_hangup\",\n\n /** An error code when the local client failed to create an offer. */\n LocalOfferFailed = \"local_offer_failed\",\n /**\n * An error code when there is no local mic/camera to use. This may be because\n * the hardware isn't plugged in, or the user has explicitly denied access.\n */\n NoUserMedia = \"no_user_media\",\n\n /**\n * Error code used when a call event failed to send\n * because unknown devices were present in the room\n */\n UnknownDevices = \"unknown_devices\",\n\n /**\n * Error code used when we fail to send the invite\n * for some reason other than there being unknown devices\n */\n SendInvite = \"send_invite\",\n\n /**\n * An answer could not be created\n */\n CreateAnswer = \"create_answer\",\n\n /**\n * An offer could not be created\n */\n CreateOffer = \"create_offer\",\n\n /**\n * Error code used when we fail to send the answer\n * for some reason other than there being unknown devices\n */\n SendAnswer = \"send_answer\",\n\n /**\n * The session description from the other side could not be set\n */\n SetRemoteDescription = \"set_remote_description\",\n\n /**\n * The session description from this side could not be set\n */\n SetLocalDescription = \"set_local_description\",\n\n /**\n * A different device answered the call\n */\n AnsweredElsewhere = \"answered_elsewhere\",\n\n /**\n * No media connection could be established to the other party\n */\n IceFailed = \"ice_failed\",\n\n /**\n * The invite timed out whilst waiting for an answer\n */\n InviteTimeout = \"invite_timeout\",\n\n /**\n * The call was replaced by another call\n */\n Replaced = \"replaced\",\n\n /**\n * Signalling for the call could not be sent (other than the initial invite)\n */\n SignallingFailed = \"signalling_timeout\",\n\n /**\n * The remote party is busy\n */\n UserBusy = \"user_busy\",\n\n /**\n * We transferred the call off to somewhere else\n */\n Transferred = \"transferred\",\n\n /**\n * A call from the same user was found with a new session id\n */\n NewSession = \"new_session\",\n}\n\n/**\n * The version field that we set in m.call.* events\n */\nconst VOIP_PROTO_VERSION = \"1\";\n\n/** The fallback ICE server to use for STUN or TURN protocols. */\nconst FALLBACK_ICE_SERVER = \"stun:turn.matrix.org\";\n\n/** The length of time a call can be ringing for. */\nconst CALL_TIMEOUT_MS = 60 * 1000; // ms\n/** The time after which we increment callLength */\nconst CALL_LENGTH_INTERVAL = 1000; // ms\n/** The time after which we end the call, if ICE got disconnected */\nconst ICE_DISCONNECTED_TIMEOUT = 30 * 1000; // ms\n\nexport class CallError extends Error {\n public readonly code: string;\n\n public constructor(code: CallErrorCode, msg: string, err: Error) {\n // Still don't think there's any way to have proper nested errors\n super(msg + \": \" + err);\n\n this.code = code;\n }\n}\n\nexport function genCallID(): string {\n return Date.now().toString() + randomString(16);\n}\n\nfunction getCodecParamMods(isPtt: boolean): CodecParamsMod[] {\n const mods = [\n {\n mediaType: \"audio\",\n codec: \"opus\",\n enableDtx: true,\n maxAverageBitrate: isPtt ? 12000 : undefined,\n },\n ] as CodecParamsMod[];\n\n return mods;\n}\n\nexport interface VoipEvent {\n type: \"toDevice\" | \"sendEvent\";\n eventType: string;\n userId?: string;\n opponentDeviceId?: string;\n roomId?: string;\n content: Record;\n}\n\n/**\n * These now all have the call object as an argument. Why? Well, to know which call a given event is\n * about you have three options:\n * 1. Use a closure as the callback that remembers what call it's listening to. This can be\n * a pain because you need to pass the listener function again when you remove the listener,\n * which might be somewhere else.\n * 2. Use not-very-well-known fact that EventEmitter sets 'this' to the emitter object in the\n * callback. This doesn't really play well with modern Typescript and eslint and doesn't work\n * with our pattern of re-emitting events.\n * 3. Pass the object in question as an argument to the callback.\n *\n * Now that we have group calls which have to deal with multiple call objects, this will\n * become more important, and I think methods 1 and 2 are just going to cause issues.\n */\nexport type CallEventHandlerMap = {\n [CallEvent.DataChannel]: (channel: RTCDataChannel, call: MatrixCall) => void;\n [CallEvent.FeedsChanged]: (feeds: CallFeed[], call: MatrixCall) => void;\n [CallEvent.Replaced]: (newCall: MatrixCall, oldCall: MatrixCall) => void;\n [CallEvent.Error]: (error: CallError, call: MatrixCall) => void;\n [CallEvent.RemoteHoldUnhold]: (onHold: boolean, call: MatrixCall) => void;\n [CallEvent.LocalHoldUnhold]: (onHold: boolean, call: MatrixCall) => void;\n [CallEvent.LengthChanged]: (length: number, call: MatrixCall) => void;\n [CallEvent.State]: (state: CallState, oldState: CallState, call: MatrixCall) => void;\n [CallEvent.Hangup]: (call: MatrixCall) => void;\n [CallEvent.AssertedIdentityChanged]: (call: MatrixCall) => void;\n /* @deprecated */\n [CallEvent.HoldUnhold]: (onHold: boolean) => void;\n [CallEvent.SendVoipEvent]: (event: VoipEvent, call: MatrixCall) => void;\n};\n\n// The key of the transceiver map (purpose + media type, separated by ':')\ntype TransceiverKey = string;\n\n// generates keys for the map of transceivers\n// kind is unfortunately a string rather than MediaType as this is the type of\n// track.kind\nfunction getTransceiverKey(purpose: SDPStreamMetadataPurpose, kind: TransceiverKey): string {\n return purpose + \":\" + kind;\n}\n\nexport class MatrixCall extends TypedEventEmitter {\n public roomId: string;\n public callId: string;\n public invitee?: string;\n public hangupParty?: CallParty;\n public hangupReason?: string;\n public direction?: CallDirection;\n public ourPartyId: string;\n public peerConn?: RTCPeerConnection;\n public toDeviceSeq = 0;\n\n // whether this call should have push-to-talk semantics\n // This should be set by the consumer on incoming & outgoing calls.\n public isPtt = false;\n\n private _state = CallState.Fledgling;\n private readonly client: MatrixClient;\n private readonly forceTURN?: boolean;\n private readonly turnServers: Array;\n // A queue for candidates waiting to go out.\n // We try to amalgamate candidates into a single candidate message where\n // possible\n private candidateSendQueue: Array = [];\n private candidateSendTries = 0;\n private candidatesEnded = false;\n private feeds: Array = [];\n\n // our transceivers for each purpose and type of media\n private transceivers = new Map();\n\n private inviteOrAnswerSent = false;\n private waitForLocalAVStream = false;\n private successor?: MatrixCall;\n private opponentMember?: RoomMember;\n private opponentVersion?: number | string;\n // The party ID of the other side: undefined if we haven't chosen a partner\n // yet, null if we have but they didn't send a party ID.\n private opponentPartyId: string | null | undefined;\n private opponentCaps?: CallCapabilities;\n private iceDisconnectedTimeout?: ReturnType;\n private inviteTimeout?: ReturnType;\n private readonly removeTrackListeners = new Map void>();\n\n // The logic of when & if a call is on hold is nontrivial and explained in is*OnHold\n // This flag represents whether we want the other party to be on hold\n private remoteOnHold = false;\n\n // the stats for the call at the point it ended. We can't get these after we\n // tear the call down, so we just grab a snapshot before we stop the call.\n // The typescript definitions have this type as 'any' :(\n private callStatsAtEnd?: any[];\n\n // Perfect negotiation state: https://www.w3.org/TR/webrtc/#perfect-negotiation-example\n private makingOffer = false;\n private ignoreOffer = false;\n\n private responsePromiseChain?: Promise;\n\n // If candidates arrive before we've picked an opponent (which, in particular,\n // will happen if the opponent sends candidates eagerly before the user answers\n // the call) we buffer them up here so we can then add the ones from the party we pick\n private remoteCandidateBuffer = new Map();\n\n private remoteAssertedIdentity?: AssertedIdentity;\n private remoteSDPStreamMetadata?: SDPStreamMetadata;\n\n private callLengthInterval?: ReturnType;\n private callStartTime?: number;\n\n private opponentDeviceId?: string;\n private opponentDeviceInfo?: DeviceInfo;\n private opponentSessionId?: string;\n public groupCallId?: string;\n\n // Used to keep the timer for the delay before actually stopping our\n // video track after muting (see setLocalVideoMuted)\n private stopVideoTrackTimer?: ReturnType;\n // Used to allow connection without Video and Audio. To establish a webrtc connection without media a Data channel is\n // needed At the moment this property is true if we allow MatrixClient with isVoipWithNoMediaAllowed = true\n private readonly isOnlyDataChannelAllowed: boolean;\n private stats: GroupCallStats | undefined;\n\n /**\n * Construct a new Matrix Call.\n * @param opts - Config options.\n */\n public constructor(opts: CallOpts) {\n super();\n\n this.roomId = opts.roomId;\n this.invitee = opts.invitee;\n this.client = opts.client;\n\n if (!this.client.deviceId) throw new Error(\"Client must have a device ID to start calls\");\n\n this.forceTURN = opts.forceTURN ?? false;\n this.ourPartyId = this.client.deviceId;\n this.opponentDeviceId = opts.opponentDeviceId;\n this.opponentSessionId = opts.opponentSessionId;\n this.groupCallId = opts.groupCallId;\n // Array of Objects with urls, username, credential keys\n this.turnServers = opts.turnServers || [];\n if (this.turnServers.length === 0 && this.client.isFallbackICEServerAllowed()) {\n this.turnServers.push({\n urls: [FALLBACK_ICE_SERVER],\n });\n }\n for (const server of this.turnServers) {\n utils.checkObjectHasKeys(server, [\"urls\"]);\n }\n this.callId = genCallID();\n // If the Client provides calls without audio and video we need a datachannel for a webrtc connection\n this.isOnlyDataChannelAllowed = this.client.isVoipWithNoMediaAllowed;\n }\n\n /**\n * Place a voice call to this room.\n * @throws If you have not specified a listener for 'error' events.\n */\n public async placeVoiceCall(): Promise {\n await this.placeCall(true, false);\n }\n\n /**\n * Place a video call to this room.\n * @throws If you have not specified a listener for 'error' events.\n */\n public async placeVideoCall(): Promise {\n await this.placeCall(true, true);\n }\n\n /**\n * Create a datachannel using this call's peer connection.\n * @param label - A human readable label for this datachannel\n * @param options - An object providing configuration options for the data channel.\n */\n public createDataChannel(label: string, options: RTCDataChannelInit | undefined): RTCDataChannel {\n const dataChannel = this.peerConn!.createDataChannel(label, options);\n this.emit(CallEvent.DataChannel, dataChannel, this);\n return dataChannel;\n }\n\n public getOpponentMember(): RoomMember | undefined {\n return this.opponentMember;\n }\n\n public getOpponentDeviceId(): string | undefined {\n return this.opponentDeviceId;\n }\n\n public getOpponentSessionId(): string | undefined {\n return this.opponentSessionId;\n }\n\n public opponentCanBeTransferred(): boolean {\n return Boolean(this.opponentCaps && this.opponentCaps[\"m.call.transferee\"]);\n }\n\n public opponentSupportsDTMF(): boolean {\n return Boolean(this.opponentCaps && this.opponentCaps[\"m.call.dtmf\"]);\n }\n\n public getRemoteAssertedIdentity(): AssertedIdentity | undefined {\n return this.remoteAssertedIdentity;\n }\n\n public get state(): CallState {\n return this._state;\n }\n\n private set state(state: CallState) {\n const oldState = this._state;\n this._state = state;\n this.emit(CallEvent.State, state, oldState, this);\n }\n\n public get type(): CallType {\n // we may want to look for a video receiver here rather than a track to match the\n // sender behaviour, although in practice they should be the same thing\n return this.hasUserMediaVideoSender || this.hasRemoteUserMediaVideoTrack ? CallType.Video : CallType.Voice;\n }\n\n public get hasLocalUserMediaVideoTrack(): boolean {\n return !!this.localUsermediaStream?.getVideoTracks().length;\n }\n\n public get hasRemoteUserMediaVideoTrack(): boolean {\n return this.getRemoteFeeds().some((feed) => {\n return feed.purpose === SDPStreamMetadataPurpose.Usermedia && feed.stream?.getVideoTracks().length;\n });\n }\n\n public get hasLocalUserMediaAudioTrack(): boolean {\n return !!this.localUsermediaStream?.getAudioTracks().length;\n }\n\n public get hasRemoteUserMediaAudioTrack(): boolean {\n return this.getRemoteFeeds().some((feed) => {\n return feed.purpose === SDPStreamMetadataPurpose.Usermedia && !!feed.stream?.getAudioTracks().length;\n });\n }\n\n private get hasUserMediaAudioSender(): boolean {\n return Boolean(this.transceivers.get(getTransceiverKey(SDPStreamMetadataPurpose.Usermedia, \"audio\"))?.sender);\n }\n\n private get hasUserMediaVideoSender(): boolean {\n return Boolean(this.transceivers.get(getTransceiverKey(SDPStreamMetadataPurpose.Usermedia, \"video\"))?.sender);\n }\n\n public get localUsermediaFeed(): CallFeed | undefined {\n return this.getLocalFeeds().find((feed) => feed.purpose === SDPStreamMetadataPurpose.Usermedia);\n }\n\n public get localScreensharingFeed(): CallFeed | undefined {\n return this.getLocalFeeds().find((feed) => feed.purpose === SDPStreamMetadataPurpose.Screenshare);\n }\n\n public get localUsermediaStream(): MediaStream | undefined {\n return this.localUsermediaFeed?.stream;\n }\n\n public get localScreensharingStream(): MediaStream | undefined {\n return this.localScreensharingFeed?.stream;\n }\n\n public get remoteUsermediaFeed(): CallFeed | undefined {\n return this.getRemoteFeeds().find((feed) => feed.purpose === SDPStreamMetadataPurpose.Usermedia);\n }\n\n public get remoteScreensharingFeed(): CallFeed | undefined {\n return this.getRemoteFeeds().find((feed) => feed.purpose === SDPStreamMetadataPurpose.Screenshare);\n }\n\n public get remoteUsermediaStream(): MediaStream | undefined {\n return this.remoteUsermediaFeed?.stream;\n }\n\n public get remoteScreensharingStream(): MediaStream | undefined {\n return this.remoteScreensharingFeed?.stream;\n }\n\n private getFeedByStreamId(streamId: string): CallFeed | undefined {\n return this.getFeeds().find((feed) => feed.stream.id === streamId);\n }\n\n /**\n * Returns an array of all CallFeeds\n * @returns CallFeeds\n */\n public getFeeds(): Array {\n return this.feeds;\n }\n\n /**\n * Returns an array of all local CallFeeds\n * @returns local CallFeeds\n */\n public getLocalFeeds(): Array {\n return this.feeds.filter((feed) => feed.isLocal());\n }\n\n /**\n * Returns an array of all remote CallFeeds\n * @returns remote CallFeeds\n */\n public getRemoteFeeds(): Array {\n return this.feeds.filter((feed) => !feed.isLocal());\n }\n\n private async initOpponentCrypto(): Promise {\n if (!this.opponentDeviceId) return;\n if (!this.client.getUseE2eForGroupCall()) return;\n // It's possible to want E2EE and yet not have the means to manage E2EE\n // ourselves (for example if the client is a RoomWidgetClient)\n if (!this.client.isCryptoEnabled()) {\n // All we know is the device ID\n this.opponentDeviceInfo = new DeviceInfo(this.opponentDeviceId);\n return;\n }\n // if we've got to this point, we do want to init crypto, so throw if we can't\n if (!this.client.crypto) throw new Error(\"Crypto is not initialised.\");\n\n const userId = this.invitee || this.getOpponentMember()?.userId;\n\n if (!userId) throw new Error(\"Couldn't find opponent user ID to init crypto\");\n\n const deviceInfoMap = await this.client.crypto.deviceList.downloadKeys([userId], false);\n this.opponentDeviceInfo = deviceInfoMap.get(userId)?.get(this.opponentDeviceId);\n if (this.opponentDeviceInfo === undefined) {\n throw new GroupCallUnknownDeviceError(userId);\n }\n }\n\n /**\n * Generates and returns localSDPStreamMetadata\n * @returns localSDPStreamMetadata\n */\n private getLocalSDPStreamMetadata(updateStreamIds = false): SDPStreamMetadata {\n const metadata: SDPStreamMetadata = {};\n for (const localFeed of this.getLocalFeeds()) {\n if (updateStreamIds) {\n localFeed.sdpMetadataStreamId = localFeed.stream.id;\n }\n\n metadata[localFeed.sdpMetadataStreamId] = {\n purpose: localFeed.purpose,\n audio_muted: localFeed.isAudioMuted(),\n video_muted: localFeed.isVideoMuted(),\n };\n }\n return metadata;\n }\n\n /**\n * Returns true if there are no incoming feeds,\n * otherwise returns false\n * @returns no incoming feeds\n */\n public noIncomingFeeds(): boolean {\n return !this.feeds.some((feed) => !feed.isLocal());\n }\n\n private pushRemoteFeed(stream: MediaStream): void {\n // Fallback to old behavior if the other side doesn't support SDPStreamMetadata\n if (!this.opponentSupportsSDPStreamMetadata()) {\n this.pushRemoteFeedWithoutMetadata(stream);\n return;\n }\n\n const userId = this.getOpponentMember()!.userId;\n const purpose = this.remoteSDPStreamMetadata![stream.id].purpose;\n const audioMuted = this.remoteSDPStreamMetadata![stream.id].audio_muted;\n const videoMuted = this.remoteSDPStreamMetadata![stream.id].video_muted;\n\n if (!purpose) {\n logger.warn(\n `Call ${this.callId} pushRemoteFeed() ignoring stream because we didn't get any metadata about it (streamId=${stream.id})`,\n );\n return;\n }\n\n if (this.getFeedByStreamId(stream.id)) {\n logger.warn(\n `Call ${this.callId} pushRemoteFeed() ignoring stream because we already have a feed for it (streamId=${stream.id})`,\n );\n return;\n }\n\n this.feeds.push(\n new CallFeed({\n client: this.client,\n call: this,\n roomId: this.roomId,\n userId,\n deviceId: this.getOpponentDeviceId(),\n stream,\n purpose,\n audioMuted,\n videoMuted,\n }),\n );\n\n this.emit(CallEvent.FeedsChanged, this.feeds, this);\n\n logger.info(\n `Call ${this.callId} pushRemoteFeed() pushed stream (streamId=${stream.id}, active=${stream.active}, purpose=${purpose})`,\n );\n }\n\n /**\n * This method is used ONLY if the other client doesn't support sending SDPStreamMetadata\n */\n private pushRemoteFeedWithoutMetadata(stream: MediaStream): void {\n const userId = this.getOpponentMember()!.userId;\n // We can guess the purpose here since the other client can only send one stream\n const purpose = SDPStreamMetadataPurpose.Usermedia;\n const oldRemoteStream = this.feeds.find((feed) => !feed.isLocal())?.stream;\n\n // Note that we check by ID and always set the remote stream: Chrome appears\n // to make new stream objects when transceiver directionality is changed and the 'active'\n // status of streams change - Dave\n // If we already have a stream, check this stream has the same id\n if (oldRemoteStream && stream.id !== oldRemoteStream.id) {\n logger.warn(\n `Call ${this.callId} pushRemoteFeedWithoutMetadata() ignoring new stream because we already have stream (streamId=${stream.id})`,\n );\n return;\n }\n\n if (this.getFeedByStreamId(stream.id)) {\n logger.warn(\n `Call ${this.callId} pushRemoteFeedWithoutMetadata() ignoring stream because we already have a feed for it (streamId=${stream.id})`,\n );\n return;\n }\n\n this.feeds.push(\n new CallFeed({\n client: this.client,\n call: this,\n roomId: this.roomId,\n audioMuted: false,\n videoMuted: false,\n userId,\n deviceId: this.getOpponentDeviceId(),\n stream,\n purpose,\n }),\n );\n\n this.emit(CallEvent.FeedsChanged, this.feeds, this);\n\n logger.info(\n `Call ${this.callId} pushRemoteFeedWithoutMetadata() pushed stream (streamId=${stream.id}, active=${stream.active})`,\n );\n }\n\n private pushNewLocalFeed(stream: MediaStream, purpose: SDPStreamMetadataPurpose, addToPeerConnection = true): void {\n const userId = this.client.getUserId()!;\n\n // Tracks don't always start off enabled, eg. chrome will give a disabled\n // audio track if you ask for user media audio and already had one that\n // you'd set to disabled (presumably because it clones them internally).\n setTracksEnabled(stream.getAudioTracks(), true);\n setTracksEnabled(stream.getVideoTracks(), true);\n\n if (this.getFeedByStreamId(stream.id)) {\n logger.warn(\n `Call ${this.callId} pushNewLocalFeed() ignoring stream because we already have a feed for it (streamId=${stream.id})`,\n );\n return;\n }\n\n this.pushLocalFeed(\n new CallFeed({\n client: this.client,\n roomId: this.roomId,\n audioMuted: false,\n videoMuted: false,\n userId,\n deviceId: this.getOpponentDeviceId(),\n stream,\n purpose,\n }),\n addToPeerConnection,\n );\n }\n\n /**\n * Pushes supplied feed to the call\n * @param callFeed - to push\n * @param addToPeerConnection - whether to add the tracks to the peer connection\n */\n public pushLocalFeed(callFeed: CallFeed, addToPeerConnection = true): void {\n if (this.feeds.some((feed) => callFeed.stream.id === feed.stream.id)) {\n logger.info(\n `Call ${this.callId} pushLocalFeed() ignoring duplicate local stream (streamId=${callFeed.stream.id})`,\n );\n return;\n }\n\n this.feeds.push(callFeed);\n\n if (addToPeerConnection) {\n for (const track of callFeed.stream.getTracks()) {\n logger.info(\n `Call ${this.callId} pushLocalFeed() adding track to peer connection (id=${track.id}, kind=${track.kind}, streamId=${callFeed.stream.id}, streamPurpose=${callFeed.purpose}, enabled=${track.enabled})`,\n );\n\n const tKey = getTransceiverKey(callFeed.purpose, track.kind);\n if (this.transceivers.has(tKey)) {\n // we already have a sender, so we re-use it. We try to re-use transceivers as much\n // as possible because they can't be removed once added, so otherwise they just\n // accumulate which makes the SDP very large very quickly: in fact it only takes\n // about 6 video tracks to exceed the maximum size of an Olm-encrypted\n // Matrix event.\n const transceiver = this.transceivers.get(tKey)!;\n\n transceiver.sender.replaceTrack(track);\n // set the direction to indicate we're going to start sending again\n // (this will trigger the re-negotiation)\n transceiver.direction = transceiver.direction === \"inactive\" ? \"sendonly\" : \"sendrecv\";\n } else {\n // create a new one. We need to use addTrack rather addTransceiver for this because firefox\n // doesn't yet implement RTCRTPSender.setStreams()\n // (https://bugzilla.mozilla.org/show_bug.cgi?id=1510802) so we'd have no way to group the\n // two tracks together into a stream.\n const newSender = this.peerConn!.addTrack(track, callFeed.stream);\n\n // now go & fish for the new transceiver\n const newTransceiver = this.peerConn!.getTransceivers().find((t) => t.sender === newSender);\n if (newTransceiver) {\n this.transceivers.set(tKey, newTransceiver);\n } else {\n logger.warn(\n `Call ${this.callId} pushLocalFeed() didn't find a matching transceiver after adding track!`,\n );\n }\n }\n }\n }\n\n logger.info(\n `Call ${this.callId} pushLocalFeed() pushed stream (id=${callFeed.stream.id}, active=${callFeed.stream.active}, purpose=${callFeed.purpose})`,\n );\n\n this.emit(CallEvent.FeedsChanged, this.feeds, this);\n }\n\n /**\n * Removes local call feed from the call and its tracks from the peer\n * connection\n * @param callFeed - to remove\n */\n public removeLocalFeed(callFeed: CallFeed): void {\n const audioTransceiverKey = getTransceiverKey(callFeed.purpose, \"audio\");\n const videoTransceiverKey = getTransceiverKey(callFeed.purpose, \"video\");\n\n for (const transceiverKey of [audioTransceiverKey, videoTransceiverKey]) {\n // this is slightly mixing the track and transceiver API but is basically just shorthand.\n // There is no way to actually remove a transceiver, so this just sets it to inactive\n // (or recvonly) and replaces the source with nothing.\n if (this.transceivers.has(transceiverKey)) {\n const transceiver = this.transceivers.get(transceiverKey)!;\n if (transceiver.sender) this.peerConn!.removeTrack(transceiver.sender);\n }\n }\n\n if (callFeed.purpose === SDPStreamMetadataPurpose.Screenshare) {\n this.client.getMediaHandler().stopScreensharingStream(callFeed.stream);\n }\n\n this.deleteFeed(callFeed);\n }\n\n private deleteAllFeeds(): void {\n for (const feed of this.feeds) {\n if (!feed.isLocal() || !this.groupCallId) {\n feed.dispose();\n }\n }\n\n this.feeds = [];\n this.emit(CallEvent.FeedsChanged, this.feeds, this);\n }\n\n private deleteFeedByStream(stream: MediaStream): void {\n const feed = this.getFeedByStreamId(stream.id);\n if (!feed) {\n logger.warn(\n `Call ${this.callId} deleteFeedByStream() didn't find the feed to delete (streamId=${stream.id})`,\n );\n return;\n }\n this.deleteFeed(feed);\n }\n\n private deleteFeed(feed: CallFeed): void {\n feed.dispose();\n this.feeds.splice(this.feeds.indexOf(feed), 1);\n this.emit(CallEvent.FeedsChanged, this.feeds, this);\n }\n\n // The typescript definitions have this type as 'any' :(\n public async getCurrentCallStats(): Promise {\n if (this.callHasEnded()) {\n return this.callStatsAtEnd;\n }\n\n return this.collectCallStats();\n }\n\n private async collectCallStats(): Promise {\n // This happens when the call fails before it starts.\n // For example when we fail to get capture sources\n if (!this.peerConn) return;\n\n const statsReport = await this.peerConn.getStats();\n const stats: any[] = [];\n statsReport.forEach((item) => {\n stats.push(item);\n });\n\n return stats;\n }\n\n /**\n * Configure this call from an invite event. Used by MatrixClient.\n * @param event - The m.call.invite event\n */\n public async initWithInvite(event: MatrixEvent): Promise {\n const invite = event.getContent();\n this.direction = CallDirection.Inbound;\n\n // make sure we have valid turn creds. Unless something's gone wrong, it should\n // poll and keep the credentials valid so this should be instant.\n const haveTurnCreds = await this.client.checkTurnServers();\n if (!haveTurnCreds) {\n logger.warn(\n `Call ${this.callId} initWithInvite() failed to get TURN credentials! Proceeding with call anyway...`,\n );\n }\n\n const sdpStreamMetadata = invite[SDPStreamMetadataKey];\n if (sdpStreamMetadata) {\n this.updateRemoteSDPStreamMetadata(sdpStreamMetadata);\n } else {\n logger.debug(\n `Call ${this.callId} initWithInvite() did not get any SDPStreamMetadata! Can not send/receive multiple streams`,\n );\n }\n\n this.peerConn = this.createPeerConnection();\n // we must set the party ID before await-ing on anything: the call event\n // handler will start giving us more call events (eg. candidates) so if\n // we haven't set the party ID, we'll ignore them.\n this.chooseOpponent(event);\n await this.initOpponentCrypto();\n try {\n await this.peerConn.setRemoteDescription(invite.offer);\n await this.addBufferedIceCandidates();\n } catch (e) {\n logger.debug(`Call ${this.callId} initWithInvite() failed to set remote description`, e);\n this.terminate(CallParty.Local, CallErrorCode.SetRemoteDescription, false);\n return;\n }\n\n const remoteStream = this.feeds.find((feed) => !feed.isLocal())?.stream;\n\n // According to previous comments in this file, firefox at some point did not\n // add streams until media started arriving on them. Testing latest firefox\n // (81 at time of writing), this is no longer a problem, so let's do it the correct way.\n //\n // For example in case of no media webrtc connections like screen share only call we have to allow webrtc\n // connections without remote media. In this case we always use a data channel. At the moment we allow as well\n // only data channel as media in the WebRTC connection with this setup here.\n if (!this.isOnlyDataChannelAllowed && (!remoteStream || remoteStream.getTracks().length === 0)) {\n logger.error(\n `Call ${this.callId} initWithInvite() no remote stream or no tracks after setting remote description!`,\n );\n this.terminate(CallParty.Local, CallErrorCode.SetRemoteDescription, false);\n return;\n }\n\n this.state = CallState.Ringing;\n\n if (event.getLocalAge()) {\n // Time out the call if it's ringing for too long\n const ringingTimer = setTimeout(() => {\n if (this.state == CallState.Ringing) {\n logger.debug(`Call ${this.callId} initWithInvite() invite has expired. Hanging up.`);\n this.hangupParty = CallParty.Remote; // effectively\n this.state = CallState.Ended;\n this.stopAllMedia();\n if (this.peerConn!.signalingState != \"closed\") {\n this.peerConn!.close();\n }\n this.stats?.removeStatsReportGatherer(this.callId);\n this.emit(CallEvent.Hangup, this);\n }\n }, invite.lifetime - event.getLocalAge());\n\n const onState = (state: CallState): void => {\n if (state !== CallState.Ringing) {\n clearTimeout(ringingTimer);\n this.off(CallEvent.State, onState);\n }\n };\n this.on(CallEvent.State, onState);\n }\n }\n\n /**\n * Configure this call from a hangup or reject event. Used by MatrixClient.\n * @param event - The m.call.hangup event\n */\n public initWithHangup(event: MatrixEvent): void {\n // perverse as it may seem, sometimes we want to instantiate a call with a\n // hangup message (because when getting the state of the room on load, events\n // come in reverse order and we want to remember that a call has been hung up)\n this.state = CallState.Ended;\n }\n\n private shouldAnswerWithMediaType(\n wantedValue: boolean | undefined,\n valueOfTheOtherSide: boolean,\n type: \"audio\" | \"video\",\n ): boolean {\n if (wantedValue && !valueOfTheOtherSide) {\n // TODO: Figure out how to do this\n logger.warn(\n `Call ${this.callId} shouldAnswerWithMediaType() unable to answer with ${type} because the other side isn't sending it either.`,\n );\n return false;\n } else if (\n !utils.isNullOrUndefined(wantedValue) &&\n wantedValue !== valueOfTheOtherSide &&\n !this.opponentSupportsSDPStreamMetadata()\n ) {\n logger.warn(\n `Call ${this.callId} shouldAnswerWithMediaType() unable to answer with ${type}=${wantedValue} because the other side doesn't support it. Answering with ${type}=${valueOfTheOtherSide}.`,\n );\n return valueOfTheOtherSide!;\n }\n return wantedValue ?? valueOfTheOtherSide!;\n }\n\n /**\n * Answer a call.\n */\n public async answer(audio?: boolean, video?: boolean): Promise {\n if (this.inviteOrAnswerSent) return;\n // TODO: Figure out how to do this\n if (audio === false && video === false) throw new Error(\"You CANNOT answer a call without media\");\n\n if (!this.localUsermediaStream && !this.waitForLocalAVStream) {\n const prevState = this.state;\n const answerWithAudio = this.shouldAnswerWithMediaType(audio, this.hasRemoteUserMediaAudioTrack, \"audio\");\n const answerWithVideo = this.shouldAnswerWithMediaType(video, this.hasRemoteUserMediaVideoTrack, \"video\");\n\n this.state = CallState.WaitLocalMedia;\n this.waitForLocalAVStream = true;\n\n try {\n const stream = await this.client.getMediaHandler().getUserMediaStream(answerWithAudio, answerWithVideo);\n this.waitForLocalAVStream = false;\n const usermediaFeed = new CallFeed({\n client: this.client,\n roomId: this.roomId,\n userId: this.client.getUserId()!,\n deviceId: this.client.getDeviceId() ?? undefined,\n stream,\n purpose: SDPStreamMetadataPurpose.Usermedia,\n audioMuted: false,\n videoMuted: false,\n });\n\n const feeds = [usermediaFeed];\n\n if (this.localScreensharingFeed) {\n feeds.push(this.localScreensharingFeed);\n }\n\n this.answerWithCallFeeds(feeds);\n } catch (e) {\n if (answerWithVideo) {\n // Try to answer without video\n logger.warn(\n `Call ${this.callId} answer() failed to getUserMedia(), trying to getUserMedia() without video`,\n );\n this.state = prevState;\n this.waitForLocalAVStream = false;\n await this.answer(answerWithAudio, false);\n } else {\n this.getUserMediaFailed(e);\n return;\n }\n }\n } else if (this.waitForLocalAVStream) {\n this.state = CallState.WaitLocalMedia;\n }\n }\n\n public answerWithCallFeeds(callFeeds: CallFeed[]): void {\n if (this.inviteOrAnswerSent) return;\n\n this.queueGotCallFeedsForAnswer(callFeeds);\n }\n\n /**\n * Replace this call with a new call, e.g. for glare resolution. Used by\n * MatrixClient.\n * @param newCall - The new call.\n */\n public replacedBy(newCall: MatrixCall): void {\n logger.debug(`Call ${this.callId} replacedBy() running (newCallId=${newCall.callId})`);\n if (this.state === CallState.WaitLocalMedia) {\n logger.debug(\n `Call ${this.callId} replacedBy() telling new call to wait for local media (newCallId=${newCall.callId})`,\n );\n newCall.waitForLocalAVStream = true;\n } else if ([CallState.CreateOffer, CallState.InviteSent].includes(this.state)) {\n if (newCall.direction === CallDirection.Outbound) {\n newCall.queueGotCallFeedsForAnswer([]);\n } else {\n logger.debug(\n `Call ${this.callId} replacedBy() handing local stream to new call(newCallId=${newCall.callId})`,\n );\n newCall.queueGotCallFeedsForAnswer(this.getLocalFeeds().map((feed) => feed.clone()));\n }\n }\n this.successor = newCall;\n this.emit(CallEvent.Replaced, newCall, this);\n this.hangup(CallErrorCode.Replaced, true);\n }\n\n /**\n * Hangup a call.\n * @param reason - The reason why the call is being hung up.\n * @param suppressEvent - True to suppress emitting an event.\n */\n public hangup(reason: CallErrorCode, suppressEvent: boolean): void {\n if (this.callHasEnded()) return;\n\n logger.debug(`Call ${this.callId} hangup() ending call (reason=${reason})`);\n this.terminate(CallParty.Local, reason, !suppressEvent);\n // We don't want to send hangup here if we didn't even get to sending an invite\n if ([CallState.Fledgling, CallState.WaitLocalMedia].includes(this.state)) return;\n const content: IContent = {};\n // Don't send UserHangup reason to older clients\n if ((this.opponentVersion && this.opponentVersion !== 0) || reason !== CallErrorCode.UserHangup) {\n content[\"reason\"] = reason;\n }\n this.sendVoipEvent(EventType.CallHangup, content);\n }\n\n /**\n * Reject a call\n * This used to be done by calling hangup, but is a separate method and protocol\n * event as of MSC2746.\n */\n public reject(): void {\n if (this.state !== CallState.Ringing) {\n throw Error(\"Call must be in 'ringing' state to reject!\");\n }\n\n if (this.opponentVersion === 0) {\n logger.info(\n `Call ${this.callId} reject() opponent version is less than 1: sending hangup instead of reject (opponentVersion=${this.opponentVersion})`,\n );\n this.hangup(CallErrorCode.UserHangup, true);\n return;\n }\n\n logger.debug(\"Rejecting call: \" + this.callId);\n this.terminate(CallParty.Local, CallErrorCode.UserHangup, true);\n this.sendVoipEvent(EventType.CallReject, {});\n }\n\n /**\n * Adds an audio and/or video track - upgrades the call\n * @param audio - should add an audio track\n * @param video - should add an video track\n */\n private async upgradeCall(audio: boolean, video: boolean): Promise {\n // We don't do call downgrades\n if (!audio && !video) return;\n if (!this.opponentSupportsSDPStreamMetadata()) return;\n\n try {\n logger.debug(`Call ${this.callId} upgradeCall() upgrading call (audio=${audio}, video=${video})`);\n const getAudio = audio || this.hasLocalUserMediaAudioTrack;\n const getVideo = video || this.hasLocalUserMediaVideoTrack;\n\n // updateLocalUsermediaStream() will take the tracks, use them as\n // replacement and throw the stream away, so it isn't reusable\n const stream = await this.client.getMediaHandler().getUserMediaStream(getAudio, getVideo, false);\n await this.updateLocalUsermediaStream(stream, audio, video);\n } catch (error) {\n logger.error(`Call ${this.callId} upgradeCall() failed to upgrade the call`, error);\n this.emit(\n CallEvent.Error,\n new CallError(CallErrorCode.NoUserMedia, \"Failed to get camera access: \", error),\n this,\n );\n }\n }\n\n /**\n * Returns true if this.remoteSDPStreamMetadata is defined, otherwise returns false\n * @returns can screenshare\n */\n public opponentSupportsSDPStreamMetadata(): boolean {\n return Boolean(this.remoteSDPStreamMetadata);\n }\n\n /**\n * If there is a screensharing stream returns true, otherwise returns false\n * @returns is screensharing\n */\n public isScreensharing(): boolean {\n return Boolean(this.localScreensharingStream);\n }\n\n /**\n * Starts/stops screensharing\n * @param enabled - the desired screensharing state\n * @param desktopCapturerSourceId - optional id of the desktop capturer source to use\n * @returns new screensharing state\n */\n public async setScreensharingEnabled(enabled: boolean, opts?: IScreensharingOpts): Promise {\n // Skip if there is nothing to do\n if (enabled && this.isScreensharing()) {\n logger.warn(\n `Call ${this.callId} setScreensharingEnabled() there is already a screensharing stream - there is nothing to do!`,\n );\n return true;\n } else if (!enabled && !this.isScreensharing()) {\n logger.warn(\n `Call ${this.callId} setScreensharingEnabled() there already isn't a screensharing stream - there is nothing to do!`,\n );\n return false;\n }\n\n // Fallback to replaceTrack()\n if (!this.opponentSupportsSDPStreamMetadata()) {\n return this.setScreensharingEnabledWithoutMetadataSupport(enabled, opts);\n }\n\n logger.debug(`Call ${this.callId} setScreensharingEnabled() running (enabled=${enabled})`);\n if (enabled) {\n try {\n const stream = await this.client.getMediaHandler().getScreensharingStream(opts);\n if (!stream) return false;\n this.pushNewLocalFeed(stream, SDPStreamMetadataPurpose.Screenshare);\n return true;\n } catch (err) {\n logger.error(`Call ${this.callId} setScreensharingEnabled() failed to get screen-sharing stream:`, err);\n return false;\n }\n } else {\n const audioTransceiver = this.transceivers.get(\n getTransceiverKey(SDPStreamMetadataPurpose.Screenshare, \"audio\"),\n );\n const videoTransceiver = this.transceivers.get(\n getTransceiverKey(SDPStreamMetadataPurpose.Screenshare, \"video\"),\n );\n\n for (const transceiver of [audioTransceiver, videoTransceiver]) {\n // this is slightly mixing the track and transceiver API but is basically just shorthand\n // for removing the sender.\n if (transceiver && transceiver.sender) this.peerConn!.removeTrack(transceiver.sender);\n }\n\n this.client.getMediaHandler().stopScreensharingStream(this.localScreensharingStream!);\n this.deleteFeedByStream(this.localScreensharingStream!);\n return false;\n }\n }\n\n /**\n * Starts/stops screensharing\n * Should be used ONLY if the opponent doesn't support SDPStreamMetadata\n * @param enabled - the desired screensharing state\n * @param desktopCapturerSourceId - optional id of the desktop capturer source to use\n * @returns new screensharing state\n */\n private async setScreensharingEnabledWithoutMetadataSupport(\n enabled: boolean,\n opts?: IScreensharingOpts,\n ): Promise {\n logger.debug(\n `Call ${this.callId} setScreensharingEnabledWithoutMetadataSupport() running (enabled=${enabled})`,\n );\n if (enabled) {\n try {\n const stream = await this.client.getMediaHandler().getScreensharingStream(opts);\n if (!stream) return false;\n\n const track = stream.getTracks().find((track) => track.kind === \"video\");\n\n const sender = this.transceivers.get(\n getTransceiverKey(SDPStreamMetadataPurpose.Usermedia, \"video\"),\n )?.sender;\n\n sender?.replaceTrack(track ?? null);\n\n this.pushNewLocalFeed(stream, SDPStreamMetadataPurpose.Screenshare, false);\n\n return true;\n } catch (err) {\n logger.error(\n `Call ${this.callId} setScreensharingEnabledWithoutMetadataSupport() failed to get screen-sharing stream:`,\n err,\n );\n return false;\n }\n } else {\n const track = this.localUsermediaStream?.getTracks().find((track) => track.kind === \"video\");\n const sender = this.transceivers.get(\n getTransceiverKey(SDPStreamMetadataPurpose.Usermedia, \"video\"),\n )?.sender;\n sender?.replaceTrack(track ?? null);\n\n this.client.getMediaHandler().stopScreensharingStream(this.localScreensharingStream!);\n this.deleteFeedByStream(this.localScreensharingStream!);\n\n return false;\n }\n }\n\n /**\n * Replaces/adds the tracks from the passed stream to the localUsermediaStream\n * @param stream - to use a replacement for the local usermedia stream\n */\n public async updateLocalUsermediaStream(\n stream: MediaStream,\n forceAudio = false,\n forceVideo = false,\n ): Promise {\n const callFeed = this.localUsermediaFeed!;\n const audioEnabled = forceAudio || (!callFeed.isAudioMuted() && !this.remoteOnHold);\n const videoEnabled = forceVideo || (!callFeed.isVideoMuted() && !this.remoteOnHold);\n logger.log(\n `Call ${this.callId} updateLocalUsermediaStream() running (streamId=${stream.id}, audio=${audioEnabled}, video=${videoEnabled})`,\n );\n setTracksEnabled(stream.getAudioTracks(), audioEnabled);\n setTracksEnabled(stream.getVideoTracks(), videoEnabled);\n\n // We want to keep the same stream id, so we replace the tracks rather\n // than the whole stream.\n\n // Firstly, we replace the tracks in our localUsermediaStream.\n for (const track of this.localUsermediaStream!.getTracks()) {\n this.localUsermediaStream!.removeTrack(track);\n track.stop();\n }\n for (const track of stream.getTracks()) {\n this.localUsermediaStream!.addTrack(track);\n }\n\n // Then replace the old tracks, if possible.\n for (const track of stream.getTracks()) {\n const tKey = getTransceiverKey(SDPStreamMetadataPurpose.Usermedia, track.kind);\n\n const transceiver = this.transceivers.get(tKey);\n const oldSender = transceiver?.sender;\n let added = false;\n if (oldSender) {\n try {\n logger.info(\n `Call ${this.callId} updateLocalUsermediaStream() replacing track (id=${track.id}, kind=${track.kind}, streamId=${stream.id}, streamPurpose=${callFeed.purpose})`,\n );\n await oldSender.replaceTrack(track);\n // Set the direction to indicate we're going to be sending.\n // This is only necessary in the cases where we're upgrading\n // the call to video after downgrading it.\n transceiver.direction = transceiver.direction === \"inactive\" ? \"sendonly\" : \"sendrecv\";\n added = true;\n } catch (error) {\n logger.warn(\n `Call ${this.callId} updateLocalUsermediaStream() replaceTrack failed: adding new transceiver instead`,\n error,\n );\n }\n }\n\n if (!added) {\n logger.info(\n `Call ${this.callId} updateLocalUsermediaStream() adding track to peer connection (id=${track.id}, kind=${track.kind}, streamId=${stream.id}, streamPurpose=${callFeed.purpose})`,\n );\n\n const newSender = this.peerConn!.addTrack(track, this.localUsermediaStream!);\n const newTransceiver = this.peerConn!.getTransceivers().find((t) => t.sender === newSender);\n if (newTransceiver) {\n this.transceivers.set(tKey, newTransceiver);\n } else {\n logger.warn(\n `Call ${this.callId} updateLocalUsermediaStream() couldn't find matching transceiver for newly added track!`,\n );\n }\n }\n }\n }\n\n /**\n * Set whether our outbound video should be muted or not.\n * @param muted - True to mute the outbound video.\n * @returns the new mute state\n */\n public async setLocalVideoMuted(muted: boolean): Promise {\n logger.log(`Call ${this.callId} setLocalVideoMuted() running ${muted}`);\n\n // if we were still thinking about stopping and removing the video\n // track: don't, because we want it back.\n if (!muted && this.stopVideoTrackTimer !== undefined) {\n clearTimeout(this.stopVideoTrackTimer);\n this.stopVideoTrackTimer = undefined;\n }\n\n if (!(await this.client.getMediaHandler().hasVideoDevice())) {\n return this.isLocalVideoMuted();\n }\n\n if (!this.hasUserMediaVideoSender && !muted) {\n this.localUsermediaFeed?.setAudioVideoMuted(null, muted);\n await this.upgradeCall(false, true);\n return this.isLocalVideoMuted();\n }\n\n // we may not have a video track - if not, re-request usermedia\n if (!muted && this.localUsermediaStream!.getVideoTracks().length === 0) {\n const stream = await this.client.getMediaHandler().getUserMediaStream(true, true);\n await this.updateLocalUsermediaStream(stream);\n }\n\n this.localUsermediaFeed?.setAudioVideoMuted(null, muted);\n\n this.updateMuteStatus();\n await this.sendMetadataUpdate();\n\n // if we're muting video, set a timeout to stop & remove the video track so we release\n // the camera. We wait a short time to do this because when we disable a track, WebRTC\n // will send black video for it. If we just stop and remove it straight away, the video\n // will just freeze which means that when we unmute video, the other side will briefly\n // get a static frame of us from before we muted. This way, the still frame is just black.\n // A very small delay is not always enough so the theory here is that it needs to be long\n // enough for WebRTC to encode a frame: 120ms should be long enough even if we're only\n // doing 10fps.\n if (muted) {\n this.stopVideoTrackTimer = setTimeout(() => {\n for (const t of this.localUsermediaStream!.getVideoTracks()) {\n t.stop();\n this.localUsermediaStream!.removeTrack(t);\n }\n }, 120);\n }\n\n return this.isLocalVideoMuted();\n }\n\n /**\n * Check if local video is muted.\n *\n * If there are multiple video tracks, all of the tracks need to be muted\n * for this to return true. This means if there are no video tracks, this will\n * return true.\n * @returns True if the local preview video is muted, else false\n * (including if the call is not set up yet).\n */\n public isLocalVideoMuted(): boolean {\n return this.localUsermediaFeed?.isVideoMuted() ?? false;\n }\n\n /**\n * Set whether the microphone should be muted or not.\n * @param muted - True to mute the mic.\n * @returns the new mute state\n */\n public async setMicrophoneMuted(muted: boolean): Promise {\n logger.log(`Call ${this.callId} setMicrophoneMuted() running ${muted}`);\n if (!(await this.client.getMediaHandler().hasAudioDevice())) {\n return this.isMicrophoneMuted();\n }\n\n if (!muted && (!this.hasUserMediaAudioSender || !this.hasLocalUserMediaAudioTrack)) {\n await this.upgradeCall(true, false);\n return this.isMicrophoneMuted();\n }\n this.localUsermediaFeed?.setAudioVideoMuted(muted, null);\n this.updateMuteStatus();\n await this.sendMetadataUpdate();\n return this.isMicrophoneMuted();\n }\n\n /**\n * Check if the microphone is muted.\n *\n * If there are multiple audio tracks, all of the tracks need to be muted\n * for this to return true. This means if there are no audio tracks, this will\n * return true.\n * @returns True if the mic is muted, else false (including if the call\n * is not set up yet).\n */\n public isMicrophoneMuted(): boolean {\n return this.localUsermediaFeed?.isAudioMuted() ?? false;\n }\n\n /**\n * @returns true if we have put the party on the other side of the call on hold\n * (that is, we are signalling to them that we are not listening)\n */\n public isRemoteOnHold(): boolean {\n return this.remoteOnHold;\n }\n\n public setRemoteOnHold(onHold: boolean): void {\n if (this.isRemoteOnHold() === onHold) return;\n this.remoteOnHold = onHold;\n\n for (const transceiver of this.peerConn!.getTransceivers()) {\n // We don't send hold music or anything so we're not actually\n // sending anything, but sendrecv is fairly standard for hold and\n // it makes it a lot easier to figure out who's put who on hold.\n transceiver.direction = onHold ? \"sendonly\" : \"sendrecv\";\n }\n this.updateMuteStatus();\n this.sendMetadataUpdate();\n\n this.emit(CallEvent.RemoteHoldUnhold, this.remoteOnHold, this);\n }\n\n /**\n * Indicates whether we are 'on hold' to the remote party (ie. if true,\n * they cannot hear us).\n * @returns true if the other party has put us on hold\n */\n public isLocalOnHold(): boolean {\n if (this.state !== CallState.Connected) return false;\n\n let callOnHold = true;\n\n // We consider a call to be on hold only if *all* the tracks are on hold\n // (is this the right thing to do?)\n for (const transceiver of this.peerConn!.getTransceivers()) {\n const trackOnHold = [\"inactive\", \"recvonly\"].includes(transceiver.currentDirection!);\n\n if (!trackOnHold) callOnHold = false;\n }\n\n return callOnHold;\n }\n\n /**\n * Sends a DTMF digit to the other party\n * @param digit - The digit (nb. string - '#' and '*' are dtmf too)\n */\n public sendDtmfDigit(digit: string): void {\n for (const sender of this.peerConn!.getSenders()) {\n if (sender.track?.kind === \"audio\" && sender.dtmf) {\n sender.dtmf.insertDTMF(digit);\n return;\n }\n }\n\n throw new Error(\"Unable to find a track to send DTMF on\");\n }\n\n private updateMuteStatus(): void {\n const micShouldBeMuted = this.isMicrophoneMuted() || this.remoteOnHold;\n const vidShouldBeMuted = this.isLocalVideoMuted() || this.remoteOnHold;\n\n logger.log(\n `Call ${this.callId} updateMuteStatus stream ${\n this.localUsermediaStream!.id\n } micShouldBeMuted ${micShouldBeMuted} vidShouldBeMuted ${vidShouldBeMuted}`,\n );\n\n setTracksEnabled(this.localUsermediaStream!.getAudioTracks(), !micShouldBeMuted);\n setTracksEnabled(this.localUsermediaStream!.getVideoTracks(), !vidShouldBeMuted);\n }\n\n public async sendMetadataUpdate(): Promise {\n await this.sendVoipEvent(EventType.CallSDPStreamMetadataChangedPrefix, {\n [SDPStreamMetadataKey]: this.getLocalSDPStreamMetadata(),\n });\n }\n\n private gotCallFeedsForInvite(callFeeds: CallFeed[], requestScreenshareFeed = false): void {\n if (this.successor) {\n this.successor.queueGotCallFeedsForAnswer(callFeeds);\n return;\n }\n if (this.callHasEnded()) {\n this.stopAllMedia();\n return;\n }\n\n for (const feed of callFeeds) {\n this.pushLocalFeed(feed);\n }\n\n if (requestScreenshareFeed) {\n this.peerConn!.addTransceiver(\"video\", {\n direction: \"recvonly\",\n });\n }\n\n this.state = CallState.CreateOffer;\n\n logger.debug(`Call ${this.callId} gotUserMediaForInvite() run`);\n // Now we wait for the negotiationneeded event\n }\n\n private async sendAnswer(): Promise {\n const answerContent = {\n answer: {\n sdp: this.peerConn!.localDescription!.sdp,\n // type is now deprecated as of Matrix VoIP v1, but\n // required to still be sent for backwards compat\n type: this.peerConn!.localDescription!.type,\n },\n [SDPStreamMetadataKey]: this.getLocalSDPStreamMetadata(true),\n } as MCallAnswer;\n\n answerContent.capabilities = {\n \"m.call.transferee\": this.client.supportsCallTransfer,\n \"m.call.dtmf\": false,\n };\n\n // We have just taken the local description from the peerConn which will\n // contain all the local candidates added so far, so we can discard any candidates\n // we had queued up because they'll be in the answer.\n const discardCount = this.discardDuplicateCandidates();\n logger.info(\n `Call ${this.callId} sendAnswer() discarding ${discardCount} candidates that will be sent in answer`,\n );\n\n try {\n await this.sendVoipEvent(EventType.CallAnswer, answerContent);\n // If this isn't the first time we've tried to send the answer,\n // we may have candidates queued up, so send them now.\n this.inviteOrAnswerSent = true;\n } catch (error) {\n // We've failed to answer: back to the ringing state\n this.state = CallState.Ringing;\n if (error instanceof MatrixError && error.event) this.client.cancelPendingEvent(error.event);\n\n let code = CallErrorCode.SendAnswer;\n let message = \"Failed to send answer\";\n if ((error).name == \"UnknownDeviceError\") {\n code = CallErrorCode.UnknownDevices;\n message = \"Unknown devices present in the room\";\n }\n this.emit(CallEvent.Error, new CallError(code, message, error), this);\n throw error;\n }\n\n // error handler re-throws so this won't happen on error, but\n // we don't want the same error handling on the candidate queue\n this.sendCandidateQueue();\n }\n\n private queueGotCallFeedsForAnswer(callFeeds: CallFeed[]): void {\n // Ensure only one negotiate/answer event is being processed at a time.\n if (this.responsePromiseChain) {\n this.responsePromiseChain = this.responsePromiseChain.then(() => this.gotCallFeedsForAnswer(callFeeds));\n } else {\n this.responsePromiseChain = this.gotCallFeedsForAnswer(callFeeds);\n }\n }\n\n // Enables DTX (discontinuous transmission) on the given session to reduce\n // bandwidth when transmitting silence\n private mungeSdp(description: RTCSessionDescriptionInit, mods: CodecParamsMod[]): void {\n // The only way to enable DTX at this time is through SDP munging\n const sdp = parseSdp(description.sdp!);\n\n sdp.media.forEach((media) => {\n const payloadTypeToCodecMap = new Map();\n const codecToPayloadTypeMap = new Map();\n for (const rtp of media.rtp) {\n payloadTypeToCodecMap.set(rtp.payload, rtp.codec);\n codecToPayloadTypeMap.set(rtp.codec, rtp.payload);\n }\n\n for (const mod of mods) {\n if (mod.mediaType !== media.type) continue;\n\n if (!codecToPayloadTypeMap.has(mod.codec)) {\n logger.info(\n `Call ${this.callId} mungeSdp() ignoring SDP modifications for ${mod.codec} as it's not present.`,\n );\n continue;\n }\n\n const extraConfig: string[] = [];\n if (mod.enableDtx !== undefined) {\n extraConfig.push(`usedtx=${mod.enableDtx ? \"1\" : \"0\"}`);\n }\n if (mod.maxAverageBitrate !== undefined) {\n extraConfig.push(`maxaveragebitrate=${mod.maxAverageBitrate}`);\n }\n\n let found = false;\n for (const fmtp of media.fmtp) {\n if (payloadTypeToCodecMap.get(fmtp.payload) === mod.codec) {\n found = true;\n fmtp.config += \";\" + extraConfig.join(\";\");\n }\n }\n if (!found) {\n media.fmtp.push({\n payload: codecToPayloadTypeMap.get(mod.codec)!,\n config: extraConfig.join(\";\"),\n });\n }\n }\n });\n description.sdp = writeSdp(sdp);\n }\n\n private async createOffer(): Promise {\n const offer = await this.peerConn!.createOffer();\n this.mungeSdp(offer, getCodecParamMods(this.isPtt));\n return offer;\n }\n\n private async createAnswer(): Promise {\n const answer = await this.peerConn!.createAnswer();\n this.mungeSdp(answer, getCodecParamMods(this.isPtt));\n return answer;\n }\n\n private async gotCallFeedsForAnswer(callFeeds: CallFeed[]): Promise {\n if (this.callHasEnded()) return;\n\n this.waitForLocalAVStream = false;\n\n for (const feed of callFeeds) {\n this.pushLocalFeed(feed);\n }\n\n this.state = CallState.CreateAnswer;\n\n let answer: RTCSessionDescriptionInit;\n try {\n this.getRidOfRTXCodecs();\n answer = await this.createAnswer();\n } catch (err) {\n logger.debug(`Call ${this.callId} gotCallFeedsForAnswer() failed to create answer: `, err);\n this.terminate(CallParty.Local, CallErrorCode.CreateAnswer, true);\n return;\n }\n\n try {\n await this.peerConn!.setLocalDescription(answer);\n\n // make sure we're still going\n if (this.callHasEnded()) return;\n\n this.state = CallState.Connecting;\n\n // Allow a short time for initial candidates to be gathered\n await new Promise((resolve) => {\n setTimeout(resolve, 200);\n });\n\n // make sure the call hasn't ended before we continue\n if (this.callHasEnded()) return;\n\n this.sendAnswer();\n } catch (err) {\n logger.debug(`Call ${this.callId} gotCallFeedsForAnswer() error setting local description!`, err);\n this.terminate(CallParty.Local, CallErrorCode.SetLocalDescription, true);\n return;\n }\n }\n\n /**\n * Internal\n */\n private gotLocalIceCandidate = (event: RTCPeerConnectionIceEvent): void => {\n if (event.candidate) {\n if (this.candidatesEnded) {\n logger.warn(\n `Call ${this.callId} gotLocalIceCandidate() got candidate after candidates have ended - ignoring!`,\n );\n return;\n }\n\n logger.debug(`Call ${this.callId} got local ICE ${event.candidate.sdpMid} ${event.candidate.candidate}`);\n\n if (this.callHasEnded()) return;\n\n // As with the offer, note we need to make a copy of this object, not\n // pass the original: that broke in Chrome ~m43.\n if (event.candidate.candidate === \"\") {\n this.queueCandidate(null);\n } else {\n this.queueCandidate(event.candidate);\n }\n }\n };\n\n private onIceGatheringStateChange = (event: Event): void => {\n logger.debug(\n `Call ${this.callId} onIceGatheringStateChange() ice gathering state changed to ${\n this.peerConn!.iceGatheringState\n }`,\n );\n if (this.peerConn?.iceGatheringState === \"complete\") {\n this.queueCandidate(null);\n }\n };\n\n public async onRemoteIceCandidatesReceived(ev: MatrixEvent): Promise {\n if (this.callHasEnded()) {\n //debuglog(\"Ignoring remote ICE candidate because call has ended\");\n return;\n }\n\n const content = ev.getContent();\n const candidates = content.candidates;\n if (!candidates) {\n logger.info(\n `Call ${this.callId} onRemoteIceCandidatesReceived() ignoring candidates event with no candidates!`,\n );\n return;\n }\n\n const fromPartyId = content.version === 0 ? null : content.party_id || null;\n\n if (this.opponentPartyId === undefined) {\n // we haven't picked an opponent yet so save the candidates\n if (fromPartyId) {\n logger.info(\n `Call ${this.callId} onRemoteIceCandidatesReceived() buffering ${candidates.length} candidates until we pick an opponent`,\n );\n const bufferedCandidates = this.remoteCandidateBuffer.get(fromPartyId) || [];\n bufferedCandidates.push(...candidates);\n this.remoteCandidateBuffer.set(fromPartyId, bufferedCandidates);\n }\n return;\n }\n\n if (!this.partyIdMatches(content)) {\n logger.info(\n `Call ${this.callId} onRemoteIceCandidatesReceived() ignoring candidates from party ID ${content.party_id}: we have chosen party ID ${this.opponentPartyId}`,\n );\n\n return;\n }\n\n await this.addIceCandidates(candidates);\n }\n\n /**\n * Used by MatrixClient.\n */\n public async onAnswerReceived(event: MatrixEvent): Promise {\n const content = event.getContent();\n logger.debug(`Call ${this.callId} onAnswerReceived() running (hangupParty=${content.party_id})`);\n\n if (this.callHasEnded()) {\n logger.debug(`Call ${this.callId} onAnswerReceived() ignoring answer because call has ended`);\n return;\n }\n\n if (this.opponentPartyId !== undefined) {\n logger.info(\n `Call ${this.callId} onAnswerReceived() ignoring answer from party ID ${content.party_id}: we already have an answer/reject from ${this.opponentPartyId}`,\n );\n return;\n }\n\n this.chooseOpponent(event);\n await this.addBufferedIceCandidates();\n\n this.state = CallState.Connecting;\n\n const sdpStreamMetadata = content[SDPStreamMetadataKey];\n if (sdpStreamMetadata) {\n this.updateRemoteSDPStreamMetadata(sdpStreamMetadata);\n } else {\n logger.warn(\n `Call ${this.callId} onAnswerReceived() did not get any SDPStreamMetadata! Can not send/receive multiple streams`,\n );\n }\n\n try {\n await this.peerConn!.setRemoteDescription(content.answer);\n } catch (e) {\n logger.debug(`Call ${this.callId} onAnswerReceived() failed to set remote description`, e);\n this.terminate(CallParty.Local, CallErrorCode.SetRemoteDescription, false);\n return;\n }\n\n // If the answer we selected has a party_id, send a select_answer event\n // We do this after setting the remote description since otherwise we'd block\n // call setup on it\n if (this.opponentPartyId !== null) {\n try {\n await this.sendVoipEvent(EventType.CallSelectAnswer, {\n selected_party_id: this.opponentPartyId,\n });\n } catch (err) {\n // This isn't fatal, and will just mean that if another party has raced to answer\n // the call, they won't know they got rejected, so we carry on & don't retry.\n logger.warn(`Call ${this.callId} onAnswerReceived() failed to send select_answer event`, err);\n }\n }\n }\n\n public async onSelectAnswerReceived(event: MatrixEvent): Promise {\n if (this.direction !== CallDirection.Inbound) {\n logger.warn(\n `Call ${this.callId} onSelectAnswerReceived() got select_answer for an outbound call: ignoring`,\n );\n return;\n }\n\n const selectedPartyId = event.getContent().selected_party_id;\n\n if (selectedPartyId === undefined || selectedPartyId === null) {\n logger.warn(\n `Call ${this.callId} onSelectAnswerReceived() got nonsensical select_answer with null/undefined selected_party_id: ignoring`,\n );\n return;\n }\n\n if (selectedPartyId !== this.ourPartyId) {\n logger.info(\n `Call ${this.callId} onSelectAnswerReceived() got select_answer for party ID ${selectedPartyId}: we are party ID ${this.ourPartyId}.`,\n );\n // The other party has picked somebody else's answer\n await this.terminate(CallParty.Remote, CallErrorCode.AnsweredElsewhere, true);\n }\n }\n\n public async onNegotiateReceived(event: MatrixEvent): Promise {\n const content = event.getContent();\n const description = content.description;\n if (!description || !description.sdp || !description.type) {\n logger.info(`Call ${this.callId} onNegotiateReceived() ignoring invalid m.call.negotiate event`);\n return;\n }\n // Politeness always follows the direction of the call: in a glare situation,\n // we pick either the inbound or outbound call, so one side will always be\n // inbound and one outbound\n const polite = this.direction === CallDirection.Inbound;\n\n // Here we follow the perfect negotiation logic from\n // https://developer.mozilla.org/en-US/docs/Web/API/WebRTC_API/Perfect_negotiation\n const offerCollision =\n description.type === \"offer\" && (this.makingOffer || this.peerConn!.signalingState !== \"stable\");\n\n this.ignoreOffer = !polite && offerCollision;\n if (this.ignoreOffer) {\n logger.info(\n `Call ${this.callId} onNegotiateReceived() ignoring colliding negotiate event because we're impolite`,\n );\n return;\n }\n\n const prevLocalOnHold = this.isLocalOnHold();\n\n const sdpStreamMetadata = content[SDPStreamMetadataKey];\n if (sdpStreamMetadata) {\n this.updateRemoteSDPStreamMetadata(sdpStreamMetadata);\n } else {\n logger.warn(\n `Call ${this.callId} onNegotiateReceived() received negotiation event without SDPStreamMetadata!`,\n );\n }\n\n try {\n await this.peerConn!.setRemoteDescription(description);\n\n if (description.type === \"offer\") {\n let answer: RTCSessionDescriptionInit;\n try {\n this.getRidOfRTXCodecs();\n answer = await this.createAnswer();\n } catch (err) {\n logger.debug(`Call ${this.callId} onNegotiateReceived() failed to create answer: `, err);\n this.terminate(CallParty.Local, CallErrorCode.CreateAnswer, true);\n return;\n }\n\n await this.peerConn!.setLocalDescription(answer);\n\n this.sendVoipEvent(EventType.CallNegotiate, {\n description: this.peerConn!.localDescription?.toJSON(),\n [SDPStreamMetadataKey]: this.getLocalSDPStreamMetadata(true),\n });\n }\n } catch (err) {\n logger.warn(`Call ${this.callId} onNegotiateReceived() failed to complete negotiation`, err);\n }\n\n const newLocalOnHold = this.isLocalOnHold();\n if (prevLocalOnHold !== newLocalOnHold) {\n this.emit(CallEvent.LocalHoldUnhold, newLocalOnHold, this);\n // also this one for backwards compat\n this.emit(CallEvent.HoldUnhold, newLocalOnHold);\n }\n }\n\n private updateRemoteSDPStreamMetadata(metadata: SDPStreamMetadata): void {\n this.remoteSDPStreamMetadata = utils.recursivelyAssign(this.remoteSDPStreamMetadata || {}, metadata, true);\n for (const feed of this.getRemoteFeeds()) {\n const streamId = feed.stream.id;\n const metadata = this.remoteSDPStreamMetadata![streamId];\n\n feed.setAudioVideoMuted(metadata?.audio_muted, metadata?.video_muted);\n feed.purpose = this.remoteSDPStreamMetadata![streamId]?.purpose;\n }\n }\n\n public onSDPStreamMetadataChangedReceived(event: MatrixEvent): void {\n const content = event.getContent();\n const metadata = content[SDPStreamMetadataKey];\n this.updateRemoteSDPStreamMetadata(metadata);\n }\n\n public async onAssertedIdentityReceived(event: MatrixEvent): Promise {\n const content = event.getContent();\n if (!content.asserted_identity) return;\n\n this.remoteAssertedIdentity = {\n id: content.asserted_identity.id,\n displayName: content.asserted_identity.display_name,\n };\n this.emit(CallEvent.AssertedIdentityChanged, this);\n }\n\n public callHasEnded(): boolean {\n // This exists as workaround to typescript trying to be clever and erroring\n // when putting if (this.state === CallState.Ended) return; twice in the same\n // function, even though that function is async.\n return this.state === CallState.Ended;\n }\n\n private queueGotLocalOffer(): void {\n // Ensure only one negotiate/answer event is being processed at a time.\n if (this.responsePromiseChain) {\n this.responsePromiseChain = this.responsePromiseChain.then(() => this.wrappedGotLocalOffer());\n } else {\n this.responsePromiseChain = this.wrappedGotLocalOffer();\n }\n }\n\n private async wrappedGotLocalOffer(): Promise {\n this.makingOffer = true;\n try {\n // XXX: in what situations do we believe gotLocalOffer actually throws? It appears\n // to handle most of its exceptions itself and terminate the call. I'm not entirely\n // sure it would ever throw, so I can't add a test for these lines.\n // Also the tense is different between \"gotLocalOffer\" and \"getLocalOfferFailed\" so\n // it's not entirely clear whether getLocalOfferFailed is just misnamed or whether\n // they've been cross-polinated somehow at some point.\n await this.gotLocalOffer();\n } catch (e) {\n this.getLocalOfferFailed(e as Error);\n return;\n } finally {\n this.makingOffer = false;\n }\n }\n\n private async gotLocalOffer(): Promise {\n logger.debug(`Call ${this.callId} gotLocalOffer() running`);\n\n if (this.callHasEnded()) {\n logger.debug(\n `Call ${this.callId} gotLocalOffer() ignoring newly created offer because the call has ended\"`,\n );\n return;\n }\n\n let offer: RTCSessionDescriptionInit;\n try {\n this.getRidOfRTXCodecs();\n offer = await this.createOffer();\n } catch (err) {\n logger.debug(`Call ${this.callId} gotLocalOffer() failed to create offer: `, err);\n this.terminate(CallParty.Local, CallErrorCode.CreateOffer, true);\n return;\n }\n\n try {\n await this.peerConn!.setLocalDescription(offer);\n } catch (err) {\n logger.debug(`Call ${this.callId} gotLocalOffer() error setting local description!`, err);\n this.terminate(CallParty.Local, CallErrorCode.SetLocalDescription, true);\n return;\n }\n\n if (this.peerConn!.iceGatheringState === \"gathering\") {\n // Allow a short time for initial candidates to be gathered\n await new Promise((resolve) => {\n setTimeout(resolve, 200);\n });\n }\n\n if (this.callHasEnded()) return;\n\n const eventType = this.state === CallState.CreateOffer ? EventType.CallInvite : EventType.CallNegotiate;\n\n const content = {\n lifetime: CALL_TIMEOUT_MS,\n } as MCallInviteNegotiate;\n\n if (eventType === EventType.CallInvite && this.invitee) {\n content.invitee = this.invitee;\n }\n\n // clunky because TypeScript can't follow the types through if we use an expression as the key\n if (this.state === CallState.CreateOffer) {\n content.offer = this.peerConn!.localDescription?.toJSON();\n } else {\n content.description = this.peerConn!.localDescription?.toJSON();\n }\n\n content.capabilities = {\n \"m.call.transferee\": this.client.supportsCallTransfer,\n \"m.call.dtmf\": false,\n };\n\n content[SDPStreamMetadataKey] = this.getLocalSDPStreamMetadata(true);\n\n // Get rid of any candidates waiting to be sent: they'll be included in the local\n // description we just got and will send in the offer.\n const discardCount = this.discardDuplicateCandidates();\n logger.info(\n `Call ${this.callId} gotLocalOffer() discarding ${discardCount} candidates that will be sent in offer`,\n );\n\n try {\n await this.sendVoipEvent(eventType, content);\n } catch (error) {\n logger.error(`Call ${this.callId} gotLocalOffer() failed to send invite`, error);\n if (error instanceof MatrixError && error.event) this.client.cancelPendingEvent(error.event);\n\n let code = CallErrorCode.SignallingFailed;\n let message = \"Signalling failed\";\n if (this.state === CallState.CreateOffer) {\n code = CallErrorCode.SendInvite;\n message = \"Failed to send invite\";\n }\n if ((error).name == \"UnknownDeviceError\") {\n code = CallErrorCode.UnknownDevices;\n message = \"Unknown devices present in the room\";\n }\n\n this.emit(CallEvent.Error, new CallError(code, message, error), this);\n this.terminate(CallParty.Local, code, false);\n\n // no need to carry on & send the candidate queue, but we also\n // don't want to rethrow the error\n return;\n }\n\n this.sendCandidateQueue();\n if (this.state === CallState.CreateOffer) {\n this.inviteOrAnswerSent = true;\n this.state = CallState.InviteSent;\n this.inviteTimeout = setTimeout(() => {\n this.inviteTimeout = undefined;\n if (this.state === CallState.InviteSent) {\n this.hangup(CallErrorCode.InviteTimeout, false);\n }\n }, CALL_TIMEOUT_MS);\n }\n }\n\n private getLocalOfferFailed = (err: Error): void => {\n logger.error(`Call ${this.callId} getLocalOfferFailed() running`, err);\n\n this.emit(\n CallEvent.Error,\n new CallError(CallErrorCode.LocalOfferFailed, \"Failed to get local offer!\", err),\n this,\n );\n this.terminate(CallParty.Local, CallErrorCode.LocalOfferFailed, false);\n };\n\n private getUserMediaFailed = (err: Error): void => {\n if (this.successor) {\n this.successor.getUserMediaFailed(err);\n return;\n }\n\n logger.warn(`Call ${this.callId} getUserMediaFailed() failed to get user media - ending call`, err);\n\n this.emit(\n CallEvent.Error,\n new CallError(\n CallErrorCode.NoUserMedia,\n \"Couldn't start capturing media! Is your microphone set up and \" + \"does this app have permission?\",\n err,\n ),\n this,\n );\n this.terminate(CallParty.Local, CallErrorCode.NoUserMedia, false);\n };\n\n private onIceConnectionStateChanged = (): void => {\n if (this.callHasEnded()) {\n return; // because ICE can still complete as we're ending the call\n }\n logger.debug(\n `Call ${this.callId} onIceConnectionStateChanged() running (state=${this.peerConn?.iceConnectionState})`,\n );\n\n // ideally we'd consider the call to be connected when we get media but\n // chrome doesn't implement any of the 'onstarted' events yet\n if ([\"connected\", \"completed\"].includes(this.peerConn?.iceConnectionState ?? \"\")) {\n clearTimeout(this.iceDisconnectedTimeout);\n this.iceDisconnectedTimeout = undefined;\n this.state = CallState.Connected;\n\n if (!this.callLengthInterval && !this.callStartTime) {\n this.callStartTime = Date.now();\n\n this.callLengthInterval = setInterval(() => {\n this.emit(CallEvent.LengthChanged, Math.round((Date.now() - this.callStartTime!) / 1000), this);\n }, CALL_LENGTH_INTERVAL);\n }\n } else if (this.peerConn?.iceConnectionState == \"failed\") {\n // Firefox for Android does not yet have support for restartIce()\n // (the types say it's always defined though, so we have to cast\n // to prevent typescript from warning).\n if (this.peerConn?.restartIce as (() => void) | null) {\n this.candidatesEnded = false;\n this.peerConn!.restartIce();\n } else {\n logger.info(\n `Call ${this.callId} onIceConnectionStateChanged() hanging up call (ICE failed and no ICE restart method)`,\n );\n this.hangup(CallErrorCode.IceFailed, false);\n }\n } else if (this.peerConn?.iceConnectionState == \"disconnected\") {\n this.iceDisconnectedTimeout = setTimeout(() => {\n logger.info(\n `Call ${this.callId} onIceConnectionStateChanged() hanging up call (ICE disconnected for too long)`,\n );\n this.hangup(CallErrorCode.IceFailed, false);\n }, ICE_DISCONNECTED_TIMEOUT);\n this.state = CallState.Connecting;\n }\n\n // In PTT mode, override feed status to muted when we lose connection to\n // the peer, since we don't want to block the line if they're not saying anything.\n // Experimenting in Chrome, this happens after 5 or 6 seconds, which is probably\n // fast enough.\n if (this.isPtt && [\"failed\", \"disconnected\"].includes(this.peerConn!.iceConnectionState)) {\n for (const feed of this.getRemoteFeeds()) {\n feed.setAudioVideoMuted(true, true);\n }\n }\n };\n\n private onSignallingStateChanged = (): void => {\n logger.debug(`Call ${this.callId} onSignallingStateChanged() running (state=${this.peerConn?.signalingState})`);\n };\n\n private onTrack = (ev: RTCTrackEvent): void => {\n if (ev.streams.length === 0) {\n logger.warn(\n `Call ${this.callId} onTrack() called with streamless track streamless (kind=${ev.track.kind})`,\n );\n return;\n }\n\n const stream = ev.streams[0];\n this.pushRemoteFeed(stream);\n\n if (!this.removeTrackListeners.has(stream)) {\n const onRemoveTrack = (): void => {\n if (stream.getTracks().length === 0) {\n logger.info(`Call ${this.callId} onTrack() removing track (streamId=${stream.id})`);\n this.deleteFeedByStream(stream);\n stream.removeEventListener(\"removetrack\", onRemoveTrack);\n this.removeTrackListeners.delete(stream);\n }\n };\n stream.addEventListener(\"removetrack\", onRemoveTrack);\n this.removeTrackListeners.set(stream, onRemoveTrack);\n }\n };\n\n private onDataChannel = (ev: RTCDataChannelEvent): void => {\n this.emit(CallEvent.DataChannel, ev.channel, this);\n };\n\n /**\n * This method removes all video/rtx codecs from screensharing video\n * transceivers. This is necessary since they can cause problems. Without\n * this the following steps should produce an error:\n * Chromium calls Firefox\n * Firefox answers\n * Firefox starts screen-sharing\n * Chromium starts screen-sharing\n * Call crashes for Chromium with:\n * [96685:23:0518/162603.933321:ERROR:webrtc_video_engine.cc(3296)] RTX codec (PT=97) mapped to PT=96 which is not in the codec list.\n * [96685:23:0518/162603.933377:ERROR:webrtc_video_engine.cc(1171)] GetChangedRecvParameters called without any video codecs.\n * [96685:23:0518/162603.933430:ERROR:sdp_offer_answer.cc(4302)] Failed to set local video description recv parameters for m-section with mid='2'. (INVALID_PARAMETER)\n */\n private getRidOfRTXCodecs(): void {\n // RTCRtpReceiver.getCapabilities and RTCRtpSender.getCapabilities don't seem to be supported on FF\n if (!RTCRtpReceiver.getCapabilities || !RTCRtpSender.getCapabilities) return;\n\n const recvCodecs = RTCRtpReceiver.getCapabilities(\"video\")!.codecs;\n const sendCodecs = RTCRtpSender.getCapabilities(\"video\")!.codecs;\n const codecs = [...sendCodecs, ...recvCodecs];\n\n for (const codec of codecs) {\n if (codec.mimeType === \"video/rtx\") {\n const rtxCodecIndex = codecs.indexOf(codec);\n codecs.splice(rtxCodecIndex, 1);\n }\n }\n\n const screenshareVideoTransceiver = this.transceivers.get(\n getTransceiverKey(SDPStreamMetadataPurpose.Screenshare, \"video\"),\n );\n if (screenshareVideoTransceiver) screenshareVideoTransceiver.setCodecPreferences(codecs);\n }\n\n private onNegotiationNeeded = async (): Promise => {\n logger.info(`Call ${this.callId} onNegotiationNeeded() negotiation is needed!`);\n\n if (this.state !== CallState.CreateOffer && this.opponentVersion === 0) {\n logger.info(\n `Call ${this.callId} onNegotiationNeeded() opponent does not support renegotiation: ignoring negotiationneeded event`,\n );\n return;\n }\n\n this.queueGotLocalOffer();\n };\n\n public onHangupReceived = (msg: MCallHangupReject): void => {\n logger.debug(`Call ${this.callId} onHangupReceived() running`);\n\n // party ID must match (our chosen partner hanging up the call) or be undefined (we haven't chosen\n // a partner yet but we're treating the hangup as a reject as per VoIP v0)\n if (this.partyIdMatches(msg) || this.state === CallState.Ringing) {\n // default reason is user_hangup\n this.terminate(CallParty.Remote, msg.reason || CallErrorCode.UserHangup, true);\n } else {\n logger.info(\n `Call ${this.callId} onHangupReceived() ignoring message from party ID ${msg.party_id}: our partner is ${this.opponentPartyId}`,\n );\n }\n };\n\n public onRejectReceived = (msg: MCallHangupReject): void => {\n logger.debug(`Call ${this.callId} onRejectReceived() running`);\n\n // No need to check party_id for reject because if we'd received either\n // an answer or reject, we wouldn't be in state InviteSent\n\n const shouldTerminate =\n // reject events also end the call if it's ringing: it's another of\n // our devices rejecting the call.\n [CallState.InviteSent, CallState.Ringing].includes(this.state) ||\n // also if we're in the init state and it's an inbound call, since\n // this means we just haven't entered the ringing state yet\n (this.state === CallState.Fledgling && this.direction === CallDirection.Inbound);\n\n if (shouldTerminate) {\n this.terminate(CallParty.Remote, msg.reason || CallErrorCode.UserHangup, true);\n } else {\n logger.debug(`Call ${this.callId} onRejectReceived() called in wrong state (state=${this.state})`);\n }\n };\n\n public onAnsweredElsewhere = (msg: MCallAnswer): void => {\n logger.debug(`Call ${this.callId} onAnsweredElsewhere() running`);\n this.terminate(CallParty.Remote, CallErrorCode.AnsweredElsewhere, true);\n };\n\n /**\n * @internal\n */\n private async sendVoipEvent(eventType: string, content: object): Promise {\n const realContent = Object.assign({}, content, {\n version: VOIP_PROTO_VERSION,\n call_id: this.callId,\n party_id: this.ourPartyId,\n conf_id: this.groupCallId,\n });\n\n if (this.opponentDeviceId) {\n const toDeviceSeq = this.toDeviceSeq++;\n const content = {\n ...realContent,\n device_id: this.client.deviceId,\n sender_session_id: this.client.getSessionId(),\n dest_session_id: this.opponentSessionId,\n seq: toDeviceSeq,\n [ToDeviceMessageId]: uuidv4(),\n };\n\n this.emit(\n CallEvent.SendVoipEvent,\n {\n type: \"toDevice\",\n eventType,\n userId: this.invitee || this.getOpponentMember()?.userId,\n opponentDeviceId: this.opponentDeviceId,\n content,\n },\n this,\n );\n\n const userId = this.invitee || this.getOpponentMember()!.userId;\n if (this.client.getUseE2eForGroupCall()) {\n if (!this.opponentDeviceInfo) {\n logger.warn(`Call ${this.callId} sendVoipEvent() failed: we do not have opponentDeviceInfo`);\n return;\n }\n\n await this.client.encryptAndSendToDevices(\n [\n {\n userId,\n deviceInfo: this.opponentDeviceInfo,\n },\n ],\n {\n type: eventType,\n content,\n },\n );\n } else {\n await this.client.sendToDevice(\n eventType,\n new Map([[userId, new Map([[this.opponentDeviceId, content]])]]),\n );\n }\n } else {\n this.emit(\n CallEvent.SendVoipEvent,\n {\n type: \"sendEvent\",\n eventType,\n roomId: this.roomId,\n content: realContent,\n userId: this.invitee || this.getOpponentMember()?.userId,\n },\n this,\n );\n\n await this.client.sendEvent(this.roomId!, eventType, realContent);\n }\n }\n\n /**\n * Queue a candidate to be sent\n * @param content - The candidate to queue up, or null if candidates have finished being generated\n * and end-of-candidates should be signalled\n */\n private queueCandidate(content: RTCIceCandidate | null): void {\n // We partially de-trickle candidates by waiting for `delay` before sending them\n // amalgamated, in order to avoid sending too many m.call.candidates events and hitting\n // rate limits in Matrix.\n // In practice, it'd be better to remove rate limits for m.call.*\n\n // N.B. this deliberately lets you queue and send blank candidates, which MSC2746\n // currently proposes as the way to indicate that candidate gathering is complete.\n // This will hopefully be changed to an explicit rather than implicit notification\n // shortly.\n if (content) {\n this.candidateSendQueue.push(content);\n } else {\n this.candidatesEnded = true;\n }\n\n // Don't send the ICE candidates yet if the call is in the ringing state: this\n // means we tried to pick (ie. started generating candidates) and then failed to\n // send the answer and went back to the ringing state. Queue up the candidates\n // to send if we successfully send the answer.\n // Equally don't send if we haven't yet sent the answer because we can send the\n // first batch of candidates along with the answer\n if (this.state === CallState.Ringing || !this.inviteOrAnswerSent) return;\n\n // MSC2746 recommends these values (can be quite long when calling because the\n // callee will need a while to answer the call)\n const delay = this.direction === CallDirection.Inbound ? 500 : 2000;\n\n if (this.candidateSendTries === 0) {\n setTimeout(() => {\n this.sendCandidateQueue();\n }, delay);\n }\n }\n\n // Discard all non-end-of-candidates messages\n // Return the number of candidate messages that were discarded.\n // Call this method before sending an invite or answer message\n private discardDuplicateCandidates(): number {\n let discardCount = 0;\n const newQueue: RTCIceCandidate[] = [];\n\n for (let i = 0; i < this.candidateSendQueue.length; i++) {\n const candidate = this.candidateSendQueue[i];\n if (candidate.candidate === \"\") {\n newQueue.push(candidate);\n } else {\n discardCount++;\n }\n }\n\n this.candidateSendQueue = newQueue;\n\n return discardCount;\n }\n\n /*\n * Transfers this call to another user\n */\n public async transfer(targetUserId: string): Promise {\n // Fetch the target user's global profile info: their room avatar / displayname\n // could be different in whatever room we share with them.\n const profileInfo = await this.client.getProfileInfo(targetUserId);\n\n const replacementId = genCallID();\n\n const body = {\n replacement_id: genCallID(),\n target_user: {\n id: targetUserId,\n display_name: profileInfo.displayname,\n avatar_url: profileInfo.avatar_url,\n },\n create_call: replacementId,\n } as MCallReplacesEvent;\n\n await this.sendVoipEvent(EventType.CallReplaces, body);\n\n await this.terminate(CallParty.Local, CallErrorCode.Transferred, true);\n }\n\n /*\n * Transfers this call to the target call, effectively 'joining' the\n * two calls (so the remote parties on each call are connected together).\n */\n public async transferToCall(transferTargetCall: MatrixCall): Promise {\n const targetUserId = transferTargetCall.getOpponentMember()?.userId;\n const targetProfileInfo = targetUserId ? await this.client.getProfileInfo(targetUserId) : undefined;\n const opponentUserId = this.getOpponentMember()?.userId;\n const transfereeProfileInfo = opponentUserId ? await this.client.getProfileInfo(opponentUserId) : undefined;\n\n const newCallId = genCallID();\n\n const bodyToTransferTarget = {\n // the replacements on each side have their own ID, and it's distinct from the\n // ID of the new call (but we can use the same function to generate it)\n replacement_id: genCallID(),\n target_user: {\n id: opponentUserId,\n display_name: transfereeProfileInfo?.displayname,\n avatar_url: transfereeProfileInfo?.avatar_url,\n },\n await_call: newCallId,\n } as MCallReplacesEvent;\n\n await transferTargetCall.sendVoipEvent(EventType.CallReplaces, bodyToTransferTarget);\n\n const bodyToTransferee = {\n replacement_id: genCallID(),\n target_user: {\n id: targetUserId,\n display_name: targetProfileInfo?.displayname,\n avatar_url: targetProfileInfo?.avatar_url,\n },\n create_call: newCallId,\n } as MCallReplacesEvent;\n\n await this.sendVoipEvent(EventType.CallReplaces, bodyToTransferee);\n\n await this.terminate(CallParty.Local, CallErrorCode.Transferred, true);\n await transferTargetCall.terminate(CallParty.Local, CallErrorCode.Transferred, true);\n }\n\n private async terminate(hangupParty: CallParty, hangupReason: CallErrorCode, shouldEmit: boolean): Promise {\n if (this.callHasEnded()) return;\n\n this.hangupParty = hangupParty;\n this.hangupReason = hangupReason;\n this.state = CallState.Ended;\n\n if (this.inviteTimeout) {\n clearTimeout(this.inviteTimeout);\n this.inviteTimeout = undefined;\n }\n if (this.iceDisconnectedTimeout !== undefined) {\n clearTimeout(this.iceDisconnectedTimeout);\n this.iceDisconnectedTimeout = undefined;\n }\n if (this.callLengthInterval) {\n clearInterval(this.callLengthInterval);\n this.callLengthInterval = undefined;\n }\n if (this.stopVideoTrackTimer !== undefined) {\n clearTimeout(this.stopVideoTrackTimer);\n this.stopVideoTrackTimer = undefined;\n }\n\n for (const [stream, listener] of this.removeTrackListeners) {\n stream.removeEventListener(\"removetrack\", listener);\n }\n this.removeTrackListeners.clear();\n\n this.callStatsAtEnd = await this.collectCallStats();\n\n // Order is important here: first we stopAllMedia() and only then we can deleteAllFeeds()\n this.stopAllMedia();\n this.deleteAllFeeds();\n\n if (this.peerConn && this.peerConn.signalingState !== \"closed\") {\n this.peerConn.close();\n }\n this.stats?.removeStatsReportGatherer(this.callId);\n\n if (shouldEmit) {\n this.emit(CallEvent.Hangup, this);\n }\n\n this.client.callEventHandler!.calls.delete(this.callId);\n }\n\n private stopAllMedia(): void {\n logger.debug(`Call ${this.callId} stopAllMedia() running`);\n\n for (const feed of this.feeds) {\n // Slightly awkward as local feed need to go via the correct method on\n // the MediaHandler so they get removed from MediaHandler (remote tracks\n // don't)\n // NB. We clone local streams when passing them to individual calls in a group\n // call, so we can (and should) stop the clones once we no longer need them:\n // the other clones will continue fine.\n if (feed.isLocal() && feed.purpose === SDPStreamMetadataPurpose.Usermedia) {\n this.client.getMediaHandler().stopUserMediaStream(feed.stream);\n } else if (feed.isLocal() && feed.purpose === SDPStreamMetadataPurpose.Screenshare) {\n this.client.getMediaHandler().stopScreensharingStream(feed.stream);\n } else if (!feed.isLocal()) {\n logger.debug(`Call ${this.callId} stopAllMedia() stopping stream (streamId=${feed.stream.id})`);\n for (const track of feed.stream.getTracks()) {\n track.stop();\n }\n }\n }\n }\n\n private checkForErrorListener(): void {\n if (this.listeners(EventEmitterEvents.Error).length === 0) {\n throw new Error(\"You MUST attach an error listener using call.on('error', function() {})\");\n }\n }\n\n private async sendCandidateQueue(): Promise {\n if (this.candidateSendQueue.length === 0 || this.callHasEnded()) {\n return;\n }\n\n const candidates = this.candidateSendQueue;\n this.candidateSendQueue = [];\n ++this.candidateSendTries;\n const content = { candidates: candidates.map((candidate) => candidate.toJSON()) };\n if (this.candidatesEnded) {\n // If there are no more candidates, signal this by adding an empty string candidate\n content.candidates.push({\n candidate: \"\",\n });\n }\n logger.debug(`Call ${this.callId} sendCandidateQueue() attempting to send ${candidates.length} candidates`);\n try {\n await this.sendVoipEvent(EventType.CallCandidates, content);\n // reset our retry count if we have successfully sent our candidates\n // otherwise queueCandidate() will refuse to try to flush the queue\n this.candidateSendTries = 0;\n\n // Try to send candidates again just in case we received more candidates while sending.\n this.sendCandidateQueue();\n } catch (error) {\n // don't retry this event: we'll send another one later as we might\n // have more candidates by then.\n if (error instanceof MatrixError && error.event) this.client.cancelPendingEvent(error.event);\n\n // put all the candidates we failed to send back in the queue\n this.candidateSendQueue.push(...candidates);\n\n if (this.candidateSendTries > 5) {\n logger.debug(\n `Call ${this.callId} sendCandidateQueue() failed to send candidates on attempt ${this.candidateSendTries}. Giving up on this call.`,\n error,\n );\n\n const code = CallErrorCode.SignallingFailed;\n const message = \"Signalling failed\";\n\n this.emit(CallEvent.Error, new CallError(code, message, error), this);\n this.hangup(code, false);\n\n return;\n }\n\n const delayMs = 500 * Math.pow(2, this.candidateSendTries);\n ++this.candidateSendTries;\n logger.debug(\n `Call ${this.callId} sendCandidateQueue() failed to send candidates. Retrying in ${delayMs}ms`,\n error,\n );\n setTimeout(() => {\n this.sendCandidateQueue();\n }, delayMs);\n }\n }\n\n /**\n * Place a call to this room.\n * @throws if you have not specified a listener for 'error' events.\n * @throws if have passed audio=false.\n */\n public async placeCall(audio: boolean, video: boolean): Promise {\n if (!audio) {\n throw new Error(\"You CANNOT start a call without audio\");\n }\n this.state = CallState.WaitLocalMedia;\n\n try {\n const stream = await this.client.getMediaHandler().getUserMediaStream(audio, video);\n\n // make sure all the tracks are enabled (same as pushNewLocalFeed -\n // we probably ought to just have one code path for adding streams)\n setTracksEnabled(stream.getAudioTracks(), true);\n setTracksEnabled(stream.getVideoTracks(), true);\n\n const callFeed = new CallFeed({\n client: this.client,\n roomId: this.roomId,\n userId: this.client.getUserId()!,\n deviceId: this.client.getDeviceId() ?? undefined,\n stream,\n purpose: SDPStreamMetadataPurpose.Usermedia,\n audioMuted: false,\n videoMuted: false,\n });\n await this.placeCallWithCallFeeds([callFeed]);\n } catch (e) {\n this.getUserMediaFailed(e);\n return;\n }\n }\n\n /**\n * Place a call to this room with call feed.\n * @param callFeeds - to use\n * @throws if you have not specified a listener for 'error' events.\n * @throws if have passed audio=false.\n */\n public async placeCallWithCallFeeds(callFeeds: CallFeed[], requestScreenshareFeed = false): Promise {\n this.checkForErrorListener();\n this.direction = CallDirection.Outbound;\n\n await this.initOpponentCrypto();\n\n // XXX Find a better way to do this\n this.client.callEventHandler!.calls.set(this.callId, this);\n\n // make sure we have valid turn creds. Unless something's gone wrong, it should\n // poll and keep the credentials valid so this should be instant.\n const haveTurnCreds = await this.client.checkTurnServers();\n if (!haveTurnCreds) {\n logger.warn(\n `Call ${this.callId} placeCallWithCallFeeds() failed to get TURN credentials! Proceeding with call anyway...`,\n );\n }\n\n // create the peer connection now so it can be gathering candidates while we get user\n // media (assuming a candidate pool size is configured)\n this.peerConn = this.createPeerConnection();\n this.gotCallFeedsForInvite(callFeeds, requestScreenshareFeed);\n }\n\n private createPeerConnection(): RTCPeerConnection {\n const pc = new window.RTCPeerConnection({\n iceTransportPolicy: this.forceTURN ? \"relay\" : undefined,\n iceServers: this.turnServers,\n iceCandidatePoolSize: this.client.iceCandidatePoolSize,\n bundlePolicy: \"max-bundle\",\n });\n\n // 'connectionstatechange' would be better, but firefox doesn't implement that.\n pc.addEventListener(\"iceconnectionstatechange\", this.onIceConnectionStateChanged);\n pc.addEventListener(\"signalingstatechange\", this.onSignallingStateChanged);\n pc.addEventListener(\"icecandidate\", this.gotLocalIceCandidate);\n pc.addEventListener(\"icegatheringstatechange\", this.onIceGatheringStateChange);\n pc.addEventListener(\"track\", this.onTrack);\n pc.addEventListener(\"negotiationneeded\", this.onNegotiationNeeded);\n pc.addEventListener(\"datachannel\", this.onDataChannel);\n\n this.stats?.addStatsReportGatherer(this.callId, \"unknown\", pc);\n return pc;\n }\n\n private partyIdMatches(msg: MCallBase): boolean {\n // They must either match or both be absent (in which case opponentPartyId will be null)\n // Also we ignore party IDs on the invite/offer if the version is 0, so we must do the same\n // here and use null if the version is 0 (woe betide any opponent sending messages in the\n // same call with different versions)\n const msgPartyId = msg.version === 0 ? null : msg.party_id || null;\n return msgPartyId === this.opponentPartyId;\n }\n\n // Commits to an opponent for the call\n // ev: An invite or answer event\n private chooseOpponent(ev: MatrixEvent): void {\n // I choo-choo-choose you\n const msg = ev.getContent();\n\n logger.debug(`Call ${this.callId} chooseOpponent() running (partyId=${msg.party_id})`);\n\n this.opponentVersion = msg.version;\n if (this.opponentVersion === 0) {\n // set to null to indicate that we've chosen an opponent, but because\n // they're v0 they have no party ID (even if they sent one, we're ignoring it)\n this.opponentPartyId = null;\n } else {\n // set to their party ID, or if they're naughty and didn't send one despite\n // not being v0, set it to null to indicate we picked an opponent with no\n // party ID\n this.opponentPartyId = msg.party_id || null;\n }\n this.opponentCaps = msg.capabilities || ({} as CallCapabilities);\n this.opponentMember = this.client.getRoom(this.roomId)!.getMember(ev.getSender()!) ?? undefined;\n }\n\n private async addBufferedIceCandidates(): Promise {\n const bufferedCandidates = this.remoteCandidateBuffer.get(this.opponentPartyId!);\n if (bufferedCandidates) {\n logger.info(\n `Call ${this.callId} addBufferedIceCandidates() adding ${bufferedCandidates.length} buffered candidates for opponent ${this.opponentPartyId}`,\n );\n await this.addIceCandidates(bufferedCandidates);\n }\n this.remoteCandidateBuffer.clear();\n }\n\n private async addIceCandidates(candidates: RTCIceCandidate[]): Promise {\n for (const candidate of candidates) {\n if (\n (candidate.sdpMid === null || candidate.sdpMid === undefined) &&\n (candidate.sdpMLineIndex === null || candidate.sdpMLineIndex === undefined)\n ) {\n logger.debug(`Call ${this.callId} addIceCandidates() got remote ICE end-of-candidates`);\n } else {\n logger.debug(\n `Call ${this.callId} addIceCandidates() got remote ICE candidate (sdpMid=${candidate.sdpMid}, candidate=${candidate.candidate})`,\n );\n }\n\n try {\n await this.peerConn!.addIceCandidate(candidate);\n } catch (err) {\n if (!this.ignoreOffer) {\n logger.info(`Call ${this.callId} addIceCandidates() failed to add remote ICE candidate`, err);\n }\n }\n }\n }\n\n public get hasPeerConnection(): boolean {\n return Boolean(this.peerConn);\n }\n\n public initStats(stats: GroupCallStats, peerId = \"unknown\"): void {\n this.stats = stats;\n this.stats.start();\n }\n}\n\nexport function setTracksEnabled(tracks: Array, enabled: boolean): void {\n for (const track of tracks) {\n track.enabled = enabled;\n }\n}\n\nexport function supportsMatrixCall(): boolean {\n // typeof prevents Node from erroring on an undefined reference\n if (typeof window === \"undefined\" || typeof document === \"undefined\") {\n // NB. We don't log here as apps try to create a call object as a test for\n // whether calls are supported, so we shouldn't fill the logs up.\n return false;\n }\n\n // Firefox throws on so little as accessing the RTCPeerConnection when operating in a secure mode.\n // There's some information at https://bugzilla.mozilla.org/show_bug.cgi?id=1542616 though the concern\n // is that the browser throwing a SecurityError will brick the client creation process.\n try {\n const supported = Boolean(\n window.RTCPeerConnection ||\n window.RTCSessionDescription ||\n window.RTCIceCandidate ||\n navigator.mediaDevices,\n );\n if (!supported) {\n /* istanbul ignore if */ // Adds a lot of noise to test runs, so disable logging there.\n if (process.env.NODE_ENV !== \"test\") {\n logger.error(\"WebRTC is not supported in this browser / environment\");\n }\n return false;\n }\n } catch (e) {\n logger.error(\"Exception thrown when trying to access WebRTC\", e);\n return false;\n }\n\n return true;\n}\n\n/**\n * DEPRECATED\n * Use client.createCall()\n *\n * Create a new Matrix call for the browser.\n * @param client - The client instance to use.\n * @param roomId - The room the call is in.\n * @param options - DEPRECATED optional options map.\n * @returns the call or null if the browser doesn't support calling.\n */\nexport function createNewMatrixCall(\n client: MatrixClient,\n roomId: string,\n options?: Pick,\n): MatrixCall | null {\n if (!supportsMatrixCall()) return null;\n\n const optionsForceTURN = options ? options.forceTURN : false;\n\n const opts: CallOpts = {\n client: client,\n roomId: roomId,\n invitee: options?.invitee,\n turnServers: client.getTurnServers(),\n // call level options\n forceTURN: client.forceTURN || optionsForceTURN,\n opponentDeviceId: options?.opponentDeviceId,\n opponentSessionId: options?.opponentSessionId,\n groupCallId: options?.groupCallId,\n };\n const call = new MatrixCall(opts);\n\n client.reEmitter.reEmit(call, Object.values(CallEvent));\n\n return call;\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts deleted file mode 100644 index 249a518..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts +++ /dev/null @@ -1,37 +0,0 @@ -import { MatrixEvent } from "../models/event"; -import { MatrixCall } from "./call"; -import { MatrixClient } from "../client"; -export declare enum CallEventHandlerEvent { - Incoming = "Call.incoming" -} -export type CallEventHandlerEventHandlerMap = { - /** - * Fires whenever an incoming call arrives. - * @param call - The incoming call. - * @example - * ``` - * matrixClient.on("Call.incoming", function(call){ - * call.answer(); // auto-answer - * }); - * ``` - */ - [CallEventHandlerEvent.Incoming]: (call: MatrixCall) => void; -}; -export declare class CallEventHandler { - calls: Map; - callEventBuffer: MatrixEvent[]; - nextSeqByCall: Map; - toDeviceEventBuffers: Map>; - private client; - private candidateEventsByCall; - private eventBufferPromiseChain?; - constructor(client: MatrixClient); - start(): void; - stop(): void; - private onSync; - private evaluateEventBuffer; - private onRoomTimeline; - private onToDeviceEvent; - private handleCallEvent; -} -//# sourceMappingURL=callEventHandler.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts.map deleted file mode 100644 index 88bf9a3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"callEventHandler.d.ts","sourceRoot":"","sources":["../../src/webrtc/callEventHandler.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EAA2E,UAAU,EAAE,MAAM,QAAQ,CAAC;AAE7G,OAAO,EAAe,YAAY,EAAE,MAAM,WAAW,CAAC;AAStD,oBAAY,qBAAqB;IAC7B,QAAQ,kBAAkB;CAC7B;AAED,MAAM,MAAM,+BAA+B,GAAG;IAC1C;;;;;;;;;OASG;IACH,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,CAAC;CAChE,CAAC;AAEF,qBAAa,gBAAgB;IAElB,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAC/B,eAAe,EAAE,WAAW,EAAE,CAAC;IAC/B,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IAC/C,oBAAoB,EAAE,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC,CAAa;IAEzE,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,qBAAqB,CAAkC;IAC/D,OAAO,CAAC,uBAAuB,CAAC,CAAgB;gBAE7B,MAAM,EAAE,YAAY;IAehC,KAAK,IAAI,IAAI;IAMb,IAAI,IAAI,IAAI;IAMnB,OAAO,CAAC,MAAM,CAaZ;YAEY,mBAAmB;IAsCjC,OAAO,CAAC,cAAc,CAEpB;IAEF,OAAO,CAAC,eAAe,CA+CrB;YAEY,eAAe;CAyOhC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js deleted file mode 100644 index 5e3c242..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js +++ /dev/null @@ -1,347 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.CallEventHandlerEvent = exports.CallEventHandler = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _logger = require("../logger"); -var _call = require("./call"); -var _event = require("../@types/event"); -var _client = require("../client"); -var _groupCall3 = require("./groupCall"); -var _room = require("../models/room"); -/* -Copyright 2020 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -// Don't ring unless we'd be ringing for at least 3 seconds: the user needs some -// time to press the 'accept' button -const RING_GRACE_PERIOD = 3000; -let CallEventHandlerEvent; -exports.CallEventHandlerEvent = CallEventHandlerEvent; -(function (CallEventHandlerEvent) { - CallEventHandlerEvent["Incoming"] = "Call.incoming"; -})(CallEventHandlerEvent || (exports.CallEventHandlerEvent = CallEventHandlerEvent = {})); -class CallEventHandler { - // XXX: Most of these are only public because of the tests - - constructor(client) { - (0, _defineProperty2.default)(this, "calls", void 0); - (0, _defineProperty2.default)(this, "callEventBuffer", void 0); - (0, _defineProperty2.default)(this, "nextSeqByCall", new Map()); - (0, _defineProperty2.default)(this, "toDeviceEventBuffers", new Map()); - (0, _defineProperty2.default)(this, "client", void 0); - (0, _defineProperty2.default)(this, "candidateEventsByCall", void 0); - (0, _defineProperty2.default)(this, "eventBufferPromiseChain", void 0); - (0, _defineProperty2.default)(this, "onSync", () => { - // Process the current event buffer and start queuing into a new one. - const currentEventBuffer = this.callEventBuffer; - this.callEventBuffer = []; - - // Ensure correct ordering by only processing this queue after the previous one has finished processing - if (this.eventBufferPromiseChain) { - this.eventBufferPromiseChain = this.eventBufferPromiseChain.then(() => this.evaluateEventBuffer(currentEventBuffer)); - } else { - this.eventBufferPromiseChain = this.evaluateEventBuffer(currentEventBuffer); - } - }); - (0, _defineProperty2.default)(this, "onRoomTimeline", event => { - this.callEventBuffer.push(event); - }); - (0, _defineProperty2.default)(this, "onToDeviceEvent", event => { - const content = event.getContent(); - if (!content.call_id) { - this.callEventBuffer.push(event); - return; - } - if (!this.nextSeqByCall.has(content.call_id)) { - this.nextSeqByCall.set(content.call_id, 0); - } - if (content.seq === undefined) { - this.callEventBuffer.push(event); - return; - } - const nextSeq = this.nextSeqByCall.get(content.call_id) || 0; - if (content.seq !== nextSeq) { - if (!this.toDeviceEventBuffers.has(content.call_id)) { - this.toDeviceEventBuffers.set(content.call_id, []); - } - const buffer = this.toDeviceEventBuffers.get(content.call_id); - const index = buffer.findIndex(e => e.getContent().seq > content.seq); - if (index === -1) { - buffer.push(event); - } else { - buffer.splice(index, 0, event); - } - } else { - const callId = content.call_id; - this.callEventBuffer.push(event); - this.nextSeqByCall.set(callId, content.seq + 1); - const buffer = this.toDeviceEventBuffers.get(callId); - let nextEvent = buffer && buffer.shift(); - while (nextEvent && nextEvent.getContent().seq === this.nextSeqByCall.get(callId)) { - this.callEventBuffer.push(nextEvent); - this.nextSeqByCall.set(callId, nextEvent.getContent().seq + 1); - nextEvent = buffer.shift(); - } - } - }); - this.client = client; - this.calls = new Map(); - // The sync code always emits one event at a time, so it will patiently - // wait for us to finish processing a call invite before delivering the - // next event, even if that next event is a hangup. We therefore accumulate - // all our call events and then process them on the 'sync' event, ie. - // each time a sync has completed. This way, we can avoid emitting incoming - // call events if we get both the invite and answer/hangup in the same sync. - // This happens quite often, eg. replaying sync from storage, catchup sync - // after loading and after we've been offline for a bit. - this.callEventBuffer = []; - this.candidateEventsByCall = new Map(); - } - start() { - this.client.on(_client.ClientEvent.Sync, this.onSync); - this.client.on(_room.RoomEvent.Timeline, this.onRoomTimeline); - this.client.on(_client.ClientEvent.ToDeviceEvent, this.onToDeviceEvent); - } - stop() { - this.client.removeListener(_client.ClientEvent.Sync, this.onSync); - this.client.removeListener(_room.RoomEvent.Timeline, this.onRoomTimeline); - this.client.removeListener(_client.ClientEvent.ToDeviceEvent, this.onToDeviceEvent); - } - async evaluateEventBuffer(eventBuffer) { - await Promise.all(eventBuffer.map(event => this.client.decryptEventIfNeeded(event))); - const callEvents = eventBuffer.filter(event => { - const eventType = event.getType(); - return eventType.startsWith("m.call.") || eventType.startsWith("org.matrix.call."); - }); - const ignoreCallIds = new Set(); - - // inspect the buffer and mark all calls which have been answered - // or hung up before passing them to the call event handler. - for (const event of callEvents) { - const eventType = event.getType(); - if (eventType === _event.EventType.CallAnswer || eventType === _event.EventType.CallHangup) { - ignoreCallIds.add(event.getContent().call_id); - } - } - - // Process call events in the order that they were received - for (const event of callEvents) { - const eventType = event.getType(); - const callId = event.getContent().call_id; - if (eventType === _event.EventType.CallInvite && ignoreCallIds.has(callId)) { - // This call has previously been answered or hung up: ignore it - continue; - } - try { - await this.handleCallEvent(event); - } catch (e) { - _logger.logger.error("CallEventHandler evaluateEventBuffer() caught exception handling call event", e); - } - } - } - async handleCallEvent(event) { - var _getGroupCallById, _getGroupCallById$roo; - this.client.emit(_client.ClientEvent.ReceivedVoipEvent, event); - const content = event.getContent(); - const callRoomId = event.getRoomId() || ((_getGroupCallById = this.client.groupCallEventHandler.getGroupCallById(content.conf_id)) === null || _getGroupCallById === void 0 ? void 0 : (_getGroupCallById$roo = _getGroupCallById.room) === null || _getGroupCallById$roo === void 0 ? void 0 : _getGroupCallById$roo.roomId); - const groupCallId = content.conf_id; - const type = event.getType(); - const senderId = event.getSender(); - let call = content.call_id ? this.calls.get(content.call_id) : undefined; - let opponentDeviceId; - let groupCall; - if (groupCallId) { - groupCall = this.client.groupCallEventHandler.getGroupCallById(groupCallId); - if (!groupCall) { - _logger.logger.warn(`CallEventHandler handleCallEvent() could not find a group call - ignoring event (groupCallId=${groupCallId}, type=${type})`); - return; - } - opponentDeviceId = content.device_id; - if (!opponentDeviceId) { - _logger.logger.warn(`CallEventHandler handleCallEvent() could not find a device id - ignoring event (senderId=${senderId})`); - groupCall.emit(_groupCall3.GroupCallEvent.Error, new _groupCall3.GroupCallUnknownDeviceError(senderId)); - return; - } - if (content.dest_session_id !== this.client.getSessionId()) { - _logger.logger.warn("CallEventHandler handleCallEvent() call event does not match current session id - ignoring"); - return; - } - } - const weSentTheEvent = senderId === this.client.credentials.userId && (opponentDeviceId === undefined || opponentDeviceId === this.client.getDeviceId()); - if (!callRoomId) return; - if (type === _event.EventType.CallInvite) { - var _this$client$getTurnS, _createNewMatrixCall, _groupCall; - // ignore invites you send - if (weSentTheEvent) return; - // expired call - if (event.getLocalAge() > content.lifetime - RING_GRACE_PERIOD) return; - // stale/old invite event - if (call && call.state === _call.CallState.Ended) return; - if (call) { - _logger.logger.warn(`CallEventHandler handleCallEvent() already has a call but got an invite - clobbering (callId=${content.call_id})`); - } - if (content.invitee && content.invitee !== this.client.getUserId()) { - return; // This invite was meant for another user in the room - } - - const timeUntilTurnCresExpire = ((_this$client$getTurnS = this.client.getTurnServersExpiry()) !== null && _this$client$getTurnS !== void 0 ? _this$client$getTurnS : 0) - Date.now(); - _logger.logger.info("CallEventHandler handleCallEvent() current turn creds expire in " + timeUntilTurnCresExpire + " ms"); - call = (_createNewMatrixCall = (0, _call.createNewMatrixCall)(this.client, callRoomId, { - forceTURN: this.client.forceTURN, - opponentDeviceId, - groupCallId, - opponentSessionId: content.sender_session_id - })) !== null && _createNewMatrixCall !== void 0 ? _createNewMatrixCall : undefined; - if (!call) { - _logger.logger.log(`CallEventHandler handleCallEvent() this client does not support WebRTC (callId=${content.call_id})`); - // don't hang up the call: there could be other clients - // connected that do support WebRTC and declining the - // the call on their behalf would be really annoying. - return; - } - call.callId = content.call_id; - const stats = (_groupCall = groupCall) === null || _groupCall === void 0 ? void 0 : _groupCall.getGroupCallStats(); - if (stats) { - call.initStats(stats); - } - try { - await call.initWithInvite(event); - } catch (e) { - if (e instanceof _call.CallError) { - if (e.code === _groupCall3.GroupCallErrorCode.UnknownDevice) { - var _groupCall2; - (_groupCall2 = groupCall) === null || _groupCall2 === void 0 ? void 0 : _groupCall2.emit(_groupCall3.GroupCallEvent.Error, e); - } else { - _logger.logger.error(e); - } - } - } - this.calls.set(call.callId, call); - - // if we stashed candidate events for that call ID, play them back now - if (this.candidateEventsByCall.get(call.callId)) { - for (const ev of this.candidateEventsByCall.get(call.callId)) { - call.onRemoteIceCandidatesReceived(ev); - } - } - - // Were we trying to call that user (room)? - let existingCall; - for (const thisCall of this.calls.values()) { - var _call$getOpponentMemb; - const isCalling = [_call.CallState.WaitLocalMedia, _call.CallState.CreateOffer, _call.CallState.InviteSent].includes(thisCall.state); - if (call.roomId === thisCall.roomId && thisCall.direction === _call.CallDirection.Outbound && ((_call$getOpponentMemb = call.getOpponentMember()) === null || _call$getOpponentMemb === void 0 ? void 0 : _call$getOpponentMemb.userId) === thisCall.invitee && isCalling) { - existingCall = thisCall; - break; - } - } - if (existingCall) { - if (existingCall.callId > call.callId) { - _logger.logger.log(`CallEventHandler handleCallEvent() detected glare - answering incoming call and canceling outgoing call (incomingId=${call.callId}, outgoingId=${existingCall.callId})`); - existingCall.replacedBy(call); - } else { - _logger.logger.log(`CallEventHandler handleCallEvent() detected glare - hanging up incoming call (incomingId=${call.callId}, outgoingId=${existingCall.callId})`); - call.hangup(_call.CallErrorCode.Replaced, true); - } - } else { - this.client.emit(CallEventHandlerEvent.Incoming, call); - } - return; - } else if (type === _event.EventType.CallCandidates) { - if (weSentTheEvent) return; - if (!call) { - // store the candidates; we may get a call eventually. - if (!this.candidateEventsByCall.has(content.call_id)) { - this.candidateEventsByCall.set(content.call_id, []); - } - this.candidateEventsByCall.get(content.call_id).push(event); - } else { - call.onRemoteIceCandidatesReceived(event); - } - return; - } else if ([_event.EventType.CallHangup, _event.EventType.CallReject].includes(type)) { - // Note that we also observe our own hangups here so we can see - // if we've already rejected a call that would otherwise be valid - if (!call) { - var _createNewMatrixCall2; - // if not live, store the fact that the call has ended because - // we're probably getting events backwards so - // the hangup will come before the invite - call = (_createNewMatrixCall2 = (0, _call.createNewMatrixCall)(this.client, callRoomId, { - opponentDeviceId, - opponentSessionId: content.sender_session_id - })) !== null && _createNewMatrixCall2 !== void 0 ? _createNewMatrixCall2 : undefined; - if (call) { - call.callId = content.call_id; - call.initWithHangup(event); - this.calls.set(content.call_id, call); - } - } else { - if (call.state !== _call.CallState.Ended) { - if (type === _event.EventType.CallHangup) { - call.onHangupReceived(content); - } else { - call.onRejectReceived(content); - } - - // @ts-expect-error typescript thinks the state can't be 'ended' because we're - // inside the if block where it wasn't, but it could have changed because - // on[Hangup|Reject]Received are side-effecty. - if (call.state === _call.CallState.Ended) this.calls.delete(content.call_id); - } - } - return; - } - - // The following events need a call and a peer connection - if (!call || !call.hasPeerConnection) { - _logger.logger.info(`CallEventHandler handleCallEvent() discarding possible call event as we don't have a call (type=${type})`); - return; - } - // Ignore remote echo - if (event.getContent().party_id === call.ourPartyId) return; - switch (type) { - case _event.EventType.CallAnswer: - if (weSentTheEvent) { - if (call.state === _call.CallState.Ringing) { - call.onAnsweredElsewhere(content); - } - } else { - call.onAnswerReceived(event); - } - break; - case _event.EventType.CallSelectAnswer: - call.onSelectAnswerReceived(event); - break; - case _event.EventType.CallNegotiate: - call.onNegotiateReceived(event); - break; - case _event.EventType.CallAssertedIdentity: - case _event.EventType.CallAssertedIdentityPrefix: - call.onAssertedIdentityReceived(event); - break; - case _event.EventType.CallSDPStreamMetadataChanged: - case _event.EventType.CallSDPStreamMetadataChangedPrefix: - call.onSDPStreamMetadataChangedReceived(event); - break; - } - } -} -exports.CallEventHandler = CallEventHandler; -//# sourceMappingURL=callEventHandler.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js.map deleted file mode 100644 index ea92d1a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventHandler.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"callEventHandler.js","names":["_logger","require","_call","_event","_client","_groupCall3","_room","RING_GRACE_PERIOD","CallEventHandlerEvent","exports","CallEventHandler","constructor","client","_defineProperty2","default","Map","currentEventBuffer","callEventBuffer","eventBufferPromiseChain","then","evaluateEventBuffer","event","push","content","getContent","call_id","nextSeqByCall","has","set","seq","undefined","nextSeq","get","toDeviceEventBuffers","buffer","index","findIndex","e","splice","callId","nextEvent","shift","calls","candidateEventsByCall","start","on","ClientEvent","Sync","onSync","RoomEvent","Timeline","onRoomTimeline","ToDeviceEvent","onToDeviceEvent","stop","removeListener","eventBuffer","Promise","all","map","decryptEventIfNeeded","callEvents","filter","eventType","getType","startsWith","ignoreCallIds","Set","EventType","CallAnswer","CallHangup","add","CallInvite","handleCallEvent","logger","error","_getGroupCallById","_getGroupCallById$roo","emit","ReceivedVoipEvent","callRoomId","getRoomId","groupCallEventHandler","getGroupCallById","conf_id","room","roomId","groupCallId","type","senderId","getSender","call","opponentDeviceId","groupCall","warn","device_id","GroupCallEvent","Error","GroupCallUnknownDeviceError","dest_session_id","getSessionId","weSentTheEvent","credentials","userId","getDeviceId","_this$client$getTurnS","_createNewMatrixCall","_groupCall","getLocalAge","lifetime","state","CallState","Ended","invitee","getUserId","timeUntilTurnCresExpire","getTurnServersExpiry","Date","now","info","createNewMatrixCall","forceTURN","opponentSessionId","sender_session_id","log","stats","getGroupCallStats","initStats","initWithInvite","CallError","code","GroupCallErrorCode","UnknownDevice","_groupCall2","ev","onRemoteIceCandidatesReceived","existingCall","thisCall","values","_call$getOpponentMemb","isCalling","WaitLocalMedia","CreateOffer","InviteSent","includes","direction","CallDirection","Outbound","getOpponentMember","replacedBy","hangup","CallErrorCode","Replaced","Incoming","CallCandidates","CallReject","_createNewMatrixCall2","initWithHangup","onHangupReceived","onRejectReceived","delete","hasPeerConnection","party_id","ourPartyId","Ringing","onAnsweredElsewhere","onAnswerReceived","CallSelectAnswer","onSelectAnswerReceived","CallNegotiate","onNegotiateReceived","CallAssertedIdentity","CallAssertedIdentityPrefix","onAssertedIdentityReceived","CallSDPStreamMetadataChanged","CallSDPStreamMetadataChangedPrefix","onSDPStreamMetadataChangedReceived"],"sources":["../../src/webrtc/callEventHandler.ts"],"sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixEvent } from \"../models/event\";\nimport { logger } from \"../logger\";\nimport { CallDirection, CallError, CallErrorCode, CallState, createNewMatrixCall, MatrixCall } from \"./call\";\nimport { EventType } from \"../@types/event\";\nimport { ClientEvent, MatrixClient } from \"../client\";\nimport { MCallAnswer, MCallHangupReject } from \"./callEventTypes\";\nimport { GroupCall, GroupCallErrorCode, GroupCallEvent, GroupCallUnknownDeviceError } from \"./groupCall\";\nimport { RoomEvent } from \"../models/room\";\n\n// Don't ring unless we'd be ringing for at least 3 seconds: the user needs some\n// time to press the 'accept' button\nconst RING_GRACE_PERIOD = 3000;\n\nexport enum CallEventHandlerEvent {\n Incoming = \"Call.incoming\",\n}\n\nexport type CallEventHandlerEventHandlerMap = {\n /**\n * Fires whenever an incoming call arrives.\n * @param call - The incoming call.\n * @example\n * ```\n * matrixClient.on(\"Call.incoming\", function(call){\n * call.answer(); // auto-answer\n * });\n * ```\n */\n [CallEventHandlerEvent.Incoming]: (call: MatrixCall) => void;\n};\n\nexport class CallEventHandler {\n // XXX: Most of these are only public because of the tests\n public calls: Map;\n public callEventBuffer: MatrixEvent[];\n public nextSeqByCall: Map = new Map();\n public toDeviceEventBuffers: Map> = new Map();\n\n private client: MatrixClient;\n private candidateEventsByCall: Map>;\n private eventBufferPromiseChain?: Promise;\n\n public constructor(client: MatrixClient) {\n this.client = client;\n this.calls = new Map();\n // The sync code always emits one event at a time, so it will patiently\n // wait for us to finish processing a call invite before delivering the\n // next event, even if that next event is a hangup. We therefore accumulate\n // all our call events and then process them on the 'sync' event, ie.\n // each time a sync has completed. This way, we can avoid emitting incoming\n // call events if we get both the invite and answer/hangup in the same sync.\n // This happens quite often, eg. replaying sync from storage, catchup sync\n // after loading and after we've been offline for a bit.\n this.callEventBuffer = [];\n this.candidateEventsByCall = new Map>();\n }\n\n public start(): void {\n this.client.on(ClientEvent.Sync, this.onSync);\n this.client.on(RoomEvent.Timeline, this.onRoomTimeline);\n this.client.on(ClientEvent.ToDeviceEvent, this.onToDeviceEvent);\n }\n\n public stop(): void {\n this.client.removeListener(ClientEvent.Sync, this.onSync);\n this.client.removeListener(RoomEvent.Timeline, this.onRoomTimeline);\n this.client.removeListener(ClientEvent.ToDeviceEvent, this.onToDeviceEvent);\n }\n\n private onSync = (): void => {\n // Process the current event buffer and start queuing into a new one.\n const currentEventBuffer = this.callEventBuffer;\n this.callEventBuffer = [];\n\n // Ensure correct ordering by only processing this queue after the previous one has finished processing\n if (this.eventBufferPromiseChain) {\n this.eventBufferPromiseChain = this.eventBufferPromiseChain.then(() =>\n this.evaluateEventBuffer(currentEventBuffer),\n );\n } else {\n this.eventBufferPromiseChain = this.evaluateEventBuffer(currentEventBuffer);\n }\n };\n\n private async evaluateEventBuffer(eventBuffer: MatrixEvent[]): Promise {\n await Promise.all(eventBuffer.map((event) => this.client.decryptEventIfNeeded(event)));\n\n const callEvents = eventBuffer.filter((event) => {\n const eventType = event.getType();\n return eventType.startsWith(\"m.call.\") || eventType.startsWith(\"org.matrix.call.\");\n });\n\n const ignoreCallIds = new Set();\n\n // inspect the buffer and mark all calls which have been answered\n // or hung up before passing them to the call event handler.\n for (const event of callEvents) {\n const eventType = event.getType();\n\n if (eventType === EventType.CallAnswer || eventType === EventType.CallHangup) {\n ignoreCallIds.add(event.getContent().call_id);\n }\n }\n\n // Process call events in the order that they were received\n for (const event of callEvents) {\n const eventType = event.getType();\n const callId = event.getContent().call_id;\n\n if (eventType === EventType.CallInvite && ignoreCallIds.has(callId)) {\n // This call has previously been answered or hung up: ignore it\n continue;\n }\n\n try {\n await this.handleCallEvent(event);\n } catch (e) {\n logger.error(\"CallEventHandler evaluateEventBuffer() caught exception handling call event\", e);\n }\n }\n }\n\n private onRoomTimeline = (event: MatrixEvent): void => {\n this.callEventBuffer.push(event);\n };\n\n private onToDeviceEvent = (event: MatrixEvent): void => {\n const content = event.getContent();\n\n if (!content.call_id) {\n this.callEventBuffer.push(event);\n return;\n }\n\n if (!this.nextSeqByCall.has(content.call_id)) {\n this.nextSeqByCall.set(content.call_id, 0);\n }\n\n if (content.seq === undefined) {\n this.callEventBuffer.push(event);\n return;\n }\n\n const nextSeq = this.nextSeqByCall.get(content.call_id) || 0;\n\n if (content.seq !== nextSeq) {\n if (!this.toDeviceEventBuffers.has(content.call_id)) {\n this.toDeviceEventBuffers.set(content.call_id, []);\n }\n\n const buffer = this.toDeviceEventBuffers.get(content.call_id)!;\n const index = buffer.findIndex((e) => e.getContent().seq > content.seq);\n\n if (index === -1) {\n buffer.push(event);\n } else {\n buffer.splice(index, 0, event);\n }\n } else {\n const callId = content.call_id;\n this.callEventBuffer.push(event);\n this.nextSeqByCall.set(callId, content.seq + 1);\n\n const buffer = this.toDeviceEventBuffers.get(callId);\n\n let nextEvent = buffer && buffer.shift();\n\n while (nextEvent && nextEvent.getContent().seq === this.nextSeqByCall.get(callId)) {\n this.callEventBuffer.push(nextEvent);\n this.nextSeqByCall.set(callId, nextEvent.getContent().seq + 1);\n nextEvent = buffer!.shift();\n }\n }\n };\n\n private async handleCallEvent(event: MatrixEvent): Promise {\n this.client.emit(ClientEvent.ReceivedVoipEvent, event);\n\n const content = event.getContent();\n const callRoomId =\n event.getRoomId() || this.client.groupCallEventHandler!.getGroupCallById(content.conf_id)?.room?.roomId;\n const groupCallId = content.conf_id;\n const type = event.getType() as EventType;\n const senderId = event.getSender()!;\n let call = content.call_id ? this.calls.get(content.call_id) : undefined;\n\n let opponentDeviceId: string | undefined;\n\n let groupCall: GroupCall | undefined;\n if (groupCallId) {\n groupCall = this.client.groupCallEventHandler!.getGroupCallById(groupCallId);\n\n if (!groupCall) {\n logger.warn(\n `CallEventHandler handleCallEvent() could not find a group call - ignoring event (groupCallId=${groupCallId}, type=${type})`,\n );\n return;\n }\n\n opponentDeviceId = content.device_id;\n\n if (!opponentDeviceId) {\n logger.warn(\n `CallEventHandler handleCallEvent() could not find a device id - ignoring event (senderId=${senderId})`,\n );\n groupCall.emit(GroupCallEvent.Error, new GroupCallUnknownDeviceError(senderId));\n return;\n }\n\n if (content.dest_session_id !== this.client.getSessionId()) {\n logger.warn(\n \"CallEventHandler handleCallEvent() call event does not match current session id - ignoring\",\n );\n return;\n }\n }\n\n const weSentTheEvent =\n senderId === this.client.credentials.userId &&\n (opponentDeviceId === undefined || opponentDeviceId === this.client.getDeviceId()!);\n\n if (!callRoomId) return;\n\n if (type === EventType.CallInvite) {\n // ignore invites you send\n if (weSentTheEvent) return;\n // expired call\n if (event.getLocalAge() > content.lifetime - RING_GRACE_PERIOD) return;\n // stale/old invite event\n if (call && call.state === CallState.Ended) return;\n\n if (call) {\n logger.warn(\n `CallEventHandler handleCallEvent() already has a call but got an invite - clobbering (callId=${content.call_id})`,\n );\n }\n\n if (content.invitee && content.invitee !== this.client.getUserId()) {\n return; // This invite was meant for another user in the room\n }\n\n const timeUntilTurnCresExpire = (this.client.getTurnServersExpiry() ?? 0) - Date.now();\n logger.info(\n \"CallEventHandler handleCallEvent() current turn creds expire in \" + timeUntilTurnCresExpire + \" ms\",\n );\n call =\n createNewMatrixCall(this.client, callRoomId, {\n forceTURN: this.client.forceTURN,\n opponentDeviceId,\n groupCallId,\n opponentSessionId: content.sender_session_id,\n }) ?? undefined;\n if (!call) {\n logger.log(\n `CallEventHandler handleCallEvent() this client does not support WebRTC (callId=${content.call_id})`,\n );\n // don't hang up the call: there could be other clients\n // connected that do support WebRTC and declining the\n // the call on their behalf would be really annoying.\n return;\n }\n\n call.callId = content.call_id;\n const stats = groupCall?.getGroupCallStats();\n if (stats) {\n call.initStats(stats);\n }\n\n try {\n await call.initWithInvite(event);\n } catch (e) {\n if (e instanceof CallError) {\n if (e.code === GroupCallErrorCode.UnknownDevice) {\n groupCall?.emit(GroupCallEvent.Error, e);\n } else {\n logger.error(e);\n }\n }\n }\n this.calls.set(call.callId, call);\n\n // if we stashed candidate events for that call ID, play them back now\n if (this.candidateEventsByCall.get(call.callId)) {\n for (const ev of this.candidateEventsByCall.get(call.callId)!) {\n call.onRemoteIceCandidatesReceived(ev);\n }\n }\n\n // Were we trying to call that user (room)?\n let existingCall: MatrixCall | undefined;\n for (const thisCall of this.calls.values()) {\n const isCalling = [CallState.WaitLocalMedia, CallState.CreateOffer, CallState.InviteSent].includes(\n thisCall.state,\n );\n\n if (\n call.roomId === thisCall.roomId &&\n thisCall.direction === CallDirection.Outbound &&\n call.getOpponentMember()?.userId === thisCall.invitee &&\n isCalling\n ) {\n existingCall = thisCall;\n break;\n }\n }\n\n if (existingCall) {\n if (existingCall.callId > call.callId) {\n logger.log(\n `CallEventHandler handleCallEvent() detected glare - answering incoming call and canceling outgoing call (incomingId=${call.callId}, outgoingId=${existingCall.callId})`,\n );\n existingCall.replacedBy(call);\n } else {\n logger.log(\n `CallEventHandler handleCallEvent() detected glare - hanging up incoming call (incomingId=${call.callId}, outgoingId=${existingCall.callId})`,\n );\n call.hangup(CallErrorCode.Replaced, true);\n }\n } else {\n this.client.emit(CallEventHandlerEvent.Incoming, call);\n }\n return;\n } else if (type === EventType.CallCandidates) {\n if (weSentTheEvent) return;\n\n if (!call) {\n // store the candidates; we may get a call eventually.\n if (!this.candidateEventsByCall.has(content.call_id)) {\n this.candidateEventsByCall.set(content.call_id, []);\n }\n this.candidateEventsByCall.get(content.call_id)!.push(event);\n } else {\n call.onRemoteIceCandidatesReceived(event);\n }\n return;\n } else if ([EventType.CallHangup, EventType.CallReject].includes(type)) {\n // Note that we also observe our own hangups here so we can see\n // if we've already rejected a call that would otherwise be valid\n if (!call) {\n // if not live, store the fact that the call has ended because\n // we're probably getting events backwards so\n // the hangup will come before the invite\n call =\n createNewMatrixCall(this.client, callRoomId, {\n opponentDeviceId,\n opponentSessionId: content.sender_session_id,\n }) ?? undefined;\n if (call) {\n call.callId = content.call_id;\n call.initWithHangup(event);\n this.calls.set(content.call_id, call);\n }\n } else {\n if (call.state !== CallState.Ended) {\n if (type === EventType.CallHangup) {\n call.onHangupReceived(content as MCallHangupReject);\n } else {\n call.onRejectReceived(content as MCallHangupReject);\n }\n\n // @ts-expect-error typescript thinks the state can't be 'ended' because we're\n // inside the if block where it wasn't, but it could have changed because\n // on[Hangup|Reject]Received are side-effecty.\n if (call.state === CallState.Ended) this.calls.delete(content.call_id);\n }\n }\n return;\n }\n\n // The following events need a call and a peer connection\n if (!call || !call.hasPeerConnection) {\n logger.info(\n `CallEventHandler handleCallEvent() discarding possible call event as we don't have a call (type=${type})`,\n );\n return;\n }\n // Ignore remote echo\n if (event.getContent().party_id === call.ourPartyId) return;\n\n switch (type) {\n case EventType.CallAnswer:\n if (weSentTheEvent) {\n if (call.state === CallState.Ringing) {\n call.onAnsweredElsewhere(content as MCallAnswer);\n }\n } else {\n call.onAnswerReceived(event);\n }\n break;\n case EventType.CallSelectAnswer:\n call.onSelectAnswerReceived(event);\n break;\n\n case EventType.CallNegotiate:\n call.onNegotiateReceived(event);\n break;\n\n case EventType.CallAssertedIdentity:\n case EventType.CallAssertedIdentityPrefix:\n call.onAssertedIdentityReceived(event);\n break;\n\n case EventType.CallSDPStreamMetadataChanged:\n case EventType.CallSDPStreamMetadataChangedPrefix:\n call.onSDPStreamMetadataChangedReceived(event);\n break;\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts deleted file mode 100644 index 09a6397..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts +++ /dev/null @@ -1,72 +0,0 @@ -import { CallErrorCode } from "./call"; -export declare const SDPStreamMetadataKey = "org.matrix.msc3077.sdp_stream_metadata"; -export declare enum SDPStreamMetadataPurpose { - Usermedia = "m.usermedia", - Screenshare = "m.screenshare" -} -export interface SDPStreamMetadataObject { - purpose: SDPStreamMetadataPurpose; - audio_muted: boolean; - video_muted: boolean; -} -export interface SDPStreamMetadata { - [key: string]: SDPStreamMetadataObject; -} -export interface CallCapabilities { - "m.call.transferee": boolean; - "m.call.dtmf": boolean; -} -export interface CallReplacesTarget { - id: string; - display_name: string; - avatar_url: string; -} -export interface MCallBase { - call_id: string; - version: string | number; - party_id?: string; - sender_session_id?: string; - dest_session_id?: string; -} -export interface MCallAnswer extends MCallBase { - answer: RTCSessionDescription; - capabilities?: CallCapabilities; - [SDPStreamMetadataKey]: SDPStreamMetadata; -} -export interface MCallSelectAnswer extends MCallBase { - selected_party_id: string; -} -export interface MCallInviteNegotiate extends MCallBase { - offer: RTCSessionDescription; - description: RTCSessionDescription; - lifetime: number; - capabilities?: CallCapabilities; - invitee?: string; - sender_session_id?: string; - dest_session_id?: string; - [SDPStreamMetadataKey]: SDPStreamMetadata; -} -export interface MCallSDPStreamMetadataChanged extends MCallBase { - [SDPStreamMetadataKey]: SDPStreamMetadata; -} -export interface MCallReplacesEvent extends MCallBase { - replacement_id: string; - target_user: CallReplacesTarget; - create_call: string; - await_call: string; - target_room: string; -} -export interface MCAllAssertedIdentity extends MCallBase { - asserted_identity: { - id: string; - display_name: string; - avatar_url: string; - }; -} -export interface MCallCandidates extends MCallBase { - candidates: RTCIceCandidate[]; -} -export interface MCallHangupReject extends MCallBase { - reason?: CallErrorCode; -} -//# sourceMappingURL=callEventTypes.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts.map deleted file mode 100644 index 1975acd..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"callEventTypes.d.ts","sourceRoot":"","sources":["../../src/webrtc/callEventTypes.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAGvC,eAAO,MAAM,oBAAoB,2CAA2C,CAAC;AAE7E,oBAAY,wBAAwB;IAChC,SAAS,gBAAgB;IACzB,WAAW,kBAAkB;CAChC;AAED,MAAM,WAAW,uBAAuB;IACpC,OAAO,EAAE,wBAAwB,CAAC;IAClC,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,iBAAiB;IAC9B,CAAC,GAAG,EAAE,MAAM,GAAG,uBAAuB,CAAC;CAC1C;AAED,MAAM,WAAW,gBAAgB;IAC7B,mBAAmB,EAAE,OAAO,CAAC;IAC7B,aAAa,EAAE,OAAO,CAAC;CAC1B;AAED,MAAM,WAAW,kBAAkB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,SAAS;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,GAAG,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,WAAY,SAAQ,SAAS;IAC1C,MAAM,EAAE,qBAAqB,CAAC;IAC9B,YAAY,CAAC,EAAE,gBAAgB,CAAC;IAChC,CAAC,oBAAoB,CAAC,EAAE,iBAAiB,CAAC;CAC7C;AAED,MAAM,WAAW,iBAAkB,SAAQ,SAAS;IAChD,iBAAiB,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,oBAAqB,SAAQ,SAAS;IACnD,KAAK,EAAE,qBAAqB,CAAC;IAC7B,WAAW,EAAE,qBAAqB,CAAC;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,gBAAgB,CAAC;IAChC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,CAAC,oBAAoB,CAAC,EAAE,iBAAiB,CAAC;CAC7C;AAED,MAAM,WAAW,6BAA8B,SAAQ,SAAS;IAC5D,CAAC,oBAAoB,CAAC,EAAE,iBAAiB,CAAC;CAC7C;AAED,MAAM,WAAW,kBAAmB,SAAQ,SAAS;IACjD,cAAc,EAAE,MAAM,CAAC;IACvB,WAAW,EAAE,kBAAkB,CAAC;IAChC,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,qBAAsB,SAAQ,SAAS;IACpD,iBAAiB,EAAE;QACf,EAAE,EAAE,MAAM,CAAC;QACX,YAAY,EAAE,MAAM,CAAC;QACrB,UAAU,EAAE,MAAM,CAAC;KACtB,CAAC;CACL;AAED,MAAM,WAAW,eAAgB,SAAQ,SAAS;IAC9C,UAAU,EAAE,eAAe,EAAE,CAAC;CACjC;AAED,MAAM,WAAW,iBAAkB,SAAQ,SAAS;IAChD,MAAM,CAAC,EAAE,aAAa,CAAC;CAC1B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js deleted file mode 100644 index 5b10142..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js +++ /dev/null @@ -1,20 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SDPStreamMetadataPurpose = exports.SDPStreamMetadataKey = void 0; -// allow non-camelcase as these are events type that go onto the wire -/* eslint-disable camelcase */ - -// TODO: Change to "sdp_stream_metadata" when MSC3077 is merged -const SDPStreamMetadataKey = "org.matrix.msc3077.sdp_stream_metadata"; -exports.SDPStreamMetadataKey = SDPStreamMetadataKey; -let SDPStreamMetadataPurpose; -exports.SDPStreamMetadataPurpose = SDPStreamMetadataPurpose; -(function (SDPStreamMetadataPurpose) { - SDPStreamMetadataPurpose["Usermedia"] = "m.usermedia"; - SDPStreamMetadataPurpose["Screenshare"] = "m.screenshare"; -})(SDPStreamMetadataPurpose || (exports.SDPStreamMetadataPurpose = SDPStreamMetadataPurpose = {})); -/* eslint-enable camelcase */ -//# sourceMappingURL=callEventTypes.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js.map deleted file mode 100644 index 5670198..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callEventTypes.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"callEventTypes.js","names":["SDPStreamMetadataKey","exports","SDPStreamMetadataPurpose"],"sources":["../../src/webrtc/callEventTypes.ts"],"sourcesContent":["// allow non-camelcase as these are events type that go onto the wire\n/* eslint-disable camelcase */\n\nimport { CallErrorCode } from \"./call\";\n\n// TODO: Change to \"sdp_stream_metadata\" when MSC3077 is merged\nexport const SDPStreamMetadataKey = \"org.matrix.msc3077.sdp_stream_metadata\";\n\nexport enum SDPStreamMetadataPurpose {\n Usermedia = \"m.usermedia\",\n Screenshare = \"m.screenshare\",\n}\n\nexport interface SDPStreamMetadataObject {\n purpose: SDPStreamMetadataPurpose;\n audio_muted: boolean;\n video_muted: boolean;\n}\n\nexport interface SDPStreamMetadata {\n [key: string]: SDPStreamMetadataObject;\n}\n\nexport interface CallCapabilities {\n \"m.call.transferee\": boolean;\n \"m.call.dtmf\": boolean;\n}\n\nexport interface CallReplacesTarget {\n id: string;\n display_name: string;\n avatar_url: string;\n}\n\nexport interface MCallBase {\n call_id: string;\n version: string | number;\n party_id?: string;\n sender_session_id?: string;\n dest_session_id?: string;\n}\n\nexport interface MCallAnswer extends MCallBase {\n answer: RTCSessionDescription;\n capabilities?: CallCapabilities;\n [SDPStreamMetadataKey]: SDPStreamMetadata;\n}\n\nexport interface MCallSelectAnswer extends MCallBase {\n selected_party_id: string;\n}\n\nexport interface MCallInviteNegotiate extends MCallBase {\n offer: RTCSessionDescription;\n description: RTCSessionDescription;\n lifetime: number;\n capabilities?: CallCapabilities;\n invitee?: string;\n sender_session_id?: string;\n dest_session_id?: string;\n [SDPStreamMetadataKey]: SDPStreamMetadata;\n}\n\nexport interface MCallSDPStreamMetadataChanged extends MCallBase {\n [SDPStreamMetadataKey]: SDPStreamMetadata;\n}\n\nexport interface MCallReplacesEvent extends MCallBase {\n replacement_id: string;\n target_user: CallReplacesTarget;\n create_call: string;\n await_call: string;\n target_room: string;\n}\n\nexport interface MCAllAssertedIdentity extends MCallBase {\n asserted_identity: {\n id: string;\n display_name: string;\n avatar_url: string;\n };\n}\n\nexport interface MCallCandidates extends MCallBase {\n candidates: RTCIceCandidate[];\n}\n\nexport interface MCallHangupReject extends MCallBase {\n reason?: CallErrorCode;\n}\n\n/* eslint-enable camelcase */\n"],"mappings":";;;;;;AAAA;AACA;;AAIA;AACO,MAAMA,oBAAoB,GAAG,wCAAwC;AAACC,OAAA,CAAAD,oBAAA,GAAAA,oBAAA;AAAA,IAEjEE,wBAAwB;AAAAD,OAAA,CAAAC,wBAAA,GAAAA,wBAAA;AAAA,WAAxBA,wBAAwB;EAAxBA,wBAAwB;EAAxBA,wBAAwB;AAAA,GAAxBA,wBAAwB,KAAAD,OAAA,CAAAC,wBAAA,GAAxBA,wBAAwB;AAmFpC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts deleted file mode 100644 index e9ffa64..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts +++ /dev/null @@ -1,128 +0,0 @@ -import { SDPStreamMetadataPurpose } from "./callEventTypes"; -import { MatrixClient } from "../client"; -import { RoomMember } from "../models/room-member"; -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { MatrixCall } from "./call"; -export declare const SPEAKING_THRESHOLD = -60; -export interface ICallFeedOpts { - client: MatrixClient; - roomId?: string; - userId: string; - deviceId: string | undefined; - stream: MediaStream; - purpose: SDPStreamMetadataPurpose; - /** - * Whether or not the remote SDPStreamMetadata says audio is muted - */ - audioMuted: boolean; - /** - * Whether or not the remote SDPStreamMetadata says video is muted - */ - videoMuted: boolean; - /** - * The MatrixCall which is the source of this CallFeed - */ - call?: MatrixCall; -} -export declare enum CallFeedEvent { - NewStream = "new_stream", - MuteStateChanged = "mute_state_changed", - LocalVolumeChanged = "local_volume_changed", - VolumeChanged = "volume_changed", - ConnectedChanged = "connected_changed", - Speaking = "speaking", - Disposed = "disposed" -} -type EventHandlerMap = { - [CallFeedEvent.NewStream]: (stream: MediaStream) => void; - [CallFeedEvent.MuteStateChanged]: (audioMuted: boolean, videoMuted: boolean) => void; - [CallFeedEvent.LocalVolumeChanged]: (localVolume: number) => void; - [CallFeedEvent.VolumeChanged]: (volume: number) => void; - [CallFeedEvent.ConnectedChanged]: (connected: boolean) => void; - [CallFeedEvent.Speaking]: (speaking: boolean) => void; - [CallFeedEvent.Disposed]: () => void; -}; -export declare class CallFeed extends TypedEventEmitter { - stream: MediaStream; - sdpMetadataStreamId: string; - userId: string; - readonly deviceId: string | undefined; - purpose: SDPStreamMetadataPurpose; - speakingVolumeSamples: number[]; - private client; - private call?; - private roomId?; - private audioMuted; - private videoMuted; - private localVolume; - private measuringVolumeActivity; - private audioContext?; - private analyser?; - private frequencyBinCount?; - private speakingThreshold; - private speaking; - private volumeLooperTimeout?; - private _disposed; - private _connected; - constructor(opts: ICallFeedOpts); - get connected(): boolean; - private set connected(value); - private get hasAudioTrack(); - private updateStream; - private initVolumeMeasuring; - private onAddTrack; - private onCallState; - /** - * Returns callRoom member - * @returns member of the callRoom - */ - getMember(): RoomMember | null; - /** - * Returns true if CallFeed is local, otherwise returns false - * @returns is local? - */ - isLocal(): boolean; - /** - * Returns true if audio is muted or if there are no audio - * tracks, otherwise returns false - * @returns is audio muted? - */ - isAudioMuted(): boolean; - /** - * Returns true video is muted or if there are no video - * tracks, otherwise returns false - * @returns is video muted? - */ - isVideoMuted(): boolean; - isSpeaking(): boolean; - /** - * Replaces the current MediaStream with a new one. - * The stream will be different and new stream as remote parties are - * concerned, but this can be used for convenience locally to set up - * volume listeners automatically on the new stream etc. - * @param newStream - new stream with which to replace the current one - */ - setNewStream(newStream: MediaStream): void; - /** - * Set one or both of feed's internal audio and video video mute state - * Either value may be null to leave it as-is - * @param audioMuted - is the feed's audio muted? - * @param videoMuted - is the feed's video muted? - */ - setAudioVideoMuted(audioMuted: boolean | null, videoMuted: boolean | null): void; - /** - * Starts emitting volume_changed events where the emitter value is in decibels - * @param enabled - emit volume changes - */ - measureVolumeActivity(enabled: boolean): void; - setSpeakingThreshold(threshold: number): void; - private volumeLooper; - clone(): CallFeed; - dispose(): void; - get disposed(): boolean; - private set disposed(value); - getLocalVolume(): number; - setLocalVolume(localVolume: number): void; -} -export {}; -//# sourceMappingURL=callFeed.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts.map deleted file mode 100644 index 85e5615..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"callFeed.d.ts","sourceRoot":"","sources":["../../src/webrtc/callFeed.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js deleted file mode 100644 index 3638765..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js +++ /dev/null @@ -1,296 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.SPEAKING_THRESHOLD = exports.CallFeedEvent = exports.CallFeed = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _callEventTypes = require("./callEventTypes"); -var _audioContext = require("./audioContext"); -var _logger = require("../logger"); -var _typedEventEmitter = require("../models/typed-event-emitter"); -var _call = require("./call"); -/* -Copyright 2021 Šimon Brandner - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -const POLLING_INTERVAL = 200; // ms -const SPEAKING_THRESHOLD = -60; // dB -exports.SPEAKING_THRESHOLD = SPEAKING_THRESHOLD; -const SPEAKING_SAMPLE_COUNT = 8; // samples -let CallFeedEvent; -exports.CallFeedEvent = CallFeedEvent; -(function (CallFeedEvent) { - CallFeedEvent["NewStream"] = "new_stream"; - CallFeedEvent["MuteStateChanged"] = "mute_state_changed"; - CallFeedEvent["LocalVolumeChanged"] = "local_volume_changed"; - CallFeedEvent["VolumeChanged"] = "volume_changed"; - CallFeedEvent["ConnectedChanged"] = "connected_changed"; - CallFeedEvent["Speaking"] = "speaking"; - CallFeedEvent["Disposed"] = "disposed"; -})(CallFeedEvent || (exports.CallFeedEvent = CallFeedEvent = {})); -class CallFeed extends _typedEventEmitter.TypedEventEmitter { - constructor(opts) { - super(); - (0, _defineProperty2.default)(this, "stream", void 0); - (0, _defineProperty2.default)(this, "sdpMetadataStreamId", void 0); - (0, _defineProperty2.default)(this, "userId", void 0); - (0, _defineProperty2.default)(this, "deviceId", void 0); - (0, _defineProperty2.default)(this, "purpose", void 0); - (0, _defineProperty2.default)(this, "speakingVolumeSamples", void 0); - (0, _defineProperty2.default)(this, "client", void 0); - (0, _defineProperty2.default)(this, "call", void 0); - (0, _defineProperty2.default)(this, "roomId", void 0); - (0, _defineProperty2.default)(this, "audioMuted", void 0); - (0, _defineProperty2.default)(this, "videoMuted", void 0); - (0, _defineProperty2.default)(this, "localVolume", 1); - (0, _defineProperty2.default)(this, "measuringVolumeActivity", false); - (0, _defineProperty2.default)(this, "audioContext", void 0); - (0, _defineProperty2.default)(this, "analyser", void 0); - (0, _defineProperty2.default)(this, "frequencyBinCount", void 0); - (0, _defineProperty2.default)(this, "speakingThreshold", SPEAKING_THRESHOLD); - (0, _defineProperty2.default)(this, "speaking", false); - (0, _defineProperty2.default)(this, "volumeLooperTimeout", void 0); - (0, _defineProperty2.default)(this, "_disposed", false); - (0, _defineProperty2.default)(this, "_connected", false); - (0, _defineProperty2.default)(this, "onAddTrack", () => { - this.emit(CallFeedEvent.NewStream, this.stream); - }); - (0, _defineProperty2.default)(this, "onCallState", state => { - if (state === _call.CallState.Connected) { - this.connected = true; - } else if (state === _call.CallState.Connecting) { - this.connected = false; - } - }); - (0, _defineProperty2.default)(this, "volumeLooper", () => { - if (!this.analyser) return; - if (!this.measuringVolumeActivity) return; - this.analyser.getFloatFrequencyData(this.frequencyBinCount); - let maxVolume = -Infinity; - for (const volume of this.frequencyBinCount) { - if (volume > maxVolume) { - maxVolume = volume; - } - } - this.speakingVolumeSamples.shift(); - this.speakingVolumeSamples.push(maxVolume); - this.emit(CallFeedEvent.VolumeChanged, maxVolume); - let newSpeaking = false; - for (const volume of this.speakingVolumeSamples) { - if (volume > this.speakingThreshold) { - newSpeaking = true; - break; - } - } - if (this.speaking !== newSpeaking) { - this.speaking = newSpeaking; - this.emit(CallFeedEvent.Speaking, this.speaking); - } - this.volumeLooperTimeout = setTimeout(this.volumeLooper, POLLING_INTERVAL); - }); - this.client = opts.client; - this.call = opts.call; - this.roomId = opts.roomId; - this.userId = opts.userId; - this.deviceId = opts.deviceId; - this.purpose = opts.purpose; - this.audioMuted = opts.audioMuted; - this.videoMuted = opts.videoMuted; - this.speakingVolumeSamples = new Array(SPEAKING_SAMPLE_COUNT).fill(-Infinity); - this.sdpMetadataStreamId = opts.stream.id; - this.updateStream(null, opts.stream); - this.stream = opts.stream; // updateStream does this, but this makes TS happier - - if (this.hasAudioTrack) { - this.initVolumeMeasuring(); - } - if (opts.call) { - opts.call.addListener(_call.CallEvent.State, this.onCallState); - this.onCallState(opts.call.state); - } - } - get connected() { - // Local feeds are always considered connected - return this.isLocal() || this._connected; - } - set connected(connected) { - this._connected = connected; - this.emit(CallFeedEvent.ConnectedChanged, this.connected); - } - get hasAudioTrack() { - return this.stream.getAudioTracks().length > 0; - } - updateStream(oldStream, newStream) { - if (newStream === oldStream) return; - if (oldStream) { - oldStream.removeEventListener("addtrack", this.onAddTrack); - this.measureVolumeActivity(false); - } - this.stream = newStream; - newStream.addEventListener("addtrack", this.onAddTrack); - if (this.hasAudioTrack) { - this.initVolumeMeasuring(); - } else { - this.measureVolumeActivity(false); - } - this.emit(CallFeedEvent.NewStream, this.stream); - } - initVolumeMeasuring() { - if (!this.hasAudioTrack) return; - if (!this.audioContext) this.audioContext = (0, _audioContext.acquireContext)(); - this.analyser = this.audioContext.createAnalyser(); - this.analyser.fftSize = 512; - this.analyser.smoothingTimeConstant = 0.1; - const mediaStreamAudioSourceNode = this.audioContext.createMediaStreamSource(this.stream); - mediaStreamAudioSourceNode.connect(this.analyser); - this.frequencyBinCount = new Float32Array(this.analyser.frequencyBinCount); - } - /** - * Returns callRoom member - * @returns member of the callRoom - */ - getMember() { - var _callRoom$getMember; - const callRoom = this.client.getRoom(this.roomId); - return (_callRoom$getMember = callRoom === null || callRoom === void 0 ? void 0 : callRoom.getMember(this.userId)) !== null && _callRoom$getMember !== void 0 ? _callRoom$getMember : null; - } - - /** - * Returns true if CallFeed is local, otherwise returns false - * @returns is local? - */ - isLocal() { - return this.userId === this.client.getUserId() && (this.deviceId === undefined || this.deviceId === this.client.getDeviceId()); - } - - /** - * Returns true if audio is muted or if there are no audio - * tracks, otherwise returns false - * @returns is audio muted? - */ - isAudioMuted() { - return this.stream.getAudioTracks().length === 0 || this.audioMuted; - } - - /** - * Returns true video is muted or if there are no video - * tracks, otherwise returns false - * @returns is video muted? - */ - isVideoMuted() { - // We assume only one video track - return this.stream.getVideoTracks().length === 0 || this.videoMuted; - } - isSpeaking() { - return this.speaking; - } - - /** - * Replaces the current MediaStream with a new one. - * The stream will be different and new stream as remote parties are - * concerned, but this can be used for convenience locally to set up - * volume listeners automatically on the new stream etc. - * @param newStream - new stream with which to replace the current one - */ - setNewStream(newStream) { - this.updateStream(this.stream, newStream); - } - - /** - * Set one or both of feed's internal audio and video video mute state - * Either value may be null to leave it as-is - * @param audioMuted - is the feed's audio muted? - * @param videoMuted - is the feed's video muted? - */ - setAudioVideoMuted(audioMuted, videoMuted) { - if (audioMuted !== null) { - if (this.audioMuted !== audioMuted) { - this.speakingVolumeSamples.fill(-Infinity); - } - this.audioMuted = audioMuted; - } - if (videoMuted !== null) this.videoMuted = videoMuted; - this.emit(CallFeedEvent.MuteStateChanged, this.audioMuted, this.videoMuted); - } - - /** - * Starts emitting volume_changed events where the emitter value is in decibels - * @param enabled - emit volume changes - */ - measureVolumeActivity(enabled) { - if (enabled) { - if (!this.analyser || !this.frequencyBinCount || !this.hasAudioTrack) return; - this.measuringVolumeActivity = true; - this.volumeLooper(); - } else { - this.measuringVolumeActivity = false; - this.speakingVolumeSamples.fill(-Infinity); - this.emit(CallFeedEvent.VolumeChanged, -Infinity); - } - } - setSpeakingThreshold(threshold) { - this.speakingThreshold = threshold; - } - clone() { - const mediaHandler = this.client.getMediaHandler(); - const stream = this.stream.clone(); - _logger.logger.log(`CallFeed clone() cloning stream (originalStreamId=${this.stream.id}, newStreamId${stream.id})`); - if (this.purpose === _callEventTypes.SDPStreamMetadataPurpose.Usermedia) { - mediaHandler.userMediaStreams.push(stream); - } else { - mediaHandler.screensharingStreams.push(stream); - } - return new CallFeed({ - client: this.client, - roomId: this.roomId, - userId: this.userId, - deviceId: this.deviceId, - stream, - purpose: this.purpose, - audioMuted: this.audioMuted, - videoMuted: this.videoMuted - }); - } - dispose() { - var _this$stream, _this$call; - clearTimeout(this.volumeLooperTimeout); - (_this$stream = this.stream) === null || _this$stream === void 0 ? void 0 : _this$stream.removeEventListener("addtrack", this.onAddTrack); - (_this$call = this.call) === null || _this$call === void 0 ? void 0 : _this$call.removeListener(_call.CallEvent.State, this.onCallState); - if (this.audioContext) { - this.audioContext = undefined; - this.analyser = undefined; - (0, _audioContext.releaseContext)(); - } - this._disposed = true; - this.emit(CallFeedEvent.Disposed); - } - get disposed() { - return this._disposed; - } - set disposed(value) { - this._disposed = value; - } - getLocalVolume() { - return this.localVolume; - } - setLocalVolume(localVolume) { - this.localVolume = localVolume; - this.emit(CallFeedEvent.LocalVolumeChanged, localVolume); - } -} -exports.CallFeed = CallFeed; -//# sourceMappingURL=callFeed.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js.map deleted file mode 100644 index 8085af3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/callFeed.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"callFeed.js","names":["_callEventTypes","require","_audioContext","_logger","_typedEventEmitter","_call","POLLING_INTERVAL","SPEAKING_THRESHOLD","exports","SPEAKING_SAMPLE_COUNT","CallFeedEvent","CallFeed","TypedEventEmitter","constructor","opts","_defineProperty2","default","emit","NewStream","stream","state","CallState","Connected","connected","Connecting","analyser","measuringVolumeActivity","getFloatFrequencyData","frequencyBinCount","maxVolume","Infinity","volume","speakingVolumeSamples","shift","push","VolumeChanged","newSpeaking","speakingThreshold","speaking","Speaking","volumeLooperTimeout","setTimeout","volumeLooper","client","call","roomId","userId","deviceId","purpose","audioMuted","videoMuted","Array","fill","sdpMetadataStreamId","id","updateStream","hasAudioTrack","initVolumeMeasuring","addListener","CallEvent","State","onCallState","isLocal","_connected","ConnectedChanged","getAudioTracks","length","oldStream","newStream","removeEventListener","onAddTrack","measureVolumeActivity","addEventListener","audioContext","acquireContext","createAnalyser","fftSize","smoothingTimeConstant","mediaStreamAudioSourceNode","createMediaStreamSource","connect","Float32Array","getMember","_callRoom$getMember","callRoom","getRoom","getUserId","undefined","getDeviceId","isAudioMuted","isVideoMuted","getVideoTracks","isSpeaking","setNewStream","setAudioVideoMuted","MuteStateChanged","enabled","setSpeakingThreshold","threshold","clone","mediaHandler","getMediaHandler","logger","log","SDPStreamMetadataPurpose","Usermedia","userMediaStreams","screensharingStreams","dispose","_this$stream","_this$call","clearTimeout","removeListener","releaseContext","_disposed","Disposed","disposed","value","getLocalVolume","localVolume","setLocalVolume","LocalVolumeChanged"],"sources":["../../src/webrtc/callFeed.ts"],"sourcesContent":["/*\nCopyright 2021 Šimon Brandner \n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { SDPStreamMetadataPurpose } from \"./callEventTypes\";\nimport { acquireContext, releaseContext } from \"./audioContext\";\nimport { MatrixClient } from \"../client\";\nimport { RoomMember } from \"../models/room-member\";\nimport { logger } from \"../logger\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { CallEvent, CallState, MatrixCall } from \"./call\";\n\nconst POLLING_INTERVAL = 200; // ms\nexport const SPEAKING_THRESHOLD = -60; // dB\nconst SPEAKING_SAMPLE_COUNT = 8; // samples\n\nexport interface ICallFeedOpts {\n client: MatrixClient;\n roomId?: string;\n userId: string;\n deviceId: string | undefined;\n stream: MediaStream;\n purpose: SDPStreamMetadataPurpose;\n /**\n * Whether or not the remote SDPStreamMetadata says audio is muted\n */\n audioMuted: boolean;\n /**\n * Whether or not the remote SDPStreamMetadata says video is muted\n */\n videoMuted: boolean;\n /**\n * The MatrixCall which is the source of this CallFeed\n */\n call?: MatrixCall;\n}\n\nexport enum CallFeedEvent {\n NewStream = \"new_stream\",\n MuteStateChanged = \"mute_state_changed\",\n LocalVolumeChanged = \"local_volume_changed\",\n VolumeChanged = \"volume_changed\",\n ConnectedChanged = \"connected_changed\",\n Speaking = \"speaking\",\n Disposed = \"disposed\",\n}\n\ntype EventHandlerMap = {\n [CallFeedEvent.NewStream]: (stream: MediaStream) => void;\n [CallFeedEvent.MuteStateChanged]: (audioMuted: boolean, videoMuted: boolean) => void;\n [CallFeedEvent.LocalVolumeChanged]: (localVolume: number) => void;\n [CallFeedEvent.VolumeChanged]: (volume: number) => void;\n [CallFeedEvent.ConnectedChanged]: (connected: boolean) => void;\n [CallFeedEvent.Speaking]: (speaking: boolean) => void;\n [CallFeedEvent.Disposed]: () => void;\n};\n\nexport class CallFeed extends TypedEventEmitter {\n public stream: MediaStream;\n public sdpMetadataStreamId: string;\n public userId: string;\n public readonly deviceId: string | undefined;\n public purpose: SDPStreamMetadataPurpose;\n public speakingVolumeSamples: number[];\n\n private client: MatrixClient;\n private call?: MatrixCall;\n private roomId?: string;\n private audioMuted: boolean;\n private videoMuted: boolean;\n private localVolume = 1;\n private measuringVolumeActivity = false;\n private audioContext?: AudioContext;\n private analyser?: AnalyserNode;\n private frequencyBinCount?: Float32Array;\n private speakingThreshold = SPEAKING_THRESHOLD;\n private speaking = false;\n private volumeLooperTimeout?: ReturnType;\n private _disposed = false;\n private _connected = false;\n\n public constructor(opts: ICallFeedOpts) {\n super();\n\n this.client = opts.client;\n this.call = opts.call;\n this.roomId = opts.roomId;\n this.userId = opts.userId;\n this.deviceId = opts.deviceId;\n this.purpose = opts.purpose;\n this.audioMuted = opts.audioMuted;\n this.videoMuted = opts.videoMuted;\n this.speakingVolumeSamples = new Array(SPEAKING_SAMPLE_COUNT).fill(-Infinity);\n this.sdpMetadataStreamId = opts.stream.id;\n\n this.updateStream(null, opts.stream);\n this.stream = opts.stream; // updateStream does this, but this makes TS happier\n\n if (this.hasAudioTrack) {\n this.initVolumeMeasuring();\n }\n\n if (opts.call) {\n opts.call.addListener(CallEvent.State, this.onCallState);\n this.onCallState(opts.call.state);\n }\n }\n\n public get connected(): boolean {\n // Local feeds are always considered connected\n return this.isLocal() || this._connected;\n }\n\n private set connected(connected: boolean) {\n this._connected = connected;\n this.emit(CallFeedEvent.ConnectedChanged, this.connected);\n }\n\n private get hasAudioTrack(): boolean {\n return this.stream.getAudioTracks().length > 0;\n }\n\n private updateStream(oldStream: MediaStream | null, newStream: MediaStream): void {\n if (newStream === oldStream) return;\n\n if (oldStream) {\n oldStream.removeEventListener(\"addtrack\", this.onAddTrack);\n this.measureVolumeActivity(false);\n }\n\n this.stream = newStream;\n newStream.addEventListener(\"addtrack\", this.onAddTrack);\n\n if (this.hasAudioTrack) {\n this.initVolumeMeasuring();\n } else {\n this.measureVolumeActivity(false);\n }\n\n this.emit(CallFeedEvent.NewStream, this.stream);\n }\n\n private initVolumeMeasuring(): void {\n if (!this.hasAudioTrack) return;\n if (!this.audioContext) this.audioContext = acquireContext();\n\n this.analyser = this.audioContext.createAnalyser();\n this.analyser.fftSize = 512;\n this.analyser.smoothingTimeConstant = 0.1;\n\n const mediaStreamAudioSourceNode = this.audioContext.createMediaStreamSource(this.stream);\n mediaStreamAudioSourceNode.connect(this.analyser);\n\n this.frequencyBinCount = new Float32Array(this.analyser.frequencyBinCount);\n }\n\n private onAddTrack = (): void => {\n this.emit(CallFeedEvent.NewStream, this.stream);\n };\n\n private onCallState = (state: CallState): void => {\n if (state === CallState.Connected) {\n this.connected = true;\n } else if (state === CallState.Connecting) {\n this.connected = false;\n }\n };\n\n /**\n * Returns callRoom member\n * @returns member of the callRoom\n */\n public getMember(): RoomMember | null {\n const callRoom = this.client.getRoom(this.roomId);\n return callRoom?.getMember(this.userId) ?? null;\n }\n\n /**\n * Returns true if CallFeed is local, otherwise returns false\n * @returns is local?\n */\n public isLocal(): boolean {\n return (\n this.userId === this.client.getUserId() &&\n (this.deviceId === undefined || this.deviceId === this.client.getDeviceId())\n );\n }\n\n /**\n * Returns true if audio is muted or if there are no audio\n * tracks, otherwise returns false\n * @returns is audio muted?\n */\n public isAudioMuted(): boolean {\n return this.stream.getAudioTracks().length === 0 || this.audioMuted;\n }\n\n /**\n * Returns true video is muted or if there are no video\n * tracks, otherwise returns false\n * @returns is video muted?\n */\n public isVideoMuted(): boolean {\n // We assume only one video track\n return this.stream.getVideoTracks().length === 0 || this.videoMuted;\n }\n\n public isSpeaking(): boolean {\n return this.speaking;\n }\n\n /**\n * Replaces the current MediaStream with a new one.\n * The stream will be different and new stream as remote parties are\n * concerned, but this can be used for convenience locally to set up\n * volume listeners automatically on the new stream etc.\n * @param newStream - new stream with which to replace the current one\n */\n public setNewStream(newStream: MediaStream): void {\n this.updateStream(this.stream, newStream);\n }\n\n /**\n * Set one or both of feed's internal audio and video video mute state\n * Either value may be null to leave it as-is\n * @param audioMuted - is the feed's audio muted?\n * @param videoMuted - is the feed's video muted?\n */\n public setAudioVideoMuted(audioMuted: boolean | null, videoMuted: boolean | null): void {\n if (audioMuted !== null) {\n if (this.audioMuted !== audioMuted) {\n this.speakingVolumeSamples.fill(-Infinity);\n }\n this.audioMuted = audioMuted;\n }\n if (videoMuted !== null) this.videoMuted = videoMuted;\n this.emit(CallFeedEvent.MuteStateChanged, this.audioMuted, this.videoMuted);\n }\n\n /**\n * Starts emitting volume_changed events where the emitter value is in decibels\n * @param enabled - emit volume changes\n */\n public measureVolumeActivity(enabled: boolean): void {\n if (enabled) {\n if (!this.analyser || !this.frequencyBinCount || !this.hasAudioTrack) return;\n\n this.measuringVolumeActivity = true;\n this.volumeLooper();\n } else {\n this.measuringVolumeActivity = false;\n this.speakingVolumeSamples.fill(-Infinity);\n this.emit(CallFeedEvent.VolumeChanged, -Infinity);\n }\n }\n\n public setSpeakingThreshold(threshold: number): void {\n this.speakingThreshold = threshold;\n }\n\n private volumeLooper = (): void => {\n if (!this.analyser) return;\n\n if (!this.measuringVolumeActivity) return;\n\n this.analyser.getFloatFrequencyData(this.frequencyBinCount!);\n\n let maxVolume = -Infinity;\n for (const volume of this.frequencyBinCount!) {\n if (volume > maxVolume) {\n maxVolume = volume;\n }\n }\n\n this.speakingVolumeSamples.shift();\n this.speakingVolumeSamples.push(maxVolume);\n\n this.emit(CallFeedEvent.VolumeChanged, maxVolume);\n\n let newSpeaking = false;\n\n for (const volume of this.speakingVolumeSamples) {\n if (volume > this.speakingThreshold) {\n newSpeaking = true;\n break;\n }\n }\n\n if (this.speaking !== newSpeaking) {\n this.speaking = newSpeaking;\n this.emit(CallFeedEvent.Speaking, this.speaking);\n }\n\n this.volumeLooperTimeout = setTimeout(this.volumeLooper, POLLING_INTERVAL);\n };\n\n public clone(): CallFeed {\n const mediaHandler = this.client.getMediaHandler();\n const stream = this.stream.clone();\n logger.log(`CallFeed clone() cloning stream (originalStreamId=${this.stream.id}, newStreamId${stream.id})`);\n\n if (this.purpose === SDPStreamMetadataPurpose.Usermedia) {\n mediaHandler.userMediaStreams.push(stream);\n } else {\n mediaHandler.screensharingStreams.push(stream);\n }\n\n return new CallFeed({\n client: this.client,\n roomId: this.roomId,\n userId: this.userId,\n deviceId: this.deviceId,\n stream,\n purpose: this.purpose,\n audioMuted: this.audioMuted,\n videoMuted: this.videoMuted,\n });\n }\n\n public dispose(): void {\n clearTimeout(this.volumeLooperTimeout);\n this.stream?.removeEventListener(\"addtrack\", this.onAddTrack);\n this.call?.removeListener(CallEvent.State, this.onCallState);\n if (this.audioContext) {\n this.audioContext = undefined;\n this.analyser = undefined;\n releaseContext();\n }\n this._disposed = true;\n this.emit(CallFeedEvent.Disposed);\n }\n\n public get disposed(): boolean {\n return this._disposed;\n }\n\n private set disposed(value: boolean) {\n this._disposed = value;\n }\n\n public getLocalVolume(): number {\n return this.localVolume;\n }\n\n public setLocalVolume(localVolume: number): void {\n this.localVolume = localVolume;\n this.emit(CallFeedEvent.LocalVolumeChanged, localVolume);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts deleted file mode 100644 index 2c1cb3e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts +++ /dev/null @@ -1,287 +0,0 @@ -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { CallFeed } from "./callFeed"; -import { MatrixClient } from "../client"; -import { CallEvent, CallEventHandlerMap, MatrixCall } from "./call"; -import { RoomMember } from "../models/room-member"; -import { Room } from "../models/room"; -import { SDPStreamMetadataPurpose } from "./callEventTypes"; -import { IScreensharingOpts } from "./mediaHandler"; -import { GroupCallStats } from "./stats/groupCallStats"; -import { ByteSentStatsReport, ConnectionStatsReport } from "./stats/statsReport"; -export declare enum GroupCallIntent { - Ring = "m.ring", - Prompt = "m.prompt", - Room = "m.room" -} -export declare enum GroupCallType { - Video = "m.video", - Voice = "m.voice" -} -export declare enum GroupCallTerminationReason { - CallEnded = "call_ended" -} -export type CallsByUserAndDevice = Map>; -/** - * Because event names are just strings, they do need - * to be unique over all event types of event emitter. - * Some objects could emit more then one set of events. - */ -export declare enum GroupCallEvent { - GroupCallStateChanged = "group_call_state_changed", - ActiveSpeakerChanged = "active_speaker_changed", - CallsChanged = "calls_changed", - UserMediaFeedsChanged = "user_media_feeds_changed", - ScreenshareFeedsChanged = "screenshare_feeds_changed", - LocalScreenshareStateChanged = "local_screenshare_state_changed", - LocalMuteStateChanged = "local_mute_state_changed", - ParticipantsChanged = "participants_changed", - Error = "group_call_error" -} -export type GroupCallEventHandlerMap = { - [GroupCallEvent.GroupCallStateChanged]: (newState: GroupCallState, oldState: GroupCallState) => void; - [GroupCallEvent.ActiveSpeakerChanged]: (activeSpeaker: CallFeed | undefined) => void; - [GroupCallEvent.CallsChanged]: (calls: CallsByUserAndDevice) => void; - [GroupCallEvent.UserMediaFeedsChanged]: (feeds: CallFeed[]) => void; - [GroupCallEvent.ScreenshareFeedsChanged]: (feeds: CallFeed[]) => void; - [GroupCallEvent.LocalScreenshareStateChanged]: (isScreensharing: boolean, feed?: CallFeed, sourceId?: string) => void; - [GroupCallEvent.LocalMuteStateChanged]: (audioMuted: boolean, videoMuted: boolean) => void; - [GroupCallEvent.ParticipantsChanged]: (participants: Map>) => void; - /** - * Fires whenever an error occurs when call.js encounters an issue with setting up the call. - *

- * The error given will have a code equal to either `MatrixCall.ERR_LOCAL_OFFER_FAILED` or - * `MatrixCall.ERR_NO_USER_MEDIA`. `ERR_LOCAL_OFFER_FAILED` is emitted when the local client - * fails to create an offer. `ERR_NO_USER_MEDIA` is emitted when the user has denied access - * to their audio/video hardware. - * @param err - The error raised by MatrixCall. - * @example - * ``` - * matrixCall.on("error", function(err){ - * console.error(err.code, err); - * }); - * ``` - */ - [GroupCallEvent.Error]: (error: GroupCallError) => void; -}; -export declare enum GroupCallStatsReportEvent { - ConnectionStats = "GroupCall.connection_stats", - ByteSentStats = "GroupCall.byte_sent_stats" -} -export type GroupCallStatsReportEventHandlerMap = { - [GroupCallStatsReportEvent.ConnectionStats]: (report: GroupCallStatsReport) => void; - [GroupCallStatsReportEvent.ByteSentStats]: (report: GroupCallStatsReport) => void; -}; -export declare enum GroupCallErrorCode { - NoUserMedia = "no_user_media", - UnknownDevice = "unknown_device", - PlaceCallFailed = "place_call_failed" -} -export interface GroupCallStatsReport { - report: T; -} -export declare class GroupCallError extends Error { - code: string; - constructor(code: GroupCallErrorCode, msg: string, err?: Error); -} -export declare class GroupCallUnknownDeviceError extends GroupCallError { - userId: string; - constructor(userId: string); -} -export declare class OtherUserSpeakingError extends Error { - constructor(); -} -export interface IGroupCallDataChannelOptions { - ordered: boolean; - maxPacketLifeTime: number; - maxRetransmits: number; - protocol: string; -} -export interface IGroupCallRoomState { - "m.intent": GroupCallIntent; - "m.type": GroupCallType; - "io.element.ptt"?: boolean; - "dataChannelsEnabled"?: boolean; - "dataChannelOptions"?: IGroupCallDataChannelOptions; -} -export interface IGroupCallRoomMemberFeed { - purpose: SDPStreamMetadataPurpose; -} -export interface IGroupCallRoomMemberDevice { - device_id: string; - session_id: string; - expires_ts: number; - feeds: IGroupCallRoomMemberFeed[]; -} -export interface IGroupCallRoomMemberCallState { - "m.call_id": string; - "m.foci"?: string[]; - "m.devices": IGroupCallRoomMemberDevice[]; -} -export interface IGroupCallRoomMemberState { - "m.calls": IGroupCallRoomMemberCallState[]; -} -export declare enum GroupCallState { - LocalCallFeedUninitialized = "local_call_feed_uninitialized", - InitializingLocalCallFeed = "initializing_local_call_feed", - LocalCallFeedInitialized = "local_call_feed_initialized", - Entered = "entered", - Ended = "ended" -} -export interface ParticipantState { - sessionId: string; - screensharing: boolean; -} -export declare class GroupCall extends TypedEventEmitter { - private client; - room: Room; - type: GroupCallType; - isPtt: boolean; - intent: GroupCallIntent; - private dataChannelsEnabled?; - private dataChannelOptions?; - activeSpeakerInterval: number; - retryCallInterval: number; - participantTimeout: number; - pttMaxTransmitTime: number; - activeSpeaker?: CallFeed; - localCallFeed?: CallFeed; - localScreenshareFeed?: CallFeed; - localDesktopCapturerSourceId?: string; - readonly userMediaFeeds: CallFeed[]; - readonly screenshareFeeds: CallFeed[]; - groupCallId: string; - readonly allowCallWithoutVideoAndAudio: boolean; - private readonly calls; - private callHandlers; - private activeSpeakerLoopInterval?; - private retryCallLoopInterval?; - private retryCallCounts; - private reEmitter; - private transmitTimer; - private participantsExpirationTimer; - private resendMemberStateTimer; - private initWithAudioMuted; - private initWithVideoMuted; - private initCallFeedPromise?; - private readonly stats; - constructor(client: MatrixClient, room: Room, type: GroupCallType, isPtt: boolean, intent: GroupCallIntent, groupCallId?: string, dataChannelsEnabled?: boolean | undefined, dataChannelOptions?: IGroupCallDataChannelOptions | undefined, isCallWithoutVideoAndAudio?: boolean); - private onConnectionStats; - private onByteSentStats; - create(): Promise; - private _state; - /** - * The group call's state. - */ - get state(): GroupCallState; - private set state(value); - private _participants; - /** - * The current participants in the call, as a map from members to device IDs - * to participant info. - */ - get participants(): Map>; - private set participants(value); - private _creationTs; - /** - * The timestamp at which the call was created, or null if it has not yet - * been created. - */ - get creationTs(): number | null; - private set creationTs(value); - private _enteredViaAnotherSession; - /** - * Whether the local device has entered this call via another session, such - * as a widget. - */ - get enteredViaAnotherSession(): boolean; - set enteredViaAnotherSession(value: boolean); - /** - * Executes the given callback on all calls in this group call. - * @param f - The callback. - */ - forEachCall(f: (call: MatrixCall) => void): void; - getLocalFeeds(): CallFeed[]; - hasLocalParticipant(): boolean; - /** - * Determines whether the given call is one that we were expecting to exist - * given our knowledge of who is participating in the group call. - */ - private callExpected; - initLocalCallFeed(): Promise; - private initLocalCallFeedInternal; - updateLocalUsermediaStream(stream: MediaStream): Promise; - enter(): Promise; - private dispose; - leave(): void; - terminate(emitStateEvent?: boolean): Promise; - isLocalVideoMuted(): boolean; - isMicrophoneMuted(): boolean; - /** - * Sets the mute state of the local participants's microphone. - * @param muted - Whether to mute the microphone - * @returns Whether muting/unmuting was successful - */ - setMicrophoneMuted(muted: boolean): Promise; - /** - * Sets the mute state of the local participants's video. - * @param muted - Whether to mute the video - * @returns Whether muting/unmuting was successful - */ - setLocalVideoMuted(muted: boolean): Promise; - setScreensharingEnabled(enabled: boolean, opts?: IScreensharingOpts): Promise; - isScreensharing(): boolean; - private onIncomingCall; - /** - * Determines whether a given participant expects us to call them (versus - * them calling us). - * @param userId - The participant's user ID. - * @param deviceId - The participant's device ID. - * @returns Whether we need to place an outgoing call to the participant. - */ - private wantsOutgoingCall; - /** - * Places calls to all participants that we're responsible for calling. - */ - private placeOutgoingCalls; - private getMemberStateEvents; - private onRetryCallLoop; - private initCall; - private disposeCall; - private onCallFeedsChanged; - private onCallStateChanged; - private onCallHangup; - private onCallReplaced; - getUserMediaFeed(userId: string, deviceId: string): CallFeed | undefined; - private addUserMediaFeed; - private replaceUserMediaFeed; - private removeUserMediaFeed; - private onActiveSpeakerLoop; - getScreenshareFeed(userId: string, deviceId: string): CallFeed | undefined; - private addScreenshareFeed; - private replaceScreenshareFeed; - private removeScreenshareFeed; - /** - * Recalculates and updates the participant map to match the room state. - */ - private updateParticipants; - /** - * Updates the local user's member state with the devices returned by the given function. - * @param fn - A function from the current devices to the new devices. If it - * returns null, the update will be skipped. - * @param keepAlive - Whether the request should outlive the window. - */ - private updateDevices; - private addDeviceToMemberState; - private updateMemberState; - /** - * Cleans up our member state by filtering out logged out devices, inactive - * devices, and our own device (if we know we haven't entered). - */ - cleanMemberState(): Promise; - private onRoomState; - private onParticipantsChanged; - private onStateChanged; - private onLocalFeedsChanged; - getGroupCallStats(): GroupCallStats; -} -//# sourceMappingURL=groupCall.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts.map deleted file mode 100644 index 89a0eb0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"groupCall.d.ts","sourceRoot":"","sources":["../../src/webrtc/groupCall.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js deleted file mode 100644 index d9c044b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js +++ /dev/null @@ -1,1184 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.OtherUserSpeakingError = exports.GroupCallUnknownDeviceError = exports.GroupCallType = exports.GroupCallTerminationReason = exports.GroupCallStatsReportEvent = exports.GroupCallState = exports.GroupCallIntent = exports.GroupCallEvent = exports.GroupCallErrorCode = exports.GroupCallError = exports.GroupCall = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _typedEventEmitter = require("../models/typed-event-emitter"); -var _callFeed = require("./callFeed"); -var _call = require("./call"); -var _roomState = require("../models/room-state"); -var _logger = require("../logger"); -var _ReEmitter = require("../ReEmitter"); -var _callEventTypes = require("./callEventTypes"); -var _event = require("../@types/event"); -var _callEventHandler = require("./callEventHandler"); -var _groupCallEventHandler = require("./groupCallEventHandler"); -var _utils = require("../utils"); -var _groupCallStats = require("./stats/groupCallStats"); -var _statsReport = require("./stats/statsReport"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -let GroupCallIntent; -exports.GroupCallIntent = GroupCallIntent; -(function (GroupCallIntent) { - GroupCallIntent["Ring"] = "m.ring"; - GroupCallIntent["Prompt"] = "m.prompt"; - GroupCallIntent["Room"] = "m.room"; -})(GroupCallIntent || (exports.GroupCallIntent = GroupCallIntent = {})); -let GroupCallType; -exports.GroupCallType = GroupCallType; -(function (GroupCallType) { - GroupCallType["Video"] = "m.video"; - GroupCallType["Voice"] = "m.voice"; -})(GroupCallType || (exports.GroupCallType = GroupCallType = {})); -let GroupCallTerminationReason; -exports.GroupCallTerminationReason = GroupCallTerminationReason; -(function (GroupCallTerminationReason) { - GroupCallTerminationReason["CallEnded"] = "call_ended"; -})(GroupCallTerminationReason || (exports.GroupCallTerminationReason = GroupCallTerminationReason = {})); -/** - * Because event names are just strings, they do need - * to be unique over all event types of event emitter. - * Some objects could emit more then one set of events. - */ -let GroupCallEvent; -exports.GroupCallEvent = GroupCallEvent; -(function (GroupCallEvent) { - GroupCallEvent["GroupCallStateChanged"] = "group_call_state_changed"; - GroupCallEvent["ActiveSpeakerChanged"] = "active_speaker_changed"; - GroupCallEvent["CallsChanged"] = "calls_changed"; - GroupCallEvent["UserMediaFeedsChanged"] = "user_media_feeds_changed"; - GroupCallEvent["ScreenshareFeedsChanged"] = "screenshare_feeds_changed"; - GroupCallEvent["LocalScreenshareStateChanged"] = "local_screenshare_state_changed"; - GroupCallEvent["LocalMuteStateChanged"] = "local_mute_state_changed"; - GroupCallEvent["ParticipantsChanged"] = "participants_changed"; - GroupCallEvent["Error"] = "group_call_error"; -})(GroupCallEvent || (exports.GroupCallEvent = GroupCallEvent = {})); -let GroupCallStatsReportEvent; -exports.GroupCallStatsReportEvent = GroupCallStatsReportEvent; -(function (GroupCallStatsReportEvent) { - GroupCallStatsReportEvent["ConnectionStats"] = "GroupCall.connection_stats"; - GroupCallStatsReportEvent["ByteSentStats"] = "GroupCall.byte_sent_stats"; -})(GroupCallStatsReportEvent || (exports.GroupCallStatsReportEvent = GroupCallStatsReportEvent = {})); -let GroupCallErrorCode; -exports.GroupCallErrorCode = GroupCallErrorCode; -(function (GroupCallErrorCode) { - GroupCallErrorCode["NoUserMedia"] = "no_user_media"; - GroupCallErrorCode["UnknownDevice"] = "unknown_device"; - GroupCallErrorCode["PlaceCallFailed"] = "place_call_failed"; -})(GroupCallErrorCode || (exports.GroupCallErrorCode = GroupCallErrorCode = {})); -class GroupCallError extends Error { - constructor(code, msg, err) { - // Still don't think there's any way to have proper nested errors - if (err) { - super(msg + ": " + err); - (0, _defineProperty2.default)(this, "code", void 0); - } else { - super(msg); - (0, _defineProperty2.default)(this, "code", void 0); - } - this.code = code; - } -} -exports.GroupCallError = GroupCallError; -class GroupCallUnknownDeviceError extends GroupCallError { - constructor(userId) { - super(GroupCallErrorCode.UnknownDevice, "No device found for " + userId); - this.userId = userId; - } -} -exports.GroupCallUnknownDeviceError = GroupCallUnknownDeviceError; -class OtherUserSpeakingError extends Error { - constructor() { - super("Cannot unmute: another user is speaking"); - } -} -exports.OtherUserSpeakingError = OtherUserSpeakingError; -let GroupCallState; -exports.GroupCallState = GroupCallState; -(function (GroupCallState) { - GroupCallState["LocalCallFeedUninitialized"] = "local_call_feed_uninitialized"; - GroupCallState["InitializingLocalCallFeed"] = "initializing_local_call_feed"; - GroupCallState["LocalCallFeedInitialized"] = "local_call_feed_initialized"; - GroupCallState["Entered"] = "entered"; - GroupCallState["Ended"] = "ended"; -})(GroupCallState || (exports.GroupCallState = GroupCallState = {})); -const DEVICE_TIMEOUT = 1000 * 60 * 60; // 1 hour - -function getCallUserId(call) { - var _call$getOpponentMemb; - return ((_call$getOpponentMemb = call.getOpponentMember()) === null || _call$getOpponentMemb === void 0 ? void 0 : _call$getOpponentMemb.userId) || call.invitee || null; -} -class GroupCall extends _typedEventEmitter.TypedEventEmitter { - // Config - - // user_id -> device_id -> MatrixCall - // user_id -> device_id -> ICallHandlers - - // user_id -> device_id -> count - - constructor(client, room, type, isPtt, intent, groupCallId, dataChannelsEnabled, dataChannelOptions, isCallWithoutVideoAndAudio) { - var _room$currentState$ge, _room$currentState$ge2; - super(); - this.client = client; - this.room = room; - this.type = type; - this.isPtt = isPtt; - this.intent = intent; - this.dataChannelsEnabled = dataChannelsEnabled; - this.dataChannelOptions = dataChannelOptions; - (0, _defineProperty2.default)(this, "activeSpeakerInterval", 1000); - (0, _defineProperty2.default)(this, "retryCallInterval", 5000); - (0, _defineProperty2.default)(this, "participantTimeout", 1000 * 15); - (0, _defineProperty2.default)(this, "pttMaxTransmitTime", 1000 * 20); - (0, _defineProperty2.default)(this, "activeSpeaker", void 0); - (0, _defineProperty2.default)(this, "localCallFeed", void 0); - (0, _defineProperty2.default)(this, "localScreenshareFeed", void 0); - (0, _defineProperty2.default)(this, "localDesktopCapturerSourceId", void 0); - (0, _defineProperty2.default)(this, "userMediaFeeds", []); - (0, _defineProperty2.default)(this, "screenshareFeeds", []); - (0, _defineProperty2.default)(this, "groupCallId", void 0); - (0, _defineProperty2.default)(this, "allowCallWithoutVideoAndAudio", void 0); - (0, _defineProperty2.default)(this, "calls", new Map()); - (0, _defineProperty2.default)(this, "callHandlers", new Map()); - (0, _defineProperty2.default)(this, "activeSpeakerLoopInterval", void 0); - (0, _defineProperty2.default)(this, "retryCallLoopInterval", void 0); - (0, _defineProperty2.default)(this, "retryCallCounts", new Map()); - (0, _defineProperty2.default)(this, "reEmitter", void 0); - (0, _defineProperty2.default)(this, "transmitTimer", null); - (0, _defineProperty2.default)(this, "participantsExpirationTimer", null); - (0, _defineProperty2.default)(this, "resendMemberStateTimer", null); - (0, _defineProperty2.default)(this, "initWithAudioMuted", false); - (0, _defineProperty2.default)(this, "initWithVideoMuted", false); - (0, _defineProperty2.default)(this, "initCallFeedPromise", void 0); - (0, _defineProperty2.default)(this, "stats", void 0); - (0, _defineProperty2.default)(this, "onConnectionStats", report => { - // @TODO: Implement data argumentation - this.emit(GroupCallStatsReportEvent.ConnectionStats, { - report - }); - }); - (0, _defineProperty2.default)(this, "onByteSentStats", report => { - // @TODO: Implement data argumentation - this.emit(GroupCallStatsReportEvent.ByteSentStats, { - report - }); - }); - (0, _defineProperty2.default)(this, "_state", GroupCallState.LocalCallFeedUninitialized); - (0, _defineProperty2.default)(this, "_participants", new Map()); - (0, _defineProperty2.default)(this, "_creationTs", null); - (0, _defineProperty2.default)(this, "_enteredViaAnotherSession", false); - (0, _defineProperty2.default)(this, "onIncomingCall", newCall => { - var _newCall$getOpponentM, _this$calls$get; - // The incoming calls may be for another room, which we will ignore. - if (newCall.roomId !== this.room.roomId) { - return; - } - if (newCall.state !== _call.CallState.Ringing) { - _logger.logger.warn(`GroupCall ${this.groupCallId} onIncomingCall() incoming call no longer in ringing state - ignoring`); - return; - } - if (!newCall.groupCallId || newCall.groupCallId !== this.groupCallId) { - _logger.logger.log(`GroupCall ${this.groupCallId} onIncomingCall() ignored because it doesn't match the current group call`); - newCall.reject(); - return; - } - const opponentUserId = (_newCall$getOpponentM = newCall.getOpponentMember()) === null || _newCall$getOpponentM === void 0 ? void 0 : _newCall$getOpponentM.userId; - if (opponentUserId === undefined) { - _logger.logger.warn(`GroupCall ${this.groupCallId} onIncomingCall() incoming call with no member - ignoring`); - return; - } - const deviceMap = (_this$calls$get = this.calls.get(opponentUserId)) !== null && _this$calls$get !== void 0 ? _this$calls$get : new Map(); - const prevCall = deviceMap.get(newCall.getOpponentDeviceId()); - if ((prevCall === null || prevCall === void 0 ? void 0 : prevCall.callId) === newCall.callId) return; - _logger.logger.log(`GroupCall ${this.groupCallId} onIncomingCall() incoming call (userId=${opponentUserId}, callId=${newCall.callId})`); - if (prevCall) prevCall.hangup(_call.CallErrorCode.Replaced, false); - this.initCall(newCall); - const feeds = this.getLocalFeeds().map(feed => feed.clone()); - if (!this.callExpected(newCall)) { - // Disable our tracks for users not explicitly participating in the - // call but trying to receive the feeds - for (const feed of feeds) { - (0, _call.setTracksEnabled)(feed.stream.getAudioTracks(), false); - (0, _call.setTracksEnabled)(feed.stream.getVideoTracks(), false); - } - } - newCall.answerWithCallFeeds(feeds); - deviceMap.set(newCall.getOpponentDeviceId(), newCall); - this.calls.set(opponentUserId, deviceMap); - this.emit(GroupCallEvent.CallsChanged, this.calls); - }); - (0, _defineProperty2.default)(this, "onRetryCallLoop", () => { - let needsRetry = false; - for (const [{ - userId - }, participantMap] of this.participants) { - const callMap = this.calls.get(userId); - let retriesMap = this.retryCallCounts.get(userId); - for (const [deviceId, participant] of participantMap) { - var _retriesMap$get, _retriesMap; - const call = callMap === null || callMap === void 0 ? void 0 : callMap.get(deviceId); - const retries = (_retriesMap$get = (_retriesMap = retriesMap) === null || _retriesMap === void 0 ? void 0 : _retriesMap.get(deviceId)) !== null && _retriesMap$get !== void 0 ? _retriesMap$get : 0; - if ((call === null || call === void 0 ? void 0 : call.getOpponentSessionId()) !== participant.sessionId && this.wantsOutgoingCall(userId, deviceId) && retries < 3) { - if (retriesMap === undefined) { - retriesMap = new Map(); - this.retryCallCounts.set(userId, retriesMap); - } - retriesMap.set(deviceId, retries + 1); - needsRetry = true; - } - } - } - if (needsRetry) this.placeOutgoingCalls(); - }); - (0, _defineProperty2.default)(this, "onCallFeedsChanged", call => { - const opponentMemberId = getCallUserId(call); - const opponentDeviceId = call.getOpponentDeviceId(); - if (!opponentMemberId) { - throw new Error("Cannot change call feeds without user id"); - } - const currentUserMediaFeed = this.getUserMediaFeed(opponentMemberId, opponentDeviceId); - const remoteUsermediaFeed = call.remoteUsermediaFeed; - const remoteFeedChanged = remoteUsermediaFeed !== currentUserMediaFeed; - if (remoteFeedChanged) { - if (!currentUserMediaFeed && remoteUsermediaFeed) { - this.addUserMediaFeed(remoteUsermediaFeed); - } else if (currentUserMediaFeed && remoteUsermediaFeed) { - this.replaceUserMediaFeed(currentUserMediaFeed, remoteUsermediaFeed); - } else if (currentUserMediaFeed && !remoteUsermediaFeed) { - this.removeUserMediaFeed(currentUserMediaFeed); - } - } - const currentScreenshareFeed = this.getScreenshareFeed(opponentMemberId, opponentDeviceId); - const remoteScreensharingFeed = call.remoteScreensharingFeed; - const remoteScreenshareFeedChanged = remoteScreensharingFeed !== currentScreenshareFeed; - if (remoteScreenshareFeedChanged) { - if (!currentScreenshareFeed && remoteScreensharingFeed) { - this.addScreenshareFeed(remoteScreensharingFeed); - } else if (currentScreenshareFeed && remoteScreensharingFeed) { - this.replaceScreenshareFeed(currentScreenshareFeed, remoteScreensharingFeed); - } else if (currentScreenshareFeed && !remoteScreensharingFeed) { - this.removeScreenshareFeed(currentScreenshareFeed); - } - } - }); - (0, _defineProperty2.default)(this, "onCallStateChanged", (call, state, _oldState) => { - var _call$getOpponentMemb2; - if (state === _call.CallState.Ended) return; - const audioMuted = this.localCallFeed.isAudioMuted(); - if (call.localUsermediaStream && call.isMicrophoneMuted() !== audioMuted) { - call.setMicrophoneMuted(audioMuted); - } - const videoMuted = this.localCallFeed.isVideoMuted(); - if (call.localUsermediaStream && call.isLocalVideoMuted() !== videoMuted) { - call.setLocalVideoMuted(videoMuted); - } - const opponentUserId = (_call$getOpponentMemb2 = call.getOpponentMember()) === null || _call$getOpponentMemb2 === void 0 ? void 0 : _call$getOpponentMemb2.userId; - if (state === _call.CallState.Connected && opponentUserId) { - const retriesMap = this.retryCallCounts.get(opponentUserId); - retriesMap === null || retriesMap === void 0 ? void 0 : retriesMap.delete(call.getOpponentDeviceId()); - if ((retriesMap === null || retriesMap === void 0 ? void 0 : retriesMap.size) === 0) this.retryCallCounts.delete(opponentUserId); - } - }); - (0, _defineProperty2.default)(this, "onCallHangup", call => { - var _call$getOpponentMemb3, _call$getOpponentMemb4; - if (call.hangupReason === _call.CallErrorCode.Replaced) return; - const opponentUserId = (_call$getOpponentMemb3 = (_call$getOpponentMemb4 = call.getOpponentMember()) === null || _call$getOpponentMemb4 === void 0 ? void 0 : _call$getOpponentMemb4.userId) !== null && _call$getOpponentMemb3 !== void 0 ? _call$getOpponentMemb3 : this.room.getMember(call.invitee).userId; - const deviceMap = this.calls.get(opponentUserId); - - // Sanity check that this call is in fact in the map - if ((deviceMap === null || deviceMap === void 0 ? void 0 : deviceMap.get(call.getOpponentDeviceId())) === call) { - this.disposeCall(call, call.hangupReason); - deviceMap.delete(call.getOpponentDeviceId()); - if (deviceMap.size === 0) this.calls.delete(opponentUserId); - this.emit(GroupCallEvent.CallsChanged, this.calls); - } - }); - (0, _defineProperty2.default)(this, "onCallReplaced", (prevCall, newCall) => { - const opponentUserId = prevCall.getOpponentMember().userId; - let deviceMap = this.calls.get(opponentUserId); - if (deviceMap === undefined) { - deviceMap = new Map(); - this.calls.set(opponentUserId, deviceMap); - } - prevCall.hangup(_call.CallErrorCode.Replaced, false); - this.initCall(newCall); - deviceMap.set(prevCall.getOpponentDeviceId(), newCall); - this.emit(GroupCallEvent.CallsChanged, this.calls); - }); - (0, _defineProperty2.default)(this, "onActiveSpeakerLoop", () => { - let topAvg = undefined; - let nextActiveSpeaker = undefined; - for (const callFeed of this.userMediaFeeds) { - if (callFeed.isLocal() && this.userMediaFeeds.length > 1) continue; - const total = callFeed.speakingVolumeSamples.reduce((acc, volume) => acc + Math.max(volume, _callFeed.SPEAKING_THRESHOLD)); - const avg = total / callFeed.speakingVolumeSamples.length; - if (!topAvg || avg > topAvg) { - topAvg = avg; - nextActiveSpeaker = callFeed; - } - } - if (nextActiveSpeaker && this.activeSpeaker !== nextActiveSpeaker && topAvg && topAvg > _callFeed.SPEAKING_THRESHOLD) { - this.activeSpeaker = nextActiveSpeaker; - this.emit(GroupCallEvent.ActiveSpeakerChanged, this.activeSpeaker); - } - }); - (0, _defineProperty2.default)(this, "onRoomState", () => this.updateParticipants()); - (0, _defineProperty2.default)(this, "onParticipantsChanged", () => { - // Re-run setTracksEnabled on all calls, so that participants that just - // left get denied access to our media, and participants that just - // joined get granted access - this.forEachCall(call => { - const expected = this.callExpected(call); - for (const feed of call.getLocalFeeds()) { - (0, _call.setTracksEnabled)(feed.stream.getAudioTracks(), !feed.isAudioMuted() && expected); - (0, _call.setTracksEnabled)(feed.stream.getVideoTracks(), !feed.isVideoMuted() && expected); - } - }); - if (this.state === GroupCallState.Entered) this.placeOutgoingCalls(); - }); - (0, _defineProperty2.default)(this, "onStateChanged", (newState, oldState) => { - if (newState === GroupCallState.Entered || oldState === GroupCallState.Entered || newState === GroupCallState.Ended) { - // We either entered, left, or ended the call - this.updateParticipants(); - this.updateMemberState().catch(e => _logger.logger.error(`GroupCall ${this.groupCallId} onStateChanged() failed to update member state devices"`, e)); - } - }); - (0, _defineProperty2.default)(this, "onLocalFeedsChanged", () => { - if (this.state === GroupCallState.Entered) { - this.updateMemberState().catch(e => _logger.logger.error(`GroupCall ${this.groupCallId} onLocalFeedsChanged() failed to update member state feeds`, e)); - } - }); - this.reEmitter = new _ReEmitter.ReEmitter(this); - this.groupCallId = groupCallId !== null && groupCallId !== void 0 ? groupCallId : (0, _call.genCallID)(); - this.creationTs = (_room$currentState$ge = (_room$currentState$ge2 = room.currentState.getStateEvents(_event.EventType.GroupCallPrefix, this.groupCallId)) === null || _room$currentState$ge2 === void 0 ? void 0 : _room$currentState$ge2.getTs()) !== null && _room$currentState$ge !== void 0 ? _room$currentState$ge : null; - this.updateParticipants(); - room.on(_roomState.RoomStateEvent.Update, this.onRoomState); - this.on(GroupCallEvent.ParticipantsChanged, this.onParticipantsChanged); - this.on(GroupCallEvent.GroupCallStateChanged, this.onStateChanged); - this.on(GroupCallEvent.LocalScreenshareStateChanged, this.onLocalFeedsChanged); - this.allowCallWithoutVideoAndAudio = !!isCallWithoutVideoAndAudio; - const userID = this.client.getUserId() || "unknown"; - this.stats = new _groupCallStats.GroupCallStats(this.groupCallId, userID); - this.stats.reports.on(_statsReport.StatsReport.CONNECTION_STATS, this.onConnectionStats); - this.stats.reports.on(_statsReport.StatsReport.BYTE_SENT_STATS, this.onByteSentStats); - } - async create() { - this.creationTs = Date.now(); - this.client.groupCallEventHandler.groupCalls.set(this.room.roomId, this); - this.client.emit(_groupCallEventHandler.GroupCallEventHandlerEvent.Outgoing, this); - const groupCallState = { - "m.intent": this.intent, - "m.type": this.type, - "io.element.ptt": this.isPtt, - // TODO: Specify data-channels better - "dataChannelsEnabled": this.dataChannelsEnabled, - "dataChannelOptions": this.dataChannelsEnabled ? this.dataChannelOptions : undefined - }; - await this.client.sendStateEvent(this.room.roomId, _event.EventType.GroupCallPrefix, groupCallState, this.groupCallId); - return this; - } - /** - * The group call's state. - */ - get state() { - return this._state; - } - set state(value) { - const prevValue = this._state; - if (value !== prevValue) { - this._state = value; - this.emit(GroupCallEvent.GroupCallStateChanged, value, prevValue); - } - } - /** - * The current participants in the call, as a map from members to device IDs - * to participant info. - */ - get participants() { - return this._participants; - } - set participants(value) { - const prevValue = this._participants; - const participantStateEqual = (x, y) => x.sessionId === y.sessionId && x.screensharing === y.screensharing; - const deviceMapsEqual = (x, y) => (0, _utils.mapsEqual)(x, y, participantStateEqual); - - // Only update if the map actually changed - if (!(0, _utils.mapsEqual)(value, prevValue, deviceMapsEqual)) { - this._participants = value; - this.emit(GroupCallEvent.ParticipantsChanged, value); - } - } - /** - * The timestamp at which the call was created, or null if it has not yet - * been created. - */ - get creationTs() { - return this._creationTs; - } - set creationTs(value) { - this._creationTs = value; - } - /** - * Whether the local device has entered this call via another session, such - * as a widget. - */ - get enteredViaAnotherSession() { - return this._enteredViaAnotherSession; - } - set enteredViaAnotherSession(value) { - this._enteredViaAnotherSession = value; - this.updateParticipants(); - } - - /** - * Executes the given callback on all calls in this group call. - * @param f - The callback. - */ - forEachCall(f) { - for (const deviceMap of this.calls.values()) { - for (const call of deviceMap.values()) f(call); - } - } - getLocalFeeds() { - const feeds = []; - if (this.localCallFeed) feeds.push(this.localCallFeed); - if (this.localScreenshareFeed) feeds.push(this.localScreenshareFeed); - return feeds; - } - hasLocalParticipant() { - var _this$participants$ge, _this$participants$ge2; - return (_this$participants$ge = (_this$participants$ge2 = this.participants.get(this.room.getMember(this.client.getUserId()))) === null || _this$participants$ge2 === void 0 ? void 0 : _this$participants$ge2.has(this.client.getDeviceId())) !== null && _this$participants$ge !== void 0 ? _this$participants$ge : false; - } - - /** - * Determines whether the given call is one that we were expecting to exist - * given our knowledge of who is participating in the group call. - */ - callExpected(call) { - var _this$participants$ge3; - const userId = getCallUserId(call); - const member = userId === null ? null : this.room.getMember(userId); - const deviceId = call.getOpponentDeviceId(); - return member !== null && deviceId !== undefined && ((_this$participants$ge3 = this.participants.get(member)) === null || _this$participants$ge3 === void 0 ? void 0 : _this$participants$ge3.get(deviceId)) !== undefined; - } - async initLocalCallFeed() { - if (this.state !== GroupCallState.LocalCallFeedUninitialized) { - throw new Error(`Cannot initialize local call feed in the "${this.state}" state.`); - } - this.state = GroupCallState.InitializingLocalCallFeed; - - // wraps the real method to serialise calls, because we don't want to try starting - // multiple call feeds at once - if (this.initCallFeedPromise) return this.initCallFeedPromise; - try { - this.initCallFeedPromise = this.initLocalCallFeedInternal(); - await this.initCallFeedPromise; - } finally { - this.initCallFeedPromise = undefined; - } - } - async initLocalCallFeedInternal() { - _logger.logger.log(`GroupCall ${this.groupCallId} initLocalCallFeedInternal() running`); - let stream; - try { - stream = await this.client.getMediaHandler().getUserMediaStream(true, this.type === GroupCallType.Video); - } catch (error) { - // If is allowed to join a call without a media stream, then we - // don't throw an error here. But we need an empty Local Feed to establish - // a connection later. - if (this.allowCallWithoutVideoAndAudio) { - stream = new MediaStream(); - } else { - this.state = GroupCallState.LocalCallFeedUninitialized; - throw error; - } - } - - // The call could've been disposed while we were waiting, and could - // also have been started back up again (hello, React 18) so if we're - // still in this 'initializing' state, carry on, otherwise bail. - if (this._state !== GroupCallState.InitializingLocalCallFeed) { - this.client.getMediaHandler().stopUserMediaStream(stream); - throw new Error("Group call disposed while gathering media stream"); - } - const callFeed = new _callFeed.CallFeed({ - client: this.client, - roomId: this.room.roomId, - userId: this.client.getUserId(), - deviceId: this.client.getDeviceId(), - stream, - purpose: _callEventTypes.SDPStreamMetadataPurpose.Usermedia, - audioMuted: this.initWithAudioMuted || stream.getAudioTracks().length === 0 || this.isPtt, - videoMuted: this.initWithVideoMuted || stream.getVideoTracks().length === 0 - }); - (0, _call.setTracksEnabled)(stream.getAudioTracks(), !callFeed.isAudioMuted()); - (0, _call.setTracksEnabled)(stream.getVideoTracks(), !callFeed.isVideoMuted()); - this.localCallFeed = callFeed; - this.addUserMediaFeed(callFeed); - this.state = GroupCallState.LocalCallFeedInitialized; - } - async updateLocalUsermediaStream(stream) { - if (this.localCallFeed) { - const oldStream = this.localCallFeed.stream; - this.localCallFeed.setNewStream(stream); - const micShouldBeMuted = this.localCallFeed.isAudioMuted(); - const vidShouldBeMuted = this.localCallFeed.isVideoMuted(); - _logger.logger.log(`GroupCall ${this.groupCallId} updateLocalUsermediaStream() (oldStreamId=${oldStream.id}, newStreamId=${stream.id}, micShouldBeMuted=${micShouldBeMuted}, vidShouldBeMuted=${vidShouldBeMuted})`); - (0, _call.setTracksEnabled)(stream.getAudioTracks(), !micShouldBeMuted); - (0, _call.setTracksEnabled)(stream.getVideoTracks(), !vidShouldBeMuted); - this.client.getMediaHandler().stopUserMediaStream(oldStream); - } - } - async enter() { - if (this.state === GroupCallState.LocalCallFeedUninitialized) { - await this.initLocalCallFeed(); - } else if (this.state !== GroupCallState.LocalCallFeedInitialized) { - throw new Error(`Cannot enter call in the "${this.state}" state`); - } - _logger.logger.log(`GroupCall ${this.groupCallId} enter() running`); - this.state = GroupCallState.Entered; - this.client.on(_callEventHandler.CallEventHandlerEvent.Incoming, this.onIncomingCall); - for (const call of this.client.callEventHandler.calls.values()) { - this.onIncomingCall(call); - } - this.retryCallLoopInterval = setInterval(this.onRetryCallLoop, this.retryCallInterval); - this.activeSpeaker = undefined; - this.onActiveSpeakerLoop(); - this.activeSpeakerLoopInterval = setInterval(this.onActiveSpeakerLoop, this.activeSpeakerInterval); - } - dispose() { - if (this.localCallFeed) { - this.removeUserMediaFeed(this.localCallFeed); - this.localCallFeed = undefined; - } - if (this.localScreenshareFeed) { - this.client.getMediaHandler().stopScreensharingStream(this.localScreenshareFeed.stream); - this.removeScreenshareFeed(this.localScreenshareFeed); - this.localScreenshareFeed = undefined; - this.localDesktopCapturerSourceId = undefined; - } - this.client.getMediaHandler().stopAllStreams(); - if (this.transmitTimer !== null) { - clearTimeout(this.transmitTimer); - this.transmitTimer = null; - } - if (this.retryCallLoopInterval !== undefined) { - clearInterval(this.retryCallLoopInterval); - this.retryCallLoopInterval = undefined; - } - if (this.participantsExpirationTimer !== null) { - clearTimeout(this.participantsExpirationTimer); - this.participantsExpirationTimer = null; - } - if (this.state !== GroupCallState.Entered) { - return; - } - this.forEachCall(call => call.hangup(_call.CallErrorCode.UserHangup, false)); - this.activeSpeaker = undefined; - clearInterval(this.activeSpeakerLoopInterval); - this.retryCallCounts.clear(); - clearInterval(this.retryCallLoopInterval); - this.client.removeListener(_callEventHandler.CallEventHandlerEvent.Incoming, this.onIncomingCall); - this.stats.stop(); - } - leave() { - this.dispose(); - this.state = GroupCallState.LocalCallFeedUninitialized; - } - async terminate(emitStateEvent = true) { - this.dispose(); - this.room.off(_roomState.RoomStateEvent.Update, this.onRoomState); - this.client.groupCallEventHandler.groupCalls.delete(this.room.roomId); - this.client.emit(_groupCallEventHandler.GroupCallEventHandlerEvent.Ended, this); - this.state = GroupCallState.Ended; - if (emitStateEvent) { - const existingStateEvent = this.room.currentState.getStateEvents(_event.EventType.GroupCallPrefix, this.groupCallId); - await this.client.sendStateEvent(this.room.roomId, _event.EventType.GroupCallPrefix, _objectSpread(_objectSpread({}, existingStateEvent.getContent()), {}, { - "m.terminated": GroupCallTerminationReason.CallEnded - }), this.groupCallId); - } - } - - /* - * Local Usermedia - */ - - isLocalVideoMuted() { - if (this.localCallFeed) { - return this.localCallFeed.isVideoMuted(); - } - return true; - } - isMicrophoneMuted() { - if (this.localCallFeed) { - return this.localCallFeed.isAudioMuted(); - } - return true; - } - - /** - * Sets the mute state of the local participants's microphone. - * @param muted - Whether to mute the microphone - * @returns Whether muting/unmuting was successful - */ - async setMicrophoneMuted(muted) { - // hasAudioDevice can block indefinitely if the window has lost focus, - // and it doesn't make much sense to keep a device from being muted, so - // we always allow muted = true changes to go through - if (!muted && !(await this.client.getMediaHandler().hasAudioDevice())) { - return false; - } - const sendUpdatesBefore = !muted && this.isPtt; - - // set a timer for the maximum transmit time on PTT calls - if (this.isPtt) { - // Set or clear the max transmit timer - if (!muted && this.isMicrophoneMuted()) { - this.transmitTimer = setTimeout(() => { - this.setMicrophoneMuted(true); - }, this.pttMaxTransmitTime); - } else if (muted && !this.isMicrophoneMuted()) { - if (this.transmitTimer !== null) clearTimeout(this.transmitTimer); - this.transmitTimer = null; - } - } - this.forEachCall(call => { - var _call$localUsermediaF; - return (_call$localUsermediaF = call.localUsermediaFeed) === null || _call$localUsermediaF === void 0 ? void 0 : _call$localUsermediaF.setAudioVideoMuted(muted, null); - }); - const sendUpdates = async () => { - const updates = []; - this.forEachCall(call => updates.push(call.sendMetadataUpdate())); - await Promise.all(updates).catch(e => _logger.logger.info(`GroupCall ${this.groupCallId} setMicrophoneMuted() failed to send some metadata updates`, e)); - }; - if (sendUpdatesBefore) await sendUpdates(); - if (this.localCallFeed) { - _logger.logger.log(`GroupCall ${this.groupCallId} setMicrophoneMuted() (streamId=${this.localCallFeed.stream.id}, muted=${muted})`); - - // We needed this here to avoid an error in case user join a call without a device. - // I can not use .then .catch functions because linter :-( - try { - if (!muted) { - const stream = await this.client.getMediaHandler().getUserMediaStream(true, !this.localCallFeed.isVideoMuted()); - if (stream === null) { - // if case permission denied to get a stream stop this here - /* istanbul ignore next */ - _logger.logger.log(`GroupCall ${this.groupCallId} setMicrophoneMuted() no device to receive local stream, muted=${muted}`); - return false; - } - } - } catch (e) { - /* istanbul ignore next */ - _logger.logger.log(`GroupCall ${this.groupCallId} setMicrophoneMuted() no device or permission to receive local stream, muted=${muted}`); - return false; - } - this.localCallFeed.setAudioVideoMuted(muted, null); - // I don't believe its actually necessary to enable these tracks: they - // are the one on the GroupCall's own CallFeed and are cloned before being - // given to any of the actual calls, so these tracks don't actually go - // anywhere. Let's do it anyway to avoid confusion. - (0, _call.setTracksEnabled)(this.localCallFeed.stream.getAudioTracks(), !muted); - } else { - _logger.logger.log(`GroupCall ${this.groupCallId} setMicrophoneMuted() no stream muted (muted=${muted})`); - this.initWithAudioMuted = muted; - } - this.forEachCall(call => (0, _call.setTracksEnabled)(call.localUsermediaFeed.stream.getAudioTracks(), !muted && this.callExpected(call))); - this.emit(GroupCallEvent.LocalMuteStateChanged, muted, this.isLocalVideoMuted()); - if (!sendUpdatesBefore) await sendUpdates(); - return true; - } - - /** - * Sets the mute state of the local participants's video. - * @param muted - Whether to mute the video - * @returns Whether muting/unmuting was successful - */ - async setLocalVideoMuted(muted) { - // hasAudioDevice can block indefinitely if the window has lost focus, - // and it doesn't make much sense to keep a device from being muted, so - // we always allow muted = true changes to go through - if (!muted && !(await this.client.getMediaHandler().hasVideoDevice())) { - return false; - } - if (this.localCallFeed) { - /* istanbul ignore next */ - _logger.logger.log(`GroupCall ${this.groupCallId} setLocalVideoMuted() (stream=${this.localCallFeed.stream.id}, muted=${muted})`); - try { - const stream = await this.client.getMediaHandler().getUserMediaStream(true, !muted); - await this.updateLocalUsermediaStream(stream); - this.localCallFeed.setAudioVideoMuted(null, muted); - (0, _call.setTracksEnabled)(this.localCallFeed.stream.getVideoTracks(), !muted); - } catch (_) { - // No permission to video device - /* istanbul ignore next */ - _logger.logger.log(`GroupCall ${this.groupCallId} setLocalVideoMuted() no device or permission to receive local stream, muted=${muted}`); - return false; - } - } else { - _logger.logger.log(`GroupCall ${this.groupCallId} setLocalVideoMuted() no stream muted (muted=${muted})`); - this.initWithVideoMuted = muted; - } - const updates = []; - this.forEachCall(call => updates.push(call.setLocalVideoMuted(muted))); - await Promise.all(updates); - - // We setTracksEnabled again, independently from the call doing it - // internally, since we might not be expecting the call - this.forEachCall(call => (0, _call.setTracksEnabled)(call.localUsermediaFeed.stream.getVideoTracks(), !muted && this.callExpected(call))); - this.emit(GroupCallEvent.LocalMuteStateChanged, this.isMicrophoneMuted(), muted); - return true; - } - async setScreensharingEnabled(enabled, opts = {}) { - if (enabled === this.isScreensharing()) { - return enabled; - } - if (enabled) { - try { - _logger.logger.log(`GroupCall ${this.groupCallId} setScreensharingEnabled() is asking for screensharing permissions`); - const stream = await this.client.getMediaHandler().getScreensharingStream(opts); - for (const track of stream.getTracks()) { - const onTrackEnded = () => { - this.setScreensharingEnabled(false); - track.removeEventListener("ended", onTrackEnded); - }; - track.addEventListener("ended", onTrackEnded); - } - _logger.logger.log(`GroupCall ${this.groupCallId} setScreensharingEnabled() granted screensharing permissions. Setting screensharing enabled on all calls`); - this.localDesktopCapturerSourceId = opts.desktopCapturerSourceId; - this.localScreenshareFeed = new _callFeed.CallFeed({ - client: this.client, - roomId: this.room.roomId, - userId: this.client.getUserId(), - deviceId: this.client.getDeviceId(), - stream, - purpose: _callEventTypes.SDPStreamMetadataPurpose.Screenshare, - audioMuted: false, - videoMuted: false - }); - this.addScreenshareFeed(this.localScreenshareFeed); - this.emit(GroupCallEvent.LocalScreenshareStateChanged, true, this.localScreenshareFeed, this.localDesktopCapturerSourceId); - - // TODO: handle errors - this.forEachCall(call => call.pushLocalFeed(this.localScreenshareFeed.clone())); - return true; - } catch (error) { - if (opts.throwOnFail) throw error; - _logger.logger.error(`GroupCall ${this.groupCallId} setScreensharingEnabled() enabling screensharing error`, error); - this.emit(GroupCallEvent.Error, new GroupCallError(GroupCallErrorCode.NoUserMedia, "Failed to get screen-sharing stream: ", error)); - return false; - } - } else { - this.forEachCall(call => { - if (call.localScreensharingFeed) call.removeLocalFeed(call.localScreensharingFeed); - }); - this.client.getMediaHandler().stopScreensharingStream(this.localScreenshareFeed.stream); - this.removeScreenshareFeed(this.localScreenshareFeed); - this.localScreenshareFeed = undefined; - this.localDesktopCapturerSourceId = undefined; - this.emit(GroupCallEvent.LocalScreenshareStateChanged, false, undefined, undefined); - return false; - } - } - isScreensharing() { - return !!this.localScreenshareFeed; - } - - /* - * Call Setup - * - * There are two different paths for calls to be created: - * 1. Incoming calls triggered by the Call.incoming event. - * 2. Outgoing calls to the initial members of a room or new members - * as they are observed by the RoomState.members event. - */ - - /** - * Determines whether a given participant expects us to call them (versus - * them calling us). - * @param userId - The participant's user ID. - * @param deviceId - The participant's device ID. - * @returns Whether we need to place an outgoing call to the participant. - */ - wantsOutgoingCall(userId, deviceId) { - const localUserId = this.client.getUserId(); - const localDeviceId = this.client.getDeviceId(); - return ( - // If a user's ID is less than our own, they'll call us - userId >= localUserId && ( - // If this is another one of our devices, compare device IDs to tell whether it'll call us - userId !== localUserId || deviceId > localDeviceId) - ); - } - - /** - * Places calls to all participants that we're responsible for calling. - */ - placeOutgoingCalls() { - let callsChanged = false; - for (const [{ - userId - }, participantMap] of this.participants) { - var _this$calls$get2; - const callMap = (_this$calls$get2 = this.calls.get(userId)) !== null && _this$calls$get2 !== void 0 ? _this$calls$get2 : new Map(); - for (const [deviceId, participant] of participantMap) { - const prevCall = callMap.get(deviceId); - if ((prevCall === null || prevCall === void 0 ? void 0 : prevCall.getOpponentSessionId()) !== participant.sessionId && this.wantsOutgoingCall(userId, deviceId)) { - callsChanged = true; - if (prevCall !== undefined) { - _logger.logger.debug(`GroupCall ${this.groupCallId} placeOutgoingCalls() replacing call (userId=${userId}, deviceId=${deviceId}, callId=${prevCall.callId})`); - prevCall.hangup(_call.CallErrorCode.NewSession, false); - } - const newCall = (0, _call.createNewMatrixCall)(this.client, this.room.roomId, { - invitee: userId, - opponentDeviceId: deviceId, - opponentSessionId: participant.sessionId, - groupCallId: this.groupCallId - }); - if (newCall === null) { - _logger.logger.error(`GroupCall ${this.groupCallId} placeOutgoingCalls() failed to create call (userId=${userId}, device=${deviceId})`); - callMap.delete(deviceId); - } else { - this.initCall(newCall); - callMap.set(deviceId, newCall); - _logger.logger.debug(`GroupCall ${this.groupCallId} placeOutgoingCalls() placing call (userId=${userId}, deviceId=${deviceId}, sessionId=${participant.sessionId})`); - newCall.placeCallWithCallFeeds(this.getLocalFeeds().map(feed => feed.clone()), participant.screensharing).then(() => { - if (this.dataChannelsEnabled) { - newCall.createDataChannel("datachannel", this.dataChannelOptions); - } - }).catch(e => { - _logger.logger.warn(`GroupCall ${this.groupCallId} placeOutgoingCalls() failed to place call (userId=${userId})`, e); - if (e instanceof _call.CallError && e.code === GroupCallErrorCode.UnknownDevice) { - this.emit(GroupCallEvent.Error, e); - } else { - this.emit(GroupCallEvent.Error, new GroupCallError(GroupCallErrorCode.PlaceCallFailed, `Failed to place call to ${userId}`)); - } - newCall.hangup(_call.CallErrorCode.SignallingFailed, false); - if (callMap.get(deviceId) === newCall) callMap.delete(deviceId); - }); - } - } - } - if (callMap.size > 0) { - this.calls.set(userId, callMap); - } else { - this.calls.delete(userId); - } - } - if (callsChanged) this.emit(GroupCallEvent.CallsChanged, this.calls); - } - - /* - * Room Member State - */ - - getMemberStateEvents(userId) { - return userId === undefined ? this.room.currentState.getStateEvents(_event.EventType.GroupCallMemberPrefix) : this.room.currentState.getStateEvents(_event.EventType.GroupCallMemberPrefix, userId); - } - initCall(call) { - const opponentMemberId = getCallUserId(call); - if (!opponentMemberId) { - throw new Error("Cannot init call without user id"); - } - const onCallFeedsChanged = () => this.onCallFeedsChanged(call); - const onCallStateChanged = (state, oldState) => this.onCallStateChanged(call, state, oldState); - const onCallHangup = this.onCallHangup; - const onCallReplaced = newCall => this.onCallReplaced(call, newCall); - let deviceMap = this.callHandlers.get(opponentMemberId); - if (deviceMap === undefined) { - deviceMap = new Map(); - this.callHandlers.set(opponentMemberId, deviceMap); - } - deviceMap.set(call.getOpponentDeviceId(), { - onCallFeedsChanged, - onCallStateChanged, - onCallHangup, - onCallReplaced - }); - call.on(_call.CallEvent.FeedsChanged, onCallFeedsChanged); - call.on(_call.CallEvent.State, onCallStateChanged); - call.on(_call.CallEvent.Hangup, onCallHangup); - call.on(_call.CallEvent.Replaced, onCallReplaced); - call.isPtt = this.isPtt; - this.reEmitter.reEmit(call, Object.values(_call.CallEvent)); - call.initStats(this.stats); - onCallFeedsChanged(); - } - disposeCall(call, hangupReason) { - const opponentMemberId = getCallUserId(call); - const opponentDeviceId = call.getOpponentDeviceId(); - if (!opponentMemberId) { - throw new Error("Cannot dispose call without user id"); - } - const deviceMap = this.callHandlers.get(opponentMemberId); - const { - onCallFeedsChanged, - onCallStateChanged, - onCallHangup, - onCallReplaced - } = deviceMap.get(opponentDeviceId); - call.removeListener(_call.CallEvent.FeedsChanged, onCallFeedsChanged); - call.removeListener(_call.CallEvent.State, onCallStateChanged); - call.removeListener(_call.CallEvent.Hangup, onCallHangup); - call.removeListener(_call.CallEvent.Replaced, onCallReplaced); - deviceMap.delete(opponentMemberId); - if (deviceMap.size === 0) this.callHandlers.delete(opponentMemberId); - if (call.hangupReason === _call.CallErrorCode.Replaced) { - return; - } - const usermediaFeed = this.getUserMediaFeed(opponentMemberId, opponentDeviceId); - if (usermediaFeed) { - this.removeUserMediaFeed(usermediaFeed); - } - const screenshareFeed = this.getScreenshareFeed(opponentMemberId, opponentDeviceId); - if (screenshareFeed) { - this.removeScreenshareFeed(screenshareFeed); - } - } - /* - * UserMedia CallFeed Event Handlers - */ - - getUserMediaFeed(userId, deviceId) { - return this.userMediaFeeds.find(f => f.userId === userId && f.deviceId === deviceId); - } - addUserMediaFeed(callFeed) { - this.userMediaFeeds.push(callFeed); - callFeed.measureVolumeActivity(true); - this.emit(GroupCallEvent.UserMediaFeedsChanged, this.userMediaFeeds); - } - replaceUserMediaFeed(existingFeed, replacementFeed) { - const feedIndex = this.userMediaFeeds.findIndex(f => f.userId === existingFeed.userId && f.deviceId === existingFeed.deviceId); - if (feedIndex === -1) { - throw new Error("Couldn't find user media feed to replace"); - } - this.userMediaFeeds.splice(feedIndex, 1, replacementFeed); - existingFeed.dispose(); - replacementFeed.measureVolumeActivity(true); - this.emit(GroupCallEvent.UserMediaFeedsChanged, this.userMediaFeeds); - } - removeUserMediaFeed(callFeed) { - const feedIndex = this.userMediaFeeds.findIndex(f => f.userId === callFeed.userId && f.deviceId === callFeed.deviceId); - if (feedIndex === -1) { - throw new Error("Couldn't find user media feed to remove"); - } - this.userMediaFeeds.splice(feedIndex, 1); - callFeed.dispose(); - this.emit(GroupCallEvent.UserMediaFeedsChanged, this.userMediaFeeds); - if (this.activeSpeaker === callFeed) { - this.activeSpeaker = this.userMediaFeeds[0]; - this.emit(GroupCallEvent.ActiveSpeakerChanged, this.activeSpeaker); - } - } - /* - * Screenshare Call Feed Event Handlers - */ - - getScreenshareFeed(userId, deviceId) { - return this.screenshareFeeds.find(f => f.userId === userId && f.deviceId === deviceId); - } - addScreenshareFeed(callFeed) { - this.screenshareFeeds.push(callFeed); - this.emit(GroupCallEvent.ScreenshareFeedsChanged, this.screenshareFeeds); - } - replaceScreenshareFeed(existingFeed, replacementFeed) { - const feedIndex = this.screenshareFeeds.findIndex(f => f.userId === existingFeed.userId && f.deviceId === existingFeed.deviceId); - if (feedIndex === -1) { - throw new Error("Couldn't find screenshare feed to replace"); - } - this.screenshareFeeds.splice(feedIndex, 1, replacementFeed); - existingFeed.dispose(); - this.emit(GroupCallEvent.ScreenshareFeedsChanged, this.screenshareFeeds); - } - removeScreenshareFeed(callFeed) { - const feedIndex = this.screenshareFeeds.findIndex(f => f.userId === callFeed.userId && f.deviceId === callFeed.deviceId); - if (feedIndex === -1) { - throw new Error("Couldn't find screenshare feed to remove"); - } - this.screenshareFeeds.splice(feedIndex, 1); - callFeed.dispose(); - this.emit(GroupCallEvent.ScreenshareFeedsChanged, this.screenshareFeeds); - } - - /** - * Recalculates and updates the participant map to match the room state. - */ - updateParticipants() { - const localMember = this.room.getMember(this.client.getUserId()); - if (!localMember) { - // The client hasn't fetched enough of the room state to get our own member - // event. This probably shouldn't happen, but sanity check & exit for now. - _logger.logger.warn(`GroupCall ${this.groupCallId} updateParticipants() tried to update participants before local room member is available`); - return; - } - if (this.participantsExpirationTimer !== null) { - clearTimeout(this.participantsExpirationTimer); - this.participantsExpirationTimer = null; - } - if (this.state === GroupCallState.Ended) { - this.participants = new Map(); - return; - } - const participants = new Map(); - const now = Date.now(); - const entered = this.state === GroupCallState.Entered || this.enteredViaAnotherSession; - let nextExpiration = Infinity; - for (const e of this.getMemberStateEvents()) { - const member = this.room.getMember(e.getStateKey()); - const content = e.getContent(); - const calls = Array.isArray(content["m.calls"]) ? content["m.calls"] : []; - const call = calls.find(call => call["m.call_id"] === this.groupCallId); - const devices = Array.isArray(call === null || call === void 0 ? void 0 : call["m.devices"]) ? call["m.devices"] : []; - - // Filter out invalid and expired devices - let validDevices = devices.filter(d => typeof d.device_id === "string" && typeof d.session_id === "string" && typeof d.expires_ts === "number" && d.expires_ts > now && Array.isArray(d.feeds)); - - // Apply local echo for the unentered case - if (!entered && (member === null || member === void 0 ? void 0 : member.userId) === this.client.getUserId()) { - validDevices = validDevices.filter(d => d.device_id !== this.client.getDeviceId()); - } - - // Must have a connected device and be joined to the room - if (validDevices.length > 0 && (member === null || member === void 0 ? void 0 : member.membership) === "join") { - const deviceMap = new Map(); - participants.set(member, deviceMap); - for (const d of validDevices) { - deviceMap.set(d.device_id, { - sessionId: d.session_id, - screensharing: d.feeds.some(f => f.purpose === _callEventTypes.SDPStreamMetadataPurpose.Screenshare) - }); - if (d.expires_ts < nextExpiration) nextExpiration = d.expires_ts; - } - } - } - - // Apply local echo for the entered case - if (entered) { - let deviceMap = participants.get(localMember); - if (deviceMap === undefined) { - deviceMap = new Map(); - participants.set(localMember, deviceMap); - } - if (!deviceMap.has(this.client.getDeviceId())) { - deviceMap.set(this.client.getDeviceId(), { - sessionId: this.client.getSessionId(), - screensharing: this.getLocalFeeds().some(f => f.purpose === _callEventTypes.SDPStreamMetadataPurpose.Screenshare) - }); - } - } - this.participants = participants; - if (nextExpiration < Infinity) { - this.participantsExpirationTimer = setTimeout(() => this.updateParticipants(), nextExpiration - now); - } - } - - /** - * Updates the local user's member state with the devices returned by the given function. - * @param fn - A function from the current devices to the new devices. If it - * returns null, the update will be skipped. - * @param keepAlive - Whether the request should outlive the window. - */ - async updateDevices(fn, keepAlive = false) { - var _event$getContent; - const now = Date.now(); - const localUserId = this.client.getUserId(); - const event = this.getMemberStateEvents(localUserId); - const content = (_event$getContent = event === null || event === void 0 ? void 0 : event.getContent()) !== null && _event$getContent !== void 0 ? _event$getContent : {}; - const calls = Array.isArray(content["m.calls"]) ? content["m.calls"] : []; - let call = null; - const otherCalls = []; - for (const c of calls) { - if (c["m.call_id"] === this.groupCallId) { - call = c; - } else { - otherCalls.push(c); - } - } - if (call === null) call = {}; - const devices = Array.isArray(call["m.devices"]) ? call["m.devices"] : []; - - // Filter out invalid and expired devices - const validDevices = devices.filter(d => typeof d.device_id === "string" && typeof d.session_id === "string" && typeof d.expires_ts === "number" && d.expires_ts > now && Array.isArray(d.feeds)); - const newDevices = fn(validDevices); - if (newDevices === null) return; - const newCalls = [...otherCalls]; - if (newDevices.length > 0) { - newCalls.push(_objectSpread(_objectSpread({}, call), {}, { - "m.call_id": this.groupCallId, - "m.devices": newDevices - })); - } - const newContent = { - "m.calls": newCalls - }; - await this.client.sendStateEvent(this.room.roomId, _event.EventType.GroupCallMemberPrefix, newContent, localUserId, { - keepAlive - }); - } - async addDeviceToMemberState() { - await this.updateDevices(devices => [...devices.filter(d => d.device_id !== this.client.getDeviceId()), { - device_id: this.client.getDeviceId(), - session_id: this.client.getSessionId(), - expires_ts: Date.now() + DEVICE_TIMEOUT, - feeds: this.getLocalFeeds().map(feed => ({ - purpose: feed.purpose - })) - // TODO: Add data channels - }]); - } - - async updateMemberState() { - // Clear the old update interval before proceeding - if (this.resendMemberStateTimer !== null) { - clearInterval(this.resendMemberStateTimer); - this.resendMemberStateTimer = null; - } - if (this.state === GroupCallState.Entered) { - // Add the local device - await this.addDeviceToMemberState(); - - // Resend the state event every so often so it doesn't become stale - this.resendMemberStateTimer = setInterval(async () => { - _logger.logger.log(`GroupCall ${this.groupCallId} updateMemberState() resending call member state"`); - try { - await this.addDeviceToMemberState(); - } catch (e) { - _logger.logger.error(`GroupCall ${this.groupCallId} updateMemberState() failed to resend call member state`, e); - } - }, DEVICE_TIMEOUT * 3 / 4); - } else { - // Remove the local device - await this.updateDevices(devices => devices.filter(d => d.device_id !== this.client.getDeviceId()), true); - } - } - - /** - * Cleans up our member state by filtering out logged out devices, inactive - * devices, and our own device (if we know we haven't entered). - */ - async cleanMemberState() { - const { - devices: myDevices - } = await this.client.getDevices(); - const deviceMap = new Map(myDevices.map(d => [d.device_id, d])); - - // updateDevices takes care of filtering out inactive devices for us - await this.updateDevices(devices => { - const newDevices = devices.filter(d => { - const device = deviceMap.get(d.device_id); - return (device === null || device === void 0 ? void 0 : device.last_seen_ts) !== undefined && !(d.device_id === this.client.getDeviceId() && this.state !== GroupCallState.Entered && !this.enteredViaAnotherSession); - }); - - // Skip the update if the devices are unchanged - return newDevices.length === devices.length ? null : newDevices; - }); - } - getGroupCallStats() { - return this.stats; - } -} -exports.GroupCall = GroupCall; -//# sourceMappingURL=groupCall.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js.map deleted file mode 100644 index aee367e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCall.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"groupCall.js","names":["_typedEventEmitter","require","_callFeed","_call","_roomState","_logger","_ReEmitter","_callEventTypes","_event","_callEventHandler","_groupCallEventHandler","_utils","_groupCallStats","_statsReport","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","GroupCallIntent","exports","GroupCallType","GroupCallTerminationReason","GroupCallEvent","GroupCallStatsReportEvent","GroupCallErrorCode","GroupCallError","Error","constructor","code","msg","err","GroupCallUnknownDeviceError","userId","UnknownDevice","OtherUserSpeakingError","GroupCallState","DEVICE_TIMEOUT","getCallUserId","call","_call$getOpponentMemb","getOpponentMember","invitee","GroupCall","TypedEventEmitter","client","room","type","isPtt","intent","groupCallId","dataChannelsEnabled","dataChannelOptions","isCallWithoutVideoAndAudio","_room$currentState$ge","_room$currentState$ge2","Map","report","emit","ConnectionStats","ByteSentStats","LocalCallFeedUninitialized","newCall","_newCall$getOpponentM","_this$calls$get","roomId","state","CallState","Ringing","logger","warn","log","reject","opponentUserId","undefined","deviceMap","calls","get","prevCall","getOpponentDeviceId","callId","hangup","CallErrorCode","Replaced","initCall","feeds","getLocalFeeds","map","feed","clone","callExpected","setTracksEnabled","stream","getAudioTracks","getVideoTracks","answerWithCallFeeds","set","CallsChanged","needsRetry","participantMap","participants","callMap","retriesMap","retryCallCounts","deviceId","participant","_retriesMap$get","_retriesMap","retries","getOpponentSessionId","sessionId","wantsOutgoingCall","placeOutgoingCalls","opponentMemberId","opponentDeviceId","currentUserMediaFeed","getUserMediaFeed","remoteUsermediaFeed","remoteFeedChanged","addUserMediaFeed","replaceUserMediaFeed","removeUserMediaFeed","currentScreenshareFeed","getScreenshareFeed","remoteScreensharingFeed","remoteScreenshareFeedChanged","addScreenshareFeed","replaceScreenshareFeed","removeScreenshareFeed","_oldState","_call$getOpponentMemb2","Ended","audioMuted","localCallFeed","isAudioMuted","localUsermediaStream","isMicrophoneMuted","setMicrophoneMuted","videoMuted","isVideoMuted","isLocalVideoMuted","setLocalVideoMuted","Connected","delete","size","_call$getOpponentMemb3","_call$getOpponentMemb4","hangupReason","getMember","disposeCall","topAvg","nextActiveSpeaker","callFeed","userMediaFeeds","isLocal","total","speakingVolumeSamples","reduce","acc","volume","Math","max","SPEAKING_THRESHOLD","avg","activeSpeaker","ActiveSpeakerChanged","updateParticipants","forEachCall","expected","Entered","newState","oldState","updateMemberState","catch","e","error","reEmitter","ReEmitter","genCallID","creationTs","currentState","getStateEvents","EventType","GroupCallPrefix","getTs","on","RoomStateEvent","Update","onRoomState","ParticipantsChanged","onParticipantsChanged","GroupCallStateChanged","onStateChanged","LocalScreenshareStateChanged","onLocalFeedsChanged","allowCallWithoutVideoAndAudio","userID","getUserId","stats","GroupCallStats","reports","StatsReport","CONNECTION_STATS","onConnectionStats","BYTE_SENT_STATS","onByteSentStats","create","Date","now","groupCallEventHandler","groupCalls","GroupCallEventHandlerEvent","Outgoing","groupCallState","sendStateEvent","_state","value","prevValue","_participants","participantStateEqual","x","y","screensharing","deviceMapsEqual","mapsEqual","_creationTs","enteredViaAnotherSession","_enteredViaAnotherSession","f","values","localScreenshareFeed","hasLocalParticipant","_this$participants$ge","_this$participants$ge2","has","getDeviceId","_this$participants$ge3","member","initLocalCallFeed","InitializingLocalCallFeed","initCallFeedPromise","initLocalCallFeedInternal","getMediaHandler","getUserMediaStream","Video","MediaStream","stopUserMediaStream","CallFeed","purpose","SDPStreamMetadataPurpose","Usermedia","initWithAudioMuted","initWithVideoMuted","LocalCallFeedInitialized","updateLocalUsermediaStream","oldStream","setNewStream","micShouldBeMuted","vidShouldBeMuted","id","enter","CallEventHandlerEvent","Incoming","onIncomingCall","callEventHandler","retryCallLoopInterval","setInterval","onRetryCallLoop","retryCallInterval","onActiveSpeakerLoop","activeSpeakerLoopInterval","activeSpeakerInterval","dispose","stopScreensharingStream","localDesktopCapturerSourceId","stopAllStreams","transmitTimer","clearTimeout","clearInterval","participantsExpirationTimer","UserHangup","clear","removeListener","stop","leave","terminate","emitStateEvent","off","existingStateEvent","getContent","CallEnded","muted","hasAudioDevice","sendUpdatesBefore","setTimeout","pttMaxTransmitTime","_call$localUsermediaF","localUsermediaFeed","setAudioVideoMuted","sendUpdates","updates","sendMetadataUpdate","Promise","all","info","LocalMuteStateChanged","hasVideoDevice","_","setScreensharingEnabled","enabled","opts","isScreensharing","getScreensharingStream","track","getTracks","onTrackEnded","removeEventListener","addEventListener","desktopCapturerSourceId","Screenshare","pushLocalFeed","throwOnFail","NoUserMedia","localScreensharingFeed","removeLocalFeed","localUserId","localDeviceId","callsChanged","_this$calls$get2","debug","NewSession","createNewMatrixCall","opponentSessionId","placeCallWithCallFeeds","then","createDataChannel","CallError","PlaceCallFailed","SignallingFailed","getMemberStateEvents","GroupCallMemberPrefix","onCallFeedsChanged","onCallStateChanged","onCallHangup","onCallReplaced","callHandlers","CallEvent","FeedsChanged","State","Hangup","reEmit","initStats","usermediaFeed","screenshareFeed","find","measureVolumeActivity","UserMediaFeedsChanged","existingFeed","replacementFeed","feedIndex","findIndex","splice","screenshareFeeds","ScreenshareFeedsChanged","localMember","entered","nextExpiration","Infinity","getStateKey","content","Array","isArray","devices","validDevices","d","device_id","session_id","expires_ts","membership","some","getSessionId","updateDevices","fn","keepAlive","_event$getContent","event","otherCalls","c","newDevices","newCalls","newContent","addDeviceToMemberState","resendMemberStateTimer","cleanMemberState","myDevices","getDevices","device","last_seen_ts","getGroupCallStats"],"sources":["../../src/webrtc/groupCall.ts"],"sourcesContent":["import { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { CallFeed, SPEAKING_THRESHOLD } from \"./callFeed\";\nimport { MatrixClient, IMyDevice } from \"../client\";\nimport {\n CallErrorCode,\n CallEvent,\n CallEventHandlerMap,\n CallState,\n genCallID,\n MatrixCall,\n setTracksEnabled,\n createNewMatrixCall,\n CallError,\n} from \"./call\";\nimport { RoomMember } from \"../models/room-member\";\nimport { Room } from \"../models/room\";\nimport { RoomStateEvent } from \"../models/room-state\";\nimport { logger } from \"../logger\";\nimport { ReEmitter } from \"../ReEmitter\";\nimport { SDPStreamMetadataPurpose } from \"./callEventTypes\";\nimport { MatrixEvent } from \"../models/event\";\nimport { EventType } from \"../@types/event\";\nimport { CallEventHandlerEvent } from \"./callEventHandler\";\nimport { GroupCallEventHandlerEvent } from \"./groupCallEventHandler\";\nimport { IScreensharingOpts } from \"./mediaHandler\";\nimport { mapsEqual } from \"../utils\";\nimport { GroupCallStats } from \"./stats/groupCallStats\";\nimport { ByteSentStatsReport, ConnectionStatsReport, StatsReport } from \"./stats/statsReport\";\n\nexport enum GroupCallIntent {\n Ring = \"m.ring\",\n Prompt = \"m.prompt\",\n Room = \"m.room\",\n}\n\nexport enum GroupCallType {\n Video = \"m.video\",\n Voice = \"m.voice\",\n}\n\nexport enum GroupCallTerminationReason {\n CallEnded = \"call_ended\",\n}\n\nexport type CallsByUserAndDevice = Map>;\n\n/**\n * Because event names are just strings, they do need\n * to be unique over all event types of event emitter.\n * Some objects could emit more then one set of events.\n */\nexport enum GroupCallEvent {\n GroupCallStateChanged = \"group_call_state_changed\",\n ActiveSpeakerChanged = \"active_speaker_changed\",\n CallsChanged = \"calls_changed\",\n UserMediaFeedsChanged = \"user_media_feeds_changed\",\n ScreenshareFeedsChanged = \"screenshare_feeds_changed\",\n LocalScreenshareStateChanged = \"local_screenshare_state_changed\",\n LocalMuteStateChanged = \"local_mute_state_changed\",\n ParticipantsChanged = \"participants_changed\",\n Error = \"group_call_error\",\n}\n\nexport type GroupCallEventHandlerMap = {\n [GroupCallEvent.GroupCallStateChanged]: (newState: GroupCallState, oldState: GroupCallState) => void;\n [GroupCallEvent.ActiveSpeakerChanged]: (activeSpeaker: CallFeed | undefined) => void;\n [GroupCallEvent.CallsChanged]: (calls: CallsByUserAndDevice) => void;\n [GroupCallEvent.UserMediaFeedsChanged]: (feeds: CallFeed[]) => void;\n [GroupCallEvent.ScreenshareFeedsChanged]: (feeds: CallFeed[]) => void;\n [GroupCallEvent.LocalScreenshareStateChanged]: (\n isScreensharing: boolean,\n feed?: CallFeed,\n sourceId?: string,\n ) => void;\n [GroupCallEvent.LocalMuteStateChanged]: (audioMuted: boolean, videoMuted: boolean) => void;\n [GroupCallEvent.ParticipantsChanged]: (participants: Map>) => void;\n /**\n * Fires whenever an error occurs when call.js encounters an issue with setting up the call.\n *

\n * The error given will have a code equal to either `MatrixCall.ERR_LOCAL_OFFER_FAILED` or\n * `MatrixCall.ERR_NO_USER_MEDIA`. `ERR_LOCAL_OFFER_FAILED` is emitted when the local client\n * fails to create an offer. `ERR_NO_USER_MEDIA` is emitted when the user has denied access\n * to their audio/video hardware.\n * @param err - The error raised by MatrixCall.\n * @example\n * ```\n * matrixCall.on(\"error\", function(err){\n * console.error(err.code, err);\n * });\n * ```\n */\n [GroupCallEvent.Error]: (error: GroupCallError) => void;\n};\n\nexport enum GroupCallStatsReportEvent {\n ConnectionStats = \"GroupCall.connection_stats\",\n ByteSentStats = \"GroupCall.byte_sent_stats\",\n}\n\nexport type GroupCallStatsReportEventHandlerMap = {\n [GroupCallStatsReportEvent.ConnectionStats]: (report: GroupCallStatsReport) => void;\n [GroupCallStatsReportEvent.ByteSentStats]: (report: GroupCallStatsReport) => void;\n};\n\nexport enum GroupCallErrorCode {\n NoUserMedia = \"no_user_media\",\n UnknownDevice = \"unknown_device\",\n PlaceCallFailed = \"place_call_failed\",\n}\n\nexport interface GroupCallStatsReport {\n report: T;\n}\n\nexport class GroupCallError extends Error {\n public code: string;\n\n public constructor(code: GroupCallErrorCode, msg: string, err?: Error) {\n // Still don't think there's any way to have proper nested errors\n if (err) {\n super(msg + \": \" + err);\n } else {\n super(msg);\n }\n\n this.code = code;\n }\n}\n\nexport class GroupCallUnknownDeviceError extends GroupCallError {\n public constructor(public userId: string) {\n super(GroupCallErrorCode.UnknownDevice, \"No device found for \" + userId);\n }\n}\n\nexport class OtherUserSpeakingError extends Error {\n public constructor() {\n super(\"Cannot unmute: another user is speaking\");\n }\n}\n\nexport interface IGroupCallDataChannelOptions {\n ordered: boolean;\n maxPacketLifeTime: number;\n maxRetransmits: number;\n protocol: string;\n}\n\nexport interface IGroupCallRoomState {\n \"m.intent\": GroupCallIntent;\n \"m.type\": GroupCallType;\n \"io.element.ptt\"?: boolean;\n // TODO: Specify data-channels\n \"dataChannelsEnabled\"?: boolean;\n \"dataChannelOptions\"?: IGroupCallDataChannelOptions;\n}\n\nexport interface IGroupCallRoomMemberFeed {\n purpose: SDPStreamMetadataPurpose;\n}\n\nexport interface IGroupCallRoomMemberDevice {\n device_id: string;\n session_id: string;\n expires_ts: number;\n feeds: IGroupCallRoomMemberFeed[];\n}\n\nexport interface IGroupCallRoomMemberCallState {\n \"m.call_id\": string;\n \"m.foci\"?: string[];\n \"m.devices\": IGroupCallRoomMemberDevice[];\n}\n\nexport interface IGroupCallRoomMemberState {\n \"m.calls\": IGroupCallRoomMemberCallState[];\n}\n\nexport enum GroupCallState {\n LocalCallFeedUninitialized = \"local_call_feed_uninitialized\",\n InitializingLocalCallFeed = \"initializing_local_call_feed\",\n LocalCallFeedInitialized = \"local_call_feed_initialized\",\n Entered = \"entered\",\n Ended = \"ended\",\n}\n\nexport interface ParticipantState {\n sessionId: string;\n screensharing: boolean;\n}\n\ninterface ICallHandlers {\n onCallFeedsChanged: (feeds: CallFeed[]) => void;\n onCallStateChanged: (state: CallState, oldState: CallState | undefined) => void;\n onCallHangup: (call: MatrixCall) => void;\n onCallReplaced: (newCall: MatrixCall) => void;\n}\n\nconst DEVICE_TIMEOUT = 1000 * 60 * 60; // 1 hour\n\nfunction getCallUserId(call: MatrixCall): string | null {\n return call.getOpponentMember()?.userId || call.invitee || null;\n}\n\nexport class GroupCall extends TypedEventEmitter<\n GroupCallEvent | CallEvent | GroupCallStatsReportEvent,\n GroupCallEventHandlerMap & CallEventHandlerMap & GroupCallStatsReportEventHandlerMap\n> {\n // Config\n public activeSpeakerInterval = 1000;\n public retryCallInterval = 5000;\n public participantTimeout = 1000 * 15;\n public pttMaxTransmitTime = 1000 * 20;\n\n public activeSpeaker?: CallFeed;\n public localCallFeed?: CallFeed;\n public localScreenshareFeed?: CallFeed;\n public localDesktopCapturerSourceId?: string;\n public readonly userMediaFeeds: CallFeed[] = [];\n public readonly screenshareFeeds: CallFeed[] = [];\n public groupCallId: string;\n public readonly allowCallWithoutVideoAndAudio: boolean;\n\n private readonly calls = new Map>(); // user_id -> device_id -> MatrixCall\n private callHandlers = new Map>(); // user_id -> device_id -> ICallHandlers\n private activeSpeakerLoopInterval?: ReturnType;\n private retryCallLoopInterval?: ReturnType;\n private retryCallCounts: Map> = new Map(); // user_id -> device_id -> count\n private reEmitter: ReEmitter;\n private transmitTimer: ReturnType | null = null;\n private participantsExpirationTimer: ReturnType | null = null;\n private resendMemberStateTimer: ReturnType | null = null;\n private initWithAudioMuted = false;\n private initWithVideoMuted = false;\n private initCallFeedPromise?: Promise;\n\n private readonly stats: GroupCallStats;\n\n public constructor(\n private client: MatrixClient,\n public room: Room,\n public type: GroupCallType,\n public isPtt: boolean,\n public intent: GroupCallIntent,\n groupCallId?: string,\n private dataChannelsEnabled?: boolean,\n private dataChannelOptions?: IGroupCallDataChannelOptions,\n isCallWithoutVideoAndAudio?: boolean,\n ) {\n super();\n this.reEmitter = new ReEmitter(this);\n this.groupCallId = groupCallId ?? genCallID();\n this.creationTs =\n room.currentState.getStateEvents(EventType.GroupCallPrefix, this.groupCallId)?.getTs() ?? null;\n this.updateParticipants();\n\n room.on(RoomStateEvent.Update, this.onRoomState);\n this.on(GroupCallEvent.ParticipantsChanged, this.onParticipantsChanged);\n this.on(GroupCallEvent.GroupCallStateChanged, this.onStateChanged);\n this.on(GroupCallEvent.LocalScreenshareStateChanged, this.onLocalFeedsChanged);\n this.allowCallWithoutVideoAndAudio = !!isCallWithoutVideoAndAudio;\n\n const userID = this.client.getUserId() || \"unknown\";\n this.stats = new GroupCallStats(this.groupCallId, userID);\n this.stats.reports.on(StatsReport.CONNECTION_STATS, this.onConnectionStats);\n this.stats.reports.on(StatsReport.BYTE_SENT_STATS, this.onByteSentStats);\n }\n\n private onConnectionStats = (report: ConnectionStatsReport): void => {\n // @TODO: Implement data argumentation\n this.emit(GroupCallStatsReportEvent.ConnectionStats, { report });\n };\n\n private onByteSentStats = (report: ByteSentStatsReport): void => {\n // @TODO: Implement data argumentation\n this.emit(GroupCallStatsReportEvent.ByteSentStats, { report });\n };\n\n public async create(): Promise {\n this.creationTs = Date.now();\n this.client.groupCallEventHandler!.groupCalls.set(this.room.roomId, this);\n this.client.emit(GroupCallEventHandlerEvent.Outgoing, this);\n\n const groupCallState: IGroupCallRoomState = {\n \"m.intent\": this.intent,\n \"m.type\": this.type,\n \"io.element.ptt\": this.isPtt,\n // TODO: Specify data-channels better\n \"dataChannelsEnabled\": this.dataChannelsEnabled,\n \"dataChannelOptions\": this.dataChannelsEnabled ? this.dataChannelOptions : undefined,\n };\n\n await this.client.sendStateEvent(this.room.roomId, EventType.GroupCallPrefix, groupCallState, this.groupCallId);\n\n return this;\n }\n\n private _state = GroupCallState.LocalCallFeedUninitialized;\n\n /**\n * The group call's state.\n */\n public get state(): GroupCallState {\n return this._state;\n }\n\n private set state(value: GroupCallState) {\n const prevValue = this._state;\n if (value !== prevValue) {\n this._state = value;\n this.emit(GroupCallEvent.GroupCallStateChanged, value, prevValue);\n }\n }\n\n private _participants = new Map>();\n\n /**\n * The current participants in the call, as a map from members to device IDs\n * to participant info.\n */\n public get participants(): Map> {\n return this._participants;\n }\n\n private set participants(value: Map>) {\n const prevValue = this._participants;\n const participantStateEqual = (x: ParticipantState, y: ParticipantState): boolean =>\n x.sessionId === y.sessionId && x.screensharing === y.screensharing;\n const deviceMapsEqual = (x: Map, y: Map): boolean =>\n mapsEqual(x, y, participantStateEqual);\n\n // Only update if the map actually changed\n if (!mapsEqual(value, prevValue, deviceMapsEqual)) {\n this._participants = value;\n this.emit(GroupCallEvent.ParticipantsChanged, value);\n }\n }\n\n private _creationTs: number | null = null;\n\n /**\n * The timestamp at which the call was created, or null if it has not yet\n * been created.\n */\n public get creationTs(): number | null {\n return this._creationTs;\n }\n\n private set creationTs(value: number | null) {\n this._creationTs = value;\n }\n\n private _enteredViaAnotherSession = false;\n\n /**\n * Whether the local device has entered this call via another session, such\n * as a widget.\n */\n public get enteredViaAnotherSession(): boolean {\n return this._enteredViaAnotherSession;\n }\n\n public set enteredViaAnotherSession(value: boolean) {\n this._enteredViaAnotherSession = value;\n this.updateParticipants();\n }\n\n /**\n * Executes the given callback on all calls in this group call.\n * @param f - The callback.\n */\n public forEachCall(f: (call: MatrixCall) => void): void {\n for (const deviceMap of this.calls.values()) {\n for (const call of deviceMap.values()) f(call);\n }\n }\n\n public getLocalFeeds(): CallFeed[] {\n const feeds: CallFeed[] = [];\n\n if (this.localCallFeed) feeds.push(this.localCallFeed);\n if (this.localScreenshareFeed) feeds.push(this.localScreenshareFeed);\n\n return feeds;\n }\n\n public hasLocalParticipant(): boolean {\n return (\n this.participants.get(this.room.getMember(this.client.getUserId()!)!)?.has(this.client.getDeviceId()!) ??\n false\n );\n }\n\n /**\n * Determines whether the given call is one that we were expecting to exist\n * given our knowledge of who is participating in the group call.\n */\n private callExpected(call: MatrixCall): boolean {\n const userId = getCallUserId(call);\n const member = userId === null ? null : this.room.getMember(userId);\n const deviceId = call.getOpponentDeviceId();\n return member !== null && deviceId !== undefined && this.participants.get(member)?.get(deviceId) !== undefined;\n }\n\n public async initLocalCallFeed(): Promise {\n if (this.state !== GroupCallState.LocalCallFeedUninitialized) {\n throw new Error(`Cannot initialize local call feed in the \"${this.state}\" state.`);\n }\n this.state = GroupCallState.InitializingLocalCallFeed;\n\n // wraps the real method to serialise calls, because we don't want to try starting\n // multiple call feeds at once\n if (this.initCallFeedPromise) return this.initCallFeedPromise;\n\n try {\n this.initCallFeedPromise = this.initLocalCallFeedInternal();\n await this.initCallFeedPromise;\n } finally {\n this.initCallFeedPromise = undefined;\n }\n }\n\n private async initLocalCallFeedInternal(): Promise {\n logger.log(`GroupCall ${this.groupCallId} initLocalCallFeedInternal() running`);\n\n let stream: MediaStream;\n\n try {\n stream = await this.client.getMediaHandler().getUserMediaStream(true, this.type === GroupCallType.Video);\n } catch (error) {\n // If is allowed to join a call without a media stream, then we\n // don't throw an error here. But we need an empty Local Feed to establish\n // a connection later.\n if (this.allowCallWithoutVideoAndAudio) {\n stream = new MediaStream();\n } else {\n this.state = GroupCallState.LocalCallFeedUninitialized;\n throw error;\n }\n }\n\n // The call could've been disposed while we were waiting, and could\n // also have been started back up again (hello, React 18) so if we're\n // still in this 'initializing' state, carry on, otherwise bail.\n if (this._state !== GroupCallState.InitializingLocalCallFeed) {\n this.client.getMediaHandler().stopUserMediaStream(stream);\n throw new Error(\"Group call disposed while gathering media stream\");\n }\n\n const callFeed = new CallFeed({\n client: this.client,\n roomId: this.room.roomId,\n userId: this.client.getUserId()!,\n deviceId: this.client.getDeviceId()!,\n stream,\n purpose: SDPStreamMetadataPurpose.Usermedia,\n audioMuted: this.initWithAudioMuted || stream.getAudioTracks().length === 0 || this.isPtt,\n videoMuted: this.initWithVideoMuted || stream.getVideoTracks().length === 0,\n });\n\n setTracksEnabled(stream.getAudioTracks(), !callFeed.isAudioMuted());\n setTracksEnabled(stream.getVideoTracks(), !callFeed.isVideoMuted());\n\n this.localCallFeed = callFeed;\n this.addUserMediaFeed(callFeed);\n\n this.state = GroupCallState.LocalCallFeedInitialized;\n }\n\n public async updateLocalUsermediaStream(stream: MediaStream): Promise {\n if (this.localCallFeed) {\n const oldStream = this.localCallFeed.stream;\n this.localCallFeed.setNewStream(stream);\n const micShouldBeMuted = this.localCallFeed.isAudioMuted();\n const vidShouldBeMuted = this.localCallFeed.isVideoMuted();\n logger.log(\n `GroupCall ${this.groupCallId} updateLocalUsermediaStream() (oldStreamId=${oldStream.id}, newStreamId=${stream.id}, micShouldBeMuted=${micShouldBeMuted}, vidShouldBeMuted=${vidShouldBeMuted})`,\n );\n setTracksEnabled(stream.getAudioTracks(), !micShouldBeMuted);\n setTracksEnabled(stream.getVideoTracks(), !vidShouldBeMuted);\n this.client.getMediaHandler().stopUserMediaStream(oldStream);\n }\n }\n\n public async enter(): Promise {\n if (this.state === GroupCallState.LocalCallFeedUninitialized) {\n await this.initLocalCallFeed();\n } else if (this.state !== GroupCallState.LocalCallFeedInitialized) {\n throw new Error(`Cannot enter call in the \"${this.state}\" state`);\n }\n\n logger.log(`GroupCall ${this.groupCallId} enter() running`);\n this.state = GroupCallState.Entered;\n\n this.client.on(CallEventHandlerEvent.Incoming, this.onIncomingCall);\n\n for (const call of this.client.callEventHandler!.calls.values()) {\n this.onIncomingCall(call);\n }\n\n this.retryCallLoopInterval = setInterval(this.onRetryCallLoop, this.retryCallInterval);\n\n this.activeSpeaker = undefined;\n this.onActiveSpeakerLoop();\n this.activeSpeakerLoopInterval = setInterval(this.onActiveSpeakerLoop, this.activeSpeakerInterval);\n }\n\n private dispose(): void {\n if (this.localCallFeed) {\n this.removeUserMediaFeed(this.localCallFeed);\n this.localCallFeed = undefined;\n }\n\n if (this.localScreenshareFeed) {\n this.client.getMediaHandler().stopScreensharingStream(this.localScreenshareFeed.stream);\n this.removeScreenshareFeed(this.localScreenshareFeed);\n this.localScreenshareFeed = undefined;\n this.localDesktopCapturerSourceId = undefined;\n }\n\n this.client.getMediaHandler().stopAllStreams();\n\n if (this.transmitTimer !== null) {\n clearTimeout(this.transmitTimer);\n this.transmitTimer = null;\n }\n\n if (this.retryCallLoopInterval !== undefined) {\n clearInterval(this.retryCallLoopInterval);\n this.retryCallLoopInterval = undefined;\n }\n\n if (this.participantsExpirationTimer !== null) {\n clearTimeout(this.participantsExpirationTimer);\n this.participantsExpirationTimer = null;\n }\n\n if (this.state !== GroupCallState.Entered) {\n return;\n }\n\n this.forEachCall((call) => call.hangup(CallErrorCode.UserHangup, false));\n\n this.activeSpeaker = undefined;\n clearInterval(this.activeSpeakerLoopInterval);\n\n this.retryCallCounts.clear();\n clearInterval(this.retryCallLoopInterval);\n\n this.client.removeListener(CallEventHandlerEvent.Incoming, this.onIncomingCall);\n this.stats.stop();\n }\n\n public leave(): void {\n this.dispose();\n this.state = GroupCallState.LocalCallFeedUninitialized;\n }\n\n public async terminate(emitStateEvent = true): Promise {\n this.dispose();\n\n this.room.off(RoomStateEvent.Update, this.onRoomState);\n this.client.groupCallEventHandler!.groupCalls.delete(this.room.roomId);\n this.client.emit(GroupCallEventHandlerEvent.Ended, this);\n this.state = GroupCallState.Ended;\n\n if (emitStateEvent) {\n const existingStateEvent = this.room.currentState.getStateEvents(\n EventType.GroupCallPrefix,\n this.groupCallId,\n )!;\n\n await this.client.sendStateEvent(\n this.room.roomId,\n EventType.GroupCallPrefix,\n {\n ...existingStateEvent.getContent(),\n \"m.terminated\": GroupCallTerminationReason.CallEnded,\n },\n this.groupCallId,\n );\n }\n }\n\n /*\n * Local Usermedia\n */\n\n public isLocalVideoMuted(): boolean {\n if (this.localCallFeed) {\n return this.localCallFeed.isVideoMuted();\n }\n\n return true;\n }\n\n public isMicrophoneMuted(): boolean {\n if (this.localCallFeed) {\n return this.localCallFeed.isAudioMuted();\n }\n\n return true;\n }\n\n /**\n * Sets the mute state of the local participants's microphone.\n * @param muted - Whether to mute the microphone\n * @returns Whether muting/unmuting was successful\n */\n public async setMicrophoneMuted(muted: boolean): Promise {\n // hasAudioDevice can block indefinitely if the window has lost focus,\n // and it doesn't make much sense to keep a device from being muted, so\n // we always allow muted = true changes to go through\n if (!muted && !(await this.client.getMediaHandler().hasAudioDevice())) {\n return false;\n }\n\n const sendUpdatesBefore = !muted && this.isPtt;\n\n // set a timer for the maximum transmit time on PTT calls\n if (this.isPtt) {\n // Set or clear the max transmit timer\n if (!muted && this.isMicrophoneMuted()) {\n this.transmitTimer = setTimeout(() => {\n this.setMicrophoneMuted(true);\n }, this.pttMaxTransmitTime);\n } else if (muted && !this.isMicrophoneMuted()) {\n if (this.transmitTimer !== null) clearTimeout(this.transmitTimer);\n this.transmitTimer = null;\n }\n }\n\n this.forEachCall((call) => call.localUsermediaFeed?.setAudioVideoMuted(muted, null));\n\n const sendUpdates = async (): Promise => {\n const updates: Promise[] = [];\n this.forEachCall((call) => updates.push(call.sendMetadataUpdate()));\n\n await Promise.all(updates).catch((e) =>\n logger.info(\n `GroupCall ${this.groupCallId} setMicrophoneMuted() failed to send some metadata updates`,\n e,\n ),\n );\n };\n\n if (sendUpdatesBefore) await sendUpdates();\n\n if (this.localCallFeed) {\n logger.log(\n `GroupCall ${this.groupCallId} setMicrophoneMuted() (streamId=${this.localCallFeed.stream.id}, muted=${muted})`,\n );\n\n // We needed this here to avoid an error in case user join a call without a device.\n // I can not use .then .catch functions because linter :-(\n try {\n if (!muted) {\n const stream = await this.client\n .getMediaHandler()\n .getUserMediaStream(true, !this.localCallFeed.isVideoMuted());\n if (stream === null) {\n // if case permission denied to get a stream stop this here\n /* istanbul ignore next */\n logger.log(\n `GroupCall ${this.groupCallId} setMicrophoneMuted() no device to receive local stream, muted=${muted}`,\n );\n return false;\n }\n }\n } catch (e) {\n /* istanbul ignore next */\n logger.log(\n `GroupCall ${this.groupCallId} setMicrophoneMuted() no device or permission to receive local stream, muted=${muted}`,\n );\n return false;\n }\n\n this.localCallFeed.setAudioVideoMuted(muted, null);\n // I don't believe its actually necessary to enable these tracks: they\n // are the one on the GroupCall's own CallFeed and are cloned before being\n // given to any of the actual calls, so these tracks don't actually go\n // anywhere. Let's do it anyway to avoid confusion.\n setTracksEnabled(this.localCallFeed.stream.getAudioTracks(), !muted);\n } else {\n logger.log(`GroupCall ${this.groupCallId} setMicrophoneMuted() no stream muted (muted=${muted})`);\n this.initWithAudioMuted = muted;\n }\n\n this.forEachCall((call) =>\n setTracksEnabled(call.localUsermediaFeed!.stream.getAudioTracks(), !muted && this.callExpected(call)),\n );\n this.emit(GroupCallEvent.LocalMuteStateChanged, muted, this.isLocalVideoMuted());\n\n if (!sendUpdatesBefore) await sendUpdates();\n\n return true;\n }\n\n /**\n * Sets the mute state of the local participants's video.\n * @param muted - Whether to mute the video\n * @returns Whether muting/unmuting was successful\n */\n public async setLocalVideoMuted(muted: boolean): Promise {\n // hasAudioDevice can block indefinitely if the window has lost focus,\n // and it doesn't make much sense to keep a device from being muted, so\n // we always allow muted = true changes to go through\n if (!muted && !(await this.client.getMediaHandler().hasVideoDevice())) {\n return false;\n }\n\n if (this.localCallFeed) {\n /* istanbul ignore next */\n logger.log(\n `GroupCall ${this.groupCallId} setLocalVideoMuted() (stream=${this.localCallFeed.stream.id}, muted=${muted})`,\n );\n\n try {\n const stream = await this.client.getMediaHandler().getUserMediaStream(true, !muted);\n await this.updateLocalUsermediaStream(stream);\n this.localCallFeed.setAudioVideoMuted(null, muted);\n setTracksEnabled(this.localCallFeed.stream.getVideoTracks(), !muted);\n } catch (_) {\n // No permission to video device\n /* istanbul ignore next */\n logger.log(\n `GroupCall ${this.groupCallId} setLocalVideoMuted() no device or permission to receive local stream, muted=${muted}`,\n );\n return false;\n }\n } else {\n logger.log(`GroupCall ${this.groupCallId} setLocalVideoMuted() no stream muted (muted=${muted})`);\n this.initWithVideoMuted = muted;\n }\n\n const updates: Promise[] = [];\n this.forEachCall((call) => updates.push(call.setLocalVideoMuted(muted)));\n await Promise.all(updates);\n\n // We setTracksEnabled again, independently from the call doing it\n // internally, since we might not be expecting the call\n this.forEachCall((call) =>\n setTracksEnabled(call.localUsermediaFeed!.stream.getVideoTracks(), !muted && this.callExpected(call)),\n );\n\n this.emit(GroupCallEvent.LocalMuteStateChanged, this.isMicrophoneMuted(), muted);\n\n return true;\n }\n\n public async setScreensharingEnabled(enabled: boolean, opts: IScreensharingOpts = {}): Promise {\n if (enabled === this.isScreensharing()) {\n return enabled;\n }\n\n if (enabled) {\n try {\n logger.log(\n `GroupCall ${this.groupCallId} setScreensharingEnabled() is asking for screensharing permissions`,\n );\n const stream = await this.client.getMediaHandler().getScreensharingStream(opts);\n\n for (const track of stream.getTracks()) {\n const onTrackEnded = (): void => {\n this.setScreensharingEnabled(false);\n track.removeEventListener(\"ended\", onTrackEnded);\n };\n\n track.addEventListener(\"ended\", onTrackEnded);\n }\n\n logger.log(\n `GroupCall ${this.groupCallId} setScreensharingEnabled() granted screensharing permissions. Setting screensharing enabled on all calls`,\n );\n\n this.localDesktopCapturerSourceId = opts.desktopCapturerSourceId;\n this.localScreenshareFeed = new CallFeed({\n client: this.client,\n roomId: this.room.roomId,\n userId: this.client.getUserId()!,\n deviceId: this.client.getDeviceId()!,\n stream,\n purpose: SDPStreamMetadataPurpose.Screenshare,\n audioMuted: false,\n videoMuted: false,\n });\n this.addScreenshareFeed(this.localScreenshareFeed);\n\n this.emit(\n GroupCallEvent.LocalScreenshareStateChanged,\n true,\n this.localScreenshareFeed,\n this.localDesktopCapturerSourceId,\n );\n\n // TODO: handle errors\n this.forEachCall((call) => call.pushLocalFeed(this.localScreenshareFeed!.clone()));\n\n return true;\n } catch (error) {\n if (opts.throwOnFail) throw error;\n logger.error(\n `GroupCall ${this.groupCallId} setScreensharingEnabled() enabling screensharing error`,\n error,\n );\n this.emit(\n GroupCallEvent.Error,\n new GroupCallError(\n GroupCallErrorCode.NoUserMedia,\n \"Failed to get screen-sharing stream: \",\n error as Error,\n ),\n );\n return false;\n }\n } else {\n this.forEachCall((call) => {\n if (call.localScreensharingFeed) call.removeLocalFeed(call.localScreensharingFeed);\n });\n this.client.getMediaHandler().stopScreensharingStream(this.localScreenshareFeed!.stream);\n this.removeScreenshareFeed(this.localScreenshareFeed!);\n this.localScreenshareFeed = undefined;\n this.localDesktopCapturerSourceId = undefined;\n this.emit(GroupCallEvent.LocalScreenshareStateChanged, false, undefined, undefined);\n return false;\n }\n }\n\n public isScreensharing(): boolean {\n return !!this.localScreenshareFeed;\n }\n\n /*\n * Call Setup\n *\n * There are two different paths for calls to be created:\n * 1. Incoming calls triggered by the Call.incoming event.\n * 2. Outgoing calls to the initial members of a room or new members\n * as they are observed by the RoomState.members event.\n */\n\n private onIncomingCall = (newCall: MatrixCall): void => {\n // The incoming calls may be for another room, which we will ignore.\n if (newCall.roomId !== this.room.roomId) {\n return;\n }\n\n if (newCall.state !== CallState.Ringing) {\n logger.warn(\n `GroupCall ${this.groupCallId} onIncomingCall() incoming call no longer in ringing state - ignoring`,\n );\n return;\n }\n\n if (!newCall.groupCallId || newCall.groupCallId !== this.groupCallId) {\n logger.log(\n `GroupCall ${this.groupCallId} onIncomingCall() ignored because it doesn't match the current group call`,\n );\n newCall.reject();\n return;\n }\n\n const opponentUserId = newCall.getOpponentMember()?.userId;\n if (opponentUserId === undefined) {\n logger.warn(`GroupCall ${this.groupCallId} onIncomingCall() incoming call with no member - ignoring`);\n return;\n }\n\n const deviceMap = this.calls.get(opponentUserId) ?? new Map();\n const prevCall = deviceMap.get(newCall.getOpponentDeviceId()!);\n\n if (prevCall?.callId === newCall.callId) return;\n\n logger.log(\n `GroupCall ${this.groupCallId} onIncomingCall() incoming call (userId=${opponentUserId}, callId=${newCall.callId})`,\n );\n\n if (prevCall) prevCall.hangup(CallErrorCode.Replaced, false);\n\n this.initCall(newCall);\n\n const feeds = this.getLocalFeeds().map((feed) => feed.clone());\n if (!this.callExpected(newCall)) {\n // Disable our tracks for users not explicitly participating in the\n // call but trying to receive the feeds\n for (const feed of feeds) {\n setTracksEnabled(feed.stream.getAudioTracks(), false);\n setTracksEnabled(feed.stream.getVideoTracks(), false);\n }\n }\n newCall.answerWithCallFeeds(feeds);\n\n deviceMap.set(newCall.getOpponentDeviceId()!, newCall);\n this.calls.set(opponentUserId, deviceMap);\n this.emit(GroupCallEvent.CallsChanged, this.calls);\n };\n\n /**\n * Determines whether a given participant expects us to call them (versus\n * them calling us).\n * @param userId - The participant's user ID.\n * @param deviceId - The participant's device ID.\n * @returns Whether we need to place an outgoing call to the participant.\n */\n private wantsOutgoingCall(userId: string, deviceId: string): boolean {\n const localUserId = this.client.getUserId()!;\n const localDeviceId = this.client.getDeviceId()!;\n return (\n // If a user's ID is less than our own, they'll call us\n userId >= localUserId &&\n // If this is another one of our devices, compare device IDs to tell whether it'll call us\n (userId !== localUserId || deviceId > localDeviceId)\n );\n }\n\n /**\n * Places calls to all participants that we're responsible for calling.\n */\n private placeOutgoingCalls(): void {\n let callsChanged = false;\n\n for (const [{ userId }, participantMap] of this.participants) {\n const callMap = this.calls.get(userId) ?? new Map();\n\n for (const [deviceId, participant] of participantMap) {\n const prevCall = callMap.get(deviceId);\n\n if (\n prevCall?.getOpponentSessionId() !== participant.sessionId &&\n this.wantsOutgoingCall(userId, deviceId)\n ) {\n callsChanged = true;\n\n if (prevCall !== undefined) {\n logger.debug(\n `GroupCall ${this.groupCallId} placeOutgoingCalls() replacing call (userId=${userId}, deviceId=${deviceId}, callId=${prevCall.callId})`,\n );\n prevCall.hangup(CallErrorCode.NewSession, false);\n }\n\n const newCall = createNewMatrixCall(this.client, this.room.roomId, {\n invitee: userId,\n opponentDeviceId: deviceId,\n opponentSessionId: participant.sessionId,\n groupCallId: this.groupCallId,\n });\n\n if (newCall === null) {\n logger.error(\n `GroupCall ${this.groupCallId} placeOutgoingCalls() failed to create call (userId=${userId}, device=${deviceId})`,\n );\n callMap.delete(deviceId);\n } else {\n this.initCall(newCall);\n callMap.set(deviceId, newCall);\n\n logger.debug(\n `GroupCall ${this.groupCallId} placeOutgoingCalls() placing call (userId=${userId}, deviceId=${deviceId}, sessionId=${participant.sessionId})`,\n );\n\n newCall\n .placeCallWithCallFeeds(\n this.getLocalFeeds().map((feed) => feed.clone()),\n participant.screensharing,\n )\n .then(() => {\n if (this.dataChannelsEnabled) {\n newCall.createDataChannel(\"datachannel\", this.dataChannelOptions);\n }\n })\n .catch((e) => {\n logger.warn(\n `GroupCall ${this.groupCallId} placeOutgoingCalls() failed to place call (userId=${userId})`,\n e,\n );\n\n if (e instanceof CallError && e.code === GroupCallErrorCode.UnknownDevice) {\n this.emit(GroupCallEvent.Error, e);\n } else {\n this.emit(\n GroupCallEvent.Error,\n new GroupCallError(\n GroupCallErrorCode.PlaceCallFailed,\n `Failed to place call to ${userId}`,\n ),\n );\n }\n\n newCall.hangup(CallErrorCode.SignallingFailed, false);\n if (callMap.get(deviceId) === newCall) callMap.delete(deviceId);\n });\n }\n }\n }\n\n if (callMap.size > 0) {\n this.calls.set(userId, callMap);\n } else {\n this.calls.delete(userId);\n }\n }\n\n if (callsChanged) this.emit(GroupCallEvent.CallsChanged, this.calls);\n }\n\n /*\n * Room Member State\n */\n\n private getMemberStateEvents(): MatrixEvent[];\n private getMemberStateEvents(userId: string): MatrixEvent | null;\n private getMemberStateEvents(userId?: string): MatrixEvent[] | MatrixEvent | null {\n return userId === undefined\n ? this.room.currentState.getStateEvents(EventType.GroupCallMemberPrefix)\n : this.room.currentState.getStateEvents(EventType.GroupCallMemberPrefix, userId);\n }\n\n private onRetryCallLoop = (): void => {\n let needsRetry = false;\n\n for (const [{ userId }, participantMap] of this.participants) {\n const callMap = this.calls.get(userId);\n let retriesMap = this.retryCallCounts.get(userId);\n\n for (const [deviceId, participant] of participantMap) {\n const call = callMap?.get(deviceId);\n const retries = retriesMap?.get(deviceId) ?? 0;\n\n if (\n call?.getOpponentSessionId() !== participant.sessionId &&\n this.wantsOutgoingCall(userId, deviceId) &&\n retries < 3\n ) {\n if (retriesMap === undefined) {\n retriesMap = new Map();\n this.retryCallCounts.set(userId, retriesMap);\n }\n retriesMap.set(deviceId, retries + 1);\n needsRetry = true;\n }\n }\n }\n\n if (needsRetry) this.placeOutgoingCalls();\n };\n\n private initCall(call: MatrixCall): void {\n const opponentMemberId = getCallUserId(call);\n\n if (!opponentMemberId) {\n throw new Error(\"Cannot init call without user id\");\n }\n\n const onCallFeedsChanged = (): void => this.onCallFeedsChanged(call);\n const onCallStateChanged = (state: CallState, oldState?: CallState): void =>\n this.onCallStateChanged(call, state, oldState);\n const onCallHangup = this.onCallHangup;\n const onCallReplaced = (newCall: MatrixCall): void => this.onCallReplaced(call, newCall);\n\n let deviceMap = this.callHandlers.get(opponentMemberId);\n if (deviceMap === undefined) {\n deviceMap = new Map();\n this.callHandlers.set(opponentMemberId, deviceMap);\n }\n\n deviceMap.set(call.getOpponentDeviceId()!, {\n onCallFeedsChanged,\n onCallStateChanged,\n onCallHangup,\n onCallReplaced,\n });\n\n call.on(CallEvent.FeedsChanged, onCallFeedsChanged);\n call.on(CallEvent.State, onCallStateChanged);\n call.on(CallEvent.Hangup, onCallHangup);\n call.on(CallEvent.Replaced, onCallReplaced);\n\n call.isPtt = this.isPtt;\n\n this.reEmitter.reEmit(call, Object.values(CallEvent));\n\n call.initStats(this.stats);\n\n onCallFeedsChanged();\n }\n\n private disposeCall(call: MatrixCall, hangupReason: CallErrorCode): void {\n const opponentMemberId = getCallUserId(call);\n const opponentDeviceId = call.getOpponentDeviceId()!;\n\n if (!opponentMemberId) {\n throw new Error(\"Cannot dispose call without user id\");\n }\n\n const deviceMap = this.callHandlers.get(opponentMemberId)!;\n const { onCallFeedsChanged, onCallStateChanged, onCallHangup, onCallReplaced } =\n deviceMap.get(opponentDeviceId)!;\n\n call.removeListener(CallEvent.FeedsChanged, onCallFeedsChanged);\n call.removeListener(CallEvent.State, onCallStateChanged);\n call.removeListener(CallEvent.Hangup, onCallHangup);\n call.removeListener(CallEvent.Replaced, onCallReplaced);\n\n deviceMap.delete(opponentMemberId);\n if (deviceMap.size === 0) this.callHandlers.delete(opponentMemberId);\n\n if (call.hangupReason === CallErrorCode.Replaced) {\n return;\n }\n\n const usermediaFeed = this.getUserMediaFeed(opponentMemberId, opponentDeviceId);\n\n if (usermediaFeed) {\n this.removeUserMediaFeed(usermediaFeed);\n }\n\n const screenshareFeed = this.getScreenshareFeed(opponentMemberId, opponentDeviceId);\n\n if (screenshareFeed) {\n this.removeScreenshareFeed(screenshareFeed);\n }\n }\n\n private onCallFeedsChanged = (call: MatrixCall): void => {\n const opponentMemberId = getCallUserId(call);\n const opponentDeviceId = call.getOpponentDeviceId()!;\n\n if (!opponentMemberId) {\n throw new Error(\"Cannot change call feeds without user id\");\n }\n\n const currentUserMediaFeed = this.getUserMediaFeed(opponentMemberId, opponentDeviceId);\n const remoteUsermediaFeed = call.remoteUsermediaFeed;\n const remoteFeedChanged = remoteUsermediaFeed !== currentUserMediaFeed;\n\n if (remoteFeedChanged) {\n if (!currentUserMediaFeed && remoteUsermediaFeed) {\n this.addUserMediaFeed(remoteUsermediaFeed);\n } else if (currentUserMediaFeed && remoteUsermediaFeed) {\n this.replaceUserMediaFeed(currentUserMediaFeed, remoteUsermediaFeed);\n } else if (currentUserMediaFeed && !remoteUsermediaFeed) {\n this.removeUserMediaFeed(currentUserMediaFeed);\n }\n }\n\n const currentScreenshareFeed = this.getScreenshareFeed(opponentMemberId, opponentDeviceId);\n const remoteScreensharingFeed = call.remoteScreensharingFeed;\n const remoteScreenshareFeedChanged = remoteScreensharingFeed !== currentScreenshareFeed;\n\n if (remoteScreenshareFeedChanged) {\n if (!currentScreenshareFeed && remoteScreensharingFeed) {\n this.addScreenshareFeed(remoteScreensharingFeed);\n } else if (currentScreenshareFeed && remoteScreensharingFeed) {\n this.replaceScreenshareFeed(currentScreenshareFeed, remoteScreensharingFeed);\n } else if (currentScreenshareFeed && !remoteScreensharingFeed) {\n this.removeScreenshareFeed(currentScreenshareFeed);\n }\n }\n };\n\n private onCallStateChanged = (call: MatrixCall, state: CallState, _oldState: CallState | undefined): void => {\n if (state === CallState.Ended) return;\n\n const audioMuted = this.localCallFeed!.isAudioMuted();\n\n if (call.localUsermediaStream && call.isMicrophoneMuted() !== audioMuted) {\n call.setMicrophoneMuted(audioMuted);\n }\n\n const videoMuted = this.localCallFeed!.isVideoMuted();\n\n if (call.localUsermediaStream && call.isLocalVideoMuted() !== videoMuted) {\n call.setLocalVideoMuted(videoMuted);\n }\n\n const opponentUserId = call.getOpponentMember()?.userId;\n if (state === CallState.Connected && opponentUserId) {\n const retriesMap = this.retryCallCounts.get(opponentUserId);\n retriesMap?.delete(call.getOpponentDeviceId()!);\n if (retriesMap?.size === 0) this.retryCallCounts.delete(opponentUserId);\n }\n };\n\n private onCallHangup = (call: MatrixCall): void => {\n if (call.hangupReason === CallErrorCode.Replaced) return;\n\n const opponentUserId = call.getOpponentMember()?.userId ?? this.room.getMember(call.invitee!)!.userId;\n const deviceMap = this.calls.get(opponentUserId);\n\n // Sanity check that this call is in fact in the map\n if (deviceMap?.get(call.getOpponentDeviceId()!) === call) {\n this.disposeCall(call, call.hangupReason as CallErrorCode);\n deviceMap.delete(call.getOpponentDeviceId()!);\n if (deviceMap.size === 0) this.calls.delete(opponentUserId);\n this.emit(GroupCallEvent.CallsChanged, this.calls);\n }\n };\n\n private onCallReplaced = (prevCall: MatrixCall, newCall: MatrixCall): void => {\n const opponentUserId = prevCall.getOpponentMember()!.userId;\n\n let deviceMap = this.calls.get(opponentUserId);\n if (deviceMap === undefined) {\n deviceMap = new Map();\n this.calls.set(opponentUserId, deviceMap);\n }\n\n prevCall.hangup(CallErrorCode.Replaced, false);\n this.initCall(newCall);\n deviceMap.set(prevCall.getOpponentDeviceId()!, newCall);\n this.emit(GroupCallEvent.CallsChanged, this.calls);\n };\n\n /*\n * UserMedia CallFeed Event Handlers\n */\n\n public getUserMediaFeed(userId: string, deviceId: string): CallFeed | undefined {\n return this.userMediaFeeds.find((f) => f.userId === userId && f.deviceId! === deviceId);\n }\n\n private addUserMediaFeed(callFeed: CallFeed): void {\n this.userMediaFeeds.push(callFeed);\n callFeed.measureVolumeActivity(true);\n this.emit(GroupCallEvent.UserMediaFeedsChanged, this.userMediaFeeds);\n }\n\n private replaceUserMediaFeed(existingFeed: CallFeed, replacementFeed: CallFeed): void {\n const feedIndex = this.userMediaFeeds.findIndex(\n (f) => f.userId === existingFeed.userId && f.deviceId! === existingFeed.deviceId,\n );\n\n if (feedIndex === -1) {\n throw new Error(\"Couldn't find user media feed to replace\");\n }\n\n this.userMediaFeeds.splice(feedIndex, 1, replacementFeed);\n\n existingFeed.dispose();\n replacementFeed.measureVolumeActivity(true);\n this.emit(GroupCallEvent.UserMediaFeedsChanged, this.userMediaFeeds);\n }\n\n private removeUserMediaFeed(callFeed: CallFeed): void {\n const feedIndex = this.userMediaFeeds.findIndex(\n (f) => f.userId === callFeed.userId && f.deviceId! === callFeed.deviceId,\n );\n\n if (feedIndex === -1) {\n throw new Error(\"Couldn't find user media feed to remove\");\n }\n\n this.userMediaFeeds.splice(feedIndex, 1);\n\n callFeed.dispose();\n this.emit(GroupCallEvent.UserMediaFeedsChanged, this.userMediaFeeds);\n\n if (this.activeSpeaker === callFeed) {\n this.activeSpeaker = this.userMediaFeeds[0];\n this.emit(GroupCallEvent.ActiveSpeakerChanged, this.activeSpeaker);\n }\n }\n\n private onActiveSpeakerLoop = (): void => {\n let topAvg: number | undefined = undefined;\n let nextActiveSpeaker: CallFeed | undefined = undefined;\n\n for (const callFeed of this.userMediaFeeds) {\n if (callFeed.isLocal() && this.userMediaFeeds.length > 1) continue;\n\n const total = callFeed.speakingVolumeSamples.reduce(\n (acc, volume) => acc + Math.max(volume, SPEAKING_THRESHOLD),\n );\n const avg = total / callFeed.speakingVolumeSamples.length;\n\n if (!topAvg || avg > topAvg) {\n topAvg = avg;\n nextActiveSpeaker = callFeed;\n }\n }\n\n if (nextActiveSpeaker && this.activeSpeaker !== nextActiveSpeaker && topAvg && topAvg > SPEAKING_THRESHOLD) {\n this.activeSpeaker = nextActiveSpeaker;\n this.emit(GroupCallEvent.ActiveSpeakerChanged, this.activeSpeaker);\n }\n };\n\n /*\n * Screenshare Call Feed Event Handlers\n */\n\n public getScreenshareFeed(userId: string, deviceId: string): CallFeed | undefined {\n return this.screenshareFeeds.find((f) => f.userId === userId && f.deviceId! === deviceId);\n }\n\n private addScreenshareFeed(callFeed: CallFeed): void {\n this.screenshareFeeds.push(callFeed);\n this.emit(GroupCallEvent.ScreenshareFeedsChanged, this.screenshareFeeds);\n }\n\n private replaceScreenshareFeed(existingFeed: CallFeed, replacementFeed: CallFeed): void {\n const feedIndex = this.screenshareFeeds.findIndex(\n (f) => f.userId === existingFeed.userId && f.deviceId! === existingFeed.deviceId,\n );\n\n if (feedIndex === -1) {\n throw new Error(\"Couldn't find screenshare feed to replace\");\n }\n\n this.screenshareFeeds.splice(feedIndex, 1, replacementFeed);\n\n existingFeed.dispose();\n this.emit(GroupCallEvent.ScreenshareFeedsChanged, this.screenshareFeeds);\n }\n\n private removeScreenshareFeed(callFeed: CallFeed): void {\n const feedIndex = this.screenshareFeeds.findIndex(\n (f) => f.userId === callFeed.userId && f.deviceId! === callFeed.deviceId,\n );\n\n if (feedIndex === -1) {\n throw new Error(\"Couldn't find screenshare feed to remove\");\n }\n\n this.screenshareFeeds.splice(feedIndex, 1);\n\n callFeed.dispose();\n this.emit(GroupCallEvent.ScreenshareFeedsChanged, this.screenshareFeeds);\n }\n\n /**\n * Recalculates and updates the participant map to match the room state.\n */\n private updateParticipants(): void {\n const localMember = this.room.getMember(this.client.getUserId()!)!;\n if (!localMember) {\n // The client hasn't fetched enough of the room state to get our own member\n // event. This probably shouldn't happen, but sanity check & exit for now.\n logger.warn(\n `GroupCall ${this.groupCallId} updateParticipants() tried to update participants before local room member is available`,\n );\n return;\n }\n\n if (this.participantsExpirationTimer !== null) {\n clearTimeout(this.participantsExpirationTimer);\n this.participantsExpirationTimer = null;\n }\n\n if (this.state === GroupCallState.Ended) {\n this.participants = new Map();\n return;\n }\n\n const participants = new Map>();\n const now = Date.now();\n const entered = this.state === GroupCallState.Entered || this.enteredViaAnotherSession;\n let nextExpiration = Infinity;\n\n for (const e of this.getMemberStateEvents()) {\n const member = this.room.getMember(e.getStateKey()!);\n const content = e.getContent>();\n const calls: Record[] = Array.isArray(content[\"m.calls\"]) ? content[\"m.calls\"] : [];\n const call = calls.find((call) => call[\"m.call_id\"] === this.groupCallId);\n const devices: Record[] = Array.isArray(call?.[\"m.devices\"]) ? call![\"m.devices\"] : [];\n\n // Filter out invalid and expired devices\n let validDevices = devices.filter(\n (d) =>\n typeof d.device_id === \"string\" &&\n typeof d.session_id === \"string\" &&\n typeof d.expires_ts === \"number\" &&\n d.expires_ts > now &&\n Array.isArray(d.feeds),\n ) as unknown as IGroupCallRoomMemberDevice[];\n\n // Apply local echo for the unentered case\n if (!entered && member?.userId === this.client.getUserId()!) {\n validDevices = validDevices.filter((d) => d.device_id !== this.client.getDeviceId()!);\n }\n\n // Must have a connected device and be joined to the room\n if (validDevices.length > 0 && member?.membership === \"join\") {\n const deviceMap = new Map();\n participants.set(member, deviceMap);\n\n for (const d of validDevices) {\n deviceMap.set(d.device_id, {\n sessionId: d.session_id,\n screensharing: d.feeds.some((f) => f.purpose === SDPStreamMetadataPurpose.Screenshare),\n });\n if (d.expires_ts < nextExpiration) nextExpiration = d.expires_ts;\n }\n }\n }\n\n // Apply local echo for the entered case\n if (entered) {\n let deviceMap = participants.get(localMember);\n if (deviceMap === undefined) {\n deviceMap = new Map();\n participants.set(localMember, deviceMap);\n }\n\n if (!deviceMap.has(this.client.getDeviceId()!)) {\n deviceMap.set(this.client.getDeviceId()!, {\n sessionId: this.client.getSessionId(),\n screensharing: this.getLocalFeeds().some((f) => f.purpose === SDPStreamMetadataPurpose.Screenshare),\n });\n }\n }\n\n this.participants = participants;\n if (nextExpiration < Infinity) {\n this.participantsExpirationTimer = setTimeout(() => this.updateParticipants(), nextExpiration - now);\n }\n }\n\n /**\n * Updates the local user's member state with the devices returned by the given function.\n * @param fn - A function from the current devices to the new devices. If it\n * returns null, the update will be skipped.\n * @param keepAlive - Whether the request should outlive the window.\n */\n private async updateDevices(\n fn: (devices: IGroupCallRoomMemberDevice[]) => IGroupCallRoomMemberDevice[] | null,\n keepAlive = false,\n ): Promise {\n const now = Date.now();\n const localUserId = this.client.getUserId()!;\n\n const event = this.getMemberStateEvents(localUserId);\n const content = event?.getContent>() ?? {};\n const calls: Record[] = Array.isArray(content[\"m.calls\"]) ? content[\"m.calls\"] : [];\n\n let call: Record | null = null;\n const otherCalls: Record[] = [];\n for (const c of calls) {\n if (c[\"m.call_id\"] === this.groupCallId) {\n call = c;\n } else {\n otherCalls.push(c);\n }\n }\n if (call === null) call = {};\n\n const devices: Record[] = Array.isArray(call[\"m.devices\"]) ? call[\"m.devices\"] : [];\n\n // Filter out invalid and expired devices\n const validDevices = devices.filter(\n (d) =>\n typeof d.device_id === \"string\" &&\n typeof d.session_id === \"string\" &&\n typeof d.expires_ts === \"number\" &&\n d.expires_ts > now &&\n Array.isArray(d.feeds),\n ) as unknown as IGroupCallRoomMemberDevice[];\n\n const newDevices = fn(validDevices);\n if (newDevices === null) return;\n\n const newCalls = [...(otherCalls as unknown as IGroupCallRoomMemberCallState[])];\n if (newDevices.length > 0) {\n newCalls.push({\n ...call,\n \"m.call_id\": this.groupCallId,\n \"m.devices\": newDevices,\n });\n }\n\n const newContent: IGroupCallRoomMemberState = { \"m.calls\": newCalls };\n\n await this.client.sendStateEvent(this.room.roomId, EventType.GroupCallMemberPrefix, newContent, localUserId, {\n keepAlive,\n });\n }\n\n private async addDeviceToMemberState(): Promise {\n await this.updateDevices((devices) => [\n ...devices.filter((d) => d.device_id !== this.client.getDeviceId()!),\n {\n device_id: this.client.getDeviceId()!,\n session_id: this.client.getSessionId(),\n expires_ts: Date.now() + DEVICE_TIMEOUT,\n feeds: this.getLocalFeeds().map((feed) => ({ purpose: feed.purpose })),\n // TODO: Add data channels\n },\n ]);\n }\n\n private async updateMemberState(): Promise {\n // Clear the old update interval before proceeding\n if (this.resendMemberStateTimer !== null) {\n clearInterval(this.resendMemberStateTimer);\n this.resendMemberStateTimer = null;\n }\n\n if (this.state === GroupCallState.Entered) {\n // Add the local device\n await this.addDeviceToMemberState();\n\n // Resend the state event every so often so it doesn't become stale\n this.resendMemberStateTimer = setInterval(async () => {\n logger.log(`GroupCall ${this.groupCallId} updateMemberState() resending call member state\"`);\n try {\n await this.addDeviceToMemberState();\n } catch (e) {\n logger.error(\n `GroupCall ${this.groupCallId} updateMemberState() failed to resend call member state`,\n e,\n );\n }\n }, (DEVICE_TIMEOUT * 3) / 4);\n } else {\n // Remove the local device\n await this.updateDevices(\n (devices) => devices.filter((d) => d.device_id !== this.client.getDeviceId()!),\n true,\n );\n }\n }\n\n /**\n * Cleans up our member state by filtering out logged out devices, inactive\n * devices, and our own device (if we know we haven't entered).\n */\n public async cleanMemberState(): Promise {\n const { devices: myDevices } = await this.client.getDevices();\n const deviceMap = new Map(myDevices.map((d) => [d.device_id, d]));\n\n // updateDevices takes care of filtering out inactive devices for us\n await this.updateDevices((devices) => {\n const newDevices = devices.filter((d) => {\n const device = deviceMap.get(d.device_id);\n return (\n device?.last_seen_ts !== undefined &&\n !(\n d.device_id === this.client.getDeviceId()! &&\n this.state !== GroupCallState.Entered &&\n !this.enteredViaAnotherSession\n )\n );\n });\n\n // Skip the update if the devices are unchanged\n return newDevices.length === devices.length ? null : newDevices;\n });\n }\n\n private onRoomState = (): void => this.updateParticipants();\n\n private onParticipantsChanged = (): void => {\n // Re-run setTracksEnabled on all calls, so that participants that just\n // left get denied access to our media, and participants that just\n // joined get granted access\n this.forEachCall((call) => {\n const expected = this.callExpected(call);\n for (const feed of call.getLocalFeeds()) {\n setTracksEnabled(feed.stream.getAudioTracks(), !feed.isAudioMuted() && expected);\n setTracksEnabled(feed.stream.getVideoTracks(), !feed.isVideoMuted() && expected);\n }\n });\n\n if (this.state === GroupCallState.Entered) this.placeOutgoingCalls();\n };\n\n private onStateChanged = (newState: GroupCallState, oldState: GroupCallState): void => {\n if (\n newState === GroupCallState.Entered ||\n oldState === GroupCallState.Entered ||\n newState === GroupCallState.Ended\n ) {\n // We either entered, left, or ended the call\n this.updateParticipants();\n this.updateMemberState().catch((e) =>\n logger.error(\n `GroupCall ${this.groupCallId} onStateChanged() failed to update member state devices\"`,\n e,\n ),\n );\n }\n };\n\n private onLocalFeedsChanged = (): void => {\n if (this.state === GroupCallState.Entered) {\n this.updateMemberState().catch((e) =>\n logger.error(\n `GroupCall ${this.groupCallId} onLocalFeedsChanged() failed to update member state feeds`,\n e,\n ),\n );\n }\n };\n\n public getGroupCallStats(): GroupCallStats {\n return this.stats;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts deleted file mode 100644 index bbaa3ba..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts +++ /dev/null @@ -1,31 +0,0 @@ -import { MatrixClient } from "../client"; -import { GroupCall } from "./groupCall"; -import { RoomMember } from "../models/room-member"; -export declare enum GroupCallEventHandlerEvent { - Incoming = "GroupCall.incoming", - Outgoing = "GroupCall.outgoing", - Ended = "GroupCall.ended", - Participants = "GroupCall.participants" -} -export type GroupCallEventHandlerEventHandlerMap = { - [GroupCallEventHandlerEvent.Incoming]: (call: GroupCall) => void; - [GroupCallEventHandlerEvent.Outgoing]: (call: GroupCall) => void; - [GroupCallEventHandlerEvent.Ended]: (call: GroupCall) => void; - [GroupCallEventHandlerEvent.Participants]: (participants: RoomMember[], call: GroupCall) => void; -}; -export declare class GroupCallEventHandler { - private client; - groupCalls: Map; - private roomDeferreds; - constructor(client: MatrixClient); - start(): Promise; - stop(): void; - private getRoomDeferred; - waitUntilRoomReadyForGroupCalls(roomId: string): Promise; - getGroupCallById(groupCallId: string): GroupCall | undefined; - private createGroupCallForRoom; - private createGroupCallFromRoomStateEvent; - private onRoomsChanged; - private onRoomStateChanged; -} -//# sourceMappingURL=groupCallEventHandler.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts.map deleted file mode 100644 index bbab3a2..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"groupCallEventHandler.d.ts","sourceRoot":"","sources":["../../src/webrtc/groupCallEventHandler.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,YAAY,EAAe,MAAM,WAAW,CAAC;AACtD,OAAO,EAAE,SAAS,EAAgE,MAAM,aAAa,CAAC;AAGtG,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAKnD,oBAAY,0BAA0B;IAClC,QAAQ,uBAAuB;IAC/B,QAAQ,uBAAuB;IAC/B,KAAK,oBAAoB;IACzB,YAAY,2BAA2B;CAC1C;AAED,MAAM,MAAM,oCAAoC,GAAG;IAC/C,CAAC,0BAA0B,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,SAAS,KAAK,IAAI,CAAC;IACjE,CAAC,0BAA0B,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,SAAS,KAAK,IAAI,CAAC;IACjE,CAAC,0BAA0B,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,EAAE,SAAS,KAAK,IAAI,CAAC;IAC9D,CAAC,0BAA0B,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE,IAAI,EAAE,SAAS,KAAK,IAAI,CAAC;CACpG,CAAC;AAOF,qBAAa,qBAAqB;IASX,OAAO,CAAC,MAAM;IAR1B,UAAU,yBAAgC;IAMjD,OAAO,CAAC,aAAa,CAAmC;gBAE7B,MAAM,EAAE,YAAY;IAElC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IA6B5B,IAAI,IAAI,IAAI;IAInB,OAAO,CAAC,eAAe;IAgBhB,+BAA+B,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI9D,gBAAgB,CAAC,WAAW,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS;IAInE,OAAO,CAAC,sBAAsB;IAyB9B,OAAO,CAAC,iCAAiC;IA6DzC,OAAO,CAAC,cAAc,CAEpB;IAEF,OAAO,CAAC,kBAAkB,CA2BxB;CACL"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js deleted file mode 100644 index c043b40..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js +++ /dev/null @@ -1,184 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.GroupCallEventHandlerEvent = exports.GroupCallEventHandler = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _client = require("../client"); -var _groupCall = require("./groupCall"); -var _roomState = require("../models/room-state"); -var _logger = require("../logger"); -var _event = require("../@types/event"); -var _sync = require("../sync"); -/* -Copyright 2021 Šimon Brandner - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let GroupCallEventHandlerEvent; -exports.GroupCallEventHandlerEvent = GroupCallEventHandlerEvent; -(function (GroupCallEventHandlerEvent) { - GroupCallEventHandlerEvent["Incoming"] = "GroupCall.incoming"; - GroupCallEventHandlerEvent["Outgoing"] = "GroupCall.outgoing"; - GroupCallEventHandlerEvent["Ended"] = "GroupCall.ended"; - GroupCallEventHandlerEvent["Participants"] = "GroupCall.participants"; -})(GroupCallEventHandlerEvent || (exports.GroupCallEventHandlerEvent = GroupCallEventHandlerEvent = {})); -class GroupCallEventHandler { - // roomId -> GroupCall - - // All rooms we know about and whether we've seen a 'Room' event - // for them. The promise will be fulfilled once we've processed that - // event which means we're "up to date" on what calls are in a room - // and get - - constructor(client) { - this.client = client; - (0, _defineProperty2.default)(this, "groupCalls", new Map()); - (0, _defineProperty2.default)(this, "roomDeferreds", new Map()); - (0, _defineProperty2.default)(this, "onRoomsChanged", room => { - this.createGroupCallForRoom(room); - }); - (0, _defineProperty2.default)(this, "onRoomStateChanged", (event, state) => { - const eventType = event.getType(); - if (eventType === _event.EventType.GroupCallPrefix) { - const groupCallId = event.getStateKey(); - const content = event.getContent(); - const currentGroupCall = this.groupCalls.get(state.roomId); - if (!currentGroupCall && !content["m.terminated"] && !event.isRedacted()) { - this.createGroupCallFromRoomStateEvent(event); - } else if (currentGroupCall && currentGroupCall.groupCallId === groupCallId) { - if (content["m.terminated"] || event.isRedacted()) { - currentGroupCall.terminate(false); - } else if (content["m.type"] !== currentGroupCall.type) { - // TODO: Handle the callType changing when the room state changes - _logger.logger.warn(`GroupCallEventHandler onRoomStateChanged() currently does not support changing type (roomId=${state.roomId})`); - } - } else if (currentGroupCall && currentGroupCall.groupCallId !== groupCallId) { - // TODO: Handle new group calls and multiple group calls - _logger.logger.warn(`GroupCallEventHandler onRoomStateChanged() currently does not support multiple calls (roomId=${state.roomId})`); - } - } - }); - } - async start() { - // We wait until the client has started syncing for real. - // This is because we only support one call at a time, and want - // the latest. We therefore want the latest state of the room before - // we create a group call for the room so we can be fairly sure that - // the group call we create is really the latest one. - if (this.client.getSyncState() !== _sync.SyncState.Syncing) { - _logger.logger.debug("GroupCallEventHandler start() waiting for client to start syncing"); - await new Promise(resolve => { - const onSync = () => { - if (this.client.getSyncState() === _sync.SyncState.Syncing) { - this.client.off(_client.ClientEvent.Sync, onSync); - return resolve(); - } - }; - this.client.on(_client.ClientEvent.Sync, onSync); - }); - } - const rooms = this.client.getRooms(); - for (const room of rooms) { - this.createGroupCallForRoom(room); - } - this.client.on(_client.ClientEvent.Room, this.onRoomsChanged); - this.client.on(_roomState.RoomStateEvent.Events, this.onRoomStateChanged); - } - stop() { - this.client.removeListener(_roomState.RoomStateEvent.Events, this.onRoomStateChanged); - } - getRoomDeferred(roomId) { - let deferred = this.roomDeferreds.get(roomId); - if (deferred === undefined) { - let resolveFunc; - deferred = { - prom: new Promise(resolve => { - resolveFunc = resolve; - }) - }; - deferred.resolve = resolveFunc; - this.roomDeferreds.set(roomId, deferred); - } - return deferred; - } - waitUntilRoomReadyForGroupCalls(roomId) { - return this.getRoomDeferred(roomId).prom; - } - getGroupCallById(groupCallId) { - return [...this.groupCalls.values()].find(groupCall => groupCall.groupCallId === groupCallId); - } - createGroupCallForRoom(room) { - const callEvents = room.currentState.getStateEvents(_event.EventType.GroupCallPrefix); - const sortedCallEvents = callEvents.sort((a, b) => b.getTs() - a.getTs()); - for (const callEvent of sortedCallEvents) { - const content = callEvent.getContent(); - if (content["m.terminated"] || callEvent.isRedacted()) { - continue; - } - _logger.logger.debug(`GroupCallEventHandler createGroupCallForRoom() choosing group call from possible calls (stateKey=${callEvent.getStateKey()}, ts=${callEvent.getTs()}, roomId=${room.roomId}, numOfPossibleCalls=${callEvents.length})`); - this.createGroupCallFromRoomStateEvent(callEvent); - break; - } - _logger.logger.info(`GroupCallEventHandler createGroupCallForRoom() processed room (roomId=${room.roomId})`); - this.getRoomDeferred(room.roomId).resolve(); - } - createGroupCallFromRoomStateEvent(event) { - const roomId = event.getRoomId(); - const content = event.getContent(); - const room = this.client.getRoom(roomId); - if (!room) { - _logger.logger.warn(`GroupCallEventHandler createGroupCallFromRoomStateEvent() couldn't find room for call (roomId=${roomId})`); - return; - } - const groupCallId = event.getStateKey(); - const callType = content["m.type"]; - if (!Object.values(_groupCall.GroupCallType).includes(callType)) { - _logger.logger.warn(`GroupCallEventHandler createGroupCallFromRoomStateEvent() received invalid call type (type=${callType}, roomId=${roomId})`); - return; - } - const callIntent = content["m.intent"]; - if (!Object.values(_groupCall.GroupCallIntent).includes(callIntent)) { - _logger.logger.warn(`Received invalid group call intent (type=${callType}, roomId=${roomId})`); - return; - } - const isPtt = Boolean(content["io.element.ptt"]); - let dataChannelOptions; - if (content !== null && content !== void 0 && content.dataChannelsEnabled && content !== null && content !== void 0 && content.dataChannelOptions) { - // Pull out just the dataChannelOptions we want to support. - const { - ordered, - maxPacketLifeTime, - maxRetransmits, - protocol - } = content.dataChannelOptions; - dataChannelOptions = { - ordered, - maxPacketLifeTime, - maxRetransmits, - protocol - }; - } - const groupCall = new _groupCall.GroupCall(this.client, room, callType, isPtt, callIntent, groupCallId, - // Because without Media section a WebRTC connection is not possible, so need a RTCDataChannel to set up a - // no media WebRTC connection anyway. - (content === null || content === void 0 ? void 0 : content.dataChannelsEnabled) || this.client.isVoipWithNoMediaAllowed, dataChannelOptions, this.client.isVoipWithNoMediaAllowed); - this.groupCalls.set(room.roomId, groupCall); - this.client.emit(GroupCallEventHandlerEvent.Incoming, groupCall); - return groupCall; - } -} -exports.GroupCallEventHandler = GroupCallEventHandler; -//# sourceMappingURL=groupCallEventHandler.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js.map deleted file mode 100644 index b5da56c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/groupCallEventHandler.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"groupCallEventHandler.js","names":["_client","require","_groupCall","_roomState","_logger","_event","_sync","GroupCallEventHandlerEvent","exports","GroupCallEventHandler","constructor","client","_defineProperty2","default","Map","room","createGroupCallForRoom","event","state","eventType","getType","EventType","GroupCallPrefix","groupCallId","getStateKey","content","getContent","currentGroupCall","groupCalls","get","roomId","isRedacted","createGroupCallFromRoomStateEvent","terminate","type","logger","warn","start","getSyncState","SyncState","Syncing","debug","Promise","resolve","onSync","off","ClientEvent","Sync","on","rooms","getRooms","Room","onRoomsChanged","RoomStateEvent","Events","onRoomStateChanged","stop","removeListener","getRoomDeferred","deferred","roomDeferreds","undefined","resolveFunc","prom","set","waitUntilRoomReadyForGroupCalls","getGroupCallById","values","find","groupCall","callEvents","currentState","getStateEvents","sortedCallEvents","sort","a","b","getTs","callEvent","length","info","getRoomId","getRoom","callType","Object","GroupCallType","includes","callIntent","GroupCallIntent","isPtt","Boolean","dataChannelOptions","dataChannelsEnabled","ordered","maxPacketLifeTime","maxRetransmits","protocol","GroupCall","isVoipWithNoMediaAllowed","emit","Incoming"],"sources":["../../src/webrtc/groupCallEventHandler.ts"],"sourcesContent":["/*\nCopyright 2021 Šimon Brandner \n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { MatrixEvent } from \"../models/event\";\nimport { MatrixClient, ClientEvent } from \"../client\";\nimport { GroupCall, GroupCallIntent, GroupCallType, IGroupCallDataChannelOptions } from \"./groupCall\";\nimport { Room } from \"../models/room\";\nimport { RoomState, RoomStateEvent } from \"../models/room-state\";\nimport { RoomMember } from \"../models/room-member\";\nimport { logger } from \"../logger\";\nimport { EventType } from \"../@types/event\";\nimport { SyncState } from \"../sync\";\n\nexport enum GroupCallEventHandlerEvent {\n Incoming = \"GroupCall.incoming\",\n Outgoing = \"GroupCall.outgoing\",\n Ended = \"GroupCall.ended\",\n Participants = \"GroupCall.participants\",\n}\n\nexport type GroupCallEventHandlerEventHandlerMap = {\n [GroupCallEventHandlerEvent.Incoming]: (call: GroupCall) => void;\n [GroupCallEventHandlerEvent.Outgoing]: (call: GroupCall) => void;\n [GroupCallEventHandlerEvent.Ended]: (call: GroupCall) => void;\n [GroupCallEventHandlerEvent.Participants]: (participants: RoomMember[], call: GroupCall) => void;\n};\n\ninterface RoomDeferred {\n prom: Promise;\n resolve?: () => void;\n}\n\nexport class GroupCallEventHandler {\n public groupCalls = new Map(); // roomId -> GroupCall\n\n // All rooms we know about and whether we've seen a 'Room' event\n // for them. The promise will be fulfilled once we've processed that\n // event which means we're \"up to date\" on what calls are in a room\n // and get\n private roomDeferreds = new Map();\n\n public constructor(private client: MatrixClient) {}\n\n public async start(): Promise {\n // We wait until the client has started syncing for real.\n // This is because we only support one call at a time, and want\n // the latest. We therefore want the latest state of the room before\n // we create a group call for the room so we can be fairly sure that\n // the group call we create is really the latest one.\n if (this.client.getSyncState() !== SyncState.Syncing) {\n logger.debug(\"GroupCallEventHandler start() waiting for client to start syncing\");\n await new Promise((resolve) => {\n const onSync = (): void => {\n if (this.client.getSyncState() === SyncState.Syncing) {\n this.client.off(ClientEvent.Sync, onSync);\n return resolve();\n }\n };\n this.client.on(ClientEvent.Sync, onSync);\n });\n }\n\n const rooms = this.client.getRooms();\n\n for (const room of rooms) {\n this.createGroupCallForRoom(room);\n }\n\n this.client.on(ClientEvent.Room, this.onRoomsChanged);\n this.client.on(RoomStateEvent.Events, this.onRoomStateChanged);\n }\n\n public stop(): void {\n this.client.removeListener(RoomStateEvent.Events, this.onRoomStateChanged);\n }\n\n private getRoomDeferred(roomId: string): RoomDeferred {\n let deferred = this.roomDeferreds.get(roomId);\n if (deferred === undefined) {\n let resolveFunc: () => void;\n deferred = {\n prom: new Promise((resolve) => {\n resolveFunc = resolve;\n }),\n };\n deferred.resolve = resolveFunc!;\n this.roomDeferreds.set(roomId, deferred);\n }\n\n return deferred;\n }\n\n public waitUntilRoomReadyForGroupCalls(roomId: string): Promise {\n return this.getRoomDeferred(roomId).prom;\n }\n\n public getGroupCallById(groupCallId: string): GroupCall | undefined {\n return [...this.groupCalls.values()].find((groupCall) => groupCall.groupCallId === groupCallId);\n }\n\n private createGroupCallForRoom(room: Room): void {\n const callEvents = room.currentState.getStateEvents(EventType.GroupCallPrefix);\n const sortedCallEvents = callEvents.sort((a, b) => b.getTs() - a.getTs());\n\n for (const callEvent of sortedCallEvents) {\n const content = callEvent.getContent();\n\n if (content[\"m.terminated\"] || callEvent.isRedacted()) {\n continue;\n }\n\n logger.debug(\n `GroupCallEventHandler createGroupCallForRoom() choosing group call from possible calls (stateKey=${callEvent.getStateKey()}, ts=${callEvent.getTs()}, roomId=${\n room.roomId\n }, numOfPossibleCalls=${callEvents.length})`,\n );\n\n this.createGroupCallFromRoomStateEvent(callEvent);\n break;\n }\n\n logger.info(`GroupCallEventHandler createGroupCallForRoom() processed room (roomId=${room.roomId})`);\n this.getRoomDeferred(room.roomId).resolve!();\n }\n\n private createGroupCallFromRoomStateEvent(event: MatrixEvent): GroupCall | undefined {\n const roomId = event.getRoomId();\n const content = event.getContent();\n\n const room = this.client.getRoom(roomId);\n\n if (!room) {\n logger.warn(\n `GroupCallEventHandler createGroupCallFromRoomStateEvent() couldn't find room for call (roomId=${roomId})`,\n );\n return;\n }\n\n const groupCallId = event.getStateKey();\n\n const callType = content[\"m.type\"];\n\n if (!Object.values(GroupCallType).includes(callType)) {\n logger.warn(\n `GroupCallEventHandler createGroupCallFromRoomStateEvent() received invalid call type (type=${callType}, roomId=${roomId})`,\n );\n return;\n }\n\n const callIntent = content[\"m.intent\"];\n\n if (!Object.values(GroupCallIntent).includes(callIntent)) {\n logger.warn(`Received invalid group call intent (type=${callType}, roomId=${roomId})`);\n return;\n }\n\n const isPtt = Boolean(content[\"io.element.ptt\"]);\n\n let dataChannelOptions: IGroupCallDataChannelOptions | undefined;\n\n if (content?.dataChannelsEnabled && content?.dataChannelOptions) {\n // Pull out just the dataChannelOptions we want to support.\n const { ordered, maxPacketLifeTime, maxRetransmits, protocol } = content.dataChannelOptions;\n dataChannelOptions = { ordered, maxPacketLifeTime, maxRetransmits, protocol };\n }\n\n const groupCall = new GroupCall(\n this.client,\n room,\n callType,\n isPtt,\n callIntent,\n groupCallId,\n // Because without Media section a WebRTC connection is not possible, so need a RTCDataChannel to set up a\n // no media WebRTC connection anyway.\n content?.dataChannelsEnabled || this.client.isVoipWithNoMediaAllowed,\n dataChannelOptions,\n this.client.isVoipWithNoMediaAllowed,\n );\n\n this.groupCalls.set(room.roomId, groupCall);\n this.client.emit(GroupCallEventHandlerEvent.Incoming, groupCall);\n\n return groupCall;\n }\n\n private onRoomsChanged = (room: Room): void => {\n this.createGroupCallForRoom(room);\n };\n\n private onRoomStateChanged = (event: MatrixEvent, state: RoomState): void => {\n const eventType = event.getType();\n\n if (eventType === EventType.GroupCallPrefix) {\n const groupCallId = event.getStateKey();\n const content = event.getContent();\n\n const currentGroupCall = this.groupCalls.get(state.roomId);\n\n if (!currentGroupCall && !content[\"m.terminated\"] && !event.isRedacted()) {\n this.createGroupCallFromRoomStateEvent(event);\n } else if (currentGroupCall && currentGroupCall.groupCallId === groupCallId) {\n if (content[\"m.terminated\"] || event.isRedacted()) {\n currentGroupCall.terminate(false);\n } else if (content[\"m.type\"] !== currentGroupCall.type) {\n // TODO: Handle the callType changing when the room state changes\n logger.warn(\n `GroupCallEventHandler onRoomStateChanged() currently does not support changing type (roomId=${state.roomId})`,\n );\n }\n } else if (currentGroupCall && currentGroupCall.groupCallId !== groupCallId) {\n // TODO: Handle new group calls and multiple group calls\n logger.warn(\n `GroupCallEventHandler onRoomStateChanged() currently does not support multiple calls (roomId=${state.roomId})`,\n );\n }\n }\n };\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts deleted file mode 100644 index 8841691..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts +++ /dev/null @@ -1,86 +0,0 @@ -import { TypedEventEmitter } from "../models/typed-event-emitter"; -import { MatrixClient } from "../client"; -export declare enum MediaHandlerEvent { - LocalStreamsChanged = "local_streams_changed" -} -export type MediaHandlerEventHandlerMap = { - [MediaHandlerEvent.LocalStreamsChanged]: () => void; -}; -export interface IScreensharingOpts { - desktopCapturerSourceId?: string; - audio?: boolean; - throwOnFail?: boolean; -} -export interface AudioSettings { - autoGainControl: boolean; - echoCancellation: boolean; - noiseSuppression: boolean; -} -export declare class MediaHandler extends TypedEventEmitter { - private client; - private audioInput?; - private audioSettings?; - private videoInput?; - private localUserMediaStream?; - userMediaStreams: MediaStream[]; - screensharingStreams: MediaStream[]; - private getMediaStreamPromise?; - constructor(client: MatrixClient); - restoreMediaSettings(audioInput: string, videoInput: string): void; - /** - * Set an audio input device to use for MatrixCalls - * @param deviceId - the identifier for the device - * undefined treated as unset - */ - setAudioInput(deviceId: string): Promise; - /** - * Set audio settings for MatrixCalls - * @param opts - audio options to set - */ - setAudioSettings(opts: AudioSettings): Promise; - /** - * Set a video input device to use for MatrixCalls - * @param deviceId - the identifier for the device - * undefined treated as unset - */ - setVideoInput(deviceId: string): Promise; - /** - * Set media input devices to use for MatrixCalls - * @param audioInput - the identifier for the audio device - * @param videoInput - the identifier for the video device - * undefined treated as unset - */ - setMediaInputs(audioInput: string, videoInput: string): Promise; - updateLocalUsermediaStreams(): Promise; - hasAudioDevice(): Promise; - hasVideoDevice(): Promise; - /** - * @param audio - should have an audio track - * @param video - should have a video track - * @param reusable - is allowed to be reused by the MediaHandler - * @returns based on passed parameters - */ - getUserMediaStream(audio: boolean, video: boolean, reusable?: boolean): Promise; - private getUserMediaStreamInternal; - /** - * Stops all tracks on the provided usermedia stream - */ - stopUserMediaStream(mediaStream: MediaStream): void; - /** - * @param desktopCapturerSourceId - sourceId for Electron DesktopCapturer - * @param reusable - is allowed to be reused by the MediaHandler - * @returns based on passed parameters - */ - getScreensharingStream(opts?: IScreensharingOpts, reusable?: boolean): Promise; - /** - * Stops all tracks on the provided screensharing stream - */ - stopScreensharingStream(mediaStream: MediaStream): void; - /** - * Stops all local media tracks - */ - stopAllStreams(): void; - private getUserMediaContraints; - private getScreenshareContraints; -} -//# sourceMappingURL=mediaHandler.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts.map deleted file mode 100644 index 46b2943..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaHandler.d.ts","sourceRoot":"","sources":["../../src/webrtc/mediaHandler.ts"],"names":[],"mappings":"AAmBA,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAGlE,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC,oBAAY,iBAAiB;IACzB,mBAAmB,0BAA0B;CAChD;AAED,MAAM,MAAM,2BAA2B,GAAG;IACtC,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,EAAE,MAAM,IAAI,CAAC;CACvD,CAAC;AAEF,MAAM,WAAW,kBAAkB;IAC/B,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,KAAK,CAAC,EAAE,OAAO,CAAC;IAKhB,WAAW,CAAC,EAAE,OAAO,CAAC;CACzB;AAED,MAAM,WAAW,aAAa;IAC1B,eAAe,EAAE,OAAO,CAAC;IACzB,gBAAgB,EAAE,OAAO,CAAC;IAC1B,gBAAgB,EAAE,OAAO,CAAC;CAC7B;AAED,qBAAa,YAAa,SAAQ,iBAAiB,CAC/C,iBAAiB,CAAC,mBAAmB,EACrC,2BAA2B,CAC9B;IAWsB,OAAO,CAAC,MAAM;IAVjC,OAAO,CAAC,UAAU,CAAC,CAAS;IAC5B,OAAO,CAAC,aAAa,CAAC,CAAgB;IACtC,OAAO,CAAC,UAAU,CAAC,CAAS;IAC5B,OAAO,CAAC,oBAAoB,CAAC,CAAc;IACpC,gBAAgB,EAAE,WAAW,EAAE,CAAM;IACrC,oBAAoB,EAAE,WAAW,EAAE,CAAM;IAGhD,OAAO,CAAC,qBAAqB,CAAC,CAAuB;gBAE1B,MAAM,EAAE,YAAY;IAIxC,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI;IAKzE;;;;OAIG;IACU,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS3D;;;OAGG;IACU,gBAAgB,CAAC,IAAI,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAOjE;;;;OAIG;IACU,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS3D;;;;;OAKG;IACU,cAAc,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAUrE,2BAA2B,IAAI,OAAO,CAAC,IAAI,CAAC;IA4D5C,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC;IAUlC,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC;IAU/C;;;;;OAKG;IACU,kBAAkB,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,UAAO,GAAG,OAAO,CAAC,WAAW,CAAC;YAaxF,0BAA0B;IAyFxC;;OAEG;IACI,mBAAmB,CAAC,WAAW,EAAE,WAAW,GAAG,IAAI;IAuB1D;;;;OAIG;IACU,sBAAsB,CAAC,IAAI,GAAE,kBAAuB,EAAE,QAAQ,UAAO,GAAG,OAAO,CAAC,WAAW,CAAC;IAkCzG;;OAEG;IACI,uBAAuB,CAAC,WAAW,EAAE,WAAW,GAAG,IAAI;IAgB9D;;OAEG;IACI,cAAc,IAAI,IAAI;IAqB7B,OAAO,CAAC,sBAAsB;IA2B9B,OAAO,CAAC,wBAAwB;CAmBnC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js deleted file mode 100644 index b82bb4a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js +++ /dev/null @@ -1,399 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MediaHandlerEvent = exports.MediaHandler = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _typedEventEmitter = require("../models/typed-event-emitter"); -var _groupCall = require("../webrtc/groupCall"); -var _logger = require("../logger"); -/* -Copyright 2015, 2016 OpenMarket Ltd -Copyright 2017 New Vector Ltd -Copyright 2019, 2020 The Matrix.org Foundation C.I.C. -Copyright 2021 - 2022 Šimon Brandner - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let MediaHandlerEvent; -exports.MediaHandlerEvent = MediaHandlerEvent; -(function (MediaHandlerEvent) { - MediaHandlerEvent["LocalStreamsChanged"] = "local_streams_changed"; -})(MediaHandlerEvent || (exports.MediaHandlerEvent = MediaHandlerEvent = {})); -class MediaHandler extends _typedEventEmitter.TypedEventEmitter { - // Promise chain to serialise calls to getMediaStream - - constructor(client) { - super(); - this.client = client; - (0, _defineProperty2.default)(this, "audioInput", void 0); - (0, _defineProperty2.default)(this, "audioSettings", void 0); - (0, _defineProperty2.default)(this, "videoInput", void 0); - (0, _defineProperty2.default)(this, "localUserMediaStream", void 0); - (0, _defineProperty2.default)(this, "userMediaStreams", []); - (0, _defineProperty2.default)(this, "screensharingStreams", []); - (0, _defineProperty2.default)(this, "getMediaStreamPromise", void 0); - } - restoreMediaSettings(audioInput, videoInput) { - this.audioInput = audioInput; - this.videoInput = videoInput; - } - - /** - * Set an audio input device to use for MatrixCalls - * @param deviceId - the identifier for the device - * undefined treated as unset - */ - async setAudioInput(deviceId) { - _logger.logger.info(`MediaHandler setAudioInput() running (deviceId=${deviceId})`); - if (this.audioInput === deviceId) return; - this.audioInput = deviceId; - await this.updateLocalUsermediaStreams(); - } - - /** - * Set audio settings for MatrixCalls - * @param opts - audio options to set - */ - async setAudioSettings(opts) { - _logger.logger.info(`MediaHandler setAudioSettings() running (opts=${JSON.stringify(opts)})`); - this.audioSettings = Object.assign({}, opts); - await this.updateLocalUsermediaStreams(); - } - - /** - * Set a video input device to use for MatrixCalls - * @param deviceId - the identifier for the device - * undefined treated as unset - */ - async setVideoInput(deviceId) { - _logger.logger.info(`MediaHandler setVideoInput() running (deviceId=${deviceId})`); - if (this.videoInput === deviceId) return; - this.videoInput = deviceId; - await this.updateLocalUsermediaStreams(); - } - - /** - * Set media input devices to use for MatrixCalls - * @param audioInput - the identifier for the audio device - * @param videoInput - the identifier for the video device - * undefined treated as unset - */ - async setMediaInputs(audioInput, videoInput) { - _logger.logger.log(`MediaHandler setMediaInputs() running (audioInput: ${audioInput} videoInput: ${videoInput})`); - this.audioInput = audioInput; - this.videoInput = videoInput; - await this.updateLocalUsermediaStreams(); - } - - /* - * Requests new usermedia streams and replace the old ones - */ - async updateLocalUsermediaStreams() { - if (this.userMediaStreams.length === 0) return; - const callMediaStreamParams = new Map(); - for (const call of this.client.callEventHandler.calls.values()) { - callMediaStreamParams.set(call.callId, { - audio: call.hasLocalUserMediaAudioTrack, - video: call.hasLocalUserMediaVideoTrack - }); - } - for (const stream of this.userMediaStreams) { - _logger.logger.log(`MediaHandler updateLocalUsermediaStreams() stopping all tracks (streamId=${stream.id})`); - for (const track of stream.getTracks()) { - track.stop(); - } - } - this.userMediaStreams = []; - this.localUserMediaStream = undefined; - for (const call of this.client.callEventHandler.calls.values()) { - if (call.callHasEnded() || !callMediaStreamParams.has(call.callId)) { - continue; - } - const { - audio, - video - } = callMediaStreamParams.get(call.callId); - _logger.logger.log(`MediaHandler updateLocalUsermediaStreams() calling getUserMediaStream() (callId=${call.callId})`); - const stream = await this.getUserMediaStream(audio, video); - if (call.callHasEnded()) { - continue; - } - await call.updateLocalUsermediaStream(stream); - } - for (const groupCall of this.client.groupCallEventHandler.groupCalls.values()) { - if (!groupCall.localCallFeed) { - continue; - } - _logger.logger.log(`MediaHandler updateLocalUsermediaStreams() calling getUserMediaStream() (groupCallId=${groupCall.groupCallId})`); - const stream = await this.getUserMediaStream(true, groupCall.type === _groupCall.GroupCallType.Video); - if (groupCall.state === _groupCall.GroupCallState.Ended) { - continue; - } - await groupCall.updateLocalUsermediaStream(stream); - } - this.emit(MediaHandlerEvent.LocalStreamsChanged); - } - async hasAudioDevice() { - try { - const devices = await navigator.mediaDevices.enumerateDevices(); - return devices.filter(device => device.kind === "audioinput").length > 0; - } catch (err) { - _logger.logger.log(`MediaHandler hasAudioDevice() calling navigator.mediaDevices.enumerateDevices with error`, err); - return false; - } - } - async hasVideoDevice() { - try { - const devices = await navigator.mediaDevices.enumerateDevices(); - return devices.filter(device => device.kind === "videoinput").length > 0; - } catch (err) { - _logger.logger.log(`MediaHandler hasVideoDevice() calling navigator.mediaDevices.enumerateDevices with error`, err); - return false; - } - } - - /** - * @param audio - should have an audio track - * @param video - should have a video track - * @param reusable - is allowed to be reused by the MediaHandler - * @returns based on passed parameters - */ - async getUserMediaStream(audio, video, reusable = true) { - // Serialise calls, othertwise we can't sensibly re-use the stream - if (this.getMediaStreamPromise) { - this.getMediaStreamPromise = this.getMediaStreamPromise.then(() => { - return this.getUserMediaStreamInternal(audio, video, reusable); - }); - } else { - this.getMediaStreamPromise = this.getUserMediaStreamInternal(audio, video, reusable); - } - return this.getMediaStreamPromise; - } - async getUserMediaStreamInternal(audio, video, reusable) { - const shouldRequestAudio = audio && (await this.hasAudioDevice()); - const shouldRequestVideo = video && (await this.hasVideoDevice()); - let stream; - let canReuseStream = true; - if (this.localUserMediaStream) { - var _this$localUserMediaS, _this$localUserMediaS2, _this$localUserMediaS3, _this$localUserMediaS4; - // This figures out if we can reuse the current localUsermediaStream - // based on whether or not the "mute state" (presence of tracks of a - // given kind) matches what is being requested - if (shouldRequestAudio !== this.localUserMediaStream.getAudioTracks().length > 0) { - canReuseStream = false; - } - if (shouldRequestVideo !== this.localUserMediaStream.getVideoTracks().length > 0) { - canReuseStream = false; - } - - // This code checks that the device ID is the same as the localUserMediaStream stream, but we update - // the localUserMediaStream whenever the device ID changes (apart from when restoring) so it's not - // clear why this would ever be different, unless there's a race. - if (shouldRequestAudio && ((_this$localUserMediaS = this.localUserMediaStream.getAudioTracks()[0]) === null || _this$localUserMediaS === void 0 ? void 0 : (_this$localUserMediaS2 = _this$localUserMediaS.getSettings()) === null || _this$localUserMediaS2 === void 0 ? void 0 : _this$localUserMediaS2.deviceId) !== this.audioInput) { - canReuseStream = false; - } - if (shouldRequestVideo && ((_this$localUserMediaS3 = this.localUserMediaStream.getVideoTracks()[0]) === null || _this$localUserMediaS3 === void 0 ? void 0 : (_this$localUserMediaS4 = _this$localUserMediaS3.getSettings()) === null || _this$localUserMediaS4 === void 0 ? void 0 : _this$localUserMediaS4.deviceId) !== this.videoInput) { - canReuseStream = false; - } - } else { - canReuseStream = false; - } - if (!canReuseStream) { - const constraints = this.getUserMediaContraints(shouldRequestAudio, shouldRequestVideo); - stream = await navigator.mediaDevices.getUserMedia(constraints); - _logger.logger.log(`MediaHandler getUserMediaStreamInternal() calling getUserMediaStream (streamId=${stream.id}, shouldRequestAudio=${shouldRequestAudio}, shouldRequestVideo=${shouldRequestVideo}, constraints=${JSON.stringify(constraints)})`); - for (const track of stream.getTracks()) { - const settings = track.getSettings(); - if (track.kind === "audio") { - this.audioInput = settings.deviceId; - } else if (track.kind === "video") { - this.videoInput = settings.deviceId; - } - } - if (reusable) { - this.localUserMediaStream = stream; - } - } else { - var _this$localUserMediaS5; - stream = this.localUserMediaStream.clone(); - _logger.logger.log(`MediaHandler getUserMediaStreamInternal() cloning (oldStreamId=${(_this$localUserMediaS5 = this.localUserMediaStream) === null || _this$localUserMediaS5 === void 0 ? void 0 : _this$localUserMediaS5.id} newStreamId=${stream.id} shouldRequestAudio=${shouldRequestAudio} shouldRequestVideo=${shouldRequestVideo})`); - if (!shouldRequestAudio) { - for (const track of stream.getAudioTracks()) { - stream.removeTrack(track); - } - } - if (!shouldRequestVideo) { - for (const track of stream.getVideoTracks()) { - stream.removeTrack(track); - } - } - } - if (reusable) { - this.userMediaStreams.push(stream); - } - this.emit(MediaHandlerEvent.LocalStreamsChanged); - return stream; - } - - /** - * Stops all tracks on the provided usermedia stream - */ - stopUserMediaStream(mediaStream) { - _logger.logger.log(`MediaHandler stopUserMediaStream() stopping (streamId=${mediaStream.id})`); - for (const track of mediaStream.getTracks()) { - track.stop(); - } - const index = this.userMediaStreams.indexOf(mediaStream); - if (index !== -1) { - _logger.logger.debug(`MediaHandler stopUserMediaStream() splicing usermedia stream out stream array (streamId=${mediaStream.id})`, mediaStream.id); - this.userMediaStreams.splice(index, 1); - } - this.emit(MediaHandlerEvent.LocalStreamsChanged); - if (this.localUserMediaStream === mediaStream) { - this.localUserMediaStream = undefined; - } - } - - /** - * @param desktopCapturerSourceId - sourceId for Electron DesktopCapturer - * @param reusable - is allowed to be reused by the MediaHandler - * @returns based on passed parameters - */ - async getScreensharingStream(opts = {}, reusable = true) { - let stream; - if (this.screensharingStreams.length === 0) { - const screenshareConstraints = this.getScreenshareContraints(opts); - if (opts.desktopCapturerSourceId) { - // We are using Electron - _logger.logger.debug(`MediaHandler getScreensharingStream() calling getUserMedia() (opts=${JSON.stringify(opts)})`); - stream = await navigator.mediaDevices.getUserMedia(screenshareConstraints); - } else { - // We are not using Electron - _logger.logger.debug(`MediaHandler getScreensharingStream() calling getDisplayMedia() (opts=${JSON.stringify(opts)})`); - stream = await navigator.mediaDevices.getDisplayMedia(screenshareConstraints); - } - } else { - const matchingStream = this.screensharingStreams[this.screensharingStreams.length - 1]; - _logger.logger.log(`MediaHandler getScreensharingStream() cloning (streamId=${matchingStream.id})`); - stream = matchingStream.clone(); - } - if (reusable) { - this.screensharingStreams.push(stream); - } - this.emit(MediaHandlerEvent.LocalStreamsChanged); - return stream; - } - - /** - * Stops all tracks on the provided screensharing stream - */ - stopScreensharingStream(mediaStream) { - _logger.logger.debug(`MediaHandler stopScreensharingStream() stopping stream (streamId=${mediaStream.id})`); - for (const track of mediaStream.getTracks()) { - track.stop(); - } - const index = this.screensharingStreams.indexOf(mediaStream); - if (index !== -1) { - _logger.logger.debug(`MediaHandler stopScreensharingStream() splicing stream out (streamId=${mediaStream.id})`); - this.screensharingStreams.splice(index, 1); - } - this.emit(MediaHandlerEvent.LocalStreamsChanged); - } - - /** - * Stops all local media tracks - */ - stopAllStreams() { - for (const stream of this.userMediaStreams) { - _logger.logger.log(`MediaHandler stopAllStreams() stopping (streamId=${stream.id})`); - for (const track of stream.getTracks()) { - track.stop(); - } - } - for (const stream of this.screensharingStreams) { - for (const track of stream.getTracks()) { - track.stop(); - } - } - this.userMediaStreams = []; - this.screensharingStreams = []; - this.localUserMediaStream = undefined; - this.emit(MediaHandlerEvent.LocalStreamsChanged); - } - getUserMediaContraints(audio, video) { - const isWebkit = !!navigator.webkitGetUserMedia; - return { - audio: audio ? { - deviceId: this.audioInput ? { - ideal: this.audioInput - } : undefined, - autoGainControl: this.audioSettings ? { - ideal: this.audioSettings.autoGainControl - } : undefined, - echoCancellation: this.audioSettings ? { - ideal: this.audioSettings.echoCancellation - } : undefined, - noiseSuppression: this.audioSettings ? { - ideal: this.audioSettings.noiseSuppression - } : undefined - } : false, - video: video ? { - deviceId: this.videoInput ? { - ideal: this.videoInput - } : undefined, - /* We want 640x360. Chrome will give it only if we ask exactly, - FF refuses entirely if we ask exactly, so have to ask for ideal - instead - XXX: Is this still true? - */ - width: isWebkit ? { - exact: 640 - } : { - ideal: 640 - }, - height: isWebkit ? { - exact: 360 - } : { - ideal: 360 - } - } : false - }; - } - getScreenshareContraints(opts) { - const { - desktopCapturerSourceId, - audio - } = opts; - if (desktopCapturerSourceId) { - return { - audio: audio !== null && audio !== void 0 ? audio : false, - video: { - mandatory: { - chromeMediaSource: "desktop", - chromeMediaSourceId: desktopCapturerSourceId - } - } - }; - } else { - return { - audio: audio !== null && audio !== void 0 ? audio : false, - video: true - }; - } - } -} -exports.MediaHandler = MediaHandler; -//# sourceMappingURL=mediaHandler.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js.map deleted file mode 100644 index ca5a93f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/mediaHandler.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaHandler.js","names":["_typedEventEmitter","require","_groupCall","_logger","MediaHandlerEvent","exports","MediaHandler","TypedEventEmitter","constructor","client","_defineProperty2","default","restoreMediaSettings","audioInput","videoInput","setAudioInput","deviceId","logger","info","updateLocalUsermediaStreams","setAudioSettings","opts","JSON","stringify","audioSettings","Object","assign","setVideoInput","setMediaInputs","log","userMediaStreams","length","callMediaStreamParams","Map","call","callEventHandler","calls","values","set","callId","audio","hasLocalUserMediaAudioTrack","video","hasLocalUserMediaVideoTrack","stream","id","track","getTracks","stop","localUserMediaStream","undefined","callHasEnded","has","get","getUserMediaStream","updateLocalUsermediaStream","groupCall","groupCallEventHandler","groupCalls","localCallFeed","groupCallId","type","GroupCallType","Video","state","GroupCallState","Ended","emit","LocalStreamsChanged","hasAudioDevice","devices","navigator","mediaDevices","enumerateDevices","filter","device","kind","err","hasVideoDevice","reusable","getMediaStreamPromise","then","getUserMediaStreamInternal","shouldRequestAudio","shouldRequestVideo","canReuseStream","_this$localUserMediaS","_this$localUserMediaS2","_this$localUserMediaS3","_this$localUserMediaS4","getAudioTracks","getVideoTracks","getSettings","constraints","getUserMediaContraints","getUserMedia","settings","_this$localUserMediaS5","clone","removeTrack","push","stopUserMediaStream","mediaStream","index","indexOf","debug","splice","getScreensharingStream","screensharingStreams","screenshareConstraints","getScreenshareContraints","desktopCapturerSourceId","getDisplayMedia","matchingStream","stopScreensharingStream","stopAllStreams","isWebkit","webkitGetUserMedia","ideal","autoGainControl","echoCancellation","noiseSuppression","width","exact","height","mandatory","chromeMediaSource","chromeMediaSourceId"],"sources":["../../src/webrtc/mediaHandler.ts"],"sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\nCopyright 2017 New Vector Ltd\nCopyright 2019, 2020 The Matrix.org Foundation C.I.C.\nCopyright 2021 - 2022 Šimon Brandner \n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { GroupCallType, GroupCallState } from \"../webrtc/groupCall\";\nimport { logger } from \"../logger\";\nimport { MatrixClient } from \"../client\";\n\nexport enum MediaHandlerEvent {\n LocalStreamsChanged = \"local_streams_changed\",\n}\n\nexport type MediaHandlerEventHandlerMap = {\n [MediaHandlerEvent.LocalStreamsChanged]: () => void;\n};\n\nexport interface IScreensharingOpts {\n desktopCapturerSourceId?: string;\n audio?: boolean;\n // For electron screen capture, there are very few options for detecting electron\n // apart from inspecting the user agent or just trying getDisplayMedia() and\n // catching the failure, so we do the latter - this flag tells the function to just\n // throw an error so we can catch it in this case, rather than logging and emitting.\n throwOnFail?: boolean;\n}\n\nexport interface AudioSettings {\n autoGainControl: boolean;\n echoCancellation: boolean;\n noiseSuppression: boolean;\n}\n\nexport class MediaHandler extends TypedEventEmitter<\n MediaHandlerEvent.LocalStreamsChanged,\n MediaHandlerEventHandlerMap\n> {\n private audioInput?: string;\n private audioSettings?: AudioSettings;\n private videoInput?: string;\n private localUserMediaStream?: MediaStream;\n public userMediaStreams: MediaStream[] = [];\n public screensharingStreams: MediaStream[] = [];\n\n // Promise chain to serialise calls to getMediaStream\n private getMediaStreamPromise?: Promise;\n\n public constructor(private client: MatrixClient) {\n super();\n }\n\n public restoreMediaSettings(audioInput: string, videoInput: string): void {\n this.audioInput = audioInput;\n this.videoInput = videoInput;\n }\n\n /**\n * Set an audio input device to use for MatrixCalls\n * @param deviceId - the identifier for the device\n * undefined treated as unset\n */\n public async setAudioInput(deviceId: string): Promise {\n logger.info(`MediaHandler setAudioInput() running (deviceId=${deviceId})`);\n\n if (this.audioInput === deviceId) return;\n\n this.audioInput = deviceId;\n await this.updateLocalUsermediaStreams();\n }\n\n /**\n * Set audio settings for MatrixCalls\n * @param opts - audio options to set\n */\n public async setAudioSettings(opts: AudioSettings): Promise {\n logger.info(`MediaHandler setAudioSettings() running (opts=${JSON.stringify(opts)})`);\n\n this.audioSettings = Object.assign({}, opts) as AudioSettings;\n await this.updateLocalUsermediaStreams();\n }\n\n /**\n * Set a video input device to use for MatrixCalls\n * @param deviceId - the identifier for the device\n * undefined treated as unset\n */\n public async setVideoInput(deviceId: string): Promise {\n logger.info(`MediaHandler setVideoInput() running (deviceId=${deviceId})`);\n\n if (this.videoInput === deviceId) return;\n\n this.videoInput = deviceId;\n await this.updateLocalUsermediaStreams();\n }\n\n /**\n * Set media input devices to use for MatrixCalls\n * @param audioInput - the identifier for the audio device\n * @param videoInput - the identifier for the video device\n * undefined treated as unset\n */\n public async setMediaInputs(audioInput: string, videoInput: string): Promise {\n logger.log(`MediaHandler setMediaInputs() running (audioInput: ${audioInput} videoInput: ${videoInput})`);\n this.audioInput = audioInput;\n this.videoInput = videoInput;\n await this.updateLocalUsermediaStreams();\n }\n\n /*\n * Requests new usermedia streams and replace the old ones\n */\n public async updateLocalUsermediaStreams(): Promise {\n if (this.userMediaStreams.length === 0) return;\n\n const callMediaStreamParams: Map = new Map();\n for (const call of this.client.callEventHandler!.calls.values()) {\n callMediaStreamParams.set(call.callId, {\n audio: call.hasLocalUserMediaAudioTrack,\n video: call.hasLocalUserMediaVideoTrack,\n });\n }\n\n for (const stream of this.userMediaStreams) {\n logger.log(`MediaHandler updateLocalUsermediaStreams() stopping all tracks (streamId=${stream.id})`);\n for (const track of stream.getTracks()) {\n track.stop();\n }\n }\n\n this.userMediaStreams = [];\n this.localUserMediaStream = undefined;\n\n for (const call of this.client.callEventHandler!.calls.values()) {\n if (call.callHasEnded() || !callMediaStreamParams.has(call.callId)) {\n continue;\n }\n\n const { audio, video } = callMediaStreamParams.get(call.callId)!;\n\n logger.log(\n `MediaHandler updateLocalUsermediaStreams() calling getUserMediaStream() (callId=${call.callId})`,\n );\n const stream = await this.getUserMediaStream(audio, video);\n\n if (call.callHasEnded()) {\n continue;\n }\n\n await call.updateLocalUsermediaStream(stream);\n }\n\n for (const groupCall of this.client.groupCallEventHandler!.groupCalls.values()) {\n if (!groupCall.localCallFeed) {\n continue;\n }\n\n logger.log(\n `MediaHandler updateLocalUsermediaStreams() calling getUserMediaStream() (groupCallId=${groupCall.groupCallId})`,\n );\n const stream = await this.getUserMediaStream(true, groupCall.type === GroupCallType.Video);\n\n if (groupCall.state === GroupCallState.Ended) {\n continue;\n }\n\n await groupCall.updateLocalUsermediaStream(stream);\n }\n\n this.emit(MediaHandlerEvent.LocalStreamsChanged);\n }\n\n public async hasAudioDevice(): Promise {\n try {\n const devices = await navigator.mediaDevices.enumerateDevices();\n return devices.filter((device) => device.kind === \"audioinput\").length > 0;\n } catch (err) {\n logger.log(`MediaHandler hasAudioDevice() calling navigator.mediaDevices.enumerateDevices with error`, err);\n return false;\n }\n }\n\n public async hasVideoDevice(): Promise {\n try {\n const devices = await navigator.mediaDevices.enumerateDevices();\n return devices.filter((device) => device.kind === \"videoinput\").length > 0;\n } catch (err) {\n logger.log(`MediaHandler hasVideoDevice() calling navigator.mediaDevices.enumerateDevices with error`, err);\n return false;\n }\n }\n\n /**\n * @param audio - should have an audio track\n * @param video - should have a video track\n * @param reusable - is allowed to be reused by the MediaHandler\n * @returns based on passed parameters\n */\n public async getUserMediaStream(audio: boolean, video: boolean, reusable = true): Promise {\n // Serialise calls, othertwise we can't sensibly re-use the stream\n if (this.getMediaStreamPromise) {\n this.getMediaStreamPromise = this.getMediaStreamPromise.then(() => {\n return this.getUserMediaStreamInternal(audio, video, reusable);\n });\n } else {\n this.getMediaStreamPromise = this.getUserMediaStreamInternal(audio, video, reusable);\n }\n\n return this.getMediaStreamPromise;\n }\n\n private async getUserMediaStreamInternal(audio: boolean, video: boolean, reusable: boolean): Promise {\n const shouldRequestAudio = audio && (await this.hasAudioDevice());\n const shouldRequestVideo = video && (await this.hasVideoDevice());\n\n let stream: MediaStream;\n\n let canReuseStream = true;\n if (this.localUserMediaStream) {\n // This figures out if we can reuse the current localUsermediaStream\n // based on whether or not the \"mute state\" (presence of tracks of a\n // given kind) matches what is being requested\n if (shouldRequestAudio !== this.localUserMediaStream.getAudioTracks().length > 0) {\n canReuseStream = false;\n }\n if (shouldRequestVideo !== this.localUserMediaStream.getVideoTracks().length > 0) {\n canReuseStream = false;\n }\n\n // This code checks that the device ID is the same as the localUserMediaStream stream, but we update\n // the localUserMediaStream whenever the device ID changes (apart from when restoring) so it's not\n // clear why this would ever be different, unless there's a race.\n if (\n shouldRequestAudio &&\n this.localUserMediaStream.getAudioTracks()[0]?.getSettings()?.deviceId !== this.audioInput\n ) {\n canReuseStream = false;\n }\n if (\n shouldRequestVideo &&\n this.localUserMediaStream.getVideoTracks()[0]?.getSettings()?.deviceId !== this.videoInput\n ) {\n canReuseStream = false;\n }\n } else {\n canReuseStream = false;\n }\n\n if (!canReuseStream) {\n const constraints = this.getUserMediaContraints(shouldRequestAudio, shouldRequestVideo);\n stream = await navigator.mediaDevices.getUserMedia(constraints);\n logger.log(\n `MediaHandler getUserMediaStreamInternal() calling getUserMediaStream (streamId=${\n stream.id\n }, shouldRequestAudio=${shouldRequestAudio}, shouldRequestVideo=${shouldRequestVideo}, constraints=${JSON.stringify(\n constraints,\n )})`,\n );\n\n for (const track of stream.getTracks()) {\n const settings = track.getSettings();\n\n if (track.kind === \"audio\") {\n this.audioInput = settings.deviceId!;\n } else if (track.kind === \"video\") {\n this.videoInput = settings.deviceId!;\n }\n }\n\n if (reusable) {\n this.localUserMediaStream = stream;\n }\n } else {\n stream = this.localUserMediaStream!.clone();\n logger.log(\n `MediaHandler getUserMediaStreamInternal() cloning (oldStreamId=${this.localUserMediaStream?.id} newStreamId=${stream.id} shouldRequestAudio=${shouldRequestAudio} shouldRequestVideo=${shouldRequestVideo})`,\n );\n\n if (!shouldRequestAudio) {\n for (const track of stream.getAudioTracks()) {\n stream.removeTrack(track);\n }\n }\n\n if (!shouldRequestVideo) {\n for (const track of stream.getVideoTracks()) {\n stream.removeTrack(track);\n }\n }\n }\n\n if (reusable) {\n this.userMediaStreams.push(stream);\n }\n\n this.emit(MediaHandlerEvent.LocalStreamsChanged);\n\n return stream;\n }\n\n /**\n * Stops all tracks on the provided usermedia stream\n */\n public stopUserMediaStream(mediaStream: MediaStream): void {\n logger.log(`MediaHandler stopUserMediaStream() stopping (streamId=${mediaStream.id})`);\n for (const track of mediaStream.getTracks()) {\n track.stop();\n }\n\n const index = this.userMediaStreams.indexOf(mediaStream);\n\n if (index !== -1) {\n logger.debug(\n `MediaHandler stopUserMediaStream() splicing usermedia stream out stream array (streamId=${mediaStream.id})`,\n mediaStream.id,\n );\n this.userMediaStreams.splice(index, 1);\n }\n\n this.emit(MediaHandlerEvent.LocalStreamsChanged);\n\n if (this.localUserMediaStream === mediaStream) {\n this.localUserMediaStream = undefined;\n }\n }\n\n /**\n * @param desktopCapturerSourceId - sourceId for Electron DesktopCapturer\n * @param reusable - is allowed to be reused by the MediaHandler\n * @returns based on passed parameters\n */\n public async getScreensharingStream(opts: IScreensharingOpts = {}, reusable = true): Promise {\n let stream: MediaStream;\n\n if (this.screensharingStreams.length === 0) {\n const screenshareConstraints = this.getScreenshareContraints(opts);\n\n if (opts.desktopCapturerSourceId) {\n // We are using Electron\n logger.debug(\n `MediaHandler getScreensharingStream() calling getUserMedia() (opts=${JSON.stringify(opts)})`,\n );\n stream = await navigator.mediaDevices.getUserMedia(screenshareConstraints);\n } else {\n // We are not using Electron\n logger.debug(\n `MediaHandler getScreensharingStream() calling getDisplayMedia() (opts=${JSON.stringify(opts)})`,\n );\n stream = await navigator.mediaDevices.getDisplayMedia(screenshareConstraints);\n }\n } else {\n const matchingStream = this.screensharingStreams[this.screensharingStreams.length - 1];\n logger.log(`MediaHandler getScreensharingStream() cloning (streamId=${matchingStream.id})`);\n stream = matchingStream.clone();\n }\n\n if (reusable) {\n this.screensharingStreams.push(stream);\n }\n\n this.emit(MediaHandlerEvent.LocalStreamsChanged);\n\n return stream;\n }\n\n /**\n * Stops all tracks on the provided screensharing stream\n */\n public stopScreensharingStream(mediaStream: MediaStream): void {\n logger.debug(`MediaHandler stopScreensharingStream() stopping stream (streamId=${mediaStream.id})`);\n for (const track of mediaStream.getTracks()) {\n track.stop();\n }\n\n const index = this.screensharingStreams.indexOf(mediaStream);\n\n if (index !== -1) {\n logger.debug(`MediaHandler stopScreensharingStream() splicing stream out (streamId=${mediaStream.id})`);\n this.screensharingStreams.splice(index, 1);\n }\n\n this.emit(MediaHandlerEvent.LocalStreamsChanged);\n }\n\n /**\n * Stops all local media tracks\n */\n public stopAllStreams(): void {\n for (const stream of this.userMediaStreams) {\n logger.log(`MediaHandler stopAllStreams() stopping (streamId=${stream.id})`);\n for (const track of stream.getTracks()) {\n track.stop();\n }\n }\n\n for (const stream of this.screensharingStreams) {\n for (const track of stream.getTracks()) {\n track.stop();\n }\n }\n\n this.userMediaStreams = [];\n this.screensharingStreams = [];\n this.localUserMediaStream = undefined;\n\n this.emit(MediaHandlerEvent.LocalStreamsChanged);\n }\n\n private getUserMediaContraints(audio: boolean, video: boolean): MediaStreamConstraints {\n const isWebkit = !!navigator.webkitGetUserMedia;\n\n return {\n audio: audio\n ? {\n deviceId: this.audioInput ? { ideal: this.audioInput } : undefined,\n autoGainControl: this.audioSettings ? { ideal: this.audioSettings.autoGainControl } : undefined,\n echoCancellation: this.audioSettings ? { ideal: this.audioSettings.echoCancellation } : undefined,\n noiseSuppression: this.audioSettings ? { ideal: this.audioSettings.noiseSuppression } : undefined,\n }\n : false,\n video: video\n ? {\n deviceId: this.videoInput ? { ideal: this.videoInput } : undefined,\n /* We want 640x360. Chrome will give it only if we ask exactly,\n FF refuses entirely if we ask exactly, so have to ask for ideal\n instead\n XXX: Is this still true?\n */\n width: isWebkit ? { exact: 640 } : { ideal: 640 },\n height: isWebkit ? { exact: 360 } : { ideal: 360 },\n }\n : false,\n };\n }\n\n private getScreenshareContraints(opts: IScreensharingOpts): DesktopCapturerConstraints {\n const { desktopCapturerSourceId, audio } = opts;\n if (desktopCapturerSourceId) {\n return {\n audio: audio ?? false,\n video: {\n mandatory: {\n chromeMediaSource: \"desktop\",\n chromeMediaSourceId: desktopCapturerSourceId,\n },\n },\n };\n } else {\n return {\n audio: audio ?? false,\n video: true,\n };\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts deleted file mode 100644 index cbc970b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts +++ /dev/null @@ -1,28 +0,0 @@ -import { TransportStats } from "./transportStats"; -import { Bitrate } from "./media/mediaTrackStats"; -export interface ConnectionStatsBandwidth { - /** - * bytes per second - */ - download: number; - /** - * bytes per second - */ - upload: number; -} -export interface ConnectionStatsBitrate extends Bitrate { - audio?: Bitrate; - video?: Bitrate; -} -export interface PacketLoos { - total: number; - download: number; - upload: number; -} -export declare class ConnectionStats { - bandwidth: ConnectionStatsBitrate; - bitrate: ConnectionStatsBitrate; - packetLoss: PacketLoos; - transport: TransportStats[]; -} -//# sourceMappingURL=connectionStats.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts.map deleted file mode 100644 index bf88119..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"connectionStats.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/connectionStats.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAElD,MAAM,WAAW,wBAAwB;IACrC;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC;IACjB;;OAEG;IACH,MAAM,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,sBAAuB,SAAQ,OAAO;IACnD,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,KAAK,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,UAAU;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;CAClB;AAED,qBAAa,eAAe;IACjB,SAAS,EAAE,sBAAsB,CAAgC;IACjE,OAAO,EAAE,sBAAsB,CAAgC;IAC/D,UAAU,EAAE,UAAU,CAAoB;IAC1C,SAAS,EAAE,cAAc,EAAE,CAAM;CAC3C"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js deleted file mode 100644 index bed0ee3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js +++ /dev/null @@ -1,34 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ConnectionStats = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class ConnectionStats { - constructor() { - (0, _defineProperty2.default)(this, "bandwidth", {}); - (0, _defineProperty2.default)(this, "bitrate", {}); - (0, _defineProperty2.default)(this, "packetLoss", {}); - (0, _defineProperty2.default)(this, "transport", []); - } -} -exports.ConnectionStats = ConnectionStats; -//# sourceMappingURL=connectionStats.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js.map deleted file mode 100644 index c326eb6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStats.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"connectionStats.js","names":["ConnectionStats","constructor","_defineProperty2","default","exports"],"sources":["../../../src/webrtc/stats/connectionStats.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { TransportStats } from \"./transportStats\";\nimport { Bitrate } from \"./media/mediaTrackStats\";\n\nexport interface ConnectionStatsBandwidth {\n /**\n * bytes per second\n */\n download: number;\n /**\n * bytes per second\n */\n upload: number;\n}\n\nexport interface ConnectionStatsBitrate extends Bitrate {\n audio?: Bitrate;\n video?: Bitrate;\n}\n\nexport interface PacketLoos {\n total: number;\n download: number;\n upload: number;\n}\n\nexport class ConnectionStats {\n public bandwidth: ConnectionStatsBitrate = {} as ConnectionStatsBitrate;\n public bitrate: ConnectionStatsBitrate = {} as ConnectionStatsBitrate;\n public packetLoss: PacketLoos = {} as PacketLoos;\n public transport: TransportStats[] = [];\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA2BO,MAAMA,eAAe,CAAC;EAAAC,YAAA;IAAA,IAAAC,gBAAA,CAAAC,OAAA,qBACkB,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,mBACJ,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,sBACX,CAAC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,qBACG,EAAE;EAAA;AAC3C;AAACC,OAAA,CAAAJ,eAAA,GAAAA,eAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts deleted file mode 100644 index 3794554..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -import { Bitrate } from "./media/mediaTrackStats"; -export declare class ConnectionStatsReporter { - static buildBandwidthReport(now: RTCIceCandidatePairStats): Bitrate; -} -//# sourceMappingURL=connectionStatsReporter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts.map deleted file mode 100644 index de97f25..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"connectionStatsReporter.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/connectionStatsReporter.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAElD,qBAAa,uBAAuB;WAClB,oBAAoB,CAAC,GAAG,EAAE,wBAAwB,GAAG,OAAO;CAS7E"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js deleted file mode 100644 index ad884af..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js +++ /dev/null @@ -1,34 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.ConnectionStatsReporter = void 0; -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class ConnectionStatsReporter { - static buildBandwidthReport(now) { - const availableIncomingBitrate = now.availableIncomingBitrate; - const availableOutgoingBitrate = now.availableOutgoingBitrate; - return { - download: availableIncomingBitrate ? Math.round(availableIncomingBitrate / 1000) : 0, - upload: availableOutgoingBitrate ? Math.round(availableOutgoingBitrate / 1000) : 0 - }; - } -} -exports.ConnectionStatsReporter = ConnectionStatsReporter; -//# sourceMappingURL=connectionStatsReporter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js.map deleted file mode 100644 index 8f3f3fe..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/connectionStatsReporter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"connectionStatsReporter.js","names":["ConnectionStatsReporter","buildBandwidthReport","now","availableIncomingBitrate","availableOutgoingBitrate","download","Math","round","upload","exports"],"sources":["../../../src/webrtc/stats/connectionStatsReporter.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\nimport { Bitrate } from \"./media/mediaTrackStats\";\n\nexport class ConnectionStatsReporter {\n public static buildBandwidthReport(now: RTCIceCandidatePairStats): Bitrate {\n const availableIncomingBitrate = now.availableIncomingBitrate;\n const availableOutgoingBitrate = now.availableOutgoingBitrate;\n\n return {\n download: availableIncomingBitrate ? Math.round(availableIncomingBitrate / 1000) : 0,\n upload: availableOutgoingBitrate ? Math.round(availableOutgoingBitrate / 1000) : 0,\n };\n }\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGO,MAAMA,uBAAuB,CAAC;EACjC,OAAcC,oBAAoBA,CAACC,GAA6B,EAAW;IACvE,MAAMC,wBAAwB,GAAGD,GAAG,CAACC,wBAAwB;IAC7D,MAAMC,wBAAwB,GAAGF,GAAG,CAACE,wBAAwB;IAE7D,OAAO;MACHC,QAAQ,EAAEF,wBAAwB,GAAGG,IAAI,CAACC,KAAK,CAACJ,wBAAwB,GAAG,IAAI,CAAC,GAAG,CAAC;MACpFK,MAAM,EAAEJ,wBAAwB,GAAGE,IAAI,CAACC,KAAK,CAACH,wBAAwB,GAAG,IAAI,CAAC,GAAG;IACrF,CAAC;EACL;AACJ;AAACK,OAAA,CAAAT,uBAAA,GAAAA,uBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts deleted file mode 100644 index bbb2d3a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts +++ /dev/null @@ -1,19 +0,0 @@ -import { StatsReportGatherer } from "./statsReportGatherer"; -import { StatsReportEmitter } from "./statsReportEmitter"; -export declare class GroupCallStats { - private groupCallId; - private userId; - private interval; - private timer; - private readonly gatherers; - readonly reports: StatsReportEmitter; - constructor(groupCallId: string, userId: string, interval?: number); - start(): void; - stop(): void; - hasStatsReportGatherer(callId: string): boolean; - addStatsReportGatherer(callId: string, userId: string, peerConnection: RTCPeerConnection): boolean; - removeStatsReportGatherer(callId: string): boolean; - getStatsReportGatherer(callId: string): StatsReportGatherer | undefined; - private processStats; -} -//# sourceMappingURL=groupCallStats.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts.map deleted file mode 100644 index f115e7c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"groupCallStats.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/groupCallStats.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D,qBAAa,cAAc;IAKJ,OAAO,CAAC,WAAW;IAAU,OAAO,CAAC,MAAM;IAAU,OAAO,CAAC,QAAQ;IAJxF,OAAO,CAAC,KAAK,CAA4C;IACzD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA4E;IACtG,SAAgB,OAAO,qBAA4B;gBAExB,WAAW,EAAE,MAAM,EAAU,MAAM,EAAE,MAAM,EAAU,QAAQ,GAAE,MAAc;IAEjG,KAAK,IAAI,IAAI;IAQb,IAAI,IAAI,IAAI;IAOZ,sBAAsB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAI/C,sBAAsB,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,iBAAiB,GAAG,OAAO;IAQlG,yBAAyB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAIlD,sBAAsB,CAAC,MAAM,EAAE,MAAM,GAAG,mBAAmB,GAAG,SAAS;IAI9E,OAAO,CAAC,YAAY;CAGvB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js deleted file mode 100644 index eeb3bc9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js +++ /dev/null @@ -1,70 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.GroupCallStats = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _statsReportGatherer = require("./statsReportGatherer"); -var _statsReportEmitter = require("./statsReportEmitter"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class GroupCallStats { - constructor(groupCallId, userId, interval = 10000) { - this.groupCallId = groupCallId; - this.userId = userId; - this.interval = interval; - (0, _defineProperty2.default)(this, "timer", void 0); - (0, _defineProperty2.default)(this, "gatherers", new Map()); - (0, _defineProperty2.default)(this, "reports", new _statsReportEmitter.StatsReportEmitter()); - } - start() { - if (this.timer === undefined) { - this.timer = setInterval(() => { - this.processStats(); - }, this.interval); - } - } - stop() { - if (this.timer !== undefined) { - clearInterval(this.timer); - this.gatherers.forEach(c => c.stopProcessingStats()); - } - } - hasStatsReportGatherer(callId) { - return this.gatherers.has(callId); - } - addStatsReportGatherer(callId, userId, peerConnection) { - if (this.hasStatsReportGatherer(callId)) { - return false; - } - this.gatherers.set(callId, new _statsReportGatherer.StatsReportGatherer(callId, userId, peerConnection, this.reports)); - return true; - } - removeStatsReportGatherer(callId) { - return this.gatherers.delete(callId); - } - getStatsReportGatherer(callId) { - return this.hasStatsReportGatherer(callId) ? this.gatherers.get(callId) : undefined; - } - processStats() { - this.gatherers.forEach(c => c.processStats(this.groupCallId, this.userId)); - } -} -exports.GroupCallStats = GroupCallStats; -//# sourceMappingURL=groupCallStats.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js.map deleted file mode 100644 index 374418c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/groupCallStats.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"groupCallStats.js","names":["_statsReportGatherer","require","_statsReportEmitter","GroupCallStats","constructor","groupCallId","userId","interval","_defineProperty2","default","Map","StatsReportEmitter","start","timer","undefined","setInterval","processStats","stop","clearInterval","gatherers","forEach","c","stopProcessingStats","hasStatsReportGatherer","callId","has","addStatsReportGatherer","peerConnection","set","StatsReportGatherer","reports","removeStatsReportGatherer","delete","getStatsReportGatherer","get","exports"],"sources":["../../../src/webrtc/stats/groupCallStats.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\nimport { StatsReportGatherer } from \"./statsReportGatherer\";\nimport { StatsReportEmitter } from \"./statsReportEmitter\";\n\nexport class GroupCallStats {\n private timer: undefined | ReturnType;\n private readonly gatherers: Map = new Map();\n public readonly reports = new StatsReportEmitter();\n\n public constructor(private groupCallId: string, private userId: string, private interval: number = 10000) {}\n\n public start(): void {\n if (this.timer === undefined) {\n this.timer = setInterval(() => {\n this.processStats();\n }, this.interval);\n }\n }\n\n public stop(): void {\n if (this.timer !== undefined) {\n clearInterval(this.timer);\n this.gatherers.forEach((c) => c.stopProcessingStats());\n }\n }\n\n public hasStatsReportGatherer(callId: string): boolean {\n return this.gatherers.has(callId);\n }\n\n public addStatsReportGatherer(callId: string, userId: string, peerConnection: RTCPeerConnection): boolean {\n if (this.hasStatsReportGatherer(callId)) {\n return false;\n }\n this.gatherers.set(callId, new StatsReportGatherer(callId, userId, peerConnection, this.reports));\n return true;\n }\n\n public removeStatsReportGatherer(callId: string): boolean {\n return this.gatherers.delete(callId);\n }\n\n public getStatsReportGatherer(callId: string): StatsReportGatherer | undefined {\n return this.hasStatsReportGatherer(callId) ? this.gatherers.get(callId) : undefined;\n }\n\n private processStats(): void {\n this.gatherers.forEach((c) => c.processStats(this.groupCallId, this.userId));\n }\n}\n"],"mappings":";;;;;;;;AAeA,IAAAA,oBAAA,GAAAC,OAAA;AACA,IAAAC,mBAAA,GAAAD,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIO,MAAME,cAAc,CAAC;EAKjBC,WAAWA,CAASC,WAAmB,EAAUC,MAAc,EAAUC,QAAgB,GAAG,KAAK,EAAE;IAAA,KAA/EF,WAAmB,GAAnBA,WAAmB;IAAA,KAAUC,MAAc,GAAdA,MAAc;IAAA,KAAUC,QAAgB,GAAhBA,QAAgB;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,qBAHjC,IAAIC,GAAG,EAA+B;IAAA,IAAAF,gBAAA,CAAAC,OAAA,mBAC3E,IAAIE,sCAAkB,EAAE;EAEyD;EAEpGC,KAAKA,CAAA,EAAS;IACjB,IAAI,IAAI,CAACC,KAAK,KAAKC,SAAS,EAAE;MAC1B,IAAI,CAACD,KAAK,GAAGE,WAAW,CAAC,MAAM;QAC3B,IAAI,CAACC,YAAY,EAAE;MACvB,CAAC,EAAE,IAAI,CAACT,QAAQ,CAAC;IACrB;EACJ;EAEOU,IAAIA,CAAA,EAAS;IAChB,IAAI,IAAI,CAACJ,KAAK,KAAKC,SAAS,EAAE;MAC1BI,aAAa,CAAC,IAAI,CAACL,KAAK,CAAC;MACzB,IAAI,CAACM,SAAS,CAACC,OAAO,CAAEC,CAAC,IAAKA,CAAC,CAACC,mBAAmB,EAAE,CAAC;IAC1D;EACJ;EAEOC,sBAAsBA,CAACC,MAAc,EAAW;IACnD,OAAO,IAAI,CAACL,SAAS,CAACM,GAAG,CAACD,MAAM,CAAC;EACrC;EAEOE,sBAAsBA,CAACF,MAAc,EAAElB,MAAc,EAAEqB,cAAiC,EAAW;IACtG,IAAI,IAAI,CAACJ,sBAAsB,CAACC,MAAM,CAAC,EAAE;MACrC,OAAO,KAAK;IAChB;IACA,IAAI,CAACL,SAAS,CAACS,GAAG,CAACJ,MAAM,EAAE,IAAIK,wCAAmB,CAACL,MAAM,EAAElB,MAAM,EAAEqB,cAAc,EAAE,IAAI,CAACG,OAAO,CAAC,CAAC;IACjG,OAAO,IAAI;EACf;EAEOC,yBAAyBA,CAACP,MAAc,EAAW;IACtD,OAAO,IAAI,CAACL,SAAS,CAACa,MAAM,CAACR,MAAM,CAAC;EACxC;EAEOS,sBAAsBA,CAACT,MAAc,EAAmC;IAC3E,OAAO,IAAI,CAACD,sBAAsB,CAACC,MAAM,CAAC,GAAG,IAAI,CAACL,SAAS,CAACe,GAAG,CAACV,MAAM,CAAC,GAAGV,SAAS;EACvF;EAEQE,YAAYA,CAAA,EAAS;IACzB,IAAI,CAACG,SAAS,CAACC,OAAO,CAAEC,CAAC,IAAKA,CAAC,CAACL,YAAY,CAAC,IAAI,CAACX,WAAW,EAAE,IAAI,CAACC,MAAM,CAAC,CAAC;EAChF;AACJ;AAAC6B,OAAA,CAAAhC,cAAA,GAAAA,cAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts deleted file mode 100644 index 0837c2b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -export type Mid = string; -export type Ssrc = string; -export type MapType = "local" | "remote"; -export declare class MediaSsrcHandler { - private readonly ssrcToMid; - findMidBySsrc(ssrc: Ssrc, type: "local" | "remote"): Mid | undefined; - parse(description: string, type: MapType): void; - getSsrcToMidMap(type: MapType): Map; -} -//# sourceMappingURL=mediaSsrcHandler.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts.map deleted file mode 100644 index 2021449..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaSsrcHandler.d.ts","sourceRoot":"","sources":["../../../../src/webrtc/stats/media/mediaSsrcHandler.ts"],"names":[],"mappings":"AAkBA,MAAM,MAAM,GAAG,GAAG,MAAM,CAAC;AACzB,MAAM,MAAM,IAAI,GAAG,MAAM,CAAC;AAC1B,MAAM,MAAM,OAAO,GAAG,OAAO,GAAG,QAAQ,CAAC;AAEzC,qBAAa,gBAAgB;IACzB,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAqE;IAExF,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,GAAG,QAAQ,GAAG,GAAG,GAAG,SAAS;IAWpE,KAAK,CAAC,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,IAAI;IAiB/C,eAAe,CAAC,IAAI,EAAE,OAAO,GAAG,GAAG,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC;CAG1D"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js deleted file mode 100644 index 971c39d..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js +++ /dev/null @@ -1,65 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MediaSsrcHandler = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _sdpTransform = require("sdp-transform"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class MediaSsrcHandler { - constructor() { - (0, _defineProperty2.default)(this, "ssrcToMid", { - local: new Map(), - remote: new Map() - }); - } - findMidBySsrc(ssrc, type) { - let mid; - this.ssrcToMid[type].forEach((ssrcs, m) => { - if (ssrcs.find(s => s == ssrc)) { - mid = m; - return; - } - }); - return mid; - } - parse(description, type) { - const sdp = (0, _sdpTransform.parse)(description); - const ssrcToMid = new Map(); - sdp.media.forEach(m => { - if (!!m.mid && m.type === "video" || m.type === "audio") { - var _m$ssrcs; - const ssrcs = []; - (_m$ssrcs = m.ssrcs) === null || _m$ssrcs === void 0 ? void 0 : _m$ssrcs.forEach(ssrc => { - if (ssrc.attribute === "cname") { - ssrcs.push(`${ssrc.id}`); - } - }); - ssrcToMid.set(`${m.mid}`, ssrcs); - } - }); - this.ssrcToMid[type] = ssrcToMid; - } - getSsrcToMidMap(type) { - return this.ssrcToMid[type]; - } -} -exports.MediaSsrcHandler = MediaSsrcHandler; -//# sourceMappingURL=mediaSsrcHandler.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js.map deleted file mode 100644 index abaf728..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaSsrcHandler.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaSsrcHandler.js","names":["_sdpTransform","require","MediaSsrcHandler","constructor","_defineProperty2","default","local","Map","remote","findMidBySsrc","ssrc","type","mid","ssrcToMid","forEach","ssrcs","m","find","s","parse","description","sdp","parseSdp","media","_m$ssrcs","attribute","push","id","set","getSsrcToMidMap","exports"],"sources":["../../../../src/webrtc/stats/media/mediaSsrcHandler.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { parse as parseSdp } from \"sdp-transform\";\n\nexport type Mid = string;\nexport type Ssrc = string;\nexport type MapType = \"local\" | \"remote\";\n\nexport class MediaSsrcHandler {\n private readonly ssrcToMid = { local: new Map(), remote: new Map() };\n\n public findMidBySsrc(ssrc: Ssrc, type: \"local\" | \"remote\"): Mid | undefined {\n let mid: Mid | undefined;\n this.ssrcToMid[type].forEach((ssrcs, m) => {\n if (ssrcs.find((s) => s == ssrc)) {\n mid = m;\n return;\n }\n });\n return mid;\n }\n\n public parse(description: string, type: MapType): void {\n const sdp = parseSdp(description);\n const ssrcToMid = new Map();\n sdp.media.forEach((m) => {\n if ((!!m.mid && m.type === \"video\") || m.type === \"audio\") {\n const ssrcs: Ssrc[] = [];\n m.ssrcs?.forEach((ssrc) => {\n if (ssrc.attribute === \"cname\") {\n ssrcs.push(`${ssrc.id}`);\n }\n });\n ssrcToMid.set(`${m.mid}`, ssrcs);\n }\n });\n this.ssrcToMid[type] = ssrcToMid;\n }\n\n public getSsrcToMidMap(type: MapType): Map {\n return this.ssrcToMid[type];\n }\n}\n"],"mappings":";;;;;;;;AAgBA,IAAAA,aAAA,GAAAC,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAQO,MAAMC,gBAAgB,CAAC;EAAAC,YAAA;IAAA,IAAAC,gBAAA,CAAAC,OAAA,qBACG;MAAEC,KAAK,EAAE,IAAIC,GAAG,EAAe;MAAEC,MAAM,EAAE,IAAID,GAAG;IAAgB,CAAC;EAAA;EAEvFE,aAAaA,CAACC,IAAU,EAAEC,IAAwB,EAAmB;IACxE,IAAIC,GAAoB;IACxB,IAAI,CAACC,SAAS,CAACF,IAAI,CAAC,CAACG,OAAO,CAAC,CAACC,KAAK,EAAEC,CAAC,KAAK;MACvC,IAAID,KAAK,CAACE,IAAI,CAAEC,CAAC,IAAKA,CAAC,IAAIR,IAAI,CAAC,EAAE;QAC9BE,GAAG,GAAGI,CAAC;QACP;MACJ;IACJ,CAAC,CAAC;IACF,OAAOJ,GAAG;EACd;EAEOO,KAAKA,CAACC,WAAmB,EAAET,IAAa,EAAQ;IACnD,MAAMU,GAAG,GAAG,IAAAC,mBAAQ,EAACF,WAAW,CAAC;IACjC,MAAMP,SAAS,GAAG,IAAIN,GAAG,EAAe;IACxCc,GAAG,CAACE,KAAK,CAACT,OAAO,CAAEE,CAAC,IAAK;MACrB,IAAK,CAAC,CAACA,CAAC,CAACJ,GAAG,IAAII,CAAC,CAACL,IAAI,KAAK,OAAO,IAAKK,CAAC,CAACL,IAAI,KAAK,OAAO,EAAE;QAAA,IAAAa,QAAA;QACvD,MAAMT,KAAa,GAAG,EAAE;QACxB,CAAAS,QAAA,GAAAR,CAAC,CAACD,KAAK,cAAAS,QAAA,uBAAPA,QAAA,CAASV,OAAO,CAAEJ,IAAI,IAAK;UACvB,IAAIA,IAAI,CAACe,SAAS,KAAK,OAAO,EAAE;YAC5BV,KAAK,CAACW,IAAI,CAAE,GAAEhB,IAAI,CAACiB,EAAG,EAAC,CAAC;UAC5B;QACJ,CAAC,CAAC;QACFd,SAAS,CAACe,GAAG,CAAE,GAAEZ,CAAC,CAACJ,GAAI,EAAC,EAAEG,KAAK,CAAC;MACpC;IACJ,CAAC,CAAC;IACF,IAAI,CAACF,SAAS,CAACF,IAAI,CAAC,GAAGE,SAAS;EACpC;EAEOgB,eAAeA,CAAClB,IAAa,EAAoB;IACpD,OAAO,IAAI,CAACE,SAAS,CAACF,IAAI,CAAC;EAC/B;AACJ;AAACmB,OAAA,CAAA5B,gBAAA,GAAAA,gBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts deleted file mode 100644 index e03ae98..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts +++ /dev/null @@ -1,11 +0,0 @@ -export type TrackId = string; -export declare class MediaTrackHandler { - private readonly pc; - constructor(pc: RTCPeerConnection); - getLocalTracks(kind: "audio" | "video"): MediaStreamTrack[]; - getTackById(trackId: string): MediaStreamTrack | undefined; - getLocalTrackIdByMid(mid: string): string | undefined; - getRemoteTrackIdByMid(mid: string): string | undefined; - getActiveSimulcastStreams(): number; -} -//# sourceMappingURL=mediaTrackHandler.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts.map deleted file mode 100644 index c107f8b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaTrackHandler.d.ts","sourceRoot":"","sources":["../../../../src/webrtc/stats/media/mediaTrackHandler.ts"],"names":[],"mappings":"AAgBA,MAAM,MAAM,OAAO,GAAG,MAAM,CAAC;AAE7B,qBAAa,iBAAiB;IACP,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,EAAE,iBAAiB;IAElD,cAAc,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,GAAG,gBAAgB,EAAE;IAc3D,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS;IAe1D,oBAAoB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAQrD,qBAAqB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAQtD,yBAAyB,IAAI,MAAM;CAI7C"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js deleted file mode 100644 index f74599f..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js +++ /dev/null @@ -1,65 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MediaTrackHandler = void 0; -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class MediaTrackHandler { - constructor(pc) { - this.pc = pc; - } - getLocalTracks(kind) { - const isNotNullAndKind = track => { - return track !== null && track.kind === kind; - }; - // @ts-ignore The linter don't get it - return this.pc.getTransceivers().filter(t => t.currentDirection === "sendonly" || t.currentDirection === "sendrecv").filter(t => t.sender !== null).map(t => t.sender).map(s => s.track).filter(isNotNullAndKind); - } - getTackById(trackId) { - return this.pc.getTransceivers().map(t => { - if ((t === null || t === void 0 ? void 0 : t.sender.track) !== null && t.sender.track.id === trackId) { - return t.sender.track; - } - if ((t === null || t === void 0 ? void 0 : t.receiver.track) !== null && t.receiver.track.id === trackId) { - return t.receiver.track; - } - return undefined; - }).find(t => t !== undefined); - } - getLocalTrackIdByMid(mid) { - const transceiver = this.pc.getTransceivers().find(t => t.mid === mid); - if (transceiver !== undefined && !!transceiver.sender && !!transceiver.sender.track) { - return transceiver.sender.track.id; - } - return undefined; - } - getRemoteTrackIdByMid(mid) { - const transceiver = this.pc.getTransceivers().find(t => t.mid === mid); - if (transceiver !== undefined && !!transceiver.receiver && !!transceiver.receiver.track) { - return transceiver.receiver.track.id; - } - return undefined; - } - getActiveSimulcastStreams() { - //@TODO implement this right.. Check how many layer configured - return 3; - } -} -exports.MediaTrackHandler = MediaTrackHandler; -//# sourceMappingURL=mediaTrackHandler.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js.map deleted file mode 100644 index 7600899..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackHandler.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaTrackHandler.js","names":["MediaTrackHandler","constructor","pc","getLocalTracks","kind","isNotNullAndKind","track","getTransceivers","filter","t","currentDirection","sender","map","s","getTackById","trackId","id","receiver","undefined","find","getLocalTrackIdByMid","mid","transceiver","getRemoteTrackIdByMid","getActiveSimulcastStreams","exports"],"sources":["../../../../src/webrtc/stats/media/mediaTrackHandler.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport type TrackId = string;\n\nexport class MediaTrackHandler {\n public constructor(private readonly pc: RTCPeerConnection) {}\n\n public getLocalTracks(kind: \"audio\" | \"video\"): MediaStreamTrack[] {\n const isNotNullAndKind = (track: MediaStreamTrack | null): boolean => {\n return track !== null && track.kind === kind;\n };\n // @ts-ignore The linter don't get it\n return this.pc\n .getTransceivers()\n .filter((t) => t.currentDirection === \"sendonly\" || t.currentDirection === \"sendrecv\")\n .filter((t) => t.sender !== null)\n .map((t) => t.sender)\n .map((s) => s.track)\n .filter(isNotNullAndKind);\n }\n\n public getTackById(trackId: string): MediaStreamTrack | undefined {\n return this.pc\n .getTransceivers()\n .map((t) => {\n if (t?.sender.track !== null && t.sender.track.id === trackId) {\n return t.sender.track;\n }\n if (t?.receiver.track !== null && t.receiver.track.id === trackId) {\n return t.receiver.track;\n }\n return undefined;\n })\n .find((t) => t !== undefined);\n }\n\n public getLocalTrackIdByMid(mid: string): string | undefined {\n const transceiver = this.pc.getTransceivers().find((t) => t.mid === mid);\n if (transceiver !== undefined && !!transceiver.sender && !!transceiver.sender.track) {\n return transceiver.sender.track.id;\n }\n return undefined;\n }\n\n public getRemoteTrackIdByMid(mid: string): string | undefined {\n const transceiver = this.pc.getTransceivers().find((t) => t.mid === mid);\n if (transceiver !== undefined && !!transceiver.receiver && !!transceiver.receiver.track) {\n return transceiver.receiver.track.id;\n }\n return undefined;\n }\n\n public getActiveSimulcastStreams(): number {\n //@TODO implement this right.. Check how many layer configured\n return 3;\n }\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAIO,MAAMA,iBAAiB,CAAC;EACpBC,WAAWA,CAAkBC,EAAqB,EAAE;IAAA,KAAvBA,EAAqB,GAArBA,EAAqB;EAAG;EAErDC,cAAcA,CAACC,IAAuB,EAAsB;IAC/D,MAAMC,gBAAgB,GAAIC,KAA8B,IAAc;MAClE,OAAOA,KAAK,KAAK,IAAI,IAAIA,KAAK,CAACF,IAAI,KAAKA,IAAI;IAChD,CAAC;IACD;IACA,OAAO,IAAI,CAACF,EAAE,CACTK,eAAe,EAAE,CACjBC,MAAM,CAAEC,CAAC,IAAKA,CAAC,CAACC,gBAAgB,KAAK,UAAU,IAAID,CAAC,CAACC,gBAAgB,KAAK,UAAU,CAAC,CACrFF,MAAM,CAAEC,CAAC,IAAKA,CAAC,CAACE,MAAM,KAAK,IAAI,CAAC,CAChCC,GAAG,CAAEH,CAAC,IAAKA,CAAC,CAACE,MAAM,CAAC,CACpBC,GAAG,CAAEC,CAAC,IAAKA,CAAC,CAACP,KAAK,CAAC,CACnBE,MAAM,CAACH,gBAAgB,CAAC;EACjC;EAEOS,WAAWA,CAACC,OAAe,EAAgC;IAC9D,OAAO,IAAI,CAACb,EAAE,CACTK,eAAe,EAAE,CACjBK,GAAG,CAAEH,CAAC,IAAK;MACR,IAAI,CAAAA,CAAC,aAADA,CAAC,uBAADA,CAAC,CAAEE,MAAM,CAACL,KAAK,MAAK,IAAI,IAAIG,CAAC,CAACE,MAAM,CAACL,KAAK,CAACU,EAAE,KAAKD,OAAO,EAAE;QAC3D,OAAON,CAAC,CAACE,MAAM,CAACL,KAAK;MACzB;MACA,IAAI,CAAAG,CAAC,aAADA,CAAC,uBAADA,CAAC,CAAEQ,QAAQ,CAACX,KAAK,MAAK,IAAI,IAAIG,CAAC,CAACQ,QAAQ,CAACX,KAAK,CAACU,EAAE,KAAKD,OAAO,EAAE;QAC/D,OAAON,CAAC,CAACQ,QAAQ,CAACX,KAAK;MAC3B;MACA,OAAOY,SAAS;IACpB,CAAC,CAAC,CACDC,IAAI,CAAEV,CAAC,IAAKA,CAAC,KAAKS,SAAS,CAAC;EACrC;EAEOE,oBAAoBA,CAACC,GAAW,EAAsB;IACzD,MAAMC,WAAW,GAAG,IAAI,CAACpB,EAAE,CAACK,eAAe,EAAE,CAACY,IAAI,CAAEV,CAAC,IAAKA,CAAC,CAACY,GAAG,KAAKA,GAAG,CAAC;IACxE,IAAIC,WAAW,KAAKJ,SAAS,IAAI,CAAC,CAACI,WAAW,CAACX,MAAM,IAAI,CAAC,CAACW,WAAW,CAACX,MAAM,CAACL,KAAK,EAAE;MACjF,OAAOgB,WAAW,CAACX,MAAM,CAACL,KAAK,CAACU,EAAE;IACtC;IACA,OAAOE,SAAS;EACpB;EAEOK,qBAAqBA,CAACF,GAAW,EAAsB;IAC1D,MAAMC,WAAW,GAAG,IAAI,CAACpB,EAAE,CAACK,eAAe,EAAE,CAACY,IAAI,CAAEV,CAAC,IAAKA,CAAC,CAACY,GAAG,KAAKA,GAAG,CAAC;IACxE,IAAIC,WAAW,KAAKJ,SAAS,IAAI,CAAC,CAACI,WAAW,CAACL,QAAQ,IAAI,CAAC,CAACK,WAAW,CAACL,QAAQ,CAACX,KAAK,EAAE;MACrF,OAAOgB,WAAW,CAACL,QAAQ,CAACX,KAAK,CAACU,EAAE;IACxC;IACA,OAAOE,SAAS;EACpB;EAEOM,yBAAyBA,CAAA,EAAW;IACvC;IACA,OAAO,CAAC;EACZ;AACJ;AAACC,OAAA,CAAAzB,iBAAA,GAAAA,iBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts deleted file mode 100644 index 0f11ce8..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts +++ /dev/null @@ -1,45 +0,0 @@ -import { TrackId } from "./mediaTrackHandler"; -export interface PacketLoss { - packetsTotal: number; - packetsLost: number; - isDownloadStream: boolean; -} -export interface Bitrate { - /** - * bytes per second - */ - download: number; - /** - * bytes per second - */ - upload: number; -} -export interface Resolution { - width: number; - height: number; -} -export type TrackStatsType = "local" | "remote"; -export declare class MediaTrackStats { - readonly trackId: TrackId; - readonly type: TrackStatsType; - readonly kind: "audio" | "video"; - private loss; - private bitrate; - private resolution; - private framerate; - private codec; - constructor(trackId: TrackId, type: TrackStatsType, kind: "audio" | "video"); - getType(): TrackStatsType; - setLoss(loos: PacketLoss): void; - getLoss(): PacketLoss; - setResolution(resolution: Resolution): void; - getResolution(): Resolution; - setFramerate(framerate: number): void; - getFramerate(): number; - setBitrate(bitrate: Bitrate): void; - getBitrate(): Bitrate; - setCodec(codecShortType: string): boolean; - getCodec(): string; - resetBitrate(): void; -} -//# sourceMappingURL=mediaTrackStats.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts.map deleted file mode 100644 index 9ef892c..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaTrackStats.d.ts","sourceRoot":"","sources":["../../../../src/webrtc/stats/media/mediaTrackStats.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,MAAM,WAAW,UAAU;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,OAAO,CAAC;CAC7B;AAED,MAAM,WAAW,OAAO;IACpB;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC;IACjB;;OAEG;IACH,MAAM,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,UAAU;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,MAAM,cAAc,GAAG,OAAO,GAAG,QAAQ,CAAC;AAEhD,qBAAa,eAAe;aAQJ,OAAO,EAAE,OAAO;aAChB,IAAI,EAAE,cAAc;aACpB,IAAI,EAAE,OAAO,GAAG,OAAO;IAT3C,OAAO,CAAC,IAAI,CAA4E;IACxF,OAAO,CAAC,OAAO,CAAuC;IACtD,OAAO,CAAC,UAAU,CAAyC;IAC3D,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,KAAK,CAAM;gBAGC,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,OAAO,GAAG,OAAO;IAGpC,OAAO,IAAI,cAAc;IAIzB,OAAO,CAAC,IAAI,EAAE,UAAU,GAAG,IAAI;IAI/B,OAAO,IAAI,UAAU;IAIrB,aAAa,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IAI3C,aAAa,IAAI,UAAU;IAI3B,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAIrC,YAAY,IAAI,MAAM;IAItB,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAIlC,UAAU,IAAI,OAAO;IAIrB,QAAQ,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO;IAKzC,QAAQ,IAAI,MAAM;IAIlB,YAAY,IAAI,IAAI;CAG9B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js deleted file mode 100644 index 581ea8a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js +++ /dev/null @@ -1,88 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MediaTrackStats = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class MediaTrackStats { - constructor(trackId, type, kind) { - this.trackId = trackId; - this.type = type; - this.kind = kind; - (0, _defineProperty2.default)(this, "loss", { - packetsTotal: 0, - packetsLost: 0, - isDownloadStream: false - }); - (0, _defineProperty2.default)(this, "bitrate", { - download: 0, - upload: 0 - }); - (0, _defineProperty2.default)(this, "resolution", { - width: -1, - height: -1 - }); - (0, _defineProperty2.default)(this, "framerate", 0); - (0, _defineProperty2.default)(this, "codec", ""); - } - getType() { - return this.type; - } - setLoss(loos) { - this.loss = loos; - } - getLoss() { - return this.loss; - } - setResolution(resolution) { - this.resolution = resolution; - } - getResolution() { - return this.resolution; - } - setFramerate(framerate) { - this.framerate = framerate; - } - getFramerate() { - return this.framerate; - } - setBitrate(bitrate) { - this.bitrate = bitrate; - } - getBitrate() { - return this.bitrate; - } - setCodec(codecShortType) { - this.codec = codecShortType; - return true; - } - getCodec() { - return this.codec; - } - resetBitrate() { - this.bitrate = { - download: 0, - upload: 0 - }; - } -} -exports.MediaTrackStats = MediaTrackStats; -//# sourceMappingURL=mediaTrackStats.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js.map deleted file mode 100644 index 1552f24..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStats.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaTrackStats.js","names":["MediaTrackStats","constructor","trackId","type","kind","_defineProperty2","default","packetsTotal","packetsLost","isDownloadStream","download","upload","width","height","getType","setLoss","loos","loss","getLoss","setResolution","resolution","getResolution","setFramerate","framerate","getFramerate","setBitrate","bitrate","getBitrate","setCodec","codecShortType","codec","getCodec","resetBitrate","exports"],"sources":["../../../../src/webrtc/stats/media/mediaTrackStats.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { TrackId } from \"./mediaTrackHandler\";\n\nexport interface PacketLoss {\n packetsTotal: number;\n packetsLost: number;\n isDownloadStream: boolean;\n}\n\nexport interface Bitrate {\n /**\n * bytes per second\n */\n download: number;\n /**\n * bytes per second\n */\n upload: number;\n}\n\nexport interface Resolution {\n width: number;\n height: number;\n}\n\nexport type TrackStatsType = \"local\" | \"remote\";\n\nexport class MediaTrackStats {\n private loss: PacketLoss = { packetsTotal: 0, packetsLost: 0, isDownloadStream: false };\n private bitrate: Bitrate = { download: 0, upload: 0 };\n private resolution: Resolution = { width: -1, height: -1 };\n private framerate = 0;\n private codec = \"\";\n\n public constructor(\n public readonly trackId: TrackId,\n public readonly type: TrackStatsType,\n public readonly kind: \"audio\" | \"video\",\n ) {}\n\n public getType(): TrackStatsType {\n return this.type;\n }\n\n public setLoss(loos: PacketLoss): void {\n this.loss = loos;\n }\n\n public getLoss(): PacketLoss {\n return this.loss;\n }\n\n public setResolution(resolution: Resolution): void {\n this.resolution = resolution;\n }\n\n public getResolution(): Resolution {\n return this.resolution;\n }\n\n public setFramerate(framerate: number): void {\n this.framerate = framerate;\n }\n\n public getFramerate(): number {\n return this.framerate;\n }\n\n public setBitrate(bitrate: Bitrate): void {\n this.bitrate = bitrate;\n }\n\n public getBitrate(): Bitrate {\n return this.bitrate;\n }\n\n public setCodec(codecShortType: string): boolean {\n this.codec = codecShortType;\n return true;\n }\n\n public getCodec(): string {\n return this.codec;\n }\n\n public resetBitrate(): void {\n this.bitrate = { download: 0, upload: 0 };\n }\n}\n"],"mappings":";;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AA4BO,MAAMA,eAAe,CAAC;EAOlBC,WAAWA,CACEC,OAAgB,EAChBC,IAAoB,EACpBC,IAAuB,EACzC;IAAA,KAHkBF,OAAgB,GAAhBA,OAAgB;IAAA,KAChBC,IAAoB,GAApBA,IAAoB;IAAA,KACpBC,IAAuB,GAAvBA,IAAuB;IAAA,IAAAC,gBAAA,CAAAC,OAAA,gBAThB;MAAEC,YAAY,EAAE,CAAC;MAAEC,WAAW,EAAE,CAAC;MAAEC,gBAAgB,EAAE;IAAM,CAAC;IAAA,IAAAJ,gBAAA,CAAAC,OAAA,mBAC5D;MAAEI,QAAQ,EAAE,CAAC;MAAEC,MAAM,EAAE;IAAE,CAAC;IAAA,IAAAN,gBAAA,CAAAC,OAAA,sBACpB;MAAEM,KAAK,EAAE,CAAC,CAAC;MAAEC,MAAM,EAAE,CAAC;IAAE,CAAC;IAAA,IAAAR,gBAAA,CAAAC,OAAA,qBACtC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,iBACL,EAAE;EAMf;EAEIQ,OAAOA,CAAA,EAAmB;IAC7B,OAAO,IAAI,CAACX,IAAI;EACpB;EAEOY,OAAOA,CAACC,IAAgB,EAAQ;IACnC,IAAI,CAACC,IAAI,GAAGD,IAAI;EACpB;EAEOE,OAAOA,CAAA,EAAe;IACzB,OAAO,IAAI,CAACD,IAAI;EACpB;EAEOE,aAAaA,CAACC,UAAsB,EAAQ;IAC/C,IAAI,CAACA,UAAU,GAAGA,UAAU;EAChC;EAEOC,aAAaA,CAAA,EAAe;IAC/B,OAAO,IAAI,CAACD,UAAU;EAC1B;EAEOE,YAAYA,CAACC,SAAiB,EAAQ;IACzC,IAAI,CAACA,SAAS,GAAGA,SAAS;EAC9B;EAEOC,YAAYA,CAAA,EAAW;IAC1B,OAAO,IAAI,CAACD,SAAS;EACzB;EAEOE,UAAUA,CAACC,OAAgB,EAAQ;IACtC,IAAI,CAACA,OAAO,GAAGA,OAAO;EAC1B;EAEOC,UAAUA,CAAA,EAAY;IACzB,OAAO,IAAI,CAACD,OAAO;EACvB;EAEOE,QAAQA,CAACC,cAAsB,EAAW;IAC7C,IAAI,CAACC,KAAK,GAAGD,cAAc;IAC3B,OAAO,IAAI;EACf;EAEOE,QAAQA,CAAA,EAAW;IACtB,OAAO,IAAI,CAACD,KAAK;EACrB;EAEOE,YAAYA,CAAA,EAAS;IACxB,IAAI,CAACN,OAAO,GAAG;MAAEhB,QAAQ,EAAE,CAAC;MAAEC,MAAM,EAAE;IAAE,CAAC;EAC7C;AACJ;AAACsB,OAAA,CAAAjC,eAAA,GAAAA,eAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts deleted file mode 100644 index 15abb2b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts +++ /dev/null @@ -1,21 +0,0 @@ -import { TrackID } from "../statsReport"; -import { MediaTrackStats } from "./mediaTrackStats"; -import { MediaTrackHandler } from "./mediaTrackHandler"; -import { MediaSsrcHandler } from "./mediaSsrcHandler"; -export declare class MediaTrackStatsHandler { - readonly mediaSsrcHandler: MediaSsrcHandler; - readonly mediaTrackHandler: MediaTrackHandler; - private readonly track2stats; - constructor(mediaSsrcHandler: MediaSsrcHandler, mediaTrackHandler: MediaTrackHandler); - /** - * Find tracks by rtc stats - * Argument report is any because the stats api is not consistent: - * For example `trackIdentifier`, `mid` not existing in every implementations - * https://www.w3.org/TR/webrtc-stats/#dom-rtcinboundrtpstreamstats - * https://developer.mozilla.org/en-US/docs/Web/API/RTCInboundRtpStreamStats - */ - findTrack2Stats(report: any, type: "remote" | "local"): MediaTrackStats | undefined; - findLocalVideoTrackStats(report: any): MediaTrackStats | undefined; - getTrack2stats(): Map; -} -//# sourceMappingURL=mediaTrackStatsHandler.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts.map deleted file mode 100644 index 80ac0a0..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaTrackStatsHandler.d.ts","sourceRoot":"","sources":["../../../../src/webrtc/stats/media/mediaTrackStatsHandler.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,qBAAa,sBAAsB;aAIX,gBAAgB,EAAE,gBAAgB;aAClC,iBAAiB,EAAE,iBAAiB;IAJxD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAuC;gBAG/C,gBAAgB,EAAE,gBAAgB,EAClC,iBAAiB,EAAE,iBAAiB;IAGxD;;;;;;OAMG;IACI,eAAe,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,eAAe,GAAG,SAAS;IAuCnF,wBAAwB,CAAC,MAAM,EAAE,GAAG,GAAG,eAAe,GAAG,SAAS;IAQlE,cAAc,IAAI,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC;CAGzD"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js deleted file mode 100644 index 6f42939..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js +++ /dev/null @@ -1,81 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.MediaTrackStatsHandler = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _mediaTrackStats = require("./mediaTrackStats"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class MediaTrackStatsHandler { - constructor(mediaSsrcHandler, mediaTrackHandler) { - this.mediaSsrcHandler = mediaSsrcHandler; - this.mediaTrackHandler = mediaTrackHandler; - (0, _defineProperty2.default)(this, "track2stats", new Map()); - } - - /** - * Find tracks by rtc stats - * Argument report is any because the stats api is not consistent: - * For example `trackIdentifier`, `mid` not existing in every implementations - * https://www.w3.org/TR/webrtc-stats/#dom-rtcinboundrtpstreamstats - * https://developer.mozilla.org/en-US/docs/Web/API/RTCInboundRtpStreamStats - */ - findTrack2Stats(report, type) { - let trackID; - if (report.trackIdentifier) { - trackID = report.trackIdentifier; - } else if (report.mid) { - trackID = type === "remote" ? this.mediaTrackHandler.getRemoteTrackIdByMid(report.mid) : this.mediaTrackHandler.getLocalTrackIdByMid(report.mid); - } else if (report.ssrc) { - const mid = this.mediaSsrcHandler.findMidBySsrc(report.ssrc, type); - if (!mid) { - return undefined; - } - trackID = type === "remote" ? this.mediaTrackHandler.getRemoteTrackIdByMid(report.mid) : this.mediaTrackHandler.getLocalTrackIdByMid(report.mid); - } - if (!trackID) { - return undefined; - } - let trackStats = this.track2stats.get(trackID); - if (!trackStats) { - const track = this.mediaTrackHandler.getTackById(trackID); - if (track !== undefined) { - const kind = track.kind === "audio" ? track.kind : "video"; - trackStats = new _mediaTrackStats.MediaTrackStats(trackID, type, kind); - this.track2stats.set(trackID, trackStats); - } else { - return undefined; - } - } - return trackStats; - } - findLocalVideoTrackStats(report) { - const localVideoTracks = this.mediaTrackHandler.getLocalTracks("video"); - if (localVideoTracks.length === 0) { - return undefined; - } - return this.findTrack2Stats(report, "local"); - } - getTrack2stats() { - return this.track2stats; - } -} -exports.MediaTrackStatsHandler = MediaTrackStatsHandler; -//# sourceMappingURL=mediaTrackStatsHandler.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map deleted file mode 100644 index 8140116..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"mediaTrackStatsHandler.js","names":["_mediaTrackStats","require","MediaTrackStatsHandler","constructor","mediaSsrcHandler","mediaTrackHandler","_defineProperty2","default","Map","findTrack2Stats","report","type","trackID","trackIdentifier","mid","getRemoteTrackIdByMid","getLocalTrackIdByMid","ssrc","findMidBySsrc","undefined","trackStats","track2stats","get","track","getTackById","kind","MediaTrackStats","set","findLocalVideoTrackStats","localVideoTracks","getLocalTracks","length","getTrack2stats","exports"],"sources":["../../../../src/webrtc/stats/media/mediaTrackStatsHandler.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\nimport { TrackID } from \"../statsReport\";\nimport { MediaTrackStats } from \"./mediaTrackStats\";\nimport { MediaTrackHandler } from \"./mediaTrackHandler\";\nimport { MediaSsrcHandler } from \"./mediaSsrcHandler\";\n\nexport class MediaTrackStatsHandler {\n private readonly track2stats = new Map();\n\n public constructor(\n public readonly mediaSsrcHandler: MediaSsrcHandler,\n public readonly mediaTrackHandler: MediaTrackHandler,\n ) {}\n\n /**\n * Find tracks by rtc stats\n * Argument report is any because the stats api is not consistent:\n * For example `trackIdentifier`, `mid` not existing in every implementations\n * https://www.w3.org/TR/webrtc-stats/#dom-rtcinboundrtpstreamstats\n * https://developer.mozilla.org/en-US/docs/Web/API/RTCInboundRtpStreamStats\n */\n public findTrack2Stats(report: any, type: \"remote\" | \"local\"): MediaTrackStats | undefined {\n let trackID;\n if (report.trackIdentifier) {\n trackID = report.trackIdentifier;\n } else if (report.mid) {\n trackID =\n type === \"remote\"\n ? this.mediaTrackHandler.getRemoteTrackIdByMid(report.mid)\n : this.mediaTrackHandler.getLocalTrackIdByMid(report.mid);\n } else if (report.ssrc) {\n const mid = this.mediaSsrcHandler.findMidBySsrc(report.ssrc, type);\n if (!mid) {\n return undefined;\n }\n trackID =\n type === \"remote\"\n ? this.mediaTrackHandler.getRemoteTrackIdByMid(report.mid)\n : this.mediaTrackHandler.getLocalTrackIdByMid(report.mid);\n }\n\n if (!trackID) {\n return undefined;\n }\n\n let trackStats = this.track2stats.get(trackID);\n\n if (!trackStats) {\n const track = this.mediaTrackHandler.getTackById(trackID);\n if (track !== undefined) {\n const kind: \"audio\" | \"video\" = track.kind === \"audio\" ? track.kind : \"video\";\n trackStats = new MediaTrackStats(trackID, type, kind);\n this.track2stats.set(trackID, trackStats);\n } else {\n return undefined;\n }\n }\n return trackStats;\n }\n\n public findLocalVideoTrackStats(report: any): MediaTrackStats | undefined {\n const localVideoTracks = this.mediaTrackHandler.getLocalTracks(\"video\");\n if (localVideoTracks.length === 0) {\n return undefined;\n }\n return this.findTrack2Stats(report, \"local\");\n }\n\n public getTrack2stats(): Map {\n return this.track2stats;\n }\n}\n"],"mappings":";;;;;;;;AAgBA,IAAAA,gBAAA,GAAAC,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAMO,MAAMC,sBAAsB,CAAC;EAGzBC,WAAWA,CACEC,gBAAkC,EAClCC,iBAAoC,EACtD;IAAA,KAFkBD,gBAAkC,GAAlCA,gBAAkC;IAAA,KAClCC,iBAAoC,GAApCA,iBAAoC;IAAA,IAAAC,gBAAA,CAAAC,OAAA,uBAJzB,IAAIC,GAAG,EAA4B;EAK/D;;EAEH;AACJ;AACA;AACA;AACA;AACA;AACA;EACWC,eAAeA,CAACC,MAAW,EAAEC,IAAwB,EAA+B;IACvF,IAAIC,OAAO;IACX,IAAIF,MAAM,CAACG,eAAe,EAAE;MACxBD,OAAO,GAAGF,MAAM,CAACG,eAAe;IACpC,CAAC,MAAM,IAAIH,MAAM,CAACI,GAAG,EAAE;MACnBF,OAAO,GACHD,IAAI,KAAK,QAAQ,GACX,IAAI,CAACN,iBAAiB,CAACU,qBAAqB,CAACL,MAAM,CAACI,GAAG,CAAC,GACxD,IAAI,CAACT,iBAAiB,CAACW,oBAAoB,CAACN,MAAM,CAACI,GAAG,CAAC;IACrE,CAAC,MAAM,IAAIJ,MAAM,CAACO,IAAI,EAAE;MACpB,MAAMH,GAAG,GAAG,IAAI,CAACV,gBAAgB,CAACc,aAAa,CAACR,MAAM,CAACO,IAAI,EAAEN,IAAI,CAAC;MAClE,IAAI,CAACG,GAAG,EAAE;QACN,OAAOK,SAAS;MACpB;MACAP,OAAO,GACHD,IAAI,KAAK,QAAQ,GACX,IAAI,CAACN,iBAAiB,CAACU,qBAAqB,CAACL,MAAM,CAACI,GAAG,CAAC,GACxD,IAAI,CAACT,iBAAiB,CAACW,oBAAoB,CAACN,MAAM,CAACI,GAAG,CAAC;IACrE;IAEA,IAAI,CAACF,OAAO,EAAE;MACV,OAAOO,SAAS;IACpB;IAEA,IAAIC,UAAU,GAAG,IAAI,CAACC,WAAW,CAACC,GAAG,CAACV,OAAO,CAAC;IAE9C,IAAI,CAACQ,UAAU,EAAE;MACb,MAAMG,KAAK,GAAG,IAAI,CAAClB,iBAAiB,CAACmB,WAAW,CAACZ,OAAO,CAAC;MACzD,IAAIW,KAAK,KAAKJ,SAAS,EAAE;QACrB,MAAMM,IAAuB,GAAGF,KAAK,CAACE,IAAI,KAAK,OAAO,GAAGF,KAAK,CAACE,IAAI,GAAG,OAAO;QAC7EL,UAAU,GAAG,IAAIM,gCAAe,CAACd,OAAO,EAAED,IAAI,EAAEc,IAAI,CAAC;QACrD,IAAI,CAACJ,WAAW,CAACM,GAAG,CAACf,OAAO,EAAEQ,UAAU,CAAC;MAC7C,CAAC,MAAM;QACH,OAAOD,SAAS;MACpB;IACJ;IACA,OAAOC,UAAU;EACrB;EAEOQ,wBAAwBA,CAAClB,MAAW,EAA+B;IACtE,MAAMmB,gBAAgB,GAAG,IAAI,CAACxB,iBAAiB,CAACyB,cAAc,CAAC,OAAO,CAAC;IACvE,IAAID,gBAAgB,CAACE,MAAM,KAAK,CAAC,EAAE;MAC/B,OAAOZ,SAAS;IACpB;IACA,OAAO,IAAI,CAACV,eAAe,CAACC,MAAM,EAAE,OAAO,CAAC;EAChD;EAEOsB,cAAcA,CAAA,EAAkC;IACnD,OAAO,IAAI,CAACX,WAAW;EAC3B;AACJ;AAACY,OAAA,CAAA/B,sBAAA,GAAAA,sBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts deleted file mode 100644 index cedabd1..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts +++ /dev/null @@ -1,33 +0,0 @@ -import { ConnectionStatsBandwidth, ConnectionStatsBitrate, PacketLoos } from "./connectionStats"; -import { TransportStats } from "./transportStats"; -import { Resolution } from "./media/mediaTrackStats"; -export declare enum StatsReport { - CONNECTION_STATS = "StatsReport.connection_stats", - BYTE_SENT_STATS = "StatsReport.byte_sent_stats" -} -export type TrackID = string; -export type ByteSend = number; -export interface ByteSentStatsReport extends Map { -} -export interface ConnectionStatsReport { - bandwidth: ConnectionStatsBandwidth; - bitrate: ConnectionStatsBitrate; - packetLoss: PacketLoos; - resolution: ResolutionMap; - framerate: FramerateMap; - codec: CodecMap; - transport: TransportStats[]; -} -export interface ResolutionMap { - local: Map; - remote: Map; -} -export interface FramerateMap { - local: Map; - remote: Map; -} -export interface CodecMap { - local: Map; - remote: Map; -} -//# sourceMappingURL=statsReport.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts.map deleted file mode 100644 index 2be9d9b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReport.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/statsReport.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACjG,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,oBAAY,WAAW;IACnB,gBAAgB,iCAAiC;IACjD,eAAe,gCAAgC;CAClD;AAED,MAAM,MAAM,OAAO,GAAG,MAAM,CAAC;AAC7B,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC;AAE9B,MAAM,WAAW,mBAAoB,SAAQ,GAAG,CAAC,OAAO,EAAE,QAAQ,CAAC;CAElE;AAED,MAAM,WAAW,qBAAqB;IAClC,SAAS,EAAE,wBAAwB,CAAC;IACpC,OAAO,EAAE,sBAAsB,CAAC;IAChC,UAAU,EAAE,UAAU,CAAC;IACvB,UAAU,EAAE,aAAa,CAAC;IAC1B,SAAS,EAAE,YAAY,CAAC;IACxB,KAAK,EAAE,QAAQ,CAAC;IAChB,SAAS,EAAE,cAAc,EAAE,CAAC;CAC/B;AAED,MAAM,WAAW,aAAa;IAC1B,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAChC,MAAM,EAAE,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;CACpC;AAED,MAAM,WAAW,YAAY;IACzB,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAC5B,MAAM,EAAE,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,QAAQ;IACrB,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAC5B,MAAM,EAAE,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;CAChC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js deleted file mode 100644 index 0b2cd05..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.StatsReport = void 0; -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -let StatsReport; -exports.StatsReport = StatsReport; -(function (StatsReport) { - StatsReport["CONNECTION_STATS"] = "StatsReport.connection_stats"; - StatsReport["BYTE_SENT_STATS"] = "StatsReport.byte_sent_stats"; -})(StatsReport || (exports.StatsReport = StatsReport = {})); -//# sourceMappingURL=statsReport.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js.map deleted file mode 100644 index 731606b..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReport.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReport.js","names":["StatsReport","exports"],"sources":["../../../src/webrtc/stats/statsReport.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ConnectionStatsBandwidth, ConnectionStatsBitrate, PacketLoos } from \"./connectionStats\";\nimport { TransportStats } from \"./transportStats\";\nimport { Resolution } from \"./media/mediaTrackStats\";\n\nexport enum StatsReport {\n CONNECTION_STATS = \"StatsReport.connection_stats\",\n BYTE_SENT_STATS = \"StatsReport.byte_sent_stats\",\n}\n\nexport type TrackID = string;\nexport type ByteSend = number;\n\nexport interface ByteSentStatsReport extends Map {\n // is a map: `local trackID` => byte send\n}\n\nexport interface ConnectionStatsReport {\n bandwidth: ConnectionStatsBandwidth;\n bitrate: ConnectionStatsBitrate;\n packetLoss: PacketLoos;\n resolution: ResolutionMap;\n framerate: FramerateMap;\n codec: CodecMap;\n transport: TransportStats[];\n}\n\nexport interface ResolutionMap {\n local: Map;\n remote: Map;\n}\n\nexport interface FramerateMap {\n local: Map;\n remote: Map;\n}\n\nexport interface CodecMap {\n local: Map;\n remote: Map;\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAdA,IAoBYA,WAAW;AAAAC,OAAA,CAAAD,WAAA,GAAAA,WAAA;AAAA,WAAXA,WAAW;EAAXA,WAAW;EAAXA,WAAW;AAAA,GAAXA,WAAW,KAAAC,OAAA,CAAAD,WAAA,GAAXA,WAAW"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts deleted file mode 100644 index 31de157..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts +++ /dev/null @@ -1,7 +0,0 @@ -import { ConnectionStatsReport, TrackID } from "./statsReport"; -import { MediaTrackStats } from "./media/mediaTrackStats"; -export declare class StatsReportBuilder { - static build(stats: Map): ConnectionStatsReport; - private static calculatePacketLoss; -} -//# sourceMappingURL=statsReportBuilder.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts.map deleted file mode 100644 index 2446b14..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReportBuilder.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/statsReportBuilder.ts"],"names":[],"mappings":"AAeA,OAAO,EAAY,qBAAqB,EAA+B,OAAO,EAAE,MAAM,eAAe,CAAC;AACtG,OAAO,EAAE,eAAe,EAAc,MAAM,yBAAyB,CAAC;AAEtE,qBAAa,kBAAkB;WACb,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,GAAG,qBAAqB;IAmFhF,OAAO,CAAC,MAAM,CAAC,mBAAmB;CAOrC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js deleted file mode 100644 index edd7094..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js +++ /dev/null @@ -1,108 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.StatsReportBuilder = void 0; -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class StatsReportBuilder { - static build(stats) { - const report = {}; - - // process stats - const totalPackets = { - download: 0, - upload: 0 - }; - const lostPackets = { - download: 0, - upload: 0 - }; - let bitrateDownload = 0; - let bitrateUpload = 0; - const resolutions = { - local: new Map(), - remote: new Map() - }; - const framerates = { - local: new Map(), - remote: new Map() - }; - const codecs = { - local: new Map(), - remote: new Map() - }; - let audioBitrateDownload = 0; - let audioBitrateUpload = 0; - let videoBitrateDownload = 0; - let videoBitrateUpload = 0; - for (const [trackId, trackStats] of stats) { - // process packet loss stats - const loss = trackStats.getLoss(); - const type = loss.isDownloadStream ? "download" : "upload"; - totalPackets[type] += loss.packetsTotal; - lostPackets[type] += loss.packetsLost; - - // process bitrate stats - bitrateDownload += trackStats.getBitrate().download; - bitrateUpload += trackStats.getBitrate().upload; - - // collect resolutions and framerates - if (trackStats.kind === "audio") { - audioBitrateDownload += trackStats.getBitrate().download; - audioBitrateUpload += trackStats.getBitrate().upload; - } else { - videoBitrateDownload += trackStats.getBitrate().download; - videoBitrateUpload += trackStats.getBitrate().upload; - } - resolutions[trackStats.getType()].set(trackId, trackStats.getResolution()); - framerates[trackStats.getType()].set(trackId, trackStats.getFramerate()); - codecs[trackStats.getType()].set(trackId, trackStats.getCodec()); - trackStats.resetBitrate(); - } - report.bitrate = { - upload: bitrateUpload, - download: bitrateDownload - }; - report.bitrate.audio = { - upload: audioBitrateUpload, - download: audioBitrateDownload - }; - report.bitrate.video = { - upload: videoBitrateUpload, - download: videoBitrateDownload - }; - report.packetLoss = { - total: StatsReportBuilder.calculatePacketLoss(lostPackets.download + lostPackets.upload, totalPackets.download + totalPackets.upload), - download: StatsReportBuilder.calculatePacketLoss(lostPackets.download, totalPackets.download), - upload: StatsReportBuilder.calculatePacketLoss(lostPackets.upload, totalPackets.upload) - }; - report.framerate = framerates; - report.resolution = resolutions; - report.codec = codecs; - return report; - } - static calculatePacketLoss(lostPackets, totalPackets) { - if (!totalPackets || totalPackets <= 0 || !lostPackets || lostPackets <= 0) { - return 0; - } - return Math.round(lostPackets / totalPackets * 100); - } -} -exports.StatsReportBuilder = StatsReportBuilder; -//# sourceMappingURL=statsReportBuilder.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js.map deleted file mode 100644 index 914dcf3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportBuilder.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReportBuilder.js","names":["StatsReportBuilder","build","stats","report","totalPackets","download","upload","lostPackets","bitrateDownload","bitrateUpload","resolutions","local","Map","remote","framerates","codecs","audioBitrateDownload","audioBitrateUpload","videoBitrateDownload","videoBitrateUpload","trackId","trackStats","loss","getLoss","type","isDownloadStream","packetsTotal","packetsLost","getBitrate","kind","getType","set","getResolution","getFramerate","getCodec","resetBitrate","bitrate","audio","video","packetLoss","total","calculatePacketLoss","framerate","resolution","codec","Math","round","exports"],"sources":["../../../src/webrtc/stats/statsReportBuilder.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\nimport { CodecMap, ConnectionStatsReport, FramerateMap, ResolutionMap, TrackID } from \"./statsReport\";\nimport { MediaTrackStats, Resolution } from \"./media/mediaTrackStats\";\n\nexport class StatsReportBuilder {\n public static build(stats: Map): ConnectionStatsReport {\n const report = {} as ConnectionStatsReport;\n\n // process stats\n const totalPackets = {\n download: 0,\n upload: 0,\n };\n const lostPackets = {\n download: 0,\n upload: 0,\n };\n let bitrateDownload = 0;\n let bitrateUpload = 0;\n const resolutions: ResolutionMap = {\n local: new Map(),\n remote: new Map(),\n };\n const framerates: FramerateMap = { local: new Map(), remote: new Map() };\n const codecs: CodecMap = { local: new Map(), remote: new Map() };\n\n let audioBitrateDownload = 0;\n let audioBitrateUpload = 0;\n let videoBitrateDownload = 0;\n let videoBitrateUpload = 0;\n\n for (const [trackId, trackStats] of stats) {\n // process packet loss stats\n const loss = trackStats.getLoss();\n const type = loss.isDownloadStream ? \"download\" : \"upload\";\n\n totalPackets[type] += loss.packetsTotal;\n lostPackets[type] += loss.packetsLost;\n\n // process bitrate stats\n bitrateDownload += trackStats.getBitrate().download;\n bitrateUpload += trackStats.getBitrate().upload;\n\n // collect resolutions and framerates\n if (trackStats.kind === \"audio\") {\n audioBitrateDownload += trackStats.getBitrate().download;\n audioBitrateUpload += trackStats.getBitrate().upload;\n } else {\n videoBitrateDownload += trackStats.getBitrate().download;\n videoBitrateUpload += trackStats.getBitrate().upload;\n }\n\n resolutions[trackStats.getType()].set(trackId, trackStats.getResolution());\n framerates[trackStats.getType()].set(trackId, trackStats.getFramerate());\n codecs[trackStats.getType()].set(trackId, trackStats.getCodec());\n\n trackStats.resetBitrate();\n }\n\n report.bitrate = {\n upload: bitrateUpload,\n download: bitrateDownload,\n };\n\n report.bitrate.audio = {\n upload: audioBitrateUpload,\n download: audioBitrateDownload,\n };\n\n report.bitrate.video = {\n upload: videoBitrateUpload,\n download: videoBitrateDownload,\n };\n\n report.packetLoss = {\n total: StatsReportBuilder.calculatePacketLoss(\n lostPackets.download + lostPackets.upload,\n totalPackets.download + totalPackets.upload,\n ),\n download: StatsReportBuilder.calculatePacketLoss(lostPackets.download, totalPackets.download),\n upload: StatsReportBuilder.calculatePacketLoss(lostPackets.upload, totalPackets.upload),\n };\n report.framerate = framerates;\n report.resolution = resolutions;\n report.codec = codecs;\n return report;\n }\n\n private static calculatePacketLoss(lostPackets: number, totalPackets: number): number {\n if (!totalPackets || totalPackets <= 0 || !lostPackets || lostPackets <= 0) {\n return 0;\n }\n\n return Math.round((lostPackets / totalPackets) * 100);\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts deleted file mode 100644 index c943bb5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { TypedEventEmitter } from "../../models/typed-event-emitter"; -import { ByteSentStatsReport, ConnectionStatsReport, StatsReport } from "./statsReport"; -export type StatsReportHandlerMap = { - [StatsReport.BYTE_SENT_STATS]: (report: ByteSentStatsReport) => void; - [StatsReport.CONNECTION_STATS]: (report: ConnectionStatsReport) => void; -}; -export declare class StatsReportEmitter extends TypedEventEmitter { - emitByteSendReport(byteSentStats: ByteSentStatsReport): void; - emitConnectionStatsReport(report: ConnectionStatsReport): void; -} -//# sourceMappingURL=statsReportEmitter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts.map deleted file mode 100644 index edefe33..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReportEmitter.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/statsReportEmitter.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAExF,MAAM,MAAM,qBAAqB,GAAG;IAChC,CAAC,WAAW,CAAC,eAAe,CAAC,EAAE,CAAC,MAAM,EAAE,mBAAmB,KAAK,IAAI,CAAC;IACrE,CAAC,WAAW,CAAC,gBAAgB,CAAC,EAAE,CAAC,MAAM,EAAE,qBAAqB,KAAK,IAAI,CAAC;CAC3E,CAAC;AAEF,qBAAa,kBAAmB,SAAQ,iBAAiB,CAAC,WAAW,EAAE,qBAAqB,CAAC;IAClF,kBAAkB,CAAC,aAAa,EAAE,mBAAmB,GAAG,IAAI;IAI5D,yBAAyB,CAAC,MAAM,EAAE,qBAAqB,GAAG,IAAI;CAGxE"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js deleted file mode 100644 index fec87d5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js +++ /dev/null @@ -1,34 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.StatsReportEmitter = void 0; -var _typedEventEmitter = require("../../models/typed-event-emitter"); -var _statsReport = require("./statsReport"); -/* -Copyright 2023 The Matrix.org Foundation C.I.C. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -class StatsReportEmitter extends _typedEventEmitter.TypedEventEmitter { - emitByteSendReport(byteSentStats) { - this.emit(_statsReport.StatsReport.BYTE_SENT_STATS, byteSentStats); - } - emitConnectionStatsReport(report) { - this.emit(_statsReport.StatsReport.CONNECTION_STATS, report); - } -} -exports.StatsReportEmitter = StatsReportEmitter; -//# sourceMappingURL=statsReportEmitter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js.map deleted file mode 100644 index 0fae3d9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportEmitter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReportEmitter.js","names":["_typedEventEmitter","require","_statsReport","StatsReportEmitter","TypedEventEmitter","emitByteSendReport","byteSentStats","emit","StatsReport","BYTE_SENT_STATS","emitConnectionStatsReport","report","CONNECTION_STATS","exports"],"sources":["../../../src/webrtc/stats/statsReportEmitter.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { TypedEventEmitter } from \"../../models/typed-event-emitter\";\nimport { ByteSentStatsReport, ConnectionStatsReport, StatsReport } from \"./statsReport\";\n\nexport type StatsReportHandlerMap = {\n [StatsReport.BYTE_SENT_STATS]: (report: ByteSentStatsReport) => void;\n [StatsReport.CONNECTION_STATS]: (report: ConnectionStatsReport) => void;\n};\n\nexport class StatsReportEmitter extends TypedEventEmitter {\n public emitByteSendReport(byteSentStats: ByteSentStatsReport): void {\n this.emit(StatsReport.BYTE_SENT_STATS, byteSentStats);\n }\n\n public emitConnectionStatsReport(report: ConnectionStatsReport): void {\n this.emit(StatsReport.CONNECTION_STATS, report);\n }\n}\n"],"mappings":";;;;;;AAgBA,IAAAA,kBAAA,GAAAC,OAAA;AACA,IAAAC,YAAA,GAAAD,OAAA;AAjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAUO,MAAME,kBAAkB,SAASC,oCAAiB,CAAqC;EACnFC,kBAAkBA,CAACC,aAAkC,EAAQ;IAChE,IAAI,CAACC,IAAI,CAACC,wBAAW,CAACC,eAAe,EAAEH,aAAa,CAAC;EACzD;EAEOI,yBAAyBA,CAACC,MAA6B,EAAQ;IAClE,IAAI,CAACJ,IAAI,CAACC,wBAAW,CAACI,gBAAgB,EAAED,MAAM,CAAC;EACnD;AACJ;AAACE,OAAA,CAAAV,kBAAA,GAAAA,kBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts deleted file mode 100644 index fc83b29..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts +++ /dev/null @@ -1,23 +0,0 @@ -import { StatsReportEmitter } from "./statsReportEmitter"; -export declare class StatsReportGatherer { - readonly callId: string; - readonly remoteUserId: string; - private readonly pc; - private readonly emitter; - private readonly isFocus; - private isActive; - private previousStatsReport; - private currentStatsReport; - private readonly connectionStats; - private readonly trackStats; - constructor(callId: string, remoteUserId: string, pc: RTCPeerConnection, emitter: StatsReportEmitter, isFocus?: boolean); - processStats(groupCallId: string, localUserId: string): Promise; - private processStatsReport; - setActive(isActive: boolean): void; - getActive(): boolean; - private handleError; - private processAndEmitReport; - stopProcessingStats(): void; - private onSignalStateChange; -} -//# sourceMappingURL=statsReportGatherer.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts.map deleted file mode 100644 index 04516a6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReportGatherer.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/statsReportGatherer.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAW1D,qBAAa,mBAAmB;aAWR,MAAM,EAAE,MAAM;aACd,YAAY,EAAE,MAAM;IACpC,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAd5B,OAAO,CAAC,QAAQ,CAAQ;IACxB,OAAO,CAAC,mBAAmB,CAA6B;IACxD,OAAO,CAAC,kBAAkB,CAA6B;IACvD,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAyB;IAEzD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAyB;gBAKhC,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM,EACnB,EAAE,EAAE,iBAAiB,EACrB,OAAO,EAAE,kBAAkB,EAC3B,OAAO,UAAO;IAMtB,YAAY,CAAC,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IA4BrF,OAAO,CAAC,kBAAkB;IAkEnB,SAAS,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAIlC,SAAS,IAAI,OAAO;IAI3B,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,oBAAoB;IAerB,mBAAmB,IAAI,IAAI;IAElC,OAAO,CAAC,mBAAmB;CAU9B"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js deleted file mode 100644 index 02522f5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js +++ /dev/null @@ -1,143 +0,0 @@ -"use strict"; - -var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.StatsReportGatherer = void 0; -var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); -var _connectionStats = require("./connectionStats"); -var _connectionStatsReporter = require("./connectionStatsReporter"); -var _transportStatsReporter = require("./transportStatsReporter"); -var _mediaSsrcHandler = require("./media/mediaSsrcHandler"); -var _mediaTrackHandler = require("./media/mediaTrackHandler"); -var _mediaTrackStatsHandler = require("./media/mediaTrackStatsHandler"); -var _trackStatsReporter = require("./trackStatsReporter"); -var _statsReportBuilder = require("./statsReportBuilder"); -var _statsValueFormatter = require("./statsValueFormatter"); -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } -class StatsReportGatherer { - // private readonly ssrcToMid = { local: new Map(), remote: new Map() }; - - constructor(callId, remoteUserId, pc, emitter, isFocus = true) { - this.callId = callId; - this.remoteUserId = remoteUserId; - this.pc = pc; - this.emitter = emitter; - this.isFocus = isFocus; - (0, _defineProperty2.default)(this, "isActive", true); - (0, _defineProperty2.default)(this, "previousStatsReport", void 0); - (0, _defineProperty2.default)(this, "currentStatsReport", void 0); - (0, _defineProperty2.default)(this, "connectionStats", new _connectionStats.ConnectionStats()); - (0, _defineProperty2.default)(this, "trackStats", void 0); - pc.addEventListener("signalingstatechange", this.onSignalStateChange.bind(this)); - this.trackStats = new _mediaTrackStatsHandler.MediaTrackStatsHandler(new _mediaSsrcHandler.MediaSsrcHandler(), new _mediaTrackHandler.MediaTrackHandler(pc)); - } - async processStats(groupCallId, localUserId) { - if (this.isActive) { - const statsPromise = this.pc.getStats(); - if (typeof (statsPromise === null || statsPromise === void 0 ? void 0 : statsPromise.then) === "function") { - return statsPromise.then(report => { - // @ts-ignore - this.currentStatsReport = typeof (report === null || report === void 0 ? void 0 : report.result) === "function" ? report.result() : report; - try { - this.processStatsReport(groupCallId, localUserId); - } catch (error) { - this.isActive = false; - return false; - } - this.previousStatsReport = this.currentStatsReport; - return true; - }).catch(error => { - this.handleError(error); - return false; - }); - } - this.isActive = false; - } - return Promise.resolve(false); - } - processStatsReport(groupCallId, localUserId) { - var _this$currentStatsRep; - const byteSentStats = new Map(); - (_this$currentStatsRep = this.currentStatsReport) === null || _this$currentStatsRep === void 0 ? void 0 : _this$currentStatsRep.forEach(now => { - const before = this.previousStatsReport ? this.previousStatsReport.get(now.id) : null; - // RTCIceCandidatePairStats - https://w3c.github.io/webrtc-stats/#candidatepair-dict* - if (now.type === "candidate-pair" && now.nominated && now.state === "succeeded") { - this.connectionStats.bandwidth = _connectionStatsReporter.ConnectionStatsReporter.buildBandwidthReport(now); - this.connectionStats.transport = _transportStatsReporter.TransportStatsReporter.buildReport(this.currentStatsReport, now, this.connectionStats.transport, this.isFocus); - - // RTCReceivedRtpStreamStats - // https://w3c.github.io/webrtc-stats/#receivedrtpstats-dict* - // RTCSentRtpStreamStats - // https://w3c.github.io/webrtc-stats/#sentrtpstats-dict* - } else if (now.type === "inbound-rtp" || now.type === "outbound-rtp") { - const trackStats = this.trackStats.findTrack2Stats(now, now.type === "inbound-rtp" ? "remote" : "local"); - if (!trackStats) { - return; - } - if (before) { - _trackStatsReporter.TrackStatsReporter.buildPacketsLost(trackStats, now, before); - } - - // Get the resolution and framerate for only remote video sources here. For the local video sources, - // 'track' stats will be used since they have the updated resolution based on the simulcast streams - // currently being sent. Promise based getStats reports three 'outbound-rtp' streams and there will be - // more calculations needed to determine what is the highest resolution stream sent by the client if the - // 'outbound-rtp' stats are used. - if (now.type === "inbound-rtp") { - _trackStatsReporter.TrackStatsReporter.buildFramerateResolution(trackStats, now); - if (before) { - _trackStatsReporter.TrackStatsReporter.buildBitrateReceived(trackStats, now, before); - } - } else if (before) { - byteSentStats.set(trackStats.trackId, _statsValueFormatter.StatsValueFormatter.getNonNegativeValue(now.bytesSent)); - _trackStatsReporter.TrackStatsReporter.buildBitrateSend(trackStats, now, before); - } - _trackStatsReporter.TrackStatsReporter.buildCodec(this.currentStatsReport, trackStats, now); - } else if (now.type === "track" && now.kind === "video" && !now.remoteSource) { - const trackStats = this.trackStats.findLocalVideoTrackStats(now); - if (!trackStats) { - return; - } - _trackStatsReporter.TrackStatsReporter.buildFramerateResolution(trackStats, now); - _trackStatsReporter.TrackStatsReporter.calculateSimulcastFramerate(trackStats, now, before, this.trackStats.mediaTrackHandler.getActiveSimulcastStreams()); - } - }); - this.emitter.emitByteSendReport(byteSentStats); - this.processAndEmitReport(); - } - setActive(isActive) { - this.isActive = isActive; - } - getActive() { - return this.isActive; - } - handleError(_) { - this.isActive = false; - } - processAndEmitReport() { - const report = _statsReportBuilder.StatsReportBuilder.build(this.trackStats.getTrack2stats()); - this.connectionStats.bandwidth = report.bandwidth; - this.connectionStats.bitrate = report.bitrate; - this.connectionStats.packetLoss = report.packetLoss; - this.emitter.emitConnectionStatsReport(_objectSpread(_objectSpread({}, report), {}, { - transport: this.connectionStats.transport - })); - this.connectionStats.transport = []; - } - stopProcessingStats() {} - onSignalStateChange() { - if (this.pc.signalingState === "stable") { - if (this.pc.currentRemoteDescription) { - this.trackStats.mediaSsrcHandler.parse(this.pc.currentRemoteDescription.sdp, "remote"); - } - if (this.pc.currentLocalDescription) { - this.trackStats.mediaSsrcHandler.parse(this.pc.currentLocalDescription.sdp, "local"); - } - } - } -} -exports.StatsReportGatherer = StatsReportGatherer; -//# sourceMappingURL=statsReportGatherer.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js.map deleted file mode 100644 index 30fa506..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsReportGatherer.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsReportGatherer.js","names":["_connectionStats","require","_connectionStatsReporter","_transportStatsReporter","_mediaSsrcHandler","_mediaTrackHandler","_mediaTrackStatsHandler","_trackStatsReporter","_statsReportBuilder","_statsValueFormatter","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","StatsReportGatherer","constructor","callId","remoteUserId","pc","emitter","isFocus","ConnectionStats","addEventListener","onSignalStateChange","bind","trackStats","MediaTrackStatsHandler","MediaSsrcHandler","MediaTrackHandler","processStats","groupCallId","localUserId","isActive","statsPromise","getStats","then","report","currentStatsReport","result","processStatsReport","error","previousStatsReport","catch","handleError","Promise","resolve","_this$currentStatsRep","byteSentStats","Map","now","before","get","id","type","nominated","state","connectionStats","bandwidth","ConnectionStatsReporter","buildBandwidthReport","transport","TransportStatsReporter","buildReport","findTrack2Stats","TrackStatsReporter","buildPacketsLost","buildFramerateResolution","buildBitrateReceived","set","trackId","StatsValueFormatter","getNonNegativeValue","bytesSent","buildBitrateSend","buildCodec","kind","remoteSource","findLocalVideoTrackStats","calculateSimulcastFramerate","mediaTrackHandler","getActiveSimulcastStreams","emitByteSendReport","processAndEmitReport","setActive","getActive","_","StatsReportBuilder","build","getTrack2stats","bitrate","packetLoss","emitConnectionStatsReport","stopProcessingStats","signalingState","currentRemoteDescription","mediaSsrcHandler","parse","sdp","currentLocalDescription","exports"],"sources":["../../../src/webrtc/stats/statsReportGatherer.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { ConnectionStats } from \"./connectionStats\";\nimport { StatsReportEmitter } from \"./statsReportEmitter\";\nimport { ByteSend, ByteSentStatsReport, TrackID } from \"./statsReport\";\nimport { ConnectionStatsReporter } from \"./connectionStatsReporter\";\nimport { TransportStatsReporter } from \"./transportStatsReporter\";\nimport { MediaSsrcHandler } from \"./media/mediaSsrcHandler\";\nimport { MediaTrackHandler } from \"./media/mediaTrackHandler\";\nimport { MediaTrackStatsHandler } from \"./media/mediaTrackStatsHandler\";\nimport { TrackStatsReporter } from \"./trackStatsReporter\";\nimport { StatsReportBuilder } from \"./statsReportBuilder\";\nimport { StatsValueFormatter } from \"./statsValueFormatter\";\n\nexport class StatsReportGatherer {\n private isActive = true;\n private previousStatsReport: RTCStatsReport | undefined;\n private currentStatsReport: RTCStatsReport | undefined;\n private readonly connectionStats = new ConnectionStats();\n\n private readonly trackStats: MediaTrackStatsHandler;\n\n // private readonly ssrcToMid = { local: new Map(), remote: new Map() };\n\n public constructor(\n public readonly callId: string,\n public readonly remoteUserId: string,\n private readonly pc: RTCPeerConnection,\n private readonly emitter: StatsReportEmitter,\n private readonly isFocus = true,\n ) {\n pc.addEventListener(\"signalingstatechange\", this.onSignalStateChange.bind(this));\n this.trackStats = new MediaTrackStatsHandler(new MediaSsrcHandler(), new MediaTrackHandler(pc));\n }\n\n public async processStats(groupCallId: string, localUserId: string): Promise {\n if (this.isActive) {\n const statsPromise = this.pc.getStats();\n if (typeof statsPromise?.then === \"function\") {\n return statsPromise\n .then((report) => {\n // @ts-ignore\n this.currentStatsReport = typeof report?.result === \"function\" ? report.result() : report;\n try {\n this.processStatsReport(groupCallId, localUserId);\n } catch (error) {\n this.isActive = false;\n return false;\n }\n\n this.previousStatsReport = this.currentStatsReport;\n return true;\n })\n .catch((error) => {\n this.handleError(error);\n return false;\n });\n }\n this.isActive = false;\n }\n return Promise.resolve(false);\n }\n\n private processStatsReport(groupCallId: string, localUserId: string): void {\n const byteSentStats: ByteSentStatsReport = new Map();\n\n this.currentStatsReport?.forEach((now) => {\n const before = this.previousStatsReport ? this.previousStatsReport.get(now.id) : null;\n // RTCIceCandidatePairStats - https://w3c.github.io/webrtc-stats/#candidatepair-dict*\n if (now.type === \"candidate-pair\" && now.nominated && now.state === \"succeeded\") {\n this.connectionStats.bandwidth = ConnectionStatsReporter.buildBandwidthReport(now);\n this.connectionStats.transport = TransportStatsReporter.buildReport(\n this.currentStatsReport,\n now,\n this.connectionStats.transport,\n this.isFocus,\n );\n\n // RTCReceivedRtpStreamStats\n // https://w3c.github.io/webrtc-stats/#receivedrtpstats-dict*\n // RTCSentRtpStreamStats\n // https://w3c.github.io/webrtc-stats/#sentrtpstats-dict*\n } else if (now.type === \"inbound-rtp\" || now.type === \"outbound-rtp\") {\n const trackStats = this.trackStats.findTrack2Stats(\n now,\n now.type === \"inbound-rtp\" ? \"remote\" : \"local\",\n );\n if (!trackStats) {\n return;\n }\n\n if (before) {\n TrackStatsReporter.buildPacketsLost(trackStats, now, before);\n }\n\n // Get the resolution and framerate for only remote video sources here. For the local video sources,\n // 'track' stats will be used since they have the updated resolution based on the simulcast streams\n // currently being sent. Promise based getStats reports three 'outbound-rtp' streams and there will be\n // more calculations needed to determine what is the highest resolution stream sent by the client if the\n // 'outbound-rtp' stats are used.\n if (now.type === \"inbound-rtp\") {\n TrackStatsReporter.buildFramerateResolution(trackStats, now);\n if (before) {\n TrackStatsReporter.buildBitrateReceived(trackStats, now, before);\n }\n } else if (before) {\n byteSentStats.set(trackStats.trackId, StatsValueFormatter.getNonNegativeValue(now.bytesSent));\n TrackStatsReporter.buildBitrateSend(trackStats, now, before);\n }\n TrackStatsReporter.buildCodec(this.currentStatsReport, trackStats, now);\n } else if (now.type === \"track\" && now.kind === \"video\" && !now.remoteSource) {\n const trackStats = this.trackStats.findLocalVideoTrackStats(now);\n if (!trackStats) {\n return;\n }\n TrackStatsReporter.buildFramerateResolution(trackStats, now);\n TrackStatsReporter.calculateSimulcastFramerate(\n trackStats,\n now,\n before,\n this.trackStats.mediaTrackHandler.getActiveSimulcastStreams(),\n );\n }\n });\n\n this.emitter.emitByteSendReport(byteSentStats);\n this.processAndEmitReport();\n }\n\n public setActive(isActive: boolean): void {\n this.isActive = isActive;\n }\n\n public getActive(): boolean {\n return this.isActive;\n }\n\n private handleError(_: any): void {\n this.isActive = false;\n }\n\n private processAndEmitReport(): void {\n const report = StatsReportBuilder.build(this.trackStats.getTrack2stats());\n\n this.connectionStats.bandwidth = report.bandwidth;\n this.connectionStats.bitrate = report.bitrate;\n this.connectionStats.packetLoss = report.packetLoss;\n\n this.emitter.emitConnectionStatsReport({\n ...report,\n transport: this.connectionStats.transport,\n });\n\n this.connectionStats.transport = [];\n }\n\n public stopProcessingStats(): void {}\n\n private onSignalStateChange(): void {\n if (this.pc.signalingState === \"stable\") {\n if (this.pc.currentRemoteDescription) {\n this.trackStats.mediaSsrcHandler.parse(this.pc.currentRemoteDescription.sdp, \"remote\");\n }\n if (this.pc.currentLocalDescription) {\n this.trackStats.mediaSsrcHandler.parse(this.pc.currentLocalDescription.sdp, \"local\");\n }\n }\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts deleted file mode 100644 index 08f5cce..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -export declare class StatsValueFormatter { - static getNonNegativeValue(imput: any): number; -} -//# sourceMappingURL=statsValueFormatter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts.map deleted file mode 100644 index 1bdbab3..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsValueFormatter.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/statsValueFormatter.ts"],"names":[],"mappings":"AAYA,qBAAa,mBAAmB;WACd,mBAAmB,CAAC,KAAK,EAAE,GAAG,GAAG,MAAM;CAaxD"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js deleted file mode 100644 index 5324ad5..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js +++ /dev/null @@ -1,32 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.StatsValueFormatter = void 0; -/* -Copyright 2023 The Matrix.org Foundation C.I.C. -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - http://www.apache.org/licenses/LICENSE-2.0 -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ -class StatsValueFormatter { - static getNonNegativeValue(imput) { - let value = imput; - if (typeof value !== "number") { - value = Number(value); - } - if (isNaN(value)) { - return 0; - } - return Math.max(0, value); - } -} -exports.StatsValueFormatter = StatsValueFormatter; -//# sourceMappingURL=statsValueFormatter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js.map deleted file mode 100644 index 3aa4877..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/statsValueFormatter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"statsValueFormatter.js","names":["StatsValueFormatter","getNonNegativeValue","imput","value","Number","isNaN","Math","max","exports"],"sources":["../../../src/webrtc/stats/statsValueFormatter.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n http://www.apache.org/licenses/LICENSE-2.0\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\nexport class StatsValueFormatter {\n public static getNonNegativeValue(imput: any): number {\n let value = imput;\n\n if (typeof value !== \"number\") {\n value = Number(value);\n }\n\n if (isNaN(value)) {\n return 0;\n }\n\n return Math.max(0, value);\n }\n}\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMA,mBAAmB,CAAC;EAC7B,OAAcC,mBAAmBA,CAACC,KAAU,EAAU;IAClD,IAAIC,KAAK,GAAGD,KAAK;IAEjB,IAAI,OAAOC,KAAK,KAAK,QAAQ,EAAE;MAC3BA,KAAK,GAAGC,MAAM,CAACD,KAAK,CAAC;IACzB;IAEA,IAAIE,KAAK,CAACF,KAAK,CAAC,EAAE;MACd,OAAO,CAAC;IACZ;IAEA,OAAOG,IAAI,CAACC,GAAG,CAAC,CAAC,EAAEJ,KAAK,CAAC;EAC7B;AACJ;AAACK,OAAA,CAAAR,mBAAA,GAAAA,mBAAA"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts deleted file mode 100644 index 99130d7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { MediaTrackStats } from "./media/mediaTrackStats"; -export declare class TrackStatsReporter { - static buildFramerateResolution(trackStats: MediaTrackStats, now: any): void; - static calculateSimulcastFramerate(trackStats: MediaTrackStats, now: any, before: any, layer: number): void; - static buildCodec(report: RTCStatsReport | undefined, trackStats: MediaTrackStats, now: any): void; - static buildBitrateReceived(trackStats: MediaTrackStats, now: any, before: any): void; - static buildBitrateSend(trackStats: MediaTrackStats, now: any, before: any): void; - static buildPacketsLost(trackStats: MediaTrackStats, now: any, before: any): void; - private static calculateBitrate; -} -//# sourceMappingURL=trackStatsReporter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts.map deleted file mode 100644 index 159f579..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"trackStatsReporter.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/trackStatsReporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAG1D,qBAAa,kBAAkB;WACb,wBAAwB,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI;WAarE,2BAA2B,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;WAuBpG,UAAU,CAAC,MAAM,EAAE,cAAc,GAAG,SAAS,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI;WAe3F,oBAAoB,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,GAAG,IAAI;WAY9E,gBAAgB,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,GAAG,IAAI;WAO1E,gBAAgB,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,GAAG,IAAI;IAsBxF,OAAO,CAAC,MAAM,CAAC,gBAAgB;CAoBlC"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js deleted file mode 100644 index af6f96a..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js +++ /dev/null @@ -1,94 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TrackStatsReporter = void 0; -var _statsValueFormatter = require("./statsValueFormatter"); -class TrackStatsReporter { - static buildFramerateResolution(trackStats, now) { - const resolution = { - height: now.frameHeight, - width: now.frameWidth - }; - const frameRate = now.framesPerSecond; - if (resolution.height && resolution.width) { - trackStats.setResolution(resolution); - } - trackStats.setFramerate(Math.round(frameRate || 0)); - } - static calculateSimulcastFramerate(trackStats, now, before, layer) { - let frameRate = trackStats.getFramerate(); - if (!frameRate) { - if (before) { - const timeMs = now.timestamp - before.timestamp; - if (timeMs > 0 && now.framesSent) { - const numberOfFramesSinceBefore = now.framesSent - before.framesSent; - frameRate = numberOfFramesSinceBefore / timeMs * 1000; - } - } - if (!frameRate) { - return; - } - } - - // Reset frame rate to 0 when video is suspended as a result of endpoint falling out of last-n. - frameRate = layer ? Math.round(frameRate / layer) : 0; - trackStats.setFramerate(frameRate); - } - static buildCodec(report, trackStats, now) { - const codec = report === null || report === void 0 ? void 0 : report.get(now.codecId); - if (codec) { - /** - * The mime type has the following form: video/VP8 or audio/ISAC, - * so we what to keep just the type after the '/', audio and video - * keys will be added on the processing side. - */ - const codecShortType = codec.mimeType.split("/")[1]; - codecShortType && trackStats.setCodec(codecShortType); - } - } - static buildBitrateReceived(trackStats, now, before) { - trackStats.setBitrate({ - download: TrackStatsReporter.calculateBitrate(now.bytesReceived, before.bytesReceived, now.timestamp, before.timestamp), - upload: 0 - }); - } - static buildBitrateSend(trackStats, now, before) { - trackStats.setBitrate({ - download: 0, - upload: this.calculateBitrate(now.bytesSent, before.bytesSent, now.timestamp, before.timestamp) - }); - } - static buildPacketsLost(trackStats, now, before) { - const key = now.type === "outbound-rtp" ? "packetsSent" : "packetsReceived"; - let packetsNow = now[key]; - if (!packetsNow || packetsNow < 0) { - packetsNow = 0; - } - const packetsBefore = _statsValueFormatter.StatsValueFormatter.getNonNegativeValue(before[key]); - const packetsDiff = Math.max(0, packetsNow - packetsBefore); - const packetsLostNow = _statsValueFormatter.StatsValueFormatter.getNonNegativeValue(now.packetsLost); - const packetsLostBefore = _statsValueFormatter.StatsValueFormatter.getNonNegativeValue(before.packetsLost); - const packetsLostDiff = Math.max(0, packetsLostNow - packetsLostBefore); - trackStats.setLoss({ - packetsTotal: packetsDiff + packetsLostDiff, - packetsLost: packetsLostDiff, - isDownloadStream: now.type !== "outbound-rtp" - }); - } - static calculateBitrate(bytesNowAny, bytesBeforeAny, nowTimestamp, beforeTimestamp) { - const bytesNow = _statsValueFormatter.StatsValueFormatter.getNonNegativeValue(bytesNowAny); - const bytesBefore = _statsValueFormatter.StatsValueFormatter.getNonNegativeValue(bytesBeforeAny); - const bytesProcessed = Math.max(0, bytesNow - bytesBefore); - const timeMs = nowTimestamp - beforeTimestamp; - let bitrateKbps = 0; - if (timeMs > 0) { - // TODO is there any reason to round here? - bitrateKbps = Math.round(bytesProcessed * 8 / timeMs); - } - return bitrateKbps; - } -} -exports.TrackStatsReporter = TrackStatsReporter; -//# sourceMappingURL=trackStatsReporter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js.map deleted file mode 100644 index 4828aae..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/trackStatsReporter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"trackStatsReporter.js","names":["_statsValueFormatter","require","TrackStatsReporter","buildFramerateResolution","trackStats","now","resolution","height","frameHeight","width","frameWidth","frameRate","framesPerSecond","setResolution","setFramerate","Math","round","calculateSimulcastFramerate","before","layer","getFramerate","timeMs","timestamp","framesSent","numberOfFramesSinceBefore","buildCodec","report","codec","get","codecId","codecShortType","mimeType","split","setCodec","buildBitrateReceived","setBitrate","download","calculateBitrate","bytesReceived","upload","buildBitrateSend","bytesSent","buildPacketsLost","key","type","packetsNow","packetsBefore","StatsValueFormatter","getNonNegativeValue","packetsDiff","max","packetsLostNow","packetsLost","packetsLostBefore","packetsLostDiff","setLoss","packetsTotal","isDownloadStream","bytesNowAny","bytesBeforeAny","nowTimestamp","beforeTimestamp","bytesNow","bytesBefore","bytesProcessed","bitrateKbps","exports"],"sources":["../../../src/webrtc/stats/trackStatsReporter.ts"],"sourcesContent":["import { MediaTrackStats } from \"./media/mediaTrackStats\";\nimport { StatsValueFormatter } from \"./statsValueFormatter\";\n\nexport class TrackStatsReporter {\n public static buildFramerateResolution(trackStats: MediaTrackStats, now: any): void {\n const resolution = {\n height: now.frameHeight,\n width: now.frameWidth,\n };\n const frameRate = now.framesPerSecond;\n\n if (resolution.height && resolution.width) {\n trackStats.setResolution(resolution);\n }\n trackStats.setFramerate(Math.round(frameRate || 0));\n }\n\n public static calculateSimulcastFramerate(trackStats: MediaTrackStats, now: any, before: any, layer: number): void {\n let frameRate = trackStats.getFramerate();\n if (!frameRate) {\n if (before) {\n const timeMs = now.timestamp - before.timestamp;\n\n if (timeMs > 0 && now.framesSent) {\n const numberOfFramesSinceBefore = now.framesSent - before.framesSent;\n\n frameRate = (numberOfFramesSinceBefore / timeMs) * 1000;\n }\n }\n\n if (!frameRate) {\n return;\n }\n }\n\n // Reset frame rate to 0 when video is suspended as a result of endpoint falling out of last-n.\n frameRate = layer ? Math.round(frameRate / layer) : 0;\n trackStats.setFramerate(frameRate);\n }\n\n public static buildCodec(report: RTCStatsReport | undefined, trackStats: MediaTrackStats, now: any): void {\n const codec = report?.get(now.codecId);\n\n if (codec) {\n /**\n * The mime type has the following form: video/VP8 or audio/ISAC,\n * so we what to keep just the type after the '/', audio and video\n * keys will be added on the processing side.\n */\n const codecShortType = codec.mimeType.split(\"/\")[1];\n\n codecShortType && trackStats.setCodec(codecShortType);\n }\n }\n\n public static buildBitrateReceived(trackStats: MediaTrackStats, now: any, before: any): void {\n trackStats.setBitrate({\n download: TrackStatsReporter.calculateBitrate(\n now.bytesReceived,\n before.bytesReceived,\n now.timestamp,\n before.timestamp,\n ),\n upload: 0,\n });\n }\n\n public static buildBitrateSend(trackStats: MediaTrackStats, now: any, before: any): void {\n trackStats.setBitrate({\n download: 0,\n upload: this.calculateBitrate(now.bytesSent, before.bytesSent, now.timestamp, before.timestamp),\n });\n }\n\n public static buildPacketsLost(trackStats: MediaTrackStats, now: any, before: any): void {\n const key = now.type === \"outbound-rtp\" ? \"packetsSent\" : \"packetsReceived\";\n\n let packetsNow = now[key];\n if (!packetsNow || packetsNow < 0) {\n packetsNow = 0;\n }\n\n const packetsBefore = StatsValueFormatter.getNonNegativeValue(before[key]);\n const packetsDiff = Math.max(0, packetsNow - packetsBefore);\n\n const packetsLostNow = StatsValueFormatter.getNonNegativeValue(now.packetsLost);\n const packetsLostBefore = StatsValueFormatter.getNonNegativeValue(before.packetsLost);\n const packetsLostDiff = Math.max(0, packetsLostNow - packetsLostBefore);\n\n trackStats.setLoss({\n packetsTotal: packetsDiff + packetsLostDiff,\n packetsLost: packetsLostDiff,\n isDownloadStream: now.type !== \"outbound-rtp\",\n });\n }\n\n private static calculateBitrate(\n bytesNowAny: any,\n bytesBeforeAny: any,\n nowTimestamp: number,\n beforeTimestamp: number,\n ): number {\n const bytesNow = StatsValueFormatter.getNonNegativeValue(bytesNowAny);\n const bytesBefore = StatsValueFormatter.getNonNegativeValue(bytesBeforeAny);\n const bytesProcessed = Math.max(0, bytesNow - bytesBefore);\n\n const timeMs = nowTimestamp - beforeTimestamp;\n let bitrateKbps = 0;\n\n if (timeMs > 0) {\n // TODO is there any reason to round here?\n bitrateKbps = Math.round((bytesProcessed * 8) / timeMs);\n }\n\n return bitrateKbps;\n }\n}\n"],"mappings":"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"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts deleted file mode 100644 index bffc9b6..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts +++ /dev/null @@ -1,11 +0,0 @@ -export interface TransportStats { - ip: string; - type: string; - localIp: string; - isFocus: boolean; - localCandidateType: string; - remoteCandidateType: string; - networkType: string; - rtt: number; -} -//# sourceMappingURL=transportStats.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts.map deleted file mode 100644 index cee2f59..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"transportStats.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/transportStats.ts"],"names":[],"mappings":"AAgBA,MAAM,WAAW,cAAc;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC;IACjB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,GAAG,EAAE,MAAM,CAAC;CACf"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js deleted file mode 100644 index 402a6ef..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js +++ /dev/null @@ -1,6 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -//# sourceMappingURL=transportStats.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js.map deleted file mode 100644 index a4ac8a7..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStats.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"transportStats.js","names":[],"sources":["../../../src/webrtc/stats/transportStats.ts"],"sourcesContent":["/*\nCopyright 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nexport interface TransportStats {\n ip: string;\n type: string;\n localIp: string;\n isFocus: boolean;\n localCandidateType: string;\n remoteCandidateType: string;\n networkType: string;\n rtt: number;\n}\n"],"mappings":""} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts deleted file mode 100644 index 0210a6e..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -import { TransportStats } from "./transportStats"; -export declare class TransportStatsReporter { - static buildReport(report: RTCStatsReport | undefined, now: RTCIceCandidatePairStats, conferenceStatsTransport: TransportStats[], isFocus: boolean): TransportStats[]; -} -//# sourceMappingURL=transportStatsReporter.d.ts.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts.map deleted file mode 100644 index ce26080..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.d.ts.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"transportStatsReporter.d.ts","sourceRoot":"","sources":["../../../src/webrtc/stats/transportStatsReporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,qBAAa,sBAAsB;WACjB,WAAW,CACrB,MAAM,EAAE,cAAc,GAAG,SAAS,EAClC,GAAG,EAAE,wBAAwB,EAC7B,wBAAwB,EAAE,cAAc,EAAE,EAC1C,OAAO,EAAE,OAAO,GACjB,cAAc,EAAE;CAuCtB"} \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js deleted file mode 100644 index bc768c9..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js +++ /dev/null @@ -1,41 +0,0 @@ -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TransportStatsReporter = void 0; -class TransportStatsReporter { - static buildReport(report, now, conferenceStatsTransport, isFocus) { - const localUsedCandidate = report === null || report === void 0 ? void 0 : report.get(now.localCandidateId); - const remoteUsedCandidate = report === null || report === void 0 ? void 0 : report.get(now.remoteCandidateId); - - // RTCIceCandidateStats - // https://w3c.github.io/webrtc-stats/#icecandidate-dict* - if (remoteUsedCandidate && localUsedCandidate) { - const remoteIpAddress = remoteUsedCandidate.ip !== undefined ? remoteUsedCandidate.ip : remoteUsedCandidate.address; - const remotePort = remoteUsedCandidate.port; - const ip = `${remoteIpAddress}:${remotePort}`; - const localIpAddress = localUsedCandidate.ip !== undefined ? localUsedCandidate.ip : localUsedCandidate.address; - const localPort = localUsedCandidate.port; - const localIp = `${localIpAddress}:${localPort}`; - const type = remoteUsedCandidate.protocol; - - // Save the address unless it has been saved already. - if (!conferenceStatsTransport.some(t => t.ip === ip && t.type === type && t.localIp === localIp)) { - conferenceStatsTransport.push({ - ip, - type, - localIp, - isFocus, - localCandidateType: localUsedCandidate.candidateType, - remoteCandidateType: remoteUsedCandidate.candidateType, - networkType: localUsedCandidate.networkType, - rtt: now.currentRoundTripTime ? now.currentRoundTripTime * 1000 : NaN - }); - } - } - return conferenceStatsTransport; - } -} -exports.TransportStatsReporter = TransportStatsReporter; -//# sourceMappingURL=transportStatsReporter.js.map \ No newline at end of file diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js.map deleted file mode 100644 index c352ddc..0000000 --- a/includes/external/matrix/node_modules/matrix-js-sdk/lib/webrtc/stats/transportStatsReporter.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"transportStatsReporter.js","names":["TransportStatsReporter","buildReport","report","now","conferenceStatsTransport","isFocus","localUsedCandidate","get","localCandidateId","remoteUsedCandidate","remoteCandidateId","remoteIpAddress","ip","undefined","address","remotePort","port","localIpAddress","localPort","localIp","type","protocol","some","t","push","localCandidateType","candidateType","remoteCandidateType","networkType","rtt","currentRoundTripTime","NaN","exports"],"sources":["../../../src/webrtc/stats/transportStatsReporter.ts"],"sourcesContent":["import { TransportStats } from \"./transportStats\";\n\nexport class TransportStatsReporter {\n public static buildReport(\n report: RTCStatsReport | undefined,\n now: RTCIceCandidatePairStats,\n conferenceStatsTransport: TransportStats[],\n isFocus: boolean,\n ): TransportStats[] {\n const localUsedCandidate = report?.get(now.localCandidateId);\n const remoteUsedCandidate = report?.get(now.remoteCandidateId);\n\n // RTCIceCandidateStats\n // https://w3c.github.io/webrtc-stats/#icecandidate-dict*\n if (remoteUsedCandidate && localUsedCandidate) {\n const remoteIpAddress =\n remoteUsedCandidate.ip !== undefined ? remoteUsedCandidate.ip : remoteUsedCandidate.address;\n const remotePort = remoteUsedCandidate.port;\n const ip = `${remoteIpAddress}:${remotePort}`;\n\n const localIpAddress =\n localUsedCandidate.ip !== undefined ? localUsedCandidate.ip : localUsedCandidate.address;\n const localPort = localUsedCandidate.port;\n const localIp = `${localIpAddress}:${localPort}`;\n\n const type = remoteUsedCandidate.protocol;\n\n // Save the address unless it has been saved already.\n if (\n !conferenceStatsTransport.some(\n (t: TransportStats) => t.ip === ip && t.type === type && t.localIp === localIp,\n )\n ) {\n conferenceStatsTransport.push({\n ip,\n type,\n localIp,\n isFocus,\n localCandidateType: localUsedCandidate.candidateType,\n remoteCandidateType: remoteUsedCandidate.candidateType,\n networkType: localUsedCandidate.networkType,\n rtt: now.currentRoundTripTime ? now.currentRoundTripTime * 1000 : NaN,\n } as TransportStats);\n }\n }\n return conferenceStatsTransport;\n }\n}\n"],"mappings":";;;;;;AAEO,MAAMA,sBAAsB,CAAC;EAChC,OAAcC,WAAWA,CACrBC,MAAkC,EAClCC,GAA6B,EAC7BC,wBAA0C,EAC1CC,OAAgB,EACA;IAChB,MAAMC,kBAAkB,GAAGJ,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEK,GAAG,CAACJ,GAAG,CAACK,gBAAgB,CAAC;IAC5D,MAAMC,mBAAmB,GAAGP,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEK,GAAG,CAACJ,GAAG,CAACO,iBAAiB,CAAC;;IAE9D;IACA;IACA,IAAID,mBAAmB,IAAIH,kBAAkB,EAAE;MAC3C,MAAMK,eAAe,GACjBF,mBAAmB,CAACG,EAAE,KAAKC,SAAS,GAAGJ,mBAAmB,CAACG,EAAE,GAAGH,mBAAmB,CAACK,OAAO;MAC/F,MAAMC,UAAU,GAAGN,mBAAmB,CAACO,IAAI;MAC3C,MAAMJ,EAAE,GAAI,GAAED,eAAgB,IAAGI,UAAW,EAAC;MAE7C,MAAME,cAAc,GAChBX,kBAAkB,CAACM,EAAE,KAAKC,SAAS,GAAGP,kBAAkB,CAACM,EAAE,GAAGN,kBAAkB,CAACQ,OAAO;MAC5F,MAAMI,SAAS,GAAGZ,kBAAkB,CAACU,IAAI;MACzC,MAAMG,OAAO,GAAI,GAAEF,cAAe,IAAGC,SAAU,EAAC;MAEhD,MAAME,IAAI,GAAGX,mBAAmB,CAACY,QAAQ;;MAEzC;MACA,IACI,CAACjB,wBAAwB,CAACkB,IAAI,CACzBC,CAAiB,IAAKA,CAAC,CAACX,EAAE,KAAKA,EAAE,IAAIW,CAAC,CAACH,IAAI,KAAKA,IAAI,IAAIG,CAAC,CAACJ,OAAO,KAAKA,OAAO,CACjF,EACH;QACEf,wBAAwB,CAACoB,IAAI,CAAC;UAC1BZ,EAAE;UACFQ,IAAI;UACJD,OAAO;UACPd,OAAO;UACPoB,kBAAkB,EAAEnB,kBAAkB,CAACoB,aAAa;UACpDC,mBAAmB,EAAElB,mBAAmB,CAACiB,aAAa;UACtDE,WAAW,EAAEtB,kBAAkB,CAACsB,WAAW;UAC3CC,GAAG,EAAE1B,GAAG,CAAC2B,oBAAoB,GAAG3B,GAAG,CAAC2B,oBAAoB,GAAG,IAAI,GAAGC;QACtE,CAAC,CAAmB;MACxB;IACJ;IACA,OAAO3B,wBAAwB;EACnC;AACJ;AAAC4B,OAAA,CAAAhC,sBAAA,GAAAA,sBAAA"} \ No newline at end of file -- cgit