@webex/internal-plugin-mercury 3.0.0-beta.34 → 3.0.0-beta.340
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/mercury.js +41 -33
- package/dist/mercury.js.map +1 -1
- package/dist/socket/socket-base.js +33 -27
- package/dist/socket/socket-base.js.map +1 -1
- package/package.json +14 -14
- package/src/mercury.js +41 -32
- package/src/socket/socket-base.js +50 -27
- package/test/integration/spec/webex.js +3 -2
- package/test/unit/spec/mercury.js +13 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["sockets","Socket","onmessage","bind","onclose","get","binaryType","bufferedAmount","extensions","protocol","readyState","url","options","resolve","reject","socket","logger","info","code","Error","reason","closeTimer","safeSetTimeout","error","warn","forceCloseDelay","event","clearTimeout","close","checkRequired","forEach","key","enumerable","value","WebSocket","getWebSocketConstructor","_fixCloseCode","UnknownResponse","BadRequest","NotAuthorized","Forbidden","ConnectionError","onopen","_authorize","then","catch","onerror","set","pongTimer","pingTimer","emit","removeAllListeners","data","JSON","parse","sequenceNumber","debug","expectedSequenceNumber","processedEvent","_acknowledge","type","send","messageId","id","uuid","v4","token","trackingId","logLevelToken","waitForBufferState","eventType","removeListener","_ping","once","toLowerCase","confirmPongId","onPongNotReceived","scheduleNextPingAndCancelPongTimer","pingInterval","pongTimeout","EventEmitter"],"sources":["socket-base.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {EventEmitter} from 'events';\n\nimport {checkRequired} from '@webex/common';\nimport {safeSetTimeout} from '@webex/common-timers';\nimport {defaults, has, isObject} from 'lodash';\nimport uuid from 'uuid';\n\nimport {\n BadRequest,\n ConnectionError,\n Forbidden,\n NotAuthorized,\n UnknownResponse,\n // NotFound\n} from '../errors';\n\nconst sockets = new WeakMap();\n\n/**\n * Generalized socket abstraction\n */\nexport default class Socket extends EventEmitter {\n /**\n * constructor\n * @returns {Socket}\n */\n constructor() {\n super();\n this.onmessage = this.onmessage.bind(this);\n this.onclose = this.onclose.bind(this);\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get binaryType() {\n return sockets.get(this).binaryType;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {number}\n */\n get bufferedAmount() {\n return sockets.get(this).bufferedAmount;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get extensions() {\n return sockets.get(this).extensions;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get protocol() {\n return sockets.get(this).protocol;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {number}\n */\n get readyState() {\n return sockets.get(this).readyState;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get url() {\n return sockets.get(this).url;\n }\n\n /**\n * Provides the environmentally appropriate constructor (ws in NodeJS,\n * WebSocket in browsers)\n * @returns {WebSocket}\n */\n static getWebSocketConstructor() {\n throw new Error(\n 'Socket.getWebSocketConstructor() must be implemented in an environmentally appropriate way'\n );\n }\n\n /**\n * Closes the socket\n * @param {Object} options\n * @param {string} options.reason\n * @param {number} options.code\n * @returns {Promise}\n */\n close(options) {\n return new Promise((resolve, reject) => {\n const socket = sockets.get(this);\n\n if (!socket) {\n // Open has not been called yet so there is no socket to close\n resolve();\n\n return;\n }\n // logger is defined once open is called\n this.logger.info('socket: closing');\n\n if (socket.readyState === 2 || socket.readyState === 3) {\n this.logger.info('socket: already closed');\n resolve();\n\n return;\n }\n\n options = options || {};\n if (options.code && options.code !== 1000 && (options.code < 3000 || options.code > 4999)) {\n reject(new Error('`options.code` must be 1000 or between 3000 and 4999 (inclusive)'));\n\n return;\n }\n\n options = defaults(options, {\n code: 1000,\n reason: 'Done',\n });\n\n const closeTimer = safeSetTimeout(() => {\n try {\n this.logger.info('socket: no close event received, forcing closure');\n resolve(\n this.onclose({\n code: 1000,\n reason: 'Done (forced)',\n })\n );\n } catch (error) {\n this.logger.warn('socket: force-close failed', error);\n }\n }, this.forceCloseDelay);\n\n socket.onclose = (event) => {\n this.logger.info('socket: close event fired', event.code, event.reason);\n clearTimeout(closeTimer);\n this.onclose(event);\n resolve(event);\n };\n\n socket.close(options.code, options.reason);\n });\n }\n\n /**\n * Opens a WebSocket\n * @param {string} url\n * @param {options} options\n * @param {number} options.forceCloseDelay (required)\n * @param {number} options.pingInterval (required)\n * @param {number} options.pongTimeout (required)\n * @param {string} options.token (required)\n * @param {string} options.trackingId (required)\n * @param {Logger} options.logger (required)\n * @param {string} options.logLevelToken\n * @returns {Promise}\n */\n open(url, options) {\n return new Promise((resolve, reject) => {\n /* eslint complexity: [0] */\n if (!url) {\n reject(new Error('`url` is required'));\n\n return;\n }\n\n if (sockets.get(this)) {\n reject(new Error('Socket#open() can only be called once per instance'));\n\n return;\n }\n\n options = options || {};\n\n checkRequired(\n ['forceCloseDelay', 'pingInterval', 'pongTimeout', 'token', 'trackingId', 'logger'],\n options\n );\n\n Object.keys(options).forEach((key) => {\n Reflect.defineProperty(this, key, {\n enumerable: false,\n value: options[key],\n });\n });\n\n const WebSocket = Socket.getWebSocketConstructor();\n\n this.logger.info('socket: creating WebSocket');\n const socket = new WebSocket(url, [], options);\n\n socket.binaryType = 'arraybuffer';\n socket.onmessage = this.onmessage;\n\n socket.onclose = (event) => {\n event = this._fixCloseCode(event);\n this.logger.info('socket: closed before open', event.code, event.reason);\n switch (event.code) {\n case 1005:\n // IE 11 doesn't seem to allow 4XXX codes, so if we get a 1005, assume\n // it's a bad websocket url. That'll trigger a device refresh; if it\n // turns out we had a bad token, the device refresh should 401 and\n // trigger a token refresh.\n return reject(new UnknownResponse(event));\n case 4400:\n return reject(new BadRequest(event));\n case 4401:\n return reject(new NotAuthorized(event));\n case 4403:\n return reject(new Forbidden(event));\n // case 4404:\n // return reject(new NotFound(event));\n default:\n return reject(new ConnectionError(event));\n }\n };\n\n socket.onopen = () => {\n this.logger.info('socket: connected');\n this._authorize()\n .then(() => {\n this.logger.info('socket: authorized');\n socket.onclose = this.onclose;\n resolve();\n })\n .catch(reject);\n };\n\n socket.onerror = (event) => {\n this.logger.warn('socket: error event fired', event);\n };\n\n sockets.set(this, socket);\n this.logger.info('socket: waiting for server');\n });\n }\n\n /**\n * Handles incoming CloseEvents\n * @param {CloseEvent} event\n * @returns {undefined}\n */\n onclose(event) {\n this.logger.info('socket: closed', event.code, event.reason);\n clearTimeout(this.pongTimer);\n clearTimeout(this.pingTimer);\n\n event = this._fixCloseCode(event);\n this.emit('close', event);\n\n // Remove all listeners to (a) avoid reacting to late pongs and (b) ensure\n // we don't have a retain cycle.\n this.removeAllListeners();\n }\n\n /**\n * Handles incoming message events\n * @param {MessageEvent} event\n * @returns {undefined}\n */\n onmessage(event) {\n try {\n const data = JSON.parse(event.data);\n const sequenceNumber = parseInt(data.sequenceNumber, 10);\n\n this.logger.debug('socket: sequence number: ', sequenceNumber);\n if (this.expectedSequenceNumber && sequenceNumber !== this.expectedSequenceNumber) {\n this.logger.debug(\n `socket: sequence number mismatch indicates lost mercury message. expected: ${this.expectedSequenceNumber}, actual: ${sequenceNumber}`\n );\n this.emit('sequence-mismatch', sequenceNumber, this.expectedSequenceNumber);\n }\n this.expectedSequenceNumber = sequenceNumber + 1;\n\n // Yes, it's a little weird looking; we want to emit message events that\n // look like normal socket message events, but event.data cannot be\n // modified and we don't actually care about anything but the data property\n const processedEvent = {data};\n\n this._acknowledge(processedEvent);\n if (data.type === 'pong') {\n this.emit('pong', processedEvent);\n } else {\n this.emit('message', processedEvent);\n }\n } catch (error) {\n // The above code should only be able to throw if we receive an unparsable\n // message from Mercury. At this time, the only action we have is to\n // ignore it and move on.\n /* istanbul ignore next */\n this.logger.warn('socket: error while receiving WebSocket message', error);\n }\n }\n\n /**\n * Sends a message up the socket\n * @param {mixed} data\n * @returns {Promise}\n */\n send(data) {\n return new Promise((resolve, reject) => {\n if (this.readyState !== 1) {\n return reject(new Error('INVALID_STATE_ERROR'));\n }\n\n if (isObject(data)) {\n data = JSON.stringify(data);\n }\n\n const socket = sockets.get(this);\n\n socket.send(data);\n\n return resolve();\n });\n }\n\n /**\n * Sends an acknowledgment for a specific event\n * @param {MessageEvent} event\n * @returns {Promise}\n */\n _acknowledge(event) {\n if (!event) {\n return Promise.reject(new Error('`event` is required'));\n }\n\n if (!has(event, 'data.id')) {\n return Promise.reject(new Error('`event.data.id` is required'));\n }\n\n return this.send({\n messageId: event.data.id,\n type: 'ack',\n });\n }\n\n /**\n * Sends an auth message up the socket\n * @private\n * @returns {Promise}\n */\n _authorize() {\n return new Promise((resolve) => {\n this.logger.info('socket: authorizing');\n this.send({\n id: uuid.v4(),\n type: 'authorization',\n data: {\n token: this.token,\n },\n trackingId: this.trackingId,\n logLevelToken: this.logLevelToken,\n });\n\n const waitForBufferState = (event) => {\n if (\n !event.data.type &&\n (event.data.data.eventType === 'mercury.buffer_state' ||\n event.data.data.eventType === 'mercury.registration_status')\n ) {\n this.removeListener('message', waitForBufferState);\n this._ping();\n resolve();\n }\n };\n\n this.once('message', waitForBufferState);\n });\n }\n\n /**\n * Deals with the fact that some browsers drop some close codes (but not\n * close reasons).\n * @param {CloseEvent} event\n * @private\n * @returns {CloseEvent}\n */\n _fixCloseCode(event) {\n if (event.code === 1005 && event.reason) {\n switch (event.reason.toLowerCase()) {\n case 'replaced':\n this.logger.info('socket: fixing CloseEvent code for reason: ', event.reason);\n event.code = 4000;\n break;\n case 'authentication failed':\n case 'authentication did not happen within the timeout window of 30000 seconds.':\n this.logger.info('socket: fixing CloseEvent code for reason: ', event.reason);\n event.code = 1008;\n break;\n default:\n // do nothing\n }\n }\n\n return event;\n }\n\n /**\n * Sends a ping up the socket and confirms we get it back\n * @param {[type]} id\n * @private\n * @returns {[type]}\n */\n _ping(id) {\n const confirmPongId = (event) => {\n try {\n this.logger.debug('socket: pong', event.data.id);\n if (event.data && event.data.id !== id) {\n this.logger.info('socket: received pong for wrong ping id, closing socket');\n this.logger.debug('socket: expected', id, 'received', event.data.id);\n this.close({\n code: 1000,\n reason: 'Pong mismatch',\n });\n }\n } catch (error) {\n // This try/catch block was added as a debugging step; to the best of my\n // knowledge, the above can never throw.\n /* istanbul ignore next */\n this.logger.error('socket: error occurred in confirmPongId', error);\n }\n };\n\n const onPongNotReceived = () => {\n try {\n this.logger.info('socket: pong not receive in expected period, closing socket');\n this.close({\n code: 1000,\n reason: 'Pong not received',\n }).catch((reason) => {\n this.logger.warn('socket: failed to close socket after missed pong', reason);\n });\n } catch (error) {\n // This try/catch block was added as a debugging step; to the best of my\n // knowledge, the above can never throw.\n /* istanbul ignore next */\n this.logger.error('socket: error occurred in onPongNotReceived', error);\n }\n };\n\n const scheduleNextPingAndCancelPongTimer = () => {\n try {\n clearTimeout(this.pongTimer);\n this.pingTimer = safeSetTimeout(() => this._ping(), this.pingInterval);\n } catch (error) {\n // This try/catch block was added as a debugging step; to the best of my\n // knowledge, the above can never throw.\n /* istanbul ignore next */\n this.logger.error('socket: error occurred in scheduleNextPingAndCancelPongTimer', error);\n }\n };\n\n id = id || uuid.v4();\n this.pongTimer = safeSetTimeout(onPongNotReceived, this.pongTimeout);\n this.once('pong', scheduleNextPingAndCancelPongTimer);\n this.once('pong', confirmPongId);\n\n this.logger.debug(`socket: ping ${id}`);\n\n return this.send({\n id,\n type: 'ping',\n });\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["sockets","Socket","_domain","onmessage","bind","onclose","get","binaryType","bufferedAmount","extensions","protocol","readyState","url","options","resolve","reject","socket","logger","info","code","Error","reason","closeTimer","safeSetTimeout","error","warn","forceCloseDelay","event","clearTimeout","close","URL","hostname","checkRequired","forEach","key","enumerable","value","WebSocket","getWebSocketConstructor","_fixCloseCode","UnknownResponse","BadRequest","NotAuthorized","Forbidden","ConnectionError","onopen","_authorize","then","catch","onerror","set","pongTimer","pingTimer","emit","removeAllListeners","data","JSON","parse","sequenceNumber","debug","expectedSequenceNumber","processedEvent","_acknowledge","type","send","messageId","id","uuid","v4","token","trackingId","logLevelToken","waitForBufferState","eventType","removeListener","_ping","once","toLowerCase","confirmPongId","onPongNotReceived","scheduleNextPingAndCancelPongTimer","pingInterval","pongTimeout","EventEmitter"],"sources":["socket-base.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {EventEmitter} from 'events';\n\nimport {checkRequired} from '@webex/common';\nimport {safeSetTimeout} from '@webex/common-timers';\nimport {defaults, has, isObject} from 'lodash';\nimport uuid from 'uuid';\n\nimport {\n BadRequest,\n ConnectionError,\n Forbidden,\n NotAuthorized,\n UnknownResponse,\n // NotFound\n} from '../errors';\n\nconst sockets = new WeakMap();\n\n/**\n * Generalized socket abstraction\n */\nexport default class Socket extends EventEmitter {\n /**\n * constructor\n * @returns {Socket}\n */\n constructor() {\n super();\n this._domain = 'unknown-domain';\n this.onmessage = this.onmessage.bind(this);\n this.onclose = this.onclose.bind(this);\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get binaryType() {\n return sockets.get(this).binaryType;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {number}\n */\n get bufferedAmount() {\n return sockets.get(this).bufferedAmount;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get extensions() {\n return sockets.get(this).extensions;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get protocol() {\n return sockets.get(this).protocol;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {number}\n */\n get readyState() {\n return sockets.get(this).readyState;\n }\n\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * @returns {string}\n */\n get url() {\n return sockets.get(this).url;\n }\n\n /**\n * Provides the environmentally appropriate constructor (ws in NodeJS,\n * WebSocket in browsers)\n * @returns {WebSocket}\n */\n static getWebSocketConstructor() {\n throw new Error(\n 'Socket.getWebSocketConstructor() must be implemented in an environmentally appropriate way'\n );\n }\n\n /**\n * Closes the socket\n * @param {Object} options\n * @param {string} options.reason\n * @param {number} options.code\n * @returns {Promise}\n */\n close(options) {\n return new Promise((resolve, reject) => {\n const socket = sockets.get(this);\n\n if (!socket) {\n // Open has not been called yet so there is no socket to close\n resolve();\n\n return;\n }\n // logger is defined once open is called\n this.logger.info(`socket,${this._domain}: closing`);\n\n if (socket.readyState === 2 || socket.readyState === 3) {\n this.logger.info(`socket,${this._domain}: already closed`);\n resolve();\n\n return;\n }\n\n options = options || {};\n if (options.code && options.code !== 1000 && (options.code < 3000 || options.code > 4999)) {\n reject(new Error('`options.code` must be 1000 or between 3000 and 4999 (inclusive)'));\n\n return;\n }\n\n options = defaults(options, {\n code: 1000,\n reason: 'Done',\n });\n\n const closeTimer = safeSetTimeout(() => {\n try {\n this.logger.info(`socket,${this._domain}: no close event received, forcing closure`);\n resolve(\n this.onclose({\n code: 1000,\n reason: 'Done (forced)',\n })\n );\n } catch (error) {\n this.logger.warn(`socket,${this._domain}: force-close failed`, error);\n }\n }, this.forceCloseDelay);\n\n socket.onclose = (event) => {\n this.logger.info(`socket,${this._domain}: close event fired`, event.code, event.reason);\n clearTimeout(closeTimer);\n this.onclose(event);\n resolve(event);\n };\n\n socket.close(options.code, options.reason);\n });\n }\n\n /**\n * Opens a WebSocket\n * @param {string} url\n * @param {options} options\n * @param {number} options.forceCloseDelay (required)\n * @param {number} options.pingInterval (required)\n * @param {number} options.pongTimeout (required)\n * @param {string} options.token (required)\n * @param {string} options.trackingId (required)\n * @param {Logger} options.logger (required)\n * @param {string} options.logLevelToken\n * @returns {Promise}\n */\n open(url, options) {\n try {\n this._domain = new URL(url).hostname;\n } catch {\n this._domain = url;\n }\n\n return new Promise((resolve, reject) => {\n /* eslint complexity: [0] */\n if (!url) {\n reject(new Error('`url` is required'));\n\n return;\n }\n\n if (sockets.get(this)) {\n reject(new Error('Socket#open() can only be called once per instance'));\n\n return;\n }\n\n options = options || {};\n\n checkRequired(\n ['forceCloseDelay', 'pingInterval', 'pongTimeout', 'token', 'trackingId', 'logger'],\n options\n );\n\n Object.keys(options).forEach((key) => {\n Reflect.defineProperty(this, key, {\n enumerable: false,\n value: options[key],\n });\n });\n\n const WebSocket = Socket.getWebSocketConstructor();\n\n this.logger.info(`socket,${this._domain}: creating WebSocket`);\n const socket = new WebSocket(url, [], options);\n\n socket.binaryType = 'arraybuffer';\n socket.onmessage = this.onmessage;\n\n socket.onclose = (event) => {\n event = this._fixCloseCode(event);\n this.logger.info(`socket,${this._domain}: closed before open`, event.code, event.reason);\n switch (event.code) {\n case 1005:\n // IE 11 doesn't seem to allow 4XXX codes, so if we get a 1005, assume\n // it's a bad websocket url. That'll trigger a device refresh; if it\n // turns out we had a bad token, the device refresh should 401 and\n // trigger a token refresh.\n return reject(new UnknownResponse(event));\n case 4400:\n return reject(new BadRequest(event));\n case 4401:\n return reject(new NotAuthorized(event));\n case 4403:\n return reject(new Forbidden(event));\n // case 4404:\n // return reject(new NotFound(event));\n default:\n return reject(new ConnectionError(event));\n }\n };\n\n socket.onopen = () => {\n this.logger.info(`socket,${this._domain}: connected`);\n this._authorize()\n .then(() => {\n this.logger.info(`socket,${this._domain}: authorized`);\n socket.onclose = this.onclose;\n resolve();\n })\n .catch(reject);\n };\n\n socket.onerror = (event) => {\n this.logger.warn(`socket,${this._domain}: error event fired`, event);\n };\n\n sockets.set(this, socket);\n this.logger.info(`socket,${this._domain}: waiting for server`);\n });\n }\n\n /**\n * Handles incoming CloseEvents\n * @param {CloseEvent} event\n * @returns {undefined}\n */\n onclose(event) {\n this.logger.info(`socket,${this._domain}: closed`, event.code, event.reason);\n clearTimeout(this.pongTimer);\n clearTimeout(this.pingTimer);\n\n event = this._fixCloseCode(event);\n this.emit('close', event);\n\n // Remove all listeners to (a) avoid reacting to late pongs and (b) ensure\n // we don't have a retain cycle.\n this.removeAllListeners();\n }\n\n /**\n * Handles incoming message events\n * @param {MessageEvent} event\n * @returns {undefined}\n */\n onmessage(event) {\n try {\n const data = JSON.parse(event.data);\n const sequenceNumber = parseInt(data.sequenceNumber, 10);\n\n this.logger.debug(`socket,${this._domain}: sequence number: `, sequenceNumber);\n if (this.expectedSequenceNumber && sequenceNumber !== this.expectedSequenceNumber) {\n this.logger.debug(\n `socket,${this._domain}: sequence number mismatch indicates lost mercury message. expected: ${this.expectedSequenceNumber}, actual: ${sequenceNumber}`\n );\n this.emit('sequence-mismatch', sequenceNumber, this.expectedSequenceNumber);\n }\n this.expectedSequenceNumber = sequenceNumber + 1;\n\n // Yes, it's a little weird looking; we want to emit message events that\n // look like normal socket message events, but event.data cannot be\n // modified and we don't actually care about anything but the data property\n const processedEvent = {data};\n\n this._acknowledge(processedEvent);\n if (data.type === 'pong') {\n this.emit('pong', processedEvent);\n } else {\n this.emit('message', processedEvent);\n }\n } catch (error) {\n // The above code should only be able to throw if we receive an unparsable\n // message from Mercury. At this time, the only action we have is to\n // ignore it and move on.\n /* istanbul ignore next */\n this.logger.warn(`socket,${this._domain}: error while receiving WebSocket message`, error);\n }\n }\n\n /**\n * Sends a message up the socket\n * @param {mixed} data\n * @returns {Promise}\n */\n send(data) {\n return new Promise((resolve, reject) => {\n if (this.readyState !== 1) {\n return reject(new Error('INVALID_STATE_ERROR'));\n }\n\n if (isObject(data)) {\n data = JSON.stringify(data);\n }\n\n const socket = sockets.get(this);\n\n socket.send(data);\n\n return resolve();\n });\n }\n\n /**\n * Sends an acknowledgment for a specific event\n * @param {MessageEvent} event\n * @returns {Promise}\n */\n _acknowledge(event) {\n if (!event) {\n return Promise.reject(new Error('`event` is required'));\n }\n\n if (!has(event, 'data.id')) {\n return Promise.reject(new Error('`event.data.id` is required'));\n }\n\n return this.send({\n messageId: event.data.id,\n type: 'ack',\n });\n }\n\n /**\n * Sends an auth message up the socket\n * @private\n * @returns {Promise}\n */\n _authorize() {\n return new Promise((resolve) => {\n this.logger.info(`socket,${this._domain}: authorizing`);\n this.send({\n id: uuid.v4(),\n type: 'authorization',\n data: {\n token: this.token,\n },\n trackingId: this.trackingId,\n logLevelToken: this.logLevelToken,\n });\n\n const waitForBufferState = (event) => {\n if (\n !event.data.type &&\n (event.data.data.eventType === 'mercury.buffer_state' ||\n event.data.data.eventType === 'mercury.registration_status')\n ) {\n this.removeListener('message', waitForBufferState);\n this._ping();\n resolve();\n }\n };\n\n this.once('message', waitForBufferState);\n });\n }\n\n /**\n * Deals with the fact that some browsers drop some close codes (but not\n * close reasons).\n * @param {CloseEvent} event\n * @private\n * @returns {CloseEvent}\n */\n _fixCloseCode(event) {\n if (event.code === 1005 && event.reason) {\n switch (event.reason.toLowerCase()) {\n case 'replaced':\n this.logger.info(\n `socket,${this._domain}: fixing CloseEvent code for reason: `,\n event.reason\n );\n event.code = 4000;\n break;\n case 'authentication failed':\n case 'authentication did not happen within the timeout window of 30000 seconds.':\n this.logger.info(\n `socket,${this._domain}: fixing CloseEvent code for reason: `,\n event.reason\n );\n event.code = 1008;\n break;\n default:\n // do nothing\n }\n }\n\n return event;\n }\n\n /**\n * Sends a ping up the socket and confirms we get it back\n * @param {[type]} id\n * @private\n * @returns {[type]}\n */\n _ping(id) {\n const confirmPongId = (event) => {\n try {\n this.logger.debug(`socket,${this._domain}: pong`, event.data.id);\n if (event.data && event.data.id !== id) {\n this.logger.info(\n `socket,${this._domain}: received pong for wrong ping id, closing socket`\n );\n this.logger.debug(`socket,${this._domain}: expected`, id, 'received', event.data.id);\n this.close({\n code: 1000,\n reason: 'Pong mismatch',\n });\n }\n } catch (error) {\n // This try/catch block was added as a debugging step; to the best of my\n // knowledge, the above can never throw.\n /* istanbul ignore next */\n this.logger.error(`socket,${this._domain}: error occurred in confirmPongId`, error);\n }\n };\n\n const onPongNotReceived = () => {\n try {\n this.logger.info(\n `socket,${this._domain}: pong not receive in expected period, closing socket`\n );\n this.close({\n code: 1000,\n reason: 'Pong not received',\n }).catch((reason) => {\n this.logger.warn(\n `socket,${this._domain}: failed to close socket after missed pong`,\n reason\n );\n });\n } catch (error) {\n // This try/catch block was added as a debugging step; to the best of my\n // knowledge, the above can never throw.\n /* istanbul ignore next */\n this.logger.error(`socket,${this._domain}: error occurred in onPongNotReceived`, error);\n }\n };\n\n const scheduleNextPingAndCancelPongTimer = () => {\n try {\n clearTimeout(this.pongTimer);\n this.pingTimer = safeSetTimeout(() => this._ping(), this.pingInterval);\n } catch (error) {\n // This try/catch block was added as a debugging step; to the best of my\n // knowledge, the above can never throw.\n /* istanbul ignore next */\n this.logger.error(\n `socket,${this._domain}: error occurred in scheduleNextPingAndCancelPongTimer`,\n error\n );\n }\n };\n\n id = id || uuid.v4();\n this.pongTimer = safeSetTimeout(onPongNotReceived, this.pongTimeout);\n this.once('pong', scheduleNextPingAndCancelPongTimer);\n this.once('pong', confirmPongId);\n\n this.logger.debug(`socket,${this._domain}: ping ${id}`);\n\n return this.send({\n id,\n type: 'ping',\n });\n }\n}\n"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webex/internal-plugin-mercury",
|
|
3
|
-
"version": "3.0.0-beta.
|
|
3
|
+
"version": "3.0.0-beta.340",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -28,19 +28,19 @@
|
|
|
28
28
|
"sinon": "^9.2.4"
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
|
-
"@webex/common": "3.0.0-beta.
|
|
32
|
-
"@webex/common-timers": "3.0.0-beta.
|
|
33
|
-
"@webex/internal-plugin-device": "3.0.0-beta.
|
|
34
|
-
"@webex/internal-plugin-feature": "3.0.0-beta.
|
|
35
|
-
"@webex/internal-plugin-mercury": "3.0.0-beta.
|
|
36
|
-
"@webex/internal-plugin-metrics": "3.0.0-beta.
|
|
37
|
-
"@webex/test-helper-chai": "3.0.0-beta.
|
|
38
|
-
"@webex/test-helper-mocha": "3.0.0-beta.
|
|
39
|
-
"@webex/test-helper-mock-web-socket": "3.0.0-beta.
|
|
40
|
-
"@webex/test-helper-mock-webex": "3.0.0-beta.
|
|
41
|
-
"@webex/test-helper-refresh-callback": "3.0.0-beta.
|
|
42
|
-
"@webex/test-helper-test-users": "3.0.0-beta.
|
|
43
|
-
"@webex/webex-core": "3.0.0-beta.
|
|
31
|
+
"@webex/common": "3.0.0-beta.340",
|
|
32
|
+
"@webex/common-timers": "3.0.0-beta.340",
|
|
33
|
+
"@webex/internal-plugin-device": "3.0.0-beta.340",
|
|
34
|
+
"@webex/internal-plugin-feature": "3.0.0-beta.340",
|
|
35
|
+
"@webex/internal-plugin-mercury": "3.0.0-beta.340",
|
|
36
|
+
"@webex/internal-plugin-metrics": "3.0.0-beta.340",
|
|
37
|
+
"@webex/test-helper-chai": "3.0.0-beta.340",
|
|
38
|
+
"@webex/test-helper-mocha": "3.0.0-beta.340",
|
|
39
|
+
"@webex/test-helper-mock-web-socket": "3.0.0-beta.340",
|
|
40
|
+
"@webex/test-helper-mock-webex": "3.0.0-beta.340",
|
|
41
|
+
"@webex/test-helper-refresh-callback": "3.0.0-beta.340",
|
|
42
|
+
"@webex/test-helper-test-users": "3.0.0-beta.340",
|
|
43
|
+
"@webex/webex-core": "3.0.0-beta.340",
|
|
44
44
|
"backoff": "^2.5.0",
|
|
45
45
|
"lodash": "^4.17.21",
|
|
46
46
|
"uuid": "^3.3.2",
|
package/src/mercury.js
CHANGED
|
@@ -49,7 +49,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
49
49
|
@oneFlight
|
|
50
50
|
connect(webSocketUrl) {
|
|
51
51
|
if (this.connected) {
|
|
52
|
-
this.logger.info(
|
|
52
|
+
this.logger.info(`${this.namespace}: already connected, will not connect again`);
|
|
53
53
|
|
|
54
54
|
return Promise.resolve();
|
|
55
55
|
}
|
|
@@ -59,7 +59,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
59
59
|
return Promise.resolve(
|
|
60
60
|
this.webex.internal.device.registered || this.webex.internal.device.register()
|
|
61
61
|
).then(() => {
|
|
62
|
-
this.logger.info(
|
|
62
|
+
this.logger.info(`${this.namespace}: connecting`);
|
|
63
63
|
|
|
64
64
|
return this._connectWithBackoff(webSocketUrl);
|
|
65
65
|
});
|
|
@@ -69,16 +69,14 @@ const Mercury = WebexPlugin.extend({
|
|
|
69
69
|
disconnect() {
|
|
70
70
|
return new Promise((resolve) => {
|
|
71
71
|
if (this.backoffCall) {
|
|
72
|
-
this.logger.info(
|
|
72
|
+
this.logger.info(`${this.namespace}: aborting connection`);
|
|
73
73
|
this.backoffCall.abort();
|
|
74
74
|
}
|
|
75
75
|
|
|
76
76
|
if (this.socket) {
|
|
77
77
|
this.socket.removeAllListeners('message');
|
|
78
78
|
this.once('offline', resolve);
|
|
79
|
-
this.socket.close();
|
|
80
|
-
|
|
81
|
-
return;
|
|
79
|
+
resolve(this.socket.close());
|
|
82
80
|
}
|
|
83
81
|
|
|
84
82
|
resolve();
|
|
@@ -165,7 +163,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
165
163
|
Promise.all([this._prepareUrl(socketUrl), this.webex.credentials.getUserToken()])
|
|
166
164
|
.then(([webSocketUrl, token]) => {
|
|
167
165
|
if (!this.backoffCall) {
|
|
168
|
-
const msg =
|
|
166
|
+
const msg = `${this.namespace}: prevent socket open when backoffCall no longer defined`;
|
|
169
167
|
|
|
170
168
|
this.logger.info(msg);
|
|
171
169
|
|
|
@@ -185,7 +183,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
185
183
|
|
|
186
184
|
// if the consumer has supplied request options use them
|
|
187
185
|
if (this.webex.config.defaultMercuryOptions) {
|
|
188
|
-
this.logger.info(
|
|
186
|
+
this.logger.info(`${this.namespace}: setting custom options`);
|
|
189
187
|
options = {...options, ...this.webex.config.defaultMercuryOptions};
|
|
190
188
|
}
|
|
191
189
|
|
|
@@ -193,6 +191,8 @@ const Mercury = WebexPlugin.extend({
|
|
|
193
191
|
// the socket if it is in the process of being opened.
|
|
194
192
|
this.socket = socket;
|
|
195
193
|
|
|
194
|
+
this.logger.info(`${this.namespace} connection url: ${webSocketUrl}`);
|
|
195
|
+
|
|
196
196
|
return socket.open(webSocketUrl, options);
|
|
197
197
|
})
|
|
198
198
|
.then(() => {
|
|
@@ -201,6 +201,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
201
201
|
success: true,
|
|
202
202
|
},
|
|
203
203
|
tags: {
|
|
204
|
+
namespace: this.namespace,
|
|
204
205
|
action: 'connected',
|
|
205
206
|
url: attemptWSUrl,
|
|
206
207
|
},
|
|
@@ -225,19 +226,19 @@ const Mercury = WebexPlugin.extend({
|
|
|
225
226
|
if (reason.code !== 1006 && this.backoffCall && this.backoffCall.getNumRetries() > 0) {
|
|
226
227
|
this._emit('connection_failed', reason, {retries: this.backoffCall.getNumRetries()});
|
|
227
228
|
}
|
|
228
|
-
this.logger.info(
|
|
229
|
+
this.logger.info(`${this.namespace}: connection attempt failed`, reason);
|
|
229
230
|
// UnknownResponse is produced by IE for any 4XXX; treated it like a bad
|
|
230
231
|
// web socket url and let WDM handle the token checking
|
|
231
232
|
if (reason instanceof UnknownResponse) {
|
|
232
233
|
this.logger.info(
|
|
233
|
-
|
|
234
|
+
`${this.namespace}: received unknown response code, refreshing device registration`
|
|
234
235
|
);
|
|
235
236
|
|
|
236
237
|
return this.webex.internal.device.refresh().then(() => callback(reason));
|
|
237
238
|
}
|
|
238
239
|
// NotAuthorized implies expired token
|
|
239
240
|
if (reason instanceof NotAuthorized) {
|
|
240
|
-
this.logger.info(
|
|
241
|
+
this.logger.info(`${this.namespace}: received authorization error, reauthorizing`);
|
|
241
242
|
|
|
242
243
|
return this.webex.credentials.refresh({force: true}).then(() => callback(reason));
|
|
243
244
|
}
|
|
@@ -250,7 +251,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
250
251
|
// BadRequest implies current credentials are for a Service Account
|
|
251
252
|
// Forbidden implies current user is not entitle for Webex
|
|
252
253
|
if (reason instanceof BadRequest || reason instanceof Forbidden) {
|
|
253
|
-
this.logger.warn(
|
|
254
|
+
this.logger.warn(`${this.namespace}: received unrecoverable response from mercury`);
|
|
254
255
|
this.backoffCall.abort();
|
|
255
256
|
|
|
256
257
|
return callback(reason);
|
|
@@ -261,13 +262,14 @@ const Mercury = WebexPlugin.extend({
|
|
|
261
262
|
.then((haMessagingEnabled) => {
|
|
262
263
|
if (haMessagingEnabled) {
|
|
263
264
|
this.logger.info(
|
|
264
|
-
|
|
265
|
+
`${this.namespace}: received a generic connection error, will try to connect to another datacenter`
|
|
265
266
|
);
|
|
266
267
|
this.webex.internal.metrics.submitClientMetrics('web-ha-mercury', {
|
|
267
268
|
fields: {
|
|
268
269
|
success: false,
|
|
269
270
|
},
|
|
270
271
|
tags: {
|
|
272
|
+
namespace: this.namespace,
|
|
271
273
|
action: 'failed',
|
|
272
274
|
error: reason.message,
|
|
273
275
|
url: attemptWSUrl,
|
|
@@ -285,7 +287,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
285
287
|
return callback(reason);
|
|
286
288
|
})
|
|
287
289
|
.catch((reason) => {
|
|
288
|
-
this.logger.error(
|
|
290
|
+
this.logger.error(`${this.namespace}: failed to handle connection failure`, reason);
|
|
289
291
|
callback(reason);
|
|
290
292
|
});
|
|
291
293
|
},
|
|
@@ -301,7 +303,9 @@ const Mercury = WebexPlugin.extend({
|
|
|
301
303
|
this.backoffCall = undefined;
|
|
302
304
|
if (err) {
|
|
303
305
|
this.logger.info(
|
|
304
|
-
|
|
306
|
+
`${
|
|
307
|
+
this.namespace
|
|
308
|
+
}: failed to connect after ${call.getNumRetries()} retries; log statement about next retry was inaccurate; ${err}`
|
|
305
309
|
);
|
|
306
310
|
|
|
307
311
|
return reject(err);
|
|
@@ -314,7 +318,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
314
318
|
|
|
315
319
|
// eslint-disable-next-line prefer-reflect
|
|
316
320
|
call = backoff.call((callback) => {
|
|
317
|
-
this.logger.info(
|
|
321
|
+
this.logger.info(`${this.namespace}: executing connection attempt ${call.getNumRetries()}`);
|
|
318
322
|
this._attemptConnection(webSocketUrl, callback);
|
|
319
323
|
}, onComplete);
|
|
320
324
|
|
|
@@ -330,7 +334,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
330
334
|
}
|
|
331
335
|
|
|
332
336
|
call.on('abort', () => {
|
|
333
|
-
this.logger.info(
|
|
337
|
+
this.logger.info(`${this.namespace}: connection aborted`);
|
|
334
338
|
reject(new Error('Mercury Connection Aborted'));
|
|
335
339
|
});
|
|
336
340
|
|
|
@@ -340,16 +344,16 @@ const Mercury = WebexPlugin.extend({
|
|
|
340
344
|
const delay = Math.min(call.strategy_.nextBackoffDelay_, this.config.backoffTimeMax);
|
|
341
345
|
|
|
342
346
|
this.logger.info(
|
|
343
|
-
|
|
347
|
+
`${this.namespace}: failed to connect; attempting retry ${number + 1} in ${delay} ms`
|
|
344
348
|
);
|
|
345
349
|
/* istanbul ignore if */
|
|
346
350
|
if (process.env.NODE_ENV === 'development') {
|
|
347
|
-
this.logger.debug(
|
|
351
|
+
this.logger.debug(`${this.namespace}: `, err, err.stack);
|
|
348
352
|
}
|
|
349
353
|
|
|
350
354
|
return;
|
|
351
355
|
}
|
|
352
|
-
this.logger.info(
|
|
356
|
+
this.logger.info(`${this.namespace}: connected`);
|
|
353
357
|
});
|
|
354
358
|
|
|
355
359
|
call.start();
|
|
@@ -362,7 +366,10 @@ const Mercury = WebexPlugin.extend({
|
|
|
362
366
|
try {
|
|
363
367
|
this.trigger(...args);
|
|
364
368
|
} catch (error) {
|
|
365
|
-
this.logger.error(
|
|
369
|
+
this.logger.error(`${this.namespace}: error occurred in event handler`, {
|
|
370
|
+
error,
|
|
371
|
+
arguments: args,
|
|
372
|
+
});
|
|
366
373
|
}
|
|
367
374
|
},
|
|
368
375
|
|
|
@@ -403,20 +410,20 @@ const Mercury = WebexPlugin.extend({
|
|
|
403
410
|
case 1003:
|
|
404
411
|
// metric: disconnect
|
|
405
412
|
this.logger.info(
|
|
406
|
-
|
|
413
|
+
`${this.namespace}: Mercury service rejected last message; will not reconnect: ${event.reason}`
|
|
407
414
|
);
|
|
408
415
|
this._emit('offline.permanent', event);
|
|
409
416
|
break;
|
|
410
417
|
case 4000:
|
|
411
418
|
// metric: disconnect
|
|
412
|
-
this.logger.info(
|
|
419
|
+
this.logger.info(`${this.namespace}: socket replaced; will not reconnect`);
|
|
413
420
|
this._emit('offline.replaced', event);
|
|
414
421
|
break;
|
|
415
422
|
case 1001:
|
|
416
423
|
case 1005:
|
|
417
424
|
case 1006:
|
|
418
425
|
case 1011:
|
|
419
|
-
this.logger.info(
|
|
426
|
+
this.logger.info(`${this.namespace}: socket disconnected; reconnecting`);
|
|
420
427
|
this._emit('offline.transient', event);
|
|
421
428
|
this._reconnect(socketUrl);
|
|
422
429
|
// metric: disconnect
|
|
@@ -424,23 +431,25 @@ const Mercury = WebexPlugin.extend({
|
|
|
424
431
|
break;
|
|
425
432
|
case 1000:
|
|
426
433
|
if (normalReconnectReasons.includes(reason)) {
|
|
427
|
-
this.logger.info(
|
|
434
|
+
this.logger.info(`${this.namespace}: socket disconnected; reconnecting`);
|
|
428
435
|
this._emit('offline.transient', event);
|
|
429
436
|
this._reconnect(socketUrl);
|
|
430
437
|
// metric: disconnect
|
|
431
438
|
// if (reason === done forced) metric: force closure
|
|
432
439
|
} else {
|
|
433
|
-
this.logger.info(
|
|
440
|
+
this.logger.info(`${this.namespace}: socket disconnected; will not reconnect`);
|
|
434
441
|
this._emit('offline.permanent', event);
|
|
435
442
|
}
|
|
436
443
|
break;
|
|
437
444
|
default:
|
|
438
|
-
this.logger.info(
|
|
445
|
+
this.logger.info(
|
|
446
|
+
`${this.namespace}: socket disconnected unexpectedly; will not reconnect`
|
|
447
|
+
);
|
|
439
448
|
// unexpected disconnect
|
|
440
449
|
this._emit('offline.permanent', event);
|
|
441
450
|
}
|
|
442
451
|
} catch (error) {
|
|
443
|
-
this.logger.error(
|
|
452
|
+
this.logger.error(`${this.namespace}: error occurred in close handler`, error);
|
|
444
453
|
}
|
|
445
454
|
},
|
|
446
455
|
|
|
@@ -448,7 +457,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
448
457
|
const envelope = event.data;
|
|
449
458
|
|
|
450
459
|
if (process.env.ENABLE_MERCURY_LOGGING) {
|
|
451
|
-
this.logger.debug(
|
|
460
|
+
this.logger.debug(`${this.namespace}: message envelope: `, envelope);
|
|
452
461
|
}
|
|
453
462
|
|
|
454
463
|
const {data} = envelope;
|
|
@@ -465,7 +474,7 @@ const Mercury = WebexPlugin.extend({
|
|
|
465
474
|
resolve((this.webex[namespace] || this.webex.internal[namespace])[name](data))
|
|
466
475
|
).catch((reason) =>
|
|
467
476
|
this.logger.error(
|
|
468
|
-
|
|
477
|
+
`${this.namespace}: error occurred in autowired event handler for ${data.eventType}`,
|
|
469
478
|
reason
|
|
470
479
|
)
|
|
471
480
|
);
|
|
@@ -484,12 +493,12 @@ const Mercury = WebexPlugin.extend({
|
|
|
484
493
|
}
|
|
485
494
|
})
|
|
486
495
|
.catch((reason) => {
|
|
487
|
-
this.logger.error(
|
|
496
|
+
this.logger.error(`${this.namespace}: error occurred processing socket message`, reason);
|
|
488
497
|
});
|
|
489
498
|
},
|
|
490
499
|
|
|
491
500
|
_reconnect(webSocketUrl) {
|
|
492
|
-
this.logger.info(
|
|
501
|
+
this.logger.info(`${this.namespace}: reconnecting`);
|
|
493
502
|
|
|
494
503
|
return this.connect(webSocketUrl);
|
|
495
504
|
},
|