@kcuf/sls-logger-base 0.0.4 → 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/dist/cjs/class/sls-logger.js +3 -10
  3. package/dist/cjs/util/convert-log-info.js +1 -1
  4. package/dist/cjs/util/flatten-object.js +11 -15
  5. package/dist/cjs/util/index.js +7 -7
  6. package/dist/cjs/util/merge-dont-send.js +1 -1
  7. package/dist/cjs/util/{convert-error-to-plain.js → normalize-payload-error.js} +5 -5
  8. package/dist/cjs/util/normalize-payload-file.js +16 -0
  9. package/dist/cjs/util/normalize-payload-form-data.js +23 -0
  10. package/dist/cjs/util/normalize-payload-headers.js +13 -0
  11. package/dist/cjs/util/normalize-payload-search-params.js +20 -0
  12. package/dist/cjs/util/normalize-payload.js +32 -0
  13. package/dist/esm/class/index.js.map +1 -1
  14. package/dist/esm/class/sls-logger.js +4 -11
  15. package/dist/esm/class/sls-logger.js.map +1 -1
  16. package/dist/esm/class/sls-pipe.js.map +1 -1
  17. package/dist/esm/const/index.js.map +1 -1
  18. package/dist/esm/factory/create-logger.js.map +1 -1
  19. package/dist/esm/factory/generate-create-logger.js.map +1 -1
  20. package/dist/esm/index.js.map +1 -1
  21. package/dist/esm/types/common.js.map +1 -1
  22. package/dist/esm/types/factory.js.map +1 -1
  23. package/dist/esm/types/options.js.map +1 -1
  24. package/dist/esm/util/build-post-body.js.map +1 -1
  25. package/dist/esm/util/convert-log-info.js +1 -1
  26. package/dist/esm/util/convert-log-info.js.map +1 -1
  27. package/dist/esm/util/create-sls-log-quick.js.map +1 -1
  28. package/dist/esm/util/flatten-object.js +11 -15
  29. package/dist/esm/util/flatten-object.js.map +1 -1
  30. package/dist/esm/util/flatten-test-path.js.map +1 -1
  31. package/dist/esm/util/get-log-once-key.js.map +1 -1
  32. package/dist/esm/util/get-silent-countdown.js.map +1 -1
  33. package/dist/esm/util/index.js +1 -1
  34. package/dist/esm/util/index.js.map +1 -1
  35. package/dist/esm/util/merge-default-params.js.map +1 -1
  36. package/dist/esm/util/merge-dont-send.js +1 -1
  37. package/dist/esm/util/merge-dont-send.js.map +1 -1
  38. package/dist/esm/util/{convert-error-to-plain.js → normalize-payload-error.js} +5 -5
  39. package/dist/esm/util/normalize-payload-error.js.map +1 -0
  40. package/dist/esm/util/normalize-payload-file.js +11 -0
  41. package/dist/esm/util/normalize-payload-file.js.map +1 -0
  42. package/dist/esm/util/normalize-payload-form-data.js +17 -0
  43. package/dist/esm/util/normalize-payload-form-data.js.map +1 -0
  44. package/dist/esm/util/normalize-payload-headers.js +8 -0
  45. package/dist/esm/util/normalize-payload-headers.js.map +1 -0
  46. package/dist/esm/util/normalize-payload-search-params.js +15 -0
  47. package/dist/esm/util/normalize-payload-search-params.js.map +1 -0
  48. package/dist/esm/util/normalize-payload.js +26 -0
  49. package/dist/esm/util/normalize-payload.js.map +1 -0
  50. package/dist/esm/util/resolve-default-params.js.map +1 -1
  51. package/dist/types/class/sls-logger.d.ts +2 -2
  52. package/dist/types/class/sls-pipe.d.ts +2 -2
  53. package/dist/types/factory/create-logger.d.ts +2 -2
  54. package/dist/types/factory/generate-create-logger.d.ts +2 -2
  55. package/dist/types/types/common.d.ts +5 -11
  56. package/dist/types/types/factory.d.ts +1 -3
  57. package/dist/types/types/options.d.ts +4 -4
  58. package/dist/types/util/build-post-body.d.ts +1 -1
  59. package/dist/types/util/convert-log-info.d.ts +1 -1
  60. package/dist/types/util/flatten-object.d.ts +2 -2
  61. package/dist/types/util/flatten-test-path.d.ts +1 -1
  62. package/dist/types/util/index.d.ts +1 -1
  63. package/dist/types/util/merge-default-params.d.ts +1 -1
  64. package/dist/types/util/merge-dont-send.d.ts +2 -2
  65. package/dist/types/util/{convert-error-to-plain.d.ts → normalize-payload-error.d.ts} +1 -1
  66. package/dist/types/util/normalize-payload-file.d.ts +10 -0
  67. package/dist/types/util/normalize-payload-form-data.d.ts +1 -0
  68. package/dist/types/util/normalize-payload-headers.d.ts +1 -0
  69. package/dist/types/util/normalize-payload-search-params.d.ts +1 -0
  70. package/dist/types/util/normalize-payload.d.ts +1 -0
  71. package/package.json +17 -17
  72. package/dist/esm/util/convert-error-to-plain.js.map +0 -1
package/CHANGELOG.md ADDED
@@ -0,0 +1,5 @@
1
+ # CHANGELOG
2
+
3
+ ## 0.0.6 2026/06/25 @驳是
4
+
5
+ * FIX 修复小程序下使用报错的问题
@@ -11,7 +11,6 @@ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/sli
11
11
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
12
12
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
13
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
14
- var _isError2 = _interopRequireDefault(require("lodash/isError"));
15
14
  var _const = require("../const");
16
15
  var _util = require("../util");
17
16
  var _slsPipe = _interopRequireDefault(require("./sls-pipe"));
