@webex/webex-core 3.9.0-next.3 → 3.9.0-next.4

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.
@@ -1 +1 @@
1
- {"version":3,"names":["_sha","_interopRequireDefault","require","_lodash","_webexPlugin","_metrics","_serviceCatalog","_serviceFedRamp","_constants","ownKeys","e","r","t","_Object$keys2","_Object$getOwnPropertySymbols","o","filter","_Object$getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","Object","forEach","_defineProperty2","default","_Object$getOwnPropertyDescriptors","_Object$defineProperties","_Object$defineProperty","trailingSlashes","DEFAULT_CLUSTER","exports","DEFAULT_CLUSTER_SERVICE","CLUSTER_SERVICE","process","env","WEBEX_CONVERSATION_CLUSTER_SERVICE","DEFAULT_CLUSTER_IDENTIFIER","WEBEX_CONVERSATION_DEFAULT_CLUSTER","concat","Services","WebexPlugin","extend","namespace","props","validateDomains","initFailed","_catalogs","_weakMap","_activeServices","_services","_getCatalog","get","webex","name","serviceGroup","catalog","clusterId","urlById","urlByName","undefined","hasAllowedDomains","getAllowedDomains","markFailedUrl","url","markFailedServiceUrl","_updateActiveServices","activeServices","_updateServices","services","unionBy","updateServices","_this","_ref","from","query","token","forceRefresh","formattedQuery","status","collecting","waitForCatalog","queryKey","_keys","includes","_promise","reject","Error","email","emailhash","sha256","toLowerCase","toString","_fetchNewServiceHostmap","then","serviceHostMap","updateServiceGroups","updateCredentialsConfig","catch","error","validateUser","_ref2","_this2","_ref2$reqId","reqId","_ref2$forceRefresh","_ref2$activationOptio","activationOptions","preloginUserId","logger","info","canAuthorize","credentials","getUserToken","sendUserActivation","userObj","activated","exists","details","user","_this$webex$credentia","config","client_id","client_secret","collectPreauthCatalog","idbrokerService","getClientToken","uri","scope","tokenObj","collectSigninCatalog","rto","all","_ref3","_ref4","_slicedToArray2","response","statusCode","responseText","body","message","getMeetingPreferences","_this3","request","method","service","resource","res","err","fetchClientRegionInfo","_this4","discovery","sqdiscovery","addAuthHeader","headers","timeout","_ref5","_this5","countryCode","timezone","clientRegionInfo","accept","authorization","timeZone","shouldRefreshAccessToken","_ref6","updateCatalog","hostMap","_formatReceivedHostmap","mode","_ref7","idbrokerUrl","identityUrl","_this$webex$config$cr","authorizationString","authorizeUrl","replace","setConfig","idbroker","identity","supertoken","access_token","postauth","ready","preauth","initServiceCatalogs","waitForService","_ref8","_this6","_ref8$timeout","fetchFromServiceUrl","servicesNotNeedValidation","find","resolve","priorityUrl","priorityUrlObj","getServiceFromUrl","isReady","internal","metrics","submitClientMetrics","METRICS","JS_SDK_SERVICE_NOT_FOUND","fields","service_name","groupsToCheck","checkCatalog","catalogGroup","scopedPriorityUrl","scopedPrioriryUrlObj","map","group","replaceHostFromHostmap","convertUrlToPriorityHostUrl","_unused","_formatHostMapEntry","_ref9","id","serviceName","serviceUrls","formattedServiceUrls","serviceUrl","host","URL","baseUrl","_ref10","_this7","formattedHostmap","getClusterId","findClusterId","getServiceFromClusterId","params","findServiceFromClusterId","getServiceUrlFromClusterId","_ref11","_ref11$cluster","cluster","split","_ref12","findServiceDetailFromUrl","defaultUrl","startsWith","href","isAllowedDomainUrl","findAllowedDomain","data","_this8","_ref13","qs","format","timestamp","Date","getTime","requestObject","newMetrics","callDiagnosticLatencies","measureLatency","_ref14","initConfig","_this9","_this$webex$config","fedramp","fedRampServices","formattedDiscoveryServices","key","priority","override","formattedOverrideServices","allowedDomains","union","COMMERCIAL_ALLOWED_DOMAINS","setAllowedDomains","_this10","getOrgId","orgId","warn","initialize","_this11","ServiceCatalog","set","listenToOnce","version","_default"],"sources":["services-v2.ts"],"sourcesContent":["import sha256 from 'crypto-js/sha256';\n\nimport {union, unionBy} from 'lodash';\nimport WebexPlugin from '../webex-plugin';\n\nimport METRICS from '../metrics';\nimport ServiceCatalog from './service-catalog';\nimport fedRampServices from './service-fed-ramp';\nimport {COMMERCIAL_ALLOWED_DOMAINS} from '../constants';\nimport {\n ActiveServices,\n IServiceCatalog,\n QueryOptions,\n Service,\n ServiceHostmap,\n ServiceGroup,\n} from './types';\n\nconst trailingSlashes = /(?:^\\/)|(?:\\/$)/;\n\n// The default cluster when one is not provided (usually as 'US' from hydra)\nexport const DEFAULT_CLUSTER = 'urn:TEAM:us-east-2_a';\n// The default service name for convo (currently identityLookup due to some weird CSB issue)\nexport const DEFAULT_CLUSTER_SERVICE = 'identityLookup';\n\nconst CLUSTER_SERVICE = process.env.WEBEX_CONVERSATION_CLUSTER_SERVICE || DEFAULT_CLUSTER_SERVICE;\nconst DEFAULT_CLUSTER_IDENTIFIER =\n process.env.WEBEX_CONVERSATION_DEFAULT_CLUSTER || `${DEFAULT_CLUSTER}:${CLUSTER_SERVICE}`;\n\n/* eslint-disable no-underscore-dangle */\n/**\n * @class\n */\nconst Services = WebexPlugin.extend({\n namespace: 'Services',\n\n props: {\n validateDomains: ['boolean', false, true],\n initFailed: ['boolean', false, false],\n },\n\n _catalogs: new WeakMap(),\n\n _activeServices: {},\n\n _services: [],\n\n /**\n * @private\n * Get the current catalog based on the assocaited\n * webex instance.\n * @returns {IServiceCatalog}\n */\n _getCatalog(): IServiceCatalog {\n return this._catalogs.get(this.webex);\n },\n\n /**\n * Get a service url from the current services list by name\n * from the associated instance catalog.\n * @param {string} name\n * @param {ServiceGroup} [serviceGroup]\n * @returns {string|undefined}\n */\n get(name: string, serviceGroup?: ServiceGroup): string | undefined {\n const catalog = this._getCatalog();\n\n const clusterId = this._activeServices[name];\n\n const urlById = catalog.get(clusterId, serviceGroup);\n const urlByName = catalog.get(name, serviceGroup);\n\n // if both are undefined, then we cannot find the service\n if (!urlById && !urlByName) {\n return undefined;\n }\n\n return urlById || urlByName;\n },\n\n /**\n * Determine if a whilelist exists in the service catalog.\n *\n * @returns {boolean} - True if a allowed domains list exists.\n */\n hasAllowedDomains(): boolean {\n const catalog = this._getCatalog();\n\n return catalog.getAllowedDomains().length > 0;\n },\n\n /**\n * Mark a priority host service url as failed.\n * This will mark the service url associated with the\n * `ServiceDetail` to be removed from the its\n * respective service url array, and then return the next\n * viable service url from the `ServiceDetail` service url array.\n * @param {string} url\n * @returns {string}\n */\n markFailedUrl(url: string): string | undefined {\n const catalog = this._getCatalog();\n\n return catalog.markFailedServiceUrl(url);\n },\n\n /**\n * saves all the services from the pre and post catalog service\n * @param {ActiveServices} activeServices\n * @returns {void}\n */\n _updateActiveServices(activeServices: ActiveServices): void {\n this._activeServices = {...this._activeServices, ...activeServices};\n },\n\n /**\n * saves the hostCatalog object\n * @param {Array<Service>} services\n * @returns {void}\n */\n _updateServices(services: Array<Service>): void {\n this._services = unionBy(services, this._services, 'id');\n },\n\n /**\n * Update a list of `serviceUrls` to the most current\n * catalog via the defined `discoveryUrl` then returns the current\n * list of services.\n * @param {object} [param]\n * @param {string} [param.from] - This accepts `limited` or `signin`\n * @param {object} [param.query] - This accepts `email`, `orgId` or `userId` key values\n * @param {string} [param.query.email] - must be a standard-format email\n * @param {string} [param.query.orgId] - must be an organization id\n * @param {string} [param.query.userId] - must be a user id\n * @param {string} [param.token] - used for signin catalog\n * @returns {Promise<object>}\n */\n updateServices(\n {from, query, token, forceRefresh} = {} as {\n from: string;\n query: QueryOptions;\n token: string;\n forceRefresh: boolean;\n }\n ): Promise<object> {\n const catalog = this._getCatalog();\n let formattedQuery;\n let serviceGroup;\n\n // map catalog name to service group name.\n switch (from) {\n case 'limited':\n serviceGroup = 'preauth';\n break;\n case 'signin':\n serviceGroup = 'signin';\n break;\n default:\n serviceGroup = 'postauth';\n break;\n }\n\n // confirm catalog update for group is not in progress.\n if (catalog.status[serviceGroup].collecting) {\n return this.waitForCatalog(serviceGroup);\n }\n\n catalog.status[serviceGroup].collecting = true;\n\n if (serviceGroup === 'preauth') {\n const queryKey = query && Object.keys(query)[0];\n\n if (!['email', 'emailhash', 'userId', 'orgId', 'mode'].includes(queryKey)) {\n return Promise.reject(\n new Error('a query param of email, emailhash, userId, orgId, or mode is required')\n );\n }\n }\n // encode email when query key is email\n if (serviceGroup === 'preauth' || serviceGroup === 'signin') {\n const queryKey = Object.keys(query)[0];\n\n formattedQuery = {};\n\n if (queryKey === 'email' && query.email) {\n formattedQuery.emailhash = sha256(query.email.toLowerCase()).toString();\n } else {\n formattedQuery[queryKey] = query[queryKey];\n }\n }\n\n return this._fetchNewServiceHostmap({\n from,\n token,\n query: formattedQuery,\n forceRefresh,\n })\n .then((serviceHostMap: ServiceHostmap) => {\n catalog.updateServiceGroups(serviceGroup, serviceHostMap);\n this.updateCredentialsConfig();\n catalog.status[serviceGroup].collecting = false;\n })\n .catch((error) => {\n catalog.status[serviceGroup].collecting = false;\n\n return Promise.reject(error);\n });\n },\n\n /**\n * User validation parameter transfer object for {@link validateUser}.\n * @param {object} ValidateUserPTO\n * @property {string} ValidateUserPTO.email - The email of the user.\n * @property {string} [ValidateUserPTO.reqId] - The activation requester.\n * @property {object} [ValidateUserPTO.activationOptions] - Extra options to pass when sending the activation\n * @property {object} [ValidateUserPTO.preloginUserId] - The prelogin user id to set when sending the activation.\n */\n\n /**\n * User validation return transfer object for {@link validateUser}.\n * @param {object} ValidateUserRTO\n * @property {boolean} ValidateUserRTO.activated - If the user is activated.\n * @property {boolean} ValidateUserRTO.exists - If the user exists.\n * @property {string} ValidateUserRTO.details - A descriptive status message.\n * @property {object} ValidateUserRTO.user - **License** service user object.\n */\n\n /**\n * Validate if a user is activated and update the service catalogs as needed\n * based on the user's activation status.\n *\n * @param {ValidateUserPTO} - The parameter transfer object.\n * @returns {ValidateUserRTO} - The return transfer object.\n */\n validateUser({\n email,\n reqId = 'WEBCLIENT',\n forceRefresh = false,\n activationOptions = {},\n preloginUserId,\n }) {\n this.logger.info('services: validating a user');\n\n // Validate that an email parameter key was provided.\n if (!email) {\n return Promise.reject(new Error('`email` is required'));\n }\n\n // Destructure the credentials object.\n const {canAuthorize} = this.webex.credentials;\n\n // Validate that the user is already authorized.\n if (canAuthorize) {\n return this.updateServices({forceRefresh})\n .then(() => this.webex.credentials.getUserToken())\n .then((token) =>\n this.sendUserActivation({\n email,\n reqId,\n token: token.toString(),\n activationOptions,\n preloginUserId,\n })\n )\n .then((userObj) => ({\n activated: true,\n exists: true,\n details: 'user is authorized via a user token',\n user: userObj,\n }));\n }\n\n // Destructure the client authorization details.\n /* eslint-disable camelcase */\n const {client_id, client_secret} = this.webex.credentials.config;\n\n // Validate that client authentication details exist.\n if (!client_id || !client_secret) {\n return Promise.reject(new Error('client authentication details are not available'));\n }\n /* eslint-enable camelcase */\n\n // Declare a class-memeber-scoped token for usage within the promise chain.\n let token;\n\n // Begin client authentication user validation.\n return (\n this.collectPreauthCatalog({email})\n .then(() => {\n // Retrieve the service url from the updated catalog. This is required\n // since `WebexCore` is usually not fully initialized at the time this\n // request completes.\n const idbrokerService = this.get('idbroker');\n\n // Collect the client auth token.\n return this.webex.credentials.getClientToken({\n uri: `${idbrokerService}idb/oauth2/v1/access_token`,\n scope: 'webexsquare:admin webexsquare:get_conversation Identity:SCIM',\n });\n })\n .then((tokenObj) => {\n // Generate the token string.\n token = tokenObj.toString();\n\n // Collect the signin catalog using the client auth information.\n return this.collectSigninCatalog({email, token, forceRefresh});\n })\n // Validate if collecting the signin catalog failed and populate the RTO\n // with the appropriate content.\n .catch((error) => ({\n exists: error.name !== 'NotFound',\n activated: false,\n details:\n error.name !== 'NotFound'\n ? 'user exists but is not activated'\n : 'user does not exist and is not activated',\n }))\n // Validate if the previous promise resolved with an RTO and populate the\n // new RTO accordingly.\n .then((rto) =>\n Promise.all([\n rto || {\n activated: true,\n exists: true,\n details: 'user exists and is activated',\n },\n this.sendUserActivation({\n email,\n reqId,\n token,\n activationOptions,\n preloginUserId,\n }),\n ])\n )\n .then(([rto, user]) => ({...rto, user}))\n .catch((error) => {\n const response = {\n statusCode: error.statusCode,\n responseText: error.body && error.body.message,\n body: error.body,\n };\n\n return Promise.reject(response);\n })\n );\n },\n\n /**\n * Get user meeting preferences (preferred webex site).\n *\n * @returns {object} - User Information including user preferrences .\n */\n getMeetingPreferences() {\n return this.request({\n method: 'GET',\n service: 'hydra',\n resource: 'meetingPreferences',\n })\n .then((res) => {\n this.logger.info('services: received user region info');\n\n return res.body;\n })\n .catch((err) => {\n this.logger.info('services: was not able to fetch user login information', err);\n // resolve successfully even if request failed\n });\n },\n\n /**\n * Fetches client region info such as countryCode and timezone.\n *\n * @returns {object} - The region info object.\n */\n fetchClientRegionInfo() {\n const {services} = this.webex.config;\n\n return this.request({\n uri: services.discovery.sqdiscovery,\n addAuthHeader: false,\n headers: {\n 'spark-user-agent': null,\n },\n timeout: 5000,\n })\n .then((res) => {\n this.logger.info('services: received user region info');\n\n return res.body;\n })\n .catch((err) => {\n this.logger.info('services: was not able to get user region info', err);\n // resolve successfully even if request failed\n });\n },\n\n /**\n * User activation parameter transfer object for {@link sendUserActivation}.\n * @typedef {object} SendUserActivationPTO\n * @property {string} SendUserActivationPTO.email - The email of the user.\n * @property {string} SendUserActivationPTO.reqId - The activation requester.\n * @property {string} SendUserActivationPTO.token - The client auth token.\n * @property {object} SendUserActivationPTO.activationOptions - Extra options to pass when sending the activation.\n * @property {object} SendUserActivationPTO.preloginUserId - The prelogin user id to set when sending the activation.\n */\n\n /**\n * Send a request to activate a user using a client token.\n *\n * @param {SendUserActivationPTO} - The Parameter transfer object.\n * @returns {LicenseDTO} - The DTO returned from the **License** service.\n */\n sendUserActivation({email, reqId, token, activationOptions, preloginUserId}) {\n this.logger.info('services: sending user activation request');\n let countryCode;\n let timezone;\n\n // try to fetch client region info first\n return (\n this.fetchClientRegionInfo()\n .then((clientRegionInfo) => {\n if (clientRegionInfo) {\n ({countryCode, timezone} = clientRegionInfo);\n }\n\n // Send the user activation request to the **License** service.\n return this.request({\n service: 'license',\n resource: 'users/activations',\n method: 'POST',\n headers: {\n accept: 'application/json',\n authorization: token,\n 'x-prelogin-userid': preloginUserId,\n },\n body: {\n email,\n reqId,\n countryCode,\n timeZone: timezone,\n ...activationOptions,\n },\n shouldRefreshAccessToken: false,\n });\n })\n // On success, return the **License** user object.\n .then(({body}) => body)\n // On failure, reject with error from **License**.\n .catch((error) => Promise.reject(error))\n );\n },\n\n /**\n * Updates a given service group i.e. preauth, signin, postauth with a new hostmap.\n * @param {ServiceGroup} serviceGroup - preauth, signin, postauth\n * @param {ServiceHostmap} hostMap - The new hostmap to update the service group with.\n * @returns {Promise<void>}\n */\n updateCatalog(serviceGroup: ServiceGroup, hostMap: ServiceHostmap): Promise<void> {\n const catalog = this._getCatalog();\n\n const serviceHostMap = this._formatReceivedHostmap(hostMap);\n\n return catalog.updateServiceGroups(serviceGroup, serviceHostMap);\n },\n\n /**\n * simplified method to update the preauth catalog via email\n *\n * @param {object} query\n * @param {string} query.email - A standard format email.\n * @param {string} query.orgId - The user's OrgId.\n * @param {boolean} forceRefresh - Boolean to bypass u2c cache control header\n * @returns {Promise<void>}\n */\n collectPreauthCatalog(query: QueryOptions, forceRefresh = false) {\n if (!query) {\n return this.updateServices({\n from: 'limited',\n query: {mode: 'DEFAULT_BY_PROXIMITY'},\n forceRefresh,\n });\n }\n\n return this.updateServices({from: 'limited', query, forceRefresh});\n },\n\n /**\n * simplified method to update the signin catalog via email and token\n * @param {object} param\n * @param {string} param.email - must be a standard-format email\n * @param {string} param.token - must be a client token\n * @returns {Promise<void>}\n */\n collectSigninCatalog(\n {email, token, forceRefresh} = {} as {email: string; token: string; forceRefresh: boolean}\n ): Promise<void> {\n if (!email) {\n return Promise.reject(new Error('`email` is required'));\n }\n if (!token) {\n return Promise.reject(new Error('`token` is required'));\n }\n\n return this.updateServices({\n from: 'signin',\n query: {email},\n token,\n forceRefresh,\n });\n },\n\n /**\n * Updates credentials config to utilize u2c catalog\n * urls.\n * @returns {void}\n */\n updateCredentialsConfig(): void {\n const idbrokerUrl = this.get('idbroker');\n const identityUrl = this.get('identity');\n\n if (idbrokerUrl && identityUrl) {\n const {authorizationString, authorizeUrl} = this.webex.config.credentials;\n\n // This must be set outside of the setConfig method used to assign the\n // idbroker and identity url values.\n this.webex.config.credentials.authorizeUrl = authorizationString\n ? authorizeUrl\n : `${idbrokerUrl.replace(trailingSlashes, '')}/idb/oauth2/v1/authorize`;\n\n this.webex.setConfig({\n credentials: {\n idbroker: {\n url: idbrokerUrl.replace(trailingSlashes, ''), // remove trailing slash\n },\n identity: {\n url: identityUrl.replace(trailingSlashes, ''), // remove trailing slash\n },\n },\n });\n }\n },\n\n /**\n * Wait until the service catalog is available,\n * or reject afte ra timeout of 60 seconds.\n * @param {ServiceGroup} serviceGroup\n * @param {number} [timeout] - in seconds\n * @returns {Promise<void>}\n */\n waitForCatalog(serviceGroup: ServiceGroup, timeout: number): Promise<void> {\n const catalog = this._getCatalog();\n const {supertoken} = this.webex.credentials;\n\n if (\n serviceGroup === 'postauth' &&\n supertoken &&\n supertoken.access_token &&\n !catalog.status.postauth.collecting &&\n !catalog.status.postauth.ready\n ) {\n if (!catalog.status.preauth.ready) {\n return this.initServiceCatalogs();\n }\n\n return this.updateServices();\n }\n\n return catalog.waitForCatalog(serviceGroup, timeout);\n },\n\n /**\n * Service waiting parameter transfer object for {@link waitForService}.\n *\n * @typedef {object} WaitForServicePTO\n * @property {string} [WaitForServicePTO.name] - The service name.\n * @property {string} [WaitForServicePTO.url] - The service url.\n * @property {string} [WaitForServicePTO.timeout] - wait duration in seconds.\n */\n\n /**\n * Wait until the service has been ammended to any service catalog. This\n * method prioritizes the service name over the service url when searching.\n *\n * @param {WaitForServicePTO} - The parameter transfer object.\n * @returns {Promise<string>} - Resolves to the priority host of a service.\n */\n waitForService({\n name,\n timeout = 5,\n url,\n }: {\n name: string;\n timeout: number;\n url: string;\n }): Promise<string> {\n const {services} = this.webex.config;\n\n // Save memory by grabbing the catalog after there isn't a priortyURL\n const catalog = this._getCatalog();\n\n const fetchFromServiceUrl = services.servicesNotNeedValidation.find(\n (service) => service === name\n );\n\n if (fetchFromServiceUrl) {\n const clusterId = this._activeServices[name];\n\n return Promise.resolve(this.get(clusterId));\n }\n\n const priorityUrl = this.get(name);\n const priorityUrlObj = this.getServiceFromUrl(url);\n\n if (priorityUrl || priorityUrlObj) {\n return Promise.resolve(priorityUrl || priorityUrlObj.priorityUrl);\n }\n\n if (catalog.isReady) {\n if (url) {\n return Promise.resolve(url);\n }\n\n this.webex.internal.metrics.submitClientMetrics(METRICS.JS_SDK_SERVICE_NOT_FOUND, {\n fields: {service_name: name},\n });\n\n return Promise.reject(\n new Error(`services: service '${name}' was not found in any of the catalogs`)\n );\n }\n\n return new Promise((resolve, reject) => {\n const groupsToCheck = ['preauth', 'signin', 'postauth'];\n const checkCatalog = (catalogGroup) =>\n catalog\n .waitForCatalog(catalogGroup, timeout)\n .then(() => {\n const scopedPriorityUrl = this.get(name);\n const scopedPrioriryUrlObj = this.getServiceFromUrl(url);\n\n if (scopedPriorityUrl || scopedPrioriryUrlObj) {\n resolve(scopedPriorityUrl || scopedPrioriryUrlObj.priorityUrl);\n }\n })\n .catch(() => undefined);\n\n Promise.all(groupsToCheck.map((group) => checkCatalog(group))).then(() => {\n this.webex.internal.metrics.submitClientMetrics(METRICS.JS_SDK_SERVICE_NOT_FOUND, {\n fields: {service_name: name},\n });\n reject(new Error(`services: service '${name}' was not found after waiting`));\n });\n });\n },\n\n /**\n * Looks up the hostname in the host catalog\n * and replaces it with the first host if it finds it\n * @param {string} uri\n * @returns {string} uri with the host replaced\n */\n replaceHostFromHostmap(uri: string): string {\n try {\n return this.convertUrlToPriorityHostUrl(uri);\n } catch {\n return uri;\n }\n },\n\n /**\n * Formats a host map entry for use in service catalog.\n *\n * @param {Object} entry - The host map entry to format.\n * @param {string} entry.serviceName - i.e. conversation, identity, etc.\n * @param {string} entry.id - The unique identifier for the service, usually clusterId.\n * @param {Array<IServiceDetail>} entry.serviceUrls - The group to which the service belongs.\n * @returns {Object} - The formatted host map entry.\n */\n _formatHostMapEntry({id, serviceName, serviceUrls}) {\n const formattedServiceUrls = serviceUrls.map((serviceUrl) => ({\n host: new URL(serviceUrl.baseUrl).host,\n ...serviceUrl,\n }));\n\n return {\n id,\n serviceName,\n serviceUrls: formattedServiceUrls,\n };\n },\n\n /**\n * @private\n * Organize a received hostmap from a service\n * @param {ServiceHostmap} serviceHostmap\n * catalog endpoint.\n * @returns {Array<Service>}\n */\n _formatReceivedHostmap({services, activeServices}) {\n const formattedHostmap = services.map((service) => this._formatHostMapEntry(service));\n this._updateActiveServices(activeServices);\n this._updateServices(services);\n\n return formattedHostmap;\n },\n\n /**\n * Get the clusterId associated with a URL string.\n * @param {string} url\n * @returns {string | undefined} - Cluster ID of url provided\n */\n getClusterId(url: string): string | undefined {\n const catalog = this._getCatalog();\n\n return catalog.findClusterId(url);\n },\n\n /**\n * Get a service value from a provided clusterId. This method will\n * return an object containing both the name and url of a found service.\n * @param {object} params\n * @param {string} params.clusterId - clusterId of found service\n * @param {ServiceGroup} [params.serviceGroup] - specify service group\n * @returns {object} service\n * @returns {string} service.name\n * @returns {string} service.url\n */\n getServiceFromClusterId(params: {\n clusterId: string;\n serviceGroup?: ServiceGroup;\n }): {name: string; url: string} | undefined {\n const catalog = this._getCatalog();\n\n return catalog.findServiceFromClusterId(params);\n },\n\n /**\n * @param {String} cluster the cluster containing the id\n * @param {UUID} [id] the id of the conversation.\n * If empty, just return the base URL.\n * @returns {String} url of the service\n */\n getServiceUrlFromClusterId({cluster = 'us'}: {cluster?: string} = {}): string {\n let clusterId = cluster === 'us' ? DEFAULT_CLUSTER_IDENTIFIER : cluster;\n\n // Determine if cluster has service name (non-US clusters from hydra do not)\n if (clusterId.split(':').length < 4) {\n // Add Service to cluster identifier\n clusterId = `${cluster}:${CLUSTER_SERVICE}`;\n }\n\n const {url} = this.getServiceFromClusterId({clusterId}) || {};\n\n if (!url) {\n throw Error(`Could not find service for cluster [${cluster}]`);\n }\n\n return url;\n },\n\n /**\n * Get a service object from a service url if the service url exists in the\n * catalog.\n *\n * @param {string} url - The url to be validated.\n * @returns {object} - Service object.\n * @returns {object.name} - The name of the service found.\n * @returns {object.priorityUrl} - The default url of the found service.\n * @returns {object.defaultUrl} - The default url of the found service.\n */\n getServiceFromUrl(url = ''): {name: string; priorityUrl: string; defaultUrl: string} | undefined {\n const service = this._getCatalog().findServiceDetailFromUrl(url);\n\n if (!service) {\n return undefined;\n }\n\n const priorityUrl = service.get();\n const defaultUrl = new URL(\n service.serviceUrls.find((serviceUrl) => url.startsWith(serviceUrl.baseUrl)).baseUrl\n ).href;\n\n return {\n name: service.serviceName,\n priorityUrl,\n defaultUrl,\n };\n },\n\n /**\n * Determine if a provided url is in the catalog's allowed domains.\n *\n * @param {string} url - The url to match allowed domains against.\n * @returns {boolean} - True if the url provided is allowed.\n */\n isAllowedDomainUrl(url: string): boolean {\n const catalog = this._getCatalog();\n\n return !!catalog.findAllowedDomain(url);\n },\n\n /**\n * Converts the host portion of the url from default host\n * to a priority host\n *\n * @param {string} url a service url that contains a default host\n * @returns {string} a service url that contains the top priority host.\n * @throws if url isn't a service url\n */\n convertUrlToPriorityHostUrl(url = '' as string): string {\n const data = this.getServiceFromUrl(url);\n\n if (!data) {\n throw Error(`No service associated with url: [${url}]`);\n }\n\n return url.replace(data.defaultUrl, data.priorityUrl);\n },\n\n /**\n * @private\n * Simplified method wrapper for sending a request to get\n * an updated service hostmap.\n * @param {object} [param]\n * @param {string} [param.from] - This accepts `limited` or `signin`\n * @param {object} [param.query] - This accepts `email`, `orgId` or `userId` key values\n * @param {string} [param.query.email] - must be a standard-format email\n * @param {string} [param.query.orgId] - must be an organization id\n * @param {string} [param.query.userId] - must be a user id\n * @param {string} [param.token] - used for signin catalog\n * @returns {Promise<object>}\n */\n _fetchNewServiceHostmap(\n {from, query, token, forceRefresh} = {} as {\n from: string;\n query: QueryOptions;\n token: string;\n forceRefresh: boolean;\n }\n ): Promise<object> {\n const service = 'u2c';\n const resource = from ? `/${from}/catalog` : '/catalog';\n const qs = {...(query || {}), format: 'U2CV2'};\n\n if (forceRefresh) {\n qs.timestamp = new Date().getTime();\n }\n\n const requestObject = {\n method: 'GET',\n service,\n resource,\n qs,\n headers: {},\n };\n\n if (token) {\n requestObject.headers = {authorization: token};\n }\n\n return this.webex.internal.newMetrics.callDiagnosticLatencies\n .measureLatency(() => this.request(requestObject), 'internal.get.u2c.time')\n .then(({body}) => this._formatReceivedHostmap(body));\n },\n\n /**\n * Initialize the discovery services and the whitelisted services.\n *\n * @returns {void}\n */\n initConfig(): void {\n // Get the catalog and destructure the services config.\n const catalog = this._getCatalog();\n const {services, fedramp} = this.webex.config;\n\n // Validate that the services configuration exists.\n if (services) {\n if (fedramp) {\n services.discovery = fedRampServices;\n }\n // Check for discovery services.\n if (services.discovery) {\n // Format the discovery configuration into an injectable array.\n const formattedDiscoveryServices = Object.keys(services.discovery).map((key) =>\n this._formatHostMapEntry({\n id: key,\n serviceName: key,\n serviceUrls: [{baseUrl: services.discovery[key], priority: 1}],\n })\n );\n\n // Inject formatted discovery services into services catalog.\n catalog.updateServiceGroups('discovery', formattedDiscoveryServices);\n }\n\n if (services.override) {\n // Format the override configuration into an injectable array.\n const formattedOverrideServices = Object.keys(services.override).map((key) =>\n this._formatHostMapEntry({\n id: key,\n serviceName: key,\n serviceUrls: [{baseUrl: services.override[key], priority: 1}],\n })\n );\n\n // Inject formatted override services into services catalog.\n catalog.updateServiceGroups('override', formattedOverrideServices);\n }\n\n // if not fedramp, append on the commercialAllowedDomains\n if (!fedramp) {\n services.allowedDomains = union(services.allowedDomains, COMMERCIAL_ALLOWED_DOMAINS);\n }\n\n // Check for allowed host domains.\n if (services.allowedDomains) {\n // Store the allowed domains as a property of the catalog.\n catalog.setAllowedDomains(services.allowedDomains);\n }\n\n // Set `validateDomains` property to match configuration\n this.validateDomains = services.validateDomains;\n }\n },\n\n /**\n * Make the initial requests to collect the root catalogs.\n *\n * @returns {Promise<void, Error>} - Errors if the token is unavailable.\n */\n initServiceCatalogs(): Promise<void> {\n this.logger.info('services: initializing initial service catalogs');\n\n // Destructure the credentials plugin.\n const {credentials} = this.webex;\n\n // Init a promise chain. Must be done as a Promise.resolve() to allow\n // credentials#getOrgId() to properly throw.\n return (\n Promise.resolve()\n // Get the user's OrgId.\n .then(() => credentials.getOrgId())\n // Begin collecting the preauth/limited catalog.\n .then((orgId) => this.collectPreauthCatalog({orgId}))\n .then(() => {\n // Validate if the token is authorized.\n if (credentials.canAuthorize) {\n // Attempt to collect the postauth catalog.\n return this.updateServices().catch(() => {\n this.initFailed = true;\n this.logger.warn('services: cannot retrieve postauth catalog');\n });\n }\n\n // Return a resolved promise for consistent return value.\n return Promise.resolve();\n })\n );\n },\n\n /**\n * Initializer\n *\n * @instance\n * @memberof Services\n * @returns {Services}\n */\n initialize(): typeof Services {\n const catalog = new ServiceCatalog();\n this._catalogs.set(this.webex, catalog);\n\n // Listen for configuration changes once.\n this.listenToOnce(this.webex, 'change:config', () => {\n this.initConfig();\n });\n\n // wait for webex instance to be ready before attempting\n // to update the service catalogs\n this.listenToOnce(this.webex, 'ready', () => {\n const {supertoken} = this.webex.credentials;\n // Validate if the supertoken exists.\n if (supertoken && supertoken.access_token) {\n this.initServiceCatalogs()\n .then(() => {\n catalog.isReady = true;\n })\n .catch((error) => {\n this.initFailed = true;\n this.logger.error(\n `services: failed to init initial services when credentials available, ${error?.message}`\n );\n });\n } else {\n const {email} = this.webex.config;\n\n this.collectPreauthCatalog(email ? {email} : undefined).catch((error) => {\n this.initFailed = true;\n this.logger.error(\n `services: failed to init initial services when no credentials available, ${error?.message}`\n );\n });\n }\n });\n },\n});\n/* eslint-enable no-underscore-dangle */\n\nexport default Services;\n"],"mappings":"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"}
1
+ {"version":3,"names":["_sha","_interopRequireDefault","require","_lodash","_webexPlugin","_metrics","_serviceCatalog","_serviceFedRamp","_constants","ownKeys","e","r","t","_Object$keys2","_Object$getOwnPropertySymbols","o","filter","_Object$getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","Object","forEach","_defineProperty2","default","_Object$getOwnPropertyDescriptors","_Object$defineProperties","_Object$defineProperty","trailingSlashes","DEFAULT_CLUSTER","exports","DEFAULT_CLUSTER_SERVICE","CLUSTER_SERVICE","process","env","WEBEX_CONVERSATION_CLUSTER_SERVICE","DEFAULT_CLUSTER_IDENTIFIER","WEBEX_CONVERSATION_DEFAULT_CLUSTER","concat","Services","WebexPlugin","extend","namespace","props","validateDomains","initFailed","_catalogs","_weakMap","_activeServices","_services","_getCatalog","get","webex","name","serviceGroup","catalog","clusterId","urlById","urlByName","undefined","hasAllowedDomains","getAllowedDomains","markFailedUrl","url","markFailedServiceUrl","_updateActiveServices","activeServices","_updateServices","services","unionBy","updateServices","_catalog$status","_catalog$status$servi","_this","_ref","from","query","token","forceRefresh","formattedQuery","status","collecting","waitForCatalog","queryKey","_keys","includes","_promise","reject","Error","email","emailhash","sha256","toLowerCase","toString","_fetchNewServiceHostmap","then","serviceHostMap","updateServiceGroups","timestamp","updateCredentialsConfig","catch","error","validateUser","_ref2","_this2","_ref2$reqId","reqId","_ref2$forceRefresh","_ref2$activationOptio","activationOptions","preloginUserId","logger","info","canAuthorize","credentials","getUserToken","sendUserActivation","userObj","activated","exists","details","user","_this$webex$credentia","config","client_id","client_secret","collectPreauthCatalog","idbrokerService","getClientToken","uri","scope","tokenObj","collectSigninCatalog","rto","all","_ref3","_ref4","_slicedToArray2","response","statusCode","responseText","body","message","switchActiveClusterIds","newActiveClusters","_this3","newActiveClusterIds","_values","missingClusterIds","some","find","service","id","warn","initServiceCatalogs","resolve","invalidateCache","_this$_getCatalog","lastTime","toNumber","invalidateTime","getMeetingPreferences","_this4","request","method","resource","res","err","fetchClientRegionInfo","_this5","discovery","sqdiscovery","addAuthHeader","headers","timeout","_ref5","_this6","countryCode","timezone","clientRegionInfo","accept","authorization","timeZone","shouldRefreshAccessToken","_ref6","updateCatalog","hostMap","_formatReceivedHostmap","mode","_ref7","idbrokerUrl","identityUrl","_this$webex$config$cr","authorizationString","authorizeUrl","replace","setConfig","idbroker","identity","supertoken","access_token","postauth","ready","preauth","waitForService","_ref8","_this7","_ref8$timeout","fetchFromServiceUrl","servicesNotNeedValidation","priorityUrl","priorityUrlObj","getServiceFromUrl","isReady","internal","metrics","submitClientMetrics","METRICS","JS_SDK_SERVICE_NOT_FOUND","fields","service_name","groupsToCheck","checkCatalog","catalogGroup","scopedPriorityUrl","scopedPrioriryUrlObj","map","group","replaceHostFromHostmap","convertUrlToPriorityHostUrl","_unused","_formatHostMapEntry","_ref9","serviceName","serviceUrls","formattedServiceUrls","serviceUrl","host","URL","baseUrl","_ref10","_this8","orgId","format","formattedHostmap","getClusterId","findClusterId","getServiceFromClusterId","params","findServiceFromClusterId","getServiceUrlFromClusterId","_ref11","_ref11$cluster","cluster","split","_ref12","findServiceDetailFromUrl","defaultUrl","startsWith","href","isAllowedDomainUrl","findAllowedDomain","data","_this9","_ref13","qs","Date","getTime","requestObject","newMetrics","callDiagnosticLatencies","measureLatency","_ref14","initConfig","_this10","_this$webex$config","fedramp","fedRampServices","formattedDiscoveryServices","key","priority","override","formattedOverrideServices","allowedDomains","union","COMMERCIAL_ALLOWED_DOMAINS","setAllowedDomains","_this11","refresh","getOrgId","initialize","_this12","ServiceCatalog","set","listenToOnce","version","_default"],"sources":["services-v2.ts"],"sourcesContent":["import sha256 from 'crypto-js/sha256';\n\nimport {toNumber, union, unionBy} from 'lodash';\nimport WebexPlugin from '../webex-plugin';\n\nimport METRICS from '../metrics';\nimport ServiceCatalog from './service-catalog';\nimport fedRampServices from './service-fed-ramp';\nimport {COMMERCIAL_ALLOWED_DOMAINS} from '../constants';\nimport {\n ActiveServices,\n IServiceCatalog,\n QueryOptions,\n Service,\n ServiceHostmap,\n ServiceGroup,\n} from './types';\n\nconst trailingSlashes = /(?:^\\/)|(?:\\/$)/;\n\n// The default cluster when one is not provided (usually as 'US' from hydra)\nexport const DEFAULT_CLUSTER = 'urn:TEAM:us-east-2_a';\n// The default service name for convo (currently identityLookup due to some weird CSB issue)\nexport const DEFAULT_CLUSTER_SERVICE = 'identityLookup';\n\nconst CLUSTER_SERVICE = process.env.WEBEX_CONVERSATION_CLUSTER_SERVICE || DEFAULT_CLUSTER_SERVICE;\nconst DEFAULT_CLUSTER_IDENTIFIER =\n process.env.WEBEX_CONVERSATION_DEFAULT_CLUSTER || `${DEFAULT_CLUSTER}:${CLUSTER_SERVICE}`;\n\n/* eslint-disable no-underscore-dangle */\n/**\n * @class\n */\nconst Services = WebexPlugin.extend({\n namespace: 'Services',\n\n props: {\n validateDomains: ['boolean', false, true],\n initFailed: ['boolean', false, false],\n },\n\n _catalogs: new WeakMap(),\n\n _activeServices: {},\n\n _services: [],\n\n /**\n * @private\n * Get the current catalog based on the assocaited\n * webex instance.\n * @returns {IServiceCatalog}\n */\n _getCatalog(): IServiceCatalog {\n return this._catalogs.get(this.webex);\n },\n\n /**\n * Get a service url from the current services list by name\n * from the associated instance catalog.\n * @param {string} name\n * @param {ServiceGroup} [serviceGroup]\n * @returns {string|undefined}\n */\n get(name: string, serviceGroup?: ServiceGroup): string | undefined {\n const catalog = this._getCatalog();\n\n const clusterId = this._activeServices[name];\n\n const urlById = catalog.get(clusterId, serviceGroup);\n const urlByName = catalog.get(name, serviceGroup);\n\n // if both are undefined, then we cannot find the service\n if (!urlById && !urlByName) {\n return undefined;\n }\n\n return urlById || urlByName;\n },\n\n /**\n * Determine if a whilelist exists in the service catalog.\n *\n * @returns {boolean} - True if a allowed domains list exists.\n */\n hasAllowedDomains(): boolean {\n const catalog = this._getCatalog();\n\n return catalog.getAllowedDomains().length > 0;\n },\n\n /**\n * Mark a priority host service url as failed.\n * This will mark the service url associated with the\n * `ServiceDetail` to be removed from the its\n * respective service url array, and then return the next\n * viable service url from the `ServiceDetail` service url array.\n * @param {string} url\n * @returns {string}\n */\n markFailedUrl(url: string): string | undefined {\n const catalog = this._getCatalog();\n\n return catalog.markFailedServiceUrl(url);\n },\n\n /**\n * saves all the services from the pre and post catalog service\n * @param {ActiveServices} activeServices\n * @returns {void}\n */\n _updateActiveServices(activeServices: ActiveServices): void {\n this._activeServices = {...this._activeServices, ...activeServices};\n },\n\n /**\n * saves the hostCatalog object\n * @param {Array<Service>} services\n * @returns {void}\n */\n _updateServices(services: Array<Service>): void {\n this._services = unionBy(services, this._services, 'id');\n },\n\n /**\n * Update a list of `serviceUrls` to the most current\n * catalog via the defined `discoveryUrl` then returns the current\n * list of services.\n * @param {object} [param]\n * @param {string} [param.from] - This accepts `limited` or `signin`\n * @param {object} [param.query] - This accepts `email`, `orgId` or `userId` key values\n * @param {string} [param.query.email] - must be a standard-format email\n * @param {string} [param.query.orgId] - must be an organization id\n * @param {string} [param.query.userId] - must be a user id\n * @param {string} [param.token] - used for signin catalog\n * @returns {Promise<object>}\n */\n updateServices(\n {from, query, token, forceRefresh} = {} as {\n from: string;\n query: QueryOptions;\n token: string;\n forceRefresh: boolean;\n }\n ): Promise<object> {\n const catalog = this._getCatalog();\n let formattedQuery;\n let serviceGroup;\n\n // map catalog name to service group name.\n switch (from) {\n case 'limited':\n serviceGroup = 'preauth';\n break;\n case 'signin':\n serviceGroup = 'signin';\n break;\n default:\n serviceGroup = 'postauth';\n break;\n }\n // confirm catalog update for group is not in progress.\n if (catalog.status?.[serviceGroup]?.collecting) {\n return this.waitForCatalog(serviceGroup);\n }\n\n catalog.status[serviceGroup].collecting = true;\n\n if (serviceGroup === 'preauth') {\n const queryKey = query && Object.keys(query)[0];\n\n if (!['email', 'emailhash', 'userId', 'orgId', 'mode'].includes(queryKey)) {\n return Promise.reject(\n new Error('a query param of email, emailhash, userId, orgId, or mode is required')\n );\n }\n }\n // encode email when query key is email\n if (serviceGroup === 'preauth' || serviceGroup === 'signin') {\n const queryKey = Object.keys(query)[0];\n\n formattedQuery = {};\n\n if (queryKey === 'email' && query.email) {\n formattedQuery.emailhash = sha256(query.email.toLowerCase()).toString();\n } else {\n formattedQuery[queryKey] = query[queryKey];\n }\n }\n\n return this._fetchNewServiceHostmap({\n from,\n token,\n query: formattedQuery,\n forceRefresh,\n })\n .then((serviceHostMap: ServiceHostmap) => {\n catalog.updateServiceGroups(\n serviceGroup,\n serviceHostMap?.services,\n serviceHostMap?.timestamp\n );\n this.updateCredentialsConfig();\n catalog.status[serviceGroup].collecting = false;\n })\n .catch((error) => {\n catalog.status[serviceGroup].collecting = false;\n\n return Promise.reject(error);\n });\n },\n\n /**\n * User validation parameter transfer object for {@link validateUser}.\n * @param {object} ValidateUserPTO\n * @property {string} ValidateUserPTO.email - The email of the user.\n * @property {string} [ValidateUserPTO.reqId] - The activation requester.\n * @property {object} [ValidateUserPTO.activationOptions] - Extra options to pass when sending the activation\n * @property {object} [ValidateUserPTO.preloginUserId] - The prelogin user id to set when sending the activation.\n */\n\n /**\n * User validation return transfer object for {@link validateUser}.\n * @param {object} ValidateUserRTO\n * @property {boolean} ValidateUserRTO.activated - If the user is activated.\n * @property {boolean} ValidateUserRTO.exists - If the user exists.\n * @property {string} ValidateUserRTO.details - A descriptive status message.\n * @property {object} ValidateUserRTO.user - **License** service user object.\n */\n\n /**\n * Validate if a user is activated and update the service catalogs as needed\n * based on the user's activation status.\n *\n * @param {ValidateUserPTO} - The parameter transfer object.\n * @returns {ValidateUserRTO} - The return transfer object.\n */\n validateUser({\n email,\n reqId = 'WEBCLIENT',\n forceRefresh = false,\n activationOptions = {},\n preloginUserId,\n }) {\n this.logger.info('services: validating a user');\n\n // Validate that an email parameter key was provided.\n if (!email) {\n return Promise.reject(new Error('`email` is required'));\n }\n\n // Destructure the credentials object.\n const {canAuthorize} = this.webex.credentials;\n\n // Validate that the user is already authorized.\n if (canAuthorize) {\n return this.updateServices({forceRefresh})\n .then(() => this.webex.credentials.getUserToken())\n .then((token) =>\n this.sendUserActivation({\n email,\n reqId,\n token: token.toString(),\n activationOptions,\n preloginUserId,\n })\n )\n .then((userObj) => ({\n activated: true,\n exists: true,\n details: 'user is authorized via a user token',\n user: userObj,\n }));\n }\n\n // Destructure the client authorization details.\n /* eslint-disable camelcase */\n const {client_id, client_secret} = this.webex.credentials.config;\n\n // Validate that client authentication details exist.\n if (!client_id || !client_secret) {\n return Promise.reject(new Error('client authentication details are not available'));\n }\n /* eslint-enable camelcase */\n\n // Declare a class-memeber-scoped token for usage within the promise chain.\n let token;\n\n // Begin client authentication user validation.\n return (\n this.collectPreauthCatalog({email})\n .then(() => {\n // Retrieve the service url from the updated catalog. This is required\n // since `WebexCore` is usually not fully initialized at the time this\n // request completes.\n const idbrokerService = this.get('idbroker');\n\n // Collect the client auth token.\n return this.webex.credentials.getClientToken({\n uri: `${idbrokerService}idb/oauth2/v1/access_token`,\n scope: 'webexsquare:admin webexsquare:get_conversation Identity:SCIM',\n });\n })\n .then((tokenObj) => {\n // Generate the token string.\n token = tokenObj.toString();\n\n // Collect the signin catalog using the client auth information.\n return this.collectSigninCatalog({email, token, forceRefresh});\n })\n // Validate if collecting the signin catalog failed and populate the RTO\n // with the appropriate content.\n .catch((error) => ({\n exists: error.name !== 'NotFound',\n activated: false,\n details:\n error.name !== 'NotFound'\n ? 'user exists but is not activated'\n : 'user does not exist and is not activated',\n }))\n // Validate if the previous promise resolved with an RTO and populate the\n // new RTO accordingly.\n .then((rto) =>\n Promise.all([\n rto || {\n activated: true,\n exists: true,\n details: 'user exists and is activated',\n },\n this.sendUserActivation({\n email,\n reqId,\n token,\n activationOptions,\n preloginUserId,\n }),\n ])\n )\n .then(([rto, user]) => ({...rto, user}))\n .catch((error) => {\n const response = {\n statusCode: error.statusCode,\n responseText: error.body && error.body.message,\n body: error.body,\n };\n\n return Promise.reject(response);\n })\n );\n },\n /**\n * Update cluster id via mercury service update. If the cluster id does not exist,\n * fetch new catalog.\n *\n * @param {ActiveServices} newActiveClusters - The new active clusters to switch to.\n * @returns {Promsie<void>}\n * */\n switchActiveClusterIds(newActiveClusters: ActiveServices): Promise<void> {\n this.logger.info('services: switching active cluster ids');\n\n const newActiveClusterIds = Object.values(newActiveClusters);\n\n const missingClusterIds = newActiveClusterIds.some((clusterId) => {\n // if the clusterId does not exist in the catalog, fetch the catalog\n return !this._services.find((service) => service.id === clusterId);\n });\n\n if (missingClusterIds) {\n this.logger.warn(\n 'services: some cluster ids do not exist in the catalog, fetching the catalog'\n );\n\n // fetch the catalog\n return this.initServiceCatalogs(true);\n }\n // update the active services\n this._updateActiveServices(newActiveClusters);\n this.logger.info('services: active cluster ids updated successfully');\n\n return Promise.resolve();\n },\n\n /**\n * Invalidate cache via mercury notification. If the timestamp is newer than current,\n * refetch catalog services.\n *\n * @param {string} timestamp - The timestamp of invalidation notification.\n * @returns {Promsie<void>}\n * */\n invalidateCache(timestamp: string): Promise<void> {\n this.logger.info('services: invalidate cache, timestamp:', timestamp);\n const lastTime = toNumber(this._getCatalog()?.timestamp) || 0;\n const invalidateTime = toNumber(timestamp) || 0;\n if (invalidateTime > lastTime) {\n this.logger.info('services: invalidateCache, refresh services');\n this.initServiceCatalogs(true);\n }\n\n return Promise.resolve();\n },\n /**\n * Get user meeting preferences (preferred webex site).\n *\n * @returns {object} - User Information including user preferrences .\n */\n getMeetingPreferences() {\n return this.request({\n method: 'GET',\n service: 'hydra',\n resource: 'meetingPreferences',\n })\n .then((res) => {\n this.logger.info('services: received user region info');\n\n return res.body;\n })\n .catch((err) => {\n this.logger.info('services: was not able to fetch user login information', err);\n // resolve successfully even if request failed\n });\n },\n\n /**\n * Fetches client region info such as countryCode and timezone.\n *\n * @returns {object} - The region info object.\n */\n fetchClientRegionInfo() {\n const {services} = this.webex.config;\n\n return this.request({\n uri: services.discovery.sqdiscovery,\n addAuthHeader: false,\n headers: {\n 'spark-user-agent': null,\n },\n timeout: 5000,\n })\n .then((res) => {\n this.logger.info('services: received user region info');\n\n return res.body;\n })\n .catch((err) => {\n this.logger.info('services: was not able to get user region info', err);\n // resolve successfully even if request failed\n });\n },\n\n /**\n * User activation parameter transfer object for {@link sendUserActivation}.\n * @typedef {object} SendUserActivationPTO\n * @property {string} SendUserActivationPTO.email - The email of the user.\n * @property {string} SendUserActivationPTO.reqId - The activation requester.\n * @property {string} SendUserActivationPTO.token - The client auth token.\n * @property {object} SendUserActivationPTO.activationOptions - Extra options to pass when sending the activation.\n * @property {object} SendUserActivationPTO.preloginUserId - The prelogin user id to set when sending the activation.\n */\n\n /**\n * Send a request to activate a user using a client token.\n *\n * @param {SendUserActivationPTO} - The Parameter transfer object.\n * @returns {LicenseDTO} - The DTO returned from the **License** service.\n */\n sendUserActivation({email, reqId, token, activationOptions, preloginUserId}) {\n this.logger.info('services: sending user activation request');\n let countryCode;\n let timezone;\n\n // try to fetch client region info first\n return (\n this.fetchClientRegionInfo()\n .then((clientRegionInfo) => {\n if (clientRegionInfo) {\n ({countryCode, timezone} = clientRegionInfo);\n }\n\n // Send the user activation request to the **License** service.\n return this.request({\n service: 'license',\n resource: 'users/activations',\n method: 'POST',\n headers: {\n accept: 'application/json',\n authorization: token,\n 'x-prelogin-userid': preloginUserId,\n },\n body: {\n email,\n reqId,\n countryCode,\n timeZone: timezone,\n ...activationOptions,\n },\n shouldRefreshAccessToken: false,\n });\n })\n // On success, return the **License** user object.\n .then(({body}) => body)\n // On failure, reject with error from **License**.\n .catch((error) => Promise.reject(error))\n );\n },\n\n /**\n * Updates a given service group i.e. preauth, signin, postauth with a new hostmap.\n * @param {ServiceGroup} serviceGroup - preauth, signin, postauth\n * @param {ServiceHostmap} hostMap - The new hostmap to update the service group with.\n * @returns {Promise<void>}\n */\n updateCatalog(serviceGroup: ServiceGroup, hostMap: ServiceHostmap): Promise<void> {\n const catalog = this._getCatalog();\n\n const serviceHostMap = this._formatReceivedHostmap(hostMap);\n\n return catalog.updateServiceGroups(\n serviceGroup,\n serviceHostMap?.services,\n serviceHostMap?.timestamp\n );\n },\n\n /**\n * simplified method to update the preauth catalog via email\n *\n * @param {object} query\n * @param {string} query.email - A standard format email.\n * @param {string} query.orgId - The user's OrgId.\n * @param {boolean} forceRefresh - Boolean to bypass u2c cache control header\n * @returns {Promise<void>}\n */\n collectPreauthCatalog(query: QueryOptions, forceRefresh = false) {\n if (!query) {\n return this.updateServices({\n from: 'limited',\n query: {mode: 'DEFAULT_BY_PROXIMITY'},\n forceRefresh,\n });\n }\n\n return this.updateServices({from: 'limited', query, forceRefresh});\n },\n\n /**\n * simplified method to update the signin catalog via email and token\n * @param {object} param\n * @param {string} param.email - must be a standard-format email\n * @param {string} param.token - must be a client token\n * @returns {Promise<void>}\n */\n collectSigninCatalog(\n {email, token, forceRefresh} = {} as {email: string; token: string; forceRefresh: boolean}\n ): Promise<void> {\n if (!email) {\n return Promise.reject(new Error('`email` is required'));\n }\n if (!token) {\n return Promise.reject(new Error('`token` is required'));\n }\n\n return this.updateServices({\n from: 'signin',\n query: {email},\n token,\n forceRefresh,\n });\n },\n\n /**\n * Updates credentials config to utilize u2c catalog\n * urls.\n * @returns {void}\n */\n updateCredentialsConfig(): void {\n const idbrokerUrl = this.get('idbroker');\n const identityUrl = this.get('identity');\n\n if (idbrokerUrl && identityUrl) {\n const {authorizationString, authorizeUrl} = this.webex.config.credentials;\n\n // This must be set outside of the setConfig method used to assign the\n // idbroker and identity url values.\n this.webex.config.credentials.authorizeUrl = authorizationString\n ? authorizeUrl\n : `${idbrokerUrl.replace(trailingSlashes, '')}/idb/oauth2/v1/authorize`;\n\n this.webex.setConfig({\n credentials: {\n idbroker: {\n url: idbrokerUrl.replace(trailingSlashes, ''), // remove trailing slash\n },\n identity: {\n url: identityUrl.replace(trailingSlashes, ''), // remove trailing slash\n },\n },\n });\n }\n },\n\n /**\n * Wait until the service catalog is available,\n * or reject afte ra timeout of 60 seconds.\n * @param {ServiceGroup} serviceGroup\n * @param {number} [timeout] - in seconds\n * @returns {Promise<void>}\n */\n waitForCatalog(serviceGroup: ServiceGroup, timeout: number): Promise<void> {\n const catalog = this._getCatalog();\n const {supertoken} = this.webex.credentials;\n\n if (\n serviceGroup === 'postauth' &&\n supertoken &&\n supertoken.access_token &&\n !catalog.status.postauth.collecting &&\n !catalog.status.postauth.ready\n ) {\n if (!catalog.status.preauth.ready) {\n return this.initServiceCatalogs();\n }\n\n return this.updateServices();\n }\n\n return catalog.waitForCatalog(serviceGroup, timeout);\n },\n\n /**\n * Service waiting parameter transfer object for {@link waitForService}.\n *\n * @typedef {object} WaitForServicePTO\n * @property {string} [WaitForServicePTO.name] - The service name.\n * @property {string} [WaitForServicePTO.url] - The service url.\n * @property {string} [WaitForServicePTO.timeout] - wait duration in seconds.\n */\n\n /**\n * Wait until the service has been ammended to any service catalog. This\n * method prioritizes the service name over the service url when searching.\n *\n * @param {WaitForServicePTO} - The parameter transfer object.\n * @returns {Promise<string>} - Resolves to the priority host of a service.\n */\n waitForService({\n name,\n timeout = 5,\n url,\n }: {\n name: string;\n timeout: number;\n url: string;\n }): Promise<string> {\n const {services} = this.webex.config;\n\n // Save memory by grabbing the catalog after there isn't a priortyURL\n const catalog = this._getCatalog();\n\n const fetchFromServiceUrl = services.servicesNotNeedValidation.find(\n (service) => service === name\n );\n\n if (fetchFromServiceUrl) {\n const clusterId = this._activeServices[name];\n\n return Promise.resolve(this.get(clusterId));\n }\n\n const priorityUrl = this.get(name);\n const priorityUrlObj = this.getServiceFromUrl(url);\n\n if (priorityUrl || priorityUrlObj) {\n return Promise.resolve(priorityUrl || priorityUrlObj.priorityUrl);\n }\n\n if (catalog.isReady) {\n if (url) {\n return Promise.resolve(url);\n }\n\n this.webex.internal.metrics.submitClientMetrics(METRICS.JS_SDK_SERVICE_NOT_FOUND, {\n fields: {service_name: name},\n });\n\n return Promise.reject(\n new Error(`services: service '${name}' was not found in any of the catalogs`)\n );\n }\n\n return new Promise((resolve, reject) => {\n const groupsToCheck = ['preauth', 'signin', 'postauth'];\n const checkCatalog = (catalogGroup) =>\n catalog\n .waitForCatalog(catalogGroup, timeout)\n .then(() => {\n const scopedPriorityUrl = this.get(name);\n const scopedPrioriryUrlObj = this.getServiceFromUrl(url);\n\n if (scopedPriorityUrl || scopedPrioriryUrlObj) {\n resolve(scopedPriorityUrl || scopedPrioriryUrlObj.priorityUrl);\n }\n })\n .catch(() => undefined);\n\n Promise.all(groupsToCheck.map((group) => checkCatalog(group))).then(() => {\n this.webex.internal.metrics.submitClientMetrics(METRICS.JS_SDK_SERVICE_NOT_FOUND, {\n fields: {service_name: name},\n });\n reject(new Error(`services: service '${name}' was not found after waiting`));\n });\n });\n },\n\n /**\n * Looks up the hostname in the host catalog\n * and replaces it with the first host if it finds it\n * @param {string} uri\n * @returns {string} uri with the host replaced\n */\n replaceHostFromHostmap(uri: string): string {\n try {\n return this.convertUrlToPriorityHostUrl(uri);\n } catch {\n return uri;\n }\n },\n\n /**\n * Formats a host map entry for use in service catalog.\n *\n * @param {Object} entry - The host map entry to format.\n * @param {string} entry.serviceName - i.e. conversation, identity, etc.\n * @param {string} entry.id - The unique identifier for the service, usually clusterId.\n * @param {Array<IServiceDetail>} entry.serviceUrls - The group to which the service belongs.\n * @returns {Object} - The formatted host map entry.\n */\n _formatHostMapEntry({id, serviceName, serviceUrls}) {\n const formattedServiceUrls = serviceUrls.map((serviceUrl) => ({\n host: new URL(serviceUrl.baseUrl).host,\n ...serviceUrl,\n }));\n\n return {\n id,\n serviceName,\n serviceUrls: formattedServiceUrls,\n };\n },\n\n /**\n * @private\n * Organize a received hostmap from a service\n * @param {ServiceHostmap} serviceHostmap\n * catalog endpoint.\n * @returns {Array<Service>}\n */\n _formatReceivedHostmap({services, activeServices, timestamp, orgId, format}) {\n const formattedHostmap: ServiceHostmap = {\n activeServices,\n services: services.map((service) => this._formatHostMapEntry(service)),\n timestamp,\n orgId,\n format,\n };\n this._updateActiveServices(activeServices);\n this._updateServices(services);\n\n return formattedHostmap;\n },\n\n /**\n * Get the clusterId associated with a URL string.\n * @param {string} url\n * @returns {string | undefined} - Cluster ID of url provided\n */\n getClusterId(url: string): string | undefined {\n const catalog = this._getCatalog();\n\n return catalog.findClusterId(url);\n },\n\n /**\n * Get a service value from a provided clusterId. This method will\n * return an object containing both the name and url of a found service.\n * @param {object} params\n * @param {string} params.clusterId - clusterId of found service\n * @param {ServiceGroup} [params.serviceGroup] - specify service group\n * @returns {object} service\n * @returns {string} service.name\n * @returns {string} service.url\n */\n getServiceFromClusterId(params: {\n clusterId: string;\n serviceGroup?: ServiceGroup;\n }): {name: string; url: string} | undefined {\n const catalog = this._getCatalog();\n\n return catalog.findServiceFromClusterId(params);\n },\n\n /**\n * @param {String} cluster the cluster containing the id\n * @param {UUID} [id] the id of the conversation.\n * If empty, just return the base URL.\n * @returns {String} url of the service\n */\n getServiceUrlFromClusterId({cluster = 'us'}: {cluster?: string} = {}): string {\n let clusterId = cluster === 'us' ? DEFAULT_CLUSTER_IDENTIFIER : cluster;\n\n // Determine if cluster has service name (non-US clusters from hydra do not)\n if (clusterId.split(':').length < 4) {\n // Add Service to cluster identifier\n clusterId = `${cluster}:${CLUSTER_SERVICE}`;\n }\n\n const {url} = this.getServiceFromClusterId({clusterId}) || {};\n\n if (!url) {\n throw Error(`Could not find service for cluster [${cluster}]`);\n }\n\n return url;\n },\n\n /**\n * Get a service object from a service url if the service url exists in the\n * catalog.\n *\n * @param {string} url - The url to be validated.\n * @returns {object} - Service object.\n * @returns {object.name} - The name of the service found.\n * @returns {object.priorityUrl} - The default url of the found service.\n * @returns {object.defaultUrl} - The default url of the found service.\n */\n getServiceFromUrl(url = ''): {name: string; priorityUrl: string; defaultUrl: string} | undefined {\n const service = this._getCatalog().findServiceDetailFromUrl(url);\n\n if (!service) {\n return undefined;\n }\n\n const priorityUrl = service.get();\n const defaultUrl = new URL(\n service.serviceUrls.find((serviceUrl) => url.startsWith(serviceUrl.baseUrl)).baseUrl\n ).href;\n\n return {\n name: service.serviceName,\n priorityUrl,\n defaultUrl,\n };\n },\n\n /**\n * Determine if a provided url is in the catalog's allowed domains.\n *\n * @param {string} url - The url to match allowed domains against.\n * @returns {boolean} - True if the url provided is allowed.\n */\n isAllowedDomainUrl(url: string): boolean {\n const catalog = this._getCatalog();\n\n return !!catalog.findAllowedDomain(url);\n },\n\n /**\n * Converts the host portion of the url from default host\n * to a priority host\n *\n * @param {string} url a service url that contains a default host\n * @returns {string} a service url that contains the top priority host.\n * @throws if url isn't a service url\n */\n convertUrlToPriorityHostUrl(url = '' as string): string {\n const data = this.getServiceFromUrl(url);\n\n if (!data) {\n throw Error(`No service associated with url: [${url}]`);\n }\n\n return url.replace(data.defaultUrl, data.priorityUrl);\n },\n\n /**\n * @private\n * Simplified method wrapper for sending a request to get\n * an updated service hostmap.\n * @param {object} [param]\n * @param {string} [param.from] - This accepts `limited` or `signin`\n * @param {object} [param.query] - This accepts `email`, `orgId` or `userId` key values\n * @param {string} [param.query.email] - must be a standard-format email\n * @param {string} [param.query.orgId] - must be an organization id\n * @param {string} [param.query.userId] - must be a user id\n * @param {string} [param.token] - used for signin catalog\n * @returns {Promise<object>}\n */\n _fetchNewServiceHostmap(\n {from, query, token, forceRefresh} = {} as {\n from: string;\n query: QueryOptions;\n token: string;\n forceRefresh: boolean;\n }\n ): Promise<object> {\n const service = 'u2c';\n const resource = from ? `/${from}/catalog` : '/catalog';\n const qs = {...(query || {}), format: 'U2CV2'};\n\n if (forceRefresh) {\n qs.timestamp = new Date().getTime();\n }\n\n const requestObject = {\n method: 'GET',\n service,\n resource,\n qs,\n headers: {},\n };\n\n if (token) {\n requestObject.headers = {authorization: token};\n }\n\n return this.webex.internal.newMetrics.callDiagnosticLatencies\n .measureLatency(() => this.request(requestObject), 'internal.get.u2c.time')\n .then(({body}) => this._formatReceivedHostmap(body));\n },\n\n /**\n * Initialize the discovery services and the whitelisted services.\n *\n * @returns {void}\n */\n initConfig(): void {\n // Get the catalog and destructure the services config.\n const catalog = this._getCatalog();\n const {services, fedramp} = this.webex.config;\n\n // Validate that the services configuration exists.\n if (services) {\n if (fedramp) {\n services.discovery = fedRampServices;\n }\n // Check for discovery services.\n if (services.discovery) {\n // Format the discovery configuration into an injectable array.\n const formattedDiscoveryServices = Object.keys(services.discovery).map((key) =>\n this._formatHostMapEntry({\n id: key,\n serviceName: key,\n serviceUrls: [{baseUrl: services.discovery[key], priority: 1}],\n })\n );\n\n // Inject formatted discovery services into services catalog.\n catalog.updateServiceGroups('discovery', formattedDiscoveryServices);\n }\n\n if (services.override) {\n // Format the override configuration into an injectable array.\n const formattedOverrideServices = Object.keys(services.override).map((key) =>\n this._formatHostMapEntry({\n id: key,\n serviceName: key,\n serviceUrls: [{baseUrl: services.override[key], priority: 1}],\n })\n );\n\n // Inject formatted override services into services catalog.\n catalog.updateServiceGroups('override', formattedOverrideServices);\n }\n\n // if not fedramp, append on the commercialAllowedDomains\n if (!fedramp) {\n services.allowedDomains = union(services.allowedDomains, COMMERCIAL_ALLOWED_DOMAINS);\n }\n\n // Check for allowed host domains.\n if (services.allowedDomains) {\n // Store the allowed domains as a property of the catalog.\n catalog.setAllowedDomains(services.allowedDomains);\n }\n\n // Set `validateDomains` property to match configuration\n this.validateDomains = services.validateDomains;\n }\n },\n\n /**\n * Make the initial requests to collect the root catalogs.\n * @param {boolean} refresh - Is need force update\n * @returns {Promise<void, Error>} - Errors if the token is unavailable.\n */\n initServiceCatalogs(refresh = false): Promise<void> {\n this.logger.info('services: initializing initial service catalogs');\n\n // Destructure the credentials plugin.\n const {credentials} = this.webex;\n\n // Init a promise chain. Must be done as a Promise.resolve() to allow\n // credentials#getOrgId() to properly throw.\n return (\n Promise.resolve()\n // Get the user's OrgId.\n .then(() => credentials.getOrgId())\n // Begin collecting the preauth/limited catalog.\n .then((orgId) => this.collectPreauthCatalog({orgId}, refresh))\n .then(() => {\n // Validate if the token is authorized.\n if (credentials.canAuthorize) {\n // Attempt to collect the postauth catalog.\n return this.updateServices({forceRefresh: refresh}).catch(() => {\n this.initFailed = true;\n this.logger.warn('services: cannot retrieve postauth catalog');\n });\n }\n\n // Return a resolved promise for consistent return value.\n return Promise.resolve();\n })\n );\n },\n\n /**\n * Initializer\n *\n * @instance\n * @memberof Services\n * @returns {Services}\n */\n initialize(): typeof Services {\n const catalog = new ServiceCatalog();\n this._catalogs.set(this.webex, catalog);\n\n // Listen for configuration changes once.\n this.listenToOnce(this.webex, 'change:config', () => {\n this.initConfig();\n });\n\n // wait for webex instance to be ready before attempting\n // to update the service catalogs\n this.listenToOnce(this.webex, 'ready', () => {\n const {supertoken} = this.webex.credentials;\n // Validate if the supertoken exists.\n if (supertoken && supertoken.access_token) {\n this.initServiceCatalogs()\n .then(() => {\n catalog.isReady = true;\n })\n .catch((error) => {\n this.initFailed = true;\n this.logger.error(\n `services: failed to init initial services when credentials available, ${error?.message}`\n );\n });\n } else {\n const {email} = this.webex.config;\n\n this.collectPreauthCatalog(email ? {email} : undefined).catch((error) => {\n this.initFailed = true;\n this.logger.error(\n `services: failed to init initial services when no credentials available, ${error?.message}`\n );\n });\n }\n });\n },\n});\n/* eslint-enable no-underscore-dangle */\n\nexport default Services;\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["type ServiceName = string;\ntype ClusterId = string;\nexport type ServiceGroup = 'discovery' | 'override' | 'preauth' | 'postauth' | 'signin';\n\nexport type ServiceUrl = {\n baseUrl: string;\n host: string;\n priority: number;\n failed?: boolean;\n};\n\nexport type ActiveServices = Record<ServiceName, ClusterId>;\nexport type Service = {\n id: ClusterId;\n serviceName: ServiceName;\n serviceUrls: Array<ServiceUrl>;\n};\nexport type QueryOptions = {\n email?: string;\n orgId?: string;\n userId?: string;\n timestamp?: number;\n};\n\nexport interface ServiceHostmap {\n activeServices: ActiveServices;\n services: Array<Service>;\n timeStamp: string;\n orgId: string;\n format: string;\n}\n\nexport interface IServiceDetail {\n id: ClusterId;\n serviceName: ServiceName;\n serviceUrls: Array<ServiceUrl>;\n failHost(url: string): boolean;\n get(): string;\n}\n\nexport interface IServiceCatalog {\n serviceGroups: {\n discovery: Array<IServiceDetail>;\n override: Array<IServiceDetail>;\n preauth: Array<IServiceDetail>;\n postauth: Array<IServiceDetail>;\n signin: Array<IServiceDetail>;\n };\n status: {\n discovery: {ready: boolean; collecting: boolean};\n override: {ready: boolean; collecting: boolean};\n preauth: {ready: boolean; collecting: boolean};\n postauth: {ready: boolean; collecting: boolean};\n signin: {ready: boolean; collecting: boolean};\n };\n isReady: boolean;\n allowedDomains: string[];\n clean(): void;\n findClusterId(url: string): string | undefined;\n findServiceFromClusterId(params: {\n clusterId: ClusterId;\n serviceGroup?: ServiceGroup;\n }): {name: string; url: string} | undefined;\n findServiceDetailFromUrl(url: string): IServiceDetail | undefined;\n findAllowedDomain(url: string): string | undefined;\n get(clusterId: ClusterId, serviceGroup?: ServiceGroup): string | undefined;\n getAllowedDomains(): string[];\n markFailedServiceUrl(url: string): string | undefined;\n setAllowedDomains(allowedDomains: string[]): void;\n addAllowedDomains(newAllowedDomains: string[]): void;\n updateServiceGroups(serviceGroup: ServiceGroup, serviceDetails: Array<IServiceDetail>): void;\n waitForCatalog(serviceGroup: ServiceGroup, timeout?: number): Promise<void>;\n}\n"],"mappings":""}
1
+ {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["type ServiceName = string;\ntype ClusterId = string;\nexport type ServiceGroup = 'discovery' | 'override' | 'preauth' | 'postauth' | 'signin';\n\nexport type ServiceUrl = {\n baseUrl: string;\n host: string;\n priority: number;\n failed?: boolean;\n};\n\nexport type ActiveServices = Record<ServiceName, ClusterId>;\nexport type Service = {\n id: ClusterId;\n serviceName: ServiceName;\n serviceUrls: Array<ServiceUrl>;\n};\nexport type QueryOptions = {\n email?: string;\n orgId?: string;\n userId?: string;\n timestamp?: number;\n};\n\nexport interface ServiceHostmap {\n activeServices: ActiveServices;\n services: Array<Service>;\n timestamp: string;\n orgId: string;\n format: string;\n}\n\nexport interface IServiceDetail {\n id: ClusterId;\n serviceName: ServiceName;\n serviceUrls: Array<ServiceUrl>;\n failHost(url: string): boolean;\n get(): string;\n}\n\nexport interface IServiceCatalog {\n serviceGroups: {\n discovery: Array<IServiceDetail>;\n override: Array<IServiceDetail>;\n preauth: Array<IServiceDetail>;\n postauth: Array<IServiceDetail>;\n signin: Array<IServiceDetail>;\n };\n status: {\n discovery: {ready: boolean; collecting: boolean};\n override: {ready: boolean; collecting: boolean};\n preauth: {ready: boolean; collecting: boolean};\n postauth: {ready: boolean; collecting: boolean};\n signin: {ready: boolean; collecting: boolean};\n };\n isReady: boolean;\n allowedDomains: string[];\n clean(): void;\n findClusterId(url: string): string | undefined;\n findServiceFromClusterId(params: {\n clusterId: ClusterId;\n serviceGroup?: ServiceGroup;\n }): {name: string; url: string} | undefined;\n findServiceDetailFromUrl(url: string): IServiceDetail | undefined;\n findAllowedDomain(url: string): string | undefined;\n get(clusterId: ClusterId, serviceGroup?: ServiceGroup): string | undefined;\n getAllowedDomains(): string[];\n markFailedServiceUrl(url: string): string | undefined;\n setAllowedDomains(allowedDomains: string[]): void;\n addAllowedDomains(newAllowedDomains: string[]): void;\n updateServiceGroups(serviceGroup: ServiceGroup, serviceDetails: Array<IServiceDetail>): void;\n waitForCatalog(serviceGroup: ServiceGroup, timeout?: number): Promise<void>;\n}\n"],"mappings":""}
@@ -57,7 +57,7 @@ var Logger = _webexPlugin.default.extend({
57
57
  info: wrapConsoleMethod('info'),
58
58
  debug: wrapConsoleMethod('debug'),
59
59
  trace: wrapConsoleMethod('trace'),
60
- version: "3.9.0-next.3"
60
+ version: "3.9.0-next.4"
61
61
  });
62
62
  (0, _webexCore.registerPlugin)('logger', Logger);
63
63
  var _default = exports.default = Logger;
@@ -96,7 +96,7 @@ var MAX_FILE_SIZE_IN_MB = 2048;
96
96
  * @class
97
97
  */
98
98
  var WebexCore = _ampersandState.default.extend((_obj = {
99
- version: "3.9.0-next.3",
99
+ version: "3.9.0-next.4",
100
100
  children: {
101
101
  internal: _webexInternalCore.default
102
102
  },
@@ -634,7 +634,7 @@ var WebexCore = _ampersandState.default.extend((_obj = {
634
634
  });
635
635
  }
636
636
  }, ((0, _applyDecoratedDescriptor2.default)(_obj, "_uploadPhaseUpload", [_common.retry], (0, _getOwnPropertyDescriptor.default)(_obj, "_uploadPhaseUpload"), _obj)), _obj));
637
- WebexCore.version = "3.9.0-next.3";
637
+ WebexCore.version = "3.9.0-next.4";
638
638
  (0, _webexInternalCorePluginMixin.default)(_webexInternalCore.default, _config.default, interceptors);
639
639
  (0, _webexCorePluginMixin.default)(WebexCore, _config.default, interceptors);
640
640
  var _default = exports.default = WebexCore;
package/package.json CHANGED
@@ -20,7 +20,7 @@
20
20
  "directory": "packages/@webex/webex-core"
21
21
  },
22
22
  "engines": {
23
- "node": ">=16"
23
+ "node": ">=18"
24
24
  },
25
25
  "browserify": {
26
26
  "transform": [
@@ -33,10 +33,10 @@
33
33
  "@sinonjs/fake-timers": "^6.0.1",
34
34
  "@webex/babel-config-legacy": "0.0.0",
35
35
  "@webex/eslint-config-legacy": "0.0.0",
36
- "@webex/internal-plugin-device": "3.9.0-next.3",
36
+ "@webex/internal-plugin-device": "3.9.0-next.4",
37
37
  "@webex/jest-config-legacy": "0.0.0",
38
38
  "@webex/legacy-tools": "0.0.0",
39
- "@webex/plugin-logger": "3.9.0-next.3",
39
+ "@webex/plugin-logger": "3.9.0-next.4",
40
40
  "@webex/test-helper-chai": "3.8.1-next.11",
41
41
  "@webex/test-helper-make-local-url": "3.8.1-next.11",
42
42
  "@webex/test-helper-mocha": "3.8.1-next.11",
@@ -73,5 +73,5 @@
73
73
  "test:style": "eslint ./src/**/*.*",
74
74
  "test:unit": "webex-legacy-tools test --unit --runner jest"
75
75
  },
76
- "version": "3.9.0-next.3"
76
+ "version": "3.9.0-next.4"
77
77
  }
@@ -49,6 +49,7 @@ const ServiceCatalog = AmpState.extend({
49
49
  }),
50
50
  ],
