matrix-js-sdk 41.5.0 → 41.6.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/CHANGELOG.md +7 -0
- package/lib/ReEmitter.js +1 -1
- package/lib/ReEmitter.js.map +1 -1
- package/lib/ToDeviceMessageQueue.js +2 -2
- package/lib/ToDeviceMessageQueue.js.map +1 -1
- package/lib/autodiscovery.js +0 -1
- package/lib/autodiscovery.js.map +1 -1
- package/lib/client.js +112 -165
- package/lib/client.js.map +1 -1
- package/lib/common-crypto/CryptoBackend.js +0 -2
- package/lib/common-crypto/CryptoBackend.js.map +1 -1
- package/lib/content-helpers.js +3 -5
- package/lib/content-helpers.js.map +1 -1
- package/lib/content-repo.js +7 -1
- package/lib/content-repo.js.map +1 -1
- package/lib/crypto/store/indexeddb-crypto-store-backend.js +9 -11
- package/lib/crypto/store/indexeddb-crypto-store-backend.js.map +1 -1
- package/lib/crypto/store/indexeddb-crypto-store.js +0 -2
- package/lib/crypto/store/indexeddb-crypto-store.js.map +1 -1
- package/lib/crypto/store/localStorage-crypto-store.js +11 -9
- package/lib/crypto/store/localStorage-crypto-store.js.map +1 -1
- package/lib/crypto/store/memory-crypto-store.js +11 -9
- package/lib/crypto/store/memory-crypto-store.js.map +1 -1
- package/lib/crypto-api/index.js +58 -58
- package/lib/crypto-api/index.js.map +1 -1
- package/lib/embedded.js +29 -45
- package/lib/embedded.js.map +1 -1
- package/lib/extensible_events_v1/MessageEvent.js +15 -15
- package/lib/extensible_events_v1/MessageEvent.js.map +1 -1
- package/lib/extensible_events_v1/PollEndEvent.js +8 -8
- package/lib/extensible_events_v1/PollEndEvent.js.map +1 -1
- package/lib/extensible_events_v1/PollResponseEvent.js +0 -1
- package/lib/extensible_events_v1/PollResponseEvent.js.map +1 -1
- package/lib/extensible_events_v1/PollStartEvent.js +28 -28
- package/lib/extensible_events_v1/PollStartEvent.js.map +1 -1
- package/lib/feature.js +5 -1
- package/lib/feature.js.map +1 -1
- package/lib/filter-component.js +4 -1
- package/lib/filter-component.js.map +1 -1
- package/lib/filter.js +1 -3
- package/lib/filter.js.map +1 -1
- package/lib/http-api/errors.js +20 -16
- package/lib/http-api/errors.js.map +1 -1
- package/lib/http-api/fetch.js +4 -6
- package/lib/http-api/fetch.js.map +1 -1
- package/lib/http-api/refresh.js +10 -12
- package/lib/http-api/refresh.js.map +1 -1
- package/lib/interactive-auth.js +1 -11
- package/lib/interactive-auth.js.map +1 -1
- package/lib/logger.js +0 -2
- package/lib/logger.js.map +1 -1
- package/lib/matrixrtc/CallMembership.js +43 -57
- package/lib/matrixrtc/CallMembership.js.map +1 -1
- package/lib/matrixrtc/MatrixRTCSession.js +19 -24
- package/lib/matrixrtc/MatrixRTCSession.js.map +1 -1
- package/lib/matrixrtc/MatrixRTCSessionManager.js +2 -3
- package/lib/matrixrtc/MatrixRTCSessionManager.js.map +1 -1
- package/lib/matrixrtc/MembershipManager.js +23 -30
- package/lib/matrixrtc/MembershipManager.js.map +1 -1
- package/lib/matrixrtc/MembershipManagerActionScheduler.js +1 -2
- package/lib/matrixrtc/MembershipManagerActionScheduler.js.map +1 -1
- package/lib/matrixrtc/RTCEncryptionManager.js +8 -11
- package/lib/matrixrtc/RTCEncryptionManager.js.map +1 -1
- package/lib/matrixrtc/ToDeviceKeyTransport.js +4 -4
- package/lib/matrixrtc/ToDeviceKeyTransport.js.map +1 -1
- package/lib/matrixrtc/utils.js +7 -1
- package/lib/matrixrtc/utils.js.map +1 -1
- package/lib/models/MSC3089TreeSpace.js +5 -7
- package/lib/models/MSC3089TreeSpace.js.map +1 -1
- package/lib/models/beacon.js +5 -11
- package/lib/models/beacon.js.map +1 -1
- package/lib/models/device.js +0 -7
- package/lib/models/device.js.map +1 -1
- package/lib/models/event-context.js +1 -2
- package/lib/models/event-context.js.map +1 -1
- package/lib/models/event-timeline-set.js +16 -26
- package/lib/models/event-timeline-set.js.map +1 -1
- package/lib/models/event-timeline.js +8 -15
- package/lib/models/event-timeline.js.map +1 -1
- package/lib/models/event.js +20 -37
- package/lib/models/event.js.map +1 -1
- package/lib/models/invites-ignorer.js +8 -12
- package/lib/models/invites-ignorer.js.map +1 -1
- package/lib/models/poll.js +7 -13
- package/lib/models/poll.js.map +1 -1
- package/lib/models/read-receipt.js +8 -4
- package/lib/models/read-receipt.js.map +1 -1
- package/lib/models/related-relations.js +0 -2
- package/lib/models/related-relations.js.map +1 -1
- package/lib/models/relations-container.js +4 -6
- package/lib/models/relations-container.js.map +1 -1
- package/lib/models/relations.js +7 -10
- package/lib/models/relations.js.map +1 -1
- package/lib/models/room-member.js +2 -24
- package/lib/models/room-member.js.map +1 -1
- package/lib/models/room-receipts.js +25 -22
- package/lib/models/room-receipts.js.map +1 -1
- package/lib/models/room-state.js +2 -2
- package/lib/models/room-state.js.map +1 -1
- package/lib/models/room-sticky-events.js +20 -5
- package/lib/models/room-sticky-events.js.map +1 -1
- package/lib/models/room.js +82 -105
- package/lib/models/room.js.map +1 -1
- package/lib/models/thread.js +12 -57
- package/lib/models/thread.js.map +1 -1
- package/lib/models/user.js +1 -20
- package/lib/models/user.js.map +1 -1
- package/lib/oidc/authorize.js +23 -32
- package/lib/oidc/authorize.js.map +1 -1
- package/lib/oidc/tokenRefresher.js +8 -11
- package/lib/oidc/tokenRefresher.js.map +1 -1
- package/lib/pushprocessor.js +8 -5
- package/lib/pushprocessor.js.map +1 -1
- package/lib/receipt-accumulator.js +12 -3
- package/lib/receipt-accumulator.js.map +1 -1
- package/lib/rendezvous/MSC4108SignInWithQR.d.ts.map +1 -1
- package/lib/rendezvous/MSC4108SignInWithQR.js +10 -23
- package/lib/rendezvous/MSC4108SignInWithQR.js.map +1 -1
- package/lib/rendezvous/channels/MSC4108SecureChannel.js +5 -10
- package/lib/rendezvous/channels/MSC4108SecureChannel.js.map +1 -1
- package/lib/rendezvous/transports/MSC4108RendezvousSession.js +5 -15
- package/lib/rendezvous/transports/MSC4108RendezvousSession.js.map +1 -1
- package/lib/room-hierarchy.js +7 -12
- package/lib/room-hierarchy.js.map +1 -1
- package/lib/rust-crypto/DehydratedDeviceManager.js +2 -3
- package/lib/rust-crypto/DehydratedDeviceManager.js.map +1 -1
- package/lib/rust-crypto/KeyClaimManager.js +1 -2
- package/lib/rust-crypto/KeyClaimManager.js.map +1 -1
- package/lib/rust-crypto/OutgoingRequestProcessor.js +11 -4
- package/lib/rust-crypto/OutgoingRequestProcessor.js.map +1 -1
- package/lib/rust-crypto/OutgoingRequestsManager.js +12 -12
- package/lib/rust-crypto/OutgoingRequestsManager.js.map +1 -1
- package/lib/rust-crypto/PerSessionKeyBackupDownloader.js +3 -5
- package/lib/rust-crypto/PerSessionKeyBackupDownloader.js.map +1 -1
- package/lib/rust-crypto/RoomEncryptor.js +6 -6
- package/lib/rust-crypto/RoomEncryptor.js.map +1 -1
- package/lib/rust-crypto/backup.js +22 -16
- package/lib/rust-crypto/backup.js.map +1 -1
- package/lib/rust-crypto/device-converter.js +13 -4
- package/lib/rust-crypto/device-converter.js.map +1 -1
- package/lib/rust-crypto/index.js +1 -3
- package/lib/rust-crypto/index.js.map +1 -1
- package/lib/rust-crypto/libolm_migration.js +13 -15
- package/lib/rust-crypto/libolm_migration.js.map +1 -1
- package/lib/rust-crypto/rust-crypto.js +52 -59
- package/lib/rust-crypto/rust-crypto.js.map +1 -1
- package/lib/rust-crypto/verification.js +10 -10
- package/lib/rust-crypto/verification.js.map +1 -1
- package/lib/scheduler.js +2 -2
- package/lib/scheduler.js.map +1 -1
- package/lib/secret-storage.js +16 -10
- package/lib/secret-storage.js.map +1 -1
- package/lib/serverCapabilities.js +2 -5
- package/lib/serverCapabilities.js.map +1 -1
- package/lib/sliding-sync-sdk.js +4 -9
- package/lib/sliding-sync-sdk.js.map +1 -1
- package/lib/sliding-sync.js +4 -9
- package/lib/sliding-sync.js.map +1 -1
- package/lib/store/indexeddb-local-backend.js +13 -8
- package/lib/store/indexeddb-local-backend.js.map +1 -1
- package/lib/store/indexeddb-remote-backend.js +6 -7
- package/lib/store/indexeddb-remote-backend.js.map +1 -1
- package/lib/store/indexeddb-store-worker.js +1 -2
- package/lib/store/indexeddb-store-worker.js.map +1 -1
- package/lib/store/indexeddb.js +4 -2
- package/lib/store/indexeddb.js.map +1 -1
- package/lib/store/memory.js +0 -4
- package/lib/store/memory.js.map +1 -1
- package/lib/sync-accumulator.js +2 -4
- package/lib/sync-accumulator.js.map +1 -1
- package/lib/sync.js +36 -43
- package/lib/sync.js.map +1 -1
- package/lib/timeline-window.js +2 -6
- package/lib/timeline-window.js.map +1 -1
- package/lib/utils/decryptAESSecretStorageItem.js +5 -1
- package/lib/utils/decryptAESSecretStorageItem.js.map +1 -1
- package/lib/utils/encryptAESSecretStorageItem.js +5 -1
- package/lib/utils/encryptAESSecretStorageItem.js.map +1 -1
- package/lib/utils.js +35 -20
- package/lib/utils.js.map +1 -1
- package/lib/webrtc/call.js +13 -45
- package/lib/webrtc/call.js.map +1 -1
- package/lib/webrtc/callEventHandler.js +0 -5
- package/lib/webrtc/callEventHandler.js.map +1 -1
- package/lib/webrtc/callFeed.js +0 -15
- package/lib/webrtc/callFeed.js.map +1 -1
- package/lib/webrtc/groupCall.js +82 -89
- package/lib/webrtc/groupCall.js.map +1 -1
- package/lib/webrtc/groupCallEventHandler.js +6 -7
- package/lib/webrtc/groupCallEventHandler.js.map +1 -1
- package/lib/webrtc/mediaHandler.js +8 -15
- package/lib/webrtc/mediaHandler.js.map +1 -1
- package/lib/webrtc/stats/callStatsReportGatherer.js +2 -5
- package/lib/webrtc/stats/callStatsReportGatherer.js.map +1 -1
- package/lib/webrtc/stats/connectionStatsReportBuilder.js +5 -1
- package/lib/webrtc/stats/connectionStatsReportBuilder.js.map +1 -1
- package/lib/webrtc/stats/groupCallStats.js +3 -4
- package/lib/webrtc/stats/groupCallStats.js.map +1 -1
- package/lib/webrtc/stats/media/mediaTrackStats.js +3 -3
- package/lib/webrtc/stats/media/mediaTrackStats.js.map +1 -1
- package/lib/webrtc/stats/media/mediaTrackStatsHandler.js +1 -1
- package/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map +1 -1
- package/package.json +3 -3
- package/src/rendezvous/MSC4108SignInWithQR.ts +2 -1
package/lib/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","names":["unhomoglyph","promiseRetry","M_TIMESTAMP","ReceiptType","interns","Map","internaliseString","str","String","toString","has","set","get","encodeParams","params","urlSearchParams","searchParams","URLSearchParams","_loop","key","val","undefined","Array","isArray","forEach","v","append","Object","entries","replaceParam","stable","unstable","dict","result","_objectSpread","decodeParams","query","o","keys","getAll","length","encodeUri","pathTemplate","variables","hasOwnProperty","value","replace","encodeURIComponent","removeElement","array","fn","reverse","i","splice","isFunction","prototype","call","checkObjectHasKeys","obj","Error","deepCopy","JSON","parse","stringify","deepCompare","x","y","isNaN","constructor","name","RegExp","Date","p","deepSortedObjectEntries","pairs","k","push","sort","a","b","lexicographicCompare","isNumber","isFinite","removeHiddenChars","normalize","removeHiddenCharsRegex","removeDirectionOverrideChars","toLowerCase","escapeRegExp","string","globToRegexp","glob","ensureNoTrailingSlash","url","endsWith","slice","sleep","ms","Promise","resolve","setTimeout","logDuration","_x","_x2","_x3","_logDuration","apply","arguments","_asyncToGenerator","logger","block","start","now","end","debug","concat","logDurationSync","immediate","isNullOrUndefined","promiseMapSeries","_x4","_x5","_promiseMapSeries","promises","promiseTry","chunkPromises","_x6","_x7","_chunkPromises","fns","chunkSize","results","all","map","simpleRetryOperation","promiseFn","shouldRetry","attempt","retries","Infinity","_ref","error","factor","minTimeout","maxTimeout","DEFAULT_ALPHABET","c","fromCharCode","alphabetPad","s","n","alphabet","padEnd","baseToString","len","BigInt","_alphabet","Number","d","r","Math","abs","stringToBase","j","charIndex","charCodeAt","averageBetweenStrings","padN","max","baseA","baseB","avg","nextString","prevString","recursivelyAssign","target","source","ignoreNullish","sourceKey","sourceValue","safeSet","getContentTimestampWithFallback","event","_M_TIMESTAMP$findIn","findIn","getContent","sortEventsByLatestContentTimestamp","left","right","isSupportedReceiptType","receiptType","Read","ReadPrivate","includes","mapsEqual","eq","v1","v2","size","processMapToObjectValue","recursiveMapToObject","targetMap","fromEntries","unsafeProp","prop","noUnsafeEventProps","room_id","sender","event_id","MapWithDefault","createDefault","getOrCreate"],"sources":["../src/utils.ts"],"sourcesContent":["/*\nCopyright 2015, 2016, 2019, 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module.\n */\n\nimport unhomoglyph from \"unhomoglyph\";\nimport promiseRetry from \"p-retry\";\n\nimport { type IEvent, type MatrixEvent } from \"./models/event.ts\";\nimport { M_TIMESTAMP } from \"./@types/location.ts\";\nimport { ReceiptType } from \"./@types/read_receipts.ts\";\nimport { type BaseLogger } from \"./logger.ts\";\n\nconst interns = new Map<string, string>();\n\n/**\n * Internalises a string, reusing a known pointer or storing the pointer\n * if needed for future strings.\n * @param str - The string to internalise.\n * @returns The internalised string.\n */\nexport function internaliseString(str: string): string {\n // Unwrap strings before entering the map, if we somehow got a wrapped\n // string as our input. This should only happen from tests.\n if ((str as unknown) instanceof String) {\n str = str.toString();\n }\n\n // Check the map to see if we can store the value\n if (!interns.has(str)) {\n interns.set(str, str);\n }\n\n // Return any cached string reference\n return interns.get(str)!;\n}\n\n/**\n * Encode a dictionary of query parameters.\n * Omits any undefined/null values.\n * @param params - A dict of key/values to encode e.g.\n * `{\"foo\": \"bar\", \"baz\": \"taz\"}`\n * @returns The encoded string e.g. foo=bar&baz=taz\n */\nexport function encodeParams(params: QueryDict, urlSearchParams?: URLSearchParams): URLSearchParams {\n const searchParams = urlSearchParams ?? new URLSearchParams();\n for (const [key, val] of Object.entries(params)) {\n if (val !== undefined && val !== null) {\n if (Array.isArray(val)) {\n val.forEach((v) => {\n searchParams.append(key, String(v));\n });\n } else {\n searchParams.append(key, String(val));\n }\n }\n }\n return searchParams;\n}\n\nexport type QueryDict = Record<string, string[] | string | number | boolean | undefined>;\n\n/**\n * Replace a stable parameter with the unstable naming for params\n */\nexport function replaceParam(stable: string, unstable: string, dict: QueryDict): QueryDict {\n const result = {\n ...dict,\n [unstable]: dict[stable],\n };\n delete result[stable];\n return result;\n}\n\n/**\n * Decode a query string in `application/x-www-form-urlencoded` format.\n * @param query - A query string to decode e.g.\n * foo=bar&via=server1&server2\n * @returns The decoded object, if any keys occurred multiple times\n * then the value will be an array of strings, else it will be an array.\n * This behaviour matches Node's qs.parse but is built on URLSearchParams\n * for native web compatibility\n */\nexport function decodeParams(query: string): Record<string, string | string[]> {\n const o: Record<string, string | string[]> = {};\n const params = new URLSearchParams(query);\n for (const key of params.keys()) {\n const val = params.getAll(key);\n o[key] = val.length === 1 ? val[0] : val;\n }\n return o;\n}\n\n/**\n * Encodes a URI according to a set of template variables. Variables will be\n * passed through encodeURIComponent.\n * @param pathTemplate - The path with template variables e.g. '/foo/$bar'.\n * @param variables - The key/value pairs to replace the template\n * variables with. E.g. `{ \"$bar\": \"baz\" }`.\n * @returns The result of replacing all template variables e.g. '/foo/baz'.\n */\nexport function encodeUri(pathTemplate: string, variables: Record<string, string | null | undefined>): string {\n for (const key in variables) {\n if (!variables.hasOwnProperty(key)) {\n continue;\n }\n const value = variables[key];\n if (value === undefined || value === null) {\n continue;\n }\n pathTemplate = pathTemplate.replace(key, encodeURIComponent(value));\n }\n return pathTemplate;\n}\n\n/**\n * The removeElement() method removes the first element in the array that\n * satisfies (returns true) the provided testing function.\n * @param array - The array.\n * @param fn - Function to execute on each value in the array, with the\n * function signature `fn(element, index, array)`. Return true to\n * remove this element and break.\n * @param reverse - True to search in reverse order.\n * @returns True if an element was removed.\n */\nexport function removeElement<T>(array: T[], fn: (t: T, i?: number, a?: T[]) => boolean, reverse?: boolean): boolean {\n let i: number;\n if (reverse) {\n for (i = array.length - 1; i >= 0; i--) {\n if (fn(array[i], i, array)) {\n array.splice(i, 1);\n return true;\n }\n }\n } else {\n for (i = 0; i < array.length; i++) {\n if (fn(array[i], i, array)) {\n array.splice(i, 1);\n return true;\n }\n }\n }\n return false;\n}\n\n/**\n * Checks if the given thing is a function.\n * @param value - The thing to check.\n * @returns True if it is a function.\n */\nexport function isFunction(value: any): boolean {\n return Object.prototype.toString.call(value) === \"[object Function]\";\n}\n\n/**\n * Checks that the given object has the specified keys.\n * @param obj - The object to check.\n * @param keys - The list of keys that 'obj' must have.\n * @throws If the object is missing keys.\n */\n// note using 'keys' here would shadow the 'keys' function defined above\nexport function checkObjectHasKeys(obj: object, keys: string[]): void {\n for (const key of keys) {\n if (!obj.hasOwnProperty(key)) {\n throw new Error(\"Missing required key: \" + key);\n }\n }\n}\n\n/**\n * Deep copy the given object. The object MUST NOT have circular references and\n * MUST NOT have functions.\n * @param obj - The object to deep copy.\n * @returns A copy of the object without any references to the original.\n */\nexport function deepCopy<T>(obj: T): T {\n return JSON.parse(JSON.stringify(obj));\n}\n\n/**\n * Compare two objects for equality. The objects MUST NOT have circular references.\n *\n * @param x - The first object to compare.\n * @param y - The second object to compare.\n *\n * @returns true if the two objects are equal\n */\nexport function deepCompare(x: any, y: any): boolean {\n // Inspired by\n // http://stackoverflow.com/questions/1068834/object-comparison-in-javascript#1144249\n\n // Compare primitives and functions.\n // Also check if both arguments link to the same object.\n if (x === y) {\n return true;\n }\n\n if (typeof x !== typeof y) {\n return false;\n }\n\n // special-case NaN (since NaN !== NaN)\n if (typeof x === \"number\" && isNaN(x) && isNaN(y)) {\n return true;\n }\n\n // special-case null (since typeof null == 'object', but null.constructor\n // throws)\n if (x === null || y === null) {\n return x === y;\n }\n\n // everything else is either an unequal primitive, or an object\n // XXX: this check has been temporarily tweaked due to issues in the jest test environment,\n // this will be reverted as part of the migration to vitest\n if (\n x.constructor.name !== \"Object\" &&\n x.constructor.name !== \"RegExp\" &&\n x.constructor.name !== \"Date\" &&\n x.constructor.name !== \"Array\"\n ) {\n return false;\n }\n\n // check they are the same type of object\n // XXX: this check has been temporarily tweaked due to issues in the jest test environment,\n // this will be reverted as part of the migration to vitest\n if (x.prototype !== y.prototype) {\n return false;\n }\n\n // special-casing for some special types of object\n if (x instanceof RegExp || x instanceof Date) {\n return x.toString() === y.toString();\n }\n\n // the object algorithm works for Array, but it's sub-optimal.\n if (Array.isArray(x)) {\n if (x.length !== y.length) {\n return false;\n }\n\n for (let i = 0; i < x.length; i++) {\n if (!deepCompare(x[i], y[i])) {\n return false;\n }\n }\n } else {\n // check that all of y's direct keys are in x\n for (const p in y) {\n if (y.hasOwnProperty(p) !== x.hasOwnProperty(p)) {\n return false;\n }\n }\n\n // finally, compare each of x's keys with y\n for (const p in x) {\n if (y.hasOwnProperty(p) !== x.hasOwnProperty(p) || !deepCompare(x[p], y[p])) {\n return false;\n }\n }\n }\n return true;\n}\n\n// Dev note: This returns an array of tuples, but jsdoc doesn't like that. https://github.com/jsdoc/jsdoc/issues/1703\n/**\n * Creates an array of object properties/values (entries) then\n * sorts the result by key, recursively. The input object must\n * ensure it does not have loops. If the input is not an object\n * then it will be returned as-is.\n * @param obj - The object to get entries of\n * @returns The entries, sorted by key.\n */\nexport function deepSortedObjectEntries(obj: any): [string, any][] {\n if (typeof obj !== \"object\") return obj;\n\n // Apparently these are object types...\n if (obj === null || obj === undefined || Array.isArray(obj)) return obj;\n\n const pairs: [string, any][] = [];\n for (const [k, v] of Object.entries(obj)) {\n pairs.push([k, deepSortedObjectEntries(v)]);\n }\n\n // lexicographicCompare is faster than localeCompare, so let's use that.\n pairs.sort((a, b) => lexicographicCompare(a[0], b[0]));\n\n return pairs;\n}\n\n/**\n * Returns whether the given value is a finite number without type-coercion\n *\n * @param value - the value to test\n * @returns whether or not value is a finite number without type-coercion\n */\nexport function isNumber(value: any): value is number {\n return typeof value === \"number\" && isFinite(value);\n}\n\n/**\n * Removes zero width chars, diacritics and whitespace from the string\n * Also applies an unhomoglyph on the string, to prevent similar looking chars\n * @param str - the string to remove hidden characters from\n * @returns a string with the hidden characters removed\n */\nexport function removeHiddenChars(str: string): string {\n if (typeof str === \"string\") {\n return unhomoglyph(str.normalize(\"NFD\").replace(removeHiddenCharsRegex, \"\"));\n }\n return \"\";\n}\n\n/**\n * Removes the direction override characters from a string\n * @returns string with chars removed\n */\nexport function removeDirectionOverrideChars(str: string): string {\n if (typeof str === \"string\") {\n return str.replace(/[\\u202d-\\u202e]/g, \"\");\n }\n return \"\";\n}\n\nexport function normalize(str: string): string {\n // Note: we have to match the filter with the removeHiddenChars() because the\n // function strips spaces and other characters (M becomes RN for example, in lowercase).\n return (\n removeHiddenChars(str.toLowerCase())\n // Strip all punctuation\n .replace(/[\\\\'!\"#$%&()*+,\\-./:;<=>?@[\\]^_`{|}~\\u2000-\\u206f\\u2e00-\\u2e7f]/g, \"\")\n // We also doubly convert to lowercase to work around oddities of the library.\n .toLowerCase()\n );\n}\n\n// Regex matching bunch of unicode control characters and otherwise misleading/invisible characters.\n// Includes:\n// various width spaces U+2000 - U+200D\n// LTR and RTL marks U+200E and U+200F\n// LTR/RTL and other directional formatting marks U+202A - U+202F\n// Arabic Letter RTL mark U+061C\n// Combining characters U+0300 - U+036F\n// Zero width no-break space (BOM) U+FEFF\n// Blank/invisible characters (U2800, U2062-U2063)\n// eslint-disable-next-line no-misleading-character-class\nconst removeHiddenCharsRegex = /[\\u2000-\\u200F\\u202A-\\u202F\\u0300-\\u036F\\uFEFF\\u061C\\u2800\\u2062-\\u2063\\s]/g;\n\nexport function escapeRegExp(string: string): string {\n return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\n/**\n * Converts Matrix glob-style string to a regular expression\n * https://spec.matrix.org/v1.7/appendices/#glob-style-matching\n * @param glob - Matrix glob-style string\n * @returns regular expression\n */\nexport function globToRegexp(glob: string): string {\n return escapeRegExp(glob).replace(/\\\\\\*/g, \".*\").replace(/\\?/g, \".\");\n}\n\nexport function ensureNoTrailingSlash(url: string): string;\nexport function ensureNoTrailingSlash(url: undefined): undefined;\nexport function ensureNoTrailingSlash(url?: string): string | undefined;\nexport function ensureNoTrailingSlash(url?: string): string | undefined {\n if (url?.endsWith(\"/\")) {\n return url.slice(0, -1);\n } else {\n return url;\n }\n}\n\n/**\n * Returns a promise which resolves with a given value after the given number of ms\n */\nexport function sleep<T>(ms: number, value?: T): Promise<T> {\n return new Promise((resolve) => {\n setTimeout(resolve, ms, value);\n });\n}\n\n/**\n * Utility to log the duration of a promise.\n *\n * @param logger - The logger to log to.\n * @param name - The name of the operation.\n * @param block - The block to execute.\n */\nexport async function logDuration<T>(logger: BaseLogger, name: string, block: () => Promise<T>): Promise<T> {\n const start = Date.now();\n try {\n return await block();\n } finally {\n const end = Date.now();\n logger.debug(`[Perf]: ${name} took ${end - start}ms`);\n }\n}\n\n/**\n * Utility to log the duration of a synchronous block.\n *\n * @param logger - The logger to log to.\n * @param name - The name of the operation.\n * @param block - The block to execute.\n */\nexport function logDurationSync<T>(logger: BaseLogger, name: string, block: () => T): T {\n const start = Date.now();\n try {\n return block();\n } finally {\n const end = Date.now();\n logger.debug(`[Perf]: ${name} took ${end - start}ms`);\n }\n}\n\n/**\n * Promise/async version of {@link setImmediate}.\n *\n * Implementation is based on `setTimeout` for wider compatibility.\n * @deprecated Use {@link sleep} instead.\n */\nexport function immediate(): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve));\n}\n\nexport function isNullOrUndefined(val: any): boolean {\n return val === null || val === undefined;\n}\n\nexport async function promiseMapSeries<T>(\n promises: Array<T | Promise<T>>,\n fn: (t: T) => Promise<unknown> | undefined, // if async we don't care about the type as we only await resolution\n): Promise<void> {\n for (const o of promises) {\n await fn(await o);\n }\n}\n\nexport function promiseTry<T>(fn: () => T | Promise<T>): Promise<T> {\n return Promise.resolve(fn());\n}\n\n// Creates and awaits all promises, running no more than `chunkSize` at the same time\nexport async function chunkPromises<T>(fns: (() => Promise<T>)[], chunkSize: number): Promise<T[]> {\n const results: T[] = [];\n for (let i = 0; i < fns.length; i += chunkSize) {\n results.push(...(await Promise.all(fns.slice(i, i + chunkSize).map((fn) => fn()))));\n }\n return results;\n}\n\n/**\n * Retries the function until it succeeds or is interrupted. The given function must return\n * a promise which throws/rejects on error, otherwise the retry will assume the request\n * succeeded. The promise chain returned will contain the successful promise. The given function\n * should always return a new promise.\n * @param promiseFn - The function to call to get a fresh promise instance. Takes an\n * attempt count as an argument, for logging/debugging purposes.\n * @param shouldRetry - Optional function which is called with the error the latest rejection from promiseFn,\n * retrying will ba aborted if this return false.\n * @returns The promise for the retried operation.\n */\nexport function simpleRetryOperation<T>(\n promiseFn: (attempt: number) => Promise<T>,\n shouldRetry?: (e: unknown) => boolean,\n): Promise<T> {\n return promiseRetry(\n (attempt: number) => {\n return promiseFn(attempt);\n },\n {\n retries: Infinity,\n shouldRetry: shouldRetry ? ({ error }): boolean => shouldRetry(error) : undefined,\n factor: 2,\n minTimeout: 3000, // ms\n maxTimeout: 15000, // ms\n },\n );\n}\n\n// String averaging inspired by https://stackoverflow.com/a/2510816\n// Dev note: We make the alphabet a string because it's easier to write syntactically\n// than arrays. Thankfully, strings implement the useful parts of the Array interface\n// anyhow.\n\n/**\n * The default alphabet used by string averaging in this SDK. This matches\n * all usefully printable ASCII characters (0x20-0x7E, inclusive).\n */\nexport const DEFAULT_ALPHABET = ((): string => {\n let str = \"\";\n for (let c = 0x20; c <= 0x7e; c++) {\n str += String.fromCharCode(c);\n }\n return str;\n})();\n\n/**\n * Pads a string using the given alphabet as a base. The returned string will be\n * padded at the end with the first character in the alphabet.\n *\n * This is intended for use with string averaging.\n * @param s - The string to pad.\n * @param n - The length to pad to.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The padded string.\n */\nexport function alphabetPad(s: string, n: number, alphabet = DEFAULT_ALPHABET): string {\n return s.padEnd(n, alphabet[0]);\n}\n\n/**\n * Converts a baseN number to a string, where N is the alphabet's length.\n *\n * This is intended for use with string averaging.\n * @param n - The baseN number.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The baseN number encoded as a string from the alphabet.\n */\nexport function baseToString(n: bigint, alphabet = DEFAULT_ALPHABET): string {\n // Developer note: the stringToBase() function offsets the character set by 1 so that repeated\n // characters (ie: \"aaaaaa\" in a..z) don't come out as zero. We have to reverse this here as\n // otherwise we'll be wrong in our conversion. Undoing a +1 before an exponent isn't very fun\n // though, so we rely on a lengthy amount of `x - 1` and integer division rules to reach a\n // sane state. This also means we have to do rollover detection: see below.\n\n const len = BigInt(alphabet.length);\n if (n <= len) {\n return alphabet[Number(n) - 1] ?? \"\";\n }\n\n let d = n / len;\n let r = Number(n % len) - 1;\n\n // Rollover detection: if the remainder is negative, it means that the string needs\n // to roll over by 1 character downwards (ie: in a..z, the previous to \"aaa\" would be\n // \"zz\").\n if (r < 0) {\n d -= BigInt(Math.abs(r)); // abs() is just to be clear what we're doing. Could also `+= r`.\n r = Number(len) - 1;\n }\n\n return baseToString(d, alphabet) + alphabet[r];\n}\n\n/**\n * Converts a string to a baseN number, where N is the alphabet's length.\n *\n * This is intended for use with string averaging.\n * @param s - The string to convert to a number.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The baseN number.\n */\nexport function stringToBase(s: string, alphabet = DEFAULT_ALPHABET): bigint {\n const len = BigInt(alphabet.length);\n\n // In our conversion to baseN we do a couple performance optimizations to avoid using\n // excess CPU and such. To create baseN numbers, the input string needs to be reversed\n // so the exponents stack up appropriately, as the last character in the unreversed\n // string has less impact than the first character (in \"abc\" the A is a lot more important\n // for lexicographic sorts). We also do a trick with the character codes to optimize the\n // alphabet lookup, avoiding an index scan of `alphabet.indexOf(reversedStr[i])` - we know\n // that the alphabet and (theoretically) the input string are constrained on character sets\n // and thus can do simple subtraction to end up with the same result.\n\n // Developer caution: we carefully cast to BigInt here to avoid losing precision. We cannot\n // rely on Math.pow() (for example) to be capable of handling our insane numbers.\n\n let result = BigInt(0);\n for (let i = s.length - 1, j = BigInt(0); i >= 0; i--, j++) {\n const charIndex = s.charCodeAt(i) - alphabet.charCodeAt(0);\n\n // We add 1 to the char index to offset the whole numbering scheme. We unpack this in\n // the baseToString() function.\n result += BigInt(1 + charIndex) * len ** j;\n }\n return result;\n}\n\n/**\n * Averages two strings, returning the midpoint between them. This is accomplished by\n * converting both to baseN numbers (where N is the alphabet's length) then averaging\n * those before re-encoding as a string.\n * @param a - The first string.\n * @param b - The second string.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The midpoint between the strings, as a string.\n */\nexport function averageBetweenStrings(a: string, b: string, alphabet = DEFAULT_ALPHABET): string {\n const padN = Math.max(a.length, b.length);\n const baseA = stringToBase(alphabetPad(a, padN, alphabet), alphabet);\n const baseB = stringToBase(alphabetPad(b, padN, alphabet), alphabet);\n const avg = (baseA + baseB) / BigInt(2);\n\n // Detect integer division conflicts. This happens when two numbers are divided too close so\n // we lose a .5 precision. We need to add a padding character in these cases.\n if (avg === baseA || avg == baseB) {\n return baseToString(avg, alphabet) + alphabet[0];\n }\n\n return baseToString(avg, alphabet);\n}\n\n/**\n * Finds the next string using the alphabet provided. This is done by converting the\n * string to a baseN number, where N is the alphabet's length, then adding 1 before\n * converting back to a string.\n * @param s - The string to start at.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The string which follows the input string.\n */\nexport function nextString(s: string, alphabet = DEFAULT_ALPHABET): string {\n return baseToString(stringToBase(s, alphabet) + BigInt(1), alphabet);\n}\n\n/**\n * Finds the previous string using the alphabet provided. This is done by converting the\n * string to a baseN number, where N is the alphabet's length, then subtracting 1 before\n * converting back to a string.\n * @param s - The string to start at.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The string which precedes the input string.\n */\nexport function prevString(s: string, alphabet = DEFAULT_ALPHABET): string {\n return baseToString(stringToBase(s, alphabet) - BigInt(1), alphabet);\n}\n\n/**\n * Compares strings lexicographically as a sort-safe function.\n * @param a - The first (reference) string.\n * @param b - The second (compare) string.\n * @returns Negative if the reference string is before the compare string;\n * positive if the reference string is after; and zero if equal.\n */\nexport function lexicographicCompare(a: string, b: string): number {\n // Dev note: this exists because I'm sad that you can use math operators on strings, so I've\n // hidden the operation in this function.\n if (a < b) {\n return -1;\n } else if (a > b) {\n return 1;\n } else {\n return 0;\n }\n}\n\n/**\n * This function is similar to Object.assign() but it assigns recursively and\n * allows you to ignore nullish values from the source\n *\n * @returns the target object\n */\nexport function recursivelyAssign<T1 extends T2, T2 extends Record<string, any>>(\n target: T1,\n source: T2,\n ignoreNullish = false,\n): T1 & T2 {\n for (const [sourceKey, sourceValue] of Object.entries(source)) {\n if (target[sourceKey] instanceof Object && sourceValue) {\n recursivelyAssign(target[sourceKey], sourceValue);\n continue;\n }\n if ((sourceValue !== null && sourceValue !== undefined) || !ignoreNullish) {\n safeSet(target, sourceKey, sourceValue);\n continue;\n }\n }\n return target as T1 & T2;\n}\n\nfunction getContentTimestampWithFallback(event: MatrixEvent): number {\n return M_TIMESTAMP.findIn<number>(event.getContent()) ?? -1;\n}\n\n/**\n * Sort events by their content m.ts property\n * Latest timestamp first\n */\nexport function sortEventsByLatestContentTimestamp(left: MatrixEvent, right: MatrixEvent): number {\n return getContentTimestampWithFallback(right) - getContentTimestampWithFallback(left);\n}\n\nexport function isSupportedReceiptType(receiptType: string): boolean {\n return [ReceiptType.Read, ReceiptType.ReadPrivate].includes(receiptType as ReceiptType);\n}\n\n/**\n * Determines whether two maps are equal.\n * @param eq - The equivalence relation to compare values by. Defaults to strict equality.\n */\nexport function mapsEqual<K, V>(x: Map<K, V>, y: Map<K, V>, eq = (v1: V, v2: V): boolean => v1 === v2): boolean {\n if (x.size !== y.size) return false;\n for (const [k, v1] of x) {\n const v2 = y.get(k);\n if (v2 === undefined || !eq(v1, v2)) return false;\n }\n return true;\n}\n\nfunction processMapToObjectValue(value: any): any {\n if (value instanceof Map) {\n // Value is a Map. Recursively map it to an object.\n return recursiveMapToObject(value);\n } else if (Array.isArray(value)) {\n // Value is an Array. Recursively map the value (e.g. to cover Array of Arrays).\n return value.map((v) => processMapToObjectValue(v));\n } else {\n return value;\n }\n}\n\n/**\n * Recursively converts Maps to plain objects.\n * Also supports sub-lists of Maps.\n */\nexport function recursiveMapToObject(map: Map<any, any>): Record<any, any> {\n const targetMap = new Map();\n\n for (const [key, value] of map) {\n targetMap.set(key, processMapToObjectValue(value));\n }\n\n return Object.fromEntries(targetMap.entries());\n}\n\nexport function unsafeProp<K extends keyof any | undefined>(prop: K): boolean {\n return prop === \"__proto__\" || prop === \"prototype\" || prop === \"constructor\";\n}\n\nexport function safeSet<O extends Record<any, any>, K extends keyof O>(obj: O, prop: K, value: O[K]): void {\n if (unsafeProp(prop)) {\n throw new Error(\"Trying to modify prototype or constructor\");\n }\n\n obj[prop] = value;\n}\n\nexport function noUnsafeEventProps(event: Partial<IEvent>): boolean {\n return !(unsafeProp(event.room_id) || unsafeProp(event.sender) || unsafeProp(event.event_id));\n}\n\nexport class MapWithDefault<K, V> extends Map<K, V> {\n public constructor(private createDefault: () => V) {\n super();\n }\n\n /**\n * Returns the value if the key already exists.\n * If not, it creates a new value under that key using the ctor callback and returns it.\n */\n public getOrCreate(key: K): V {\n if (!this.has(key)) {\n this.set(key, this.createDefault());\n }\n\n return this.get(key)!;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"utils.js","names":["unhomoglyph","promiseRetry","M_TIMESTAMP","ReceiptType","interns","Map","internaliseString","str","String","toString","has","set","get","encodeParams","params","urlSearchParams","searchParams","URLSearchParams","_loop","_ref2","_slicedToArray","_ref3","key","val","undefined","Array","isArray","forEach","v","append","Object","entries","replaceParam","stable","unstable","dict","result","_objectSpread","decodeParams","query","o","keys","getAll","length","encodeUri","pathTemplate","variables","hasOwnProperty","value","replace","encodeURIComponent","removeElement","array","fn","reverse","i","splice","isFunction","prototype","call","checkObjectHasKeys","obj","Error","deepCopy","JSON","parse","stringify","deepCompare","x","y","isNaN","constructor","name","RegExp","Date","p","deepSortedObjectEntries","pairs","_ref6","_ref5","k","push","sort","a","b","lexicographicCompare","isNumber","isFinite","removeHiddenChars","normalize","removeHiddenCharsRegex","removeDirectionOverrideChars","toLowerCase","escapeRegExp","string","globToRegexp","glob","ensureNoTrailingSlash","url","endsWith","slice","sleep","ms","Promise","resolve","setTimeout","logDuration","_x","_x2","_x3","_logDuration","apply","arguments","_asyncToGenerator","logger","block","start","now","end","debug","concat","logDurationSync","immediate","isNullOrUndefined","promiseMapSeries","_x4","_x5","_promiseMapSeries","promises","promiseTry","chunkPromises","_x6","_x7","_chunkPromises","fns","chunkSize","results","all","map","simpleRetryOperation","promiseFn","shouldRetry","attempt","retries","Infinity","_ref7","error","factor","minTimeout","maxTimeout","DEFAULT_ALPHABET","c","fromCharCode","alphabetPad","s","n","alphabet","padEnd","baseToString","len","BigInt","_alphabet","Number","d","r","Math","abs","stringToBase","j","charIndex","charCodeAt","averageBetweenStrings","padN","max","baseA","baseB","avg","nextString","prevString","recursivelyAssign","target","source","ignoreNullish","_ref0","_ref9","sourceKey","sourceValue","safeSet","getContentTimestampWithFallback","event","_M_TIMESTAMP$findIn","findIn","getContent","sortEventsByLatestContentTimestamp","left","right","isSupportedReceiptType","receiptType","Read","ReadPrivate","includes","mapsEqual","eq","v1","v2","size","_ref11","_ref10","processMapToObjectValue","recursiveMapToObject","targetMap","_ref14","_ref13","fromEntries","unsafeProp","prop","noUnsafeEventProps","room_id","sender","event_id","MapWithDefault","createDefault","getOrCreate"],"sources":["../src/utils.ts"],"sourcesContent":["/*\nCopyright 2015, 2016, 2019, 2023 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\n/**\n * This is an internal module.\n */\n\nimport unhomoglyph from \"unhomoglyph\";\nimport promiseRetry from \"p-retry\";\n\nimport { type IEvent, type MatrixEvent } from \"./models/event.ts\";\nimport { M_TIMESTAMP } from \"./@types/location.ts\";\nimport { ReceiptType } from \"./@types/read_receipts.ts\";\nimport { type BaseLogger } from \"./logger.ts\";\n\nconst interns = new Map<string, string>();\n\n/**\n * Internalises a string, reusing a known pointer or storing the pointer\n * if needed for future strings.\n * @param str - The string to internalise.\n * @returns The internalised string.\n */\nexport function internaliseString(str: string): string {\n // Unwrap strings before entering the map, if we somehow got a wrapped\n // string as our input. This should only happen from tests.\n if ((str as unknown) instanceof String) {\n str = str.toString();\n }\n\n // Check the map to see if we can store the value\n if (!interns.has(str)) {\n interns.set(str, str);\n }\n\n // Return any cached string reference\n return interns.get(str)!;\n}\n\n/**\n * Encode a dictionary of query parameters.\n * Omits any undefined/null values.\n * @param params - A dict of key/values to encode e.g.\n * `{\"foo\": \"bar\", \"baz\": \"taz\"}`\n * @returns The encoded string e.g. foo=bar&baz=taz\n */\nexport function encodeParams(params: QueryDict, urlSearchParams?: URLSearchParams): URLSearchParams {\n const searchParams = urlSearchParams ?? new URLSearchParams();\n for (const [key, val] of Object.entries(params)) {\n if (val !== undefined && val !== null) {\n if (Array.isArray(val)) {\n val.forEach((v) => {\n searchParams.append(key, String(v));\n });\n } else {\n searchParams.append(key, String(val));\n }\n }\n }\n return searchParams;\n}\n\nexport type QueryDict = Record<string, string[] | string | number | boolean | undefined>;\n\n/**\n * Replace a stable parameter with the unstable naming for params\n */\nexport function replaceParam(stable: string, unstable: string, dict: QueryDict): QueryDict {\n const result = {\n ...dict,\n [unstable]: dict[stable],\n };\n delete result[stable];\n return result;\n}\n\n/**\n * Decode a query string in `application/x-www-form-urlencoded` format.\n * @param query - A query string to decode e.g.\n * foo=bar&via=server1&server2\n * @returns The decoded object, if any keys occurred multiple times\n * then the value will be an array of strings, else it will be an array.\n * This behaviour matches Node's qs.parse but is built on URLSearchParams\n * for native web compatibility\n */\nexport function decodeParams(query: string): Record<string, string | string[]> {\n const o: Record<string, string | string[]> = {};\n const params = new URLSearchParams(query);\n for (const key of params.keys()) {\n const val = params.getAll(key);\n o[key] = val.length === 1 ? val[0] : val;\n }\n return o;\n}\n\n/**\n * Encodes a URI according to a set of template variables. Variables will be\n * passed through encodeURIComponent.\n * @param pathTemplate - The path with template variables e.g. '/foo/$bar'.\n * @param variables - The key/value pairs to replace the template\n * variables with. E.g. `{ \"$bar\": \"baz\" }`.\n * @returns The result of replacing all template variables e.g. '/foo/baz'.\n */\nexport function encodeUri(pathTemplate: string, variables: Record<string, string | null | undefined>): string {\n for (const key in variables) {\n if (!variables.hasOwnProperty(key)) {\n continue;\n }\n const value = variables[key];\n if (value === undefined || value === null) {\n continue;\n }\n pathTemplate = pathTemplate.replace(key, encodeURIComponent(value));\n }\n return pathTemplate;\n}\n\n/**\n * The removeElement() method removes the first element in the array that\n * satisfies (returns true) the provided testing function.\n * @param array - The array.\n * @param fn - Function to execute on each value in the array, with the\n * function signature `fn(element, index, array)`. Return true to\n * remove this element and break.\n * @param reverse - True to search in reverse order.\n * @returns True if an element was removed.\n */\nexport function removeElement<T>(array: T[], fn: (t: T, i?: number, a?: T[]) => boolean, reverse?: boolean): boolean {\n let i: number;\n if (reverse) {\n for (i = array.length - 1; i >= 0; i--) {\n if (fn(array[i], i, array)) {\n array.splice(i, 1);\n return true;\n }\n }\n } else {\n for (i = 0; i < array.length; i++) {\n if (fn(array[i], i, array)) {\n array.splice(i, 1);\n return true;\n }\n }\n }\n return false;\n}\n\n/**\n * Checks if the given thing is a function.\n * @param value - The thing to check.\n * @returns True if it is a function.\n */\nexport function isFunction(value: any): boolean {\n return Object.prototype.toString.call(value) === \"[object Function]\";\n}\n\n/**\n * Checks that the given object has the specified keys.\n * @param obj - The object to check.\n * @param keys - The list of keys that 'obj' must have.\n * @throws If the object is missing keys.\n */\n// note using 'keys' here would shadow the 'keys' function defined above\nexport function checkObjectHasKeys(obj: object, keys: string[]): void {\n for (const key of keys) {\n if (!obj.hasOwnProperty(key)) {\n throw new Error(\"Missing required key: \" + key);\n }\n }\n}\n\n/**\n * Deep copy the given object. The object MUST NOT have circular references and\n * MUST NOT have functions.\n * @param obj - The object to deep copy.\n * @returns A copy of the object without any references to the original.\n */\nexport function deepCopy<T>(obj: T): T {\n return JSON.parse(JSON.stringify(obj));\n}\n\n/**\n * Compare two objects for equality. The objects MUST NOT have circular references.\n *\n * @param x - The first object to compare.\n * @param y - The second object to compare.\n *\n * @returns true if the two objects are equal\n */\nexport function deepCompare(x: any, y: any): boolean {\n // Inspired by\n // http://stackoverflow.com/questions/1068834/object-comparison-in-javascript#1144249\n\n // Compare primitives and functions.\n // Also check if both arguments link to the same object.\n if (x === y) {\n return true;\n }\n\n if (typeof x !== typeof y) {\n return false;\n }\n\n // special-case NaN (since NaN !== NaN)\n if (typeof x === \"number\" && isNaN(x) && isNaN(y)) {\n return true;\n }\n\n // special-case null (since typeof null == 'object', but null.constructor\n // throws)\n if (x === null || y === null) {\n return x === y;\n }\n\n // everything else is either an unequal primitive, or an object\n // XXX: this check has been temporarily tweaked due to issues in the jest test environment,\n // this will be reverted as part of the migration to vitest\n if (\n x.constructor.name !== \"Object\" &&\n x.constructor.name !== \"RegExp\" &&\n x.constructor.name !== \"Date\" &&\n x.constructor.name !== \"Array\"\n ) {\n return false;\n }\n\n // check they are the same type of object\n // XXX: this check has been temporarily tweaked due to issues in the jest test environment,\n // this will be reverted as part of the migration to vitest\n if (x.prototype !== y.prototype) {\n return false;\n }\n\n // special-casing for some special types of object\n if (x instanceof RegExp || x instanceof Date) {\n return x.toString() === y.toString();\n }\n\n // the object algorithm works for Array, but it's sub-optimal.\n if (Array.isArray(x)) {\n if (x.length !== y.length) {\n return false;\n }\n\n for (let i = 0; i < x.length; i++) {\n if (!deepCompare(x[i], y[i])) {\n return false;\n }\n }\n } else {\n // check that all of y's direct keys are in x\n for (const p in y) {\n if (y.hasOwnProperty(p) !== x.hasOwnProperty(p)) {\n return false;\n }\n }\n\n // finally, compare each of x's keys with y\n for (const p in x) {\n if (y.hasOwnProperty(p) !== x.hasOwnProperty(p) || !deepCompare(x[p], y[p])) {\n return false;\n }\n }\n }\n return true;\n}\n\n// Dev note: This returns an array of tuples, but jsdoc doesn't like that. https://github.com/jsdoc/jsdoc/issues/1703\n/**\n * Creates an array of object properties/values (entries) then\n * sorts the result by key, recursively. The input object must\n * ensure it does not have loops. If the input is not an object\n * then it will be returned as-is.\n * @param obj - The object to get entries of\n * @returns The entries, sorted by key.\n */\nexport function deepSortedObjectEntries(obj: any): [string, any][] {\n if (typeof obj !== \"object\") return obj;\n\n // Apparently these are object types...\n if (obj === null || obj === undefined || Array.isArray(obj)) return obj;\n\n const pairs: [string, any][] = [];\n for (const [k, v] of Object.entries(obj)) {\n pairs.push([k, deepSortedObjectEntries(v)]);\n }\n\n // lexicographicCompare is faster than localeCompare, so let's use that.\n pairs.sort((a, b) => lexicographicCompare(a[0], b[0]));\n\n return pairs;\n}\n\n/**\n * Returns whether the given value is a finite number without type-coercion\n *\n * @param value - the value to test\n * @returns whether or not value is a finite number without type-coercion\n */\nexport function isNumber(value: any): value is number {\n return typeof value === \"number\" && isFinite(value);\n}\n\n/**\n * Removes zero width chars, diacritics and whitespace from the string\n * Also applies an unhomoglyph on the string, to prevent similar looking chars\n * @param str - the string to remove hidden characters from\n * @returns a string with the hidden characters removed\n */\nexport function removeHiddenChars(str: string): string {\n if (typeof str === \"string\") {\n return unhomoglyph(str.normalize(\"NFD\").replace(removeHiddenCharsRegex, \"\"));\n }\n return \"\";\n}\n\n/**\n * Removes the direction override characters from a string\n * @returns string with chars removed\n */\nexport function removeDirectionOverrideChars(str: string): string {\n if (typeof str === \"string\") {\n return str.replace(/[\\u202d-\\u202e]/g, \"\");\n }\n return \"\";\n}\n\nexport function normalize(str: string): string {\n // Note: we have to match the filter with the removeHiddenChars() because the\n // function strips spaces and other characters (M becomes RN for example, in lowercase).\n return (\n removeHiddenChars(str.toLowerCase())\n // Strip all punctuation\n .replace(/[\\\\'!\"#$%&()*+,\\-./:;<=>?@[\\]^_`{|}~\\u2000-\\u206f\\u2e00-\\u2e7f]/g, \"\")\n // We also doubly convert to lowercase to work around oddities of the library.\n .toLowerCase()\n );\n}\n\n// Regex matching bunch of unicode control characters and otherwise misleading/invisible characters.\n// Includes:\n// various width spaces U+2000 - U+200D\n// LTR and RTL marks U+200E and U+200F\n// LTR/RTL and other directional formatting marks U+202A - U+202F\n// Arabic Letter RTL mark U+061C\n// Combining characters U+0300 - U+036F\n// Zero width no-break space (BOM) U+FEFF\n// Blank/invisible characters (U2800, U2062-U2063)\n// eslint-disable-next-line no-misleading-character-class\nconst removeHiddenCharsRegex = /[\\u2000-\\u200F\\u202A-\\u202F\\u0300-\\u036F\\uFEFF\\u061C\\u2800\\u2062-\\u2063\\s]/g;\n\nexport function escapeRegExp(string: string): string {\n return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\n/**\n * Converts Matrix glob-style string to a regular expression\n * https://spec.matrix.org/v1.7/appendices/#glob-style-matching\n * @param glob - Matrix glob-style string\n * @returns regular expression\n */\nexport function globToRegexp(glob: string): string {\n return escapeRegExp(glob).replace(/\\\\\\*/g, \".*\").replace(/\\?/g, \".\");\n}\n\nexport function ensureNoTrailingSlash(url: string): string;\nexport function ensureNoTrailingSlash(url: undefined): undefined;\nexport function ensureNoTrailingSlash(url?: string): string | undefined;\nexport function ensureNoTrailingSlash(url?: string): string | undefined {\n if (url?.endsWith(\"/\")) {\n return url.slice(0, -1);\n } else {\n return url;\n }\n}\n\n/**\n * Returns a promise which resolves with a given value after the given number of ms\n */\nexport function sleep<T>(ms: number, value?: T): Promise<T> {\n return new Promise((resolve) => {\n setTimeout(resolve, ms, value);\n });\n}\n\n/**\n * Utility to log the duration of a promise.\n *\n * @param logger - The logger to log to.\n * @param name - The name of the operation.\n * @param block - The block to execute.\n */\nexport async function logDuration<T>(logger: BaseLogger, name: string, block: () => Promise<T>): Promise<T> {\n const start = Date.now();\n try {\n return await block();\n } finally {\n const end = Date.now();\n logger.debug(`[Perf]: ${name} took ${end - start}ms`);\n }\n}\n\n/**\n * Utility to log the duration of a synchronous block.\n *\n * @param logger - The logger to log to.\n * @param name - The name of the operation.\n * @param block - The block to execute.\n */\nexport function logDurationSync<T>(logger: BaseLogger, name: string, block: () => T): T {\n const start = Date.now();\n try {\n return block();\n } finally {\n const end = Date.now();\n logger.debug(`[Perf]: ${name} took ${end - start}ms`);\n }\n}\n\n/**\n * Promise/async version of {@link setImmediate}.\n *\n * Implementation is based on `setTimeout` for wider compatibility.\n * @deprecated Use {@link sleep} instead.\n */\nexport function immediate(): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve));\n}\n\nexport function isNullOrUndefined(val: any): boolean {\n return val === null || val === undefined;\n}\n\nexport async function promiseMapSeries<T>(\n promises: Array<T | Promise<T>>,\n fn: (t: T) => Promise<unknown> | undefined, // if async we don't care about the type as we only await resolution\n): Promise<void> {\n for (const o of promises) {\n await fn(await o);\n }\n}\n\nexport function promiseTry<T>(fn: () => T | Promise<T>): Promise<T> {\n return Promise.resolve(fn());\n}\n\n// Creates and awaits all promises, running no more than `chunkSize` at the same time\nexport async function chunkPromises<T>(fns: (() => Promise<T>)[], chunkSize: number): Promise<T[]> {\n const results: T[] = [];\n for (let i = 0; i < fns.length; i += chunkSize) {\n results.push(...(await Promise.all(fns.slice(i, i + chunkSize).map((fn) => fn()))));\n }\n return results;\n}\n\n/**\n * Retries the function until it succeeds or is interrupted. The given function must return\n * a promise which throws/rejects on error, otherwise the retry will assume the request\n * succeeded. The promise chain returned will contain the successful promise. The given function\n * should always return a new promise.\n * @param promiseFn - The function to call to get a fresh promise instance. Takes an\n * attempt count as an argument, for logging/debugging purposes.\n * @param shouldRetry - Optional function which is called with the error the latest rejection from promiseFn,\n * retrying will ba aborted if this return false.\n * @returns The promise for the retried operation.\n */\nexport function simpleRetryOperation<T>(\n promiseFn: (attempt: number) => Promise<T>,\n shouldRetry?: (e: unknown) => boolean,\n): Promise<T> {\n return promiseRetry(\n (attempt: number) => {\n return promiseFn(attempt);\n },\n {\n retries: Infinity,\n shouldRetry: shouldRetry ? ({ error }): boolean => shouldRetry(error) : undefined,\n factor: 2,\n minTimeout: 3000, // ms\n maxTimeout: 15000, // ms\n },\n );\n}\n\n// String averaging inspired by https://stackoverflow.com/a/2510816\n// Dev note: We make the alphabet a string because it's easier to write syntactically\n// than arrays. Thankfully, strings implement the useful parts of the Array interface\n// anyhow.\n\n/**\n * The default alphabet used by string averaging in this SDK. This matches\n * all usefully printable ASCII characters (0x20-0x7E, inclusive).\n */\nexport const DEFAULT_ALPHABET = ((): string => {\n let str = \"\";\n for (let c = 0x20; c <= 0x7e; c++) {\n str += String.fromCharCode(c);\n }\n return str;\n})();\n\n/**\n * Pads a string using the given alphabet as a base. The returned string will be\n * padded at the end with the first character in the alphabet.\n *\n * This is intended for use with string averaging.\n * @param s - The string to pad.\n * @param n - The length to pad to.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The padded string.\n */\nexport function alphabetPad(s: string, n: number, alphabet = DEFAULT_ALPHABET): string {\n return s.padEnd(n, alphabet[0]);\n}\n\n/**\n * Converts a baseN number to a string, where N is the alphabet's length.\n *\n * This is intended for use with string averaging.\n * @param n - The baseN number.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The baseN number encoded as a string from the alphabet.\n */\nexport function baseToString(n: bigint, alphabet = DEFAULT_ALPHABET): string {\n // Developer note: the stringToBase() function offsets the character set by 1 so that repeated\n // characters (ie: \"aaaaaa\" in a..z) don't come out as zero. We have to reverse this here as\n // otherwise we'll be wrong in our conversion. Undoing a +1 before an exponent isn't very fun\n // though, so we rely on a lengthy amount of `x - 1` and integer division rules to reach a\n // sane state. This also means we have to do rollover detection: see below.\n\n const len = BigInt(alphabet.length);\n if (n <= len) {\n return alphabet[Number(n) - 1] ?? \"\";\n }\n\n let d = n / len;\n let r = Number(n % len) - 1;\n\n // Rollover detection: if the remainder is negative, it means that the string needs\n // to roll over by 1 character downwards (ie: in a..z, the previous to \"aaa\" would be\n // \"zz\").\n if (r < 0) {\n d -= BigInt(Math.abs(r)); // abs() is just to be clear what we're doing. Could also `+= r`.\n r = Number(len) - 1;\n }\n\n return baseToString(d, alphabet) + alphabet[r];\n}\n\n/**\n * Converts a string to a baseN number, where N is the alphabet's length.\n *\n * This is intended for use with string averaging.\n * @param s - The string to convert to a number.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The baseN number.\n */\nexport function stringToBase(s: string, alphabet = DEFAULT_ALPHABET): bigint {\n const len = BigInt(alphabet.length);\n\n // In our conversion to baseN we do a couple performance optimizations to avoid using\n // excess CPU and such. To create baseN numbers, the input string needs to be reversed\n // so the exponents stack up appropriately, as the last character in the unreversed\n // string has less impact than the first character (in \"abc\" the A is a lot more important\n // for lexicographic sorts). We also do a trick with the character codes to optimize the\n // alphabet lookup, avoiding an index scan of `alphabet.indexOf(reversedStr[i])` - we know\n // that the alphabet and (theoretically) the input string are constrained on character sets\n // and thus can do simple subtraction to end up with the same result.\n\n // Developer caution: we carefully cast to BigInt here to avoid losing precision. We cannot\n // rely on Math.pow() (for example) to be capable of handling our insane numbers.\n\n let result = BigInt(0);\n for (let i = s.length - 1, j = BigInt(0); i >= 0; i--, j++) {\n const charIndex = s.charCodeAt(i) - alphabet.charCodeAt(0);\n\n // We add 1 to the char index to offset the whole numbering scheme. We unpack this in\n // the baseToString() function.\n result += BigInt(1 + charIndex) * len ** j;\n }\n return result;\n}\n\n/**\n * Averages two strings, returning the midpoint between them. This is accomplished by\n * converting both to baseN numbers (where N is the alphabet's length) then averaging\n * those before re-encoding as a string.\n * @param a - The first string.\n * @param b - The second string.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The midpoint between the strings, as a string.\n */\nexport function averageBetweenStrings(a: string, b: string, alphabet = DEFAULT_ALPHABET): string {\n const padN = Math.max(a.length, b.length);\n const baseA = stringToBase(alphabetPad(a, padN, alphabet), alphabet);\n const baseB = stringToBase(alphabetPad(b, padN, alphabet), alphabet);\n const avg = (baseA + baseB) / BigInt(2);\n\n // Detect integer division conflicts. This happens when two numbers are divided too close so\n // we lose a .5 precision. We need to add a padding character in these cases.\n if (avg === baseA || avg == baseB) {\n return baseToString(avg, alphabet) + alphabet[0];\n }\n\n return baseToString(avg, alphabet);\n}\n\n/**\n * Finds the next string using the alphabet provided. This is done by converting the\n * string to a baseN number, where N is the alphabet's length, then adding 1 before\n * converting back to a string.\n * @param s - The string to start at.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The string which follows the input string.\n */\nexport function nextString(s: string, alphabet = DEFAULT_ALPHABET): string {\n return baseToString(stringToBase(s, alphabet) + BigInt(1), alphabet);\n}\n\n/**\n * Finds the previous string using the alphabet provided. This is done by converting the\n * string to a baseN number, where N is the alphabet's length, then subtracting 1 before\n * converting back to a string.\n * @param s - The string to start at.\n * @param alphabet - The alphabet to use as a single string.\n * @returns The string which precedes the input string.\n */\nexport function prevString(s: string, alphabet = DEFAULT_ALPHABET): string {\n return baseToString(stringToBase(s, alphabet) - BigInt(1), alphabet);\n}\n\n/**\n * Compares strings lexicographically as a sort-safe function.\n * @param a - The first (reference) string.\n * @param b - The second (compare) string.\n * @returns Negative if the reference string is before the compare string;\n * positive if the reference string is after; and zero if equal.\n */\nexport function lexicographicCompare(a: string, b: string): number {\n // Dev note: this exists because I'm sad that you can use math operators on strings, so I've\n // hidden the operation in this function.\n if (a < b) {\n return -1;\n } else if (a > b) {\n return 1;\n } else {\n return 0;\n }\n}\n\n/**\n * This function is similar to Object.assign() but it assigns recursively and\n * allows you to ignore nullish values from the source\n *\n * @returns the target object\n */\nexport function recursivelyAssign<T1 extends T2, T2 extends Record<string, any>>(\n target: T1,\n source: T2,\n ignoreNullish = false,\n): T1 & T2 {\n for (const [sourceKey, sourceValue] of Object.entries(source)) {\n if (target[sourceKey] instanceof Object && sourceValue) {\n recursivelyAssign(target[sourceKey], sourceValue);\n continue;\n }\n if ((sourceValue !== null && sourceValue !== undefined) || !ignoreNullish) {\n safeSet(target, sourceKey, sourceValue);\n continue;\n }\n }\n return target as T1 & T2;\n}\n\nfunction getContentTimestampWithFallback(event: MatrixEvent): number {\n return M_TIMESTAMP.findIn<number>(event.getContent()) ?? -1;\n}\n\n/**\n * Sort events by their content m.ts property\n * Latest timestamp first\n */\nexport function sortEventsByLatestContentTimestamp(left: MatrixEvent, right: MatrixEvent): number {\n return getContentTimestampWithFallback(right) - getContentTimestampWithFallback(left);\n}\n\nexport function isSupportedReceiptType(receiptType: string): boolean {\n return [ReceiptType.Read, ReceiptType.ReadPrivate].includes(receiptType as ReceiptType);\n}\n\n/**\n * Determines whether two maps are equal.\n * @param eq - The equivalence relation to compare values by. Defaults to strict equality.\n */\nexport function mapsEqual<K, V>(x: Map<K, V>, y: Map<K, V>, eq = (v1: V, v2: V): boolean => v1 === v2): boolean {\n if (x.size !== y.size) return false;\n for (const [k, v1] of x) {\n const v2 = y.get(k);\n if (v2 === undefined || !eq(v1, v2)) return false;\n }\n return true;\n}\n\nfunction processMapToObjectValue(value: any): any {\n if (value instanceof Map) {\n // Value is a Map. Recursively map it to an object.\n return recursiveMapToObject(value);\n } else if (Array.isArray(value)) {\n // Value is an Array. Recursively map the value (e.g. to cover Array of Arrays).\n return value.map((v) => processMapToObjectValue(v));\n } else {\n return value;\n }\n}\n\n/**\n * Recursively converts Maps to plain objects.\n * Also supports sub-lists of Maps.\n */\nexport function recursiveMapToObject(map: Map<any, any>): Record<any, any> {\n const targetMap = new Map();\n\n for (const [key, value] of map) {\n targetMap.set(key, processMapToObjectValue(value));\n }\n\n return Object.fromEntries(targetMap.entries());\n}\n\nexport function unsafeProp<K extends keyof any | undefined>(prop: K): boolean {\n return prop === \"__proto__\" || prop === \"prototype\" || prop === \"constructor\";\n}\n\nexport function safeSet<O extends Record<any, any>, K extends keyof O>(obj: O, prop: K, value: O[K]): void {\n if (unsafeProp(prop)) {\n throw new Error(\"Trying to modify prototype or constructor\");\n }\n\n obj[prop] = value;\n}\n\nexport function noUnsafeEventProps(event: Partial<IEvent>): boolean {\n return !(unsafeProp(event.room_id) || unsafeProp(event.sender) || unsafeProp(event.event_id));\n}\n\nexport class MapWithDefault<K, V> extends Map<K, V> {\n public constructor(private createDefault: () => V) {\n super();\n }\n\n /**\n * Returns the value if the key already exists.\n * If not, it creates a new value under that key using the ctor callback and returns it.\n */\n public getOrCreate(key: K): V {\n if (!this.has(key)) {\n this.set(key, this.createDefault());\n }\n\n return this.get(key)!;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
package/lib/webrtc/call.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
1
2
|
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
2
3
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
3
4
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
@@ -189,7 +190,6 @@ export class CallError extends Error {
|
|
|
189
190
|
constructor(code, msg, err) {
|
|
190
191
|
// Still don't think there's any way to have proper nested errors
|
|
191
192
|
super(msg + ": " + err);
|
|
192
|
-
_defineProperty(this, "code", void 0);
|
|
193
193
|
this.code = code;
|
|
194
194
|
}
|
|
195
195
|
}
|
|
@@ -230,6 +230,12 @@ function getTransceiverKey(purpose, kind) {
|
|
|
230
230
|
return purpose + ":" + kind;
|
|
231
231
|
}
|
|
232
232
|
export class MatrixCall extends TypedEventEmitter {
|
|
233
|
+
// Used to keep the timer for the delay before actually stopping our
|
|
234
|
+
// video track after muting (see setLocalVideoMuted)
|
|
235
|
+
|
|
236
|
+
// Used to allow connection without Video and Audio. To establish a webrtc connection without media a Data channel is
|
|
237
|
+
// needed At the moment this property is true if we allow MatrixClient with isVoipWithNoMediaAllowed = true
|
|
238
|
+
|
|
233
239
|
/**
|
|
234
240
|
* Construct a new Matrix Call.
|
|
235
241
|
* @param opts - Config options.
|
|
@@ -238,22 +244,11 @@ export class MatrixCall extends TypedEventEmitter {
|
|
|
238
244
|
var _this, _opts$forceTURN;
|
|
239
245
|
super();
|
|
240
246
|
_this = this;
|
|
241
|
-
_defineProperty(this, "roomId", void 0);
|
|
242
|
-
_defineProperty(this, "callId", void 0);
|
|
243
|
-
_defineProperty(this, "invitee", void 0);
|
|
244
|
-
_defineProperty(this, "hangupParty", void 0);
|
|
245
|
-
_defineProperty(this, "hangupReason", void 0);
|
|
246
|
-
_defineProperty(this, "direction", void 0);
|
|
247
|
-
_defineProperty(this, "ourPartyId", void 0);
|
|
248
|
-
_defineProperty(this, "peerConn", void 0);
|
|
249
247
|
_defineProperty(this, "toDeviceSeq", 0);
|
|
250
248
|
// whether this call should have push-to-talk semantics
|
|
251
249
|
// This should be set by the consumer on incoming & outgoing calls.
|
|
252
250
|
_defineProperty(this, "isPtt", false);
|
|
253
251
|
_defineProperty(this, "_state", CallState.Fledgling);
|
|
254
|
-
_defineProperty(this, "client", void 0);
|
|
255
|
-
_defineProperty(this, "forceTURN", void 0);
|
|
256
|
-
_defineProperty(this, "turnServers", void 0);
|
|
257
252
|
// A queue for candidates waiting to go out.
|
|
258
253
|
// We try to amalgamate candidates into a single candidate message where
|
|
259
254
|
// possible
|
|
@@ -265,48 +260,18 @@ export class MatrixCall extends TypedEventEmitter {
|
|
|
265
260
|
_defineProperty(this, "transceivers", new Map());
|
|
266
261
|
_defineProperty(this, "inviteOrAnswerSent", false);
|
|
267
262
|
_defineProperty(this, "waitForLocalAVStream", false);
|
|
268
|
-
_defineProperty(this, "successor", void 0);
|
|
269
|
-
_defineProperty(this, "opponentMember", void 0);
|
|
270
|
-
_defineProperty(this, "opponentVersion", void 0);
|
|
271
|
-
// The party ID of the other side: undefined if we haven't chosen a partner
|
|
272
|
-
// yet, null if we have but they didn't send a party ID.
|
|
273
|
-
_defineProperty(this, "opponentPartyId", void 0);
|
|
274
|
-
_defineProperty(this, "opponentCaps", void 0);
|
|
275
|
-
_defineProperty(this, "iceDisconnectedTimeout", void 0);
|
|
276
|
-
_defineProperty(this, "iceReconnectionTimeOut", void 0);
|
|
277
|
-
_defineProperty(this, "inviteTimeout", void 0);
|
|
278
263
|
_defineProperty(this, "removeTrackListeners", new Map());
|
|
279
264
|
// The logic of when & if a call is on hold is nontrivial and explained in is*OnHold
|
|
280
265
|
// This flag represents whether we want the other party to be on hold
|
|
281
266
|
_defineProperty(this, "remoteOnHold", false);
|
|
282
|
-
// the stats for the call at the point it ended. We can't get these after we
|
|
283
|
-
// tear the call down, so we just grab a snapshot before we stop the call.
|
|
284
|
-
// The typescript definitions have this type as 'any' :(
|
|
285
|
-
_defineProperty(this, "callStatsAtEnd", void 0);
|
|
286
267
|
// Perfect negotiation state: https://www.w3.org/TR/webrtc/#perfect-negotiation-example
|
|
287
268
|
_defineProperty(this, "makingOffer", false);
|
|
288
269
|
_defineProperty(this, "ignoreOffer", false);
|
|
289
270
|
_defineProperty(this, "isSettingRemoteAnswerPending", false);
|
|
290
|
-
_defineProperty(this, "responsePromiseChain", void 0);
|
|
291
271
|
// If candidates arrive before we've picked an opponent (which, in particular,
|
|
292
272
|
// will happen if the opponent sends candidates eagerly before the user answers
|
|
293
273
|
// the call) we buffer them up here so we can then add the ones from the party we pick
|
|
294
274
|
_defineProperty(this, "remoteCandidateBuffer", new Map());
|
|
295
|
-
_defineProperty(this, "remoteAssertedIdentity", void 0);
|
|
296
|
-
_defineProperty(this, "remoteSDPStreamMetadata", void 0);
|
|
297
|
-
_defineProperty(this, "callLengthInterval", void 0);
|
|
298
|
-
_defineProperty(this, "callStartTime", void 0);
|
|
299
|
-
_defineProperty(this, "opponentDeviceId", void 0);
|
|
300
|
-
_defineProperty(this, "hasOpponentDeviceInfo", void 0);
|
|
301
|
-
_defineProperty(this, "opponentSessionId", void 0);
|
|
302
|
-
_defineProperty(this, "groupCallId", void 0);
|
|
303
|
-
// Used to keep the timer for the delay before actually stopping our
|
|
304
|
-
// video track after muting (see setLocalVideoMuted)
|
|
305
|
-
_defineProperty(this, "stopVideoTrackTimer", void 0);
|
|
306
|
-
// Used to allow connection without Video and Audio. To establish a webrtc connection without media a Data channel is
|
|
307
|
-
// needed At the moment this property is true if we allow MatrixClient with isVoipWithNoMediaAllowed = true
|
|
308
|
-
_defineProperty(this, "isOnlyDataChannelAllowed", void 0);
|
|
309
|
-
_defineProperty(this, "stats", void 0);
|
|
310
275
|
/**
|
|
311
276
|
* Internal
|
|
312
277
|
*/
|
|
@@ -2261,7 +2226,10 @@ export class MatrixCall extends TypedEventEmitter {
|
|
|
2261
2226
|
clearTimeout(_this29.stopVideoTrackTimer);
|
|
2262
2227
|
_this29.stopVideoTrackTimer = undefined;
|
|
2263
2228
|
}
|
|
2264
|
-
for (var
|
|
2229
|
+
for (var _ref4 of _this29.removeTrackListeners) {
|
|
2230
|
+
var _ref3 = _slicedToArray(_ref4, 2);
|
|
2231
|
+
var stream = _ref3[0];
|
|
2232
|
+
var listener = _ref3[1];
|
|
2265
2233
|
stream.removeEventListener("removetrack", listener);
|
|
2266
2234
|
}
|
|
2267
2235
|
_this29.removeTrackListeners.clear();
|
|
@@ -2548,8 +2516,8 @@ export function supportsMatrixCall() {
|
|
|
2548
2516
|
// There's some information at https://bugzilla.mozilla.org/show_bug.cgi?id=1542616 though the concern
|
|
2549
2517
|
// is that the browser throwing a SecurityError will brick the client creation process.
|
|
2550
2518
|
try {
|
|
2551
|
-
var
|
|
2552
|
-
var supported = Boolean((
|
|
2519
|
+
var _ref5, _ref6, _window$RTCPeerConnec;
|
|
2520
|
+
var supported = Boolean((_ref5 = (_ref6 = (_window$RTCPeerConnec = window.RTCPeerConnection) !== null && _window$RTCPeerConnec !== void 0 ? _window$RTCPeerConnec : window.RTCSessionDescription) !== null && _ref6 !== void 0 ? _ref6 : window.RTCIceCandidate) !== null && _ref5 !== void 0 ? _ref5 : navigator.mediaDevices);
|
|
2553
2521
|
if (!supported) {
|
|
2554
2522
|
/* istanbul ignore if */ // Adds a lot of noise to test runs, so disable logging there.
|
|
2555
2523
|
if (process.env.NODE_ENV !== "test") {
|