pino-sdk 9.7.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.

Potentially problematic release.


This version of pino-sdk might be problematic. Click here for more details.

Files changed (202) hide show
  1. package/.eslintignore +2 -0
  2. package/.eslintrc +8 -0
  3. package/.github/dependabot.yml +13 -0
  4. package/.github/workflows/bench.yml +61 -0
  5. package/.github/workflows/ci.yml +88 -0
  6. package/.github/workflows/lock-threads.yml +30 -0
  7. package/.github/workflows/target-main.yml +23 -0
  8. package/.nojekyll +0 -0
  9. package/.prettierignore +1 -0
  10. package/.taprc.yaml +8 -0
  11. package/CNAME +1 -0
  12. package/CONTRIBUTING.md +30 -0
  13. package/LICENSE +21 -0
  14. package/README.md +161 -0
  15. package/SECURITY.md +68 -0
  16. package/benchmarks/basic.bench.js +95 -0
  17. package/benchmarks/child-child.bench.js +52 -0
  18. package/benchmarks/child-creation.bench.js +73 -0
  19. package/benchmarks/child.bench.js +62 -0
  20. package/benchmarks/deep-object.bench.js +88 -0
  21. package/benchmarks/formatters.bench.js +50 -0
  22. package/benchmarks/internal/custom-levels.js +67 -0
  23. package/benchmarks/internal/just-pino-heavy.bench.js +76 -0
  24. package/benchmarks/internal/just-pino.bench.js +182 -0
  25. package/benchmarks/internal/parent-vs-child.bench.js +75 -0
  26. package/benchmarks/internal/redact.bench.js +86 -0
  27. package/benchmarks/long-string.bench.js +81 -0
  28. package/benchmarks/multi-arg.bench.js +193 -0
  29. package/benchmarks/multistream.js +98 -0
  30. package/benchmarks/object.bench.js +82 -0
  31. package/benchmarks/utils/generate-benchmark-doc.js +36 -0
  32. package/benchmarks/utils/runbench.js +138 -0
  33. package/benchmarks/utils/wrap-log-level.js +55 -0
  34. package/bin.js +6 -0
  35. package/browser.js +505 -0
  36. package/build/sync-version.js +10 -0
  37. package/docs/api.md +1490 -0
  38. package/docs/asynchronous.md +40 -0
  39. package/docs/benchmarks.md +55 -0
  40. package/docs/browser.md +242 -0
  41. package/docs/bundling.md +40 -0
  42. package/docs/child-loggers.md +95 -0
  43. package/docs/ecosystem.md +84 -0
  44. package/docs/help.md +345 -0
  45. package/docs/lts.md +64 -0
  46. package/docs/pretty.md +35 -0
  47. package/docs/redaction.md +135 -0
  48. package/docs/transports.md +1263 -0
  49. package/docs/web.md +309 -0
  50. package/docsify/sidebar.md +26 -0
  51. package/examples/basic.js +43 -0
  52. package/examples/transport.js +68 -0
  53. package/favicon-16x16.png +0 -0
  54. package/favicon-32x32.png +0 -0
  55. package/favicon.ico +0 -0
  56. package/file.js +12 -0
  57. package/inc-version.sh +42 -0
  58. package/index.html +55 -0
  59. package/lib/caller.js +30 -0
  60. package/lib/constants.js +28 -0
  61. package/lib/deprecations.js +8 -0
  62. package/lib/levels.js +241 -0
  63. package/lib/meta.js +3 -0
  64. package/lib/multistream.js +188 -0
  65. package/lib/proto.js +234 -0
  66. package/lib/redaction.js +118 -0
  67. package/lib/symbols.js +74 -0
  68. package/lib/time.js +11 -0
  69. package/lib/tools.js +390 -0
  70. package/lib/transport-stream.js +56 -0
  71. package/lib/transport.js +167 -0
  72. package/lib/worker.js +194 -0
  73. package/package.json +119 -0
  74. package/pino-banner.png +0 -0
  75. package/pino-logo-hire.png +0 -0
  76. package/pino-tree.png +0 -0
  77. package/pino2.d.ts +913 -0
  78. package/pino2.js +234 -0
  79. package/pretty-demo.png +0 -0
  80. package/test/basic.test.js +874 -0
  81. package/test/broken-pipe.test.js +57 -0
  82. package/test/browser-child.test.js +132 -0
  83. package/test/browser-disabled.test.js +87 -0
  84. package/test/browser-early-console-freeze.test.js +12 -0
  85. package/test/browser-is-level-enabled.test.js +104 -0
  86. package/test/browser-levels.test.js +241 -0
  87. package/test/browser-serializers.test.js +352 -0
  88. package/test/browser-timestamp.test.js +88 -0
  89. package/test/browser-transmit.test.js +417 -0
  90. package/test/browser.test.js +679 -0
  91. package/test/complex-objects.test.js +34 -0
  92. package/test/crlf.test.js +32 -0
  93. package/test/custom-levels.test.js +253 -0
  94. package/test/error.test.js +398 -0
  95. package/test/errorKey.test.js +34 -0
  96. package/test/escaping.test.js +91 -0
  97. package/test/esm/esm.mjs +12 -0
  98. package/test/esm/index.test.js +34 -0
  99. package/test/esm/named-exports.mjs +27 -0
  100. package/test/exit.test.js +77 -0
  101. package/test/fixtures/broken-pipe/basic.js +9 -0
  102. package/test/fixtures/broken-pipe/destination.js +10 -0
  103. package/test/fixtures/broken-pipe/syncfalse.js +12 -0
  104. package/test/fixtures/console-transport.js +13 -0
  105. package/test/fixtures/crashing-transport.js +13 -0
  106. package/test/fixtures/default-exit.js +8 -0
  107. package/test/fixtures/destination-exit.js +8 -0
  108. package/test/fixtures/eval/index.js +13 -0
  109. package/test/fixtures/eval/node_modules/14-files.js +3 -0
  110. package/test/fixtures/eval/node_modules/2-files.js +3 -0
  111. package/test/fixtures/eval/node_modules/file1.js +5 -0
  112. package/test/fixtures/eval/node_modules/file10.js +5 -0
  113. package/test/fixtures/eval/node_modules/file11.js +5 -0
  114. package/test/fixtures/eval/node_modules/file12.js +5 -0
  115. package/test/fixtures/eval/node_modules/file13.js +5 -0
  116. package/test/fixtures/eval/node_modules/file14.js +11 -0
  117. package/test/fixtures/eval/node_modules/file2.js +5 -0
  118. package/test/fixtures/eval/node_modules/file3.js +5 -0
  119. package/test/fixtures/eval/node_modules/file4.js +5 -0
  120. package/test/fixtures/eval/node_modules/file5.js +5 -0
  121. package/test/fixtures/eval/node_modules/file6.js +5 -0
  122. package/test/fixtures/eval/node_modules/file7.js +5 -0
  123. package/test/fixtures/eval/node_modules/file8.js +5 -0
  124. package/test/fixtures/eval/node_modules/file9.js +5 -0
  125. package/test/fixtures/noop-transport.js +10 -0
  126. package/test/fixtures/pretty/null-prototype.js +8 -0
  127. package/test/fixtures/stdout-hack-protection.js +11 -0
  128. package/test/fixtures/syncfalse-child.js +6 -0
  129. package/test/fixtures/syncfalse-exit.js +9 -0
  130. package/test/fixtures/syncfalse-flush-exit.js +10 -0
  131. package/test/fixtures/syncfalse.js +6 -0
  132. package/test/fixtures/syntax-error-esm.mjs +2 -0
  133. package/test/fixtures/to-file-transport-with-transform.js +20 -0
  134. package/test/fixtures/to-file-transport.js +13 -0
  135. package/test/fixtures/to-file-transport.mjs +8 -0
  136. package/test/fixtures/transport/index.js +12 -0
  137. package/test/fixtures/transport/package.json +5 -0
  138. package/test/fixtures/transport-exit-immediately-with-async-dest.js +16 -0
  139. package/test/fixtures/transport-exit-immediately.js +11 -0
  140. package/test/fixtures/transport-exit-on-ready.js +12 -0
  141. package/test/fixtures/transport-main.js +9 -0
  142. package/test/fixtures/transport-many-lines.js +29 -0
  143. package/test/fixtures/transport-string-stdout.js +9 -0
  144. package/test/fixtures/transport-transform.js +21 -0
  145. package/test/fixtures/transport-uses-pino-config.js +33 -0
  146. package/test/fixtures/transport-with-on-exit.js +12 -0
  147. package/test/fixtures/transport-worker-data.js +19 -0
  148. package/test/fixtures/transport-worker.js +15 -0
  149. package/test/fixtures/transport-wrong-export-type.js +3 -0
  150. package/test/fixtures/ts/to-file-transport-with-transform.ts +18 -0
  151. package/test/fixtures/ts/to-file-transport.ts +11 -0
  152. package/test/fixtures/ts/transpile.cjs +36 -0
  153. package/test/fixtures/ts/transport-exit-immediately-with-async-dest.ts +15 -0
  154. package/test/fixtures/ts/transport-exit-immediately.ts +10 -0
  155. package/test/fixtures/ts/transport-exit-on-ready.ts +11 -0
  156. package/test/fixtures/ts/transport-main.ts +8 -0
  157. package/test/fixtures/ts/transport-string-stdout.ts +8 -0
  158. package/test/fixtures/ts/transport-worker.ts +14 -0
  159. package/test/formatters.test.js +355 -0
  160. package/test/helper.d.ts +4 -0
  161. package/test/helper.js +128 -0
  162. package/test/hooks.test.js +118 -0
  163. package/test/http.test.js +242 -0
  164. package/test/internals/version.test.js +15 -0
  165. package/test/is-level-enabled.test.js +185 -0
  166. package/test/jest/basic.spec.js +10 -0
  167. package/test/levels.test.js +772 -0
  168. package/test/metadata.test.js +106 -0
  169. package/test/mixin-merge-strategy.test.js +55 -0
  170. package/test/mixin.test.js +218 -0
  171. package/test/multistream.test.js +673 -0
  172. package/test/pkg/index.js +46 -0
  173. package/test/pkg/pkg.config.json +17 -0
  174. package/test/pkg/pkg.test.js +58 -0
  175. package/test/redact.test.js +847 -0
  176. package/test/serializers.test.js +253 -0
  177. package/test/stdout-protection.test.js +39 -0
  178. package/test/syncfalse.test.js +188 -0
  179. package/test/timestamp.test.js +121 -0
  180. package/test/transport/big.test.js +43 -0
  181. package/test/transport/bundlers-support.test.js +97 -0
  182. package/test/transport/caller.test.js +23 -0
  183. package/test/transport/core.test.js +643 -0
  184. package/test/transport/core.test.ts +236 -0
  185. package/test/transport/core.transpiled.test.ts +112 -0
  186. package/test/transport/crash.test.js +34 -0
  187. package/test/transport/module-link.test.js +239 -0
  188. package/test/transport/pipeline.test.js +135 -0
  189. package/test/transport/repl.test.js +14 -0
  190. package/test/transport/syncTrue.test.js +55 -0
  191. package/test/transport/syncfalse.test.js +68 -0
  192. package/test/transport/targets.test.js +44 -0
  193. package/test/transport/uses-pino-config.test.js +167 -0
  194. package/test/transport-stream.test.js +26 -0
  195. package/test/types/pino-import.test-d.ts +29 -0
  196. package/test/types/pino-multistream.test-d.ts +28 -0
  197. package/test/types/pino-top-export.test-d.ts +35 -0
  198. package/test/types/pino-transport.test-d.ts +145 -0
  199. package/test/types/pino-type-only.test-d.ts +64 -0
  200. package/test/types/pino.test-d.ts +527 -0
  201. package/test/types/pino.ts +78 -0
  202. package/tsconfig.json +14 -0
