@webex/contact-center 3.9.0-next.6 → 3.9.0-next.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/dist/cc.js +14 -0
  2. package/dist/cc.js.map +1 -1
  3. package/dist/metrics/MetricsManager.js +1 -1
  4. package/dist/metrics/MetricsManager.js.map +1 -1
  5. package/dist/metrics/constants.js +2 -0
  6. package/dist/metrics/constants.js.map +1 -1
  7. package/dist/services/core/GlobalTypes.js.map +1 -1
  8. package/dist/services/core/Utils.js +47 -2
  9. package/dist/services/core/Utils.js.map +1 -1
  10. package/dist/services/core/aqm-reqs.js +0 -4
  11. package/dist/services/core/aqm-reqs.js.map +1 -1
  12. package/dist/services/core/websocket/WebSocketManager.js +0 -4
  13. package/dist/services/core/websocket/WebSocketManager.js.map +1 -1
  14. package/dist/services/task/index.js +122 -52
  15. package/dist/services/task/index.js.map +1 -1
  16. package/dist/types/metrics/constants.d.ts +1 -0
  17. package/dist/types/services/core/GlobalTypes.d.ts +25 -0
  18. package/dist/types/services/core/Utils.d.ts +16 -1
  19. package/dist/webex.js +1 -1
  20. package/package.json +2 -2
  21. package/src/cc.ts +15 -0
  22. package/src/metrics/MetricsManager.ts +1 -1
  23. package/src/metrics/constants.ts +3 -0
  24. package/src/services/core/GlobalTypes.ts +27 -0
  25. package/src/services/core/Utils.ts +57 -1
  26. package/src/services/core/aqm-reqs.ts +0 -5
  27. package/src/services/core/websocket/WebSocketManager.ts +0 -4
  28. package/src/services/task/index.ts +124 -28
  29. package/test/unit/spec/metrics/MetricsManager.ts +0 -1
  30. package/test/unit/spec/services/core/aqm-reqs.ts +1 -3
  31. package/test/unit/spec/services/core/websocket/WebSocketManager.ts +0 -4
  32. package/test/unit/spec/services/task/index.ts +153 -111
  33. package/umd/contact-center.min.js +2 -2
  34. package/umd/contact-center.min.js.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"names":["_behavioralEvents","require","_loggerProxy","_interopRequireDefault","_constants","obj","__esModule","default","PRODUCT_NAME_UPPER","PRODUCT_NAME","toUpperCase","MetricsManager","runningEvents","pendingBehavioralEvents","pendingOperationalEvents","pendingBusinessEvents","readyToSubmitEvents","submittingEvents","metricsDisabled","constructor","setReadyToSubmitEvents","submitPendingEvents","submitPendingBehavioralEvents","submitPendingOperationalEvents","submitPendingBusinessEvents","length","eventsToSubmit","forEach","event","webex","internal","newMetrics","submitBehavioralEvent","product","taxonomy","agent","target","verb","payload","submitOperationalEvent","name","submitBusinessEvent","metadata","appType","addDurationIfTimed","eventName","options","durationKey","genericKey","timing","Object","entries","keys","has","startTime","Date","now","spacesToUnderscore","str","replace","preparePayload","key","undefined","Array","isArray","window","payloadWithCommonMetadata","tabHidden","document","hidden","isMetricsDisabled","setMetricsDisabled","disabled","clearPendingEvents","trackBehavioralEvent","getEventTaxonomy","push","trackOperationalEvent","trackBusinessEvent","trackEvent","metricServices","metricService","LoggerProxy","error","timeEvent","keyArray","Set","setWebex","ready","once","getInstance","instance","resetInstance","getCommonTrackingFieldForAQMResponse","response","fields","agentId","data","agentSessionId","teamId","siteId","orgId","eventType","type","trackingId","notifTrackingId","getCommonTrackingFieldForAQMResponseFailed","failureResponse","failureType","failureReason","reason","reasonCode","exports"],"sources":["MetricsManager.ts"],"sourcesContent":["import {\n EventPayload,\n MetricEventAgent,\n MetricEventProduct,\n MetricEventVerb,\n} from '@webex/internal-plugin-metrics/src/metrics.types';\n\nimport {WebexSDK} from '../types';\nimport {BehavioralEventTaxonomy, getEventTaxonomy} from './behavioral-events';\nimport LoggerProxy from '../logger-proxy';\nimport {METRIC_EVENT_NAMES} from './constants';\nimport {Failure} from '../services/core/GlobalTypes';\nimport {PRODUCT_NAME} from '../constants';\n\ntype BehavioralEvent = {\n taxonomy: BehavioralEventTaxonomy;\n payload: EventPayload;\n};\n\ntype GenericEvent = {\n name: string;\n payload: EventPayload;\n};\n\nexport type MetricsType = 'behavioral' | 'operational' | 'business';\n\nconst PRODUCT_NAME_UPPER = PRODUCT_NAME.toUpperCase();\n/**\n * @class MetricsManager\n * @classdesc Manages the collection, batching, and submission of behavioral, operational, and business metrics for the Webex SDK.\n * Implements a singleton pattern to ensure a single instance throughout the application lifecycle.\n *\n * @remarks\n * This class is responsible for tracking, batching, and submitting various types of metric events.\n * It also provides utility methods for extracting common tracking fields from AQM responses.\n * @ignore\n */\nexport default class MetricsManager {\n /**\n * The Webex SDK instance used for submitting metrics.\n * @private\n */\n private webex: WebexSDK;\n\n /**\n * Stores currently running timed events.\n * @private\n */\n private readonly runningEvents: Record<string, {startTime: number; keys: Set<string>}> = {};\n\n /**\n * Queue for pending behavioral events.\n * @private\n */\n private pendingBehavioralEvents: BehavioralEvent[] = [];\n\n /**\n * Queue for pending operational events.\n * @private\n */\n private pendingOperationalEvents: GenericEvent[] = [];\n\n /**\n * Queue for pending business events.\n * @private\n */\n private pendingBusinessEvents: GenericEvent[] = [];\n\n /**\n * Indicates if the manager is ready to submit events.\n * @private\n */\n private readyToSubmitEvents = false;\n\n /**\n * Lock to prevent concurrent submissions.\n * @private\n */\n private submittingEvents = false; // Add a lock for submitting events\n\n /**\n * Singleton instance of MetricsManager.\n * @private\n */\n private static instance: MetricsManager;\n\n /**\n * Flag to disable metrics collection.\n * @private\n */\n private metricsDisabled = false; // TODO: SPARK-637285\n\n /**\n * Private constructor to enforce singleton pattern.\n * @private\n */\n // eslint-disable-next-line no-useless-constructor\n private constructor() {}\n\n /**\n * Marks the manager as ready to submit events and triggers submission.\n * @private\n */\n private setReadyToSubmitEvents() {\n this.readyToSubmitEvents = true;\n this.submitPendingEvents();\n }\n\n /**\n * Submits all pending events if not already submitting.\n * @private\n */\n private async submitPendingEvents() {\n if (this.submittingEvents) {\n return;\n }\n this.submittingEvents = true;\n try {\n await this.submitPendingBehavioralEvents();\n await this.submitPendingOperationalEvents();\n await this.submitPendingBusinessEvents();\n } finally {\n this.submittingEvents = false;\n }\n }\n\n /**\n * Submits all pending behavioral events if ready.\n * @private\n */\n private async submitPendingBehavioralEvents() {\n if (this.pendingBehavioralEvents.length === 0) {\n return;\n }\n if (this.readyToSubmitEvents) {\n const eventsToSubmit = [...this.pendingBehavioralEvents];\n this.pendingBehavioralEvents.length = 0;\n eventsToSubmit.forEach((event) => {\n this.webex.internal.newMetrics.submitBehavioralEvent({\n product: event.taxonomy.product as MetricEventProduct,\n agent: event.taxonomy.agent as MetricEventAgent,\n target: event.taxonomy.target,\n verb: event.taxonomy.verb as MetricEventVerb,\n payload: event.payload,\n });\n });\n }\n }\n\n /**\n * Submits all pending operational events if ready.\n * @private\n */\n private async submitPendingOperationalEvents() {\n if (this.pendingOperationalEvents.length === 0) {\n return;\n }\n if (this.readyToSubmitEvents) {\n const eventsToSubmit = [...this.pendingOperationalEvents];\n this.pendingOperationalEvents.length = 0;\n eventsToSubmit.forEach((event) => {\n this.webex.internal.newMetrics.submitOperationalEvent({\n name: `${PRODUCT_NAME_UPPER}_${event.name}`,\n payload: event.payload,\n });\n });\n }\n }\n\n /**\n * Submits all pending business events if ready.\n * @private\n */\n private async submitPendingBusinessEvents() {\n if (this.pendingBusinessEvents.length === 0) {\n return;\n }\n if (this.readyToSubmitEvents) {\n const eventsToSubmit = [...this.pendingBusinessEvents];\n this.pendingBusinessEvents.length = 0;\n eventsToSubmit.forEach((event) => {\n this.webex.internal.newMetrics.submitBusinessEvent({\n name: `${PRODUCT_NAME_UPPER}_${event.name}`,\n payload: event.payload,\n metadata: {\n appType: PRODUCT_NAME,\n },\n });\n });\n }\n }\n\n /**\n * Adds a duration property to the event payload if the event was timed.\n * @param eventName - The name of the event.\n * @param options - Optional event payload.\n * @returns The event payload with duration if applicable.\n * @private\n */\n private addDurationIfTimed(eventName: string, options?: EventPayload): EventPayload {\n const durationKey = 'duration_ms';\n for (const [genericKey, timing] of Object.entries(this.runningEvents)) {\n if (timing.keys.has(eventName)) {\n const startTime = timing.startTime;\n // Remove all keys for this operation.\n delete this.runningEvents[genericKey];\n options = options || {};\n options[durationKey] = Date.now() - startTime;\n\n return options;\n }\n }\n\n return options || {};\n }\n\n /**\n * Converts spaces in a string to underscores.\n * @param str - The input string.\n * @returns The string with spaces replaced by underscores.\n * @public\n * @example\n * MetricsManager.spacesToUnderscore('my event name'); // 'my_event_name'\n */\n static spacesToUnderscore(str: string): string {\n return str.replace(/ /g, '_');\n }\n\n /**\n * Prepares the event payload by removing empty or undefined fields and adding common metadata.\n * @param obj - The original event payload.\n * @returns The cleaned and enriched event payload.\n * @private\n */\n private static preparePayload(obj: EventPayload): EventPayload {\n const payload: EventPayload = {};\n\n Object.keys(obj).forEach((key) => {\n if (\n obj[key] !== undefined &&\n obj[key] !== null &&\n obj[key] !== '' &&\n !Array.isArray(obj[key]) &&\n !(typeof obj[key] === 'object' && Object.keys(obj[key]).length === 0)\n ) {\n payload[MetricsManager.spacesToUnderscore(key)] = obj[key];\n }\n });\n\n if (typeof window === 'undefined') {\n return payload;\n }\n\n const payloadWithCommonMetadata = {...payload};\n payloadWithCommonMetadata.tabHidden = document.hidden;\n\n return payloadWithCommonMetadata;\n }\n\n /**\n * Checks if metrics collection is currently disabled.\n * @returns True if metrics are disabled, false otherwise.\n * @private\n */\n private isMetricsDisabled(): boolean {\n // TODO: SPARK-637285 Need to return true if in development mode to avoid sending metrics to the server\n return this.metricsDisabled;\n }\n\n /**\n * Enables or disables metrics collection. Clears pending events if disabled.\n * @param disabled - Whether to disable metrics.\n * @public\n * @example\n * MetricsManager.getInstance().setMetricsDisabled(true);\n */\n public setMetricsDisabled(disabled: boolean) {\n this.metricsDisabled = disabled;\n if (disabled) {\n this.clearPendingEvents();\n }\n }\n\n /**\n * Clears all pending events from the queues.\n * @private\n */\n private clearPendingEvents() {\n this.pendingBehavioralEvents.length = 0;\n this.pendingOperationalEvents.length = 0;\n this.pendingBusinessEvents.length = 0;\n }\n\n /**\n * Tracks a behavioral event and submits it if possible.\n * @param name - The metric event name.\n * @param options - Optional event payload.\n * @public\n * @example\n * MetricsManager.getInstance().trackBehavioralEvent('AGENT_LOGIN', {agentId: '123'});\n */\n public trackBehavioralEvent(name: METRIC_EVENT_NAMES, options?: EventPayload) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n const taxonomy = getEventTaxonomy(name);\n\n const payload = MetricsManager.preparePayload(this.addDurationIfTimed(name, options));\n\n this.pendingBehavioralEvents.push({taxonomy, payload});\n this.submitPendingBehavioralEvents();\n }\n\n /**\n * Tracks an operational event and submits it if possible.\n * @param name - The metric event name.\n * @param options - Optional event payload.\n * @public\n * @example\n * MetricsManager.getInstance().trackOperationalEvent('AGENT_LOGOUT', {agentId: '123'});\n */\n public trackOperationalEvent(name: METRIC_EVENT_NAMES, options?: EventPayload) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n const payload = this.addDurationIfTimed(name, options);\n this.pendingOperationalEvents.push({\n name: MetricsManager.spacesToUnderscore(name).toUpperCase(),\n payload: MetricsManager.preparePayload(payload),\n });\n this.submitPendingOperationalEvents();\n }\n\n /**\n * Tracks a business event and submits it if possible.\n * @param name - The metric event name.\n * @param options - Optional event payload.\n * @public\n * @example\n * MetricsManager.getInstance().trackBusinessEvent('AGENT_TRANSFER', {agentId: '123'});\n */\n public trackBusinessEvent(name: METRIC_EVENT_NAMES, options?: EventPayload) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n const payload = this.addDurationIfTimed(name, options);\n this.pendingBusinessEvents.push({\n name: MetricsManager.spacesToUnderscore(name).toUpperCase(),\n payload: MetricsManager.preparePayload(payload),\n });\n this.submitPendingBusinessEvents();\n }\n\n /**\n * Tracks an event across one or more metric services.\n * @param name - The metric event name.\n * @param payload - Optional event payload.\n * @param metricServices - Array of metric types to track (default: ['behavioral']).\n * @public\n * @example\n * MetricsManager.getInstance().trackEvent('AGENT_LOGIN', {agentId: '123'}, ['behavioral', 'operational']);\n */\n public trackEvent(\n name: METRIC_EVENT_NAMES,\n payload?: EventPayload,\n metricServices: MetricsType[] = ['behavioral']\n ) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n for (const metricService of metricServices) {\n switch (metricService) {\n case 'behavioral':\n this.trackBehavioralEvent(name, payload);\n break;\n case 'operational':\n this.trackOperationalEvent(name, payload);\n break;\n case 'business':\n this.trackBusinessEvent(name, payload);\n break;\n default:\n LoggerProxy.error(`[MetricsManager] Invalid metric type: ${metricService}`);\n }\n }\n }\n\n /**\n * Starts timing for one or more event keys.\n * @param keys - A string or array of strings representing event keys.\n * @public\n * @example\n * MetricsManager.getInstance().timeEvent('AGENT_LOGIN');\n * MetricsManager.getInstance().timeEvent(['AGENT_LOGIN', 'AGENT_LOGOUT']);\n */\n public timeEvent(keys: string | string[]) {\n if (this.isMetricsDisabled()) {\n return;\n }\n const keyArray = Array.isArray(keys) ? keys : [keys];\n // Use the first key as the tracking key.\n if (keyArray.length === 0) {\n LoggerProxy.error('[MetricsManager] No keys provided for timeEvent');\n\n return;\n }\n const genericKey = keyArray[0];\n this.runningEvents[genericKey] = {startTime: Date.now(), keys: new Set(keyArray)};\n }\n\n /**\n * Sets the Webex SDK instance and marks the manager as ready when the SDK is ready.\n * @param webex - The Webex SDK instance.\n * @private\n */\n private setWebex(webex: WebexSDK) {\n this.webex = webex;\n if (this.webex.ready) {\n this.setReadyToSubmitEvents();\n }\n this.webex.once('ready', () => {\n this.setReadyToSubmitEvents();\n });\n }\n\n /**\n * Returns the singleton instance of MetricsManager, initializing it if necessary.\n * @param options - Optional object containing the Webex SDK instance.\n * @returns The singleton MetricsManager instance.\n * @public\n * @example\n * const metrics = MetricsManager.getInstance({webex});\n */\n public static getInstance(options?: {webex: WebexSDK}): MetricsManager {\n if (!MetricsManager.instance) {\n MetricsManager.instance = new MetricsManager();\n }\n\n if (!MetricsManager.instance.webex && options && options.webex) {\n MetricsManager.instance.setWebex(options.webex);\n }\n\n return MetricsManager.instance;\n }\n\n /**\n * Resets the singleton instance of MetricsManager. Useful for testing.\n * @public\n * @example\n * MetricsManager.resetInstance();\n */\n public static resetInstance() {\n MetricsManager.instance = undefined;\n }\n\n /**\n * Extracts common tracking fields from an AQM response object.\n * @param response - The AQM response object.\n * @returns An object containing common tracking fields.\n * @public\n * @example\n * const fields = MetricsManager.getCommonTrackingFieldForAQMResponse(response);\n */\n public static getCommonTrackingFieldForAQMResponse(response: any): Record<string, any> {\n // This method is used to extract common tracking fields from the AQM response\n // and return them as an object. The fields are extracted from the response\n // object and its data property.\n const fields = {\n agentId: response?.data?.agentId || response?.agentId,\n agentSessionId: response?.data?.agentSessionId || response?.agentSessionId,\n teamId: response?.teamId ?? response?.data?.teamId ?? undefined,\n siteId: response?.data?.siteId || response?.siteId,\n orgId: response?.data?.orgId || response?.orgId,\n eventType: response?.type,\n trackingId: response?.data?.trackingId,\n notifTrackingId: response?.trackingId,\n };\n\n return fields;\n }\n\n /**\n * Extracts common tracking fields from an AQM failure response object.\n * @param failureResponse - The AQM failure response object.\n * @returns An object containing common tracking fields for failures.\n * @public\n * @example\n * const fields = MetricsManager.getCommonTrackingFieldForAQMResponseFailed(failureResponse);\n */\n public static getCommonTrackingFieldForAQMResponseFailed(\n failureResponse: Failure\n ): Record<string, any> {\n // This method is used to extract common tracking fields from the AQM response failure\n // and return them as an object. The fields are extracted from the response\n // object and its data property.\n const fields = {\n agentId: failureResponse?.data?.agentId,\n trackingId: failureResponse?.trackingId,\n notifTrackingId: failureResponse?.trackingId,\n orgId: failureResponse?.orgId,\n failureType: failureResponse?.type,\n failureReason: failureResponse?.data?.reason,\n reasonCode: failureResponse?.data?.reasonCode,\n };\n\n return fields;\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["_loggerProxy","_interopRequireDefault","require","_behavioralEvents","_constants","obj","__esModule","default","PRODUCT_NAME_UPPER","PRODUCT_NAME","toUpperCase","MetricsManager","runningEvents","pendingBehavioralEvents","pendingOperationalEvents","pendingBusinessEvents","readyToSubmitEvents","submittingEvents","metricsDisabled","constructor","setReadyToSubmitEvents","submitPendingEvents","submitPendingBehavioralEvents","submitPendingOperationalEvents","submitPendingBusinessEvents","length","eventsToSubmit","forEach","event","webex","internal","newMetrics","submitBehavioralEvent","product","taxonomy","agent","target","verb","payload","submitOperationalEvent","name","submitBusinessEvent","metadata","appType","addDurationIfTimed","eventName","options","durationKey","genericKey","timing","Object","entries","keys","has","startTime","Date","now","spacesToUnderscore","str","replace","preparePayload","key","undefined","Array","isArray","window","payloadWithCommonMetadata","tabHidden","document","hidden","isMetricsDisabled","setMetricsDisabled","disabled","clearPendingEvents","trackBehavioralEvent","getEventTaxonomy","push","trackOperationalEvent","trackBusinessEvent","trackEvent","metricServices","metricService","LoggerProxy","error","timeEvent","keyArray","Set","setWebex","ready","once","getInstance","instance","resetInstance","getCommonTrackingFieldForAQMResponse","response","fields","agentId","data","agentSessionId","teamId","siteId","orgId","eventType","type","trackingId","notifTrackingId","getCommonTrackingFieldForAQMResponseFailed","failureResponse","failureType","failureReason","reason","reasonCode","exports"],"sources":["MetricsManager.ts"],"sourcesContent":["import {\n EventPayload,\n MetricEventAgent,\n MetricEventProduct,\n MetricEventVerb,\n} from '@webex/internal-plugin-metrics/src/metrics.types';\n\nimport {WebexSDK} from '../types';\nimport LoggerProxy from '../logger-proxy';\nimport {BehavioralEventTaxonomy, getEventTaxonomy} from './behavioral-events';\nimport {METRIC_EVENT_NAMES} from './constants';\nimport {Failure} from '../services/core/GlobalTypes';\nimport {PRODUCT_NAME} from '../constants';\n\ntype BehavioralEvent = {\n taxonomy: BehavioralEventTaxonomy;\n payload: EventPayload;\n};\n\ntype GenericEvent = {\n name: string;\n payload: EventPayload;\n};\n\nexport type MetricsType = 'behavioral' | 'operational' | 'business';\n\nconst PRODUCT_NAME_UPPER = PRODUCT_NAME.toUpperCase();\n/**\n * @class MetricsManager\n * @classdesc Manages the collection, batching, and submission of behavioral, operational, and business metrics for the Webex SDK.\n * Implements a singleton pattern to ensure a single instance throughout the application lifecycle.\n *\n * @remarks\n * This class is responsible for tracking, batching, and submitting various types of metric events.\n * It also provides utility methods for extracting common tracking fields from AQM responses.\n * @ignore\n */\nexport default class MetricsManager {\n /**\n * The Webex SDK instance used for submitting metrics.\n * @private\n */\n private webex: WebexSDK;\n\n /**\n * Stores currently running timed events.\n * @private\n */\n private readonly runningEvents: Record<string, {startTime: number; keys: Set<string>}> = {};\n\n /**\n * Queue for pending behavioral events.\n * @private\n */\n private pendingBehavioralEvents: BehavioralEvent[] = [];\n\n /**\n * Queue for pending operational events.\n * @private\n */\n private pendingOperationalEvents: GenericEvent[] = [];\n\n /**\n * Queue for pending business events.\n * @private\n */\n private pendingBusinessEvents: GenericEvent[] = [];\n\n /**\n * Indicates if the manager is ready to submit events.\n * @private\n */\n private readyToSubmitEvents = false;\n\n /**\n * Lock to prevent concurrent submissions.\n * @private\n */\n private submittingEvents = false; // Add a lock for submitting events\n\n /**\n * Singleton instance of MetricsManager.\n * @private\n */\n private static instance: MetricsManager;\n\n /**\n * Flag to disable metrics collection.\n * @private\n */\n private metricsDisabled = false; // TODO: SPARK-637285\n\n /**\n * Private constructor to enforce singleton pattern.\n * @private\n */\n // eslint-disable-next-line no-useless-constructor\n private constructor() {}\n\n /**\n * Marks the manager as ready to submit events and triggers submission.\n * @private\n */\n private setReadyToSubmitEvents() {\n this.readyToSubmitEvents = true;\n this.submitPendingEvents();\n }\n\n /**\n * Submits all pending events if not already submitting.\n * @private\n */\n private async submitPendingEvents() {\n if (this.submittingEvents) {\n return;\n }\n this.submittingEvents = true;\n try {\n await this.submitPendingBehavioralEvents();\n await this.submitPendingOperationalEvents();\n await this.submitPendingBusinessEvents();\n } finally {\n this.submittingEvents = false;\n }\n }\n\n /**\n * Submits all pending behavioral events if ready.\n * @private\n */\n private async submitPendingBehavioralEvents() {\n if (this.pendingBehavioralEvents.length === 0) {\n return;\n }\n if (this.readyToSubmitEvents) {\n const eventsToSubmit = [...this.pendingBehavioralEvents];\n this.pendingBehavioralEvents.length = 0;\n eventsToSubmit.forEach((event) => {\n this.webex.internal.newMetrics.submitBehavioralEvent({\n product: event.taxonomy.product as MetricEventProduct,\n agent: event.taxonomy.agent as MetricEventAgent,\n target: event.taxonomy.target,\n verb: event.taxonomy.verb as MetricEventVerb,\n payload: event.payload,\n });\n });\n }\n }\n\n /**\n * Submits all pending operational events if ready.\n * @private\n */\n private async submitPendingOperationalEvents() {\n if (this.pendingOperationalEvents.length === 0) {\n return;\n }\n if (this.readyToSubmitEvents) {\n const eventsToSubmit = [...this.pendingOperationalEvents];\n this.pendingOperationalEvents.length = 0;\n eventsToSubmit.forEach((event) => {\n this.webex.internal.newMetrics.submitOperationalEvent({\n name: `${PRODUCT_NAME_UPPER}_${event.name}`,\n payload: event.payload,\n });\n });\n }\n }\n\n /**\n * Submits all pending business events if ready.\n * @private\n */\n private async submitPendingBusinessEvents() {\n if (this.pendingBusinessEvents.length === 0) {\n return;\n }\n if (this.readyToSubmitEvents) {\n const eventsToSubmit = [...this.pendingBusinessEvents];\n this.pendingBusinessEvents.length = 0;\n eventsToSubmit.forEach((event) => {\n this.webex.internal.newMetrics.submitBusinessEvent({\n name: `${PRODUCT_NAME_UPPER}_${event.name}`,\n payload: event.payload,\n metadata: {\n appType: PRODUCT_NAME,\n },\n });\n });\n }\n }\n\n /**\n * Adds a duration property to the event payload if the event was timed.\n * @param eventName - The name of the event.\n * @param options - Optional event payload.\n * @returns The event payload with duration if applicable.\n * @private\n */\n private addDurationIfTimed(eventName: string, options?: EventPayload): EventPayload {\n const durationKey = 'duration_ms';\n for (const [genericKey, timing] of Object.entries(this.runningEvents)) {\n if (timing.keys.has(eventName)) {\n const startTime = timing.startTime;\n // Remove all keys for this operation.\n delete this.runningEvents[genericKey];\n options = options || {};\n options[durationKey] = Date.now() - startTime;\n\n return options;\n }\n }\n\n return options || {};\n }\n\n /**\n * Converts spaces in a string to underscores.\n * @param str - The input string.\n * @returns The string with spaces replaced by underscores.\n * @public\n * @example\n * MetricsManager.spacesToUnderscore('my event name'); // 'my_event_name'\n */\n static spacesToUnderscore(str: string): string {\n return str.replace(/ /g, '_');\n }\n\n /**\n * Prepares the event payload by removing empty or undefined fields and adding common metadata.\n * @param obj - The original event payload.\n * @returns The cleaned and enriched event payload.\n * @private\n */\n private static preparePayload(obj: EventPayload): EventPayload {\n const payload: EventPayload = {};\n\n Object.keys(obj).forEach((key) => {\n if (\n obj[key] !== undefined &&\n obj[key] !== null &&\n obj[key] !== '' &&\n !Array.isArray(obj[key]) &&\n !(typeof obj[key] === 'object' && Object.keys(obj[key]).length === 0)\n ) {\n payload[MetricsManager.spacesToUnderscore(key)] = obj[key];\n }\n });\n\n if (typeof window === 'undefined') {\n return payload;\n }\n\n const payloadWithCommonMetadata = {...payload};\n payloadWithCommonMetadata.tabHidden = document.hidden;\n\n return payloadWithCommonMetadata;\n }\n\n /**\n * Checks if metrics collection is currently disabled.\n * @returns True if metrics are disabled, false otherwise.\n * @private\n */\n private isMetricsDisabled(): boolean {\n // TODO: SPARK-637285 Need to return true if in development mode to avoid sending metrics to the server\n return this.metricsDisabled;\n }\n\n /**\n * Enables or disables metrics collection. Clears pending events if disabled.\n * @param disabled - Whether to disable metrics.\n * @public\n * @example\n * MetricsManager.getInstance().setMetricsDisabled(true);\n */\n public setMetricsDisabled(disabled: boolean) {\n this.metricsDisabled = disabled;\n if (disabled) {\n this.clearPendingEvents();\n }\n }\n\n /**\n * Clears all pending events from the queues.\n * @private\n */\n private clearPendingEvents() {\n this.pendingBehavioralEvents.length = 0;\n this.pendingOperationalEvents.length = 0;\n this.pendingBusinessEvents.length = 0;\n }\n\n /**\n * Tracks a behavioral event and submits it if possible.\n * @param name - The metric event name.\n * @param options - Optional event payload.\n * @public\n * @example\n * MetricsManager.getInstance().trackBehavioralEvent('AGENT_LOGIN', {agentId: '123'});\n */\n public trackBehavioralEvent(name: METRIC_EVENT_NAMES, options?: EventPayload) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n const taxonomy = getEventTaxonomy(name);\n\n const payload = MetricsManager.preparePayload(this.addDurationIfTimed(name, options));\n\n this.pendingBehavioralEvents.push({taxonomy, payload});\n this.submitPendingBehavioralEvents();\n }\n\n /**\n * Tracks an operational event and submits it if possible.\n * @param name - The metric event name.\n * @param options - Optional event payload.\n * @public\n * @example\n * MetricsManager.getInstance().trackOperationalEvent('AGENT_LOGOUT', {agentId: '123'});\n */\n public trackOperationalEvent(name: METRIC_EVENT_NAMES, options?: EventPayload) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n const payload = this.addDurationIfTimed(name, options);\n this.pendingOperationalEvents.push({\n name: MetricsManager.spacesToUnderscore(name).toUpperCase(),\n payload: MetricsManager.preparePayload(payload),\n });\n this.submitPendingOperationalEvents();\n }\n\n /**\n * Tracks a business event and submits it if possible.\n * @param name - The metric event name.\n * @param options - Optional event payload.\n * @public\n * @example\n * MetricsManager.getInstance().trackBusinessEvent('AGENT_TRANSFER', {agentId: '123'});\n */\n public trackBusinessEvent(name: METRIC_EVENT_NAMES, options?: EventPayload) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n const payload = this.addDurationIfTimed(name, options);\n this.pendingBusinessEvents.push({\n name: MetricsManager.spacesToUnderscore(name).toUpperCase(),\n payload: MetricsManager.preparePayload(payload),\n });\n this.submitPendingBusinessEvents();\n }\n\n /**\n * Tracks an event across one or more metric services.\n * @param name - The metric event name.\n * @param payload - Optional event payload.\n * @param metricServices - Array of metric types to track (default: ['behavioral']).\n * @public\n * @example\n * MetricsManager.getInstance().trackEvent('AGENT_LOGIN', {agentId: '123'}, ['behavioral', 'operational']);\n */\n public trackEvent(\n name: METRIC_EVENT_NAMES,\n payload?: EventPayload,\n metricServices: MetricsType[] = ['behavioral']\n ) {\n if (this.isMetricsDisabled()) {\n return;\n }\n\n for (const metricService of metricServices) {\n switch (metricService) {\n case 'behavioral':\n this.trackBehavioralEvent(name, payload);\n break;\n case 'operational':\n this.trackOperationalEvent(name, payload);\n break;\n case 'business':\n this.trackBusinessEvent(name, payload);\n break;\n default:\n LoggerProxy.error(`[MetricsManager] Invalid metric type: ${metricService}`);\n }\n }\n }\n\n /**\n * Starts timing for one or more event keys.\n * @param keys - A string or array of strings representing event keys.\n * @public\n * @example\n * MetricsManager.getInstance().timeEvent('AGENT_LOGIN');\n * MetricsManager.getInstance().timeEvent(['AGENT_LOGIN', 'AGENT_LOGOUT']);\n */\n public timeEvent(keys: string | string[]) {\n if (this.isMetricsDisabled()) {\n return;\n }\n const keyArray = Array.isArray(keys) ? keys : [keys];\n // Use the first key as the tracking key.\n if (keyArray.length === 0) {\n LoggerProxy.error('[MetricsManager] No keys provided for timeEvent');\n\n return;\n }\n const genericKey = keyArray[0];\n this.runningEvents[genericKey] = {startTime: Date.now(), keys: new Set(keyArray)};\n }\n\n /**\n * Sets the Webex SDK instance and marks the manager as ready when the SDK is ready.\n * @param webex - The Webex SDK instance.\n * @private\n */\n private setWebex(webex: WebexSDK) {\n this.webex = webex;\n if (this.webex.ready) {\n this.setReadyToSubmitEvents();\n }\n this.webex.once('ready', () => {\n this.setReadyToSubmitEvents();\n });\n }\n\n /**\n * Returns the singleton instance of MetricsManager, initializing it if necessary.\n * @param options - Optional object containing the Webex SDK instance.\n * @returns The singleton MetricsManager instance.\n * @public\n * @example\n * const metrics = MetricsManager.getInstance({webex});\n */\n public static getInstance(options?: {webex: WebexSDK}): MetricsManager {\n if (!MetricsManager.instance) {\n MetricsManager.instance = new MetricsManager();\n }\n\n if (!MetricsManager.instance.webex && options && options.webex) {\n MetricsManager.instance.setWebex(options.webex);\n }\n\n return MetricsManager.instance;\n }\n\n /**\n * Resets the singleton instance of MetricsManager. Useful for testing.\n * @public\n * @example\n * MetricsManager.resetInstance();\n */\n public static resetInstance() {\n MetricsManager.instance = undefined;\n }\n\n /**\n * Extracts common tracking fields from an AQM response object.\n * @param response - The AQM response object.\n * @returns An object containing common tracking fields.\n * @public\n * @example\n * const fields = MetricsManager.getCommonTrackingFieldForAQMResponse(response);\n */\n public static getCommonTrackingFieldForAQMResponse(response: any): Record<string, any> {\n // This method is used to extract common tracking fields from the AQM response\n // and return them as an object. The fields are extracted from the response\n // object and its data property.\n const fields = {\n agentId: response?.data?.agentId || response?.agentId,\n agentSessionId: response?.data?.agentSessionId || response?.agentSessionId,\n teamId: response?.teamId ?? response?.data?.teamId ?? undefined,\n siteId: response?.data?.siteId || response?.siteId,\n orgId: response?.data?.orgId || response?.orgId,\n eventType: response?.type,\n trackingId: response?.data?.trackingId,\n notifTrackingId: response?.trackingId,\n };\n\n return fields;\n }\n\n /**\n * Extracts common tracking fields from an AQM failure response object.\n * @param failureResponse - The AQM failure response object.\n * @returns An object containing common tracking fields for failures.\n * @public\n * @example\n * const fields = MetricsManager.getCommonTrackingFieldForAQMResponseFailed(failureResponse);\n */\n public static getCommonTrackingFieldForAQMResponseFailed(\n failureResponse: Failure\n ): Record<string, any> {\n // This method is used to extract common tracking fields from the AQM response failure\n // and return them as an object. The fields are extracted from the response\n // object and its data property.\n const fields = {\n agentId: failureResponse?.data?.agentId,\n trackingId: failureResponse?.trackingId,\n notifTrackingId: failureResponse?.trackingId,\n orgId: failureResponse?.orgId,\n failureType: failureResponse?.type,\n failureReason: failureResponse?.data?.reason,\n reasonCode: failureResponse?.data?.reasonCode,\n };\n\n return fields;\n }\n}\n"],"mappings":"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"}
@@ -116,6 +116,8 @@ const METRIC_EVENT_NAMES = exports.METRIC_EVENT_NAMES = {
116
116
  UPLOAD_LOGS_FAILED: 'Upload Logs Failed',
117
117
  WEBSOCKET_DEREGISTER_SUCCESS: 'Websocket Deregister Success',
118
118
  WEBSOCKET_DEREGISTER_FAIL: 'Websocket Deregister Failed',
119
+ // WebSocket message events
120
+ WEBSOCKET_EVENT_RECEIVED: 'Websocket Event Received',
119
121
  AGENT_DEVICE_TYPE_UPDATE_SUCCESS: 'Agent Device Type Update Success',
120
122
  AGENT_DEVICE_TYPE_UPDATE_FAILED: 'Agent Device Type Update Failed'
121
123
  };
@@ -1 +1 @@
1
- {"version":3,"names":["METRIC_EVENT_NAMES","exports","STATION_LOGIN_SUCCESS","STATION_LOGIN_FAILED","STATION_LOGOUT_SUCCESS","STATION_LOGOUT_FAILED","STATION_RELOGIN_SUCCESS","STATION_RELOGIN_FAILED","AGENT_STATE_CHANGE_SUCCESS","AGENT_STATE_CHANGE_FAILED","FETCH_BUDDY_AGENTS_SUCCESS","FETCH_BUDDY_AGENTS_FAILED","WEBSOCKET_REGISTER_SUCCESS","WEBSOCKET_REGISTER_FAILED","AGENT_RONA","AGENT_CONTACT_ASSIGN_FAILED","AGENT_INVITE_FAILED","TASK_ACCEPT_SUCCESS","TASK_ACCEPT_FAILED","TASK_DECLINE_SUCCESS","TASK_DECLINE_FAILED","TASK_END_SUCCESS","TASK_END_FAILED","TASK_WRAPUP_SUCCESS","TASK_WRAPUP_FAILED","TASK_HOLD_SUCCESS","TASK_HOLD_FAILED","TASK_RESUME_SUCCESS","TASK_RESUME_FAILED","TASK_CONSULT_START_SUCCESS","TASK_CONSULT_START_FAILED","TASK_CONSULT_END_SUCCESS","TASK_CONSULT_END_FAILED","TASK_TRANSFER_SUCCESS","TASK_TRANSFER_FAILED","TASK_RESUME_RECORDING_SUCCESS","TASK_RESUME_RECORDING_FAILED","TASK_PAUSE_RECORDING_SUCCESS","TASK_PAUSE_RECORDING_FAILED","TASK_ACCEPT_CONSULT_SUCCESS","TASK_ACCEPT_CONSULT_FAILED","TASK_OUTDIAL_SUCCESS","TASK_OUTDIAL_FAILED","UPLOAD_LOGS_SUCCESS","UPLOAD_LOGS_FAILED","WEBSOCKET_DEREGISTER_SUCCESS","WEBSOCKET_DEREGISTER_FAIL","AGENT_DEVICE_TYPE_UPDATE_SUCCESS","AGENT_DEVICE_TYPE_UPDATE_FAILED"],"sources":["constants.ts"],"sourcesContent":["type Enum<T extends Record<string, unknown>> = T[keyof T];\n\n/**\n * @ignore\n * @module METRIC_EVENT_NAMES\n * @export\n * @description\n * A constant object containing all metric event names used for tracking various agent and task-related events\n * within the Contact Center plugin. Each property represents a specific event and its corresponding string value\n * as reported in metrics.\n *\n * @property {string} STATION_LOGIN_SUCCESS - Event name for successful station login.\n * @property {string} STATION_LOGIN_FAILED - Event name for failed station login.\n * @property {string} STATION_LOGOUT_SUCCESS - Event name for successful station logout.\n * @property {string} STATION_LOGOUT_FAILED - Event name for failed station logout.\n * @property {string} STATION_RELOGIN_SUCCESS - Event name for successful station relogin.\n * @property {string} STATION_RELOGIN_FAILED - Event name for failed station relogin.\n * @property {string} AGENT_STATE_CHANGE_SUCCESS - Event name for successful agent state change.\n * @property {string} AGENT_STATE_CHANGE_FAILED - Event name for failed agent state change.\n * @property {string} FETCH_BUDDY_AGENTS_SUCCESS - Event name for successfully fetching buddy agents.\n * @property {string} FETCH_BUDDY_AGENTS_FAILED - Event name for failed attempt to fetch buddy agents.\n * @property {string} WEBSOCKET_REGISTER_SUCCESS - Event name for successful websocket registration.\n * @property {string} WEBSOCKET_REGISTER_FAILED - Event name for failed websocket registration.\n * @property {string} AGENT_RONA - Event name for agent RONA (Ring No Answer).\n * @property {string} AGENT_CONTACT_ASSIGN_FAILED - Event name for failed agent contact assignment.\n * @property {string} AGENT_INVITE_FAILED - Event name for failed agent invite.\n *\n * @property {string} TASK_ACCEPT_SUCCESS - Event name for successful task acceptance.\n * @property {string} TASK_ACCEPT_FAILED - Event name for failed task acceptance.\n * @property {string} TASK_DECLINE_SUCCESS - Event name for successful task decline.\n * @property {string} TASK_DECLINE_FAILED - Event name for failed task decline.\n * @property {string} TASK_END_SUCCESS - Event name for successful task end.\n * @property {string} TASK_END_FAILED - Event name for failed task end.\n * @property {string} TASK_WRAPUP_SUCCESS - Event name for successful task wrap-up.\n * @property {string} TASK_WRAPUP_FAILED - Event name for failed task wrap-up.\n * @property {string} TASK_HOLD_SUCCESS - Event name for successful task hold.\n * @property {string} TASK_HOLD_FAILED - Event name for failed task hold.\n * @property {string} TASK_RESUME_SUCCESS - Event name for successful task resume.\n * @property {string} TASK_RESUME_FAILED - Event name for failed task resume.\n *\n * @property {string} TASK_CONSULT_START_SUCCESS - Event name for successful consult start.\n * @property {string} TASK_CONSULT_START_FAILED - Event name for failed consult start.\n * @property {string} TASK_CONSULT_END_SUCCESS - Event name for successful consult end.\n * @property {string} TASK_CONSULT_END_FAILED - Event name for failed consult end.\n * @property {string} TASK_TRANSFER_SUCCESS - Event name for successful task transfer.\n * @property {string} TASK_TRANSFER_FAILED - Event name for failed task transfer.\n * @property {string} TASK_RESUME_RECORDING_SUCCESS - Event name for successful resume of recording.\n * @property {string} TASK_RESUME_RECORDING_FAILED - Event name for failed resume of recording.\n * @property {string} TASK_PAUSE_RECORDING_SUCCESS - Event name for successful pause of recording.\n * @property {string} TASK_PAUSE_RECORDING_FAILED - Event name for failed pause of recording.\n * @property {string} TASK_ACCEPT_CONSULT_SUCCESS - Event name for successful consult acceptance.\n * @property {string} TASK_ACCEPT_CONSULT_FAILED - Event name for failed consult acceptance.\n *\n * @property {string} TASK_OUTDIAL_SUCCESS - Event name for successful outdial task.\n * @property {string} TASK_OUTDIAL_FAILED - Event name for failed outdial task.\n *\n * @property {string} UPLOAD_LOGS_SUCCESS - Event name for successful log upload.\n * @property {string} UPLOAD_LOGS_FAILED - Event name for failed log upload.\n * @property {string} WEBSOCKET_DEREGISTER_SUCCESS - Event name for successful websocket deregistration.\n * @property {string} WEBSOCKET_DEREGISTER_FAIL - Event name for failed websocket deregistration.\n *\n * @property {string} AGENT_DEVICE_TYPE_UPDATE_SUCCESS - Event name for successful agent device type update.\n * @property {string} AGENT_DEVICE_TYPE_UPDATE_FAILED - Event name for failed agent device type update.\n *\n * @readonly\n */\nexport const METRIC_EVENT_NAMES = {\n STATION_LOGIN_SUCCESS: 'Station Login Success',\n STATION_LOGIN_FAILED: 'Station Login Failed',\n STATION_LOGOUT_SUCCESS: 'Station Logout Success',\n STATION_LOGOUT_FAILED: 'Station Logout Failed',\n STATION_RELOGIN_SUCCESS: 'Station Relogin Success',\n STATION_RELOGIN_FAILED: 'Station Relogin Failed',\n AGENT_STATE_CHANGE_SUCCESS: 'Agent State Change Success',\n AGENT_STATE_CHANGE_FAILED: 'Agent State Change Failed',\n FETCH_BUDDY_AGENTS_SUCCESS: 'Fetch Buddy Agents Success',\n FETCH_BUDDY_AGENTS_FAILED: 'Fetch Buddy Agents Failed',\n WEBSOCKET_REGISTER_SUCCESS: 'Websocket Register Success',\n WEBSOCKET_REGISTER_FAILED: 'Websocket Register Failed',\n AGENT_RONA: 'Agent RONA',\n AGENT_CONTACT_ASSIGN_FAILED: 'Agent Contact Assign Failed',\n AGENT_INVITE_FAILED: 'Agent Invite Failed',\n\n // Basic Tasks\n TASK_ACCEPT_SUCCESS: 'Task Accept Success',\n TASK_ACCEPT_FAILED: 'Task Accept Failed',\n TASK_DECLINE_SUCCESS: 'Task Decline Success',\n TASK_DECLINE_FAILED: 'Task Decline Failed',\n TASK_END_SUCCESS: 'Task End Success',\n TASK_END_FAILED: 'Task End Failed',\n TASK_WRAPUP_SUCCESS: 'Task Wrapup Success',\n TASK_WRAPUP_FAILED: 'Task Wrapup Failed',\n TASK_HOLD_SUCCESS: 'Task Hold Success',\n TASK_HOLD_FAILED: 'Task Hold Failed',\n TASK_RESUME_SUCCESS: 'Task Resume Success',\n TASK_RESUME_FAILED: 'Task Resume Failed',\n\n // Advanced Tasks\n TASK_CONSULT_START_SUCCESS: 'Task Consult Start Success',\n TASK_CONSULT_START_FAILED: 'Task Consult Start Failed',\n TASK_CONSULT_END_SUCCESS: 'Task Consult End Success',\n TASK_CONSULT_END_FAILED: 'Task Consult End Failed',\n TASK_TRANSFER_SUCCESS: 'Task Transfer Success',\n TASK_TRANSFER_FAILED: 'Task Transfer Failed',\n TASK_RESUME_RECORDING_SUCCESS: 'Task Resume Recording Success',\n TASK_RESUME_RECORDING_FAILED: 'Task Resume Recording Failed',\n TASK_PAUSE_RECORDING_SUCCESS: 'Task Pause Recording Success',\n TASK_PAUSE_RECORDING_FAILED: 'Task Pause Recording Failed',\n TASK_ACCEPT_CONSULT_SUCCESS: 'Task Accept Consult Success',\n TASK_ACCEPT_CONSULT_FAILED: 'Task Accept Consult Failed',\n\n TASK_OUTDIAL_SUCCESS: 'Task Outdial Success',\n TASK_OUTDIAL_FAILED: 'Task Outdial Failed',\n\n UPLOAD_LOGS_SUCCESS: 'Upload Logs Success',\n UPLOAD_LOGS_FAILED: 'Upload Logs Failed',\n WEBSOCKET_DEREGISTER_SUCCESS: 'Websocket Deregister Success',\n WEBSOCKET_DEREGISTER_FAIL: 'Websocket Deregister Failed',\n\n AGENT_DEVICE_TYPE_UPDATE_SUCCESS: 'Agent Device Type Update Success',\n AGENT_DEVICE_TYPE_UPDATE_FAILED: 'Agent Device Type Update Failed',\n} as const;\n\n/**\n * Represents the possible metric event names used within the metrics system.\n *\n * This type is derived from the keys of the `METRIC_EVENT_NAMES` constant, ensuring\n * type safety and consistency when referring to metric event names throughout the codebase.\n * @export\n * @typedef {Enum<typeof METRIC_EVENT_NAMES>} METRIC_EVENT_NAMES\n * @typeParam T - The type of the `METRIC_EVENT_NAMES` constant.\n *\n * @see {@link METRIC_EVENT_NAMES}\n */\nexport type METRIC_EVENT_NAMES = Enum<typeof METRIC_EVENT_NAMES>;\n"],"mappings":";;;;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMA,kBAAkB,GAAAC,OAAA,CAAAD,kBAAA,GAAG;EAChCE,qBAAqB,EAAE,uBAAuB;EAC9CC,oBAAoB,EAAE,sBAAsB;EAC5CC,sBAAsB,EAAE,wBAAwB;EAChDC,qBAAqB,EAAE,uBAAuB;EAC9CC,uBAAuB,EAAE,yBAAyB;EAClDC,sBAAsB,EAAE,wBAAwB;EAChDC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,UAAU,EAAE,YAAY;EACxBC,2BAA2B,EAAE,6BAA6B;EAC1DC,mBAAmB,EAAE,qBAAqB;EAE1C;EACAC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EACxCC,oBAAoB,EAAE,sBAAsB;EAC5CC,mBAAmB,EAAE,qBAAqB;EAC1CC,gBAAgB,EAAE,kBAAkB;EACpCC,eAAe,EAAE,iBAAiB;EAClCC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EACxCC,iBAAiB,EAAE,mBAAmB;EACtCC,gBAAgB,EAAE,kBAAkB;EACpCC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EAExC;EACAC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,wBAAwB,EAAE,0BAA0B;EACpDC,uBAAuB,EAAE,yBAAyB;EAClDC,qBAAqB,EAAE,uBAAuB;EAC9CC,oBAAoB,EAAE,sBAAsB;EAC5CC,6BAA6B,EAAE,+BAA+B;EAC9DC,4BAA4B,EAAE,8BAA8B;EAC5DC,4BAA4B,EAAE,8BAA8B;EAC5DC,2BAA2B,EAAE,6BAA6B;EAC1DC,2BAA2B,EAAE,6BAA6B;EAC1DC,0BAA0B,EAAE,4BAA4B;EAExDC,oBAAoB,EAAE,sBAAsB;EAC5CC,mBAAmB,EAAE,qBAAqB;EAE1CC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EACxCC,4BAA4B,EAAE,8BAA8B;EAC5DC,yBAAyB,EAAE,6BAA6B;EAExDC,gCAAgC,EAAE,kCAAkC;EACpEC,+BAA+B,EAAE;AACnC,CAAU;;AAEV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA"}
1
+ {"version":3,"names":["METRIC_EVENT_NAMES","exports","STATION_LOGIN_SUCCESS","STATION_LOGIN_FAILED","STATION_LOGOUT_SUCCESS","STATION_LOGOUT_FAILED","STATION_RELOGIN_SUCCESS","STATION_RELOGIN_FAILED","AGENT_STATE_CHANGE_SUCCESS","AGENT_STATE_CHANGE_FAILED","FETCH_BUDDY_AGENTS_SUCCESS","FETCH_BUDDY_AGENTS_FAILED","WEBSOCKET_REGISTER_SUCCESS","WEBSOCKET_REGISTER_FAILED","AGENT_RONA","AGENT_CONTACT_ASSIGN_FAILED","AGENT_INVITE_FAILED","TASK_ACCEPT_SUCCESS","TASK_ACCEPT_FAILED","TASK_DECLINE_SUCCESS","TASK_DECLINE_FAILED","TASK_END_SUCCESS","TASK_END_FAILED","TASK_WRAPUP_SUCCESS","TASK_WRAPUP_FAILED","TASK_HOLD_SUCCESS","TASK_HOLD_FAILED","TASK_RESUME_SUCCESS","TASK_RESUME_FAILED","TASK_CONSULT_START_SUCCESS","TASK_CONSULT_START_FAILED","TASK_CONSULT_END_SUCCESS","TASK_CONSULT_END_FAILED","TASK_TRANSFER_SUCCESS","TASK_TRANSFER_FAILED","TASK_RESUME_RECORDING_SUCCESS","TASK_RESUME_RECORDING_FAILED","TASK_PAUSE_RECORDING_SUCCESS","TASK_PAUSE_RECORDING_FAILED","TASK_ACCEPT_CONSULT_SUCCESS","TASK_ACCEPT_CONSULT_FAILED","TASK_OUTDIAL_SUCCESS","TASK_OUTDIAL_FAILED","UPLOAD_LOGS_SUCCESS","UPLOAD_LOGS_FAILED","WEBSOCKET_DEREGISTER_SUCCESS","WEBSOCKET_DEREGISTER_FAIL","WEBSOCKET_EVENT_RECEIVED","AGENT_DEVICE_TYPE_UPDATE_SUCCESS","AGENT_DEVICE_TYPE_UPDATE_FAILED"],"sources":["constants.ts"],"sourcesContent":["type Enum<T extends Record<string, unknown>> = T[keyof T];\n\n/**\n * @ignore\n * @module METRIC_EVENT_NAMES\n * @export\n * @description\n * A constant object containing all metric event names used for tracking various agent and task-related events\n * within the Contact Center plugin. Each property represents a specific event and its corresponding string value\n * as reported in metrics.\n *\n * @property {string} STATION_LOGIN_SUCCESS - Event name for successful station login.\n * @property {string} STATION_LOGIN_FAILED - Event name for failed station login.\n * @property {string} STATION_LOGOUT_SUCCESS - Event name for successful station logout.\n * @property {string} STATION_LOGOUT_FAILED - Event name for failed station logout.\n * @property {string} STATION_RELOGIN_SUCCESS - Event name for successful station relogin.\n * @property {string} STATION_RELOGIN_FAILED - Event name for failed station relogin.\n * @property {string} AGENT_STATE_CHANGE_SUCCESS - Event name for successful agent state change.\n * @property {string} AGENT_STATE_CHANGE_FAILED - Event name for failed agent state change.\n * @property {string} FETCH_BUDDY_AGENTS_SUCCESS - Event name for successfully fetching buddy agents.\n * @property {string} FETCH_BUDDY_AGENTS_FAILED - Event name for failed attempt to fetch buddy agents.\n * @property {string} WEBSOCKET_REGISTER_SUCCESS - Event name for successful websocket registration.\n * @property {string} WEBSOCKET_REGISTER_FAILED - Event name for failed websocket registration.\n * @property {string} AGENT_RONA - Event name for agent RONA (Ring No Answer).\n * @property {string} AGENT_CONTACT_ASSIGN_FAILED - Event name for failed agent contact assignment.\n * @property {string} AGENT_INVITE_FAILED - Event name for failed agent invite.\n *\n * @property {string} TASK_ACCEPT_SUCCESS - Event name for successful task acceptance.\n * @property {string} TASK_ACCEPT_FAILED - Event name for failed task acceptance.\n * @property {string} TASK_DECLINE_SUCCESS - Event name for successful task decline.\n * @property {string} TASK_DECLINE_FAILED - Event name for failed task decline.\n * @property {string} TASK_END_SUCCESS - Event name for successful task end.\n * @property {string} TASK_END_FAILED - Event name for failed task end.\n * @property {string} TASK_WRAPUP_SUCCESS - Event name for successful task wrap-up.\n * @property {string} TASK_WRAPUP_FAILED - Event name for failed task wrap-up.\n * @property {string} TASK_HOLD_SUCCESS - Event name for successful task hold.\n * @property {string} TASK_HOLD_FAILED - Event name for failed task hold.\n * @property {string} TASK_RESUME_SUCCESS - Event name for successful task resume.\n * @property {string} TASK_RESUME_FAILED - Event name for failed task resume.\n *\n * @property {string} TASK_CONSULT_START_SUCCESS - Event name for successful consult start.\n * @property {string} TASK_CONSULT_START_FAILED - Event name for failed consult start.\n * @property {string} TASK_CONSULT_END_SUCCESS - Event name for successful consult end.\n * @property {string} TASK_CONSULT_END_FAILED - Event name for failed consult end.\n * @property {string} TASK_TRANSFER_SUCCESS - Event name for successful task transfer.\n * @property {string} TASK_TRANSFER_FAILED - Event name for failed task transfer.\n * @property {string} TASK_RESUME_RECORDING_SUCCESS - Event name for successful resume of recording.\n * @property {string} TASK_RESUME_RECORDING_FAILED - Event name for failed resume of recording.\n * @property {string} TASK_PAUSE_RECORDING_SUCCESS - Event name for successful pause of recording.\n * @property {string} TASK_PAUSE_RECORDING_FAILED - Event name for failed pause of recording.\n * @property {string} TASK_ACCEPT_CONSULT_SUCCESS - Event name for successful consult acceptance.\n * @property {string} TASK_ACCEPT_CONSULT_FAILED - Event name for failed consult acceptance.\n *\n * @property {string} TASK_OUTDIAL_SUCCESS - Event name for successful outdial task.\n * @property {string} TASK_OUTDIAL_FAILED - Event name for failed outdial task.\n *\n * @property {string} UPLOAD_LOGS_SUCCESS - Event name for successful log upload.\n * @property {string} UPLOAD_LOGS_FAILED - Event name for failed log upload.\n * @property {string} WEBSOCKET_DEREGISTER_SUCCESS - Event name for successful websocket deregistration.\n * @property {string} WEBSOCKET_DEREGISTER_FAIL - Event name for failed websocket deregistration.\n *\n * @property {string} AGENT_DEVICE_TYPE_UPDATE_SUCCESS - Event name for successful agent device type update.\n * @property {string} AGENT_DEVICE_TYPE_UPDATE_FAILED - Event name for failed agent device type update.\n *\n * @readonly\n */\nexport const METRIC_EVENT_NAMES = {\n STATION_LOGIN_SUCCESS: 'Station Login Success',\n STATION_LOGIN_FAILED: 'Station Login Failed',\n STATION_LOGOUT_SUCCESS: 'Station Logout Success',\n STATION_LOGOUT_FAILED: 'Station Logout Failed',\n STATION_RELOGIN_SUCCESS: 'Station Relogin Success',\n STATION_RELOGIN_FAILED: 'Station Relogin Failed',\n AGENT_STATE_CHANGE_SUCCESS: 'Agent State Change Success',\n AGENT_STATE_CHANGE_FAILED: 'Agent State Change Failed',\n FETCH_BUDDY_AGENTS_SUCCESS: 'Fetch Buddy Agents Success',\n FETCH_BUDDY_AGENTS_FAILED: 'Fetch Buddy Agents Failed',\n WEBSOCKET_REGISTER_SUCCESS: 'Websocket Register Success',\n WEBSOCKET_REGISTER_FAILED: 'Websocket Register Failed',\n AGENT_RONA: 'Agent RONA',\n AGENT_CONTACT_ASSIGN_FAILED: 'Agent Contact Assign Failed',\n AGENT_INVITE_FAILED: 'Agent Invite Failed',\n\n // Basic Tasks\n TASK_ACCEPT_SUCCESS: 'Task Accept Success',\n TASK_ACCEPT_FAILED: 'Task Accept Failed',\n TASK_DECLINE_SUCCESS: 'Task Decline Success',\n TASK_DECLINE_FAILED: 'Task Decline Failed',\n TASK_END_SUCCESS: 'Task End Success',\n TASK_END_FAILED: 'Task End Failed',\n TASK_WRAPUP_SUCCESS: 'Task Wrapup Success',\n TASK_WRAPUP_FAILED: 'Task Wrapup Failed',\n TASK_HOLD_SUCCESS: 'Task Hold Success',\n TASK_HOLD_FAILED: 'Task Hold Failed',\n TASK_RESUME_SUCCESS: 'Task Resume Success',\n TASK_RESUME_FAILED: 'Task Resume Failed',\n\n // Advanced Tasks\n TASK_CONSULT_START_SUCCESS: 'Task Consult Start Success',\n TASK_CONSULT_START_FAILED: 'Task Consult Start Failed',\n TASK_CONSULT_END_SUCCESS: 'Task Consult End Success',\n TASK_CONSULT_END_FAILED: 'Task Consult End Failed',\n TASK_TRANSFER_SUCCESS: 'Task Transfer Success',\n TASK_TRANSFER_FAILED: 'Task Transfer Failed',\n TASK_RESUME_RECORDING_SUCCESS: 'Task Resume Recording Success',\n TASK_RESUME_RECORDING_FAILED: 'Task Resume Recording Failed',\n TASK_PAUSE_RECORDING_SUCCESS: 'Task Pause Recording Success',\n TASK_PAUSE_RECORDING_FAILED: 'Task Pause Recording Failed',\n TASK_ACCEPT_CONSULT_SUCCESS: 'Task Accept Consult Success',\n TASK_ACCEPT_CONSULT_FAILED: 'Task Accept Consult Failed',\n\n TASK_OUTDIAL_SUCCESS: 'Task Outdial Success',\n TASK_OUTDIAL_FAILED: 'Task Outdial Failed',\n\n UPLOAD_LOGS_SUCCESS: 'Upload Logs Success',\n UPLOAD_LOGS_FAILED: 'Upload Logs Failed',\n WEBSOCKET_DEREGISTER_SUCCESS: 'Websocket Deregister Success',\n WEBSOCKET_DEREGISTER_FAIL: 'Websocket Deregister Failed',\n\n // WebSocket message events\n WEBSOCKET_EVENT_RECEIVED: 'Websocket Event Received',\n\n AGENT_DEVICE_TYPE_UPDATE_SUCCESS: 'Agent Device Type Update Success',\n AGENT_DEVICE_TYPE_UPDATE_FAILED: 'Agent Device Type Update Failed',\n} as const;\n\n/**\n * Represents the possible metric event names used within the metrics system.\n *\n * This type is derived from the keys of the `METRIC_EVENT_NAMES` constant, ensuring\n * type safety and consistency when referring to metric event names throughout the codebase.\n * @export\n * @typedef {Enum<typeof METRIC_EVENT_NAMES>} METRIC_EVENT_NAMES\n * @typeParam T - The type of the `METRIC_EVENT_NAMES` constant.\n *\n * @see {@link METRIC_EVENT_NAMES}\n */\nexport type METRIC_EVENT_NAMES = Enum<typeof METRIC_EVENT_NAMES>;\n"],"mappings":";;;;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMA,kBAAkB,GAAAC,OAAA,CAAAD,kBAAA,GAAG;EAChCE,qBAAqB,EAAE,uBAAuB;EAC9CC,oBAAoB,EAAE,sBAAsB;EAC5CC,sBAAsB,EAAE,wBAAwB;EAChDC,qBAAqB,EAAE,uBAAuB;EAC9CC,uBAAuB,EAAE,yBAAyB;EAClDC,sBAAsB,EAAE,wBAAwB;EAChDC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,UAAU,EAAE,YAAY;EACxBC,2BAA2B,EAAE,6BAA6B;EAC1DC,mBAAmB,EAAE,qBAAqB;EAE1C;EACAC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EACxCC,oBAAoB,EAAE,sBAAsB;EAC5CC,mBAAmB,EAAE,qBAAqB;EAC1CC,gBAAgB,EAAE,kBAAkB;EACpCC,eAAe,EAAE,iBAAiB;EAClCC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EACxCC,iBAAiB,EAAE,mBAAmB;EACtCC,gBAAgB,EAAE,kBAAkB;EACpCC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EAExC;EACAC,0BAA0B,EAAE,4BAA4B;EACxDC,yBAAyB,EAAE,2BAA2B;EACtDC,wBAAwB,EAAE,0BAA0B;EACpDC,uBAAuB,EAAE,yBAAyB;EAClDC,qBAAqB,EAAE,uBAAuB;EAC9CC,oBAAoB,EAAE,sBAAsB;EAC5CC,6BAA6B,EAAE,+BAA+B;EAC9DC,4BAA4B,EAAE,8BAA8B;EAC5DC,4BAA4B,EAAE,8BAA8B;EAC5DC,2BAA2B,EAAE,6BAA6B;EAC1DC,2BAA2B,EAAE,6BAA6B;EAC1DC,0BAA0B,EAAE,4BAA4B;EAExDC,oBAAoB,EAAE,sBAAsB;EAC5CC,mBAAmB,EAAE,qBAAqB;EAE1CC,mBAAmB,EAAE,qBAAqB;EAC1CC,kBAAkB,EAAE,oBAAoB;EACxCC,4BAA4B,EAAE,8BAA8B;EAC5DC,yBAAyB,EAAE,6BAA6B;EAExD;EACAC,wBAAwB,EAAE,0BAA0B;EAEpDC,gCAAgC,EAAE,kCAAkC;EACpEC,+BAA+B,EAAE;AACnC,CAAU;;AAEV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA"}
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["GlobalTypes.ts"],"sourcesContent":["/**\n * Generic message interface used throughout the plugin\n * @template T - Type of the data payload (defaults to any)\n * @private\n * @ignore\n */\nexport type Msg<T = any> = {\n /** Message/Event type identifier */\n type: string;\n /** Organization identifier */\n orgId: string;\n /** Unique tracking identifier for the message/Event */\n trackingId: string;\n /** Message/Event payload data */\n data: T;\n};\n\n/**\n * Represents a failure message with specific error details\n * @private\n * @ignore\n */\nexport type Failure = Msg<{\n /** Agent identifier associated with the failure */\n agentId: string;\n /** Tracking identifier for the failure event */\n trackingId: string;\n /** Numeric code indicating the reason for failure */\n reasonCode: number;\n /** Organization identifier */\n orgId: string;\n /** Human-readable description of the failure reason */\n reason: string;\n}>;\n"],"mappings":""}
1
+ {"version":3,"names":[],"sources":["GlobalTypes.ts"],"sourcesContent":["/**\n * Generic message interface used throughout the plugin\n * @template T - Type of the data payload (defaults to any)\n * @private\n * @ignore\n */\nexport type Msg<T = any> = {\n /** Message/Event type identifier */\n type: string;\n /** Organization identifier */\n orgId: string;\n /** Unique tracking identifier for the message/Event */\n trackingId: string;\n /** Message/Event payload data */\n data: T;\n};\n\n/**\n * Represents a failure message with specific error details\n * @private\n * @ignore\n */\nexport type Failure = Msg<{\n /** Agent identifier associated with the failure */\n agentId: string;\n /** Tracking identifier for the failure event */\n trackingId: string;\n /** Numeric code indicating the reason for failure */\n reasonCode: number;\n /** Organization identifier */\n orgId: string;\n /** Human-readable description of the failure reason */\n reason: string;\n}>;\n\n/**\n * Represents task API error details in a structured format\n * @public\n */\nexport interface TaskError {\n /** Original error object for throwing */\n error: Error;\n /** Unique tracking identifier for correlation */\n trackingId: string;\n /** Detailed error message from the API */\n errorMessage: string;\n /** Type/category of the error (e.g., \"Bad Request\") */\n errorType: string;\n /** Additional error context data */\n errorData: string;\n /** Numeric reason code */\n reasonCode: number;\n}\n\n/**\n * An Error object augmented with a flexible data field for additional context.\n * Use this to attach structured data to thrown errors without ts-ignore.\n */\nexport interface AugmentedError extends Error {\n data?: Record<string, any>;\n}\n"],"mappings":""}
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.isValidDialNumber = exports.getStationLoginErrorData = exports.getErrorDetails = exports.getDestinationAgentId = exports.deriveConsultTransferDestinationType = exports.createErrDetailsObject = void 0;
6
+ exports.isValidDialNumber = exports.getStationLoginErrorData = exports.getErrorDetails = exports.getDestinationAgentId = exports.generateTaskErrorObject = exports.deriveConsultTransferDestinationType = exports.createErrDetailsObject = void 0;
7
7
  var Err = _interopRequireWildcard(require("./Err"));
8
8
  var _types = require("../../types");
9
9
  var _loggerProxy = _interopRequireDefault(require("../../logger-proxy"));
@@ -130,6 +130,51 @@ const getErrorDetails = (error, methodName, moduleName) => {
130
130
  };
131
131
  };
