@webex/contact-center 3.11.0 → 3.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/dist/cc.js +91 -27
  2. package/dist/cc.js.map +1 -1
  3. package/dist/constants.js +5 -1
  4. package/dist/constants.js.map +1 -1
  5. package/dist/index.js +7 -0
  6. package/dist/index.js.map +1 -1
  7. package/dist/metrics/behavioral-events.js +13 -0
  8. package/dist/metrics/behavioral-events.js.map +1 -1
  9. package/dist/metrics/constants.js +9 -1
  10. package/dist/metrics/constants.js.map +1 -1
  11. package/dist/services/ApiAiAssistant.js +173 -0
  12. package/dist/services/ApiAiAssistant.js.map +1 -0
  13. package/dist/services/agent/types.js.map +1 -1
  14. package/dist/services/config/Util.js +6 -2
  15. package/dist/services/config/Util.js.map +1 -1
  16. package/dist/services/config/constants.js +12 -0
  17. package/dist/services/config/constants.js.map +1 -1
  18. package/dist/services/config/index.js +41 -2
  19. package/dist/services/config/index.js.map +1 -1
  20. package/dist/services/config/types.js +19 -1
  21. package/dist/services/config/types.js.map +1 -1
  22. package/dist/services/constants.js +19 -1
  23. package/dist/services/constants.js.map +1 -1
  24. package/dist/services/core/Err.js.map +1 -1
  25. package/dist/services/core/Utils.js +28 -6
  26. package/dist/services/core/Utils.js.map +1 -1
  27. package/dist/services/core/aqm-reqs.js +92 -17
  28. package/dist/services/core/aqm-reqs.js.map +1 -1
  29. package/dist/services/core/websocket/WebSocketManager.js +13 -1
  30. package/dist/services/core/websocket/WebSocketManager.js.map +1 -1
  31. package/dist/services/task/TaskManager.js +96 -25
  32. package/dist/services/task/TaskManager.js.map +1 -1
  33. package/dist/services/task/TaskUtils.js +16 -3
  34. package/dist/services/task/TaskUtils.js.map +1 -1
  35. package/dist/services/task/constants.js +14 -1
  36. package/dist/services/task/constants.js.map +1 -1
  37. package/dist/services/task/dialer.js +51 -0
  38. package/dist/services/task/dialer.js.map +1 -1
  39. package/dist/services/task/types.js +15 -0
  40. package/dist/services/task/types.js.map +1 -1
  41. package/dist/types/cc.d.ts +800 -0
  42. package/dist/types/config.d.ts +66 -0
  43. package/dist/types/constants.d.ts +50 -0
  44. package/dist/types/index.d.ts +184 -0
  45. package/dist/types/logger-proxy.d.ts +71 -0
  46. package/dist/types/metrics/MetricsManager.d.ts +223 -0
  47. package/dist/types/metrics/behavioral-events.d.ts +29 -0
  48. package/dist/types/metrics/constants.d.ts +161 -0
  49. package/dist/types/services/AddressBook.d.ts +74 -0
  50. package/dist/types/services/ApiAiAssistant.d.ts +31 -0
  51. package/dist/types/services/EntryPoint.d.ts +67 -0
  52. package/dist/types/services/Queue.d.ts +76 -0
  53. package/dist/types/services/WebCallingService.d.ts +1 -0
  54. package/dist/types/services/agent/index.d.ts +46 -0
  55. package/dist/types/services/agent/types.d.ts +413 -0
  56. package/dist/types/services/config/Util.d.ts +20 -0
  57. package/dist/types/services/config/constants.d.ts +249 -0
  58. package/dist/types/services/config/index.d.ts +177 -0
  59. package/dist/types/services/config/types.d.ts +1207 -0
  60. package/dist/types/services/constants.d.ts +103 -0
  61. package/dist/types/services/core/Err.d.ts +121 -0
  62. package/dist/types/services/core/GlobalTypes.d.ts +58 -0
  63. package/dist/types/services/core/Utils.d.ts +101 -0
  64. package/dist/types/services/core/WebexRequest.d.ts +22 -0
  65. package/dist/types/services/core/aqm-reqs.d.ts +65 -0
  66. package/dist/types/services/core/constants.d.ts +99 -0
  67. package/dist/types/services/core/types.d.ts +47 -0
  68. package/dist/types/services/core/websocket/WebSocketManager.d.ts +34 -0
  69. package/dist/types/services/core/websocket/connection-service.d.ts +27 -0
  70. package/dist/types/services/core/websocket/keepalive.worker.d.ts +2 -0
  71. package/dist/types/services/core/websocket/types.d.ts +37 -0
  72. package/dist/types/services/index.d.ts +52 -0
  73. package/dist/types/services/task/AutoWrapup.d.ts +40 -0
  74. package/dist/types/services/task/TaskManager.d.ts +1 -0
  75. package/dist/types/services/task/TaskUtils.d.ts +92 -0
  76. package/dist/types/services/task/constants.d.ts +83 -0
  77. package/dist/types/services/task/contact.d.ts +69 -0
  78. package/dist/types/services/task/dialer.d.ts +43 -0
  79. package/dist/types/services/task/index.d.ts +650 -0
  80. package/dist/types/services/task/types.d.ts +1319 -0
  81. package/dist/types/types.d.ts +643 -0
  82. package/dist/types/utils/PageCache.d.ts +173 -0
  83. package/dist/types/webex-config.d.ts +53 -0
  84. package/dist/types/webex.d.ts +7 -0
  85. package/dist/types.js +14 -1
  86. package/dist/types.js.map +1 -1
  87. package/dist/webex.js +1 -1
  88. package/package.json +9 -9
  89. package/src/cc.ts +120 -29
  90. package/src/constants.ts +4 -0
  91. package/src/index.ts +1 -0
  92. package/src/metrics/behavioral-events.ts +14 -0
  93. package/src/metrics/constants.ts +11 -0
  94. package/src/services/ApiAiAssistant.ts +217 -0
  95. package/src/services/agent/types.ts +1 -1
  96. package/src/services/config/Util.ts +8 -0
  97. package/src/services/config/constants.ts +12 -0
  98. package/src/services/config/index.ts +45 -1
  99. package/src/services/config/types.ts +67 -0
  100. package/src/services/constants.ts +21 -0
  101. package/src/services/core/Err.ts +1 -0
  102. package/src/services/core/Utils.ts +32 -5
  103. package/src/services/core/aqm-reqs.ts +100 -22
  104. package/src/services/core/websocket/WebSocketManager.ts +12 -0
  105. package/src/services/task/TaskManager.ts +149 -28
  106. package/src/services/task/TaskUtils.ts +12 -0
  107. package/src/services/task/constants.ts +15 -0
  108. package/src/services/task/dialer.ts +56 -1
  109. package/src/services/task/types.ts +24 -0
  110. package/src/types.ts +40 -1
  111. package/test/unit/spec/cc.ts +92 -22
  112. package/test/unit/spec/services/ApiAiAssistant.ts +115 -0
  113. package/test/unit/spec/services/config/index.ts +56 -0
  114. package/test/unit/spec/services/core/Utils.ts +63 -1
  115. package/test/unit/spec/services/core/websocket/WebSocketManager.ts +71 -1
  116. package/test/unit/spec/services/task/TaskManager.ts +1015 -165
  117. package/test/unit/spec/services/task/dialer.ts +198 -112
  118. package/umd/contact-center.min.js +2 -2
  119. package/umd/contact-center.min.js.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"names":["_constants","require","_types","getUrlMapping","urlMappings","name","mappedUrl","find","mapping","url","getMsftConfig","agentProfileData","showUserDetailsMS","stateSynchronizationMS","getWebexConfig","showUserDetailsWebex","stateSynchronizationWebex","getDefaultAgentDN","agentDNValidation","getFilteredDialplanEntries","dialPlanData","profileDialPlans","dialPlanEntries","forEach","dailPlan","includes","id","filteredPlan","regex","regularExpression","prefix","strippedChars","push","getFilterAuxCodes","auxCodes","type","specificCodes","filteredAuxCodes","auxCode","workTypeCode","active","length","isSystem","isSystemCode","isDefault","defaultCode","getDefaultWrapUpCode","wrapUpReasonList","c","parseAgentConfigs","profileData","userData","teamData","tenantData","orgInfoData","orgSettingsData","urlMapping","tenantDataTimeout","timeoutDesktopInactivityEnabled","timeoutDesktopInactivityMins","inactivityTimeoutTimer","timeoutDesktopInactivityCustomEnabled","wrapupCodes","WRAP_UP_CODE","accessWrapUpCode","wrapUpCodes","idleCodes","IDLE_CODE","accessIdleCode","defaultWrapUpData","finalData","teams","defaultDn","defaultDialledNumber","forceDefaultDn","forceDefaultDnForAgent","regexUS","dnDefaultRegex","regexOther","dnOtherRegex","agentId","ciUserId","agentName","firstName","lastName","agentMailId","email","agentProfileID","agentProfileId","autoAnswer","dialPlan","dialPlanEnabled","dialPlanEntity","dialPlans","undefined","multimediaProfileId","skillProfileId","siteId","enterpriseId","tenantId","tenantTimezone","timezone","privacyShieldVisible","organizationIdleCodes","idleCodesAccess","wrapUpData","wrapUpProps","autoWrapup","autoWrapUp","autoWrapupInterval","autoWrapAfterSeconds","lastAgentRoute","lastAgentRouting","wrapUpCodeAccess","allowCancelAutoWrapup","allowAutoWrapUpExtension","defaultWrapupCode","isOutboundEnabledForTenant","outdialEnabled","isOutboundEnabledForAgent","isAdhocDialingEnabled","isAgentAvailableAfterOutdial","agentAvailableAfterOutdial","outDialEp","outdialEntryPointId","isCampaignManagementEnabled","campaignManagerEnabled","isEndCallEnabled","endCallEnabled","isEndConsultEnabled","endConsultEnabled","callVariablesSuppressed","agentDbId","dbId","allowConsultToQueue","consultToQueue","agentPersonalStatsEnabled","viewableStatistics","agentStats","addressBookId","outdialANIId","analyserUserId","acqueonApiUrl","acqueonConsoleUrl","isTimeoutDesktopInactivityEnabled","loginVoiceOptions","webRtcEnabled","maskSensitiveData","microsoftConfig","webexConfig","lostConnectionRecoveryTimeout","LOST_CONNECTION_RECOVERY_TIMEOUT"],"sources":["Util.ts"],"sourcesContent":["import {LOST_CONNECTION_RECOVERY_TIMEOUT} from '../core/constants';\nimport {\n AgentResponse,\n AuxCode,\n AuxCodeType,\n DesktopProfileResponse,\n DialPlanEntity,\n Entity,\n IDLE_CODE,\n OrgInfo,\n OrgSettings,\n Profile,\n Team,\n TenantData,\n URLMapping,\n WRAP_UP_CODE,\n} from './types';\n\n/**\n * Get the URL mapping for the given name\n * @param {Array<URLMapping>} urlMappings\n * @param {string} name\n * @returns {string}\n */\nconst getUrlMapping = (urlMappings: Array<URLMapping>, name: string) => {\n const mappedUrl = urlMappings.find((mapping) => mapping.name === name)?.url;\n\n return mappedUrl || '';\n};\n\n/**\n * Get the MSFT and Webex configuration\n * @param {DesktopProfileResponse} agentProfileData\n * @returns {Object}\n */\nconst getMsftConfig = (agentProfileData: DesktopProfileResponse) => {\n return {\n showUserDetailsMS: agentProfileData.showUserDetailsMS ?? false,\n stateSynchronizationMS: agentProfileData.stateSynchronizationMS ?? false,\n };\n};\n\n/**\n * Get the Webex configuration\n * @param {DesktopProfileResponse} agentProfileData\n * @returns {Object}\n */\nconst getWebexConfig = (agentProfileData: DesktopProfileResponse) => {\n return {\n showUserDetailsWebex: agentProfileData.showUserDetailsWebex ?? false,\n stateSynchronizationWebex: agentProfileData.stateSynchronizationWebex ?? false,\n };\n};\n\n/**\n * Get the default agent DN\n * @param {string} agentDNValidation\n * @returns {boolean}\n */\nconst getDefaultAgentDN = (agentDNValidation: string) => {\n return agentDNValidation === 'PROVISIONED_VALUE';\n};\n\n/**\n * Get the filtered dialplan entries\n * @param {Array<DialPlanEntity>} dialPlanData\n * @param {Array<string>} profileDialPlans\n * @returns {Array<Entity>}\n */\nconst getFilteredDialplanEntries = (dialPlanData: DialPlanEntity[], profileDialPlans: string[]) => {\n const dialPlanEntries = [];\n dialPlanData.forEach((dailPlan: DialPlanEntity) => {\n if (profileDialPlans.includes(dailPlan.id)) {\n const filteredPlan = {\n regex: dailPlan.regularExpression,\n prefix: dailPlan.prefix,\n strippedChars: dailPlan.strippedChars,\n name: dailPlan.name,\n };\n dialPlanEntries.push(filteredPlan);\n }\n });\n\n return dialPlanEntries;\n};\n\n/**\n * Get the filtered aux codes\n * @param {Array<AuxCode>} auxCodes\n * @param {AuxCodeType} type\n * @param {Array<string>} specificCodes\n * @returns {Array<Entity>}\n */\nconst getFilterAuxCodes = (\n auxCodes: Array<AuxCode>,\n type: AuxCodeType,\n specificCodes: string[]\n) => {\n const filteredAuxCodes: Array<Entity> = [];\n auxCodes.forEach((auxCode: AuxCode) => {\n if (\n auxCode.workTypeCode === type &&\n auxCode.active &&\n (specificCodes.length === 0 || specificCodes.includes(auxCode.id))\n ) {\n filteredAuxCodes.push({\n id: auxCode.id,\n name: auxCode.name,\n isSystem: auxCode.isSystemCode,\n isDefault: auxCode.defaultCode,\n });\n }\n });\n\n return filteredAuxCodes;\n};\n\n/**\n * Get the default wrapup code\n * @param {Array<Entity>} wrapUpReasonList\n * @returns {Entity}\n */\nfunction getDefaultWrapUpCode(wrapUpReasonList: Entity[]) {\n return wrapUpReasonList?.find((c: Entity) => c.isDefault);\n}\n\n/**\n * Parse the agent configurations\n * @param {Object} profileData\n * @returns {Profile}\n */\nfunction parseAgentConfigs(profileData: {\n userData: AgentResponse;\n teamData: Team[];\n tenantData: TenantData;\n orgInfoData: OrgInfo;\n auxCodes: AuxCode[];\n orgSettingsData: OrgSettings;\n agentProfileData: DesktopProfileResponse;\n dialPlanData: DialPlanEntity[];\n urlMapping: URLMapping[];\n multimediaProfileId: string;\n}): Profile {\n const {\n userData,\n teamData,\n tenantData,\n orgInfoData,\n auxCodes,\n orgSettingsData,\n agentProfileData,\n dialPlanData,\n urlMapping,\n } = profileData;\n\n const tenantDataTimeout = tenantData.timeoutDesktopInactivityEnabled\n ? tenantData.timeoutDesktopInactivityMins\n : null;\n const inactivityTimeoutTimer = agentProfileData.timeoutDesktopInactivityCustomEnabled\n ? agentProfileData.timeoutDesktopInactivityMins\n : tenantDataTimeout;\n\n const wrapupCodes = getFilterAuxCodes(\n auxCodes,\n WRAP_UP_CODE,\n agentProfileData.accessWrapUpCode === 'ALL' ? [] : agentProfileData.wrapUpCodes\n );\n\n const idleCodes = getFilterAuxCodes(\n auxCodes,\n IDLE_CODE,\n agentProfileData.accessIdleCode === 'ALL' ? [] : agentProfileData.idleCodes\n );\n\n idleCodes.push({\n id: '0',\n name: 'Available',\n isSystem: false,\n isDefault: false,\n }); // pushing available state to idle codes\n\n const defaultWrapUpData = getDefaultWrapUpCode(wrapupCodes);\n\n const finalData = {\n teams: teamData,\n defaultDn: userData.defaultDialledNumber,\n forceDefaultDn: tenantData.forceDefaultDn,\n forceDefaultDnForAgent: getDefaultAgentDN(agentProfileData.agentDNValidation),\n regexUS: tenantData.dnDefaultRegex,\n regexOther: tenantData.dnOtherRegex,\n agentId: userData.ciUserId,\n agentName: `${userData.firstName} ${userData.lastName}`,\n agentMailId: userData.email,\n agentProfileID: userData.agentProfileId,\n autoAnswer: agentProfileData.autoAnswer,\n dialPlan: agentProfileData.dialPlanEnabled\n ? {\n type: 'adhocDial',\n dialPlanEntity: getFilteredDialplanEntries(dialPlanData, agentProfileData.dialPlans),\n }\n : undefined,\n multimediaProfileId: profileData.multimediaProfileId,\n skillProfileId: userData.skillProfileId ? userData.skillProfileId : null,\n siteId: userData.siteId,\n enterpriseId: orgInfoData.tenantId,\n tenantTimezone: orgInfoData.timezone,\n privacyShieldVisible: tenantData.privacyShieldVisible,\n organizationIdleCodes: [], // TODO: for supervisor, getOrgFilteredIdleCodes(auxCodes, false),\n idleCodesAccess: agentProfileData.accessIdleCode as 'ALL' | 'SPECIFIC',\n idleCodes,\n wrapupCodes,\n wrapUpData: {\n wrapUpProps: {\n autoWrapup: agentProfileData.autoWrapUp,\n autoWrapupInterval: agentProfileData.autoWrapAfterSeconds,\n lastAgentRoute: agentProfileData.lastAgentRouting,\n wrapUpCodeAccess: agentProfileData.accessWrapUpCode,\n wrapUpReasonList: wrapupCodes,\n allowCancelAutoWrapup: agentProfileData.allowAutoWrapUpExtension,\n },\n },\n defaultWrapupCode: defaultWrapUpData?.id ?? '',\n isOutboundEnabledForTenant: tenantData.outdialEnabled,\n isOutboundEnabledForAgent: agentProfileData.outdialEnabled,\n isAdhocDialingEnabled: agentProfileData.dialPlanEnabled,\n isAgentAvailableAfterOutdial: agentProfileData.agentAvailableAfterOutdial,\n outDialEp: agentProfileData.outdialEntryPointId,\n isCampaignManagementEnabled: orgSettingsData.campaignManagerEnabled,\n isEndCallEnabled: tenantData.endCallEnabled,\n isEndConsultEnabled: tenantData.endConsultEnabled,\n callVariablesSuppressed: tenantData.callVariablesSuppressed,\n agentDbId: userData.dbId,\n allowConsultToQueue: agentProfileData.consultToQueue,\n agentPersonalStatsEnabled: agentProfileData.viewableStatistics\n ? agentProfileData.viewableStatistics.agentStats\n : false,\n addressBookId: agentProfileData.addressBookId,\n outdialANIId: agentProfileData.outdialANIId,\n analyserUserId: userData.id,\n\n urlMappings: {\n acqueonApiUrl: getUrlMapping(urlMapping, 'ACQUEON_API_URL'),\n acqueonConsoleUrl: getUrlMapping(urlMapping, 'ACQUEON_CONSOLE_URL'),\n },\n isTimeoutDesktopInactivityEnabled: tenantData.timeoutDesktopInactivityEnabled,\n timeoutDesktopInactivityMins: inactivityTimeoutTimer,\n loginVoiceOptions: agentProfileData.loginVoiceOptions ?? [],\n webRtcEnabled: orgSettingsData.webRtcEnabled,\n maskSensitiveData: orgSettingsData.maskSensitiveData\n ? orgSettingsData.maskSensitiveData\n : false,\n microsoftConfig: getMsftConfig(agentProfileData),\n webexConfig: getWebexConfig(agentProfileData),\n lostConnectionRecoveryTimeout:\n tenantData.lostConnectionRecoveryTimeout || LOST_CONNECTION_RECOVERY_TIMEOUT,\n };\n\n return finalData;\n}\n\nexport {parseAgentConfigs};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_constants","require","_types","getUrlMapping","urlMappings","name","mappedUrl","find","mapping","url","getMsftConfig","agentProfileData","showUserDetailsMS","stateSynchronizationMS","getWebexConfig","showUserDetailsWebex","stateSynchronizationWebex","getDefaultAgentDN","agentDNValidation","getFilteredDialplanEntries","dialPlanData","profileDialPlans","dialPlanEntries","forEach","dailPlan","includes","id","filteredPlan","regex","regularExpression","prefix","strippedChars","push","getFilterAuxCodes","auxCodes","type","specificCodes","filteredAuxCodes","auxCode","workTypeCode","active","length","isSystem","isSystemCode","isDefault","defaultCode","getDefaultWrapUpCode","wrapUpReasonList","c","parseAgentConfigs","profileData","userData","teamData","tenantData","orgInfoData","orgSettingsData","urlMapping","aiFeatureFlags","tenantDataTimeout","timeoutDesktopInactivityEnabled","timeoutDesktopInactivityMins","inactivityTimeoutTimer","timeoutDesktopInactivityCustomEnabled","wrapupCodes","WRAP_UP_CODE","accessWrapUpCode","wrapUpCodes","idleCodes","IDLE_CODE","accessIdleCode","defaultWrapUpData","aiFeature","data","undefined","finalData","teams","defaultDn","defaultDialledNumber","forceDefaultDn","forceDefaultDnForAgent","regexUS","dnDefaultRegex","regexOther","dnOtherRegex","agentId","ciUserId","agentName","firstName","lastName","agentMailId","email","agentProfileID","agentProfileId","autoAnswer","dialPlan","dialPlanEnabled","dialPlanEntity","dialPlans","multimediaProfileId","skillProfileId","siteId","enterpriseId","tenantId","tenantTimezone","timezone","environment","privacyShieldVisible","organizationIdleCodes","idleCodesAccess","wrapUpData","wrapUpProps","autoWrapup","autoWrapUp","autoWrapupInterval","autoWrapAfterSeconds","lastAgentRoute","lastAgentRouting","wrapUpCodeAccess","allowCancelAutoWrapup","allowAutoWrapUpExtension","defaultWrapupCode","isOutboundEnabledForTenant","outdialEnabled","isOutboundEnabledForAgent","isAdhocDialingEnabled","isAgentAvailableAfterOutdial","agentAvailableAfterOutdial","outDialEp","outdialEntryPointId","isCampaignManagementEnabled","campaignManagerEnabled","isEndCallEnabled","endCallEnabled","isEndConsultEnabled","endConsultEnabled","callVariablesSuppressed","agentDbId","dbId","allowConsultToQueue","consultToQueue","agentPersonalStatsEnabled","viewableStatistics","agentStats","addressBookId","outdialANIId","analyserUserId","acqueonApiUrl","acqueonConsoleUrl","isTimeoutDesktopInactivityEnabled","loginVoiceOptions","webRtcEnabled","maskSensitiveData","microsoftConfig","webexConfig","lostConnectionRecoveryTimeout","LOST_CONNECTION_RECOVERY_TIMEOUT"],"sources":["Util.ts"],"sourcesContent":["import {LOST_CONNECTION_RECOVERY_TIMEOUT} from '../core/constants';\nimport {\n AgentResponse,\n AuxCode,\n AuxCodeType,\n DesktopProfileResponse,\n DialPlanEntity,\n Entity,\n IDLE_CODE,\n OrgInfo,\n OrgSettings,\n Profile,\n Team,\n TenantData,\n URLMapping,\n WRAP_UP_CODE,\n AIFeatureFlagsResponse,\n AIFeatureFlags,\n} from './types';\n\n/**\n * Get the URL mapping for the given name\n * @param {Array<URLMapping>} urlMappings\n * @param {string} name\n * @returns {string}\n */\nconst getUrlMapping = (urlMappings: Array<URLMapping>, name: string) => {\n const mappedUrl = urlMappings.find((mapping) => mapping.name === name)?.url;\n\n return mappedUrl || '';\n};\n\n/**\n * Get the MSFT and Webex configuration\n * @param {DesktopProfileResponse} agentProfileData\n * @returns {Object}\n */\nconst getMsftConfig = (agentProfileData: DesktopProfileResponse) => {\n return {\n showUserDetailsMS: agentProfileData.showUserDetailsMS ?? false,\n stateSynchronizationMS: agentProfileData.stateSynchronizationMS ?? false,\n };\n};\n\n/**\n * Get the Webex configuration\n * @param {DesktopProfileResponse} agentProfileData\n * @returns {Object}\n */\nconst getWebexConfig = (agentProfileData: DesktopProfileResponse) => {\n return {\n showUserDetailsWebex: agentProfileData.showUserDetailsWebex ?? false,\n stateSynchronizationWebex: agentProfileData.stateSynchronizationWebex ?? false,\n };\n};\n\n/**\n * Get the default agent DN\n * @param {string} agentDNValidation\n * @returns {boolean}\n */\nconst getDefaultAgentDN = (agentDNValidation: string) => {\n return agentDNValidation === 'PROVISIONED_VALUE';\n};\n\n/**\n * Get the filtered dialplan entries\n * @param {Array<DialPlanEntity>} dialPlanData\n * @param {Array<string>} profileDialPlans\n * @returns {Array<Entity>}\n */\nconst getFilteredDialplanEntries = (dialPlanData: DialPlanEntity[], profileDialPlans: string[]) => {\n const dialPlanEntries = [];\n dialPlanData.forEach((dailPlan: DialPlanEntity) => {\n if (profileDialPlans.includes(dailPlan.id)) {\n const filteredPlan = {\n regex: dailPlan.regularExpression,\n prefix: dailPlan.prefix,\n strippedChars: dailPlan.strippedChars,\n name: dailPlan.name,\n };\n dialPlanEntries.push(filteredPlan);\n }\n });\n\n return dialPlanEntries;\n};\n\n/**\n * Get the filtered aux codes\n * @param {Array<AuxCode>} auxCodes\n * @param {AuxCodeType} type\n * @param {Array<string>} specificCodes\n * @returns {Array<Entity>}\n */\nconst getFilterAuxCodes = (\n auxCodes: Array<AuxCode>,\n type: AuxCodeType,\n specificCodes: string[]\n) => {\n const filteredAuxCodes: Array<Entity> = [];\n auxCodes.forEach((auxCode: AuxCode) => {\n if (\n auxCode.workTypeCode === type &&\n auxCode.active &&\n (specificCodes.length === 0 || specificCodes.includes(auxCode.id))\n ) {\n filteredAuxCodes.push({\n id: auxCode.id,\n name: auxCode.name,\n isSystem: auxCode.isSystemCode,\n isDefault: auxCode.defaultCode,\n });\n }\n });\n\n return filteredAuxCodes;\n};\n\n/**\n * Get the default wrapup code\n * @param {Array<Entity>} wrapUpReasonList\n * @returns {Entity}\n */\nfunction getDefaultWrapUpCode(wrapUpReasonList: Entity[]) {\n return wrapUpReasonList?.find((c: Entity) => c.isDefault);\n}\n\n/**\n * Parse the agent configurations\n * @param {Object} profileData\n * @returns {Profile}\n */\nfunction parseAgentConfigs(profileData: {\n userData: AgentResponse;\n teamData: Team[];\n tenantData: TenantData;\n orgInfoData: OrgInfo;\n auxCodes: AuxCode[];\n orgSettingsData: OrgSettings;\n agentProfileData: DesktopProfileResponse;\n dialPlanData: DialPlanEntity[];\n urlMapping: URLMapping[];\n multimediaProfileId: string;\n aiFeatureFlags: AIFeatureFlagsResponse;\n}): Profile {\n const {\n userData,\n teamData,\n tenantData,\n orgInfoData,\n auxCodes,\n orgSettingsData,\n agentProfileData,\n dialPlanData,\n urlMapping,\n aiFeatureFlags,\n } = profileData;\n\n const tenantDataTimeout = tenantData.timeoutDesktopInactivityEnabled\n ? tenantData.timeoutDesktopInactivityMins\n : null;\n const inactivityTimeoutTimer = agentProfileData.timeoutDesktopInactivityCustomEnabled\n ? agentProfileData.timeoutDesktopInactivityMins\n : tenantDataTimeout;\n\n const wrapupCodes = getFilterAuxCodes(\n auxCodes,\n WRAP_UP_CODE,\n agentProfileData.accessWrapUpCode === 'ALL' ? [] : agentProfileData.wrapUpCodes\n );\n\n const idleCodes = getFilterAuxCodes(\n auxCodes,\n IDLE_CODE,\n agentProfileData.accessIdleCode === 'ALL' ? [] : agentProfileData.idleCodes\n );\n\n idleCodes.push({\n id: '0',\n name: 'Available',\n isSystem: false,\n isDefault: false,\n }); // pushing available state to idle codes\n\n const defaultWrapUpData = getDefaultWrapUpCode(wrapupCodes);\n const aiFeature: AIFeatureFlags | undefined =\n aiFeatureFlags?.data && aiFeatureFlags.data.length > 0 ? aiFeatureFlags.data[0] : undefined;\n\n const finalData = {\n teams: teamData,\n defaultDn: userData.defaultDialledNumber,\n forceDefaultDn: tenantData.forceDefaultDn,\n forceDefaultDnForAgent: getDefaultAgentDN(agentProfileData.agentDNValidation),\n regexUS: tenantData.dnDefaultRegex,\n regexOther: tenantData.dnOtherRegex,\n agentId: userData.ciUserId,\n agentName: `${userData.firstName} ${userData.lastName}`,\n agentMailId: userData.email,\n agentProfileID: userData.agentProfileId,\n autoAnswer: agentProfileData.autoAnswer,\n dialPlan: agentProfileData.dialPlanEnabled\n ? {\n type: 'adhocDial',\n dialPlanEntity: getFilteredDialplanEntries(dialPlanData, agentProfileData.dialPlans),\n }\n : undefined,\n multimediaProfileId: profileData.multimediaProfileId,\n skillProfileId: userData.skillProfileId ? userData.skillProfileId : null,\n siteId: userData.siteId,\n enterpriseId: orgInfoData.tenantId,\n tenantTimezone: orgInfoData.timezone,\n environment: orgInfoData.environment,\n privacyShieldVisible: tenantData.privacyShieldVisible,\n organizationIdleCodes: [], // TODO: for supervisor, getOrgFilteredIdleCodes(auxCodes, false),\n idleCodesAccess: agentProfileData.accessIdleCode as 'ALL' | 'SPECIFIC',\n idleCodes,\n wrapupCodes,\n wrapUpData: {\n wrapUpProps: {\n autoWrapup: agentProfileData.autoWrapUp,\n autoWrapupInterval: agentProfileData.autoWrapAfterSeconds,\n lastAgentRoute: agentProfileData.lastAgentRouting,\n wrapUpCodeAccess: agentProfileData.accessWrapUpCode,\n wrapUpReasonList: wrapupCodes,\n allowCancelAutoWrapup: agentProfileData.allowAutoWrapUpExtension,\n },\n },\n defaultWrapupCode: defaultWrapUpData?.id ?? '',\n isOutboundEnabledForTenant: tenantData.outdialEnabled,\n isOutboundEnabledForAgent: agentProfileData.outdialEnabled,\n isAdhocDialingEnabled: agentProfileData.dialPlanEnabled,\n isAgentAvailableAfterOutdial: agentProfileData.agentAvailableAfterOutdial,\n outDialEp: agentProfileData.outdialEntryPointId,\n isCampaignManagementEnabled: orgSettingsData.campaignManagerEnabled,\n isEndCallEnabled: tenantData.endCallEnabled,\n isEndConsultEnabled: tenantData.endConsultEnabled,\n callVariablesSuppressed: tenantData.callVariablesSuppressed,\n agentDbId: userData.dbId,\n allowConsultToQueue: agentProfileData.consultToQueue,\n agentPersonalStatsEnabled: agentProfileData.viewableStatistics\n ? agentProfileData.viewableStatistics.agentStats\n : false,\n addressBookId: agentProfileData.addressBookId,\n outdialANIId: agentProfileData.outdialANIId,\n analyserUserId: userData.id,\n\n urlMappings: {\n acqueonApiUrl: getUrlMapping(urlMapping, 'ACQUEON_API_URL'),\n acqueonConsoleUrl: getUrlMapping(urlMapping, 'ACQUEON_CONSOLE_URL'),\n },\n isTimeoutDesktopInactivityEnabled: tenantData.timeoutDesktopInactivityEnabled,\n timeoutDesktopInactivityMins: inactivityTimeoutTimer,\n loginVoiceOptions: agentProfileData.loginVoiceOptions ?? [],\n webRtcEnabled: orgSettingsData.webRtcEnabled,\n maskSensitiveData: orgSettingsData.maskSensitiveData\n ? orgSettingsData.maskSensitiveData\n : false,\n microsoftConfig: getMsftConfig(agentProfileData),\n webexConfig: getWebexConfig(agentProfileData),\n lostConnectionRecoveryTimeout:\n tenantData.lostConnectionRecoveryTimeout || LOST_CONNECTION_RECOVERY_TIMEOUT,\n aiFeature,\n };\n\n return finalData;\n}\n\nexport {parseAgentConfigs};\n"],"mappings":"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","ignoreList":[]}
