@webex/plugin-logger 2.59.3-next.1 → 2.59.4-next.1
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/.eslintrc.js +6 -6
- package/README.md +82 -82
- package/babel.config.js +3 -3
- package/dist/config.js +13 -13
- package/dist/config.js.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/logger.js +83 -87
- package/dist/logger.js.map +1 -1
- package/jest.config.js +3 -3
- package/package.json +10 -10
- package/process +1 -1
- package/src/config.js +23 -23
- package/src/index.js +15 -15
- package/src/logger.js +427 -427
- package/test/unit/spec/logger.js +805 -805
package/.eslintrc.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
const config = {
|
|
2
|
-
root: true,
|
|
3
|
-
extends: ['@webex/eslint-config-legacy'],
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
module.exports = config;
|
|
1
|
+
const config = {
|
|
2
|
+
root: true,
|
|
3
|
+
extends: ['@webex/eslint-config-legacy'],
|
|
4
|
+
};
|
|
5
|
+
|
|
6
|
+
module.exports = config;
|
package/README.md
CHANGED
|
@@ -1,82 +1,82 @@
|
|
|
1
|
-
# @webex/plugin-logger
|
|
2
|
-
|
|
3
|
-
[](https://github.com/RichardLitt/standard-readme)
|
|
4
|
-
|
|
5
|
-
> Logging plugin for the Cisco Webex JS SDK.
|
|
6
|
-
|
|
7
|
-
- [@webex/plugin-logger](#webexplugin-logger)
|
|
8
|
-
- [Install](#install)
|
|
9
|
-
- [Usage](#usage)
|
|
10
|
-
- [Log Levels](#log-levels)
|
|
11
|
-
- [Level Control](#level-control)
|
|
12
|
-
- [Maintainers](#maintainers)
|
|
13
|
-
- [Contribute](#contribute)
|
|
14
|
-
- [License](#license)
|
|
15
|
-
|
|
16
|
-
## Install
|
|
17
|
-
|
|
18
|
-
```bash
|
|
19
|
-
npm install --save @webex/plugin-logger
|
|
20
|
-
```
|
|
21
|
-
|
|
22
|
-
## Usage
|
|
23
|
-
|
|
24
|
-
This is a plugin for the Cisco Webex JS SDK . Please see our [developer portal](https://developer.webex.com/) and the [API docs](https://webex.github.io/webex-js-sdk/api/) for full details.
|
|
25
|
-
|
|
26
|
-
```js
|
|
27
|
-
const Webex = require('webex');
|
|
28
|
-
const webex = Webex.init();
|
|
29
|
-
|
|
30
|
-
webex.logger.info('Hello World'); // => wx-js-sdk Hello World
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
### Log Levels
|
|
34
|
-
|
|
35
|
-
This logger plugin supports different logging levels to control what gets output to the user's console:
|
|
36
|
-
|
|
37
|
-
- **silent**
|
|
38
|
-
- Nothing prints to the console.
|
|
39
|
-
- **error** [DEFAULT]
|
|
40
|
-
- Error messages thrown by exceptions. This level is meant for the developer and end user to help with troubleshooting.
|
|
41
|
-
- Example: `Unable to connect to websocket on port 4343`
|
|
42
|
-
- **warn**
|
|
43
|
-
- Warning messages meant to help guide developers away from potential errors.
|
|
44
|
-
- Example: `The usage of person email has been deprecated`
|
|
45
|
-
- **log**
|
|
46
|
-
- General output of logging messages.
|
|
47
|
-
- Example: `Websocket connected on port 4343`
|
|
48
|
-
- **info**
|
|
49
|
-
- More detailed logging of SDK information.
|
|
50
|
-
- Example: `Network status changed from DISCONNECTED to ONLINE`
|
|
51
|
-
- **debug**
|
|
52
|
-
- Developer specific information, helpful with debugging issues.
|
|
53
|
-
- Example: `Network packet received, contents: {data}`
|
|
54
|
-
- **trace**
|
|
55
|
-
- Prints the stack trace of the current call path.
|
|
56
|
-
|
|
57
|
-
### Level Control
|
|
58
|
-
|
|
59
|
-
The developer can control what level gets printed by setting the environment variable: `WEBEX_LOG_LEVEL`.
|
|
60
|
-
|
|
61
|
-
These variables can be set on the command line or in the `.env` file:
|
|
62
|
-
|
|
63
|
-
```bash
|
|
64
|
-
WEBEX_LOG_LEVEL="debug" npm start
|
|
65
|
-
```
|
|
66
|
-
|
|
67
|
-
```env
|
|
68
|
-
# .env file
|
|
69
|
-
WEBEX_LOG_LEVEL=debug
|
|
70
|
-
```
|
|
71
|
-
|
|
72
|
-
## Maintainers
|
|
73
|
-
|
|
74
|
-
This package is maintained by [Cisco Webex for Developers](https://developer.webex.com/).
|
|
75
|
-
|
|
76
|
-
## Contribute
|
|
77
|
-
|
|
78
|
-
Pull requests welcome. Please see [CONTRIBUTING.md](https://github.com/webex/webex-js-sdk/blob/master/CONTRIBUTING.md) for more details.
|
|
79
|
-
|
|
80
|
-
## License
|
|
81
|
-
|
|
82
|
-
© 2016-2020 Cisco and/or its affiliates. All Rights Reserved.
|
|
1
|
+
# @webex/plugin-logger
|
|
2
|
+
|
|
3
|
+
[](https://github.com/RichardLitt/standard-readme)
|
|
4
|
+
|
|
5
|
+
> Logging plugin for the Cisco Webex JS SDK.
|
|
6
|
+
|
|
7
|
+
- [@webex/plugin-logger](#webexplugin-logger)
|
|
8
|
+
- [Install](#install)
|
|
9
|
+
- [Usage](#usage)
|
|
10
|
+
- [Log Levels](#log-levels)
|
|
11
|
+
- [Level Control](#level-control)
|
|
12
|
+
- [Maintainers](#maintainers)
|
|
13
|
+
- [Contribute](#contribute)
|
|
14
|
+
- [License](#license)
|
|
15
|
+
|
|
16
|
+
## Install
|
|
17
|
+
|
|
18
|
+
```bash
|
|
19
|
+
npm install --save @webex/plugin-logger
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## Usage
|
|
23
|
+
|
|
24
|
+
This is a plugin for the Cisco Webex JS SDK . Please see our [developer portal](https://developer.webex.com/) and the [API docs](https://webex.github.io/webex-js-sdk/api/) for full details.
|
|
25
|
+
|
|
26
|
+
```js
|
|
27
|
+
const Webex = require('webex');
|
|
28
|
+
const webex = Webex.init();
|
|
29
|
+
|
|
30
|
+
webex.logger.info('Hello World'); // => wx-js-sdk Hello World
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
### Log Levels
|
|
34
|
+
|
|
35
|
+
This logger plugin supports different logging levels to control what gets output to the user's console:
|
|
36
|
+
|
|
37
|
+
- **silent**
|
|
38
|
+
- Nothing prints to the console.
|
|
39
|
+
- **error** [DEFAULT]
|
|
40
|
+
- Error messages thrown by exceptions. This level is meant for the developer and end user to help with troubleshooting.
|
|
41
|
+
- Example: `Unable to connect to websocket on port 4343`
|
|
42
|
+
- **warn**
|
|
43
|
+
- Warning messages meant to help guide developers away from potential errors.
|
|
44
|
+
- Example: `The usage of person email has been deprecated`
|
|
45
|
+
- **log**
|
|
46
|
+
- General output of logging messages.
|
|
47
|
+
- Example: `Websocket connected on port 4343`
|
|
48
|
+
- **info**
|
|
49
|
+
- More detailed logging of SDK information.
|
|
50
|
+
- Example: `Network status changed from DISCONNECTED to ONLINE`
|
|
51
|
+
- **debug**
|
|
52
|
+
- Developer specific information, helpful with debugging issues.
|
|
53
|
+
- Example: `Network packet received, contents: {data}`
|
|
54
|
+
- **trace**
|
|
55
|
+
- Prints the stack trace of the current call path.
|
|
56
|
+
|
|
57
|
+
### Level Control
|
|
58
|
+
|
|
59
|
+
The developer can control what level gets printed by setting the environment variable: `WEBEX_LOG_LEVEL`.
|
|
60
|
+
|
|
61
|
+
These variables can be set on the command line or in the `.env` file:
|
|
62
|
+
|
|
63
|
+
```bash
|
|
64
|
+
WEBEX_LOG_LEVEL="debug" npm start
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
```env
|
|
68
|
+
# .env file
|
|
69
|
+
WEBEX_LOG_LEVEL=debug
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
## Maintainers
|
|
73
|
+
|
|
74
|
+
This package is maintained by [Cisco Webex for Developers](https://developer.webex.com/).
|
|
75
|
+
|
|
76
|
+
## Contribute
|
|
77
|
+
|
|
78
|
+
Pull requests welcome. Please see [CONTRIBUTING.md](https://github.com/webex/webex-js-sdk/blob/master/CONTRIBUTING.md) for more details.
|
|
79
|
+
|
|
80
|
+
## License
|
|
81
|
+
|
|
82
|
+
© 2016-2020 Cisco and/or its affiliates. All Rights Reserved.
|
package/babel.config.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
const babelConfigLegacy = require('@webex/babel-config-legacy');
|
|
2
|
-
|
|
3
|
-
module.exports = babelConfigLegacy;
|
|
1
|
+
const babelConfigLegacy = require('@webex/babel-config-legacy');
|
|
2
|
+
|
|
3
|
+
module.exports = babelConfigLegacy;
|
package/dist/config.js
CHANGED
|
@@ -5,20 +5,20 @@ _Object$defineProperty(exports, "__esModule", {
|
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
7
|
exports.default = void 0;
|
|
8
|
-
/*!
|
|
9
|
-
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
8
|
+
/*!
|
|
9
|
+
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
10
10
|
*/
|
|
11
|
-
/**
|
|
12
|
-
* @typedef {Object} LoggerConfig
|
|
13
|
-
* @property {string} [level=process.env.WEBEX_LOG_LEVEL] - Maximum log level that
|
|
14
|
-
* should be printed to the console. One of
|
|
15
|
-
* silent|error|warn|log|info|debug|trace
|
|
16
|
-
* @property {number} [historyLength=1000] - Maximum number of entries to store in the log buffer.
|
|
17
|
-
* @example
|
|
18
|
-
* {
|
|
19
|
-
* level: process.env.WEBEX_LOG_LEVEL,
|
|
20
|
-
* historyLength: 1000
|
|
21
|
-
* }
|
|
11
|
+
/**
|
|
12
|
+
* @typedef {Object} LoggerConfig
|
|
13
|
+
* @property {string} [level=process.env.WEBEX_LOG_LEVEL] - Maximum log level that
|
|
14
|
+
* should be printed to the console. One of
|
|
15
|
+
* silent|error|warn|log|info|debug|trace
|
|
16
|
+
* @property {number} [historyLength=1000] - Maximum number of entries to store in the log buffer.
|
|
17
|
+
* @example
|
|
18
|
+
* {
|
|
19
|
+
* level: process.env.WEBEX_LOG_LEVEL,
|
|
20
|
+
* historyLength: 1000
|
|
21
|
+
* }
|
|
22
22
|
*/
|
|
23
23
|
var _default = {
|
|
24
24
|
logger: {
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_default","logger","level","process","env","WEBEX_LOG_LEVEL","historyLength","exports","default"],"sources":["config.js"],"sourcesContent":["/*!\
|
|
1
|
+
{"version":3,"names":["_default","logger","level","process","env","WEBEX_LOG_LEVEL","historyLength","exports","default"],"sources":["config.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\n/**\n * @typedef {Object} LoggerConfig\n * @property {string} [level=process.env.WEBEX_LOG_LEVEL] - Maximum log level that\n * should be printed to the console. One of\n * silent|error|warn|log|info|debug|trace\n * @property {number} [historyLength=1000] - Maximum number of entries to store in the log buffer.\n * @example\n * {\n * level: process.env.WEBEX_LOG_LEVEL,\n * historyLength: 1000\n * }\n */\n\nexport default {\n logger: {\n level: process.env.WEBEX_LOG_LEVEL,\n historyLength: 1000,\n },\n};\n"],"mappings":";;;;;;;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAXA,IAAAA,QAAA,GAae;EACbC,MAAM,EAAE;IACNC,KAAK,EAAEC,OAAO,CAACC,GAAG,CAACC,eAAe;IAClCC,aAAa,EAAE;EACjB;AACF,CAAC;AAAAC,OAAA,CAAAC,OAAA,GAAAR,QAAA"}
|
package/dist/index.js
CHANGED
|
@@ -25,8 +25,8 @@ var _logger = _interopRequireWildcard(require("./logger"));
|
|
|
25
25
|
var _config = _interopRequireDefault(require("./config"));
|
|
26
26
|
function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "function") return null; var cacheBabelInterop = new _WeakMap(); var cacheNodeInterop = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
27
27
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = _Object$defineProperty && _Object$getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? _Object$getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { _Object$defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
28
|
-
/*!
|
|
29
|
-
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
28
|
+
/*!
|
|
29
|
+
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
30
30
|
*/
|
|
31
31
|
|
|
32
32
|
(0, _webexCore.registerPlugin)('logger', _logger.default, {
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_webexCore","require","_logger","_interopRequireWildcard","_config","_interopRequireDefault","_getRequireWildcardCache","nodeInterop","_WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","_Object$defineProperty","_Object$getOwnPropertyDescriptor","key","Object","prototype","hasOwnProperty","call","desc","set","registerPlugin","Logger","config","replace"],"sources":["index.js"],"sourcesContent":["/*!\
|
|
1
|
+
{"version":3,"names":["_webexCore","require","_logger","_interopRequireWildcard","_config","_interopRequireDefault","_getRequireWildcardCache","nodeInterop","_WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","_Object$defineProperty","_Object$getOwnPropertyDescriptor","key","Object","prototype","hasOwnProperty","call","desc","set","registerPlugin","Logger","config","replace"],"sources":["index.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {registerPlugin} from '@webex/webex-core';\n\nimport Logger from './logger';\nimport config from './config';\n\nregisterPlugin('logger', Logger, {\n config,\n replace: true,\n});\n\nexport {default, levels} from './logger';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAIA,IAAAA,UAAA,GAAAC,OAAA;AAEA,IAAAC,OAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,OAAA,GAAAC,sBAAA,CAAAJ,OAAA;AAA8B,SAAAK,yBAAAC,WAAA,eAAAC,QAAA,kCAAAC,iBAAA,OAAAD,QAAA,QAAAE,gBAAA,OAAAF,QAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAJ,wBAAAQ,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,sBAAA,IAAAC,gCAAA,WAAAC,GAAA,IAAAX,GAAA,QAAAW,GAAA,kBAAAC,MAAA,CAAAC,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAW,GAAA,SAAAK,IAAA,GAAAR,qBAAA,GAAAE,gCAAA,CAAAV,GAAA,EAAAW,GAAA,cAAAK,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,sBAAA,CAAAF,MAAA,EAAAI,GAAA,EAAAK,IAAA,YAAAT,MAAA,CAAAI,GAAA,IAAAX,GAAA,CAAAW,GAAA,SAAAJ,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAP9B;AACA;AACA;;AAOA,IAAAW,yBAAc,EAAC,QAAQ,EAAEC,eAAM,EAAE;EAC/BC,MAAM,EAANA,eAAM;EACNC,OAAO,EAAE;AACX,CAAC,CAAC"}
|
package/dist/logger.js
CHANGED
|
@@ -6,20 +6,16 @@ _Object$defineProperty(exports, "__esModule", {
|
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
8
|
exports.levels = exports.default = void 0;
|
|
9
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/slicedToArray"));
|
|
9
11
|
var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
|
|
10
12
|
var _entries = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/entries"));
|
|
11
13
|
var _deleteProperty = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/reflect/delete-property"));
|
|
12
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
|
|
13
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/slicedToArray"));
|
|
14
|
-
var _isString2 = _interopRequireDefault(require("lodash/isString"));
|
|
15
|
-
var _isObject2 = _interopRequireDefault(require("lodash/isObject"));
|
|
16
|
-
var _isArray2 = _interopRequireDefault(require("lodash/isArray"));
|
|
17
|
-
var _has2 = _interopRequireDefault(require("lodash/has"));
|
|
18
|
-
var _cloneDeep2 = _interopRequireDefault(require("lodash/cloneDeep"));
|
|
19
14
|
var _common = require("@webex/common");
|
|
20
15
|
var _webexCore = require("@webex/webex-core");
|
|
21
|
-
|
|
22
|
-
|
|
16
|
+
var _lodash = require("lodash");
|
|
17
|
+
/*!
|
|
18
|
+
* Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
|
|
23
19
|
*/
|
|
24
20
|
|
|
25
21
|
var precedence = {
|
|
@@ -51,12 +47,12 @@ var LOG_TYPES = {
|
|
|
51
47
|
var SDK_LOG_TYPE_NAME = 'wx-js-sdk';
|
|
52
48
|
var authTokenKeyPattern = /[Aa]uthorization/;
|
|
53
49
|
|
|
54
|
-
/**
|
|
55
|
-
* Recursively strips "authorization" fields from the specified object
|
|
56
|
-
* @param {Object} object
|
|
57
|
-
* @param {Array<mixed>} [visited]
|
|
58
|
-
* @private
|
|
59
|
-
* @returns {Object}
|
|
50
|
+
/**
|
|
51
|
+
* Recursively strips "authorization" fields from the specified object
|
|
52
|
+
* @param {Object} object
|
|
53
|
+
* @param {Array<mixed>} [visited]
|
|
54
|
+
* @private
|
|
55
|
+
* @returns {Object}
|
|
60
56
|
*/
|
|
61
57
|
function walkAndFilter(object) {
|
|
62
58
|
var visited = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
@@ -65,13 +61,13 @@ function walkAndFilter(object) {
|
|
|
65
61
|
return object;
|
|
66
62
|
}
|
|
67
63
|
visited.push(object);
|
|
68
|
-
if ((0,
|
|
64
|
+
if ((0, _lodash.isArray)(object)) {
|
|
69
65
|
return object.map(function (o) {
|
|
70
66
|
return walkAndFilter(o, visited);
|
|
71
67
|
});
|
|
72
68
|
}
|
|
73
|
-
if (!(0,
|
|
74
|
-
if ((0,
|
|
69
|
+
if (!(0, _lodash.isObject)(object)) {
|
|
70
|
+
if ((0, _lodash.isString)(object)) {
|
|
75
71
|
if (_common.patterns.containsEmails.test(object)) {
|
|
76
72
|
return object.replace(_common.patterns.containsEmails, '[REDACTED]');
|
|
77
73
|
}
|
|
@@ -91,8 +87,8 @@ function walkAndFilter(object) {
|
|
|
91
87
|
return object;
|
|
92
88
|
}
|
|
93
89
|
|
|
94
|
-
/**
|
|
95
|
-
* @class
|
|
90
|
+
/**
|
|
91
|
+
* @class
|
|
96
92
|
*/
|
|
97
93
|
var Logger = _webexCore.WebexPlugin.extend({
|
|
98
94
|
namespace: 'Logger',
|
|
@@ -138,12 +134,12 @@ var Logger = _webexCore.WebexPlugin.extend({
|
|
|
138
134
|
}
|
|
139
135
|
}
|
|
140
136
|
},
|
|
141
|
-
/**
|
|
142
|
-
* Ensures auth headers don't get printed in logs
|
|
143
|
-
* @param {Array<mixed>} args
|
|
144
|
-
* @private
|
|
145
|
-
* @memberof Logger
|
|
146
|
-
* @returns {Array<mixed>}
|
|
137
|
+
/**
|
|
138
|
+
* Ensures auth headers don't get printed in logs
|
|
139
|
+
* @param {Array<mixed>} args
|
|
140
|
+
* @private
|
|
141
|
+
* @memberof Logger
|
|
142
|
+
* @returns {Array<mixed>}
|
|
147
143
|
*/
|
|
148
144
|
filter: function filter() {
|
|
149
145
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
@@ -164,46 +160,46 @@ var Logger = _webexCore.WebexPlugin.extend({
|
|
|
164
160
|
}
|
|
165
161
|
return arg;
|
|
166
162
|
}
|
|
167
|
-
arg = (0,
|
|
163
|
+
arg = (0, _lodash.cloneDeep)(arg);
|
|
168
164
|
return walkAndFilter(arg);
|
|
169
165
|
});
|
|
170
166
|
},
|
|
171
|
-
/**
|
|
172
|
-
* Determines if the current level allows logs at the specified level to be
|
|
173
|
-
* printed
|
|
174
|
-
* @param {string} level
|
|
175
|
-
* @param {string} type type of log, SDK or client
|
|
176
|
-
* @private
|
|
177
|
-
* @memberof Logger
|
|
178
|
-
* @returns {boolean}
|
|
167
|
+
/**
|
|
168
|
+
* Determines if the current level allows logs at the specified level to be
|
|
169
|
+
* printed
|
|
170
|
+
* @param {string} level
|
|
171
|
+
* @param {string} type type of log, SDK or client
|
|
172
|
+
* @private
|
|
173
|
+
* @memberof Logger
|
|
174
|
+
* @returns {boolean}
|
|
179
175
|
*/
|
|
180
176
|
shouldPrint: function shouldPrint(level) {
|
|
181
177
|
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : LOG_TYPES.SDK;
|
|
182
178
|
return precedence[level] <= precedence[type === LOG_TYPES.SDK ? this.getCurrentLevel() : this.getCurrentClientLevel()];
|
|
183
179
|
},
|
|
184
|
-
/**
|
|
185
|
-
* Determines if the current level allows logs at the specified level to be
|
|
186
|
-
* put into the log buffer. We're configuring it omit trace and debug logs
|
|
187
|
-
* because there are *a lot* of debug logs that really don't provide value at
|
|
188
|
-
* runtime (they're helpful for debugging locally, but really just pollute the
|
|
189
|
-
* uploaded logs and push useful info out).
|
|
190
|
-
* @param {string} level
|
|
191
|
-
* @param {string} type type of log, SDK or client
|
|
192
|
-
* @private
|
|
193
|
-
* @memberof Logger
|
|
194
|
-
* @returns {boolean}
|
|
180
|
+
/**
|
|
181
|
+
* Determines if the current level allows logs at the specified level to be
|
|
182
|
+
* put into the log buffer. We're configuring it omit trace and debug logs
|
|
183
|
+
* because there are *a lot* of debug logs that really don't provide value at
|
|
184
|
+
* runtime (they're helpful for debugging locally, but really just pollute the
|
|
185
|
+
* uploaded logs and push useful info out).
|
|
186
|
+
* @param {string} level
|
|
187
|
+
* @param {string} type type of log, SDK or client
|
|
188
|
+
* @private
|
|
189
|
+
* @memberof Logger
|
|
190
|
+
* @returns {boolean}
|
|
195
191
|
*/
|
|
196
192
|
shouldBuffer: function shouldBuffer(level) {
|
|
197
193
|
return precedence[level] <= (this.config.bufferLogLevel ? precedence[this.config.bufferLogLevel] : precedence.info);
|
|
198
194
|
},
|
|
199
|
-
/**
|
|
200
|
-
* Indicates the current SDK log level based on env vars, feature toggles, and
|
|
201
|
-
* user type.
|
|
202
|
-
* @instance
|
|
203
|
-
* @memberof Logger
|
|
204
|
-
* @private
|
|
205
|
-
* @memberof Logger
|
|
206
|
-
* @returns {string}
|
|
195
|
+
/**
|
|
196
|
+
* Indicates the current SDK log level based on env vars, feature toggles, and
|
|
197
|
+
* user type.
|
|
198
|
+
* @instance
|
|
199
|
+
* @memberof Logger
|
|
200
|
+
* @private
|
|
201
|
+
* @memberof Logger
|
|
202
|
+
* @returns {string}
|
|
207
203
|
*/
|
|
208
204
|
// eslint-disable-next-line complexity
|
|
209
205
|
getCurrentLevel: function getCurrentLevel() {
|
|
@@ -229,13 +225,13 @@ var Logger = _webexCore.WebexPlugin.extend({
|
|
|
229
225
|
}
|
|
230
226
|
return 'error';
|
|
231
227
|
},
|
|
232
|
-
/**
|
|
233
|
-
* Indicates the current client log level based on config, defaults to SDK level
|
|
234
|
-
* @instance
|
|
235
|
-
* @memberof Logger
|
|
236
|
-
* @private
|
|
237
|
-
* @memberof Logger
|
|
238
|
-
* @returns {string}
|
|
228
|
+
/**
|
|
229
|
+
* Indicates the current client log level based on config, defaults to SDK level
|
|
230
|
+
* @instance
|
|
231
|
+
* @memberof Logger
|
|
232
|
+
* @private
|
|
233
|
+
* @memberof Logger
|
|
234
|
+
* @returns {string}
|
|
239
235
|
*/
|
|
240
236
|
getCurrentClientLevel: function getCurrentClientLevel() {
|
|
241
237
|
// If a client log level has been explicitly set via config, alway use it.
|
|
@@ -246,16 +242,16 @@ var Logger = _webexCore.WebexPlugin.extend({
|
|
|
246
242
|
// otherwise default to SDK level
|
|
247
243
|
return this.getCurrentLevel();
|
|
248
244
|
},
|
|
249
|
-
/**
|
|
250
|
-
* Format logs (for upload)
|
|
251
|
-
*
|
|
252
|
-
* If separate client, SDK buffers is configured, merge the buffers, if configured
|
|
253
|
-
*
|
|
254
|
-
* @instance
|
|
255
|
-
* @memberof Logger
|
|
256
|
-
* @public
|
|
257
|
-
* @memberof Logger
|
|
258
|
-
* @returns {string} formatted buffer
|
|
245
|
+
/**
|
|
246
|
+
* Format logs (for upload)
|
|
247
|
+
*
|
|
248
|
+
* If separate client, SDK buffers is configured, merge the buffers, if configured
|
|
249
|
+
*
|
|
250
|
+
* @instance
|
|
251
|
+
* @memberof Logger
|
|
252
|
+
* @public
|
|
253
|
+
* @memberof Logger
|
|
254
|
+
* @returns {string} formatted buffer
|
|
259
255
|
*/
|
|
260
256
|
formatLogs: function formatLogs() {
|
|
261
257
|
function getDate(log) {
|
|
@@ -288,23 +284,23 @@ var Logger = _webexCore.WebexPlugin.extend({
|
|
|
288
284
|
}
|
|
289
285
|
return buffer.join('\n');
|
|
290
286
|
},
|
|
291
|
-
version: "2.59.
|
|
287
|
+
version: "2.59.4-next.1"
|
|
292
288
|
});
|
|
293
289
|
|
|
294
|
-
/**
|
|
295
|
-
* Creates a logger method
|
|
296
|
-
*
|
|
297
|
-
*
|
|
298
|
-
* @param {string} level level to create (info, error, warn, etc.)
|
|
299
|
-
* @param {string} impl the level to use when writing to console
|
|
300
|
-
* @param {string} type type of log, SDK or client
|
|
301
|
-
* @param {bool} neverPrint function never prints to console
|
|
302
|
-
* @param {bool} alwaysBuffer function always logs to log buffer
|
|
303
|
-
* @instance
|
|
304
|
-
* @memberof Logger
|
|
305
|
-
* @private
|
|
306
|
-
* @memberof Logger
|
|
307
|
-
* @returns {function} logger method with specified params
|
|
290
|
+
/**
|
|
291
|
+
* Creates a logger method
|
|
292
|
+
*
|
|
293
|
+
*
|
|
294
|
+
* @param {string} level level to create (info, error, warn, etc.)
|
|
295
|
+
* @param {string} impl the level to use when writing to console
|
|
296
|
+
* @param {string} type type of log, SDK or client
|
|
297
|
+
* @param {bool} neverPrint function never prints to console
|
|
298
|
+
* @param {bool} alwaysBuffer function always logs to log buffer
|
|
299
|
+
* @instance
|
|
300
|
+
* @memberof Logger
|
|
301
|
+
* @private
|
|
302
|
+
* @memberof Logger
|
|
303
|
+
* @returns {function} logger method with specified params
|
|
308
304
|
*/
|
|
309
305
|
function makeLoggerMethod(level, impl, type) {
|
|
310
306
|
var neverPrint = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
|
@@ -348,7 +344,7 @@ function makeLoggerMethod(level, impl, type) {
|
|
|
348
344
|
var toPrint = _common.inBrowser ? stringified : filtered;
|
|
349
345
|
|
|
350
346
|
/* istanbul ignore if */
|
|
351
|
-
if (process.env.NODE_ENV === 'test' && (0,
|
|
347
|
+
if (process.env.NODE_ENV === 'test' && (0, _lodash.has)(this, 'webex.internal.device.url')) {
|
|
352
348
|
toPrint.unshift(this.webex.internal.device.url.slice(-3));
|
|
353
349
|
}
|
|
354
350
|
// eslint-disable-next-line no-console
|
package/dist/logger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_common","require","_webexCore","precedence","silent","group","groupEnd","error","warn","log","info","debug","trace","levels","_keys","default","filter","level","exports","fallbacks","LOG_TYPES","SDK","CLIENT","SDK_LOG_TYPE_NAME","authTokenKeyPattern","walkAndFilter","object","visited","arguments","length","undefined","includes","push","_isArray2","map","o","_isObject2","_isString2","patterns","containsEmails","test","replace","_i","_Object$entries","_entries","_Object$entries$_i","_slicedToArray2","key","value","_deleteProperty","Logger","WebexPlugin","extend","namespace","derived","cache","fn","getCurrentLevel","client_level","getCurrentClientLevel","session","buffer","type","_default","groupLevel","sdkBuffer","clientBuffer","_len","args","Array","_key","arg","Error","process","env","NODE_ENV","inBrowser","ret","toString","stack","_cloneDeep2","shouldPrint","shouldBuffer","config","bufferLogLevel","WEBEX_LOG_LEVEL","webex","internal","device","features","developer","get","clientLevel","formatLogs","getDate","clientIndex","sdkIndex","separateLogBuffers","Date","join","version","makeLoggerMethod","impl","neverPrint","alwaysBuffer","wrappedConsoleMethod","logType","clientName","historyLength","clientHistoryLength","filtered","concat","_toConsumableArray2","apply","stringified","item","WebexHttpError","_console","toPrint","_has2","unshift","url","slice","console","logDate","toISOString","repeat","shift","reason","forEach","impls","pop","prototype","client_logToBuffer","logToBuffer","_default2"],"sources":["logger.js"],"sourcesContent":["/*!\r\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\r\n */\r\n\r\nimport {inBrowser, patterns} from '@webex/common';\r\nimport {WebexHttpError, WebexPlugin} from '@webex/webex-core';\r\nimport {cloneDeep, has, isArray, isObject, isString} from 'lodash';\r\n\r\nconst precedence = {\r\n silent: 0,\r\n group: 1,\r\n groupEnd: 2,\r\n error: 3,\r\n warn: 4,\r\n log: 5,\r\n info: 6,\r\n debug: 7,\r\n trace: 8,\r\n};\r\n\r\nexport const levels = Object.keys(precedence).filter((level) => level !== 'silent');\r\n\r\nconst fallbacks = {\r\n error: ['log'],\r\n warn: ['error', 'log'],\r\n info: ['log'],\r\n debug: ['info', 'log'],\r\n trace: ['debug', 'info', 'log'],\r\n};\r\n\r\nconst LOG_TYPES = {\r\n SDK: 'sdk',\r\n CLIENT: 'client',\r\n};\r\n\r\nconst SDK_LOG_TYPE_NAME = 'wx-js-sdk';\r\n\r\nconst authTokenKeyPattern = /[Aa]uthorization/;\r\n\r\n/**\r\n * Recursively strips \"authorization\" fields from the specified object\r\n * @param {Object} object\r\n * @param {Array<mixed>} [visited]\r\n * @private\r\n * @returns {Object}\r\n */\r\nfunction walkAndFilter(object, visited = []) {\r\n if (visited.includes(object)) {\r\n // Prevent circular references\r\n return object;\r\n }\r\n\r\n visited.push(object);\r\n\r\n if (isArray(object)) {\r\n return object.map((o) => walkAndFilter(o, visited));\r\n }\r\n if (!isObject(object)) {\r\n if (isString(object)) {\r\n if (patterns.containsEmails.test(object)) {\r\n return object.replace(patterns.containsEmails, '[REDACTED]');\r\n }\r\n }\r\n\r\n return object;\r\n }\r\n\r\n for (const [key, value] of Object.entries(object)) {\r\n if (authTokenKeyPattern.test(key)) {\r\n Reflect.deleteProperty(object, key);\r\n } else {\r\n object[key] = walkAndFilter(value, visited);\r\n }\r\n }\r\n\r\n return object;\r\n}\r\n\r\n/**\r\n * @class\r\n */\r\nconst Logger = WebexPlugin.extend({\r\n namespace: 'Logger',\r\n\r\n derived: {\r\n level: {\r\n cache: false,\r\n fn() {\r\n return this.getCurrentLevel();\r\n },\r\n },\r\n client_level: {\r\n cache: false,\r\n fn() {\r\n return this.getCurrentClientLevel();\r\n },\r\n },\r\n },\r\n session: {\r\n // for when configured to use single buffer\r\n buffer: {\r\n type: 'array',\r\n default() {\r\n return [];\r\n },\r\n },\r\n groupLevel: {\r\n type: 'number',\r\n default() {\r\n return 0;\r\n },\r\n },\r\n // for when configured to use separate buffers\r\n sdkBuffer: {\r\n type: 'array',\r\n default() {\r\n return [];\r\n },\r\n },\r\n clientBuffer: {\r\n type: 'array',\r\n default() {\r\n return [];\r\n },\r\n },\r\n },\r\n\r\n /**\r\n * Ensures auth headers don't get printed in logs\r\n * @param {Array<mixed>} args\r\n * @private\r\n * @memberof Logger\r\n * @returns {Array<mixed>}\r\n */\r\n filter(...args) {\r\n return args.map((arg) => {\r\n // WebexHttpError already ensures auth tokens don't get printed, so, no\r\n // need to alter it here.\r\n if (arg instanceof Error) {\r\n // karma logs won't print subclassed errors correctly, so we need\r\n // explicitly call their tostring methods.\r\n if (process.env.NODE_ENV === 'test' && inBrowser) {\r\n let ret = arg.toString();\r\n\r\n ret += 'BEGIN STACK';\r\n ret += arg.stack;\r\n ret += 'END STACK';\r\n\r\n return ret;\r\n }\r\n\r\n return arg;\r\n }\r\n\r\n arg = cloneDeep(arg);\r\n\r\n return walkAndFilter(arg);\r\n });\r\n },\r\n\r\n /**\r\n * Determines if the current level allows logs at the specified level to be\r\n * printed\r\n * @param {string} level\r\n * @param {string} type type of log, SDK or client\r\n * @private\r\n * @memberof Logger\r\n * @returns {boolean}\r\n */\r\n shouldPrint(level, type = LOG_TYPES.SDK) {\r\n return (\r\n precedence[level] <=\r\n precedence[type === LOG_TYPES.SDK ? this.getCurrentLevel() : this.getCurrentClientLevel()]\r\n );\r\n },\r\n\r\n /**\r\n * Determines if the current level allows logs at the specified level to be\r\n * put into the log buffer. We're configuring it omit trace and debug logs\r\n * because there are *a lot* of debug logs that really don't provide value at\r\n * runtime (they're helpful for debugging locally, but really just pollute the\r\n * uploaded logs and push useful info out).\r\n * @param {string} level\r\n * @param {string} type type of log, SDK or client\r\n * @private\r\n * @memberof Logger\r\n * @returns {boolean}\r\n */\r\n shouldBuffer(level) {\r\n return (\r\n precedence[level] <=\r\n (this.config.bufferLogLevel ? precedence[this.config.bufferLogLevel] : precedence.info)\r\n );\r\n },\r\n\r\n /**\r\n * Indicates the current SDK log level based on env vars, feature toggles, and\r\n * user type.\r\n * @instance\r\n * @memberof Logger\r\n * @private\r\n * @memberof Logger\r\n * @returns {string}\r\n */\r\n // eslint-disable-next-line complexity\r\n getCurrentLevel() {\r\n // If a level has been explicitly set via config, alway use it.\r\n if (this.config.level) {\r\n return this.config.level;\r\n }\r\n\r\n if (levels.includes(process.env.WEBEX_LOG_LEVEL)) {\r\n return process.env.WEBEX_LOG_LEVEL;\r\n }\r\n\r\n // Always use debug-level logging in test mode;\r\n if (process.env.NODE_ENV === 'test') {\r\n return 'trace';\r\n }\r\n\r\n // Use server-side-feature toggles to configure log levels\r\n const level =\r\n this.webex.internal.device && this.webex.internal.device.features.developer.get('log-level');\r\n\r\n if (level) {\r\n if (levels.includes(level)) {\r\n return level;\r\n }\r\n }\r\n\r\n return 'error';\r\n },\r\n\r\n /**\r\n * Indicates the current client log level based on config, defaults to SDK level\r\n * @instance\r\n * @memberof Logger\r\n * @private\r\n * @memberof Logger\r\n * @returns {string}\r\n */\r\n getCurrentClientLevel() {\r\n // If a client log level has been explicitly set via config, alway use it.\r\n if (this.config.clientLevel) {\r\n return this.config.clientLevel;\r\n }\r\n\r\n // otherwise default to SDK level\r\n return this.getCurrentLevel();\r\n },\r\n\r\n /**\r\n * Format logs (for upload)\r\n *\r\n * If separate client, SDK buffers is configured, merge the buffers, if configured\r\n *\r\n * @instance\r\n * @memberof Logger\r\n * @public\r\n * @memberof Logger\r\n * @returns {string} formatted buffer\r\n */\r\n formatLogs() {\r\n function getDate(log) {\r\n return log[1];\r\n }\r\n let buffer = [];\r\n let clientIndex = 0;\r\n let sdkIndex = 0;\r\n\r\n if (this.config.separateLogBuffers) {\r\n // merge the client and sdk buffers\r\n // while we have entries in either buffer\r\n while (clientIndex < this.clientBuffer.length || sdkIndex < this.sdkBuffer.length) {\r\n // if we have remaining entries in the SDK buffer\r\n if (\r\n sdkIndex < this.sdkBuffer.length &&\r\n // and we haven't exhausted all the client buffer entries, or SDK date is before client date\r\n (clientIndex >= this.clientBuffer.length ||\r\n new Date(getDate(this.sdkBuffer[sdkIndex])) <=\r\n new Date(getDate(this.clientBuffer[clientIndex])))\r\n ) {\r\n // then add to the SDK buffer\r\n buffer.push(this.sdkBuffer[sdkIndex]);\r\n sdkIndex += 1;\r\n }\r\n // otherwise if we haven't exhausted all the client buffer entries, add client entry, whether it was because\r\n // it was the only remaining entries or date was later (the above if)\r\n else if (clientIndex < this.clientBuffer.length) {\r\n buffer.push(this.clientBuffer[clientIndex]);\r\n clientIndex += 1;\r\n }\r\n }\r\n } else {\r\n buffer = this.buffer;\r\n }\r\n\r\n return buffer.join('\\n');\r\n },\r\n});\r\n\r\n/**\r\n * Creates a logger method\r\n *\r\n *\r\n * @param {string} level level to create (info, error, warn, etc.)\r\n * @param {string} impl the level to use when writing to console\r\n * @param {string} type type of log, SDK or client\r\n * @param {bool} neverPrint function never prints to console\r\n * @param {bool} alwaysBuffer function always logs to log buffer\r\n * @instance\r\n * @memberof Logger\r\n * @private\r\n * @memberof Logger\r\n * @returns {function} logger method with specified params\r\n */\r\nfunction makeLoggerMethod(level, impl, type, neverPrint = false, alwaysBuffer = false) {\r\n // Much of the complexity in the following function is due to a test-mode-only\r\n // helper\r\n return function wrappedConsoleMethod(...args) {\r\n // it would be easier to just pass in the name and buffer here, but the config isn't completely initialized\r\n // in Ampersand, even if the initialize method is used to set this up. so we keep the type to achieve\r\n // a sort of late binding to allow retrieving a name from config.\r\n const logType = type;\r\n const clientName =\r\n logType === LOG_TYPES.SDK ? SDK_LOG_TYPE_NAME : this.config.clientName || logType;\r\n\r\n let buffer;\r\n let historyLength;\r\n\r\n if (this.config.separateLogBuffers) {\r\n historyLength = this.config.clientHistoryLength\r\n ? this.config.clientHistoryLength\r\n : this.config.historyLength;\r\n buffer = logType === LOG_TYPES.SDK ? this.sdkBuffer : this.clientBuffer;\r\n } else {\r\n buffer = this.buffer;\r\n historyLength = this.config.historyLength;\r\n }\r\n\r\n try {\r\n const shouldPrint = !neverPrint && this.shouldPrint(level, logType);\r\n const shouldBuffer = alwaysBuffer || this.shouldBuffer(level);\r\n\r\n if (!shouldBuffer && !shouldPrint) {\r\n return;\r\n }\r\n\r\n const filtered = [clientName, ...this.filter(...args)];\r\n const stringified = filtered.map((item) => {\r\n if (item instanceof WebexHttpError) {\r\n return item.toString();\r\n }\r\n\r\n return item;\r\n });\r\n\r\n if (shouldPrint) {\r\n // when logging an object in browsers, we tend to get a dynamic\r\n // reference, thus going back to look at the logged value doesn't\r\n // necessarily show the state at log time, thus we print the stringified\r\n // value.\r\n const toPrint = inBrowser ? stringified : filtered;\r\n\r\n /* istanbul ignore if */\r\n if (process.env.NODE_ENV === 'test' && has(this, 'webex.internal.device.url')) {\r\n toPrint.unshift(this.webex.internal.device.url.slice(-3));\r\n }\r\n // eslint-disable-next-line no-console\r\n console[impl](...toPrint);\r\n }\r\n\r\n if (shouldBuffer) {\r\n const logDate = new Date();\r\n\r\n stringified.unshift(logDate.toISOString());\r\n stringified.unshift('| '.repeat(this.groupLevel));\r\n buffer.push(stringified);\r\n if (buffer.length > historyLength) {\r\n buffer.shift();\r\n }\r\n if (level === 'group') this.groupLevel += 1;\r\n if (level === 'groupEnd' && this.groupLevel > 0) this.groupLevel -= 1;\r\n }\r\n } catch (reason) {\r\n if (!neverPrint) {\r\n /* istanbul ignore next */\r\n // eslint-disable-next-line no-console\r\n console.warn(`failed to execute Logger#${level}`, reason);\r\n }\r\n }\r\n };\r\n}\r\n\r\nlevels.forEach((level) => {\r\n let impls = fallbacks[level];\r\n let impl = level;\r\n\r\n if (impls) {\r\n impls = impls.slice();\r\n // eslint-disable-next-line no-console\r\n while (!console[impl]) {\r\n impl = impls.pop();\r\n }\r\n }\r\n\r\n // eslint-disable-next-line complexity\r\n Logger.prototype[`client_${level}`] = makeLoggerMethod(level, impl, LOG_TYPES.CLIENT);\r\n Logger.prototype[level] = makeLoggerMethod(level, impl, LOG_TYPES.SDK);\r\n});\r\n\r\nLogger.prototype.client_logToBuffer = makeLoggerMethod(\r\n levels.info,\r\n levels.info,\r\n LOG_TYPES.CLIENT,\r\n true,\r\n true\r\n);\r\nLogger.prototype.logToBuffer = makeLoggerMethod(\r\n levels.info,\r\n levels.info,\r\n LOG_TYPES.SDK,\r\n true,\r\n true\r\n);\r\n\r\nexport default Logger;\r\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["_common","require","_webexCore","_lodash","precedence","silent","group","groupEnd","error","warn","log","info","debug","trace","levels","_keys","default","filter","level","exports","fallbacks","LOG_TYPES","SDK","CLIENT","SDK_LOG_TYPE_NAME","authTokenKeyPattern","walkAndFilter","object","visited","arguments","length","undefined","includes","push","isArray","map","o","isObject","isString","patterns","containsEmails","test","replace","_i","_Object$entries","_entries","_Object$entries$_i","_slicedToArray2","key","value","_deleteProperty","Logger","WebexPlugin","extend","namespace","derived","cache","fn","getCurrentLevel","client_level","getCurrentClientLevel","session","buffer","type","_default","groupLevel","sdkBuffer","clientBuffer","_len","args","Array","_key","arg","Error","process","env","NODE_ENV","inBrowser","ret","toString","stack","cloneDeep","shouldPrint","shouldBuffer","config","bufferLogLevel","WEBEX_LOG_LEVEL","webex","internal","device","features","developer","get","clientLevel","formatLogs","getDate","clientIndex","sdkIndex","separateLogBuffers","Date","join","version","makeLoggerMethod","impl","neverPrint","alwaysBuffer","wrappedConsoleMethod","logType","clientName","historyLength","clientHistoryLength","filtered","concat","_toConsumableArray2","apply","stringified","item","WebexHttpError","_console","toPrint","has","unshift","url","slice","console","logDate","toISOString","repeat","shift","reason","forEach","impls","pop","prototype","client_logToBuffer","logToBuffer","_default2"],"sources":["logger.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport {inBrowser, patterns} from '@webex/common';\nimport {WebexHttpError, WebexPlugin} from '@webex/webex-core';\nimport {cloneDeep, has, isArray, isObject, isString} from 'lodash';\n\nconst precedence = {\n silent: 0,\n group: 1,\n groupEnd: 2,\n error: 3,\n warn: 4,\n log: 5,\n info: 6,\n debug: 7,\n trace: 8,\n};\n\nexport const levels = Object.keys(precedence).filter((level) => level !== 'silent');\n\nconst fallbacks = {\n error: ['log'],\n warn: ['error', 'log'],\n info: ['log'],\n debug: ['info', 'log'],\n trace: ['debug', 'info', 'log'],\n};\n\nconst LOG_TYPES = {\n SDK: 'sdk',\n CLIENT: 'client',\n};\n\nconst SDK_LOG_TYPE_NAME = 'wx-js-sdk';\n\nconst authTokenKeyPattern = /[Aa]uthorization/;\n\n/**\n * Recursively strips \"authorization\" fields from the specified object\n * @param {Object} object\n * @param {Array<mixed>} [visited]\n * @private\n * @returns {Object}\n */\nfunction walkAndFilter(object, visited = []) {\n if (visited.includes(object)) {\n // Prevent circular references\n return object;\n }\n\n visited.push(object);\n\n if (isArray(object)) {\n return object.map((o) => walkAndFilter(o, visited));\n }\n if (!isObject(object)) {\n if (isString(object)) {\n if (patterns.containsEmails.test(object)) {\n return object.replace(patterns.containsEmails, '[REDACTED]');\n }\n }\n\n return object;\n }\n\n for (const [key, value] of Object.entries(object)) {\n if (authTokenKeyPattern.test(key)) {\n Reflect.deleteProperty(object, key);\n } else {\n object[key] = walkAndFilter(value, visited);\n }\n }\n\n return object;\n}\n\n/**\n * @class\n */\nconst Logger = WebexPlugin.extend({\n namespace: 'Logger',\n\n derived: {\n level: {\n cache: false,\n fn() {\n return this.getCurrentLevel();\n },\n },\n client_level: {\n cache: false,\n fn() {\n return this.getCurrentClientLevel();\n },\n },\n },\n session: {\n // for when configured to use single buffer\n buffer: {\n type: 'array',\n default() {\n return [];\n },\n },\n groupLevel: {\n type: 'number',\n default() {\n return 0;\n },\n },\n // for when configured to use separate buffers\n sdkBuffer: {\n type: 'array',\n default() {\n return [];\n },\n },\n clientBuffer: {\n type: 'array',\n default() {\n return [];\n },\n },\n },\n\n /**\n * Ensures auth headers don't get printed in logs\n * @param {Array<mixed>} args\n * @private\n * @memberof Logger\n * @returns {Array<mixed>}\n */\n filter(...args) {\n return args.map((arg) => {\n // WebexHttpError already ensures auth tokens don't get printed, so, no\n // need to alter it here.\n if (arg instanceof Error) {\n // karma logs won't print subclassed errors correctly, so we need\n // explicitly call their tostring methods.\n if (process.env.NODE_ENV === 'test' && inBrowser) {\n let ret = arg.toString();\n\n ret += 'BEGIN STACK';\n ret += arg.stack;\n ret += 'END STACK';\n\n return ret;\n }\n\n return arg;\n }\n\n arg = cloneDeep(arg);\n\n return walkAndFilter(arg);\n });\n },\n\n /**\n * Determines if the current level allows logs at the specified level to be\n * printed\n * @param {string} level\n * @param {string} type type of log, SDK or client\n * @private\n * @memberof Logger\n * @returns {boolean}\n */\n shouldPrint(level, type = LOG_TYPES.SDK) {\n return (\n precedence[level] <=\n precedence[type === LOG_TYPES.SDK ? this.getCurrentLevel() : this.getCurrentClientLevel()]\n );\n },\n\n /**\n * Determines if the current level allows logs at the specified level to be\n * put into the log buffer. We're configuring it omit trace and debug logs\n * because there are *a lot* of debug logs that really don't provide value at\n * runtime (they're helpful for debugging locally, but really just pollute the\n * uploaded logs and push useful info out).\n * @param {string} level\n * @param {string} type type of log, SDK or client\n * @private\n * @memberof Logger\n * @returns {boolean}\n */\n shouldBuffer(level) {\n return (\n precedence[level] <=\n (this.config.bufferLogLevel ? precedence[this.config.bufferLogLevel] : precedence.info)\n );\n },\n\n /**\n * Indicates the current SDK log level based on env vars, feature toggles, and\n * user type.\n * @instance\n * @memberof Logger\n * @private\n * @memberof Logger\n * @returns {string}\n */\n // eslint-disable-next-line complexity\n getCurrentLevel() {\n // If a level has been explicitly set via config, alway use it.\n if (this.config.level) {\n return this.config.level;\n }\n\n if (levels.includes(process.env.WEBEX_LOG_LEVEL)) {\n return process.env.WEBEX_LOG_LEVEL;\n }\n\n // Always use debug-level logging in test mode;\n if (process.env.NODE_ENV === 'test') {\n return 'trace';\n }\n\n // Use server-side-feature toggles to configure log levels\n const level =\n this.webex.internal.device && this.webex.internal.device.features.developer.get('log-level');\n\n if (level) {\n if (levels.includes(level)) {\n return level;\n }\n }\n\n return 'error';\n },\n\n /**\n * Indicates the current client log level based on config, defaults to SDK level\n * @instance\n * @memberof Logger\n * @private\n * @memberof Logger\n * @returns {string}\n */\n getCurrentClientLevel() {\n // If a client log level has been explicitly set via config, alway use it.\n if (this.config.clientLevel) {\n return this.config.clientLevel;\n }\n\n // otherwise default to SDK level\n return this.getCurrentLevel();\n },\n\n /**\n * Format logs (for upload)\n *\n * If separate client, SDK buffers is configured, merge the buffers, if configured\n *\n * @instance\n * @memberof Logger\n * @public\n * @memberof Logger\n * @returns {string} formatted buffer\n */\n formatLogs() {\n function getDate(log) {\n return log[1];\n }\n let buffer = [];\n let clientIndex = 0;\n let sdkIndex = 0;\n\n if (this.config.separateLogBuffers) {\n // merge the client and sdk buffers\n // while we have entries in either buffer\n while (clientIndex < this.clientBuffer.length || sdkIndex < this.sdkBuffer.length) {\n // if we have remaining entries in the SDK buffer\n if (\n sdkIndex < this.sdkBuffer.length &&\n // and we haven't exhausted all the client buffer entries, or SDK date is before client date\n (clientIndex >= this.clientBuffer.length ||\n new Date(getDate(this.sdkBuffer[sdkIndex])) <=\n new Date(getDate(this.clientBuffer[clientIndex])))\n ) {\n // then add to the SDK buffer\n buffer.push(this.sdkBuffer[sdkIndex]);\n sdkIndex += 1;\n }\n // otherwise if we haven't exhausted all the client buffer entries, add client entry, whether it was because\n // it was the only remaining entries or date was later (the above if)\n else if (clientIndex < this.clientBuffer.length) {\n buffer.push(this.clientBuffer[clientIndex]);\n clientIndex += 1;\n }\n }\n } else {\n buffer = this.buffer;\n }\n\n return buffer.join('\\n');\n },\n});\n\n/**\n * Creates a logger method\n *\n *\n * @param {string} level level to create (info, error, warn, etc.)\n * @param {string} impl the level to use when writing to console\n * @param {string} type type of log, SDK or client\n * @param {bool} neverPrint function never prints to console\n * @param {bool} alwaysBuffer function always logs to log buffer\n * @instance\n * @memberof Logger\n * @private\n * @memberof Logger\n * @returns {function} logger method with specified params\n */\nfunction makeLoggerMethod(level, impl, type, neverPrint = false, alwaysBuffer = false) {\n // Much of the complexity in the following function is due to a test-mode-only\n // helper\n return function wrappedConsoleMethod(...args) {\n // it would be easier to just pass in the name and buffer here, but the config isn't completely initialized\n // in Ampersand, even if the initialize method is used to set this up. so we keep the type to achieve\n // a sort of late binding to allow retrieving a name from config.\n const logType = type;\n const clientName =\n logType === LOG_TYPES.SDK ? SDK_LOG_TYPE_NAME : this.config.clientName || logType;\n\n let buffer;\n let historyLength;\n\n if (this.config.separateLogBuffers) {\n historyLength = this.config.clientHistoryLength\n ? this.config.clientHistoryLength\n : this.config.historyLength;\n buffer = logType === LOG_TYPES.SDK ? this.sdkBuffer : this.clientBuffer;\n } else {\n buffer = this.buffer;\n historyLength = this.config.historyLength;\n }\n\n try {\n const shouldPrint = !neverPrint && this.shouldPrint(level, logType);\n const shouldBuffer = alwaysBuffer || this.shouldBuffer(level);\n\n if (!shouldBuffer && !shouldPrint) {\n return;\n }\n\n const filtered = [clientName, ...this.filter(...args)];\n const stringified = filtered.map((item) => {\n if (item instanceof WebexHttpError) {\n return item.toString();\n }\n\n return item;\n });\n\n if (shouldPrint) {\n // when logging an object in browsers, we tend to get a dynamic\n // reference, thus going back to look at the logged value doesn't\n // necessarily show the state at log time, thus we print the stringified\n // value.\n const toPrint = inBrowser ? stringified : filtered;\n\n /* istanbul ignore if */\n if (process.env.NODE_ENV === 'test' && has(this, 'webex.internal.device.url')) {\n toPrint.unshift(this.webex.internal.device.url.slice(-3));\n }\n // eslint-disable-next-line no-console\n console[impl](...toPrint);\n }\n\n if (shouldBuffer) {\n const logDate = new Date();\n\n stringified.unshift(logDate.toISOString());\n stringified.unshift('| '.repeat(this.groupLevel));\n buffer.push(stringified);\n if (buffer.length > historyLength) {\n buffer.shift();\n }\n if (level === 'group') this.groupLevel += 1;\n if (level === 'groupEnd' && this.groupLevel > 0) this.groupLevel -= 1;\n }\n } catch (reason) {\n if (!neverPrint) {\n /* istanbul ignore next */\n // eslint-disable-next-line no-console\n console.warn(`failed to execute Logger#${level}`, reason);\n }\n }\n };\n}\n\nlevels.forEach((level) => {\n let impls = fallbacks[level];\n let impl = level;\n\n if (impls) {\n impls = impls.slice();\n // eslint-disable-next-line no-console\n while (!console[impl]) {\n impl = impls.pop();\n }\n }\n\n // eslint-disable-next-line complexity\n Logger.prototype[`client_${level}`] = makeLoggerMethod(level, impl, LOG_TYPES.CLIENT);\n Logger.prototype[level] = makeLoggerMethod(level, impl, LOG_TYPES.SDK);\n});\n\nLogger.prototype.client_logToBuffer = makeLoggerMethod(\n levels.info,\n levels.info,\n LOG_TYPES.CLIENT,\n true,\n true\n);\nLogger.prototype.logToBuffer = makeLoggerMethod(\n levels.info,\n levels.info,\n LOG_TYPES.SDK,\n true,\n true\n);\n\nexport default Logger;\n"],"mappings":"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"}
|
package/jest.config.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
const config = require('@webex/jest-config-legacy');
|
|
2
|
-
|
|
3
|
-
module.exports = config;
|
|
1
|
+
const config = require('@webex/jest-config-legacy');
|
|
2
|
+
|
|
3
|
+
module.exports = config;
|