@webex/internal-plugin-metrics 3.0.0-beta.2 → 3.0.0-beta.200
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -3
- package/dist/batcher.js +3 -22
- package/dist/batcher.js.map +1 -1
- package/dist/call-diagnostic/call-diagnostic-metrics-batcher.js +56 -0
- package/dist/call-diagnostic/call-diagnostic-metrics-batcher.js.map +1 -0
- package/dist/call-diagnostic/call-diagnostic-metrics-latencies.js +451 -0
- package/dist/call-diagnostic/call-diagnostic-metrics-latencies.js.map +1 -0
- package/dist/call-diagnostic/call-diagnostic-metrics.js +584 -0
- package/dist/call-diagnostic/call-diagnostic-metrics.js.map +1 -0
- package/dist/call-diagnostic/call-diagnostic-metrics.util.js +225 -0
- package/dist/call-diagnostic/call-diagnostic-metrics.util.js.map +1 -0
- package/dist/call-diagnostic/config.js +461 -0
- package/dist/call-diagnostic/config.js.map +1 -0
- package/dist/call-diagnostic/generated-types-temp/ClientEvent.js +7 -0
- package/dist/call-diagnostic/generated-types-temp/ClientEvent.js.map +1 -0
- package/dist/call-diagnostic/generated-types-temp/Event.js +7 -0
- package/dist/call-diagnostic/generated-types-temp/Event.js.map +1 -0
- package/dist/call-diagnostic/generated-types-temp/MediaQualityEvent.js +7 -0
- package/dist/call-diagnostic/generated-types-temp/MediaQualityEvent.js.map +1 -0
- package/dist/client-metrics-batcher.js +1 -7
- package/dist/client-metrics-batcher.js.map +1 -1
- package/dist/config.js +21 -5
- package/dist/config.js.map +1 -1
- package/dist/index.js +26 -10
- package/dist/index.js.map +1 -1
- package/dist/metrics.js +43 -80
- package/dist/metrics.js.map +1 -1
- package/dist/metrics.types.js +7 -0
- package/dist/metrics.types.js.map +1 -0
- package/dist/new-metrics.js +249 -0
- package/dist/new-metrics.js.map +1 -0
- package/dist/types/batcher.d.ts +2 -0
- package/dist/types/call-diagnostic/call-diagnostic-metrics-batcher.d.ts +2 -0
- package/dist/types/call-diagnostic/call-diagnostic-metrics-latencies.d.ts +189 -0
- package/dist/types/call-diagnostic/call-diagnostic-metrics.d.ts +348 -0
- package/dist/types/call-diagnostic/call-diagnostic-metrics.util.d.ts +52 -0
- package/dist/types/call-diagnostic/config.d.ts +57 -0
- package/dist/types/call-diagnostic/generated-types-temp/ClientEvent.d.ts +1112 -0
- package/dist/types/call-diagnostic/generated-types-temp/Event.d.ts +4851 -0
- package/dist/types/call-diagnostic/generated-types-temp/MediaQualityEvent.d.ts +2121 -0
- package/dist/types/client-metrics-batcher.d.ts +2 -0
- package/dist/types/config.d.ts +35 -0
- package/dist/types/index.d.ts +11 -0
- package/dist/types/metrics.d.ts +3 -0
- package/dist/types/metrics.types.d.ts +92 -0
- package/dist/types/new-metrics.d.ts +119 -0
- package/package.json +12 -8
- package/src/batcher.js +33 -26
- package/src/call-diagnostic/call-diagnostic-metrics-batcher.ts +51 -0
- package/src/call-diagnostic/call-diagnostic-metrics-latencies.ts +408 -0
- package/src/call-diagnostic/call-diagnostic-metrics.ts +591 -0
- package/src/call-diagnostic/call-diagnostic-metrics.util.ts +233 -0
- package/src/call-diagnostic/config.ts +455 -0
- package/src/call-diagnostic/generated-types-temp/ClientEvent.ts +2395 -0
- package/src/call-diagnostic/generated-types-temp/Event.ts +7762 -0
- package/src/call-diagnostic/generated-types-temp/MediaQualityEvent.ts +2321 -0
- package/src/client-metrics-batcher.js +3 -4
- package/src/config.js +25 -5
- package/src/index.ts +39 -0
- package/src/metrics.js +44 -58
- package/src/metrics.types.ts +137 -0
- package/src/new-metrics.ts +223 -0
- package/test/unit/spec/batcher.js +26 -15
- package/test/unit/spec/call-diagnostic/call-diagnostic-metrics-batcher.ts +243 -0
- package/test/unit/spec/call-diagnostic/call-diagnostic-metrics-latencies.ts +474 -0
- package/test/unit/spec/call-diagnostic/call-diagnostic-metrics.ts +820 -0
- package/test/unit/spec/call-diagnostic/call-diagnostic-metrics.util.ts +336 -0
- package/test/unit/spec/client-metrics-batcher.js +26 -15
- package/test/unit/spec/metrics.js +85 -116
- package/test/unit/spec/new-metrics.ts +153 -0
- package/tsconfig.json +6 -0
- package/dist/call-diagnostic-events-batcher.js +0 -70
- package/dist/call-diagnostic-events-batcher.js.map +0 -1
- package/src/call-diagnostic-events-batcher.js +0 -62
- package/src/index.js +0 -17
- package/test/unit/spec/call-diagnostic-events-batcher.js +0 -180
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["MediaQualityEvent.ts"],"sourcesContent":["/* eslint-disable */\n/**\n * This file was automatically generated by json-schema-to-typescript.\n * DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,\n * and run json-schema-to-typescript to regenerate this file.\n */\n\n/**\n * Media Quality Events from media services (e.g. Linus, Edonus, Clients)\n */\nexport interface MediaQualityEvent {\n canProceed: boolean;\n state?: string;\n mediaType?: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\" | \"gamestate\";\n csi?: number;\n /**\n * media capability for both transmit and receive\n */\n mediaCapabilities?: {\n /**\n * explicit indication of media capabilities. true=supported\n */\n tx: {\n audio: boolean;\n video: boolean;\n share: boolean;\n share_audio: boolean;\n whiteboard: boolean;\n gamestate?: boolean;\n };\n /**\n * explicit indication of media capabilities. true=supported\n */\n rx: {\n audio: boolean;\n video: boolean;\n share: boolean;\n share_audio: boolean;\n whiteboard: boolean;\n gamestate?: boolean;\n };\n };\n mediaLines?: {\n mediaType: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\" | \"gamestate\";\n remoteIP?: string;\n localIP?: string;\n localNetworkPrefix?: string;\n localPort?: number;\n remotePort?: number;\n protocol: \"udp\" | \"tcp\" | \"xtls\" | \"unknown\";\n direction: \"sendrecv\" | \"sendonly\" | \"recvonly\" | \"inactive\";\n clusterName?: string;\n status?: \"succeeded\" | \"in-progress\" | \"failed\";\n failureReason?: \"network\" | \"transport\" | \"rejected\" | \"timeout\" | \"notstarted\" | \"succeeded\";\n failureDescription?: string;\n errorCode?: number;\n mediaLineData?: {};\n iceMangled?: boolean;\n transactionId?: string;\n ufrag?: string;\n sentReqTime?: string;\n recvRespTime?: string;\n }[];\n /**\n * allows client to specify media preferences\n */\n clientMediaPreferences?: {\n preferTranscoding: boolean;\n };\n pstnAudioType?: \"dial-in\" | \"dial-out\";\n success?: boolean;\n isTranscoded?: boolean;\n isGatewayed?: boolean;\n isComposed?: boolean;\n /**\n * determine how the events are processed as well as how the reports are aggregated and sliced\n */\n registrationMode?: \"SIP\" | \"Cloud\" | \"CloudAware\";\n /**\n * protocols used to help determine how the events are processed as well as how the reports are aggregated and sliced\n */\n protocol?: \"SIP\" | \"H323\" | \"Locus\" | \"WebRTC\";\n /**\n * The underlying service provider of the call.\n */\n meetingPlatform?: \"MsTeams\" | \"GoogleMeet\" | \"Zoom\" | \"Webex\";\n labels?: string[];\n webexServiceType?: \"MC\" | \"EC\" | \"SC\" | \"TC\" | \"AA\" | \"RA\" | \"NBR\" | \"WRF\" | \"HOL\";\n /**\n * this defines the sub service type\n */\n webexSubServiceType?: \"PMR\" | \"Event\" | \"Training\" | \"ScheduleMeeting\" | \"ScheduledMeeting\" | \"Webinar\" | \"others\";\n ivrDialogType?:\n | \"MEDIA_ON_HOLD\"\n | \"ANNOUNCEMENT\"\n | \"TONE\"\n | \"COLLECT_PIN\"\n | \"PROMPT\"\n | \"MEDIA_SERVICE_AGENT\"\n | \"COLLECT\";\n ivrDialogResult?:\n | \"SUCCESS\"\n | \"FAILURE\"\n | \"HOST_PIN_MATCH\"\n | \"GUEST_PIN_MATCH\"\n | \"PANELIST_PIN_MATCH\"\n | \"NO_MATCH\"\n | \"INVALID_PIN\";\n callType?:\n | \"VIDEO_DIALIN\"\n | \"VIDEO_DIALOUT\"\n | \"CASCADE\"\n | \"HYBRID_CASCADE\"\n | \"PSTN_SIP\"\n | \"PSTN_DIALIN\"\n | \"PSTN_DIALOUT\"\n | \"PSTN_ONLY_DIALIN\"\n | \"PSTN_ONLY_DIALOUT\"\n | \"H323\"\n | \"H323_IP\"\n | \"SIP_ENTERPRISE\"\n | \"SIP_MOBILE\"\n | \"SIP_NATIONAL\"\n | \"SIP_INTERNATIONAL\"\n | \"SIP_EMERGENCY\"\n | \"SIP_OPERATOR\"\n | \"SIP_SHORTCODE\"\n | \"SIP_TOLLFREE\"\n | \"SIP_PREMIUM\"\n | \"SIP_URI\"\n | \"SIP_INBOUND\"\n | \"UNKNOWN\"\n | \"ZTM\"\n | \"SIP_MEETING\";\n eventData?: {};\n derivedSipClientType?:\n | \"SIP_CE_SINGLE_SCREEN\"\n | \"SIP_CE_MULTI_SCREEN\"\n | \"SIP_JABBER\"\n | \"SIP_TIP_SINGLE_SCREEN\"\n | \"SIP_TIP_THREE_SCREEN\"\n | \"SIP_PSTN\"\n | \"SIP_OTHER\"\n | \"SIP_WEBEX_CASCADE\"\n | \"SIP_NONE\";\n /**\n * this defines the major client types\n */\n derivedClientType?:\n | \"MEETING_CENTER\"\n | \"EVENT_CENTER\"\n | \"TRAINING_CENTER\"\n | \"TEAMS_CLIENT\"\n | \"TEAMS_DEVICE\"\n | \"TEAMS_SHARE\"\n | \"SIP\"\n | \"RECORDING\"\n | \"CLOUD_AWARE_SIP\"\n | \"TEAMS_WXC_CLIENT\"\n | \"WXC_CLIENT\"\n | \"WXC_DEVICE\"\n | \"WEBEX_JS_SDK\"\n | \"VOICEA_CLIENT\"\n | \"CISCO_SIP_GW\"\n | \"WEBEX_SDK\"\n | \"CPAAS_THIRD_PARTY_SDK\"\n | \"WXC_THIRD_PARTY\";\n /**\n * this defines the sub types of clients\n */\n derivedSubClientType?:\n | \"DESKTOP_APP\"\n | \"DESKTOP_APP_VDI\"\n | \"DEVICE_CURRENT\"\n | \"DEVICE_LEGACY_2020\"\n | \"HVDI_APP\"\n | \"MOBILE_APP\"\n | \"VDI_APP\"\n | \"WEB_APP\"\n | \"MOBILE_NETWORK\"\n | \"HOLOGRAM_HEADSET_APP\";\n serverRole?:\n | \"CONFERENCE\"\n | \"TRANSCODER\"\n | \"WHITEBOARD_INJECTOR\"\n | \"MS_TEAMS_CONFERENCE\"\n | \"RECORDING\"\n | \"GATEWAY\"\n | \"GATEWAY_CLIENT_SIDE\"\n | \"UNKNOWN\"\n | \"HOLOGRAM_RENDER\";\n reconnect?: boolean;\n retryCount?: number;\n meetSimple?: boolean;\n /**\n * represents media quality status report such as no media or drop out\n */\n mediaStatus?: {\n mediaType?: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\";\n mediaSuccess?: boolean;\n shareType?:\n | \"cb-normal-share\"\n | \"ce-airplay-share\"\n | \"ce-direct-share\"\n | \"ce-gui-loopback-share\"\n | \"ce-input-source-share\"\n | \"ce-input-source-share-hdmi\"\n | \"ce-input-source-share-usbc\"\n | \"ce-jpg-share\"\n | \"ce-miracast-share\"\n | \"mcs-normal-share\"\n | \"mcs-normal-audio-share\"\n | \"mcs-hfps-share\"\n | \"mcs-hfps-audio-share\";\n isTransmitter?: boolean;\n audioJoinType?:\n | \"phone-call-in\"\n | \"phone-call-back\"\n | \"voip\"\n | \"device-call-back\"\n | \"never-join-audio\"\n | \"tried-but-never-join\";\n /**\n * indicates transport type used\n */\n transportType?: \"UDP\" | \"TCP\" | \"xTLS\" | \"TLS\";\n additionalData?: {};\n };\n shareInstanceId?: string;\n hologramStreamId?: string;\n /**\n * represents all of the properities that could cause delay during media setup process.\n */\n audioSetupDelay?: {\n floorReqSentReceived?: number;\n floorRespSentReceived?: number;\n mediaType?: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\";\n txReqFloorGranted?: number;\n txSessionCreateConfirm?: number;\n txApeEnrollConfirm?: number;\n txUIDelay?: number;\n txScreenCaptureDelay?: number;\n txScreenCaptureDelayReasonCode?: number;\n txShareStartOverallDelay?: number;\n rx1stPacket2RenderDelay?: number;\n rxGranted2RenderDelay?: number;\n rxFailFrameNumB4Success?: number;\n e2eFirstFrameDelay?: number;\n CBSessionRespToLocusFloorGrantDelay?: number;\n CBShareReceiveToServerShareTransmitDelay?: number;\n CBShareReceiveToTPGWFirstKeyFrameDelay?: number;\n TPGWFirstKeyFrameToServerShareTransmitDelay?: number;\n MCSSessionActivateToLocusFloorGrantDelay?: number;\n ServerShareInitiateToLocusFloorGrantDelay?: number;\n LocusFloorGrantToCBSessionStartDelay?: number;\n ServerShareReceiveToTPGWFirstKeyFrameDelay?: number;\n LocusFloorGrantToTPGWFloorGrantDelay?: number;\n LocusFloorGrantToReceiverNotificationDelay?: number;\n CBShareSessionRespDelay?: number;\n LocusShareFloorGrantRespDelay?: number;\n ServerShareFloorGrantRespDelay?: number;\n joinRespRxStart?: number;\n joinRespTxStart?: number;\n maxRemoteLossRate?: number;\n media2SignalDelay?: number;\n warholDownloadTime?: number;\n contentDownloadTime?: number;\n boardCreationTime?: number;\n totalBoardServiceRespDelay?: number;\n };\n /**\n * represents all of the properities that could cause delay during media setup process.\n */\n videoSetupDelay?: {\n floorReqSentReceived?: number;\n floorRespSentReceived?: number;\n mediaType?: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\";\n txReqFloorGranted?: number;\n txSessionCreateConfirm?: number;\n txApeEnrollConfirm?: number;\n txUIDelay?: number;\n txScreenCaptureDelay?: number;\n txScreenCaptureDelayReasonCode?: number;\n txShareStartOverallDelay?: number;\n rx1stPacket2RenderDelay?: number;\n rxGranted2RenderDelay?: number;\n rxFailFrameNumB4Success?: number;\n e2eFirstFrameDelay?: number;\n CBSessionRespToLocusFloorGrantDelay?: number;\n CBShareReceiveToServerShareTransmitDelay?: number;\n CBShareReceiveToTPGWFirstKeyFrameDelay?: number;\n TPGWFirstKeyFrameToServerShareTransmitDelay?: number;\n MCSSessionActivateToLocusFloorGrantDelay?: number;\n ServerShareInitiateToLocusFloorGrantDelay?: number;\n LocusFloorGrantToCBSessionStartDelay?: number;\n ServerShareReceiveToTPGWFirstKeyFrameDelay?: number;\n LocusFloorGrantToTPGWFloorGrantDelay?: number;\n LocusFloorGrantToReceiverNotificationDelay?: number;\n CBShareSessionRespDelay?: number;\n LocusShareFloorGrantRespDelay?: number;\n ServerShareFloorGrantRespDelay?: number;\n joinRespRxStart?: number;\n joinRespTxStart?: number;\n maxRemoteLossRate?: number;\n media2SignalDelay?: number;\n warholDownloadTime?: number;\n contentDownloadTime?: number;\n boardCreationTime?: number;\n totalBoardServiceRespDelay?: number;\n };\n /**\n * represents all of the properities that could cause delay during media setup process.\n */\n shareSetupDelay?: {\n floorReqSentReceived?: number;\n floorRespSentReceived?: number;\n mediaType?: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\";\n txReqFloorGranted?: number;\n txSessionCreateConfirm?: number;\n txApeEnrollConfirm?: number;\n txUIDelay?: number;\n txScreenCaptureDelay?: number;\n txScreenCaptureDelayReasonCode?: number;\n txShareStartOverallDelay?: number;\n rx1stPacket2RenderDelay?: number;\n rxGranted2RenderDelay?: number;\n rxFailFrameNumB4Success?: number;\n e2eFirstFrameDelay?: number;\n CBSessionRespToLocusFloorGrantDelay?: number;\n CBShareReceiveToServerShareTransmitDelay?: number;\n CBShareReceiveToTPGWFirstKeyFrameDelay?: number;\n TPGWFirstKeyFrameToServerShareTransmitDelay?: number;\n MCSSessionActivateToLocusFloorGrantDelay?: number;\n ServerShareInitiateToLocusFloorGrantDelay?: number;\n LocusFloorGrantToCBSessionStartDelay?: number;\n ServerShareReceiveToTPGWFirstKeyFrameDelay?: number;\n LocusFloorGrantToTPGWFloorGrantDelay?: number;\n LocusFloorGrantToReceiverNotificationDelay?: number;\n CBShareSessionRespDelay?: number;\n LocusShareFloorGrantRespDelay?: number;\n ServerShareFloorGrantRespDelay?: number;\n joinRespRxStart?: number;\n joinRespTxStart?: number;\n maxRemoteLossRate?: number;\n media2SignalDelay?: number;\n warholDownloadTime?: number;\n contentDownloadTime?: number;\n boardCreationTime?: number;\n totalBoardServiceRespDelay?: number;\n };\n /**\n * represents all of the properities that could cause delay during media setup process.\n */\n shareAudioSetupDelay?: {\n floorReqSentReceived?: number;\n floorRespSentReceived?: number;\n mediaType?: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\";\n txReqFloorGranted?: number;\n txSessionCreateConfirm?: number;\n txApeEnrollConfirm?: number;\n txUIDelay?: number;\n txScreenCaptureDelay?: number;\n txScreenCaptureDelayReasonCode?: number;\n txShareStartOverallDelay?: number;\n rx1stPacket2RenderDelay?: number;\n rxGranted2RenderDelay?: number;\n rxFailFrameNumB4Success?: number;\n e2eFirstFrameDelay?: number;\n CBSessionRespToLocusFloorGrantDelay?: number;\n CBShareReceiveToServerShareTransmitDelay?: number;\n CBShareReceiveToTPGWFirstKeyFrameDelay?: number;\n TPGWFirstKeyFrameToServerShareTransmitDelay?: number;\n MCSSessionActivateToLocusFloorGrantDelay?: number;\n ServerShareInitiateToLocusFloorGrantDelay?: number;\n LocusFloorGrantToCBSessionStartDelay?: number;\n ServerShareReceiveToTPGWFirstKeyFrameDelay?: number;\n LocusFloorGrantToTPGWFloorGrantDelay?: number;\n LocusFloorGrantToReceiverNotificationDelay?: number;\n CBShareSessionRespDelay?: number;\n LocusShareFloorGrantRespDelay?: number;\n ServerShareFloorGrantRespDelay?: number;\n joinRespRxStart?: number;\n joinRespTxStart?: number;\n maxRemoteLossRate?: number;\n media2SignalDelay?: number;\n warholDownloadTime?: number;\n contentDownloadTime?: number;\n boardCreationTime?: number;\n totalBoardServiceRespDelay?: number;\n };\n /**\n * represents all of the properities that could cause delay during media setup process.\n */\n whiteboardSetupDelay?: {\n floorReqSentReceived?: number;\n floorRespSentReceived?: number;\n mediaType?: \"audio\" | \"video\" | \"share\" | \"share_audio\" | \"whiteboard\";\n txReqFloorGranted?: number;\n txSessionCreateConfirm?: number;\n txApeEnrollConfirm?: number;\n txUIDelay?: number;\n txScreenCaptureDelay?: number;\n txScreenCaptureDelayReasonCode?: number;\n txShareStartOverallDelay?: number;\n rx1stPacket2RenderDelay?: number;\n rxGranted2RenderDelay?: number;\n rxFailFrameNumB4Success?: number;\n e2eFirstFrameDelay?: number;\n CBSessionRespToLocusFloorGrantDelay?: number;\n CBShareReceiveToServerShareTransmitDelay?: number;\n CBShareReceiveToTPGWFirstKeyFrameDelay?: number;\n TPGWFirstKeyFrameToServerShareTransmitDelay?: number;\n MCSSessionActivateToLocusFloorGrantDelay?: number;\n ServerShareInitiateToLocusFloorGrantDelay?: number;\n LocusFloorGrantToCBSessionStartDelay?: number;\n ServerShareReceiveToTPGWFirstKeyFrameDelay?: number;\n LocusFloorGrantToTPGWFloorGrantDelay?: number;\n LocusFloorGrantToReceiverNotificationDelay?: number;\n CBShareSessionRespDelay?: number;\n LocusShareFloorGrantRespDelay?: number;\n ServerShareFloorGrantRespDelay?: number;\n joinRespRxStart?: number;\n joinRespTxStart?: number;\n maxRemoteLossRate?: number;\n media2SignalDelay?: number;\n warholDownloadTime?: number;\n contentDownloadTime?: number;\n boardCreationTime?: number;\n totalBoardServiceRespDelay?: number;\n };\n isFocus?: boolean;\n processingDelay?: number;\n shareType?:\n | \"cb-normal-share\"\n | \"ce-airplay-share\"\n | \"ce-direct-share\"\n | \"ce-gui-loopback-share\"\n | \"ce-input-source-share\"\n | \"ce-input-source-share-hdmi\"\n | \"ce-input-source-share-usbc\"\n | \"ce-jpg-share\"\n | \"ce-miracast-share\"\n | \"mcs-normal-share\"\n | \"mcs-normal-audio-share\"\n | \"mcs-hfps-share\"\n | \"mcs-hfps-audio-share\";\n isShareBeingTakenOver?: boolean;\n floorBeneficiaryUpdated?: boolean;\n meetingJoinedTime?: string;\n meetingScheduledTime?: string;\n e2eeKeyEpoch?: number;\n e2eeDecompressRatio?: number;\n keyResponses?: {\n gotKeyTime?: number;\n useKeyTime?: number;\n cacheKeyTime?: number;\n }[];\n e2eeVersion?: \"E2EEV1\" | \"E2EEV2\" | \"E2EEV3\";\n isConvergedArchitectureEnabled?: boolean;\n callingServiceType?: \"CUCM\" | \"WEBEXCALLING\" | \"BROADWORKS\" | \"LOCUS\";\n inLobby?: boolean;\n isVIPMeeting?: boolean;\n webexAppEntrypoint?: string;\n firstParticipant?: boolean;\n isImmersiveShare?: boolean;\n /**\n * Request/Response Time for Internal Services\n */\n registeredTimestamps?: {\n locusCreateConfluenceRequestTime?: string;\n locusCreateConfluenceResponseTime?: string;\n locusCreateVenueRequestTime?: string;\n locusCreateVenueResponseTime?: string;\n };\n skipInterstitialWindow?: boolean;\n callDurationSecs?: number;\n /**\n * Details associated with a breakout move\n */\n breakout?: {\n moveType?: \"between_breakout\" | \"to_breakout\" | \"to_main\";\n trigger?: \"assignment_changed\" | \"client_initiated\" | \"session_ended\" | \"session_started\";\n startState?: \"joined\" | \"lobby\";\n endState?: \"joined\" | \"lobby\";\n };\n /**\n * Latency values associated with breakout session\n */\n breakoutLatency?: {\n boBreakoutMoveProcessed?: number;\n boBreakoutMoveResp?: number;\n boLocusBreakoutMoveResp?: number;\n locusBreakoutMoveResp?: number;\n orpheusConfluenceMoveReqResp?: number;\n };\n /**\n * two-way whiteboard related info\n */\n whiteboard?: {\n action?: \"open\" | \"create\";\n type?: \"whiteboard\" | \"annotation\";\n capability?: \"one_way\" | \"two_way\";\n granted?: \"one_way\" | \"two_way\";\n };\n /**\n * ROAP message details\n */\n roap?: {\n type?:\n | \"ANSWER\"\n | \"ERROR\"\n | \"OFFER\"\n | \"OFFER_REQUEST\"\n | \"OFFER_RESPONSE\"\n | \"OK\"\n | \"OKAY\"\n | \"TURN_DISCOVERY_REQUEST\"\n | \"TURN_DISCOVERY_RESPONSE\";\n messageType?:\n | \"ANSWER\"\n | \"ERROR\"\n | \"OFFER\"\n | \"OFFER_REQUEST\"\n | \"OFFER_RESPONSE\"\n | \"OK\"\n | \"OKAY\"\n | \"TURN_DISCOVERY_REQUEST\"\n | \"TURN_DISCOVERY_RESPONSE\";\n error?: string;\n duration?: number;\n seq?: number;\n };\n trigger?: \"dummyTrigger1\" | \"dummyTrigger2\" | \"media-quality\";\n name: \"server.mediaquality.event\" | \"client.mediaquality.event\";\n /**\n * Base type for the various identifiers used to connect the dots.\n * In general, these should be populated whenever possible. Subtypes may make a particular key required.\n *\n */\n identifiers: {\n attendeeId?: string;\n breakoutGroupId?: string;\n breakoutMoveId?: string;\n breakoutSessionId?: string;\n confluenceId?: string;\n /**\n * Set of identifiers dedicated to CPaaS clients\n * In general, these should be populated whenever possible. Subtypes may make a particular key required.\n *\n */\n cpaasIdentifiers?: {\n imiTenantId: string;\n devClientId: string;\n imiServiceId: string;\n imiAppId: string;\n sessionId: string;\n sessionInstanceId: string;\n };\n csdmDeviceUrl?: string;\n destinationBreakoutSessionId?: string;\n destinationLocusSessionId?: string;\n destinationLocusUrl?: string;\n destinationVenueId?: string;\n deviceId?: string;\n ivrCallId?: string;\n ivrDialogId?: string;\n ivrId?: string;\n locusId?: string;\n locusSessionId?: string;\n locusStartTime?: string;\n locusUrl?: string;\n mediaAgentAlias?: string;\n mediaAgentGroupId?: string;\n meetClusterName?: string;\n meetingLookupUrl?: string;\n meetingOrgId?: string;\n msteamsTenantGuid?: string;\n msteamsConferenceId?: string;\n oauth2ClientId?: string;\n orgId?: string;\n provisionalCorrelationId?: string;\n roomId?: string;\n sipCallId?: string;\n sipSessionId?: {\n local?: string;\n remote?: string;\n };\n sipUri?: string;\n subConfId?: string;\n tenantId?: string;\n trackingId?: string;\n userId?: string;\n venueId?: string;\n venueUrl?: string;\n whiteboardUrl?: string;\n webexConferenceId?: number;\n webexClusterName?: string;\n webexConferenceIdStr?: string;\n webexDataCenter?: string;\n webexGuestId?: number;\n webexMeetingId?: number;\n webexNodeId?: number;\n webexSiteId?: number;\n webexSiteName?: string;\n webexUserId?: number;\n webexWebDomain?: string;\n correlationId: string;\n };\n /**\n * metadata associated with emitter of the event. This data is included only in the first emitted for a given call and does not need to be repeated with each event.\n */\n sourceMetadata?: {\n mediaEngineSoftwareType: string;\n mediaEngineSoftwareVersion: string;\n applicationSoftwareType: string;\n applicationSoftwareVersion: string;\n hardwareType?: string;\n clientRegion?: string;\n serverRegion?: string;\n serverOrg?: string;\n serverGroup?: string;\n serverAlias?: string;\n serverDeployType?: \"private\" | \"public\";\n startTime: string;\n endTime?: string;\n csi?: number[];\n isCascade?: boolean;\n isHybridMedia?: boolean;\n videoMeshClusterName?: string;\n videoMeshServerName?: string;\n isTIP?: boolean;\n isMARI?: boolean;\n has264Checksum?: boolean;\n intervalPeriod?: number;\n cascadePeerRegion?: string;\n cascadePeerOrg?: string;\n cascadePeerGroup?: string;\n cascadePeerAlias?: string;\n cascadePeerServerType?:\n | \"CB\"\n | \"CMS\"\n | \"HESIOD\"\n | \"LINUS\"\n | \"MCC\"\n | \"MCS\"\n | \"MES\"\n | \"MJS\"\n | \"MRS\"\n | \"MYGDONUS\"\n | \"MZM\"\n | \"TERMINUS\"\n | \"TPGW\"\n | \"TA\"\n | \"HOMER\"\n | \"SUPERHOMER\"\n | \"U2C\"\n | \"WCA\"\n | \"MSE\"\n | \"UNKNOWN\";\n cascadePeerDeployType?: \"private\" | \"public\";\n };\n /**\n * Details of a media edge server which is in the media path but does not generate MQE directly\n */\n edgeInfo?: {\n alias: string;\n publicIP: string;\n privateIP: string;\n version: string;\n labels?: string;\n };\n intervals: {\n intervalNumber: number;\n /**\n * The metadata associated with the emitter of the event. This data is separate from the source metadata and must be emitted with every event.\n */\n intervalMetadata: {\n peerReflexiveIP?: string;\n maskedPeerReflexiveIP?: string;\n remoteMediaIP?: string;\n maskedRemoteMediaIP?: string;\n staticPerformanceLevel?: number;\n processAverageCPU?: number;\n processMaximumCPU?: number;\n systemAverageCPU?: number;\n systemMaximumCPU?: number;\n systemAverageGPU?: number;\n systemMaximumGPU?: number;\n /**\n * this object defines the memory related fields that are tracked in media quality events and reports\n */\n memoryUsage?: {\n processAverageMemoryUsage: number;\n processMaximumMemoryUsage: number;\n systemAverageMemoryUsage: number;\n systemMaximumMemoryUsage: number;\n processMaximumMemoryBytes: number;\n mainProcessMaximumMemoryBytes: number;\n osBitWidth: number;\n cpuBitWidth: number;\n };\n peripherals?: {\n name: \"camera\" | \"microphone\" | \"speaker\";\n information: string;\n driver?: string;\n errorCode?: string;\n connectionType?: unknown;\n bluetoothMode?: unknown;\n }[];\n /**\n * information object for the peripheral\n */\n cameraInfo?: {\n name: \"camera\" | \"microphone\" | \"speaker\";\n information: string;\n driver?: string;\n errorCode?: string;\n connectionType?: unknown;\n bluetoothMode?: unknown;\n };\n /**\n * information object for the peripheral\n */\n microphoneInfo?: {\n name: \"camera\" | \"microphone\" | \"speaker\";\n information: string;\n driver?: string;\n errorCode?: string;\n connectionType?: unknown;\n bluetoothMode?: unknown;\n };\n /**\n * information object for the peripheral\n */\n speakerInfo?: {\n name: \"camera\" | \"microphone\" | \"speaker\";\n information: string;\n driver?: string;\n errorCode?: string;\n connectionType?: unknown;\n bluetoothMode?: unknown;\n };\n /**\n * This object defines the fields related to the CPU being used by the emitter of the event\n */\n cpuInfo?: {\n description: string;\n clockSpeedGigaHertz: number;\n numberOfCores: number;\n architecture: \"intel32\" | \"intel64\" | \"amd32\" | \"amd64\" | \"arm32\" | \"arm64\" | \"unknown\";\n staticPerformance?: string;\n };\n /**\n * Thread level cpu performance insights\n */\n cpuDataDetail?: {\n processesData?: unknown[];\n coresCpuData?: unknown[];\n coreVariance?: number;\n };\n /**\n * This object defines the fields related to the GPU being used by the emitter of the event\n */\n defaultGpuInfo?: {\n description: string;\n memoryMegaBytes: number;\n };\n otherGpuInfo?: {\n description: string;\n memoryMegaBytes: number;\n }[];\n dpcRecord?: string[];\n mediaLabels?: string[];\n screenResolution?: number;\n screenWidth?: number;\n screenHeight?: number;\n appWindowSize?: number;\n appWindowHeight?: number;\n appWindowWidth?: number;\n meetingUserCount?: number;\n videoUserCount?: number;\n numScreens?: number;\n configuredBitrate?: number;\n };\n audioTransmit: {\n /**\n * contains the transmit related fields common between all session types for each interval\n */\n common: {\n /**\n * contains the fields common to both transmit and receive sessions for each interval\n */\n common: {\n isMain: boolean;\n mariFecEnabled: boolean;\n mariRtxEnabled?: boolean;\n mariQosEnabled: boolean;\n mariLiteEnabled?: boolean;\n multistreamEnabled: boolean;\n isMediaBypassEdge?: boolean;\n direction: \"sendrecv\" | \"sendonly\" | \"recvonly\" | \"inactive\";\n localPort?: number;\n peerReflexivePort?: number;\n remotePort?: number;\n };\n fecPackets: number;\n fecBitrate: number;\n rtxPackets?: number;\n rtxBitrate?: number;\n rtpPackets: number;\n rtpBitrate: number;\n rtcpPackets: number;\n rtcpBitrate: number;\n /**\n * RTCP Information for a given Interval\n */\n txRtcpInfo?: {\n rtcpSrPackets: number;\n rtcpRrPackets: number;\n rtcpReportBlocks: number;\n rtcpSdesPackets: number;\n rtcpByePackets: number;\n rtcpAppPackets: number;\n rtcpRtpFbPacket: number;\n rtcpPsFbPackets: number;\n rtcpPsFbMariPackets: number;\n rtcpPsFbMultistreamPackets: number;\n rtcpXrPackets: number;\n };\n stunPackets: number;\n stunBitrate: number;\n dtlsPackets: number;\n dtlsBitrate: number;\n transportType: \"UDP\" | \"TCP\" | \"xTLS\" | \"TLS\";\n maxBitrate: number;\n availableBitrate: number;\n queueDelay: number;\n meanRoundTripTime?: number;\n maxRoundTripTime?: number;\n roundTripTime: number;\n remoteReceiveRate?: number;\n maxRemoteLossRate?: number;\n remoteLossRate?: number;\n meanRemoteLossRate?: number;\n maxRemoteJitter?: number;\n remoteJitter?: number;\n meanRemoteJitter?: number;\n traversalMinDelayMs?: number;\n traversalMaxDelayMs?: number;\n traversalMeanDelayMs?: number;\n rtpInputFifoDelayMs?: number;\n rtpInputFifoMaxDelayMs?: number;\n rtpInputFifoMinDelayMs?: number;\n rtpInputFifoMeanDelayMs?: number;\n };\n streams: {\n /**\n * contains fields common to all transmit streams types\n */\n common: {\n ssci: number;\n duplicateSsci?: number;\n rtpPackets: number;\n transmittedFrameRate: number;\n requestedFrames: number;\n transmittedBitrate: number;\n requestedBitrate: number;\n captureOffset?: number;\n codec: string;\n csi?: number[];\n /**\n * This object tracks SSRC and CSRC changes for an RTP stream, session, etc\n */\n sourceChanges?: {\n /**\n * The number of RTP SSRC changes seen. The first RTP packet seen should NOT be counted as a change.\n */\n ssrcChanges: number;\n /**\n * The number of RTP CSRC changes seen. The first RTP packet seen should NOT be counted as a change. Changes from zero to non-zero CSRC should be counted as a change.\n */\n csrcChanges: number;\n };\n };\n backgroundNoiseReductionMode?:\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_NONE\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_HIGH_PERFORMANCE\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_LOW_POWER\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_AUTO_HIGH_PERFORMANCE\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_AUTO_LOW_POWER\";\n backgroundNoiseReductionTalkerMode?:\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_TALKER_NONE\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_CLASSIC_MODE\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_SINGLE_TALKER_MODE\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_MULTI_TALKER_MODE\"\n | \"AUDIO_BACKGROUND_NOISE_REDUCTION_MUSIC_MODE\";\n audioTXSPCStatus?: \"AUDIO_SPC_STATUS_DISABLED\" | \"AUDIO_SPC_STATUS_SUSPENDED\" | \"AUDIO_SPC_STATUS_ENABLED\";\n audioTXSPCLevel?:\n | \"AUDIO_NONE\"\n | \"AUDIO_LOW\"\n | \"AUDIO_MEDIUM\"\n | \"AUDIO_NORMAL\"\n | \"AUDIO_HIGH\"\n | \"AUDIO_HIGHPLUS\"\n | \"AUDIO_TOP\";\n /**\n * audio encoder engine performance data\n */\n audioEncoderEngineInfo?: {\n /**\n * The number of audio packets sent to the encoder buffer\n */\n encoderBufferPacket?: number;\n /**\n * The number of dropped audio packets before sent to the encoder buffer\n */\n encoderBufferDroppedPacket?: number;\n /**\n * The average processing time (microseconds) on background noise reduction (BNR)\n */\n averageBNRProcessTime?: number;\n /**\n * The average processing time (microseconds) on audio encoder pipeline\n */\n averageEncoderProcessTime?: number;\n };\n /**\n * audio transmitted algorithm modules performance data(AEC,AGC,NR,MultiChannelPreprocess)\n */\n audioAlgorithmModulesInfo?: {\n /**\n * one char every 1 minute, 0 indicate 0db, plus 1 indicate -0.5dB\n */\n aecNearPower: number;\n /**\n * one char every 1 minute, 0 indicate 0db, plus 1 indicate -0.5dB\n */\n aecFarPower: number;\n /**\n * one char every 1 minute, 0 indicate 0db, plus 1 indicate -0.5dB\n */\n aecLinearOutPower?: number;\n /**\n * one char every 1 minute, 0 indicate 0db, plus 1 indicate -0.5dB\n */\n aecOutPower?: number;\n /**\n * one char every 1 minute, 0 indicate 54dB, plus 1 indicate +0.5dB\n */\n aecERLE?: number;\n /**\n * one char every 1 minute, 0 indicate 0dB, plus 1 indicate +0.5dB\n */\n aecERL?: number;\n /**\n * one char every 1 minute, 0 indicate 54dB, plus 1 indicate +0.5dB\n */\n linearAecERLE?: number;\n /**\n * one char every 1 minute, 0 indicate 0ms, plus 1 indicate 10ms\n */\n estDelay?: number;\n /**\n * one char every 1 minute\n */\n aecType?: number;\n /**\n * one unsigned short every 1 minute\n */\n aecCostTime?: number;\n /**\n * one unsigned short every 1 minute\n */\n multichannelChangedDelay?: number;\n /**\n * one unsigend char every 1 minute, 0 indicate 0db, plus 1 indicate -0.5dB\n */\n multichannelDelaySumOutPower?: number;\n /**\n * one unsigend char every 1 minute, 0 indicate 0db, plus 1 indicate -0.5dB\n */\n multichannelAverageOutPower?: number;\n /**\n * one unsigned char every 1 minute, 0 for 0dB, plus 1 for -0.5dB\n */\n speechRMS?: number;\n /**\n * one unsigned char every 1 minute, 0 for 0s, plus 4 for +1s\n */\n speechLength?: number;\n /**\n * one unsigned char every 1 minute, VAD value to reflect speech quality\n */\n speechQuality?: number;\n /**\n * one char every 1 minute.\n */\n remoteIOStatus?: number;\n /**\n * one char every 1 minute\n */\n multichannelPreprocessEnabled?: number;\n /**\n * one char every 1 minute\n */\n bypassWindowsAPOAllowListEnabled?: number;\n /**\n * one char every 1 minute, 0 for 0dB, plus 1 for 0.5dB\n */\n bnrSNR?: number;\n /**\n * one unsigned short every 1 minute\n */\n bnrTRN?: number;\n /**\n * one short every 1 minute\n */\n ftLeakage?: number;\n /**\n * one short every 1 minute\n */\n noiseLeakage?: number;\n /**\n * one short every 1 minute\n */\n echoLeakage?: number;\n /**\n * one char every 1 minute, 0 indicate 0db, plus 1 indicate 0.0472dB.\n */\n multichannelDelaySumAndDirectMixRMSRatio?: number;\n windowsAPOBypassed?: boolean;\n };\n /**\n * audio transmit pipeline modules' quality metric\n */\n audioModuleQualityInfo?: {\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n aecNearPower?: number[];\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n aecLinearOutPower?: number[];\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n aecOutPower?: number[];\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n aecFarPower?: number[];\n /**\n * One char every 2 seconds.\n */\n aecStatus?: number[];\n /**\n * one char every 2 seconds.\n */\n bblOutPower?: number[];\n /**\n * one char every 2 seconds\n */\n volumeAndDelay?: number[];\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n agcOutPower?: number[];\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n agcAvgOutPower?: number[];\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n agcAvgInputPower?: number[];\n /**\n * one char every 1 minute.\n */\n agcType?: number;\n };\n audioCaptureMethod?: \"AUDIO_ANDROID_JAVA_METHOD\" | \"AUDIO_ANDROID_AAUDIO_METHOD\";\n }[];\n /**\n * information about tracked audio levels\n */\n levels?: {\n /**\n * The average audio input gain for a microphone or speaker, in decibels\n */\n audioMeanGain?: number;\n /**\n * The minimum audio input gain for a microphone or speaker, in decibels\n */\n audioMinGain?: number;\n /**\n * The maximum audio input gain for a microphone or speaker, in decibels\n */\n audioMaxGain?: number;\n /**\n * The mean audio output volume for a microphone or speaker, in absolute volume [0-65535]\n */\n audioMeanVolume?: number;\n /**\n * The min audio output volume for a microphone or speaker, in absolute volume [0-65535]\n */\n audioMinVolume?: number;\n /**\n * The max audio output volume for a microphone or speaker, in absolute volume [0-65535]\n */\n audioMaxVolume?: number;\n };\n captureHardwareProvidedAudioPacketsPerSecond?: number;\n sharedAudioPacketsPerSecond?: number;\n }[];\n videoTransmit: {\n /**\n * contains the transmit related fields common between all session types for each interval\n */\n common: {\n /**\n * contains the fields common to both transmit and receive sessions for each interval\n */\n common: {\n isMain: boolean;\n mariFecEnabled: boolean;\n mariRtxEnabled?: boolean;\n mariQosEnabled: boolean;\n mariLiteEnabled?: boolean;\n multistreamEnabled: boolean;\n isMediaBypassEdge?: boolean;\n direction: \"sendrecv\" | \"sendonly\" | \"recvonly\" | \"inactive\";\n localPort?: number;\n peerReflexivePort?: number;\n remotePort?: number;\n };\n fecPackets: number;\n fecBitrate: number;\n rtxPackets?: number;\n rtxBitrate?: number;\n rtpPackets: number;\n rtpBitrate: number;\n rtcpPackets: number;\n rtcpBitrate: number;\n /**\n * RTCP Information for a given Interval\n */\n txRtcpInfo?: {\n rtcpSrPackets: number;\n rtcpRrPackets: number;\n rtcpReportBlocks: number;\n rtcpSdesPackets: number;\n rtcpByePackets: number;\n rtcpAppPackets: number;\n rtcpRtpFbPacket: number;\n rtcpPsFbPackets: number;\n rtcpPsFbMariPackets: number;\n rtcpPsFbMultistreamPackets: number;\n rtcpXrPackets: number;\n };\n stunPackets: number;\n stunBitrate: number;\n dtlsPackets: number;\n dtlsBitrate: number;\n transportType: \"UDP\" | \"TCP\" | \"xTLS\" | \"TLS\";\n maxBitrate: number;\n availableBitrate: number;\n queueDelay: number;\n meanRoundTripTime?: number;\n maxRoundTripTime?: number;\n roundTripTime: number;\n remoteReceiveRate?: number;\n maxRemoteLossRate?: number;\n remoteLossRate?: number;\n meanRemoteLossRate?: number;\n maxRemoteJitter?: number;\n remoteJitter?: number;\n meanRemoteJitter?: number;\n traversalMinDelayMs?: number;\n traversalMaxDelayMs?: number;\n traversalMeanDelayMs?: number;\n rtpInputFifoDelayMs?: number;\n rtpInputFifoMaxDelayMs?: number;\n rtpInputFifoMinDelayMs?: number;\n rtpInputFifoMeanDelayMs?: number;\n };\n streams: {\n /**\n * contains fields common to all transmit streams types\n */\n common: {\n ssci: number;\n duplicateSsci?: number;\n rtpPackets: number;\n transmittedFrameRate: number;\n requestedFrames: number;\n transmittedBitrate: number;\n requestedBitrate: number;\n captureOffset?: number;\n codec: string;\n csi?: number[];\n /**\n * This object tracks SSRC and CSRC changes for an RTP stream, session, etc\n */\n sourceChanges?: {\n /**\n * The number of RTP SSRC changes seen. The first RTP packet seen should NOT be counted as a change.\n */\n ssrcChanges: number;\n /**\n * The number of RTP CSRC changes seen. The first RTP packet seen should NOT be counted as a change. Changes from zero to non-zero CSRC should be counted as a change.\n */\n csrcChanges: number;\n };\n };\n transmittedFrameSize: number;\n requestedFrameSize: number;\n transmittedHeight: number;\n transmittedWidth: number;\n transmittedKeyFrames: number;\n requestedKeyFrames: number;\n transmittedKeyFramesFeedback?: number;\n transmittedKeyFramesConfigurationChange?: number;\n transmittedKeyFramesSceneChange?: number;\n transmittedKeyFramesOtherLayer?: number;\n transmittedKeyFramesClient?: number;\n transmittedKeyFramesPeriodic?: number;\n transmittedKeyFramesLocalDrop?: number;\n transmittedKeyFramesStartup?: number;\n transmittedKeyFramesUnknown?: number;\n transmittedKeyFramesEncLayerIndexChange?: number;\n transmittedKeyFramesSwitchingPoint?: number;\n localConfigurationChanges: number;\n remoteConfigurationChanges: number;\n h264CodecProfile: \"BP\" | \"CHP\";\n isAvatar?: boolean;\n /**\n * video encode quality metrics\n */\n encodeQuality?: {\n minRegionQp: number;\n maxFrameQp: number;\n maxNoiseLevel: number;\n };\n /**\n * video transmit downgrade reasons\n */\n downgradeReason?: {\n isCamera: boolean;\n isNetwork: boolean;\n isCpu: boolean;\n isRequested?: boolean;\n isUser?: boolean;\n isHardware?: boolean;\n };\n isHardwareEncoded?: boolean;\n backgroundAugmentationType?:\n | \"VIDEO_BACKGROUND_AUGMENT_NONE\"\n | \"VIDEO_BACKGROUND_AUGMENT_BLUR\"\n | \"VIDEO_BACKGROUND_AUGMENT_REPLACE_IMAGE\"\n | \"VIDEO_BACKGROUND_AUGMENT_REPLACE_VIDEO\"\n | \"VIDEO_BACKGROUND_AUGMENT_BLUR_INHOUSE\"\n | \"VIDEO_BACKGROUND_AUGMENT_REPLACE_IMAGE_INHOUSE\"\n | \"VIDEO_BACKGROUND_AUGMENT_REPLACE_VIDEO_INHOUSE\";\n backgroundAugmentationFrameworkType?:\n | \"VIDEO_VBG_FRAMEWORK_NONE\"\n | \"VIDEO_VBG_FRAMEWORK_COREML\"\n | \"VIDEO_VBG_FRAMEWORK_METAL\"\n | \"VIDEO_VBG_FRAMEWORK_CBASED\"\n | \"VIDEO_VBG_FRAMEWORK_OPENVINO\"\n | \"VIDEO_VBG_FRAMEWORK_COREML_LADON\"\n | \"VIDEO_VBG_FRAMEWORK_METAL_LADON\"\n | \"VIDEO_VBG_FRAMEWORK_CBASED_LADON\"\n | \"VIDEO_VBG_FRAMEWORK_OPENVINO_LADON\";\n /**\n * transmit video pipeline performance metric\n */\n encoderProcessInfo?: {\n meanEncoderProcessMillis: number;\n maxEncoderProcessMillis: number;\n meanVbgProcessMillis?: number;\n maxVbgProcessMillis?: number;\n };\n backgroundAugmentationModelVersion?: string;\n isGestureDetectorOn?: boolean;\n capturedFrameRateNormalShare?: number;\n capturedFrameRateHFPSShare?: number;\n transmittedFrameRateNormalShare?: number;\n transmittedFrameRateHFPSShare?: number;\n /**\n * the method use to capture the screen for screen sharing\n */\n screenCaptureMode?:\n | \"Unknown\"\n | \"Default\"\n | \"MAG\"\n | \"DUP\"\n | \"AVF\"\n | \"CGS\"\n | \"GDI\"\n | \"DIRECTX\"\n | \"WINDOW\"\n | \"SCK\";\n processShareContentDetectMillis?: number;\n }[];\n }[];\n audioReceive: {\n /**\n * contains the receive related fields between all sessions types for each interval.\n */\n common: {\n /**\n * contains the fields common to both transmit and receive sessions for each interval\n */\n common: {\n isMain: boolean;\n mariFecEnabled: boolean;\n mariRtxEnabled?: boolean;\n mariQosEnabled: boolean;\n mariLiteEnabled?: boolean;\n multistreamEnabled: boolean;\n isMediaBypassEdge?: boolean;\n direction: \"sendrecv\" | \"sendonly\" | \"recvonly\" | \"inactive\";\n localPort?: number;\n peerReflexivePort?: number;\n remotePort?: number;\n };\n fecPackets: number;\n fecBitrate: number;\n rtxPackets?: number;\n rtxBitrate?: number;\n meanRtxDelay?: number;\n maxRtxDelay?: number;\n rtpPackets: number;\n rtpBitrate: number;\n rtpHopByHopLost: number;\n mediaHopByHopLost: number;\n rtpRecovered: number;\n rtxRecovered?: number;\n rtcpPackets: number;\n rtcpBitrate: number;\n /**\n * RTCP Information for a given Interval\n */\n rxRtcpInfo?: {\n rtcpSrPackets: number;\n rtcpRrPackets: number;\n rtcpReportBlocks: number;\n rtcpSdesPackets: number;\n rtcpByePackets: number;\n rtcpAppPackets: number;\n rtcpRtpFbPacket: number;\n rtcpPsFbPackets: number;\n rtcpPsFbMariPackets: number;\n rtcpPsFbMultistreamPackets: number;\n rtcpXrPackets: number;\n };\n stunPackets: number;\n stunBitrate: number;\n dtlsPackets: number;\n dtlsBitrate: number;\n transportType: \"UDP\" | \"TCP\" | \"xTLS\" | \"TLS\";\n maxBitrate: number;\n srtpUnprotectErrors: number;\n /**\n * SRTP/SRTCP unprotect error details\n */\n srtpUnprotectErrorDetails?: {\n authFailures: number;\n cipherFailures: number;\n replayFailures: number;\n unknownFailures: number;\n };\n srtcpUnprotectErrors: number;\n /**\n * SRTP/SRTCP unprotect error details\n */\n srtcpUnprotectErrorDetails?: {\n authFailures: number;\n cipherFailures: number;\n replayFailures: number;\n unknownFailures: number;\n };\n };\n streams: {\n /**\n * contains fields common to all types of receive stream\n */\n common: {\n ssci: number;\n rtpPackets: number;\n rtpEndToEndLost: number;\n concealedFrames: number;\n maxConcealRunLength: number;\n receivedFrameRate: number;\n renderedFrameRate: number;\n requestedFrameRate: number;\n optimalFrameRate: number;\n meanRtpJitter?: number;\n maxRtpJitter?: number;\n rtpJitter?: number;\n receivedBitrate: number;\n requestedBitrate: number;\n optimalBitrate: number;\n durationForSpeedChanged?: number;\n endToEndTransmitDelay?: number;\n csi: number[];\n codec: string;\n /**\n * This object tracks SSRC and CSRC changes for an RTP stream, session, etc\n */\n sourceChanges?: {\n /**\n * The number of RTP SSRC changes seen. The first RTP packet seen should NOT be counted as a change.\n */\n ssrcChanges: number;\n /**\n * The number of RTP CSRC changes seen. The first RTP packet seen should NOT be counted as a change. Changes from zero to non-zero CSRC should be counted as a change.\n */\n csrcChanges: number;\n };\n /**\n * The object tracks the detail reasons by which concealment is caused. The unit of metrics depend on upper-level objects. Currently, packet or frame can be used as unit.\n */\n concealmentReasonByPacket?: {\n /**\n * concealment caused by network loss\n */\n byNetwork?: number;\n /**\n * concealment caused by buffer overflow. when total buffer length exceeds max delay threshold, buffer will overflow and data will be dropped.\n */\n byOverflow?: number;\n /**\n * concealment caused by buffer is reset.\n */\n byReset?: number;\n /**\n * concealment caused by late packet or frame. some packets or frames arrive late and the previous one has been played.\n */\n byLate?: number;\n /**\n * concealment caused by poor performance.\n */\n byPoorPerformance?: number;\n /**\n * only for audio. Number of concealment packets/frames sent to the audio decoder when frames are held back to increase re-order audio delay.\n */\n byIncreasedDelay?: number;\n /**\n * only for video. concealment caused by AV sync\n */\n byAVSync?: number;\n /**\n * only for video. Some video frames which have not been complete are forced to pop up because the subsequent frame has been complete. This cause video concealment.\n */\n byPrevFramePopped?: number;\n /**\n * concealment caused by the other unknown reasons\n */\n byOthers?: number;\n };\n /**\n * The object tracks the detail reasons by which concealment is caused. The unit of metrics depend on upper-level objects. Currently, packet or frame can be used as unit.\n */\n concealmentReasonByFrame?: {\n /**\n * concealment caused by network loss\n */\n byNetwork?: number;\n /**\n * concealment caused by buffer overflow. when total buffer length exceeds max delay threshold, buffer will overflow and data will be dropped.\n */\n byOverflow?: number;\n /**\n * concealment caused by buffer is reset.\n */\n byReset?: number;\n /**\n * concealment caused by late packet or frame. some packets or frames arrive late and the previous one has been played.\n */\n byLate?: number;\n /**\n * concealment caused by poor performance.\n */\n byPoorPerformance?: number;\n /**\n * only for audio. Number of concealment packets/frames sent to the audio decoder when frames are held back to increase re-order audio delay.\n */\n byIncreasedDelay?: number;\n /**\n * only for video. concealment caused by AV sync\n */\n byAVSync?: number;\n /**\n * only for video. Some video frames which have not been complete are forced to pop up because the subsequent frame has been complete. This cause video concealment.\n */\n byPrevFramePopped?: number;\n /**\n * concealment caused by the other unknown reasons\n */\n byOthers?: number;\n };\n /**\n * the number of consecutive concealment time which is larger than the threshold in one minute. Currently, 60 and 120 ms are used as the threshold.\n */\n interruptCount?: {\n /**\n * interrupt count longer than 60 ms in one minute\n */\n longerThan60?: number;\n /**\n * interrupt count longer than 120 ms in one minute\n */\n longerThan120?: number;\n };\n /**\n * This object tracks the delay associated with a jitter buffer\n */\n jitterBufferDelay?: {\n /**\n * The average delay (in milliseconds) used by the jitter buffer\n */\n meanDelay: number;\n /**\n * The maximum delay (in milliseconds) used by the jitter buffer\n */\n maxDelay: number;\n /**\n * The minimum delay (in milliseconds) used by the jitter buffer\n */\n minDelay: number;\n };\n /**\n * This object tracks the the end to end delay(the delay between capture time of sender side and render time of receiver side)\n */\n endToEndDelay?: {\n /**\n * The average delay (in milliseconds) from end to end\n */\n meanDelay: number;\n /**\n * The maximum delay (in milliseconds) from end to end\n */\n maxDelay: number;\n /**\n * The minimum delay (in milliseconds) from end to end\n */\n minDelay: number;\n };\n /**\n * Aggregated end to end delay representing the mean, max, min delay group by csi\n */\n endToEndDelayByCsi?: {\n csi?: number;\n delay?: unknown;\n }[];\n };\n isRxCallBackgroundNoiseReductionModeOn?: boolean;\n isMeasureSNROn?: boolean;\n averageSNRValue?: number;\n /**\n * contains fields for QOEM MOS score\n */\n audioqoem?: {\n version: string;\n /**\n * Average Estimated Mean Opinion Score by considering network’s jitter, loss etc.\n */\n averageNetMOS: number;\n /**\n * Min Estimated Mean Opinion score by considering network’s jitter, loss etc.\n */\n minNetMOS: number;\n /**\n * Average Estimated Mean Opinion Score jitter buffer’s status, such as drop packet, do PLC, do recover etc.\n */\n averageJitterMOS: number;\n /**\n * Min Estimated Mean Opinion Score jitter buffer’s status, such as drop packet, do PLC, do recover etc.\n */\n minJitterMOS: number;\n /**\n * Perceptual Evaluation of Speech Quality - Listening Quality Objective (PESQ-LQO)\n */\n pesqLQO?: number;\n };\n audioPlaybackMethod?: \"AUDIO_ANDROID_JAVA_METHOD\" | \"AUDIO_ANDROID_AAUDIO_METHOD\";\n /**\n * audio received algorithm modules performance data(AGC,NR,MultiChannelPreprocess)\n */\n audioAlgorithmModulesInfo?: {\n /**\n * one unsigned char every 1 minute, 0 for 0dB, plus 1 for -0.5dB\n */\n speechRMS?: number;\n /**\n * one unsigned char every 1 minute, 0 for 0s, plus 4 for +1s\n */\n speechLength?: number;\n /**\n * one unsigned char every 1 minute, VAD value to reflect speech quality\n */\n speechQuality?: number;\n /**\n * one unsigned short every 1 minute\n */\n bnrTRN?: number;\n };\n /**\n * audio receive pipeline modules' quality metric\n */\n audioModuleQualityInfo?: {\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n agcOutPower?: number[];\n /**\n * one char every 2 seconds. 0 indicate 0dB, plus 1 indicate -0.5dB\n */\n agcAvgOutPower?: number[];\n };\n /**\n * This object tracks the the audio video sync data, to see whether the video timestamp is matching with audio timestamp\n */\n avSync?: {\n /**\n * Compared with audio, the maximum video delay time (in milliseconds) in last interval\n */\n maxVideoLateInterval?: number;\n /**\n * Compared with audio, the maximum video early time (in milliseconds) in last interval\n */\n maxVideoEarlyInterval?: number;\n /**\n * Compared with audio, the unsync video frames get played out / total frames\n */\n decidePlayedUnsyncRatio?: number;\n };\n }[];\n /**\n * information about tracked audio levels\n */\n levels?: {\n /**\n * The average audio input gain for a microphone or speaker, in decibels\n */\n audioMeanGain?: number;\n /**\n * The minimum audio input gain for a microphone or speaker, in decibels\n */\n audioMinGain?: number;\n /**\n * The maximum audio input gain for a microphone or speaker, in decibels\n */\n audioMaxGain?: number;\n /**\n * The mean audio output volume for a microphone or speaker, in absolute volume [0-65535]\n */\n audioMeanVolume?: number;\n /**\n * The min audio output volume for a microphone or speaker, in absolute volume [0-65535]\n */\n audioMinVolume?: number;\n /**\n * The max audio output volume for a microphone or speaker, in absolute volume [0-65535]\n */\n audioMaxVolume?: number;\n };\n playbackHardwareRequiredAudioPacketsPerSecond?: number;\n }[];\n videoReceive: {\n /**\n * contains the receive related fields between all sessions types for each interval.\n */\n common: {\n /**\n * contains the fields common to both transmit and receive sessions for each interval\n */\n common: {\n isMain: boolean;\n mariFecEnabled: boolean;\n mariRtxEnabled?: boolean;\n mariQosEnabled: boolean;\n mariLiteEnabled?: boolean;\n multistreamEnabled: boolean;\n isMediaBypassEdge?: boolean;\n direction: \"sendrecv\" | \"sendonly\" | \"recvonly\" | \"inactive\";\n localPort?: number;\n peerReflexivePort?: number;\n remotePort?: number;\n };\n fecPackets: number;\n fecBitrate: number;\n rtxPackets?: number;\n rtxBitrate?: number;\n meanRtxDelay?: number;\n maxRtxDelay?: number;\n rtpPackets: number;\n rtpBitrate: number;\n rtpHopByHopLost: number;\n mediaHopByHopLost: number;\n rtpRecovered: number;\n rtxRecovered?: number;\n rtcpPackets: number;\n rtcpBitrate: number;\n /**\n * RTCP Information for a given Interval\n */\n rxRtcpInfo?: {\n rtcpSrPackets: number;\n rtcpRrPackets: number;\n rtcpReportBlocks: number;\n rtcpSdesPackets: number;\n rtcpByePackets: number;\n rtcpAppPackets: number;\n rtcpRtpFbPacket: number;\n rtcpPsFbPackets: number;\n rtcpPsFbMariPackets: number;\n rtcpPsFbMultistreamPackets: number;\n rtcpXrPackets: number;\n };\n stunPackets: number;\n stunBitrate: number;\n dtlsPackets: number;\n dtlsBitrate: number;\n transportType: \"UDP\" | \"TCP\" | \"xTLS\" | \"TLS\";\n maxBitrate: number;\n srtpUnprotectErrors: number;\n /**\n * SRTP/SRTCP unprotect error details\n */\n srtpUnprotectErrorDetails?: {\n authFailures: number;\n cipherFailures: number;\n replayFailures: number;\n unknownFailures: number;\n };\n srtcpUnprotectErrors: number;\n /**\n * SRTP/SRTCP unprotect error details\n */\n srtcpUnprotectErrorDetails?: {\n authFailures: number;\n cipherFailures: number;\n replayFailures: number;\n unknownFailures: number;\n };\n };\n streams: {\n /**\n * contains fields common to all types of receive stream\n */\n common: {\n ssci: number;\n rtpPackets: number;\n rtpEndToEndLost: number;\n concealedFrames: number;\n maxConcealRunLength: number;\n receivedFrameRate: number;\n renderedFrameRate: number;\n requestedFrameRate: number;\n optimalFrameRate: number;\n meanRtpJitter?: number;\n maxRtpJitter?: number;\n rtpJitter?: number;\n receivedBitrate: number;\n requestedBitrate: number;\n optimalBitrate: number;\n durationForSpeedChanged?: number;\n endToEndTransmitDelay?: number;\n csi: number[];\n codec: string;\n /**\n * This object tracks SSRC and CSRC changes for an RTP stream, session, etc\n */\n sourceChanges?: {\n /**\n * The number of RTP SSRC changes seen. The first RTP packet seen should NOT be counted as a change.\n */\n ssrcChanges: number;\n /**\n * The number of RTP CSRC changes seen. The first RTP packet seen should NOT be counted as a change. Changes from zero to non-zero CSRC should be counted as a change.\n */\n csrcChanges: number;\n };\n /**\n * The object tracks the detail reasons by which concealment is caused. The unit of metrics depend on upper-level objects. Currently, packet or frame can be used as unit.\n */\n concealmentReasonByPacket?: {\n /**\n * concealment caused by network loss\n */\n byNetwork?: number;\n /**\n * concealment caused by buffer overflow. when total buffer length exceeds max delay threshold, buffer will overflow and data will be dropped.\n */\n byOverflow?: number;\n /**\n * concealment caused by buffer is reset.\n */\n byReset?: number;\n /**\n * concealment caused by late packet or frame. some packets or frames arrive late and the previous one has been played.\n */\n byLate?: number;\n /**\n * concealment caused by poor performance.\n */\n byPoorPerformance?: number;\n /**\n * only for audio. Number of concealment packets/frames sent to the audio decoder when frames are held back to increase re-order audio delay.\n */\n byIncreasedDelay?: number;\n /**\n * only for video. concealment caused by AV sync\n */\n byAVSync?: number;\n /**\n * only for video. Some video frames which have not been complete are forced to pop up because the subsequent frame has been complete. This cause video concealment.\n */\n byPrevFramePopped?: number;\n /**\n * concealment caused by the other unknown reasons\n */\n byOthers?: number;\n };\n /**\n * The object tracks the detail reasons by which concealment is caused. The unit of metrics depend on upper-level objects. Currently, packet or frame can be used as unit.\n */\n concealmentReasonByFrame?: {\n /**\n * concealment caused by network loss\n */\n byNetwork?: number;\n /**\n * concealment caused by buffer overflow. when total buffer length exceeds max delay threshold, buffer will overflow and data will be dropped.\n */\n byOverflow?: number;\n /**\n * concealment caused by buffer is reset.\n */\n byReset?: number;\n /**\n * concealment caused by late packet or frame. some packets or frames arrive late and the previous one has been played.\n */\n byLate?: number;\n /**\n * concealment caused by poor performance.\n */\n byPoorPerformance?: number;\n /**\n * only for audio. Number of concealment packets/frames sent to the audio decoder when frames are held back to increase re-order audio delay.\n */\n byIncreasedDelay?: number;\n /**\n * only for video. concealment caused by AV sync\n */\n byAVSync?: number;\n /**\n * only for video. Some video frames which have not been complete are forced to pop up because the subsequent frame has been complete. This cause video concealment.\n */\n byPrevFramePopped?: number;\n /**\n * concealment caused by the other unknown reasons\n */\n byOthers?: number;\n };\n /**\n * the number of consecutive concealment time which is larger than the threshold in one minute. Currently, 60 and 120 ms are used as the threshold.\n */\n interruptCount?: {\n /**\n * interrupt count longer than 60 ms in one minute\n */\n longerThan60?: number;\n /**\n * interrupt count longer than 120 ms in one minute\n */\n longerThan120?: number;\n };\n /**\n * This object tracks the delay associated with a jitter buffer\n */\n jitterBufferDelay?: {\n /**\n * The average delay (in milliseconds) used by the jitter buffer\n */\n meanDelay: number;\n /**\n * The maximum delay (in milliseconds) used by the jitter buffer\n */\n maxDelay: number;\n /**\n * The minimum delay (in milliseconds) used by the jitter buffer\n */\n minDelay: number;\n };\n /**\n * This object tracks the the end to end delay(the delay between capture time of sender side and render time of receiver side)\n */\n endToEndDelay?: {\n /**\n * The average delay (in milliseconds) from end to end\n */\n meanDelay: number;\n /**\n * The maximum delay (in milliseconds) from end to end\n */\n maxDelay: number;\n /**\n * The minimum delay (in milliseconds) from end to end\n */\n minDelay: number;\n };\n /**\n * Aggregated end to end delay representing the mean, max, min delay group by csi\n */\n endToEndDelayByCsi?: {\n csi?: number;\n delay?: unknown;\n }[];\n };\n receivedFrameSize: number;\n requestedFrameSize: number;\n optimalFrameSize: number;\n receivedHeight: number;\n receivedWidth: number;\n receivedKeyFrames: number;\n requestedKeyFrames: number;\n receivedKeyFramesSourceChange?: number;\n receivedKeyFramesConfigurationChange?: number;\n receivedKeyFramesForRequest?: number;\n receivedKeyFramesUnknown?: number;\n isActiveSpeaker?: boolean;\n h264CodecProfile: \"BP\" | \"CHP\";\n isHardwareDecoded?: boolean;\n /**\n * receive video pipeline performance metric\n */\n decoderProcessInfo?: {\n meanDecoderProcessMillis: number;\n maxDecoderProcessMillis: number;\n };\n receivedBuffer?: number;\n receivedFrameRateNormalShare?: number;\n receivedFrameRateHFPSShare?: number;\n renderWindowResolution?: number;\n scaledResolution?: number;\n }[];\n }[];\n gamestateTransmit?: {\n /**\n * contains the transmit related fields common between all session types for each interval\n */\n common: {\n /**\n * contains the fields common to both transmit and receive sessions for each interval\n */\n common: {\n isMain: boolean;\n mariFecEnabled: boolean;\n mariRtxEnabled?: boolean;\n mariQosEnabled: boolean;\n mariLiteEnabled?: boolean;\n multistreamEnabled: boolean;\n isMediaBypassEdge?: boolean;\n direction: \"sendrecv\" | \"sendonly\" | \"recvonly\" | \"inactive\";\n localPort?: number;\n peerReflexivePort?: number;\n remotePort?: number;\n };\n fecPackets: number;\n fecBitrate: number;\n rtxPackets?: number;\n rtxBitrate?: number;\n rtpPackets: number;\n rtpBitrate: number;\n rtcpPackets: number;\n rtcpBitrate: number;\n /**\n * RTCP Information for a given Interval\n */\n txRtcpInfo?: {\n rtcpSrPackets: number;\n rtcpRrPackets: number;\n rtcpReportBlocks: number;\n rtcpSdesPackets: number;\n rtcpByePackets: number;\n rtcpAppPackets: number;\n rtcpRtpFbPacket: number;\n rtcpPsFbPackets: number;\n rtcpPsFbMariPackets: number;\n rtcpPsFbMultistreamPackets: number;\n rtcpXrPackets: number;\n };\n stunPackets: number;\n stunBitrate: number;\n dtlsPackets: number;\n dtlsBitrate: number;\n transportType: \"UDP\" | \"TCP\" | \"xTLS\" | \"TLS\";\n maxBitrate: number;\n availableBitrate: number;\n queueDelay: number;\n meanRoundTripTime?: number;\n maxRoundTripTime?: number;\n roundTripTime: number;\n remoteReceiveRate?: number;\n maxRemoteLossRate?: number;\n remoteLossRate?: number;\n meanRemoteLossRate?: number;\n maxRemoteJitter?: number;\n remoteJitter?: number;\n meanRemoteJitter?: number;\n traversalMinDelayMs?: number;\n traversalMaxDelayMs?: number;\n traversalMeanDelayMs?: number;\n rtpInputFifoDelayMs?: number;\n rtpInputFifoMaxDelayMs?: number;\n rtpInputFifoMinDelayMs?: number;\n rtpInputFifoMeanDelayMs?: number;\n };\n streams: {\n /**\n * contains fields common to all transmit streams types\n */\n common: {\n ssci: number;\n duplicateSsci?: number;\n rtpPackets: number;\n transmittedFrameRate: number;\n requestedFrames: number;\n transmittedBitrate: number;\n requestedBitrate: number;\n captureOffset?: number;\n codec: string;\n csi?: number[];\n /**\n * This object tracks SSRC and CSRC changes for an RTP stream, session, etc\n */\n sourceChanges?: {\n /**\n * The number of RTP SSRC changes seen. The first RTP packet seen should NOT be counted as a change.\n */\n ssrcChanges: number;\n /**\n * The number of RTP CSRC changes seen. The first RTP packet seen should NOT be counted as a change. Changes from zero to non-zero CSRC should be counted as a change.\n */\n csrcChanges: number;\n };\n };\n gamestateObjects?: {\n objectId: number;\n numberOfUpdates: number;\n tag: unknown;\n isActive: boolean;\n }[];\n }[];\n }[];\n gamestateReceive?: {\n /**\n * contains the receive related fields between all sessions types for each interval.\n */\n common: {\n /**\n * contains the fields common to both transmit and receive sessions for each interval\n */\n common: {\n isMain: boolean;\n mariFecEnabled: boolean;\n mariRtxEnabled?: boolean;\n mariQosEnabled: boolean;\n mariLiteEnabled?: boolean;\n multistreamEnabled: boolean;\n isMediaBypassEdge?: boolean;\n direction: \"sendrecv\" | \"sendonly\" | \"recvonly\" | \"inactive\";\n localPort?: number;\n peerReflexivePort?: number;\n remotePort?: number;\n };\n fecPackets: number;\n fecBitrate: number;\n rtxPackets?: number;\n rtxBitrate?: number;\n meanRtxDelay?: number;\n maxRtxDelay?: number;\n rtpPackets: number;\n rtpBitrate: number;\n rtpHopByHopLost: number;\n mediaHopByHopLost: number;\n rtpRecovered: number;\n rtxRecovered?: number;\n rtcpPackets: number;\n rtcpBitrate: number;\n /**\n * RTCP Information for a given Interval\n */\n rxRtcpInfo?: {\n rtcpSrPackets: number;\n rtcpRrPackets: number;\n rtcpReportBlocks: number;\n rtcpSdesPackets: number;\n rtcpByePackets: number;\n rtcpAppPackets: number;\n rtcpRtpFbPacket: number;\n rtcpPsFbPackets: number;\n rtcpPsFbMariPackets: number;\n rtcpPsFbMultistreamPackets: number;\n rtcpXrPackets: number;\n };\n stunPackets: number;\n stunBitrate: number;\n dtlsPackets: number;\n dtlsBitrate: number;\n transportType: \"UDP\" | \"TCP\" | \"xTLS\" | \"TLS\";\n maxBitrate: number;\n srtpUnprotectErrors: number;\n /**\n * SRTP/SRTCP unprotect error details\n */\n srtpUnprotectErrorDetails?: {\n authFailures: number;\n cipherFailures: number;\n replayFailures: number;\n unknownFailures: number;\n };\n srtcpUnprotectErrors: number;\n /**\n * SRTP/SRTCP unprotect error details\n */\n srtcpUnprotectErrorDetails?: {\n authFailures: number;\n cipherFailures: number;\n replayFailures: number;\n unknownFailures: number;\n };\n };\n streams: {\n /**\n * contains fields common to all types of receive stream\n */\n common: {\n ssci: number;\n rtpPackets: number;\n rtpEndToEndLost: number;\n concealedFrames: number;\n maxConcealRunLength: number;\n receivedFrameRate: number;\n renderedFrameRate: number;\n requestedFrameRate: number;\n optimalFrameRate: number;\n meanRtpJitter?: number;\n maxRtpJitter?: number;\n rtpJitter?: number;\n receivedBitrate: number;\n requestedBitrate: number;\n optimalBitrate: number;\n durationForSpeedChanged?: number;\n endToEndTransmitDelay?: number;\n csi: number[];\n codec: string;\n /**\n * This object tracks SSRC and CSRC changes for an RTP stream, session, etc\n */\n sourceChanges?: {\n /**\n * The number of RTP SSRC changes seen. The first RTP packet seen should NOT be counted as a change.\n */\n ssrcChanges: number;\n /**\n * The number of RTP CSRC changes seen. The first RTP packet seen should NOT be counted as a change. Changes from zero to non-zero CSRC should be counted as a change.\n */\n csrcChanges: number;\n };\n /**\n * The object tracks the detail reasons by which concealment is caused. The unit of metrics depend on upper-level objects. Currently, packet or frame can be used as unit.\n */\n concealmentReasonByPacket?: {\n /**\n * concealment caused by network loss\n */\n byNetwork?: number;\n /**\n * concealment caused by buffer overflow. when total buffer length exceeds max delay threshold, buffer will overflow and data will be dropped.\n */\n byOverflow?: number;\n /**\n * concealment caused by buffer is reset.\n */\n byReset?: number;\n /**\n * concealment caused by late packet or frame. some packets or frames arrive late and the previous one has been played.\n */\n byLate?: number;\n /**\n * concealment caused by poor performance.\n */\n byPoorPerformance?: number;\n /**\n * only for audio. Number of concealment packets/frames sent to the audio decoder when frames are held back to increase re-order audio delay.\n */\n byIncreasedDelay?: number;\n /**\n * only for video. concealment caused by AV sync\n */\n byAVSync?: number;\n /**\n * only for video. Some video frames which have not been complete are forced to pop up because the subsequent frame has been complete. This cause video concealment.\n */\n byPrevFramePopped?: number;\n /**\n * concealment caused by the other unknown reasons\n */\n byOthers?: number;\n };\n /**\n * The object tracks the detail reasons by which concealment is caused. The unit of metrics depend on upper-level objects. Currently, packet or frame can be used as unit.\n */\n concealmentReasonByFrame?: {\n /**\n * concealment caused by network loss\n */\n byNetwork?: number;\n /**\n * concealment caused by buffer overflow. when total buffer length exceeds max delay threshold, buffer will overflow and data will be dropped.\n */\n byOverflow?: number;\n /**\n * concealment caused by buffer is reset.\n */\n byReset?: number;\n /**\n * concealment caused by late packet or frame. some packets or frames arrive late and the previous one has been played.\n */\n byLate?: number;\n /**\n * concealment caused by poor performance.\n */\n byPoorPerformance?: number;\n /**\n * only for audio. Number of concealment packets/frames sent to the audio decoder when frames are held back to increase re-order audio delay.\n */\n byIncreasedDelay?: number;\n /**\n * only for video. concealment caused by AV sync\n */\n byAVSync?: number;\n /**\n * only for video. Some video frames which have not been complete are forced to pop up because the subsequent frame has been complete. This cause video concealment.\n */\n byPrevFramePopped?: number;\n /**\n * concealment caused by the other unknown reasons\n */\n byOthers?: number;\n };\n /**\n * the number of consecutive concealment time which is larger than the threshold in one minute. Currently, 60 and 120 ms are used as the threshold.\n */\n interruptCount?: {\n /**\n * interrupt count longer than 60 ms in one minute\n */\n longerThan60?: number;\n /**\n * interrupt count longer than 120 ms in one minute\n */\n longerThan120?: number;\n };\n /**\n * This object tracks the delay associated with a jitter buffer\n */\n jitterBufferDelay?: {\n /**\n * The average delay (in milliseconds) used by the jitter buffer\n */\n meanDelay: number;\n /**\n * The maximum delay (in milliseconds) used by the jitter buffer\n */\n maxDelay: number;\n /**\n * The minimum delay (in milliseconds) used by the jitter buffer\n */\n minDelay: number;\n };\n /**\n * This object tracks the the end to end delay(the delay between capture time of sender side and render time of receiver side)\n */\n endToEndDelay?: {\n /**\n * The average delay (in milliseconds) from end to end\n */\n meanDelay: number;\n /**\n * The maximum delay (in milliseconds) from end to end\n */\n maxDelay: number;\n /**\n * The minimum delay (in milliseconds) from end to end\n */\n minDelay: number;\n };\n /**\n * Aggregated end to end delay representing the mean, max, min delay group by csi\n */\n endToEndDelayByCsi?: {\n csi?: number;\n delay?: unknown;\n }[];\n };\n gamestateObjects?: {\n objectId: number;\n numberOfUpdates: number;\n tag: unknown;\n isActive: boolean;\n }[];\n }[];\n }[];\n }[];\n}\n"],"mappings":""}
|
|
@@ -1,22 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
-
|
|
5
4
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
6
|
-
|
|
7
5
|
_Object$defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
|
-
|
|
11
8
|
exports.default = void 0;
|
|
12
|
-
|
|
13
9
|
var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
|
|
14
|
-
|
|
15
10
|
var _batcher = _interopRequireDefault(require("./batcher"));
|
|
16
|
-
|
|
17
11
|
/*!
|
|
18
12
|
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
19
13
|
*/
|
|
14
|
+
|
|
20
15
|
var ClientMetricsBatcher = _batcher.default.extend({
|
|
21
16
|
namespace: 'Metrics',
|
|
22
17
|
prepareItem: function prepareItem(item) {
|
|
@@ -37,7 +32,6 @@ var ClientMetricsBatcher = _batcher.default.extend({
|
|
|
37
32
|
});
|
|
38
33
|
}
|
|
39
34
|
});
|
|
40
|
-
|
|
41
35
|
var _default = ClientMetricsBatcher;
|
|
42
36
|
exports.default = _default;
|
|
43
37
|
//# sourceMappingURL=client-metrics-batcher.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["ClientMetricsBatcher","Batcher","extend","namespace","prepareItem","item","resolve","prepareRequest","queue","submitHttpRequest","payload","webex","request","method","service","resource","body","metrics"],"sources":["client-metrics-batcher.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport Batcher from './batcher';\n\nconst ClientMetricsBatcher = Batcher.extend({\n namespace: 'Metrics',\n\n prepareItem(item) {\n // Add more defaults to payload when the clientmetrics endpoint evolves to support richer payloads\n return Promise.resolve(item);\n },\n\n prepareRequest(queue) {\n return Promise.resolve(queue);\n },\n\n submitHttpRequest(payload) {\n return this.webex.request({\n method: 'POST',\n service: 'metrics',\n resource: 'clientmetrics',\n body: {\n metrics: payload
|
|
1
|
+
{"version":3,"names":["ClientMetricsBatcher","Batcher","extend","namespace","prepareItem","item","resolve","prepareRequest","queue","submitHttpRequest","payload","webex","request","method","service","resource","body","metrics"],"sources":["client-metrics-batcher.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport Batcher from './batcher';\n\nconst ClientMetricsBatcher = Batcher.extend({\n namespace: 'Metrics',\n\n prepareItem(item) {\n // Add more defaults to payload when the clientmetrics endpoint evolves to support richer payloads\n return Promise.resolve(item);\n },\n\n prepareRequest(queue) {\n return Promise.resolve(queue);\n },\n\n submitHttpRequest(payload) {\n return this.webex.request({\n method: 'POST',\n service: 'metrics',\n resource: 'clientmetrics',\n body: {\n metrics: payload,\n },\n });\n },\n});\n\nexport default ClientMetricsBatcher;\n"],"mappings":";;;;;;;;;AAIA;AAJA;AACA;AACA;;AAIA,IAAMA,oBAAoB,GAAGC,gBAAO,CAACC,MAAM,CAAC;EAC1CC,SAAS,EAAE,SAAS;EAEpBC,WAAW,uBAACC,IAAI,EAAE;IAChB;IACA,OAAO,iBAAQC,OAAO,CAACD,IAAI,CAAC;EAC9B,CAAC;EAEDE,cAAc,0BAACC,KAAK,EAAE;IACpB,OAAO,iBAAQF,OAAO,CAACE,KAAK,CAAC;EAC/B,CAAC;EAEDC,iBAAiB,6BAACC,OAAO,EAAE;IACzB,OAAO,IAAI,CAACC,KAAK,CAACC,OAAO,CAAC;MACxBC,MAAM,EAAE,MAAM;MACdC,OAAO,EAAE,SAAS;MAClBC,QAAQ,EAAE,eAAe;MACzBC,IAAI,EAAE;QACJC,OAAO,EAAEP;MACX;IACF,CAAC,CAAC;EACJ;AACF,CAAC,CAAC;AAAC,eAEYV,oBAAoB;AAAA"}
|
package/dist/config.js
CHANGED
|
@@ -1,18 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
-
|
|
5
4
|
_Object$defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
|
-
|
|
9
|
-
exports.default = exports.CLIENT_NAME = void 0;
|
|
10
|
-
|
|
7
|
+
exports.default = exports.OS_NAME = exports.OSMap = exports.CLIENT_NAME = void 0;
|
|
11
8
|
var _common = require("@webex/common");
|
|
12
|
-
|
|
13
9
|
/*!
|
|
14
10
|
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
15
11
|
*/
|
|
12
|
+
|
|
16
13
|
var CLIENT_NAME = 'webex-js-sdk';
|
|
17
14
|
exports.CLIENT_NAME = CLIENT_NAME;
|
|
18
15
|
var _default = {
|
|
@@ -31,4 +28,23 @@ var _default = {
|
|
|
31
28
|
}
|
|
32
29
|
};
|
|
33
30
|
exports.default = _default;
|
|
31
|
+
var OS_NAME = {
|
|
32
|
+
WINDOWS: 'windows',
|
|
33
|
+
MAC: 'mac',
|
|
34
|
+
IOS: 'ios',
|
|
35
|
+
ANDROID: 'android',
|
|
36
|
+
CHROME: 'chrome',
|
|
37
|
+
LINUX: 'linux',
|
|
38
|
+
OTHERS: 'other'
|
|
39
|
+
};
|
|
40
|
+
exports.OS_NAME = OS_NAME;
|
|
41
|
+
var OSMap = {
|
|
42
|
+
'Chrome OS': OS_NAME.CHROME,
|
|
43
|
+
macOS: OS_NAME.MAC,
|
|
44
|
+
Windows: OS_NAME.WINDOWS,
|
|
45
|
+
iOS: OS_NAME.IOS,
|
|
46
|
+
Android: OS_NAME.ANDROID,
|
|
47
|
+
Linux: OS_NAME.LINUX
|
|
48
|
+
};
|
|
49
|
+
exports.OSMap = OSMap;
|
|
34
50
|
//# sourceMappingURL=config.js.map
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["CLIENT_NAME","device","preDiscoveryServices","metricsServiceUrl","process","env","METRICS_SERVICE_URL","metrics","appType","inBrowser","batcherWait","batcherMaxCalls","batcherMaxWait","batcherRetryPlateau"],"sources":["config.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {inBrowser} from '@webex/common';\n\nexport const CLIENT_NAME = 'webex-js-sdk';\nexport default {\n device: {\n preDiscoveryServices: {\n metricsServiceUrl
|
|
1
|
+
{"version":3,"names":["CLIENT_NAME","device","preDiscoveryServices","metricsServiceUrl","process","env","METRICS_SERVICE_URL","metrics","appType","inBrowser","batcherWait","batcherMaxCalls","batcherMaxWait","batcherRetryPlateau","OS_NAME","WINDOWS","MAC","IOS","ANDROID","CHROME","LINUX","OTHERS","OSMap","macOS","Windows","iOS","Android","Linux"],"sources":["config.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {inBrowser} from '@webex/common';\n\nexport const CLIENT_NAME = 'webex-js-sdk';\nexport default {\n device: {\n preDiscoveryServices: {\n metricsServiceUrl:\n process.env.METRICS_SERVICE_URL || 'https://metrics-a.wbx2.com/metrics/api/v1',\n metrics: process.env.METRICS_SERVICE_URL || 'https://metrics-a.wbx2.com/metrics/api/v1',\n },\n },\n metrics: {\n appType: inBrowser ? 'browser' : 'nodejs',\n batcherWait: 500,\n batcherMaxCalls: 50,\n batcherMaxWait: 1500,\n batcherRetryPlateau: 32000,\n },\n};\n\nexport const OS_NAME = {\n WINDOWS: 'windows',\n MAC: 'mac',\n IOS: 'ios',\n ANDROID: 'android',\n CHROME: 'chrome',\n LINUX: 'linux',\n OTHERS: 'other',\n};\n\nexport const OSMap = {\n 'Chrome OS': OS_NAME.CHROME,\n macOS: OS_NAME.MAC,\n Windows: OS_NAME.WINDOWS,\n iOS: OS_NAME.IOS,\n Android: OS_NAME.ANDROID,\n Linux: OS_NAME.LINUX,\n};\n"],"mappings":";;;;;;;AAIA;AAJA;AACA;AACA;;AAIO,IAAMA,WAAW,GAAG,cAAc;AAAC;AAAA,eAC3B;EACbC,MAAM,EAAE;IACNC,oBAAoB,EAAE;MACpBC,iBAAiB,EACfC,OAAO,CAACC,GAAG,CAACC,mBAAmB,IAAI,2CAA2C;MAChFC,OAAO,EAAEH,OAAO,CAACC,GAAG,CAACC,mBAAmB,IAAI;IAC9C;EACF,CAAC;EACDC,OAAO,EAAE;IACPC,OAAO,EAAEC,iBAAS,GAAG,SAAS,GAAG,QAAQ;IACzCC,WAAW,EAAE,GAAG;IAChBC,eAAe,EAAE,EAAE;IACnBC,cAAc,EAAE,IAAI;IACpBC,mBAAmB,EAAE;EACvB;AACF,CAAC;AAAA;AAEM,IAAMC,OAAO,GAAG;EACrBC,OAAO,EAAE,SAAS;EAClBC,GAAG,EAAE,KAAK;EACVC,GAAG,EAAE,KAAK;EACVC,OAAO,EAAE,SAAS;EAClBC,MAAM,EAAE,QAAQ;EAChBC,KAAK,EAAE,OAAO;EACdC,MAAM,EAAE;AACV,CAAC;AAAC;AAEK,IAAMC,KAAK,GAAG;EACnB,WAAW,EAAER,OAAO,CAACK,MAAM;EAC3BI,KAAK,EAAET,OAAO,CAACE,GAAG;EAClBQ,OAAO,EAAEV,OAAO,CAACC,OAAO;EACxBU,GAAG,EAAEX,OAAO,CAACG,GAAG;EAChBS,OAAO,EAAEZ,OAAO,CAACI,OAAO;EACxBS,KAAK,EAAEb,OAAO,CAACM;AACjB,CAAC;AAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,39 +1,55 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var _typeof = require("@babel/runtime-corejs2/helpers/typeof");
|
|
4
|
+
var _WeakMap = require("@babel/runtime-corejs2/core-js/weak-map");
|
|
3
5
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
-
|
|
6
|
+
var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptor");
|
|
5
7
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
6
|
-
|
|
7
8
|
_Object$defineProperty(exports, "__esModule", {
|
|
8
9
|
value: true
|
|
9
10
|
});
|
|
10
|
-
|
|
11
|
+
exports.CALL_DIAGNOSTIC_CONFIG = void 0;
|
|
12
|
+
_Object$defineProperty(exports, "NewMetrics", {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: function get() {
|
|
15
|
+
return _newMetrics.default;
|
|
16
|
+
}
|
|
17
|
+
});
|
|
11
18
|
_Object$defineProperty(exports, "config", {
|
|
12
19
|
enumerable: true,
|
|
13
20
|
get: function get() {
|
|
14
21
|
return _config.default;
|
|
15
22
|
}
|
|
16
23
|
});
|
|
17
|
-
|
|
18
24
|
_Object$defineProperty(exports, "default", {
|
|
19
25
|
enumerable: true,
|
|
20
26
|
get: function get() {
|
|
21
27
|
return _metrics.default;
|
|
22
28
|
}
|
|
23
29
|
});
|
|
24
|
-
|
|
30
|
+
_Object$defineProperty(exports, "getOSNameInternal", {
|
|
31
|
+
enumerable: true,
|
|
32
|
+
get: function get() {
|
|
33
|
+
return _metrics.getOSNameInternal;
|
|
34
|
+
}
|
|
35
|
+
});
|
|
25
36
|
require("@webex/internal-plugin-device");
|
|
26
|
-
|
|
27
37
|
var _webexCore = require("@webex/webex-core");
|
|
28
|
-
|
|
29
|
-
var _metrics = _interopRequireDefault(require("./metrics"));
|
|
30
|
-
|
|
38
|
+
var _metrics = _interopRequireWildcard(require("./metrics"));
|
|
31
39
|
var _config = _interopRequireDefault(require("./config"));
|
|
32
|
-
|
|
40
|
+
var _newMetrics = _interopRequireDefault(require("./new-metrics"));
|
|
41
|
+
var CALL_DIAGNOSTIC_CONFIG = _interopRequireWildcard(require("./call-diagnostic/config"));
|
|
42
|
+
exports.CALL_DIAGNOSTIC_CONFIG = CALL_DIAGNOSTIC_CONFIG;
|
|
43
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "function") return null; var cacheBabelInterop = new _WeakMap(); var cacheNodeInterop = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
44
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = _Object$defineProperty && _Object$getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? _Object$getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { _Object$defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
33
45
|
/*!
|
|
34
46
|
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
35
47
|
*/
|
|
48
|
+
|
|
36
49
|
(0, _webexCore.registerInternalPlugin)('metrics', _metrics.default, {
|
|
37
50
|
config: _config.default
|
|
38
51
|
});
|
|
52
|
+
(0, _webexCore.registerInternalPlugin)('newMetrics', _newMetrics.default, {
|
|
53
|
+
config: _config.default
|
|
54
|
+
});
|
|
39
55
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["registerInternalPlugin","Metrics","config"],"sources":["index.
|
|
1
|
+
{"version":3,"names":["registerInternalPlugin","Metrics","config","NewMetrics"],"sources":["index.ts"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport '@webex/internal-plugin-device';\n\nimport {registerInternalPlugin} from '@webex/webex-core';\n\nimport Metrics from './metrics';\nimport config from './config';\nimport NewMetrics from './new-metrics';\nimport {\n ClientEvent,\n SubmitBehavioralEvent,\n SubmitClientEvent,\n SubmitInternalEvent,\n SubmitOperationalEvent,\n SubmitMQE,\n} from './metrics.types';\nimport * as CALL_DIAGNOSTIC_CONFIG from './call-diagnostic/config';\n\nregisterInternalPlugin('metrics', Metrics, {\n config,\n});\n\nregisterInternalPlugin('newMetrics', NewMetrics, {\n config,\n});\n\nexport {default, getOSNameInternal} from './metrics';\nexport {config, CALL_DIAGNOSTIC_CONFIG, NewMetrics};\nexport type {\n ClientEvent,\n SubmitBehavioralEvent,\n SubmitClientEvent,\n SubmitInternalEvent,\n SubmitMQE,\n SubmitOperationalEvent,\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;AAEA;AAEA;AACA;AACA;AASA;AAAmE;AAAA;AAAA;AAnBnE;AACA;AACA;;AAmBA,IAAAA,iCAAsB,EAAC,SAAS,EAAEC,gBAAO,EAAE;EACzCC,MAAM,EAANA;AACF,CAAC,CAAC;AAEF,IAAAF,iCAAsB,EAAC,YAAY,EAAEG,mBAAU,EAAE;EAC/CD,MAAM,EAANA;AACF,CAAC,CAAC"}
|
package/dist/metrics.js
CHANGED
|
@@ -1,126 +1,88 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Object$keys = require("@babel/runtime-corejs2/core-js/object/keys");
|
|
4
|
-
|
|
5
4
|
var _Object$getOwnPropertySymbols = require("@babel/runtime-corejs2/core-js/object/get-own-property-symbols");
|
|
6
|
-
|
|
7
5
|
var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptor");
|
|
8
|
-
|
|
9
6
|
var _Object$getOwnPropertyDescriptors = require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptors");
|
|
10
|
-
|
|
11
7
|
var _Object$defineProperties = require("@babel/runtime-corejs2/core-js/object/define-properties");
|
|
12
|
-
|
|
13
8
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
14
|
-
|
|
15
9
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
16
|
-
|
|
17
10
|
_Object$defineProperty(exports, "__esModule", {
|
|
18
11
|
value: true
|
|
19
12
|
});
|
|
20
|
-
|
|
21
13
|
exports.default = void 0;
|
|
22
|
-
|
|
14
|
+
exports.getOSNameInternal = getOSNameInternal;
|
|
23
15
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
24
|
-
|
|
25
|
-
var _assign = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/assign"));
|
|
26
|
-
|
|
27
16
|
var _webexCore = require("@webex/webex-core");
|
|
28
|
-
|
|
29
17
|
var _common = require("@webex/common");
|
|
30
|
-
|
|
31
18
|
var _config = require("./config");
|
|
32
|
-
|
|
33
19
|
var _batcher = _interopRequireDefault(require("./batcher"));
|
|
34
|
-
|
|
35
20
|
var _clientMetricsBatcher = _interopRequireDefault(require("./client-metrics-batcher"));
|
|
36
|
-
|
|
37
|
-
var _callDiagnosticEventsBatcher = _interopRequireDefault(require("./call-diagnostic-events-batcher"));
|
|
38
|
-
|
|
39
21
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
40
|
-
|
|
41
22
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
42
|
-
|
|
43
23
|
var _BrowserDetection = (0, _common.BrowserDetection)(),
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
24
|
+
getOSName = _BrowserDetection.getOSName,
|
|
25
|
+
getOSVersion = _BrowserDetection.getOSVersion,
|
|
26
|
+
getBrowserName = _BrowserDetection.getBrowserName,
|
|
27
|
+
getBrowserVersion = _BrowserDetection.getBrowserVersion;
|
|
28
|
+
function getOSNameInternal() {
|
|
29
|
+
var _OSMap$getOSName;
|
|
30
|
+
return (_OSMap$getOSName = _config.OSMap[getOSName()]) !== null && _OSMap$getOSName !== void 0 ? _OSMap$getOSName : _config.OS_NAME.OTHERS;
|
|
31
|
+
}
|
|
49
32
|
function getSparkUserAgent(webex) {
|
|
50
33
|
var _webex$config;
|
|
51
|
-
|
|
52
34
|
var _ref = (_webex$config = webex === null || webex === void 0 ? void 0 : webex.config) !== null && _webex$config !== void 0 ? _webex$config : {},
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
35
|
+
appName = _ref.appName,
|
|
36
|
+
appVersion = _ref.appVersion,
|
|
37
|
+
appPlatform = _ref.appPlatform;
|
|
57
38
|
var sparkUserAgent = _config.CLIENT_NAME;
|
|
58
|
-
|
|
59
39
|
if (appName) {
|
|
60
40
|
sparkUserAgent += " ".concat(appName, "/").concat(appVersion !== null && appVersion !== void 0 ? appVersion : '0.0');
|
|
61
41
|
}
|
|
62
|
-
|
|
63
42
|
if (appPlatform) {
|
|
64
43
|
sparkUserAgent += " ".concat(appPlatform);
|
|
65
44
|
}
|
|
66
|
-
|
|
67
45
|
return sparkUserAgent;
|
|
68
46
|
}
|
|
69
|
-
|
|
70
47
|
var Metrics = _webexCore.WebexPlugin.extend({
|
|
71
48
|
children: {
|
|
72
49
|
batcher: _batcher.default,
|
|
73
|
-
clientMetricsBatcher: _clientMetricsBatcher.default
|
|
74
|
-
callDiagnosticEventsBatcher: _callDiagnosticEventsBatcher.default
|
|
50
|
+
clientMetricsBatcher: _clientMetricsBatcher.default
|
|
75
51
|
},
|
|
76
52
|
namespace: 'Metrics',
|
|
77
53
|
submit: function submit(key, value) {
|
|
78
|
-
return this.batcher.request((
|
|
54
|
+
return this.batcher.request(_objectSpread({
|
|
79
55
|
key: key
|
|
80
56
|
}, value));
|
|
81
57
|
},
|
|
82
|
-
|
|
83
58
|
/**
|
|
84
|
-
*
|
|
59
|
+
* Returns the payload for submitting client metrics.
|
|
85
60
|
* @param {string} eventName
|
|
86
|
-
* @param {
|
|
87
|
-
* @
|
|
88
|
-
* @returns {Object} HttpResponse object
|
|
61
|
+
* @param {any} props
|
|
62
|
+
* @returns {any} - the payload
|
|
89
63
|
*/
|
|
90
|
-
|
|
91
|
-
var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
92
|
-
var preLoginId = arguments.length > 2 ? arguments[2] : undefined;
|
|
93
|
-
|
|
64
|
+
getClientMetricsPayload: function getClientMetricsPayload(eventName, props) {
|
|
94
65
|
if (!eventName) {
|
|
95
66
|
throw Error('Missing behavioral metric name. Please provide one');
|
|
96
67
|
}
|
|
97
|
-
|
|
98
68
|
var payload = {
|
|
99
69
|
metricName: eventName
|
|
100
70
|
};
|
|
101
71
|
payload.tags = _objectSpread(_objectSpread({}, props.tags), {}, {
|
|
102
72
|
browser: getBrowserName(),
|
|
103
|
-
os:
|
|
73
|
+
os: getOSNameInternal(),
|
|
104
74
|
// Node does not like this so we need to check if it exists or not
|
|
105
75
|
// eslint-disable-next-line no-undef
|
|
106
|
-
domain: typeof window !== 'undefined' ? window.location.hostname || 'non-browser' : 'non-browser'
|
|
107
|
-
// Check what else we could measure
|
|
108
|
-
client_id: this.webex.credentials.config.client_id,
|
|
109
|
-
user_id: this.webex.internal.device.userId
|
|
76
|
+
domain: typeof window !== 'undefined' ? window.location.hostname || 'non-browser' : 'non-browser' // Check what else we could measure
|
|
110
77
|
});
|
|
111
78
|
|
|
112
|
-
try {
|
|
113
|
-
payload.tags.org_id = this.webex.credentials.getOrgId();
|
|
114
|
-
} catch (_unused) {
|
|
115
|
-
this.logger.info('metrics: unable to get orgId');
|
|
116
|
-
}
|
|
117
|
-
|
|
118
79
|
payload.fields = _objectSpread(_objectSpread({}, props.fields), {}, {
|
|
119
80
|
browser_version: getBrowserVersion(),
|
|
120
81
|
os_version: getOSVersion(),
|
|
121
82
|
sdk_version: this.webex.version,
|
|
122
83
|
platform: 'Web',
|
|
123
|
-
spark_user_agent: getSparkUserAgent(this.webex)
|
|
84
|
+
spark_user_agent: getSparkUserAgent(this.webex),
|
|
85
|
+
client_id: this.webex.credentials.config.client_id
|
|
124
86
|
});
|
|
125
87
|
payload.type = props.type || this.webex.config.metrics.type;
|
|
126
88
|
payload.context = _objectSpread(_objectSpread({}, props.context), {}, {
|
|
@@ -129,32 +91,42 @@ var Metrics = _webexCore.WebexPlugin.extend({
|
|
|
129
91
|
},
|
|
130
92
|
locale: 'en-US',
|
|
131
93
|
os: {
|
|
132
|
-
name:
|
|
94
|
+
name: getOSNameInternal(),
|
|
133
95
|
version: getOSVersion()
|
|
134
96
|
}
|
|
135
97
|
});
|
|
136
|
-
|
|
137
98
|
if (props.eventPayload) {
|
|
138
99
|
payload.eventPayload = props.eventPayload;
|
|
139
|
-
}
|
|
140
|
-
// is impossible so unable to use Date.now()
|
|
141
|
-
|
|
100
|
+
}
|
|
142
101
|
|
|
102
|
+
// Mocking the time in tests when running in node
|
|
103
|
+
// is impossible so unable to use Date.now()
|
|
143
104
|
payload.timestamp = new Date().valueOf();
|
|
144
|
-
|
|
105
|
+
return payload;
|
|
106
|
+
},
|
|
107
|
+
/**
|
|
108
|
+
* This corresponds to #sendSemiStructured() in the deprecated metrics handler
|
|
109
|
+
* @param {string} eventName
|
|
110
|
+
* @param {Object} props
|
|
111
|
+
* @param {string} preLoginId
|
|
112
|
+
* @returns {Object} HttpResponse object
|
|
113
|
+
*/
|
|
114
|
+
submitClientMetrics: function submitClientMetrics(eventName) {
|
|
115
|
+
var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
116
|
+
var preLoginId = arguments.length > 2 ? arguments[2] : undefined;
|
|
117
|
+
var payload = this.getClientMetricsPayload(eventName, props);
|
|
145
118
|
if (preLoginId) {
|
|
146
119
|
var _payload = {
|
|
147
120
|
metrics: [payload]
|
|
148
|
-
};
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
// Do not batch these because pre-login events occur during onboarding, so we will be partially blind
|
|
149
124
|
// to users' progress through the reg flow if we wait to persist pre-login metrics for people who drop off because
|
|
150
125
|
// their metrics will not post from a queue flush in time
|
|
151
|
-
|
|
152
126
|
return this.postPreLoginMetric(_payload, preLoginId);
|
|
153
127
|
}
|
|
154
|
-
|
|
155
128
|
return this.clientMetricsBatcher.request(payload);
|
|
156
129
|
},
|
|
157
|
-
|
|
158
130
|
/**
|
|
159
131
|
* Issue request to alias a user's pre-login ID with their CI UUID
|
|
160
132
|
* @param {string} preLoginId
|
|
@@ -176,7 +148,6 @@ var Metrics = _webexCore.WebexPlugin.extend({
|
|
|
176
148
|
},
|
|
177
149
|
postPreLoginMetric: function postPreLoginMetric(payload, preLoginId) {
|
|
178
150
|
var _this = this;
|
|
179
|
-
|
|
180
151
|
return this.webex.credentials.getClientToken().then(function (token) {
|
|
181
152
|
return _this.request({
|
|
182
153
|
method: 'POST',
|
|
@@ -190,16 +161,8 @@ var Metrics = _webexCore.WebexPlugin.extend({
|
|
|
190
161
|
});
|
|
191
162
|
});
|
|
192
163
|
},
|
|
193
|
-
|
|
194
|
-
var event = {
|
|
195
|
-
type: 'diagnostic-event',
|
|
196
|
-
eventPayload: payload
|
|
197
|
-
};
|
|
198
|
-
return this.callDiagnosticEventsBatcher.request(event);
|
|
199
|
-
},
|
|
200
|
-
version: "3.0.0-beta.2"
|
|
164
|
+
version: "3.0.0-beta.200"
|
|
201
165
|
});
|
|
202
|
-
|
|
203
166
|
var _default = Metrics;
|
|
204
167
|
exports.default = _default;
|
|
205
168
|
//# sourceMappingURL=metrics.js.map
|