@@ -66,6 +66,8 @@ const METHODS = exports.METHODS = {
66
66
  GET_TENANT_DATA: 'getTenantData',
67
67
  GET_URL_MAPPING: 'getURLMapping',
68
68
  GET_DIAL_PLAN_DATA: 'getDialPlanData',
69
+ GET_AI_FEATURE_FLAGS: 'getAIFeatureFlags',
70
+ GET_QUEUES: 'getQueues',
69
71
  // Util methods
70
72
  PARSE_AGENT_CONFIGS: 'parseAgentConfigs',
71
73
  GET_URL_MAPPING_UTIL: 'getUrlMapping',
@@ -205,6 +207,16 @@ const endPointMap = exports.endPointMap = {
205
207
  * @ignore
206
208
  */
207
209
  dialPlan: orgId => `organization/${orgId}/dial-plan?agentView=true`,
210
+ /**
211
+ * Gets the endpoint for listing AI feature flags.
212
+ * @param orgId - Organization ID.
213
+ * @returns The endpoint URL string.
214
+ * @public
215
+ * @example
216
+ * const url = endPointMap.aiFeatureFlags('org123');
217
+ * @ignore
218
+ */
219
+ aiFeature: orgId => `organization/${orgId}/v2/ai-feature?page=0&pageSize=100`,
208
220
  /**
209
221
  * Gets the endpoint for the queue list with custom query parameters.
210
222
  * @param orgId - Organization ID.
@@ -1 +1 @@
1
- {"version":3,"names":["DEFAULT_PAGE","exports","DEFAULT_PAGE_SIZE","AGENT_STATE_AVAILABLE_ID","AGENT_STATE_AVAILABLE","AGENT_STATE_AVAILABLE_DESCRIPTION","DEFAULT_AUXCODE_ATTRIBUTES","METHODS","GET_AGENT_CONFIG","GET_USER_USING_CI","GET_DESKTOP_PROFILE_BY_ID","GET_MULTIMEDIA_PROFILE_BY_ID","GET_LIST_OF_TEAMS","GET_ALL_TEAMS","GET_LIST_OF_AUX_CODES","GET_ALL_AUX_CODES","GET_SITE_INFO","GET_ORG_INFO","GET_ORGANIZATION_SETTING","GET_TENANT_DATA","GET_URL_MAPPING","GET_DIAL_PLAN_DATA","PARSE_AGENT_CONFIGS","GET_URL_MAPPING_UTIL","GET_MSFT_CONFIG","GET_WEBEX_CONFIG","GET_DEFAULT_AGENT_DN","GET_FILTERED_DIALPLAN_ENTRIES","GET_FILTER_AUX_CODES","GET_DEFAULT_WRAP_UP_CODE","endPointMap","userByCI","orgId","agentId","desktopProfile","desktopProfileId","multimediaProfile","multimediaProfileId","listTeams","page","pageSize","filter","length","listAuxCodes","attributes","orgInfo","orgSettings","siteInfo","siteId","tenantData","urlMapping","dialPlan","queueList","queryParams","entryPointList","addressBookEntries","addressBookId","outdialAniEntries","outdialANI"],"sources":["constants.ts"],"sourcesContent":["// making query params configurable for List Teams and List Aux Codes API\nexport const DEFAULT_PAGE = 0;\n\n/**\n * Default page size for paginated API requests.\n * @type {number}\n * @public\n * @example\n * const pageSize = DEFAULT_PAGE_SIZE; // 100\n * @ignore\n */\nexport const DEFAULT_PAGE_SIZE = 100;\n\n/**\n * Agent state ID for 'Available'.\n * @type {string}\n * @public\n * @ignore\n */\nexport const AGENT_STATE_AVAILABLE_ID = '0';\n\n/**\n * Agent state label for 'Available'.\n * @type {string}\n * @public\n * @ignore\n */\nexport const AGENT_STATE_AVAILABLE = 'Available';\n\n/**\n * Description for the 'Available' agent state.\n * @type {string}\n * @public\n * @ignore\n */\nexport const AGENT_STATE_AVAILABLE_DESCRIPTION = 'Agent is available to receive calls';\n\n/**\n * Default attributes for auxiliary code API requests.\n * @type {string[]}\n * @public\n * @ignore\n */\nexport const DEFAULT_AUXCODE_ATTRIBUTES = [\n 'id',\n 'isSystemCode',\n 'name',\n 'defaultCode',\n 'workTypeCode',\n 'active',\n];\n\n// Method names for config services\nexport const METHODS = {\n // AgentConfigService methods\n GET_AGENT_CONFIG: 'getAgentConfig',\n GET_USER_USING_CI: 'getUserUsingCI',\n GET_DESKTOP_PROFILE_BY_ID: 'getDesktopProfileById',\n GET_MULTIMEDIA_PROFILE_BY_ID: 'getMultimediaProfileById',\n GET_LIST_OF_TEAMS: 'getListOfTeams',\n GET_ALL_TEAMS: 'getAllTeams',\n GET_LIST_OF_AUX_CODES: 'getListOfAuxCodes',\n GET_ALL_AUX_CODES: 'getAllAuxCodes',\n GET_SITE_INFO: 'getSiteInfo',\n GET_ORG_INFO: 'getOrgInfo',\n GET_ORGANIZATION_SETTING: 'getOrganizationSetting',\n GET_TENANT_DATA: 'getTenantData',\n GET_URL_MAPPING: 'getURLMapping',\n GET_DIAL_PLAN_DATA: 'getDialPlanData',\n\n // Util methods\n PARSE_AGENT_CONFIGS: 'parseAgentConfigs',\n GET_URL_MAPPING_UTIL: 'getUrlMapping',\n GET_MSFT_CONFIG: 'getMsftConfig',\n GET_WEBEX_CONFIG: 'getWebexConfig',\n GET_DEFAULT_AGENT_DN: 'getDefaultAgentDN',\n GET_FILTERED_DIALPLAN_ENTRIES: 'getFilteredDialplanEntries',\n GET_FILTER_AUX_CODES: 'getFilterAuxCodes',\n GET_DEFAULT_WRAP_UP_CODE: 'getDefaultWrapUpCode',\n};\n\n/**\n * Maps API endpoint names to functions that generate endpoint URLs for various organization resources.\n * @public\n * @example\n * const url = endPointMap.userByCI('org123', 'agent456');\n */\nexport const endPointMap = {\n /**\n * Gets the endpoint for a user by CI user ID.\n * @param orgId - Organization ID.\n * @param agentId - Agent ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.userByCI('org123', 'agent456');\n * @ignore\n */\n userByCI: (orgId: string, agentId: string) =>\n `organization/${orgId}/user/by-ci-user-id/${agentId}`,\n\n /**\n * Gets the endpoint for a desktop profile.\n * @param orgId - Organization ID.\n * @param desktopProfileId - Desktop profile ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.desktopProfile('org123', 'profile789');\n * @ignore\n */\n desktopProfile: (orgId: string, desktopProfileId: string) =>\n `organization/${orgId}/agent-profile/${desktopProfileId}`,\n\n /**\n * Gets the endpoint for a multimedia profile.\n * @param orgId - Organization ID.\n * @param multimediaProfileId - Multimedia profile ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.multimediaProfile('org123', 'multi456');\n * @ignore\n */\n multimediaProfile: (orgId: string, multimediaProfileId: string) =>\n `organization/${orgId}/multimedia-profile/${multimediaProfileId}`,\n\n /**\n * Gets the endpoint for listing teams with optional filters.\n * @param orgId - Organization ID.\n * @param page - Page number.\n * @param pageSize - Page size.\n * @param filter - Array of team IDs to filter.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.listTeams('org123', 0, 100, ['team1', 'team2']);\n * @ignore\n */\n listTeams: (orgId: string, page: number, pageSize: number, filter: string[]) =>\n `organization/${orgId}/v2/team?page=${page}&pageSize=${pageSize}${\n filter && filter.length > 0 ? `&filter=id=in=(${filter})` : ''\n }`,\n\n /**\n * Gets the endpoint for listing auxiliary codes with optional filters and attributes.\n * @param orgId - Organization ID.\n * @param page - Page number.\n * @param pageSize - Page size.\n * @param filter - Array of auxiliary code IDs to filter.\n * @param attributes - Array of attribute names to include.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.listAuxCodes('org123', 0, 100, ['aux1'], ['id', 'name']);\n * @ignore\n */\n listAuxCodes: (\n orgId: string,\n page: number,\n pageSize: number,\n filter: string[],\n attributes: string[]\n ) =>\n `organization/${orgId}/v2/auxiliary-code?page=${page}&pageSize=${pageSize}${\n filter && filter.length > 0 ? `&filter=id=in=(${filter})` : ''\n }&attributes=${attributes}`,\n\n /**\n * Gets the endpoint for organization info.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.orgInfo('org123');\n * @ignore\n */\n orgInfo: (orgId: string) => `organization/${orgId}`,\n\n /**\n * Gets the endpoint for organization settings.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.orgSettings('org123');\n * @ignore\n */\n orgSettings: (orgId: string) => `organization/${orgId}/v2/organization-setting?agentView=true`,\n\n /**\n * Gets the endpoint for site info.\n * @param orgId - Organization ID.\n * @param siteId - Site ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.siteInfo('org123', 'site456');\n * @ignore\n */\n siteInfo: (orgId: string, siteId: string) => `organization/${orgId}/site/${siteId}`,\n\n /**\n * Gets the endpoint for tenant configuration data.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.tenantData('org123');\n * @ignore\n */\n tenantData: (orgId: string) => `organization/${orgId}/v2/tenant-configuration?agentView=true`,\n\n /**\n * Gets the endpoint for organization URL mapping.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.urlMapping('org123');\n * @ignore\n */\n urlMapping: (orgId: string) => `organization/${orgId}/v2/org-url-mapping?sort=name,ASC`,\n\n /**\n * Gets the endpoint for dial plan.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.dialPlan('org123');\n * @ignore\n */\n dialPlan: (orgId: string) => `organization/${orgId}/dial-plan?agentView=true`,\n\n /**\n * Gets the endpoint for the queue list with custom query parameters.\n * @param orgId - Organization ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.queueList('org123', 'page=0&pageSize=10');\n * @ignore\n */\n queueList: (orgId: string, queryParams: string) =>\n `/organization/${orgId}/v2/contact-service-queue?${queryParams}`,\n /**\n * Gets the endpoint for entry points list with custom query parameters.\n * @param orgId - Organization ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.entryPointList('org123', 'page=0&pageSize=10');\n * @ignore\n */\n entryPointList: (orgId: string, queryParams: string) =>\n `/organization/${orgId}/v2/entry-point?${queryParams}`,\n /**\n * Gets the endpoint for address book entries with custom query parameters.\n * @param orgId - Organization ID.\n * @param addressBookId - Address book ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.addressBookEntries('org123', 'book456', 'page=0&pageSize=10');\n * @ignore\n */\n addressBookEntries: (orgId: string, addressBookId: string, queryParams: string) =>\n `/organization/${orgId}/v2/address-book/${addressBookId}/entry?${queryParams}`,\n\n /**\n * Gets the endpoint for outdial ANI entries with custom query parameters.\n * @param orgId - Organization ID.\n * @param outdialANI - Outdial ANI ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.outdialAniEntries('org123', 'ani456', 'page=0&pageSize=10');\n * @ignore\n */\n outdialAniEntries: (orgId: string, outdialANI: string, queryParams: string) =>\n `organization/${orgId}/v2/outdial-ani/${outdialANI}/entry${\n queryParams ? `?${queryParams}` : ''\n }`,\n};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["DEFAULT_PAGE","exports","DEFAULT_PAGE_SIZE","AGENT_STATE_AVAILABLE_ID","AGENT_STATE_AVAILABLE","AGENT_STATE_AVAILABLE_DESCRIPTION","DEFAULT_AUXCODE_ATTRIBUTES","METHODS","GET_AGENT_CONFIG","GET_USER_USING_CI","GET_DESKTOP_PROFILE_BY_ID","GET_MULTIMEDIA_PROFILE_BY_ID","GET_LIST_OF_TEAMS","GET_ALL_TEAMS","GET_LIST_OF_AUX_CODES","GET_ALL_AUX_CODES","GET_SITE_INFO","GET_ORG_INFO","GET_ORGANIZATION_SETTING","GET_TENANT_DATA","GET_URL_MAPPING","GET_DIAL_PLAN_DATA","GET_AI_FEATURE_FLAGS","GET_QUEUES","PARSE_AGENT_CONFIGS","GET_URL_MAPPING_UTIL","GET_MSFT_CONFIG","GET_WEBEX_CONFIG","GET_DEFAULT_AGENT_DN","GET_FILTERED_DIALPLAN_ENTRIES","GET_FILTER_AUX_CODES","GET_DEFAULT_WRAP_UP_CODE","endPointMap","userByCI","orgId","agentId","desktopProfile","desktopProfileId","multimediaProfile","multimediaProfileId","listTeams","page","pageSize","filter","length","listAuxCodes","attributes","orgInfo","orgSettings","siteInfo","siteId","tenantData","urlMapping","dialPlan","aiFeature","queueList","queryParams","entryPointList","addressBookEntries","addressBookId","outdialAniEntries","outdialANI"],"sources":["constants.ts"],"sourcesContent":["// making query params configurable for List Teams and List Aux Codes API\nexport const DEFAULT_PAGE = 0;\n\n/**\n * Default page size for paginated API requests.\n * @type {number}\n * @public\n * @example\n * const pageSize = DEFAULT_PAGE_SIZE; // 100\n * @ignore\n */\nexport const DEFAULT_PAGE_SIZE = 100;\n\n/**\n * Agent state ID for 'Available'.\n * @type {string}\n * @public\n * @ignore\n */\nexport const AGENT_STATE_AVAILABLE_ID = '0';\n\n/**\n * Agent state label for 'Available'.\n * @type {string}\n * @public\n * @ignore\n */\nexport const AGENT_STATE_AVAILABLE = 'Available';\n\n/**\n * Description for the 'Available' agent state.\n * @type {string}\n * @public\n * @ignore\n */\nexport const AGENT_STATE_AVAILABLE_DESCRIPTION = 'Agent is available to receive calls';\n\n/**\n * Default attributes for auxiliary code API requests.\n * @type {string[]}\n * @public\n * @ignore\n */\nexport const DEFAULT_AUXCODE_ATTRIBUTES = [\n 'id',\n 'isSystemCode',\n 'name',\n 'defaultCode',\n 'workTypeCode',\n 'active',\n];\n\n// Method names for config services\nexport const METHODS = {\n // AgentConfigService methods\n GET_AGENT_CONFIG: 'getAgentConfig',\n GET_USER_USING_CI: 'getUserUsingCI',\n GET_DESKTOP_PROFILE_BY_ID: 'getDesktopProfileById',\n GET_MULTIMEDIA_PROFILE_BY_ID: 'getMultimediaProfileById',\n GET_LIST_OF_TEAMS: 'getListOfTeams',\n GET_ALL_TEAMS: 'getAllTeams',\n GET_LIST_OF_AUX_CODES: 'getListOfAuxCodes',\n GET_ALL_AUX_CODES: 'getAllAuxCodes',\n GET_SITE_INFO: 'getSiteInfo',\n GET_ORG_INFO: 'getOrgInfo',\n GET_ORGANIZATION_SETTING: 'getOrganizationSetting',\n GET_TENANT_DATA: 'getTenantData',\n GET_URL_MAPPING: 'getURLMapping',\n GET_DIAL_PLAN_DATA: 'getDialPlanData',\n GET_AI_FEATURE_FLAGS: 'getAIFeatureFlags',\n GET_QUEUES: 'getQueues',\n\n // Util methods\n PARSE_AGENT_CONFIGS: 'parseAgentConfigs',\n GET_URL_MAPPING_UTIL: 'getUrlMapping',\n GET_MSFT_CONFIG: 'getMsftConfig',\n GET_WEBEX_CONFIG: 'getWebexConfig',\n GET_DEFAULT_AGENT_DN: 'getDefaultAgentDN',\n GET_FILTERED_DIALPLAN_ENTRIES: 'getFilteredDialplanEntries',\n GET_FILTER_AUX_CODES: 'getFilterAuxCodes',\n GET_DEFAULT_WRAP_UP_CODE: 'getDefaultWrapUpCode',\n};\n\n/**\n * Maps API endpoint names to functions that generate endpoint URLs for various organization resources.\n * @public\n * @example\n * const url = endPointMap.userByCI('org123', 'agent456');\n */\nexport const endPointMap = {\n /**\n * Gets the endpoint for a user by CI user ID.\n * @param orgId - Organization ID.\n * @param agentId - Agent ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.userByCI('org123', 'agent456');\n * @ignore\n */\n userByCI: (orgId: string, agentId: string) =>\n `organization/${orgId}/user/by-ci-user-id/${agentId}`,\n\n /**\n * Gets the endpoint for a desktop profile.\n * @param orgId - Organization ID.\n * @param desktopProfileId - Desktop profile ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.desktopProfile('org123', 'profile789');\n * @ignore\n */\n desktopProfile: (orgId: string, desktopProfileId: string) =>\n `organization/${orgId}/agent-profile/${desktopProfileId}`,\n\n /**\n * Gets the endpoint for a multimedia profile.\n * @param orgId - Organization ID.\n * @param multimediaProfileId - Multimedia profile ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.multimediaProfile('org123', 'multi456');\n * @ignore\n */\n multimediaProfile: (orgId: string, multimediaProfileId: string) =>\n `organization/${orgId}/multimedia-profile/${multimediaProfileId}`,\n\n /**\n * Gets the endpoint for listing teams with optional filters.\n * @param orgId - Organization ID.\n * @param page - Page number.\n * @param pageSize - Page size.\n * @param filter - Array of team IDs to filter.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.listTeams('org123', 0, 100, ['team1', 'team2']);\n * @ignore\n */\n listTeams: (orgId: string, page: number, pageSize: number, filter: string[]) =>\n `organization/${orgId}/v2/team?page=${page}&pageSize=${pageSize}${\n filter && filter.length > 0 ? `&filter=id=in=(${filter})` : ''\n }`,\n\n /**\n * Gets the endpoint for listing auxiliary codes with optional filters and attributes.\n * @param orgId - Organization ID.\n * @param page - Page number.\n * @param pageSize - Page size.\n * @param filter - Array of auxiliary code IDs to filter.\n * @param attributes - Array of attribute names to include.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.listAuxCodes('org123', 0, 100, ['aux1'], ['id', 'name']);\n * @ignore\n */\n listAuxCodes: (\n orgId: string,\n page: number,\n pageSize: number,\n filter: string[],\n attributes: string[]\n ) =>\n `organization/${orgId}/v2/auxiliary-code?page=${page}&pageSize=${pageSize}${\n filter && filter.length > 0 ? `&filter=id=in=(${filter})` : ''\n }&attributes=${attributes}`,\n\n /**\n * Gets the endpoint for organization info.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.orgInfo('org123');\n * @ignore\n */\n orgInfo: (orgId: string) => `organization/${orgId}`,\n\n /**\n * Gets the endpoint for organization settings.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.orgSettings('org123');\n * @ignore\n */\n orgSettings: (orgId: string) => `organization/${orgId}/v2/organization-setting?agentView=true`,\n\n /**\n * Gets the endpoint for site info.\n * @param orgId - Organization ID.\n * @param siteId - Site ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.siteInfo('org123', 'site456');\n * @ignore\n */\n siteInfo: (orgId: string, siteId: string) => `organization/${orgId}/site/${siteId}`,\n\n /**\n * Gets the endpoint for tenant configuration data.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.tenantData('org123');\n * @ignore\n */\n tenantData: (orgId: string) => `organization/${orgId}/v2/tenant-configuration?agentView=true`,\n\n /**\n * Gets the endpoint for organization URL mapping.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.urlMapping('org123');\n * @ignore\n */\n urlMapping: (orgId: string) => `organization/${orgId}/v2/org-url-mapping?sort=name,ASC`,\n\n /**\n * Gets the endpoint for dial plan.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.dialPlan('org123');\n * @ignore\n */\n dialPlan: (orgId: string) => `organization/${orgId}/dial-plan?agentView=true`,\n /**\n * Gets the endpoint for listing AI feature flags.\n * @param orgId - Organization ID.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.aiFeatureFlags('org123');\n * @ignore\n */\n aiFeature: (orgId: string) => `organization/${orgId}/v2/ai-feature?page=0&pageSize=100`,\n\n /**\n * Gets the endpoint for the queue list with custom query parameters.\n * @param orgId - Organization ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.queueList('org123', 'page=0&pageSize=10');\n * @ignore\n */\n queueList: (orgId: string, queryParams: string) =>\n `/organization/${orgId}/v2/contact-service-queue?${queryParams}`,\n /**\n * Gets the endpoint for entry points list with custom query parameters.\n * @param orgId - Organization ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.entryPointList('org123', 'page=0&pageSize=10');\n * @ignore\n */\n entryPointList: (orgId: string, queryParams: string) =>\n `/organization/${orgId}/v2/entry-point?${queryParams}`,\n /**\n * Gets the endpoint for address book entries with custom query parameters.\n * @param orgId - Organization ID.\n * @param addressBookId - Address book ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.addressBookEntries('org123', 'book456', 'page=0&pageSize=10');\n * @ignore\n */\n addressBookEntries: (orgId: string, addressBookId: string, queryParams: string) =>\n `/organization/${orgId}/v2/address-book/${addressBookId}/entry?${queryParams}`,\n\n /**\n * Gets the endpoint for outdial ANI entries with custom query parameters.\n * @param orgId - Organization ID.\n * @param outdialANI - Outdial ANI ID.\n * @param queryParams - Query parameters string.\n * @returns The endpoint URL string.\n * @public\n * @example\n * const url = endPointMap.outdialAniEntries('org123', 'ani456', 'page=0&pageSize=10');\n * @ignore\n */\n outdialAniEntries: (orgId: string, outdialANI: string, queryParams: string) =>\n `organization/${orgId}/v2/outdial-ani/${outdialANI}/entry${\n queryParams ? `?${queryParams}` : ''\n }`,\n};\n"],"mappings":"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","ignoreList":[]}
@@ -42,6 +42,7 @@ class AgentConfigService {
42
42
  const orgSettingsPromise = this.getOrganizationSetting(orgId);
43
43
  const tenantDataPromise = this.getTenantData(orgId);
44
44
  const urlMappingPromise = this.getURLMapping(orgId);
45
+ const aiFeatureFlagsPromise = this.getAIFeatureFlags(orgId);
45
46
  const auxCodesPromise = this.getAllAuxCodes(orgId, _constants3.DEFAULT_PAGE_SIZE, [], _constants3.DEFAULT_AUXCODE_ATTRIBUTES);
46
47
  const userConfigData = await userConfigPromise;
47
48
  _loggerProxy.default.info(`Fetched user data, userId: ${userConfigData.ciUserId}`, {
@@ -52,7 +53,7 @@ class AgentConfigService {
52
53
  const siteInfoPromise = this.getSiteInfo(orgId, userConfigData.siteId);
53
54
  const userDialPlanPromise = agentProfilePromise.then(agentProfileConfigData => agentProfileConfigData.dialPlanEnabled ? this.getDialPlanData(orgId) : []);
54
55
  const userTeamPromise = userConfigData.teamIds ? this.getAllTeams(orgId, _constants3.DEFAULT_PAGE_SIZE, userConfigData.teamIds) : Promise.resolve([]);
55
- const [agentProfileConfigData, siteInfo, userDialPlanData, userTeamData, orgInfo, orgSettingsData, tenantData, urlMappingData, auxCodesData] = await Promise.all([agentProfilePromise, siteInfoPromise, userDialPlanPromise, userTeamPromise, orgInfoPromise, orgSettingsPromise, tenantDataPromise, urlMappingPromise, auxCodesPromise]);
56
+ const [agentProfileConfigData, siteInfo, userDialPlanData, userTeamData, orgInfo, orgSettingsData, tenantData, urlMappingData, aiFeatureFlagsData, auxCodesData] = await Promise.all([agentProfilePromise, siteInfoPromise, userDialPlanPromise, userTeamPromise, orgInfoPromise, orgSettingsPromise, tenantDataPromise, urlMappingPromise, aiFeatureFlagsPromise, auxCodesPromise]);
56
57
  const multimediaProfileId = userConfigData.multimediaProfileId || userTeamData[0]?.multiMediaProfileId || siteInfo.multimediaProfileId;
57
58
  _loggerProxy.default.info('Fetched all required data', {
58
59
  module: _constants2.CONFIG_FILE_NAME,
@@ -68,7 +69,8 @@ class AgentConfigService {
68
69
  agentProfileData: agentProfileConfigData,
69
70
  dialPlanData: userDialPlanData,
70
71
  urlMapping: urlMappingData,
71
- multimediaProfileId
72
+ multimediaProfileId,
73
+ aiFeatureFlags: aiFeatureFlagsData
72
74
  });
73
75
  _loggerProxy.default.info('Parsing completed for agent-config', {
74
76
  module: _constants2.CONFIG_FILE_NAME,
@@ -526,6 +528,43 @@ class AgentConfigService {
526
528
  }
527
529
  }
528
530
 
531
+ /**
532
+ * Fetches AI feature resources for the organization.
533
+ * @ignore
534
+ * @param {string} orgId - organization ID for which AI feature resources are to be fetched.
535
+ * @returns {Promise<AIFeatureFlagsResponse>} - AI feature resources response.
536
+ * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.
537
+ * @private
538
+ */
539
+ async getAIFeatureFlags(orgId) {
540
+ _loggerProxy.default.info('Fetching AI feature resources', {
541
+ module: _constants2.CONFIG_FILE_NAME,
542
+ method: _constants3.METHODS.GET_AI_FEATURE_FLAGS
543
+ });
544
+ try {
545
+ const resource = _constants3.endPointMap.aiFeature(orgId);
546
+ const response = await this.webexReq.request({
547
+ service: _constants.WCC_API_GATEWAY,
548
+ resource,
549
+ method: _types.HTTP_METHODS.GET
550
+ });
551
+ if (response.statusCode !== 200) {
552
+ throw new Error(`API call failed with ${response.statusCode}`);
553
+ }
554
+ _loggerProxy.default.log('getAIFeatureFlags api success.', {
555
+ module: _constants2.CONFIG_FILE_NAME,
556
+ method: _constants3.METHODS.GET_AI_FEATURE_FLAGS
557
+ });
558
+ return Promise.resolve(response.body);
559
+ } catch (error) {
560
+ _loggerProxy.default.error(`getAIFeatureFlags API call failed with ${error}`, {
561
+ module: _constants2.CONFIG_FILE_NAME,
562
+ method: _constants3.METHODS.GET_AI_FEATURE_FLAGS
563
+ });
564
+ throw error;
565
+ }
566
+ }
567
+
529
568
  /**
530
569
  * Fetches the dial plan data for the given orgId.
531
570
  * @ignore
@@ -1 +1 @@
1
- {"version":3,"names":["_types","require","_loggerProxy","_interopRequireDefault","_WebexRequest","_constants","_constants2","_Util","_constants3","e","__esModule","default","AgentConfigService","constructor","webexReq","WebexRequest","getInstance","getAgentConfig","orgId","agentId","userConfigPromise","getUserUsingCI","orgInfoPromise","getOrgInfo","orgSettingsPromise","getOrganizationSetting","tenantDataPromise","getTenantData","urlMappingPromise","getURLMapping","auxCodesPromise","getAllAuxCodes","DEFAULT_PAGE_SIZE","DEFAULT_AUXCODE_ATTRIBUTES","userConfigData","LoggerProxy","info","ciUserId","module","CONFIG_FILE_NAME","method","METHODS","GET_AGENT_CONFIG","agentProfilePromise","getDesktopProfileById","agentProfileId","siteInfoPromise","getSiteInfo","siteId","userDialPlanPromise","then","agentProfileConfigData","dialPlanEnabled","getDialPlanData","userTeamPromise","teamIds","getAllTeams","Promise","resolve","siteInfo","userDialPlanData","userTeamData","orgInfo","orgSettingsData","tenantData","urlMappingData","auxCodesData","all","multimediaProfileId","multiMediaProfileId","response","parseAgentConfigs","userData","teamData","orgInfoData","auxCodes","agentProfileData","dialPlanData","urlMapping","error","GET_USER_USING_CI","resource","endPointMap","userByCI","request","service","WCC_API_GATEWAY","HTTP_METHODS","GET","statusCode","Error","log","body","desktopProfileId","GET_DESKTOP_PROFILE_BY_ID","desktopProfile","getMultimediaProfileById","GET_MULTIMEDIA_PROFILE_BY_ID","multimediaProfile","getListOfTeams","page","pageSize","filter","GET_LIST_OF_TEAMS","listTeams","allTeams","DEFAULT_PAGE","firstResponse","totalPages","meta","concat","data","requests","push","responses","GET_ALL_TEAMS","getListOfAuxCodes","attributes","GET_LIST_OF_AUX_CODES","listAuxCodes","allAuxCodes","promises","forEach","GET_ALL_AUX_CODES","GET_SITE_INFO","GET_ORG_INFO","orgSettings","GET_ORGANIZATION_SETTING","GET_TENANT_DATA","GET_URL_MAPPING","dialPlan","GET_DIAL_PLAN_DATA","getOutdialAniEntries","params","outdialANI","search","MAIN_METHODS","GET_OUTDIAL_ANI_ENTRIES","queryParams","undefined","queryString","length","join","outdialAniEntries","exports"],"sources":["index.ts"],"sourcesContent":["/**\n * @packageDocumentation\n * @module AgentConfigService\n */\n\nimport {HTTP_METHODS} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport {\n DesktopProfileResponse,\n ListAuxCodesResponse,\n AgentResponse,\n TenantData,\n OrgInfo,\n OrgSettings,\n URLMapping,\n TeamList,\n DialPlanEntity,\n Profile,\n ListTeamsResponse,\n AuxCode,\n MultimediaProfileResponse,\n SiteInfo,\n OutdialAniEntriesResponse,\n OutdialAniParams,\n} from './types';\nimport WebexRequest from '../core/WebexRequest';\nimport {WCC_API_GATEWAY} from '../constants';\nimport {CONFIG_FILE_NAME, METHODS as MAIN_METHODS} from '../../constants';\nimport {parseAgentConfigs} from './Util';\nimport {\n DEFAULT_AUXCODE_ATTRIBUTES,\n DEFAULT_PAGE,\n DEFAULT_PAGE_SIZE,\n endPointMap,\n METHODS,\n} from './constants';\n\n/**\n * The AgentConfigService class provides methods to fetch agent configuration data.\n * @private\n * @ignore\n */\nexport default class AgentConfigService {\n private webexReq: WebexRequest;\n constructor() {\n this.webexReq = WebexRequest.getInstance();\n }\n\n /**\n * Fetches the agent configuration data for the given orgId and agentId.\n * @param {string} orgId - organization ID for which the agent configuration is to be fetched.\n * @param {string} agentId - agent ID for which the configuration is to be fetched.\n * @returns {Promise<Profile>} - A promise that resolves to the agent configuration profile.\n * @throws {Error} - Throws an error if any API call fails or if the response status is not 200.\n * @public\n */\n public async getAgentConfig(orgId: string, agentId: string): Promise<Profile> {\n try {\n const userConfigPromise = this.getUserUsingCI(orgId, agentId);\n const orgInfoPromise = this.getOrgInfo(orgId);\n const orgSettingsPromise = this.getOrganizationSetting(orgId);\n const tenantDataPromise = this.getTenantData(orgId);\n const urlMappingPromise = this.getURLMapping(orgId);\n const auxCodesPromise = this.getAllAuxCodes(\n orgId,\n DEFAULT_PAGE_SIZE,\n [],\n DEFAULT_AUXCODE_ATTRIBUTES\n );\n\n const userConfigData = await userConfigPromise;\n LoggerProxy.info(`Fetched user data, userId: ${userConfigData.ciUserId}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n\n const agentProfilePromise = this.getDesktopProfileById(orgId, userConfigData.agentProfileId);\n const siteInfoPromise = this.getSiteInfo(orgId, userConfigData.siteId);\n\n const userDialPlanPromise = agentProfilePromise.then((agentProfileConfigData) =>\n agentProfileConfigData.dialPlanEnabled ? this.getDialPlanData(orgId) : []\n );\n\n const userTeamPromise = userConfigData.teamIds\n ? this.getAllTeams(orgId, DEFAULT_PAGE_SIZE, userConfigData.teamIds)\n : Promise.resolve([]);\n\n const [\n agentProfileConfigData,\n siteInfo,\n userDialPlanData,\n userTeamData,\n orgInfo,\n orgSettingsData,\n tenantData,\n urlMappingData,\n auxCodesData,\n ] = await Promise.all([\n agentProfilePromise,\n siteInfoPromise,\n userDialPlanPromise,\n userTeamPromise,\n orgInfoPromise,\n orgSettingsPromise,\n tenantDataPromise,\n urlMappingPromise,\n auxCodesPromise,\n ]);\n\n const multimediaProfileId =\n userConfigData.multimediaProfileId ||\n userTeamData[0]?.multiMediaProfileId ||\n siteInfo.multimediaProfileId;\n\n LoggerProxy.info('Fetched all required data', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n\n const response = parseAgentConfigs({\n userData: userConfigData,\n teamData: userTeamData,\n tenantData,\n orgInfoData: orgInfo,\n auxCodes: auxCodesData,\n orgSettingsData,\n agentProfileData: agentProfileConfigData,\n dialPlanData: userDialPlanData,\n urlMapping: urlMappingData,\n multimediaProfileId,\n });\n\n LoggerProxy.info('Parsing completed for agent-config', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n LoggerProxy.info('Fetched configuration data successfully', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n\n return response;\n } catch (error) {\n LoggerProxy.error(`getAgentConfig call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the agent configuration data for the given orgId and agentId.\n * @ignore\n * @param {string} orgId - organization ID for which the agent configuration is to be fetched.\n * @param {string} agentId - agent ID for which the configuration is to be fetched.\n * @returns {Promise<AgentResponse>} - A promise that resolves to the agent configuration response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getUserUsingCI(orgId: string, agentId: string): Promise<AgentResponse> {\n LoggerProxy.info('Fetching user data using CI', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_USER_USING_CI,\n });\n\n try {\n const resource = endPointMap.userByCI(orgId, agentId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getUserUsingCI api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_USER_USING_CI,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getUserUsingCI API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_USER_USING_CI,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the desktop profile data for the given orgId and desktopProfileId.\n * @ignore\n * @param {string} orgId - organization ID for which the desktop profile is to be fetched.\n * @param {string} desktopProfileId - desktop profile ID for which the data is to be fetched.\n * @returns {Promise<DesktopProfileResponse>} - A promise that resolves to the desktop profile response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getDesktopProfileById(\n orgId: string,\n desktopProfileId: string\n ): Promise<DesktopProfileResponse> {\n LoggerProxy.info('Fetching desktop profile', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DESKTOP_PROFILE_BY_ID,\n });\n\n try {\n const resource = endPointMap.desktopProfile(orgId, desktopProfileId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getDesktopProfileById api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DESKTOP_PROFILE_BY_ID,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getDesktopProfileById API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DESKTOP_PROFILE_BY_ID,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the multimedia profile data for the given orgId and multimediaProfileId.\n * @ignore\n * @param {string} orgId - organization ID for which the multimedia profile is to be fetched.\n * @param {string} multimediaProfileId - multimedia profile ID for which the data is to be fetched.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @returns {Promise<MultimediaProfileResponse>} - A promise that resolves to the multimedia profile response.\n * @private\n */\n public async getMultimediaProfileById(\n orgId: string,\n multimediaProfileId: string\n ): Promise<MultimediaProfileResponse> {\n LoggerProxy.info('Fetching multimedia profile', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_MULTIMEDIA_PROFILE_BY_ID,\n });\n\n try {\n const resource = endPointMap.multimediaProfile(orgId, multimediaProfileId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getMultimediaProfileById API success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_MULTIMEDIA_PROFILE_BY_ID,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getMultimediaProfileById API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_MULTIMEDIA_PROFILE_BY_ID,\n });\n throw error;\n }\n }\n\n /**\n * fetches the list of teams for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the teams are to be fetched.\n * @param {number} page - the page number to fetch.\n * @param {number} pageSize - the number of teams to fetch per page.\n * @param {string[]} filter - optional filter criteria for the teams.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<ListTeamsResponse>} - A promise that resolves to the list of teams response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getListOfTeams(\n orgId: string,\n page: number,\n pageSize: number,\n filter: string[]\n ): Promise<ListTeamsResponse> {\n LoggerProxy.info('Fetching list of teams', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_TEAMS,\n });\n\n try {\n const resource = endPointMap.listTeams(orgId, page, pageSize, filter);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getListOfTeams api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_TEAMS,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getListOfTeams API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_TEAMS,\n });\n throw error;\n }\n }\n\n /**\n * Fetches all teams from all pages for the given orgId\n * @ignore\n * @param {string} orgId - organization ID for which the teams are to be fetched.\n * @param {number} pageSize - the number of teams to fetch per page.\n * @param {string[]} filter - optional filter criteria for the teams.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<TeamList[]>} - A promise that resolves to the list of teams.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getAllTeams(orgId: string, pageSize: number, filter: string[]): Promise<TeamList[]> {\n try {\n let allTeams: TeamList[] = [];\n let page = DEFAULT_PAGE;\n const firstResponse = await this.getListOfTeams(orgId, page, pageSize, filter);\n const totalPages = firstResponse.meta.totalPages;\n allTeams = allTeams.concat(firstResponse.data);\n const requests = [];\n for (page = DEFAULT_PAGE + 1; page < totalPages; page += 1) {\n requests.push(this.getListOfTeams(orgId, page, pageSize, filter));\n }\n const responses = await Promise.all(requests);\n\n for (const response of responses) {\n allTeams = allTeams.concat(response.data);\n }\n\n return allTeams;\n } catch (error) {\n LoggerProxy.error(`getAllTeams API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ALL_TEAMS,\n });\n throw error;\n }\n }\n\n /**\n * fetches the list of aux codes for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the aux codes are to be fetched.\n * @param {number} page - the page number to fetch.\n * @param {number} pageSize - the number of aux codes to fetch per page.\n * @param {string[]} filter - optional filter criteria for the aux codes.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<ListAuxCodesResponse>} - A promise that resolves to the list of aux codes response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getListOfAuxCodes(\n orgId: string,\n page: number,\n pageSize: number,\n filter: string[],\n attributes: string[]\n ): Promise<ListAuxCodesResponse> {\n LoggerProxy.info('Fetching list of aux codes', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_AUX_CODES,\n });\n\n try {\n const resource = endPointMap.listAuxCodes(orgId, page, pageSize, filter, attributes);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getListOfAuxCodes api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_AUX_CODES,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getListOfAuxCodes API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_AUX_CODES,\n });\n throw error;\n }\n }\n\n /**\n * Fetches all aux codes from all pages for the given orgId\n * @ignore\n * @param {string} orgId - organization ID for which the aux codes are to be fetched.\n * @param {number} pageSize - the number of aux codes to fetch per page.\n * @param {string[]} filter - optional filter criteria for the aux codes.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<AuxCode[]>} - A promise that resolves to the list of aux codes.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getAllAuxCodes(\n orgId: string,\n pageSize: number,\n filter: string[],\n attributes: string[]\n ): Promise<AuxCode[]> {\n try {\n let allAuxCodes: AuxCode[] = [];\n let page = DEFAULT_PAGE;\n\n const firstResponse = await this.getListOfAuxCodes(orgId, page, pageSize, filter, attributes);\n allAuxCodes = allAuxCodes.concat(firstResponse.data);\n const totalPages = firstResponse.meta.totalPages;\n\n const promises: Promise<ListAuxCodesResponse>[] = [];\n for (page = DEFAULT_PAGE + 1; page < totalPages; page += 1) {\n promises.push(this.getListOfAuxCodes(orgId, page, pageSize, filter, attributes));\n }\n\n const responses = await Promise.all(promises);\n\n responses.forEach((response) => {\n allAuxCodes = allAuxCodes.concat(response.data);\n });\n\n return allAuxCodes;\n } catch (error) {\n LoggerProxy.error(`getAllAuxCodes API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ALL_AUX_CODES,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the site data for the given orgId and siteId.\n * @ignore\n * @param {string} orgId - organization ID for which the site info is to be fetched.\n * @param {string} siteId - site ID for which the data is to be fetched.\n * @returns {Promise<SiteInfo>} - A promise that resolves to the site info response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getSiteInfo(orgId: string, siteId: string): Promise<SiteInfo> {\n LoggerProxy.info('Fetching site information', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_SITE_INFO,\n });\n try {\n const resource = endPointMap.siteInfo(orgId, siteId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getSiteInfo api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_SITE_INFO,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getSiteInfo API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_SITE_INFO,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the organization info for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the organization info is to be fetched.\n * @returns {Promise<OrgInfo>} - A promise that resolves to the organization info response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getOrgInfo(orgId: string): Promise<OrgInfo> {\n try {\n const resource = endPointMap.orgInfo(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getOrgInfo api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORG_INFO,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getOrgInfo API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORG_INFO,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the organization settings for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the organization settings are to be fetched.\n * @returns {Promise<OrgSettings>} - A promise that resolves to the organization settings response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getOrganizationSetting(orgId: string): Promise<OrgSettings> {\n try {\n const resource = endPointMap.orgSettings(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getOrganizationSetting api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORGANIZATION_SETTING,\n });\n\n return Promise.resolve(response.body.data[0]);\n } catch (error) {\n LoggerProxy.error(`getOrganizationSetting API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORGANIZATION_SETTING,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the tenant data for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the tenant data is to be fetched.\n * @returns {Promise<TenantData>} - A promise that resolves to the tenant data response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getTenantData(orgId: string): Promise<TenantData> {\n try {\n const resource = endPointMap.tenantData(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getTenantData api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_TENANT_DATA,\n });\n\n return Promise.resolve(response.body.data[0]);\n } catch (error) {\n LoggerProxy.error(`getTenantData API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_TENANT_DATA,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the URL mapping data for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the URL mapping is to be fetched.\n * @returns {Promise<URLMapping[]>} - A promise that resolves to the URL mapping response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getURLMapping(orgId: string): Promise<URLMapping[]> {\n try {\n const resource = endPointMap.urlMapping(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getURLMapping api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_URL_MAPPING,\n });\n\n return Promise.resolve(response.body.data);\n } catch (error) {\n LoggerProxy.error(`getURLMapping API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_URL_MAPPING,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the dial plan data for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the dial plan data is to be fetched.\n * @returns {Promise<DialPlanEntity[]>} - A promise that resolves to the dial plan data response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getDialPlanData(orgId: string): Promise<DialPlanEntity[]> {\n try {\n const resource = endPointMap.dialPlan(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getDialPlanData api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DIAL_PLAN_DATA,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getDialPlanData API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DIAL_PLAN_DATA,\n });\n throw error;\n }\n }\n\n // getQueues removed - use Queue instead\n\n /**\n * Fetches outdial ANI (Automatic Number Identification) entries for the given orgId and outdial ANI ID.\n * @ignore\n * @param {string} orgId - organization ID for which the outdial ANI entries are to be fetched.\n * @param {OutdialAniParams} params - parameters object containing outdialANI and optional pagination/filtering options\n * @returns {Promise<OutdialAniEntriesResponse>} - A promise that resolves to the outdial ANI entries response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getOutdialAniEntries(\n orgId: string,\n params: OutdialAniParams\n ): Promise<OutdialAniEntriesResponse> {\n const {outdialANI, page, pageSize, search, filter, attributes} = params;\n\n LoggerProxy.info('Fetching outdial ANI entries', {\n module: CONFIG_FILE_NAME,\n method: MAIN_METHODS.GET_OUTDIAL_ANI_ENTRIES,\n });\n\n try {\n const queryParams = [];\n if (page !== undefined) queryParams.push(`page=${page}`);\n if (pageSize !== undefined) queryParams.push(`pageSize=${pageSize}`);\n if (search) queryParams.push(`search=${search}`);\n if (filter) queryParams.push(`filter=${filter}`);\n if (attributes) queryParams.push(`attributes=${attributes}`);\n\n const queryString = queryParams.length > 0 ? queryParams.join('&') : '';\n const resource = endPointMap.outdialAniEntries(orgId, outdialANI, queryString);\n\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n LoggerProxy.log('getOutdialAniEntries API success.', {\n module: CONFIG_FILE_NAME,\n method: MAIN_METHODS.GET_OUTDIAL_ANI_ENTRIES,\n });\n\n return response.body?.data;\n } catch (error) {\n LoggerProxy.error(`getOutdialAniEntries API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: MAIN_METHODS.GET_OUTDIAL_ANI_ENTRIES,\n });\n throw error;\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_types","require","_loggerProxy","_interopRequireDefault","_WebexRequest","_constants","_constants2","_Util","_constants3","e","__esModule","default","AgentConfigService","constructor","webexReq","WebexRequest","getInstance","getAgentConfig","orgId","agentId","userConfigPromise","getUserUsingCI","orgInfoPromise","getOrgInfo","orgSettingsPromise","getOrganizationSetting","tenantDataPromise","getTenantData","urlMappingPromise","getURLMapping","aiFeatureFlagsPromise","getAIFeatureFlags","auxCodesPromise","getAllAuxCodes","DEFAULT_PAGE_SIZE","DEFAULT_AUXCODE_ATTRIBUTES","userConfigData","LoggerProxy","info","ciUserId","module","CONFIG_FILE_NAME","method","METHODS","GET_AGENT_CONFIG","agentProfilePromise","getDesktopProfileById","agentProfileId","siteInfoPromise","getSiteInfo","siteId","userDialPlanPromise","then","agentProfileConfigData","dialPlanEnabled","getDialPlanData","userTeamPromise","teamIds","getAllTeams","Promise","resolve","siteInfo","userDialPlanData","userTeamData","orgInfo","orgSettingsData","tenantData","urlMappingData","aiFeatureFlagsData","auxCodesData","all","multimediaProfileId","multiMediaProfileId","response","parseAgentConfigs","userData","teamData","orgInfoData","auxCodes","agentProfileData","dialPlanData","urlMapping","aiFeatureFlags","error","GET_USER_USING_CI","resource","endPointMap","userByCI","request","service","WCC_API_GATEWAY","HTTP_METHODS","GET","statusCode","Error","log","body","desktopProfileId","GET_DESKTOP_PROFILE_BY_ID","desktopProfile","getMultimediaProfileById","GET_MULTIMEDIA_PROFILE_BY_ID","multimediaProfile","getListOfTeams","page","pageSize","filter","GET_LIST_OF_TEAMS","listTeams","allTeams","DEFAULT_PAGE","firstResponse","totalPages","meta","concat","data","requests","push","responses","GET_ALL_TEAMS","getListOfAuxCodes","attributes","GET_LIST_OF_AUX_CODES","listAuxCodes","allAuxCodes","promises","forEach","GET_ALL_AUX_CODES","GET_SITE_INFO","GET_ORG_INFO","orgSettings","GET_ORGANIZATION_SETTING","GET_TENANT_DATA","GET_URL_MAPPING","GET_AI_FEATURE_FLAGS","aiFeature","dialPlan","GET_DIAL_PLAN_DATA","getOutdialAniEntries","params","outdialANI","search","MAIN_METHODS","GET_OUTDIAL_ANI_ENTRIES","queryParams","undefined","queryString","length","join","outdialAniEntries","exports"],"sources":["index.ts"],"sourcesContent":["/**\n * @packageDocumentation\n * @module AgentConfigService\n */\n\nimport {HTTP_METHODS} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport {\n DesktopProfileResponse,\n ListAuxCodesResponse,\n AgentResponse,\n TenantData,\n OrgInfo,\n OrgSettings,\n URLMapping,\n TeamList,\n DialPlanEntity,\n Profile,\n ListTeamsResponse,\n AuxCode,\n MultimediaProfileResponse,\n SiteInfo,\n OutdialAniEntriesResponse,\n OutdialAniParams,\n AIFeatureFlagsResponse,\n} from './types';\nimport WebexRequest from '../core/WebexRequest';\nimport {WCC_API_GATEWAY} from '../constants';\nimport {CONFIG_FILE_NAME, METHODS as MAIN_METHODS} from '../../constants';\nimport {parseAgentConfigs} from './Util';\nimport {\n DEFAULT_AUXCODE_ATTRIBUTES,\n DEFAULT_PAGE,\n DEFAULT_PAGE_SIZE,\n endPointMap,\n METHODS,\n} from './constants';\n\n/**\n * The AgentConfigService class provides methods to fetch agent configuration data.\n * @private\n * @ignore\n */\nexport default class AgentConfigService {\n private webexReq: WebexRequest;\n constructor() {\n this.webexReq = WebexRequest.getInstance();\n }\n\n /**\n * Fetches the agent configuration data for the given orgId and agentId.\n * @param {string} orgId - organization ID for which the agent configuration is to be fetched.\n * @param {string} agentId - agent ID for which the configuration is to be fetched.\n * @returns {Promise<Profile>} - A promise that resolves to the agent configuration profile.\n * @throws {Error} - Throws an error if any API call fails or if the response status is not 200.\n * @public\n */\n public async getAgentConfig(orgId: string, agentId: string): Promise<Profile> {\n try {\n const userConfigPromise = this.getUserUsingCI(orgId, agentId);\n const orgInfoPromise = this.getOrgInfo(orgId);\n const orgSettingsPromise = this.getOrganizationSetting(orgId);\n const tenantDataPromise = this.getTenantData(orgId);\n const urlMappingPromise = this.getURLMapping(orgId);\n const aiFeatureFlagsPromise = this.getAIFeatureFlags(orgId);\n const auxCodesPromise = this.getAllAuxCodes(\n orgId,\n DEFAULT_PAGE_SIZE,\n [],\n DEFAULT_AUXCODE_ATTRIBUTES\n );\n\n const userConfigData = await userConfigPromise;\n LoggerProxy.info(`Fetched user data, userId: ${userConfigData.ciUserId}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n\n const agentProfilePromise = this.getDesktopProfileById(orgId, userConfigData.agentProfileId);\n const siteInfoPromise = this.getSiteInfo(orgId, userConfigData.siteId);\n\n const userDialPlanPromise = agentProfilePromise.then((agentProfileConfigData) =>\n agentProfileConfigData.dialPlanEnabled ? this.getDialPlanData(orgId) : []\n );\n\n const userTeamPromise = userConfigData.teamIds\n ? this.getAllTeams(orgId, DEFAULT_PAGE_SIZE, userConfigData.teamIds)\n : Promise.resolve([]);\n\n const [\n agentProfileConfigData,\n siteInfo,\n userDialPlanData,\n userTeamData,\n orgInfo,\n orgSettingsData,\n tenantData,\n urlMappingData,\n aiFeatureFlagsData,\n auxCodesData,\n ] = await Promise.all([\n agentProfilePromise,\n siteInfoPromise,\n userDialPlanPromise,\n userTeamPromise,\n orgInfoPromise,\n orgSettingsPromise,\n tenantDataPromise,\n urlMappingPromise,\n aiFeatureFlagsPromise,\n auxCodesPromise,\n ]);\n const multimediaProfileId =\n userConfigData.multimediaProfileId ||\n userTeamData[0]?.multiMediaProfileId ||\n siteInfo.multimediaProfileId;\n\n LoggerProxy.info('Fetched all required data', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n\n const response = parseAgentConfigs({\n userData: userConfigData,\n teamData: userTeamData,\n tenantData,\n orgInfoData: orgInfo,\n auxCodes: auxCodesData,\n orgSettingsData,\n agentProfileData: agentProfileConfigData,\n dialPlanData: userDialPlanData,\n urlMapping: urlMappingData,\n multimediaProfileId,\n aiFeatureFlags: aiFeatureFlagsData,\n });\n\n LoggerProxy.info('Parsing completed for agent-config', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n LoggerProxy.info('Fetched configuration data successfully', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n\n return response;\n } catch (error) {\n LoggerProxy.error(`getAgentConfig call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AGENT_CONFIG,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the agent configuration data for the given orgId and agentId.\n * @ignore\n * @param {string} orgId - organization ID for which the agent configuration is to be fetched.\n * @param {string} agentId - agent ID for which the configuration is to be fetched.\n * @returns {Promise<AgentResponse>} - A promise that resolves to the agent configuration response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getUserUsingCI(orgId: string, agentId: string): Promise<AgentResponse> {\n LoggerProxy.info('Fetching user data using CI', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_USER_USING_CI,\n });\n\n try {\n const resource = endPointMap.userByCI(orgId, agentId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getUserUsingCI api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_USER_USING_CI,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getUserUsingCI API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_USER_USING_CI,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the desktop profile data for the given orgId and desktopProfileId.\n * @ignore\n * @param {string} orgId - organization ID for which the desktop profile is to be fetched.\n * @param {string} desktopProfileId - desktop profile ID for which the data is to be fetched.\n * @returns {Promise<DesktopProfileResponse>} - A promise that resolves to the desktop profile response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getDesktopProfileById(\n orgId: string,\n desktopProfileId: string\n ): Promise<DesktopProfileResponse> {\n LoggerProxy.info('Fetching desktop profile', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DESKTOP_PROFILE_BY_ID,\n });\n\n try {\n const resource = endPointMap.desktopProfile(orgId, desktopProfileId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getDesktopProfileById api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DESKTOP_PROFILE_BY_ID,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getDesktopProfileById API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DESKTOP_PROFILE_BY_ID,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the multimedia profile data for the given orgId and multimediaProfileId.\n * @ignore\n * @param {string} orgId - organization ID for which the multimedia profile is to be fetched.\n * @param {string} multimediaProfileId - multimedia profile ID for which the data is to be fetched.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @returns {Promise<MultimediaProfileResponse>} - A promise that resolves to the multimedia profile response.\n * @private\n */\n public async getMultimediaProfileById(\n orgId: string,\n multimediaProfileId: string\n ): Promise<MultimediaProfileResponse> {\n LoggerProxy.info('Fetching multimedia profile', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_MULTIMEDIA_PROFILE_BY_ID,\n });\n\n try {\n const resource = endPointMap.multimediaProfile(orgId, multimediaProfileId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getMultimediaProfileById API success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_MULTIMEDIA_PROFILE_BY_ID,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getMultimediaProfileById API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_MULTIMEDIA_PROFILE_BY_ID,\n });\n throw error;\n }\n }\n\n /**\n * fetches the list of teams for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the teams are to be fetched.\n * @param {number} page - the page number to fetch.\n * @param {number} pageSize - the number of teams to fetch per page.\n * @param {string[]} filter - optional filter criteria for the teams.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<ListTeamsResponse>} - A promise that resolves to the list of teams response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getListOfTeams(\n orgId: string,\n page: number,\n pageSize: number,\n filter: string[]\n ): Promise<ListTeamsResponse> {\n LoggerProxy.info('Fetching list of teams', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_TEAMS,\n });\n\n try {\n const resource = endPointMap.listTeams(orgId, page, pageSize, filter);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getListOfTeams api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_TEAMS,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getListOfTeams API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_TEAMS,\n });\n throw error;\n }\n }\n\n /**\n * Fetches all teams from all pages for the given orgId\n * @ignore\n * @param {string} orgId - organization ID for which the teams are to be fetched.\n * @param {number} pageSize - the number of teams to fetch per page.\n * @param {string[]} filter - optional filter criteria for the teams.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<TeamList[]>} - A promise that resolves to the list of teams.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getAllTeams(orgId: string, pageSize: number, filter: string[]): Promise<TeamList[]> {\n try {\n let allTeams: TeamList[] = [];\n let page = DEFAULT_PAGE;\n const firstResponse = await this.getListOfTeams(orgId, page, pageSize, filter);\n const totalPages = firstResponse.meta.totalPages;\n allTeams = allTeams.concat(firstResponse.data);\n const requests = [];\n for (page = DEFAULT_PAGE + 1; page < totalPages; page += 1) {\n requests.push(this.getListOfTeams(orgId, page, pageSize, filter));\n }\n const responses = await Promise.all(requests);\n\n for (const response of responses) {\n allTeams = allTeams.concat(response.data);\n }\n\n return allTeams;\n } catch (error) {\n LoggerProxy.error(`getAllTeams API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ALL_TEAMS,\n });\n throw error;\n }\n }\n\n /**\n * fetches the list of aux codes for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the aux codes are to be fetched.\n * @param {number} page - the page number to fetch.\n * @param {number} pageSize - the number of aux codes to fetch per page.\n * @param {string[]} filter - optional filter criteria for the aux codes.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<ListAuxCodesResponse>} - A promise that resolves to the list of aux codes response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getListOfAuxCodes(\n orgId: string,\n page: number,\n pageSize: number,\n filter: string[],\n attributes: string[]\n ): Promise<ListAuxCodesResponse> {\n LoggerProxy.info('Fetching list of aux codes', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_AUX_CODES,\n });\n\n try {\n const resource = endPointMap.listAuxCodes(orgId, page, pageSize, filter, attributes);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getListOfAuxCodes api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_AUX_CODES,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getListOfAuxCodes API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_LIST_OF_AUX_CODES,\n });\n throw error;\n }\n }\n\n /**\n * Fetches all aux codes from all pages for the given orgId\n * @ignore\n * @param {string} orgId - organization ID for which the aux codes are to be fetched.\n * @param {number} pageSize - the number of aux codes to fetch per page.\n * @param {string[]} filter - optional filter criteria for the aux codes.\n * @param {string[]} attributes - optional attributes to include in the response.\n * @returns {Promise<AuxCode[]>} - A promise that resolves to the list of aux codes.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getAllAuxCodes(\n orgId: string,\n pageSize: number,\n filter: string[],\n attributes: string[]\n ): Promise<AuxCode[]> {\n try {\n let allAuxCodes: AuxCode[] = [];\n let page = DEFAULT_PAGE;\n\n const firstResponse = await this.getListOfAuxCodes(orgId, page, pageSize, filter, attributes);\n allAuxCodes = allAuxCodes.concat(firstResponse.data);\n const totalPages = firstResponse.meta.totalPages;\n\n const promises: Promise<ListAuxCodesResponse>[] = [];\n for (page = DEFAULT_PAGE + 1; page < totalPages; page += 1) {\n promises.push(this.getListOfAuxCodes(orgId, page, pageSize, filter, attributes));\n }\n\n const responses = await Promise.all(promises);\n\n responses.forEach((response) => {\n allAuxCodes = allAuxCodes.concat(response.data);\n });\n\n return allAuxCodes;\n } catch (error) {\n LoggerProxy.error(`getAllAuxCodes API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ALL_AUX_CODES,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the site data for the given orgId and siteId.\n * @ignore\n * @param {string} orgId - organization ID for which the site info is to be fetched.\n * @param {string} siteId - site ID for which the data is to be fetched.\n * @returns {Promise<SiteInfo>} - A promise that resolves to the site info response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getSiteInfo(orgId: string, siteId: string): Promise<SiteInfo> {\n LoggerProxy.info('Fetching site information', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_SITE_INFO,\n });\n try {\n const resource = endPointMap.siteInfo(orgId, siteId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getSiteInfo api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_SITE_INFO,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getSiteInfo API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_SITE_INFO,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the organization info for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the organization info is to be fetched.\n * @returns {Promise<OrgInfo>} - A promise that resolves to the organization info response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getOrgInfo(orgId: string): Promise<OrgInfo> {\n try {\n const resource = endPointMap.orgInfo(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getOrgInfo api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORG_INFO,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getOrgInfo API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORG_INFO,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the organization settings for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the organization settings are to be fetched.\n * @returns {Promise<OrgSettings>} - A promise that resolves to the organization settings response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getOrganizationSetting(orgId: string): Promise<OrgSettings> {\n try {\n const resource = endPointMap.orgSettings(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getOrganizationSetting api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORGANIZATION_SETTING,\n });\n\n return Promise.resolve(response.body.data[0]);\n } catch (error) {\n LoggerProxy.error(`getOrganizationSetting API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_ORGANIZATION_SETTING,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the tenant data for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the tenant data is to be fetched.\n * @returns {Promise<TenantData>} - A promise that resolves to the tenant data response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getTenantData(orgId: string): Promise<TenantData> {\n try {\n const resource = endPointMap.tenantData(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getTenantData api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_TENANT_DATA,\n });\n\n return Promise.resolve(response.body.data[0]);\n } catch (error) {\n LoggerProxy.error(`getTenantData API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_TENANT_DATA,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the URL mapping data for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the URL mapping is to be fetched.\n * @returns {Promise<URLMapping[]>} - A promise that resolves to the URL mapping response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getURLMapping(orgId: string): Promise<URLMapping[]> {\n try {\n const resource = endPointMap.urlMapping(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getURLMapping api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_URL_MAPPING,\n });\n\n return Promise.resolve(response.body.data);\n } catch (error) {\n LoggerProxy.error(`getURLMapping API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_URL_MAPPING,\n });\n throw error;\n }\n }\n\n /**\n * Fetches AI feature resources for the organization.\n * @ignore\n * @param {string} orgId - organization ID for which AI feature resources are to be fetched.\n * @returns {Promise<AIFeatureFlagsResponse>} - AI feature resources response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getAIFeatureFlags(orgId: string): Promise<AIFeatureFlagsResponse> {\n LoggerProxy.info('Fetching AI feature resources', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AI_FEATURE_FLAGS,\n });\n try {\n const resource = endPointMap.aiFeature(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getAIFeatureFlags api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AI_FEATURE_FLAGS,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getAIFeatureFlags API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_AI_FEATURE_FLAGS,\n });\n throw error;\n }\n }\n\n /**\n * Fetches the dial plan data for the given orgId.\n * @ignore\n * @param {string} orgId - organization ID for which the dial plan data is to be fetched.\n * @returns {Promise<DialPlanEntity[]>} - A promise that resolves to the dial plan data response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getDialPlanData(orgId: string): Promise<DialPlanEntity[]> {\n try {\n const resource = endPointMap.dialPlan(orgId);\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n if (response.statusCode !== 200) {\n throw new Error(`API call failed with ${response.statusCode}`);\n }\n\n LoggerProxy.log('getDialPlanData api success.', {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DIAL_PLAN_DATA,\n });\n\n return Promise.resolve(response.body);\n } catch (error) {\n LoggerProxy.error(`getDialPlanData API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: METHODS.GET_DIAL_PLAN_DATA,\n });\n throw error;\n }\n }\n\n // getQueues removed - use Queue instead\n\n /**\n * Fetches outdial ANI (Automatic Number Identification) entries for the given orgId and outdial ANI ID.\n * @ignore\n * @param {string} orgId - organization ID for which the outdial ANI entries are to be fetched.\n * @param {OutdialAniParams} params - parameters object containing outdialANI and optional pagination/filtering options\n * @returns {Promise<OutdialAniEntriesResponse>} - A promise that resolves to the outdial ANI entries response.\n * @throws {Error} - Throws an error if the API call fails or if the response status is not 200.\n * @private\n */\n public async getOutdialAniEntries(\n orgId: string,\n params: OutdialAniParams\n ): Promise<OutdialAniEntriesResponse> {\n const {outdialANI, page, pageSize, search, filter, attributes} = params;\n\n LoggerProxy.info('Fetching outdial ANI entries', {\n module: CONFIG_FILE_NAME,\n method: MAIN_METHODS.GET_OUTDIAL_ANI_ENTRIES,\n });\n\n try {\n const queryParams = [];\n if (page !== undefined) queryParams.push(`page=${page}`);\n if (pageSize !== undefined) queryParams.push(`pageSize=${pageSize}`);\n if (search) queryParams.push(`search=${search}`);\n if (filter) queryParams.push(`filter=${filter}`);\n if (attributes) queryParams.push(`attributes=${attributes}`);\n\n const queryString = queryParams.length > 0 ? queryParams.join('&') : '';\n const resource = endPointMap.outdialAniEntries(orgId, outdialANI, queryString);\n\n const response = await this.webexReq.request({\n service: WCC_API_GATEWAY,\n resource,\n method: HTTP_METHODS.GET,\n });\n\n LoggerProxy.log('getOutdialAniEntries API success.', {\n module: CONFIG_FILE_NAME,\n method: MAIN_METHODS.GET_OUTDIAL_ANI_ENTRIES,\n });\n\n return response.body?.data;\n } catch (error) {\n LoggerProxy.error(`getOutdialAniEntries API call failed with ${error}`, {\n module: CONFIG_FILE_NAME,\n method: MAIN_METHODS.GET_OUTDIAL_ANI_ENTRIES,\n });\n throw error;\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -113,7 +113,15 @@ const CC_TASK_EVENTS = exports.CC_TASK_EVENTS = {
113
113
  /** Event emitted when contact is unassigned from agent */
114
114
  AGENT_CONTACT_UNASSIGNED: 'AgentContactUnassigned',
115
115
  /** Event emitted when inviting agent fails */
116
- AGENT_INVITE_FAILED: 'AgentInviteFailed'
116
+ AGENT_INVITE_FAILED: 'AgentInviteFailed',
117
+ /** Event emitted when a campaign preview contact is offered to the agent */
118
+ AGENT_OFFER_CAMPAIGN_RESERVATION: 'AgentOfferCampaignReservation',
119
+ /** Event emitted when campaign contact is updated */
120
+ CAMPAIGN_CONTACT_UPDATED: 'CampaignContactUpdated',
121
+ /** Event emitted when accepting a campaign preview contact fails */
122
+ CAMPAIGN_PREVIEW_ACCEPT_FAILED: 'CampaignPreviewAcceptFailed',
123
+ /** Event emitted when a real-time transcript chunk is received */
124
+ REAL_TIME_TRANSCRIPTION: 'REAL_TIME_TRANSCRIPTION'
117
125
  };
118
126
 
119
127
  /**
@@ -338,6 +346,16 @@ const WRAP_UP_CODE = exports.WRAP_UP_CODE = 'WRAP_UP_CODE';
338
346
  * @public
339
347
  */
340
348
 
349
+ /**
350
+ * AI feature resource row returned by /v2/ai-feature API.
351
+ * @public
352
+ */
353
+
354
+ /**
355
+ * Response type for list AI feature resources API.
356
+ * @public
357
+ */
358
+
341
359
  /**
342
360
  * Comprehensive agent profile configuration in the contact center system
343
361
  * Contains all settings and capabilities for an agent