UNPKG

@twilio/voice-sdk

Version:
281 lines 20.3 kB
"use strict"; var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); Object.defineProperty(exports, "__esModule", { value: true }); /** * @packageDocumentation * @module Voice * @internalapi */ // @ts-nocheck var events_1 = require("events"); var request_1 = require("./request"); /** * Builds Endpoint Analytics (EA) event payloads and sends them to * the EA server. * @constructor * @param {String} productName - Name of the product publishing events. * @param {String} token - The JWT token to use to authenticate with * the EA server. * @param {EventPublisher.Options} options * @property {Boolean} isEnabled - Whether or not this publisher is publishing * to the server. Currently ignores the request altogether, in the future this * may store them in case publishing is re-enabled later. Defaults to true. */ /** * @typedef {Object} EventPublisher.Options * @property {Object} [metadata=undefined] - A publisher_metadata object to send * with each payload. * @property {String} [host='eventgw.twilio.com'] - The host address of the EA * server to publish to. * @property {Object|Function} [defaultPayload] - A default payload to extend * when creating and sending event payloads. Also takes a function that * should return an object representing the default payload. This is * useful for fields that should always be present when they are * available, but are not always available. */ var EventPublisher = /** @class */ (function (_super) { __extends(EventPublisher, _super); function EventPublisher(productName, token, options) { var _this = _super.call(this) || this; if (!(_this instanceof EventPublisher)) { return new EventPublisher(productName, token, options); } // Apply default options options = Object.assign({ defaultPayload: function () { return {}; } }, options); var defaultPayload = options.defaultPayload; if (typeof defaultPayload !== 'function') { defaultPayload = function () { return Object.assign({}, options.defaultPayload); }; } var isEnabled = true; var metadata = Object.assign({ app_name: undefined, app_version: undefined }, options.metadata); Object.defineProperties(_this, { _defaultPayload: { value: defaultPayload }, _host: { value: options.host, writable: true }, _isEnabled: { get: function () { return isEnabled; }, set: function (_isEnabled) { isEnabled = _isEnabled; }, }, _log: { value: options.log }, _request: { value: options.request || request_1.default, writable: true }, _token: { value: token, writable: true }, isEnabled: { enumerable: true, get: function () { return isEnabled; }, }, metadata: { enumerable: true, get: function () { return metadata; }, }, productName: { enumerable: true, value: productName }, token: { enumerable: true, get: function () { return this._token; }, }, }); return _this; } return EventPublisher; }(events_1.EventEmitter)); /** * Post to an EA server. * @private * @param {String} endpointName - Endpoint to post the event to * @param {String} level - ['debug', 'info', 'warning', 'error'] * @param {String} group - The name of the group the event belongs to. * @param {String} name - The designated event name. * @param {?Object} [payload=null] - The payload to pass. This will be extended * onto the default payload object, if one exists. * @param {?Connection} [connection=null] - The {@link Connection} which is posting this payload. * @param {?Boolean} [force=false] - Whether or not to send this even if * publishing is disabled. * @returns {Promise} Fulfilled if the HTTP response is 20x. */ EventPublisher.prototype._post = function _post(endpointName, level, group, name, payload, connection, force) { var _this = this; if ((!this.isEnabled && !force) || !this._host) { return Promise.resolve(); } if (!connection || ((!connection.parameters || !connection.parameters.CallSid) && !connection.outboundConnectionId)) { return Promise.resolve(); } var event = { group: group, level: level.toUpperCase(), name: name, payload: (payload && payload.forEach) ? payload.slice(0) : Object.assign(this._defaultPayload(connection), payload), payload_type: 'application/json', private: false, publisher: this.productName, timestamp: (new Date()).toISOString(), }; if (this.metadata) { event.publisher_metadata = this.metadata; } var requestParams = { body: event, headers: { 'Content-Type': 'application/json', 'X-Twilio-Token': this.token, }, url: "https://" + this._host + "/v4/" + endpointName, }; return new Promise(function (resolve, reject) { _this._request.post(requestParams, function (err) { if (err) { _this.emit('error', err); reject(err); } else { resolve(); } }); }).catch(function (e) { _this._log.warn("Unable to post " + group + " " + name + " event to Insights. Received error: " + e); }); }; /** * Post an event to the EA server. Use this method when the level * is dynamic. Otherwise, it's better practice to use the sugar * methods named for the specific level. * @param {String} level - ['debug', 'info', 'warning', 'error'] * @param {String} group - The name of the group the event belongs to. * @param {String} name - The designated event name. * @param {?Object} [payload=null] - The payload to pass. This will be extended * onto the default payload object, if one exists. * @param {?Connection} [connection=null] - The {@link Connection} which is posting this payload. * @returns {Promise} Fulfilled if the HTTP response is 20x. */ EventPublisher.prototype.post = function post(level, group, name, payload, connection, force) { return this._post('EndpointEvents', level, group, name, payload, connection, force); }; /** * Post a debug-level event to the EA server. * @param {String} group - The name of the group the event belongs to. * @param {String} name - The designated event name. * @param {?Object} [payload=null] - The payload to pass. This will be extended * onto the default payload object, if one exists. * @param {?Connection} [connection=null] - The {@link Connection} which is posting this payload. * @returns {Promise} Fulfilled if the HTTP response is 20x. */ EventPublisher.prototype.debug = function debug(group, name, payload, connection) { return this.post('debug', group, name, payload, connection); }; /** * Post an info-level event to the EA server. * @param {String} group - The name of the group the event belongs to. * @param {String} name - The designated event name. * @param {?Object} [payload=null] - The payload to pass. This will be extended * onto the default payload object, if one exists. * @param {?Connection} [connection=null] - The {@link Connection} which is posting this payload. * @returns {Promise} Fulfilled if the HTTP response is 20x. */ EventPublisher.prototype.info = function info(group, name, payload, connection) { return this.post('info', group, name, payload, connection); }; /** * Post a warning-level event to the EA server. * @param {String} group - The name of the group the event belongs to. * @param {String} name - The designated event name. * @param {?Object} [payload=null] - The payload to pass. This will be extended * onto the default payload object, if one exists. * @param {?Connection} [connection=null] - The {@link Connection} which is posting this payload. * @returns {Promise} Fulfilled if the HTTP response is 20x. */ EventPublisher.prototype.warn = function warn(group, name, payload, connection) { return this.post('warning', group, name, payload, connection); }; /** * Post an error-level event to the EA server. * @param {String} group - The name of the group the event belongs to. * @param {String} name - The designated event name. * @param {?Object} [payload=null] - The payload to pass. This will be extended * onto the default payload object, if one exists. * @param {?Connection} [connection=null] - The {@link Connection} which is posting this payload. * @returns {Promise} Fulfilled if the HTTP response is 20x. */ EventPublisher.prototype.error = function error(group, name, payload, connection) { return this.post('error', group, name, payload, connection); }; /** * Post a metrics event to the EA server. * @param {String} group - The name of the group the event belongs to. * @param {String} name - The designated event name. * @param {Array<Object>} metrics - The metrics to post. * @param {?Object} [customFields] - Custom fields to append to each payload. * @returns {Promise} Fulfilled if the HTTP response is 20x. */ EventPublisher.prototype.postMetrics = function postMetrics(group, name, metrics, customFields, connection) { var _this = this; return new Promise(function (resolve) { var samples = metrics .map(formatMetric) .map(function (sample) { return Object.assign(sample, customFields); }); resolve(_this._post('EndpointMetrics', 'info', group, name, samples, connection)); }); }; /** * Update the host address of the insights server to publish to. * @param {String} host - The new host address of the insights server. */ EventPublisher.prototype.setHost = function setHost(host) { this._host = host; }; /** * Update the token to use to authenticate requests. * @param {string} token * @returns {void} */ EventPublisher.prototype.setToken = function setToken(token) { this._token = token; }; /** * Enable the publishing of events. */ EventPublisher.prototype.enable = function enable() { this._isEnabled = true; }; /** * Disable the publishing of events. */ EventPublisher.prototype.disable = function disable() { this._isEnabled = false; }; function formatMetric(sample) { return { audio_codec: sample.codecName, audio_level_in: sample.audioInputLevel, audio_level_out: sample.audioOutputLevel, bytes_received: sample.bytesReceived, bytes_sent: sample.bytesSent, call_volume_input: sample.inputVolume, call_volume_output: sample.outputVolume, jitter: sample.jitter, mos: sample.mos && (Math.round(sample.mos * 100) / 100), packets_lost: sample.packetsLost, packets_lost_fraction: sample.packetsLostFraction && (Math.round(sample.packetsLostFraction * 100) / 100), packets_received: sample.packetsReceived, rtt: sample.rtt, timestamp: (new Date(sample.timestamp)).toISOString(), total_bytes_received: sample.totals.bytesReceived, total_bytes_sent: sample.totals.bytesSent, total_packets_lost: sample.totals.packetsLost, total_packets_received: sample.totals.packetsReceived, total_packets_sent: sample.totals.packetsSent, }; } exports.default = EventPublisher; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventpublisher.js","sourceRoot":"","sources":["../../lib/twilio/eventpublisher.ts"],"names":[],"mappings":"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"}