nightingale-json-formatter 14.2.1 → 16.0.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 CHANGED
@@ -3,6 +3,39 @@
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.0.0](https://github.com/christophehurpeau/nightingale/compare/v15.0.0...v16.0.0) (2025-03-30)
7
+
8
+ ### ⚠ BREAKING CHANGES
9
+
10
+ * drop node 18
11
+
12
+ ### Features
13
+
14
+ * drop node 18 ([1b11a55](https://github.com/christophehurpeau/nightingale/commit/1b11a55dd24c9435be50519a748316079f554414))
15
+
16
+ ### Bug Fixes
17
+
18
+ * fix lib exports ([5b562b2](https://github.com/christophehurpeau/nightingale/commit/5b562b245aac1aa86b728a9433f3c9d28c62fe04))
19
+
20
+ Version bump for dependency: nightingale
21
+
22
+
23
+ ## [15.0.0](https://github.com/christophehurpeau/nightingale/compare/v14.2.1...v15.0.0) (2023-12-25)
24
+
25
+
26
+ ### ⚠ BREAKING CHANGES
27
+
28
+ * update babel and drop browser modern version
29
+
30
+ ### Features
31
+
32
+ * update babel and drop browser modern version ([5c76abc](https://github.com/christophehurpeau/nightingale/commit/5c76abc8bfb595a617fc4c8b795dae7e674ea664))
33
+
34
+ Version bump for dependency: nightingale-formatter
35
+ Version bump for dependency: nightingale-types
36
+ Version bump for dependency: nightingale-levels
37
+
38
+
6
39
  ## [14.2.1](https://github.com/christophehurpeau/nightingale/compare/v14.2.0...v14.2.1) (2023-11-05)
7
40
 
8
41
  Note: no notable changes
package/README.md CHANGED
@@ -1,27 +1,29 @@
1
- <h3 align="center">
1
+ <h1 align="center">
2
2
  nightingale-json-formatter
3
- </h3>
3
+ </h1>
4
4
 
5
5
  <p align="center">
6
- Nightingale JSON formatter
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-json-formatter
20
+ npm install --save nightingale
21
21
  ```
22
22
 
23
23
  ## Usage
24
24
 
25
25
  ```js
26
- import jsonFormatter from 'nightingale-json-formatter';
26
+ import { JSONFormatter } from "nightingale";
27
+
28
+ JSONFormatter.format(record);
27
29
  ```
package/lib/index.js ADDED
@@ -0,0 +1,3 @@
1
+ import { JSONFormatter } from "nightingale";
2
+
3
+ export default JSONFormatter.format;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "nightingale-json-formatter",
3
- "version": "14.2.1",
4
- "description": "Nightingale JSON formatter",
3
+ "version": "16.0.0",
4
+ "description": "Deprecated: use JSONFormatter from nightingale",
5
5
  "keywords": [
6
6
  "nightingale",
7
7
  "nightingale-formatter"
@@ -16,79 +16,28 @@
16
16
  "homepage": "https://github.com/christophehurpeau/nightingale",
17
17
  "type": "module",
18
18
  "engines": {
19
- "node": ">=18.12.0"
19
+ "node": ">=20.9.0"
20
20
  },
21
- "browserslist": {
22
- "production": [
23
- "defaults",
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
- "browser:modern": {
43
- "import": "./dist/index-browsermodern.es.js"
44
- },
45
- "import": "./dist/index-browser.es.js"
46
- }
47
- }
26
+ ".": "./lib/index.js"
48
27
  },
49
- "sideEffects": false,
50
28
  "files": [
51
- "src",
52
- "dist"
29
+ "lib"
53
30
  ],
54
31
  "scripts": {
55
- "build": "yarn clean:build && rollup --config rollup.config.mjs && yarn run build:definitions",
56
- "build:definitions": "tsc -p tsconfig.json",
57
32
  "clean": "yarn clean:build",
58
- "clean:build": "pob-babel-clean-out dist",
59
33
  "lint": "yarn run lint:eslint",
60
- "lint:eslint": "yarn ../.. run eslint --report-unused-disable-directives --resolve-plugins-relative-to . --quiet packages/nightingale-json-formatter",
34
+ "lint:eslint": "yarn ../.. run eslint --quiet packages/nightingale-json-formatter",
61
35
  "test": "yarn ../../ run test -- packages/nightingale-json-formatter",
62
36
  "watch": "yarn clean:build && rollup --config rollup.config.mjs --watch"
63
37
  },
38
+ "pob": {},
64
39
  "prettier": "@pob/root/prettier-config",
65
- "pob": {
66
- "babelEnvs": [
67
- {
68
- "target": "node",
69
- "version": "18"
70
- },
71
- {
72
- "target": "browser",
73
- "version": "modern"
74
- },
75
- {
76
- "target": "browser"
77
- }
78
- ],
79
- "entries": [
80
- "index"
81
- ]
82
- },
83
40
  "dependencies": {
84
- "nightingale-formatter": "14.2.1",
85
- "nightingale-types": "14.2.1"
86
- },
87
- "devDependencies": {
88
- "@babel/core": "7.23.2",
89
- "@babel/preset-env": "7.23.2",
90
- "nightingale-levels": "14.2.1",
91
- "pob-babel": "36.6.1",
92
- "typescript": "5.2.2"
41
+ "nightingale": "16.0.0"
93
42
  }
94
43
  }
@@ -1,3 +0,0 @@
1
- import type { LogRecord, Metadata } from 'nightingale-types';
2
- export default function format<T extends Metadata>(record: LogRecord<T>): string;
3
- //# sourceMappingURL=index.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=index.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../src/index.test.ts"],"names":[],"mappings":""}
@@ -1,38 +0,0 @@
1
- function map2object(map) {
2
- var object = {};
3
- map.forEach(function (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, function (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,IAAMC,MAA+B,GAAG,EAAE,CAAA;AAE1CD,EAAAA,GAAG,CAACE,OAAO,CAAC,UAACC,KAAK,EAAEC,GAAG,EAAK;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,UAACC,GAAG,EAAEK,WAAW,EAAK;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;;;;"}
@@ -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-browsermodern.es.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-browsermodern.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;;;;"}
@@ -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;;;;"}
@@ -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
- }