@unwanted/matrix-sdk-mini 34.12.0 → 34.13.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/git-revision.txt +1 -1
- package/lib/@types/event.d.ts +0 -19
- package/lib/@types/event.d.ts.map +1 -1
- package/lib/@types/event.js.map +1 -1
- package/lib/@types/global.d.js +0 -2
- package/lib/@types/global.d.js.map +1 -1
- package/lib/autodiscovery.d.ts +1 -1
- package/lib/autodiscovery.d.ts.map +1 -1
- package/lib/autodiscovery.js.map +1 -1
- package/lib/base64.d.ts +3 -6
- package/lib/base64.d.ts.map +1 -1
- package/lib/base64.js +43 -36
- package/lib/base64.js.map +1 -1
- package/lib/browser-index.d.ts.map +1 -1
- package/lib/browser-index.js +0 -11
- package/lib/browser-index.js.map +1 -1
- package/lib/client.d.ts +2 -1298
- package/lib/client.d.ts.map +1 -1
- package/lib/client.js +348 -2967
- package/lib/client.js.map +1 -1
- package/lib/digest.d.ts +2 -2
- package/lib/digest.d.ts.map +1 -1
- package/lib/digest.js +2 -2
- package/lib/digest.js.map +1 -1
- package/lib/embedded.d.ts +0 -22
- package/lib/embedded.d.ts.map +1 -1
- package/lib/embedded.js +58 -168
- package/lib/embedded.js.map +1 -1
- package/lib/event-mapper.d.ts.map +1 -1
- package/lib/event-mapper.js +0 -4
- package/lib/event-mapper.js.map +1 -1
- package/lib/matrix.d.ts +0 -25
- package/lib/matrix.d.ts.map +1 -1
- package/lib/matrix.js +1 -30
- package/lib/matrix.js.map +1 -1
- package/lib/models/MSC3089Branch.d.ts.map +1 -1
- package/lib/models/MSC3089Branch.js +0 -3
- package/lib/models/MSC3089Branch.js.map +1 -1
- package/lib/models/event-timeline-set.d.ts +6 -10
- package/lib/models/event-timeline-set.d.ts.map +1 -1
- package/lib/models/event-timeline-set.js +28 -36
- package/lib/models/event-timeline-set.js.map +1 -1
- package/lib/models/event-timeline.d.ts +7 -2
- package/lib/models/event-timeline.d.ts.map +1 -1
- package/lib/models/event-timeline.js +8 -9
- package/lib/models/event-timeline.js.map +1 -1
- package/lib/models/event.d.ts +1 -95
- package/lib/models/event.d.ts.map +1 -1
- package/lib/models/event.js +11 -281
- package/lib/models/event.js.map +1 -1
- package/lib/models/poll.d.ts.map +1 -1
- package/lib/models/poll.js +1 -5
- package/lib/models/poll.js.map +1 -1
- package/lib/models/relations-container.d.ts.map +1 -1
- package/lib/models/relations-container.js +1 -7
- package/lib/models/relations-container.js.map +1 -1
- package/lib/models/relations.d.ts +0 -1
- package/lib/models/relations.d.ts.map +1 -1
- package/lib/models/relations.js +0 -8
- package/lib/models/relations.js.map +1 -1
- package/lib/models/room-state.d.ts +2 -13
- package/lib/models/room-state.d.ts.map +1 -1
- package/lib/models/room-state.js +12 -56
- package/lib/models/room-state.js.map +1 -1
- package/lib/models/room.d.ts +2 -20
- package/lib/models/room.d.ts.map +1 -1
- package/lib/models/room.js +121 -162
- package/lib/models/room.js.map +1 -1
- package/lib/models/thread.d.ts.map +1 -1
- package/lib/models/thread.js +5 -4
- package/lib/models/thread.js.map +1 -1
- package/lib/sliding-sync-sdk.d.ts +3 -4
- package/lib/sliding-sync-sdk.d.ts.map +1 -1
- package/lib/sliding-sync-sdk.js +55 -102
- package/lib/sliding-sync-sdk.js.map +1 -1
- package/lib/sliding-sync.js +9 -6
- package/lib/sliding-sync.js.map +1 -1
- package/lib/store/indexeddb.d.ts +1 -1
- package/lib/store/indexeddb.d.ts.map +1 -1
- package/lib/store/indexeddb.js.map +1 -1
- package/lib/sync-accumulator.d.ts +6 -4
- package/lib/sync-accumulator.d.ts.map +1 -1
- package/lib/sync-accumulator.js +23 -12
- package/lib/sync-accumulator.js.map +1 -1
- package/lib/sync.d.ts +10 -13
- package/lib/sync.d.ts.map +1 -1
- package/lib/sync.js +94 -115
- package/lib/sync.js.map +1 -1
- package/lib/testing.d.ts +0 -48
- package/lib/testing.d.ts.map +1 -1
- package/lib/testing.js +0 -105
- package/lib/testing.js.map +1 -1
- package/lib/types.d.ts +0 -1
- package/lib/types.d.ts.map +1 -1
- package/lib/types.js.map +1 -1
- package/package.json +10 -11
- package/src/@types/event.ts +2 -36
- package/src/@types/global.d.ts +21 -4
- package/src/autodiscovery.ts +1 -1
- package/src/base64.ts +38 -40
- package/src/browser-index.ts +0 -11
- package/src/client.ts +68 -3087
- package/src/digest.ts +3 -3
- package/src/embedded.ts +38 -134
- package/src/event-mapper.ts +0 -4
- package/src/matrix.ts +0 -41
- package/src/models/MSC3089Branch.ts +0 -3
- package/src/models/event-timeline-set.ts +17 -38
- package/src/models/event-timeline.ts +10 -5
- package/src/models/event.ts +8 -295
- package/src/models/poll.ts +0 -6
- package/src/models/relations-container.ts +1 -8
- package/src/models/relations.ts +0 -8
- package/src/models/room-state.ts +4 -37
- package/src/models/room.ts +18 -68
- package/src/models/thread.ts +4 -3
- package/src/sliding-sync-sdk.ts +10 -83
- package/src/sliding-sync.ts +6 -6
- package/src/store/indexeddb.ts +1 -1
- package/src/sync-accumulator.ts +33 -16
- package/src/sync.ts +112 -143
- package/src/testing.ts +0 -108
- package/src/types.ts +0 -1
- package/CHANGELOG.md +0 -5910
- package/lib/@types/AESEncryptedSecretStoragePayload.d.ts +0 -14
- package/lib/@types/AESEncryptedSecretStoragePayload.d.ts.map +0 -1
- package/lib/@types/AESEncryptedSecretStoragePayload.js +0 -1
- package/lib/@types/AESEncryptedSecretStoragePayload.js.map +0 -1
- package/lib/@types/crypto.d.ts +0 -47
- package/lib/@types/crypto.d.ts.map +0 -1
- package/lib/@types/crypto.js +0 -1
- package/lib/@types/crypto.js.map +0 -1
- package/lib/@types/matrix-sdk-crypto-wasm.d.js +0 -1
- package/lib/@types/matrix-sdk-crypto-wasm.d.js.map +0 -1
- package/lib/common-crypto/CryptoBackend.d.ts +0 -240
- package/lib/common-crypto/CryptoBackend.d.ts.map +0 -1
- package/lib/common-crypto/CryptoBackend.js +0 -73
- package/lib/common-crypto/CryptoBackend.js.map +0 -1
- package/lib/common-crypto/key-passphrase.d.ts +0 -14
- package/lib/common-crypto/key-passphrase.d.ts.map +0 -1
- package/lib/common-crypto/key-passphrase.js +0 -33
- package/lib/common-crypto/key-passphrase.js.map +0 -1
- package/lib/crypto/CrossSigning.d.ts +0 -184
- package/lib/crypto/CrossSigning.d.ts.map +0 -1
- package/lib/crypto/CrossSigning.js +0 -718
- package/lib/crypto/CrossSigning.js.map +0 -1
- package/lib/crypto/DeviceList.d.ts +0 -216
- package/lib/crypto/DeviceList.d.ts.map +0 -1
- package/lib/crypto/DeviceList.js +0 -892
- package/lib/crypto/DeviceList.js.map +0 -1
- package/lib/crypto/EncryptionSetup.d.ts +0 -152
- package/lib/crypto/EncryptionSetup.d.ts.map +0 -1
- package/lib/crypto/EncryptionSetup.js +0 -356
- package/lib/crypto/EncryptionSetup.js.map +0 -1
- package/lib/crypto/OlmDevice.d.ts +0 -457
- package/lib/crypto/OlmDevice.d.ts.map +0 -1
- package/lib/crypto/OlmDevice.js +0 -1241
- package/lib/crypto/OlmDevice.js.map +0 -1
- package/lib/crypto/OutgoingRoomKeyRequestManager.d.ts +0 -109
- package/lib/crypto/OutgoingRoomKeyRequestManager.d.ts.map +0 -1
- package/lib/crypto/OutgoingRoomKeyRequestManager.js +0 -415
- package/lib/crypto/OutgoingRoomKeyRequestManager.js.map +0 -1
- package/lib/crypto/RoomList.d.ts +0 -26
- package/lib/crypto/RoomList.d.ts.map +0 -1
- package/lib/crypto/RoomList.js +0 -71
- package/lib/crypto/RoomList.js.map +0 -1
- package/lib/crypto/SecretSharing.d.ts +0 -24
- package/lib/crypto/SecretSharing.d.ts.map +0 -1
- package/lib/crypto/SecretSharing.js +0 -194
- package/lib/crypto/SecretSharing.js.map +0 -1
- package/lib/crypto/SecretStorage.d.ts +0 -55
- package/lib/crypto/SecretStorage.d.ts.map +0 -1
- package/lib/crypto/SecretStorage.js +0 -118
- package/lib/crypto/SecretStorage.js.map +0 -1
- package/lib/crypto/aes.d.ts +0 -6
- package/lib/crypto/aes.d.ts.map +0 -1
- package/lib/crypto/aes.js +0 -24
- package/lib/crypto/aes.js.map +0 -1
- package/lib/crypto/algorithms/base.d.ts +0 -156
- package/lib/crypto/algorithms/base.d.ts.map +0 -1
- package/lib/crypto/algorithms/base.js +0 -187
- package/lib/crypto/algorithms/base.js.map +0 -1
- package/lib/crypto/algorithms/index.d.ts +0 -4
- package/lib/crypto/algorithms/index.d.ts.map +0 -1
- package/lib/crypto/algorithms/index.js +0 -20
- package/lib/crypto/algorithms/index.js.map +0 -1
- package/lib/crypto/algorithms/megolm.d.ts +0 -385
- package/lib/crypto/algorithms/megolm.d.ts.map +0 -1
- package/lib/crypto/algorithms/megolm.js +0 -1822
- package/lib/crypto/algorithms/megolm.js.map +0 -1
- package/lib/crypto/algorithms/olm.d.ts +0 -5
- package/lib/crypto/algorithms/olm.d.ts.map +0 -1
- package/lib/crypto/algorithms/olm.js +0 -299
- package/lib/crypto/algorithms/olm.js.map +0 -1
- package/lib/crypto/api.d.ts +0 -32
- package/lib/crypto/api.d.ts.map +0 -1
- package/lib/crypto/api.js +0 -22
- package/lib/crypto/api.js.map +0 -1
- package/lib/crypto/backup.d.ts +0 -227
- package/lib/crypto/backup.d.ts.map +0 -1
- package/lib/crypto/backup.js +0 -824
- package/lib/crypto/backup.js.map +0 -1
- package/lib/crypto/crypto.d.ts +0 -3
- package/lib/crypto/crypto.d.ts.map +0 -1
- package/lib/crypto/crypto.js +0 -19
- package/lib/crypto/crypto.js.map +0 -1
- package/lib/crypto/dehydration.d.ts +0 -34
- package/lib/crypto/dehydration.d.ts.map +0 -1
- package/lib/crypto/dehydration.js +0 -252
- package/lib/crypto/dehydration.js.map +0 -1
- package/lib/crypto/device-converter.d.ts +0 -9
- package/lib/crypto/device-converter.d.ts.map +0 -1
- package/lib/crypto/device-converter.js +0 -42
- package/lib/crypto/device-converter.js.map +0 -1
- package/lib/crypto/deviceinfo.d.ts +0 -99
- package/lib/crypto/deviceinfo.d.ts.map +0 -1
- package/lib/crypto/deviceinfo.js +0 -148
- package/lib/crypto/deviceinfo.js.map +0 -1
- package/lib/crypto/index.d.ts +0 -1210
- package/lib/crypto/index.d.ts.map +0 -1
- package/lib/crypto/index.js +0 -4101
- package/lib/crypto/index.js.map +0 -1
- package/lib/crypto/key_passphrase.d.ts +0 -14
- package/lib/crypto/key_passphrase.d.ts.map +0 -1
- package/lib/crypto/key_passphrase.js +0 -44
- package/lib/crypto/key_passphrase.js.map +0 -1
- package/lib/crypto/keybackup.d.ts +0 -18
- package/lib/crypto/keybackup.d.ts.map +0 -1
- package/lib/crypto/keybackup.js +0 -1
- package/lib/crypto/keybackup.js.map +0 -1
- package/lib/crypto/olmlib.d.ts +0 -129
- package/lib/crypto/olmlib.d.ts.map +0 -1
- package/lib/crypto/olmlib.js +0 -492
- package/lib/crypto/olmlib.js.map +0 -1
- package/lib/crypto/recoverykey.d.ts +0 -2
- package/lib/crypto/recoverykey.d.ts.map +0 -1
- package/lib/crypto/recoverykey.js +0 -19
- package/lib/crypto/recoverykey.js.map +0 -1
- package/lib/crypto/store/base.d.ts +0 -252
- package/lib/crypto/store/base.d.ts.map +0 -1
- package/lib/crypto/store/base.js +0 -64
- package/lib/crypto/store/base.js.map +0 -1
- package/lib/crypto/store/indexeddb-crypto-store-backend.d.ts +0 -187
- package/lib/crypto/store/indexeddb-crypto-store-backend.d.ts.map +0 -1
- package/lib/crypto/store/indexeddb-crypto-store-backend.js +0 -1145
- package/lib/crypto/store/indexeddb-crypto-store-backend.js.map +0 -1
- package/lib/crypto/store/indexeddb-crypto-store.d.ts +0 -432
- package/lib/crypto/store/indexeddb-crypto-store.d.ts.map +0 -1
- package/lib/crypto/store/indexeddb-crypto-store.js +0 -728
- package/lib/crypto/store/indexeddb-crypto-store.js.map +0 -1
- package/lib/crypto/store/localStorage-crypto-store.d.ts +0 -119
- package/lib/crypto/store/localStorage-crypto-store.d.ts.map +0 -1
- package/lib/crypto/store/localStorage-crypto-store.js +0 -531
- package/lib/crypto/store/localStorage-crypto-store.js.map +0 -1
- package/lib/crypto/store/memory-crypto-store.d.ts +0 -215
- package/lib/crypto/store/memory-crypto-store.d.ts.map +0 -1
- package/lib/crypto/store/memory-crypto-store.js +0 -622
- package/lib/crypto/store/memory-crypto-store.js.map +0 -1
- package/lib/crypto/verification/Base.d.ts +0 -105
- package/lib/crypto/verification/Base.d.ts.map +0 -1
- package/lib/crypto/verification/Base.js +0 -372
- package/lib/crypto/verification/Base.js.map +0 -1
- package/lib/crypto/verification/Error.d.ts +0 -35
- package/lib/crypto/verification/Error.d.ts.map +0 -1
- package/lib/crypto/verification/Error.js +0 -86
- package/lib/crypto/verification/Error.js.map +0 -1
- package/lib/crypto/verification/IllegalMethod.d.ts +0 -15
- package/lib/crypto/verification/IllegalMethod.d.ts.map +0 -1
- package/lib/crypto/verification/IllegalMethod.js +0 -43
- package/lib/crypto/verification/IllegalMethod.js.map +0 -1
- package/lib/crypto/verification/QRCode.d.ts +0 -51
- package/lib/crypto/verification/QRCode.d.ts.map +0 -1
- package/lib/crypto/verification/QRCode.js +0 -277
- package/lib/crypto/verification/QRCode.js.map +0 -1
- package/lib/crypto/verification/SAS.d.ts +0 -27
- package/lib/crypto/verification/SAS.d.ts.map +0 -1
- package/lib/crypto/verification/SAS.js +0 -485
- package/lib/crypto/verification/SAS.js.map +0 -1
- package/lib/crypto/verification/SASDecimal.d.ts +0 -8
- package/lib/crypto/verification/SASDecimal.d.ts.map +0 -1
- package/lib/crypto/verification/SASDecimal.js +0 -34
- package/lib/crypto/verification/SASDecimal.js.map +0 -1
- package/lib/crypto/verification/request/Channel.d.ts +0 -18
- package/lib/crypto/verification/request/Channel.d.ts.map +0 -1
- package/lib/crypto/verification/request/Channel.js +0 -1
- package/lib/crypto/verification/request/Channel.js.map +0 -1
- package/lib/crypto/verification/request/InRoomChannel.d.ts +0 -113
- package/lib/crypto/verification/request/InRoomChannel.d.ts.map +0 -1
- package/lib/crypto/verification/request/InRoomChannel.js +0 -351
- package/lib/crypto/verification/request/InRoomChannel.js.map +0 -1
- package/lib/crypto/verification/request/ToDeviceChannel.d.ts +0 -105
- package/lib/crypto/verification/request/ToDeviceChannel.d.ts.map +0 -1
- package/lib/crypto/verification/request/ToDeviceChannel.js +0 -328
- package/lib/crypto/verification/request/ToDeviceChannel.js.map +0 -1
- package/lib/crypto/verification/request/VerificationRequest.d.ts +0 -227
- package/lib/crypto/verification/request/VerificationRequest.d.ts.map +0 -1
- package/lib/crypto/verification/request/VerificationRequest.js +0 -937
- package/lib/crypto/verification/request/VerificationRequest.js.map +0 -1
- package/lib/crypto-api/CryptoEvent.d.ts +0 -69
- package/lib/crypto-api/CryptoEvent.d.ts.map +0 -1
- package/lib/crypto-api/CryptoEvent.js +0 -33
- package/lib/crypto-api/CryptoEvent.js.map +0 -1
- package/lib/crypto-api/CryptoEventHandlerMap.d.ts +0 -16
- package/lib/crypto-api/CryptoEventHandlerMap.d.ts.map +0 -1
- package/lib/crypto-api/CryptoEventHandlerMap.js +0 -22
- package/lib/crypto-api/CryptoEventHandlerMap.js.map +0 -1
- package/lib/crypto-api/index.d.ts +0 -978
- package/lib/crypto-api/index.d.ts.map +0 -1
- package/lib/crypto-api/index.js +0 -304
- package/lib/crypto-api/index.js.map +0 -1
- package/lib/crypto-api/key-passphrase.d.ts +0 -11
- package/lib/crypto-api/key-passphrase.d.ts.map +0 -1
- package/lib/crypto-api/key-passphrase.js +0 -51
- package/lib/crypto-api/key-passphrase.js.map +0 -1
- package/lib/crypto-api/keybackup.d.ts +0 -88
- package/lib/crypto-api/keybackup.d.ts.map +0 -1
- package/lib/crypto-api/keybackup.js +0 -1
- package/lib/crypto-api/keybackup.js.map +0 -1
- package/lib/crypto-api/recovery-key.d.ts +0 -11
- package/lib/crypto-api/recovery-key.d.ts.map +0 -1
- package/lib/crypto-api/recovery-key.js +0 -65
- package/lib/crypto-api/recovery-key.js.map +0 -1
- package/lib/crypto-api/verification.d.ts +0 -344
- package/lib/crypto-api/verification.d.ts.map +0 -1
- package/lib/crypto-api/verification.js +0 -91
- package/lib/crypto-api/verification.js.map +0 -1
- package/lib/matrixrtc/CallMembership.d.ts +0 -66
- package/lib/matrixrtc/CallMembership.d.ts.map +0 -1
- package/lib/matrixrtc/CallMembership.js +0 -197
- package/lib/matrixrtc/CallMembership.js.map +0 -1
- package/lib/matrixrtc/LivekitFocus.d.ts +0 -16
- package/lib/matrixrtc/LivekitFocus.d.ts.map +0 -1
- package/lib/matrixrtc/LivekitFocus.js +0 -20
- package/lib/matrixrtc/LivekitFocus.js.map +0 -1
- package/lib/matrixrtc/MatrixRTCSession.d.ts +0 -295
- package/lib/matrixrtc/MatrixRTCSession.d.ts.map +0 -1
- package/lib/matrixrtc/MatrixRTCSession.js +0 -1043
- package/lib/matrixrtc/MatrixRTCSession.js.map +0 -1
- package/lib/matrixrtc/MatrixRTCSessionManager.d.ts +0 -40
- package/lib/matrixrtc/MatrixRTCSessionManager.d.ts.map +0 -1
- package/lib/matrixrtc/MatrixRTCSessionManager.js +0 -146
- package/lib/matrixrtc/MatrixRTCSessionManager.js.map +0 -1
- package/lib/matrixrtc/focus.d.ts +0 -10
- package/lib/matrixrtc/focus.d.ts.map +0 -1
- package/lib/matrixrtc/focus.js +0 -1
- package/lib/matrixrtc/focus.js.map +0 -1
- package/lib/matrixrtc/index.d.ts +0 -7
- package/lib/matrixrtc/index.d.ts.map +0 -1
- package/lib/matrixrtc/index.js +0 -21
- package/lib/matrixrtc/index.js.map +0 -1
- package/lib/matrixrtc/types.d.ts +0 -19
- package/lib/matrixrtc/types.d.ts.map +0 -1
- package/lib/matrixrtc/types.js +0 -1
- package/lib/matrixrtc/types.js.map +0 -1
- package/lib/rendezvous/MSC4108SignInWithQR.d.ts +0 -112
- package/lib/rendezvous/MSC4108SignInWithQR.d.ts.map +0 -1
- package/lib/rendezvous/MSC4108SignInWithQR.js +0 -392
- package/lib/rendezvous/MSC4108SignInWithQR.js.map +0 -1
- package/lib/rendezvous/RendezvousChannel.d.ts +0 -27
- package/lib/rendezvous/RendezvousChannel.d.ts.map +0 -1
- package/lib/rendezvous/RendezvousChannel.js +0 -1
- package/lib/rendezvous/RendezvousChannel.js.map +0 -1
- package/lib/rendezvous/RendezvousCode.d.ts +0 -9
- package/lib/rendezvous/RendezvousCode.d.ts.map +0 -1
- package/lib/rendezvous/RendezvousCode.js +0 -1
- package/lib/rendezvous/RendezvousCode.js.map +0 -1
- package/lib/rendezvous/RendezvousError.d.ts +0 -6
- package/lib/rendezvous/RendezvousError.d.ts.map +0 -1
- package/lib/rendezvous/RendezvousError.js +0 -23
- package/lib/rendezvous/RendezvousError.js.map +0 -1
- package/lib/rendezvous/RendezvousFailureReason.d.ts +0 -31
- package/lib/rendezvous/RendezvousFailureReason.d.ts.map +0 -1
- package/lib/rendezvous/RendezvousFailureReason.js +0 -38
- package/lib/rendezvous/RendezvousFailureReason.js.map +0 -1
- package/lib/rendezvous/RendezvousIntent.d.ts +0 -5
- package/lib/rendezvous/RendezvousIntent.d.ts.map +0 -1
- package/lib/rendezvous/RendezvousIntent.js +0 -22
- package/lib/rendezvous/RendezvousIntent.js.map +0 -1
- package/lib/rendezvous/RendezvousTransport.d.ts +0 -36
- package/lib/rendezvous/RendezvousTransport.d.ts.map +0 -1
- package/lib/rendezvous/RendezvousTransport.js +0 -1
- package/lib/rendezvous/RendezvousTransport.js.map +0 -1
- package/lib/rendezvous/channels/MSC4108SecureChannel.d.ts +0 -58
- package/lib/rendezvous/channels/MSC4108SecureChannel.d.ts.map +0 -1
- package/lib/rendezvous/channels/MSC4108SecureChannel.js +0 -246
- package/lib/rendezvous/channels/MSC4108SecureChannel.js.map +0 -1
- package/lib/rendezvous/channels/index.d.ts +0 -2
- package/lib/rendezvous/channels/index.d.ts.map +0 -1
- package/lib/rendezvous/channels/index.js +0 -18
- package/lib/rendezvous/channels/index.js.map +0 -1
- package/lib/rendezvous/index.d.ts +0 -10
- package/lib/rendezvous/index.d.ts.map +0 -1
- package/lib/rendezvous/index.js +0 -23
- package/lib/rendezvous/index.js.map +0 -1
- package/lib/rendezvous/transports/MSC4108RendezvousSession.d.ts +0 -61
- package/lib/rendezvous/transports/MSC4108RendezvousSession.d.ts.map +0 -1
- package/lib/rendezvous/transports/MSC4108RendezvousSession.js +0 -253
- package/lib/rendezvous/transports/MSC4108RendezvousSession.js.map +0 -1
- package/lib/rendezvous/transports/index.d.ts +0 -2
- package/lib/rendezvous/transports/index.d.ts.map +0 -1
- package/lib/rendezvous/transports/index.js +0 -18
- package/lib/rendezvous/transports/index.js.map +0 -1
- package/lib/rust-crypto/CrossSigningIdentity.d.ts +0 -33
- package/lib/rust-crypto/CrossSigningIdentity.d.ts.map +0 -1
- package/lib/rust-crypto/CrossSigningIdentity.js +0 -157
- package/lib/rust-crypto/CrossSigningIdentity.js.map +0 -1
- package/lib/rust-crypto/DehydratedDeviceManager.d.ts +0 -98
- package/lib/rust-crypto/DehydratedDeviceManager.d.ts.map +0 -1
- package/lib/rust-crypto/DehydratedDeviceManager.js +0 -285
- package/lib/rust-crypto/DehydratedDeviceManager.js.map +0 -1
- package/lib/rust-crypto/KeyClaimManager.d.ts +0 -33
- package/lib/rust-crypto/KeyClaimManager.d.ts.map +0 -1
- package/lib/rust-crypto/KeyClaimManager.js +0 -82
- package/lib/rust-crypto/KeyClaimManager.js.map +0 -1
- package/lib/rust-crypto/OutgoingRequestProcessor.d.ts +0 -43
- package/lib/rust-crypto/OutgoingRequestProcessor.d.ts.map +0 -1
- package/lib/rust-crypto/OutgoingRequestProcessor.js +0 -195
- package/lib/rust-crypto/OutgoingRequestProcessor.js.map +0 -1
- package/lib/rust-crypto/OutgoingRequestsManager.d.ts +0 -47
- package/lib/rust-crypto/OutgoingRequestsManager.d.ts.map +0 -1
- package/lib/rust-crypto/OutgoingRequestsManager.js +0 -148
- package/lib/rust-crypto/OutgoingRequestsManager.js.map +0 -1
- package/lib/rust-crypto/PerSessionKeyBackupDownloader.d.ts +0 -120
- package/lib/rust-crypto/PerSessionKeyBackupDownloader.d.ts.map +0 -1
- package/lib/rust-crypto/PerSessionKeyBackupDownloader.js +0 -467
- package/lib/rust-crypto/PerSessionKeyBackupDownloader.js.map +0 -1
- package/lib/rust-crypto/RoomEncryptor.d.ts +0 -98
- package/lib/rust-crypto/RoomEncryptor.d.ts.map +0 -1
- package/lib/rust-crypto/RoomEncryptor.js +0 -299
- package/lib/rust-crypto/RoomEncryptor.js.map +0 -1
- package/lib/rust-crypto/backup.d.ts +0 -254
- package/lib/rust-crypto/backup.d.ts.map +0 -1
- package/lib/rust-crypto/backup.js +0 -837
- package/lib/rust-crypto/backup.js.map +0 -1
- package/lib/rust-crypto/constants.d.ts +0 -3
- package/lib/rust-crypto/constants.d.ts.map +0 -1
- package/lib/rust-crypto/constants.js +0 -19
- package/lib/rust-crypto/constants.js.map +0 -1
- package/lib/rust-crypto/device-converter.d.ts +0 -28
- package/lib/rust-crypto/device-converter.d.ts.map +0 -1
- package/lib/rust-crypto/device-converter.js +0 -123
- package/lib/rust-crypto/device-converter.js.map +0 -1
- package/lib/rust-crypto/index.d.ts +0 -61
- package/lib/rust-crypto/index.d.ts.map +0 -1
- package/lib/rust-crypto/index.js +0 -152
- package/lib/rust-crypto/index.js.map +0 -1
- package/lib/rust-crypto/libolm_migration.d.ts +0 -81
- package/lib/rust-crypto/libolm_migration.d.ts.map +0 -1
- package/lib/rust-crypto/libolm_migration.js +0 -459
- package/lib/rust-crypto/libolm_migration.js.map +0 -1
- package/lib/rust-crypto/rust-crypto.d.ts +0 -556
- package/lib/rust-crypto/rust-crypto.d.ts.map +0 -1
- package/lib/rust-crypto/rust-crypto.js +0 -2016
- package/lib/rust-crypto/rust-crypto.js.map +0 -1
- package/lib/rust-crypto/secret-storage.d.ts +0 -22
- package/lib/rust-crypto/secret-storage.d.ts.map +0 -1
- package/lib/rust-crypto/secret-storage.js +0 -63
- package/lib/rust-crypto/secret-storage.js.map +0 -1
- package/lib/rust-crypto/verification.d.ts +0 -319
- package/lib/rust-crypto/verification.d.ts.map +0 -1
- package/lib/rust-crypto/verification.js +0 -816
- package/lib/rust-crypto/verification.js.map +0 -1
- package/lib/secret-storage.d.ts +0 -370
- package/lib/secret-storage.d.ts.map +0 -1
- package/lib/secret-storage.js +0 -466
- package/lib/secret-storage.js.map +0 -1
- package/lib/utils/decryptAESSecretStorageItem.d.ts +0 -12
- package/lib/utils/decryptAESSecretStorageItem.d.ts.map +0 -1
- package/lib/utils/decryptAESSecretStorageItem.js +0 -50
- package/lib/utils/decryptAESSecretStorageItem.js.map +0 -1
- package/lib/utils/encryptAESSecretStorageItem.d.ts +0 -16
- package/lib/utils/encryptAESSecretStorageItem.d.ts.map +0 -1
- package/lib/utils/encryptAESSecretStorageItem.js +0 -68
- package/lib/utils/encryptAESSecretStorageItem.js.map +0 -1
- package/lib/utils/internal/deriveKeys.d.ts +0 -10
- package/lib/utils/internal/deriveKeys.d.ts.map +0 -1
- package/lib/utils/internal/deriveKeys.js +0 -60
- package/lib/utils/internal/deriveKeys.js.map +0 -1
- package/lib/webrtc/audioContext.d.ts +0 -15
- package/lib/webrtc/audioContext.d.ts.map +0 -1
- package/lib/webrtc/audioContext.js +0 -46
- package/lib/webrtc/audioContext.js.map +0 -1
- package/lib/webrtc/call.d.ts +0 -560
- package/lib/webrtc/call.d.ts.map +0 -1
- package/lib/webrtc/call.js +0 -2541
- package/lib/webrtc/call.js.map +0 -1
- package/lib/webrtc/callEventHandler.d.ts +0 -37
- package/lib/webrtc/callEventHandler.d.ts.map +0 -1
- package/lib/webrtc/callEventHandler.js +0 -344
- package/lib/webrtc/callEventHandler.js.map +0 -1
- package/lib/webrtc/callEventTypes.d.ts +0 -73
- package/lib/webrtc/callEventTypes.d.ts.map +0 -1
- package/lib/webrtc/callEventTypes.js +0 -13
- package/lib/webrtc/callEventTypes.js.map +0 -1
- package/lib/webrtc/callFeed.d.ts +0 -128
- package/lib/webrtc/callFeed.d.ts.map +0 -1
- package/lib/webrtc/callFeed.js +0 -289
- package/lib/webrtc/callFeed.js.map +0 -1
- package/lib/webrtc/groupCall.d.ts +0 -323
- package/lib/webrtc/groupCall.d.ts.map +0 -1
- package/lib/webrtc/groupCall.js +0 -1337
- package/lib/webrtc/groupCall.js.map +0 -1
- package/lib/webrtc/groupCallEventHandler.d.ts +0 -31
- package/lib/webrtc/groupCallEventHandler.d.ts.map +0 -1
- package/lib/webrtc/groupCallEventHandler.js +0 -178
- package/lib/webrtc/groupCallEventHandler.js.map +0 -1
- package/lib/webrtc/mediaHandler.d.ts +0 -89
- package/lib/webrtc/mediaHandler.d.ts.map +0 -1
- package/lib/webrtc/mediaHandler.js +0 -437
- package/lib/webrtc/mediaHandler.js.map +0 -1
- package/lib/webrtc/stats/callFeedStatsReporter.d.ts +0 -8
- package/lib/webrtc/stats/callFeedStatsReporter.d.ts.map +0 -1
- package/lib/webrtc/stats/callFeedStatsReporter.js +0 -82
- package/lib/webrtc/stats/callFeedStatsReporter.js.map +0 -1
- package/lib/webrtc/stats/callStatsReportGatherer.d.ts +0 -25
- package/lib/webrtc/stats/callStatsReportGatherer.d.ts.map +0 -1
- package/lib/webrtc/stats/callStatsReportGatherer.js +0 -199
- package/lib/webrtc/stats/callStatsReportGatherer.js.map +0 -1
- package/lib/webrtc/stats/callStatsReportSummary.d.ts +0 -17
- package/lib/webrtc/stats/callStatsReportSummary.d.ts.map +0 -1
- package/lib/webrtc/stats/callStatsReportSummary.js +0 -1
- package/lib/webrtc/stats/callStatsReportSummary.js.map +0 -1
- package/lib/webrtc/stats/connectionStats.d.ts +0 -28
- package/lib/webrtc/stats/connectionStats.d.ts.map +0 -1
- package/lib/webrtc/stats/connectionStats.js +0 -26
- package/lib/webrtc/stats/connectionStats.js.map +0 -1
- package/lib/webrtc/stats/connectionStatsBuilder.d.ts +0 -5
- package/lib/webrtc/stats/connectionStatsBuilder.d.ts.map +0 -1
- package/lib/webrtc/stats/connectionStatsBuilder.js +0 -27
- package/lib/webrtc/stats/connectionStatsBuilder.js.map +0 -1
- package/lib/webrtc/stats/connectionStatsReportBuilder.d.ts +0 -7
- package/lib/webrtc/stats/connectionStatsReportBuilder.d.ts.map +0 -1
- package/lib/webrtc/stats/connectionStatsReportBuilder.js +0 -121
- package/lib/webrtc/stats/connectionStatsReportBuilder.js.map +0 -1
- package/lib/webrtc/stats/groupCallStats.d.ts +0 -22
- package/lib/webrtc/stats/groupCallStats.d.ts.map +0 -1
- package/lib/webrtc/stats/groupCallStats.js +0 -78
- package/lib/webrtc/stats/groupCallStats.js.map +0 -1
- package/lib/webrtc/stats/media/mediaSsrcHandler.d.ts +0 -10
- package/lib/webrtc/stats/media/mediaSsrcHandler.d.ts.map +0 -1
- package/lib/webrtc/stats/media/mediaSsrcHandler.js +0 -57
- package/lib/webrtc/stats/media/mediaSsrcHandler.js.map +0 -1
- package/lib/webrtc/stats/media/mediaTrackHandler.d.ts +0 -12
- package/lib/webrtc/stats/media/mediaTrackHandler.d.ts.map +0 -1
- package/lib/webrtc/stats/media/mediaTrackHandler.js +0 -62
- package/lib/webrtc/stats/media/mediaTrackHandler.js.map +0 -1
- package/lib/webrtc/stats/media/mediaTrackStats.d.ts +0 -86
- package/lib/webrtc/stats/media/mediaTrackStats.d.ts.map +0 -1
- package/lib/webrtc/stats/media/mediaTrackStats.js +0 -142
- package/lib/webrtc/stats/media/mediaTrackStats.js.map +0 -1
- package/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts +0 -22
- package/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts.map +0 -1
- package/lib/webrtc/stats/media/mediaTrackStatsHandler.js +0 -76
- package/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map +0 -1
- package/lib/webrtc/stats/statsReport.d.ts +0 -99
- package/lib/webrtc/stats/statsReport.d.ts.map +0 -1
- package/lib/webrtc/stats/statsReport.js +0 -32
- package/lib/webrtc/stats/statsReport.js.map +0 -1
- package/lib/webrtc/stats/statsReportEmitter.d.ts +0 -15
- package/lib/webrtc/stats/statsReportEmitter.d.ts.map +0 -1
- package/lib/webrtc/stats/statsReportEmitter.js +0 -33
- package/lib/webrtc/stats/statsReportEmitter.js.map +0 -1
- package/lib/webrtc/stats/summaryStatsReportGatherer.d.ts +0 -16
- package/lib/webrtc/stats/summaryStatsReportGatherer.d.ts.map +0 -1
- package/lib/webrtc/stats/summaryStatsReportGatherer.js +0 -116
- package/lib/webrtc/stats/summaryStatsReportGatherer.js.map +0 -1
- package/lib/webrtc/stats/trackStatsBuilder.d.ts +0 -19
- package/lib/webrtc/stats/trackStatsBuilder.d.ts.map +0 -1
- package/lib/webrtc/stats/trackStatsBuilder.js +0 -168
- package/lib/webrtc/stats/trackStatsBuilder.js.map +0 -1
- package/lib/webrtc/stats/transportStats.d.ts +0 -11
- package/lib/webrtc/stats/transportStats.d.ts.map +0 -1
- package/lib/webrtc/stats/transportStats.js +0 -1
- package/lib/webrtc/stats/transportStats.js.map +0 -1
- package/lib/webrtc/stats/transportStatsBuilder.d.ts +0 -5
- package/lib/webrtc/stats/transportStatsBuilder.d.ts.map +0 -1
- package/lib/webrtc/stats/transportStatsBuilder.js +0 -34
- package/lib/webrtc/stats/transportStatsBuilder.js.map +0 -1
- package/lib/webrtc/stats/valueFormatter.d.ts +0 -4
- package/lib/webrtc/stats/valueFormatter.d.ts.map +0 -1
- package/lib/webrtc/stats/valueFormatter.js +0 -25
- package/lib/webrtc/stats/valueFormatter.js.map +0 -1
- package/src/@types/AESEncryptedSecretStoragePayload.ts +0 -29
- package/src/@types/crypto.ts +0 -73
- package/src/@types/matrix-sdk-crypto-wasm.d.ts +0 -44
- package/src/common-crypto/CryptoBackend.ts +0 -302
- package/src/common-crypto/README.md +0 -4
- package/src/common-crypto/key-passphrase.ts +0 -43
- package/src/crypto/CrossSigning.ts +0 -773
- package/src/crypto/DeviceList.ts +0 -989
- package/src/crypto/EncryptionSetup.ts +0 -351
- package/src/crypto/OlmDevice.ts +0 -1500
- package/src/crypto/OutgoingRoomKeyRequestManager.ts +0 -485
- package/src/crypto/RoomList.ts +0 -70
- package/src/crypto/SecretSharing.ts +0 -240
- package/src/crypto/SecretStorage.ts +0 -136
- package/src/crypto/aes.ts +0 -23
- package/src/crypto/algorithms/base.ts +0 -236
- package/src/crypto/algorithms/index.ts +0 -20
- package/src/crypto/algorithms/megolm.ts +0 -2216
- package/src/crypto/algorithms/olm.ts +0 -381
- package/src/crypto/api.ts +0 -70
- package/src/crypto/backup.ts +0 -922
- package/src/crypto/crypto.ts +0 -18
- package/src/crypto/dehydration.ts +0 -272
- package/src/crypto/device-converter.ts +0 -45
- package/src/crypto/deviceinfo.ts +0 -158
- package/src/crypto/index.ts +0 -4418
- package/src/crypto/key_passphrase.ts +0 -42
- package/src/crypto/keybackup.ts +0 -47
- package/src/crypto/olmlib.ts +0 -539
- package/src/crypto/recoverykey.ts +0 -18
- package/src/crypto/store/base.ts +0 -348
- package/src/crypto/store/indexeddb-crypto-store-backend.ts +0 -1250
- package/src/crypto/store/indexeddb-crypto-store.ts +0 -845
- package/src/crypto/store/localStorage-crypto-store.ts +0 -579
- package/src/crypto/store/memory-crypto-store.ts +0 -680
- package/src/crypto/verification/Base.ts +0 -409
- package/src/crypto/verification/Error.ts +0 -76
- package/src/crypto/verification/IllegalMethod.ts +0 -50
- package/src/crypto/verification/QRCode.ts +0 -310
- package/src/crypto/verification/SAS.ts +0 -494
- package/src/crypto/verification/SASDecimal.ts +0 -37
- package/src/crypto/verification/request/Channel.ts +0 -34
- package/src/crypto/verification/request/InRoomChannel.ts +0 -371
- package/src/crypto/verification/request/ToDeviceChannel.ts +0 -354
- package/src/crypto/verification/request/VerificationRequest.ts +0 -976
- package/src/crypto-api/CryptoEvent.ts +0 -93
- package/src/crypto-api/CryptoEventHandlerMap.ts +0 -32
- package/src/crypto-api/index.ts +0 -1175
- package/src/crypto-api/key-passphrase.ts +0 -58
- package/src/crypto-api/keybackup.ts +0 -115
- package/src/crypto-api/recovery-key.ts +0 -69
- package/src/crypto-api/verification.ts +0 -408
- package/src/matrixrtc/CallMembership.ts +0 -247
- package/src/matrixrtc/LivekitFocus.ts +0 -39
- package/src/matrixrtc/MatrixRTCSession.ts +0 -1319
- package/src/matrixrtc/MatrixRTCSessionManager.ts +0 -166
- package/src/matrixrtc/focus.ts +0 -25
- package/src/matrixrtc/index.ts +0 -22
- package/src/matrixrtc/types.ts +0 -36
- package/src/rendezvous/MSC4108SignInWithQR.ts +0 -444
- package/src/rendezvous/RendezvousChannel.ts +0 -48
- package/src/rendezvous/RendezvousCode.ts +0 -25
- package/src/rendezvous/RendezvousError.ts +0 -26
- package/src/rendezvous/RendezvousFailureReason.ts +0 -49
- package/src/rendezvous/RendezvousIntent.ts +0 -20
- package/src/rendezvous/RendezvousTransport.ts +0 -58
- package/src/rendezvous/channels/MSC4108SecureChannel.ts +0 -270
- package/src/rendezvous/channels/index.ts +0 -17
- package/src/rendezvous/index.ts +0 -25
- package/src/rendezvous/transports/MSC4108RendezvousSession.ts +0 -270
- package/src/rendezvous/transports/index.ts +0 -17
- package/src/rust-crypto/CrossSigningIdentity.ts +0 -183
- package/src/rust-crypto/DehydratedDeviceManager.ts +0 -306
- package/src/rust-crypto/KeyClaimManager.ts +0 -86
- package/src/rust-crypto/OutgoingRequestProcessor.ts +0 -236
- package/src/rust-crypto/OutgoingRequestsManager.ts +0 -143
- package/src/rust-crypto/PerSessionKeyBackupDownloader.ts +0 -501
- package/src/rust-crypto/RoomEncryptor.ts +0 -352
- package/src/rust-crypto/backup.ts +0 -881
- package/src/rust-crypto/constants.ts +0 -18
- package/src/rust-crypto/device-converter.ts +0 -128
- package/src/rust-crypto/index.ts +0 -237
- package/src/rust-crypto/libolm_migration.ts +0 -530
- package/src/rust-crypto/rust-crypto.ts +0 -2205
- package/src/rust-crypto/secret-storage.ts +0 -60
- package/src/rust-crypto/verification.ts +0 -830
- package/src/secret-storage.ts +0 -693
- package/src/utils/decryptAESSecretStorageItem.ts +0 -54
- package/src/utils/encryptAESSecretStorageItem.ts +0 -73
- package/src/utils/internal/deriveKeys.ts +0 -63
- package/src/webrtc/audioContext.ts +0 -44
- package/src/webrtc/call.ts +0 -3074
- package/src/webrtc/callEventHandler.ts +0 -425
- package/src/webrtc/callEventTypes.ts +0 -93
- package/src/webrtc/callFeed.ts +0 -364
- package/src/webrtc/groupCall.ts +0 -1735
- package/src/webrtc/groupCallEventHandler.ts +0 -234
- package/src/webrtc/mediaHandler.ts +0 -484
- package/src/webrtc/stats/callFeedStatsReporter.ts +0 -94
- package/src/webrtc/stats/callStatsReportGatherer.ts +0 -219
- package/src/webrtc/stats/callStatsReportSummary.ts +0 -30
- package/src/webrtc/stats/connectionStats.ts +0 -47
- package/src/webrtc/stats/connectionStatsBuilder.ts +0 -28
- package/src/webrtc/stats/connectionStatsReportBuilder.ts +0 -140
- package/src/webrtc/stats/groupCallStats.ts +0 -93
- package/src/webrtc/stats/media/mediaSsrcHandler.ts +0 -57
- package/src/webrtc/stats/media/mediaTrackHandler.ts +0 -76
- package/src/webrtc/stats/media/mediaTrackStats.ts +0 -176
- package/src/webrtc/stats/media/mediaTrackStatsHandler.ts +0 -90
- package/src/webrtc/stats/statsReport.ts +0 -133
- package/src/webrtc/stats/statsReportEmitter.ts +0 -49
- package/src/webrtc/stats/summaryStatsReportGatherer.ts +0 -148
- package/src/webrtc/stats/trackStatsBuilder.ts +0 -207
- package/src/webrtc/stats/transportStats.ts +0 -26
- package/src/webrtc/stats/transportStatsBuilder.ts +0 -48
- package/src/webrtc/stats/valueFormatter.ts +0 -27
package/lib/models/room.js
CHANGED
@@ -250,11 +250,13 @@ export class Room extends ReadReceipt {
|
|
250
250
|
timelineSet.addLiveEvent(thread.rootEvent, {
|
251
251
|
duplicateStrategy: DuplicateStrategy.Replace,
|
252
252
|
fromCache: false,
|
253
|
-
roomState: this.currentState
|
253
|
+
roomState: this.currentState,
|
254
|
+
addToState: false
|
254
255
|
});
|
255
256
|
} else {
|
256
257
|
timelineSet.addEventToTimeline(thread.rootEvent, timelineSet.getLiveTimeline(), {
|
257
|
-
toStartOfTimeline
|
258
|
+
toStartOfTimeline,
|
259
|
+
addToState: false
|
258
260
|
});
|
259
261
|
}
|
260
262
|
}
|
@@ -327,7 +329,6 @@ export class Room extends ReadReceipt {
|
|
327
329
|
events.forEach(/*#__PURE__*/function () {
|
328
330
|
var _ref = _asyncToGenerator(function* (serializedEvent) {
|
329
331
|
var event = mapper(serializedEvent);
|
330
|
-
yield client.decryptEventIfNeeded(event);
|
331
332
|
event.setStatus(EventStatus.NOT_SENT);
|
332
333
|
_this.addPendingEvent(event, event.getTxnId());
|
333
334
|
});
|
@@ -368,46 +369,6 @@ export class Room extends ReadReceipt {
|
|
368
369
|
})();
|
369
370
|
}
|
370
371
|
|
371
|
-
/**
|
372
|
-
* Bulk decrypt critical events in a room
|
373
|
-
*
|
374
|
-
* Critical events represents the minimal set of events to decrypt
|
375
|
-
* for a typical UI to function properly
|
376
|
-
*
|
377
|
-
* - Last event of every room (to generate likely message preview)
|
378
|
-
* - All events up to the read receipt (to calculate an accurate notification count)
|
379
|
-
*
|
380
|
-
* @returns Signals when all events have been decrypted
|
381
|
-
*/
|
382
|
-
decryptCriticalEvents() {
|
383
|
-
var _this3 = this;
|
384
|
-
return _asyncToGenerator(function* () {
|
385
|
-
if (!_this3.client.isCryptoEnabled()) return;
|
386
|
-
var readReceiptEventId = _this3.getEventReadUpTo(_this3.client.getUserId(), true);
|
387
|
-
var events = _this3.getLiveTimeline().getEvents();
|
388
|
-
var readReceiptTimelineIndex = events.findIndex(matrixEvent => {
|
389
|
-
return matrixEvent.event.event_id === readReceiptEventId;
|
390
|
-
});
|
391
|
-
var decryptionPromises = events.slice(readReceiptTimelineIndex).reverse().map(event => _this3.client.decryptEventIfNeeded(event));
|
392
|
-
yield Promise.allSettled(decryptionPromises);
|
393
|
-
})();
|
394
|
-
}
|
395
|
-
|
396
|
-
/**
|
397
|
-
* Bulk decrypt events in a room
|
398
|
-
*
|
399
|
-
* @returns Signals when all events have been decrypted
|
400
|
-
*/
|
401
|
-
decryptAllEvents() {
|
402
|
-
var _this4 = this;
|
403
|
-
return _asyncToGenerator(function* () {
|
404
|
-
if (!_this4.client.isCryptoEnabled()) return;
|
405
|
-
var decryptionPromises = _this4.getUnfilteredTimelineSet().getLiveTimeline().getEvents().slice(0) // copy before reversing
|
406
|
-
.reverse().map(event => _this4.client.decryptEventIfNeeded(event));
|
407
|
-
yield Promise.allSettled(decryptionPromises);
|
408
|
-
})();
|
409
|
-
}
|
410
|
-
|
411
372
|
/**
|
412
373
|
* Gets the creator of the room
|
413
374
|
* @returns The creator of the room, or null if it could not be determined
|
@@ -447,11 +408,11 @@ export class Room extends ReadReceipt {
|
|
447
408
|
* Resolves to the version the room should be upgraded to.
|
448
409
|
*/
|
449
410
|
getRecommendedVersion() {
|
450
|
-
var
|
411
|
+
var _this3 = this;
|
451
412
|
return _asyncToGenerator(function* () {
|
452
413
|
var capabilities = {};
|
453
414
|
try {
|
454
|
-
capabilities = yield
|
415
|
+
capabilities = yield _this3.client.getCapabilities();
|
455
416
|
} catch (_unused2) {}
|
456
417
|
var versionCap = capabilities["m.room_versions"];
|
457
418
|
if (!versionCap) {
|
@@ -463,7 +424,7 @@ export class Room extends ReadReceipt {
|
|
463
424
|
versionCap.available[safeVer] = RoomVersionStability.Stable;
|
464
425
|
}
|
465
426
|
}
|
466
|
-
var result =
|
427
|
+
var result = _this3.checkVersionAgainstCapability(versionCap);
|
467
428
|
if (result.urgent && result.needsUpgrade) {
|
468
429
|
// Something doesn't feel right: we shouldn't need to update
|
469
430
|
// because the version we're on should be in the protocol's
|
@@ -473,7 +434,7 @@ export class Room extends ReadReceipt {
|
|
473
434
|
// the capability we're using to determine this.
|
474
435
|
logger.warn("Refreshing room version capability because the server looks " + "to be supporting a newer room version we don't know about.");
|
475
436
|
try {
|
476
|
-
capabilities = yield
|
437
|
+
capabilities = yield _this3.client.fetchCapabilities();
|
477
438
|
} catch (e) {
|
478
439
|
logger.warn("Failed to refresh room version capabilities", e);
|
479
440
|
}
|
@@ -482,7 +443,7 @@ export class Room extends ReadReceipt {
|
|
482
443
|
logger.warn("No room version capability - assuming upgrade required.");
|
483
444
|
return result;
|
484
445
|
} else {
|
485
|
-
result =
|
446
|
+
result = _this3.checkVersionAgainstCapability(versionCap);
|
486
447
|
}
|
487
448
|
}
|
488
449
|
return result;
|
@@ -799,30 +760,30 @@ export class Room extends ReadReceipt {
|
|
799
760
|
}
|
800
761
|
}
|
801
762
|
loadMembersFromServer() {
|
802
|
-
var
|
763
|
+
var _this4 = this;
|
803
764
|
return _asyncToGenerator(function* () {
|
804
|
-
var lastSyncToken =
|
805
|
-
var response = yield
|
765
|
+
var lastSyncToken = _this4.client.store.getSyncToken();
|
766
|
+
var response = yield _this4.client.members(_this4.roomId, undefined, KnownMembership.Leave, lastSyncToken !== null && lastSyncToken !== void 0 ? lastSyncToken : undefined);
|
806
767
|
return response.chunk;
|
807
768
|
})();
|
808
769
|
}
|
809
770
|
loadMembers() {
|
810
|
-
var
|
771
|
+
var _this5 = this;
|
811
772
|
return _asyncToGenerator(function* () {
|
812
773
|
// were the members loaded from the server?
|
813
774
|
var fromServer = false;
|
814
|
-
var rawMembersEvents = yield
|
775
|
+
var rawMembersEvents = yield _this5.client.store.getOutOfBandMembers(_this5.roomId);
|
815
776
|
// If the room is encrypted, we always fetch members from the server at
|
816
777
|
// least once, in case the latest state wasn't persisted properly. Note
|
817
778
|
// that this function is only called once (unless loading the members
|
818
779
|
// fails), since loadMembersIfNeeded always returns this.membersPromise
|
819
780
|
// if set, which will be the result of the first (successful) call.
|
820
|
-
if (rawMembersEvents === null ||
|
781
|
+
if (rawMembersEvents === null || _this5.hasEncryptionStateEvent()) {
|
821
782
|
fromServer = true;
|
822
|
-
rawMembersEvents = yield
|
823
|
-
logger.log("LL: got ".concat(rawMembersEvents.length, " ") + "members from server for room ".concat(
|
783
|
+
rawMembersEvents = yield _this5.loadMembersFromServer();
|
784
|
+
logger.log("LL: got ".concat(rawMembersEvents.length, " ") + "members from server for room ".concat(_this5.roomId));
|
824
785
|
}
|
825
|
-
var memberEvents = rawMembersEvents.filter(noUnsafeEventProps).map(
|
786
|
+
var memberEvents = rawMembersEvents.filter(noUnsafeEventProps).map(_this5.client.getEventMapper());
|
826
787
|
return {
|
827
788
|
memberEvents,
|
828
789
|
fromServer
|
@@ -898,13 +859,13 @@ export class Room extends ReadReceipt {
|
|
898
859
|
* Removes the lazily loaded members from storage if needed
|
899
860
|
*/
|
900
861
|
clearLoadedMembersIfNeeded() {
|
901
|
-
var
|
862
|
+
var _this6 = this;
|
902
863
|
return _asyncToGenerator(function* () {
|
903
|
-
if (
|
904
|
-
yield
|
905
|
-
yield
|
906
|
-
|
907
|
-
|
864
|
+
if (_this6.opts.lazyLoadMembers && _this6.membersPromise) {
|
865
|
+
yield _this6.loadMembersIfNeeded();
|
866
|
+
yield _this6.client.store.clearOutOfBandMembers(_this6.roomId);
|
867
|
+
_this6.currentState.clearOutOfBandMembers();
|
868
|
+
_this6.membersPromise = undefined;
|
908
869
|
}
|
909
870
|
})();
|
910
871
|
}
|
@@ -934,17 +895,17 @@ export class Room extends ReadReceipt {
|
|
934
895
|
* `room.getTimelineNeedsRefresh()`.
|
935
896
|
*/
|
936
897
|
refreshLiveTimeline() {
|
937
|
-
var
|
898
|
+
var _this7 = this;
|
938
899
|
return _asyncToGenerator(function* () {
|
939
|
-
var liveTimelineBefore =
|
900
|
+
var liveTimelineBefore = _this7.getLiveTimeline();
|
940
901
|
var forwardPaginationToken = liveTimelineBefore.getPaginationToken(EventTimeline.FORWARDS);
|
941
902
|
var backwardPaginationToken = liveTimelineBefore.getPaginationToken(EventTimeline.BACKWARDS);
|
942
903
|
var eventsBefore = liveTimelineBefore.getEvents();
|
943
904
|
var mostRecentEventInTimeline = eventsBefore[eventsBefore.length - 1];
|
944
|
-
logger.log("[refreshLiveTimeline for ".concat(
|
905
|
+
logger.log("[refreshLiveTimeline for ".concat(_this7.roomId, "] at ") + "mostRecentEventInTimeline=".concat(mostRecentEventInTimeline && mostRecentEventInTimeline.getId(), " ") + "liveTimelineBefore=".concat(liveTimelineBefore.toString(), " ") + "forwardPaginationToken=".concat(forwardPaginationToken, " ") + "backwardPaginationToken=".concat(backwardPaginationToken));
|
945
906
|
|
946
907
|
// Get the main TimelineSet
|
947
|
-
var timelineSet =
|
908
|
+
var timelineSet = _this7.getUnfilteredTimelineSet();
|
948
909
|
var newTimeline;
|
949
910
|
// If there isn't any event in the timeline, let's go fetch the latest
|
950
911
|
// event and construct a timeline from it.
|
@@ -953,7 +914,7 @@ export class Room extends ReadReceipt {
|
|
953
914
|
// with refreshing the timeline before which left them in a blank
|
954
915
|
// timeline from `resetLiveTimeline`.
|
955
916
|
if (!mostRecentEventInTimeline) {
|
956
|
-
newTimeline = yield
|
917
|
+
newTimeline = yield _this7.client.getLatestTimeline(timelineSet);
|
957
918
|
} else {
|
958
919
|
// Empty out all of `this.timelineSets`. But we also need to keep the
|
959
920
|
// same `timelineSet` references around so the React code updates
|
@@ -962,21 +923,21 @@ export class Room extends ReadReceipt {
|
|
962
923
|
// `timelineSet` empty so that the `client.getEventTimeline(...)` call
|
963
924
|
// later, will call `/context` and create a new timeline instead of
|
964
925
|
// returning the same one.
|
965
|
-
|
926
|
+
_this7.resetLiveTimeline(null, null);
|
966
927
|
|
967
928
|
// Make the UI timeline show the new blank live timeline we just
|
968
929
|
// reset so that if the network fails below it's showing the
|
969
930
|
// accurate state of what we're working with instead of the
|
970
931
|
// disconnected one in the TimelineWindow which is just hanging
|
971
932
|
// around by reference.
|
972
|
-
|
933
|
+
_this7.emit(RoomEvent.TimelineRefresh, _this7, timelineSet);
|
973
934
|
|
974
935
|
// Use `client.getEventTimeline(...)` to construct a new timeline from a
|
975
936
|
// `/context` response state and events for the most recent event before
|
976
937
|
// we reset everything. The `timelineSet` we pass in needs to be empty
|
977
938
|
// in order for this function to call `/context` and generate a new
|
978
939
|
// timeline.
|
979
|
-
newTimeline = yield
|
940
|
+
newTimeline = yield _this7.client.getEventTimeline(timelineSet, mostRecentEventInTimeline.getId());
|
980
941
|
}
|
981
942
|
|
982
943
|
// If a racing `/sync` beat us to creating a new timeline, use that
|
@@ -984,7 +945,7 @@ export class Room extends ReadReceipt {
|
|
984
945
|
// the scrollback will include the history.
|
985
946
|
var liveTimeline = timelineSet.getLiveTimeline();
|
986
947
|
if (!liveTimeline || liveTimeline.getPaginationToken(Direction.Forward) === null && liveTimeline.getPaginationToken(Direction.Backward) === null && liveTimeline.getEvents().length === 0) {
|
987
|
-
logger.log("[refreshLiveTimeline for ".concat(
|
948
|
+
logger.log("[refreshLiveTimeline for ".concat(_this7.roomId, "] using our new live timeline"));
|
988
949
|
// Set the pagination token back to the live sync token (`null`) instead
|
989
950
|
// of using the `/context` historical token (ex. `t12-13_0_0_0_0_0_0_0_0`)
|
990
951
|
// so that it matches the next response from `/sync` and we can properly
|
@@ -996,17 +957,17 @@ export class Room extends ReadReceipt {
|
|
996
957
|
timelineSet.setLiveTimeline(newTimeline);
|
997
958
|
// Fixup `this.oldstate` so that `scrollback` has the pagination tokens
|
998
959
|
// available
|
999
|
-
|
960
|
+
_this7.fixUpLegacyTimelineFields();
|
1000
961
|
} else {
|
1001
|
-
logger.log("[refreshLiveTimeline for ".concat(
|
962
|
+
logger.log("[refreshLiveTimeline for ".concat(_this7.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.");
|
1002
963
|
}
|
1003
964
|
|
1004
965
|
// The timeline has now been refreshed ✅
|
1005
|
-
|
966
|
+
_this7.setTimelineNeedsRefresh(false);
|
1006
967
|
|
1007
968
|
// Emit an event which clients can react to and re-load the timeline
|
1008
969
|
// from the SDK
|
1009
|
-
|
970
|
+
_this7.emit(RoomEvent.TimelineRefresh, _this7, timelineSet);
|
1010
971
|
})();
|
1011
972
|
}
|
1012
973
|
|
@@ -1478,8 +1439,8 @@ export class Room extends ReadReceipt {
|
|
1478
1439
|
* @remarks
|
1479
1440
|
* Fires {@link RoomEvent.Timeline}
|
1480
1441
|
*/
|
1481
|
-
addEventsToTimeline(events, toStartOfTimeline, timeline, paginationToken) {
|
1482
|
-
timeline.getTimelineSet().addEventsToTimeline(events, toStartOfTimeline, timeline, paginationToken);
|
1442
|
+
addEventsToTimeline(events, toStartOfTimeline, addToState, timeline, paginationToken) {
|
1443
|
+
timeline.getTimelineSet().addEventsToTimeline(events, toStartOfTimeline, addToState, timeline, paginationToken);
|
1483
1444
|
}
|
1484
1445
|
|
1485
1446
|
/**
|
@@ -1569,12 +1530,12 @@ export class Room extends ReadReceipt {
|
|
1569
1530
|
* we should encrypt messages for in this room.
|
1570
1531
|
*/
|
1571
1532
|
getEncryptionTargetMembers() {
|
1572
|
-
var
|
1533
|
+
var _this8 = this;
|
1573
1534
|
return _asyncToGenerator(function* () {
|
1574
|
-
yield
|
1575
|
-
var members =
|
1576
|
-
if (
|
1577
|
-
members = members.concat(
|
1535
|
+
yield _this8.loadMembersIfNeeded();
|
1536
|
+
var members = _this8.getMembersWithMembership(KnownMembership.Join);
|
1537
|
+
if (_this8.shouldEncryptForInvitedMembers()) {
|
1538
|
+
members = members.concat(_this8.getMembersWithMembership(KnownMembership.Invite));
|
1578
1539
|
}
|
1579
1540
|
return members;
|
1580
1541
|
})();
|
@@ -1653,7 +1614,9 @@ export class Room extends ReadReceipt {
|
|
1653
1614
|
// see https://github.com/vector-im/vector-web/issues/2109
|
1654
1615
|
|
1655
1616
|
unfilteredLiveTimeline.getEvents().forEach(function (event) {
|
1656
|
-
timelineSet.addLiveEvent(event
|
1617
|
+
timelineSet.addLiveEvent(event, {
|
1618
|
+
addToState: false
|
1619
|
+
}); // Filtered timeline sets should not track state
|
1657
1620
|
});
|
1658
1621
|
|
1659
1622
|
// find the earliest unfiltered timeline
|
@@ -1679,10 +1642,10 @@ export class Room extends ReadReceipt {
|
|
1679
1642
|
}
|
1680
1643
|
getThreadListFilter() {
|
1681
1644
|
var _arguments = arguments,
|
1682
|
-
|
1645
|
+
_this9 = this;
|
1683
1646
|
return _asyncToGenerator(function* () {
|
1684
1647
|
var filterType = _arguments.length > 0 && _arguments[0] !== undefined ? _arguments[0] : ThreadFilterType.All;
|
1685
|
-
var myUserId =
|
1648
|
+
var myUserId = _this9.client.getUserId();
|
1686
1649
|
var filter = new Filter(myUserId);
|
1687
1650
|
var definition = {
|
1688
1651
|
room: {
|
@@ -1695,40 +1658,41 @@ export class Room extends ReadReceipt {
|
|
1695
1658
|
definition.room.timeline[FILTER_RELATED_BY_SENDERS.name] = [myUserId];
|
1696
1659
|
}
|
1697
1660
|
filter.setDefinition(definition);
|
1698
|
-
var filterId = yield
|
1661
|
+
var filterId = yield _this9.client.getOrCreateFilter("THREAD_PANEL_".concat(_this9.roomId, "_").concat(filterType), filter);
|
1699
1662
|
filter.filterId = filterId;
|
1700
1663
|
return filter;
|
1701
1664
|
})();
|
1702
1665
|
}
|
1703
1666
|
createThreadTimelineSet(filterType) {
|
1704
|
-
var
|
1667
|
+
var _this10 = this;
|
1705
1668
|
return _asyncToGenerator(function* () {
|
1706
1669
|
var timelineSet;
|
1707
1670
|
if (Thread.hasServerSideListSupport) {
|
1708
|
-
timelineSet = new EventTimelineSet(
|
1671
|
+
timelineSet = new EventTimelineSet(_this10, _objectSpread(_objectSpread({}, _this10.opts), {}, {
|
1709
1672
|
pendingEvents: false
|
1710
1673
|
}), undefined, undefined, filterType !== null && filterType !== void 0 ? filterType : ThreadFilterType.All);
|
1711
|
-
|
1674
|
+
_this10.reEmitter.reEmit(timelineSet, [RoomEvent.Timeline, RoomEvent.TimelineReset]);
|
1712
1675
|
} else if (Thread.hasServerSideSupport) {
|
1713
|
-
var filter = yield
|
1714
|
-
timelineSet =
|
1676
|
+
var filter = yield _this10.getThreadListFilter(filterType);
|
1677
|
+
timelineSet = _this10.getOrCreateFilteredTimelineSet(filter, {
|
1715
1678
|
prepopulateTimeline: false,
|
1716
1679
|
useSyncEvents: false,
|
1717
1680
|
pendingEvents: false
|
1718
1681
|
});
|
1719
1682
|
} else {
|
1720
|
-
timelineSet = new EventTimelineSet(
|
1683
|
+
timelineSet = new EventTimelineSet(_this10, {
|
1721
1684
|
pendingEvents: false
|
1722
1685
|
});
|
1723
|
-
Array.from(
|
1686
|
+
Array.from(_this10.threads).forEach(_ref3 => {
|
1724
1687
|
var [, thread] = _ref3;
|
1725
1688
|
if (thread.length === 0) return;
|
1726
1689
|
var currentUserParticipated = thread.timeline.some(event => {
|
1727
|
-
return event.getSender() ===
|
1690
|
+
return event.getSender() === _this10.client.getUserId();
|
1728
1691
|
});
|
1729
1692
|
if (filterType !== ThreadFilterType.My || currentUserParticipated) {
|
1730
1693
|
timelineSet.getLiveTimeline().addEvent(thread.rootEvent, {
|
1731
|
-
toStartOfTimeline: false
|
1694
|
+
toStartOfTimeline: false,
|
1695
|
+
addToState: false
|
1732
1696
|
});
|
1733
1697
|
}
|
1734
1698
|
});
|
@@ -1755,22 +1719,22 @@ export class Room extends ReadReceipt {
|
|
1755
1719
|
* Without server support that means fetching as much at once as the server allows us to.
|
1756
1720
|
*/
|
1757
1721
|
fetchRoomThreads() {
|
1758
|
-
var
|
1722
|
+
var _this11 = this;
|
1759
1723
|
return _asyncToGenerator(function* () {
|
1760
|
-
if (
|
1724
|
+
if (_this11.threadsReady || !_this11.client.supportsThreads()) {
|
1761
1725
|
return;
|
1762
1726
|
}
|
1763
1727
|
if (Thread.hasServerSideListSupport) {
|
1764
|
-
yield Promise.all([
|
1728
|
+
yield Promise.all([_this11.fetchRoomThreadList(ThreadFilterType.All), _this11.fetchRoomThreadList(ThreadFilterType.My)]);
|
1765
1729
|
} else {
|
1766
|
-
var allThreadsFilter = yield
|
1730
|
+
var allThreadsFilter = yield _this11.getThreadListFilter();
|
1767
1731
|
var {
|
1768
1732
|
chunk: events
|
1769
|
-
} = yield
|
1733
|
+
} = yield _this11.client.createMessagesRequest(_this11.roomId, "", Number.MAX_SAFE_INTEGER, Direction.Backward, allThreadsFilter);
|
1770
1734
|
if (!events.length) return;
|
1771
1735
|
|
1772
1736
|
// Sorted by last_reply origin_server_ts
|
1773
|
-
var threadRoots = events.map(
|
1737
|
+
var threadRoots = events.map(_this11.client.getEventMapper()).sort((eventA, eventB) => {
|
1774
1738
|
/**
|
1775
1739
|
* `origin_server_ts` in a decentralised world is far from ideal
|
1776
1740
|
* but for lack of any better, we will have to use this
|
@@ -1781,33 +1745,28 @@ export class Room extends ReadReceipt {
|
|
1781
1745
|
var threadBMetadata = eventB.getServerAggregatedRelation(THREAD_RELATION_TYPE.name);
|
1782
1746
|
return threadAMetadata.latest_event.origin_server_ts - threadBMetadata.latest_event.origin_server_ts;
|
1783
1747
|
});
|
1784
|
-
var
|
1785
|
-
var roomState = _this13.getLiveTimeline().getState(EventTimeline.FORWARDS);
|
1748
|
+
var roomState = _this11.getLiveTimeline().getState(EventTimeline.FORWARDS);
|
1786
1749
|
for (var rootEvent of threadRoots) {
|
1787
|
-
var
|
1750
|
+
var _this11$threadsTimeli;
|
1788
1751
|
var _opts = {
|
1789
1752
|
duplicateStrategy: DuplicateStrategy.Ignore,
|
1790
1753
|
fromCache: false,
|
1754
|
+
addToState: false,
|
1791
1755
|
roomState
|
1792
1756
|
};
|
1793
|
-
(
|
1757
|
+
(_this11$threadsTimeli = _this11.threadsTimelineSets[0]) === null || _this11$threadsTimeli === void 0 || _this11$threadsTimeli.addLiveEvent(rootEvent, _opts);
|
1794
1758
|
var threadRelationship = rootEvent.getServerAggregatedRelation(THREAD_RELATION_TYPE.name);
|
1795
1759
|
if (threadRelationship !== null && threadRelationship !== void 0 && threadRelationship.current_user_participated) {
|
1796
|
-
var
|
1797
|
-
(
|
1798
|
-
latestMyThreadsRootEvent = rootEvent;
|
1760
|
+
var _this11$threadsTimeli2;
|
1761
|
+
(_this11$threadsTimeli2 = _this11.threadsTimelineSets[1]) === null || _this11$threadsTimeli2 === void 0 || _this11$threadsTimeli2.addLiveEvent(rootEvent, _opts);
|
1799
1762
|
}
|
1800
1763
|
}
|
1801
|
-
|
1802
|
-
_this13.client.decryptEventIfNeeded(threadRoots[threadRoots.length - 1]);
|
1803
|
-
if (latestMyThreadsRootEvent) {
|
1804
|
-
_this13.client.decryptEventIfNeeded(latestMyThreadsRootEvent);
|
1805
|
-
}
|
1764
|
+
_this11.processThreadRoots(threadRoots, true);
|
1806
1765
|
}
|
1807
|
-
|
1808
|
-
|
1809
|
-
|
1810
|
-
|
1766
|
+
_this11.on(ThreadEvent.NewReply, _this11.onThreadReply);
|
1767
|
+
_this11.on(ThreadEvent.Update, _this11.onThreadUpdate);
|
1768
|
+
_this11.on(ThreadEvent.Delete, _this11.onThreadDelete);
|
1769
|
+
_this11.threadsReady = true;
|
1811
1770
|
})();
|
1812
1771
|
}
|
1813
1772
|
|
@@ -1817,7 +1776,7 @@ export class Room extends ReadReceipt {
|
|
1817
1776
|
* @param events - List of events
|
1818
1777
|
*/
|
1819
1778
|
processPollEvents(events) {
|
1820
|
-
var
|
1779
|
+
var _this12 = this;
|
1821
1780
|
return _asyncToGenerator(function* () {
|
1822
1781
|
for (var event of events) {
|
1823
1782
|
try {
|
@@ -1828,8 +1787,7 @@ export class Room extends ReadReceipt {
|
|
1828
1787
|
* Try to decrypt the event. Promise resolution does not guarantee a successful decryption.
|
1829
1788
|
* Retry is handled in {@link processPollEvent}.
|
1830
1789
|
*/
|
1831
|
-
|
1832
|
-
_this14.processPollEvent(event);
|
1790
|
+
_this12.processPollEvent(event);
|
1833
1791
|
} catch (err) {
|
1834
1792
|
logger.warn("Error processing poll event", event.getId(), err);
|
1835
1793
|
}
|
@@ -1848,31 +1806,25 @@ export class Room extends ReadReceipt {
|
|
1848
1806
|
* @param event - Event that could be a poll event
|
1849
1807
|
*/
|
1850
1808
|
processPollEvent(event) {
|
1851
|
-
var
|
1809
|
+
var _this13 = this;
|
1852
1810
|
return _asyncToGenerator(function* () {
|
1853
|
-
if (event.isDecryptionFailure()) {
|
1854
|
-
event.once(MatrixEventEvent.Decrypted, maybeDecryptedEvent => {
|
1855
|
-
_this15.processPollEvent(maybeDecryptedEvent);
|
1856
|
-
});
|
1857
|
-
return;
|
1858
|
-
}
|
1859
1811
|
if (M_POLL_START.matches(event.getType())) {
|
1860
1812
|
try {
|
1861
|
-
var poll = new Poll(event,
|
1862
|
-
|
1863
|
-
|
1813
|
+
var poll = new Poll(event, _this13.client, _this13);
|
1814
|
+
_this13.polls.set(event.getId(), poll);
|
1815
|
+
_this13.emit(PollEvent.New, poll);
|
1864
1816
|
|
1865
1817
|
// remove the poll when redacted
|
1866
1818
|
event.once(MatrixEventEvent.BeforeRedaction, redactedEvent => {
|
1867
|
-
|
1819
|
+
_this13.polls.delete(redactedEvent.getId());
|
1868
1820
|
});
|
1869
1821
|
} catch (_unused3) {}
|
1870
1822
|
// poll creation can fail for malformed poll start events
|
1871
1823
|
return;
|
1872
1824
|
}
|
1873
1825
|
var relationEventId = event.relationEventId;
|
1874
|
-
if (relationEventId &&
|
1875
|
-
var _poll =
|
1826
|
+
if (relationEventId && _this13.polls.has(relationEventId)) {
|
1827
|
+
var _poll = _this13.polls.get(relationEventId);
|
1876
1828
|
_poll === null || _poll === void 0 || _poll.onNewRelation(event);
|
1877
1829
|
}
|
1878
1830
|
})();
|
@@ -1883,25 +1835,26 @@ export class Room extends ReadReceipt {
|
|
1883
1835
|
* @internal
|
1884
1836
|
*/
|
1885
1837
|
fetchRoomThreadList(filter) {
|
1886
|
-
var
|
1838
|
+
var _this14 = this;
|
1887
1839
|
return _asyncToGenerator(function* () {
|
1888
|
-
if (!
|
1889
|
-
if (
|
1890
|
-
var timelineSet = filter === ThreadFilterType.My ?
|
1840
|
+
if (!_this14.client.supportsThreads()) return;
|
1841
|
+
if (_this14.threadsTimelineSets.length === 0) return;
|
1842
|
+
var timelineSet = filter === ThreadFilterType.My ? _this14.threadsTimelineSets[1] : _this14.threadsTimelineSets[0];
|
1891
1843
|
var {
|
1892
1844
|
chunk: events,
|
1893
1845
|
end
|
1894
|
-
} = yield
|
1846
|
+
} = yield _this14.client.createThreadListMessagesRequest(_this14.roomId, null, undefined, Direction.Backward, timelineSet.threadListType, timelineSet.getFilter());
|
1895
1847
|
timelineSet.getLiveTimeline().setPaginationToken(end !== null && end !== void 0 ? end : null, Direction.Backward);
|
1896
1848
|
if (!events.length) return;
|
1897
|
-
var matrixEvents = events.map(
|
1898
|
-
|
1899
|
-
var roomState =
|
1849
|
+
var matrixEvents = events.map(_this14.client.getEventMapper());
|
1850
|
+
_this14.processThreadRoots(matrixEvents, true);
|
1851
|
+
var roomState = _this14.getLiveTimeline().getState(EventTimeline.FORWARDS);
|
1900
1852
|
for (var rootEvent of matrixEvents) {
|
1901
1853
|
timelineSet.addLiveEvent(rootEvent, {
|
1902
1854
|
duplicateStrategy: DuplicateStrategy.Replace,
|
1903
1855
|
fromCache: false,
|
1904
|
-
roomState
|
1856
|
+
roomState,
|
1857
|
+
addToState: false
|
1905
1858
|
});
|
1906
1859
|
}
|
1907
1860
|
})();
|
@@ -2158,7 +2111,8 @@ export class Room extends ReadReceipt {
|
|
2158
2111
|
var {
|
2159
2112
|
duplicateStrategy,
|
2160
2113
|
timelineWasEmpty,
|
2161
|
-
fromCache
|
2114
|
+
fromCache,
|
2115
|
+
addToState
|
2162
2116
|
} = addLiveEventOptions;
|
2163
2117
|
|
2164
2118
|
// add to our timeline sets
|
@@ -2166,7 +2120,8 @@ export class Room extends ReadReceipt {
|
|
2166
2120
|
timelineSet.addLiveEvent(event, {
|
2167
2121
|
duplicateStrategy,
|
2168
2122
|
fromCache,
|
2169
|
-
timelineWasEmpty
|
2123
|
+
timelineWasEmpty,
|
2124
|
+
addToState
|
2170
2125
|
});
|
2171
2126
|
}
|
2172
2127
|
|
@@ -2246,12 +2201,14 @@ export class Room extends ReadReceipt {
|
|
2246
2201
|
if (timelineSet.getFilter()) {
|
2247
2202
|
if (timelineSet.getFilter().filterRoomTimeline([event]).length) {
|
2248
2203
|
timelineSet.addEventToTimeline(event, timelineSet.getLiveTimeline(), {
|
2249
|
-
toStartOfTimeline: false
|
2204
|
+
toStartOfTimeline: false,
|
2205
|
+
addToState: false // We don't support localEcho of state events yet
|
2250
2206
|
});
|
2251
2207
|
}
|
2252
2208
|
} else {
|
2253
2209
|
timelineSet.addEventToTimeline(event, timelineSet.getLiveTimeline(), {
|
2254
|
-
toStartOfTimeline: false
|
2210
|
+
toStartOfTimeline: false,
|
2211
|
+
addToState: false // We don't support localEcho of state events yet
|
2255
2212
|
});
|
2256
2213
|
}
|
2257
2214
|
}
|
@@ -2479,25 +2436,27 @@ export class Room extends ReadReceipt {
|
|
2479
2436
|
* @throws If `duplicateStrategy` is not falsey, 'replace' or 'ignore'.
|
2480
2437
|
*/
|
2481
2438
|
addLiveEvents(events, addLiveEventOptions) {
|
2482
|
-
var
|
2439
|
+
var _this15 = this;
|
2483
2440
|
return _asyncToGenerator(function* () {
|
2484
2441
|
var {
|
2485
2442
|
duplicateStrategy,
|
2486
2443
|
fromCache,
|
2487
|
-
timelineWasEmpty = false
|
2488
|
-
|
2444
|
+
timelineWasEmpty = false,
|
2445
|
+
addToState
|
2446
|
+
} = addLiveEventOptions;
|
2489
2447
|
if (duplicateStrategy && ["replace", "ignore"].indexOf(duplicateStrategy) === -1) {
|
2490
2448
|
throw new Error("duplicateStrategy MUST be either 'replace' or 'ignore'");
|
2491
2449
|
}
|
2492
2450
|
|
2493
2451
|
// sanity check that the live timeline is still live
|
2494
|
-
|
2495
|
-
var threadRoots =
|
2452
|
+
_this15.assertTimelineSetsAreLive();
|
2453
|
+
var threadRoots = _this15.findThreadRoots(events);
|
2496
2454
|
var eventsByThread = {};
|
2497
2455
|
var options = {
|
2498
2456
|
duplicateStrategy,
|
2499
2457
|
fromCache,
|
2500
|
-
timelineWasEmpty
|
2458
|
+
timelineWasEmpty,
|
2459
|
+
addToState
|
2501
2460
|
};
|
2502
2461
|
|
2503
2462
|
// List of extra events to check for being parents of any relations encountered
|
@@ -2505,12 +2464,12 @@ export class Room extends ReadReceipt {
|
|
2505
2464
|
for (var event of events) {
|
2506
2465
|
var _eventsByThread$threa;
|
2507
2466
|
// TODO: We should have a filter to say "only add state event types X Y Z to the timeline".
|
2508
|
-
|
2467
|
+
_this15.processLiveEvent(event);
|
2509
2468
|
if (event.getUnsigned().transaction_id) {
|
2510
|
-
var existingEvent =
|
2469
|
+
var existingEvent = _this15.txnToEvent.get(event.getUnsigned().transaction_id);
|
2511
2470
|
if (existingEvent) {
|
2512
2471
|
// remote echo of an event we sent earlier
|
2513
|
-
|
2472
|
+
_this15.handleRemoteEcho(event, existingEvent);
|
2514
2473
|
continue; // we can skip adding the event to the timeline sets, it is already there
|
2515
2474
|
}
|
2516
2475
|
}
|
@@ -2518,10 +2477,10 @@ export class Room extends ReadReceipt {
|
|
2518
2477
|
shouldLiveInRoom,
|
2519
2478
|
shouldLiveInThread,
|
2520
2479
|
threadId = ""
|
2521
|
-
} =
|
2480
|
+
} = _this15.eventShouldLiveIn(event, neighbouringEvents, threadRoots);
|
2522
2481
|
if (!shouldLiveInThread && !shouldLiveInRoom && event.isRelation()) {
|
2523
2482
|
try {
|
2524
|
-
var parentEvent = new MatrixEvent(yield
|
2483
|
+
var parentEvent = new MatrixEvent(yield _this15.client.fetchRoomEvent(_this15.roomId, event.relationEventId));
|
2525
2484
|
neighbouringEvents.push(parentEvent);
|
2526
2485
|
if (parentEvent.threadRootId) {
|
2527
2486
|
threadRoots.add(parentEvent.threadRootId);
|
@@ -2533,7 +2492,7 @@ export class Room extends ReadReceipt {
|
|
2533
2492
|
shouldLiveInRoom,
|
2534
2493
|
shouldLiveInThread,
|
2535
2494
|
threadId = ""
|
2536
|
-
} =
|
2495
|
+
} = _this15.eventShouldLiveIn(event, neighbouringEvents, threadRoots));
|
2537
2496
|
} catch (e) {
|
2538
2497
|
logger.error("Failed to load parent event of unhandled relation", e);
|
2539
2498
|
}
|
@@ -2543,14 +2502,14 @@ export class Room extends ReadReceipt {
|
|
2543
2502
|
}
|
2544
2503
|
(_eventsByThread$threa = eventsByThread[threadId]) === null || _eventsByThread$threa === void 0 || _eventsByThread$threa.push(event);
|
2545
2504
|
if (shouldLiveInRoom) {
|
2546
|
-
|
2505
|
+
_this15.addLiveEvent(event, options);
|
2547
2506
|
} else if (!shouldLiveInThread && event.isRelation()) {
|
2548
|
-
|
2507
|
+
_this15.relations.aggregateChildEvent(event);
|
2549
2508
|
}
|
2550
2509
|
}
|
2551
2510
|
Object.entries(eventsByThread).forEach(_ref5 => {
|
2552
2511
|
var [threadId, threadEvents] = _ref5;
|
2553
|
-
|
2512
|
+
_this15.addThreadedEvents(threadId, threadEvents, false);
|
2554
2513
|
});
|
2555
2514
|
})();
|
2556
2515
|
}
|