@@ -67,15 +66,9 @@ var SlsLogger = exports.default = /*#__PURE__*/function () {
67
66
  if (onceKey) {
68
67
  _this.once[onceKey] = 1;
69
68
  }
70
- var plainInfo;
71
- if (payload) {
72
- if (flatten) {
73
- plainInfo = (0, _util.flattenObject)(payload, flatten === true ? '' : flatten);
74
- } else if ((0, _isError2.default)(payload)) {
75
- plainInfo = (0, _util.convertErrorToPlain)(payload);
76
- } else {
77
- plainInfo = payload;
78
- }
69
+ var plainInfo = payload ? (0, _util.normalizePayload)(payload) : payload;
70
+ if (plainInfo && flatten) {
71
+ plainInfo = (0, _util.flattenObject)(plainInfo, flatten === true ? '' : flatten);
79
72
  }
80
73
  _this.slsPipe.pipe((0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _util.resolveDefaultParams)(defaultParams)), plainInfo), {}, {
81
74
  __topic__: finalTopic,
@@ -25,7 +25,7 @@ function convertLogInfo(info) {
25
25
  try {
26
26
  // 避免 cyclic error
27
27
  o[k] = JSON.stringify(v);
28
- } catch (err) {
28
+ } catch (_err) {
29
29
  o[k] = 'TypeError: cyclic object value';
30
30
  }
31
31
  }
@@ -8,10 +8,9 @@ exports.default = flattenObject;
8
8
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
9
9
  var _isEmpty2 = _interopRequireDefault(require("lodash/isEmpty"));
10
10
  var _isPlainObject2 = _interopRequireDefault(require("lodash/isPlainObject"));
11
- var _isError2 = _interopRequireDefault(require("lodash/isError"));
12
11
  var _forEach2 = _interopRequireDefault(require("lodash/forEach"));
13
- var _convertErrorToPlain = _interopRequireDefault(require("./convert-error-to-plain"));
14
12
  var _flattenTestPath = _interopRequireDefault(require("./flatten-test-path"));
13
+ var _normalizePayload = _interopRequireDefault(require("./normalize-payload"));
15
14
  /**
16
15
  * 有时候为了统计方便,需要把传入的对象展平,比如 error 对象,可能会展平成如下形状:
17
16
  *
@@ -31,35 +30,32 @@ function flattenObject(o, options) {
31
30
  _resolvedOptions$dept = resolvedOptions.depth,
32
31
  depth = _resolvedOptions$dept === void 0 ? 5 : _resolvedOptions$dept,
33
32
  omit = resolvedOptions.omit,
34
- pass = resolvedOptions.pass;
33
+ direct = resolvedOptions.direct;
35
34
  var result = {};
36
- function makeSureErrorObject(errorOrObject) {
37
- return (0, _isError2.default)(errorOrObject) ? (0, _convertErrorToPlain.default)(errorOrObject) : errorOrObject;
38
- }
39
35
  function loop(currentObj, parentPaths) {
40
36
  var depthFull = depth > 0 && parentPaths.length + 1 >= depth;
41
37
  (0, _forEach2.default)(currentObj, function (v, k) {
42
38
  var pathKey = [].concat((0, _toConsumableArray2.default)(parentPaths), [k]).join('.');
43
39
  var scopedPathKey = scope ? "".concat(scope, ".").concat(pathKey) : pathKey;
44
40
 
45
- // 可以忽略不重要的信息,默认不记录 `_` 打头的所有数据
46
- if (/^_/.test(k) || omit && (0, _flattenTestPath.default)(pathKey, omit)) {
41
+ // 可以忽略不重要的信息,不记录方法,不记录 `_` 打头的数据
42
+ if (k.startsWith('_') || typeof v === 'function' || omit && (0, _flattenTestPath.default)(pathKey, omit)) {
47
43
  return;
48
44
  }
49
- var vAsObject = makeSureErrorObject(v);
45
+ var normalizedV = (0, _normalizePayload.default)(v);
50
46
 
51
47
  // 不继续 loop:
52
48
  // 1. 深度满了
53
- // 2. 不是对象,不是 Error
49
+ // 2. 不是对象(已经 normalize 掉了一部分)
54
50
  // 3. 空对象,或空数组
55
- // 4. 命中 `pass` 规则
56
- if (depthFull || !(0, _isPlainObject2.default)(vAsObject) || (0, _isEmpty2.default)(vAsObject) || pass && (0, _flattenTestPath.default)(pathKey, pass)) {
57
- result[scopedPathKey] = vAsObject;
51
+ // 4. 命中 `direct` 规则
52
+ if (depthFull || !(0, _isPlainObject2.default)(normalizedV) || (0, _isEmpty2.default)(normalizedV) || direct && (0, _flattenTestPath.default)(pathKey, direct)) {
53
+ result[scopedPathKey] = normalizedV;
58
54
  return;
59
55
  }
60
- loop(vAsObject, [].concat((0, _toConsumableArray2.default)(parentPaths), [k]));
56
+ loop(normalizedV, [].concat((0, _toConsumableArray2.default)(parentPaths), [k]));
61
57
  });
62
58
  }
63
- loop(makeSureErrorObject(o), []);
59
+ loop(o, []);
64
60
  return result;
65
61
  }
@@ -10,12 +10,6 @@ Object.defineProperty(exports, "buildPostBody", {
10
10
  return _buildPostBody.default;
11
11
  }
12
12
  });
13
- Object.defineProperty(exports, "convertErrorToPlain", {
14
- enumerable: true,
15
- get: function get() {
16
- return _convertErrorToPlain.default;
17
- }
18
- });
19
13
  Object.defineProperty(exports, "createSlsLogQuick", {
20
14
  enumerable: true,
21
15
  get: function get() {
@@ -52,6 +46,12 @@ Object.defineProperty(exports, "mergeDontSend", {
52
46
  return _mergeDontSend.default;
53
47
  }
54
48
  });
49
+ Object.defineProperty(exports, "normalizePayload", {
50
+ enumerable: true,
51
+ get: function get() {
52
+ return _normalizePayload.default;
53
+ }
54
+ });
55
55
  Object.defineProperty(exports, "resolveDefaultParams", {
56
56
  enumerable: true,
57
57
  get: function get() {
@@ -62,7 +62,7 @@ var _getSilentCountdown = _interopRequireDefault(require("./get-silent-countdown
62
62
  var _getLogOnceKey = _interopRequireDefault(require("./get-log-once-key"));
63
63
  var _flattenObject = _interopRequireDefault(require("./flatten-object"));
64
64
  var _buildPostBody = _interopRequireDefault(require("./build-post-body"));
65
- var _convertErrorToPlain = _interopRequireDefault(require("./convert-error-to-plain"));
65
+ var _normalizePayload = _interopRequireDefault(require("./normalize-payload"));
66
66
  var _resolveDefaultParams = _interopRequireDefault(require("./resolve-default-params"));
67
67
  var _createSlsLogQuick = _interopRequireDefault(require("./create-sls-log-quick"));
68
68
  var _mergeDefaultParams = _interopRequireDefault(require("./merge-default-params"));
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.default = mergeDontSend;
7
7
  function mergeDontSend(factoryDontSend, dontSend) {
8
8
  if (!factoryDontSend || !dontSend) {
9
- return dontSend || factoryDontSend;
9
+ return dontSend !== null && dontSend !== void 0 ? dontSend : factoryDontSend;
10
10
  }
11
11
  return function () {
12
12
  return factoryDontSend() || dontSend();
@@ -4,18 +4,18 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- exports.default = convertErrorToPlain;
7
+ exports.default = normalizePayloadError;
8
8
  var _forEach2 = _interopRequireDefault(require("lodash/forEach"));
9
9
  /**
10
10
  * Error 身上的 name、message、stack 等信息用 _forEach 遍历不到,故需要转成普通对象
11
11
  */
12
- function convertErrorToPlain(err) {
13
- var plainError = {
12
+ function normalizePayloadError(err) {
13
+ var normalized = {
14
14
  name: err.name,
15
15
  message: err.message
16
16
  };
17
17
  (0, _forEach2.default)(err, function (v, k) {
18
- plainError[k] = v;
18
+ normalized[k] = v;
19
19
  });
20
- return plainError;
20
+ return normalized;
21
21
  }
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = normalizePayloadFile;
7
+ /**
8
+ * 文件不可能直接记录
9
+ */
10
+ function normalizePayloadFile(file) {
11
+ return {
12
+ name: file.name,
13
+ size: file.size,
14
+ type: file.type
15
+ };
16
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = normalizePayloadFormData;
8
+ var _normalizePayloadFile = _interopRequireDefault(require("./normalize-payload-file"));
9
+ function normalizePayloadFormData(formData) {
10
+ var normalized = {};
11
+ formData.forEach(function (v, k) {
12
+ var value = v instanceof File ? (0, _normalizePayloadFile.default)(v) : v;
13
+ var exist = normalized[k];
14
+ if (Array.isArray(exist)) {
15
+ exist.push(value);
16
+ } else if (exist) {
17
+ normalized[k] = [exist, value];
18
+ } else {
19
+ normalized[k] = value;
20
+ }
21
+ });
22
+ return normalized;
23
+ }
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = normalizePayloadHeaders;
7
+ function normalizePayloadHeaders(headers) {
8
+ var normalized = {};
9
+ headers.forEach(function (v, k) {
10
+ normalized[k] = v;
11
+ });
12
+ return normalized;
13
+ }
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = normalizePayloadSearchParams;
7
+ function normalizePayloadSearchParams(searchParams) {
8
+ var normalized = {};
9
+ searchParams.forEach(function (v, k) {
10
+ var exist = normalized[k];
11
+ if (Array.isArray(exist)) {
12
+ exist.push(v);
13
+ } else if (exist) {
14
+ normalized[k] = [exist, v];
15
+ } else {
16
+ normalized[k] = v;
17
+ }
18
+ });
19
+ return normalized;
20
+ }
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = normalizePayload;
8
+ var _isError2 = _interopRequireDefault(require("lodash/isError"));
9
+ var _normalizePayloadError = _interopRequireDefault(require("./normalize-payload-error"));
10
+ var _normalizePayloadHeaders = _interopRequireDefault(require("./normalize-payload-headers"));
11
+ var _normalizePayloadFile = _interopRequireDefault(require("./normalize-payload-file"));
12
+ var _normalizePayloadFormData = _interopRequireDefault(require("./normalize-payload-form-data"));
13
+ var _normalizePayloadSearchParams = _interopRequireDefault(require("./normalize-payload-search-params"));
14
+ function normalizePayload(o) {
15
+ if ((0, _isError2.default)(o)) {
16
+ return (0, _normalizePayloadError.default)(o);
17
+ }
18
+ if (typeof Headers !== 'undefined' && o instanceof Headers) {
19
+ // 使用 typeof 以免在小程序等环境下崩坏
20
+ return (0, _normalizePayloadHeaders.default)(o);
21
+ }
22
+ if (typeof File !== 'undefined' && o instanceof File) {
23
+ return (0, _normalizePayloadFile.default)(o);
24
+ }
25
+ if (typeof FormData !== 'undefined' && o instanceof FormData) {
26
+ return (0, _normalizePayloadFormData.default)(o);
27
+ }
28
+ if (typeof URLSearchParams !== 'undefined' && o instanceof URLSearchParams) {
29
+ return (0, _normalizePayloadSearchParams.default)(o);
30
+ }
31
+ return o;
32
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["default","SlsLogger"],"sources":["../../../src/class/index.ts"],"sourcesContent":["export { default as SlsLogger } from './sls-logger';"],"mappings":"AAAA,SAASA,OAAO,IAAIC,SAAS,QAAQ,cAAc","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["default","SlsLogger"],"sources":["../../../src/class/index.ts"],"sourcesContent":["export { default as SlsLogger } from './sls-logger';\n"],"mappings":"AAAA,SAASA,OAAO,IAAIC,SAAS,QAAQ,cAAc","ignoreList":[]}
@@ -4,9 +4,8 @@ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
4
  import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
5
5
  import _createClass from "@babel/runtime/helpers/createClass";
6
6
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
7
- import _isError from 'lodash/isError';
8
7
  import { API_VERSION, PIPE_SILENT_TIME, PIPE_WAIT_TIME, PIPE_MAX_CHUNK } from '../const';
9
- import { getLogOnceKey, flattenObject, convertErrorToPlain, resolveDefaultParams } from '../util';
8
+ import { getLogOnceKey, flattenObject, normalizePayload, resolveDefaultParams } from '../util';
10
9
  import SlsPipe from './sls-pipe';
11
10
 
12
11
  /**
@@ -61,15 +60,9 @@ var SlsLogger = /*#__PURE__*/function () {
61
60
  if (onceKey) {
62
61
  _this.once[onceKey] = 1;
63
62
  }
64
- var plainInfo;
65
- if (payload) {
66
- if (flatten) {
67
- plainInfo = flattenObject(payload, flatten === true ? '' : flatten);
68
- } else if (_isError(payload)) {
69
- plainInfo = convertErrorToPlain(payload);
70
- } else {
71
- plainInfo = payload;
72
- }
63
+ var plainInfo = payload ? normalizePayload(payload) : payload;
64
+ if (plainInfo && flatten) {
65
+ plainInfo = flattenObject(plainInfo, flatten === true ? '' : flatten);
73
66
  }
74
67
  _this.slsPipe.pipe(_objectSpread(_objectSpread(_objectSpread({}, resolveDefaultParams(defaultParams)), plainInfo), {}, {
75
68
  __topic__: finalTopic,
@@ -1 +1 @@
1
- {"version":3,"file":"sls-logger.js","names":["_isError","API_VERSION","PIPE_SILENT_TIME","PIPE_WAIT_TIME","PIPE_MAX_CHUNK","getLogOnceKey","flattenObject","convertErrorToPlain","resolveDefaultParams","SlsPipe","SlsLogger","sender","options","_this","_options$silentTime","_options$waitTime","_options$maxChunk","_classCallCheck","_defineProperty","topic","payload","_len","arguments","length","args","Array","_key","_ref","_ref2","_slicedToArray","_ref3","_ref4","_this$options","factoryPrefix","prefix","factorySampling","sampling","defaultParams","_options2","_options2$group","group","_options2$prefix","_options2$sampling","instant","once","flatten","finalTopic","concat","onceKey","dontSend","plainInfo","slsPipe","pipe","_objectSpread","__topic__","_GROUP","trackUrl","project","endpoint","logstore","apiVersion","silentTime","waitTime","maxChunk","_createClass","key","value","_dontSend","Math","random","default"],"sources":["../../../src/class/sls-logger.ts"],"sourcesContent":["import _isError from 'lodash/isError';\n\nimport {\n TLogArgs,\n ICreateLoggerOptions,\n ILogSender,\n ISlsLogOptions,\n ISlsLogFn\n} from '../types';\nimport {\n API_VERSION,\n PIPE_SILENT_TIME,\n PIPE_WAIT_TIME,\n PIPE_MAX_CHUNK\n} from '../const';\nimport {\n getLogOnceKey,\n flattenObject,\n convertErrorToPlain,\n resolveDefaultParams\n} from '../util';\n\nimport SlsPipe from './sls-pipe';\n\n/**\n * 创建 SLS 日志方法\n */\nexport default class SlsLogger {\n private readonly options: ICreateLoggerOptions;\n private readonly slsPipe: SlsPipe;\n private once: Record<string, 1> = {};\n \n constructor(sender: ILogSender, options: ICreateLoggerOptions) {\n this.options = options;\n this.slsPipe = new SlsPipe(sender, {\n trackUrl: `https://${options.project}.${options.endpoint}/logstores/${options.logstore}/track`,\n apiVersion: options.apiVersion || API_VERSION,\n silentTime: options.silentTime ?? PIPE_SILENT_TIME,\n waitTime: options.waitTime ?? PIPE_WAIT_TIME,\n maxChunk: options.maxChunk ?? PIPE_MAX_CHUNK\n });\n }\n \n log: ISlsLogFn = (...args: TLogArgs): void => {\n let options: ISlsLogOptions = {};\n let topic: string;\n let payload: Record<string, unknown> | undefined;\n \n if (typeof args[0] === 'string') {\n [topic, payload] = args as [string, Record<string, unknown>?];\n } else {\n [options, topic, payload] = args as [ISlsLogOptions, string, Record<string, unknown>?];\n }\n \n const {\n options: {\n prefix: factoryPrefix,\n sampling: factorySampling,\n defaultParams\n }\n } = this;\n const {\n group = 'LOG',\n prefix = factoryPrefix,\n sampling = factorySampling,\n instant,\n once,\n flatten\n } = options;\n const finalTopic = prefix ? `${prefix}${topic}` : topic;\n const onceKey: string | undefined = getLogOnceKey(finalTopic, once);\n \n if (this.dontSend(sampling, onceKey)) {\n return;\n }\n \n if (onceKey) {\n this.once[onceKey] = 1;\n }\n \n let plainInfo: object | undefined;\n \n if (payload) {\n if (flatten) {\n plainInfo = flattenObject(payload, flatten === true ? '' : flatten);\n } else if (_isError(payload)) {\n plainInfo = convertErrorToPlain(payload);\n } else {\n plainInfo = payload;\n }\n }\n \n this.slsPipe.pipe({\n ...resolveDefaultParams(defaultParams),\n ...plainInfo,\n __topic__: finalTopic,\n _GROUP: group\n }, instant);\n };\n \n /**\n * 检查是否需要忽略\n */\n private dontSend(sampling?: number, onceKey?: string): boolean {\n const {\n options: {\n dontSend\n }\n } = this;\n \n if (onceKey && this.once[onceKey]) { // 只需发送一次,已发送过,忽略\n return true;\n }\n \n if (dontSend?.() === true) { // dontSend 阻止发送\n return true;\n }\n \n if (typeof sampling === 'number' && sampling > 0 && sampling < 1) { // 采样,`(0, 1)` 开区间\n return Math.random() > sampling;\n }\n \n return false;\n }\n}"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"sls-logger.js","names":["API_VERSION","PIPE_SILENT_TIME","PIPE_WAIT_TIME","PIPE_MAX_CHUNK","getLogOnceKey","flattenObject","normalizePayload","resolveDefaultParams","SlsPipe","SlsLogger","sender","options","_this","_options$silentTime","_options$waitTime","_options$maxChunk","_classCallCheck","_defineProperty","topic","payload","_len","arguments","length","args","Array","_key","_ref","_ref2","_slicedToArray","_ref3","_ref4","_this$options","factoryPrefix","prefix","factorySampling","sampling","defaultParams","_options2","_options2$group","group","_options2$prefix","_options2$sampling","instant","once","flatten","finalTopic","concat","onceKey","dontSend","plainInfo","slsPipe","pipe","_objectSpread","__topic__","_GROUP","trackUrl","project","endpoint","logstore","apiVersion","silentTime","waitTime","maxChunk","_createClass","key","value","_dontSend","Math","random","default"],"sources":["../../../src/class/sls-logger.ts"],"sourcesContent":["import {\n TLogArgs,\n ICreateLoggerOptions,\n TLogSender,\n ISlsLogOptions,\n ISlsLogFn\n} from '../types';\nimport {\n API_VERSION,\n PIPE_SILENT_TIME,\n PIPE_WAIT_TIME,\n PIPE_MAX_CHUNK\n} from '../const';\nimport {\n getLogOnceKey,\n flattenObject,\n normalizePayload,\n resolveDefaultParams\n} from '../util';\n\nimport SlsPipe from './sls-pipe';\n\n/**\n * 创建 SLS 日志方法\n */\nexport default class SlsLogger {\n private readonly options: ICreateLoggerOptions;\n private readonly slsPipe: SlsPipe;\n private once: Record<string, 1> = {};\n \n constructor(sender: TLogSender, options: ICreateLoggerOptions) {\n this.options = options;\n this.slsPipe = new SlsPipe(sender, {\n trackUrl: `https://${options.project}.${options.endpoint}/logstores/${options.logstore}/track`,\n apiVersion: options.apiVersion || API_VERSION,\n silentTime: options.silentTime ?? PIPE_SILENT_TIME,\n waitTime: options.waitTime ?? PIPE_WAIT_TIME,\n maxChunk: options.maxChunk ?? PIPE_MAX_CHUNK\n });\n }\n \n log: ISlsLogFn = (...args: TLogArgs): void => {\n let options: ISlsLogOptions = {};\n let topic: string;\n let payload: object | undefined;\n \n if (typeof args[0] === 'string') {\n [topic, payload] = args as [string, object?];\n } else {\n [options, topic, payload] = args as [ISlsLogOptions, string, object?];\n }\n \n const {\n options: {\n prefix: factoryPrefix,\n sampling: factorySampling,\n defaultParams\n }\n } = this;\n const {\n group = 'LOG',\n prefix = factoryPrefix,\n sampling = factorySampling,\n instant,\n once,\n flatten\n } = options;\n const finalTopic = prefix ? `${prefix}${topic}` : topic;\n const onceKey: string | undefined = getLogOnceKey(finalTopic, once);\n \n if (this.dontSend(sampling, onceKey)) {\n return;\n }\n \n if (onceKey) {\n this.once[onceKey] = 1;\n }\n \n let plainInfo: object | undefined = payload ? normalizePayload(payload) : payload;\n \n if (plainInfo && flatten) {\n plainInfo = flattenObject(plainInfo, flatten === true ? '' : flatten);\n }\n \n this.slsPipe.pipe({\n ...resolveDefaultParams(defaultParams),\n ...plainInfo,\n __topic__: finalTopic,\n _GROUP: group\n }, instant);\n };\n \n /**\n * 检查是否需要忽略\n */\n private dontSend(sampling?: number, onceKey?: string): boolean {\n const {\n options: {\n dontSend\n }\n } = this;\n \n if (onceKey && this.once[onceKey]) { // 只需发送一次,已发送过,忽略\n return true;\n }\n \n if (dontSend?.() === true) { // dontSend 阻止发送\n return true;\n }\n \n if (typeof sampling === 'number' && sampling > 0 && sampling < 1) { // 采样,`(0, 1)` 开区间\n return Math.random() > sampling;\n }\n \n return false;\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"sls-pipe.js","names":["_chunk","getSilentCountdown","buildPostBody","SlsPipe","sender","options","_this","_classCallCheck","_defineProperty","silentCountdown","silentTime","silent","setTimeout","clearQueue","_createClass","key","value","pipe","payload","instant","sendLogs","queue","push","signalSend","length","refreshTimer","payloads","_this2","_this$options","trackUrl","apiVersion","maxChunk","forEach","v","body","JSON","stringify","String","clearTimer","timer","clearTimeout","_this3","waitTime","default"],"sources":["../../../src/class/sls-pipe.ts"],"sourcesContent":["import _chunk from 'lodash/chunk';\n\nimport {\n ISlsLogPayload,\n ISlsPipeOptions,\n ILogSender\n} from '../types';\nimport {\n getSilentCountdown,\n buildPostBody\n} from '../util';\n\n/**\n * SLS 日志管道,用于在一定的时间内积压日志,以避免造成业务请求性能问题\n */\nexport default class SlsPipe {\n private readonly sender: ILogSender;\n private readonly options: ISlsPipeOptions;\n private queue: ISlsLogPayload[] = [];\n private timer: ReturnType<typeof setTimeout> | null = null;\n private silent = false;\n \n constructor(sender: ILogSender, options: ISlsPipeOptions) {\n this.sender = sender;\n this.options = options;\n \n const silentCountdown = getSilentCountdown(options.silentTime);\n \n if (silentCountdown > 0) {\n this.silent = true;\n \n setTimeout(() => {\n this.silent = false;\n this.clearQueue();\n }, silentCountdown);\n }\n }\n \n /**\n * 将日志推入队列,并通知发送\n */\n pipe(payload: ISlsLogPayload, instant?: boolean): void {\n if (instant) { // 即时发送\n this.sendLogs([payload]);\n \n return;\n }\n \n this.queue.push(payload);\n this.signalSend();\n }\n \n private signalSend(): void {\n if (!this.queue.length || this.silent) {\n return;\n }\n \n this.refreshTimer();\n }\n \n /**\n * 真正发送日志\n */\n private sendLogs(payloads: ISlsLogPayload[]): void {\n const {\n options: {\n trackUrl,\n apiVersion,\n maxChunk\n }\n } = this;\n \n _chunk(payloads, maxChunk).forEach(v => {\n const body = JSON.stringify(buildPostBody(v)); // buildPostBody 可以保证外边不会出 JSON 错误\n \n this.sender(trackUrl, body, {\n 'Content-Type': 'application/json',\n // 'x-log-compresstype': 'lz4'\n 'x-log-apiversion': apiVersion,\n 'x-log-bodyrawsize': String(body.length)\n });\n });\n }\n \n /**\n * 把队列中的日志全部发送并重置队列\n */\n private clearQueue(): void { // 必须是箭头函数,可以脱离 this\n this.clearTimer();\n this.sendLogs(this.queue);\n this.queue = [];\n }\n \n private clearTimer(): void {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n \n private refreshTimer(): void {\n this.clearTimer();\n this.timer = setTimeout(() => this.clearQueue(), this.options.waitTime);\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"sls-pipe.js","names":["_chunk","getSilentCountdown","buildPostBody","SlsPipe","sender","options","_this","_classCallCheck","_defineProperty","silentCountdown","silentTime","silent","setTimeout","clearQueue","_createClass","key","value","pipe","payload","instant","sendLogs","queue","push","signalSend","length","refreshTimer","payloads","_this2","_this$options","trackUrl","apiVersion","maxChunk","forEach","v","body","JSON","stringify","String","clearTimer","timer","clearTimeout","_this3","waitTime","default"],"sources":["../../../src/class/sls-pipe.ts"],"sourcesContent":["import _chunk from 'lodash/chunk';\n\nimport {\n ISlsLogPayload,\n ISlsPipeOptions,\n TLogSender\n} from '../types';\nimport {\n getSilentCountdown,\n buildPostBody\n} from '../util';\n\n/**\n * SLS 日志管道,用于在一定的时间内积压日志,以避免造成业务请求性能问题\n */\nexport default class SlsPipe {\n private readonly sender: TLogSender;\n private readonly options: ISlsPipeOptions;\n private queue: ISlsLogPayload[] = [];\n private timer: ReturnType<typeof setTimeout> | null = null;\n private silent = false;\n \n constructor(sender: TLogSender, options: ISlsPipeOptions) {\n this.sender = sender;\n this.options = options;\n \n const silentCountdown = getSilentCountdown(options.silentTime);\n \n if (silentCountdown > 0) {\n this.silent = true;\n \n setTimeout(() => {\n this.silent = false;\n this.clearQueue();\n }, silentCountdown);\n }\n }\n \n /**\n * 将日志推入队列,并通知发送\n */\n pipe(payload: ISlsLogPayload, instant?: boolean): void {\n if (instant) { // 即时发送\n this.sendLogs([payload]);\n \n return;\n }\n \n this.queue.push(payload);\n this.signalSend();\n }\n \n private signalSend(): void {\n if (!this.queue.length || this.silent) {\n return;\n }\n \n this.refreshTimer();\n }\n \n /**\n * 真正发送日志\n */\n private sendLogs(payloads: ISlsLogPayload[]): void {\n const {\n options: {\n trackUrl,\n apiVersion,\n maxChunk\n }\n } = this;\n \n _chunk(payloads, maxChunk).forEach(v => {\n const body = JSON.stringify(buildPostBody(v)); // buildPostBody 可以保证外边不会出 JSON 错误\n \n this.sender(trackUrl, body, {\n 'Content-Type': 'application/json',\n // 'x-log-compresstype': 'lz4'\n 'x-log-apiversion': apiVersion,\n 'x-log-bodyrawsize': String(body.length)\n });\n });\n }\n \n /**\n * 把队列中的日志全部发送并重置队列\n */\n private clearQueue(): void { // 必须是箭头函数,可以脱离 this\n this.clearTimer();\n this.sendLogs(this.queue);\n this.queue = [];\n }\n \n private clearTimer(): void {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n \n private refreshTimer(): void {\n this.clearTimer();\n this.timer = setTimeout(() => this.clearQueue(), this.options.waitTime);\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["TOPIC_MERGED","API_VERSION","PIPE_SILENT_TIME","PIPE_WAIT_TIME","PIPE_MAX_CHUNK"],"sources":["../../../src/const/index.ts"],"sourcesContent":["/**\n * 合并日志的最外层的 topic\n */\nexport const TOPIC_MERGED = 'SLS_MERGED';\n\n/**\n * 定死的 API 版本,GET 的时候为参数 `APIVersion`,POST 的时候为 header `x-log-apiversion`\n */\nexport const API_VERSION = '0.6.0';\n\nexport const PIPE_SILENT_TIME = 5000;\n\nexport const PIPE_WAIT_TIME = 200;\n\nexport const PIPE_MAX_CHUNK = 50;"],"mappings":"AAAA;AACA;AACA;AACA,OAAO,IAAMA,YAAY,GAAG,YAAY;;AAExC;AACA;AACA;AACA,OAAO,IAAMC,WAAW,GAAG,OAAO;AAElC,OAAO,IAAMC,gBAAgB,GAAG,IAAI;AAEpC,OAAO,IAAMC,cAAc,GAAG,GAAG;AAEjC,OAAO,IAAMC,cAAc,GAAG,EAAE","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["TOPIC_MERGED","API_VERSION","PIPE_SILENT_TIME","PIPE_WAIT_TIME","PIPE_MAX_CHUNK"],"sources":["../../../src/const/index.ts"],"sourcesContent":["/**\n * 合并日志的最外层的 topic\n */\nexport const TOPIC_MERGED = 'SLS_MERGED';\n\n/**\n * 定死的 API 版本,GET 的时候为参数 `APIVersion`,POST 的时候为 header `x-log-apiversion`\n */\nexport const API_VERSION = '0.6.0';\n\nexport const PIPE_SILENT_TIME = 5000;\n\nexport const PIPE_WAIT_TIME = 200;\n\nexport const PIPE_MAX_CHUNK = 50;\n"],"mappings":"AAAA;AACA;AACA;AACA,OAAO,IAAMA,YAAY,GAAG,YAAY;;AAExC;AACA;AACA;AACA,OAAO,IAAMC,WAAW,GAAG,OAAO;AAElC,OAAO,IAAMC,gBAAgB,GAAG,IAAI;AAEpC,OAAO,IAAMC,cAAc,GAAG,GAAG;AAEjC,OAAO,IAAMC,cAAc,GAAG,EAAE","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"create-logger.js","names":["SlsLogger","createSlsLogQuick","createLogger","sender","options","logger","sls","log","debug","info","warn","error","fatal"],"sources":["../../../src/factory/create-logger.ts"],"sourcesContent":["import {\n ICreateLoggerOptions,\n ISlsLogger,\n ILogSender\n} from '../types';\nimport {\n SlsLogger\n} from '../class';\nimport {\n createSlsLogQuick\n} from '../util';\n\n/**\n * 创建 Logger 方法\n */\nexport default function createLogger(sender: ILogSender, options: ICreateLoggerOptions): ISlsLogger {\n const logger = new SlsLogger(sender, options);\n const sls = logger.log as ISlsLogger;\n \n sls.debug = createSlsLogQuick(sls, 'DEBUG');\n sls.log = createSlsLogQuick(sls, 'LOG');\n sls.info = createSlsLogQuick(sls, 'INFO');\n sls.warn = createSlsLogQuick(sls, 'WARN');\n sls.error = createSlsLogQuick(sls, 'ERROR');\n sls.fatal = createSlsLogQuick(sls, 'FATAL');\n \n return sls;\n}"],"mappings":"AAKA,SACEA,SAAS,QACJ,UAAU;AACjB,SACEC,iBAAiB,QACZ,SAAS;;AAEhB;AACA;AACA;AACA,eAAe,SAASC,YAAYA,CAACC,MAAkB,EAAEC,OAA6B,EAAc;EAClG,IAAMC,MAAM,GAAG,IAAIL,SAAS,CAACG,MAAM,EAAEC,OAAO,CAAC;EAC7C,IAAME,GAAG,GAAGD,MAAM,CAACE,GAAiB;EAEpCD,GAAG,CAACE,KAAK,GAAGP,iBAAiB,CAACK,GAAG,EAAE,OAAO,CAAC;EAC3CA,GAAG,CAACC,GAAG,GAAGN,iBAAiB,CAACK,GAAG,EAAE,KAAK,CAAC;EACvCA,GAAG,CAACG,IAAI,GAAGR,iBAAiB,CAACK,GAAG,EAAE,MAAM,CAAC;EACzCA,GAAG,CAACI,IAAI,GAAGT,iBAAiB,CAACK,GAAG,EAAE,MAAM,CAAC;EACzCA,GAAG,CAACK,KAAK,GAAGV,iBAAiB,CAACK,GAAG,EAAE,OAAO,CAAC;EAC3CA,GAAG,CAACM,KAAK,GAAGX,iBAAiB,CAACK,GAAG,EAAE,OAAO,CAAC;EAE3C,OAAOA,GAAG;AACZ","ignoreList":[]}
1
+ {"version":3,"file":"create-logger.js","names":["SlsLogger","createSlsLogQuick","createLogger","sender","options","logger","sls","log","debug","info","warn","error","fatal"],"sources":["../../../src/factory/create-logger.ts"],"sourcesContent":["import {\n ICreateLoggerOptions,\n ISlsLogger,\n TLogSender\n} from '../types';\nimport {\n SlsLogger\n} from '../class';\nimport {\n createSlsLogQuick\n} from '../util';\n\n/**\n * 创建 Logger 方法\n */\nexport default function createLogger(sender: TLogSender, options: ICreateLoggerOptions): ISlsLogger {\n const logger = new SlsLogger(sender, options);\n const sls = logger.log as ISlsLogger;\n \n sls.debug = createSlsLogQuick(sls, 'DEBUG');\n sls.log = createSlsLogQuick(sls, 'LOG');\n sls.info = createSlsLogQuick(sls, 'INFO');\n sls.warn = createSlsLogQuick(sls, 'WARN');\n sls.error = createSlsLogQuick(sls, 'ERROR');\n sls.fatal = createSlsLogQuick(sls, 'FATAL');\n \n return sls;\n}\n"],"mappings":"AAKA,SACEA,SAAS,QACJ,UAAU;AACjB,SACEC,iBAAiB,QACZ,SAAS;;AAEhB;AACA;AACA;AACA,eAAe,SAASC,YAAYA,CAACC,MAAkB,EAAEC,OAA6B,EAAc;EAClG,IAAMC,MAAM,GAAG,IAAIL,SAAS,CAACG,MAAM,EAAEC,OAAO,CAAC;EAC7C,IAAME,GAAG,GAAGD,MAAM,CAACE,GAAiB;EAEpCD,GAAG,CAACE,KAAK,GAAGP,iBAAiB,CAACK,GAAG,EAAE,OAAO,CAAC;EAC3CA,GAAG,CAACC,GAAG,GAAGN,iBAAiB,CAACK,GAAG,EAAE,KAAK,CAAC;EACvCA,GAAG,CAACG,IAAI,GAAGR,iBAAiB,CAACK,GAAG,EAAE,MAAM,CAAC;EACzCA,GAAG,CAACI,IAAI,GAAGT,iBAAiB,CAACK,GAAG,EAAE,MAAM,CAAC;EACzCA,GAAG,CAACK,KAAK,GAAGV,iBAAiB,CAACK,GAAG,EAAE,OAAO,CAAC;EAC3CA,GAAG,CAACM,KAAK,GAAGX,iBAAiB,CAACK,GAAG,EAAE,OAAO,CAAC;EAE3C,OAAOA,GAAG;AACZ","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"generate-create-logger.js","names":["mergeDefaultParams","mergeDontSend","createLogger","generateCreateLogger","sender","_ref","factoryDefaultParams","defaultParams","factoryDontSend","dontSend","_ref2","options","_objectWithoutProperties","_excluded","_objectSpread"],"sources":["../../../src/factory/generate-create-logger.ts"],"sourcesContent":["import {\n ILogSender,\n ICreateLogger,\n ICreateLoggerOptions,\n IGenerateCreateLoggerOptions\n} from '../types';\nimport {\n mergeDefaultParams,\n mergeDontSend\n} from '../util';\n\nimport createLogger from './create-logger';\n\n/**\n * 创建 `createLogger` 方法的方法,对期望扩展默认参数的场景做了规范。\n *\n * 一般不会在项目中直接使用,而是用来写可复用 npm 包。\n */\nexport default function generateCreateLogger(sender: ILogSender, {\n defaultParams: factoryDefaultParams,\n dontSend: factoryDontSend\n}: IGenerateCreateLoggerOptions): ICreateLogger {\n return ({\n defaultParams,\n dontSend,\n ...options\n }: ICreateLoggerOptions) => createLogger(sender, {\n defaultParams: mergeDefaultParams(factoryDefaultParams, defaultParams),\n dontSend: mergeDontSend(factoryDontSend, dontSend),\n ...options\n });\n}"],"mappings":";;;AAMA,SACEA,kBAAkB,EAClBC,aAAa,QACR,SAAS;AAEhB,OAAOC,YAAY,MAAM,iBAAiB;;AAE1C;AACA;AACA;AACA;AACA;AACA,eAAe,SAASC,oBAAoBA,CAACC,MAAkB,EAAAC,IAAA,EAGf;EAAA,IAF/BC,oBAAoB,GAAAD,IAAA,CAAnCE,aAAa;IACHC,eAAe,GAAAH,IAAA,CAAzBI,QAAQ;EAER,OAAO,UAAAC,KAAA;IAAA,IACLH,aAAa,GAAAG,KAAA,CAAbH,aAAa;MACbE,QAAQ,GAAAC,KAAA,CAARD,QAAQ;MACLE,OAAO,GAAAC,wBAAA,CAAAF,KAAA,EAAAG,SAAA;IAAA,OACgBX,YAAY,CAACE,MAAM,EAAAU,aAAA;MAC7CP,aAAa,EAAEP,kBAAkB,CAACM,oBAAoB,EAAEC,aAAa,CAAC;MACtEE,QAAQ,EAAER,aAAa,CAACO,eAAe,EAAEC,QAAQ;IAAC,GAC/CE,OAAO,CACX,CAAC;EAAA;AACJ","ignoreList":[]}
1
+ {"version":3,"file":"generate-create-logger.js","names":["mergeDefaultParams","mergeDontSend","createLogger","generateCreateLogger","sender","_ref","factoryDefaultParams","defaultParams","factoryDontSend","dontSend","_ref2","options","_objectWithoutProperties","_excluded","_objectSpread"],"sources":["../../../src/factory/generate-create-logger.ts"],"sourcesContent":["import {\n TLogSender,\n ICreateLogger,\n ICreateLoggerOptions,\n IGenerateCreateLoggerOptions\n} from '../types';\nimport {\n mergeDefaultParams,\n mergeDontSend\n} from '../util';\n\nimport createLogger from './create-logger';\n\n/**\n * 创建 `createLogger` 方法的方法,对期望扩展默认参数的场景做了规范。\n *\n * 一般不会在项目中直接使用,而是用来写可复用 npm 包。\n */\nexport default function generateCreateLogger(sender: TLogSender, {\n defaultParams: factoryDefaultParams,\n dontSend: factoryDontSend\n}: IGenerateCreateLoggerOptions): ICreateLogger {\n return ({\n defaultParams,\n dontSend,\n ...options\n }: ICreateLoggerOptions) => createLogger(sender, {\n defaultParams: mergeDefaultParams(factoryDefaultParams, defaultParams),\n dontSend: mergeDontSend(factoryDontSend, dontSend),\n ...options\n });\n}\n"],"mappings":";;;AAMA,SACEA,kBAAkB,EAClBC,aAAa,QACR,SAAS;AAEhB,OAAOC,YAAY,MAAM,iBAAiB;;AAE1C;AACA;AACA;AACA;AACA;AACA,eAAe,SAASC,oBAAoBA,CAACC,MAAkB,EAAAC,IAAA,EAGf;EAAA,IAF/BC,oBAAoB,GAAAD,IAAA,CAAnCE,aAAa;IACHC,eAAe,GAAAH,IAAA,CAAzBI,QAAQ;EAER,OAAO,UAAAC,KAAA;IAAA,IACLH,aAAa,GAAAG,KAAA,CAAbH,aAAa;MACbE,QAAQ,GAAAC,KAAA,CAARD,QAAQ;MACLE,OAAO,GAAAC,wBAAA,CAAAF,KAAA,EAAAG,SAAA;IAAA,OACgBX,YAAY,CAACE,MAAM,EAAAU,aAAA;MAC7CP,aAAa,EAAEP,kBAAkB,CAACM,oBAAoB,EAAEC,aAAa,CAAC;MACtEE,QAAQ,EAAER,aAAa,CAACO,eAAe,EAAEC,QAAQ;IAAC,GAC/CE,OAAO,CACX,CAAC;EAAA;AACJ","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["default","generateCreateLoggerBase"],"sources":["../../src/index.ts"],"sourcesContent":["export { default } from './factory/create-logger';\nexport { default as generateCreateLoggerBase } from './factory/generate-create-logger';\n\nexport type {\n ICreateLogger as CreateLogger,\n ICreateLoggerOptions as CreateLoggerOptions,\n IGenerateCreateLoggerOptions as GenerateCreateLoggerOptions,\n ISlsLogger as SlsLogger,\n ISlsLogOptions as SlsLogOptions,\n ISlsLogOptionsQuick as SlsLogOptionsQuick,\n ISlsPostBody as SlsPostBody\n} from './types';"],"mappings":"AAAA,SAASA,OAAO,QAAQ,yBAAyB;AACjD,SAASA,OAAO,IAAIC,wBAAwB,QAAQ,kCAAkC","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["default","generateCreateLoggerBase"],"sources":["../../src/index.ts"],"sourcesContent":["export { default } from './factory/create-logger';\nexport { default as generateCreateLoggerBase } from './factory/generate-create-logger';\n\nexport type {\n ICreateLogger as CreateLogger,\n ICreateLoggerOptions as CreateLoggerOptions,\n IGenerateCreateLoggerOptions as GenerateCreateLoggerOptions,\n ISlsLogger as SlsLogger,\n ISlsLogOptions as SlsLogOptions,\n ISlsLogOptionsQuick as SlsLogOptionsQuick,\n ISlsPostBody as SlsPostBody\n} from './types';\n"],"mappings":"AAAA,SAASA,OAAO,QAAQ,yBAAyB;AACjD,SAASA,OAAO,IAAIC,wBAAwB,QAAQ,kCAAkC","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"common.js","names":[],"sources":["../../../src/types/common.ts"],"sourcesContent":["export interface IDefaultParams {\n (): Record<string, unknown>;\n}\n\nexport type TDefaultParams = Record<string, unknown> | IDefaultParams;\n\nexport interface IDontSend {\n (): void | boolean;\n}\n\n/**\n * 真正发送请求的实现逻辑(以支持多平台的需求),注意必需用 POST\n */\nexport interface ILogSender {\n (trackUrl: string, body: string, headers: Record<string, string>): void;\n}\n\nexport type TFlattenPathTester = string | RegExp | Array<string | RegExp>;\n\nexport interface ISlsLogPayload {\n __topic__: string;\n [k: string]: unknown;\n}\n\nexport interface ISlsPostBody {\n __topic__: string;\n __logs__: Record<string, string>[];\n // __source__?: string;\n // __tags__?: Record<string, string>;\n}"],"mappings":"","ignoreList":[]}
1
+ {"version":3,"file":"common.js","names":[],"sources":["../../../src/types/common.ts"],"sourcesContent":["export type TFnDefaultParams = () => Record<string, unknown>;\n\nexport type TDefaultParams = Record<string, unknown> | TFnDefaultParams;\n\nexport type TDontSend = () => undefined | boolean;\n\n/**\n * 真正发送请求的实现逻辑(以支持多平台的需求),注意必需用 POST\n */\nexport type TLogSender = (trackUrl: string, body: string, headers: Record<string, string>) => void;\n\nexport type TFlattenPathTester = string | RegExp | (string | RegExp)[];\n\nexport interface ISlsLogPayload {\n __topic__: string;\n [k: string]: unknown;\n}\n\nexport interface ISlsPostBody {\n __topic__: string;\n __logs__: Record<string, string>[];\n // __source__?: string;\n // __tags__?: Record<string, string>;\n}\n"],"mappings":"","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"factory.js","names":[],"sources":["../../../src/types/factory.ts"],"sourcesContent":["import {\n ICreateLoggerOptions,\n ISlsLogOptionsQuick,\n ISlsLogOptions\n} from './options';\n\nexport type TLogArgs = [string, Record<string, unknown>?] | [ISlsLogOptions, string, Record<string, unknown>?];\nexport type TLogQuickArgs = [string, Record<string, unknown>?] | [ISlsLogOptionsQuick, string, Record<string, unknown>?];\n\nexport interface ISlsLogFn {\n (topic: string): void;\n <P extends object>(topic: string, payload: P): void;\n (options: ISlsLogOptions, topic: string): void;\n <P extends object>(options: ISlsLogOptions, topic: string, payload: P): void;\n}\n\nexport interface ISlsLogFnQuick {\n (topic: string): void;\n <P extends object>(topic: string, payload: P): void;\n (options: ISlsLogOptionsQuick, topic: string): void;\n <P extends object>(options: ISlsLogOptionsQuick, topic: string, payload: P): void;\n}\n\nexport interface ISlsLogger {\n (topic: string): void;\n <P extends object>(topic: string, payload: P): void;\n (options: ISlsLogOptions, topic: string): void;\n <P extends object>(options: ISlsLogOptions, topic: string, payload: P): void;\n debug: ISlsLogFnQuick;\n log: ISlsLogFnQuick;\n info: ISlsLogFnQuick;\n warn: ISlsLogFnQuick;\n error: ISlsLogFnQuick;\n fatal: ISlsLogFnQuick;\n}\n\nexport interface ICreateLogger {\n (options: ICreateLoggerOptions): ISlsLogger;\n}"],"mappings":"","ignoreList":[]}
1
+ {"version":3,"file":"factory.js","names":[],"sources":["../../../src/types/factory.ts"],"sourcesContent":["import {\n ICreateLoggerOptions,\n ISlsLogOptionsQuick,\n ISlsLogOptions\n} from './options';\n\nexport type TLogArgs = [string, Record<string, unknown>?] | [ISlsLogOptions, string, Record<string, unknown>?];\nexport type TLogQuickArgs = [string, Record<string, unknown>?] | [ISlsLogOptionsQuick, string, Record<string, unknown>?];\n\nexport interface ISlsLogFn {\n (topic: string): void;\n <P extends object>(topic: string, payload: P): void;\n (options: ISlsLogOptions, topic: string): void;\n <P extends object>(options: ISlsLogOptions, topic: string, payload: P): void;\n}\n\nexport interface ISlsLogFnQuick {\n (topic: string): void;\n <P extends object>(topic: string, payload: P): void;\n (options: ISlsLogOptionsQuick, topic: string): void;\n <P extends object>(options: ISlsLogOptionsQuick, topic: string, payload: P): void;\n}\n\nexport interface ISlsLogger {\n (topic: string): void;\n <P extends object>(topic: string, payload: P): void;\n (options: ISlsLogOptions, topic: string): void;\n <P extends object>(options: ISlsLogOptions, topic: string, payload: P): void;\n debug: ISlsLogFnQuick;\n log: ISlsLogFnQuick;\n info: ISlsLogFnQuick;\n warn: ISlsLogFnQuick;\n error: ISlsLogFnQuick;\n fatal: ISlsLogFnQuick;\n}\n\nexport type ICreateLogger = (options: ICreateLoggerOptions) => ISlsLogger;\n"],"mappings":"","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"options.js","names":[],"sources":["../../../src/types/options.ts"],"sourcesContent":["import {\n TDefaultParams,\n TFlattenPathTester,\n IDontSend\n} from './common';\n\nexport interface ISlsPipeOptions {\n trackUrl: string;\n /**\n * 不知所谓的参数,但必需,说是保留字段,默认 `0.6.0`(文档中的版本号),请不要使用\n */\n apiVersion: string;\n /**\n * 应用初始化后,多少时间内对日志请求进行冷冻处理,以让行业务请求,提升业务性能\n *\n * 默认 5000ms\n */\n silentTime: number;\n /**\n * 调用方法到日志被真正发送的等待时间,这段时间内,若有新的日志进来,会被合并并重新计时\n *\n * 默认 200ms\n */\n waitTime: number;\n /**\n * 一次最多发送日志条数,若积累的日志数超过,将切成多个请求发送\n *\n * 默认 50\n */\n maxChunk: number;\n}\n\nexport interface ICreateLoggerOptions extends Partial<ISlsPipeOptions> {\n /**\n * logstore 所在的 SLS project\n */\n project: string;\n /**\n * project 的外网访问域名,在 SLS 控制台 project 概览页可以找到,\n * 如 `cn-hangzhou.log.aliyuncs.com`(仅跟 project 所在地域有关)\n */\n endpoint: string;\n /**\n * SLS project 下的 logstore,必须开通 Web Tracking 功能,日志记录的存储点\n */\n logstore: string;\n /**\n * 当希望同一个模块的日志使用统一的前缀,又不想每次调用的时候写,可以用这个\n */\n prefix?: string;\n /**\n * 生产出的日志方法的整体采样率,可在调用时由方法参数覆盖,范围为 (0, 1],默认 1\n */\n sampling?: number;\n /**\n * 默认参数,避免每次都要传,可以是静态数据或产生动态数据的方法,这些参数可以覆盖自动记录的参数,\n * 但会被日志方法的第二个参数 `params` 中对应的字段覆盖\n */\n defaultParams?: TDefaultParams;\n /**\n * 上报之前进行判断是否继续,返回 true 以阻止上报\n *\n * 在某些场景下需要禁用日志上报功能,比如可能禁止日志跨境\n */\n dontSend?: IDontSend;\n}\n\n/**\n * 生成 `createLogger` 方法的工厂方法的 options,用于制定工厂级别的参数的忽略方法\n */\nexport interface IGenerateCreateLoggerOptions {\n defaultParams?: TDefaultParams;\n dontSend?: IDontSend;\n}\n\nexport interface IFlattenOptions {\n scope?: string;\n depth?: number;\n /**\n * 将属性从结果中剔除\n */\n omit?: TFlattenPathTester;\n /**\n * 将属性直接输出,提前结束该属性深度\n */\n pass?: TFlattenPathTester;\n}\n\n/**\n * SLS 日志方法 Options\n */\nexport interface ISlsLogOptions {\n /**\n * 覆盖 IFactoryOptions 的 prefix 设置,仅针对当前日志\n */\n prefix?: string;\n /**\n * 覆盖 IFactoryOptions 的 sampling 设置,仅针对当前日志\n */\n sampling?: number;\n /**\n * 有日志只需要在应用起来后记录一次,后续的将被丢弃\n *\n * - true 表示以该 topic 做判断,针对该 topic 只记录一次\n * - 如果是字符串,则以「topic + 此字符串」做判断\n */\n once?: true | string;\n /**\n * 日志不是强需求,不能压过业务,要业务先行。网络请求一般在页面的一开始最密集,如果日志在这时上报会造成网络阻塞而产生性能问题。\n *\n * 办法是先积压着,等到时间到了,再把积压着的日志一起上报。\n *\n * 所以,为了提升性能,做了以下事情:\n *\n * 1. 应用起来后,有一定的静默时间,这段时间的日志会被积压,用于给应用的请求让路\n * 2. 整体或单个日志的延时时间\n * 3. 整体或单个日志的采样率\n * 4. 有的日志只会发送一次\n * 5. 日志发送前也有一个很短的等待时间,在这段时间内,如果有新的日志进来,也将被积压,并重新计时\n * 6. 最后,积压的日志利用 POST 请求对日志进行合并发送\n *\n * 然而,总有例外,有的日志希望是即时的,比如需要拿它来算 PvUv,instant 就是为此而生。\n * 注意:instant 会忽略延时,但不会忽略采样率\n */\n instant?: boolean;\n /**\n * 是否对 info 进行 flatten 操作\n */\n flatten?: boolean | string | IFlattenOptions;\n /**\n * 为日志增加默认参数 `_GROUP`,可用于数据分析分组\n */\n group?: string;\n}\n\n/**\n * SLS 快捷方法 Options\n */\nexport interface ISlsLogOptionsQuick extends Omit<ISlsLogOptions, 'group'> {}"],"mappings":"","ignoreList":[]}
1
+ {"version":3,"file":"options.js","names":[],"sources":["../../../src/types/options.ts"],"sourcesContent":["import {\n TDefaultParams,\n TFlattenPathTester,\n TDontSend\n} from './common';\n\nexport interface ISlsPipeOptions {\n trackUrl: string;\n /**\n * 不知所谓的参数,但必需,说是保留字段,默认 `0.6.0`(文档中的版本号),请不要使用\n */\n apiVersion: string;\n /**\n * 应用初始化后,多少时间内对日志请求进行冷冻处理,以让行业务请求,提升业务性能\n *\n * 默认 5000ms\n */\n silentTime: number;\n /**\n * 调用方法到日志被真正发送的等待时间,这段时间内,若有新的日志进来,会被合并并重新计时\n *\n * 默认 200ms\n */\n waitTime: number;\n /**\n * 一次最多发送日志条数,若积累的日志数超过,将切成多个请求发送\n *\n * 默认 50\n */\n maxChunk: number;\n}\n\nexport interface ICreateLoggerOptions extends Partial<ISlsPipeOptions> {\n /**\n * logstore 所在的 SLS project\n */\n project: string;\n /**\n * project 的外网访问域名,在 SLS 控制台 project 概览页可以找到,\n * 如 `cn-hangzhou.log.aliyuncs.com`(仅跟 project 所在地域有关)\n */\n endpoint: string;\n /**\n * SLS project 下的 logstore,必须开通 Web Tracking 功能,日志记录的存储点\n */\n logstore: string;\n /**\n * 当希望同一个模块的日志使用统一的前缀,又不想每次调用的时候写,可以用这个\n */\n prefix?: string;\n /**\n * 生产出的日志方法的整体采样率,可在调用时由方法参数覆盖,范围为 (0, 1],默认 1\n */\n sampling?: number;\n /**\n * 默认参数,避免每次都要传,可以是静态数据或产生动态数据的方法,这些参数可以覆盖自动记录的参数,\n * 但会被日志方法的第二个参数 `params` 中对应的字段覆盖\n */\n defaultParams?: TDefaultParams;\n /**\n * 上报之前进行判断是否继续,返回 true 以阻止上报\n *\n * 在某些场景下需要禁用日志上报功能,比如可能禁止日志跨境\n */\n dontSend?: TDontSend;\n}\n\n/**\n * 生成 `createLogger` 方法的工厂方法的 options,用于制定工厂级别的参数的忽略方法\n */\nexport interface IGenerateCreateLoggerOptions {\n defaultParams?: TDefaultParams;\n dontSend?: TDontSend;\n}\n\nexport interface IFlattenOptions {\n scope?: string;\n depth?: number;\n /**\n * 将属性从结果中剔除\n */\n omit?: TFlattenPathTester;\n /**\n * 将属性直接输出,提前结束该属性深度\n */\n direct?: TFlattenPathTester;\n}\n\n/**\n * SLS 日志方法 Options\n */\nexport interface ISlsLogOptions {\n /**\n * 覆盖 IFactoryOptions 的 prefix 设置,仅针对当前日志\n */\n prefix?: string;\n /**\n * 覆盖 IFactoryOptions 的 sampling 设置,仅针对当前日志\n */\n sampling?: number;\n /**\n * 有日志只需要在应用起来后记录一次,后续的将被丢弃\n *\n * - true 表示以该 topic 做判断,针对该 topic 只记录一次\n * - 如果是字符串,则以「topic + 此字符串」做判断\n */\n once?: true | string;\n /**\n * 日志不是强需求,不能压过业务,要业务先行。网络请求一般在页面的一开始最密集,如果日志在这时上报会造成网络阻塞而产生性能问题。\n *\n * 办法是先积压着,等到时间到了,再把积压着的日志一起上报。\n *\n * 所以,为了提升性能,做了以下事情:\n *\n * 1. 应用起来后,有一定的静默时间,这段时间的日志会被积压,用于给应用的请求让路\n * 2. 整体或单个日志的延时时间\n * 3. 整体或单个日志的采样率\n * 4. 有的日志只会发送一次\n * 5. 日志发送前也有一个很短的等待时间,在这段时间内,如果有新的日志进来,也将被积压,并重新计时\n * 6. 最后,积压的日志利用 POST 请求对日志进行合并发送\n *\n * 然而,总有例外,有的日志希望是即时的,比如需要拿它来算 PvUv,instant 就是为此而生。\n * 注意:instant 会忽略延时,但不会忽略采样率\n */\n instant?: boolean;\n /**\n * 是否对 info 进行 flatten 操作\n */\n flatten?: boolean | string | IFlattenOptions;\n /**\n * 为日志增加默认参数 `_GROUP`,可用于数据分析分组\n */\n group?: string;\n}\n\n/**\n * SLS 快捷方法 Options\n */\nexport interface ISlsLogOptionsQuick extends Omit<ISlsLogOptions, 'group'> {}\n"],"mappings":"","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"build-post-body.js","names":["TOPIC_MERGED","convertLogInfo","buildPostBody","payloads","topic","length","__topic__","__logs__","map"],"sources":["../../../src/util/build-post-body.ts"],"sourcesContent":["import type {\n ISlsLogPayload,\n ISlsPostBody\n} from '../types';\nimport {\n TOPIC_MERGED\n} from '../const';\n\nimport convertLogInfo from './convert-log-info';\n\n/**\n * 利用 PutWebTracking 发送日志,如果 `__logs__` 里含有 `__topic__` 则,外部的这个 `__topic__` 将被改为 `__topic__0`,\n * 为了干净,在仅发送一条日志的时候,将 `__logs__` 里的 `__topic__` 往上提。\n *\n * 但是,POST 的时候 `__source__` 不会被默认填充成 IP,IP 在 `__tag__:__client_ip__`(GET 方式也有)\n */\nexport default function buildPostBody(payloads: ISlsLogPayload[]): ISlsPostBody {\n let topic = TOPIC_MERGED;\n \n if (payloads.length === 1) {\n topic = payloads[0]!.__topic__; // eslint-disable-line @typescript-eslint/no-non-null-assertion\n }\n \n return {\n __topic__: topic,\n __logs__: payloads.map(convertLogInfo)\n };\n}"],"mappings":"AAIA,SACEA,YAAY,QACP,UAAU;AAEjB,OAAOC,cAAc,MAAM,oBAAoB;;AAE/C;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,SAASC,aAAaA,CAACC,QAA0B,EAAgB;EAC9E,IAAIC,KAAK,GAAGJ,YAAY;EAExB,IAAIG,QAAQ,CAACE,MAAM,KAAK,CAAC,EAAE;IACzBD,KAAK,GAAGD,QAAQ,CAAC,CAAC,CAAC,CAAEG,SAAS,CAAC,CAAC;EAClC;EAEA,OAAO;IACLA,SAAS,EAAEF,KAAK;IAChBG,QAAQ,EAAEJ,QAAQ,CAACK,GAAG,CAACP,cAAc;EACvC,CAAC;AACH","ignoreList":[]}
1
+ {"version":3,"file":"build-post-body.js","names":["TOPIC_MERGED","convertLogInfo","buildPostBody","payloads","topic","length","__topic__","__logs__","map"],"sources":["../../../src/util/build-post-body.ts"],"sourcesContent":["import {\n ISlsLogPayload,\n ISlsPostBody\n} from '../types';\nimport {\n TOPIC_MERGED\n} from '../const';\n\nimport convertLogInfo from './convert-log-info';\n\n/**\n * 利用 PutWebTracking 发送日志,如果 `__logs__` 里含有 `__topic__` 则,外部的这个 `__topic__` 将被改为 `__topic__0`,\n * 为了干净,在仅发送一条日志的时候,将 `__logs__` 里的 `__topic__` 往上提。\n *\n * 但是,POST 的时候 `__source__` 不会被默认填充成 IP,IP 在 `__tag__:__client_ip__`(GET 方式也有)\n */\nexport default function buildPostBody(payloads: ISlsLogPayload[]): ISlsPostBody {\n let topic = TOPIC_MERGED;\n \n if (payloads.length === 1) {\n topic = payloads[0]!.__topic__; // eslint-disable-line @typescript-eslint/no-non-null-assertion\n }\n \n return {\n __topic__: topic,\n __logs__: payloads.map(convertLogInfo)\n };\n}\n"],"mappings":"AAIA,SACEA,YAAY,QACP,UAAU;AAEjB,OAAOC,cAAc,MAAM,oBAAoB;;AAE/C;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,SAASC,aAAaA,CAACC,QAA0B,EAAgB;EAC9E,IAAIC,KAAK,GAAGJ,YAAY;EAExB,IAAIG,QAAQ,CAACE,MAAM,KAAK,CAAC,EAAE;IACzBD,KAAK,GAAGD,QAAQ,CAAC,CAAC,CAAC,CAAEG,SAAS,CAAC,CAAC;EAClC;EAEA,OAAO;IACLA,SAAS,EAAEF,KAAK;IAChBG,QAAQ,EAAEJ,QAAQ,CAACK,GAAG,CAACP,cAAc;EACvC,CAAC;AACH","ignoreList":[]}
@@ -19,7 +19,7 @@ export default function convertLogInfo(info) {
19
19
  try {
20
20
  // 避免 cyclic error
21
21
  o[k] = JSON.stringify(v);
22
- } catch (err) {
22
+ } catch (_err) {
23
23
  o[k] = 'TypeError: cyclic object value';
24
24
  }
25
25
  }
@@ -1 +1 @@
1
- {"version":3,"file":"convert-log-info.js","names":["convertLogInfo","info","o","Object","keys","forEach","k","v","undefined","toString","JSON","stringify","err","_TOPIC","__topic__"],"sources":["../../../src/util/convert-log-info.ts"],"sourcesContent":["import type {\n ISlsLogPayload\n} from '../types';\n\n/**\n * 发送的 JSON 里边不可以有除了字符串以外的值,否则报错\n *\n * - code = PostBodyInvalid\n * - message = Value in log is not string data type\n */\nexport default function convertLogInfo(info: ISlsLogPayload): Record<string, string> {\n const o: Record<string, string> = {};\n \n Object.keys(info).forEach(k => {\n const v = info[k];\n \n if (v === '' || v === null || v === undefined) {\n return;\n }\n \n if (typeof v === 'string') {\n o[k] = v;\n } else if (typeof v === 'number' || typeof v === 'boolean') {\n o[k] = v.toString();\n } else {\n try { // 避免 cyclic error\n o[k] = JSON.stringify(v);\n } catch (err) {\n o[k] = 'TypeError: cyclic object value';\n }\n }\n });\n \n /**\n * SLS 说不要用 __topic__ 做检索... ~~但又必须每条日志有个 __topic__...~~ <- 刚看了文档 __topic__ 非必填\n * 在发送多条日志的时候,无法通过内部的 __topic__ 检索到相关的内容,这是一个很奇葩的设定,所以这里给每条日志\n * 增加一个 _TOPIC 属性用来检索的时候替代 __topic__\n *\n * 详情 https://aone.alibaba-inc.com/issue/34492769\n */\n o._TOPIC = o.__topic__!; // eslint-disable-line @typescript-eslint/no-non-null-assertion\n \n return o;\n}"],"mappings":"AAIA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,SAASA,cAAcA,CAACC,IAAoB,EAA0B;EACnF,IAAMC,CAAyB,GAAG,CAAC,CAAC;EAEpCC,MAAM,CAACC,IAAI,CAACH,IAAI,CAAC,CAACI,OAAO,CAAC,UAAAC,CAAC,EAAI;IAC7B,IAAMC,CAAC,GAAGN,IAAI,CAACK,CAAC,CAAC;IAEjB,IAAIC,CAAC,KAAK,EAAE,IAAIA,CAAC,KAAK,IAAI,IAAIA,CAAC,KAAKC,SAAS,EAAE;MAC7C;IACF;IAEA,IAAI,OAAOD,CAAC,KAAK,QAAQ,EAAE;MACzBL,CAAC,CAACI,CAAC,CAAC,GAAGC,CAAC;IACV,CAAC,MAAM,IAAI,OAAOA,CAAC,KAAK,QAAQ,IAAI,OAAOA,CAAC,KAAK,SAAS,EAAE;MAC1DL,CAAC,CAACI,CAAC,CAAC,GAAGC,CAAC,CAACE,QAAQ,CAAC,CAAC;IACrB,CAAC,MAAM;MACL,IAAI;QAAE;QACJP,CAAC,CAACI,CAAC,CAAC,GAAGI,IAAI,CAACC,SAAS,CAACJ,CAAC,CAAC;MAC1B,CAAC,CAAC,OAAOK,GAAG,EAAE;QACZV,CAAC,CAACI,CAAC,CAAC,GAAG,gCAAgC;MACzC;IACF;EACF,CAAC,CAAC;;EAEF;AACF;AACA;AACA;AACA;AACA;AACA;EACEJ,CAAC,CAACW,MAAM,GAAGX,CAAC,CAACY,SAAU,CAAC,CAAC;;EAEzB,OAAOZ,CAAC;AACV","ignoreList":[]}
1
+ {"version":3,"file":"convert-log-info.js","names":["convertLogInfo","info","o","Object","keys","forEach","k","v","undefined","toString","JSON","stringify","_err","_TOPIC","__topic__"],"sources":["../../../src/util/convert-log-info.ts"],"sourcesContent":["import {\n ISlsLogPayload\n} from '../types';\n\n/**\n * 发送的 JSON 里边不可以有除了字符串以外的值,否则报错\n *\n * - code = PostBodyInvalid\n * - message = Value in log is not string data type\n */\nexport default function convertLogInfo(info: ISlsLogPayload): Record<string, string> {\n const o: Record<string, string> = {};\n \n Object.keys(info).forEach(k => {\n const v = info[k];\n \n if (v === '' || v === null || v === undefined) {\n return;\n }\n \n if (typeof v === 'string') {\n o[k] = v;\n } else if (typeof v === 'number' || typeof v === 'boolean') {\n o[k] = v.toString();\n } else {\n try { // 避免 cyclic error\n o[k] = JSON.stringify(v);\n } catch (_err) {\n o[k] = 'TypeError: cyclic object value';\n }\n }\n });\n \n /**\n * SLS 说不要用 __topic__ 做检索... ~~但又必须每条日志有个 __topic__...~~ <- 刚看了文档 __topic__ 非必填\n * 在发送多条日志的时候,无法通过内部的 __topic__ 检索到相关的内容,这是一个很奇葩的设定,所以这里给每条日志\n * 增加一个 _TOPIC 属性用来检索的时候替代 __topic__\n *\n * 详情 https://aone.alibaba-inc.com/issue/34492769\n */\n o._TOPIC = o.__topic__!; // eslint-disable-line @typescript-eslint/no-non-null-assertion\n \n return o;\n}\n"],"mappings":"AAIA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,SAASA,cAAcA,CAACC,IAAoB,EAA0B;EACnF,IAAMC,CAAyB,GAAG,CAAC,CAAC;EAEpCC,MAAM,CAACC,IAAI,CAACH,IAAI,CAAC,CAACI,OAAO,CAAC,UAAAC,CAAC,EAAI;IAC7B,IAAMC,CAAC,GAAGN,IAAI,CAACK,CAAC,CAAC;IAEjB,IAAIC,CAAC,KAAK,EAAE,IAAIA,CAAC,KAAK,IAAI,IAAIA,CAAC,KAAKC,SAAS,EAAE;MAC7C;IACF;IAEA,IAAI,OAAOD,CAAC,KAAK,QAAQ,EAAE;MACzBL,CAAC,CAACI,CAAC,CAAC,GAAGC,CAAC;IACV,CAAC,MAAM,IAAI,OAAOA,CAAC,KAAK,QAAQ,IAAI,OAAOA,CAAC,KAAK,SAAS,EAAE;MAC1DL,CAAC,CAACI,CAAC,CAAC,GAAGC,CAAC,CAACE,QAAQ,CAAC,CAAC;IACrB,CAAC,MAAM;MACL,IAAI;QAAE;QACJP,CAAC,CAACI,CAAC,CAAC,GAAGI,IAAI,CAACC,SAAS,CAACJ,CAAC,CAAC;MAC1B,CAAC,CAAC,OAAOK,IAAI,EAAE;QACbV,CAAC,CAACI,CAAC,CAAC,GAAG,gCAAgC;MACzC;IACF;EACF,CAAC,CAAC;;EAEF;AACF;AACA;AACA;AACA;AACA;AACA;EACEJ,CAAC,CAACW,MAAM,GAAGX,CAAC,CAACY,SAAU,CAAC,CAAC;;EAEzB,OAAOZ,CAAC;AACV","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"create-sls-log-quick.js","names":["createSlsLogQuick","sls","group","options","topic","payload","_len","arguments","length","args","Array","_key","_ref","_ref2","_slicedToArray","_ref3","_ref4","_objectSpread"],"sources":["../../../src/util/create-sls-log-quick.ts"],"sourcesContent":["import {\n ISlsLogFn,\n ISlsLogFnQuick,\n ISlsLogOptions,\n TLogQuickArgs\n} from '../types';\n\nexport default function createSlsLogQuick(sls: ISlsLogFn, group: string): ISlsLogFnQuick {\n return (...args: TLogQuickArgs): void => {\n let options: ISlsLogOptions = {};\n let topic: string;\n let payload: object | undefined;\n \n if (typeof args[0] === 'string') {\n [topic, payload] = args as [string, object?];\n } else {\n [options, topic, payload] = args as [ISlsLogOptions, string, object?];\n }\n \n sls({\n ...options,\n group\n }, topic, payload as object);\n };\n}"],"mappings":";;AAOA,eAAe,SAASA,iBAAiBA,CAACC,GAAc,EAAEC,KAAa,EAAkB;EACvF,OAAO,YAAkC;IACvC,IAAIC,OAAuB,GAAG,CAAC,CAAC;IAChC,IAAIC,KAAa;IACjB,IAAIC,OAA2B;IAAC,SAAAC,IAAA,GAAAC,SAAA,CAAAC,MAAA,EAHvBC,IAAI,OAAAC,KAAA,CAAAJ,IAAA,GAAAK,IAAA,MAAAA,IAAA,GAAAL,IAAA,EAAAK,IAAA;MAAJF,IAAI,CAAAE,IAAA,IAAAJ,SAAA,CAAAI,IAAA;IAAA;IAKb,IAAI,OAAOF,IAAI,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE;MAAA,IAAAG,IAAA,GACZH,IAAI;MAAA,IAAAI,KAAA,GAAAC,cAAA,CAAAF,IAAA;MAAtBR,KAAK,GAAAS,KAAA;MAAER,OAAO,GAAAQ,KAAA;IACjB,CAAC,MAAM;MAAA,IAAAE,KAAA,GACuBN,IAAI;MAAA,IAAAO,KAAA,GAAAF,cAAA,CAAAC,KAAA;MAA/BZ,OAAO,GAAAa,KAAA;MAAEZ,KAAK,GAAAY,KAAA;MAAEX,OAAO,GAAAW,KAAA;IAC1B;IAEAf,GAAG,CAAAgB,aAAA,CAAAA,aAAA,KACEd,OAAO;MACVD,KAAK,EAALA;IAAK,IACJE,KAAK,EAAEC,OAAiB,CAAC;EAC9B,CAAC;AACH","ignoreList":[]}
1
+ {"version":3,"file":"create-sls-log-quick.js","names":["createSlsLogQuick","sls","group","options","topic","payload","_len","arguments","length","args","Array","_key","_ref","_ref2","_slicedToArray","_ref3","_ref4","_objectSpread"],"sources":["../../../src/util/create-sls-log-quick.ts"],"sourcesContent":["import {\n ISlsLogFn,\n ISlsLogFnQuick,\n ISlsLogOptions,\n TLogQuickArgs\n} from '../types';\n\nexport default function createSlsLogQuick(sls: ISlsLogFn, group: string): ISlsLogFnQuick {\n return (...args: TLogQuickArgs): void => {\n let options: ISlsLogOptions = {};\n let topic: string;\n let payload: object | undefined;\n \n if (typeof args[0] === 'string') {\n [topic, payload] = args as [string, object?];\n } else {\n [options, topic, payload] = args as [ISlsLogOptions, string, object?];\n }\n \n sls({\n ...options,\n group\n }, topic, payload as object);\n };\n}\n"],"mappings":";;AAOA,eAAe,SAASA,iBAAiBA,CAACC,GAAc,EAAEC,KAAa,EAAkB;EACvF,OAAO,YAAkC;IACvC,IAAIC,OAAuB,GAAG,CAAC,CAAC;IAChC,IAAIC,KAAa;IACjB,IAAIC,OAA2B;IAAC,SAAAC,IAAA,GAAAC,SAAA,CAAAC,MAAA,EAHvBC,IAAI,OAAAC,KAAA,CAAAJ,IAAA,GAAAK,IAAA,MAAAA,IAAA,GAAAL,IAAA,EAAAK,IAAA;MAAJF,IAAI,CAAAE,IAAA,IAAAJ,SAAA,CAAAI,IAAA;IAAA;IAKb,IAAI,OAAOF,IAAI,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE;MAAA,IAAAG,IAAA,GACZH,IAAI;MAAA,IAAAI,KAAA,GAAAC,cAAA,CAAAF,IAAA;MAAtBR,KAAK,GAAAS,KAAA;MAAER,OAAO,GAAAQ,KAAA;IACjB,CAAC,MAAM;MAAA,IAAAE,KAAA,GACuBN,IAAI;MAAA,IAAAO,KAAA,GAAAF,cAAA,CAAAC,KAAA;MAA/BZ,OAAO,GAAAa,KAAA;MAAEZ,KAAK,GAAAY,KAAA;MAAEX,OAAO,GAAAW,KAAA;IAC1B;IAEAf,GAAG,CAAAgB,aAAA,CAAAA,aAAA,KACEd,OAAO;MACVD,KAAK,EAALA;IAAK,IACJE,KAAK,EAAEC,OAAiB,CAAC;EAC9B,CAAC;AACH","ignoreList":[]}
@@ -1,10 +1,9 @@
1
1
  import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
2
2
  import _isEmpty from 'lodash/isEmpty';
3
3
  import _isPlainObject from 'lodash/isPlainObject';
4
- import _isError from 'lodash/isError';
5
4
  import _forEach from 'lodash/forEach';
6
- import convertErrorToPlain from './convert-error-to-plain';
7
5
  import flattenTestPath from './flatten-test-path';
6
+ import normalizePayload from './normalize-payload';
8
7
 
9
8
  /**
10
9
  * 有时候为了统计方便,需要把传入的对象展平,比如 error 对象,可能会展平成如下形状:
@@ -25,36 +24,33 @@ export default function flattenObject(o, options) {
25
24
  _resolvedOptions$dept = resolvedOptions.depth,
26
25
  depth = _resolvedOptions$dept === void 0 ? 5 : _resolvedOptions$dept,
27
26
  omit = resolvedOptions.omit,
28
- pass = resolvedOptions.pass;
27
+ direct = resolvedOptions.direct;
29
28
  var result = {};
30
- function makeSureErrorObject(errorOrObject) {
31
- return _isError(errorOrObject) ? convertErrorToPlain(errorOrObject) : errorOrObject;
32
- }
33
29
  function loop(currentObj, parentPaths) {
34
30
  var depthFull = depth > 0 && parentPaths.length + 1 >= depth;
35
31
  _forEach(currentObj, function (v, k) {
36
32
  var pathKey = [].concat(_toConsumableArray(parentPaths), [k]).join('.');
37
33
  var scopedPathKey = scope ? "".concat(scope, ".").concat(pathKey) : pathKey;
38
34
 
39
- // 可以忽略不重要的信息,默认不记录 `_` 打头的所有数据
40
- if (/^_/.test(k) || omit && flattenTestPath(pathKey, omit)) {
35
+ // 可以忽略不重要的信息,不记录方法,不记录 `_` 打头的数据
36
+ if (k.startsWith('_') || typeof v === 'function' || omit && flattenTestPath(pathKey, omit)) {
41
37
  return;
42
38
  }
43
- var vAsObject = makeSureErrorObject(v);
39
+ var normalizedV = normalizePayload(v);
44
40
 
45
41
  // 不继续 loop:
46
42
  // 1. 深度满了
47
- // 2. 不是对象,不是 Error
43
+ // 2. 不是对象(已经 normalize 掉了一部分)
48
44
  // 3. 空对象,或空数组
49
- // 4. 命中 `pass` 规则
50
- if (depthFull || !_isPlainObject(vAsObject) || _isEmpty(vAsObject) || pass && flattenTestPath(pathKey, pass)) {
51
- result[scopedPathKey] = vAsObject;
45
+ // 4. 命中 `direct` 规则
46
+ if (depthFull || !_isPlainObject(normalizedV) || _isEmpty(normalizedV) || direct && flattenTestPath(pathKey, direct)) {
47
+ result[scopedPathKey] = normalizedV;
52
48
  return;
53
49
  }
54
- loop(vAsObject, [].concat(_toConsumableArray(parentPaths), [k]));
50
+ loop(normalizedV, [].concat(_toConsumableArray(parentPaths), [k]));
55
51
  });
56
52
  }
57
- loop(makeSureErrorObject(o), []);
53
+ loop(o, []);
58
54
  return result;
59
55
  }
60
56
  //# sourceMappingURL=flatten-object.js.map