nightingale-json-formatter 15.0.0 → 16.1.0
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/CHANGELOG.md +22 -0
- package/README.md +11 -9
- package/lib/index.js +3 -0
- package/package.json +11 -55
- package/dist/definitions/index.d.ts +0 -3
- package/dist/definitions/index.d.ts.map +0 -1
- package/dist/definitions/index.test.d.ts +0 -2
- package/dist/definitions/index.test.d.ts.map +0 -1
- package/dist/index-browser.es.js +0 -38
- package/dist/index-browser.es.js.map +0 -1
- package/dist/index-node18.mjs +0 -38
- package/dist/index-node18.mjs.map +0 -1
- package/src/.eslintrc.json +0 -27
- package/src/index.test.ts +0 -62
- package/src/index.ts +0 -49
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,28 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [16.1.0](https://github.com/christophehurpeau/nightingale/compare/v16.0.0...v16.1.0) (2025-03-30)
|
|
7
|
+
|
|
8
|
+
Version bump for dependency: nightingale
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
## [16.0.0](https://github.com/christophehurpeau/nightingale/compare/v15.0.0...v16.0.0) (2025-03-30)
|
|
12
|
+
|
|
13
|
+
### ⚠ BREAKING CHANGES
|
|
14
|
+
|
|
15
|
+
* drop node 18
|
|
16
|
+
|
|
17
|
+
### Features
|
|
18
|
+
|
|
19
|
+
* drop node 18 ([1b11a55](https://github.com/christophehurpeau/nightingale/commit/1b11a55dd24c9435be50519a748316079f554414))
|
|
20
|
+
|
|
21
|
+
### Bug Fixes
|
|
22
|
+
|
|
23
|
+
* fix lib exports ([5b562b2](https://github.com/christophehurpeau/nightingale/commit/5b562b245aac1aa86b728a9433f3c9d28c62fe04))
|
|
24
|
+
|
|
25
|
+
Version bump for dependency: nightingale
|
|
26
|
+
|
|
27
|
+
|
|
6
28
|
## [15.0.0](https://github.com/christophehurpeau/nightingale/compare/v14.2.1...v15.0.0) (2023-12-25)
|
|
7
29
|
|
|
8
30
|
|
package/README.md
CHANGED
|
@@ -1,27 +1,29 @@
|
|
|
1
|
-
<
|
|
1
|
+
<h1 align="center">
|
|
2
2
|
nightingale-json-formatter
|
|
3
|
-
</
|
|
3
|
+
</h1>
|
|
4
4
|
|
|
5
5
|
<p align="center">
|
|
6
|
-
|
|
6
|
+
Deprecated: use JSONFormatter from nightingale
|
|
7
7
|
</p>
|
|
8
8
|
|
|
9
9
|
<p align="center">
|
|
10
|
-
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/npm/v/nightingale-json-formatter.svg?style=flat-square"></a>
|
|
11
|
-
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/npm/dw/nightingale-json-formatter.svg?style=flat-square"></a>
|
|
12
|
-
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/node/v/nightingale-json-formatter.svg?style=flat-square"></a>
|
|
13
|
-
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/npm/types/nightingale-json-formatter.svg?style=flat-square"></a>
|
|
10
|
+
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/npm/v/nightingale-json-formatter.svg?style=flat-square" alt="npm version"></a>
|
|
11
|
+
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/npm/dw/nightingale-json-formatter.svg?style=flat-square" alt="npm downloads"></a>
|
|
12
|
+
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/node/v/nightingale-json-formatter.svg?style=flat-square" alt="node version"></a>
|
|
13
|
+
<a href="https://npmjs.org/package/nightingale-json-formatter"><img src="https://img.shields.io/npm/types/nightingale-json-formatter.svg?style=flat-square" alt="types"></a>
|
|
14
14
|
<a href="https://codecov.io/gh/christophehurpeau/nightingale"><img src="https://img.shields.io/codecov/c/github/christophehurpeau/nightingale/master.svg?style=flat-square"></a>
|
|
15
15
|
</p>
|
|
16
16
|
|
|
17
17
|
## Install
|
|
18
18
|
|
|
19
19
|
```sh
|
|
20
|
-
npm install --save nightingale
|
|
20
|
+
npm install --save nightingale
|
|
21
21
|
```
|
|
22
22
|
|
|
23
23
|
## Usage
|
|
24
24
|
|
|
25
25
|
```js
|
|
26
|
-
import
|
|
26
|
+
import { JSONFormatter } from "nightingale";
|
|
27
|
+
|
|
28
|
+
JSONFormatter.format(record);
|
|
27
29
|
```
|
package/lib/index.js
ADDED
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "nightingale-json-formatter",
|
|
3
|
-
"version": "
|
|
4
|
-
"description": "
|
|
3
|
+
"version": "16.1.0",
|
|
4
|
+
"description": "Deprecated: use JSONFormatter from nightingale",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"nightingale",
|
|
7
7
|
"nightingale-formatter"
|
|
@@ -16,72 +16,28 @@
|
|
|
16
16
|
"homepage": "https://github.com/christophehurpeau/nightingale",
|
|
17
17
|
"type": "module",
|
|
18
18
|
"engines": {
|
|
19
|
-
"node": ">=
|
|
19
|
+
"node": ">=20.9.0"
|
|
20
20
|
},
|
|
21
|
-
"
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
"> 0.2%",
|
|
25
|
-
"not ie < 12",
|
|
26
|
-
"not safari < 10",
|
|
27
|
-
"not ios_saf < 10"
|
|
28
|
-
]
|
|
29
|
-
},
|
|
30
|
-
"main": "./dist/index-node18.mjs",
|
|
31
|
-
"types": "./dist/definitions/index.d.ts",
|
|
32
|
-
"module": "./dist/index-browser.es.js",
|
|
33
|
-
"browser": "./dist/index-browser.es.js",
|
|
21
|
+
"sideEffects": false,
|
|
22
|
+
"main": "./lib/index.js",
|
|
23
|
+
"types": "./lib/index.d.ts",
|
|
34
24
|
"exports": {
|
|
35
25
|
"./package.json": "./package.json",
|
|
36
|
-
".":
|
|
37
|
-
"types": "./dist/definitions/index.d.ts",
|
|
38
|
-
"node": {
|
|
39
|
-
"import": "./dist/index-node18.mjs"
|
|
40
|
-
},
|
|
41
|
-
"browser": {
|
|
42
|
-
"import": "./dist/index-browser.es.js"
|
|
43
|
-
}
|
|
44
|
-
}
|
|
26
|
+
".": "./lib/index.js"
|
|
45
27
|
},
|
|
46
|
-
"sideEffects": false,
|
|
47
28
|
"files": [
|
|
48
|
-
"
|
|
49
|
-
"dist"
|
|
29
|
+
"lib"
|
|
50
30
|
],
|
|
51
31
|
"scripts": {
|
|
52
|
-
"build": "yarn clean:build && rollup --config rollup.config.mjs && yarn run build:definitions",
|
|
53
|
-
"build:definitions": "tsc -p tsconfig.json",
|
|
54
32
|
"clean": "yarn clean:build",
|
|
55
|
-
"clean:build": "pob-babel-clean-out dist",
|
|
56
33
|
"lint": "yarn run lint:eslint",
|
|
57
|
-
"lint:eslint": "yarn ../.. run eslint --
|
|
34
|
+
"lint:eslint": "yarn ../.. run eslint --quiet packages/nightingale-json-formatter",
|
|
58
35
|
"test": "yarn ../../ run test -- packages/nightingale-json-formatter",
|
|
59
36
|
"watch": "yarn clean:build && rollup --config rollup.config.mjs --watch"
|
|
60
37
|
},
|
|
38
|
+
"pob": {},
|
|
61
39
|
"prettier": "@pob/root/prettier-config",
|
|
62
|
-
"pob": {
|
|
63
|
-
"babelEnvs": [
|
|
64
|
-
{
|
|
65
|
-
"target": "node",
|
|
66
|
-
"version": "18"
|
|
67
|
-
},
|
|
68
|
-
{
|
|
69
|
-
"target": "browser"
|
|
70
|
-
}
|
|
71
|
-
],
|
|
72
|
-
"entries": [
|
|
73
|
-
"index"
|
|
74
|
-
]
|
|
75
|
-
},
|
|
76
40
|
"dependencies": {
|
|
77
|
-
"nightingale
|
|
78
|
-
"nightingale-types": "15.0.0"
|
|
79
|
-
},
|
|
80
|
-
"devDependencies": {
|
|
81
|
-
"@babel/core": "7.23.6",
|
|
82
|
-
"@babel/preset-env": "7.23.6",
|
|
83
|
-
"nightingale-levels": "15.0.0",
|
|
84
|
-
"pob-babel": "38.0.0",
|
|
85
|
-
"typescript": "5.3.3"
|
|
41
|
+
"nightingale": "16.1.0"
|
|
86
42
|
}
|
|
87
43
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAqC7D,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,CAAC,SAAS,QAAQ,EAC/C,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,GACnB,MAAM,CASR"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../src/index.test.ts"],"names":[],"mappings":""}
|
package/dist/index-browser.es.js
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
function map2object(map) {
|
|
2
|
-
const object = {};
|
|
3
|
-
map.forEach((value, key) => {
|
|
4
|
-
if (typeof key === 'object') {
|
|
5
|
-
// ignore key
|
|
6
|
-
return;
|
|
7
|
-
}
|
|
8
|
-
object[String(key)] = value;
|
|
9
|
-
});
|
|
10
|
-
return object;
|
|
11
|
-
}
|
|
12
|
-
function stringify(value, space) {
|
|
13
|
-
return JSON.stringify(value, (key, objectValue) => {
|
|
14
|
-
if (objectValue instanceof Map) {
|
|
15
|
-
return map2object(objectValue);
|
|
16
|
-
}
|
|
17
|
-
if (objectValue instanceof Error) {
|
|
18
|
-
return {
|
|
19
|
-
message: objectValue.message,
|
|
20
|
-
stack: objectValue.stack
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
return objectValue;
|
|
24
|
-
}, space);
|
|
25
|
-
}
|
|
26
|
-
function format(record) {
|
|
27
|
-
return stringify({
|
|
28
|
-
key: record.key,
|
|
29
|
-
level: record.level,
|
|
30
|
-
datetime: record.datetime,
|
|
31
|
-
message: record.message,
|
|
32
|
-
metadata: record.metadata,
|
|
33
|
-
extra: record.extra
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
export { format as default };
|
|
38
|
-
//# sourceMappingURL=index-browser.es.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-browser.es.js","sources":["../src/index.ts"],"sourcesContent":["import type { LogRecord, Metadata } from 'nightingale-types';\n\nfunction map2object(map: Map<unknown, unknown>): unknown {\n const object: Record<string, unknown> = {};\n\n map.forEach((value, key) => {\n if (typeof key === 'object') {\n // ignore key\n return;\n }\n\n object[String(key)] = value;\n });\n\n return object;\n}\n\nfunction stringify(value: unknown, space?: number | string): string {\n return JSON.stringify(\n value,\n (key, objectValue) => {\n if (objectValue instanceof Map) {\n return map2object(objectValue);\n }\n if (objectValue instanceof Error) {\n return {\n message: objectValue.message,\n stack: objectValue.stack,\n };\n }\n\n return objectValue as unknown;\n },\n space,\n );\n}\n\nexport default function format<T extends Metadata>(\n record: LogRecord<T>,\n): string {\n return stringify({\n key: record.key,\n level: record.level,\n datetime: record.datetime,\n message: record.message,\n metadata: record.metadata,\n extra: record.extra,\n });\n}\n"],"names":["map2object","map","object","forEach","value","key","String","stringify","space","JSON","objectValue","Map","Error","message","stack","format","record","level","datetime","metadata","extra"],"mappings":"AAEA,SAASA,UAAUA,CAACC,GAA0B,EAAW;EACvD,MAAMC,MAA+B,GAAG,EAAE,CAAA;AAE1CD,EAAAA,GAAG,CAACE,OAAO,CAAC,CAACC,KAAK,EAAEC,GAAG,KAAK;AAC1B,IAAA,IAAI,OAAOA,GAAG,KAAK,QAAQ,EAAE;AAC3B;AACA,MAAA,OAAA;AACF,KAAA;AAEAH,IAAAA,MAAM,CAACI,MAAM,CAACD,GAAG,CAAC,CAAC,GAAGD,KAAK,CAAA;AAC7B,GAAC,CAAC,CAAA;AAEF,EAAA,OAAOF,MAAM,CAAA;AACf,CAAA;AAEA,SAASK,SAASA,CAACH,KAAc,EAAEI,KAAuB,EAAU;EAClE,OAAOC,IAAI,CAACF,SAAS,CACnBH,KAAK,EACL,CAACC,GAAG,EAAEK,WAAW,KAAK;IACpB,IAAIA,WAAW,YAAYC,GAAG,EAAE;MAC9B,OAAOX,UAAU,CAACU,WAAW,CAAC,CAAA;AAChC,KAAA;IACA,IAAIA,WAAW,YAAYE,KAAK,EAAE;MAChC,OAAO;QACLC,OAAO,EAAEH,WAAW,CAACG,OAAO;QAC5BC,KAAK,EAAEJ,WAAW,CAACI,KAAAA;OACpB,CAAA;AACH,KAAA;AAEA,IAAA,OAAOJ,WAAW,CAAA;GACnB,EACDF,KACF,CAAC,CAAA;AACH,CAAA;AAEe,SAASO,MAAMA,CAC5BC,MAAoB,EACZ;AACR,EAAA,OAAOT,SAAS,CAAC;IACfF,GAAG,EAAEW,MAAM,CAACX,GAAG;IACfY,KAAK,EAAED,MAAM,CAACC,KAAK;IACnBC,QAAQ,EAAEF,MAAM,CAACE,QAAQ;IACzBL,OAAO,EAAEG,MAAM,CAACH,OAAO;IACvBM,QAAQ,EAAEH,MAAM,CAACG,QAAQ;IACzBC,KAAK,EAAEJ,MAAM,CAACI,KAAAA;AAChB,GAAC,CAAC,CAAA;AACJ;;;;"}
|
package/dist/index-node18.mjs
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
function map2object(map) {
|
|
2
|
-
const object = {};
|
|
3
|
-
map.forEach((value, key) => {
|
|
4
|
-
if (typeof key === 'object') {
|
|
5
|
-
// ignore key
|
|
6
|
-
return;
|
|
7
|
-
}
|
|
8
|
-
object[String(key)] = value;
|
|
9
|
-
});
|
|
10
|
-
return object;
|
|
11
|
-
}
|
|
12
|
-
function stringify(value, space) {
|
|
13
|
-
return JSON.stringify(value, (key, objectValue) => {
|
|
14
|
-
if (objectValue instanceof Map) {
|
|
15
|
-
return map2object(objectValue);
|
|
16
|
-
}
|
|
17
|
-
if (objectValue instanceof Error) {
|
|
18
|
-
return {
|
|
19
|
-
message: objectValue.message,
|
|
20
|
-
stack: objectValue.stack
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
return objectValue;
|
|
24
|
-
}, space);
|
|
25
|
-
}
|
|
26
|
-
function format(record) {
|
|
27
|
-
return stringify({
|
|
28
|
-
key: record.key,
|
|
29
|
-
level: record.level,
|
|
30
|
-
datetime: record.datetime,
|
|
31
|
-
message: record.message,
|
|
32
|
-
metadata: record.metadata,
|
|
33
|
-
extra: record.extra
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
export { format as default };
|
|
38
|
-
//# sourceMappingURL=index-node18.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-node18.mjs","sources":["../src/index.ts"],"sourcesContent":["import type { LogRecord, Metadata } from 'nightingale-types';\n\nfunction map2object(map: Map<unknown, unknown>): unknown {\n const object: Record<string, unknown> = {};\n\n map.forEach((value, key) => {\n if (typeof key === 'object') {\n // ignore key\n return;\n }\n\n object[String(key)] = value;\n });\n\n return object;\n}\n\nfunction stringify(value: unknown, space?: number | string): string {\n return JSON.stringify(\n value,\n (key, objectValue) => {\n if (objectValue instanceof Map) {\n return map2object(objectValue);\n }\n if (objectValue instanceof Error) {\n return {\n message: objectValue.message,\n stack: objectValue.stack,\n };\n }\n\n return objectValue as unknown;\n },\n space,\n );\n}\n\nexport default function format<T extends Metadata>(\n record: LogRecord<T>,\n): string {\n return stringify({\n key: record.key,\n level: record.level,\n datetime: record.datetime,\n message: record.message,\n metadata: record.metadata,\n extra: record.extra,\n });\n}\n"],"names":["map2object","map","object","forEach","value","key","String","stringify","space","JSON","objectValue","Map","Error","message","stack","format","record","level","datetime","metadata","extra"],"mappings":"AAEA,SAASA,UAAUA,CAACC,GAA0B,EAAW;EACvD,MAAMC,MAA+B,GAAG,EAAE,CAAA;AAE1CD,EAAAA,GAAG,CAACE,OAAO,CAAC,CAACC,KAAK,EAAEC,GAAG,KAAK;AAC1B,IAAA,IAAI,OAAOA,GAAG,KAAK,QAAQ,EAAE;AAC3B;AACA,MAAA,OAAA;AACF,KAAA;AAEAH,IAAAA,MAAM,CAACI,MAAM,CAACD,GAAG,CAAC,CAAC,GAAGD,KAAK,CAAA;AAC7B,GAAC,CAAC,CAAA;AAEF,EAAA,OAAOF,MAAM,CAAA;AACf,CAAA;AAEA,SAASK,SAASA,CAACH,KAAc,EAAEI,KAAuB,EAAU;EAClE,OAAOC,IAAI,CAACF,SAAS,CACnBH,KAAK,EACL,CAACC,GAAG,EAAEK,WAAW,KAAK;IACpB,IAAIA,WAAW,YAAYC,GAAG,EAAE;MAC9B,OAAOX,UAAU,CAACU,WAAW,CAAC,CAAA;AAChC,KAAA;IACA,IAAIA,WAAW,YAAYE,KAAK,EAAE;MAChC,OAAO;QACLC,OAAO,EAAEH,WAAW,CAACG,OAAO;QAC5BC,KAAK,EAAEJ,WAAW,CAACI,KAAAA;OACpB,CAAA;AACH,KAAA;AAEA,IAAA,OAAOJ,WAAW,CAAA;GACnB,EACDF,KACF,CAAC,CAAA;AACH,CAAA;AAEe,SAASO,MAAMA,CAC5BC,MAAoB,EACZ;AACR,EAAA,OAAOT,SAAS,CAAC;IACfF,GAAG,EAAEW,MAAM,CAACX,GAAG;IACfY,KAAK,EAAED,MAAM,CAACC,KAAK;IACnBC,QAAQ,EAAEF,MAAM,CAACE,QAAQ;IACzBL,OAAO,EAAEG,MAAM,CAACH,OAAO;IACvBM,QAAQ,EAAEH,MAAM,CAACG,QAAQ;IACzBC,KAAK,EAAEJ,MAAM,CAACI,KAAAA;AAChB,GAAC,CAAC,CAAA;AACJ;;;;"}
|
package/src/.eslintrc.json
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"root": true,
|
|
3
|
-
"parser": "@typescript-eslint/parser",
|
|
4
|
-
"parserOptions": {
|
|
5
|
-
"project": "packages/nightingale-json-formatter/tsconfig.json"
|
|
6
|
-
},
|
|
7
|
-
"plugins": ["@typescript-eslint"],
|
|
8
|
-
"extends": ["@pob/eslint-config-typescript"],
|
|
9
|
-
"ignorePatterns": ["*.d.ts"],
|
|
10
|
-
"overrides": [
|
|
11
|
-
{
|
|
12
|
-
"files": ["**/*.test.ts", "__tests__/**/*.ts"],
|
|
13
|
-
"extends": ["@pob/eslint-config-typescript/test"],
|
|
14
|
-
"env": {
|
|
15
|
-
"jest": true
|
|
16
|
-
},
|
|
17
|
-
"rules": {
|
|
18
|
-
"import/no-extraneous-dependencies": [
|
|
19
|
-
"error",
|
|
20
|
-
{
|
|
21
|
-
"devDependencies": true
|
|
22
|
-
}
|
|
23
|
-
]
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
]
|
|
27
|
-
}
|
package/src/index.test.ts
DELETED
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { Level } from 'nightingale-levels';
|
|
2
|
-
import format from '.';
|
|
3
|
-
|
|
4
|
-
test('format record', () => {
|
|
5
|
-
const record = {
|
|
6
|
-
key: 'record.key',
|
|
7
|
-
level: Level.INFO,
|
|
8
|
-
datetime: new Date(2000, 1, 1, 1, 0, 0),
|
|
9
|
-
message: 'record.message',
|
|
10
|
-
metadata: {},
|
|
11
|
-
extra: {},
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
expect(format(record)).toBe(JSON.stringify(record));
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
test('format error', () => {
|
|
18
|
-
const error = new Error('test message');
|
|
19
|
-
const record = {
|
|
20
|
-
key: 'record.key',
|
|
21
|
-
level: Level.INFO,
|
|
22
|
-
datetime: new Date(2000, 1, 1, 1, 0, 0),
|
|
23
|
-
message: 'record.message',
|
|
24
|
-
metadata: {
|
|
25
|
-
error,
|
|
26
|
-
},
|
|
27
|
-
extra: {},
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
expect(format(record)).toBe(
|
|
31
|
-
JSON.stringify({
|
|
32
|
-
...record,
|
|
33
|
-
metadata: { error: { message: 'test message', stack: error.stack } },
|
|
34
|
-
}),
|
|
35
|
-
);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
test('format map', () => {
|
|
39
|
-
const map = new Map<unknown, unknown>([
|
|
40
|
-
[1, 'value1'],
|
|
41
|
-
['2', 'value2'],
|
|
42
|
-
['3', 3],
|
|
43
|
-
[{}, 'ignore value'],
|
|
44
|
-
]);
|
|
45
|
-
const record = {
|
|
46
|
-
key: 'record.key',
|
|
47
|
-
level: Level.INFO,
|
|
48
|
-
datetime: new Date(2000, 1, 1, 1, 0, 0),
|
|
49
|
-
message: 'record.message',
|
|
50
|
-
metadata: {
|
|
51
|
-
map,
|
|
52
|
-
},
|
|
53
|
-
extra: {},
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
expect(format(record)).toBe(
|
|
57
|
-
JSON.stringify({
|
|
58
|
-
...record,
|
|
59
|
-
metadata: { map: { '1': 'value1', '2': 'value2', '3': 3 } },
|
|
60
|
-
}),
|
|
61
|
-
);
|
|
62
|
-
});
|
package/src/index.ts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import type { LogRecord, Metadata } from 'nightingale-types';
|
|
2
|
-
|
|
3
|
-
function map2object(map: Map<unknown, unknown>): unknown {
|
|
4
|
-
const object: Record<string, unknown> = {};
|
|
5
|
-
|
|
6
|
-
map.forEach((value, key) => {
|
|
7
|
-
if (typeof key === 'object') {
|
|
8
|
-
// ignore key
|
|
9
|
-
return;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
object[String(key)] = value;
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
return object;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
function stringify(value: unknown, space?: number | string): string {
|
|
19
|
-
return JSON.stringify(
|
|
20
|
-
value,
|
|
21
|
-
(key, objectValue) => {
|
|
22
|
-
if (objectValue instanceof Map) {
|
|
23
|
-
return map2object(objectValue);
|
|
24
|
-
}
|
|
25
|
-
if (objectValue instanceof Error) {
|
|
26
|
-
return {
|
|
27
|
-
message: objectValue.message,
|
|
28
|
-
stack: objectValue.stack,
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
return objectValue as unknown;
|
|
33
|
-
},
|
|
34
|
-
space,
|
|
35
|
-
);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
export default function format<T extends Metadata>(
|
|
39
|
-
record: LogRecord<T>,
|
|
40
|
-
): string {
|
|
41
|
-
return stringify({
|
|
42
|
-
key: record.key,
|
|
43
|
-
level: record.level,
|
|
44
|
-
datetime: record.datetime,
|
|
45
|
-
message: record.message,
|
|
46
|
-
metadata: record.metadata,
|
|
47
|
-
extra: record.extra,
|
|
48
|
-
});
|
|
49
|
-
}
|