@@ -0,0 +1,145 @@
1
+ import { pino } from '../../pino'
2
+ import { expectType } from "tsd";
3
+
4
+ // Single
5
+ const transport = pino.transport({
6
+ target: '#pino/pretty',
7
+ options: { some: 'options for', the: 'transport' }
8
+ })
9
+ pino(transport)
10
+
11
+ expectType<pino.Logger>(pino({
12
+ transport: {
13
+ target: 'pino-pretty'
14
+ },
15
+ }))
16
+
17
+ // Multiple
18
+ const transports = pino.transport({targets: [
19
+ {
20
+ level: 'info',
21
+ target: '#pino/pretty',
22
+ options: { some: 'options for', the: 'transport' }
23
+ },
24
+ {
25
+ level: 'trace',
26
+ target: '#pino/file',
27
+ options: { destination: './test.log' }
28
+ }
29
+ ]})
30
+ pino(transports)
31
+
32
+ expectType<pino.Logger>(pino({
33
+ transport: {targets: [
34
+ {
35
+ level: 'info',
36
+ target: '#pino/pretty',
37
+ options: { some: 'options for', the: 'transport' }
38
+ },
39
+ {
40
+ level: 'trace',
41
+ target: '#pino/file',
42
+ options: { destination: './test.log' }
43
+ }
44
+ ]},
45
+ }))
46
+
47
+ const transportsWithCustomLevels = pino.transport({targets: [
48
+ {
49
+ level: 'info',
50
+ target: '#pino/pretty',
51
+ options: { some: 'options for', the: 'transport' }
52
+ },
53
+ {
54
+ level: 'foo',
55
+ target: '#pino/file',
56
+ options: { destination: './test.log' }
57
+ }
58
+ ], levels: { foo: 35 }})
59
+ pino(transports)
60
+
61
+ expectType<pino.Logger>(pino({
62
+ transport: {targets: [
63
+ {
64
+ level: 'info',
65
+ target: '#pino/pretty',
66
+ options: { some: 'options for', the: 'transport' }
67
+ },
68
+ {
69
+ level: 'trace',
70
+ target: '#pino/file',
71
+ options: { destination: './test.log' }
72
+ }
73
+ ], levels: { foo: 35 }
74
+ },
75
+ }))
76
+
77
+ const transportsWithoutOptions = pino.transport({
78
+ targets: [
79
+ { target: '#pino/pretty' },
80
+ { target: '#pino/file' }
81
+ ], levels: { foo: 35 }
82
+ })
83
+ pino(transports)
84
+
85
+ expectType<pino.Logger>(pino({
86
+ transport: {
87
+ targets: [
88
+ { target: '#pino/pretty' },
89
+ { target: '#pino/file' }
90
+ ], levels: { foo: 35 }
91
+ },
92
+ }))
93
+
94
+ const pipelineTransport = pino.transport({
95
+ pipeline: [{
96
+ target: './my-transform.js'
97
+ }, {
98
+ // Use target: 'pino/file' to write to stdout
99
+ // without any change.
100
+ target: 'pino-pretty'
101
+ }]
102
+ })
103
+ pino(pipelineTransport)
104
+
105
+ expectType<pino.Logger>(pino({
106
+ transport: {
107
+ pipeline: [{
108
+ target: './my-transform.js'
109
+ }, {
110
+ // Use target: 'pino/file' to write to stdout
111
+ // without any change.
112
+ target: 'pino-pretty'
113
+ }]
114
+ }
115
+ }))
116
+
117
+ type TransportConfig = {
118
+ id: string
119
+ }
120
+
121
+ // Custom transport params
122
+ const customTransport = pino.transport<TransportConfig>({
123
+ target: 'custom',
124
+ options: { id: 'abc' }
125
+ })
126
+ pino(customTransport)
127
+
128
+ // Worker
129
+ pino.transport({
130
+ target: 'custom',
131
+ worker: {
132
+ argv: ['a', 'b'],
133
+ stdin: false,
134
+ stderr: true,
135
+ stdout: false,
136
+ autoEnd: true,
137
+ },
138
+ options: { id: 'abc' }
139
+ })
140
+
141
+ // Dedupe
142
+ pino.transport({
143
+ targets: [],
144
+ dedupe: true,
145
+ })
@@ -0,0 +1,64 @@
1
+ import { expectAssignable, expectType, expectNotAssignable } from "tsd";
2
+
3
+ import pino from "../../";
4
+ import type {LevelWithSilent, Logger, LogFn, P, DestinationStreamWithMetadata, Level, LevelOrString, LevelWithSilentOrString, LoggerExtras, LoggerOptions } from "../../pino";
5
+
6
+ // NB: can also use `import * as pino`, but that form is callable as `pino()`
7
+ // under `esModuleInterop: false` or `pino.default()` under `esModuleInterop: true`.
8
+ const log = pino();
9
+ expectAssignable<LoggerExtras>(log);
10
+ expectType<Logger>(log);
11
+ expectType<LogFn>(log.info);
12
+
13
+ expectType<P.Logger>(log);
14
+ expectType<P.LogFn>(log.info);
15
+
16
+ expectType<Parameters<typeof log.isLevelEnabled>>([log.level]);
17
+
18
+ const level: Level = 'debug';
19
+ expectAssignable<string>(level);
20
+ expectAssignable<P.Level>(level);
21
+
22
+ const levelWithSilent: LevelWithSilent = 'silent';
23
+ expectAssignable<string>(levelWithSilent);
24
+ expectAssignable<P.LevelWithSilent>(levelWithSilent);
25
+
26
+ const levelOrString: LevelOrString = "myCustomLevel";
27
+ expectAssignable<string>(levelOrString);
28
+ expectNotAssignable<pino.Level>(levelOrString);
29
+ expectNotAssignable<pino.LevelWithSilent>(levelOrString);
30
+ expectAssignable<pino.LevelWithSilentOrString>(levelOrString);
31
+
32
+ const levelWithSilentOrString: LevelWithSilentOrString = "myCustomLevel";
33
+ expectAssignable<string>(levelWithSilentOrString);
34
+ expectNotAssignable<pino.Level>(levelWithSilentOrString);
35
+ expectNotAssignable<pino.LevelWithSilent>(levelWithSilentOrString);
36
+ expectAssignable<pino.LevelOrString>(levelWithSilentOrString);
37
+
38
+ function createStream(): DestinationStreamWithMetadata {
39
+ return { write() {} };
40
+ }
41
+
42
+ const stream = createStream();
43
+ // Argh. TypeScript doesn't seem to narrow unless we assign the symbol like so, and tsd seems to
44
+ // break without annotating the type explicitly
45
+ const needsMetadata: typeof pino.symbols.needsMetadataGsym = pino.symbols.needsMetadataGsym;
46
+ if (stream[needsMetadata]) {
47
+ expectType<number>(stream.lastLevel);
48
+ }
49
+
50
+ const loggerOptions:LoggerOptions = {
51
+ browser: {
52
+ formatters: {
53
+ log(obj) {
54
+ return obj
55
+ },
56
+ level(label, number) {
57
+ return { label, number}
58
+ }
59
+
60
+ }
61
+ }
62
+ }
63
+
64
+ expectType<LoggerOptions>(loggerOptions)