@phenixrts/sdk 2022.0.2 → 2022.0.5

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.
Files changed (50) hide show
  1. package/dist/debug/channels.js +277 -135
  2. package/dist/debug/full.js +277 -135
  3. package/dist/debug/groups.js +1 -1
  4. package/dist/debug/messaging.js +1 -1
  5. package/dist/debug/publish.js +1 -1
  6. package/dist/debug.private/channels.js +277 -135
  7. package/dist/debug.private/full.js +277 -135
  8. package/dist/debug.private/groups.js +1 -1
  9. package/dist/debug.private/messaging.js +1 -1
  10. package/dist/debug.private/publish.js +1 -1
  11. package/dist/es5.debug.private/channels.js +276 -135
  12. package/dist/es5.debug.private/full.js +276 -135
  13. package/dist/es5.debug.private/groups.js +1 -1
  14. package/dist/es5.debug.private/messaging.js +1 -1
  15. package/dist/es5.debug.private/publish.js +1 -1
  16. package/dist/legacy.debug/channels.js +277 -135
  17. package/dist/legacy.debug/full.js +277 -135
  18. package/dist/legacy.debug/groups.js +1 -1
  19. package/dist/legacy.debug/messaging.js +1 -1
  20. package/dist/legacy.debug/publish.js +1 -1
  21. package/dist/legacy.debug.private/channels.js +276 -135
  22. package/dist/legacy.debug.private/full.js +276 -135
  23. package/dist/legacy.debug.private/groups.js +1 -1
  24. package/dist/legacy.debug.private/messaging.js +1 -1
  25. package/dist/legacy.debug.private/publish.js +1 -1
  26. package/dist/legacy.min/channels.js +1 -1
  27. package/dist/legacy.min/channels.js.map +1 -1
  28. package/dist/legacy.min/full.js +1 -1
  29. package/dist/legacy.min/full.js.map +1 -1
  30. package/dist/legacy.min/groups.js +1 -1
  31. package/dist/legacy.min/messaging.js +1 -1
  32. package/dist/legacy.min/publish.js +1 -1
  33. package/dist/min/channels.js +1 -1
  34. package/dist/min/channels.js.map +1 -1
  35. package/dist/min/full.js +1 -1
  36. package/dist/min/full.js.map +1 -1
  37. package/dist/min/groups.js +1 -1
  38. package/dist/min/messaging.js +1 -1
  39. package/dist/min/publish.js +1 -1
  40. package/dist/min.private/channels.js +1 -1
  41. package/dist/min.private/channels.js.map +1 -1
  42. package/dist/min.private/full.js +1 -1
  43. package/dist/min.private/full.js.map +1 -1
  44. package/dist/min.private/groups.js +1 -1
  45. package/dist/min.private/messaging.js +1 -1
  46. package/dist/min.private/publish.js +1 -1
  47. package/dist/types/rtc/RtcConnectionMonitor.d.ts +1 -0
  48. package/dist/types/sdk/channels/Channel.d.ts +4 -2
  49. package/dist/types/sdk/channels/ChannelContext.d.ts +1 -0
  50. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["webpack://phenix/webpack/universalModuleDefinition","webpack://phenix/./node_modules/@babel/runtime/helpers/arrayLikeToArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/arrayWithHoles.js","webpack://phenix/./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","webpack://phenix/./node_modules/@babel/runtime/helpers/assertThisInitialized.js","webpack://phenix/./node_modules/@babel/runtime/helpers/asyncToGenerator.js","webpack://phenix/./node_modules/@babel/runtime/helpers/classCallCheck.js","webpack://phenix/./node_modules/@babel/runtime/helpers/createClass.js","webpack://phenix/./node_modules/@babel/runtime/helpers/defineProperty.js","webpack://phenix/./node_modules/@babel/runtime/helpers/getPrototypeOf.js","webpack://phenix/./node_modules/@babel/runtime/helpers/inherits.js","webpack://phenix/./node_modules/@babel/runtime/helpers/iterableToArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","webpack://phenix/./node_modules/@babel/runtime/helpers/nonIterableRest.js","webpack://phenix/./node_modules/@babel/runtime/helpers/nonIterableSpread.js","webpack://phenix/./node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","webpack://phenix/./node_modules/@babel/runtime/helpers/setPrototypeOf.js","webpack://phenix/./node_modules/@babel/runtime/helpers/slicedToArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/toConsumableArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/typeof.js","webpack://phenix/./node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","webpack://phenix/./node_modules/@babel/runtime/regenerator/index.js","webpack://phenix/./src/promise/PromiseHandler.ts","webpack://phenix/./src/promise/Promise.ts","webpack://phenix/./src/logger/Logger.ts","webpack://phenix/./src/logger/Appenders.ts","webpack://phenix/./src/dom/PrivacyMode.ts","webpack://phenix/./src/logger/LoggerDefaults.ts","webpack://phenix/./src/logger/LoggingThreshold.ts","webpack://phenix/./src/logger/ConsoleAppender.ts","webpack://phenix/./src/sdk/version/VersionManager.ts","webpack://phenix/./src/telemetry/TelemetryService.ts","webpack://phenix/./src/metrics/MetricsConfiguration.ts","webpack://phenix/./src/telemetry/TelemetryApender.ts","webpack://phenix/./src/telemetry/TelemetryConfiguration.ts","webpack://phenix/./src/metrics/TelemetryDefault.ts","webpack://phenix/./src/lang/assertUnreachable.ts","webpack://phenix/./src/metrics/TelemetricLevelMapping.ts","webpack://phenix/./src/logger/LoggingLevelMapping.ts","webpack://phenix/./src/dom/PlainConfigurationParameterReader.ts","webpack://phenix/./src/logger/LoggerFactory.ts","webpack://phenix/./src/lang/Strings.ts","webpack://phenix/./src/lang/Disposable.ts","webpack://phenix/./src/rx/Subject.ts","webpack://phenix/./src/rx/ReadOnlySubject.ts","webpack://phenix/./src/dom/BrowserDetector.ts","webpack://phenix/./src/sdk/feature/FeatureEnablement.ts","webpack://phenix/./src/rtc/VanillaPeerConnection.ts","webpack://phenix/./src/rtc/VanillaPeerConnectionFactory.ts","webpack://phenix/./src/sdk/edgeAuth/EdgeAuth.ts","webpack://phenix/./src/metrics/MetricsType.ts","webpack://phenix/./src/lang/DisposableList.ts","webpack://phenix/./src/dom/ApplicationActivityMonitor.ts","webpack://phenix/./src/sdk/TelemetryUrl.ts","webpack://phenix/./src/sdk/Environment.ts","webpack://phenix/./src/sdk/discovery/DiscoveryUri.ts","webpack://phenix/./src/sdk/defaults.ts","webpack://phenix/./src/metrics/MetricType.ts","webpack://phenix/./src/metrics/MetricsService.ts","webpack://phenix/./src/metrics/MetricsFactory.ts","webpack://phenix/./src/sdk/SDK.ts","webpack://phenix/./src/sdk/channels/ChannelState.ts","webpack://phenix/./src/video/Dimension.ts","webpack://phenix/./src/sdk/api/SetTemporaryMaximalBitrate.ts","webpack://phenix/./src/time/Duration.ts","webpack://phenix/./src/video/VideoTelemetry.ts","webpack://phenix/./src/dom/StreamSetupListener.ts","webpack://phenix/./src/dom/NetworkMonitor.ts","webpack://phenix/./src/video/SessionTelemetry.ts","webpack://phenix/./src/sdk/channels/ChannelContext.ts","webpack://phenix/./src/rtc/PeerConnectionService.ts","webpack://phenix/./src/sdk/discovery/BitrateModeMapping.ts","webpack://phenix/./src/sdk/discovery/BitrateStateMapping.ts","webpack://phenix/./src/sdk/discovery/EndPoint.ts","webpack://phenix/./src/sdk/discovery/DiscoveryService.ts","webpack://phenix/./src/sdk/discovery/Discovery.ts","webpack://phenix/./src/rtc/SdpParser.ts","webpack://phenix/./src/rtc/RtcConnectionMonitor.ts","webpack://phenix/./src/sdk/streaming/RealTimeStream.ts","webpack://phenix/./src/sdk/streaming/RealTimeStreamFactory.ts","webpack://phenix/./src/sdk/channels/Channel.ts","webpack://phenix/./src/sdk/channels/Channels.ts","webpack://phenix/./src/sdk/full/index.ts","webpack://phenix/./node_modules/regenerator-runtime/runtime.js","webpack://phenix/webpack/bootstrap","webpack://phenix/webpack/startup","webpack://phenix/webpack/runtime/compat get default export","webpack://phenix/webpack/runtime/define property getters","webpack://phenix/webpack/runtime/hasOwnProperty shorthand","webpack://phenix/webpack/runtime/make namespace object"],"names":["root","factory","exports","module","define","amd","self","arr","len","length","i","arr2","Array","isArray","arrayLikeToArray","ReferenceError","asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","done","Promise","then","fn","this","args","arguments","apply","err","undefined","instance","Constructor","TypeError","_defineProperties","target","props","descriptor","enumerable","configurable","writable","Object","defineProperty","protoProps","staticProps","prototype","obj","_getPrototypeOf","o","setPrototypeOf","getPrototypeOf","__proto__","subClass","superClass","create","constructor","iter","Symbol","iterator","from","_arr","_n","_d","_e","_s","_i","next","push","_typeof","assertThisInitialized","call","_setPrototypeOf","p","arrayWithHoles","iterableToArrayLimit","unsupportedIterableToArray","nonIterableRest","arrayWithoutHoles","iterableToArray","nonIterableSpread","minLen","n","toString","slice","name","test","PromiseHandler","onFulfilled","onRejected","promise","callback","_state","_handled","_value","_deferreds","doResolve","promiseResolve","reason","promiseReject","newValue","finale","e","_immediate","_unhandledRejection","handle","deferred","result","remaining","manageResponse","_","setTimeout","console","warn","LoggingLevel","Logger","category","appenders","threshold","_category","_appenders","_threshold","Trace","log","Debug","Info","Warn","Error","Fatal","level","date","Date","message","replacePlaceholders","forEach","appender","replacePlaceholdersString","index","indexOf","substring","replaceArgument","splice","stringify","reduce","accumulator","currentValue","array","stack","cache","JSON","includes","argument","data","toStringStr","Appenders","items","item","PrivacyMode","_isPrivate","__PRIVACY_MODE__","applyIsPrivate","LoggerDefaults","isPrivate","Off","All","LoggingThreshold","defaultLoggingLevel","ConsoleAppender","logLevel","fullMessage","toISOString","VersionManager","__SDKVERSION__","_defaultVersion","TelemetryLevel","TelemetryService","telemetryConfiguration","location","hostname","_telemetryConfiguration","timestamp","logRecord","tenancy","sessionId","version","sdkVersion","environment","fullQualifiedName","_domain","_logs","unshift","sendLogsIfAble","logMessages","formData","FormData","append","records","fetch","url","method","body","_isSending","numberOfLogsToSend","sizeOfLogsToSend","getLogSize","values","sum","sendLogs","response","catch","TelemetryAppender","_tenancy","_sessionId","_telemetryService","TelemetryConfiguration","defaultTelemetryLoggingLevel","_url","telemetryUrl","URL","pathname","_environment","TelemetryDefault","Essential","MetricsConfiguration","defaultTelemetryLevel","metricsUrl","x","TelemetryLevelMapping","telemetryLevel","assertUnreachable","telemetryLevelType","LoggingLevelMapping","loggingLevel","loggingLevelType","PlainConfigurationParameterReader","defaultStringValue","defaultBooleanValue","convertTelemetryLevelToTelemetryLevelType","convertLoggingLevelToLoggingLevelType","defaultConsoleLoggingLevel","LoggerFactory","_loggers","applyLoggingLevel","applyAppenderLoggingLevel","applyConsoleLogger","bind","applyTelemetryLogger","parameterValue","_configurationParameterReader","getStringValue","setThreshold","applyAppender","add","ConfigurationParameterReader","applyLoggerConfigFromParameterConfiguration","Strings","loops","Math","ceil","fill","random","string","func","Disposable","disposable","_disposed","_disposable","DisposableListener","listeners","listener","idx","Subject","_listeners","changed","comparable","equals","ReadOnlySubject","subject","_subject","subscribe","BrowserDetector","navigator","userAgent","browserNameAndVersion","match","_browserNameAndVersionRegex","parseBrowserNameAndVersionForIE","_browserNameAndVersion","browserNameList","split","browserVersionList","fullVersion","Number","msie","parseInt","_browserName","_browserMajorVersion","_isChrome69","_isChrome70","_isChrome71","_isChrome72","_isChrome74","_isChrome75","_isChrome76","_isChrome77","parseBrowserNameAndVersion","parseBrowserName","parseBrowserMajorVersion","FeatureEnablement","isChrome74","isChrome75","isChrome76","isChrome77","isChrome69","isChrome70","isChrome71","isChrome72","browserName","browserMajorVersion","configuration","getLogger","webkitRTCPeerConnectionEnabled","_peerConnection","webkitRTCPeerConnection","RTCPeerConnection","options","promiseBasedPCMethodsDisabled","createOffer","createAnswer","description","setLocalDescription","RTCSessionDescription","sdp","_logger","setRemoteDescription","selector","getStats","type","addEventListener","removeEventListener","addTransceiver","getConfiguration","setConfiguration","close","currentLocalDescription","currentRemoteDescription","iceConnectionState","addTranceiverDisabled","handler","ontrack","onicecandidate","oniceconnectionstatechange","VanillaPeerConnection","edgeAuthTokenPrefix","EdgeAuth","token","isValidToken","encodedEdgeAuthToken","atob","substr","edgeAuthToken","parse","parsedToken","uri","applicationId","startsWith","MetricsType","DisposableList","_list","dispose","ApplicationActivityMonitor","now","_isForeground","_readOnlyIsForeground","detectTabFocusChange","_timeOfLastTabFocusChange","_disposables","hidden","visibilityChange","document","msHidden","webkitHidden","handleVisibilityChange","isForeground","setFocusState","listenForDocumentFocus","_documentFocusInterval","window","setInterval","hasFocus","clearInterval","TelemetryUrl","baseURL","segments","protocol","endsWith","join","origin","Environment","DiscoveryUri","search","URLSearchParams","_discoveryUri","MetricType","metrics","_metrics","MetricsService","metricsConfiguration","_metricsConfiguration","metric","streamId","previousValue","runtime","resource","kind","metricType","getTelemetryLevel","metricRecord","getName","sendMetricsIfAble","metricsMessages","sendMetrics","MetricsFactory","metricsServices","_metricsServices","SDK","clientSessionId","getTelemetryUrl","getEnvironmentFromUrl","convertTelemetryLevelTypeToTelemetryLevel","metricsService","pageLoadTime","telemetryAppender","find","remove","_metricsService","getMetricsService","_telemetryLevel","_automaticallyRetryOnFailure","getBooleanValue","_automaticallyReconnectPeerConnection","discoveryUri","channelToken","parseToken","getTenancy","getUri","uriValue","baseURIValue","_initialized","_applicationActivityMonitor","peerConnectionFactory","_peerConnectionFactory","convertLoggingLevelTypeToLoggingLevel","consoleLoggingLevel","consoleAppender","automaticallyPlayMediaStream","_automaticallyPlayMediaStream","automaticallyMuteVideoOnPlayFailure","_automaticallyMuteVideoOnPlayFailure","webPlayerLoader","_webPlayerLoader","shakaPlayerLoader","_shakaPlayerLoader","hlsJsLoader","_hlsJsLoader","_sendLocalCandidates","_clientSessionId","_loadedTimestamp","_readOnlyInitialized","_readOnlyDiscoveryUri","_readOnlyPeerConnectionFactory","_telemetryUrl","_maximalNumberOfPeerConnectionReconnectAttempts","retriesAmount","VanillaPeerConnectionFactory","applyDiscoveryUriDefaultFromParameterConfiguration","applyMetricsConfiguration","applyTelemetryConfiguration","applyAutomaticallyRetryOnFailureFromParameterConfiguration","applyAutomaticallyReconnectPeerConnectionFromParameterConfiguration","init","ChannelState","Dimension","width","height","other","BitrateState","BitrateMode","Durations","duration","_duration","isNegative","abs","offset","floor","milliseconds","seconds","minutes","hours","parts","String","padStart","targetLength","padString","repeat","VideoTelemetry","channelStartTime","_streamId","_pageLoadTime","_channelStartTime","video","_startRecordingFirstFrame","_listenToFirstTime","callTimeToFirstFrame","_clearTimeToFirstFrameListener","_listenForStall","onStall","_listenForContinuation","event","onContinuation","_clearRebufferingListener","pushTimeToFirstFrame","pushChannelCreationTimeToFirstFrame","_timeToFirstFrame","uint64","durationSincePageLoad","toIsoString","_channelCreationTimeToFirstFrame","_videoStalled","buffered","bufferLength","hasNotProgressedSinceLastProgressEvent","end","_lastProgress","timeSinceStop","newResolution","_videoResolution","StreamSetupListener","_startTime","recordStreamMetric","_metricSubmitted","setupTime","metricName","NetworkMonitor","isSupported","setupNetworkChangeListeners","updateStatistics","downlink","downlinkMax","effectiveType","rtt","_rtt","getRoundTripTime","_effectiveType","getEffectiveType","_downlinkThroughputCapacity","getDownlinkThroughputCapacity","_isSupported","SessionTelemetry","applicationActivityMonitor","_networkMonitor","recordForegroundChange","recordNetworkRTTUpdate","recordNetworkTypeChangeUpdate","downlinkThroughputCapacity","recordNetworkDownlinkThroughputCapacityUpdate","timeSinceLastChange","getTimeSinceLastChange","newRTT","oldRtt","_lastNetworkStatistics","newNetworkType","oldNetworkType","newCapacity","oldCapacity","float","ChannelContext","targetLag","isDisposed","disposables","channelDisposables","rendererDisposables","channelInitialization","videoElement","peerConnection","mediaStream","state","autoMuted","autoPaused","tokenExpiring","authorized","online","loading","playing","standby","stopped","lag","bitrateLimit","resolution","empty","failureCount","endPoint","stream","rtcStatistics","peerConnectionReconnectAttempts","status","dataset","PeerConnectionService","isPrecachingEnabled","precacheCreatePeerConnectionOffer","_cached","createPeerConnectionOffer","createPeerConnection","supportsAddTransceiver","audioTransceiver","direction","videoTransceiver","offerToReceiveAudio","offerToReceiveVideo","localOffer","initiateInitialPrecaching","BitrateModeMapping","bitrateMode","Normal","Force","Reset","BitrateStateMapping","bitrateState","Keep","EndPoint","timeout","_uri","_timeout","buildPingUrl","start","race","finished","ok","_roundTripTime","localSessionDescription","buildUrl","clientVersion","bodyWithOffer","apiVersion","sessionDescription","convertRTCSdpTypeToSdpType","createAnswerDescription","bodyWithoutOffer","createOfferDescription","finally","clearTimeout","httpResponse","mapHttpStatusToSubscribeStatus","convertHttpResponseToSubscribeResponse","subscribeResponse","debug","sharedSecret","mapHttpStatusToSetRemoteDescriptionStatus","convertHttpResponseToSetRemoteDescriptionResponse","setRemoteDescriptionResponse","elapsedInMilliseconds","bitrateInBitsPerSecond","convertBitrateStateToBitrateStateType","convertBitrateModeToBitrateModeType","mapHttpStatusToSetTemporaryMaximalBitrateStatus","candidates","discoveryCompleted","mapHttpStatusToAddIceCandidatesStatus","convertHttpResponseToAddIceCandidatesResponse","addIceCandidatesResponse","mapHttpStatusToSetDestroyStreamStatus","convertHttpResponseToDestroyStreamResponse","destroyStreamResponse","path","pathAsArray","concat","json","rtcConfiguration","bundlePolicy","iceCandidatePoolSize","iceServers","urls","username","credential","iceTransportPolicy","peerIdentity","rtcpMuxPolicy","convertISessionDescriptionToRTCSessionDescription","createAnswerDescriptionResponse","createOfferDescriptionResponse","rtcSessionDescription","destroyStream","DiscoveryService","text","asString","endPoints","map","buildDiscoveryUrl","discoverNearbyEndPoints","neverResolve","ping","time","Discovery","discoverClosestEndPointWithCaching","_cache","discoveryService","cachedValue","discoverClosestEndPoint","precacheClosestEndPointDiscovery","SdpParser","_sdp","_audioCodec","applyCodec","_videoCodec","splitSdp","RtcConnectionMonitor","estimatedRoundTripTime","_estimatedRoundTripTime","_tracksToMonitor","getTracks","track","getCurrentOfferDisabled","parsedSDP","_estimatedAudioCodec","audioCodec","_estimatedVideoCodec","videoCodec","updateStatistic","_isMonitorRunning","_updateTimeOut","getStatsPromiseBasedDisabled","updateStatisticLegacy","getKindForSafari11","id","stats","rtcStats","roundTripTime","currentRoundTripTime","mediaType","codec","codecId","mimeType","ssrc","bytesReceived","packetsLost","packetsReceived","getCodecByType","_rtcStatistic","framesDecoded","getStatsLegacy","report","names","stat","RealTimeStream","channelContext","handleStreamFailure","_channelContext","_handleStreamFailure","listenOnStreamSetup","playMediaStreamInVideoElement","all","clientOfferDisabled","supportsSetConfiguration","supportsGetConfiguration","applySessionAndStreamPropertiesToVideoElement","mapSubscribeStatusToChannelStatus","applyStatus","applyRtcConfiguration","submitCandidatesTimeout","cancelDiscovery","sendLocalCandidates","candidate","addIceCandidates","retryCallback","pause","srcObject","onLine","reconnectPeerConnection","mediaStreamPromise","onTrackDisabled","trackListener","timeoutId","streams","answer","mapSetRemoteDescriptionStatusToChannelStatus","success","rtcConnectionMonitor","rtcStatistic","statistics","rtcVideoStatistic","rtcAudioStatistic","audio","audioTrackFailed","videoTrackFailed","optionalPeerConnection","truncateIceServers","newRtcConfiguration","maximalNumberOfPeerConnectionReconnectAttempts","automaticallyReconnectPeerConnection","iceRestart","offer","RealTimeStreamFactory","capabilities","defaultStreamTerminationReason","Channel","_context","_readOnlyVideoElement","_readOnlyToken","_readOnlyPeerConnection","_readOnlyState","_readOnlyAutoMuted","_readOnlyAutoPaused","_readOnlyTokenExpiring","_readOnlyAuthorized","_readOnlyOnline","_readOnlyLoading","_readOnlyPlaying","_readOnlyStandby","_readOnlyStopped","_readOnlyTargetLag","_readOnlyLag","_readOnlyBitrateLimit","_readOnlyResolution","_readOnlyFailureCount","_readOnlyEndPoint","_readOnlyStream","_readOnlyRtcStatistics","_readOnlyMediaStream","sessionTelemetry","_videoMetaDataChangedHandler","handleVideoMetaDataChanged","videoTelemetry","setupListenerForTimeToFirstTime","setupListenerForRebuffering","restartAfterStop","clearFailureCountTimeout","onVideoResolutionChanges","getTime","limitBitrate","videoWidth","videoHeight","cleanUpResources","muted","stop","streamPlayer","StreamFactory","fail","automaticRetryOnFailure","getRetryInterval","min","pow","max","playPromise","play","hasAudioTrack","filter","automaticallyMuteVideoOnPlayFailureOff","Channels","initialized","Op","hasOwn","hasOwnProperty","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","wrap","innerFn","outerFn","tryLocsList","protoGenerator","Generator","generator","context","Context","_invoke","GenStateSuspendedStart","GenStateExecuting","GenStateCompleted","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","record","tryCatch","GenStateSuspendedYield","makeInvokeMethod","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","invoke","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","resultName","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","reset","iterable","iteratorMethod","isNaN","displayName","isGeneratorFunction","genFun","ctor","mark","awrap","async","keys","object","reverse","pop","skipTempReset","prev","charAt","rootRecord","rval","exception","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","Function","__webpack_module_cache__","__webpack_require__","moduleId","__webpack_modules__","getter","__esModule","d","a","definition","get","prop","r"],"mappings":"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","file":"full.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"phenix\"] = factory();\n\telse\n\t\troot[\"phenix\"] = factory();\n})(self, function() {\nreturn ","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n\nmodule.exports = _arrayLikeToArray;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles;","var arrayLikeToArray = require(\"./arrayLikeToArray\");\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}\n\nmodule.exports = _arrayWithoutHoles;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nmodule.exports = _assertThisInitialized;","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nfunction _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}\n\nmodule.exports = _asyncToGenerator;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\n\nmodule.exports = _createClass;","function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nmodule.exports = _defineProperty;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf;","var setPrototypeOf = require(\"./setPrototypeOf\");\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inherits;","function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter);\n}\n\nmodule.exports = _iterableToArray;","function _iterableToArrayLimit(arr, i) {\n if (typeof Symbol === \"undefined\" || !(Symbol.iterator in Object(arr))) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n\nmodule.exports = _iterableToArrayLimit;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableRest;","function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableSpread;","var _typeof = require(\"@babel/runtime/helpers/typeof\");\n\nvar assertThisInitialized = require(\"./assertThisInitialized\");\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n }\n\n return assertThisInitialized(self);\n}\n\nmodule.exports = _possibleConstructorReturn;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf;","var arrayWithHoles = require(\"./arrayWithHoles\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray\");\n\nvar nonIterableRest = require(\"./nonIterableRest\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray;","var arrayWithoutHoles = require(\"./arrayWithoutHoles\");\n\nvar iterableToArray = require(\"./iterableToArray\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread\");\n\nfunction _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n module.exports = _typeof = function _typeof(obj) {\n return typeof obj;\n };\n } else {\n module.exports = _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n}\n\nmodule.exports = _typeof;","var arrayLikeToArray = require(\"./arrayLikeToArray\");\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\n\nmodule.exports = _unsupportedIterableToArray;","module.exports = require(\"regenerator-runtime\");\n","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport Promise from './Promise';\n\nexport default class PromiseHandler {\n onFulfilled: Function;\n onRejected: Function;\n promise: Promise;\n\n constructor(onFulfilled, onRejected, promise) {\n this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;\n this.onRejected = typeof onRejected === 'function' ? onRejected : null;\n this.promise = promise;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport PromiseHandler from './PromiseHandler';\n\nclass Promise {\n _state: number;\n _handled: boolean;\n _value: Promise;\n _deferreds: Array<PromiseHandler>;\n /* eslint-disable */\n // @ts-ignore\n then(onFulfilled: Function, onRejected: Function): Promise | void;\n /* eslint-enable*/\n\n constructor(callback) {\n if (!(this instanceof Promise)) {\n throw new TypeError('Promises must be constructed via new');\n }\n\n if (typeof callback !== 'function') {\n throw new TypeError('not a function');\n }\n\n this._state = 0;\n this._handled = false;\n this._value = undefined;\n this._deferreds = [];\n\n this.doResolve(callback);\n }\n\n doResolve(callback: Function): void {\n let done = false;\n\n try {\n callback(\n value => {\n if (done) {\n return;\n }\n\n done = true;\n this.promiseResolve(value);\n },\n reason => {\n if (done) {\n return;\n }\n\n done = true;\n this.promiseReject(reason);\n }\n );\n } catch (error) {\n if (done) {\n return;\n }\n\n done = true;\n this.promiseReject(error);\n }\n }\n\n promiseResolve(newValue: Promise | undefined): void {\n const promise = this as Promise;\n\n try {\n // Promise Resolution Procedure: https://github.com/Promises-aplus/Promises-spec#the-Promise-resolution-procedure\n if (newValue === promise) {\n throw new TypeError('A Promise cannot be resolved with it self.');\n }\n\n if (newValue && (typeof newValue === 'object' || typeof newValue === 'function')) {\n const then = newValue.then;\n\n if (newValue instanceof Promise) {\n promise._state = 3;\n promise._value = newValue;\n promise.finale();\n\n return;\n } else if (typeof then === 'function') {\n promise.doResolve(function(): void {\n // eslint-disable-next-line prefer-rest-params\n then.apply(newValue, arguments);\n });\n\n return;\n }\n }\n\n promise._state = 1;\n promise._value = newValue;\n promise.finale();\n } catch (e) {\n promise.promiseReject(e);\n }\n }\n\n promiseReject(newValue: Promise | undefined): void{\n this._state = 2;\n this._value = newValue;\n this.finale();\n }\n\n finale(): void {\n if (this._state === 2 && this._deferreds.length === 0) {\n Promise._immediate(() => {\n if (!this._handled) {\n Promise._unhandledRejection(this._value);\n }\n });\n }\n\n for (let i = 0, len = this._deferreds.length; i < len; i++) {\n this.handle(this._deferreds[i]);\n }\n\n this._deferreds = null;\n }\n\n handle(deferred: PromiseHandler): void {\n let promise = this as Promise;\n\n while (promise._state === 3) {\n promise = promise._value;\n }\n\n if (promise._state === 0) {\n promise._deferreds.push(deferred);\n\n return;\n }\n\n promise._handled = true;\n Promise._immediate(() => {\n const callback = promise._state === 1 ? deferred.onFulfilled : deferred.onRejected;\n\n if (callback === null) {\n if (promise._state === 1) {\n deferred.promise.promiseResolve(promise._value);\n } else {\n deferred.promise.promiseReject(promise._value);\n }\n\n return;\n }\n\n let result;\n\n try {\n result = callback(promise._value);\n } catch (e) {\n deferred.promise.promiseReject(e);\n\n return;\n }\n\n deferred.promise.promiseResolve(result);\n });\n }\n\n static all(arr: Array<Promise>): Promise {\n return new Promise((resolve, reject) => {\n if (!Array.isArray(arr)) {\n return reject(new TypeError('Promise.all accepts an array'));\n }\n\n const args = Array.prototype.slice.call(arr);\n\n if (args.length === 0) {\n return resolve([]);\n }\n\n let remaining = args.length;\n const manageResponse = (i, value): void => {\n try {\n if (value && (typeof value === 'object' || typeof value === 'function')) {\n const then = value.then;\n\n if (typeof then === 'function') {\n then.call(\n value,\n value => manageResponse(i, value),\n reject\n );\n\n return;\n }\n }\n\n args[i] = value;\n\n if (--remaining === 0) {\n resolve(args);\n }\n } catch (error) {\n reject(error);\n }\n };\n\n for (let i = 0; i < args.length; i++) {\n manageResponse(i, args[i]);\n }\n });\n }\n\n static resolve(value): Promise {\n if (value && typeof value === 'object' && value.constructor === Promise) {\n return value;\n }\n\n return new Promise(resolve => resolve(value));\n }\n\n static reject(value): Promise {\n return new Promise((_, reject) => reject(value));\n }\n\n static race(arr: Array<Promise>): Promise {\n return new Promise((resolve, reject) => {\n if (!Array.isArray(arr)) {\n return reject(new TypeError('Promise.race accepts an array'));\n }\n\n for (let i = 0, len = arr.length; i < len; i++) {\n Promise.resolve(arr[i]).then(resolve, reject);\n }\n });\n }\n\n static _immediate(callback: Function): void {\n const ignored = setTimeout(callback, 0);\n }\n\n static _unhandledRejection(error): void {\n if (typeof console !== 'undefined' && console) {\n console.warn('Possible Unhandled Promise Rejection:', error); // eslint-disable-line no-console\n }\n }\n}\n\nPromise.prototype['catch'] = function(onRejected: Function): Promise | void {\n return this.then(null, onRejected);\n};\n\nPromise.prototype['then'] = function(onFulfilled: Function, onRejected: Function): Promise | void {\n const promise = new this.constructor(() => null);\n\n this.handle(new PromiseHandler(onFulfilled, onRejected, promise));\n\n return promise;\n};\n\nPromise.prototype['finally'] = function(callback: Function): Promise | void {\n const constructor = this.constructor;\n\n return this.then(\n value => constructor.resolve(callback()).then(() => value),\n reason => constructor.resolve(callback()).then(() => constructor.reject(reason))\n );\n};\n\nexport default Promise;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {IAppender} from './IAppender';\nimport Appenders from './Appenders';\nimport LoggingThreshold from './LoggingThreshold';\n\nexport enum LoggingLevel {\n All = -1,\n Trace = 10,\n Debug = 20,\n Info = 30,\n Warn = 40,\n Error = 50,\n Fatal = 60,\n Off = 100,\n}\n\nexport type LoggingLevelInputTypes = 'Off' | 'Trace' | 'Debug' | 'Info' | 'Warn' | 'Error' | 'Fatal' | 'All';\n\nexport default class Logger {\n private readonly _category: string;\n private readonly _appenders: Appenders;\n private readonly _threshold: LoggingThreshold;\n\n get category(): string {\n return this._category;\n }\n\n get appenders(): Appenders {\n return this._appenders;\n }\n\n get threshold(): LoggingThreshold {\n return this._threshold;\n }\n\n trace(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Trace) {\n return;\n }\n\n this.log(LoggingLevel.Trace, args);\n }\n\n debug(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Debug) {\n return;\n }\n\n this.log(LoggingLevel.Debug, args);\n }\n\n info(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Info) {\n return;\n }\n\n this.log(LoggingLevel.Info, args);\n }\n\n warn(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Warn) {\n return;\n }\n\n this.log(LoggingLevel.Warn, args);\n }\n\n error(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Error) {\n return;\n }\n\n this.log(LoggingLevel.Error, args);\n }\n\n fatal(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Fatal) {\n return;\n }\n\n this.log(LoggingLevel.Fatal, args);\n }\n\n private log(level: number, args: any): void {\n const date = new Date();\n const message = this.replacePlaceholders(args);\n\n this._appenders.value.forEach((appender: IAppender) => {\n appender.log(level, message, this.category, date);\n });\n }\n\n private replacePlaceholders(args: any): string {\n let replacePlaceholdersString = args[0];\n let index = 0;\n\n while (replacePlaceholdersString.indexOf && args.length > 1 && index >= 0) {\n index = replacePlaceholdersString.indexOf('%', index);\n\n if (index > 0) {\n const type = replacePlaceholdersString.substring(index + 1, index + 2);\n\n switch (type) {\n case '%':\n // Escaped '%%' turns into '%'\n replacePlaceholdersString = replacePlaceholdersString.substring(0, index) + replacePlaceholdersString.substring(index + 1);\n index++;\n\n break;\n case 's':\n case 'd':\n // Replace '%d' or '%s' with the argument\n args[0] = replacePlaceholdersString = this.replaceArgument(\n this.toString(args[1]),\n replacePlaceholdersString,\n index\n );\n args.splice(1, 1);\n\n break;\n case 'j':\n // Replace %j' with the argument\n args[0] = replacePlaceholdersString = this.replaceArgument(\n this.stringify(args[1]),\n replacePlaceholdersString,\n index\n );\n\n args.splice(1, 1);\n\n break;\n default:\n return args.toString();\n }\n }\n }\n\n if (args.length > 1) {\n args = args.reduce((accumulator, currentValue, index, array) => {\n if (index + 1 === array.length && currentValue instanceof Error) {\n return accumulator + '\\n' + this.toString(currentValue.stack);\n }\n\n return accumulator + `[${this.toString(currentValue)}]`;\n });\n }\n\n return args.toString();\n }\n\n private stringify(arg: any): string {\n const cache = [];\n\n try {\n return JSON.stringify(\n arg instanceof Error ? this.toString(arg) : arg,\n (key, value) => {\n if (!!value && value instanceof Object) {\n if (cache.includes(value)) {\n return '<recursive>';\n }\n\n cache.push(value);\n }\n\n return value;\n },\n 2\n );\n } catch (e) {\n return '[object invalid JSON.stringify]';\n }\n }\n\n private replaceArgument(argument: any, replacePlaceholdersString: string, index: number): string {\n return replacePlaceholdersString.substring(0, index) + this.toString(argument) + replacePlaceholdersString.substring(index + 2);\n }\n\n private toString(data: any): string {\n if (typeof data === 'string') {\n return data;\n }\n\n if (typeof data === 'boolean') {\n return data ? 'true' : 'false';\n }\n\n if (typeof data === 'number') {\n return data.toString();\n }\n\n let toStringStr = '';\n\n if (data) {\n if (typeof data === 'function') {\n toStringStr = data.toString();\n } else if (data instanceof Object) {\n try {\n toStringStr = data.toString();\n } catch (e) {\n toStringStr = '[object invalid toString()]';\n }\n }\n }\n\n return toStringStr;\n }\n\n constructor(category: string, appenders: Appenders, threshold: LoggingThreshold) {\n this._category = category;\n this._appenders = appenders;\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {IAppender} from './IAppender';\n\nexport default class Appenders {\n private _appenders: Array<IAppender> = [];\n\n get value(): Array<IAppender> {\n return this._appenders;\n }\n\n add(appender: IAppender): void {\n this._appenders.push(appender);\n }\n\n remove(appender): void {\n this._appenders = this._appenders.reduce((items, item) => {\n if (!(item === appender)) {\n items.push(item);\n }\n\n return items;\n }, [] as Array<IAppender>);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\ndeclare const __PRIVACY_MODE__: boolean;\n\nexport default class PrivacyMode {\n private static _isPrivate: boolean;\n\n static get isPrivate(): boolean {\n return this._isPrivate;\n }\n\n static applyIsPrivate(): void {\n try {\n this._isPrivate = __PRIVACY_MODE__;\n } catch (e) {\n this._isPrivate = false;\n }\n }\n}\n\nPrivacyMode.applyIsPrivate();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport PrivacyMode from '../dom/PrivacyMode';\nimport {LoggingLevel} from '../logger/Logger';\n\nexport default class LoggerDefaults {\n static get defaultLoggingLevel(): LoggingLevel {\n return PrivacyMode.isPrivate ? LoggingLevel.Off : LoggingLevel.All;\n }\n\n static get defaultConsoleLoggingLevel(): LoggingLevel {\n return PrivacyMode.isPrivate ? LoggingLevel.Off : LoggingLevel.All;\n }\n\n static get defaultTelemetryLoggingLevel(): LoggingLevel {\n return LoggingLevel.Info;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerDefaults from './LoggerDefaults';\nimport {LoggingLevel} from './Logger';\n\nexport default class LoggingThreshold {\n private _threshold: LoggingLevel = LoggerDefaults.defaultLoggingLevel;\n\n get value(): LoggingLevel {\n return this._threshold;\n }\n\n setThreshold(threshold: LoggingLevel): void {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {IAppender} from './IAppender';\nimport {LoggingLevel} from './Logger';\n\nexport default class ConsoleAppender implements IAppender {\n private readonly _threshold: LoggingLevel;\n\n log(logLevel: LoggingLevel, message: string, category: string, date: Date): void {\n if (logLevel < this._threshold) {\n return;\n }\n\n const fullMessage = `${date.toISOString()} [${category}] [${LoggingLevel[logLevel]}] ${message}`;\n\n if (logLevel < LoggingLevel.Warn) {\n console.log(fullMessage);\n\n return;\n }\n\n console.error(fullMessage);\n }\n\n constructor(threshold: LoggingLevel) {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\ndeclare const __SDKVERSION__: string;\n\nexport default class VersionManager {\n private static _defaultVersion = new Date().toISOString();\n\n static get sdkVersion(): string {\n try {\n return __SDKVERSION__;\n } catch (e) {\n return this._defaultVersion;\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {LoggingLevel} from '../logger/Logger';\nimport VersionManager from '../sdk/version/VersionManager';\nimport TelemetryConfiguration from './TelemetryConfiguration';\n\nconst requestSizeLimit = 8192;\n\ninterface ILogItem {\n timestamp: string;\n tenancy: string;\n level: string;\n category: string;\n message: string;\n sessionId: string;\n version: string;\n environment: string;\n fullQualifiedName: string;\n}\n\nexport default class TelemetryService {\n private readonly _telemetryConfiguration: TelemetryConfiguration;\n\n private _logs: Array<ILogItem> = [];\n private _isSending: boolean;\n private _domain = location.hostname;\n\n constructor(telemetryConfiguration: TelemetryConfiguration) {\n this._telemetryConfiguration = telemetryConfiguration;\n }\n\n push(logLevel: LoggingLevel, message: string, category: string, timestamp: Date): void {\n const logRecord = {\n timestamp: timestamp.toISOString(),\n tenancy: this._telemetryConfiguration.tenancy,\n level: LoggingLevel[logLevel],\n category,\n message,\n sessionId: this._telemetryConfiguration.sessionId,\n version: VersionManager.sdkVersion,\n environment: this._telemetryConfiguration.environment,\n fullQualifiedName: this._domain\n };\n\n if (logLevel < LoggingLevel.Error) {\n this._logs.push(logRecord);\n } else {\n this._logs.unshift(logRecord);\n }\n\n const ignored = this.sendLogsIfAble();\n }\n\n private async sendLogs(logMessages: Array<ILogItem>): Promise<Response | void> {\n const formData = new FormData();\n\n formData.append('jsonBody', JSON.stringify({records: logMessages}));\n\n return await fetch(this._telemetryConfiguration.url, {\n method: 'POST',\n body: formData\n });\n }\n\n private async sendLogsIfAble(): Promise<Response | void> {\n if (this._logs.length <= 0 || this._isSending) {\n return;\n }\n\n let numberOfLogsToSend = 0;\n let sizeOfLogsToSend = 0;\n\n this._isSending = true;\n\n const getLogSize = (log: ILogItem): number => Object.values(log)\n .reduce((sum, item) => sum + (item ? item.length : 0), 0);\n\n while (this._logs.length > numberOfLogsToSend && getLogSize(this._logs[numberOfLogsToSend]) + sizeOfLogsToSend < requestSizeLimit) {\n sizeOfLogsToSend += getLogSize(this._logs[numberOfLogsToSend]);\n numberOfLogsToSend++;\n }\n\n if (!numberOfLogsToSend) {\n this._logs[numberOfLogsToSend].message = this._logs[numberOfLogsToSend].message.substring(0,\n getLogSize(this._logs[numberOfLogsToSend]) + (requestSizeLimit - getLogSize(this._logs[numberOfLogsToSend])));\n numberOfLogsToSend = 1;\n }\n\n const logMessages = this._logs.slice(0, numberOfLogsToSend);\n\n this._logs = this._logs.slice(numberOfLogsToSend);\n\n return this.sendLogs(logMessages).then(response => {\n this._isSending = false;\n\n const ignored = this.sendLogsIfAble();\n\n return response;\n }).catch(() => {\n this._isSending = false;\n\n const ignored = this.sendLogsIfAble();\n });\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport TelemetryDefault from './TelemetryDefault';\n\nexport enum TelemetryLevel {\n Off = 100,\n Essential = 10,\n All = -1\n}\n\nexport type TelemetryLevelType = 'Off' | 'Essential' | 'All';\n\nexport default class MetricsConfiguration {\n private _url = 'https://telemetry.phenixrts.com/telemetry/metrics';\n private _tenancy: string;\n private _sessionId: string;\n private _environment: string;\n private _threshold: TelemetryLevel = TelemetryDefault.defaultTelemetryLevel;\n\n get url(): string {\n return this._url;\n }\n\n set url(url: string) {\n const metricsUrl = new URL(url);\n\n metricsUrl.pathname = metricsUrl.pathname + '/metrics';\n\n this._url = metricsUrl.toString();\n }\n\n get environment(): string {\n return this._environment;\n }\n\n set environment(environment: string) {\n this._environment = environment;\n }\n\n get tenancy(): string {\n return this._tenancy;\n }\n\n set tenancy(tenancy: string) {\n this._tenancy = tenancy;\n }\n\n get sessionId(): string {\n return this._sessionId;\n }\n\n set sessionId(sessionId: string) {\n this._sessionId = sessionId;\n }\n\n get threshold(): TelemetryLevel {\n return this._threshold;\n }\n\n set threshold(threshold: TelemetryLevel) {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport TelemetryService from './TelemetryService';\nimport TelemetryConfiguration from './TelemetryConfiguration';\nimport {IAppender} from '../logger/IAppender';\nimport {LoggingLevel} from '../logger/Logger';\n\nexport default class TelemetryAppender implements IAppender {\n private readonly _telemetryService: TelemetryService;\n private readonly _tenancy: string;\n private readonly _sessionId: string;\n private readonly _threshold: LoggingLevel;\n\n constructor(telemetryConfiguration: TelemetryConfiguration) {\n this._tenancy = telemetryConfiguration.tenancy;\n this._sessionId = telemetryConfiguration.sessionId;\n this._threshold = telemetryConfiguration.threshold;\n this._telemetryService = new TelemetryService(telemetryConfiguration);\n }\n\n log(logLevel: LoggingLevel, message: string, category: string, date: Date): void {\n if (logLevel < this._threshold) {\n return;\n }\n\n this._telemetryService.push(logLevel, message, category, date);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {LoggingLevel} from '../logger/Logger';\nimport LoggerDefaults from '../logger/LoggerDefaults';\n\nexport default class TelemetryConfiguration {\n private _url = 'https://telemetry.phenixrts.com/telemetry/logs';\n private _tenancy: string;\n private _sessionId: string;\n private _environment: string;\n private _threshold = LoggerDefaults.defaultTelemetryLoggingLevel;\n\n get url(): string {\n return this._url;\n }\n\n set url(url: string) {\n const telemetryUrl = new URL(url);\n\n telemetryUrl.pathname = telemetryUrl.pathname + '/logs';\n\n this._url = telemetryUrl.toString();\n }\n\n get environment(): string {\n return this._environment;\n }\n\n set environment(environment: string) {\n this._environment = environment;\n }\n\n get tenancy(): string {\n return this._tenancy;\n }\n\n set tenancy(tenancy: string) {\n this._tenancy = tenancy;\n }\n\n get sessionId(): string {\n return this._sessionId;\n }\n\n set sessionId(sessionId: string) {\n this._sessionId = sessionId;\n }\n\n get threshold(): LoggingLevel {\n return this._threshold;\n }\n\n set threshold(threshold: LoggingLevel) {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport PrivacyMode from '../dom/PrivacyMode';\nimport {TelemetryLevel} from '../metrics/MetricsConfiguration';\n\nexport default class TelemetryDefault {\n static get defaultTelemetryLevel(): TelemetryLevel {\n return PrivacyMode.isPrivate ? TelemetryLevel.Essential : TelemetryLevel.All;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nexport function assertUnreachable(x: never): never {\n throw new Error(`Unexpected value [${x}]. This should never be reached`);\n}\n\nexport default assertUnreachable;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {TelemetryLevel, TelemetryLevelType} from './MetricsConfiguration';\nimport assertUnreachable from '../lang/assertUnreachable';\n\nexport default class TelemetryLevelMapping {\n static convertTelemetryLevelToTelemetryLevelType(telemetryLevel: TelemetryLevel): TelemetryLevelType {\n switch (telemetryLevel) {\n case TelemetryLevel.Off:\n return 'Off';\n case TelemetryLevel.Essential:\n return 'Essential';\n case TelemetryLevel.All:\n return 'All';\n default:\n assertUnreachable(telemetryLevel);\n }\n }\n\n static convertTelemetryLevelTypeToTelemetryLevel(telemetryLevelType: TelemetryLevelType): TelemetryLevel {\n switch (telemetryLevelType) {\n case 'Off':\n return TelemetryLevel.Off;\n case 'Essential':\n return TelemetryLevel.Essential;\n case 'All':\n return TelemetryLevel.All;\n default:\n assertUnreachable(telemetryLevelType);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport assertUnreachable from '../lang/assertUnreachable';\nimport {LoggingLevel, LoggingLevelInputTypes} from './Logger';\n\nexport default class LoggingLevelMapping {\n static convertLoggingLevelToLoggingLevelType(loggingLevel: LoggingLevel): LoggingLevelInputTypes {\n switch (loggingLevel) {\n case LoggingLevel.Off:\n return 'Off';\n case LoggingLevel.Trace:\n return 'Trace';\n case LoggingLevel.Debug:\n return 'Debug';\n case LoggingLevel.Info:\n return 'Trace';\n case LoggingLevel.Warn:\n return 'Warn';\n case LoggingLevel.Error:\n return 'Error';\n case LoggingLevel.Fatal:\n return 'Fatal';\n case LoggingLevel.All:\n return 'All';\n default:\n assertUnreachable(loggingLevel);\n }\n }\n\n static convertLoggingLevelTypeToLoggingLevel(loggingLevelType: LoggingLevelInputTypes): LoggingLevel {\n switch (loggingLevelType) {\n case 'Off':\n return LoggingLevel.Off;\n case 'Trace':\n return LoggingLevel.Trace;\n case 'Debug':\n return LoggingLevel.Debug;\n case 'Info':\n return LoggingLevel.Info;\n case 'Warn':\n return LoggingLevel.Warn;\n case 'Error':\n return LoggingLevel.Error;\n case 'Fatal':\n return LoggingLevel.Fatal;\n case 'All':\n return LoggingLevel.All;\n default:\n assertUnreachable(loggingLevelType);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport TelemetryLevelMapping from '../metrics/TelemetricLevelMapping';\nimport TelemetryDefault from '../metrics/TelemetryDefault';\nimport LoggingLevelMapping from '../logger/LoggingLevelMapping';\nimport LoggerDefaults from '../logger/LoggerDefaults';\n\n// This file is used only for the silent build to mock ConfigurationParameterReader class\nexport default class PlainConfigurationParameterReader {\n getStringValue(name: string): string {\n return this.defaultStringValue[name];\n }\n\n getBooleanValue(name: string): boolean {\n return this.defaultBooleanValue[name];\n }\n\n private get defaultStringValue(): { [name: string]: string } {\n return {\n 'phenix-metrics-level': TelemetryLevelMapping.convertTelemetryLevelToTelemetryLevelType(TelemetryDefault.defaultTelemetryLevel),\n 'phenix-logging-level': LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(LoggerDefaults.defaultLoggingLevel),\n 'phenix-console-logging-level': LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(LoggerDefaults.defaultConsoleLoggingLevel),\n 'phenix-telemetry-logging-level': LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(LoggerDefaults.defaultTelemetryLoggingLevel),\n 'phenix-channel-token': '',\n 'phenix-uri': '',\n 'phenix-base-uri': ''\n };\n }\n\n private get defaultBooleanValue(): { [name: string]: boolean } {\n return {\n 'phenix-automatically-retry-on-failure': true,\n 'phenix-automatically-reconnect-peer-connection': true\n };\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {ILogger} from './LoggerInterface';\nimport Logger, {LoggingLevel} from './Logger';\nimport Appenders from './Appenders';\nimport LoggingThreshold from './LoggingThreshold';\nimport ConsoleAppender from './ConsoleAppender';\nimport TelemetryAppender from '../telemetry/TelemetryApender';\nimport TelemetryConfiguration from '../telemetry/TelemetryConfiguration';\nimport ConfigurationParameterReader from '../dom/ConfigurationParameterReader';\nimport {IConfigurationParameterReader} from '../dom/IConfigurationParamaterReader';\nimport LoggerDefaults from './LoggerDefaults';\n\nexport default class LoggerFactory {\n private static _configurationParameterReader: IConfigurationParameterReader = new ConfigurationParameterReader();\n private static _loggers: {[category: string]: ILogger} = {};\n private static _appenders: Appenders = new Appenders();\n private static _threshold: LoggingThreshold = new LoggingThreshold();\n private static _telemetryConfiguration: TelemetryConfiguration = new TelemetryConfiguration();\n\n static get telemetryConfiguration(): TelemetryConfiguration {\n return LoggerFactory._telemetryConfiguration;\n }\n\n static getLogger(category: string): ILogger {\n if (typeof category !== 'string') {\n category = 'SDK';\n }\n\n const logger = LoggerFactory._loggers[category];\n\n if (logger) {\n return logger;\n }\n\n return LoggerFactory._loggers[category] = new Logger(category, this._appenders, this._threshold);\n }\n\n static applyLoggerConfigFromParameterConfiguration(): void {\n LoggerFactory.applyLoggingLevel();\n LoggerFactory.applyAppenderLoggingLevel('console', LoggerFactory.applyConsoleLogger.bind(this));\n LoggerFactory.applyAppenderLoggingLevel('telemetry', LoggerFactory.applyTelemetryLogger.bind(this));\n }\n\n private static applyLoggingLevel(): void {\n const parameterValue = this._configurationParameterReader.getStringValue('phenix-logging-level');\n\n if (LoggingLevel[parameterValue]) {\n this._threshold.setThreshold(LoggingLevel[parameterValue]);\n }\n\n return;\n }\n\n private static applyAppenderLoggingLevel(name: string, applyAppender: (level: LoggingLevel) => void): void {\n const parameterValue = this._configurationParameterReader.getStringValue(`phenix-${name}-logging-level`);\n\n if (parameterValue === 'Off') {\n return;\n }\n\n applyAppender(LoggingLevel[parameterValue]);\n }\n\n private static applyConsoleLogger(level: LoggingLevel): void {\n this._appenders.add(new ConsoleAppender(level || LoggerDefaults.defaultConsoleLoggingLevel));\n }\n\n private static applyTelemetryLogger(level: LoggingLevel): void {\n this._telemetryConfiguration.threshold = level || LoggerDefaults.defaultTelemetryLoggingLevel;\n\n this._appenders.add(new TelemetryAppender(this._telemetryConfiguration));\n }\n\n private constructor() {\n throw new Error('LoggerFactory is a static class that may not be instantiated');\n }\n}\n\nLoggerFactory.applyLoggerConfigFromParameterConfiguration();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nexport default class Strings {\n static random(length: number): string {\n const random13Characters = (): string => {\n return Math.random().toString(16).substring(2, 15);\n };\n\n const loops: number = Math.ceil(length / 13);\n\n return new Array(loops).fill(random13Characters).reduce((string, func) => {\n return string + func();\n }, '').substring(0, length);\n }\n\n private constructor() {\n throw new Error('Strings is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IDisposable from './IDisposable';\n\nexport default class Disposable implements IDisposable {\n private _disposed: boolean;\n private _disposable: () => void;\n\n constructor(disposable: () => void) {\n this._disposed = false;\n this._disposable = disposable;\n }\n\n dispose(): void {\n if (this._disposed) {\n return;\n }\n\n this._disposed = true;\n\n return this._disposable.call(this);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport IDisposable from '../lang/IDisposable';\nimport Disposable from '../lang/Disposable';\nimport IComparable from '../lang/IComparable';\n\nclass DisposableListener<T> extends Disposable {\n constructor(listeners: Array<T>, listener: T) {\n super(() => {\n const idx = listeners.indexOf(listener);\n\n if (idx >= 0) {\n listeners.splice(idx, 1);\n }\n });\n }\n}\n\nexport default class Subject<T> {\n private readonly _listeners: Array<(T) => void>;\n private _value: T;\n\n constructor(value: T) {\n this._listeners = [];\n this._value = value;\n }\n\n set value(value: T) {\n let changed = this._value !== value;\n\n if (changed && value) {\n const comparable = value as unknown as IComparable<T>;\n\n if (typeof comparable.equals === 'function') {\n changed = !comparable.equals(this._value);\n }\n }\n\n if (!changed) {\n return;\n }\n\n this._value = value;\n\n this._listeners.forEach(listener => {\n listener(value);\n });\n }\n\n get value(): T {\n return this._value;\n }\n\n subscribe(listener: (T) => void): IDisposable {\n this._listeners.push(listener);\n\n listener(this._value);\n\n return new DisposableListener<(T) => void>(this._listeners, listener);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport Subject from './Subject';\nimport IDisposable from '../lang/IDisposable';\n\nexport default class ReadOnlySubject<T> {\n private readonly _subject: Subject<T>;\n\n constructor(subject: Subject<T>) {\n this._subject = subject;\n }\n\n get value(): T {\n return this._subject.value;\n }\n\n subscribe(listener: (T) => void): IDisposable {\n return this._subject.subscribe(listener);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nexport default class BrowserDetector {\n private static readonly _browserNameAndVersionRegex = /(MSIE|(?!Gecko.+)Firefox|(?!AppleWebKit.+Chrome.+)Safari|(?!AppleWebKit.+)Chrome|AppleWebKit(?!.+Chrome|.+Safari)|Gecko(?!.+Firefox))(?: |\\/)([\\d.apre]+)/g;\n private static readonly _browserNameAndVersion = BrowserDetector.parseBrowserNameAndVersion();\n private static readonly _browserName = BrowserDetector.parseBrowserName();\n private static readonly _browserMajorVersion = BrowserDetector.parseBrowserMajorVersion();\n\n private static readonly _isChrome69 = BrowserDetector._browserNameAndVersion.includes('Chrome/69.');\n private static readonly _isChrome70 = BrowserDetector._browserNameAndVersion.includes('Chrome/70.');\n private static readonly _isChrome71 = BrowserDetector._browserNameAndVersion.includes('Chrome/71.');\n private static readonly _isChrome72 = BrowserDetector._browserNameAndVersion.includes('Chrome/72.');\n private static readonly _isChrome74 = BrowserDetector._browserNameAndVersion.includes('Chrome/74.');\n private static readonly _isChrome75 = BrowserDetector._browserNameAndVersion.includes('Chrome/75.');\n private static readonly _isChrome76 = BrowserDetector._browserNameAndVersion.includes('Chrome/76.');\n private static readonly _isChrome77 = BrowserDetector._browserNameAndVersion.includes('Chrome/77.');\n\n static get browserNameAndVersion(): string {\n return BrowserDetector._browserNameAndVersion;\n }\n\n static get browserName(): string {\n return this._browserName;\n }\n\n static get browserMajorVersion(): number {\n return this._browserMajorVersion;\n }\n\n static get isChrome69(): boolean {\n return BrowserDetector._isChrome69;\n }\n\n static get isChrome70(): boolean {\n return BrowserDetector._isChrome70;\n }\n\n static get isChrome71(): boolean {\n return BrowserDetector._isChrome71;\n }\n\n static get isChrome72(): boolean {\n return BrowserDetector._isChrome72;\n }\n\n static get isChrome74(): boolean {\n return BrowserDetector._isChrome74;\n }\n\n static get isChrome75(): boolean {\n return BrowserDetector._isChrome75;\n }\n\n static get isChrome76(): boolean {\n return BrowserDetector._isChrome76;\n }\n\n static get isChrome77(): boolean {\n return BrowserDetector._isChrome77;\n }\n\n private static parseBrowserNameAndVersion(): string {\n if (!navigator || !navigator.userAgent) {\n return '';\n }\n\n const browserNameAndVersion = navigator.userAgent.match(BrowserDetector._browserNameAndVersionRegex);\n\n if (browserNameAndVersion && browserNameAndVersion[0]) {\n return browserNameAndVersion[0];\n }\n\n return BrowserDetector.parseBrowserNameAndVersionForIE();\n }\n\n private static parseBrowserName(): string {\n if (!BrowserDetector._browserNameAndVersion) {\n return '';\n }\n\n const browserNameList = BrowserDetector._browserNameAndVersion.split('/');\n\n if (!browserNameList || !browserNameList[0]) {\n return '';\n }\n\n return browserNameList[0];\n }\n\n private static parseBrowserMajorVersion(): number {\n if (!BrowserDetector._browserNameAndVersion) {\n return 0;\n }\n\n const browserVersionList = BrowserDetector._browserNameAndVersion.split('/');\n\n if (!browserVersionList || !browserVersionList[1]) {\n return 0;\n }\n\n const fullVersion = browserVersionList[1];\n\n if (!fullVersion) {\n return 0;\n }\n\n return Number(fullVersion.split('.')[0]) || 0;\n }\n\n private static parseBrowserNameAndVersionForIE(): string {\n if (!navigator || !navigator.userAgent) {\n return '';\n }\n\n const userAgent = navigator.userAgent;\n const msie = userAgent.indexOf('MSIE ');\n\n if (msie > 0) {\n // IE 10 or older => return version number\n return `IE/${parseInt(userAgent.substring(msie + 5, userAgent.indexOf('.', msie)), 10)}`;\n }\n\n const trident = userAgent.indexOf('Trident/');\n\n if (trident > 0) {\n // IE 11 => return version number\n const version = userAgent.indexOf('rv:');\n\n return `IE/${parseInt(userAgent.substring(version + 3, userAgent.indexOf('.', version)), 10)}`;\n }\n\n return '';\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport BrowserDetector from '../../dom/BrowserDetector';\n\nexport default class FeatureEnablement {\n static get clientOfferDisabled(): boolean {\n // Client offer workflow does not work correctly in the following browsers\n return BrowserDetector.isChrome74 ||\n BrowserDetector.isChrome75 ||\n BrowserDetector.isChrome76 ||\n BrowserDetector.isChrome77;\n }\n\n static get addTranceiverDisabled(): boolean {\n // Chrome 69, 70, 71, 72 exposes `addTranceiver` but it does not work correctly\n return BrowserDetector.isChrome69 ||\n BrowserDetector.isChrome70 ||\n BrowserDetector.isChrome71 ||\n BrowserDetector.isChrome72;\n }\n\n static get getStatsPromiseBasedDisabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 66;\n }\n\n static get getCurrentOfferDisabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 69 ||\n BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion <= 56;\n }\n\n static get onTrackDisabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 63 ||\n BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion <= 52;\n }\n\n static get webkitRTCPeerConnectionEnabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 55;\n }\n\n static get promiseBasedPCMethodsDisabled(): boolean {\n return BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion <= 52;\n }\n\n static get shouldUseNativeHls(): boolean {\n return BrowserDetector.browserName === 'Safari' ||\n BrowserDetector.browserName === 'SamsungBrowser';\n }\n\n static get isRTMPEnabled(): boolean {\n return (BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion < 84) ||\n (BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion < 70) ||\n BrowserDetector.browserName === 'Edge' ||\n BrowserDetector.browserName === 'IE';\n }\n\n static get isPrecachingEnabled(): boolean {\n return BrowserDetector.browserName !== 'IE';\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport IPeerConnection, {PeerConnectionEvents} from './IPeerConnection';\nimport {ILogger} from '../logger/LoggerInterface';\nimport FeatureEnablement from '../sdk/feature/FeatureEnablement';\nimport {ILegacyRTCStatsReport} from './RtcConnectionMonitor';\n\nclass VanillaPeerConnection implements IPeerConnection {\n private readonly _logger: ILogger = LoggerFactory.getLogger('VanillaPeerConnection');\n private readonly _peerConnection: RTCPeerConnection;\n\n constructor(configuration?: RTCConfiguration) {\n if (FeatureEnablement.webkitRTCPeerConnectionEnabled) {\n this._peerConnection = new webkitRTCPeerConnection(configuration);\n\n return;\n }\n\n this._peerConnection = new RTCPeerConnection(configuration);\n }\n\n get native(): RTCPeerConnection {\n return this._peerConnection;\n }\n\n get currentLocalDescription(): RTCSessionDescription | null {\n return this._peerConnection.currentLocalDescription;\n }\n\n get currentRemoteDescription(): RTCSessionDescription | null {\n return this._peerConnection.currentRemoteDescription;\n }\n\n get iceConnectionState(): RTCIceConnectionState {\n return this._peerConnection.iceConnectionState;\n }\n\n get supportsGetConfiguration(): boolean {\n return typeof this._peerConnection.getConfiguration === 'function';\n }\n\n get supportsSetConfiguration(): boolean {\n return typeof this._peerConnection.setConfiguration === 'function';\n }\n\n get supportsAddTransceiver(): boolean {\n return !FeatureEnablement.addTranceiverDisabled && typeof this._peerConnection.addTransceiver === 'function';\n }\n\n async createOffer(options?: RTCOfferOptions): Promise<RTCSessionDescriptionInit> {\n if (FeatureEnablement.promiseBasedPCMethodsDisabled) {\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n return new Promise((resolve, reject) => this._peerConnection.createOffer(resolve, reject, options));\n /* eslint-enable */\n }\n\n return this._peerConnection.createOffer(options);\n }\n\n async createAnswer(options?: RTCAnswerOptions): Promise<RTCSessionDescriptionInit> {\n if (FeatureEnablement.promiseBasedPCMethodsDisabled) {\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n return new Promise((resolve, reject) => this._peerConnection.createAnswer(resolve, reject, options));\n /* eslint-enable */\n }\n\n return this._peerConnection.createAnswer(options);\n }\n\n async setLocalDescription(description: RTCSessionDescriptionInit): Promise<void> {\n return this._peerConnection.setLocalDescription(FeatureEnablement.promiseBasedPCMethodsDisabled ?\n new RTCSessionDescription(description) : description);\n }\n\n async setRemoteDescription(description: RTCSessionDescriptionInit): Promise<void> {\n const hasCrypto = description.sdp.match(/a=crypto:/i);\n\n if (hasCrypto) {\n this._logger.warn('SDP a=crypto is not supported');\n }\n\n return this._peerConnection.setRemoteDescription(FeatureEnablement.promiseBasedPCMethodsDisabled ?\n new RTCSessionDescription(description) : description);\n }\n\n getStats(selector?: MediaStreamTrack | null): Promise<RTCStatsReport> {\n return this._peerConnection.getStats(selector);\n }\n\n getStatsLegacy(): Promise<ILegacyRTCStatsReport> {\n return new Promise(resolve => {\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n const ignored = this._peerConnection.getStats(resolve);\n /* eslint-enable */\n });\n }\n\n addEventListener(type: PeerConnectionEvents, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void {\n this._peerConnection.addEventListener(type, listener, options);\n }\n\n removeEventListener(type: PeerConnectionEvents, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void {\n this._peerConnection.removeEventListener(type, listener, options);\n }\n\n addTransceiver(name: string, options: RTCRtpTransceiverInit): RTCRtpTransceiver {\n return this._peerConnection.addTransceiver(name, options);\n }\n\n getConfiguration(): RTCConfiguration {\n return this._peerConnection.getConfiguration();\n }\n\n setConfiguration(configuration: RTCConfiguration): void {\n this._peerConnection.setConfiguration(configuration);\n }\n\n set ontrack(handler: ((this: RTCPeerConnection, ev: RTCTrackEvent) => unknown) | null) {\n this._peerConnection.ontrack = handler;\n }\n\n get ontrack(): ((this: RTCPeerConnection, ev: RTCTrackEvent) => unknown) | null {\n return this._peerConnection.ontrack;\n }\n\n set onicecandidate(handler: ((this: RTCPeerConnection, ev: RTCPeerConnectionIceEvent) => unknown) | null) {\n this._peerConnection.onicecandidate = handler;\n }\n\n get onicecandidate(): ((this: RTCPeerConnection, ev: RTCPeerConnectionIceEvent) => unknown) | null {\n return this._peerConnection.onicecandidate;\n }\n\n set oniceconnectionstatechange(handler: ((this: RTCPeerConnection, ev: Event) => unknown) | null) {\n this._peerConnection.oniceconnectionstatechange = handler;\n }\n\n get oniceconnectionstatechange(): ((this: RTCPeerConnection, ev: Event) => unknown) | null {\n return this._peerConnection.oniceconnectionstatechange;\n }\n\n close(): void {\n this._peerConnection.close();\n }\n}\n\nexport default VanillaPeerConnection;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport IPeerConnectionFactory from './IPeerConnectionFactory';\nimport IPeerConnection from './IPeerConnection';\nimport VanillaPeerConnection from './VanillaPeerConnection';\n\nclass VanillaPeerConnectionFactory implements IPeerConnectionFactory {\n async createPeerConnection(configuration?: RTCConfiguration): Promise<IPeerConnection> {\n return new VanillaPeerConnection(configuration);\n }\n}\n\nexport default VanillaPeerConnectionFactory;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport {IEdgeAuth} from './EdgeAuthToken';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport {EdgeToken} from './EdgeToken';\n\nconst edgeAuthTokenPrefix = 'DIGEST:';\n\nexport default class EdgeAuth {\n private static _logger: ILogger = LoggerFactory.getLogger('EdgeAuth');\n\n static parseToken(token: EdgeToken): IEdgeAuth {\n if (!this.isValidToken(token)) {\n EdgeAuth._logger.error('Token is not valid [%s]', token);\n\n return undefined;\n }\n\n try {\n const encodedEdgeAuthToken = atob(token.substr(edgeAuthTokenPrefix.length));\n const edgeAuthToken = JSON.parse(encodedEdgeAuthToken);\n\n edgeAuthToken.token = JSON.parse(edgeAuthToken.token);\n\n return edgeAuthToken;\n } catch (e) {\n EdgeAuth._logger.error('Cannot parse token value', e);\n\n return undefined;\n }\n }\n\n static getUri(parsedToken: IEdgeAuth): URL {\n return parsedToken && parsedToken.token && parsedToken.token.uri ?\n new URL(parsedToken.token.uri) : null;\n }\n\n static getTenancy(parsedToken: IEdgeAuth): string {\n return parsedToken && parsedToken.applicationId ?\n parsedToken.applicationId : '';\n }\n\n static isValidToken(token: EdgeToken): boolean {\n return !!token && token.startsWith(edgeAuthTokenPrefix);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nenum MetricsType {\n TimeToFirstFrame,\n ChannelCreationTimeToFirstFrame,\n Stalled,\n Buffering,\n SetupCompleted,\n SetupFailed,\n RoundTripTime,\n DownlinkThroughputCapacity,\n NetworkType,\n ResolutionChanged,\n ApplicationForeground,\n ApplicationBackground\n}\n\nexport default MetricsType;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IDisposable from './IDisposable';\n\nexport default class DisposableList {\n private readonly _list: IDisposable[] = [];\n\n add(disposable: IDisposable): void {\n this._list.push(disposable);\n }\n\n dispose(): void {\n this._list.forEach(disposable => disposable.dispose());\n this._list.length = 0;\n }\n\n toString(): string {\n return `DisposableList[disposables=${this._list.length}]`;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport Disposable from '../lang/Disposable';\nimport Subject from '../rx/Subject';\nimport ReadOnlySubject from '../rx/ReadOnlySubject';\nimport DisposableList from '../lang/DisposableList';\n\nconst defaultDocumentFocusIntervalTimeout = 3000;\n\nexport default class ApplicationActivityMonitor {\n private readonly _disposables: DisposableList = new DisposableList();\n private readonly _readOnlyIsForeground: ReadOnlySubject<boolean>;\n private readonly _isForeground: Subject<boolean>;\n private _timeOfLastTabFocusChange: number = Date.now();\n private _documentFocusInterval: number;\n\n constructor() {\n this._isForeground = new Subject<boolean>(true);\n this._readOnlyIsForeground = new ReadOnlySubject(this._isForeground);\n this.detectTabFocusChange();\n }\n\n get isForeground(): ReadOnlySubject<boolean> {\n return this._readOnlyIsForeground;\n }\n\n getTimeSinceLastChange(): number {\n return Date.now() - this._timeOfLastTabFocusChange;\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private detectTabFocusChange(): void {\n let hidden;\n let visibilityChange;\n\n if (typeof document !== 'object') {\n return;\n }\n\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n if (typeof document.msHidden !== 'undefined') {\n hidden = 'msHidden';\n visibilityChange = 'msvisibilitychange';\n // @ts-ignore\n } else if (typeof document.webkitHidden !== 'undefined') {\n hidden = 'webkitHidden';\n visibilityChange = 'webkitvisibilitychange';\n } else if (typeof document.hidden !== 'undefined') { // Opera 12.10 and Firefox 18 and later support\n hidden = 'hidden';\n visibilityChange = 'visibilitychange';\n }\n /* eslint-enable */\n\n const handleVisibilityChange = (): void => {\n const isForeground = !document[hidden];\n\n this.setFocusState(isForeground);\n };\n\n if (typeof document.addEventListener !== 'undefined' && typeof document[hidden] !== 'undefined') {\n document.addEventListener(visibilityChange, handleVisibilityChange, false);\n\n this._disposables.add(new Disposable(() => {\n document.removeEventListener(visibilityChange, handleVisibilityChange, false);\n }));\n } else {\n this.listenForDocumentFocus.call(this);\n }\n }\n\n private listenForDocumentFocus(): void {\n this._documentFocusInterval = window.setInterval(() => {\n const isForeground = document.hasFocus();\n\n this.setFocusState(isForeground);\n }, defaultDocumentFocusIntervalTimeout);\n\n this._disposables.add(new Disposable(() => {\n if (this._documentFocusInterval) {\n clearInterval(this._documentFocusInterval);\n }\n\n this._documentFocusInterval = null;\n }));\n }\n\n private setFocusState(isForeground): void {\n if (this._isForeground === isForeground) {\n return;\n }\n\n this._isForeground.value = isForeground;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class TelemetryUrl {\n static getTelemetryUrl(url: string): string {\n try {\n const baseURL = new URL(url);\n const segments = baseURL.hostname.split('.');\n\n switch (baseURL.protocol) {\n case 'ws:':\n baseURL.protocol = 'http:';\n\n break;\n case 'wss:':\n baseURL.protocol = 'https:';\n\n break;\n\n default:\n break;\n }\n\n if (segments.length === 2 ||\n (segments.length === 3 && segments[segments.length - 2].length <= 2 && segments[segments.length - 1].length <= 3)\n ) {\n segments.unshift('telemetry');\n } else if (segments[0].startsWith('stg-') || segments[0].endsWith('-stg') || segments[0].includes('-stg-') || segments[0] === 'stg') {\n segments[0] = 'telemetry-stg';\n } else if (segments[0].startsWith('local') || segments[0].endsWith('-local')) {\n // Leave URL unchanged\n } else {\n segments[0] = 'telemetry';\n }\n\n baseURL.hostname = segments.join('.');\n\n return `${baseURL.origin}/telemetry`;\n } catch (e) {\n return url;\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class Environment {\n static getEnvironmentFromUrl(url: string): string {\n try {\n const baseURL = new URL(url);\n\n return baseURL.origin;\n } catch (e) {\n return '';\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport {defaultDiscoveryUri} from '../defaults';\nimport Subject from '../../rx/Subject';\nimport VersionManager from '../version/VersionManager';\n\nexport default class DiscoveryUri {\n private static readonly _discoveryUri: Subject<string> = new Subject<string>(defaultDiscoveryUri);\n\n static get uri(): Subject<string> {\n return DiscoveryUri._discoveryUri;\n }\n\n static buildDiscoveryUrl(uri: URL): string {\n const url = new URL(uri.toString());\n const sdkVersion = VersionManager.sdkVersion;\n\n url.search = `?${new URLSearchParams([['version', sdkVersion], ['_', `${Date.now()}`]]).toString()}`;\n\n if (url.pathname === '/') {\n url.pathname = '/pcast/endPoints';\n }\n\n return url.toString();\n }\n\n private constructor() {\n throw new Error('DiscoveryUri is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nconst defaultDiscoveryUri = 'https://pcast.phenixrts.com/pcast/endPoints';\n\nexport {defaultDiscoveryUri};","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {TelemetryLevel} from './MetricsConfiguration';\nimport assertUnreachable from '../lang/assertUnreachable';\nimport MetricsType from './MetricsType';\n\nexport default class MetricType {\n private readonly _metrics: MetricsType;\n\n constructor(metrics: MetricsType) {\n this._metrics = metrics;\n }\n\n getName(): string {\n return MetricsType[this._metrics];\n }\n\n getTelemetryLevel(): TelemetryLevel {\n switch (this._metrics) {\n case MetricsType.TimeToFirstFrame:\n return TelemetryLevel.Essential;\n case MetricsType.ChannelCreationTimeToFirstFrame:\n return TelemetryLevel.Essential;\n case MetricsType.Stalled:\n return TelemetryLevel.All;\n case MetricsType.Buffering:\n return TelemetryLevel.All;\n case MetricsType.SetupCompleted:\n return TelemetryLevel.All;\n case MetricsType.SetupFailed:\n return TelemetryLevel.All;\n case MetricsType.RoundTripTime:\n return TelemetryLevel.All;\n case MetricsType.DownlinkThroughputCapacity:\n return TelemetryLevel.All;\n case MetricsType.NetworkType:\n return TelemetryLevel.All;\n case MetricsType.ResolutionChanged:\n return TelemetryLevel.All;\n case MetricsType.ApplicationForeground:\n return TelemetryLevel.All;\n case MetricsType.ApplicationBackground:\n return TelemetryLevel.All;\n default:\n assertUnreachable(this._metrics);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport VersionManager from '../sdk/version/VersionManager';\nimport MetricsConfiguration from './MetricsConfiguration';\nimport MetricType from './MetricType';\nimport MetricsType from './MetricsType';\n\nconst requestSizeLimit = 1024;\n\ninterface IValue {\n string?: string;\n uint64?: number;\n float?: number;\n}\n\ninterface IMetricRecord {\n timestamp: string;\n tenancy: string;\n sessionId: string;\n streamId: string;\n metric: string;\n value: IValue;\n previousValue: IValue;\n fullQualifiedName: string;\n environment: string;\n version: string;\n runtime: number;\n resource?: string;\n kind?: string;\n}\n\ninterface IMetric {\n streamId?: string;\n metricType: MetricsType;\n value?: IValue;\n previousValue?: IValue;\n runtime: number;\n resource?: string;\n kind?: string;\n}\n\nexport default class MetricsService {\n private readonly _metricsConfiguration: MetricsConfiguration;\n private _metrics: Array<IMetricRecord> = [];\n private _isSending: boolean;\n private _domain = location.hostname;\n\n constructor(metricsConfiguration: MetricsConfiguration) {\n this._metricsConfiguration = metricsConfiguration;\n }\n\n get metricsConfiguration(): MetricsConfiguration {\n return this._metricsConfiguration;\n }\n\n push(metric: IMetric): void {\n const {streamId, value, previousValue, runtime, resource, kind} = metric;\n const metricType = new MetricType(metric.metricType);\n\n if (this._metricsConfiguration.threshold > metricType.getTelemetryLevel()) {\n return;\n }\n\n const metricRecord = {\n timestamp: new Date().toISOString(),\n tenancy: this._metricsConfiguration.tenancy,\n sessionId: this._metricsConfiguration.sessionId,\n streamId,\n metric: metricType.getName(),\n value,\n previousValue,\n fullQualifiedName: this._domain,\n environment: this._metricsConfiguration.environment,\n version: VersionManager.sdkVersion,\n runtime,\n resource,\n kind\n };\n\n this._metrics.push(metricRecord);\n\n const ignored = this.sendMetricsIfAble();\n }\n\n private async sendMetrics(metricsMessages: Array<IMetricRecord>): Promise<Response | void> {\n const formData = new FormData();\n\n formData.append('jsonBody', JSON.stringify({records: metricsMessages}));\n\n return await fetch(this._metricsConfiguration.url, {\n method: 'POST',\n body: formData\n });\n }\n\n private async sendMetricsIfAble(): Promise<Response | void> {\n if (this._metrics.length <= 0 || this._isSending) {\n return;\n }\n\n this._isSending = true;\n\n const metricsMessages = this._metrics.slice(0, requestSizeLimit);\n\n this._metrics = this._metrics.slice(requestSizeLimit);\n\n return this.sendMetrics(metricsMessages).then(response => {\n this._isSending = false;\n\n const ignored = this.sendMetricsIfAble();\n\n return response;\n }).catch(() => {\n this._isSending = false;\n\n const ignored = this.sendMetricsIfAble();\n });\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport MetricsService from './MetricsService';\nimport MetricsConfiguration, {TelemetryLevel} from './MetricsConfiguration';\nimport SDK from '../sdk/SDK';\nimport TelemetryUrl from '../sdk/TelemetryUrl';\nimport Environment from '../sdk/Environment';\nimport TelemetryLevelMapping from './TelemetricLevelMapping';\n\nexport default class MetricsFactory {\n private static _metricsServices: {[category: string]: MetricsService} = {};\n\n static getMetricsService(url: string): MetricsService {\n if (typeof url !== 'string') {\n throw new Error('ur');\n }\n\n const metricsServices = MetricsFactory._metricsServices[url];\n\n if (metricsServices) {\n return metricsServices;\n }\n\n const metricsConfiguration = new MetricsConfiguration();\n\n metricsConfiguration.sessionId = SDK.clientSessionId;\n metricsConfiguration.tenancy = SDK.tenancy.value;\n metricsConfiguration.url = TelemetryUrl.getTelemetryUrl(url);\n metricsConfiguration.environment = Environment.getEnvironmentFromUrl(url);\n\n metricsConfiguration.threshold = TelemetryLevelMapping.convertTelemetryLevelTypeToTelemetryLevel(SDK.telemetryLevel);\n\n return MetricsFactory._metricsServices[url] = new MetricsService(metricsConfiguration);\n }\n\n static setTelemetryLevel(telemetryLevel: TelemetryLevel): void {\n const metricsServices = Object.values(MetricsFactory._metricsServices);\n\n if (metricsServices && metricsServices.length) {\n metricsServices.forEach(metricsService => {\n const metricsConfiguration = metricsService.metricsConfiguration;\n\n metricsConfiguration.threshold = telemetryLevel;\n });\n }\n }\n\n private constructor() {\n throw new Error('LoggerFactory is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport Strings from '../lang/Strings';\nimport Subject from '../rx/Subject';\nimport ReadOnlySubject from '../rx/ReadOnlySubject';\nimport IPeerConnectionFactory from '../rtc/IPeerConnectionFactory';\nimport VanillaPeerConnectionFactory from '../rtc/VanillaPeerConnectionFactory';\nimport EdgeAuth from './edgeAuth/EdgeAuth';\nimport {ILogger} from '../logger/LoggerInterface';\nimport {LoggingLevel, LoggingLevelInputTypes} from '../logger/Logger';\nimport ConsoleAppender from '../logger/ConsoleAppender';\nimport TelemetryAppender from '../telemetry/TelemetryApender';\nimport ConfigurationParameterReader from '../dom/ConfigurationParameterReader';\nimport MetricsConfiguration, {TelemetryLevel, TelemetryLevelType} from '../metrics/MetricsConfiguration';\nimport MetricsService from '../metrics/MetricsService';\nimport TelemetryLevelMapping from '../metrics/TelemetricLevelMapping';\nimport LoggingLevelMapping from '../logger/LoggingLevelMapping';\nimport PrivacyMode from '../dom/PrivacyMode';\nimport BrowserDetector from '../dom/BrowserDetector';\nimport {IConfigurationParameterReader} from '../dom/IConfigurationParamaterReader';\nimport ApplicationActivityMonitor from '../dom/ApplicationActivityMonitor';\nimport TelemetryUrl from './TelemetryUrl';\nimport Environment from './Environment';\nimport {HlsPlayerType, ShakaType, WebPlayerType} from './streaming/StreamTypes';\nimport DiscoveryUri from './discovery/DiscoveryUri';\nimport MetricsFactory from '../metrics/MetricsFactory';\nimport TelemetryDefault from '../metrics/TelemetryDefault';\n\nconst pageLoadTime = window['__phenixPageLoadTime'] || window['__pageLoadTime'] || Date.now();\n\ninterface IInitOptions {\n discoveryUri?: string;\n peerConnectionFactory?: IPeerConnectionFactory;\n telemetryLevel?: TelemetryLevelType;\n loggingLevel?: LoggingLevelInputTypes;\n consoleLoggingLevel?: LoggingLevelInputTypes;\n automaticallyPlayMediaStream?: boolean;\n automaticallyMuteVideoOnPlayFailure?: boolean;\n webPlayerLoader?: (player: WebPlayerType) => void;\n shakaPlayerLoader?: (player: ShakaType) => void;\n hlsJsLoader?: (player: HlsPlayerType) => void;\n}\n\nexport default class SDK {\n private static _automaticallyRetryOnFailure = true;\n private static _automaticallyReconnectPeerConnection = true;\n private static _automaticallyPlayMediaStream = true;\n private static _automaticallyMuteVideoOnPlayFailure = true;\n private static _webPlayerLoader = null;\n private static _shakaPlayerLoader = null;\n private static _hlsJsLoader = null;\n private static _configurationParameterReader: IConfigurationParameterReader = new ConfigurationParameterReader();\n private static _applicationActivityMonitor: ApplicationActivityMonitor;\n private static _environment: Subject<string> = new Subject<string>('');\n private static _telemetryUrl: Subject<string> = new Subject<string>('https://telemetry.phenixrts.com/telemetry');\n private static _maximalNumberOfPeerConnectionReconnectAttempts = 8;\n private static _telemetryLevel: Subject<TelemetryLevel> = new Subject<TelemetryLevel>(TelemetryDefault.defaultTelemetryLevel);\n private static _metricsService: MetricsService;\n private static _metricsConfiguration: MetricsConfiguration\n private static readonly _sendLocalCandidates: Subject<boolean> = new Subject(!PrivacyMode.isPrivate);\n private static readonly _tenancy: Subject<string> = new Subject<string>('');\n private static readonly _clientSessionId: string = Strings.random(32);\n private static readonly _loadedTimestamp: Date = new Date();\n private static readonly _logger: ILogger = LoggerFactory.getLogger('SDK');\n private static readonly _initialized: Subject<boolean> = new Subject<boolean>(false);\n private static readonly _peerConnectionFactory: Subject<IPeerConnectionFactory> = new Subject<IPeerConnectionFactory>(new VanillaPeerConnectionFactory());\n private static readonly _readOnlyInitialized: ReadOnlySubject<boolean> = new ReadOnlySubject<boolean>(SDK._initialized);\n private static readonly _readOnlyDiscoveryUri: ReadOnlySubject<string> = new ReadOnlySubject<string>(DiscoveryUri.uri);\n private static readonly _readOnlyPeerConnectionFactory: ReadOnlySubject<IPeerConnectionFactory> = new ReadOnlySubject<IPeerConnectionFactory>(SDK._peerConnectionFactory);\n\n static get pageLoadTime(): number {\n return pageLoadTime;\n }\n\n static get sendLocalCandidates(): Subject<boolean> {\n return this._sendLocalCandidates;\n }\n\n static get tenancy(): Subject<string> {\n return this._tenancy;\n }\n\n static get clientSessionId(): string {\n return SDK._clientSessionId;\n }\n\n static get loadedTimestamp(): Date {\n return SDK._loadedTimestamp;\n }\n\n static get initialized(): ReadOnlySubject<boolean> {\n return SDK._readOnlyInitialized;\n }\n\n static get discoveryUri(): ReadOnlySubject<string> {\n return SDK._readOnlyDiscoveryUri;\n }\n\n static get peerConnectionFactory(): ReadOnlySubject<IPeerConnectionFactory> {\n return SDK._readOnlyPeerConnectionFactory;\n }\n\n static get automaticRetryOnFailure(): boolean {\n return SDK._automaticallyRetryOnFailure;\n }\n\n static get automaticallyReconnectPeerConnection(): boolean {\n return SDK._automaticallyReconnectPeerConnection;\n }\n\n static get automaticallyPlayMediaStream(): boolean {\n return SDK._automaticallyPlayMediaStream;\n }\n\n static get automaticallyMuteVideoOnPlayFailure(): boolean {\n return SDK._automaticallyMuteVideoOnPlayFailure;\n }\n\n static get webPlayerLoader(): (WebPlayerType) => void {\n return this._webPlayerLoader;\n }\n\n static get shakaPlayerLoader(): (ShakaType) => void {\n return this._shakaPlayerLoader;\n }\n\n static get hlsJsLoader(): (HlsPlayerType) => void {\n return this._hlsJsLoader;\n }\n\n static get metricsService(): MetricsService {\n return SDK._metricsService;\n }\n\n static get applicationActivityMonitor(): ApplicationActivityMonitor {\n return this._applicationActivityMonitor;\n }\n\n static get telemetryUrl(): Subject<string> {\n return this._telemetryUrl;\n }\n\n static get maximalNumberOfPeerConnectionReconnectAttempts(): number {\n return this._maximalNumberOfPeerConnectionReconnectAttempts;\n }\n\n static set maximalNumberOfPeerConnectionReconnectAttempts(retriesAmount: number) {\n this._maximalNumberOfPeerConnectionReconnectAttempts = retriesAmount;\n }\n\n static get loggingLevel(): LoggingLevelInputTypes {\n return LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(this._logger.threshold.value);\n }\n\n static get telemetryLevel(): TelemetryLevelType {\n return TelemetryLevelMapping.convertTelemetryLevelToTelemetryLevelType(SDK._telemetryLevel.value);\n }\n\n static get browserDetector(): BrowserDetector {\n return BrowserDetector;\n }\n\n static applyTelemetryConfiguration(): void {\n const telemetryConfiguration = LoggerFactory.telemetryConfiguration;\n\n telemetryConfiguration.sessionId = SDK.clientSessionId;\n\n const ignoredEnvironment = SDK._environment.subscribe(environment => {\n telemetryConfiguration.environment = environment;\n });\n const ignoredDiscoveryUri = SDK.telemetryUrl.subscribe(value => {\n const telemetryAppender = this._logger.appenders.value.find(appender => appender instanceof TelemetryAppender);\n\n if (telemetryAppender) {\n telemetryConfiguration.url = value;\n\n this._logger.appenders.remove(telemetryAppender);\n this._logger.appenders.add(new TelemetryAppender(telemetryConfiguration));\n this._logger.info('Telemetry URL was set to [%s]', telemetryConfiguration.url);\n }\n });\n const ignoredTenancy = SDK._tenancy.subscribe(tenancy => {\n const telemetryAppender = this._logger.appenders.value.find(appender => appender instanceof TelemetryAppender);\n\n if (telemetryAppender && tenancy) {\n telemetryConfiguration.tenancy = tenancy;\n\n this._logger.appenders.remove(telemetryAppender);\n this._logger.appenders.add(new TelemetryAppender(telemetryConfiguration));\n this._logger.info('Telemetry tenancy was set to [%s]', telemetryConfiguration.tenancy);\n }\n });\n }\n\n static applyMetricsConfiguration(): void {\n SDK._metricsService = MetricsFactory.getMetricsService(DiscoveryUri.uri.value);\n SDK._metricsConfiguration = SDK._metricsService.metricsConfiguration;\n\n SDK._metricsConfiguration.sessionId = SDK.clientSessionId;\n\n const ignoredEnvironment = SDK._environment.subscribe(environment => {\n SDK._metricsConfiguration.environment = environment;\n });\n const ignoredDiscoveryUri = SDK.telemetryUrl.subscribe(value => {\n SDK._metricsConfiguration.url = value;\n });\n const ignoredTenancy = SDK._tenancy.subscribe(tenancy => {\n SDK._metricsConfiguration.tenancy = tenancy;\n });\n const value = this._configurationParameterReader.getStringValue('phenix-metrics-level');\n\n if (value) {\n MetricsFactory.setTelemetryLevel(TelemetryLevel[value]);\n }\n\n const ignoredTelemetryLevel = SDK._telemetryLevel.subscribe(telemetryLevel => {\n MetricsFactory.setTelemetryLevel(telemetryLevel);\n });\n }\n\n static applyAutomaticallyRetryOnFailureFromParameterConfiguration(): void {\n this._automaticallyRetryOnFailure = this._configurationParameterReader.getBooleanValue('phenix-automatically-retry-on-failure');\n this._logger.info('Automatically retry on failure is set to: [%s]', this._automaticallyRetryOnFailure);\n\n return;\n }\n\n static applyAutomaticallyReconnectPeerConnectionFromParameterConfiguration(): void {\n this._automaticallyReconnectPeerConnection = this._configurationParameterReader.getBooleanValue('phenix-automatically-reconnect-peer-connection');\n this._logger.info('Automatically reconnect peer connection is set to: [%s]', this._automaticallyReconnectPeerConnection);\n\n return;\n }\n\n static applyDiscoveryUriDefaultFromParameterConfiguration(): void {\n SDK.discoveryUri.subscribe(value => {\n SDK.telemetryUrl.value = SDK.getTelemetryUrl(value);\n SDK._environment.value = Environment.getEnvironmentFromUrl(value);\n });\n\n const channelToken = this._configurationParameterReader.getStringValue('phenix-channel-token');\n\n if (channelToken) {\n const parsedToken = EdgeAuth.parseToken(channelToken);\n\n SDK._tenancy.value = EdgeAuth.getTenancy(parsedToken);\n DiscoveryUri.uri.value = (EdgeAuth.getUri(parsedToken) || SDK.discoveryUri.value).toString();\n\n this._logger.info('Discovery URI set from configuration parameter to [%s]', SDK.discoveryUri.value);\n\n return;\n }\n\n const uriValue = this._configurationParameterReader.getStringValue('phenix-uri');\n\n if (uriValue) {\n DiscoveryUri.uri.value = uriValue;\n this._logger.info('Discovery URI set from \"phenix-uri\" configuration parameter tag to [%s]', SDK.discoveryUri.value);\n\n return;\n }\n\n const baseURIValue = this._configurationParameterReader.getStringValue('phenix-base-uri');\n\n if (baseURIValue) {\n DiscoveryUri.uri.value = `${baseURIValue}/pcast/endPoints`;\n this._logger.info('Discovery URI set from \"phenix-base-uri\" configuration parameter tag to [%s]', SDK.discoveryUri.value);\n\n return;\n }\n }\n\n static init(options?: IInitOptions): void {\n if (!this._initialized.value) {\n this._applicationActivityMonitor = new ApplicationActivityMonitor();\n }\n\n if (options) {\n if (options.discoveryUri) {\n DiscoveryUri.uri.value = options.discoveryUri;\n }\n\n if (options.peerConnectionFactory) {\n SDK._peerConnectionFactory.value = options.peerConnectionFactory;\n }\n\n if (options.telemetryLevel && TelemetryLevel[options.telemetryLevel]) {\n SDK._telemetryLevel.value = TelemetryLevelMapping.convertTelemetryLevelTypeToTelemetryLevel(options.telemetryLevel);\n }\n\n if (options.loggingLevel && LoggingLevel[options.loggingLevel]) {\n this._logger.threshold.setThreshold(LoggingLevelMapping.convertLoggingLevelTypeToLoggingLevel(options.loggingLevel));\n }\n\n if (options.consoleLoggingLevel &&\n LoggingLevel[options.consoleLoggingLevel]) {\n const consoleAppender = this._logger.appenders.value.find(appender => appender instanceof ConsoleAppender);\n\n if (consoleAppender) {\n this._logger.appenders.remove(consoleAppender);\n }\n\n if (options.consoleLoggingLevel !== 'Off') {\n this._logger.appenders.add(new ConsoleAppender(LoggingLevelMapping.convertLoggingLevelTypeToLoggingLevel(options.consoleLoggingLevel)));\n }\n }\n\n if (typeof options.automaticallyPlayMediaStream === 'boolean') {\n this._automaticallyPlayMediaStream = options.automaticallyPlayMediaStream;\n }\n\n if (typeof options.automaticallyMuteVideoOnPlayFailure === 'boolean') {\n this._automaticallyMuteVideoOnPlayFailure = options.automaticallyMuteVideoOnPlayFailure;\n }\n\n if (options.webPlayerLoader) {\n this._webPlayerLoader = options.webPlayerLoader;\n }\n\n if (options.shakaPlayerLoader) {\n this._shakaPlayerLoader = options.shakaPlayerLoader;\n }\n\n if (options.hlsJsLoader) {\n this._hlsJsLoader = options.hlsJsLoader;\n }\n }\n\n SDK._initialized.value = true;\n }\n\n static dispose(): void {\n SDK._initialized.value = false;\n this._applicationActivityMonitor.dispose();\n this._applicationActivityMonitor = null;\n }\n\n static getTelemetryUrl(url: string): string {\n return TelemetryUrl.getTelemetryUrl(url);\n }\n\n private constructor() {\n throw new Error('SDK is a static class that may not be instantiated');\n }\n}\n\nwindow.addEventListener('unload', () => {\n SDK.dispose();\n});\n\nSDK.applyDiscoveryUriDefaultFromParameterConfiguration();\nSDK.applyMetricsConfiguration();\nSDK.applyTelemetryConfiguration();\nSDK.applyAutomaticallyRetryOnFailureFromParameterConfiguration();\nSDK.applyAutomaticallyReconnectPeerConnectionFromParameterConfiguration();\nSDK.init();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nenum ChannelState {\n Offline = 1,\n Starting,\n Paused,\n Playing,\n Recovering,\n Reconnecting,\n StandBy,\n Stopped,\n Unauthorized,\n GeoRestricted,\n GeoBlocked,\n Error,\n UnsupportedFeature\n}\n\nexport default ChannelState;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IComparable from '../lang/IComparable';\n\nexport default class Dimension implements IComparable<Dimension> {\n readonly width: number;\n readonly height: number;\n\n static get empty(): Dimension {\n return new Dimension(0, 0);\n }\n\n constructor(width: number, height: number) {\n this.width = width;\n this.height = height;\n }\n\n equals(other: Dimension): boolean {\n return other && this.width === other.width && this.height === other.height;\n }\n\n toString(): string {\n return `${this.width}x${this.height}`;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport type BitrateStateType = 'Keep' | 'Reset';\nexport type BitrateModeType = 'Normal' | 'Force' | 'Reset';\n\nexport enum BitrateState {\n Keep,\n Reset\n}\n\nexport enum BitrateMode {\n Normal,\n Force,\n Reset\n}\n\nexport interface ISetTemporaryMaximalBitrate {\n apiVersion: number;\n sharedSecret: string;\n elapsedInMilliseconds: number;\n bitrateInBitsPerSecond: number;\n bitrateState: BitrateStateType;\n bitrateMode: BitrateModeType;\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class Durations {\n private readonly _duration: number;\n\n constructor(duration = 0) {\n this._duration = duration;\n }\n\n toIsoString(): string {\n if (this._duration === 0) {\n return 'P0S';\n }\n\n const isNegative = this._duration < 0;\n const duration = isNegative ? Math.abs(this._duration) : this._duration;\n let offset = Math.floor(duration);\n const milliseconds = offset % 1000;\n\n offset = Math.floor(offset / 1000);\n\n const seconds = offset % 60;\n\n offset = Math.floor(offset / 60);\n\n const minutes = offset % 60;\n\n offset = Math.floor(offset / 60);\n\n const hours = offset % 24;\n const parts = ['PT'];\n\n if (isNegative) {\n parts.unshift('-');\n }\n\n if (hours) {\n parts.push(hours + 'H');\n }\n\n if (minutes) {\n parts.push(minutes + 'M');\n }\n\n if (seconds || milliseconds) {\n parts.push(String(seconds));\n\n if (milliseconds) {\n parts.push('.' + this.padStart(milliseconds.toString(), 3, '0'));\n }\n\n parts.push('S');\n }\n\n return parts.join('');\n }\n\n padStart(item: string, targetLength: number, padString: string): string {\n targetLength = targetLength >> 0;\n padString = String((typeof padString !== 'undefined' ? padString : ' '));\n\n if (item.length > targetLength) {\n return item;\n }\n\n targetLength = targetLength - item.length;\n\n if (targetLength > padString.length) {\n padString += padString.repeat(targetLength / padString.length);\n }\n\n return padString.slice(0, targetLength) + item;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport {ILogger} from '../logger/LoggerInterface';\nimport Durations from '../time/Duration';\nimport Disposable from '../lang/Disposable';\nimport IDisposable from '../lang/IDisposable';\nimport MetricsType from '../metrics/MetricsType';\nimport DisposableList from '../lang/DisposableList';\nimport MetricsService from '../metrics/MetricsService';\n\nexport default class VideoTelemetry implements IDisposable {\n private readonly _pageLoadTime: number;\n private readonly _channelStartTime: number;\n private readonly _logger: ILogger = LoggerFactory.getLogger('StreamTelemetry');\n private readonly _disposables: DisposableList = new DisposableList();\n private readonly _streamId: string;\n private readonly _metricsService: MetricsService;\n private _listenToFirstTime: () => void;\n private _listenForStall: () => void;\n private _listenForContinuation: (event) => void;\n private _timeToFirstFrame: number;\n private _channelCreationTimeToFirstFrame: number;\n private _startRecordingFirstFrame: number;\n private _videoStalled: number;\n private _lastProgress: number;\n private _videoResolution: string;\n private _clearTimeToFirstFrameListener: Disposable;\n private _clearRebufferingListener: Disposable;\n\n constructor(streamId: string, pageLoadTime: number, channelStartTime: number, metricsService: MetricsService) {\n this._streamId = streamId;\n this._pageLoadTime = pageLoadTime;\n this._channelStartTime = channelStartTime;\n\n this._metricsService = metricsService;\n }\n\n setupListenerForTimeToFirstTime(video: HTMLVideoElement): void {\n this._startRecordingFirstFrame = Date.now();\n\n this._listenToFirstTime = (): void => this.callTimeToFirstFrame();\n\n video.addEventListener('loadeddata', this._listenToFirstTime);\n video.addEventListener('loadedmetadata', this._listenToFirstTime);\n\n this._clearTimeToFirstFrameListener = new Disposable(() => {\n video.removeEventListener('loadeddata', this._listenToFirstTime);\n video.removeEventListener('loadedmetadata', this._listenToFirstTime);\n });\n this._disposables.add(this._clearTimeToFirstFrameListener);\n }\n\n setupListenerForRebuffering(video: HTMLVideoElement): void {\n this._listenForStall = (): void => this.onStall();\n\n this._listenForContinuation = (event): void => this.onContinuation(event, video);\n\n video.addEventListener('stalled', this._listenForStall);\n video.addEventListener('pause', this._listenForStall);\n video.addEventListener('suspend', this._listenForStall);\n video.addEventListener('play', this._listenForContinuation);\n video.addEventListener('playing', this._listenForContinuation);\n video.addEventListener('progress', this._listenForContinuation);\n video.addEventListener('timeupdate', this._listenForContinuation);\n\n this._clearRebufferingListener = new Disposable(() => {\n video.removeEventListener('stalled', this._listenForStall);\n video.removeEventListener('pause', this._listenForStall);\n video.removeEventListener('suspend', this._listenForStall);\n video.removeEventListener('play', this._listenForContinuation);\n video.removeEventListener('playing', this._listenForContinuation);\n video.removeEventListener('progress', this._listenForContinuation);\n video.removeEventListener('timeupdate', this._listenForContinuation);\n });\n\n this._disposables.add(this._clearRebufferingListener);\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private get durationSincePageLoad(): string {\n const now = Date.now();\n\n return new Durations(now - this._pageLoadTime).toIsoString();\n }\n\n private callTimeToFirstFrame(): void {\n const now = Date.now();\n\n this.pushTimeToFirstFrame(now);\n this.pushChannelCreationTimeToFirstFrame(now);\n\n this._clearTimeToFirstFrameListener.dispose();\n }\n\n private pushTimeToFirstFrame(now): void {\n this._timeToFirstFrame = now - this._startRecordingFirstFrame;\n\n this._metricsService.push({\n metricType: MetricsType.TimeToFirstFrame,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: this._timeToFirstFrame},\n streamId: this._streamId\n });\n\n this._logger.info(\n '[%s] [%s] First frame [%s]',\n this.durationSincePageLoad,\n this._streamId,\n new Durations(this._timeToFirstFrame).toIsoString()\n );\n }\n\n private pushChannelCreationTimeToFirstFrame(now): void {\n this._channelCreationTimeToFirstFrame = now - this._channelStartTime;\n\n this._metricsService.push({\n metricType: MetricsType.ChannelCreationTimeToFirstFrame,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: this._channelCreationTimeToFirstFrame},\n streamId: this._streamId\n });\n\n this._logger.info(\n '[%s] [%s] Channel creation to first frame [%s]',\n this.durationSincePageLoad,\n this._streamId,\n new Durations(this._channelCreationTimeToFirstFrame).toIsoString()\n );\n }\n\n private onStall(): void {\n if (this._videoStalled) {\n return;\n }\n\n this._metricsService.push({\n metricType: MetricsType.Stalled,\n runtime: (Date.now() - this._pageLoadTime) / 1000,\n streamId: this._streamId\n });\n\n this._videoStalled = Date.now();\n\n this._logger.info(\n '[%s] [%s] [buffering] Stream has stalled',\n this.durationSincePageLoad,\n this._streamId\n );\n }\n\n private onContinuation(event, video): void {\n if (!video.buffered) {\n return;\n }\n\n const bufferLength = video.buffered.length;\n const hasNotProgressedSinceLastProgressEvent = event.type === 'playing'\n || bufferLength > 0 ? (event.type === 'progress'\n || event.type === 'timeupdate')\n && video.buffered.end(bufferLength - 1) === this._lastProgress : true;\n\n if (!this._videoStalled || hasNotProgressedSinceLastProgressEvent) {\n return;\n }\n\n if (event.type === 'progress') {\n this._lastProgress = video.buffered.end(bufferLength - 1);\n }\n\n const timeSinceStop = Date.now() - this._videoStalled;\n\n this._metricsService.push({\n metricType: MetricsType.Buffering,\n runtime: (Date.now() - this._pageLoadTime) / 1000,\n value: {uint64: timeSinceStop},\n streamId: this._streamId\n });\n\n this._logger.info(\n '[%s] [%s] [buffering] Stream has recovered from stall after [%s]',\n this.durationSincePageLoad,\n this._streamId,\n new Durations(timeSinceStop).toIsoString()\n );\n this._videoStalled = null;\n }\n\n onVideoResolutionChanges(newResolution: string): void {\n this._metricsService.push({\n metricType: MetricsType.ResolutionChanged,\n runtime: (Date.now() - this._pageLoadTime) / 1000,\n value: {string: newResolution},\n previousValue: this._videoResolution ? {string: this._videoResolution} : undefined,\n streamId: this._streamId\n });\n\n this._videoResolution = newResolution;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport MetricsType from '../metrics/MetricsType';\nimport MetricType from '../metrics/MetricType';\nimport Durations from '../time/Duration';\nimport {ILogger} from '../logger/LoggerInterface';\nimport SDK from '../sdk/SDK';\nimport LoggerFactory from '../logger/LoggerFactory';\n\nexport class StreamSetupListener {\n private readonly _logger: ILogger = LoggerFactory.getLogger('StreamSetupListener');\n private readonly metricsService = SDK.metricsService;\n private readonly _pageLoadTime: number;\n private readonly _startTime: number;\n private _metricSubmitted = false;\n\n constructor(pageLoadTime: number) {\n this._startTime = Date.now();\n this._pageLoadTime = pageLoadTime;\n }\n\n success(streamId): void {\n this.recordStreamMetric(MetricsType.SetupCompleted, streamId);\n }\n\n fail(): void {\n this.recordStreamMetric(MetricsType.SetupFailed);\n }\n\n private recordStreamMetric(metricType: MetricsType, streamId?: string): void {\n if (this._metricSubmitted) {\n return ;\n }\n\n this._metricSubmitted = true;\n\n const now = Date.now();\n const setupTime = now - this._startTime;\n const metricName = new MetricType(metricType).getName();\n\n this.metricsService.push({\n metricType,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: setupTime},\n streamId\n });\n\n this._logger.info(\n '[%s] [%s] Stream metric [%s] in [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n streamId,\n metricName,\n new Durations(setupTime).toIsoString()\n );\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport IDisposable from '../lang/IDisposable';\nimport Disposable from '../lang/Disposable';\nimport Subject from '../rx/Subject';\nimport DisposableList from '../lang/DisposableList';\n\nexport default class NetworkMonitor implements IDisposable {\n private readonly _disposables: DisposableList = new DisposableList();\n private readonly _isSupported = navigator && navigator['connection'];\n private readonly _rtt: Subject<number> = new Subject(undefined);\n private readonly _effectiveType: Subject<string> = new Subject(undefined);\n private readonly _downlinkThroughputCapacity: Subject<number> = new Subject(undefined);\n\n constructor() {\n if (!this.isSupported) {\n return;\n }\n\n this.setupNetworkChangeListeners();\n this.updateStatistics();\n }\n\n get isSupported(): boolean {\n return this._isSupported;\n }\n\n get rtt(): Subject<number> {\n return this._rtt;\n }\n\n get effectiveType(): Subject<string> {\n return this._effectiveType;\n }\n\n get downlinkThroughputCapacity(): Subject<number> {\n return this._downlinkThroughputCapacity;\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private getDownlinkThroughputCapacity(): number {\n if (!this.isSupported) {\n return -1;\n }\n\n return navigator['connection'].downlink || navigator['connection'].downlinkMax;\n }\n\n private getEffectiveType(): string {\n if (!this.isSupported) {\n return 'Unknown';\n }\n\n return navigator['connection'].effectiveType || navigator['connection'].type;\n }\n\n private getRoundTripTime(): number {\n return navigator['connection'].rtt;\n }\n\n private setupNetworkChangeListeners(): void {\n const listener = (): void => {\n this.updateStatistics();\n };\n\n navigator['connection'].addEventListener('change', listener);\n\n this._disposables.add(new Disposable(() => {\n navigator['connection'].removeEventListener('change', listener);\n }));\n }\n\n private updateStatistics(): void {\n this._rtt.value = this.getRoundTripTime();\n this._effectiveType.value = this.getEffectiveType();\n this._downlinkThroughputCapacity.value = this.getDownlinkThroughputCapacity();\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {StreamSetupListener} from '../dom/StreamSetupListener';\nimport {ILogger} from '../logger/LoggerInterface';\nimport LoggerFactory from '../logger/LoggerFactory';\nimport NetworkMonitor from '../dom/NetworkMonitor';\nimport SDK from '../sdk/SDK';\nimport MetricsType from '../metrics/MetricsType';\nimport Durations from '../time/Duration';\nimport IDisposable from '../lang/IDisposable';\nimport DisposableList from '../lang/DisposableList';\nimport MetricsService from '../metrics/MetricsService';\n\ninterface INetworkStatistics {\n rtt?: number;\n effectiveType?: string;\n downlinkThroughputCapacity?: number;\n}\n\nexport default class SessionTelemetry implements IDisposable {\n private readonly _logger: ILogger = LoggerFactory.getLogger('SessionTelemetry');\n private readonly _metricsService: MetricsService;\n private readonly _applicationActivityMonitor = SDK.applicationActivityMonitor;\n private readonly _networkMonitor: NetworkMonitor = new NetworkMonitor();\n private readonly _pageLoadTime: number;\n private readonly _disposables: DisposableList = new DisposableList();\n private _lastNetworkStatistics: INetworkStatistics = {};\n\n constructor(pageLoadTime: number, metricsService: MetricsService) {\n this._pageLoadTime = pageLoadTime;\n this._disposables.add(this._networkMonitor);\n this._metricsService = metricsService;\n\n if (!this._networkMonitor.isSupported) {\n return;\n }\n\n this._disposables.add(this._applicationActivityMonitor.isForeground.subscribe(isForeground => {\n this.recordForegroundChange(isForeground);\n }));\n this._disposables.add(this._networkMonitor.rtt.subscribe(value => {\n this.recordNetworkRTTUpdate(value);\n }));\n this._disposables.add(this._networkMonitor.effectiveType.subscribe(value => {\n this.recordNetworkTypeChangeUpdate(value);\n }));\n this._disposables.add(this._networkMonitor.downlinkThroughputCapacity.subscribe(value => {\n this.recordNetworkDownlinkThroughputCapacityUpdate(value);\n }));\n }\n\n listenOnStreamSetup(): StreamSetupListener {\n return new StreamSetupListener(this._pageLoadTime);\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private recordForegroundChange(isForeground: boolean): void {\n const now = Date.now();\n const timeSinceLastChange = this._applicationActivityMonitor.getTimeSinceLastChange();\n\n this._metricsService.push({\n metricType: isForeground ? MetricsType.ApplicationForeground : MetricsType.ApplicationBackground,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: timeSinceLastChange}\n });\n\n this._logger.info(\n 'Application has gone into the [%s] after [%s] ms',\n isForeground ? 'foreground' : 'background',\n new Durations(timeSinceLastChange).toIsoString(),\n );\n }\n\n private recordNetworkRTTUpdate(newRTT: number): void {\n const now = Date.now();\n const oldRtt = this._lastNetworkStatistics.rtt;\n\n this._lastNetworkStatistics.rtt = newRTT;\n\n this._metricsService.push({\n metricType: MetricsType.RoundTripTime,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: newRTT},\n previousValue: oldRtt ? {uint64: oldRtt} : undefined,\n resource: 'navigator'\n });\n\n this._logger.info(\n '[%s] Network RTT changed to [%s] from [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n newRTT,\n oldRtt\n );\n }\n\n private recordNetworkTypeChangeUpdate(newNetworkType: string): void {\n const now = Date.now();\n const oldNetworkType = this._lastNetworkStatistics.effectiveType;\n\n this._lastNetworkStatistics.effectiveType = newNetworkType;\n\n this._metricsService.push({\n metricType: MetricsType.NetworkType,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {string: newNetworkType},\n previousValue: oldNetworkType ? {string: oldNetworkType} : undefined\n });\n\n this._logger.info(\n '[%s] Network effective type has changed to [%s] from [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n newNetworkType,\n oldNetworkType\n );\n }\n\n private recordNetworkDownlinkThroughputCapacityUpdate(newCapacity: number): void {\n const now = Date.now();\n const oldCapacity = this._lastNetworkStatistics.downlinkThroughputCapacity;\n\n this._lastNetworkStatistics.downlinkThroughputCapacity = newCapacity;\n\n this._metricsService.push({\n metricType: MetricsType.DownlinkThroughputCapacity,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {float: newCapacity},\n previousValue: oldCapacity ? {float: oldCapacity} : undefined\n });\n\n this._logger.info(\n '[%s] Network downlink throughput capacity changed to [%s] from [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n newCapacity,\n oldCapacity\n );\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport Subject from '../../rx/Subject';\nimport IPeerConnection from '../../rtc/IPeerConnection';\nimport ChannelState from './ChannelState';\nimport Dimension from '../../video/Dimension';\nimport EndPoint, {IStream, SubscribeStatus} from '../discovery/EndPoint';\nimport VideoTelemetry from '../../video/VideoTelemetry';\nimport SessionTelemetry from '../../video/SessionTelemetry';\nimport {IRtcMonitorStatistic, IRtcStatistic} from '../../rtc/RtcConnectionMonitor';\nimport SDK from '../SDK';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport DisposableList from '../../lang/DisposableList';\nimport {EdgeToken} from '../edgeAuth/EdgeToken';\nimport {BitsPerSecond, Millisecond} from '../../units/Units';\n\nexport default class ChannelContext {\n channelInitialization: Date;\n disposables: DisposableList;\n channelDisposables: DisposableList;\n rendererDisposables: DisposableList;\n videoElement: Subject<HTMLVideoElement>;\n token: Subject<EdgeToken>;\n peerConnection: Subject<IPeerConnection>;\n mediaStream: Subject<MediaStream>;\n state: Subject<ChannelState>;\n autoMuted: Subject<boolean>;\n autoPaused: Subject<boolean>;\n tokenExpiring: Subject<boolean>;\n authorized: Subject<boolean>;\n online: Subject<boolean>;\n loading: Subject<boolean>;\n playing: Subject<boolean>;\n standby: Subject<boolean>;\n stopped: Subject<boolean>;\n targetLag: Subject<Millisecond>;\n lag: Subject<Millisecond>;\n bitrateLimit: Subject<BitsPerSecond>;\n resolution: Subject<Dimension>;\n failureCount: Subject<number>;\n endPoint: Subject<EndPoint>;\n stream: Subject<IStream>;\n rtcStatistics: Subject<IRtcMonitorStatistic>;\n\n peerConnectionReconnectAttempts: number;\n isDisposed: boolean;\n videoTelemetry: VideoTelemetry;\n sessionTelemetry: SessionTelemetry;\n rtcAudioStatistic: IRtcStatistic;\n rtcVideoStatistic: IRtcStatistic;\n clearFailureCountTimeout: number;\n\n constructor(token: string, targetLag: number) {\n this.isDisposed = false;\n this.disposables = new DisposableList();\n this.channelDisposables = new DisposableList();\n this.rendererDisposables = new DisposableList();\n this.channelInitialization = new Date();\n this.videoElement = new Subject<HTMLVideoElement>(null);\n this.token = new Subject<EdgeToken>(token);\n this.peerConnection = new Subject<IPeerConnection>(null);\n this.mediaStream = new Subject<MediaStream>(null);\n this.state = new Subject<ChannelState>(ChannelState.Starting);\n this.autoMuted = new Subject<boolean>(false);\n this.autoPaused = new Subject<boolean>(false);\n this.tokenExpiring = new Subject<boolean>(false);\n this.authorized = new Subject<boolean>(true);\n this.online = new Subject<boolean>(true);\n this.loading = new Subject<boolean>(false);\n this.playing = new Subject<boolean>(false);\n this.standby = new Subject<boolean>(false);\n this.stopped = new Subject<boolean>(false);\n this.targetLag = new Subject<Millisecond>(targetLag);\n this.lag = new Subject<Millisecond>(0);\n this.bitrateLimit = new Subject<BitsPerSecond>(0);\n this.resolution = new Subject<Dimension>(Dimension.empty);\n this.failureCount = new Subject<number>(0);\n this.endPoint = new Subject<EndPoint>(null);\n this.stream = new Subject<IStream>(null);\n this.rtcStatistics = new Subject<IRtcMonitorStatistic>(null);\n this.peerConnectionReconnectAttempts = 0;\n }\n\n get streamId(): string {\n const stream = this.stream.value;\n\n if (!stream) {\n return '-';\n }\n\n return stream.streamId;\n }\n\n applyStatus(status: SubscribeStatus): void {\n switch (status) {\n case 'ok':\n break;\n case 'unauthorized':\n case 'geo-restricted':\n case 'geo-blocked':\n this.authorized.value = false;\n\n // eslint-disable-next-line no-fallthrough\n case 'no-stream':\n case 'not-found':\n this.failureCount.value = 0;\n this.playing.value = false;\n this.standby.value = true;\n this.stopped.value = false;\n this.stream.value = null;\n\n return;\n default:\n this.failureCount.value++;\n this.playing.value = false;\n this.standby.value = true;\n this.stopped.value = false;\n this.stream.value = null;\n this.state.value = ChannelState.Error;\n\n return;\n }\n }\n\n applySessionAndStreamPropertiesToVideoElement(): void {\n if (this.videoElement.value && this.videoElement.value.dataset) {\n this.videoElement.value.dataset.sessionId = SDK.clientSessionId;\n this.videoElement.value.dataset.streamId = this.streamId;\n }\n }\n\n mapSubscribeStatusToChannelStatus(status: SubscribeStatus): ChannelState {\n switch (status) {\n case 'ok':\n return ChannelState.Starting;\n case 'no-stream':\n case 'not-found':\n return ChannelState.StandBy;\n case 'geo-restricted':\n return ChannelState.GeoRestricted;\n case 'geo-blocked':\n return ChannelState.GeoBlocked;\n case 'unauthorized':\n return ChannelState.Unauthorized;\n case 'capacity':\n case 'rate-limited':\n case 'timeout':\n return ChannelState.Recovering;\n case 'failed':\n return ChannelState.Error;\n default:\n assertUnreachable(status);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport SDK from '../sdk/SDK';\nimport IPeerConnection from './IPeerConnection';\nimport {ILogger} from '../logger/LoggerInterface';\nimport FeatureEnablement from '../sdk/feature/FeatureEnablement';\n\nexport interface IPeerConnectionOfferInit {\n audioTransceiver?: RTCRtpTransceiver;\n videoTransceiver?: RTCRtpTransceiver;\n peerConnection: IPeerConnection;\n localOffer: RTCSessionDescriptionInit;\n}\n\nexport default class PeerConnectionService {\n private static _logger: ILogger = LoggerFactory.getLogger('PeerConnectionService');\n private static _cached: Promise<IPeerConnectionOfferInit>;\n\n static initiateInitialPrecaching(): void {\n if (FeatureEnablement.isPrecachingEnabled) {\n const ignored = PeerConnectionService.precacheCreatePeerConnectionOffer()\n .catch(e => PeerConnectionService._logger.error('Failed to pre-cache peer connection offer\"', e));\n }\n }\n\n static async precacheCreatePeerConnectionOffer(): Promise<IPeerConnectionOfferInit> {\n return PeerConnectionService._cached = PeerConnectionService.createPeerConnectionOffer()\n .catch(e => {\n PeerConnectionService._cached = null;\n\n throw e;\n });\n }\n\n static async createPeerConnectionOffer(): Promise<IPeerConnectionOfferInit> {\n if (PeerConnectionService._cached) {\n const value = PeerConnectionService._cached;\n\n PeerConnectionService._cached = null;\n\n return value;\n }\n\n const peerConnectionFactory = SDK.peerConnectionFactory.value;\n\n return peerConnectionFactory.createPeerConnection()\n .then(async peerConnection => {\n const supportsAddTransceiver = peerConnection.supportsAddTransceiver;\n let videoTransceiver, audioTransceiver;\n\n if (supportsAddTransceiver) {\n audioTransceiver = peerConnection.addTransceiver('audio', {direction: 'recvonly'});\n videoTransceiver = peerConnection.addTransceiver('video', {direction: 'recvonly'});\n }\n\n return {\n audioTransceiver,\n videoTransceiver,\n peerConnection: peerConnection,\n localOffer: await peerConnection.createOffer(supportsAddTransceiver ? undefined : {\n offerToReceiveAudio: true,\n offerToReceiveVideo: true\n })\n };\n });\n }\n\n private constructor() {\n throw new Error('PeerConnectionService is a static class that may not be instantiated');\n }\n}\n\nPeerConnectionService.initiateInitialPrecaching();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {BitrateMode, BitrateModeType} from '../api/SetTemporaryMaximalBitrate';\nimport assertUnreachable from '../../lang/assertUnreachable';\n\nexport default class BitrateModeMapping {\n static convertBitrateModeToBitrateModeType(bitrateMode: BitrateMode): BitrateModeType {\n switch (bitrateMode) {\n case BitrateMode.Normal:\n return 'Normal';\n case BitrateMode.Force:\n return 'Force';\n case BitrateMode.Reset:\n return 'Reset';\n default:\n assertUnreachable(bitrateMode);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {BitrateState, BitrateStateType} from '../api/SetTemporaryMaximalBitrate';\nimport assertUnreachable from '../../lang/assertUnreachable';\n\nexport default class BitrateStateMapping {\n static convertBitrateStateToBitrateStateType(bitrateState: BitrateState): BitrateStateType {\n switch (bitrateState) {\n case BitrateState.Keep:\n return 'Keep';\n case BitrateState.Reset:\n return 'Reset';\n default:\n assertUnreachable(bitrateState);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport {ILogger} from '../../logger/LoggerInterface';\n\nimport {\n ISubscribeResponse,\n ISubscribeWithOfferRequest,\n ISubscribeWithoutOfferRequest\n} from '../api/Subscribe';\nimport {ISetRemoteDescriptionRequest, ISetRemoteDescriptionResponse} from '../api/SetRemoteDescription';\nimport {ISessionDescription, SdpType} from '../api/SessionDescription';\nimport {IDestroyStreamRequest, IDestroyStreamResponse} from '../api/DestroyStream';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport {IAddIceCandidatesRequest, IAddIceCandidatesResponse} from '../api/AddIceCandidates';\nimport VersionManager from '../version/VersionManager';\nimport EdgeAuth from '../edgeAuth/EdgeAuth';\nimport {BitrateMode, BitrateState, ISetTemporaryMaximalBitrate} from '../api/SetTemporaryMaximalBitrate';\nimport BitrateModeMapping from './BitrateModeMapping';\nimport BitrateStateMapping from './BitrateStateMapping';\nimport {BitsPerSecond, Millisecond} from '../../units/Units';\n\nconst apiVersion = 6;\n\nexport type SubscribeStatus = 'ok' | 'no-stream' | 'not-found' | 'unauthorized' | 'geo-restricted' | 'geo-blocked' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type SetRemoteDescriptionStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type SetTemporaryMaximalBitrateStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type RemoveTemporaryMaximalBitrateStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type AddIceCandidatesStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type DestroyStreamStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport interface IStream {\n streamId: string;\n sharedSecret: string;\n tenancy: string;\n}\n\nexport interface ISubscribeResponseInit {\n status: SubscribeStatus;\n stream?: IStream;\n lag?: Millisecond;\n rtcConfiguration?: RTCConfiguration;\n setRemoteDescriptionResponse?: {\n sessionDescription: RTCSessionDescriptionInit;\n };\n createOfferDescriptionResponse?: {\n sessionDescription: RTCSessionDescriptionInit;\n };\n createAnswerDescriptionResponse?: {\n sessionDescription: RTCSessionDescriptionInit;\n };\n}\n\ninterface ISetRemoteDescriptionResponseInit {\n status: SetRemoteDescriptionStatus;\n sessionDescription?: RTCSessionDescriptionInit;\n}\n\ninterface IAddIceCandidatesResponseInit {\n status: AddIceCandidatesStatus;\n options?: string[];\n}\n\ninterface ISetTemporaryMaximalBitrateResponseInit {\n status: SetTemporaryMaximalBitrateStatus;\n}\n\ninterface IDestroyStreamResponseInit {\n status: DestroyStreamStatus;\n}\n\nexport default class EndPoint {\n private readonly _logger: ILogger = LoggerFactory.getLogger('EndPoint');\n private readonly _uri: string;\n private readonly _timeout: number;\n private _roundTripTime: number;\n\n constructor(uri: string, timeout: number) {\n this._uri = uri;\n this._timeout = timeout;\n\n if (!timeout) {\n throw new Error(`End point requires a timeout`);\n }\n }\n\n get roundTripTime(): number {\n return this._roundTripTime;\n }\n\n toString(): string {\n return `EndPoint[uri=${this._uri}]`;\n }\n\n async ping(): Promise<number> {\n const url = this.buildPingUrl();\n const start = Date.now();\n const response = await Promise.race([\n fetch(url, {\n method: 'GET',\n cache: 'no-cache'\n }),\n new Promise<Response>((_, reject) =>\n setTimeout(() => reject(new Error(`Ping timed out [${url}]`)), this._timeout)\n )\n ]);\n const finished = Date.now();\n\n if (!response.ok) { /* Handle */\n throw new Error(`Ping failed [${url}] [${response.status}]`);\n }\n\n this._roundTripTime = finished - start;\n\n return this._roundTripTime;\n }\n\n async subscribe(token: string, localSessionDescription: RTCSessionDescriptionInit, failureCount: number): Promise<ISubscribeResponseInit> {\n const parsedToken = EdgeAuth.parseToken(token);\n\n if (!parsedToken || !parsedToken.applicationId) {\n this._logger.error('Failed to parse token [%s]', token);\n\n return {status: 'unauthorized'};\n }\n\n const tenancy = parsedToken.applicationId;\n const url = this.buildUrl([tenancy, 'stream', 'subscribe']).toString();\n const formData = new FormData();\n const clientVersion = VersionManager.sdkVersion;\n\n if (failureCount === 0 && localSessionDescription) {\n const bodyWithOffer: ISubscribeWithOfferRequest = {\n apiVersion,\n clientVersion,\n edgeAuthToken: token,\n failureCount,\n setRemoteDescription: {\n apiVersion,\n sessionDescription: {\n type: this.convertRTCSdpTypeToSdpType(localSessionDescription.type),\n sdp: localSessionDescription.sdp\n }\n },\n createAnswerDescription: {apiVersion}\n };\n\n formData.append('jsonBody', JSON.stringify(bodyWithOffer));\n } else {\n const bodyWithoutOffer: ISubscribeWithoutOfferRequest = {\n apiVersion,\n clientVersion,\n edgeAuthToken: token,\n failureCount,\n createOfferDescription: {apiVersion}\n };\n\n formData.append('jsonBody', JSON.stringify(bodyWithoutOffer));\n }\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to subscribe', new Error(`Subscribe timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to subscribe', e);\n\n return {status: 'failed'};\n }\n\n const status: SubscribeStatus = this.mapHttpStatusToSubscribeStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const subscribeResponse = await this.convertHttpResponseToSubscribeResponse(tenancy, httpResponse);\n\n this._logger.debug('Got subscribe response [%j] in [%s] ms', subscribeResponse, finished - start);\n\n return subscribeResponse;\n }\n\n async setRemoteDescription(stream: IStream, sessionDescription: RTCSessionDescriptionInit): Promise<ISetRemoteDescriptionResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'description', 'remote']).toString();\n const formData = new FormData();\n const body: ISetRemoteDescriptionRequest = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n sessionDescription: {\n type: this.convertRTCSdpTypeToSdpType(sessionDescription.type),\n sdp: sessionDescription.sdp\n }\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to set remote description', new Error(`Set remote description timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to set remote description', e);\n\n return {status: 'failed'};\n }\n\n const status: SetRemoteDescriptionStatus = this.mapHttpStatusToSetRemoteDescriptionStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const setRemoteDescriptionResponse = await this.convertHttpResponseToSetRemoteDescriptionResponse(httpResponse);\n\n this._logger.debug('Got set remote description response [%j] in [%s] ms', setRemoteDescriptionResponse, finished - start);\n\n return setRemoteDescriptionResponse;\n }\n\n async limitBitrate(\n stream: IStream,\n elapsedInMilliseconds: number,\n bitrateInBitsPerSecond: BitsPerSecond,\n bitrateState: BitrateState,\n bitrateMode: BitrateMode,\n ): Promise<ISetTemporaryMaximalBitrateResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'bitrate']).toString();\n const formData = new FormData();\n const body: ISetTemporaryMaximalBitrate = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n elapsedInMilliseconds,\n bitrateInBitsPerSecond,\n bitrateState: BitrateStateMapping.convertBitrateStateToBitrateStateType(bitrateState),\n bitrateMode: BitrateModeMapping.convertBitrateModeToBitrateModeType(bitrateMode)\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to set limit bitrate timed', new Error(`Set limit bitrate timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to set limit bitrate timed', e);\n\n return {status: 'failed'};\n }\n\n const status: SetTemporaryMaximalBitrateStatus = this.mapHttpStatusToSetTemporaryMaximalBitrateStatus(httpResponse);\n const finished = Date.now();\n\n this._logger.info('Got set limit bitrate response [%s] in [%s] ms', status, finished - start);\n\n return {status};\n }\n\n async addIceCandidates(stream: IStream, candidates: RTCIceCandidate[], discoveryCompleted: boolean, options: string[] = []): Promise<IAddIceCandidatesResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'ice', 'candidates']).toString();\n const formData = new FormData();\n const body: IAddIceCandidatesRequest = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n candidates,\n discoveryCompleted,\n options\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to add ice candidates', new Error(`Add ice candidates timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to add ice candidates', e);\n\n return {status: 'failed'};\n }\n\n const status: AddIceCandidatesStatus = this.mapHttpStatusToAddIceCandidatesStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const addIceCandidatesResponse = await this.convertHttpResponseToAddIceCandidatesResponse(httpResponse);\n\n this._logger.info('Got add ICE candidates response [%j] in [%s] ms', addIceCandidatesResponse, finished - start);\n\n return addIceCandidatesResponse;\n }\n\n async destroyStream(stream: IStream, reason: string): Promise<IDestroyStreamResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'destroy']).toString();\n const formData = new FormData();\n const body: IDestroyStreamRequest = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n reason,\n options: []\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData,\n cache: 'no-cache'\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to subscribe', new Error(`Delete stream timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to delete stream', e);\n\n return {status: 'failed'};\n }\n\n const status: DestroyStreamStatus = this.mapHttpStatusToSetDestroyStreamStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const destroyStreamResponse = await this.convertHttpResponseToDestroyStreamResponse(httpResponse);\n\n this._logger.info('Got destroy stream response [%j] in [%s] ms', destroyStreamResponse, finished - start);\n\n return destroyStreamResponse;\n }\n\n buildUrl(path: string[]): URL {\n const uri = new URL(this._uri);\n const pathAsArray = uri.pathname.split('/');\n\n pathAsArray.length = pathAsArray.length - 1;\n\n uri.pathname = pathAsArray.concat(...path).join('/');\n\n return uri;\n }\n\n private buildPingUrl(): string {\n const uri = new URL(this._uri);\n const sdkVersion = VersionManager.sdkVersion;\n\n uri.search = `?${new URLSearchParams([['type', 'http'], ['version', sdkVersion], ['_', `${Date.now()}`]]).toString()}`;\n\n return uri.toString();\n }\n\n private mapHttpStatusToSubscribeStatus(response: Response): SubscribeStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 402:\n return 'geo-restricted';\n case 403:\n return 'geo-blocked';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToSetRemoteDescriptionStatus(response: Response): SetRemoteDescriptionStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToSetTemporaryMaximalBitrateStatus(response: Response): SetTemporaryMaximalBitrateStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToAddIceCandidatesStatus(response: Response): AddIceCandidatesStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToSetDestroyStreamStatus(response: Response): DestroyStreamStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private async convertHttpResponseToSubscribeResponse(tenancy: string, response: Response): Promise<ISubscribeResponseInit> {\n const data = await response.json() as ISubscribeResponse;\n const subscribeResponse: ISubscribeResponseInit = {status: data.status};\n\n subscribeResponse.stream = {\n tenancy,\n streamId: data.streamId,\n sharedSecret: data.sharedSecret\n };\n\n subscribeResponse.lag = data.lag;\n\n if (data) {\n if (data.rtcConfiguration) {\n const rtcConfiguration: RTCConfiguration = {};\n\n if (data.rtcConfiguration.bundlePolicy) {\n switch (data.rtcConfiguration.bundlePolicy) {\n case 'BundlePolicyBalanced':\n rtcConfiguration.bundlePolicy = 'balanced';\n\n break;\n case 'BundlePolicyMaxCompat':\n rtcConfiguration.bundlePolicy = 'max-compat';\n\n break;\n case 'BundlePolicyMaxBundle':\n rtcConfiguration.bundlePolicy = 'max-bundle';\n\n break;\n default:\n assertUnreachable(data.rtcConfiguration.bundlePolicy);\n }\n }\n\n if (typeof data.rtcConfiguration.iceCandidatePoolSize === 'number') {\n rtcConfiguration.iceCandidatePoolSize = data.rtcConfiguration.iceCandidatePoolSize;\n }\n\n if (data.rtcConfiguration.iceServers) {\n const iceServers: RTCIceServer[] = [];\n\n for (let i = 0; i < data.rtcConfiguration.iceServers.length; i++) {\n iceServers.push({\n urls: data.rtcConfiguration.iceServers[i].urls,\n username: data.rtcConfiguration.iceServers[i].username,\n credential: data.rtcConfiguration.iceServers[i].credential\n });\n }\n\n rtcConfiguration.iceServers = iceServers;\n }\n\n if (data.rtcConfiguration.iceTransportPolicy) {\n switch (data.rtcConfiguration.iceTransportPolicy) {\n case 'IceTransportPolicyAll':\n rtcConfiguration.iceTransportPolicy = 'all';\n\n break;\n case 'IceTransportPolicyRelay':\n rtcConfiguration.iceTransportPolicy = 'relay';\n\n break;\n case 'IceTransportPolicyPublic':\n // Deprecated - Not supported\n break;\n default:\n assertUnreachable(data.rtcConfiguration.iceTransportPolicy);\n }\n }\n\n if (data.rtcConfiguration.peerIdentity) {\n rtcConfiguration.peerIdentity = data.rtcConfiguration.peerIdentity;\n }\n\n if (data.rtcConfiguration.rtcpMuxPolicy) {\n switch (data.rtcConfiguration.rtcpMuxPolicy) {\n case 'RtcpMuxPolicyNegotiate':\n rtcConfiguration.rtcpMuxPolicy = 'negotiate';\n\n break;\n case 'RtcpMuxPolicyRequire':\n rtcConfiguration.rtcpMuxPolicy = 'require';\n\n break;\n default:\n assertUnreachable(data.rtcConfiguration.rtcpMuxPolicy);\n }\n }\n\n subscribeResponse.rtcConfiguration = rtcConfiguration;\n }\n\n if (data.setRemoteDescriptionResponse && data.setRemoteDescriptionResponse.sessionDescription) {\n subscribeResponse.setRemoteDescriptionResponse = {sessionDescription: this.convertISessionDescriptionToRTCSessionDescription(data.setRemoteDescriptionResponse.sessionDescription)};\n }\n\n if (data.createAnswerDescriptionResponse && data.createAnswerDescriptionResponse.sessionDescription) {\n subscribeResponse.createAnswerDescriptionResponse = {sessionDescription: this.convertISessionDescriptionToRTCSessionDescription(data.createAnswerDescriptionResponse.sessionDescription)};\n }\n\n if (data.createOfferDescriptionResponse && data.createOfferDescriptionResponse.sessionDescription) {\n subscribeResponse.createOfferDescriptionResponse = {sessionDescription: this.convertISessionDescriptionToRTCSessionDescription(data.createOfferDescriptionResponse.sessionDescription)};\n }\n }\n\n return subscribeResponse;\n }\n\n private convertISessionDescriptionToRTCSessionDescription(sessionDescription: ISessionDescription): RTCSessionDescriptionInit {\n const rtcSessionDescription: RTCSessionDescriptionInit = {sdp: sessionDescription.sdp};\n\n switch (sessionDescription.type) {\n case 'Offer':\n rtcSessionDescription.type = 'offer';\n\n break;\n case 'Answer':\n rtcSessionDescription.type = 'answer';\n\n break;\n default:\n assertUnreachable(sessionDescription.type);\n }\n\n return rtcSessionDescription;\n }\n\n private async convertHttpResponseToSetRemoteDescriptionResponse(response: Response): Promise<ISetRemoteDescriptionResponseInit> {\n const data = await response.json() as ISetRemoteDescriptionResponse;\n const setRemoteDescriptionResponse: ISetRemoteDescriptionResponseInit = {status: data.status};\n\n if (data && data.sessionDescription) {\n setRemoteDescriptionResponse.sessionDescription = this.convertISessionDescriptionToRTCSessionDescription(data.sessionDescription);\n }\n\n return setRemoteDescriptionResponse;\n }\n\n private async convertHttpResponseToAddIceCandidatesResponse(response: Response): Promise<IAddIceCandidatesResponseInit> {\n const data = await response.json() as IAddIceCandidatesResponse;\n const addIceCandidatesResponse: IAddIceCandidatesResponseInit = {\n status: data.status,\n options: []\n };\n\n if (data) {\n if (data.options) {\n addIceCandidatesResponse.options = data.options;\n }\n }\n\n return addIceCandidatesResponse;\n }\n\n private async convertHttpResponseToDestroyStreamResponse(response: Response): Promise<IDestroyStreamResponseInit> {\n const data = await response.json() as IDestroyStreamResponse;\n const destroyStream: IDestroyStreamResponseInit = {status: data.status};\n\n return destroyStream;\n }\n\n private convertRTCSdpTypeToSdpType(type: RTCSdpType): SdpType {\n switch (type) {\n case 'answer':\n return 'Answer';\n case 'offer':\n return 'Offer';\n case 'pranswer':\n case 'rollback':\n throw new Error(`SDP type [${type}] is not supported`);\n default:\n assertUnreachable(type);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport EndPoint from './EndPoint';\nimport SDK from '../SDK';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport MetricsType from '../../metrics/MetricsType';\nimport DiscoveryUri from './DiscoveryUri';\nimport MetricsService from '../../metrics/MetricsService';\nimport MetricsFactory from '../../metrics/MetricsFactory';\n\nconst defaultTimeout = 20000;\n\nexport default class DiscoveryService {\n private _logger: ILogger = LoggerFactory.getLogger('Discovery');\n private _metricsService: MetricsService;\n private _uri: URL;\n\n constructor(uri: URL) {\n if (!uri) {\n throw new Error('Discovery requires uri');\n }\n\n this._metricsService = MetricsFactory.getMetricsService(uri.toString());\n this._uri = uri;\n }\n\n async discoverNearbyEndPoints(uri: URL, timeout: number): Promise<EndPoint[]> {\n if (!timeout) {\n throw new Error('Discovery requires timeout');\n }\n\n const url = uri.toString();\n const response = await Promise.race([\n fetch(url, {\n method: 'GET',\n cache: 'no-cache'\n }),\n new Promise<Response>((_, reject) =>\n setTimeout(() => reject(new Error(`Discovery timed out [${url}]`)), timeout)\n )\n ]);\n\n if (!response.ok) {\n throw new Error(`Discovery failed [${url}] [${response.status}]`);\n }\n\n if (response.body === null) {\n throw new Error(`Discovery failed with no data [${url}]`);\n }\n\n const asString = await response.text();\n const endPoints = asString.split(',');\n\n return endPoints.map(endPoint => new EndPoint(endPoint, timeout));\n }\n\n async discoverClosestEndPoint(timeout: number = defaultTimeout): Promise<EndPoint> {\n const url = DiscoveryUri.buildDiscoveryUrl(this._uri);\n const endPoints = await this.discoverNearbyEndPoints(new URL(url), timeout);\n const neverResolve = (): Promise<void> => new Promise(() => {\n this._logger.info('Request [%s] failed, preventing it from completing', url);\n });\n const endPoint = await Promise.race(endPoints.map(endPoint => endPoint\n .ping()\n .catch(e => {\n this._logger.warn('Failed to ping end point [%s]', endPoint, e);\n\n return neverResolve();\n })\n .then(time => {\n const now = Date.now();\n\n this._logger.info('Discovered end point [%s] with time [%s]', endPoint.toString(), time);\n this._metricsService.push({\n metricType: MetricsType.RoundTripTime,\n runtime: (now - SDK.pageLoadTime) / 1000,\n value: {uint64: time || 0},\n resource: endPoint.toString(),\n kind: 'ping'\n });\n\n return endPoint;\n })));\n\n return endPoint;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport EndPoint from './EndPoint';\nimport SDK from '../SDK';\nimport DiscoveryService from './DiscoveryService';\n\nconst discoveryCacheInterval = 60000;\n\ninterface IPerURIEndpoint { [x: string]: Promise<EndPoint> }\n\nexport default class Discovery {\n private static _cache: IPerURIEndpoint = {};\n\n static async precacheClosestEndPointDiscovery(): Promise<EndPoint> {\n const uri = new URL(SDK.discoveryUri.value);\n\n return Discovery.discoverClosestEndPointWithCaching(uri);\n }\n\n static async discoverClosestEndPointWithCaching(uri: URL): Promise<EndPoint> {\n const url = uri.toString();\n\n if (Discovery._cache[url]) {\n return Discovery._cache[url];\n }\n\n const discoveryService = new DiscoveryService(uri);\n const cachedValue = Discovery._cache[url] = discoveryService.discoverClosestEndPoint();\n\n Discovery._cache[url].then(() => {\n const ignored = setTimeout(() => {\n if (Discovery._cache[url] === cachedValue) {\n delete Discovery._cache[url];\n }\n }, discoveryCacheInterval);\n }).catch(e => {\n delete Discovery._cache[url];\n\n throw e;\n });\n\n return cachedValue;\n }\n\n private constructor() {\n throw new Error('Discovery is a static class that may not be instantiated');\n }\n}\n\nconst ignored = Discovery.precacheClosestEndPointDiscovery();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class SdpParser {\n private readonly _sdp: string;\n private readonly _audioCodec: string;\n private readonly _videoCodec: string;\n\n constructor(sdp: string) {\n this._sdp = sdp;\n this._audioCodec = this.applyCodec('audio');\n this._videoCodec = this.applyCodec('video');\n }\n\n get audioCodec(): string {\n return this._audioCodec;\n }\n\n get videoCodec(): string {\n return this._videoCodec;\n }\n\n applyCodec(type: string): string {\n const splitSdp = this._sdp.split(/(\\r\\n|\\r|\\n)/);\n const usedCodecLine = splitSdp.find(item => item.includes(`a=rtpmap:${splitSdp.find(i => i.includes(`m=${type}`)).split(' ')[3]}`));\n const usedCodec = usedCodecLine.split(' ')[1];\n const codecName = usedCodec.split('/')[0];\n\n return codecName;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IPeerConnection from './IPeerConnection';\nimport Subject from '../rx/Subject';\nimport FeatureEnablement from '../sdk/feature/FeatureEnablement';\nimport SdpParser from './SdpParser';\nimport IDisposable from '../lang/IDisposable';\n\nexport interface IRtcMonitorStatistic {\n [kind: string]: IRtcStatistic;\n}\n\nexport interface ILegacyRTCStatsReport {\n result: () => ILegacyRTCStatsReportItem[];\n}\n\nexport interface ILegacyRTCStatsReportItem extends RTCStatsReport {\n type: string;\n names: () => string[];\n stat: (name) => number;\n}\n\nexport interface IRtcStatistic {\n ssrc?: string;\n mediaType?: string;\n timestamp: number;\n bytesReceived?: number;\n framesDecoded?: number;\n packetsLost?: number;\n packetsReceived?: number;\n codec?: string;\n fps?: number;\n roundTripTime?: number;\n}\n\nconst updateStatisticTimeOut = 1000;\n\nexport default class RtcConnectionMonitor implements IDisposable {\n private readonly _estimatedRoundTripTime: number;\n private readonly _estimatedVideoCodec: string;\n private readonly _estimatedAudioCodec: string;\n private readonly _rtcStatistic: Subject<IRtcMonitorStatistic> = new Subject<IRtcMonitorStatistic>({});\n private _peerConnection: IPeerConnection;\n private _isMonitorRunning = true;\n private _updateTimeOut: number;\n private _tracksToMonitor: string[];\n\n constructor(peerConnection: IPeerConnection, mediaStream: MediaStream, estimatedRoundTripTime: number) {\n this._peerConnection = peerConnection;\n this._estimatedRoundTripTime = estimatedRoundTripTime;\n this._tracksToMonitor = mediaStream.getTracks().map(track => track.kind) || [];\n\n if (this._peerConnection) {\n if (!FeatureEnablement.getCurrentOfferDisabled) {\n const parsedSDP = new SdpParser(this._peerConnection.currentRemoteDescription.sdp);\n\n this._estimatedAudioCodec = parsedSDP.audioCodec;\n this._estimatedVideoCodec = parsedSDP.videoCodec;\n }\n\n this.updateStatistic();\n }\n }\n\n get rtcStatistic(): Subject<IRtcMonitorStatistic> {\n return this._rtcStatistic;\n }\n\n dispose(): void {\n this._isMonitorRunning = false;\n this._peerConnection = null;\n\n if (this._updateTimeOut) {\n clearTimeout(this._updateTimeOut);\n this._updateTimeOut = null;\n }\n }\n\n private async updateStatistic(): Promise<void> {\n if (FeatureEnablement.getStatsPromiseBasedDisabled) {\n const ignored = await this.updateStatisticLegacy();\n\n return;\n }\n\n // Safari 11 doesnt have kind or mediaType so we need to take it from the inbound-rtp object id\n const getKindForSafari11 = (item): string => item.id.includes('Audio') ? 'audio' : item.id.includes('Video') ? 'video' : '';\n const ignored = await this._peerConnection.getStats(null)\n .then(stats => {\n const rtcStats: IRtcMonitorStatistic = {};\n\n if (stats) {\n let roundTripTime = this._estimatedRoundTripTime;\n\n stats.forEach(i => {\n if (i.type === 'candidate-pair' && i.currentRoundTripTime) {\n roundTripTime = i.currentRoundTripTime * 1000;\n }\n\n if (i.type === 'inbound-rtp') {\n const kind = i.kind || i.mediaType || getKindForSafari11(i);\n let codec = '';\n\n stats.forEach(item => {\n if (item.id === i.codecId) {\n codec = item.mimeType;\n }\n });\n\n if (kind && this._tracksToMonitor.includes(kind)) {\n rtcStats[kind] = {\n ssrc: i.ssrc,\n mediaType: kind,\n timestamp: i.timestamp,\n bytesReceived: i.bytesReceived,\n packetsLost: i.packetsLost,\n packetsReceived: i.packetsReceived,\n codec: codec || this.getCodecByType(kind),\n roundTripTime\n };\n\n if (kind === 'video' && this._rtcStatistic.value && this._rtcStatistic.value.video) {\n rtcStats[kind].framesDecoded = i.framesDecoded;\n rtcStats[kind]['fps'] = (i.framesDecoded - this._rtcStatistic.value.video.framesDecoded) /\n (rtcStats[kind].timestamp - this._rtcStatistic.value.video.timestamp) *\n 1000 || 0;\n }\n }\n }\n });\n }\n\n this._rtcStatistic.value = rtcStats;\n }).then(() => {\n if (this._isMonitorRunning) {\n this._updateTimeOut = window.setTimeout(() => this.updateStatistic(), updateStatisticTimeOut);\n }\n });\n }\n\n private async updateStatisticLegacy(): Promise<void> {\n const ignored = await this._peerConnection.getStatsLegacy().then(stats => {\n const rtcStats: IRtcMonitorStatistic = {};\n let roundTripTime = this._estimatedRoundTripTime;\n\n stats.result().forEach(report => {\n report.names().forEach(name => {\n if (name === 'googRTT') {\n roundTripTime = report.stat(name);\n }\n });\n\n if (report.type === 'ssrc') {\n const mediaType = report.stat('mediaType').toString();\n\n rtcStats[mediaType] = {timestamp: Date.now()};\n rtcStats[mediaType]['ssrc'] = report.stat('ssrc').toString();\n rtcStats[mediaType]['mediaType'] = mediaType;\n rtcStats[mediaType]['bytesReceived'] = report.stat('bytesReceived');\n rtcStats[mediaType]['packetsLost'] = report.stat('packetsLost');\n rtcStats[mediaType]['packetsReceived'] = report.stat('packetsReceived');\n rtcStats[mediaType]['codec'] = report.stat('googCodecName').toString() || this.getCodecByType(mediaType);\n rtcStats[mediaType]['roundTripTime'] = roundTripTime;\n\n if (mediaType === 'video' && this._rtcStatistic.value && this._rtcStatistic.value.video) {\n rtcStats[mediaType]['framesDecoded'] = report.stat('framesDecoded');\n rtcStats[mediaType]['fps'] = (rtcStats[mediaType].framesDecoded - this._rtcStatistic.value.video.framesDecoded) /\n (rtcStats[mediaType].timestamp - this._rtcStatistic.value.video.timestamp) *\n 1000 || 0;\n }\n }\n });\n this._rtcStatistic.value = rtcStats;\n }).then(() => {\n if (this._isMonitorRunning) {\n this._updateTimeOut = window.setTimeout(() => this.updateStatistic(), updateStatisticTimeOut);\n }\n });\n }\n\n private getCodecByType(type: string): string {\n switch (type) {\n case 'audio':\n return this._estimatedAudioCodec;\n case 'video':\n return this._estimatedVideoCodec;\n default:\n return 'unknown';\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IPeerConnection from '../../rtc/IPeerConnection';\nimport SDK from '../SDK';\nimport {IStream} from './IStream';\nimport EndPoint, {SetRemoteDescriptionStatus} from '../discovery/EndPoint';\nimport PeerConnectionService, {IPeerConnectionOfferInit} from '../../rtc/PeerConnectionService';\nimport Discovery from '../discovery/Discovery';\nimport FeatureEnablement from '../feature/FeatureEnablement';\nimport ChannelState from '../channels/ChannelState';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport RtcConnectionMonitor from '../../rtc/RtcConnectionMonitor';\nimport Durations from '../../time/Duration';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport ChannelContext from '../channels/ChannelContext';\n\nconst iceCandidateAccumulationInterval = 100;\nconst defaultStreamSetupTimeout = 30000;\n\nexport default class RealTimeStream implements IStream {\n private readonly _logger: ILogger = LoggerFactory.getLogger('RealTimeStream');\n private readonly _channelContext: ChannelContext;\n private readonly _handleStreamFailure: () => Promise<void>;\n\n constructor(channelContext, handleStreamFailure: () => Promise<void>) {\n this._channelContext = channelContext;\n this._handleStreamFailure = handleStreamFailure;\n }\n\n start(uri, token, listenOnStreamSetup, playMediaStreamInVideoElement): Promise<void> {\n return Promise.all<EndPoint, IPeerConnectionOfferInit>([\n Discovery.discoverClosestEndPointWithCaching(uri),\n PeerConnectionService.createPeerConnectionOffer()\n ])\n .then(([endPoint, {localOffer, peerConnection}]) => {\n this._channelContext.online.value = true;\n this._channelContext.endPoint.value = endPoint;\n this._logger.info('Connecting to [%s]', endPoint.toString());\n this._logger.info('Local offer:\\n' + localOffer.sdp);\n\n if (FeatureEnablement.clientOfferDisabled || !peerConnection.supportsSetConfiguration || !peerConnection.supportsGetConfiguration) {\n peerConnection.close();\n peerConnection = null;\n localOffer = null;\n }\n\n this._channelContext.peerConnection.value = peerConnection;\n\n return endPoint.subscribe(token, localOffer, this._channelContext.failureCount.value);\n })\n .then(({status, stream, rtcConfiguration, setRemoteDescriptionResponse, createOfferDescriptionResponse, createAnswerDescriptionResponse, lag}) => {\n this._channelContext.stream.value = stream;\n this._channelContext.lag.value = lag;\n\n this._channelContext.applySessionAndStreamPropertiesToVideoElement();\n\n this._logger.debug(\n '[%s] Subscribe completed [%s] [%j] [%j] [%j] [%j]',\n this._channelContext.streamId,\n status,\n rtcConfiguration,\n setRemoteDescriptionResponse,\n createOfferDescriptionResponse,\n createAnswerDescriptionResponse\n );\n\n this._channelContext.state.value = this._channelContext.mapSubscribeStatusToChannelStatus(status);\n\n this._channelContext.applyStatus(status);\n\n if (status !== 'ok') {\n return;\n }\n\n return this.applyRtcConfiguration(this._channelContext.peerConnection.value, rtcConfiguration)\n .then(peerConnection => {\n let submitCandidatesTimeout;\n let cancelDiscovery = false;\n let discoveryCompleted = false;\n const candidates: RTCIceCandidate[] = [];\n\n peerConnection.onicecandidate = (e): void => {\n if (this._channelContext.stream.value !== stream) {\n return;\n }\n\n if (this._channelContext.peerConnection.value !== peerConnection) {\n return;\n }\n\n if (cancelDiscovery) {\n return;\n }\n\n if (!SDK.sendLocalCandidates.value) {\n return;\n }\n\n if (e.candidate && e.candidate.candidate) {\n candidates.push(e.candidate);\n } else {\n discoveryCompleted = true;\n }\n\n if (!submitCandidatesTimeout) {\n submitCandidatesTimeout = setTimeout(() => {\n if (this._channelContext.stream.value !== stream) {\n return;\n }\n\n if (cancelDiscovery) {\n return;\n }\n\n const ignored = this._channelContext.endPoint.value.addIceCandidates(stream, candidates, discoveryCompleted)\n .then(({status, options}) => {\n if (status !== 'ok') {\n this._logger.warn('[%s] Failed to add ICE candidates with reason [%s]', this._channelContext.streamId, status);\n\n return;\n }\n\n if (options.includes('cancel')) {\n cancelDiscovery = true;\n }\n\n this._logger.info('[%s] Added ICE candidates with reason [%s] and options [%s]', this._channelContext.streamId, status, options);\n })\n .catch(e => {\n this._logger.error('[%s] Failed to add ICE candidates', this._channelContext.streamId, e);\n });\n }, iceCandidateAccumulationInterval);\n }\n };\n\n peerConnection.oniceconnectionstatechange = (): void => {\n if (this._channelContext.stream.value !== stream) {\n return;\n }\n\n if (this._channelContext.peerConnection.value !== peerConnection) {\n return;\n }\n\n const retryCallback = (): void => {\n // If we stop normally the peer connection is unregistered first.\n // Thus anytime we see a closed peer connection that is still valid, it is an error.\n this._channelContext.state.value = ChannelState.Error;\n\n if (this._channelContext.videoElement.value) {\n this._channelContext.videoElement.value.pause();\n this._channelContext.videoElement.value.srcObject = null;\n }\n\n this._channelContext.playing.value = false;\n this._channelContext.loading.value = true;\n\n const ignored = this._handleStreamFailure()\n .catch(e => {\n this._logger.error(\n '[%s] Failed handling stream failure after peer connection stopped with state [%s]',\n this._channelContext.streamId,\n peerConnection.iceConnectionState,\n e\n );\n });\n };\n\n switch (peerConnection.iceConnectionState) {\n case 'checking':\n case 'completed':\n case 'connected':\n case 'new':\n return;\n\n case 'disconnected':\n case 'failed':\n if (navigator.onLine) {\n this._logger.info('[%s] ICE connection state changed to [%s], trying to reconnect', this._channelContext.streamId, peerConnection.iceConnectionState);\n this.reconnectPeerConnection(peerConnection, retryCallback);\n }\n\n return;\n case 'closed':\n this._logger.info('[%s] ICE connection state changed to [%s], retrying to connect', this._channelContext.streamId, peerConnection.iceConnectionState);\n retryCallback();\n\n return;\n default:\n assertUnreachable(peerConnection.iceConnectionState);\n }\n };\n\n const mediaStreamPromise = new Promise<MediaStream>((resolve, reject) => {\n if (!FeatureEnablement.onTrackDisabled) {\n const timeoutId = setTimeout(() => reject(new Error('Stream setup timed out')), defaultStreamSetupTimeout);\n\n peerConnection.ontrack = (e): void => {\n clearTimeout(timeoutId);\n\n resolve(e.streams[0]);\n };\n\n return;\n }\n\n const trackListener = (e): void => {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n clearTimeout(timeoutId);\n peerConnection.removeEventListener('track', trackListener);\n peerConnection.removeEventListener('addstream', trackListener);\n\n if (e.streams) {\n resolve(e.streams[0]);\n } else {\n resolve(e.stream);\n }\n };\n\n const timeoutId = setTimeout(() => {\n peerConnection.removeEventListener('track', trackListener);\n peerConnection.removeEventListener('addstream', trackListener);\n reject(new Error('Stream setup timed out'));\n }, defaultStreamSetupTimeout);\n\n peerConnection.addEventListener('track', trackListener);\n peerConnection.addEventListener('addstream', trackListener);\n\n return;\n });\n\n return new Promise(resolve => {\n resolve();\n }).then(() => {\n if (!setRemoteDescriptionResponse) {\n return;\n }\n\n this._logger.info('[%s] Set local SDP offer [%s]', this._channelContext.streamId, setRemoteDescriptionResponse.sessionDescription.sdp);\n\n return peerConnection.setLocalDescription(setRemoteDescriptionResponse.sessionDescription);\n }).then(() => {\n if (!createAnswerDescriptionResponse) {\n return;\n }\n\n this._logger.info('[%s] Set remote SDP answer [%s]', this._channelContext.streamId, createAnswerDescriptionResponse.sessionDescription.sdp);\n\n return peerConnection.setRemoteDescription(createAnswerDescriptionResponse.sessionDescription);\n }).then(() => {\n if (!createOfferDescriptionResponse) {\n return;\n }\n\n this._logger.info('[%s] Set remote SDP offer [%s]', this._channelContext.streamId, createOfferDescriptionResponse.sessionDescription.sdp);\n\n return peerConnection.setRemoteDescription(createOfferDescriptionResponse.sessionDescription)\n .then(() => {\n return peerConnection.createAnswer({\n offerToReceiveAudio: true,\n offerToReceiveVideo: true\n });\n }).then(answer => {\n this._logger.info('[%s] Set local SDP answer [%j]', this._channelContext.streamId, answer);\n\n return this._channelContext.endPoint.value.setRemoteDescription(stream, answer);\n }).then(({status, sessionDescription}) => {\n this._channelContext.state.value = this.mapSetRemoteDescriptionStatusToChannelStatus(status);\n\n if (status !== 'ok') {\n this._channelContext.playing.value = false;\n this._channelContext.standby.value = true;\n this._channelContext.stopped.value = false;\n\n return;\n }\n\n return peerConnection.setLocalDescription(sessionDescription);\n });\n }).then(() => {\n listenOnStreamSetup.success(this._channelContext.streamId);\n\n return mediaStreamPromise;\n }).then(mediaStream => {\n this._channelContext.mediaStream.value = mediaStream;\n\n const rtcConnectionMonitor = new RtcConnectionMonitor(peerConnection, mediaStream, this._channelContext.endPoint.value.roundTripTime / 4);\n\n this._channelContext.disposables.add(rtcConnectionMonitor);\n\n const ignored = rtcConnectionMonitor.rtcStatistic.subscribe(statistics => {\n this._channelContext.rtcStatistics.value = statistics;\n\n if (!this._channelContext.rtcVideoStatistic && !this._channelContext.rtcAudioStatistic) {\n this._channelContext.rtcAudioStatistic = statistics.audio;\n this._channelContext.rtcVideoStatistic = statistics.video;\n\n return;\n }\n\n let audioTrackFailed = false;\n let videoTrackFailed = false;\n\n if (statistics.audio) {\n if (this._channelContext.rtcAudioStatistic && this._channelContext.rtcAudioStatistic.timestamp !== statistics.audio.timestamp) {\n audioTrackFailed = this._channelContext.rtcAudioStatistic && this._channelContext.rtcAudioStatistic.bytesReceived === statistics.audio.bytesReceived;\n\n if (audioTrackFailed && navigator.onLine) {\n this._logger.info(\n '[%s] Audio track failed with last bytesReceived [%s] is equal to previous bytesReceived [%s] within [%s]',\n this._channelContext.streamId,\n statistics.audio.bytesReceived,\n this._channelContext.rtcAudioStatistic.bytesReceived,\n new Durations(statistics.audio.timestamp - this._channelContext.rtcAudioStatistic.timestamp).toIsoString()\n );\n }\n\n this._channelContext.rtcAudioStatistic = statistics.audio;\n }\n }\n\n if (statistics.video) {\n if (this._channelContext.rtcVideoStatistic && this._channelContext.rtcVideoStatistic.timestamp !== statistics.video.timestamp) {\n videoTrackFailed = this._channelContext.rtcVideoStatistic && this._channelContext.rtcVideoStatistic.bytesReceived === statistics.video.bytesReceived;\n\n if (videoTrackFailed && navigator.onLine) {\n this._logger.info(\n '[%s] Video track failed with last bytesReceived [%s] is equal to previous bytesReceived [%s] within [%s]',\n this._channelContext.streamId,\n statistics.video.bytesReceived,\n this._channelContext.rtcVideoStatistic.bytesReceived,\n new Durations(statistics.video.timestamp - this._channelContext.rtcVideoStatistic.timestamp).toIsoString()\n );\n }\n\n this._channelContext.rtcVideoStatistic = statistics.video;\n }\n }\n\n if ((videoTrackFailed || audioTrackFailed) && navigator.onLine) {\n const retryCallback = (): void => {\n this._channelContext.state.value = ChannelState.Error;\n\n if (this._channelContext.videoElement.value) {\n this._channelContext.videoElement.value.pause();\n this._channelContext.videoElement.value.srcObject = null;\n }\n\n this._channelContext.playing.value = false;\n this._channelContext.loading.value = true;\n\n rtcConnectionMonitor.dispose();\n\n const ignored = this._handleStreamFailure()\n .catch(e => {\n this._logger.error(\n '[%s] Failed handling stream failure after track stopped with state [%s]',\n this._channelContext.streamId,\n peerConnection.iceConnectionState,\n e\n );\n });\n };\n\n this.reconnectPeerConnection(peerConnection, retryCallback);\n } else {\n this._channelContext.peerConnectionReconnectAttempts = 0;\n }\n });\n\n if (!SDK.automaticallyPlayMediaStream) {\n this._channelContext.autoMuted.value = false;\n this._channelContext.autoPaused.value = true;\n this._channelContext.loading.value = false;\n this._channelContext.playing.value = false;\n this._channelContext.state.value = ChannelState.Paused;\n\n return;\n }\n\n return playMediaStreamInVideoElement(mediaStream);\n });\n });\n });\n }\n\n private async applyRtcConfiguration(\n optionalPeerConnection: IPeerConnection | null,\n rtcConfiguration: RTCConfiguration): Promise<IPeerConnection> {\n if (!optionalPeerConnection) {\n rtcConfiguration = this.truncateIceServers(rtcConfiguration);\n\n return SDK.peerConnectionFactory.value.createPeerConnection(rtcConfiguration);\n }\n\n const newRtcConfiguration = {\n ...optionalPeerConnection.getConfiguration(),\n ...rtcConfiguration\n };\n\n optionalPeerConnection.setConfiguration(newRtcConfiguration);\n\n return optionalPeerConnection;\n }\n\n private truncateIceServers(configuration: RTCConfiguration): RTCConfiguration {\n const iceServers: RTCIceServer[] = [];\n\n for (let i = 0; i < configuration.iceServers.length; i++) {\n const urls: string[] = [];\n\n for (let index = 0; index < 2; index++) {\n const url = configuration.iceServers[i].urls[index];\n\n if (url) {\n urls.push(configuration.iceServers[i].urls[index]);\n }\n }\n\n iceServers.push({\n urls: urls,\n username: configuration.iceServers[i].username,\n credential: configuration.iceServers[i].credential\n });\n }\n\n configuration.iceServers = iceServers;\n\n return configuration;\n }\n\n private reconnectPeerConnection(peerConnection: IPeerConnection, retryCallback: () => void): void {\n if (peerConnection.iceConnectionState === 'closed') {\n return;\n }\n\n this._channelContext.state.value = ChannelState.Reconnecting;\n\n if (this._channelContext.peerConnectionReconnectAttempts < SDK.maximalNumberOfPeerConnectionReconnectAttempts || !SDK.automaticallyReconnectPeerConnection) {\n this._channelContext.peerConnectionReconnectAttempts++;\n\n if (FeatureEnablement.clientOfferDisabled ||\n !peerConnection.supportsSetConfiguration ||\n !peerConnection.supportsGetConfiguration ||\n this._channelContext.failureCount.value\n ) {\n return;\n }\n\n this._logger.info('Reconnecting peer connection by restarting ICE');\n\n const localOffer = peerConnection.currentLocalDescription;\n const ignored = peerConnection.createOffer({iceRestart: true}).then(offer => {\n return peerConnection.setLocalDescription(offer).then(() => {\n return peerConnection.setLocalDescription(localOffer);\n });\n })\n .catch(e => {\n this._logger.error('Failed to reconnect peer connection', e);\n this._channelContext.peerConnectionReconnectAttempts = 0;\n retryCallback();\n });\n\n return;\n }\n\n this._logger.info('Failed to reconnect peer connection after [%s] attempts, performing full recovery', this._channelContext.peerConnectionReconnectAttempts);\n this._channelContext.peerConnectionReconnectAttempts = 0;\n retryCallback();\n }\n\n private mapSetRemoteDescriptionStatusToChannelStatus(status: SetRemoteDescriptionStatus): ChannelState {\n switch (status) {\n case 'ok':\n return ChannelState.Starting;\n case 'unauthorized':\n return ChannelState.Unauthorized;\n case 'not-found':\n case 'capacity':\n case 'rate-limited':\n case 'timeout':\n return ChannelState.Recovering;\n case 'failed':\n return ChannelState.Error;\n default:\n assertUnreachable(status);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {IStream} from './IStream';\nimport EdgeAuth from '../edgeAuth/EdgeAuth';\nimport RealTimeStream from './RealTimeStream';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport ChannelState from '../channels/ChannelState';\n\nexport default class RealTimeStreamFactory {\n private static _logger: ILogger = LoggerFactory.getLogger('Streaming');\n\n static create(token: string, channelContext, handleStreamFailure: () => Promise<void>): IStream {\n const parsedToken = EdgeAuth.parseToken(token);\n const isRtmp = parsedToken && parsedToken.token && parsedToken.token.capabilities && parsedToken.token.capabilities.includes('rtmp');\n\n if (isRtmp) {\n this._logger.error('This build does not support RTMP playback.');\n channelContext.state.value = ChannelState.UnsupportedFeature;\n\n return;\n }\n\n const isStreaming = parsedToken && parsedToken.token && parsedToken.token.capabilities && parsedToken.token.capabilities.includes('streaming');\n\n if (isStreaming) {\n this._logger.error('This build does not support Live Stream playback.');\n channelContext.state.value = ChannelState.UnsupportedFeature;\n\n return;\n }\n\n return new RealTimeStream(channelContext, handleStreamFailure);\n }\n\n constructor() {\n throw new Error('RealTimeStreamFactory is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport IDisposable from '../../lang/IDisposable';\nimport ReadOnlySubject from '../../rx/ReadOnlySubject';\nimport Dimension from '../../video/Dimension';\nimport EndPoint, {IStream} from '../discovery/EndPoint';\nimport SDK from '../SDK';\nimport IPeerConnection from '../../rtc/IPeerConnection';\nimport ChannelState from './ChannelState';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport Disposable from '../../lang/Disposable';\nimport EdgeAuth from '../edgeAuth/EdgeAuth';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport VideoTelemetry from '../../video/VideoTelemetry';\nimport SessionTelemetry from '../../video/SessionTelemetry';\nimport {IRtcMonitorStatistic} from '../../rtc/RtcConnectionMonitor';\nimport {BitrateMode, BitrateState} from '../api/SetTemporaryMaximalBitrate';\n\nimport {EdgeToken} from '../edgeAuth/EdgeToken';\nimport {BitsPerSecond, Millisecond} from '../../units/Units';\nimport ChannelContext from './ChannelContext';\nimport StreamFactory from '../streaming/StreamFactory';\nimport DiscoveryUri from '../discovery/DiscoveryUri';\nimport MetricsFactory from '../../metrics/MetricsFactory';\nimport MetricsService from '../../metrics/MetricsService';\n\nconst defaultTargetLag = 0;\nconst defaultStreamTerminationReason = 'client:termination';\nconst backoffIntervalInMilliseconds = 2000;\nconst failureCountCleanUpIntervalInMilliseconds = 3000;\nconst maxBackoffIntervalInMilliseconds = 300000;\nconst standbyPollingIntervalInMilliseconds = 15000;\n\nexport default class Channel implements IDisposable {\n private readonly _logger: ILogger = LoggerFactory.getLogger('Channel');\n private readonly _context: ChannelContext;\n private readonly _channelStartTime: number;\n private readonly _readOnlyVideoElement: ReadOnlySubject<HTMLVideoElement>;\n private readonly _readOnlyToken: ReadOnlySubject<EdgeToken>;\n private readonly _readOnlyPeerConnection: ReadOnlySubject<IPeerConnection>;\n private readonly _readOnlyState: ReadOnlySubject<ChannelState>;\n private readonly _readOnlyAutoMuted: ReadOnlySubject<boolean>;\n private readonly _readOnlyAutoPaused: ReadOnlySubject<boolean>;\n private readonly _readOnlyTokenExpiring: ReadOnlySubject<boolean>;\n private readonly _readOnlyAuthorized: ReadOnlySubject<boolean>;\n private readonly _readOnlyOnline: ReadOnlySubject<boolean>;\n private readonly _readOnlyLoading: ReadOnlySubject<boolean>;\n private readonly _readOnlyPlaying: ReadOnlySubject<boolean>;\n private readonly _readOnlyStandby: ReadOnlySubject<boolean>;\n private readonly _readOnlyStopped: ReadOnlySubject<boolean>;\n private readonly _readOnlyTargetLag: ReadOnlySubject<Millisecond>;\n private readonly _readOnlyLag: ReadOnlySubject<Millisecond>;\n private readonly _readOnlyBitrateLimit: ReadOnlySubject<BitsPerSecond>;\n private readonly _readOnlyResolution: ReadOnlySubject<Dimension>;\n private readonly _readOnlyFailureCount: ReadOnlySubject<number>;\n private readonly _readOnlyEndPoint: ReadOnlySubject<EndPoint>;\n private readonly _readOnlyStream: ReadOnlySubject<IStream>;\n private readonly _readOnlyRtcStatistics: ReadOnlySubject<IRtcMonitorStatistic>;\n private readonly _readOnlyMediaStream: ReadOnlySubject<MediaStream>;\n\n private _metricsService: MetricsService;\n private readonly _videoMetaDataChangedHandler: () => void;\n\n constructor(videoElement: HTMLVideoElement, token: string, targetLag: number = defaultTargetLag) {\n this._context = new ChannelContext(token, targetLag);\n this._channelStartTime = Date.now();\n this._readOnlyVideoElement = new ReadOnlySubject<HTMLVideoElement>(this._context.videoElement);\n this._readOnlyToken = new ReadOnlySubject<string>(this._context.token);\n this._readOnlyPeerConnection = new ReadOnlySubject<IPeerConnection>(this._context.peerConnection);\n this._readOnlyState = new ReadOnlySubject<ChannelState>(this._context.state);\n this._readOnlyAutoMuted = new ReadOnlySubject<boolean>(this._context.autoMuted);\n this._readOnlyAutoPaused = new ReadOnlySubject<boolean>(this._context.autoPaused);\n this._readOnlyTokenExpiring = new ReadOnlySubject<boolean>(this._context.tokenExpiring);\n this._readOnlyAuthorized = new ReadOnlySubject<boolean>(this._context.authorized);\n this._readOnlyOnline = new ReadOnlySubject<boolean>(this._context.online);\n this._readOnlyLoading = new ReadOnlySubject<boolean>(this._context.loading);\n this._readOnlyPlaying = new ReadOnlySubject<boolean>(this._context.playing);\n this._readOnlyStandby = new ReadOnlySubject<boolean>(this._context.standby);\n this._readOnlyStopped = new ReadOnlySubject<boolean>(this._context.stopped);\n this._readOnlyTargetLag = new ReadOnlySubject<number>(this._context.targetLag);\n this._readOnlyLag = new ReadOnlySubject<number>(this._context.lag);\n this._readOnlyBitrateLimit = new ReadOnlySubject<number>(this._context.bitrateLimit);\n this._readOnlyResolution = new ReadOnlySubject<Dimension>(this._context.resolution);\n this._readOnlyFailureCount = new ReadOnlySubject<number>(this._context.failureCount);\n this._readOnlyEndPoint = new ReadOnlySubject<EndPoint>(this._context.endPoint);\n this._readOnlyStream = new ReadOnlySubject<IStream>(this._context.stream);\n this._readOnlyRtcStatistics = new ReadOnlySubject<IRtcMonitorStatistic>(this._context.rtcStatistics);\n this._readOnlyMediaStream = new ReadOnlySubject<MediaStream>(this._context.mediaStream);\n\n const parsedToken = EdgeAuth.parseToken(this._context.token.value);\n const discoveryUri = (EdgeAuth.getUri(parsedToken) || SDK.discoveryUri.value).toString();\n\n SDK.tenancy.value = EdgeAuth.getTenancy(parsedToken) || SDK.tenancy.value;\n DiscoveryUri.uri.value = discoveryUri;\n this._metricsService = MetricsFactory.getMetricsService(discoveryUri);\n this._context.sessionTelemetry = new SessionTelemetry(SDK.pageLoadTime, this._metricsService);\n this._context.channelDisposables.add(this._context.sessionTelemetry);\n this._videoMetaDataChangedHandler = this.handleVideoMetaDataChanged.bind(this);\n this.videoElement = videoElement;\n\n this._context.channelDisposables.add(\n this._context.videoElement.subscribe(videoElement => {\n this._context.rendererDisposables.dispose();\n\n if (!videoElement) {\n return;\n }\n\n this._context.rendererDisposables.add(this._context.stream.subscribe(stream => {\n if (this._context.videoTelemetry) {\n this._context.videoTelemetry.dispose();\n }\n\n if (!stream) {\n return;\n }\n\n if (!this.videoElement) {\n return;\n }\n\n if (this.videoElement.dataset) {\n this.videoElement.dataset.sessionId = SDK.clientSessionId;\n this.videoElement.dataset.streamId = this.streamId;\n }\n\n this._context.videoTelemetry = new VideoTelemetry(this.streamId, SDK.pageLoadTime, this._channelStartTime, this._metricsService);\n this._context.videoTelemetry.setupListenerForTimeToFirstTime(this.videoElement);\n this._context.videoTelemetry.setupListenerForRebuffering(this.videoElement);\n\n if (this._context.state.value === ChannelState.Stopped) {\n const ignored = this.restartAfterStop();\n }\n }));\n\n this._context.channelDisposables.add(this._context.rendererDisposables);\n }));\n this._context.channelDisposables.add(\n this._context.state.subscribe(state => {\n if (this._context.clearFailureCountTimeout) {\n clearTimeout(this._context.clearFailureCountTimeout);\n }\n\n if (!this._context.failureCount.value) {\n return;\n }\n\n if (state !== ChannelState.Playing) {\n return;\n }\n\n this._context.clearFailureCountTimeout = window.setTimeout(() => {\n this._context.failureCount.value = 0;\n }, failureCountCleanUpIntervalInMilliseconds);\n }));\n this._context.channelDisposables.add(\n this._context.resolution.subscribe(resolution => {\n if (this._context.videoTelemetry) {\n this._context.videoTelemetry.onVideoResolutionChanges(resolution.toString());\n }\n }));\n this._context.channelDisposables.add(\n this._context.bitrateLimit.subscribe(bitrateLimit => {\n if (bitrateLimit && this._context.endPoint.value && this._context.stream.value) {\n const elapsedInMilliseconds = Date.now() - this._context.channelInitialization.getTime();\n const ignored = this._context.endPoint.value.limitBitrate(\n this._context.stream.value,\n elapsedInMilliseconds,\n bitrateLimit,\n BitrateState.Keep,\n BitrateMode.Normal\n )\n .catch(e => {\n this._logger.error('Error while setting limit bitrate', e);\n });\n }\n })\n );\n\n this.start();\n }\n\n get videoElement(): HTMLVideoElement {\n return this._context.videoElement.value;\n }\n\n set videoElement(videoElement: HTMLVideoElement) {\n if (this._context.videoElement.value) {\n this._context.videoElement.value.removeEventListener('loadeddata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.removeEventListener('loadedmetadata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.removeEventListener('resize', this._videoMetaDataChangedHandler);\n\n if (this._context.videoElement.value.dataset) {\n this._context.videoElement.value.dataset.sessionId = '';\n this._context.videoElement.value.dataset.streamId = '';\n }\n\n this._context.rendererDisposables.dispose();\n\n this._context.videoElement.value.pause();\n this._context.videoElement.value.srcObject = null;\n }\n\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Stopped;\n\n this._context.videoElement.value = videoElement;\n\n if (this._context.videoElement.value) {\n this._context.videoElement.value.addEventListener('loadeddata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.addEventListener('loadedmetadata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.addEventListener('resize', this._videoMetaDataChangedHandler);\n }\n }\n\n private handleVideoMetaDataChanged(): void {\n const videoElement = this._context.videoElement.value;\n\n if (videoElement) {\n if (this.resolution.value.width !== videoElement.videoWidth || this.resolution.value.height !== videoElement.videoHeight) {\n this._context.resolution.value = new Dimension(videoElement.videoWidth, videoElement.videoHeight);\n }\n } else {\n this._context.resolution.value = Dimension.empty;\n }\n }\n\n get token(): EdgeToken {\n return this._context.token.value;\n }\n\n set token(token: EdgeToken) {\n this._context.disposables.dispose();\n\n this._context.token.value = token;\n this._context.tokenExpiring.value = false;\n\n const parsedToken = EdgeAuth.parseToken(this._context.token.value);\n const discoveryUri = (EdgeAuth.getUri(parsedToken) || SDK.discoveryUri.value).toString();\n\n SDK.tenancy.value = EdgeAuth.getTenancy(parsedToken) || SDK.tenancy.value;\n DiscoveryUri.uri.value = discoveryUri;\n\n this._metricsService = MetricsFactory.getMetricsService(discoveryUri);\n\n this.start();\n }\n\n get peerConnection(): ReadOnlySubject<IPeerConnection> {\n return this._readOnlyPeerConnection;\n }\n\n get state(): ReadOnlySubject<ChannelState> {\n return this._readOnlyState;\n }\n\n get autoMuted(): ReadOnlySubject<boolean> {\n return this._readOnlyAutoMuted;\n }\n\n get autoPaused(): ReadOnlySubject<boolean> {\n return this._readOnlyAutoPaused;\n }\n\n get tokenExpiring(): ReadOnlySubject<boolean> {\n return this._readOnlyTokenExpiring;\n }\n\n get authorized(): ReadOnlySubject<boolean> {\n return this._readOnlyAuthorized;\n }\n\n get online(): ReadOnlySubject<boolean> {\n return this._readOnlyOnline;\n }\n\n get loading(): ReadOnlySubject<boolean> {\n return this._readOnlyLoading;\n }\n\n get playing(): ReadOnlySubject<boolean> {\n return this._readOnlyPlaying;\n }\n\n get standby(): ReadOnlySubject<boolean> {\n return this._readOnlyStandby;\n }\n\n get stopped(): ReadOnlySubject<boolean> {\n return this._readOnlyStopped;\n }\n\n get targetLag(): ReadOnlySubject<Millisecond> {\n return this._readOnlyTargetLag;\n }\n\n get lag(): ReadOnlySubject<Millisecond> {\n return this._readOnlyLag;\n }\n\n get bitrateLimit(): number {\n return this._readOnlyBitrateLimit.value;\n }\n\n get resolution(): ReadOnlySubject<Dimension> {\n return this._readOnlyResolution;\n }\n\n get failureCount(): ReadOnlySubject<number> {\n return this._readOnlyFailureCount;\n }\n\n get endPoint(): ReadOnlySubject<EndPoint> {\n return this._readOnlyEndPoint;\n }\n\n get stream(): ReadOnlySubject<IStream> {\n return this._readOnlyStream;\n }\n\n get streamId(): string {\n return this._context.streamId;\n }\n\n get rtcStats(): ReadOnlySubject<IRtcMonitorStatistic> {\n return this._readOnlyRtcStatistics;\n }\n\n get mediaStream(): ReadOnlySubject<MediaStream> {\n return this._readOnlyMediaStream;\n }\n\n setBitrateLimit(bitrateLimit: BitsPerSecond): void {\n this._context.bitrateLimit.value = bitrateLimit;\n }\n\n clearBitrateLimit(): void {\n if (this._context.bitrateLimit.value && this._context.endPoint.value && this._context.stream.value) {\n const elapsedInMilliseconds = Date.now() - this._context.channelInitialization.getTime();\n const bitrateInBitsPerSecond = 0;\n const ignored = this._context.endPoint.value.limitBitrate(\n this._context.stream.value,\n elapsedInMilliseconds,\n bitrateInBitsPerSecond,\n BitrateState.Keep,\n BitrateMode.Reset\n )\n .then(({status}) => {\n if (status === 'ok') {\n this._context.bitrateLimit.value = 0;\n }\n })\n .catch(e => {\n this._logger.error('Error while setting limit bitrate', e);\n });\n }\n }\n\n updateTargetLag(lag: Millisecond): void {\n this._context.targetLag.value = lag;\n }\n\n stop(reason: string): void {\n if (this._context.videoElement.value) {\n this._context.videoElement.value.pause();\n this._context.videoElement.value.srcObject = null;\n }\n\n this._context.rendererDisposables.dispose();\n\n this.cleanUpResources(reason);\n\n this._context.state.value = ChannelState.Stopped;\n }\n\n async resume(): Promise<void> {\n if (this._context.mediaStream.value) {\n this._context.autoPaused.value = false;\n\n return this.playMediaStreamInVideoElement(this._context.mediaStream.value);\n }\n }\n\n mute(): void {\n const videoElement = this._context.videoElement.value;\n\n if (videoElement) {\n videoElement.muted = true;\n }\n }\n\n unmute(): void {\n const videoElement = this._context.videoElement.value;\n\n if (videoElement) {\n videoElement.muted = false;\n this._context.autoMuted.value = false;\n }\n }\n\n dispose(): void {\n this.stop('client:channel-dispose');\n this._context.channelDisposables.dispose();\n this._context.isDisposed = true;\n }\n\n getUri(token): URL {\n const parsedToken = EdgeAuth.parseToken(token);\n const url = EdgeAuth.getUri(parsedToken);\n\n if (url) {\n return url;\n }\n\n this._logger.info('Fall back to the default discover URI [%s]', SDK.discoveryUri.value);\n\n return new URL(SDK.discoveryUri.value);\n }\n\n async start(): Promise<void> {\n if (this._context.isDisposed) {\n throw new Error('Channel was already disposed');\n }\n\n const token = this._context.token.value;\n const listenOnStreamSetup = this._context.sessionTelemetry.listenOnStreamSetup();\n\n if (!EdgeAuth.isValidToken(token)) {\n this._logger.error('Failed to parse token [%s]', token);\n this._context.state.value = ChannelState.Unauthorized;\n this._context.authorized.value = false;\n\n return;\n }\n\n this.cleanUpResources('client:start');\n this._context.state.value = ChannelState.Starting;\n this._context.loading.value = true;\n\n const uri = this.getUri(token);\n const streamPlayer = StreamFactory.create(token, this._context, this.handleStreamFailure.bind(this));\n\n if (!streamPlayer) {\n return;\n }\n\n return streamPlayer.start(\n uri,\n token,\n listenOnStreamSetup,\n this.playMediaStreamInVideoElement.bind(this))\n .then(() => {\n this._context.loading.value = false;\n })\n .then(() => {\n this._context.loading.value = false;\n })\n .catch(e => {\n listenOnStreamSetup.fail();\n\n this._context.failureCount.value++;\n\n this._context.online.value = false;\n\n this.cleanUpResources('client:cleanup-after-failed-setup');\n\n this._context.state.value = ChannelState.Error;\n\n this._logger.error('Failed to discover end point, marking as offline', e);\n })\n .finally(() => {\n if (this._context.state.value === ChannelState.Playing || !SDK.automaticRetryOnFailure) {\n return;\n }\n\n const timeoutId = setTimeout(() => {\n const ignored = this.handleStreamFailure()\n .catch(e => {\n this._logger.error('Failed handling stream failure', e);\n });\n }, this.getRetryInterval());\n\n this._context.disposables.add(new Disposable(() => {\n clearTimeout(timeoutId);\n }));\n });\n }\n\n private async restartAfterStop(): Promise<void> {\n if (this._context.isDisposed) {\n throw new Error('Channel was already disposed');\n }\n\n if (this._context.mediaStream.value) {\n return this.playMediaStreamInVideoElement(this._context.mediaStream.value);\n }\n\n if (this._context.token.value) {\n const ignored = this.start();\n }\n }\n\n public async play(): Promise<void> {\n const mediaStream = this._context.mediaStream.value;\n\n if (!mediaStream) {\n return this.start();\n }\n\n return this.playMediaStreamInVideoElement(mediaStream);\n }\n\n private getRetryInterval(): number {\n switch (this._context.state.value) {\n case ChannelState.StandBy:\n case ChannelState.Offline:\n return standbyPollingIntervalInMilliseconds;\n case ChannelState.Error:\n case ChannelState.Recovering:\n case ChannelState.Unauthorized:\n case ChannelState.GeoRestricted:\n case ChannelState.GeoBlocked:\n case ChannelState.Stopped:\n case ChannelState.Starting:\n case ChannelState.Playing:\n case ChannelState.Paused:\n case ChannelState.Reconnecting:\n case ChannelState.UnsupportedFeature:\n // First and second attempt fast, after that exponential with backoff interval\n return Math.min(maxBackoffIntervalInMilliseconds, Math.pow(backoffIntervalInMilliseconds, Math.max(0, this._context.failureCount.value - 1)));\n default:\n assertUnreachable(this._context.state.value);\n }\n }\n\n private async handleStreamFailure(): Promise<void> {\n switch (this._context.state.value) {\n case ChannelState.Error:\n case ChannelState.Reconnecting:\n case ChannelState.StandBy:\n case ChannelState.Offline:\n case ChannelState.Recovering:\n this._logger.info('Retry start with initial state [%s] [%s]', this._context.state.value, ChannelState[this._context.state.value]);\n\n break;\n case ChannelState.Unauthorized:\n this._logger.info('Channel is unauthorized, skipping retry of start. Please provide a new token and invoke start()');\n\n return;\n case ChannelState.GeoRestricted:\n this._logger.info('Channel is geo restricted, skipping retry of start. Please provide a new token and invoke start()');\n\n return;\n case ChannelState.GeoBlocked:\n this._logger.info('Channel is geo blocked, skipping retry of start. Please provide a new token and invoke start()');\n\n return;\n case ChannelState.Stopped:\n this._logger.info('Channel is stopped, skipping retry of start.');\n\n return;\n case ChannelState.Playing:\n this._logger.info('Channel is playing, skipping retry of start');\n\n return;\n case ChannelState.Paused:\n this._logger.info('Channel is paused, skipping retry of start. Please invoke play()');\n\n return;\n case ChannelState.Starting:\n this._logger.info('Channel is already starting, skipping retry of start');\n\n return;\n case ChannelState.UnsupportedFeature:\n this._logger.info('Channel is stopped due to unsupported feature, skipping retry of start.');\n\n return;\n default:\n assertUnreachable(this._context.state.value);\n }\n\n return this.start();\n }\n\n private cleanUpResources(reason: string = defaultStreamTerminationReason): void {\n this._context.disposables.dispose();\n\n const peerConnection = this._context.peerConnection.value;\n\n if (peerConnection) {\n this._context.peerConnection.value = null;\n peerConnection.close();\n }\n\n if (this._context.mediaStream.value) {\n this._context.mediaStream.value.getTracks().forEach(track => track.stop());\n this._context.mediaStream.value = null;\n }\n\n this._context.autoPaused.value = false;\n this._context.autoMuted.value = false;\n this._context.playing.value = false;\n this._context.stopped.value = true;\n this._context.standby.value = false;\n\n if (this._context.stream.value && this._context.endPoint.value) {\n const ignored = this._context.endPoint.value.destroyStream(this._context.stream.value, reason)\n .then(({status}) => {\n if (status !== 'ok') {\n this._logger.warn('[%s] Failed to destroy stream with reason [%s]', this.streamId, status);\n\n return;\n }\n\n this._logger.info('[%s] Destroyed stream with reason [%s]', this.streamId, status);\n })\n .catch(e => {\n this._logger.error('[%s] Failed to destroy stream', this.streamId, e);\n });\n }\n\n if (this.videoElement && this.videoElement.dataset) {\n this.videoElement.dataset.sessionId = '';\n this.videoElement.dataset.streamId = '';\n }\n\n this._context.stream.value = null;\n this._context.endPoint.value = null;\n }\n\n private async playMediaStreamInVideoElement(mediaStream: MediaStream): Promise<void> {\n const videoElement = this._context.videoElement.value;\n\n if (!videoElement) {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Stopped;\n\n return;\n }\n\n videoElement.srcObject = mediaStream;\n\n const playPromise = videoElement.play();\n\n if (playPromise === undefined) {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = true;\n this._context.state.value = ChannelState.Playing;\n\n return;\n }\n\n return playPromise.then(() => {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = true;\n this._context.state.value = ChannelState.Playing;\n }).catch(e => {\n const hasAudioTrack = !!mediaStream.getTracks().filter(track => {\n return track.kind === 'audio';\n });\n const automaticallyMuteVideoOnPlayFailureOff = !SDK.automaticallyMuteVideoOnPlayFailure;\n\n if (automaticallyMuteVideoOnPlayFailureOff || videoElement.muted || !hasAudioTrack) {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = true;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Paused;\n\n if (automaticallyMuteVideoOnPlayFailureOff) {\n this._logger.info('[%s] Paused video after play failed. Manual user action required.', this.streamId, e);\n videoElement.srcObject = null;\n\n return;\n }\n\n if (hasAudioTrack) {\n this._logger.info('[%s] Failed to play video. Manual user action required.', this.streamId, e);\n\n return;\n }\n\n this._logger.info('[%s] Failed to play muted video. Manual user action required.', this.streamId, e);\n\n return;\n }\n\n videoElement.muted = true;\n\n return videoElement.play()\n .then(() => {\n this._logger.info('[%s] Played video after auto muting. Manual user action required to unmute.', this.streamId);\n\n this._context.autoMuted.value = true;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = true;\n this._context.state.value = ChannelState.Playing;\n }).catch(e => {\n videoElement.muted = false;\n\n this._logger.info('[%s] Failed to play video. Manual user action required.', this.streamId, e);\n\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = true;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Playing;\n });\n });\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport Channel from './Channel';\nimport SDK from '../SDK';\nimport {EdgeToken} from '../edgeAuth/EdgeToken';\nimport {Millisecond} from '../../units/Units';\n\ntype CreateChannelOptions = {\n videoElement: HTMLVideoElement;\n token: EdgeToken;\n targetLag?: Millisecond;\n}\n\nexport default class Channels {\n static createChannel(options: CreateChannelOptions): Channel {\n if (!SDK.initialized.value) {\n throw new Error('SDK is not loaded.');\n }\n\n return new Channel(options.videoElement, options.token, options.targetLag);\n }\n\n private constructor() {\n throw new Error('Channels is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport SDK from '../SDK';\nimport Channels from '../channels/Channels';\nimport ChannelState from '../channels/ChannelState';\n\nexport {\n SDK,\n Channels,\n ChannelState\n};\n\nexport default {\n SDK,\n Channels,\n ChannelState\n};","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n IteratorPrototype[iteratorSymbol] = function () {\n return this;\n };\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n GeneratorFunctionPrototype.constructor = GeneratorFunction;\n GeneratorFunctionPrototype[toStringTagSymbol] =\n GeneratorFunction.displayName = \"GeneratorFunction\";\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n prototype[method] = function(arg) {\n return this._invoke(method, arg);\n };\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n if (!(toStringTagSymbol in genFun)) {\n genFun[toStringTagSymbol] = \"GeneratorFunction\";\n }\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n return this;\n };\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n Gp[toStringTagSymbol] = \"Generator\";\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n Gp[iteratorSymbol] = function() {\n return this;\n };\n\n Gp.toString = function() {\n return \"[object Generator]\";\n };\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// module exports must be returned from runtime so entry inlining is disabled\n// startup\n// Load entry module and return exports\nreturn __webpack_require__(190);\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => module['default'] :\n\t\t() => module;\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop)","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};"],"sourceRoot":""}
1
+ {"version":3,"sources":["webpack://phenix/webpack/universalModuleDefinition","webpack://phenix/./node_modules/@babel/runtime/helpers/arrayLikeToArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/arrayWithHoles.js","webpack://phenix/./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","webpack://phenix/./node_modules/@babel/runtime/helpers/assertThisInitialized.js","webpack://phenix/./node_modules/@babel/runtime/helpers/asyncToGenerator.js","webpack://phenix/./node_modules/@babel/runtime/helpers/classCallCheck.js","webpack://phenix/./node_modules/@babel/runtime/helpers/createClass.js","webpack://phenix/./node_modules/@babel/runtime/helpers/defineProperty.js","webpack://phenix/./node_modules/@babel/runtime/helpers/getPrototypeOf.js","webpack://phenix/./node_modules/@babel/runtime/helpers/inherits.js","webpack://phenix/./node_modules/@babel/runtime/helpers/iterableToArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","webpack://phenix/./node_modules/@babel/runtime/helpers/nonIterableRest.js","webpack://phenix/./node_modules/@babel/runtime/helpers/nonIterableSpread.js","webpack://phenix/./node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","webpack://phenix/./node_modules/@babel/runtime/helpers/setPrototypeOf.js","webpack://phenix/./node_modules/@babel/runtime/helpers/slicedToArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/toConsumableArray.js","webpack://phenix/./node_modules/@babel/runtime/helpers/typeof.js","webpack://phenix/./node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","webpack://phenix/./node_modules/@babel/runtime/regenerator/index.js","webpack://phenix/./src/promise/PromiseHandler.ts","webpack://phenix/./src/promise/Promise.ts","webpack://phenix/./src/logger/Logger.ts","webpack://phenix/./src/logger/Appenders.ts","webpack://phenix/./src/dom/PrivacyMode.ts","webpack://phenix/./src/logger/LoggerDefaults.ts","webpack://phenix/./src/logger/LoggingThreshold.ts","webpack://phenix/./src/logger/ConsoleAppender.ts","webpack://phenix/./src/sdk/version/VersionManager.ts","webpack://phenix/./src/telemetry/TelemetryService.ts","webpack://phenix/./src/metrics/MetricsConfiguration.ts","webpack://phenix/./src/telemetry/TelemetryApender.ts","webpack://phenix/./src/telemetry/TelemetryConfiguration.ts","webpack://phenix/./src/metrics/TelemetryDefault.ts","webpack://phenix/./src/lang/assertUnreachable.ts","webpack://phenix/./src/metrics/TelemetricLevelMapping.ts","webpack://phenix/./src/logger/LoggingLevelMapping.ts","webpack://phenix/./src/dom/PlainConfigurationParameterReader.ts","webpack://phenix/./src/logger/LoggerFactory.ts","webpack://phenix/./src/lang/Strings.ts","webpack://phenix/./src/lang/Disposable.ts","webpack://phenix/./src/rx/Subject.ts","webpack://phenix/./src/rx/ReadOnlySubject.ts","webpack://phenix/./src/dom/BrowserDetector.ts","webpack://phenix/./src/sdk/feature/FeatureEnablement.ts","webpack://phenix/./src/rtc/VanillaPeerConnection.ts","webpack://phenix/./src/rtc/VanillaPeerConnectionFactory.ts","webpack://phenix/./src/sdk/edgeAuth/EdgeAuth.ts","webpack://phenix/./src/metrics/MetricsType.ts","webpack://phenix/./src/lang/DisposableList.ts","webpack://phenix/./src/dom/ApplicationActivityMonitor.ts","webpack://phenix/./src/sdk/TelemetryUrl.ts","webpack://phenix/./src/sdk/Environment.ts","webpack://phenix/./src/sdk/discovery/DiscoveryUri.ts","webpack://phenix/./src/sdk/defaults.ts","webpack://phenix/./src/metrics/MetricType.ts","webpack://phenix/./src/metrics/MetricsService.ts","webpack://phenix/./src/metrics/MetricsFactory.ts","webpack://phenix/./src/sdk/SDK.ts","webpack://phenix/./src/sdk/channels/ChannelState.ts","webpack://phenix/./src/video/Dimension.ts","webpack://phenix/./src/sdk/api/SetTemporaryMaximalBitrate.ts","webpack://phenix/./src/time/Duration.ts","webpack://phenix/./src/video/VideoTelemetry.ts","webpack://phenix/./src/dom/StreamSetupListener.ts","webpack://phenix/./src/dom/NetworkMonitor.ts","webpack://phenix/./src/video/SessionTelemetry.ts","webpack://phenix/./src/sdk/channels/ChannelContext.ts","webpack://phenix/./src/rtc/PeerConnectionService.ts","webpack://phenix/./src/sdk/discovery/BitrateModeMapping.ts","webpack://phenix/./src/sdk/discovery/BitrateStateMapping.ts","webpack://phenix/./src/sdk/discovery/EndPoint.ts","webpack://phenix/./src/sdk/discovery/DiscoveryService.ts","webpack://phenix/./src/sdk/discovery/Discovery.ts","webpack://phenix/./src/rtc/SdpParser.ts","webpack://phenix/./src/rtc/RtcConnectionMonitor.ts","webpack://phenix/./src/sdk/streaming/RealTimeStream.ts","webpack://phenix/./src/sdk/streaming/RealTimeStreamFactory.ts","webpack://phenix/./src/sdk/channels/Channel.ts","webpack://phenix/./src/sdk/channels/Channels.ts","webpack://phenix/./src/sdk/full/index.ts","webpack://phenix/./node_modules/regenerator-runtime/runtime.js","webpack://phenix/webpack/bootstrap","webpack://phenix/webpack/startup","webpack://phenix/webpack/runtime/compat get default export","webpack://phenix/webpack/runtime/define property getters","webpack://phenix/webpack/runtime/hasOwnProperty shorthand","webpack://phenix/webpack/runtime/make namespace object"],"names":["root","factory","exports","module","define","amd","self","arr","len","length","i","arr2","Array","isArray","arrayLikeToArray","ReferenceError","asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","done","Promise","then","fn","this","args","arguments","apply","err","undefined","instance","Constructor","TypeError","_defineProperties","target","props","descriptor","enumerable","configurable","writable","Object","defineProperty","protoProps","staticProps","prototype","obj","_getPrototypeOf","o","setPrototypeOf","getPrototypeOf","__proto__","subClass","superClass","create","constructor","iter","Symbol","iterator","from","_arr","_n","_d","_e","_s","_i","next","push","_typeof","assertThisInitialized","call","_setPrototypeOf","p","arrayWithHoles","iterableToArrayLimit","unsupportedIterableToArray","nonIterableRest","arrayWithoutHoles","iterableToArray","nonIterableSpread","minLen","n","toString","slice","name","test","PromiseHandler","onFulfilled","onRejected","promise","callback","_state","_handled","_value","_deferreds","doResolve","promiseResolve","reason","promiseReject","newValue","finale","e","_immediate","_unhandledRejection","handle","deferred","result","remaining","manageResponse","_","setTimeout","console","warn","LoggingLevel","Logger","category","appenders","threshold","_category","_appenders","_threshold","Trace","log","Debug","Info","Warn","Error","Fatal","level","date","Date","message","replacePlaceholders","forEach","appender","replacePlaceholdersString","index","indexOf","substring","replaceArgument","splice","stringify","reduce","accumulator","currentValue","array","stack","cache","JSON","includes","argument","data","toStringStr","Appenders","items","item","PrivacyMode","_isPrivate","__PRIVACY_MODE__","applyIsPrivate","LoggerDefaults","isPrivate","Off","All","LoggingThreshold","defaultLoggingLevel","ConsoleAppender","logLevel","fullMessage","toISOString","VersionManager","__SDKVERSION__","_defaultVersion","TelemetryLevel","TelemetryService","telemetryConfiguration","location","hostname","_telemetryConfiguration","timestamp","logRecord","tenancy","sessionId","version","sdkVersion","environment","fullQualifiedName","_domain","_logs","unshift","sendLogsIfAble","logMessages","formData","FormData","append","records","fetch","url","method","body","_isSending","numberOfLogsToSend","sizeOfLogsToSend","getLogSize","values","sum","sendLogs","response","catch","TelemetryAppender","_tenancy","_sessionId","_telemetryService","TelemetryConfiguration","defaultTelemetryLoggingLevel","_url","telemetryUrl","URL","pathname","_environment","TelemetryDefault","Essential","MetricsConfiguration","defaultTelemetryLevel","metricsUrl","x","TelemetryLevelMapping","telemetryLevel","assertUnreachable","telemetryLevelType","LoggingLevelMapping","loggingLevel","loggingLevelType","PlainConfigurationParameterReader","defaultStringValue","defaultBooleanValue","convertTelemetryLevelToTelemetryLevelType","convertLoggingLevelToLoggingLevelType","defaultConsoleLoggingLevel","LoggerFactory","_loggers","applyLoggingLevel","applyAppenderLoggingLevel","applyConsoleLogger","bind","applyTelemetryLogger","parameterValue","_configurationParameterReader","getStringValue","setThreshold","applyAppender","add","ConfigurationParameterReader","applyLoggerConfigFromParameterConfiguration","Strings","loops","Math","ceil","fill","random","string","func","Disposable","disposable","_disposed","_disposable","DisposableListener","listeners","listener","idx","Subject","_listeners","changed","comparable","equals","ReadOnlySubject","subject","_subject","subscribe","BrowserDetector","navigator","userAgent","browserNameAndVersion","match","_browserNameAndVersionRegex","parseBrowserNameAndVersionForIE","_browserNameAndVersion","browserNameList","split","browserVersionList","fullVersion","Number","msie","parseInt","_browserName","_browserMajorVersion","_isChrome69","_isChrome70","_isChrome71","_isChrome72","_isChrome74","_isChrome75","_isChrome76","_isChrome77","parseBrowserNameAndVersion","parseBrowserName","parseBrowserMajorVersion","FeatureEnablement","isChrome74","isChrome75","isChrome76","isChrome77","isChrome69","isChrome70","isChrome71","isChrome72","browserName","browserMajorVersion","configuration","getLogger","webkitRTCPeerConnectionEnabled","_peerConnection","webkitRTCPeerConnection","RTCPeerConnection","options","promiseBasedPCMethodsDisabled","createOffer","createAnswer","description","setLocalDescription","RTCSessionDescription","sdp","_logger","setRemoteDescription","selector","getStats","type","addEventListener","removeEventListener","addTransceiver","getConfiguration","setConfiguration","close","currentLocalDescription","currentRemoteDescription","iceConnectionState","addTranceiverDisabled","handler","ontrack","onicecandidate","oniceconnectionstatechange","VanillaPeerConnection","edgeAuthTokenPrefix","EdgeAuth","token","isValidToken","encodedEdgeAuthToken","atob","substr","edgeAuthToken","parse","parsedToken","uri","applicationId","startsWith","MetricsType","DisposableList","_list","dispose","ApplicationActivityMonitor","now","_isForeground","_readOnlyIsForeground","detectTabFocusChange","_timeOfLastTabFocusChange","_disposables","hidden","visibilityChange","document","msHidden","webkitHidden","handleVisibilityChange","isForeground","setFocusState","listenForDocumentFocus","_documentFocusInterval","window","setInterval","hasFocus","clearInterval","TelemetryUrl","baseURL","segments","protocol","endsWith","join","origin","Environment","DiscoveryUri","search","URLSearchParams","_discoveryUri","MetricType","metrics","_metrics","MetricsService","metricsConfiguration","_metricsConfiguration","metric","streamId","previousValue","runtime","resource","kind","metricType","getTelemetryLevel","metricRecord","getName","sendMetricsIfAble","metricsMessages","sendMetrics","MetricsFactory","metricsServices","_metricsServices","SDK","clientSessionId","getTelemetryUrl","getEnvironmentFromUrl","convertTelemetryLevelTypeToTelemetryLevel","metricsService","pageLoadTime","telemetryAppender","find","remove","_metricsService","getMetricsService","_telemetryLevel","_automaticallyRetryOnFailure","getBooleanValue","_automaticallyReconnectPeerConnection","discoveryUri","channelToken","parseToken","getTenancy","getUri","uriValue","baseURIValue","_initialized","_applicationActivityMonitor","peerConnectionFactory","_peerConnectionFactory","convertLoggingLevelTypeToLoggingLevel","consoleLoggingLevel","consoleAppender","automaticallyPlayMediaStream","_automaticallyPlayMediaStream","automaticallyMuteVideoOnPlayFailure","_automaticallyMuteVideoOnPlayFailure","webPlayerLoader","_webPlayerLoader","shakaPlayerLoader","_shakaPlayerLoader","hlsJsLoader","_hlsJsLoader","_sendLocalCandidates","_clientSessionId","_loadedTimestamp","_readOnlyInitialized","_readOnlyDiscoveryUri","_readOnlyPeerConnectionFactory","_telemetryUrl","_maximalNumberOfPeerConnectionReconnectAttempts","retriesAmount","VanillaPeerConnectionFactory","applyDiscoveryUriDefaultFromParameterConfiguration","applyMetricsConfiguration","applyTelemetryConfiguration","applyAutomaticallyRetryOnFailureFromParameterConfiguration","applyAutomaticallyReconnectPeerConnectionFromParameterConfiguration","init","ChannelState","Dimension","width","height","other","BitrateState","BitrateMode","Durations","duration","_duration","isNegative","abs","offset","floor","milliseconds","seconds","minutes","hours","parts","String","padStart","targetLength","padString","repeat","VideoTelemetry","channelStartTime","_streamId","_pageLoadTime","_channelStartTime","video","_startRecordingFirstFrame","_listenToFirstTime","callTimeToFirstFrame","_clearTimeToFirstFrameListener","_listenForStall","onStall","_listenForContinuation","event","onContinuation","_clearRebufferingListener","pushTimeToFirstFrame","pushChannelCreationTimeToFirstFrame","_timeToFirstFrame","uint64","durationSincePageLoad","toIsoString","_channelCreationTimeToFirstFrame","_videoStalled","buffered","bufferLength","hasNotProgressedSinceLastProgressEvent","end","_lastProgress","timeSinceStop","newResolution","_videoResolution","StreamSetupListener","_startTime","recordStreamMetric","_metricSubmitted","setupTime","metricName","NetworkMonitor","isSupported","setupNetworkChangeListeners","updateStatistics","downlink","downlinkMax","effectiveType","rtt","_rtt","getRoundTripTime","_effectiveType","getEffectiveType","_downlinkThroughputCapacity","getDownlinkThroughputCapacity","_isSupported","SessionTelemetry","applicationActivityMonitor","_networkMonitor","recordForegroundChange","recordNetworkRTTUpdate","recordNetworkTypeChangeUpdate","downlinkThroughputCapacity","recordNetworkDownlinkThroughputCapacityUpdate","timeSinceLastChange","getTimeSinceLastChange","newRTT","oldRtt","_lastNetworkStatistics","newNetworkType","oldNetworkType","newCapacity","oldCapacity","float","ChannelContext","targetLag","isDisposed","isStarting","disposables","channelDisposables","rendererDisposables","channelInitialization","videoElement","peerConnection","mediaStream","state","autoMuted","autoPaused","tokenExpiring","authorized","online","loading","playing","standby","stopped","lag","bitrateLimit","resolution","empty","failureCount","endPoint","stream","rtcStatistics","peerConnectionReconnectAttempts","status","dataset","PeerConnectionService","isPrecachingEnabled","precacheCreatePeerConnectionOffer","_cached","createPeerConnectionOffer","createPeerConnection","supportsAddTransceiver","audioTransceiver","direction","videoTransceiver","offerToReceiveAudio","offerToReceiveVideo","localOffer","initiateInitialPrecaching","BitrateModeMapping","bitrateMode","Normal","Force","Reset","BitrateStateMapping","bitrateState","Keep","EndPoint","timeout","_uri","_timeout","buildPingUrl","start","race","finished","ok","_roundTripTime","localSessionDescription","buildUrl","clientVersion","bodyWithOffer","apiVersion","sessionDescription","convertRTCSdpTypeToSdpType","createAnswerDescription","bodyWithoutOffer","createOfferDescription","finally","clearTimeout","httpResponse","mapHttpStatusToSubscribeStatus","convertHttpResponseToSubscribeResponse","subscribeResponse","debug","sharedSecret","mapHttpStatusToSetRemoteDescriptionStatus","convertHttpResponseToSetRemoteDescriptionResponse","setRemoteDescriptionResponse","elapsedInMilliseconds","bitrateInBitsPerSecond","convertBitrateStateToBitrateStateType","convertBitrateModeToBitrateModeType","mapHttpStatusToSetTemporaryMaximalBitrateStatus","candidates","discoveryCompleted","mapHttpStatusToAddIceCandidatesStatus","convertHttpResponseToAddIceCandidatesResponse","addIceCandidatesResponse","mapHttpStatusToSetDestroyStreamStatus","convertHttpResponseToDestroyStreamResponse","destroyStreamResponse","path","pathAsArray","concat","json","rtcConfiguration","bundlePolicy","iceCandidatePoolSize","iceServers","urls","username","credential","iceTransportPolicy","peerIdentity","rtcpMuxPolicy","convertISessionDescriptionToRTCSessionDescription","createAnswerDescriptionResponse","createOfferDescriptionResponse","rtcSessionDescription","destroyStream","DiscoveryService","text","asString","endPoints","map","buildDiscoveryUrl","discoverNearbyEndPoints","neverResolve","ping","time","Discovery","discoverClosestEndPointWithCaching","_cache","discoveryService","cachedValue","discoverClosestEndPoint","precacheClosestEndPointDiscovery","SdpParser","_sdp","_audioCodec","applyCodec","_videoCodec","splitSdp","RtcConnectionMonitor","estimatedRoundTripTime","_estimatedRoundTripTime","_tracksToMonitor","getTracks","track","getCurrentOfferDisabled","parsedSDP","_estimatedAudioCodec","audioCodec","_estimatedVideoCodec","videoCodec","updateStatistic","_isMonitorRunning","_updateTimeOut","getStatsPromiseBasedDisabled","updateStatisticLegacy","getKindForSafari11","id","stats","rtcStats","lastPacketReceivedTimestamp","roundTripTime","report","currentRoundTripTime","mediaType","codec","codecId","mimeType","ssrc","bytesReceived","packetsLost","packetsReceived","getCodecByType","_rtcStatistic","framesDecoded","getStatsLegacy","names","stat","RealTimeStream","channelContext","handleStreamFailure","_channelContext","_handleStreamFailure","listenOnStreamSetup","playMediaStreamInVideoElement","all","clientOfferDisabled","supportsSetConfiguration","supportsGetConfiguration","applySessionAndStreamPropertiesToVideoElement","mapSubscribeStatusToChannelStatus","applyStatus","applyRtcConfiguration","submitCandidatesTimeout","cancelDiscovery","sendLocalCandidates","candidate","addIceCandidates","retryCallback","pause","srcObject","onLine","reconnectPeerConnection","mediaStreamPromise","onTrackDisabled","trackListener","timeoutId","streams","answer","mapSetRemoteDescriptionStatusToChannelStatus","success","rtcConnectionMonitor","rtcStatistic","statistics","rtcVideoStatistic","rtcAudioStatistic","audio","audioTrackFailed","videoTrackFailed","optionalPeerConnection","truncateIceServers","newRtcConfiguration","maximalNumberOfPeerConnectionReconnectAttempts","automaticallyReconnectPeerConnection","iceRestart","offer","RealTimeStreamFactory","capabilities","defaultStreamTerminationReason","Channel","_context","_readOnlyVideoElement","_readOnlyToken","_readOnlyPeerConnection","_readOnlyState","_readOnlyAutoMuted","_readOnlyAutoPaused","_readOnlyTokenExpiring","_readOnlyAuthorized","_readOnlyOnline","_readOnlyLoading","_readOnlyPlaying","_readOnlyStandby","_readOnlyStopped","_readOnlyTargetLag","_readOnlyLag","_readOnlyBitrateLimit","_readOnlyResolution","_readOnlyFailureCount","_readOnlyEndPoint","_readOnlyStream","_readOnlyRtcStatistics","_readOnlyMediaStream","sessionTelemetry","_videoMetaDataChangedHandler","handleVideoMetaDataChanged","videoTelemetry","setupListenerForTimeToFirstTime","setupListenerForRebuffering","restartAfterStop","clearFailureCountTimeout","onVideoResolutionChanges","getTime","limitBitrate","videoWidth","videoHeight","processStop","cleanUpResources","muted","stop","processStart","handleStreamFailureCallback","streamPlayer","StreamFactory","fail","automaticRetryOnFailure","getRetryInterval","min","pow","max","playPromise","play","hasAudioTrack","filter","automaticallyMuteVideoOnPlayFailureOff","Channels","initialized","Op","hasOwn","hasOwnProperty","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","wrap","innerFn","outerFn","tryLocsList","protoGenerator","Generator","generator","context","Context","_invoke","GenStateSuspendedStart","GenStateExecuting","GenStateCompleted","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","record","tryCatch","GenStateSuspendedYield","makeInvokeMethod","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","invoke","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","resultName","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","reset","iterable","iteratorMethod","isNaN","displayName","isGeneratorFunction","genFun","ctor","mark","awrap","async","keys","object","reverse","pop","skipTempReset","prev","charAt","rootRecord","rval","exception","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","Function","__webpack_module_cache__","__webpack_require__","moduleId","__webpack_modules__","getter","__esModule","d","a","definition","get","prop","r"],"mappings":"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","file":"full.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"phenix\"] = factory();\n\telse\n\t\troot[\"phenix\"] = factory();\n})(self, function() {\nreturn ","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n\nmodule.exports = _arrayLikeToArray;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles;","var arrayLikeToArray = require(\"./arrayLikeToArray\");\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}\n\nmodule.exports = _arrayWithoutHoles;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nmodule.exports = _assertThisInitialized;","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nfunction _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}\n\nmodule.exports = _asyncToGenerator;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\n\nmodule.exports = _createClass;","function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nmodule.exports = _defineProperty;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf;","var setPrototypeOf = require(\"./setPrototypeOf\");\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inherits;","function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter);\n}\n\nmodule.exports = _iterableToArray;","function _iterableToArrayLimit(arr, i) {\n if (typeof Symbol === \"undefined\" || !(Symbol.iterator in Object(arr))) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n\nmodule.exports = _iterableToArrayLimit;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableRest;","function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableSpread;","var _typeof = require(\"@babel/runtime/helpers/typeof\");\n\nvar assertThisInitialized = require(\"./assertThisInitialized\");\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n }\n\n return assertThisInitialized(self);\n}\n\nmodule.exports = _possibleConstructorReturn;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf;","var arrayWithHoles = require(\"./arrayWithHoles\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray\");\n\nvar nonIterableRest = require(\"./nonIterableRest\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray;","var arrayWithoutHoles = require(\"./arrayWithoutHoles\");\n\nvar iterableToArray = require(\"./iterableToArray\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread\");\n\nfunction _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n module.exports = _typeof = function _typeof(obj) {\n return typeof obj;\n };\n } else {\n module.exports = _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n}\n\nmodule.exports = _typeof;","var arrayLikeToArray = require(\"./arrayLikeToArray\");\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\n\nmodule.exports = _unsupportedIterableToArray;","module.exports = require(\"regenerator-runtime\");\n","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport Promise from './Promise';\n\nexport default class PromiseHandler {\n onFulfilled: Function;\n onRejected: Function;\n promise: Promise;\n\n constructor(onFulfilled, onRejected, promise) {\n this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;\n this.onRejected = typeof onRejected === 'function' ? onRejected : null;\n this.promise = promise;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport PromiseHandler from './PromiseHandler';\n\nclass Promise {\n _state: number;\n _handled: boolean;\n _value: Promise;\n _deferreds: Array<PromiseHandler>;\n /* eslint-disable */\n // @ts-ignore\n then(onFulfilled: Function, onRejected: Function): Promise | void;\n /* eslint-enable*/\n\n constructor(callback) {\n if (!(this instanceof Promise)) {\n throw new TypeError('Promises must be constructed via new');\n }\n\n if (typeof callback !== 'function') {\n throw new TypeError('not a function');\n }\n\n this._state = 0;\n this._handled = false;\n this._value = undefined;\n this._deferreds = [];\n\n this.doResolve(callback);\n }\n\n doResolve(callback: Function): void {\n let done = false;\n\n try {\n callback(\n value => {\n if (done) {\n return;\n }\n\n done = true;\n this.promiseResolve(value);\n },\n reason => {\n if (done) {\n return;\n }\n\n done = true;\n this.promiseReject(reason);\n }\n );\n } catch (error) {\n if (done) {\n return;\n }\n\n done = true;\n this.promiseReject(error);\n }\n }\n\n promiseResolve(newValue: Promise | undefined): void {\n const promise = this as Promise;\n\n try {\n // Promise Resolution Procedure: https://github.com/Promises-aplus/Promises-spec#the-Promise-resolution-procedure\n if (newValue === promise) {\n throw new TypeError('A Promise cannot be resolved with it self.');\n }\n\n if (newValue && (typeof newValue === 'object' || typeof newValue === 'function')) {\n const then = newValue.then;\n\n if (newValue instanceof Promise) {\n promise._state = 3;\n promise._value = newValue;\n promise.finale();\n\n return;\n } else if (typeof then === 'function') {\n promise.doResolve(function(): void {\n // eslint-disable-next-line prefer-rest-params\n then.apply(newValue, arguments);\n });\n\n return;\n }\n }\n\n promise._state = 1;\n promise._value = newValue;\n promise.finale();\n } catch (e) {\n promise.promiseReject(e);\n }\n }\n\n promiseReject(newValue: Promise | undefined): void{\n this._state = 2;\n this._value = newValue;\n this.finale();\n }\n\n finale(): void {\n if (this._state === 2 && this._deferreds.length === 0) {\n Promise._immediate(() => {\n if (!this._handled) {\n Promise._unhandledRejection(this._value);\n }\n });\n }\n\n for (let i = 0, len = this._deferreds.length; i < len; i++) {\n this.handle(this._deferreds[i]);\n }\n\n this._deferreds = null;\n }\n\n handle(deferred: PromiseHandler): void {\n let promise = this as Promise;\n\n while (promise._state === 3) {\n promise = promise._value;\n }\n\n if (promise._state === 0) {\n promise._deferreds.push(deferred);\n\n return;\n }\n\n promise._handled = true;\n Promise._immediate(() => {\n const callback = promise._state === 1 ? deferred.onFulfilled : deferred.onRejected;\n\n if (callback === null) {\n if (promise._state === 1) {\n deferred.promise.promiseResolve(promise._value);\n } else {\n deferred.promise.promiseReject(promise._value);\n }\n\n return;\n }\n\n let result;\n\n try {\n result = callback(promise._value);\n } catch (e) {\n deferred.promise.promiseReject(e);\n\n return;\n }\n\n deferred.promise.promiseResolve(result);\n });\n }\n\n static all(arr: Array<Promise>): Promise {\n return new Promise((resolve, reject) => {\n if (!Array.isArray(arr)) {\n return reject(new TypeError('Promise.all accepts an array'));\n }\n\n const args = Array.prototype.slice.call(arr);\n\n if (args.length === 0) {\n return resolve([]);\n }\n\n let remaining = args.length;\n const manageResponse = (i, value): void => {\n try {\n if (value && (typeof value === 'object' || typeof value === 'function')) {\n const then = value.then;\n\n if (typeof then === 'function') {\n then.call(\n value,\n value => manageResponse(i, value),\n reject\n );\n\n return;\n }\n }\n\n args[i] = value;\n\n if (--remaining === 0) {\n resolve(args);\n }\n } catch (error) {\n reject(error);\n }\n };\n\n for (let i = 0; i < args.length; i++) {\n manageResponse(i, args[i]);\n }\n });\n }\n\n static resolve(value): Promise {\n if (value && typeof value === 'object' && value.constructor === Promise) {\n return value;\n }\n\n return new Promise(resolve => resolve(value));\n }\n\n static reject(value): Promise {\n return new Promise((_, reject) => reject(value));\n }\n\n static race(arr: Array<Promise>): Promise {\n return new Promise((resolve, reject) => {\n if (!Array.isArray(arr)) {\n return reject(new TypeError('Promise.race accepts an array'));\n }\n\n for (let i = 0, len = arr.length; i < len; i++) {\n Promise.resolve(arr[i]).then(resolve, reject);\n }\n });\n }\n\n static _immediate(callback: Function): void {\n const ignored = setTimeout(callback, 0);\n }\n\n static _unhandledRejection(error): void {\n if (typeof console !== 'undefined' && console) {\n console.warn('Possible Unhandled Promise Rejection:', error); // eslint-disable-line no-console\n }\n }\n}\n\nPromise.prototype['catch'] = function(onRejected: Function): Promise | void {\n return this.then(null, onRejected);\n};\n\nPromise.prototype['then'] = function(onFulfilled: Function, onRejected: Function): Promise | void {\n const promise = new this.constructor(() => null);\n\n this.handle(new PromiseHandler(onFulfilled, onRejected, promise));\n\n return promise;\n};\n\nPromise.prototype['finally'] = function(callback: Function): Promise | void {\n const constructor = this.constructor;\n\n return this.then(\n value => constructor.resolve(callback()).then(() => value),\n reason => constructor.resolve(callback()).then(() => constructor.reject(reason))\n );\n};\n\nexport default Promise;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {IAppender} from './IAppender';\nimport Appenders from './Appenders';\nimport LoggingThreshold from './LoggingThreshold';\n\nexport enum LoggingLevel {\n All = -1,\n Trace = 10,\n Debug = 20,\n Info = 30,\n Warn = 40,\n Error = 50,\n Fatal = 60,\n Off = 100,\n}\n\nexport type LoggingLevelInputTypes = 'Off' | 'Trace' | 'Debug' | 'Info' | 'Warn' | 'Error' | 'Fatal' | 'All';\n\nexport default class Logger {\n private readonly _category: string;\n private readonly _appenders: Appenders;\n private readonly _threshold: LoggingThreshold;\n\n get category(): string {\n return this._category;\n }\n\n get appenders(): Appenders {\n return this._appenders;\n }\n\n get threshold(): LoggingThreshold {\n return this._threshold;\n }\n\n trace(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Trace) {\n return;\n }\n\n this.log(LoggingLevel.Trace, args);\n }\n\n debug(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Debug) {\n return;\n }\n\n this.log(LoggingLevel.Debug, args);\n }\n\n info(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Info) {\n return;\n }\n\n this.log(LoggingLevel.Info, args);\n }\n\n warn(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Warn) {\n return;\n }\n\n this.log(LoggingLevel.Warn, args);\n }\n\n error(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Error) {\n return;\n }\n\n this.log(LoggingLevel.Error, args);\n }\n\n fatal(...args: any): void {\n if (!this._threshold.value || this._threshold.value > LoggingLevel.Fatal) {\n return;\n }\n\n this.log(LoggingLevel.Fatal, args);\n }\n\n private log(level: number, args: any): void {\n const date = new Date();\n const message = this.replacePlaceholders(args);\n\n this._appenders.value.forEach((appender: IAppender) => {\n appender.log(level, message, this.category, date);\n });\n }\n\n private replacePlaceholders(args: any): string {\n let replacePlaceholdersString = args[0];\n let index = 0;\n\n while (replacePlaceholdersString.indexOf && args.length > 1 && index >= 0) {\n index = replacePlaceholdersString.indexOf('%', index);\n\n if (index > 0) {\n const type = replacePlaceholdersString.substring(index + 1, index + 2);\n\n switch (type) {\n case '%':\n // Escaped '%%' turns into '%'\n replacePlaceholdersString = replacePlaceholdersString.substring(0, index) + replacePlaceholdersString.substring(index + 1);\n index++;\n\n break;\n case 's':\n case 'd':\n // Replace '%d' or '%s' with the argument\n args[0] = replacePlaceholdersString = this.replaceArgument(\n this.toString(args[1]),\n replacePlaceholdersString,\n index\n );\n args.splice(1, 1);\n\n break;\n case 'j':\n // Replace %j' with the argument\n args[0] = replacePlaceholdersString = this.replaceArgument(\n this.stringify(args[1]),\n replacePlaceholdersString,\n index\n );\n\n args.splice(1, 1);\n\n break;\n default:\n return args.toString();\n }\n }\n }\n\n if (args.length > 1) {\n args = args.reduce((accumulator, currentValue, index, array) => {\n if (index + 1 === array.length && currentValue instanceof Error) {\n return accumulator + '\\n' + this.toString(currentValue.stack);\n }\n\n return accumulator + `[${this.toString(currentValue)}]`;\n });\n }\n\n return args.toString();\n }\n\n private stringify(arg: any): string {\n const cache = [];\n\n try {\n return JSON.stringify(\n arg instanceof Error ? this.toString(arg) : arg,\n (key, value) => {\n if (!!value && value instanceof Object) {\n if (cache.includes(value)) {\n return '<recursive>';\n }\n\n cache.push(value);\n }\n\n return value;\n },\n 2\n );\n } catch (e) {\n return '[object invalid JSON.stringify]';\n }\n }\n\n private replaceArgument(argument: any, replacePlaceholdersString: string, index: number): string {\n return replacePlaceholdersString.substring(0, index) + this.toString(argument) + replacePlaceholdersString.substring(index + 2);\n }\n\n private toString(data: any): string {\n if (typeof data === 'string') {\n return data;\n }\n\n if (typeof data === 'boolean') {\n return data ? 'true' : 'false';\n }\n\n if (typeof data === 'number') {\n return data.toString();\n }\n\n let toStringStr = '';\n\n if (data) {\n if (typeof data === 'function') {\n toStringStr = data.toString();\n } else if (data instanceof Object) {\n try {\n toStringStr = data.toString();\n } catch (e) {\n toStringStr = '[object invalid toString()]';\n }\n }\n }\n\n return toStringStr;\n }\n\n constructor(category: string, appenders: Appenders, threshold: LoggingThreshold) {\n this._category = category;\n this._appenders = appenders;\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {IAppender} from './IAppender';\n\nexport default class Appenders {\n private _appenders: Array<IAppender> = [];\n\n get value(): Array<IAppender> {\n return this._appenders;\n }\n\n add(appender: IAppender): void {\n this._appenders.push(appender);\n }\n\n remove(appender): void {\n this._appenders = this._appenders.reduce((items, item) => {\n if (!(item === appender)) {\n items.push(item);\n }\n\n return items;\n }, [] as Array<IAppender>);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\ndeclare const __PRIVACY_MODE__: boolean;\n\nexport default class PrivacyMode {\n private static _isPrivate: boolean;\n\n static get isPrivate(): boolean {\n return this._isPrivate;\n }\n\n static applyIsPrivate(): void {\n try {\n this._isPrivate = __PRIVACY_MODE__;\n } catch (e) {\n this._isPrivate = false;\n }\n }\n}\n\nPrivacyMode.applyIsPrivate();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport PrivacyMode from '../dom/PrivacyMode';\nimport {LoggingLevel} from '../logger/Logger';\n\nexport default class LoggerDefaults {\n static get defaultLoggingLevel(): LoggingLevel {\n return PrivacyMode.isPrivate ? LoggingLevel.Off : LoggingLevel.All;\n }\n\n static get defaultConsoleLoggingLevel(): LoggingLevel {\n return PrivacyMode.isPrivate ? LoggingLevel.Off : LoggingLevel.All;\n }\n\n static get defaultTelemetryLoggingLevel(): LoggingLevel {\n return LoggingLevel.Info;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerDefaults from './LoggerDefaults';\nimport {LoggingLevel} from './Logger';\n\nexport default class LoggingThreshold {\n private _threshold: LoggingLevel = LoggerDefaults.defaultLoggingLevel;\n\n get value(): LoggingLevel {\n return this._threshold;\n }\n\n setThreshold(threshold: LoggingLevel): void {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {IAppender} from './IAppender';\nimport {LoggingLevel} from './Logger';\n\nexport default class ConsoleAppender implements IAppender {\n private readonly _threshold: LoggingLevel;\n\n log(logLevel: LoggingLevel, message: string, category: string, date: Date): void {\n if (logLevel < this._threshold) {\n return;\n }\n\n const fullMessage = `${date.toISOString()} [${category}] [${LoggingLevel[logLevel]}] ${message}`;\n\n if (logLevel < LoggingLevel.Warn) {\n console.log(fullMessage);\n\n return;\n }\n\n console.error(fullMessage);\n }\n\n constructor(threshold: LoggingLevel) {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\ndeclare const __SDKVERSION__: string;\n\nexport default class VersionManager {\n private static _defaultVersion = new Date().toISOString();\n\n static get sdkVersion(): string {\n try {\n return __SDKVERSION__;\n } catch (e) {\n return this._defaultVersion;\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {LoggingLevel} from '../logger/Logger';\nimport VersionManager from '../sdk/version/VersionManager';\nimport TelemetryConfiguration from './TelemetryConfiguration';\n\nconst requestSizeLimit = 8192;\n\ninterface ILogItem {\n timestamp: string;\n tenancy: string;\n level: string;\n category: string;\n message: string;\n sessionId: string;\n version: string;\n environment: string;\n fullQualifiedName: string;\n}\n\nexport default class TelemetryService {\n private readonly _telemetryConfiguration: TelemetryConfiguration;\n\n private _logs: Array<ILogItem> = [];\n private _isSending: boolean;\n private _domain = location.hostname;\n\n constructor(telemetryConfiguration: TelemetryConfiguration) {\n this._telemetryConfiguration = telemetryConfiguration;\n }\n\n push(logLevel: LoggingLevel, message: string, category: string, timestamp: Date): void {\n const logRecord = {\n timestamp: timestamp.toISOString(),\n tenancy: this._telemetryConfiguration.tenancy,\n level: LoggingLevel[logLevel],\n category,\n message,\n sessionId: this._telemetryConfiguration.sessionId,\n version: VersionManager.sdkVersion,\n environment: this._telemetryConfiguration.environment,\n fullQualifiedName: this._domain\n };\n\n if (logLevel < LoggingLevel.Error) {\n this._logs.push(logRecord);\n } else {\n this._logs.unshift(logRecord);\n }\n\n const ignored = this.sendLogsIfAble();\n }\n\n private async sendLogs(logMessages: Array<ILogItem>): Promise<Response | void> {\n const formData = new FormData();\n\n formData.append('jsonBody', JSON.stringify({records: logMessages}));\n\n return await fetch(this._telemetryConfiguration.url, {\n method: 'POST',\n body: formData\n });\n }\n\n private async sendLogsIfAble(): Promise<Response | void> {\n if (this._logs.length <= 0 || this._isSending) {\n return;\n }\n\n let numberOfLogsToSend = 0;\n let sizeOfLogsToSend = 0;\n\n this._isSending = true;\n\n const getLogSize = (log: ILogItem): number => Object.values(log)\n .reduce((sum, item) => sum + (item ? item.length : 0), 0);\n\n while (this._logs.length > numberOfLogsToSend && getLogSize(this._logs[numberOfLogsToSend]) + sizeOfLogsToSend < requestSizeLimit) {\n sizeOfLogsToSend += getLogSize(this._logs[numberOfLogsToSend]);\n numberOfLogsToSend++;\n }\n\n if (!numberOfLogsToSend) {\n this._logs[numberOfLogsToSend].message = this._logs[numberOfLogsToSend].message.substring(0,\n getLogSize(this._logs[numberOfLogsToSend]) + (requestSizeLimit - getLogSize(this._logs[numberOfLogsToSend])));\n numberOfLogsToSend = 1;\n }\n\n const logMessages = this._logs.slice(0, numberOfLogsToSend);\n\n this._logs = this._logs.slice(numberOfLogsToSend);\n\n return this.sendLogs(logMessages).then(response => {\n this._isSending = false;\n\n const ignored = this.sendLogsIfAble();\n\n return response;\n }).catch(() => {\n this._isSending = false;\n\n const ignored = this.sendLogsIfAble();\n });\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport TelemetryDefault from './TelemetryDefault';\n\nexport enum TelemetryLevel {\n Off = 100,\n Essential = 10,\n All = -1\n}\n\nexport type TelemetryLevelType = 'Off' | 'Essential' | 'All';\n\nexport default class MetricsConfiguration {\n private _url = 'https://telemetry.phenixrts.com/telemetry/metrics';\n private _tenancy: string;\n private _sessionId: string;\n private _environment: string;\n private _threshold: TelemetryLevel = TelemetryDefault.defaultTelemetryLevel;\n\n get url(): string {\n return this._url;\n }\n\n set url(url: string) {\n const metricsUrl = new URL(url);\n\n metricsUrl.pathname = metricsUrl.pathname + '/metrics';\n\n this._url = metricsUrl.toString();\n }\n\n get environment(): string {\n return this._environment;\n }\n\n set environment(environment: string) {\n this._environment = environment;\n }\n\n get tenancy(): string {\n return this._tenancy;\n }\n\n set tenancy(tenancy: string) {\n this._tenancy = tenancy;\n }\n\n get sessionId(): string {\n return this._sessionId;\n }\n\n set sessionId(sessionId: string) {\n this._sessionId = sessionId;\n }\n\n get threshold(): TelemetryLevel {\n return this._threshold;\n }\n\n set threshold(threshold: TelemetryLevel) {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport TelemetryService from './TelemetryService';\nimport TelemetryConfiguration from './TelemetryConfiguration';\nimport {IAppender} from '../logger/IAppender';\nimport {LoggingLevel} from '../logger/Logger';\n\nexport default class TelemetryAppender implements IAppender {\n private readonly _telemetryService: TelemetryService;\n private readonly _tenancy: string;\n private readonly _sessionId: string;\n private readonly _threshold: LoggingLevel;\n\n constructor(telemetryConfiguration: TelemetryConfiguration) {\n this._tenancy = telemetryConfiguration.tenancy;\n this._sessionId = telemetryConfiguration.sessionId;\n this._threshold = telemetryConfiguration.threshold;\n this._telemetryService = new TelemetryService(telemetryConfiguration);\n }\n\n log(logLevel: LoggingLevel, message: string, category: string, date: Date): void {\n if (logLevel < this._threshold) {\n return;\n }\n\n this._telemetryService.push(logLevel, message, category, date);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {LoggingLevel} from '../logger/Logger';\nimport LoggerDefaults from '../logger/LoggerDefaults';\n\nexport default class TelemetryConfiguration {\n private _url = 'https://telemetry.phenixrts.com/telemetry/logs';\n private _tenancy: string;\n private _sessionId: string;\n private _environment: string;\n private _threshold = LoggerDefaults.defaultTelemetryLoggingLevel;\n\n get url(): string {\n return this._url;\n }\n\n set url(url: string) {\n const telemetryUrl = new URL(url);\n\n telemetryUrl.pathname = telemetryUrl.pathname + '/logs';\n\n this._url = telemetryUrl.toString();\n }\n\n get environment(): string {\n return this._environment;\n }\n\n set environment(environment: string) {\n this._environment = environment;\n }\n\n get tenancy(): string {\n return this._tenancy;\n }\n\n set tenancy(tenancy: string) {\n this._tenancy = tenancy;\n }\n\n get sessionId(): string {\n return this._sessionId;\n }\n\n set sessionId(sessionId: string) {\n this._sessionId = sessionId;\n }\n\n get threshold(): LoggingLevel {\n return this._threshold;\n }\n\n set threshold(threshold: LoggingLevel) {\n this._threshold = threshold;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport PrivacyMode from '../dom/PrivacyMode';\nimport {TelemetryLevel} from '../metrics/MetricsConfiguration';\n\nexport default class TelemetryDefault {\n static get defaultTelemetryLevel(): TelemetryLevel {\n return PrivacyMode.isPrivate ? TelemetryLevel.Essential : TelemetryLevel.All;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nexport function assertUnreachable(x: never): never {\n throw new Error(`Unexpected value [${x}]. This should never be reached`);\n}\n\nexport default assertUnreachable;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {TelemetryLevel, TelemetryLevelType} from './MetricsConfiguration';\nimport assertUnreachable from '../lang/assertUnreachable';\n\nexport default class TelemetryLevelMapping {\n static convertTelemetryLevelToTelemetryLevelType(telemetryLevel: TelemetryLevel): TelemetryLevelType {\n switch (telemetryLevel) {\n case TelemetryLevel.Off:\n return 'Off';\n case TelemetryLevel.Essential:\n return 'Essential';\n case TelemetryLevel.All:\n return 'All';\n default:\n assertUnreachable(telemetryLevel);\n }\n }\n\n static convertTelemetryLevelTypeToTelemetryLevel(telemetryLevelType: TelemetryLevelType): TelemetryLevel {\n switch (telemetryLevelType) {\n case 'Off':\n return TelemetryLevel.Off;\n case 'Essential':\n return TelemetryLevel.Essential;\n case 'All':\n return TelemetryLevel.All;\n default:\n assertUnreachable(telemetryLevelType);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport assertUnreachable from '../lang/assertUnreachable';\nimport {LoggingLevel, LoggingLevelInputTypes} from './Logger';\n\nexport default class LoggingLevelMapping {\n static convertLoggingLevelToLoggingLevelType(loggingLevel: LoggingLevel): LoggingLevelInputTypes {\n switch (loggingLevel) {\n case LoggingLevel.Off:\n return 'Off';\n case LoggingLevel.Trace:\n return 'Trace';\n case LoggingLevel.Debug:\n return 'Debug';\n case LoggingLevel.Info:\n return 'Trace';\n case LoggingLevel.Warn:\n return 'Warn';\n case LoggingLevel.Error:\n return 'Error';\n case LoggingLevel.Fatal:\n return 'Fatal';\n case LoggingLevel.All:\n return 'All';\n default:\n assertUnreachable(loggingLevel);\n }\n }\n\n static convertLoggingLevelTypeToLoggingLevel(loggingLevelType: LoggingLevelInputTypes): LoggingLevel {\n switch (loggingLevelType) {\n case 'Off':\n return LoggingLevel.Off;\n case 'Trace':\n return LoggingLevel.Trace;\n case 'Debug':\n return LoggingLevel.Debug;\n case 'Info':\n return LoggingLevel.Info;\n case 'Warn':\n return LoggingLevel.Warn;\n case 'Error':\n return LoggingLevel.Error;\n case 'Fatal':\n return LoggingLevel.Fatal;\n case 'All':\n return LoggingLevel.All;\n default:\n assertUnreachable(loggingLevelType);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport TelemetryLevelMapping from '../metrics/TelemetricLevelMapping';\nimport TelemetryDefault from '../metrics/TelemetryDefault';\nimport LoggingLevelMapping from '../logger/LoggingLevelMapping';\nimport LoggerDefaults from '../logger/LoggerDefaults';\n\n// This file is used only for the silent build to mock ConfigurationParameterReader class\nexport default class PlainConfigurationParameterReader {\n getStringValue(name: string): string {\n return this.defaultStringValue[name];\n }\n\n getBooleanValue(name: string): boolean {\n return this.defaultBooleanValue[name];\n }\n\n private get defaultStringValue(): { [name: string]: string } {\n return {\n 'phenix-metrics-level': TelemetryLevelMapping.convertTelemetryLevelToTelemetryLevelType(TelemetryDefault.defaultTelemetryLevel),\n 'phenix-logging-level': LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(LoggerDefaults.defaultLoggingLevel),\n 'phenix-console-logging-level': LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(LoggerDefaults.defaultConsoleLoggingLevel),\n 'phenix-telemetry-logging-level': LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(LoggerDefaults.defaultTelemetryLoggingLevel),\n 'phenix-channel-token': '',\n 'phenix-uri': '',\n 'phenix-base-uri': ''\n };\n }\n\n private get defaultBooleanValue(): { [name: string]: boolean } {\n return {\n 'phenix-automatically-retry-on-failure': true,\n 'phenix-automatically-reconnect-peer-connection': true\n };\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {ILogger} from './LoggerInterface';\nimport Logger, {LoggingLevel} from './Logger';\nimport Appenders from './Appenders';\nimport LoggingThreshold from './LoggingThreshold';\nimport ConsoleAppender from './ConsoleAppender';\nimport TelemetryAppender from '../telemetry/TelemetryApender';\nimport TelemetryConfiguration from '../telemetry/TelemetryConfiguration';\nimport ConfigurationParameterReader from '../dom/ConfigurationParameterReader';\nimport {IConfigurationParameterReader} from '../dom/IConfigurationParamaterReader';\nimport LoggerDefaults from './LoggerDefaults';\n\nexport default class LoggerFactory {\n private static _configurationParameterReader: IConfigurationParameterReader = new ConfigurationParameterReader();\n private static _loggers: {[category: string]: ILogger} = {};\n private static _appenders: Appenders = new Appenders();\n private static _threshold: LoggingThreshold = new LoggingThreshold();\n private static _telemetryConfiguration: TelemetryConfiguration = new TelemetryConfiguration();\n\n static get telemetryConfiguration(): TelemetryConfiguration {\n return LoggerFactory._telemetryConfiguration;\n }\n\n static getLogger(category: string): ILogger {\n if (typeof category !== 'string') {\n category = 'SDK';\n }\n\n const logger = LoggerFactory._loggers[category];\n\n if (logger) {\n return logger;\n }\n\n return LoggerFactory._loggers[category] = new Logger(category, this._appenders, this._threshold);\n }\n\n static applyLoggerConfigFromParameterConfiguration(): void {\n LoggerFactory.applyLoggingLevel();\n LoggerFactory.applyAppenderLoggingLevel('console', LoggerFactory.applyConsoleLogger.bind(this));\n LoggerFactory.applyAppenderLoggingLevel('telemetry', LoggerFactory.applyTelemetryLogger.bind(this));\n }\n\n private static applyLoggingLevel(): void {\n const parameterValue = this._configurationParameterReader.getStringValue('phenix-logging-level');\n\n if (LoggingLevel[parameterValue]) {\n this._threshold.setThreshold(LoggingLevel[parameterValue]);\n }\n\n return;\n }\n\n private static applyAppenderLoggingLevel(name: string, applyAppender: (level: LoggingLevel) => void): void {\n const parameterValue = this._configurationParameterReader.getStringValue(`phenix-${name}-logging-level`);\n\n if (parameterValue === 'Off') {\n return;\n }\n\n applyAppender(LoggingLevel[parameterValue]);\n }\n\n private static applyConsoleLogger(level: LoggingLevel): void {\n this._appenders.add(new ConsoleAppender(level || LoggerDefaults.defaultConsoleLoggingLevel));\n }\n\n private static applyTelemetryLogger(level: LoggingLevel): void {\n this._telemetryConfiguration.threshold = level || LoggerDefaults.defaultTelemetryLoggingLevel;\n\n this._appenders.add(new TelemetryAppender(this._telemetryConfiguration));\n }\n\n private constructor() {\n throw new Error('LoggerFactory is a static class that may not be instantiated');\n }\n}\n\nLoggerFactory.applyLoggerConfigFromParameterConfiguration();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nexport default class Strings {\n static random(length: number): string {\n const random13Characters = (): string => {\n return Math.random().toString(16).substring(2, 15);\n };\n\n const loops: number = Math.ceil(length / 13);\n\n return new Array(loops).fill(random13Characters).reduce((string, func) => {\n return string + func();\n }, '').substring(0, length);\n }\n\n private constructor() {\n throw new Error('Strings is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IDisposable from './IDisposable';\n\nexport default class Disposable implements IDisposable {\n private _disposed: boolean;\n private _disposable: () => void;\n\n constructor(disposable: () => void) {\n this._disposed = false;\n this._disposable = disposable;\n }\n\n dispose(): void {\n if (this._disposed) {\n return;\n }\n\n this._disposed = true;\n\n return this._disposable.call(this);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport IDisposable from '../lang/IDisposable';\nimport Disposable from '../lang/Disposable';\nimport IComparable from '../lang/IComparable';\n\nclass DisposableListener<T> extends Disposable {\n constructor(listeners: Array<T>, listener: T) {\n super(() => {\n const idx = listeners.indexOf(listener);\n\n if (idx >= 0) {\n listeners.splice(idx, 1);\n }\n });\n }\n}\n\nexport default class Subject<T> {\n private readonly _listeners: Array<(T) => void>;\n private _value: T;\n\n constructor(value: T) {\n this._listeners = [];\n this._value = value;\n }\n\n set value(value: T) {\n let changed = this._value !== value;\n\n if (changed && value) {\n const comparable = value as unknown as IComparable<T>;\n\n if (typeof comparable.equals === 'function') {\n changed = !comparable.equals(this._value);\n }\n }\n\n if (!changed) {\n return;\n }\n\n this._value = value;\n\n this._listeners.forEach(listener => {\n listener(value);\n });\n }\n\n get value(): T {\n return this._value;\n }\n\n subscribe(listener: (T) => void): IDisposable {\n this._listeners.push(listener);\n\n listener(this._value);\n\n return new DisposableListener<(T) => void>(this._listeners, listener);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport Subject from './Subject';\nimport IDisposable from '../lang/IDisposable';\n\nexport default class ReadOnlySubject<T> {\n private readonly _subject: Subject<T>;\n\n constructor(subject: Subject<T>) {\n this._subject = subject;\n }\n\n get value(): T {\n return this._subject.value;\n }\n\n subscribe(listener: (T) => void): IDisposable {\n return this._subject.subscribe(listener);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nexport default class BrowserDetector {\n private static readonly _browserNameAndVersionRegex = /(MSIE|(?!Gecko.+)Firefox|(?!AppleWebKit.+Chrome.+)Safari|(?!AppleWebKit.+)Chrome|AppleWebKit(?!.+Chrome|.+Safari)|Gecko(?!.+Firefox))(?: |\\/)([\\d.apre]+)/g;\n private static readonly _browserNameAndVersion = BrowserDetector.parseBrowserNameAndVersion();\n private static readonly _browserName = BrowserDetector.parseBrowserName();\n private static readonly _browserMajorVersion = BrowserDetector.parseBrowserMajorVersion();\n\n private static readonly _isChrome69 = BrowserDetector._browserNameAndVersion.includes('Chrome/69.');\n private static readonly _isChrome70 = BrowserDetector._browserNameAndVersion.includes('Chrome/70.');\n private static readonly _isChrome71 = BrowserDetector._browserNameAndVersion.includes('Chrome/71.');\n private static readonly _isChrome72 = BrowserDetector._browserNameAndVersion.includes('Chrome/72.');\n private static readonly _isChrome74 = BrowserDetector._browserNameAndVersion.includes('Chrome/74.');\n private static readonly _isChrome75 = BrowserDetector._browserNameAndVersion.includes('Chrome/75.');\n private static readonly _isChrome76 = BrowserDetector._browserNameAndVersion.includes('Chrome/76.');\n private static readonly _isChrome77 = BrowserDetector._browserNameAndVersion.includes('Chrome/77.');\n\n static get browserNameAndVersion(): string {\n return BrowserDetector._browserNameAndVersion;\n }\n\n static get browserName(): string {\n return this._browserName;\n }\n\n static get browserMajorVersion(): number {\n return this._browserMajorVersion;\n }\n\n static get isChrome69(): boolean {\n return BrowserDetector._isChrome69;\n }\n\n static get isChrome70(): boolean {\n return BrowserDetector._isChrome70;\n }\n\n static get isChrome71(): boolean {\n return BrowserDetector._isChrome71;\n }\n\n static get isChrome72(): boolean {\n return BrowserDetector._isChrome72;\n }\n\n static get isChrome74(): boolean {\n return BrowserDetector._isChrome74;\n }\n\n static get isChrome75(): boolean {\n return BrowserDetector._isChrome75;\n }\n\n static get isChrome76(): boolean {\n return BrowserDetector._isChrome76;\n }\n\n static get isChrome77(): boolean {\n return BrowserDetector._isChrome77;\n }\n\n private static parseBrowserNameAndVersion(): string {\n if (!navigator || !navigator.userAgent) {\n return '';\n }\n\n const browserNameAndVersion = navigator.userAgent.match(BrowserDetector._browserNameAndVersionRegex);\n\n if (browserNameAndVersion && browserNameAndVersion[0]) {\n return browserNameAndVersion[0];\n }\n\n return BrowserDetector.parseBrowserNameAndVersionForIE();\n }\n\n private static parseBrowserName(): string {\n if (!BrowserDetector._browserNameAndVersion) {\n return '';\n }\n\n const browserNameList = BrowserDetector._browserNameAndVersion.split('/');\n\n if (!browserNameList || !browserNameList[0]) {\n return '';\n }\n\n return browserNameList[0];\n }\n\n private static parseBrowserMajorVersion(): number {\n if (!BrowserDetector._browserNameAndVersion) {\n return 0;\n }\n\n const browserVersionList = BrowserDetector._browserNameAndVersion.split('/');\n\n if (!browserVersionList || !browserVersionList[1]) {\n return 0;\n }\n\n const fullVersion = browserVersionList[1];\n\n if (!fullVersion) {\n return 0;\n }\n\n return Number(fullVersion.split('.')[0]) || 0;\n }\n\n private static parseBrowserNameAndVersionForIE(): string {\n if (!navigator || !navigator.userAgent) {\n return '';\n }\n\n const userAgent = navigator.userAgent;\n const msie = userAgent.indexOf('MSIE ');\n\n if (msie > 0) {\n // IE 10 or older => return version number\n return `IE/${parseInt(userAgent.substring(msie + 5, userAgent.indexOf('.', msie)), 10)}`;\n }\n\n const trident = userAgent.indexOf('Trident/');\n\n if (trident > 0) {\n // IE 11 => return version number\n const version = userAgent.indexOf('rv:');\n\n return `IE/${parseInt(userAgent.substring(version + 3, userAgent.indexOf('.', version)), 10)}`;\n }\n\n return '';\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport BrowserDetector from '../../dom/BrowserDetector';\n\nexport default class FeatureEnablement {\n static get clientOfferDisabled(): boolean {\n // Client offer workflow does not work correctly in the following browsers\n return BrowserDetector.isChrome74 ||\n BrowserDetector.isChrome75 ||\n BrowserDetector.isChrome76 ||\n BrowserDetector.isChrome77;\n }\n\n static get addTranceiverDisabled(): boolean {\n // Chrome 69, 70, 71, 72 exposes `addTranceiver` but it does not work correctly\n return BrowserDetector.isChrome69 ||\n BrowserDetector.isChrome70 ||\n BrowserDetector.isChrome71 ||\n BrowserDetector.isChrome72;\n }\n\n static get getStatsPromiseBasedDisabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 66;\n }\n\n static get getCurrentOfferDisabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 69 ||\n BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion <= 56;\n }\n\n static get onTrackDisabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 63 ||\n BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion <= 52;\n }\n\n static get webkitRTCPeerConnectionEnabled(): boolean {\n return BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion <= 55;\n }\n\n static get promiseBasedPCMethodsDisabled(): boolean {\n return BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion <= 52;\n }\n\n static get shouldUseNativeHls(): boolean {\n return BrowserDetector.browserName === 'Safari' ||\n BrowserDetector.browserName === 'SamsungBrowser';\n }\n\n static get isRTMPEnabled(): boolean {\n return (BrowserDetector.browserName === 'Firefox' && BrowserDetector.browserMajorVersion < 84) ||\n (BrowserDetector.browserName === 'Chrome' && BrowserDetector.browserMajorVersion < 70) ||\n BrowserDetector.browserName === 'Edge' ||\n BrowserDetector.browserName === 'IE';\n }\n\n static get isPrecachingEnabled(): boolean {\n return BrowserDetector.browserName !== 'IE';\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport IPeerConnection, {PeerConnectionEvents} from './IPeerConnection';\nimport {ILogger} from '../logger/LoggerInterface';\nimport FeatureEnablement from '../sdk/feature/FeatureEnablement';\nimport {ILegacyRTCStatsReport} from './RtcConnectionMonitor';\n\nclass VanillaPeerConnection implements IPeerConnection {\n private readonly _logger: ILogger = LoggerFactory.getLogger('VanillaPeerConnection');\n private readonly _peerConnection: RTCPeerConnection;\n\n constructor(configuration?: RTCConfiguration) {\n if (FeatureEnablement.webkitRTCPeerConnectionEnabled) {\n this._peerConnection = new webkitRTCPeerConnection(configuration);\n\n return;\n }\n\n this._peerConnection = new RTCPeerConnection(configuration);\n }\n\n get native(): RTCPeerConnection {\n return this._peerConnection;\n }\n\n get currentLocalDescription(): RTCSessionDescription | null {\n return this._peerConnection.currentLocalDescription;\n }\n\n get currentRemoteDescription(): RTCSessionDescription | null {\n return this._peerConnection.currentRemoteDescription;\n }\n\n get iceConnectionState(): RTCIceConnectionState {\n return this._peerConnection.iceConnectionState;\n }\n\n get supportsGetConfiguration(): boolean {\n return typeof this._peerConnection.getConfiguration === 'function';\n }\n\n get supportsSetConfiguration(): boolean {\n return typeof this._peerConnection.setConfiguration === 'function';\n }\n\n get supportsAddTransceiver(): boolean {\n return !FeatureEnablement.addTranceiverDisabled && typeof this._peerConnection.addTransceiver === 'function';\n }\n\n async createOffer(options?: RTCOfferOptions): Promise<RTCSessionDescriptionInit> {\n if (FeatureEnablement.promiseBasedPCMethodsDisabled) {\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n return new Promise((resolve, reject) => this._peerConnection.createOffer(resolve, reject, options));\n /* eslint-enable */\n }\n\n return this._peerConnection.createOffer(options);\n }\n\n async createAnswer(options?: RTCAnswerOptions): Promise<RTCSessionDescriptionInit> {\n if (FeatureEnablement.promiseBasedPCMethodsDisabled) {\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n return new Promise((resolve, reject) => this._peerConnection.createAnswer(resolve, reject, options));\n /* eslint-enable */\n }\n\n return this._peerConnection.createAnswer(options);\n }\n\n async setLocalDescription(description: RTCSessionDescriptionInit): Promise<void> {\n return this._peerConnection.setLocalDescription(FeatureEnablement.promiseBasedPCMethodsDisabled ?\n new RTCSessionDescription(description) : description);\n }\n\n async setRemoteDescription(description: RTCSessionDescriptionInit): Promise<void> {\n const hasCrypto = description.sdp.match(/a=crypto:/i);\n\n if (hasCrypto) {\n this._logger.warn('SDP a=crypto is not supported');\n }\n\n return this._peerConnection.setRemoteDescription(FeatureEnablement.promiseBasedPCMethodsDisabled ?\n new RTCSessionDescription(description) : description);\n }\n\n getStats(selector?: MediaStreamTrack | null): Promise<RTCStatsReport> {\n return this._peerConnection.getStats(selector);\n }\n\n getStatsLegacy(): Promise<ILegacyRTCStatsReport> {\n return new Promise(resolve => {\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n const ignored = this._peerConnection.getStats(resolve);\n /* eslint-enable */\n });\n }\n\n addEventListener(type: PeerConnectionEvents, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void {\n this._peerConnection.addEventListener(type, listener, options);\n }\n\n removeEventListener(type: PeerConnectionEvents, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void {\n this._peerConnection.removeEventListener(type, listener, options);\n }\n\n addTransceiver(name: string, options: RTCRtpTransceiverInit): RTCRtpTransceiver {\n return this._peerConnection.addTransceiver(name, options);\n }\n\n getConfiguration(): RTCConfiguration {\n return this._peerConnection.getConfiguration();\n }\n\n setConfiguration(configuration: RTCConfiguration): void {\n this._peerConnection.setConfiguration(configuration);\n }\n\n set ontrack(handler: ((this: RTCPeerConnection, ev: RTCTrackEvent) => unknown) | null) {\n this._peerConnection.ontrack = handler;\n }\n\n get ontrack(): ((this: RTCPeerConnection, ev: RTCTrackEvent) => unknown) | null {\n return this._peerConnection.ontrack;\n }\n\n set onicecandidate(handler: ((this: RTCPeerConnection, ev: RTCPeerConnectionIceEvent) => unknown) | null) {\n this._peerConnection.onicecandidate = handler;\n }\n\n get onicecandidate(): ((this: RTCPeerConnection, ev: RTCPeerConnectionIceEvent) => unknown) | null {\n return this._peerConnection.onicecandidate;\n }\n\n set oniceconnectionstatechange(handler: ((this: RTCPeerConnection, ev: Event) => unknown) | null) {\n this._peerConnection.oniceconnectionstatechange = handler;\n }\n\n get oniceconnectionstatechange(): ((this: RTCPeerConnection, ev: Event) => unknown) | null {\n return this._peerConnection.oniceconnectionstatechange;\n }\n\n close(): void {\n this._peerConnection.close();\n }\n}\n\nexport default VanillaPeerConnection;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport IPeerConnectionFactory from './IPeerConnectionFactory';\nimport IPeerConnection from './IPeerConnection';\nimport VanillaPeerConnection from './VanillaPeerConnection';\n\nclass VanillaPeerConnectionFactory implements IPeerConnectionFactory {\n async createPeerConnection(configuration?: RTCConfiguration): Promise<IPeerConnection> {\n return new VanillaPeerConnection(configuration);\n }\n}\n\nexport default VanillaPeerConnectionFactory;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport {IEdgeAuth} from './EdgeAuthToken';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport {EdgeToken} from './EdgeToken';\n\nconst edgeAuthTokenPrefix = 'DIGEST:';\n\nexport default class EdgeAuth {\n private static _logger: ILogger = LoggerFactory.getLogger('EdgeAuth');\n\n static parseToken(token: EdgeToken): IEdgeAuth {\n if (!this.isValidToken(token)) {\n EdgeAuth._logger.error('Token is not valid [%s]', token);\n\n return undefined;\n }\n\n try {\n const encodedEdgeAuthToken = atob(token.substr(edgeAuthTokenPrefix.length));\n const edgeAuthToken = JSON.parse(encodedEdgeAuthToken);\n\n edgeAuthToken.token = JSON.parse(edgeAuthToken.token);\n\n return edgeAuthToken;\n } catch (e) {\n EdgeAuth._logger.error('Cannot parse token value', e);\n\n return undefined;\n }\n }\n\n static getUri(parsedToken: IEdgeAuth): URL {\n return parsedToken && parsedToken.token && parsedToken.token.uri ?\n new URL(parsedToken.token.uri) : null;\n }\n\n static getTenancy(parsedToken: IEdgeAuth): string {\n return parsedToken && parsedToken.applicationId ?\n parsedToken.applicationId : '';\n }\n\n static isValidToken(token: EdgeToken): boolean {\n return !!token && token.startsWith(edgeAuthTokenPrefix);\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nenum MetricsType {\n TimeToFirstFrame,\n ChannelCreationTimeToFirstFrame,\n Stalled,\n Buffering,\n SetupCompleted,\n SetupFailed,\n RoundTripTime,\n DownlinkThroughputCapacity,\n NetworkType,\n ResolutionChanged,\n ApplicationForeground,\n ApplicationBackground\n}\n\nexport default MetricsType;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IDisposable from './IDisposable';\n\nexport default class DisposableList {\n private readonly _list: IDisposable[] = [];\n\n add(disposable: IDisposable): void {\n this._list.push(disposable);\n }\n\n dispose(): void {\n this._list.forEach(disposable => disposable.dispose());\n this._list.length = 0;\n }\n\n toString(): string {\n return `DisposableList[disposables=${this._list.length}]`;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport Disposable from '../lang/Disposable';\nimport Subject from '../rx/Subject';\nimport ReadOnlySubject from '../rx/ReadOnlySubject';\nimport DisposableList from '../lang/DisposableList';\n\nconst defaultDocumentFocusIntervalTimeout = 3000;\n\nexport default class ApplicationActivityMonitor {\n private readonly _disposables: DisposableList = new DisposableList();\n private readonly _readOnlyIsForeground: ReadOnlySubject<boolean>;\n private readonly _isForeground: Subject<boolean>;\n private _timeOfLastTabFocusChange: number = Date.now();\n private _documentFocusInterval: number;\n\n constructor() {\n this._isForeground = new Subject<boolean>(true);\n this._readOnlyIsForeground = new ReadOnlySubject(this._isForeground);\n this.detectTabFocusChange();\n }\n\n get isForeground(): ReadOnlySubject<boolean> {\n return this._readOnlyIsForeground;\n }\n\n getTimeSinceLastChange(): number {\n return Date.now() - this._timeOfLastTabFocusChange;\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private detectTabFocusChange(): void {\n let hidden;\n let visibilityChange;\n\n if (typeof document !== 'object') {\n return;\n }\n\n // Ignored as typescript does not have legacy getStats types\n /* eslint-disable @typescript-eslint/ban-ts-ignore */\n // @ts-ignore\n if (typeof document.msHidden !== 'undefined') {\n hidden = 'msHidden';\n visibilityChange = 'msvisibilitychange';\n // @ts-ignore\n } else if (typeof document.webkitHidden !== 'undefined') {\n hidden = 'webkitHidden';\n visibilityChange = 'webkitvisibilitychange';\n } else if (typeof document.hidden !== 'undefined') { // Opera 12.10 and Firefox 18 and later support\n hidden = 'hidden';\n visibilityChange = 'visibilitychange';\n }\n /* eslint-enable */\n\n const handleVisibilityChange = (): void => {\n const isForeground = !document[hidden];\n\n this.setFocusState(isForeground);\n };\n\n if (typeof document.addEventListener !== 'undefined' && typeof document[hidden] !== 'undefined') {\n document.addEventListener(visibilityChange, handleVisibilityChange, false);\n\n this._disposables.add(new Disposable(() => {\n document.removeEventListener(visibilityChange, handleVisibilityChange, false);\n }));\n } else {\n this.listenForDocumentFocus.call(this);\n }\n }\n\n private listenForDocumentFocus(): void {\n this._documentFocusInterval = window.setInterval(() => {\n const isForeground = document.hasFocus();\n\n this.setFocusState(isForeground);\n }, defaultDocumentFocusIntervalTimeout);\n\n this._disposables.add(new Disposable(() => {\n if (this._documentFocusInterval) {\n clearInterval(this._documentFocusInterval);\n }\n\n this._documentFocusInterval = null;\n }));\n }\n\n private setFocusState(isForeground): void {\n if (this._isForeground === isForeground) {\n return;\n }\n\n this._isForeground.value = isForeground;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class TelemetryUrl {\n static getTelemetryUrl(url: string): string {\n try {\n const baseURL = new URL(url);\n const segments = baseURL.hostname.split('.');\n\n switch (baseURL.protocol) {\n case 'ws:':\n baseURL.protocol = 'http:';\n\n break;\n case 'wss:':\n baseURL.protocol = 'https:';\n\n break;\n\n default:\n break;\n }\n\n if (segments.length === 2 ||\n (segments.length === 3 && segments[segments.length - 2].length <= 2 && segments[segments.length - 1].length <= 3)\n ) {\n segments.unshift('telemetry');\n } else if (segments[0].startsWith('stg-') || segments[0].endsWith('-stg') || segments[0].includes('-stg-') || segments[0] === 'stg') {\n segments[0] = 'telemetry-stg';\n } else if (segments[0].startsWith('local') || segments[0].endsWith('-local')) {\n // Leave URL unchanged\n } else {\n segments[0] = 'telemetry';\n }\n\n baseURL.hostname = segments.join('.');\n\n return `${baseURL.origin}/telemetry`;\n } catch (e) {\n return url;\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class Environment {\n static getEnvironmentFromUrl(url: string): string {\n try {\n const baseURL = new URL(url);\n\n return baseURL.origin;\n } catch (e) {\n return '';\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport {defaultDiscoveryUri} from '../defaults';\nimport Subject from '../../rx/Subject';\nimport VersionManager from '../version/VersionManager';\n\nexport default class DiscoveryUri {\n private static readonly _discoveryUri: Subject<string> = new Subject<string>(defaultDiscoveryUri);\n\n static get uri(): Subject<string> {\n return DiscoveryUri._discoveryUri;\n }\n\n static buildDiscoveryUrl(uri: URL): string {\n const url = new URL(uri.toString());\n const sdkVersion = VersionManager.sdkVersion;\n\n url.search = `?${new URLSearchParams([['version', sdkVersion], ['_', `${Date.now()}`]]).toString()}`;\n\n if (url.pathname === '/') {\n url.pathname = '/pcast/endPoints';\n }\n\n return url.toString();\n }\n\n private constructor() {\n throw new Error('DiscoveryUri is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nconst defaultDiscoveryUri = 'https://pcast.phenixrts.com/pcast/endPoints';\n\nexport {defaultDiscoveryUri};","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {TelemetryLevel} from './MetricsConfiguration';\nimport assertUnreachable from '../lang/assertUnreachable';\nimport MetricsType from './MetricsType';\n\nexport default class MetricType {\n private readonly _metrics: MetricsType;\n\n constructor(metrics: MetricsType) {\n this._metrics = metrics;\n }\n\n getName(): string {\n return MetricsType[this._metrics];\n }\n\n getTelemetryLevel(): TelemetryLevel {\n switch (this._metrics) {\n case MetricsType.TimeToFirstFrame:\n return TelemetryLevel.Essential;\n case MetricsType.ChannelCreationTimeToFirstFrame:\n return TelemetryLevel.Essential;\n case MetricsType.Stalled:\n return TelemetryLevel.All;\n case MetricsType.Buffering:\n return TelemetryLevel.All;\n case MetricsType.SetupCompleted:\n return TelemetryLevel.All;\n case MetricsType.SetupFailed:\n return TelemetryLevel.All;\n case MetricsType.RoundTripTime:\n return TelemetryLevel.All;\n case MetricsType.DownlinkThroughputCapacity:\n return TelemetryLevel.All;\n case MetricsType.NetworkType:\n return TelemetryLevel.All;\n case MetricsType.ResolutionChanged:\n return TelemetryLevel.All;\n case MetricsType.ApplicationForeground:\n return TelemetryLevel.All;\n case MetricsType.ApplicationBackground:\n return TelemetryLevel.All;\n default:\n assertUnreachable(this._metrics);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport VersionManager from '../sdk/version/VersionManager';\nimport MetricsConfiguration from './MetricsConfiguration';\nimport MetricType from './MetricType';\nimport MetricsType from './MetricsType';\n\nconst requestSizeLimit = 1024;\n\ninterface IValue {\n string?: string;\n uint64?: number;\n float?: number;\n}\n\ninterface IMetricRecord {\n timestamp: string;\n tenancy: string;\n sessionId: string;\n streamId: string;\n metric: string;\n value: IValue;\n previousValue: IValue;\n fullQualifiedName: string;\n environment: string;\n version: string;\n runtime: number;\n resource?: string;\n kind?: string;\n}\n\ninterface IMetric {\n streamId?: string;\n metricType: MetricsType;\n value?: IValue;\n previousValue?: IValue;\n runtime: number;\n resource?: string;\n kind?: string;\n}\n\nexport default class MetricsService {\n private readonly _metricsConfiguration: MetricsConfiguration;\n private _metrics: Array<IMetricRecord> = [];\n private _isSending: boolean;\n private _domain = location.hostname;\n\n constructor(metricsConfiguration: MetricsConfiguration) {\n this._metricsConfiguration = metricsConfiguration;\n }\n\n get metricsConfiguration(): MetricsConfiguration {\n return this._metricsConfiguration;\n }\n\n push(metric: IMetric): void {\n const {streamId, value, previousValue, runtime, resource, kind} = metric;\n const metricType = new MetricType(metric.metricType);\n\n if (this._metricsConfiguration.threshold > metricType.getTelemetryLevel()) {\n return;\n }\n\n const metricRecord = {\n timestamp: new Date().toISOString(),\n tenancy: this._metricsConfiguration.tenancy,\n sessionId: this._metricsConfiguration.sessionId,\n streamId,\n metric: metricType.getName(),\n value,\n previousValue,\n fullQualifiedName: this._domain,\n environment: this._metricsConfiguration.environment,\n version: VersionManager.sdkVersion,\n runtime,\n resource,\n kind\n };\n\n this._metrics.push(metricRecord);\n\n const ignored = this.sendMetricsIfAble();\n }\n\n private async sendMetrics(metricsMessages: Array<IMetricRecord>): Promise<Response | void> {\n const formData = new FormData();\n\n formData.append('jsonBody', JSON.stringify({records: metricsMessages}));\n\n return await fetch(this._metricsConfiguration.url, {\n method: 'POST',\n body: formData\n });\n }\n\n private async sendMetricsIfAble(): Promise<Response | void> {\n if (this._metrics.length <= 0 || this._isSending) {\n return;\n }\n\n this._isSending = true;\n\n const metricsMessages = this._metrics.slice(0, requestSizeLimit);\n\n this._metrics = this._metrics.slice(requestSizeLimit);\n\n return this.sendMetrics(metricsMessages).then(response => {\n this._isSending = false;\n\n const ignored = this.sendMetricsIfAble();\n\n return response;\n }).catch(() => {\n this._isSending = false;\n\n const ignored = this.sendMetricsIfAble();\n });\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport MetricsService from './MetricsService';\nimport MetricsConfiguration, {TelemetryLevel} from './MetricsConfiguration';\nimport SDK from '../sdk/SDK';\nimport TelemetryUrl from '../sdk/TelemetryUrl';\nimport Environment from '../sdk/Environment';\nimport TelemetryLevelMapping from './TelemetricLevelMapping';\n\nexport default class MetricsFactory {\n private static _metricsServices: {[category: string]: MetricsService} = {};\n\n static getMetricsService(url: string): MetricsService {\n if (typeof url !== 'string') {\n throw new Error('ur');\n }\n\n const metricsServices = MetricsFactory._metricsServices[url];\n\n if (metricsServices) {\n return metricsServices;\n }\n\n const metricsConfiguration = new MetricsConfiguration();\n\n metricsConfiguration.sessionId = SDK.clientSessionId;\n metricsConfiguration.tenancy = SDK.tenancy.value;\n metricsConfiguration.url = TelemetryUrl.getTelemetryUrl(url);\n metricsConfiguration.environment = Environment.getEnvironmentFromUrl(url);\n\n metricsConfiguration.threshold = TelemetryLevelMapping.convertTelemetryLevelTypeToTelemetryLevel(SDK.telemetryLevel);\n\n return MetricsFactory._metricsServices[url] = new MetricsService(metricsConfiguration);\n }\n\n static setTelemetryLevel(telemetryLevel: TelemetryLevel): void {\n const metricsServices = Object.values(MetricsFactory._metricsServices);\n\n if (metricsServices && metricsServices.length) {\n metricsServices.forEach(metricsService => {\n const metricsConfiguration = metricsService.metricsConfiguration;\n\n metricsConfiguration.threshold = telemetryLevel;\n });\n }\n }\n\n private constructor() {\n throw new Error('LoggerFactory is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport Strings from '../lang/Strings';\nimport Subject from '../rx/Subject';\nimport ReadOnlySubject from '../rx/ReadOnlySubject';\nimport IPeerConnectionFactory from '../rtc/IPeerConnectionFactory';\nimport VanillaPeerConnectionFactory from '../rtc/VanillaPeerConnectionFactory';\nimport EdgeAuth from './edgeAuth/EdgeAuth';\nimport {ILogger} from '../logger/LoggerInterface';\nimport {LoggingLevel, LoggingLevelInputTypes} from '../logger/Logger';\nimport ConsoleAppender from '../logger/ConsoleAppender';\nimport TelemetryAppender from '../telemetry/TelemetryApender';\nimport ConfigurationParameterReader from '../dom/ConfigurationParameterReader';\nimport MetricsConfiguration, {TelemetryLevel, TelemetryLevelType} from '../metrics/MetricsConfiguration';\nimport MetricsService from '../metrics/MetricsService';\nimport TelemetryLevelMapping from '../metrics/TelemetricLevelMapping';\nimport LoggingLevelMapping from '../logger/LoggingLevelMapping';\nimport PrivacyMode from '../dom/PrivacyMode';\nimport BrowserDetector from '../dom/BrowserDetector';\nimport {IConfigurationParameterReader} from '../dom/IConfigurationParamaterReader';\nimport ApplicationActivityMonitor from '../dom/ApplicationActivityMonitor';\nimport TelemetryUrl from './TelemetryUrl';\nimport Environment from './Environment';\nimport {HlsPlayerType, ShakaType, WebPlayerType} from './streaming/StreamTypes';\nimport DiscoveryUri from './discovery/DiscoveryUri';\nimport MetricsFactory from '../metrics/MetricsFactory';\nimport TelemetryDefault from '../metrics/TelemetryDefault';\n\nconst pageLoadTime = window['__phenixPageLoadTime'] || window['__pageLoadTime'] || Date.now();\n\ninterface IInitOptions {\n discoveryUri?: string;\n peerConnectionFactory?: IPeerConnectionFactory;\n telemetryLevel?: TelemetryLevelType;\n loggingLevel?: LoggingLevelInputTypes;\n consoleLoggingLevel?: LoggingLevelInputTypes;\n automaticallyPlayMediaStream?: boolean;\n automaticallyMuteVideoOnPlayFailure?: boolean;\n webPlayerLoader?: (player: WebPlayerType) => void;\n shakaPlayerLoader?: (player: ShakaType) => void;\n hlsJsLoader?: (player: HlsPlayerType) => void;\n}\n\nexport default class SDK {\n private static _automaticallyRetryOnFailure = true;\n private static _automaticallyReconnectPeerConnection = true;\n private static _automaticallyPlayMediaStream = true;\n private static _automaticallyMuteVideoOnPlayFailure = true;\n private static _webPlayerLoader = null;\n private static _shakaPlayerLoader = null;\n private static _hlsJsLoader = null;\n private static _configurationParameterReader: IConfigurationParameterReader = new ConfigurationParameterReader();\n private static _applicationActivityMonitor: ApplicationActivityMonitor;\n private static _environment: Subject<string> = new Subject<string>('');\n private static _telemetryUrl: Subject<string> = new Subject<string>('https://telemetry.phenixrts.com/telemetry');\n private static _maximalNumberOfPeerConnectionReconnectAttempts = 8;\n private static _telemetryLevel: Subject<TelemetryLevel> = new Subject<TelemetryLevel>(TelemetryDefault.defaultTelemetryLevel);\n private static _metricsService: MetricsService;\n private static _metricsConfiguration: MetricsConfiguration\n private static readonly _sendLocalCandidates: Subject<boolean> = new Subject(!PrivacyMode.isPrivate);\n private static readonly _tenancy: Subject<string> = new Subject<string>('');\n private static readonly _clientSessionId: string = Strings.random(32);\n private static readonly _loadedTimestamp: Date = new Date();\n private static readonly _logger: ILogger = LoggerFactory.getLogger('SDK');\n private static readonly _initialized: Subject<boolean> = new Subject<boolean>(false);\n private static readonly _peerConnectionFactory: Subject<IPeerConnectionFactory> = new Subject<IPeerConnectionFactory>(new VanillaPeerConnectionFactory());\n private static readonly _readOnlyInitialized: ReadOnlySubject<boolean> = new ReadOnlySubject<boolean>(SDK._initialized);\n private static readonly _readOnlyDiscoveryUri: ReadOnlySubject<string> = new ReadOnlySubject<string>(DiscoveryUri.uri);\n private static readonly _readOnlyPeerConnectionFactory: ReadOnlySubject<IPeerConnectionFactory> = new ReadOnlySubject<IPeerConnectionFactory>(SDK._peerConnectionFactory);\n\n static get pageLoadTime(): number {\n return pageLoadTime;\n }\n\n static get sendLocalCandidates(): Subject<boolean> {\n return this._sendLocalCandidates;\n }\n\n static get tenancy(): Subject<string> {\n return this._tenancy;\n }\n\n static get clientSessionId(): string {\n return SDK._clientSessionId;\n }\n\n static get loadedTimestamp(): Date {\n return SDK._loadedTimestamp;\n }\n\n static get initialized(): ReadOnlySubject<boolean> {\n return SDK._readOnlyInitialized;\n }\n\n static get discoveryUri(): ReadOnlySubject<string> {\n return SDK._readOnlyDiscoveryUri;\n }\n\n static get peerConnectionFactory(): ReadOnlySubject<IPeerConnectionFactory> {\n return SDK._readOnlyPeerConnectionFactory;\n }\n\n static get automaticRetryOnFailure(): boolean {\n return SDK._automaticallyRetryOnFailure;\n }\n\n static get automaticallyReconnectPeerConnection(): boolean {\n return SDK._automaticallyReconnectPeerConnection;\n }\n\n static get automaticallyPlayMediaStream(): boolean {\n return SDK._automaticallyPlayMediaStream;\n }\n\n static get automaticallyMuteVideoOnPlayFailure(): boolean {\n return SDK._automaticallyMuteVideoOnPlayFailure;\n }\n\n static get webPlayerLoader(): (WebPlayerType) => void {\n return this._webPlayerLoader;\n }\n\n static get shakaPlayerLoader(): (ShakaType) => void {\n return this._shakaPlayerLoader;\n }\n\n static get hlsJsLoader(): (HlsPlayerType) => void {\n return this._hlsJsLoader;\n }\n\n static get metricsService(): MetricsService {\n return SDK._metricsService;\n }\n\n static get applicationActivityMonitor(): ApplicationActivityMonitor {\n return this._applicationActivityMonitor;\n }\n\n static get telemetryUrl(): Subject<string> {\n return this._telemetryUrl;\n }\n\n static get maximalNumberOfPeerConnectionReconnectAttempts(): number {\n return this._maximalNumberOfPeerConnectionReconnectAttempts;\n }\n\n static set maximalNumberOfPeerConnectionReconnectAttempts(retriesAmount: number) {\n this._maximalNumberOfPeerConnectionReconnectAttempts = retriesAmount;\n }\n\n static get loggingLevel(): LoggingLevelInputTypes {\n return LoggingLevelMapping.convertLoggingLevelToLoggingLevelType(this._logger.threshold.value);\n }\n\n static get telemetryLevel(): TelemetryLevelType {\n return TelemetryLevelMapping.convertTelemetryLevelToTelemetryLevelType(SDK._telemetryLevel.value);\n }\n\n static get browserDetector(): BrowserDetector {\n return BrowserDetector;\n }\n\n static applyTelemetryConfiguration(): void {\n const telemetryConfiguration = LoggerFactory.telemetryConfiguration;\n\n telemetryConfiguration.sessionId = SDK.clientSessionId;\n\n const ignoredEnvironment = SDK._environment.subscribe(environment => {\n telemetryConfiguration.environment = environment;\n });\n const ignoredDiscoveryUri = SDK.telemetryUrl.subscribe(value => {\n const telemetryAppender = this._logger.appenders.value.find(appender => appender instanceof TelemetryAppender);\n\n if (telemetryAppender) {\n telemetryConfiguration.url = value;\n\n this._logger.appenders.remove(telemetryAppender);\n this._logger.appenders.add(new TelemetryAppender(telemetryConfiguration));\n this._logger.info('Telemetry URL was set to [%s]', telemetryConfiguration.url);\n }\n });\n const ignoredTenancy = SDK._tenancy.subscribe(tenancy => {\n const telemetryAppender = this._logger.appenders.value.find(appender => appender instanceof TelemetryAppender);\n\n if (telemetryAppender && tenancy) {\n telemetryConfiguration.tenancy = tenancy;\n\n this._logger.appenders.remove(telemetryAppender);\n this._logger.appenders.add(new TelemetryAppender(telemetryConfiguration));\n this._logger.info('Telemetry tenancy was set to [%s]', telemetryConfiguration.tenancy);\n }\n });\n }\n\n static applyMetricsConfiguration(): void {\n SDK._metricsService = MetricsFactory.getMetricsService(DiscoveryUri.uri.value);\n SDK._metricsConfiguration = SDK._metricsService.metricsConfiguration;\n\n SDK._metricsConfiguration.sessionId = SDK.clientSessionId;\n\n const ignoredEnvironment = SDK._environment.subscribe(environment => {\n SDK._metricsConfiguration.environment = environment;\n });\n const ignoredDiscoveryUri = SDK.telemetryUrl.subscribe(value => {\n SDK._metricsConfiguration.url = value;\n });\n const ignoredTenancy = SDK._tenancy.subscribe(tenancy => {\n SDK._metricsConfiguration.tenancy = tenancy;\n });\n const value = this._configurationParameterReader.getStringValue('phenix-metrics-level');\n\n if (value) {\n MetricsFactory.setTelemetryLevel(TelemetryLevel[value]);\n }\n\n const ignoredTelemetryLevel = SDK._telemetryLevel.subscribe(telemetryLevel => {\n MetricsFactory.setTelemetryLevel(telemetryLevel);\n });\n }\n\n static applyAutomaticallyRetryOnFailureFromParameterConfiguration(): void {\n this._automaticallyRetryOnFailure = this._configurationParameterReader.getBooleanValue('phenix-automatically-retry-on-failure');\n this._logger.info('Automatically retry on failure is set to: [%s]', this._automaticallyRetryOnFailure);\n\n return;\n }\n\n static applyAutomaticallyReconnectPeerConnectionFromParameterConfiguration(): void {\n this._automaticallyReconnectPeerConnection = this._configurationParameterReader.getBooleanValue('phenix-automatically-reconnect-peer-connection');\n this._logger.info('Automatically reconnect peer connection is set to: [%s]', this._automaticallyReconnectPeerConnection);\n\n return;\n }\n\n static applyDiscoveryUriDefaultFromParameterConfiguration(): void {\n SDK.discoveryUri.subscribe(value => {\n SDK.telemetryUrl.value = SDK.getTelemetryUrl(value);\n SDK._environment.value = Environment.getEnvironmentFromUrl(value);\n });\n\n const channelToken = this._configurationParameterReader.getStringValue('phenix-channel-token');\n\n if (channelToken) {\n const parsedToken = EdgeAuth.parseToken(channelToken);\n\n SDK._tenancy.value = EdgeAuth.getTenancy(parsedToken);\n DiscoveryUri.uri.value = (EdgeAuth.getUri(parsedToken) || SDK.discoveryUri.value).toString();\n\n this._logger.info('Discovery URI set from configuration parameter to [%s]', SDK.discoveryUri.value);\n\n return;\n }\n\n const uriValue = this._configurationParameterReader.getStringValue('phenix-uri');\n\n if (uriValue) {\n DiscoveryUri.uri.value = uriValue;\n this._logger.info('Discovery URI set from \"phenix-uri\" configuration parameter tag to [%s]', SDK.discoveryUri.value);\n\n return;\n }\n\n const baseURIValue = this._configurationParameterReader.getStringValue('phenix-base-uri');\n\n if (baseURIValue) {\n DiscoveryUri.uri.value = `${baseURIValue}/pcast/endPoints`;\n this._logger.info('Discovery URI set from \"phenix-base-uri\" configuration parameter tag to [%s]', SDK.discoveryUri.value);\n\n return;\n }\n }\n\n static init(options?: IInitOptions): void {\n if (!this._initialized.value) {\n this._applicationActivityMonitor = new ApplicationActivityMonitor();\n }\n\n if (options) {\n if (options.discoveryUri) {\n DiscoveryUri.uri.value = options.discoveryUri;\n }\n\n if (options.peerConnectionFactory) {\n SDK._peerConnectionFactory.value = options.peerConnectionFactory;\n }\n\n if (options.telemetryLevel && TelemetryLevel[options.telemetryLevel]) {\n SDK._telemetryLevel.value = TelemetryLevelMapping.convertTelemetryLevelTypeToTelemetryLevel(options.telemetryLevel);\n }\n\n if (options.loggingLevel && LoggingLevel[options.loggingLevel]) {\n this._logger.threshold.setThreshold(LoggingLevelMapping.convertLoggingLevelTypeToLoggingLevel(options.loggingLevel));\n }\n\n if (options.consoleLoggingLevel &&\n LoggingLevel[options.consoleLoggingLevel]) {\n const consoleAppender = this._logger.appenders.value.find(appender => appender instanceof ConsoleAppender);\n\n if (consoleAppender) {\n this._logger.appenders.remove(consoleAppender);\n }\n\n if (options.consoleLoggingLevel !== 'Off') {\n this._logger.appenders.add(new ConsoleAppender(LoggingLevelMapping.convertLoggingLevelTypeToLoggingLevel(options.consoleLoggingLevel)));\n }\n }\n\n if (typeof options.automaticallyPlayMediaStream === 'boolean') {\n this._automaticallyPlayMediaStream = options.automaticallyPlayMediaStream;\n }\n\n if (typeof options.automaticallyMuteVideoOnPlayFailure === 'boolean') {\n this._automaticallyMuteVideoOnPlayFailure = options.automaticallyMuteVideoOnPlayFailure;\n }\n\n if (options.webPlayerLoader) {\n this._webPlayerLoader = options.webPlayerLoader;\n }\n\n if (options.shakaPlayerLoader) {\n this._shakaPlayerLoader = options.shakaPlayerLoader;\n }\n\n if (options.hlsJsLoader) {\n this._hlsJsLoader = options.hlsJsLoader;\n }\n }\n\n SDK._initialized.value = true;\n }\n\n static dispose(): void {\n SDK._initialized.value = false;\n this._applicationActivityMonitor.dispose();\n this._applicationActivityMonitor = null;\n }\n\n static getTelemetryUrl(url: string): string {\n return TelemetryUrl.getTelemetryUrl(url);\n }\n\n private constructor() {\n throw new Error('SDK is a static class that may not be instantiated');\n }\n}\n\nwindow.addEventListener('unload', () => {\n SDK.dispose();\n});\n\nSDK.applyDiscoveryUriDefaultFromParameterConfiguration();\nSDK.applyMetricsConfiguration();\nSDK.applyTelemetryConfiguration();\nSDK.applyAutomaticallyRetryOnFailureFromParameterConfiguration();\nSDK.applyAutomaticallyReconnectPeerConnectionFromParameterConfiguration();\nSDK.init();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nenum ChannelState {\n Offline = 1,\n Starting,\n Paused,\n Playing,\n Recovering,\n Reconnecting,\n StandBy,\n Stopped,\n Unauthorized,\n GeoRestricted,\n GeoBlocked,\n Error,\n UnsupportedFeature\n}\n\nexport default ChannelState;","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IComparable from '../lang/IComparable';\n\nexport default class Dimension implements IComparable<Dimension> {\n readonly width: number;\n readonly height: number;\n\n static get empty(): Dimension {\n return new Dimension(0, 0);\n }\n\n constructor(width: number, height: number) {\n this.width = width;\n this.height = height;\n }\n\n equals(other: Dimension): boolean {\n return other && this.width === other.width && this.height === other.height;\n }\n\n toString(): string {\n return `${this.width}x${this.height}`;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport type BitrateStateType = 'Keep' | 'Reset';\nexport type BitrateModeType = 'Normal' | 'Force' | 'Reset';\n\nexport enum BitrateState {\n Keep,\n Reset\n}\n\nexport enum BitrateMode {\n Normal,\n Force,\n Reset\n}\n\nexport interface ISetTemporaryMaximalBitrate {\n apiVersion: number;\n sharedSecret: string;\n elapsedInMilliseconds: number;\n bitrateInBitsPerSecond: number;\n bitrateState: BitrateStateType;\n bitrateMode: BitrateModeType;\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class Durations {\n private readonly _duration: number;\n\n constructor(duration = 0) {\n this._duration = duration;\n }\n\n toIsoString(): string {\n if (this._duration === 0) {\n return 'P0S';\n }\n\n const isNegative = this._duration < 0;\n const duration = isNegative ? Math.abs(this._duration) : this._duration;\n let offset = Math.floor(duration);\n const milliseconds = offset % 1000;\n\n offset = Math.floor(offset / 1000);\n\n const seconds = offset % 60;\n\n offset = Math.floor(offset / 60);\n\n const minutes = offset % 60;\n\n offset = Math.floor(offset / 60);\n\n const hours = offset % 24;\n const parts = ['PT'];\n\n if (isNegative) {\n parts.unshift('-');\n }\n\n if (hours) {\n parts.push(hours + 'H');\n }\n\n if (minutes) {\n parts.push(minutes + 'M');\n }\n\n if (seconds || milliseconds) {\n parts.push(String(seconds));\n\n if (milliseconds) {\n parts.push('.' + this.padStart(milliseconds.toString(), 3, '0'));\n }\n\n parts.push('S');\n }\n\n return parts.join('');\n }\n\n padStart(item: string, targetLength: number, padString: string): string {\n targetLength = targetLength >> 0;\n padString = String((typeof padString !== 'undefined' ? padString : ' '));\n\n if (item.length > targetLength) {\n return item;\n }\n\n targetLength = targetLength - item.length;\n\n if (targetLength > padString.length) {\n padString += padString.repeat(targetLength / padString.length);\n }\n\n return padString.slice(0, targetLength) + item;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport {ILogger} from '../logger/LoggerInterface';\nimport Durations from '../time/Duration';\nimport Disposable from '../lang/Disposable';\nimport IDisposable from '../lang/IDisposable';\nimport MetricsType from '../metrics/MetricsType';\nimport DisposableList from '../lang/DisposableList';\nimport MetricsService from '../metrics/MetricsService';\n\nexport default class VideoTelemetry implements IDisposable {\n private readonly _pageLoadTime: number;\n private readonly _channelStartTime: number;\n private readonly _logger: ILogger = LoggerFactory.getLogger('StreamTelemetry');\n private readonly _disposables: DisposableList = new DisposableList();\n private readonly _streamId: string;\n private readonly _metricsService: MetricsService;\n private _listenToFirstTime: () => void;\n private _listenForStall: () => void;\n private _listenForContinuation: (event) => void;\n private _timeToFirstFrame: number;\n private _channelCreationTimeToFirstFrame: number;\n private _startRecordingFirstFrame: number;\n private _videoStalled: number;\n private _lastProgress: number;\n private _videoResolution: string;\n private _clearTimeToFirstFrameListener: Disposable;\n private _clearRebufferingListener: Disposable;\n\n constructor(streamId: string, pageLoadTime: number, channelStartTime: number, metricsService: MetricsService) {\n this._streamId = streamId;\n this._pageLoadTime = pageLoadTime;\n this._channelStartTime = channelStartTime;\n\n this._metricsService = metricsService;\n }\n\n setupListenerForTimeToFirstTime(video: HTMLVideoElement): void {\n this._startRecordingFirstFrame = Date.now();\n\n this._listenToFirstTime = (): void => this.callTimeToFirstFrame();\n\n video.addEventListener('loadeddata', this._listenToFirstTime);\n video.addEventListener('loadedmetadata', this._listenToFirstTime);\n\n this._clearTimeToFirstFrameListener = new Disposable(() => {\n video.removeEventListener('loadeddata', this._listenToFirstTime);\n video.removeEventListener('loadedmetadata', this._listenToFirstTime);\n });\n this._disposables.add(this._clearTimeToFirstFrameListener);\n }\n\n setupListenerForRebuffering(video: HTMLVideoElement): void {\n this._listenForStall = (): void => this.onStall();\n\n this._listenForContinuation = (event): void => this.onContinuation(event, video);\n\n video.addEventListener('stalled', this._listenForStall);\n video.addEventListener('pause', this._listenForStall);\n video.addEventListener('suspend', this._listenForStall);\n video.addEventListener('play', this._listenForContinuation);\n video.addEventListener('playing', this._listenForContinuation);\n video.addEventListener('progress', this._listenForContinuation);\n video.addEventListener('timeupdate', this._listenForContinuation);\n\n this._clearRebufferingListener = new Disposable(() => {\n video.removeEventListener('stalled', this._listenForStall);\n video.removeEventListener('pause', this._listenForStall);\n video.removeEventListener('suspend', this._listenForStall);\n video.removeEventListener('play', this._listenForContinuation);\n video.removeEventListener('playing', this._listenForContinuation);\n video.removeEventListener('progress', this._listenForContinuation);\n video.removeEventListener('timeupdate', this._listenForContinuation);\n });\n\n this._disposables.add(this._clearRebufferingListener);\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private get durationSincePageLoad(): string {\n const now = Date.now();\n\n return new Durations(now - this._pageLoadTime).toIsoString();\n }\n\n private callTimeToFirstFrame(): void {\n const now = Date.now();\n\n this.pushTimeToFirstFrame(now);\n this.pushChannelCreationTimeToFirstFrame(now);\n\n this._clearTimeToFirstFrameListener.dispose();\n }\n\n private pushTimeToFirstFrame(now): void {\n this._timeToFirstFrame = now - this._startRecordingFirstFrame;\n\n this._metricsService.push({\n metricType: MetricsType.TimeToFirstFrame,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: this._timeToFirstFrame},\n streamId: this._streamId\n });\n\n this._logger.info(\n '[%s] [%s] First frame [%s]',\n this.durationSincePageLoad,\n this._streamId,\n new Durations(this._timeToFirstFrame).toIsoString()\n );\n }\n\n private pushChannelCreationTimeToFirstFrame(now): void {\n this._channelCreationTimeToFirstFrame = now - this._channelStartTime;\n\n this._metricsService.push({\n metricType: MetricsType.ChannelCreationTimeToFirstFrame,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: this._channelCreationTimeToFirstFrame},\n streamId: this._streamId\n });\n\n this._logger.info(\n '[%s] [%s] Channel creation to first frame [%s]',\n this.durationSincePageLoad,\n this._streamId,\n new Durations(this._channelCreationTimeToFirstFrame).toIsoString()\n );\n }\n\n private onStall(): void {\n if (this._videoStalled) {\n return;\n }\n\n this._metricsService.push({\n metricType: MetricsType.Stalled,\n runtime: (Date.now() - this._pageLoadTime) / 1000,\n streamId: this._streamId\n });\n\n this._videoStalled = Date.now();\n\n this._logger.info(\n '[%s] [%s] [buffering] Stream has stalled',\n this.durationSincePageLoad,\n this._streamId\n );\n }\n\n private onContinuation(event, video): void {\n if (!video.buffered) {\n return;\n }\n\n const bufferLength = video.buffered.length;\n const hasNotProgressedSinceLastProgressEvent = event.type === 'playing'\n || bufferLength > 0 ? (event.type === 'progress'\n || event.type === 'timeupdate')\n && video.buffered.end(bufferLength - 1) === this._lastProgress : true;\n\n if (!this._videoStalled || hasNotProgressedSinceLastProgressEvent) {\n return;\n }\n\n if (event.type === 'progress') {\n this._lastProgress = video.buffered.end(bufferLength - 1);\n }\n\n const timeSinceStop = Date.now() - this._videoStalled;\n\n this._metricsService.push({\n metricType: MetricsType.Buffering,\n runtime: (Date.now() - this._pageLoadTime) / 1000,\n value: {uint64: timeSinceStop},\n streamId: this._streamId\n });\n\n this._logger.info(\n '[%s] [%s] [buffering] Stream has recovered from stall after [%s]',\n this.durationSincePageLoad,\n this._streamId,\n new Durations(timeSinceStop).toIsoString()\n );\n this._videoStalled = null;\n }\n\n onVideoResolutionChanges(newResolution: string): void {\n this._metricsService.push({\n metricType: MetricsType.ResolutionChanged,\n runtime: (Date.now() - this._pageLoadTime) / 1000,\n value: {string: newResolution},\n previousValue: this._videoResolution ? {string: this._videoResolution} : undefined,\n streamId: this._streamId\n });\n\n this._videoResolution = newResolution;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport MetricsType from '../metrics/MetricsType';\nimport MetricType from '../metrics/MetricType';\nimport Durations from '../time/Duration';\nimport {ILogger} from '../logger/LoggerInterface';\nimport SDK from '../sdk/SDK';\nimport LoggerFactory from '../logger/LoggerFactory';\n\nexport class StreamSetupListener {\n private readonly _logger: ILogger = LoggerFactory.getLogger('StreamSetupListener');\n private readonly metricsService = SDK.metricsService;\n private readonly _pageLoadTime: number;\n private readonly _startTime: number;\n private _metricSubmitted = false;\n\n constructor(pageLoadTime: number) {\n this._startTime = Date.now();\n this._pageLoadTime = pageLoadTime;\n }\n\n success(streamId): void {\n this.recordStreamMetric(MetricsType.SetupCompleted, streamId);\n }\n\n fail(): void {\n this.recordStreamMetric(MetricsType.SetupFailed);\n }\n\n private recordStreamMetric(metricType: MetricsType, streamId?: string): void {\n if (this._metricSubmitted) {\n return ;\n }\n\n this._metricSubmitted = true;\n\n const now = Date.now();\n const setupTime = now - this._startTime;\n const metricName = new MetricType(metricType).getName();\n\n this.metricsService.push({\n metricType,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: setupTime},\n streamId\n });\n\n this._logger.info(\n '[%s] [%s] Stream metric [%s] in [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n streamId,\n metricName,\n new Durations(setupTime).toIsoString()\n );\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport IDisposable from '../lang/IDisposable';\nimport Disposable from '../lang/Disposable';\nimport Subject from '../rx/Subject';\nimport DisposableList from '../lang/DisposableList';\n\nexport default class NetworkMonitor implements IDisposable {\n private readonly _disposables: DisposableList = new DisposableList();\n private readonly _isSupported = navigator && navigator['connection'];\n private readonly _rtt: Subject<number> = new Subject(undefined);\n private readonly _effectiveType: Subject<string> = new Subject(undefined);\n private readonly _downlinkThroughputCapacity: Subject<number> = new Subject(undefined);\n\n constructor() {\n if (!this.isSupported) {\n return;\n }\n\n this.setupNetworkChangeListeners();\n this.updateStatistics();\n }\n\n get isSupported(): boolean {\n return this._isSupported;\n }\n\n get rtt(): Subject<number> {\n return this._rtt;\n }\n\n get effectiveType(): Subject<string> {\n return this._effectiveType;\n }\n\n get downlinkThroughputCapacity(): Subject<number> {\n return this._downlinkThroughputCapacity;\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private getDownlinkThroughputCapacity(): number {\n if (!this.isSupported) {\n return -1;\n }\n\n return navigator['connection'].downlink || navigator['connection'].downlinkMax;\n }\n\n private getEffectiveType(): string {\n if (!this.isSupported) {\n return 'Unknown';\n }\n\n return navigator['connection'].effectiveType || navigator['connection'].type;\n }\n\n private getRoundTripTime(): number {\n return navigator['connection'].rtt;\n }\n\n private setupNetworkChangeListeners(): void {\n const listener = (): void => {\n this.updateStatistics();\n };\n\n navigator['connection'].addEventListener('change', listener);\n\n this._disposables.add(new Disposable(() => {\n navigator['connection'].removeEventListener('change', listener);\n }));\n }\n\n private updateStatistics(): void {\n this._rtt.value = this.getRoundTripTime();\n this._effectiveType.value = this.getEffectiveType();\n this._downlinkThroughputCapacity.value = this.getDownlinkThroughputCapacity();\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {StreamSetupListener} from '../dom/StreamSetupListener';\nimport {ILogger} from '../logger/LoggerInterface';\nimport LoggerFactory from '../logger/LoggerFactory';\nimport NetworkMonitor from '../dom/NetworkMonitor';\nimport SDK from '../sdk/SDK';\nimport MetricsType from '../metrics/MetricsType';\nimport Durations from '../time/Duration';\nimport IDisposable from '../lang/IDisposable';\nimport DisposableList from '../lang/DisposableList';\nimport MetricsService from '../metrics/MetricsService';\n\ninterface INetworkStatistics {\n rtt?: number;\n effectiveType?: string;\n downlinkThroughputCapacity?: number;\n}\n\nexport default class SessionTelemetry implements IDisposable {\n private readonly _logger: ILogger = LoggerFactory.getLogger('SessionTelemetry');\n private readonly _metricsService: MetricsService;\n private readonly _applicationActivityMonitor = SDK.applicationActivityMonitor;\n private readonly _networkMonitor: NetworkMonitor = new NetworkMonitor();\n private readonly _pageLoadTime: number;\n private readonly _disposables: DisposableList = new DisposableList();\n private _lastNetworkStatistics: INetworkStatistics = {};\n\n constructor(pageLoadTime: number, metricsService: MetricsService) {\n this._pageLoadTime = pageLoadTime;\n this._disposables.add(this._networkMonitor);\n this._metricsService = metricsService;\n\n if (!this._networkMonitor.isSupported) {\n return;\n }\n\n this._disposables.add(this._applicationActivityMonitor.isForeground.subscribe(isForeground => {\n this.recordForegroundChange(isForeground);\n }));\n this._disposables.add(this._networkMonitor.rtt.subscribe(value => {\n this.recordNetworkRTTUpdate(value);\n }));\n this._disposables.add(this._networkMonitor.effectiveType.subscribe(value => {\n this.recordNetworkTypeChangeUpdate(value);\n }));\n this._disposables.add(this._networkMonitor.downlinkThroughputCapacity.subscribe(value => {\n this.recordNetworkDownlinkThroughputCapacityUpdate(value);\n }));\n }\n\n listenOnStreamSetup(): StreamSetupListener {\n return new StreamSetupListener(this._pageLoadTime);\n }\n\n dispose(): void {\n this._disposables.dispose();\n }\n\n private recordForegroundChange(isForeground: boolean): void {\n const now = Date.now();\n const timeSinceLastChange = this._applicationActivityMonitor.getTimeSinceLastChange();\n\n this._metricsService.push({\n metricType: isForeground ? MetricsType.ApplicationForeground : MetricsType.ApplicationBackground,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: timeSinceLastChange}\n });\n\n this._logger.info(\n 'Application has gone into the [%s] after [%s] ms',\n isForeground ? 'foreground' : 'background',\n new Durations(timeSinceLastChange).toIsoString(),\n );\n }\n\n private recordNetworkRTTUpdate(newRTT: number): void {\n const now = Date.now();\n const oldRtt = this._lastNetworkStatistics.rtt;\n\n this._lastNetworkStatistics.rtt = newRTT;\n\n this._metricsService.push({\n metricType: MetricsType.RoundTripTime,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {uint64: newRTT},\n previousValue: oldRtt ? {uint64: oldRtt} : undefined,\n resource: 'navigator'\n });\n\n this._logger.info(\n '[%s] Network RTT changed to [%s] from [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n newRTT,\n oldRtt\n );\n }\n\n private recordNetworkTypeChangeUpdate(newNetworkType: string): void {\n const now = Date.now();\n const oldNetworkType = this._lastNetworkStatistics.effectiveType;\n\n this._lastNetworkStatistics.effectiveType = newNetworkType;\n\n this._metricsService.push({\n metricType: MetricsType.NetworkType,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {string: newNetworkType},\n previousValue: oldNetworkType ? {string: oldNetworkType} : undefined\n });\n\n this._logger.info(\n '[%s] Network effective type has changed to [%s] from [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n newNetworkType,\n oldNetworkType\n );\n }\n\n private recordNetworkDownlinkThroughputCapacityUpdate(newCapacity: number): void {\n const now = Date.now();\n const oldCapacity = this._lastNetworkStatistics.downlinkThroughputCapacity;\n\n this._lastNetworkStatistics.downlinkThroughputCapacity = newCapacity;\n\n this._metricsService.push({\n metricType: MetricsType.DownlinkThroughputCapacity,\n runtime: (now - this._pageLoadTime) / 1000,\n value: {float: newCapacity},\n previousValue: oldCapacity ? {float: oldCapacity} : undefined\n });\n\n this._logger.info(\n '[%s] Network downlink throughput capacity changed to [%s] from [%s]',\n new Durations(now - this._pageLoadTime).toIsoString(),\n newCapacity,\n oldCapacity\n );\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport Subject from '../../rx/Subject';\nimport IPeerConnection from '../../rtc/IPeerConnection';\nimport ChannelState from './ChannelState';\nimport Dimension from '../../video/Dimension';\nimport EndPoint, {IStream, SubscribeStatus} from '../discovery/EndPoint';\nimport VideoTelemetry from '../../video/VideoTelemetry';\nimport SessionTelemetry from '../../video/SessionTelemetry';\nimport {IRtcMonitorStatistic, IRtcStatistic} from '../../rtc/RtcConnectionMonitor';\nimport SDK from '../SDK';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport DisposableList from '../../lang/DisposableList';\nimport {EdgeToken} from '../edgeAuth/EdgeToken';\nimport {BitsPerSecond, Millisecond} from '../../units/Units';\n\nexport default class ChannelContext {\n channelInitialization: Date;\n disposables: DisposableList;\n channelDisposables: DisposableList;\n rendererDisposables: DisposableList;\n videoElement: Subject<HTMLVideoElement>;\n token: Subject<EdgeToken>;\n peerConnection: Subject<IPeerConnection>;\n mediaStream: Subject<MediaStream>;\n state: Subject<ChannelState>;\n autoMuted: Subject<boolean>;\n autoPaused: Subject<boolean>;\n tokenExpiring: Subject<boolean>;\n authorized: Subject<boolean>;\n online: Subject<boolean>;\n loading: Subject<boolean>;\n playing: Subject<boolean>;\n standby: Subject<boolean>;\n stopped: Subject<boolean>;\n targetLag: Subject<Millisecond>;\n lag: Subject<Millisecond>;\n bitrateLimit: Subject<BitsPerSecond>;\n resolution: Subject<Dimension>;\n failureCount: Subject<number>;\n endPoint: Subject<EndPoint>;\n stream: Subject<IStream>;\n rtcStatistics: Subject<IRtcMonitorStatistic>;\n\n peerConnectionReconnectAttempts: number;\n isDisposed: boolean;\n isStarting: Subject<boolean>;\n videoTelemetry: VideoTelemetry;\n sessionTelemetry: SessionTelemetry;\n rtcAudioStatistic: IRtcStatistic;\n rtcVideoStatistic: IRtcStatistic;\n clearFailureCountTimeout: number;\n\n constructor(token: string, targetLag: number) {\n this.isDisposed = false;\n this.isStarting = new Subject<boolean>(false);\n this.disposables = new DisposableList();\n this.channelDisposables = new DisposableList();\n this.rendererDisposables = new DisposableList();\n this.channelInitialization = new Date();\n this.videoElement = new Subject<HTMLVideoElement>(null);\n this.token = new Subject<EdgeToken>(token);\n this.peerConnection = new Subject<IPeerConnection>(null);\n this.mediaStream = new Subject<MediaStream>(null);\n this.state = new Subject<ChannelState>(ChannelState.Starting);\n this.autoMuted = new Subject<boolean>(false);\n this.autoPaused = new Subject<boolean>(false);\n this.tokenExpiring = new Subject<boolean>(false);\n this.authorized = new Subject<boolean>(true);\n this.online = new Subject<boolean>(true);\n this.loading = new Subject<boolean>(false);\n this.playing = new Subject<boolean>(false);\n this.standby = new Subject<boolean>(false);\n this.stopped = new Subject<boolean>(false);\n this.targetLag = new Subject<Millisecond>(targetLag);\n this.lag = new Subject<Millisecond>(0);\n this.bitrateLimit = new Subject<BitsPerSecond>(0);\n this.resolution = new Subject<Dimension>(Dimension.empty);\n this.failureCount = new Subject<number>(0);\n this.endPoint = new Subject<EndPoint>(null);\n this.stream = new Subject<IStream>(null);\n this.rtcStatistics = new Subject<IRtcMonitorStatistic>(null);\n this.peerConnectionReconnectAttempts = 0;\n }\n\n get streamId(): string {\n const stream = this.stream.value;\n\n if (!stream) {\n return '-';\n }\n\n return stream.streamId;\n }\n\n applyStatus(status: SubscribeStatus): void {\n switch (status) {\n case 'ok':\n break;\n case 'unauthorized':\n case 'geo-restricted':\n case 'geo-blocked':\n this.authorized.value = false;\n\n // eslint-disable-next-line no-fallthrough\n case 'no-stream':\n case 'not-found':\n this.failureCount.value = 0;\n this.playing.value = false;\n this.standby.value = true;\n this.stopped.value = false;\n this.stream.value = null;\n\n return;\n default:\n this.failureCount.value++;\n this.playing.value = false;\n this.standby.value = true;\n this.stopped.value = false;\n this.stream.value = null;\n this.state.value = ChannelState.Error;\n\n return;\n }\n }\n\n applySessionAndStreamPropertiesToVideoElement(): void {\n if (this.videoElement.value && this.videoElement.value.dataset) {\n this.videoElement.value.dataset.sessionId = SDK.clientSessionId;\n this.videoElement.value.dataset.streamId = this.streamId;\n }\n }\n\n mapSubscribeStatusToChannelStatus(status: SubscribeStatus): ChannelState {\n switch (status) {\n case 'ok':\n return ChannelState.Starting;\n case 'no-stream':\n case 'not-found':\n return ChannelState.StandBy;\n case 'geo-restricted':\n return ChannelState.GeoRestricted;\n case 'geo-blocked':\n return ChannelState.GeoBlocked;\n case 'unauthorized':\n return ChannelState.Unauthorized;\n case 'capacity':\n case 'rate-limited':\n case 'timeout':\n return ChannelState.Recovering;\n case 'failed':\n return ChannelState.Error;\n default:\n assertUnreachable(status);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../logger/LoggerFactory';\nimport SDK from '../sdk/SDK';\nimport IPeerConnection from './IPeerConnection';\nimport {ILogger} from '../logger/LoggerInterface';\nimport FeatureEnablement from '../sdk/feature/FeatureEnablement';\n\nexport interface IPeerConnectionOfferInit {\n audioTransceiver?: RTCRtpTransceiver;\n videoTransceiver?: RTCRtpTransceiver;\n peerConnection: IPeerConnection;\n localOffer: RTCSessionDescriptionInit;\n}\n\nexport default class PeerConnectionService {\n private static _logger: ILogger = LoggerFactory.getLogger('PeerConnectionService');\n private static _cached: Promise<IPeerConnectionOfferInit>;\n\n static initiateInitialPrecaching(): void {\n if (FeatureEnablement.isPrecachingEnabled) {\n const ignored = PeerConnectionService.precacheCreatePeerConnectionOffer()\n .catch(e => PeerConnectionService._logger.error('Failed to pre-cache peer connection offer\"', e));\n }\n }\n\n static async precacheCreatePeerConnectionOffer(): Promise<IPeerConnectionOfferInit> {\n return PeerConnectionService._cached = PeerConnectionService.createPeerConnectionOffer()\n .catch(e => {\n PeerConnectionService._cached = null;\n\n throw e;\n });\n }\n\n static async createPeerConnectionOffer(): Promise<IPeerConnectionOfferInit> {\n if (PeerConnectionService._cached) {\n const value = PeerConnectionService._cached;\n\n PeerConnectionService._cached = null;\n\n return value;\n }\n\n const peerConnectionFactory = SDK.peerConnectionFactory.value;\n\n return peerConnectionFactory.createPeerConnection()\n .then(async peerConnection => {\n const supportsAddTransceiver = peerConnection.supportsAddTransceiver;\n let videoTransceiver, audioTransceiver;\n\n if (supportsAddTransceiver) {\n audioTransceiver = peerConnection.addTransceiver('audio', {direction: 'recvonly'});\n videoTransceiver = peerConnection.addTransceiver('video', {direction: 'recvonly'});\n }\n\n return {\n audioTransceiver,\n videoTransceiver,\n peerConnection: peerConnection,\n localOffer: await peerConnection.createOffer(supportsAddTransceiver ? undefined : {\n offerToReceiveAudio: true,\n offerToReceiveVideo: true\n })\n };\n });\n }\n\n private constructor() {\n throw new Error('PeerConnectionService is a static class that may not be instantiated');\n }\n}\n\nPeerConnectionService.initiateInitialPrecaching();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {BitrateMode, BitrateModeType} from '../api/SetTemporaryMaximalBitrate';\nimport assertUnreachable from '../../lang/assertUnreachable';\n\nexport default class BitrateModeMapping {\n static convertBitrateModeToBitrateModeType(bitrateMode: BitrateMode): BitrateModeType {\n switch (bitrateMode) {\n case BitrateMode.Normal:\n return 'Normal';\n case BitrateMode.Force:\n return 'Force';\n case BitrateMode.Reset:\n return 'Reset';\n default:\n assertUnreachable(bitrateMode);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {BitrateState, BitrateStateType} from '../api/SetTemporaryMaximalBitrate';\nimport assertUnreachable from '../../lang/assertUnreachable';\n\nexport default class BitrateStateMapping {\n static convertBitrateStateToBitrateStateType(bitrateState: BitrateState): BitrateStateType {\n switch (bitrateState) {\n case BitrateState.Keep:\n return 'Keep';\n case BitrateState.Reset:\n return 'Reset';\n default:\n assertUnreachable(bitrateState);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport {ILogger} from '../../logger/LoggerInterface';\n\nimport {\n ISubscribeResponse,\n ISubscribeWithOfferRequest,\n ISubscribeWithoutOfferRequest\n} from '../api/Subscribe';\nimport {ISetRemoteDescriptionRequest, ISetRemoteDescriptionResponse} from '../api/SetRemoteDescription';\nimport {ISessionDescription, SdpType} from '../api/SessionDescription';\nimport {IDestroyStreamRequest, IDestroyStreamResponse} from '../api/DestroyStream';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport {IAddIceCandidatesRequest, IAddIceCandidatesResponse} from '../api/AddIceCandidates';\nimport VersionManager from '../version/VersionManager';\nimport EdgeAuth from '../edgeAuth/EdgeAuth';\nimport {BitrateMode, BitrateState, ISetTemporaryMaximalBitrate} from '../api/SetTemporaryMaximalBitrate';\nimport BitrateModeMapping from './BitrateModeMapping';\nimport BitrateStateMapping from './BitrateStateMapping';\nimport {BitsPerSecond, Millisecond} from '../../units/Units';\n\nconst apiVersion = 6;\n\nexport type SubscribeStatus = 'ok' | 'no-stream' | 'not-found' | 'unauthorized' | 'geo-restricted' | 'geo-blocked' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type SetRemoteDescriptionStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type SetTemporaryMaximalBitrateStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type RemoveTemporaryMaximalBitrateStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type AddIceCandidatesStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport type DestroyStreamStatus = 'ok' | 'not-found' | 'unauthorized' | 'rate-limited' | 'capacity' | 'timeout' | 'failed';\nexport interface IStream {\n streamId: string;\n sharedSecret: string;\n tenancy: string;\n}\n\nexport interface ISubscribeResponseInit {\n status: SubscribeStatus;\n stream?: IStream;\n lag?: Millisecond;\n rtcConfiguration?: RTCConfiguration;\n setRemoteDescriptionResponse?: {\n sessionDescription: RTCSessionDescriptionInit;\n };\n createOfferDescriptionResponse?: {\n sessionDescription: RTCSessionDescriptionInit;\n };\n createAnswerDescriptionResponse?: {\n sessionDescription: RTCSessionDescriptionInit;\n };\n}\n\ninterface ISetRemoteDescriptionResponseInit {\n status: SetRemoteDescriptionStatus;\n sessionDescription?: RTCSessionDescriptionInit;\n}\n\ninterface IAddIceCandidatesResponseInit {\n status: AddIceCandidatesStatus;\n options?: string[];\n}\n\ninterface ISetTemporaryMaximalBitrateResponseInit {\n status: SetTemporaryMaximalBitrateStatus;\n}\n\ninterface IDestroyStreamResponseInit {\n status: DestroyStreamStatus;\n}\n\nexport default class EndPoint {\n private readonly _logger: ILogger = LoggerFactory.getLogger('EndPoint');\n private readonly _uri: string;\n private readonly _timeout: number;\n private _roundTripTime: number;\n\n constructor(uri: string, timeout: number) {\n this._uri = uri;\n this._timeout = timeout;\n\n if (!timeout) {\n throw new Error(`End point requires a timeout`);\n }\n }\n\n get roundTripTime(): number {\n return this._roundTripTime;\n }\n\n toString(): string {\n return `EndPoint[uri=${this._uri}]`;\n }\n\n async ping(): Promise<number> {\n const url = this.buildPingUrl();\n const start = Date.now();\n const response = await Promise.race([\n fetch(url, {\n method: 'GET',\n cache: 'no-cache'\n }),\n new Promise<Response>((_, reject) =>\n setTimeout(() => reject(new Error(`Ping timed out [${url}]`)), this._timeout)\n )\n ]);\n const finished = Date.now();\n\n if (!response.ok) { /* Handle */\n throw new Error(`Ping failed [${url}] [${response.status}]`);\n }\n\n this._roundTripTime = finished - start;\n\n return this._roundTripTime;\n }\n\n async subscribe(token: string, localSessionDescription: RTCSessionDescriptionInit, failureCount: number): Promise<ISubscribeResponseInit> {\n const parsedToken = EdgeAuth.parseToken(token);\n\n if (!parsedToken || !parsedToken.applicationId) {\n this._logger.error('Failed to parse token [%s]', token);\n\n return {status: 'unauthorized'};\n }\n\n const tenancy = parsedToken.applicationId;\n const url = this.buildUrl([tenancy, 'stream', 'subscribe']).toString();\n const formData = new FormData();\n const clientVersion = VersionManager.sdkVersion;\n\n if (failureCount === 0 && localSessionDescription) {\n const bodyWithOffer: ISubscribeWithOfferRequest = {\n apiVersion,\n clientVersion,\n edgeAuthToken: token,\n failureCount,\n setRemoteDescription: {\n apiVersion,\n sessionDescription: {\n type: this.convertRTCSdpTypeToSdpType(localSessionDescription.type),\n sdp: localSessionDescription.sdp\n }\n },\n createAnswerDescription: {apiVersion}\n };\n\n formData.append('jsonBody', JSON.stringify(bodyWithOffer));\n } else {\n const bodyWithoutOffer: ISubscribeWithoutOfferRequest = {\n apiVersion,\n clientVersion,\n edgeAuthToken: token,\n failureCount,\n createOfferDescription: {apiVersion}\n };\n\n formData.append('jsonBody', JSON.stringify(bodyWithoutOffer));\n }\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to subscribe', new Error(`Subscribe timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to subscribe', e);\n\n return {status: 'failed'};\n }\n\n const status: SubscribeStatus = this.mapHttpStatusToSubscribeStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const subscribeResponse = await this.convertHttpResponseToSubscribeResponse(tenancy, httpResponse);\n\n this._logger.debug('Got subscribe response [%j] in [%s] ms', subscribeResponse, finished - start);\n\n return subscribeResponse;\n }\n\n async setRemoteDescription(stream: IStream, sessionDescription: RTCSessionDescriptionInit): Promise<ISetRemoteDescriptionResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'description', 'remote']).toString();\n const formData = new FormData();\n const body: ISetRemoteDescriptionRequest = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n sessionDescription: {\n type: this.convertRTCSdpTypeToSdpType(sessionDescription.type),\n sdp: sessionDescription.sdp\n }\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to set remote description', new Error(`Set remote description timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to set remote description', e);\n\n return {status: 'failed'};\n }\n\n const status: SetRemoteDescriptionStatus = this.mapHttpStatusToSetRemoteDescriptionStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const setRemoteDescriptionResponse = await this.convertHttpResponseToSetRemoteDescriptionResponse(httpResponse);\n\n this._logger.debug('Got set remote description response [%j] in [%s] ms', setRemoteDescriptionResponse, finished - start);\n\n return setRemoteDescriptionResponse;\n }\n\n async limitBitrate(\n stream: IStream,\n elapsedInMilliseconds: number,\n bitrateInBitsPerSecond: BitsPerSecond,\n bitrateState: BitrateState,\n bitrateMode: BitrateMode,\n ): Promise<ISetTemporaryMaximalBitrateResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'bitrate']).toString();\n const formData = new FormData();\n const body: ISetTemporaryMaximalBitrate = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n elapsedInMilliseconds,\n bitrateInBitsPerSecond,\n bitrateState: BitrateStateMapping.convertBitrateStateToBitrateStateType(bitrateState),\n bitrateMode: BitrateModeMapping.convertBitrateModeToBitrateModeType(bitrateMode)\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to set limit bitrate timed', new Error(`Set limit bitrate timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to set limit bitrate timed', e);\n\n return {status: 'failed'};\n }\n\n const status: SetTemporaryMaximalBitrateStatus = this.mapHttpStatusToSetTemporaryMaximalBitrateStatus(httpResponse);\n const finished = Date.now();\n\n this._logger.info('Got set limit bitrate response [%s] in [%s] ms', status, finished - start);\n\n return {status};\n }\n\n async addIceCandidates(stream: IStream, candidates: RTCIceCandidate[], discoveryCompleted: boolean, options: string[] = []): Promise<IAddIceCandidatesResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'ice', 'candidates']).toString();\n const formData = new FormData();\n const body: IAddIceCandidatesRequest = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n candidates,\n discoveryCompleted,\n options\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to add ice candidates', new Error(`Add ice candidates timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to add ice candidates', e);\n\n return {status: 'failed'};\n }\n\n const status: AddIceCandidatesStatus = this.mapHttpStatusToAddIceCandidatesStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const addIceCandidatesResponse = await this.convertHttpResponseToAddIceCandidatesResponse(httpResponse);\n\n this._logger.info('Got add ICE candidates response [%j] in [%s] ms', addIceCandidatesResponse, finished - start);\n\n return addIceCandidatesResponse;\n }\n\n async destroyStream(stream: IStream, reason: string): Promise<IDestroyStreamResponseInit> {\n const url = this.buildUrl([stream.tenancy, 'stream', stream.streamId, 'destroy']).toString();\n const formData = new FormData();\n const body: IDestroyStreamRequest = {\n apiVersion,\n sharedSecret: stream.sharedSecret,\n reason,\n options: []\n };\n\n formData.append('jsonBody', JSON.stringify(body));\n\n const start = Date.now();\n let httpResponse: Response;\n\n try {\n let timeout = null;\n\n httpResponse = await Promise.race([\n fetch(url, {\n method: 'POST',\n body: formData,\n cache: 'no-cache'\n }),\n new Promise<Response>(resolve =>\n timeout = window.setTimeout(() => {\n this._logger.error('Failed to subscribe', new Error(`Delete stream timed out [${url}]`));\n resolve({status: 408} as Response);\n }, this._timeout)\n )\n ])\n .finally(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n });\n } catch (e) {\n this._logger.error('Failed to delete stream', e);\n\n return {status: 'failed'};\n }\n\n const status: DestroyStreamStatus = this.mapHttpStatusToSetDestroyStreamStatus(httpResponse);\n\n if (status !== 'ok') {\n return {status};\n }\n\n const finished = Date.now();\n const destroyStreamResponse = await this.convertHttpResponseToDestroyStreamResponse(httpResponse);\n\n this._logger.info('Got destroy stream response [%j] in [%s] ms', destroyStreamResponse, finished - start);\n\n return destroyStreamResponse;\n }\n\n buildUrl(path: string[]): URL {\n const uri = new URL(this._uri);\n const pathAsArray = uri.pathname.split('/');\n\n pathAsArray.length = pathAsArray.length - 1;\n\n uri.pathname = pathAsArray.concat(...path).join('/');\n\n return uri;\n }\n\n private buildPingUrl(): string {\n const uri = new URL(this._uri);\n const sdkVersion = VersionManager.sdkVersion;\n\n uri.search = `?${new URLSearchParams([['type', 'http'], ['version', sdkVersion], ['_', `${Date.now()}`]]).toString()}`;\n\n return uri.toString();\n }\n\n private mapHttpStatusToSubscribeStatus(response: Response): SubscribeStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 402:\n return 'geo-restricted';\n case 403:\n return 'geo-blocked';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToSetRemoteDescriptionStatus(response: Response): SetRemoteDescriptionStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToSetTemporaryMaximalBitrateStatus(response: Response): SetTemporaryMaximalBitrateStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToAddIceCandidatesStatus(response: Response): AddIceCandidatesStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private mapHttpStatusToSetDestroyStreamStatus(response: Response): DestroyStreamStatus {\n if (!response) {\n return 'failed';\n }\n\n switch (response.status) {\n case 200:\n return 'ok';\n case 401:\n return 'unauthorized';\n case 408:\n return 'timeout';\n case 503:\n return 'capacity';\n case 504:\n return 'rate-limited';\n default:\n return 'failed';\n }\n }\n\n private async convertHttpResponseToSubscribeResponse(tenancy: string, response: Response): Promise<ISubscribeResponseInit> {\n const data = await response.json() as ISubscribeResponse;\n const subscribeResponse: ISubscribeResponseInit = {status: data.status};\n\n subscribeResponse.stream = {\n tenancy,\n streamId: data.streamId,\n sharedSecret: data.sharedSecret\n };\n\n subscribeResponse.lag = data.lag;\n\n if (data) {\n if (data.rtcConfiguration) {\n const rtcConfiguration: RTCConfiguration = {};\n\n if (data.rtcConfiguration.bundlePolicy) {\n switch (data.rtcConfiguration.bundlePolicy) {\n case 'BundlePolicyBalanced':\n rtcConfiguration.bundlePolicy = 'balanced';\n\n break;\n case 'BundlePolicyMaxCompat':\n rtcConfiguration.bundlePolicy = 'max-compat';\n\n break;\n case 'BundlePolicyMaxBundle':\n rtcConfiguration.bundlePolicy = 'max-bundle';\n\n break;\n default:\n assertUnreachable(data.rtcConfiguration.bundlePolicy);\n }\n }\n\n if (typeof data.rtcConfiguration.iceCandidatePoolSize === 'number') {\n rtcConfiguration.iceCandidatePoolSize = data.rtcConfiguration.iceCandidatePoolSize;\n }\n\n if (data.rtcConfiguration.iceServers) {\n const iceServers: RTCIceServer[] = [];\n\n for (let i = 0; i < data.rtcConfiguration.iceServers.length; i++) {\n iceServers.push({\n urls: data.rtcConfiguration.iceServers[i].urls,\n username: data.rtcConfiguration.iceServers[i].username,\n credential: data.rtcConfiguration.iceServers[i].credential\n });\n }\n\n rtcConfiguration.iceServers = iceServers;\n }\n\n if (data.rtcConfiguration.iceTransportPolicy) {\n switch (data.rtcConfiguration.iceTransportPolicy) {\n case 'IceTransportPolicyAll':\n rtcConfiguration.iceTransportPolicy = 'all';\n\n break;\n case 'IceTransportPolicyRelay':\n rtcConfiguration.iceTransportPolicy = 'relay';\n\n break;\n case 'IceTransportPolicyPublic':\n // Deprecated - Not supported\n break;\n default:\n assertUnreachable(data.rtcConfiguration.iceTransportPolicy);\n }\n }\n\n if (data.rtcConfiguration.peerIdentity) {\n rtcConfiguration.peerIdentity = data.rtcConfiguration.peerIdentity;\n }\n\n if (data.rtcConfiguration.rtcpMuxPolicy) {\n switch (data.rtcConfiguration.rtcpMuxPolicy) {\n case 'RtcpMuxPolicyNegotiate':\n rtcConfiguration.rtcpMuxPolicy = 'negotiate';\n\n break;\n case 'RtcpMuxPolicyRequire':\n rtcConfiguration.rtcpMuxPolicy = 'require';\n\n break;\n default:\n assertUnreachable(data.rtcConfiguration.rtcpMuxPolicy);\n }\n }\n\n subscribeResponse.rtcConfiguration = rtcConfiguration;\n }\n\n if (data.setRemoteDescriptionResponse && data.setRemoteDescriptionResponse.sessionDescription) {\n subscribeResponse.setRemoteDescriptionResponse = {sessionDescription: this.convertISessionDescriptionToRTCSessionDescription(data.setRemoteDescriptionResponse.sessionDescription)};\n }\n\n if (data.createAnswerDescriptionResponse && data.createAnswerDescriptionResponse.sessionDescription) {\n subscribeResponse.createAnswerDescriptionResponse = {sessionDescription: this.convertISessionDescriptionToRTCSessionDescription(data.createAnswerDescriptionResponse.sessionDescription)};\n }\n\n if (data.createOfferDescriptionResponse && data.createOfferDescriptionResponse.sessionDescription) {\n subscribeResponse.createOfferDescriptionResponse = {sessionDescription: this.convertISessionDescriptionToRTCSessionDescription(data.createOfferDescriptionResponse.sessionDescription)};\n }\n }\n\n return subscribeResponse;\n }\n\n private convertISessionDescriptionToRTCSessionDescription(sessionDescription: ISessionDescription): RTCSessionDescriptionInit {\n const rtcSessionDescription: RTCSessionDescriptionInit = {sdp: sessionDescription.sdp};\n\n switch (sessionDescription.type) {\n case 'Offer':\n rtcSessionDescription.type = 'offer';\n\n break;\n case 'Answer':\n rtcSessionDescription.type = 'answer';\n\n break;\n default:\n assertUnreachable(sessionDescription.type);\n }\n\n return rtcSessionDescription;\n }\n\n private async convertHttpResponseToSetRemoteDescriptionResponse(response: Response): Promise<ISetRemoteDescriptionResponseInit> {\n const data = await response.json() as ISetRemoteDescriptionResponse;\n const setRemoteDescriptionResponse: ISetRemoteDescriptionResponseInit = {status: data.status};\n\n if (data && data.sessionDescription) {\n setRemoteDescriptionResponse.sessionDescription = this.convertISessionDescriptionToRTCSessionDescription(data.sessionDescription);\n }\n\n return setRemoteDescriptionResponse;\n }\n\n private async convertHttpResponseToAddIceCandidatesResponse(response: Response): Promise<IAddIceCandidatesResponseInit> {\n const data = await response.json() as IAddIceCandidatesResponse;\n const addIceCandidatesResponse: IAddIceCandidatesResponseInit = {\n status: data.status,\n options: []\n };\n\n if (data) {\n if (data.options) {\n addIceCandidatesResponse.options = data.options;\n }\n }\n\n return addIceCandidatesResponse;\n }\n\n private async convertHttpResponseToDestroyStreamResponse(response: Response): Promise<IDestroyStreamResponseInit> {\n const data = await response.json() as IDestroyStreamResponse;\n const destroyStream: IDestroyStreamResponseInit = {status: data.status};\n\n return destroyStream;\n }\n\n private convertRTCSdpTypeToSdpType(type: RTCSdpType): SdpType {\n switch (type) {\n case 'answer':\n return 'Answer';\n case 'offer':\n return 'Offer';\n case 'pranswer':\n case 'rollback':\n throw new Error(`SDP type [${type}] is not supported`);\n default:\n assertUnreachable(type);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport EndPoint from './EndPoint';\nimport SDK from '../SDK';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport MetricsType from '../../metrics/MetricsType';\nimport DiscoveryUri from './DiscoveryUri';\nimport MetricsService from '../../metrics/MetricsService';\nimport MetricsFactory from '../../metrics/MetricsFactory';\n\nconst defaultTimeout = 20000;\n\nexport default class DiscoveryService {\n private _logger: ILogger = LoggerFactory.getLogger('Discovery');\n private _metricsService: MetricsService;\n private _uri: URL;\n\n constructor(uri: URL) {\n if (!uri) {\n throw new Error('Discovery requires uri');\n }\n\n this._metricsService = MetricsFactory.getMetricsService(uri.toString());\n this._uri = uri;\n }\n\n async discoverNearbyEndPoints(uri: URL, timeout: number): Promise<EndPoint[]> {\n if (!timeout) {\n throw new Error('Discovery requires timeout');\n }\n\n const url = uri.toString();\n const response = await Promise.race([\n fetch(url, {\n method: 'GET',\n cache: 'no-cache'\n }),\n new Promise<Response>((_, reject) =>\n setTimeout(() => reject(new Error(`Discovery timed out [${url}]`)), timeout)\n )\n ]);\n\n if (!response.ok) {\n throw new Error(`Discovery failed [${url}] [${response.status}]`);\n }\n\n if (response.body === null) {\n throw new Error(`Discovery failed with no data [${url}]`);\n }\n\n const asString = await response.text();\n const endPoints = asString.split(',');\n\n return endPoints.map(endPoint => new EndPoint(endPoint, timeout));\n }\n\n async discoverClosestEndPoint(timeout: number = defaultTimeout): Promise<EndPoint> {\n const url = DiscoveryUri.buildDiscoveryUrl(this._uri);\n const endPoints = await this.discoverNearbyEndPoints(new URL(url), timeout);\n const neverResolve = (): Promise<void> => new Promise(() => {\n this._logger.info('Request [%s] failed, preventing it from completing', url);\n });\n const endPoint = await Promise.race(endPoints.map(endPoint => endPoint\n .ping()\n .catch(e => {\n this._logger.warn('Failed to ping end point [%s]', endPoint, e);\n\n return neverResolve();\n })\n .then(time => {\n const now = Date.now();\n\n this._logger.info('Discovered end point [%s] with time [%s]', endPoint.toString(), time);\n this._metricsService.push({\n metricType: MetricsType.RoundTripTime,\n runtime: (now - SDK.pageLoadTime) / 1000,\n value: {uint64: time || 0},\n resource: endPoint.toString(),\n kind: 'ping'\n });\n\n return endPoint;\n })));\n\n return endPoint;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport EndPoint from './EndPoint';\nimport SDK from '../SDK';\nimport DiscoveryService from './DiscoveryService';\n\nconst discoveryCacheInterval = 60000;\n\ninterface IPerURIEndpoint { [x: string]: Promise<EndPoint> }\n\nexport default class Discovery {\n private static _cache: IPerURIEndpoint = {};\n\n static async precacheClosestEndPointDiscovery(): Promise<EndPoint> {\n const uri = new URL(SDK.discoveryUri.value);\n\n return Discovery.discoverClosestEndPointWithCaching(uri);\n }\n\n static async discoverClosestEndPointWithCaching(uri: URL): Promise<EndPoint> {\n const url = uri.toString();\n\n if (Discovery._cache[url]) {\n return Discovery._cache[url];\n }\n\n const discoveryService = new DiscoveryService(uri);\n const cachedValue = Discovery._cache[url] = discoveryService.discoverClosestEndPoint();\n\n Discovery._cache[url].then(() => {\n const ignored = setTimeout(() => {\n if (Discovery._cache[url] === cachedValue) {\n delete Discovery._cache[url];\n }\n }, discoveryCacheInterval);\n }).catch(e => {\n delete Discovery._cache[url];\n\n throw e;\n });\n\n return cachedValue;\n }\n\n private constructor() {\n throw new Error('Discovery is a static class that may not be instantiated');\n }\n}\n\nconst ignored = Discovery.precacheClosestEndPointDiscovery();","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nexport default class SdpParser {\n private readonly _sdp: string;\n private readonly _audioCodec: string;\n private readonly _videoCodec: string;\n\n constructor(sdp: string) {\n this._sdp = sdp;\n this._audioCodec = this.applyCodec('audio');\n this._videoCodec = this.applyCodec('video');\n }\n\n get audioCodec(): string {\n return this._audioCodec;\n }\n\n get videoCodec(): string {\n return this._videoCodec;\n }\n\n applyCodec(type: string): string {\n const splitSdp = this._sdp.split(/(\\r\\n|\\r|\\n)/);\n const usedCodecLine = splitSdp.find(item => item.includes(`a=rtpmap:${splitSdp.find(i => i.includes(`m=${type}`)).split(' ')[3]}`));\n const usedCodec = usedCodecLine.split(' ')[1];\n const codecName = usedCodec.split('/')[0];\n\n return codecName;\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IPeerConnection from './IPeerConnection';\nimport Subject from '../rx/Subject';\nimport FeatureEnablement from '../sdk/feature/FeatureEnablement';\nimport SdpParser from './SdpParser';\nimport IDisposable from '../lang/IDisposable';\n\nexport interface IRtcMonitorStatistic {\n [kind: string]: IRtcStatistic;\n}\n\nexport interface ILegacyRTCStatsReport {\n result: () => ILegacyRTCStatsReportItem[];\n}\n\nexport interface ILegacyRTCStatsReportItem extends RTCStatsReport {\n type: string;\n names: () => string[];\n stat: (name) => number;\n}\n\nexport interface IRtcStatistic {\n ssrc?: string;\n mediaType?: string;\n timestamp: number;\n bytesReceived?: number;\n framesDecoded?: number;\n packetsLost?: number;\n packetsReceived?: number;\n codec?: string;\n fps?: number;\n roundTripTime?: number;\n lastPacketReceivedTimestamp?: number;\n}\n\nconst updateStatisticTimeOut = 1000;\n\nexport default class RtcConnectionMonitor implements IDisposable {\n private readonly _estimatedRoundTripTime: number;\n private readonly _estimatedVideoCodec: string;\n private readonly _estimatedAudioCodec: string;\n private readonly _rtcStatistic: Subject<IRtcMonitorStatistic> = new Subject<IRtcMonitorStatistic>({});\n private _peerConnection: IPeerConnection;\n private _isMonitorRunning = true;\n private _updateTimeOut: number;\n private _tracksToMonitor: string[];\n\n constructor(peerConnection: IPeerConnection, mediaStream: MediaStream, estimatedRoundTripTime: number) {\n this._peerConnection = peerConnection;\n this._estimatedRoundTripTime = estimatedRoundTripTime;\n this._tracksToMonitor = mediaStream.getTracks().map(track => track.kind) || [];\n\n if (this._peerConnection) {\n if (!FeatureEnablement.getCurrentOfferDisabled) {\n const parsedSDP = new SdpParser(this._peerConnection.currentRemoteDescription.sdp);\n\n this._estimatedAudioCodec = parsedSDP.audioCodec;\n this._estimatedVideoCodec = parsedSDP.videoCodec;\n }\n\n this.updateStatistic();\n }\n }\n\n get rtcStatistic(): Subject<IRtcMonitorStatistic> {\n return this._rtcStatistic;\n }\n\n dispose(): void {\n this._isMonitorRunning = false;\n this._peerConnection = null;\n\n if (this._updateTimeOut) {\n clearTimeout(this._updateTimeOut);\n this._updateTimeOut = null;\n }\n }\n\n private async updateStatistic(): Promise<void> {\n if (FeatureEnablement.getStatsPromiseBasedDisabled) {\n const ignored = await this.updateStatisticLegacy();\n\n return;\n }\n\n // Safari 11 doesnt have kind or mediaType so we need to take it from the inbound-rtp object id\n const getKindForSafari11 = (item): string => item.id.includes('Audio') ? 'audio' : item.id.includes('Video') ? 'video' : '';\n const ignored = await this._peerConnection.getStats(null)\n .then(stats => {\n const rtcStats: IRtcMonitorStatistic = {};\n\n if (stats) {\n let roundTripTime = this._estimatedRoundTripTime;\n let lastPacketReceivedTimestamp;\n\n stats.forEach(report => {\n if (report.type === 'candidate-pair' && report.currentRoundTripTime) {\n roundTripTime = report.currentRoundTripTime * 1000;\n\n if (rtcStats['audio']) {\n rtcStats['audio'].roundTripTime = roundTripTime;\n }\n\n if (rtcStats['video']) {\n rtcStats['video'].roundTripTime = roundTripTime;\n }\n }\n\n if (report.type === 'candidate-pair' && report.lastPacketReceivedTimestamp) {\n lastPacketReceivedTimestamp = report.lastPacketReceivedTimestamp;\n\n if (rtcStats['audio']) {\n rtcStats['audio'].lastPacketReceivedTimestamp = lastPacketReceivedTimestamp;\n }\n\n if (rtcStats['video']) {\n rtcStats['video'].lastPacketReceivedTimestamp = lastPacketReceivedTimestamp;\n }\n }\n\n if (report.type === 'inbound-rtp') {\n const kind = report.kind || report.mediaType || getKindForSafari11(report);\n let codec = '';\n\n stats.forEach(item => {\n if (item.id === report.codecId) {\n codec = item.mimeType;\n }\n });\n\n if (kind && this._tracksToMonitor.includes(kind)) {\n rtcStats[kind] = {\n ssrc: report.ssrc,\n mediaType: kind,\n timestamp: report.timestamp,\n bytesReceived: report.bytesReceived,\n packetsLost: report.packetsLost,\n packetsReceived: report.packetsReceived,\n codec: codec || this.getCodecByType(kind),\n roundTripTime\n };\n\n if (report.lastPacketReceivedTimestamp || lastPacketReceivedTimestamp) {\n rtcStats[kind].lastPacketReceivedTimestamp = report.lastPacketReceivedTimestamp || lastPacketReceivedTimestamp;\n }\n\n if (kind === 'video' && this._rtcStatistic.value && this._rtcStatistic.value.video) {\n rtcStats[kind]['framesDecoded'] = report.framesDecoded;\n rtcStats[kind]['fps'] = (report.framesDecoded - this._rtcStatistic.value.video.framesDecoded) /\n (rtcStats[kind].timestamp - this._rtcStatistic.value.video.timestamp) *\n 1000 || 0;\n }\n }\n }\n });\n }\n\n this._rtcStatistic.value = rtcStats;\n }).then(() => {\n if (this._isMonitorRunning) {\n this._updateTimeOut = window.setTimeout(() => this.updateStatistic(), updateStatisticTimeOut);\n }\n });\n }\n\n private async updateStatisticLegacy(): Promise<void> {\n const ignored = await this._peerConnection.getStatsLegacy().then(stats => {\n const rtcStats: IRtcMonitorStatistic = {};\n let roundTripTime = this._estimatedRoundTripTime;\n\n stats.result().forEach(report => {\n report.names().forEach(name => {\n if (name === 'googRTT') {\n roundTripTime = report.stat(name);\n }\n });\n\n if (report.type === 'ssrc') {\n const mediaType = report.stat('mediaType').toString();\n\n rtcStats[mediaType] = {timestamp: Date.now()};\n rtcStats[mediaType]['ssrc'] = report.stat('ssrc').toString();\n rtcStats[mediaType]['mediaType'] = mediaType;\n rtcStats[mediaType]['bytesReceived'] = report.stat('bytesReceived');\n rtcStats[mediaType]['packetsLost'] = report.stat('packetsLost');\n rtcStats[mediaType]['packetsReceived'] = report.stat('packetsReceived');\n rtcStats[mediaType]['codec'] = report.stat('googCodecName').toString() || this.getCodecByType(mediaType);\n rtcStats[mediaType]['roundTripTime'] = roundTripTime;\n\n if (mediaType === 'video' && this._rtcStatistic.value && this._rtcStatistic.value.video) {\n rtcStats[mediaType]['framesDecoded'] = report.stat('framesDecoded');\n rtcStats[mediaType]['fps'] = (rtcStats[mediaType].framesDecoded - this._rtcStatistic.value.video.framesDecoded) /\n (rtcStats[mediaType].timestamp - this._rtcStatistic.value.video.timestamp) *\n 1000 || 0;\n }\n }\n });\n this._rtcStatistic.value = rtcStats;\n }).then(() => {\n if (this._isMonitorRunning) {\n this._updateTimeOut = window.setTimeout(() => this.updateStatistic(), updateStatisticTimeOut);\n }\n });\n }\n\n private getCodecByType(type: string): string {\n switch (type) {\n case 'audio':\n return this._estimatedAudioCodec;\n case 'video':\n return this._estimatedVideoCodec;\n default:\n return 'unknown';\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport IPeerConnection from '../../rtc/IPeerConnection';\nimport SDK from '../SDK';\nimport {IStream} from './IStream';\nimport EndPoint, {SetRemoteDescriptionStatus} from '../discovery/EndPoint';\nimport PeerConnectionService, {IPeerConnectionOfferInit} from '../../rtc/PeerConnectionService';\nimport Discovery from '../discovery/Discovery';\nimport FeatureEnablement from '../feature/FeatureEnablement';\nimport ChannelState from '../channels/ChannelState';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport RtcConnectionMonitor from '../../rtc/RtcConnectionMonitor';\nimport Durations from '../../time/Duration';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport ChannelContext from '../channels/ChannelContext';\n\nconst iceCandidateAccumulationInterval = 100;\nconst defaultStreamSetupTimeout = 30000;\n\nexport default class RealTimeStream implements IStream {\n private readonly _logger: ILogger = LoggerFactory.getLogger('RealTimeStream');\n private readonly _channelContext: ChannelContext;\n private readonly _handleStreamFailure: () => Promise<void>;\n\n constructor(channelContext, handleStreamFailure: () => Promise<void>) {\n this._channelContext = channelContext;\n this._handleStreamFailure = handleStreamFailure;\n }\n\n start(uri, token, listenOnStreamSetup, playMediaStreamInVideoElement): Promise<void> {\n return Promise.all<EndPoint, IPeerConnectionOfferInit>([\n Discovery.discoverClosestEndPointWithCaching(uri),\n PeerConnectionService.createPeerConnectionOffer()\n ])\n .then(([endPoint, {localOffer, peerConnection}]) => {\n this._channelContext.online.value = true;\n this._channelContext.endPoint.value = endPoint;\n this._logger.info('Connecting to [%s]', endPoint.toString());\n this._logger.info('Local offer:\\n' + localOffer.sdp);\n\n if (FeatureEnablement.clientOfferDisabled || !peerConnection.supportsSetConfiguration || !peerConnection.supportsGetConfiguration) {\n peerConnection.close();\n peerConnection = null;\n localOffer = null;\n }\n\n this._channelContext.peerConnection.value = peerConnection;\n\n return endPoint.subscribe(token, localOffer, this._channelContext.failureCount.value);\n })\n .then(({status, stream, rtcConfiguration, setRemoteDescriptionResponse, createOfferDescriptionResponse, createAnswerDescriptionResponse, lag}) => {\n this._channelContext.stream.value = stream;\n this._channelContext.lag.value = lag;\n\n this._channelContext.applySessionAndStreamPropertiesToVideoElement();\n\n this._logger.debug(\n '[%s] Subscribe completed [%s] [%j] [%j] [%j] [%j]',\n this._channelContext.streamId,\n status,\n rtcConfiguration,\n setRemoteDescriptionResponse,\n createOfferDescriptionResponse,\n createAnswerDescriptionResponse\n );\n\n this._channelContext.state.value = this._channelContext.mapSubscribeStatusToChannelStatus(status);\n\n this._channelContext.applyStatus(status);\n\n if (status !== 'ok') {\n return;\n }\n\n return this.applyRtcConfiguration(this._channelContext.peerConnection.value, rtcConfiguration)\n .then(peerConnection => {\n let submitCandidatesTimeout;\n let cancelDiscovery = false;\n let discoveryCompleted = false;\n const candidates: RTCIceCandidate[] = [];\n\n if (!this._channelContext.peerConnection.value) {\n this._channelContext.peerConnection.value = peerConnection;\n }\n\n peerConnection.onicecandidate = (e): void => {\n if (this._channelContext.stream.value !== stream) {\n return;\n }\n\n if (this._channelContext.peerConnection.value !== peerConnection) {\n return;\n }\n\n if (cancelDiscovery) {\n return;\n }\n\n if (!SDK.sendLocalCandidates.value) {\n return;\n }\n\n if (e.candidate && e.candidate.candidate) {\n candidates.push(e.candidate);\n } else {\n discoveryCompleted = true;\n }\n\n if (!submitCandidatesTimeout) {\n submitCandidatesTimeout = setTimeout(() => {\n if (this._channelContext.stream.value !== stream) {\n return;\n }\n\n if (cancelDiscovery) {\n return;\n }\n\n const ignored = this._channelContext.endPoint.value.addIceCandidates(stream, candidates, discoveryCompleted)\n .then(({status, options}) => {\n if (status !== 'ok') {\n this._logger.warn('[%s] Failed to add ICE candidates with reason [%s]', this._channelContext.streamId, status);\n\n return;\n }\n\n if (options.includes('cancel')) {\n cancelDiscovery = true;\n }\n\n this._logger.info('[%s] Added ICE candidates with reason [%s] and options [%s]', this._channelContext.streamId, status, options);\n })\n .catch(e => {\n this._logger.error('[%s] Failed to add ICE candidates', this._channelContext.streamId, e);\n });\n }, iceCandidateAccumulationInterval);\n }\n };\n\n peerConnection.oniceconnectionstatechange = (): void => {\n if (this._channelContext.stream.value !== stream) {\n return;\n }\n\n if (this._channelContext.peerConnection.value !== peerConnection) {\n return;\n }\n\n const retryCallback = (): void => {\n // If we stop normally the peer connection is unregistered first.\n // Thus anytime we see a closed peer connection that is still valid, it is an error.\n this._channelContext.state.value = ChannelState.Error;\n\n if (this._channelContext.videoElement.value) {\n this._channelContext.videoElement.value.pause();\n this._channelContext.videoElement.value.srcObject = null;\n }\n\n this._channelContext.playing.value = false;\n this._channelContext.loading.value = true;\n\n const ignored = this._handleStreamFailure()\n .catch(e => {\n this._logger.error(\n '[%s] Failed handling stream failure after peer connection stopped with state [%s]',\n this._channelContext.streamId,\n peerConnection.iceConnectionState,\n e\n );\n });\n };\n\n switch (peerConnection.iceConnectionState) {\n case 'checking':\n case 'completed':\n case 'connected':\n case 'new':\n return;\n\n case 'disconnected':\n case 'failed':\n if (navigator.onLine) {\n this._logger.info('[%s] ICE connection state changed to [%s], trying to reconnect', this._channelContext.streamId, peerConnection.iceConnectionState);\n this.reconnectPeerConnection(peerConnection, retryCallback);\n }\n\n return;\n case 'closed':\n this._logger.info('[%s] ICE connection state changed to [%s], retrying to connect', this._channelContext.streamId, peerConnection.iceConnectionState);\n retryCallback();\n\n return;\n default:\n assertUnreachable(peerConnection.iceConnectionState);\n }\n };\n\n const mediaStreamPromise = new Promise<MediaStream>((resolve, reject) => {\n if (!FeatureEnablement.onTrackDisabled) {\n const timeoutId = setTimeout(() => reject(new Error('Stream setup timed out')), defaultStreamSetupTimeout);\n\n peerConnection.ontrack = (e): void => {\n clearTimeout(timeoutId);\n\n resolve(e.streams[0]);\n };\n\n return;\n }\n\n const trackListener = (e): void => {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n clearTimeout(timeoutId);\n peerConnection.removeEventListener('track', trackListener);\n peerConnection.removeEventListener('addstream', trackListener);\n\n if (e.streams) {\n resolve(e.streams[0]);\n } else {\n resolve(e.stream);\n }\n };\n\n const timeoutId = setTimeout(() => {\n peerConnection.removeEventListener('track', trackListener);\n peerConnection.removeEventListener('addstream', trackListener);\n reject(new Error('Stream setup timed out'));\n }, defaultStreamSetupTimeout);\n\n peerConnection.addEventListener('track', trackListener);\n peerConnection.addEventListener('addstream', trackListener);\n\n return;\n });\n\n return new Promise(resolve => {\n resolve();\n }).then(() => {\n if (!setRemoteDescriptionResponse) {\n return;\n }\n\n this._logger.info('[%s] Set local SDP offer [%s]', this._channelContext.streamId, setRemoteDescriptionResponse.sessionDescription.sdp);\n\n return peerConnection.setLocalDescription(setRemoteDescriptionResponse.sessionDescription);\n }).then(() => {\n if (!createAnswerDescriptionResponse) {\n return;\n }\n\n this._logger.info('[%s] Set remote SDP answer [%s]', this._channelContext.streamId, createAnswerDescriptionResponse.sessionDescription.sdp);\n\n return peerConnection.setRemoteDescription(createAnswerDescriptionResponse.sessionDescription);\n }).then(() => {\n if (!createOfferDescriptionResponse) {\n return;\n }\n\n this._logger.info('[%s] Set remote SDP offer [%s]', this._channelContext.streamId, createOfferDescriptionResponse.sessionDescription.sdp);\n\n return peerConnection.setRemoteDescription(createOfferDescriptionResponse.sessionDescription)\n .then(() => {\n return peerConnection.createAnswer({\n offerToReceiveAudio: true,\n offerToReceiveVideo: true\n });\n }).then(answer => {\n this._logger.info('[%s] Set local SDP answer [%j]', this._channelContext.streamId, answer);\n\n return this._channelContext.endPoint.value.setRemoteDescription(stream, answer);\n }).then(({status, sessionDescription}) => {\n this._channelContext.state.value = this.mapSetRemoteDescriptionStatusToChannelStatus(status);\n\n if (status !== 'ok') {\n this._channelContext.playing.value = false;\n this._channelContext.standby.value = true;\n this._channelContext.stopped.value = false;\n\n return;\n }\n\n return peerConnection.setLocalDescription(sessionDescription);\n });\n }).then(() => {\n listenOnStreamSetup.success(this._channelContext.streamId);\n\n return mediaStreamPromise;\n }).then(mediaStream => {\n this._channelContext.mediaStream.value = mediaStream;\n\n const rtcConnectionMonitor = new RtcConnectionMonitor(peerConnection, mediaStream, this._channelContext.endPoint.value.roundTripTime / 4);\n\n this._channelContext.disposables.add(rtcConnectionMonitor);\n\n const ignored = rtcConnectionMonitor.rtcStatistic.subscribe(statistics => {\n this._channelContext.rtcStatistics.value = statistics;\n\n if (!this._channelContext.rtcVideoStatistic && !this._channelContext.rtcAudioStatistic) {\n this._channelContext.rtcAudioStatistic = statistics.audio;\n this._channelContext.rtcVideoStatistic = statistics.video;\n\n return;\n }\n\n let audioTrackFailed = false;\n let videoTrackFailed = false;\n\n if (statistics.audio) {\n if (this._channelContext.rtcAudioStatistic && this._channelContext.rtcAudioStatistic.timestamp !== statistics.audio.timestamp) {\n audioTrackFailed = this._channelContext.rtcAudioStatistic && this._channelContext.rtcAudioStatistic.bytesReceived === statistics.audio.bytesReceived;\n\n if (audioTrackFailed && navigator.onLine) {\n this._logger.info(\n '[%s] Audio track failed with last bytesReceived [%s] is equal to previous bytesReceived [%s] within [%s]',\n this._channelContext.streamId,\n statistics.audio.bytesReceived,\n this._channelContext.rtcAudioStatistic.bytesReceived,\n new Durations(statistics.audio.timestamp - this._channelContext.rtcAudioStatistic.timestamp).toIsoString()\n );\n }\n\n this._channelContext.rtcAudioStatistic = statistics.audio;\n }\n }\n\n if (statistics.video) {\n if (this._channelContext.rtcVideoStatistic && this._channelContext.rtcVideoStatistic.timestamp !== statistics.video.timestamp) {\n videoTrackFailed = this._channelContext.rtcVideoStatistic && this._channelContext.rtcVideoStatistic.bytesReceived === statistics.video.bytesReceived;\n\n if (videoTrackFailed && navigator.onLine) {\n this._logger.info(\n '[%s] Video track failed with last bytesReceived [%s] is equal to previous bytesReceived [%s] within [%s]',\n this._channelContext.streamId,\n statistics.video.bytesReceived,\n this._channelContext.rtcVideoStatistic.bytesReceived,\n new Durations(statistics.video.timestamp - this._channelContext.rtcVideoStatistic.timestamp).toIsoString()\n );\n }\n\n this._channelContext.rtcVideoStatistic = statistics.video;\n }\n }\n\n if ((videoTrackFailed || audioTrackFailed) && navigator.onLine) {\n const retryCallback = (): void => {\n this._channelContext.state.value = ChannelState.Error;\n\n if (this._channelContext.videoElement.value) {\n this._channelContext.videoElement.value.pause();\n this._channelContext.videoElement.value.srcObject = null;\n }\n\n this._channelContext.playing.value = false;\n this._channelContext.loading.value = true;\n\n rtcConnectionMonitor.dispose();\n\n const ignored = this._handleStreamFailure()\n .catch(e => {\n this._logger.error(\n '[%s] Failed handling stream failure after track stopped with state [%s]',\n this._channelContext.streamId,\n peerConnection.iceConnectionState,\n e\n );\n });\n };\n\n this.reconnectPeerConnection(peerConnection, retryCallback);\n } else {\n this._channelContext.peerConnectionReconnectAttempts = 0;\n }\n });\n\n if (!SDK.automaticallyPlayMediaStream) {\n this._channelContext.autoMuted.value = false;\n this._channelContext.autoPaused.value = true;\n this._channelContext.loading.value = false;\n this._channelContext.playing.value = false;\n this._channelContext.state.value = ChannelState.Paused;\n\n return;\n }\n\n return playMediaStreamInVideoElement(mediaStream);\n });\n });\n });\n }\n\n private async applyRtcConfiguration(\n optionalPeerConnection: IPeerConnection | null,\n rtcConfiguration: RTCConfiguration): Promise<IPeerConnection> {\n if (!optionalPeerConnection) {\n rtcConfiguration = this.truncateIceServers(rtcConfiguration);\n\n return SDK.peerConnectionFactory.value.createPeerConnection(rtcConfiguration);\n }\n\n const newRtcConfiguration = {\n ...optionalPeerConnection.getConfiguration(),\n ...rtcConfiguration\n };\n\n optionalPeerConnection.setConfiguration(newRtcConfiguration);\n\n return optionalPeerConnection;\n }\n\n private truncateIceServers(configuration: RTCConfiguration): RTCConfiguration {\n const iceServers: RTCIceServer[] = [];\n\n for (let i = 0; i < configuration.iceServers.length; i++) {\n const urls: string[] = [];\n\n for (let index = 0; index < 2; index++) {\n const url = configuration.iceServers[i].urls[index];\n\n if (url) {\n urls.push(configuration.iceServers[i].urls[index]);\n }\n }\n\n iceServers.push({\n urls: urls,\n username: configuration.iceServers[i].username,\n credential: configuration.iceServers[i].credential\n });\n }\n\n configuration.iceServers = iceServers;\n\n return configuration;\n }\n\n private reconnectPeerConnection(peerConnection: IPeerConnection, retryCallback: () => void): void {\n if (peerConnection.iceConnectionState === 'closed') {\n return;\n }\n\n this._channelContext.state.value = ChannelState.Reconnecting;\n\n if (this._channelContext.peerConnectionReconnectAttempts < SDK.maximalNumberOfPeerConnectionReconnectAttempts || !SDK.automaticallyReconnectPeerConnection) {\n this._channelContext.peerConnectionReconnectAttempts++;\n\n if (FeatureEnablement.clientOfferDisabled ||\n !peerConnection.supportsSetConfiguration ||\n !peerConnection.supportsGetConfiguration ||\n this._channelContext.failureCount.value\n ) {\n return;\n }\n\n this._logger.info('Reconnecting peer connection by restarting ICE');\n\n const localOffer = peerConnection.currentLocalDescription;\n const ignored = peerConnection.createOffer({iceRestart: true}).then(offer => {\n return peerConnection.setLocalDescription(offer).then(() => {\n return peerConnection.setLocalDescription(localOffer);\n });\n })\n .catch(e => {\n this._logger.error('Failed to reconnect peer connection', e);\n this._channelContext.peerConnectionReconnectAttempts = 0;\n retryCallback();\n });\n\n return;\n }\n\n this._logger.info('Failed to reconnect peer connection after [%s] attempts, performing full recovery', this._channelContext.peerConnectionReconnectAttempts);\n this._channelContext.peerConnectionReconnectAttempts = 0;\n retryCallback();\n }\n\n private mapSetRemoteDescriptionStatusToChannelStatus(status: SetRemoteDescriptionStatus): ChannelState {\n switch (status) {\n case 'ok':\n return ChannelState.Starting;\n case 'unauthorized':\n return ChannelState.Unauthorized;\n case 'not-found':\n case 'capacity':\n case 'rate-limited':\n case 'timeout':\n return ChannelState.Recovering;\n case 'failed':\n return ChannelState.Error;\n default:\n assertUnreachable(status);\n }\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport {IStream} from './IStream';\nimport EdgeAuth from '../edgeAuth/EdgeAuth';\nimport RealTimeStream from './RealTimeStream';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport ChannelState from '../channels/ChannelState';\n\nexport default class RealTimeStreamFactory {\n private static _logger: ILogger = LoggerFactory.getLogger('Streaming');\n\n static create(token: string, channelContext, handleStreamFailure: () => Promise<void>): IStream {\n const parsedToken = EdgeAuth.parseToken(token);\n const isRtmp = parsedToken && parsedToken.token && parsedToken.token.capabilities && parsedToken.token.capabilities.includes('rtmp');\n\n if (isRtmp) {\n this._logger.error('This build does not support RTMP playback.');\n channelContext.state.value = ChannelState.UnsupportedFeature;\n\n return;\n }\n\n const isStreaming = parsedToken && parsedToken.token && parsedToken.token.capabilities && parsedToken.token.capabilities.includes('streaming');\n\n if (isStreaming) {\n this._logger.error('This build does not support Live Stream playback.');\n channelContext.state.value = ChannelState.UnsupportedFeature;\n\n return;\n }\n\n return new RealTimeStream(channelContext, handleStreamFailure);\n }\n\n constructor() {\n throw new Error('RealTimeStreamFactory is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\nimport LoggerFactory from '../../logger/LoggerFactory';\nimport IDisposable from '../../lang/IDisposable';\nimport ReadOnlySubject from '../../rx/ReadOnlySubject';\nimport Dimension from '../../video/Dimension';\nimport EndPoint, {IStream} from '../discovery/EndPoint';\nimport SDK from '../SDK';\nimport IPeerConnection from '../../rtc/IPeerConnection';\nimport ChannelState from './ChannelState';\nimport assertUnreachable from '../../lang/assertUnreachable';\nimport Disposable from '../../lang/Disposable';\nimport EdgeAuth from '../edgeAuth/EdgeAuth';\nimport {ILogger} from '../../logger/LoggerInterface';\nimport VideoTelemetry from '../../video/VideoTelemetry';\nimport SessionTelemetry from '../../video/SessionTelemetry';\nimport {IRtcMonitorStatistic} from '../../rtc/RtcConnectionMonitor';\nimport {BitrateMode, BitrateState} from '../api/SetTemporaryMaximalBitrate';\n\nimport {EdgeToken} from '../edgeAuth/EdgeToken';\nimport {BitsPerSecond, Millisecond} from '../../units/Units';\nimport ChannelContext from './ChannelContext';\nimport StreamFactory from '../streaming/StreamFactory';\nimport DiscoveryUri from '../discovery/DiscoveryUri';\nimport MetricsFactory from '../../metrics/MetricsFactory';\nimport MetricsService from '../../metrics/MetricsService';\n\nconst defaultTargetLag = 0;\nconst defaultStreamTerminationReason = 'client:termination';\nconst backoffIntervalInMilliseconds = 2000;\nconst failureCountCleanUpIntervalInMilliseconds = 3000;\nconst maxBackoffIntervalInMilliseconds = 300000;\nconst standbyPollingIntervalInMilliseconds = 15000;\n\nexport default class Channel implements IDisposable {\n private readonly _logger: ILogger = LoggerFactory.getLogger('Channel');\n private readonly _context: ChannelContext;\n private readonly _channelStartTime: number;\n private readonly _readOnlyVideoElement: ReadOnlySubject<HTMLVideoElement>;\n private readonly _readOnlyToken: ReadOnlySubject<EdgeToken>;\n private readonly _readOnlyPeerConnection: ReadOnlySubject<IPeerConnection>;\n private readonly _readOnlyState: ReadOnlySubject<ChannelState>;\n private readonly _readOnlyAutoMuted: ReadOnlySubject<boolean>;\n private readonly _readOnlyAutoPaused: ReadOnlySubject<boolean>;\n private readonly _readOnlyTokenExpiring: ReadOnlySubject<boolean>;\n private readonly _readOnlyAuthorized: ReadOnlySubject<boolean>;\n private readonly _readOnlyOnline: ReadOnlySubject<boolean>;\n private readonly _readOnlyLoading: ReadOnlySubject<boolean>;\n private readonly _readOnlyPlaying: ReadOnlySubject<boolean>;\n private readonly _readOnlyStandby: ReadOnlySubject<boolean>;\n private readonly _readOnlyStopped: ReadOnlySubject<boolean>;\n private readonly _readOnlyTargetLag: ReadOnlySubject<Millisecond>;\n private readonly _readOnlyLag: ReadOnlySubject<Millisecond>;\n private readonly _readOnlyBitrateLimit: ReadOnlySubject<BitsPerSecond>;\n private readonly _readOnlyResolution: ReadOnlySubject<Dimension>;\n private readonly _readOnlyFailureCount: ReadOnlySubject<number>;\n private readonly _readOnlyEndPoint: ReadOnlySubject<EndPoint>;\n private readonly _readOnlyStream: ReadOnlySubject<IStream>;\n private readonly _readOnlyRtcStatistics: ReadOnlySubject<IRtcMonitorStatistic>;\n private readonly _readOnlyMediaStream: ReadOnlySubject<MediaStream>;\n\n private _metricsService: MetricsService;\n private readonly _videoMetaDataChangedHandler: () => void;\n\n constructor(videoElement: HTMLVideoElement, token: string, targetLag: number = defaultTargetLag) {\n this._context = new ChannelContext(token, targetLag);\n this._channelStartTime = Date.now();\n this._readOnlyVideoElement = new ReadOnlySubject<HTMLVideoElement>(this._context.videoElement);\n this._readOnlyToken = new ReadOnlySubject<string>(this._context.token);\n this._readOnlyPeerConnection = new ReadOnlySubject<IPeerConnection>(this._context.peerConnection);\n this._readOnlyState = new ReadOnlySubject<ChannelState>(this._context.state);\n this._readOnlyAutoMuted = new ReadOnlySubject<boolean>(this._context.autoMuted);\n this._readOnlyAutoPaused = new ReadOnlySubject<boolean>(this._context.autoPaused);\n this._readOnlyTokenExpiring = new ReadOnlySubject<boolean>(this._context.tokenExpiring);\n this._readOnlyAuthorized = new ReadOnlySubject<boolean>(this._context.authorized);\n this._readOnlyOnline = new ReadOnlySubject<boolean>(this._context.online);\n this._readOnlyLoading = new ReadOnlySubject<boolean>(this._context.loading);\n this._readOnlyPlaying = new ReadOnlySubject<boolean>(this._context.playing);\n this._readOnlyStandby = new ReadOnlySubject<boolean>(this._context.standby);\n this._readOnlyStopped = new ReadOnlySubject<boolean>(this._context.stopped);\n this._readOnlyTargetLag = new ReadOnlySubject<number>(this._context.targetLag);\n this._readOnlyLag = new ReadOnlySubject<number>(this._context.lag);\n this._readOnlyBitrateLimit = new ReadOnlySubject<number>(this._context.bitrateLimit);\n this._readOnlyResolution = new ReadOnlySubject<Dimension>(this._context.resolution);\n this._readOnlyFailureCount = new ReadOnlySubject<number>(this._context.failureCount);\n this._readOnlyEndPoint = new ReadOnlySubject<EndPoint>(this._context.endPoint);\n this._readOnlyStream = new ReadOnlySubject<IStream>(this._context.stream);\n this._readOnlyRtcStatistics = new ReadOnlySubject<IRtcMonitorStatistic>(this._context.rtcStatistics);\n this._readOnlyMediaStream = new ReadOnlySubject<MediaStream>(this._context.mediaStream);\n\n const parsedToken = EdgeAuth.parseToken(this._context.token.value);\n const discoveryUri = (EdgeAuth.getUri(parsedToken) || SDK.discoveryUri.value).toString();\n\n SDK.tenancy.value = EdgeAuth.getTenancy(parsedToken) || SDK.tenancy.value;\n DiscoveryUri.uri.value = discoveryUri;\n this._metricsService = MetricsFactory.getMetricsService(discoveryUri);\n this._context.sessionTelemetry = new SessionTelemetry(SDK.pageLoadTime, this._metricsService);\n this._context.channelDisposables.add(this._context.sessionTelemetry);\n this._videoMetaDataChangedHandler = this.handleVideoMetaDataChanged.bind(this);\n this.videoElement = videoElement;\n\n this._context.channelDisposables.add(\n this._context.videoElement.subscribe(videoElement => {\n this._context.rendererDisposables.dispose();\n\n if (!videoElement) {\n return;\n }\n\n this._context.rendererDisposables.add(this._context.stream.subscribe(stream => {\n if (this._context.videoTelemetry) {\n this._context.videoTelemetry.dispose();\n }\n\n if (!stream) {\n return;\n }\n\n if (!this.videoElement) {\n return;\n }\n\n if (this.videoElement.dataset) {\n this.videoElement.dataset.sessionId = SDK.clientSessionId;\n this.videoElement.dataset.streamId = this.streamId;\n }\n\n this._context.videoTelemetry = new VideoTelemetry(this.streamId, SDK.pageLoadTime, this._channelStartTime, this._metricsService);\n this._context.videoTelemetry.setupListenerForTimeToFirstTime(this.videoElement);\n this._context.videoTelemetry.setupListenerForRebuffering(this.videoElement);\n\n if (this._context.state.value === ChannelState.Stopped) {\n const ignored = this.restartAfterStop();\n }\n }));\n\n this._context.channelDisposables.add(this._context.rendererDisposables);\n }));\n this._context.channelDisposables.add(\n this._context.state.subscribe(state => {\n if (this._context.clearFailureCountTimeout) {\n clearTimeout(this._context.clearFailureCountTimeout);\n }\n\n if (!this._context.failureCount.value) {\n return;\n }\n\n if (state !== ChannelState.Playing) {\n return;\n }\n\n this._context.clearFailureCountTimeout = window.setTimeout(() => {\n this._context.failureCount.value = 0;\n }, failureCountCleanUpIntervalInMilliseconds);\n }));\n this._context.channelDisposables.add(\n this._context.resolution.subscribe(resolution => {\n if (this._context.videoTelemetry) {\n this._context.videoTelemetry.onVideoResolutionChanges(resolution.toString());\n }\n }));\n this._context.channelDisposables.add(\n this._context.bitrateLimit.subscribe(bitrateLimit => {\n if (bitrateLimit && this._context.endPoint.value && this._context.stream.value) {\n const elapsedInMilliseconds = Date.now() - this._context.channelInitialization.getTime();\n const ignored = this._context.endPoint.value.limitBitrate(\n this._context.stream.value,\n elapsedInMilliseconds,\n bitrateLimit,\n BitrateState.Keep,\n BitrateMode.Normal\n )\n .catch(e => {\n this._logger.error('Error while setting limit bitrate', e);\n });\n }\n })\n );\n\n this.start();\n }\n\n get videoElement(): HTMLVideoElement {\n return this._context.videoElement.value;\n }\n\n set videoElement(videoElement: HTMLVideoElement) {\n if (this._context.videoElement.value) {\n this._context.videoElement.value.removeEventListener('loadeddata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.removeEventListener('loadedmetadata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.removeEventListener('resize', this._videoMetaDataChangedHandler);\n\n if (this._context.videoElement.value.dataset) {\n this._context.videoElement.value.dataset.sessionId = '';\n this._context.videoElement.value.dataset.streamId = '';\n }\n\n this._context.rendererDisposables.dispose();\n\n this._context.videoElement.value.pause();\n this._context.videoElement.value.srcObject = null;\n }\n\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Stopped;\n\n this._context.videoElement.value = videoElement;\n\n if (this._context.videoElement.value) {\n this._context.videoElement.value.addEventListener('loadeddata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.addEventListener('loadedmetadata', this._videoMetaDataChangedHandler);\n this._context.videoElement.value.addEventListener('resize', this._videoMetaDataChangedHandler);\n }\n }\n\n private handleVideoMetaDataChanged(): void {\n const videoElement = this._context.videoElement.value;\n\n if (videoElement) {\n if (this.resolution.value.width !== videoElement.videoWidth || this.resolution.value.height !== videoElement.videoHeight) {\n this._context.resolution.value = new Dimension(videoElement.videoWidth, videoElement.videoHeight);\n }\n } else {\n this._context.resolution.value = Dimension.empty;\n }\n }\n\n get token(): EdgeToken {\n return this._context.token.value;\n }\n\n set token(token: EdgeToken) {\n this._context.disposables.dispose();\n\n this._context.token.value = token;\n this._context.tokenExpiring.value = false;\n\n const parsedToken = EdgeAuth.parseToken(this._context.token.value);\n const discoveryUri = (EdgeAuth.getUri(parsedToken) || SDK.discoveryUri.value).toString();\n\n SDK.tenancy.value = EdgeAuth.getTenancy(parsedToken) || SDK.tenancy.value;\n DiscoveryUri.uri.value = discoveryUri;\n\n this._metricsService = MetricsFactory.getMetricsService(discoveryUri);\n\n this.start();\n }\n\n get peerConnection(): ReadOnlySubject<IPeerConnection> {\n return this._readOnlyPeerConnection;\n }\n\n get state(): ReadOnlySubject<ChannelState> {\n return this._readOnlyState;\n }\n\n get autoMuted(): ReadOnlySubject<boolean> {\n return this._readOnlyAutoMuted;\n }\n\n get autoPaused(): ReadOnlySubject<boolean> {\n return this._readOnlyAutoPaused;\n }\n\n get tokenExpiring(): ReadOnlySubject<boolean> {\n return this._readOnlyTokenExpiring;\n }\n\n get authorized(): ReadOnlySubject<boolean> {\n return this._readOnlyAuthorized;\n }\n\n get online(): ReadOnlySubject<boolean> {\n return this._readOnlyOnline;\n }\n\n get loading(): ReadOnlySubject<boolean> {\n return this._readOnlyLoading;\n }\n\n get playing(): ReadOnlySubject<boolean> {\n return this._readOnlyPlaying;\n }\n\n get standby(): ReadOnlySubject<boolean> {\n return this._readOnlyStandby;\n }\n\n get stopped(): ReadOnlySubject<boolean> {\n return this._readOnlyStopped;\n }\n\n get targetLag(): ReadOnlySubject<Millisecond> {\n return this._readOnlyTargetLag;\n }\n\n get lag(): ReadOnlySubject<Millisecond> {\n return this._readOnlyLag;\n }\n\n get bitrateLimit(): number {\n return this._readOnlyBitrateLimit.value;\n }\n\n get resolution(): ReadOnlySubject<Dimension> {\n return this._readOnlyResolution;\n }\n\n get failureCount(): ReadOnlySubject<number> {\n return this._readOnlyFailureCount;\n }\n\n get endPoint(): ReadOnlySubject<EndPoint> {\n return this._readOnlyEndPoint;\n }\n\n get stream(): ReadOnlySubject<IStream> {\n return this._readOnlyStream;\n }\n\n get streamId(): string {\n return this._context.streamId;\n }\n\n get rtcStats(): ReadOnlySubject<IRtcMonitorStatistic> {\n return this._readOnlyRtcStatistics;\n }\n\n get mediaStream(): ReadOnlySubject<MediaStream> {\n return this._readOnlyMediaStream;\n }\n\n setBitrateLimit(bitrateLimit: BitsPerSecond): void {\n this._context.bitrateLimit.value = bitrateLimit;\n }\n\n clearBitrateLimit(): void {\n if (this._context.bitrateLimit.value && this._context.endPoint.value && this._context.stream.value) {\n const elapsedInMilliseconds = Date.now() - this._context.channelInitialization.getTime();\n const bitrateInBitsPerSecond = 0;\n const ignored = this._context.endPoint.value.limitBitrate(\n this._context.stream.value,\n elapsedInMilliseconds,\n bitrateInBitsPerSecond,\n BitrateState.Keep,\n BitrateMode.Reset\n )\n .then(({status}) => {\n if (status === 'ok') {\n this._context.bitrateLimit.value = 0;\n }\n })\n .catch(e => {\n this._logger.error('Error while setting limit bitrate', e);\n });\n }\n }\n\n updateTargetLag(lag: Millisecond): void {\n this._context.targetLag.value = lag;\n }\n\n async stop(reason: string): Promise<void> {\n return new Promise(resolve => {\n if (!this._context.isStarting.value) {\n this.processStop(reason);\n\n resolve();\n\n return;\n }\n\n this._context.rendererDisposables.add(this._context.isStarting.subscribe(isStarting => {\n if (!isStarting) {\n this.processStop(reason);\n resolve();\n }\n }));\n });\n }\n\n private processStop(reason: string): void {\n if (this._context.videoElement.value) {\n this._context.videoElement.value.pause();\n this._context.videoElement.value.srcObject = null;\n }\n\n this._context.rendererDisposables.dispose();\n\n this.cleanUpResources(reason);\n\n this._context.state.value = ChannelState.Stopped;\n }\n\n async resume(): Promise<void> {\n if (this._context.mediaStream.value) {\n this._context.autoPaused.value = false;\n\n return this.playMediaStreamInVideoElement(this._context.mediaStream.value);\n }\n }\n\n mute(): void {\n const videoElement = this._context.videoElement.value;\n\n if (videoElement) {\n videoElement.muted = true;\n }\n }\n\n unmute(): void {\n const videoElement = this._context.videoElement.value;\n\n if (videoElement) {\n videoElement.muted = false;\n this._context.autoMuted.value = false;\n }\n }\n\n async dispose(): Promise<void> {\n return this.stop('client:channel-dispose').then(() => {\n this._context.channelDisposables.dispose();\n this._context.isDisposed = true;\n });\n }\n\n getUri(token): URL {\n const parsedToken = EdgeAuth.parseToken(token);\n const url = EdgeAuth.getUri(parsedToken);\n\n if (url) {\n return url;\n }\n\n this._logger.info('Fall back to the default discover URI [%s]', SDK.discoveryUri.value);\n\n return new URL(SDK.discoveryUri.value);\n }\n\n async start(): Promise<void> {\n if (this._context.isDisposed) {\n throw new Error('Channel was already disposed');\n }\n\n if (this._context.isStarting.value) {\n this._logger.info('Channel is already starting, skipping start');\n\n return;\n }\n\n this._context.isStarting.value = true;\n\n return this.processStart()\n .finally(() => {\n this._context.isStarting.value = false;\n });\n }\n\n private async processStart(): Promise<void> {\n const token = this._context.token.value;\n const listenOnStreamSetup = this._context.sessionTelemetry.listenOnStreamSetup();\n\n if (!EdgeAuth.isValidToken(token)) {\n this._logger.error('Failed to parse token [%s]', token);\n this._context.state.value = ChannelState.Unauthorized;\n this._context.authorized.value = false;\n\n return;\n }\n\n this.cleanUpResources('client:start');\n this._context.state.value = ChannelState.Starting;\n this._context.loading.value = true;\n\n const uri = this.getUri(token);\n const handleStreamFailureCallback: () => Promise<void> = () => new Promise((resolve): void => {\n // Need to set isStarting to false and call handleStreamFailure if stream monitors found an issue\n this._context.isStarting.value = false;\n\n return resolve(this.handleStreamFailure());\n });\n const streamPlayer = StreamFactory.create(token, this._context, handleStreamFailureCallback);\n\n if (!streamPlayer) {\n return;\n }\n\n return streamPlayer.start(\n uri,\n token,\n listenOnStreamSetup,\n this.playMediaStreamInVideoElement.bind(this))\n .then(() => {\n this._context.loading.value = false;\n })\n .catch(e => {\n listenOnStreamSetup.fail();\n\n this._context.failureCount.value++;\n\n this._context.online.value = false;\n\n this.cleanUpResources('client:cleanup-after-failed-setup');\n\n this._context.state.value = ChannelState.Error;\n\n this._logger.error('Failed to start channel', e);\n })\n .finally(() => {\n if (this._context.state.value === ChannelState.Playing || !SDK.automaticRetryOnFailure) {\n return;\n }\n\n const timeoutId = setTimeout(() => {\n const ignored = this.handleStreamFailure()\n .catch(e => {\n this._logger.error('Failed handling stream failure', e);\n });\n }, this.getRetryInterval());\n\n this._context.disposables.add(new Disposable(() => {\n clearTimeout(timeoutId);\n }));\n });\n }\n\n private async restartAfterStop(): Promise<void> {\n if (this._context.isDisposed) {\n throw new Error('Channel was already disposed');\n }\n\n if (this._context.mediaStream.value) {\n return this.playMediaStreamInVideoElement(this._context.mediaStream.value);\n }\n\n if (this._context.token.value) {\n const ignored = this.start();\n }\n }\n\n public async play(): Promise<void> {\n const mediaStream = this._context.mediaStream.value;\n\n if (!mediaStream) {\n return this.start();\n }\n\n return this.playMediaStreamInVideoElement(mediaStream);\n }\n\n private getRetryInterval(): number {\n switch (this._context.state.value) {\n case ChannelState.StandBy:\n case ChannelState.Offline:\n return standbyPollingIntervalInMilliseconds;\n case ChannelState.Error:\n case ChannelState.Recovering:\n case ChannelState.Unauthorized:\n case ChannelState.GeoRestricted:\n case ChannelState.GeoBlocked:\n case ChannelState.Stopped:\n case ChannelState.Starting:\n case ChannelState.Playing:\n case ChannelState.Paused:\n case ChannelState.Reconnecting:\n case ChannelState.UnsupportedFeature:\n // First and second attempt fast, after that exponential with backoff interval\n return Math.min(maxBackoffIntervalInMilliseconds, Math.pow(backoffIntervalInMilliseconds, Math.max(0, this._context.failureCount.value - 1)));\n default:\n assertUnreachable(this._context.state.value);\n }\n }\n\n private async handleStreamFailure(): Promise<void> {\n switch (this._context.state.value) {\n case ChannelState.Error:\n case ChannelState.Reconnecting:\n case ChannelState.StandBy:\n case ChannelState.Offline:\n case ChannelState.Recovering:\n this._logger.info('Retry start with initial state [%s] [%s]', this._context.state.value, ChannelState[this._context.state.value]);\n\n break;\n case ChannelState.Unauthorized:\n this._logger.info('Channel is unauthorized, skipping retry of start. Please provide a new token and invoke start()');\n\n return;\n case ChannelState.GeoRestricted:\n this._logger.info('Channel is geo restricted, skipping retry of start. Please provide a new token and invoke start()');\n\n return;\n case ChannelState.GeoBlocked:\n this._logger.info('Channel is geo blocked, skipping retry of start. Please provide a new token and invoke start()');\n\n return;\n case ChannelState.Stopped:\n this._logger.info('Channel is stopped, skipping retry of start.');\n\n return;\n case ChannelState.Playing:\n this._logger.info('Channel is playing, skipping retry of start');\n\n return;\n case ChannelState.Paused:\n this._logger.info('Channel is paused, skipping retry of start. Please invoke play()');\n\n return;\n case ChannelState.Starting:\n this._logger.info('Channel is already starting, skipping retry of start');\n\n return;\n case ChannelState.UnsupportedFeature:\n this._logger.info('Channel is stopped due to unsupported feature, skipping retry of start.');\n\n return;\n default:\n assertUnreachable(this._context.state.value);\n }\n\n return this.start();\n }\n\n private cleanUpResources(reason: string = defaultStreamTerminationReason): void {\n this._context.disposables.dispose();\n\n const peerConnection = this._context.peerConnection.value;\n\n if (peerConnection) {\n this._context.peerConnection.value = null;\n peerConnection.close();\n }\n\n if (this._context.mediaStream.value) {\n this._context.mediaStream.value.getTracks().forEach(track => track.stop());\n this._context.mediaStream.value = null;\n }\n\n this._context.autoPaused.value = false;\n this._context.autoMuted.value = false;\n this._context.playing.value = false;\n this._context.stopped.value = true;\n this._context.standby.value = false;\n\n if (this._context.stream.value && this._context.endPoint.value) {\n const ignored = this._context.endPoint.value.destroyStream(this._context.stream.value, reason)\n .then(({status}) => {\n if (status !== 'ok') {\n this._logger.warn('[%s] Failed to destroy stream with reason [%s]', this.streamId, status);\n\n return;\n }\n\n this._logger.info('[%s] Destroyed stream with reason [%s]', this.streamId, status);\n })\n .catch(e => {\n this._logger.error('[%s] Failed to destroy stream', this.streamId, e);\n });\n }\n\n if (this.videoElement && this.videoElement.dataset) {\n this.videoElement.dataset.sessionId = '';\n this.videoElement.dataset.streamId = '';\n }\n\n this._context.stream.value = null;\n this._context.endPoint.value = null;\n this._context.peerConnectionReconnectAttempts = 0;\n }\n\n private async playMediaStreamInVideoElement(mediaStream: MediaStream): Promise<void> {\n const videoElement = this._context.videoElement.value;\n\n if (!videoElement) {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Stopped;\n\n return;\n }\n\n videoElement.srcObject = mediaStream;\n\n const playPromise = videoElement.play();\n\n if (playPromise === undefined) {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = true;\n this._context.state.value = ChannelState.Playing;\n\n return;\n }\n\n return playPromise.then(() => {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = true;\n this._context.state.value = ChannelState.Playing;\n }).catch(e => {\n const hasAudioTrack = !!mediaStream.getTracks().filter(track => {\n return track.kind === 'audio';\n });\n const automaticallyMuteVideoOnPlayFailureOff = !SDK.automaticallyMuteVideoOnPlayFailure;\n\n if (automaticallyMuteVideoOnPlayFailureOff || videoElement.muted || !hasAudioTrack) {\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = true;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Paused;\n\n if (automaticallyMuteVideoOnPlayFailureOff) {\n this._logger.info('[%s] Paused video after play failed. Manual user action required.', this.streamId, e);\n videoElement.srcObject = null;\n\n return;\n }\n\n if (hasAudioTrack) {\n this._logger.info('[%s] Failed to play video. Manual user action required.', this.streamId, e);\n\n return;\n }\n\n this._logger.info('[%s] Failed to play muted video. Manual user action required.', this.streamId, e);\n\n return;\n }\n\n videoElement.muted = true;\n\n return videoElement.play()\n .then(() => {\n this._logger.info('[%s] Played video after auto muting. Manual user action required to unmute.', this.streamId);\n\n this._context.autoMuted.value = true;\n this._context.autoPaused.value = false;\n this._context.loading.value = false;\n this._context.playing.value = true;\n this._context.state.value = ChannelState.Playing;\n }).catch(e => {\n videoElement.muted = false;\n\n this._logger.info('[%s] Failed to play video. Manual user action required.', this.streamId, e);\n\n this._context.autoMuted.value = false;\n this._context.autoPaused.value = true;\n this._context.loading.value = false;\n this._context.playing.value = false;\n this._context.state.value = ChannelState.Paused;\n });\n });\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport Channel from './Channel';\nimport SDK from '../SDK';\nimport {EdgeToken} from '../edgeAuth/EdgeToken';\nimport {Millisecond} from '../../units/Units';\n\ntype CreateChannelOptions = {\n videoElement: HTMLVideoElement;\n token: EdgeToken;\n targetLag?: Millisecond;\n}\n\nexport default class Channels {\n static createChannel(options: CreateChannelOptions): Channel {\n if (!SDK.initialized.value) {\n throw new Error('SDK is not loaded.');\n }\n\n return new Channel(options.videoElement, options.token, options.targetLag);\n }\n\n private constructor() {\n throw new Error('Channels is a static class that may not be instantiated');\n }\n}","/**\n * Copyright 2022 Phenix Real Time Solutions, Inc. Confidential and Proprietary. All Rights Reserved.\n */\n\nimport SDK from '../SDK';\nimport Channels from '../channels/Channels';\nimport ChannelState from '../channels/ChannelState';\n\nexport {\n SDK,\n Channels,\n ChannelState\n};\n\nexport default {\n SDK,\n Channels,\n ChannelState\n};","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n IteratorPrototype[iteratorSymbol] = function () {\n return this;\n };\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n GeneratorFunctionPrototype.constructor = GeneratorFunction;\n GeneratorFunctionPrototype[toStringTagSymbol] =\n GeneratorFunction.displayName = \"GeneratorFunction\";\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n prototype[method] = function(arg) {\n return this._invoke(method, arg);\n };\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n if (!(toStringTagSymbol in genFun)) {\n genFun[toStringTagSymbol] = \"GeneratorFunction\";\n }\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n return this;\n };\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n Gp[toStringTagSymbol] = \"Generator\";\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n Gp[iteratorSymbol] = function() {\n return this;\n };\n\n Gp.toString = function() {\n return \"[object Generator]\";\n };\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// module exports must be returned from runtime so entry inlining is disabled\n// startup\n// Load entry module and return exports\nreturn __webpack_require__(190);\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => module['default'] :\n\t\t() => module;\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop)","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};"],"sourceRoot":""}