132
132
 
133
+ /**
134
+ * Extracts error details from task API errors and logs them. Also uploads logs for the error.
135
+ * This handles the specific error format returned by task API calls.
136
+ *
137
+ * @param error - The error object from task API calls with structure: {id: string, details: {trackingId: string, msg: {...}}}
138
+ * @param methodName - The name of the method where the error occurred.
139
+ * @param moduleName - The name of the module where the error occurred.
140
+ * @returns AugmentedError containing structured error details on err.data for metrics and logging
141
+ * @public
142
+ * @example
143
+ * const taskError = generateTaskErrorObject(error, 'transfer', 'TaskModule');
144
+ * throw taskError.error;
145
+ * @ignore
146
+ */
147
+ exports.getErrorDetails = getErrorDetails;
148
+ const generateTaskErrorObject = (error, methodName, moduleName) => {
149
+ const trackingId = error?.details?.trackingId || error?.trackingId || '';
150
+ const errorMsg = error?.details?.msg;
151
+ const fallbackMessage = error && typeof error.message === 'string' && error.message || `Error while performing ${methodName}`;
152
+ const errorMessage = errorMsg?.errorMessage || fallbackMessage;
153
+ const errorType = errorMsg?.errorType || error && typeof error.name === 'string' && error.name || 'Unknown Error';
154
+ const errorData = errorMsg?.errorData || '';
155
+ const reasonCode = errorMsg?.reasonCode || 0;
156
+
157
+ // Log and upload for Task API formatted errors
158
+ _loggerProxy.default.error(`${methodName} failed: ${errorMessage} (${errorType})`, {
159
+ module: moduleName,
160
+ method: methodName,
161
+ trackingId
162
+ });
163
+ _WebexRequest.default.getInstance().uploadLogs({
164
+ correlationId: trackingId
165
+ });
166
+ const reason = `${errorType}: ${errorMessage}${errorData ? ` (${errorData})` : ''}`;
167
+ const err = new Error(reason);
168
+ err.data = {
169
+ message: errorMessage,
170
+ errorType,
171
+ errorData,
172
+ reasonCode,
173
+ trackingId
174
+ };
175
+ return err;
176
+ };
177
+
133
178
  /**
134
179
  * Creates an error details object suitable for use with the Err.Details class.
135
180
  *
@@ -140,7 +185,7 @@ const getErrorDetails = (error, methodName, moduleName) => {
140
185
  * const errDetails = createErrDetailsObject(webexRequestPayload);
141
186
  * @ignore
142
187
  */
