@unwanted/matrix-sdk-mini 34.12.0 → 36.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/git-revision.txt +1 -1
- package/lib/@types/event.d.ts +25 -19
- package/lib/@types/event.d.ts.map +1 -1
- package/lib/@types/event.js +5 -0
- 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 +45 -1306
- package/lib/client.d.ts.map +1 -1
- package/lib/client.js +406 -2963
- 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 +2 -23
- package/lib/embedded.d.ts.map +1 -1
- package/lib/embedded.js +82 -209
- 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/feature.d.ts.map +1 -1
- package/lib/feature.js +2 -1
- package/lib/feature.js.map +1 -1
- package/lib/http-api/errors.d.ts +3 -3
- package/lib/http-api/errors.js +3 -3
- package/lib/http-api/errors.js.map +1 -1
- package/lib/http-api/utils.js +2 -2
- package/lib/http-api/utils.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 +9 -30
- package/lib/models/event-timeline.js.map +1 -1
- package/lib/models/event.d.ts +12 -96
- package/lib/models/event.d.ts.map +1 -1
- package/lib/models/event.js +59 -286
- package/lib/models/event.js.map +1 -1
- package/lib/models/invites-ignorer-types.d.ts +27 -0
- package/lib/models/invites-ignorer-types.d.ts.map +1 -0
- package/lib/models/invites-ignorer-types.js +36 -0
- package/lib/models/invites-ignorer-types.js.map +1 -0
- package/lib/models/invites-ignorer.d.ts +2 -26
- package/lib/models/invites-ignorer.d.ts.map +1 -1
- package/lib/models/invites-ignorer.js +2 -27
- package/lib/models/invites-ignorer.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-member.d.ts +6 -1
- package/lib/models/room-member.d.ts.map +1 -1
- package/lib/models/room-member.js +7 -1
- package/lib/models/room-member.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 +8 -21
- package/lib/models/room.d.ts.map +1 -1
- package/lib/models/room.js +128 -163
- 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/oidc/authorize.d.ts +2 -2
- package/lib/oidc/authorize.d.ts.map +1 -1
- package/lib/oidc/authorize.js +5 -5
- package/lib/oidc/authorize.js.map +1 -1
- package/lib/oidc/discovery.d.ts +8 -0
- package/lib/oidc/discovery.d.ts.map +1 -1
- package/lib/oidc/discovery.js +22 -11
- package/lib/oidc/discovery.js.map +1 -1
- package/lib/oidc/index.d.ts +3 -4
- package/lib/oidc/index.d.ts.map +1 -1
- package/lib/oidc/index.js.map +1 -1
- package/lib/oidc/register.js +3 -3
- package/lib/oidc/register.js.map +1 -1
- package/lib/oidc/tokenRefresher.d.ts.map +1 -1
- package/lib/oidc/tokenRefresher.js +6 -5
- package/lib/oidc/tokenRefresher.js.map +1 -1
- package/lib/oidc/validate.d.ts +9 -23
- package/lib/oidc/validate.d.ts.map +1 -1
- package/lib/oidc/validate.js +13 -28
- package/lib/oidc/validate.js.map +1 -1
- package/lib/randomstring.d.ts +30 -3
- package/lib/randomstring.d.ts.map +1 -1
- package/lib/randomstring.js +68 -16
- package/lib/randomstring.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-local-backend.js +4 -2
- package/lib/store/indexeddb-local-backend.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 +13 -44
- package/lib/testing.d.ts.map +1 -1
- package/lib/testing.js +36 -99
- 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 +14 -15
- package/src/@types/event.ts +19 -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 +175 -3136
- package/src/digest.ts +3 -3
- package/src/embedded.ts +43 -149
- package/src/event-mapper.ts +0 -4
- package/src/feature.ts +1 -0
- package/src/http-api/errors.ts +3 -3
- package/src/http-api/utils.ts +2 -2
- 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 +11 -26
- package/src/models/event.ts +54 -295
- package/src/models/invites-ignorer-types.ts +48 -0
- package/src/models/invites-ignorer.ts +7 -42
- 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-member.ts +16 -1
- package/src/models/room-state.ts +4 -37
- package/src/models/room.ts +34 -69
- package/src/models/thread.ts +4 -3
- package/src/oidc/authorize.ts +7 -7
- package/src/oidc/discovery.ts +16 -10
- package/src/oidc/index.ts +3 -4
- package/src/oidc/register.ts +3 -3
- package/src/oidc/tokenRefresher.ts +3 -2
- package/src/oidc/validate.ts +40 -63
- package/src/randomstring.ts +65 -19
- package/src/sliding-sync-sdk.ts +10 -83
- package/src/sliding-sync.ts +6 -6
- package/src/store/indexeddb-local-backend.ts +2 -2
- package/src/store/indexeddb.ts +1 -1
- package/src/sync-accumulator.ts +33 -16
- package/src/sync.ts +112 -143
- package/src/testing.ts +36 -103
- 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
@@ -1,166 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
Copyright 2023 The Matrix.org Foundation C.I.C.
|
3
|
-
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
-
you may not use this file except in compliance with the License.
|
6
|
-
You may obtain a copy of the License at
|
7
|
-
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
9
|
-
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
-
See the License for the specific language governing permissions and
|
14
|
-
limitations under the License.
|
15
|
-
*/
|
16
|
-
|
17
|
-
import { logger as rootLogger } from "../logger.ts";
|
18
|
-
import { MatrixClient, ClientEvent } from "../client.ts";
|
19
|
-
import { TypedEventEmitter } from "../models/typed-event-emitter.ts";
|
20
|
-
import { Room, RoomEvent } from "../models/room.ts";
|
21
|
-
import { RoomState, RoomStateEvent } from "../models/room-state.ts";
|
22
|
-
import { MatrixEvent } from "../models/event.ts";
|
23
|
-
import { MatrixRTCSession } from "./MatrixRTCSession.ts";
|
24
|
-
import { EventType } from "../@types/event.ts";
|
25
|
-
|
26
|
-
const logger = rootLogger.getChild("MatrixRTCSessionManager");
|
27
|
-
|
28
|
-
export enum MatrixRTCSessionManagerEvents {
|
29
|
-
// A member has joined the MatrixRTC session, creating an active session in a room where there wasn't previously
|
30
|
-
SessionStarted = "session_started",
|
31
|
-
// All participants have left a given MatrixRTC session.
|
32
|
-
SessionEnded = "session_ended",
|
33
|
-
}
|
34
|
-
|
35
|
-
type EventHandlerMap = {
|
36
|
-
[MatrixRTCSessionManagerEvents.SessionStarted]: (roomId: string, session: MatrixRTCSession) => void;
|
37
|
-
[MatrixRTCSessionManagerEvents.SessionEnded]: (roomId: string, session: MatrixRTCSession) => void;
|
38
|
-
};
|
39
|
-
|
40
|
-
/**
|
41
|
-
* Holds all active MatrixRTC session objects and creates new ones as events arrive.
|
42
|
-
* This interface is UNSTABLE and may change without warning.
|
43
|
-
*/
|
44
|
-
export class MatrixRTCSessionManager extends TypedEventEmitter<MatrixRTCSessionManagerEvents, EventHandlerMap> {
|
45
|
-
// All the room-scoped sessions we know about. This will include any where the app
|
46
|
-
// has queried for the MatrixRTC sessions in a room, whether it's ever had any members
|
47
|
-
// or not). We keep a (lazily created) session object for every room to ensure that there
|
48
|
-
// is only ever one single room session object for any given room for the lifetime of the
|
49
|
-
// client: that way there can never be any code holding onto a stale object that is no
|
50
|
-
// longer the correct session object for the room.
|
51
|
-
private roomSessions = new Map<string, MatrixRTCSession>();
|
52
|
-
|
53
|
-
public constructor(private client: MatrixClient) {
|
54
|
-
super();
|
55
|
-
}
|
56
|
-
|
57
|
-
public start(): void {
|
58
|
-
// We shouldn't need to null-check here, but matrix-client.spec.ts mocks getRooms
|
59
|
-
// returning nothing, and breaks tests if you change it to return an empty array :'(
|
60
|
-
for (const room of this.client.getRooms() ?? []) {
|
61
|
-
const session = MatrixRTCSession.roomSessionForRoom(this.client, room);
|
62
|
-
if (session.memberships.length > 0) {
|
63
|
-
this.roomSessions.set(room.roomId, session);
|
64
|
-
}
|
65
|
-
}
|
66
|
-
|
67
|
-
this.client.on(ClientEvent.Room, this.onRoom);
|
68
|
-
this.client.on(RoomEvent.Timeline, this.onTimeline);
|
69
|
-
this.client.on(RoomStateEvent.Events, this.onRoomState);
|
70
|
-
}
|
71
|
-
|
72
|
-
public stop(): void {
|
73
|
-
for (const sess of this.roomSessions.values()) {
|
74
|
-
sess.stop();
|
75
|
-
}
|
76
|
-
this.roomSessions.clear();
|
77
|
-
|
78
|
-
this.client.off(ClientEvent.Room, this.onRoom);
|
79
|
-
this.client.off(RoomEvent.Timeline, this.onTimeline);
|
80
|
-
this.client.off(RoomStateEvent.Events, this.onRoomState);
|
81
|
-
}
|
82
|
-
|
83
|
-
/**
|
84
|
-
* Gets the main MatrixRTC session for a room, or undefined if there is
|
85
|
-
* no current session
|
86
|
-
*/
|
87
|
-
public getActiveRoomSession(room: Room): MatrixRTCSession | undefined {
|
88
|
-
return this.roomSessions.get(room.roomId)!;
|
89
|
-
}
|
90
|
-
|
91
|
-
/**
|
92
|
-
* Gets the main MatrixRTC session for a room, returning an empty session
|
93
|
-
* if no members are currently participating
|
94
|
-
*/
|
95
|
-
public getRoomSession(room: Room): MatrixRTCSession {
|
96
|
-
if (!this.roomSessions.has(room.roomId)) {
|
97
|
-
this.roomSessions.set(room.roomId, MatrixRTCSession.roomSessionForRoom(this.client, room));
|
98
|
-
}
|
99
|
-
|
100
|
-
return this.roomSessions.get(room.roomId)!;
|
101
|
-
}
|
102
|
-
|
103
|
-
private async consumeCallEncryptionEvent(event: MatrixEvent, isRetry = false): Promise<void> {
|
104
|
-
await this.client.decryptEventIfNeeded(event);
|
105
|
-
if (event.isDecryptionFailure()) {
|
106
|
-
if (!isRetry) {
|
107
|
-
logger.warn(
|
108
|
-
`Decryption failed for event ${event.getId()}: ${event.decryptionFailureReason} will retry once only`,
|
109
|
-
);
|
110
|
-
// retry after 1 second. After this we give up.
|
111
|
-
setTimeout(() => this.consumeCallEncryptionEvent(event, true), 1000);
|
112
|
-
} else {
|
113
|
-
logger.warn(`Decryption failed for event ${event.getId()}: ${event.decryptionFailureReason}`);
|
114
|
-
}
|
115
|
-
return;
|
116
|
-
} else if (isRetry) {
|
117
|
-
logger.info(`Decryption succeeded for event ${event.getId()} after retry`);
|
118
|
-
}
|
119
|
-
|
120
|
-
if (event.getType() !== EventType.CallEncryptionKeysPrefix) return Promise.resolve();
|
121
|
-
|
122
|
-
const room = this.client.getRoom(event.getRoomId());
|
123
|
-
if (!room) {
|
124
|
-
logger.error(`Got room state event for unknown room ${event.getRoomId()}!`);
|
125
|
-
return Promise.resolve();
|
126
|
-
}
|
127
|
-
|
128
|
-
this.getRoomSession(room).onCallEncryption(event);
|
129
|
-
}
|
130
|
-
private onTimeline = (event: MatrixEvent): void => {
|
131
|
-
this.consumeCallEncryptionEvent(event);
|
132
|
-
};
|
133
|
-
|
134
|
-
private onRoom = (room: Room): void => {
|
135
|
-
this.refreshRoom(room);
|
136
|
-
};
|
137
|
-
|
138
|
-
private onRoomState = (event: MatrixEvent, _state: RoomState): void => {
|
139
|
-
const room = this.client.getRoom(event.getRoomId());
|
140
|
-
if (!room) {
|
141
|
-
logger.error(`Got room state event for unknown room ${event.getRoomId()}!`);
|
142
|
-
return;
|
143
|
-
}
|
144
|
-
|
145
|
-
if (event.getType() == EventType.GroupCallMemberPrefix) {
|
146
|
-
this.refreshRoom(room);
|
147
|
-
}
|
148
|
-
};
|
149
|
-
|
150
|
-
private refreshRoom(room: Room): void {
|
151
|
-
const isNewSession = !this.roomSessions.has(room.roomId);
|
152
|
-
const sess = this.getRoomSession(room);
|
153
|
-
|
154
|
-
const wasActiveAndKnown = sess.memberships.length > 0 && !isNewSession;
|
155
|
-
|
156
|
-
sess.onMembershipUpdate();
|
157
|
-
|
158
|
-
const nowActive = sess.memberships.length > 0;
|
159
|
-
|
160
|
-
if (wasActiveAndKnown && !nowActive) {
|
161
|
-
this.emit(MatrixRTCSessionManagerEvents.SessionEnded, room.roomId, this.roomSessions.get(room.roomId)!);
|
162
|
-
} else if (!wasActiveAndKnown && nowActive) {
|
163
|
-
this.emit(MatrixRTCSessionManagerEvents.SessionStarted, room.roomId, this.roomSessions.get(room.roomId)!);
|
164
|
-
}
|
165
|
-
}
|
166
|
-
}
|
package/src/matrixrtc/focus.ts
DELETED
@@ -1,25 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
Copyright 2023 The Matrix.org Foundation C.I.C.
|
3
|
-
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
-
you may not use this file except in compliance with the License.
|
6
|
-
You may obtain a copy of the License at
|
7
|
-
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
9
|
-
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
-
See the License for the specific language governing permissions and
|
14
|
-
limitations under the License.
|
15
|
-
*/
|
16
|
-
|
17
|
-
/**
|
18
|
-
* Information about a MatrixRTC conference focus. The only attribute that
|
19
|
-
* the js-sdk (currently) knows about is the type: applications can extend
|
20
|
-
* this class for different types of focus.
|
21
|
-
*/
|
22
|
-
export interface Focus {
|
23
|
-
type: string;
|
24
|
-
[key: string]: unknown;
|
25
|
-
}
|
package/src/matrixrtc/index.ts
DELETED
@@ -1,22 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
Copyright 2024 The Matrix.org Foundation C.I.C.
|
3
|
-
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
-
you may not use this file except in compliance with the License.
|
6
|
-
You may obtain a copy of the License at
|
7
|
-
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
9
|
-
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
-
See the License for the specific language governing permissions and
|
14
|
-
limitations under the License.
|
15
|
-
*/
|
16
|
-
|
17
|
-
export * from "./CallMembership.ts";
|
18
|
-
export type * from "./focus.ts";
|
19
|
-
export * from "./LivekitFocus.ts";
|
20
|
-
export * from "./MatrixRTCSession.ts";
|
21
|
-
export * from "./MatrixRTCSessionManager.ts";
|
22
|
-
export type * from "./types.ts";
|
package/src/matrixrtc/types.ts
DELETED
@@ -1,36 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
Copyright 2023 The Matrix.org Foundation C.I.C.
|
3
|
-
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
-
you may not use this file except in compliance with the License.
|
6
|
-
You may obtain a copy of the License at
|
7
|
-
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
9
|
-
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
-
See the License for the specific language governing permissions and
|
14
|
-
limitations under the License.
|
15
|
-
*/
|
16
|
-
import { IMentions } from "../matrix.ts";
|
17
|
-
export interface EncryptionKeyEntry {
|
18
|
-
index: number;
|
19
|
-
key: string;
|
20
|
-
}
|
21
|
-
|
22
|
-
export interface EncryptionKeysEventContent {
|
23
|
-
keys: EncryptionKeyEntry[];
|
24
|
-
device_id: string;
|
25
|
-
call_id: string;
|
26
|
-
sent_ts?: number;
|
27
|
-
}
|
28
|
-
|
29
|
-
export type CallNotifyType = "ring" | "notify";
|
30
|
-
|
31
|
-
export interface ICallNotifyContent {
|
32
|
-
"application": string;
|
33
|
-
"m.mentions": IMentions;
|
34
|
-
"notify_type": CallNotifyType;
|
35
|
-
"call_id": string;
|
36
|
-
}
|
@@ -1,444 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
Copyright 2024 The Matrix.org Foundation C.I.C.
|
3
|
-
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
-
you may not use this file except in compliance with the License.
|
6
|
-
You may obtain a copy of the License at
|
7
|
-
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
9
|
-
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
13
|
-
See the License for the specific language governing permissions and
|
14
|
-
limitations under the License.
|
15
|
-
*/
|
16
|
-
|
17
|
-
import { QrCodeMode } from "@matrix-org/matrix-sdk-crypto-wasm";
|
18
|
-
|
19
|
-
import {
|
20
|
-
ClientRendezvousFailureReason,
|
21
|
-
MSC4108FailureReason,
|
22
|
-
RendezvousError,
|
23
|
-
RendezvousFailureListener,
|
24
|
-
} from "./index.ts";
|
25
|
-
import { MatrixClient } from "../client.ts";
|
26
|
-
import { logger } from "../logger.ts";
|
27
|
-
import { MSC4108SecureChannel } from "./channels/MSC4108SecureChannel.ts";
|
28
|
-
import { MatrixError } from "../http-api/index.ts";
|
29
|
-
import { sleep } from "../utils.ts";
|
30
|
-
import { DEVICE_CODE_SCOPE, discoverAndValidateOIDCIssuerWellKnown, OidcClientConfig } from "../oidc/index.ts";
|
31
|
-
import { CryptoApi } from "../crypto-api/index.ts";
|
32
|
-
|
33
|
-
/**
|
34
|
-
* Enum representing the payload types transmissible over [MSC4108](https://github.com/matrix-org/matrix-spec-proposals/pull/4108)
|
35
|
-
* secure channels.
|
36
|
-
* @experimental Note that this is UNSTABLE and may have breaking changes without notice.
|
37
|
-
*/
|
38
|
-
export enum PayloadType {
|
39
|
-
Protocols = "m.login.protocols",
|
40
|
-
Protocol = "m.login.protocol",
|
41
|
-
Failure = "m.login.failure",
|
42
|
-
Success = "m.login.success",
|
43
|
-
Secrets = "m.login.secrets",
|
44
|
-
ProtocolAccepted = "m.login.protocol_accepted",
|
45
|
-
Declined = "m.login.declined",
|
46
|
-
}
|
47
|
-
|
48
|
-
/**
|
49
|
-
* Type representing the base payload format for [MSC4108](https://github.com/matrix-org/matrix-spec-proposals/pull/4108)
|
50
|
-
* messages sent over the secure channel.
|
51
|
-
* @experimental Note that this is UNSTABLE and may have breaking changes without notice.
|
52
|
-
*/
|
53
|
-
export interface MSC4108Payload {
|
54
|
-
type: PayloadType;
|
55
|
-
}
|
56
|
-
|
57
|
-
interface ProtocolsPayload extends MSC4108Payload {
|
58
|
-
type: PayloadType.Protocols;
|
59
|
-
protocols: string[];
|
60
|
-
homeserver: string;
|
61
|
-
}
|
62
|
-
|
63
|
-
interface ProtocolPayload extends MSC4108Payload {
|
64
|
-
type: PayloadType.Protocol;
|
65
|
-
protocol: Exclude<string, "device_authorization_grant">;
|
66
|
-
device_id: string;
|
67
|
-
}
|
68
|
-
|
69
|
-
interface DeviceAuthorizationGrantProtocolPayload extends ProtocolPayload {
|
70
|
-
protocol: "device_authorization_grant";
|
71
|
-
device_authorization_grant: {
|
72
|
-
verification_uri: string;
|
73
|
-
verification_uri_complete?: string;
|
74
|
-
};
|
75
|
-
}
|
76
|
-
|
77
|
-
function isDeviceAuthorizationGrantProtocolPayload(
|
78
|
-
payload: ProtocolPayload,
|
79
|
-
): payload is DeviceAuthorizationGrantProtocolPayload {
|
80
|
-
return payload.protocol === "device_authorization_grant";
|
81
|
-
}
|
82
|
-
|
83
|
-
interface FailurePayload extends MSC4108Payload {
|
84
|
-
type: PayloadType.Failure;
|
85
|
-
reason: MSC4108FailureReason;
|
86
|
-
homeserver?: string;
|
87
|
-
}
|
88
|
-
|
89
|
-
interface DeclinedPayload extends MSC4108Payload {
|
90
|
-
type: PayloadType.Declined;
|
91
|
-
}
|
92
|
-
|
93
|
-
interface SuccessPayload extends MSC4108Payload {
|
94
|
-
type: PayloadType.Success;
|
95
|
-
}
|
96
|
-
|
97
|
-
interface AcceptedPayload extends MSC4108Payload {
|
98
|
-
type: PayloadType.ProtocolAccepted;
|
99
|
-
}
|
100
|
-
|
101
|
-
interface SecretsPayload extends MSC4108Payload, Awaited<ReturnType<NonNullable<CryptoApi["exportSecretsBundle"]>>> {
|
102
|
-
type: PayloadType.Secrets;
|
103
|
-
}
|
104
|
-
|
105
|
-
/**
|
106
|
-
* Prototype of the unstable [MSC4108](https://github.com/matrix-org/matrix-spec-proposals/pull/4108)
|
107
|
-
* sign in with QR + OIDC flow.
|
108
|
-
* @experimental Note that this is UNSTABLE and may have breaking changes without notice.
|
109
|
-
*/
|
110
|
-
export class MSC4108SignInWithQR {
|
111
|
-
private readonly ourIntent: QrCodeMode;
|
112
|
-
private _code?: Uint8Array;
|
113
|
-
private expectingNewDeviceId?: string;
|
114
|
-
|
115
|
-
/**
|
116
|
-
* Returns the check code for the secure channel or undefined if not generated yet.
|
117
|
-
*/
|
118
|
-
public get checkCode(): string | undefined {
|
119
|
-
return this.channel?.getCheckCode();
|
120
|
-
}
|
121
|
-
|
122
|
-
/**
|
123
|
-
* @param channel - The secure channel used for communication
|
124
|
-
* @param client - The Matrix client in used on the device already logged in
|
125
|
-
* @param didScanCode - Whether this side of the channel scanned the QR code from the other party
|
126
|
-
* @param onFailure - Callback for when the rendezvous fails
|
127
|
-
*/
|
128
|
-
public constructor(
|
129
|
-
private readonly channel: MSC4108SecureChannel,
|
130
|
-
private readonly didScanCode: boolean,
|
131
|
-
private readonly client?: MatrixClient,
|
132
|
-
public onFailure?: RendezvousFailureListener,
|
133
|
-
) {
|
134
|
-
this.ourIntent = client ? QrCodeMode.Reciprocate : QrCodeMode.Login;
|
135
|
-
}
|
136
|
-
|
137
|
-
/**
|
138
|
-
* Returns the code representing the rendezvous suitable for rendering in a QR code or undefined if not generated yet.
|
139
|
-
*/
|
140
|
-
public get code(): Uint8Array | undefined {
|
141
|
-
return this._code;
|
142
|
-
}
|
143
|
-
|
144
|
-
/**
|
145
|
-
* Generate the code including doing partial set up of the channel where required.
|
146
|
-
*/
|
147
|
-
public async generateCode(): Promise<void> {
|
148
|
-
if (this._code) {
|
149
|
-
return;
|
150
|
-
}
|
151
|
-
|
152
|
-
if (this.ourIntent === QrCodeMode.Reciprocate && this.client) {
|
153
|
-
this._code = await this.channel.generateCode(this.ourIntent, this.client.getDomain()!);
|
154
|
-
} else if (this.ourIntent === QrCodeMode.Login) {
|
155
|
-
this._code = await this.channel.generateCode(this.ourIntent);
|
156
|
-
}
|
157
|
-
}
|
158
|
-
|
159
|
-
/**
|
160
|
-
* Returns true if the device is the already logged in device reciprocating a new login on the other side of the channel.
|
161
|
-
*/
|
162
|
-
public get isExistingDevice(): boolean {
|
163
|
-
return this.ourIntent === QrCodeMode.Reciprocate;
|
164
|
-
}
|
165
|
-
|
166
|
-
/**
|
167
|
-
* Returns true if the device is the new device logging in being reciprocated by the device on the other side of the channel.
|
168
|
-
*/
|
169
|
-
public get isNewDevice(): boolean {
|
170
|
-
return !this.isExistingDevice;
|
171
|
-
}
|
172
|
-
|
173
|
-
/**
|
174
|
-
* The first step in the OIDC QR login process.
|
175
|
-
* To be called after the QR code has been rendered or scanned.
|
176
|
-
* The scanning device has to discover the homeserver details, if they scanned the code then they already have it.
|
177
|
-
* If the new device is the one rendering the QR code then it has to wait be sent the homeserver details via the rendezvous channel.
|
178
|
-
*/
|
179
|
-
public async negotiateProtocols(): Promise<{ serverName?: string }> {
|
180
|
-
logger.info(`negotiateProtocols(isNewDevice=${this.isNewDevice} didScanCode=${this.didScanCode})`);
|
181
|
-
await this.channel.connect();
|
182
|
-
|
183
|
-
if (this.didScanCode) {
|
184
|
-
// Secure Channel step 6 completed, we trust the channel
|
185
|
-
|
186
|
-
if (this.isNewDevice) {
|
187
|
-
// MSC4108-Flow: ExistingScanned - take homeserver from QR code which should already be set
|
188
|
-
} else {
|
189
|
-
// MSC4108-Flow: NewScanned -send protocols message
|
190
|
-
let oidcClientConfig: OidcClientConfig | undefined;
|
191
|
-
try {
|
192
|
-
const { issuer } = await this.client!.getAuthIssuer();
|
193
|
-
oidcClientConfig = await discoverAndValidateOIDCIssuerWellKnown(issuer);
|
194
|
-
} catch (e) {
|
195
|
-
logger.error("Failed to discover OIDC metadata", e);
|
196
|
-
}
|
197
|
-
|
198
|
-
if (oidcClientConfig?.metadata.grant_types_supported.includes(DEVICE_CODE_SCOPE)) {
|
199
|
-
await this.send<ProtocolsPayload>({
|
200
|
-
type: PayloadType.Protocols,
|
201
|
-
protocols: ["device_authorization_grant"],
|
202
|
-
homeserver: this.client!.getDomain()!,
|
203
|
-
});
|
204
|
-
} else {
|
205
|
-
await this.send<FailurePayload>({
|
206
|
-
type: PayloadType.Failure,
|
207
|
-
reason: MSC4108FailureReason.UnsupportedProtocol,
|
208
|
-
});
|
209
|
-
throw new RendezvousError(
|
210
|
-
"Device code grant unsupported",
|
211
|
-
MSC4108FailureReason.UnsupportedProtocol,
|
212
|
-
);
|
213
|
-
}
|
214
|
-
}
|
215
|
-
} else if (this.isNewDevice) {
|
216
|
-
// MSC4108-Flow: ExistingScanned - wait for protocols message
|
217
|
-
logger.info("Waiting for protocols message");
|
218
|
-
const payload = await this.receive<ProtocolsPayload>();
|
219
|
-
|
220
|
-
if (payload?.type === PayloadType.Failure) {
|
221
|
-
throw new RendezvousError("Failed", payload.reason);
|
222
|
-
}
|
223
|
-
|
224
|
-
if (payload?.type !== PayloadType.Protocols) {
|
225
|
-
await this.send<FailurePayload>({
|
226
|
-
type: PayloadType.Failure,
|
227
|
-
reason: MSC4108FailureReason.UnexpectedMessageReceived,
|
228
|
-
});
|
229
|
-
throw new RendezvousError(
|
230
|
-
"Unexpected message received",
|
231
|
-
MSC4108FailureReason.UnexpectedMessageReceived,
|
232
|
-
);
|
233
|
-
}
|
234
|
-
|
235
|
-
return { serverName: payload.homeserver };
|
236
|
-
} else {
|
237
|
-
// MSC4108-Flow: NewScanned - nothing to do
|
238
|
-
}
|
239
|
-
return {};
|
240
|
-
}
|
241
|
-
|
242
|
-
/**
|
243
|
-
* The second & third step in the OIDC QR login process.
|
244
|
-
* To be called after `negotiateProtocols` for the existing device.
|
245
|
-
* To be called after OIDC negotiation for the new device. (Currently unsupported)
|
246
|
-
*/
|
247
|
-
public async deviceAuthorizationGrant(): Promise<{
|
248
|
-
verificationUri?: string;
|
249
|
-
userCode?: string;
|
250
|
-
}> {
|
251
|
-
if (this.isNewDevice) {
|
252
|
-
throw new Error("New device flows around OIDC are not yet implemented");
|
253
|
-
} else {
|
254
|
-
// The user needs to do step 7 for the out-of-band confirmation
|
255
|
-
// but, first we receive the protocol chosen by the other device so that
|
256
|
-
// the confirmation_uri is ready to go
|
257
|
-
logger.info("Waiting for protocol message");
|
258
|
-
const payload = await this.receive<ProtocolPayload | DeviceAuthorizationGrantProtocolPayload>();
|
259
|
-
|
260
|
-
if (payload?.type === PayloadType.Failure) {
|
261
|
-
throw new RendezvousError("Failed", payload.reason);
|
262
|
-
}
|
263
|
-
|
264
|
-
if (payload?.type !== PayloadType.Protocol) {
|
265
|
-
await this.send<FailurePayload>({
|
266
|
-
type: PayloadType.Failure,
|
267
|
-
reason: MSC4108FailureReason.UnexpectedMessageReceived,
|
268
|
-
});
|
269
|
-
throw new RendezvousError(
|
270
|
-
"Unexpected message received",
|
271
|
-
MSC4108FailureReason.UnexpectedMessageReceived,
|
272
|
-
);
|
273
|
-
}
|
274
|
-
|
275
|
-
if (isDeviceAuthorizationGrantProtocolPayload(payload)) {
|
276
|
-
const { device_authorization_grant: dag, device_id: expectingNewDeviceId } = payload;
|
277
|
-
const { verification_uri: verificationUri, verification_uri_complete: verificationUriComplete } = dag;
|
278
|
-
|
279
|
-
let deviceAlreadyExists = true;
|
280
|
-
try {
|
281
|
-
await this.client?.getDevice(expectingNewDeviceId);
|
282
|
-
} catch (err: MatrixError | unknown) {
|
283
|
-
if (err instanceof MatrixError && err.httpStatus === 404) {
|
284
|
-
deviceAlreadyExists = false;
|
285
|
-
}
|
286
|
-
}
|
287
|
-
|
288
|
-
if (deviceAlreadyExists) {
|
289
|
-
await this.send<FailurePayload>({
|
290
|
-
type: PayloadType.Failure,
|
291
|
-
reason: MSC4108FailureReason.DeviceAlreadyExists,
|
292
|
-
});
|
293
|
-
throw new RendezvousError(
|
294
|
-
"Specified device ID already exists",
|
295
|
-
MSC4108FailureReason.DeviceAlreadyExists,
|
296
|
-
);
|
297
|
-
}
|
298
|
-
|
299
|
-
this.expectingNewDeviceId = expectingNewDeviceId;
|
300
|
-
|
301
|
-
return { verificationUri: verificationUriComplete ?? verificationUri };
|
302
|
-
}
|
303
|
-
|
304
|
-
await this.send<FailurePayload>({
|
305
|
-
type: PayloadType.Failure,
|
306
|
-
reason: MSC4108FailureReason.UnsupportedProtocol,
|
307
|
-
});
|
308
|
-
throw new RendezvousError(
|
309
|
-
"Received a request for an unsupported protocol",
|
310
|
-
MSC4108FailureReason.UnsupportedProtocol,
|
311
|
-
);
|
312
|
-
}
|
313
|
-
}
|
314
|
-
|
315
|
-
/**
|
316
|
-
* The fifth (and final) step in the OIDC QR login process.
|
317
|
-
* To be called after the new device has completed authentication.
|
318
|
-
*/
|
319
|
-
public async shareSecrets(): Promise<{ secrets?: Omit<SecretsPayload, "type"> }> {
|
320
|
-
if (this.isNewDevice) {
|
321
|
-
await this.send<SuccessPayload>({
|
322
|
-
type: PayloadType.Success,
|
323
|
-
});
|
324
|
-
// then wait for secrets
|
325
|
-
logger.info("Waiting for secrets message");
|
326
|
-
const payload = await this.receive<SecretsPayload>();
|
327
|
-
if (payload?.type === PayloadType.Failure) {
|
328
|
-
throw new RendezvousError("Failed", payload.reason);
|
329
|
-
}
|
330
|
-
|
331
|
-
if (payload?.type !== PayloadType.Secrets) {
|
332
|
-
await this.send<FailurePayload>({
|
333
|
-
type: PayloadType.Failure,
|
334
|
-
reason: MSC4108FailureReason.UnexpectedMessageReceived,
|
335
|
-
});
|
336
|
-
throw new RendezvousError(
|
337
|
-
"Unexpected message received",
|
338
|
-
MSC4108FailureReason.UnexpectedMessageReceived,
|
339
|
-
);
|
340
|
-
}
|
341
|
-
return { secrets: payload };
|
342
|
-
// then done?
|
343
|
-
} else {
|
344
|
-
if (!this.expectingNewDeviceId) {
|
345
|
-
throw new Error("No new device ID expected");
|
346
|
-
}
|
347
|
-
await this.send<AcceptedPayload>({
|
348
|
-
type: PayloadType.ProtocolAccepted,
|
349
|
-
});
|
350
|
-
|
351
|
-
logger.info("Waiting for outcome message");
|
352
|
-
const payload = await this.receive<SuccessPayload | DeclinedPayload>();
|
353
|
-
|
354
|
-
if (payload?.type === PayloadType.Failure) {
|
355
|
-
throw new RendezvousError("Failed", payload.reason);
|
356
|
-
}
|
357
|
-
|
358
|
-
if (payload?.type === PayloadType.Declined) {
|
359
|
-
throw new RendezvousError("User declined", ClientRendezvousFailureReason.UserDeclined);
|
360
|
-
}
|
361
|
-
|
362
|
-
if (payload?.type !== PayloadType.Success) {
|
363
|
-
await this.send<FailurePayload>({
|
364
|
-
type: PayloadType.Failure,
|
365
|
-
reason: MSC4108FailureReason.UnexpectedMessageReceived,
|
366
|
-
});
|
367
|
-
throw new RendezvousError("Unexpected message", MSC4108FailureReason.UnexpectedMessageReceived);
|
368
|
-
}
|
369
|
-
|
370
|
-
const timeout = Date.now() + 10000; // wait up to 10 seconds
|
371
|
-
do {
|
372
|
-
// is the device visible via the Homeserver?
|
373
|
-
try {
|
374
|
-
const device = await this.client?.getDevice(this.expectingNewDeviceId);
|
375
|
-
|
376
|
-
if (device) {
|
377
|
-
// if so, return the secrets
|
378
|
-
const secretsBundle = await this.client!.getCrypto()!.exportSecretsBundle!();
|
379
|
-
if (this.channel.cancelled) {
|
380
|
-
throw new RendezvousError("User cancelled", MSC4108FailureReason.UserCancelled);
|
381
|
-
}
|
382
|
-
// send secrets
|
383
|
-
await this.send<SecretsPayload>({
|
384
|
-
type: PayloadType.Secrets,
|
385
|
-
...secretsBundle,
|
386
|
-
});
|
387
|
-
return { secrets: secretsBundle };
|
388
|
-
// let the other side close the rendezvous session
|
389
|
-
}
|
390
|
-
} catch (err: MatrixError | unknown) {
|
391
|
-
if (err instanceof MatrixError && err.httpStatus === 404) {
|
392
|
-
// not found, so keep waiting until timeout
|
393
|
-
} else {
|
394
|
-
throw err;
|
395
|
-
}
|
396
|
-
}
|
397
|
-
await sleep(1000);
|
398
|
-
} while (Date.now() < timeout);
|
399
|
-
|
400
|
-
await this.send<FailurePayload>({
|
401
|
-
type: PayloadType.Failure,
|
402
|
-
reason: MSC4108FailureReason.DeviceNotFound,
|
403
|
-
});
|
404
|
-
throw new RendezvousError("New device not found", MSC4108FailureReason.DeviceNotFound);
|
405
|
-
}
|
406
|
-
}
|
407
|
-
|
408
|
-
private async receive<T extends MSC4108Payload>(): Promise<T | FailurePayload | undefined> {
|
409
|
-
return (await this.channel.secureReceive()) as T | undefined;
|
410
|
-
}
|
411
|
-
|
412
|
-
private async send<T extends MSC4108Payload>(payload: T): Promise<void> {
|
413
|
-
await this.channel.secureSend(payload);
|
414
|
-
}
|
415
|
-
|
416
|
-
/**
|
417
|
-
* Decline the login on the existing device.
|
418
|
-
*/
|
419
|
-
public async declineLoginOnExistingDevice(): Promise<void> {
|
420
|
-
if (!this.isExistingDevice) {
|
421
|
-
throw new Error("Can only decline login on existing device");
|
422
|
-
}
|
423
|
-
await this.send<FailurePayload>({
|
424
|
-
type: PayloadType.Failure,
|
425
|
-
reason: MSC4108FailureReason.UserCancelled,
|
426
|
-
});
|
427
|
-
}
|
428
|
-
|
429
|
-
/**
|
430
|
-
* Cancels the rendezvous session.
|
431
|
-
* @param reason the reason for the cancellation
|
432
|
-
*/
|
433
|
-
public async cancel(reason: MSC4108FailureReason | ClientRendezvousFailureReason): Promise<void> {
|
434
|
-
this.onFailure?.(reason);
|
435
|
-
await this.channel.cancel(reason);
|
436
|
-
}
|
437
|
-
|
438
|
-
/**
|
439
|
-
* Closes the rendezvous session.
|
440
|
-
*/
|
441
|
-
public async close(): Promise<void> {
|
442
|
-
await this.channel.close();
|
443
|
-
}
|
444
|
-
}
|