51
51
  isReady: ['boolean', false, false],
52
+ timestamp: ['string', false, ''],
52
53
  allowedDomains: ['array', false, () => []],
53
54
  },
54
55
 
@@ -300,9 +301,14 @@ const ServiceCatalog = AmpState.extend({
300
301
  * @emits ServiceCatalog#postauthorized
301
302
  * @param {ServiceGroup} serviceGroup
302
303
  * @param {Array<IServiceDetail>} serviceDetails
304
+ * @param {timestamp<string>} timestamp of the catalog
303
305
  * @returns {void}
304
306
  */
305
- updateServiceGroups(serviceGroup: ServiceGroup, serviceDetails: Array<IServiceDetail>) {
307
+ updateServiceGroups(
308
+ serviceGroup: ServiceGroup,
309
+ serviceDetails: Array<IServiceDetail>,
310
+ timestamp?: string
311
+ ) {
306
312
  const currentServiceDetails = this.serviceGroups[serviceGroup];
307
313
 
308
314
  const unusedServicesDetails = currentServiceDetails.filter((serviceDetail) =>
@@ -321,6 +327,7 @@ const ServiceCatalog = AmpState.extend({
321
327
  }
322
328
  });
323
329
 
330
+ this.timestamp = timestamp;
324
331
  this.status[serviceGroup].ready = true;
325
332
  this.trigger(serviceGroup);
326
333
  },
@@ -1,6 +1,6 @@
1
1
  import sha256 from 'crypto-js/sha256';
2
2
 
3
- import {union, unionBy} from 'lodash';
3
+ import {toNumber, union, unionBy} from 'lodash';
4
4
  import WebexPlugin from '../webex-plugin';
5
5
 
6
6
  import METRICS from '../metrics';
@@ -159,9 +159,8 @@ const Services = WebexPlugin.extend({
159
159
  serviceGroup = 'postauth';
160
160
  break;
161
161
  }
162
-
163
162
  // confirm catalog update for group is not in progress.
164
- if (catalog.status[serviceGroup].collecting) {
163
+ if (catalog.status?.[serviceGroup]?.collecting) {
165
164
  return this.waitForCatalog(serviceGroup);
166
165
  }
167
166
 
@@ -196,7 +195,11 @@ const Services = WebexPlugin.extend({
196
195
  forceRefresh,
197
196
  })
198
197
  .then((serviceHostMap: ServiceHostmap) => {
199
- catalog.updateServiceGroups(serviceGroup, serviceHostMap);
198
+ catalog.updateServiceGroups(
199
+ serviceGroup,
200
+ serviceHostMap?.services,
201
+ serviceHostMap?.timestamp
202
+ );
200
203
  this.updateCredentialsConfig();
201
204
  catalog.status[serviceGroup].collecting = false;
202
205
  })
@@ -345,7 +348,56 @@ const Services = WebexPlugin.extend({
345
348
  })
346
349
  );
347
350
  },
351
+ /**
352
+ * Update cluster id via mercury service update. If the cluster id does not exist,
353
+ * fetch new catalog.
354
+ *
355
+ * @param {ActiveServices} newActiveClusters - The new active clusters to switch to.
356
+ * @returns {Promsie<void>}
357
+ * */
358
+ switchActiveClusterIds(newActiveClusters: ActiveServices): Promise<void> {
359
+ this.logger.info('services: switching active cluster ids');
360
+
361
+ const newActiveClusterIds = Object.values(newActiveClusters);
362
+
363
+ const missingClusterIds = newActiveClusterIds.some((clusterId) => {
364
+ // if the clusterId does not exist in the catalog, fetch the catalog
365
+ return !this._services.find((service) => service.id === clusterId);
366
+ });
367
+
368
+ if (missingClusterIds) {
369
+ this.logger.warn(
370
+ 'services: some cluster ids do not exist in the catalog, fetching the catalog'
371
+ );
372
+
373
+ // fetch the catalog
374
+ return this.initServiceCatalogs(true);
375
+ }
376
+ // update the active services
377
+ this._updateActiveServices(newActiveClusters);
378
+ this.logger.info('services: active cluster ids updated successfully');
348
379
 
380
+ return Promise.resolve();
381
+ },
382
+
383
+ /**
384
+ * Invalidate cache via mercury notification. If the timestamp is newer than current,
385
+ * refetch catalog services.
386
+ *
387
+ * @param {string} timestamp - The timestamp of invalidation notification.
388
+ * @returns {Promsie<void>}
389
+ * */
390
+ invalidateCache(timestamp: string): Promise<void> {
391
+ this.logger.info('services: invalidate cache, timestamp:', timestamp);
392
+ const lastTime = toNumber(this._getCatalog()?.timestamp) || 0;
393
+ const invalidateTime = toNumber(timestamp) || 0;
394
+ if (invalidateTime > lastTime) {
395
+ this.logger.info('services: invalidateCache, refresh services');
396
+ this.initServiceCatalogs(true);
397
+ }
398
+
399
+ return Promise.resolve();
400
+ },
349
401
  /**
350
402
  * Get user meeting preferences (preferred webex site).
351
403
  *
@@ -462,7 +514,11 @@ const Services = WebexPlugin.extend({
462
514
 
463
515
  const serviceHostMap = this._formatReceivedHostmap(hostMap);
464
516
 
465
- return catalog.updateServiceGroups(serviceGroup, serviceHostMap);
517
+ return catalog.updateServiceGroups(
518
+ serviceGroup,
519
+ serviceHostMap?.services,
520
+ serviceHostMap?.timestamp
521
+ );
466
522
  },
467
523
 
468
524
  /**
@@ -698,8 +754,14 @@ const Services = WebexPlugin.extend({
698
754
  * catalog endpoint.
699
755
  * @returns {Array<Service>}
700
756
  */
701
- _formatReceivedHostmap({services, activeServices}) {
702
- const formattedHostmap = services.map((service) => this._formatHostMapEntry(service));
757
+ _formatReceivedHostmap({services, activeServices, timestamp, orgId, format}) {
758
+ const formattedHostmap: ServiceHostmap = {
759
+ activeServices,
760
+ services: services.map((service) => this._formatHostMapEntry(service)),
761
+ timestamp,
762
+ orgId,
763
+ format,
764
+ };
703
765
  this._updateActiveServices(activeServices);
704
766
  this._updateServices(services);
705
767
 
@@ -927,10 +989,10 @@ const Services = WebexPlugin.extend({
927
989
 
928
990
  /**
929
991
  * Make the initial requests to collect the root catalogs.
930
- *
992
+ * @param {boolean} refresh - Is need force update
931
993
  * @returns {Promise<void, Error>} - Errors if the token is unavailable.
932
994
  */
933
- initServiceCatalogs(): Promise<void> {
995
+ initServiceCatalogs(refresh = false): Promise<void> {
934
996
  this.logger.info('services: initializing initial service catalogs');
935
997
 
936
998
  // Destructure the credentials plugin.
@@ -943,12 +1005,12 @@ const Services = WebexPlugin.extend({
943
1005
  // Get the user's OrgId.
944
1006
  .then(() => credentials.getOrgId())
945
1007
  // Begin collecting the preauth/limited catalog.
946
- .then((orgId) => this.collectPreauthCatalog({orgId}))
1008
+ .then((orgId) => this.collectPreauthCatalog({orgId}, refresh))
947
1009
  .then(() => {
948
1010
  // Validate if the token is authorized.
949
1011
  if (credentials.canAuthorize) {
950
1012
  // Attempt to collect the postauth catalog.
951
- return this.updateServices().catch(() => {
1013
+ return this.updateServices({forceRefresh: refresh}).catch(() => {
952
1014
  this.initFailed = true;
953
1015
  this.logger.warn('services: cannot retrieve postauth catalog');
954
1016
  });
@@ -25,7 +25,7 @@ export type QueryOptions = {
25
25
  export interface ServiceHostmap {
26
26
  activeServices: ActiveServices;
27
27
  services: Array<Service>;
28
- timeStamp: string;
28
+ timestamp: string;
29
29
  orgId: string;
30
30
  format: string;
31
31
  }