143
- exports.getErrorDetails = getErrorDetails;
188
+ exports.generateTaskErrorObject = generateTaskErrorObject;
144
189
  const createErrDetailsObject = errObj => {
145
190
  const details = getCommonErrorDetails(errObj);
146
191
  return new Err.Details('Service.reqs.generic.failure', details);
@@ -1 +1 @@
1
- {"version":3,"names":["Err","_interopRequireWildcard","require","_types","_loggerProxy","_interopRequireDefault","_WebexRequest","_types2","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","getCommonErrorDetails","errObj","trackingId","headers","trackingid","TrackingID","msg","body","isEntryPointOrEpdn","destAgentType","getAgentActionTypeFromTask","taskData","destinationType","isDialNumber","isEntryPointVariant","isValidDialNumber","input","regexForDn","test","exports","getStationLoginErrorData","failure","loginOption","duplicateLocationMessage","LoginOption","EXTENSION","AGENT_DN","errorCodeMessageMap","DUPLICATE_LOCATION","message","fieldName","INVALID_DIAL_NUMBER","defaultMessage","defaultFieldName","reason","data","getErrorDetails","error","methodName","moduleName","errData","details","LoggerProxy","module","method","WebexRequest","getInstance","uploadLogs","correlationId","err","Error","createErrDetailsObject","Details","isNonCustomerParticipant","participantType","getDestinationAgentId","participants","agentId","id","keys","forEach","participant","participantData","type","isWrapUp","deriveConsultTransferDestinationType","agentActionType","CONSULT_TRANSFER_DESTINATION_TYPE","ENTRYPOINT","DIALNUMBER","AGENT"],"sources":["Utils.ts"],"sourcesContent":["import * as Err from './Err';\nimport {LoginOption, WebexRequestPayload} from '../../types';\nimport {Failure} from './GlobalTypes';\nimport LoggerProxy from '../../logger-proxy';\nimport WebexRequest from './WebexRequest';\nimport {\n TaskData,\n ConsultTransferPayLoad,\n CONSULT_TRANSFER_DESTINATION_TYPE,\n Interaction,\n} from '../task/types';\n\n/**\n * Extracts common error details from a Webex request payload.\n *\n * @param errObj - The Webex request payload object.\n * @returns An object containing the tracking ID and message body.\n * @private\n * @ignore\n */\nconst getCommonErrorDetails = (errObj: WebexRequestPayload) => {\n return {\n trackingId: errObj?.headers?.trackingid || errObj?.headers?.TrackingID,\n msg: errObj?.body,\n };\n};\n\n/**\n * Checks if the destination type represents an entry point variant (EPDN or ENTRYPOINT).\n */\nconst isEntryPointOrEpdn = (destAgentType?: string): boolean => {\n return destAgentType === 'EPDN' || destAgentType === 'ENTRYPOINT';\n};\n\n/**\n * Determines if the task involves dialing a number based on the destination type.\n * Returns 'DIAL_NUMBER' for dial-related destinations, empty string otherwise.\n */\nconst getAgentActionTypeFromTask = (taskData?: TaskData): 'DIAL_NUMBER' | '' => {\n const destAgentType = taskData?.destinationType;\n\n // Check if destination requires dialing: direct dial number or entry point variants\n const isDialNumber = destAgentType === 'DN';\n const isEntryPointVariant = isEntryPointOrEpdn(destAgentType);\n\n // If the destination type is a dial number or an entry point variant, return 'DIAL_NUMBER'\n return isDialNumber || isEntryPointVariant ? 'DIAL_NUMBER' : '';\n};\n\nexport const isValidDialNumber = (input: string): boolean => {\n // This regex checks for a valid dial number format for only few countries such as US, Canada.\n const regexForDn = /1[0-9]{3}[2-9][0-9]{6}([,]{1,10}[0-9]+){0,1}/;\n\n return regexForDn.test(input);\n};\n\nexport const getStationLoginErrorData = (failure: Failure, loginOption: LoginOption) => {\n let duplicateLocationMessage = 'This value is already in use';\n\n if (loginOption === LoginOption.EXTENSION) {\n duplicateLocationMessage = 'This extension is already in use';\n }\n\n if (loginOption === LoginOption.AGENT_DN) {\n duplicateLocationMessage =\n 'Dial number is in use. Try a different one. For help, reach out to your administrator or support team.';\n }\n\n const errorCodeMessageMap = {\n DUPLICATE_LOCATION: {\n message: duplicateLocationMessage,\n fieldName: loginOption,\n },\n INVALID_DIAL_NUMBER: {\n message:\n 'Enter a valid US dial number. For help, reach out to your administrator or support team.',\n fieldName: loginOption,\n },\n };\n\n const defaultMessage = 'An error occurred while logging in to the station';\n const defaultFieldName = 'generic';\n\n const reason = failure?.data?.reason || '';\n\n return {\n message: errorCodeMessageMap[reason]?.message || defaultMessage,\n fieldName: errorCodeMessageMap[reason]?.fieldName || defaultFieldName,\n };\n};\n\n/**\n * Extracts error details and logs the error. Also uploads logs for the error unless it is a silent relogin agent not found error.\n *\n * @param error - The error object, expected to have a `details` property of type Failure.\n * @param methodName - The name of the method where the error occurred.\n * @param moduleName - The name of the module where the error occurred.\n * @returns An object containing the error instance and the reason string.\n * @public\n * @example\n * const details = getErrorDetails(error, 'fetchData', 'DataModule');\n * if (details.error) { handleError(details.error); }\n * @ignore\n */\nexport const getErrorDetails = (error: any, methodName: string, moduleName: string) => {\n let errData = {message: '', fieldName: ''};\n\n const failure = error.details as Failure;\n const reason = failure?.data?.reason ?? `Error while performing ${methodName}`;\n\n if (!(reason === 'AGENT_NOT_FOUND' && methodName === 'silentRelogin')) {\n LoggerProxy.error(`${methodName} failed with reason: ${reason}`, {\n module: moduleName,\n method: methodName,\n trackingId: failure?.trackingId,\n });\n // we can add more conditions here if not needed for specific cases eg: silentReLogin\n WebexRequest.getInstance().uploadLogs({\n correlationId: failure?.trackingId,\n });\n }\n\n if (methodName === 'stationLogin') {\n errData = getStationLoginErrorData(failure, error.loginOption);\n\n LoggerProxy.error(\n `${methodName} failed with reason: ${reason}, message: ${errData.message}, fieldName: ${errData.fieldName}`,\n {\n module: moduleName,\n method: methodName,\n trackingId: failure?.trackingId,\n }\n );\n }\n\n const err = new Error(reason ?? `Error while performing ${methodName}`);\n // @ts-ignore - add custom property to the error object for backward compatibility\n err.data = errData;\n\n return {\n error: err,\n reason,\n };\n};\n\n/**\n * Creates an error details object suitable for use with the Err.Details class.\n *\n * @param errObj - The Webex request payload object.\n * @returns An instance of Err.Details with the generic failure message and extracted details.\n * @public\n * @example\n * const errDetails = createErrDetailsObject(webexRequestPayload);\n * @ignore\n */\nexport const createErrDetailsObject = (errObj: WebexRequestPayload) => {\n const details = getCommonErrorDetails(errObj);\n\n return new Err.Details('Service.reqs.generic.failure', details);\n};\n\n/**\n * Derives the consult transfer destination type based on the provided task data.\n *\n * Logic parity with desktop behavior:\n * - If agent action is dialing a number (DN/EPDN/ENTRYPOINT):\n * - ENTRYPOINT/EPDN map to ENTRYPOINT\n * - DN maps to DIALNUMBER\n * - Otherwise defaults to AGENT\n *\n * @param taskData - The task data used to infer the agent action and destination type\n * @returns The normalized destination type to be used for consult transfer\n */\n/**\n * Checks if a participant type represents a non-customer participant.\n * Non-customer participants include agents, dial numbers, entry point dial numbers,\n * and entry points.\n */\nconst isNonCustomerParticipant = (participantType: string): boolean => {\n return (\n participantType === 'Agent' ||\n participantType === 'DN' ||\n participantType === 'EpDn' ||\n participantType === 'entryPoint'\n );\n};\n\n/**\n * Gets the destination agent ID from participants data by finding the first\n * non-customer participant that is not the current agent and is not in wrap-up state.\n *\n * @param participants - The participants data from the interaction\n * @param agentId - The current agent's ID to exclude from the search\n * @returns The destination agent ID, or empty string if none found\n */\nexport const getDestinationAgentId = (\n participants: Interaction['participants'],\n agentId: string\n): string => {\n let id = '';\n\n if (participants) {\n Object.keys(participants).forEach((participant) => {\n const participantData = participants[participant];\n if (\n isNonCustomerParticipant(participantData.type) &&\n participantData.id !== agentId &&\n !participantData.isWrapUp\n ) {\n id = participantData.id;\n }\n });\n }\n\n return id;\n};\n\nexport const deriveConsultTransferDestinationType = (\n taskData?: TaskData\n): ConsultTransferPayLoad['destinationType'] => {\n const agentActionType = getAgentActionTypeFromTask(taskData);\n\n if (agentActionType === 'DIAL_NUMBER') {\n return isEntryPointOrEpdn(taskData?.destinationType)\n ? CONSULT_TRANSFER_DESTINATION_TYPE.ENTRYPOINT\n : CONSULT_TRANSFER_DESTINATION_TYPE.DIALNUMBER;\n }\n\n return CONSULT_TRANSFER_DESTINATION_TYPE.AGENT;\n};\n"],"mappings":"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"}
1
+ {"version":3,"names":["Err","_interopRequireWildcard","require","_types","_loggerProxy","_interopRequireDefault","_WebexRequest","_types2","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","getCommonErrorDetails","errObj","trackingId","headers","trackingid","TrackingID","msg","body","isEntryPointOrEpdn","destAgentType","getAgentActionTypeFromTask","taskData","destinationType","isDialNumber","isEntryPointVariant","isValidDialNumber","input","regexForDn","test","exports","getStationLoginErrorData","failure","loginOption","duplicateLocationMessage","LoginOption","EXTENSION","AGENT_DN","errorCodeMessageMap","DUPLICATE_LOCATION","message","fieldName","INVALID_DIAL_NUMBER","defaultMessage","defaultFieldName","reason","data","getErrorDetails","error","methodName","moduleName","errData","details","LoggerProxy","module","method","WebexRequest","getInstance","uploadLogs","correlationId","err","Error","generateTaskErrorObject","errorMsg","fallbackMessage","errorMessage","errorType","name","errorData","reasonCode","createErrDetailsObject","Details","isNonCustomerParticipant","participantType","getDestinationAgentId","participants","agentId","id","keys","forEach","participant","participantData","type","isWrapUp","deriveConsultTransferDestinationType","agentActionType","CONSULT_TRANSFER_DESTINATION_TYPE","ENTRYPOINT","DIALNUMBER","AGENT"],"sources":["Utils.ts"],"sourcesContent":["import * as Err from './Err';\nimport {LoginOption, WebexRequestPayload} from '../../types';\nimport {Failure, AugmentedError} from './GlobalTypes';\nimport LoggerProxy from '../../logger-proxy';\nimport WebexRequest from './WebexRequest';\nimport {\n TaskData,\n ConsultTransferPayLoad,\n CONSULT_TRANSFER_DESTINATION_TYPE,\n Interaction,\n} from '../task/types';\n\n/**\n * Extracts common error details from a Webex request payload.\n *\n * @param errObj - The Webex request payload object.\n * @returns An object containing the tracking ID and message body.\n * @private\n * @ignore\n */\nconst getCommonErrorDetails = (errObj: WebexRequestPayload) => {\n return {\n trackingId: errObj?.headers?.trackingid || errObj?.headers?.TrackingID,\n msg: errObj?.body,\n };\n};\n\n/**\n * Checks if the destination type represents an entry point variant (EPDN or ENTRYPOINT).\n */\nconst isEntryPointOrEpdn = (destAgentType?: string): boolean => {\n return destAgentType === 'EPDN' || destAgentType === 'ENTRYPOINT';\n};\n\n/**\n * Determines if the task involves dialing a number based on the destination type.\n * Returns 'DIAL_NUMBER' for dial-related destinations, empty string otherwise.\n */\nconst getAgentActionTypeFromTask = (taskData?: TaskData): 'DIAL_NUMBER' | '' => {\n const destAgentType = taskData?.destinationType;\n\n // Check if destination requires dialing: direct dial number or entry point variants\n const isDialNumber = destAgentType === 'DN';\n const isEntryPointVariant = isEntryPointOrEpdn(destAgentType);\n\n // If the destination type is a dial number or an entry point variant, return 'DIAL_NUMBER'\n return isDialNumber || isEntryPointVariant ? 'DIAL_NUMBER' : '';\n};\n\nexport const isValidDialNumber = (input: string): boolean => {\n // This regex checks for a valid dial number format for only few countries such as US, Canada.\n const regexForDn = /1[0-9]{3}[2-9][0-9]{6}([,]{1,10}[0-9]+){0,1}/;\n\n return regexForDn.test(input);\n};\n\nexport const getStationLoginErrorData = (failure: Failure, loginOption: LoginOption) => {\n let duplicateLocationMessage = 'This value is already in use';\n\n if (loginOption === LoginOption.EXTENSION) {\n duplicateLocationMessage = 'This extension is already in use';\n }\n\n if (loginOption === LoginOption.AGENT_DN) {\n duplicateLocationMessage =\n 'Dial number is in use. Try a different one. For help, reach out to your administrator or support team.';\n }\n\n const errorCodeMessageMap = {\n DUPLICATE_LOCATION: {\n message: duplicateLocationMessage,\n fieldName: loginOption,\n },\n INVALID_DIAL_NUMBER: {\n message:\n 'Enter a valid US dial number. For help, reach out to your administrator or support team.',\n fieldName: loginOption,\n },\n };\n\n const defaultMessage = 'An error occurred while logging in to the station';\n const defaultFieldName = 'generic';\n\n const reason = failure?.data?.reason || '';\n\n return {\n message: errorCodeMessageMap[reason]?.message || defaultMessage,\n fieldName: errorCodeMessageMap[reason]?.fieldName || defaultFieldName,\n };\n};\n\n/**\n * Extracts error details and logs the error. Also uploads logs for the error unless it is a silent relogin agent not found error.\n *\n * @param error - The error object, expected to have a `details` property of type Failure.\n * @param methodName - The name of the method where the error occurred.\n * @param moduleName - The name of the module where the error occurred.\n * @returns An object containing the error instance and the reason string.\n * @public\n * @example\n * const details = getErrorDetails(error, 'fetchData', 'DataModule');\n * if (details.error) { handleError(details.error); }\n * @ignore\n */\nexport const getErrorDetails = (error: any, methodName: string, moduleName: string) => {\n let errData = {message: '', fieldName: ''};\n\n const failure = error.details as Failure;\n const reason = failure?.data?.reason ?? `Error while performing ${methodName}`;\n\n if (!(reason === 'AGENT_NOT_FOUND' && methodName === 'silentRelogin')) {\n LoggerProxy.error(`${methodName} failed with reason: ${reason}`, {\n module: moduleName,\n method: methodName,\n trackingId: failure?.trackingId,\n });\n // we can add more conditions here if not needed for specific cases eg: silentReLogin\n WebexRequest.getInstance().uploadLogs({\n correlationId: failure?.trackingId,\n });\n }\n\n if (methodName === 'stationLogin') {\n errData = getStationLoginErrorData(failure, error.loginOption);\n\n LoggerProxy.error(\n `${methodName} failed with reason: ${reason}, message: ${errData.message}, fieldName: ${errData.fieldName}`,\n {\n module: moduleName,\n method: methodName,\n trackingId: failure?.trackingId,\n }\n );\n }\n\n const err = new Error(reason ?? `Error while performing ${methodName}`);\n // @ts-ignore - add custom property to the error object for backward compatibility\n err.data = errData;\n\n return {\n error: err,\n reason,\n };\n};\n\n/**\n * Extracts error details from task API errors and logs them. Also uploads logs for the error.\n * This handles the specific error format returned by task API calls.\n *\n * @param error - The error object from task API calls with structure: {id: string, details: {trackingId: string, msg: {...}}}\n * @param methodName - The name of the method where the error occurred.\n * @param moduleName - The name of the module where the error occurred.\n * @returns AugmentedError containing structured error details on err.data for metrics and logging\n * @public\n * @example\n * const taskError = generateTaskErrorObject(error, 'transfer', 'TaskModule');\n * throw taskError.error;\n * @ignore\n */\nexport const generateTaskErrorObject = (\n error: any,\n methodName: string,\n moduleName: string\n): AugmentedError => {\n const trackingId = error?.details?.trackingId || error?.trackingId || '';\n const errorMsg = error?.details?.msg;\n\n const fallbackMessage =\n (error && typeof error.message === 'string' && error.message) ||\n `Error while performing ${methodName}`;\n const errorMessage = errorMsg?.errorMessage || fallbackMessage;\n const errorType =\n errorMsg?.errorType ||\n (error && typeof error.name === 'string' && error.name) ||\n 'Unknown Error';\n const errorData = errorMsg?.errorData || '';\n const reasonCode = errorMsg?.reasonCode || 0;\n\n // Log and upload for Task API formatted errors\n LoggerProxy.error(`${methodName} failed: ${errorMessage} (${errorType})`, {\n module: moduleName,\n method: methodName,\n trackingId,\n });\n WebexRequest.getInstance().uploadLogs({\n correlationId: trackingId,\n });\n\n const reason = `${errorType}: ${errorMessage}${errorData ? ` (${errorData})` : ''}`;\n const err: AugmentedError = new Error(reason);\n err.data = {\n message: errorMessage,\n errorType,\n errorData,\n reasonCode,\n trackingId,\n };\n\n return err;\n};\n\n/**\n * Creates an error details object suitable for use with the Err.Details class.\n *\n * @param errObj - The Webex request payload object.\n * @returns An instance of Err.Details with the generic failure message and extracted details.\n * @public\n * @example\n * const errDetails = createErrDetailsObject(webexRequestPayload);\n * @ignore\n */\nexport const createErrDetailsObject = (errObj: WebexRequestPayload) => {\n const details = getCommonErrorDetails(errObj);\n\n return new Err.Details('Service.reqs.generic.failure', details);\n};\n\n/**\n * Derives the consult transfer destination type based on the provided task data.\n *\n * Logic parity with desktop behavior:\n * - If agent action is dialing a number (DN/EPDN/ENTRYPOINT):\n * - ENTRYPOINT/EPDN map to ENTRYPOINT\n * - DN maps to DIALNUMBER\n * - Otherwise defaults to AGENT\n *\n * @param taskData - The task data used to infer the agent action and destination type\n * @returns The normalized destination type to be used for consult transfer\n */\n/**\n * Checks if a participant type represents a non-customer participant.\n * Non-customer participants include agents, dial numbers, entry point dial numbers,\n * and entry points.\n */\nconst isNonCustomerParticipant = (participantType: string): boolean => {\n return (\n participantType === 'Agent' ||\n participantType === 'DN' ||\n participantType === 'EpDn' ||\n participantType === 'entryPoint'\n );\n};\n\n/**\n * Gets the destination agent ID from participants data by finding the first\n * non-customer participant that is not the current agent and is not in wrap-up state.\n *\n * @param participants - The participants data from the interaction\n * @param agentId - The current agent's ID to exclude from the search\n * @returns The destination agent ID, or empty string if none found\n */\nexport const getDestinationAgentId = (\n participants: Interaction['participants'],\n agentId: string\n): string => {\n let id = '';\n\n if (participants) {\n Object.keys(participants).forEach((participant) => {\n const participantData = participants[participant];\n if (\n isNonCustomerParticipant(participantData.type) &&\n participantData.id !== agentId &&\n !participantData.isWrapUp\n ) {\n id = participantData.id;\n }\n });\n }\n\n return id;\n};\n\nexport const deriveConsultTransferDestinationType = (\n taskData?: TaskData\n): ConsultTransferPayLoad['destinationType'] => {\n const agentActionType = getAgentActionTypeFromTask(taskData);\n\n if (agentActionType === 'DIAL_NUMBER') {\n return isEntryPointOrEpdn(taskData?.destinationType)\n ? CONSULT_TRANSFER_DESTINATION_TYPE.ENTRYPOINT\n : CONSULT_TRANSFER_DESTINATION_TYPE.DIALNUMBER;\n }\n\n return CONSULT_TRANSFER_DESTINATION_TYPE.AGENT;\n};\n"],"mappings":"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"}
@@ -200,10 +200,6 @@ class AqmReqs {
200
200
  return;
201
201
  }
202
202
  if (event.keepalive === 'true') {
203
- _loggerProxy.default.info(`Keepalive from web socket`, {
204
- module: _constants2.AQM_REQS_FILE,
205
- method: _constants.METHODS.ON_MESSAGE
206
- });
207
203
  return;
208
204
  }
209
205
  if (event.type === 'AgentReloginFailed') {
@@ -1 +1 @@
1
- {"version":3,"names":["Err","_interopRequireWildcard","require","_types","_loggerProxy","_interopRequireDefault","_constants","_constants2","_WebexRequest","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","AqmReqs","pendingRequests","pendingNotifCancelrequest","constructor","webSocketManager","webexRequest","WebexRequest","getInstance","on","onMessage","bind","req","c","p","cbRes","makeAPIRequest","reqEmpty","createPromise","Promise","resolve","reject","keySuccess","bindPrint","notifSuccess","keyFail","notifFail","keyCancel","notifCancel","k","timeout","Details","key","msg","isClear","clear","check","bindCheck","handle","alternateBind","alternateBindKey","LoggerProxy","log","JSON","stringify","module","AQM_REQS_FILE","method","METHODS","CREATE_PROMISE","eerr","errId","err","response","request","service","host","resource","url","data","HTTP_METHODS","POST","GET","body","then","res","catch","error","headers","Authorization","Message","window","setTimeout","TIMEOUT_REQ","result","Array","isArray","join","slice","includes","event","parse","type","info","ON_MESSAGE","keepalive","isHandled","kReq","keys","thisReq","kReqAlt","exports"],"sources":["aqm-reqs.ts"],"sourcesContent":["import {Msg} from './GlobalTypes';\nimport * as Err from './Err';\nimport {HTTP_METHODS, WebexRequestPayload} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport {CbRes, Conf, ConfEmpty, Pending, Req, Res, ResEmpty} from './types';\nimport {TIMEOUT_REQ, METHODS} from './constants';\nimport {AQM_REQS_FILE} from '../../constants';\nimport WebexRequest from './WebexRequest';\nimport {WebSocketManager} from './websocket/WebSocketManager';\n\nexport default class AqmReqs {\n private pendingRequests: Record<string, Pending> = {};\n private pendingNotifCancelrequest: Record<string, Pending> = {};\n private webexRequest: WebexRequest;\n private webSocketManager: WebSocketManager;\n\n constructor(webSocketManager: WebSocketManager) {\n this.webexRequest = WebexRequest.getInstance();\n this.webSocketManager = webSocketManager;\n this.webSocketManager.on('message', this.onMessage.bind(this));\n }\n\n req<TRes, TErr, TReq>(c: Conf<TRes, TErr, TReq>): Res<TRes, TReq> {\n return (p: TReq, cbRes?: CbRes<TRes>) => this.makeAPIRequest(c(p), cbRes);\n }\n\n reqEmpty<TRes, TErr>(c: ConfEmpty<TRes, TErr>): ResEmpty<TRes> {\n return (cbRes?: CbRes<TRes>) => this.makeAPIRequest(c(), cbRes);\n }\n\n private async makeAPIRequest<TRes, TErr>(c: Req<TRes, TErr>, cbRes?: CbRes<TRes>): Promise<TRes> {\n return this.createPromise(c, cbRes);\n }\n\n private createPromise<TRes, TErr>(c: Req<TRes, TErr>, cbRes?: CbRes<TRes>) {\n return new Promise<TRes>((resolve, reject) => {\n const keySuccess = this.bindPrint(c.notifSuccess.bind);\n const keyFail = c.notifFail ? this.bindPrint(c.notifFail.bind) : null;\n const keyCancel = c.notifCancel?.bind ? this.bindPrint(c.notifCancel.bind) : null;\n let k = '';\n if (this.pendingRequests[keySuccess]) {\n k = keySuccess;\n }\n if (keyFail && this.pendingRequests[keyFail]) {\n k += keyFail;\n }\n if (k && c.timeout !== 'disabled') {\n reject(\n new Err.Details('Service.aqm.reqs.Pending', {\n key: k,\n msg: 'The request has been already created, multiple requests are not allowed.',\n })\n );\n\n return;\n }\n\n let isClear = false;\n const clear = () => {\n delete this.pendingRequests[keySuccess];\n if (keyFail) {\n delete this.pendingRequests[keyFail];\n }\n if (keyCancel) {\n delete this.pendingNotifCancelrequest[keyCancel];\n }\n isClear = true;\n };\n\n this.pendingRequests[keySuccess] = {\n check: (msg: Msg) => this.bindCheck(c.notifSuccess.bind, msg),\n handle: (msg: Msg) => {\n clear();\n resolve(msg as any);\n },\n };\n if (keyCancel) {\n this.pendingRequests[keySuccess].alternateBind = keyCancel;\n this.pendingNotifCancelrequest[keyCancel] = {\n check: (msg: Msg) => this.bindCheck(c.notifCancel?.bind, msg),\n handle: (msg: Msg) => {\n const alternateBindKey = this.pendingNotifCancelrequest[keyCancel].alternateBind;\n if (alternateBindKey) {\n this.pendingRequests[alternateBindKey].handle(msg);\n }\n },\n alternateBind: keySuccess,\n };\n }\n\n if (keyFail) {\n this.pendingRequests[keyFail] = {\n check: (msg: Msg) => this.bindCheck(c.notifFail!.bind, msg),\n handle: (msg: Msg) => {\n clear();\n const notifFail = c.notifFail!;\n if ('errId' in notifFail) {\n LoggerProxy.log(`Routing request failed: ${JSON.stringify(msg)}`, {\n module: AQM_REQS_FILE,\n method: METHODS.CREATE_PROMISE,\n });\n const eerr = new Err.Details(notifFail.errId, msg as any);\n LoggerProxy.log(`Routing request failed: ${eerr}`, {\n module: AQM_REQS_FILE,\n method: METHODS.CREATE_PROMISE,\n });\n reject(eerr);\n } else {\n reject(notifFail.err(msg as any));\n }\n },\n };\n }\n let response: WebexRequestPayload | null = null;\n this.webexRequest\n .request({\n service: c.host ?? '',\n resource: c.url,\n // eslint-disable-next-line no-nested-ternary\n method: c.method ? c.method : c.data ? HTTP_METHODS.POST : HTTP_METHODS.GET,\n\n body: c.data,\n })\n .then((res: any) => {\n response = res;\n if (cbRes) {\n cbRes(res);\n }\n })\n .catch((error: WebexRequestPayload) => {\n clear();\n if (error?.headers) {\n error.headers.Authorization = '*';\n }\n if (error?.headers) {\n error.headers.Authorization = '*';\n }\n if (typeof c.err === 'function') {\n reject(c.err(error));\n } else if (typeof c.err === 'string') {\n reject(new Err.Message(c.err));\n } else {\n reject(new Err.Message('Service.aqm.reqs.GenericRequestError'));\n }\n });\n\n if (c.timeout !== 'disabled') {\n window.setTimeout(\n () => {\n if (isClear) {\n return;\n }\n clear();\n if (response?.headers) {\n response.headers.Authorization = '*';\n }\n LoggerProxy.error(`Routing request timeout${keySuccess}${response!}${c.url}`, {\n module: AQM_REQS_FILE,\n method: METHODS.CREATE_PROMISE,\n });\n reject(\n new Err.Details('Service.aqm.reqs.Timeout', {\n key: keySuccess,\n response: response!,\n })\n );\n },\n c.timeout && c.timeout > 0 ? c.timeout : TIMEOUT_REQ\n );\n }\n });\n }\n\n private bindPrint(bind: any) {\n let result = '';\n // eslint-disable-next-line no-restricted-syntax\n for (const k in bind) {\n if (Array.isArray(bind[k])) {\n result += `${k}=[${bind[k].join(',')}],`;\n } else if (typeof bind[k] === 'object' && bind[k] !== null) {\n result += `${k}=(${this.bindPrint(bind[k])}),`;\n } else {\n result += `${k}=${bind[k]},`;\n }\n }\n\n return result ? result.slice(0, -1) : result;\n }\n\n private bindCheck(bind: any, msg: any) {\n // eslint-disable-next-line no-restricted-syntax\n for (const k in bind) {\n if (Array.isArray(bind[k])) {\n // Check if the message value matches any of the values in the array\n if (!bind[k].includes(msg[k])) {\n return false;\n }\n } else if (typeof bind[k] === 'object' && bind[k] !== null) {\n if (typeof msg[k] === 'object' && msg[k] !== null) {\n if (!this.bindCheck(bind[k], msg[k])) {\n return false;\n }\n } else {\n return false;\n }\n } else if (!msg[k] || msg[k] !== bind[k]) {\n return false;\n }\n }\n\n return true;\n }\n\n // must be lambda\n private readonly onMessage = (msg: any) => {\n const event = JSON.parse(msg);\n if (event.type === 'Welcome') {\n LoggerProxy.info(`Welcome message from Notifs Websocket`, {\n module: AQM_REQS_FILE,\n method: METHODS.ON_MESSAGE,\n });\n\n return;\n }\n\n if (event.keepalive === 'true') {\n LoggerProxy.info(`Keepalive from web socket`, {\n module: AQM_REQS_FILE,\n method: METHODS.ON_MESSAGE,\n });\n\n return;\n }\n\n if (event.type === 'AgentReloginFailed') {\n LoggerProxy.info('Silently handling the agent relogin fail', {\n module: AQM_REQS_FILE,\n method: METHODS.ON_MESSAGE,\n });\n }\n\n let isHandled = false;\n\n const kReq = Object.keys(this.pendingRequests);\n for (const thisReq of kReq) {\n const req = this.pendingRequests[thisReq];\n if (req.check(event)) {\n req.handle(event);\n isHandled = true;\n break;\n }\n }\n // pendingNotifCancelrequest stores the secondary bind key, checks for the secondary bind key and handles the event\n const kReqAlt = Object.keys(this.pendingNotifCancelrequest);\n for (const thisReq of kReqAlt) {\n const req = this.pendingNotifCancelrequest[thisReq];\n if (req.check(event)) {\n req.handle(event);\n isHandled = true;\n }\n }\n\n // TODO: add event emitter for unhandled events to replicate event.listen or .on\n\n if (!isHandled) {\n LoggerProxy.info(`event=missingEventHandler | [AqmReqs] missing routing message handler`, {\n module: AQM_REQS_FILE,\n method: METHODS.ON_MESSAGE,\n });\n }\n };\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["Err","_interopRequireWildcard","require","_types","_loggerProxy","_interopRequireDefault","_constants","_constants2","_WebexRequest","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","AqmReqs","pendingRequests","pendingNotifCancelrequest","constructor","webSocketManager","webexRequest","WebexRequest","getInstance","on","onMessage","bind","req","c","p","cbRes","makeAPIRequest","reqEmpty","createPromise","Promise","resolve","reject","keySuccess","bindPrint","notifSuccess","keyFail","notifFail","keyCancel","notifCancel","k","timeout","Details","key","msg","isClear","clear","check","bindCheck","handle","alternateBind","alternateBindKey","LoggerProxy","log","JSON","stringify","module","AQM_REQS_FILE","method","METHODS","CREATE_PROMISE","eerr","errId","err","response","request","service","host","resource","url","data","HTTP_METHODS","POST","GET","body","then","res","catch","error","headers","Authorization","Message","window","setTimeout","TIMEOUT_REQ","result","Array","isArray","join","slice","includes","event","parse","type","info","ON_MESSAGE","keepalive","isHandled","kReq","keys","thisReq","kReqAlt","exports"],"sources":["aqm-reqs.ts"],"sourcesContent":["import {Msg} from './GlobalTypes';\nimport * as Err from './Err';\nimport {HTTP_METHODS, WebexRequestPayload} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport {CbRes, Conf, ConfEmpty, Pending, Req, Res, ResEmpty} from './types';\nimport {TIMEOUT_REQ, METHODS} from './constants';\nimport {AQM_REQS_FILE} from '../../constants';\nimport WebexRequest from './WebexRequest';\nimport {WebSocketManager} from './websocket/WebSocketManager';\n\nexport default class AqmReqs {\n private pendingRequests: Record<string, Pending> = {};\n private pendingNotifCancelrequest: Record<string, Pending> = {};\n private webexRequest: WebexRequest;\n private webSocketManager: WebSocketManager;\n\n constructor(webSocketManager: WebSocketManager) {\n this.webexRequest = WebexRequest.getInstance();\n this.webSocketManager = webSocketManager;\n this.webSocketManager.on('message', this.onMessage.bind(this));\n }\n\n req<TRes, TErr, TReq>(c: Conf<TRes, TErr, TReq>): Res<TRes, TReq> {\n return (p: TReq, cbRes?: CbRes<TRes>) => this.makeAPIRequest(c(p), cbRes);\n }\n\n reqEmpty<TRes, TErr>(c: ConfEmpty<TRes, TErr>): ResEmpty<TRes> {\n return (cbRes?: CbRes<TRes>) => this.makeAPIRequest(c(), cbRes);\n }\n\n private async makeAPIRequest<TRes, TErr>(c: Req<TRes, TErr>, cbRes?: CbRes<TRes>): Promise<TRes> {\n return this.createPromise(c, cbRes);\n }\n\n private createPromise<TRes, TErr>(c: Req<TRes, TErr>, cbRes?: CbRes<TRes>) {\n return new Promise<TRes>((resolve, reject) => {\n const keySuccess = this.bindPrint(c.notifSuccess.bind);\n const keyFail = c.notifFail ? this.bindPrint(c.notifFail.bind) : null;\n const keyCancel = c.notifCancel?.bind ? this.bindPrint(c.notifCancel.bind) : null;\n let k = '';\n if (this.pendingRequests[keySuccess]) {\n k = keySuccess;\n }\n if (keyFail && this.pendingRequests[keyFail]) {\n k += keyFail;\n }\n if (k && c.timeout !== 'disabled') {\n reject(\n new Err.Details('Service.aqm.reqs.Pending', {\n key: k,\n msg: 'The request has been already created, multiple requests are not allowed.',\n })\n );\n\n return;\n }\n\n let isClear = false;\n const clear = () => {\n delete this.pendingRequests[keySuccess];\n if (keyFail) {\n delete this.pendingRequests[keyFail];\n }\n if (keyCancel) {\n delete this.pendingNotifCancelrequest[keyCancel];\n }\n isClear = true;\n };\n\n this.pendingRequests[keySuccess] = {\n check: (msg: Msg) => this.bindCheck(c.notifSuccess.bind, msg),\n handle: (msg: Msg) => {\n clear();\n resolve(msg as any);\n },\n };\n if (keyCancel) {\n this.pendingRequests[keySuccess].alternateBind = keyCancel;\n this.pendingNotifCancelrequest[keyCancel] = {\n check: (msg: Msg) => this.bindCheck(c.notifCancel?.bind, msg),\n handle: (msg: Msg) => {\n const alternateBindKey = this.pendingNotifCancelrequest[keyCancel].alternateBind;\n if (alternateBindKey) {\n this.pendingRequests[alternateBindKey].handle(msg);\n }\n },\n alternateBind: keySuccess,\n };\n }\n\n if (keyFail) {\n this.pendingRequests[keyFail] = {\n check: (msg: Msg) => this.bindCheck(c.notifFail!.bind, msg),\n handle: (msg: Msg) => {\n clear();\n const notifFail = c.notifFail!;\n if ('errId' in notifFail) {\n LoggerProxy.log(`Routing request failed: ${JSON.stringify(msg)}`, {\n module: AQM_REQS_FILE,\n method: METHODS.CREATE_PROMISE,\n });\n const eerr = new Err.Details(notifFail.errId, msg as any);\n LoggerProxy.log(`Routing request failed: ${eerr}`, {\n module: AQM_REQS_FILE,\n method: METHODS.CREATE_PROMISE,\n });\n reject(eerr);\n } else {\n reject(notifFail.err(msg as any));\n }\n },\n };\n }\n let response: WebexRequestPayload | null = null;\n this.webexRequest\n .request({\n service: c.host ?? '',\n resource: c.url,\n // eslint-disable-next-line no-nested-ternary\n method: c.method ? c.method : c.data ? HTTP_METHODS.POST : HTTP_METHODS.GET,\n\n body: c.data,\n })\n .then((res: any) => {\n response = res;\n if (cbRes) {\n cbRes(res);\n }\n })\n .catch((error: WebexRequestPayload) => {\n clear();\n if (error?.headers) {\n error.headers.Authorization = '*';\n }\n if (error?.headers) {\n error.headers.Authorization = '*';\n }\n if (typeof c.err === 'function') {\n reject(c.err(error));\n } else if (typeof c.err === 'string') {\n reject(new Err.Message(c.err));\n } else {\n reject(new Err.Message('Service.aqm.reqs.GenericRequestError'));\n }\n });\n\n if (c.timeout !== 'disabled') {\n window.setTimeout(\n () => {\n if (isClear) {\n return;\n }\n clear();\n if (response?.headers) {\n response.headers.Authorization = '*';\n }\n LoggerProxy.error(`Routing request timeout${keySuccess}${response!}${c.url}`, {\n module: AQM_REQS_FILE,\n method: METHODS.CREATE_PROMISE,\n });\n reject(\n new Err.Details('Service.aqm.reqs.Timeout', {\n key: keySuccess,\n response: response!,\n })\n );\n },\n c.timeout && c.timeout > 0 ? c.timeout : TIMEOUT_REQ\n );\n }\n });\n }\n\n private bindPrint(bind: any) {\n let result = '';\n // eslint-disable-next-line no-restricted-syntax\n for (const k in bind) {\n if (Array.isArray(bind[k])) {\n result += `${k}=[${bind[k].join(',')}],`;\n } else if (typeof bind[k] === 'object' && bind[k] !== null) {\n result += `${k}=(${this.bindPrint(bind[k])}),`;\n } else {\n result += `${k}=${bind[k]},`;\n }\n }\n\n return result ? result.slice(0, -1) : result;\n }\n\n private bindCheck(bind: any, msg: any) {\n // eslint-disable-next-line no-restricted-syntax\n for (const k in bind) {\n if (Array.isArray(bind[k])) {\n // Check if the message value matches any of the values in the array\n if (!bind[k].includes(msg[k])) {\n return false;\n }\n } else if (typeof bind[k] === 'object' && bind[k] !== null) {\n if (typeof msg[k] === 'object' && msg[k] !== null) {\n if (!this.bindCheck(bind[k], msg[k])) {\n return false;\n }\n } else {\n return false;\n }\n } else if (!msg[k] || msg[k] !== bind[k]) {\n return false;\n }\n }\n\n return true;\n }\n\n // must be lambda\n private readonly onMessage = (msg: any) => {\n const event = JSON.parse(msg);\n if (event.type === 'Welcome') {\n LoggerProxy.info(`Welcome message from Notifs Websocket`, {\n module: AQM_REQS_FILE,\n method: METHODS.ON_MESSAGE,\n });\n\n return;\n }\n\n if (event.keepalive === 'true') {\n return;\n }\n\n if (event.type === 'AgentReloginFailed') {\n LoggerProxy.info('Silently handling the agent relogin fail', {\n module: AQM_REQS_FILE,\n method: METHODS.ON_MESSAGE,\n });\n }\n\n let isHandled = false;\n\n const kReq = Object.keys(this.pendingRequests);\n for (const thisReq of kReq) {\n const req = this.pendingRequests[thisReq];\n if (req.check(event)) {\n req.handle(event);\n isHandled = true;\n break;\n }\n }\n // pendingNotifCancelrequest stores the secondary bind key, checks for the secondary bind key and handles the event\n const kReqAlt = Object.keys(this.pendingNotifCancelrequest);\n for (const thisReq of kReqAlt) {\n const req = this.pendingNotifCancelrequest[thisReq];\n if (req.check(event)) {\n req.handle(event);\n isHandled = true;\n }\n }\n\n // TODO: add event emitter for unhandled events to replicate event.listen or .on\n\n if (!isHandled) {\n LoggerProxy.info(`event=missingEventHandler | [AqmReqs] missing routing message handler`, {\n module: AQM_REQS_FILE,\n method: METHODS.ON_MESSAGE,\n });\n }\n };\n}\n"],"mappings":"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"}
@@ -169,10 +169,6 @@ class WebSocketManager extends _events.default {
169
169
  issueReason = 'WebSocket auto close timed out. Forcefully closed websocket.';
170
170
  } else {
171
171
  const onlineStatus = navigator.onLine;
172
- _loggerProxy.default.info(`[WebSocketStatus] | desktop online status is ${onlineStatus}`, {
173
- module: _constants3.WEB_SOCKET_MANAGER_FILE,
174
- method: _constants2.METHODS.WEB_SOCKET_ON_CLOSE_HANDLER
175
- });
176
172
  issueReason = !onlineStatus ? 'network issue' : 'missing keepalive from either desktop or notif service';
177
173
  }
178
174
  _loggerProxy.default.error(`[WebSocketStatus] | event=webSocketClose | WebSocket connection closed REASON: ${issueReason}`, {
@@ -1 +1 @@
1
- {"version":3,"names":["_events","_interopRequireDefault","require","_types","_constants","_types2","_loggerProxy","_keepalive","_constants2","_constants3","obj","__esModule","default","WebSocketManager","EventEmitter","url","welcomePromiseResolve","constructor","options","webex","shouldReconnect","websocket","isSocketClosed","isWelcomeReceived","forceCloseWebSocketOnTimeout","isConnectionLost","workerScriptBlob","Blob","workerScript","type","keepaliveWorker","Worker","URL","createObjectURL","initWebSocket","connectionConfig","body","register","Promise","resolve","reject","connect","catch","error","LoggerProxy","module","WEB_SOCKET_MANAGER_FILE","method","METHODS","INIT_WEB_SOCKET","close","reason","postMessage","log","CLOSE","handleConnectionLost","event","subscribeResponse","request","service","WCC_API_GATEWAY","resource","SUBSCRIBE_API","HTTP_METHODS","POST","webSocketUrl","e","REGISTER","undefined","CONNECT","WebSocket","onopen","send","JSON","stringify","keepalive","onmessage","keepAliveEvent","data","intervalDuration","KEEPALIVE_WORKER_INTERVAL","closeSocketTimeout","CLOSE_SOCKET_TIMEOUT","onerror","onclose","webSocketOnCloseHandler","emit","eventData","parse","CC_EVENTS","WELCOME","issueReason","onlineStatus","navigator","onLine","info","WEB_SOCKET_ON_CLOSE_HANDLER","exports"],"sources":["WebSocketManager.ts"],"sourcesContent":["import EventEmitter from 'events';\nimport {WebexSDK, SubscribeRequest, HTTP_METHODS} from '../../../types';\nimport {SUBSCRIBE_API, WCC_API_GATEWAY} from '../../constants';\nimport {ConnectionLostDetails} from './types';\nimport {CC_EVENTS, SubscribeResponse, WelcomeResponse} from '../../config/types';\nimport LoggerProxy from '../../../logger-proxy';\nimport workerScript from './keepalive.worker';\nimport {KEEPALIVE_WORKER_INTERVAL, CLOSE_SOCKET_TIMEOUT, METHODS} from '../constants';\nimport {WEB_SOCKET_MANAGER_FILE} from '../../../constants';\n\n/**\n * WebSocketManager handles the WebSocket connection for Contact Center operations.\n * It manages the connection lifecycle, including registration, reconnection, and message handling.\n * It also utilizes a Web Worker to manage keepalive messages and socket closure.\n * @ignore\n */\nexport class WebSocketManager extends EventEmitter {\n private websocket: WebSocket;\n shouldReconnect: boolean;\n isSocketClosed: boolean;\n private isWelcomeReceived: boolean;\n private url: string | null = null;\n private forceCloseWebSocketOnTimeout: boolean;\n private isConnectionLost: boolean;\n private webex: WebexSDK;\n private welcomePromiseResolve:\n | ((value: WelcomeResponse | PromiseLike<WelcomeResponse>) => void)\n | null = null;\n\n private keepaliveWorker: Worker;\n\n constructor(options: {webex: WebexSDK}) {\n super();\n const {webex} = options;\n this.webex = webex;\n this.shouldReconnect = true;\n this.websocket = {} as WebSocket;\n this.isSocketClosed = false;\n this.isWelcomeReceived = false;\n this.forceCloseWebSocketOnTimeout = false;\n this.isConnectionLost = false;\n\n const workerScriptBlob = new Blob([workerScript], {type: 'application/javascript'});\n this.keepaliveWorker = new Worker(URL.createObjectURL(workerScriptBlob));\n }\n\n async initWebSocket(options: {body: SubscribeRequest}): Promise<WelcomeResponse> {\n const connectionConfig = options.body;\n await this.register(connectionConfig);\n\n return new Promise((resolve, reject) => {\n this.welcomePromiseResolve = resolve;\n this.connect().catch((error) => {\n LoggerProxy.error(`[WebSocketStatus] | Error in connecting Websocket ${error}`, {\n module: WEB_SOCKET_MANAGER_FILE,\n method: METHODS.INIT_WEB_SOCKET,\n });\n reject(error);\n });\n });\n }\n\n close(shouldReconnect: boolean, reason = 'Unknown') {\n if (!this.isSocketClosed && this.shouldReconnect) {\n this.shouldReconnect = shouldReconnect;\n this.websocket.close();\n this.keepaliveWorker.postMessage({type: 'terminate'});\n LoggerProxy.log(\n `[WebSocketStatus] | event=webSocketClose | WebSocket connection closed manually REASON: ${reason}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CLOSE}\n );\n }\n }\n\n handleConnectionLost(event: ConnectionLostDetails) {\n this.isConnectionLost = event.isConnectionLost;\n }\n\n private async register(connectionConfig: SubscribeRequest) {\n try {\n const subscribeResponse: SubscribeResponse = await this.webex.request({\n service: WCC_API_GATEWAY,\n resource: SUBSCRIBE_API,\n method: HTTP_METHODS.POST,\n body: connectionConfig,\n });\n this.url = subscribeResponse.body.webSocketUrl;\n } catch (e) {\n LoggerProxy.error(\n `Register API Failed, Request to RoutingNotifs websocket registration API failed ${e}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.REGISTER}\n );\n }\n }\n\n private async connect() {\n if (!this.url) {\n return undefined;\n }\n LoggerProxy.log(\n `[WebSocketStatus] | event=webSocketConnecting | Connecting to WebSocket: ${this.url}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n this.websocket = new WebSocket(this.url);\n\n return new Promise((resolve, reject) => {\n this.websocket.onopen = () => {\n this.isSocketClosed = false;\n this.shouldReconnect = true;\n\n this.websocket.send(JSON.stringify({keepalive: 'true'}));\n this.keepaliveWorker.onmessage = (keepAliveEvent: {data: any}) => {\n if (keepAliveEvent?.data?.type === 'keepalive') {\n this.websocket.send(JSON.stringify({keepalive: 'true'}));\n }\n\n if (keepAliveEvent?.data?.type === 'closeSocket' && this.isConnectionLost) {\n this.forceCloseWebSocketOnTimeout = true;\n this.close(true, 'WebSocket did not auto close within 16 secs');\n LoggerProxy.error(\n '[webSocketTimeout] | event=webSocketTimeout | WebSocket connection closed forcefully',\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n }\n };\n\n this.keepaliveWorker.postMessage({\n type: 'start',\n intervalDuration: KEEPALIVE_WORKER_INTERVAL, // Keepalive interval\n isSocketClosed: this.isSocketClosed,\n closeSocketTimeout: CLOSE_SOCKET_TIMEOUT, // Close socket timeout\n });\n };\n\n this.websocket.onerror = (event: any) => {\n LoggerProxy.error(\n `[WebSocketStatus] | event=socketConnectionFailed | WebSocket connection failed ${event}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n reject();\n };\n\n this.websocket.onclose = async (event: any) => {\n this.webSocketOnCloseHandler(event);\n };\n\n this.websocket.onmessage = (e: MessageEvent) => {\n this.emit('message', e.data);\n const eventData = JSON.parse(e.data);\n\n if (eventData.type === CC_EVENTS.WELCOME) {\n this.isWelcomeReceived = true;\n if (this.welcomePromiseResolve) {\n this.welcomePromiseResolve(eventData.data as WelcomeResponse);\n this.welcomePromiseResolve = null;\n }\n }\n\n if (eventData.type === 'AGENT_MULTI_LOGIN') {\n this.close(false, 'multiLogin');\n LoggerProxy.error(\n '[WebSocketStatus] | event=agentMultiLogin | WebSocket connection closed by agent multiLogin',\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n }\n };\n });\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n private async webSocketOnCloseHandler(event: any) {\n this.isSocketClosed = true;\n this.keepaliveWorker.postMessage({type: 'terminate'});\n if (this.shouldReconnect) {\n this.emit('socketClose');\n let issueReason;\n if (this.forceCloseWebSocketOnTimeout) {\n issueReason = 'WebSocket auto close timed out. Forcefully closed websocket.';\n } else {\n const onlineStatus = navigator.onLine;\n LoggerProxy.info(`[WebSocketStatus] | desktop online status is ${onlineStatus}`, {\n module: WEB_SOCKET_MANAGER_FILE,\n method: METHODS.WEB_SOCKET_ON_CLOSE_HANDLER,\n });\n issueReason = !onlineStatus\n ? 'network issue'\n : 'missing keepalive from either desktop or notif service';\n }\n LoggerProxy.error(\n `[WebSocketStatus] | event=webSocketClose | WebSocket connection closed REASON: ${issueReason}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.WEB_SOCKET_ON_CLOSE_HANDLER}\n );\n this.forceCloseWebSocketOnTimeout = false;\n }\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["_events","_interopRequireDefault","require","_types","_constants","_types2","_loggerProxy","_keepalive","_constants2","_constants3","obj","__esModule","default","WebSocketManager","EventEmitter","url","welcomePromiseResolve","constructor","options","webex","shouldReconnect","websocket","isSocketClosed","isWelcomeReceived","forceCloseWebSocketOnTimeout","isConnectionLost","workerScriptBlob","Blob","workerScript","type","keepaliveWorker","Worker","URL","createObjectURL","initWebSocket","connectionConfig","body","register","Promise","resolve","reject","connect","catch","error","LoggerProxy","module","WEB_SOCKET_MANAGER_FILE","method","METHODS","INIT_WEB_SOCKET","close","reason","postMessage","log","CLOSE","handleConnectionLost","event","subscribeResponse","request","service","WCC_API_GATEWAY","resource","SUBSCRIBE_API","HTTP_METHODS","POST","webSocketUrl","e","REGISTER","undefined","CONNECT","WebSocket","onopen","send","JSON","stringify","keepalive","onmessage","keepAliveEvent","data","intervalDuration","KEEPALIVE_WORKER_INTERVAL","closeSocketTimeout","CLOSE_SOCKET_TIMEOUT","onerror","onclose","webSocketOnCloseHandler","emit","eventData","parse","CC_EVENTS","WELCOME","issueReason","onlineStatus","navigator","onLine","WEB_SOCKET_ON_CLOSE_HANDLER","exports"],"sources":["WebSocketManager.ts"],"sourcesContent":["import EventEmitter from 'events';\nimport {WebexSDK, SubscribeRequest, HTTP_METHODS} from '../../../types';\nimport {SUBSCRIBE_API, WCC_API_GATEWAY} from '../../constants';\nimport {ConnectionLostDetails} from './types';\nimport {CC_EVENTS, SubscribeResponse, WelcomeResponse} from '../../config/types';\nimport LoggerProxy from '../../../logger-proxy';\nimport workerScript from './keepalive.worker';\nimport {KEEPALIVE_WORKER_INTERVAL, CLOSE_SOCKET_TIMEOUT, METHODS} from '../constants';\nimport {WEB_SOCKET_MANAGER_FILE} from '../../../constants';\n\n/**\n * WebSocketManager handles the WebSocket connection for Contact Center operations.\n * It manages the connection lifecycle, including registration, reconnection, and message handling.\n * It also utilizes a Web Worker to manage keepalive messages and socket closure.\n * @ignore\n */\nexport class WebSocketManager extends EventEmitter {\n private websocket: WebSocket;\n shouldReconnect: boolean;\n isSocketClosed: boolean;\n private isWelcomeReceived: boolean;\n private url: string | null = null;\n private forceCloseWebSocketOnTimeout: boolean;\n private isConnectionLost: boolean;\n private webex: WebexSDK;\n private welcomePromiseResolve:\n | ((value: WelcomeResponse | PromiseLike<WelcomeResponse>) => void)\n | null = null;\n\n private keepaliveWorker: Worker;\n\n constructor(options: {webex: WebexSDK}) {\n super();\n const {webex} = options;\n this.webex = webex;\n this.shouldReconnect = true;\n this.websocket = {} as WebSocket;\n this.isSocketClosed = false;\n this.isWelcomeReceived = false;\n this.forceCloseWebSocketOnTimeout = false;\n this.isConnectionLost = false;\n\n const workerScriptBlob = new Blob([workerScript], {type: 'application/javascript'});\n this.keepaliveWorker = new Worker(URL.createObjectURL(workerScriptBlob));\n }\n\n async initWebSocket(options: {body: SubscribeRequest}): Promise<WelcomeResponse> {\n const connectionConfig = options.body;\n await this.register(connectionConfig);\n\n return new Promise((resolve, reject) => {\n this.welcomePromiseResolve = resolve;\n this.connect().catch((error) => {\n LoggerProxy.error(`[WebSocketStatus] | Error in connecting Websocket ${error}`, {\n module: WEB_SOCKET_MANAGER_FILE,\n method: METHODS.INIT_WEB_SOCKET,\n });\n reject(error);\n });\n });\n }\n\n close(shouldReconnect: boolean, reason = 'Unknown') {\n if (!this.isSocketClosed && this.shouldReconnect) {\n this.shouldReconnect = shouldReconnect;\n this.websocket.close();\n this.keepaliveWorker.postMessage({type: 'terminate'});\n LoggerProxy.log(\n `[WebSocketStatus] | event=webSocketClose | WebSocket connection closed manually REASON: ${reason}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CLOSE}\n );\n }\n }\n\n handleConnectionLost(event: ConnectionLostDetails) {\n this.isConnectionLost = event.isConnectionLost;\n }\n\n private async register(connectionConfig: SubscribeRequest) {\n try {\n const subscribeResponse: SubscribeResponse = await this.webex.request({\n service: WCC_API_GATEWAY,\n resource: SUBSCRIBE_API,\n method: HTTP_METHODS.POST,\n body: connectionConfig,\n });\n this.url = subscribeResponse.body.webSocketUrl;\n } catch (e) {\n LoggerProxy.error(\n `Register API Failed, Request to RoutingNotifs websocket registration API failed ${e}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.REGISTER}\n );\n }\n }\n\n private async connect() {\n if (!this.url) {\n return undefined;\n }\n LoggerProxy.log(\n `[WebSocketStatus] | event=webSocketConnecting | Connecting to WebSocket: ${this.url}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n this.websocket = new WebSocket(this.url);\n\n return new Promise((resolve, reject) => {\n this.websocket.onopen = () => {\n this.isSocketClosed = false;\n this.shouldReconnect = true;\n\n this.websocket.send(JSON.stringify({keepalive: 'true'}));\n this.keepaliveWorker.onmessage = (keepAliveEvent: {data: any}) => {\n if (keepAliveEvent?.data?.type === 'keepalive') {\n this.websocket.send(JSON.stringify({keepalive: 'true'}));\n }\n\n if (keepAliveEvent?.data?.type === 'closeSocket' && this.isConnectionLost) {\n this.forceCloseWebSocketOnTimeout = true;\n this.close(true, 'WebSocket did not auto close within 16 secs');\n LoggerProxy.error(\n '[webSocketTimeout] | event=webSocketTimeout | WebSocket connection closed forcefully',\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n }\n };\n\n this.keepaliveWorker.postMessage({\n type: 'start',\n intervalDuration: KEEPALIVE_WORKER_INTERVAL, // Keepalive interval\n isSocketClosed: this.isSocketClosed,\n closeSocketTimeout: CLOSE_SOCKET_TIMEOUT, // Close socket timeout\n });\n };\n\n this.websocket.onerror = (event: any) => {\n LoggerProxy.error(\n `[WebSocketStatus] | event=socketConnectionFailed | WebSocket connection failed ${event}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n reject();\n };\n\n this.websocket.onclose = async (event: any) => {\n this.webSocketOnCloseHandler(event);\n };\n\n this.websocket.onmessage = (e: MessageEvent) => {\n this.emit('message', e.data);\n const eventData = JSON.parse(e.data);\n\n if (eventData.type === CC_EVENTS.WELCOME) {\n this.isWelcomeReceived = true;\n if (this.welcomePromiseResolve) {\n this.welcomePromiseResolve(eventData.data as WelcomeResponse);\n this.welcomePromiseResolve = null;\n }\n }\n\n if (eventData.type === 'AGENT_MULTI_LOGIN') {\n this.close(false, 'multiLogin');\n LoggerProxy.error(\n '[WebSocketStatus] | event=agentMultiLogin | WebSocket connection closed by agent multiLogin',\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n }\n };\n });\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n private async webSocketOnCloseHandler(event: any) {\n this.isSocketClosed = true;\n this.keepaliveWorker.postMessage({type: 'terminate'});\n if (this.shouldReconnect) {\n this.emit('socketClose');\n let issueReason;\n if (this.forceCloseWebSocketOnTimeout) {\n issueReason = 'WebSocket auto close timed out. Forcefully closed websocket.';\n } else {\n const onlineStatus = navigator.onLine;\n issueReason = !onlineStatus\n ? 'network issue'\n : 'missing keepalive from either desktop or notif service';\n }\n LoggerProxy.error(\n `[WebSocketStatus] | event=webSocketClose | WebSocket connection closed REASON: ${issueReason}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.WEB_SOCKET_ON_CLOSE_HANDLER}\n );\n this.forceCloseWebSocketOnTimeout = false;\n }\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AAEA,IAAAG,OAAA,GAAAH,OAAA;AACA,IAAAI,YAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,UAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,WAAA,GAAAN,OAAA;AACA,IAAAO,WAAA,GAAAP,OAAA;AAA2D,SAAAD,uBAAAS,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAE3D;AACA;AACA;AACA;AACA;AACA;AACO,MAAMG,gBAAgB,SAASC,eAAY,CAAC;EAKzCC,GAAG,GAAkB,IAAI;EAIzBC,qBAAqB,GAElB,IAAI;EAIfC,WAAWA,CAACC,OAA0B,EAAE;IACtC,KAAK,CAAC,CAAC;IACP,MAAM;MAACC;IAAK,CAAC,GAAGD,OAAO;IACvB,IAAI,CAACC,KAAK,GAAGA,KAAK;IAClB,IAAI,CAACC,eAAe,GAAG,IAAI;IAC3B,IAAI,CAACC,SAAS,GAAG,CAAC,CAAc;IAChC,IAAI,CAACC,cAAc,GAAG,KAAK;IAC3B,IAAI,CAACC,iBAAiB,GAAG,KAAK;IAC9B,IAAI,CAACC,4BAA4B,GAAG,KAAK;IACzC,IAAI,CAACC,gBAAgB,GAAG,KAAK;IAE7B,MAAMC,gBAAgB,GAAG,IAAIC,IAAI,CAAC,CAACC,kBAAY,CAAC,EAAE;MAACC,IAAI,EAAE;IAAwB,CAAC,CAAC;IACnF,IAAI,CAACC,eAAe,GAAG,IAAIC,MAAM,CAACC,GAAG,CAACC,eAAe,CAACP,gBAAgB,CAAC,CAAC;EAC1E;EAEA,MAAMQ,aAAaA,CAAChB,OAAiC,EAA4B;IAC/E,MAAMiB,gBAAgB,GAAGjB,OAAO,CAACkB,IAAI;IACrC,MAAM,IAAI,CAACC,QAAQ,CAACF,gBAAgB,CAAC;IAErC,OAAO,IAAIG,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;MACtC,IAAI,CAACxB,qBAAqB,GAAGuB,OAAO;MACpC,IAAI,CAACE,OAAO,CAAC,CAAC,CAACC,KAAK,CAAEC,KAAK,IAAK;QAC9BC,oBAAW,CAACD,KAAK,CAAE,qDAAoDA,KAAM,EAAC,EAAE;UAC9EE,MAAM,EAAEC,mCAAuB;UAC/BC,MAAM,EAAEC,mBAAO,CAACC;QAClB,CAAC,CAAC;QACFT,MAAM,CAACG,KAAK,CAAC;MACf,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ;EAEAO,KAAKA,CAAC9B,eAAwB,EAAE+B,MAAM,GAAG,SAAS,EAAE;IAClD,IAAI,CAAC,IAAI,CAAC7B,cAAc,IAAI,IAAI,CAACF,eAAe,EAAE;MAChD,IAAI,CAACA,eAAe,GAAGA,eAAe;MACtC,IAAI,CAACC,SAAS,CAAC6B,KAAK,CAAC,CAAC;MACtB,IAAI,CAACpB,eAAe,CAACsB,WAAW,CAAC;QAACvB,IAAI,EAAE;MAAW,CAAC,CAAC;MACrDe,oBAAW,CAACS,GAAG,CACZ,2FAA0FF,MAAO,EAAC,EACnG;QAACN,MAAM,EAAEC,mCAAuB;QAAEC,MAAM,EAAEC,mBAAO,CAACM;MAAK,CACzD,CAAC;IACH;EACF;EAEAC,oBAAoBA,CAACC,KAA4B,EAAE;IACjD,IAAI,CAAC/B,gBAAgB,GAAG+B,KAAK,CAAC/B,gBAAgB;EAChD;EAEA,MAAcY,QAAQA,CAACF,gBAAkC,EAAE;IACzD,IAAI;MACF,MAAMsB,iBAAoC,GAAG,MAAM,IAAI,CAACtC,KAAK,CAACuC,OAAO,CAAC;QACpEC,OAAO,EAAEC,0BAAe;QACxBC,QAAQ,EAAEC,wBAAa;QACvBf,MAAM,EAAEgB,mBAAY,CAACC,IAAI;QACzB5B,IAAI,EAAED;MACR,CAAC,CAAC;MACF,IAAI,CAACpB,GAAG,GAAG0C,iBAAiB,CAACrB,IAAI,CAAC6B,YAAY;IAChD,CAAC,CAAC,OAAOC,CAAC,EAAE;MACVtB,oBAAW,CAACD,KAAK,CACd,mFAAkFuB,CAAE,EAAC,EACtF;QAACrB,MAAM,EAAEC,mCAAuB;QAAEC,MAAM,EAAEC,mBAAO,CAACmB;MAAQ,CAC5D,CAAC;IACH;EACF;EAEA,MAAc1B,OAAOA,CAAA,EAAG;IACtB,IAAI,CAAC,IAAI,CAAC1B,GAAG,EAAE;MACb,OAAOqD,SAAS;IAClB;IACAxB,oBAAW,CAACS,GAAG,CACZ,4EAA2E,IAAI,CAACtC,GAAI,EAAC,EACtF;MAAC8B,MAAM,EAAEC,mCAAuB;MAAEC,MAAM,EAAEC,mBAAO,CAACqB;IAAO,CAC3D,CAAC;IACD,IAAI,CAAChD,SAAS,GAAG,IAAIiD,SAAS,CAAC,IAAI,CAACvD,GAAG,CAAC;IAExC,OAAO,IAAIuB,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;MACtC,IAAI,CAACnB,SAAS,CAACkD,MAAM,GAAG,MAAM;QAC5B,IAAI,CAACjD,cAAc,GAAG,KAAK;QAC3B,IAAI,CAACF,eAAe,GAAG,IAAI;QAE3B,IAAI,CAACC,SAAS,CAACmD,IAAI,CAACC,IAAI,CAACC,SAAS,CAAC;UAACC,SAAS,EAAE;QAAM,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC7C,eAAe,CAAC8C,SAAS,GAAIC,cAA2B,IAAK;UAChE,IAAIA,cAAc,EAAEC,IAAI,EAAEjD,IAAI,KAAK,WAAW,EAAE;YAC9C,IAAI,CAACR,SAAS,CAACmD,IAAI,CAACC,IAAI,CAACC,SAAS,CAAC;cAACC,SAAS,EAAE;YAAM,CAAC,CAAC,CAAC;UAC1D;UAEA,IAAIE,cAAc,EAAEC,IAAI,EAAEjD,IAAI,KAAK,aAAa,IAAI,IAAI,CAACJ,gBAAgB,EAAE;YACzE,IAAI,CAACD,4BAA4B,GAAG,IAAI;YACxC,IAAI,CAAC0B,KAAK,CAAC,IAAI,EAAE,6CAA6C,CAAC;YAC/DN,oBAAW,CAACD,KAAK,CACf,sFAAsF,EACtF;cAACE,MAAM,EAAEC,mCAAuB;cAAEC,MAAM,EAAEC,mBAAO,CAACqB;YAAO,CAC3D,CAAC;UACH;QACF,CAAC;QAED,IAAI,CAACvC,eAAe,CAACsB,WAAW,CAAC;UAC/BvB,IAAI,EAAE,OAAO;UACbkD,gBAAgB,EAAEC,qCAAyB;UAAE;UAC7C1D,cAAc,EAAE,IAAI,CAACA,cAAc;UACnC2D,kBAAkB,EAAEC,gCAAoB,CAAE;QAC5C,CAAC,CAAC;MACJ,CAAC;;MAED,IAAI,CAAC7D,SAAS,CAAC8D,OAAO,GAAI3B,KAAU,IAAK;QACvCZ,oBAAW,CAACD,KAAK,CACd,kFAAiFa,KAAM,EAAC,EACzF;UAACX,MAAM,EAAEC,mCAAuB;UAAEC,MAAM,EAAEC,mBAAO,CAACqB;QAAO,CAC3D,CAAC;QACD7B,MAAM,CAAC,CAAC;MACV,CAAC;MAED,IAAI,CAACnB,SAAS,CAAC+D,OAAO,GAAG,MAAO5B,KAAU,IAAK;QAC7C,IAAI,CAAC6B,uBAAuB,CAAC7B,KAAK,CAAC;MACrC,CAAC;MAED,IAAI,CAACnC,SAAS,CAACuD,SAAS,GAAIV,CAAe,IAAK;QAC9C,IAAI,CAACoB,IAAI,CAAC,SAAS,EAAEpB,CAAC,CAACY,IAAI,CAAC;QAC5B,MAAMS,SAAS,GAAGd,IAAI,CAACe,KAAK,CAACtB,CAAC,CAACY,IAAI,CAAC;QAEpC,IAAIS,SAAS,CAAC1D,IAAI,KAAK4D,iBAAS,CAACC,OAAO,EAAE;UACxC,IAAI,CAACnE,iBAAiB,GAAG,IAAI;UAC7B,IAAI,IAAI,CAACP,qBAAqB,EAAE;YAC9B,IAAI,CAACA,qBAAqB,CAACuE,SAAS,CAACT,IAAuB,CAAC;YAC7D,IAAI,CAAC9D,qBAAqB,GAAG,IAAI;UACnC;QACF;QAEA,IAAIuE,SAAS,CAAC1D,IAAI,KAAK,mBAAmB,EAAE;UAC1C,IAAI,CAACqB,KAAK,CAAC,KAAK,EAAE,YAAY,CAAC;UAC/BN,oBAAW,CAACD,KAAK,CACf,6FAA6F,EAC7F;YAACE,MAAM,EAAEC,mCAAuB;YAAEC,MAAM,EAAEC,mBAAO,CAACqB;UAAO,CAC3D,CAAC;QACH;MACF,CAAC;IACH,CAAC,CAAC;EACJ;;EAEA;EACA,MAAcgB,uBAAuBA,CAAC7B,KAAU,EAAE;IAChD,IAAI,CAAClC,cAAc,GAAG,IAAI;IAC1B,IAAI,CAACQ,eAAe,CAACsB,WAAW,CAAC;MAACvB,IAAI,EAAE;IAAW,CAAC,CAAC;IACrD,IAAI,IAAI,CAACT,eAAe,EAAE;MACxB,IAAI,CAACkE,IAAI,CAAC,aAAa,CAAC;MACxB,IAAIK,WAAW;MACf,IAAI,IAAI,CAACnE,4BAA4B,EAAE;QACrCmE,WAAW,GAAG,8DAA8D;MAC9E,CAAC,MAAM;QACL,MAAMC,YAAY,GAAGC,SAAS,CAACC,MAAM;QACrCH,WAAW,GAAG,CAACC,YAAY,GACvB,eAAe,GACf,wDAAwD;MAC9D;MACAhD,oBAAW,CAACD,KAAK,CACd,kFAAiFgD,WAAY,EAAC,EAC/F;QAAC9C,MAAM,EAAEC,mCAAuB;QAAEC,MAAM,EAAEC,mBAAO,CAAC+C;MAA2B,CAC/E,CAAC;MACD,IAAI,CAACvE,4BAA4B,GAAG,KAAK;IAC3C;EACF;AACF;AAACwE,OAAA,CAAAnF,gBAAA,GAAAA,gBAAA"}