@contrast/agent 3.11.23 → 3.11.26

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 (263) hide show
  1. package/bin/VERSION +1 -1
  2. package/bin/linux/contrast-service +0 -0
  3. package/bin/mac/contrast-service +0 -0
  4. package/bin/windows/contrast-service.exe +0 -0
  5. package/changelog.config.js +56 -0
  6. package/lib.asar +0 -0
  7. package/node_modules/@colors/colors/LICENSE +26 -0
  8. package/node_modules/@colors/colors/README.md +219 -0
  9. package/node_modules/@colors/colors/examples/normal-usage.js +83 -0
  10. package/node_modules/@colors/colors/examples/safe-string.js +80 -0
  11. package/node_modules/@colors/colors/index.d.ts +136 -0
  12. package/node_modules/@colors/colors/lib/colors.js +211 -0
  13. package/node_modules/@colors/colors/lib/custom/trap.js +46 -0
  14. package/node_modules/@colors/colors/lib/custom/zalgo.js +110 -0
  15. package/node_modules/@colors/colors/lib/extendStringPrototype.js +110 -0
  16. package/node_modules/@colors/colors/lib/index.js +13 -0
  17. package/node_modules/@colors/colors/lib/maps/america.js +10 -0
  18. package/node_modules/@colors/colors/lib/maps/rainbow.js +12 -0
  19. package/node_modules/@colors/colors/lib/maps/random.js +11 -0
  20. package/node_modules/@colors/colors/lib/maps/zebra.js +5 -0
  21. package/node_modules/@colors/colors/lib/styles.js +95 -0
  22. package/node_modules/@colors/colors/lib/system/has-flag.js +35 -0
  23. package/node_modules/@colors/colors/lib/system/supports-colors.js +151 -0
  24. package/node_modules/@colors/colors/package.json +49 -0
  25. package/node_modules/@colors/colors/safe.d.ts +48 -0
  26. package/node_modules/@colors/colors/safe.js +10 -0
  27. package/node_modules/@colors/colors/themes/generic-logging.js +12 -0
  28. package/node_modules/@dabh/diagnostics/README.md +16 -16
  29. package/node_modules/@dabh/diagnostics/package.json +9 -9
  30. package/node_modules/async/CHANGELOG.md +13 -0
  31. package/node_modules/async/all.js +74 -9
  32. package/node_modules/async/allLimit.js +3 -3
  33. package/node_modules/async/allSeries.js +3 -3
  34. package/node_modules/async/any.js +75 -9
  35. package/node_modules/async/anyLimit.js +3 -3
  36. package/node_modules/async/anySeries.js +3 -3
  37. package/node_modules/async/applyEach.js +2 -2
  38. package/node_modules/async/applyEachSeries.js +2 -2
  39. package/node_modules/async/asyncify.js +3 -3
  40. package/node_modules/async/auto.js +81 -15
  41. package/node_modules/async/autoInject.js +30 -4
  42. package/node_modules/async/cargo.js +1 -1
  43. package/node_modules/async/cargoQueue.js +1 -1
  44. package/node_modules/async/compose.js +1 -1
  45. package/node_modules/async/concat.js +72 -4
  46. package/node_modules/async/concatLimit.js +3 -3
  47. package/node_modules/async/concatSeries.js +2 -2
  48. package/node_modules/async/detect.js +43 -8
  49. package/node_modules/async/detectLimit.js +3 -3
  50. package/node_modules/async/detectSeries.js +3 -3
  51. package/node_modules/async/dir.js +1 -1
  52. package/node_modules/async/dist/async.js +1379 -168
  53. package/node_modules/async/dist/async.min.js +1 -1
  54. package/node_modules/async/dist/async.mjs +1372 -161
  55. package/node_modules/async/doDuring.js +3 -3
  56. package/node_modules/async/doUntil.js +2 -2
  57. package/node_modules/async/doWhilst.js +3 -3
  58. package/node_modules/async/during.js +3 -3
  59. package/node_modules/async/each.js +69 -28
  60. package/node_modules/async/eachLimit.js +4 -4
  61. package/node_modules/async/eachOf.js +85 -16
  62. package/node_modules/async/eachOfLimit.js +3 -3
  63. package/node_modules/async/eachOfSeries.js +2 -2
  64. package/node_modules/async/eachSeries.js +2 -2
  65. package/node_modules/async/ensureAsync.js +2 -2
  66. package/node_modules/async/every.js +74 -9
  67. package/node_modules/async/everyLimit.js +3 -3
  68. package/node_modules/async/everySeries.js +3 -3
  69. package/node_modules/async/filter.js +49 -9
  70. package/node_modules/async/filterLimit.js +3 -3
  71. package/node_modules/async/filterSeries.js +3 -3
  72. package/node_modules/async/find.js +43 -8
  73. package/node_modules/async/findLimit.js +3 -3
  74. package/node_modules/async/findSeries.js +3 -3
  75. package/node_modules/async/flatMap.js +72 -4
  76. package/node_modules/async/flatMapLimit.js +3 -3
  77. package/node_modules/async/flatMapSeries.js +2 -2
  78. package/node_modules/async/foldl.js +87 -11
  79. package/node_modules/async/foldr.js +2 -2
  80. package/node_modules/async/forEach.js +69 -28
  81. package/node_modules/async/forEachLimit.js +4 -4
  82. package/node_modules/async/forEachOf.js +85 -16
  83. package/node_modules/async/forEachOfLimit.js +3 -3
  84. package/node_modules/async/forEachOfSeries.js +2 -2
  85. package/node_modules/async/forEachSeries.js +2 -2
  86. package/node_modules/async/forever.js +4 -4
  87. package/node_modules/async/groupBy.js +62 -8
  88. package/node_modules/async/groupByLimit.js +3 -3
  89. package/node_modules/async/groupBySeries.js +2 -2
  90. package/node_modules/async/inject.js +87 -11
  91. package/node_modules/async/internal/applyEach.js +2 -2
  92. package/node_modules/async/internal/asyncEachOfLimit.js +1 -1
  93. package/node_modules/async/internal/consoleFunc.js +5 -1
  94. package/node_modules/async/internal/createTester.js +2 -2
  95. package/node_modules/async/internal/eachOfLimit.js +6 -6
  96. package/node_modules/async/internal/filter.js +2 -2
  97. package/node_modules/async/internal/iterator.js +5 -2
  98. package/node_modules/async/internal/map.js +1 -1
  99. package/node_modules/async/internal/parallel.js +3 -3
  100. package/node_modules/async/internal/queue.js +4 -4
  101. package/node_modules/async/internal/reject.js +2 -2
  102. package/node_modules/async/internal/setImmediate.js +6 -2
  103. package/node_modules/async/internal/wrapAsync.js +1 -1
  104. package/node_modules/async/log.js +1 -1
  105. package/node_modules/async/map.js +86 -6
  106. package/node_modules/async/mapLimit.js +3 -3
  107. package/node_modules/async/mapSeries.js +3 -3
  108. package/node_modules/async/mapValues.js +102 -12
  109. package/node_modules/async/mapValuesLimit.js +4 -4
  110. package/node_modules/async/mapValuesSeries.js +1 -1
  111. package/node_modules/async/memoize.js +3 -3
  112. package/node_modules/async/nextTick.js +3 -3
  113. package/node_modules/async/package.json +4 -6
  114. package/node_modules/async/parallel.js +96 -7
  115. package/node_modules/async/parallelLimit.js +2 -2
  116. package/node_modules/async/priorityQueue.js +11 -4
  117. package/node_modules/async/queue.js +4 -4
  118. package/node_modules/async/race.js +3 -3
  119. package/node_modules/async/reduce.js +87 -11
  120. package/node_modules/async/reduceRight.js +2 -2
  121. package/node_modules/async/reflect.js +2 -2
  122. package/node_modules/async/reflectAll.js +1 -1
  123. package/node_modules/async/reject.js +44 -10
  124. package/node_modules/async/rejectLimit.js +3 -3
  125. package/node_modules/async/rejectSeries.js +3 -3
  126. package/node_modules/async/retry.js +2 -2
  127. package/node_modules/async/retryable.js +4 -4
  128. package/node_modules/async/select.js +49 -9
  129. package/node_modules/async/selectLimit.js +3 -3
  130. package/node_modules/async/selectSeries.js +3 -3
  131. package/node_modules/async/seq.js +4 -4
  132. package/node_modules/async/series.js +112 -12
  133. package/node_modules/async/setImmediate.js +1 -1
  134. package/node_modules/async/some.js +75 -9
  135. package/node_modules/async/someLimit.js +3 -3
  136. package/node_modules/async/someSeries.js +3 -3
  137. package/node_modules/async/sortBy.js +121 -19
  138. package/node_modules/async/timeout.js +2 -2
  139. package/node_modules/async/times.js +1 -1
  140. package/node_modules/async/timesLimit.js +3 -3
  141. package/node_modules/async/timesSeries.js +1 -1
  142. package/node_modules/async/transform.js +111 -19
  143. package/node_modules/async/tryEach.js +3 -3
  144. package/node_modules/async/until.js +3 -3
  145. package/node_modules/async/waterfall.js +4 -4
  146. package/node_modules/async/whilst.js +3 -3
  147. package/node_modules/async/wrapSync.js +3 -3
  148. package/node_modules/color/README.md +9 -0
  149. package/node_modules/color/index.js +4 -1
  150. package/node_modules/color/package.json +8 -8
  151. package/node_modules/color-string/README.md +6 -2
  152. package/node_modules/color-string/index.js +21 -13
  153. package/node_modules/color-string/package.json +4 -4
  154. package/node_modules/colorspace/package.json +5 -5
  155. package/node_modules/fecha/dist/fecha.min.js +1 -1
  156. package/node_modules/fecha/dist/fecha.min.js.map +1 -0
  157. package/node_modules/fecha/lib/fecha.d.ts +2 -2
  158. package/node_modules/fecha/lib/fecha.js +35 -18
  159. package/node_modules/fecha/lib/fecha.js.map +1 -0
  160. package/node_modules/fecha/lib/fecha.umd.js +35 -18
  161. package/node_modules/fecha/lib/fecha.umd.js.map +1 -0
  162. package/node_modules/fecha/package.json +9 -10
  163. package/node_modules/fecha/src/fecha.ts +524 -0
  164. package/node_modules/logform/.eslintrc +1 -1
  165. package/node_modules/logform/CHANGELOG.md +24 -0
  166. package/node_modules/logform/README.md +15 -17
  167. package/node_modules/logform/browser.js +3 -1
  168. package/node_modules/logform/cli.js +1 -1
  169. package/node_modules/logform/colorize.js +2 -2
  170. package/node_modules/logform/dist/browser.js +8 -2
  171. package/node_modules/logform/dist/cli.js +2 -2
  172. package/node_modules/logform/dist/colorize.js +5 -5
  173. package/node_modules/logform/dist/errors.js +1 -1
  174. package/node_modules/logform/dist/format.js +9 -5
  175. package/node_modules/logform/dist/index.js +53 -20
  176. package/node_modules/logform/dist/json.js +7 -6
  177. package/node_modules/logform/dist/logstash.js +1 -1
  178. package/node_modules/logform/dist/pad-levels.js +4 -4
  179. package/node_modules/logform/dist/printf.js +1 -1
  180. package/node_modules/logform/dist/simple.js +1 -1
  181. package/node_modules/logform/dist/splat.js +2 -2
  182. package/node_modules/logform/dist/uncolorize.js +1 -1
  183. package/node_modules/logform/errors.js +1 -1
  184. package/node_modules/logform/index.d.ts +36 -0
  185. package/node_modules/logform/index.js +19 -20
  186. package/node_modules/logform/json.js +7 -7
  187. package/node_modules/logform/logstash.js +1 -1
  188. package/node_modules/logform/package.json +10 -9
  189. package/node_modules/logform/simple.js +1 -1
  190. package/node_modules/logform/uncolorize.js +1 -1
  191. package/node_modules/safe-stable-stringify/CHANGELOG.md +75 -0
  192. package/node_modules/safe-stable-stringify/LICENSE +21 -0
  193. package/node_modules/safe-stable-stringify/esm/package.json +4 -0
  194. package/node_modules/safe-stable-stringify/esm/wrapper.js +6 -0
  195. package/node_modules/safe-stable-stringify/index.d.ts +18 -0
  196. package/node_modules/safe-stable-stringify/index.js +618 -0
  197. package/node_modules/safe-stable-stringify/package.json +69 -0
  198. package/node_modules/safe-stable-stringify/readme.md +170 -0
  199. package/node_modules/safe-stable-stringify/tsconfig.json +22 -0
  200. package/node_modules/unix-dgram/build/Makefile +2 -2
  201. package/node_modules/unix-dgram/build/Release/.deps/Release/obj.target/unix_dgram/src/unix_dgram.o.d +35 -35
  202. package/node_modules/unix-dgram/build/config.gypi +8 -8
  203. package/node_modules/unix-dgram/build/unix_dgram.target.mk +14 -14
  204. package/node_modules/winston/LICENSE +18 -18
  205. package/node_modules/winston/README.md +1231 -1230
  206. package/node_modules/winston/dist/winston/common.js +10 -10
  207. package/node_modules/winston/dist/winston/config/index.js +17 -17
  208. package/node_modules/winston/dist/winston/container.js +46 -46
  209. package/node_modules/winston/dist/winston/create-logger.js +28 -24
  210. package/node_modules/winston/dist/winston/exception-handler.js +49 -49
  211. package/node_modules/winston/dist/winston/exception-stream.js +27 -27
  212. package/node_modules/winston/dist/winston/logger.js +152 -138
  213. package/node_modules/winston/dist/winston/profiler.js +22 -22
  214. package/node_modules/winston/dist/winston/rejection-handler.js +54 -54
  215. package/node_modules/winston/dist/winston/tail-file.js +14 -14
  216. package/node_modules/winston/dist/winston/transports/console.js +31 -31
  217. package/node_modules/winston/dist/winston/transports/file.js +101 -101
  218. package/node_modules/winston/dist/winston/transports/http.js +119 -41
  219. package/node_modules/winston/dist/winston/transports/index.js +17 -17
  220. package/node_modules/winston/dist/winston/transports/stream.js +24 -24
  221. package/node_modules/winston/dist/winston.js +91 -97
  222. package/node_modules/winston/index.d.ts +213 -193
  223. package/node_modules/winston/lib/winston/common.js +61 -61
  224. package/node_modules/winston/lib/winston/config/index.d.ts +99 -98
  225. package/node_modules/winston/lib/winston/config/index.js +35 -35
  226. package/node_modules/winston/lib/winston/container.js +114 -114
  227. package/node_modules/winston/lib/winston/create-logger.js +104 -104
  228. package/node_modules/winston/lib/winston/exception-handler.js +245 -245
  229. package/node_modules/winston/lib/winston/exception-stream.js +54 -54
  230. package/node_modules/winston/lib/winston/logger.js +676 -667
  231. package/node_modules/winston/lib/winston/profiler.js +51 -51
  232. package/node_modules/winston/lib/winston/rejection-handler.js +251 -251
  233. package/node_modules/winston/lib/winston/tail-file.js +124 -124
  234. package/node_modules/winston/lib/winston/transports/console.js +117 -117
  235. package/node_modules/winston/lib/winston/transports/file.js +695 -695
  236. package/node_modules/winston/lib/winston/transports/http.js +267 -202
  237. package/node_modules/winston/lib/winston/transports/index.d.ts +103 -100
  238. package/node_modules/winston/lib/winston/transports/index.js +56 -56
  239. package/node_modules/winston/lib/winston/transports/stream.js +63 -63
  240. package/node_modules/winston/lib/winston.js +176 -182
  241. package/node_modules/winston/node_modules/winston-transport/.babelrc +3 -0
  242. package/node_modules/winston/node_modules/winston-transport/.eslintrc +7 -0
  243. package/node_modules/winston/node_modules/winston-transport/.gitattributes +1 -0
  244. package/node_modules/winston/node_modules/winston-transport/.nyc_output/c3d7ddb9-cc26-466b-a4f6-993ad69e86f6.json +1 -0
  245. package/node_modules/winston/node_modules/winston-transport/.nyc_output/processinfo/c3d7ddb9-cc26-466b-a4f6-993ad69e86f6.json +1 -0
  246. package/node_modules/winston/node_modules/winston-transport/.nyc_output/processinfo/index.json +1 -0
  247. package/node_modules/winston/node_modules/winston-transport/CHANGELOG.md +126 -0
  248. package/node_modules/winston/node_modules/winston-transport/LICENSE +22 -0
  249. package/node_modules/winston/node_modules/winston-transport/README.md +50 -0
  250. package/node_modules/winston/node_modules/winston-transport/dist/index.js +215 -0
  251. package/node_modules/winston/node_modules/winston-transport/dist/legacy.js +116 -0
  252. package/node_modules/winston/node_modules/winston-transport/index.d.ts +39 -0
  253. package/node_modules/winston/node_modules/winston-transport/index.js +215 -0
  254. package/node_modules/winston/node_modules/winston-transport/legacy.js +119 -0
  255. package/node_modules/winston/node_modules/winston-transport/package.json +56 -0
  256. package/node_modules/winston/package.json +76 -75
  257. package/package.json +4 -3
  258. package/node_modules/@dabh/diagnostics/example.png +0 -0
  259. package/node_modules/color-string/CHANGELOG.md +0 -18
  260. package/node_modules/colorspace/test.js +0 -14
  261. package/node_modules/fecha/CHANGELOG.md +0 -67
  262. package/node_modules/logform/.travis.yml +0 -17
  263. package/node_modules/winston/CHANGELOG.md +0 -560
@@ -1,124 +1,124 @@
1
- /**
2
- * tail-file.js: TODO: add file header description.
3
- *
4
- * (C) 2010 Charlie Robbins
5
- * MIT LICENCE
6
- */
7
-
8
- 'use strict';
9
-
10
- const fs = require('fs');
11
- const { StringDecoder } = require('string_decoder');
12
- const { Stream } = require('readable-stream');
13
-
14
- /**
15
- * Simple no-op function.
16
- * @returns {undefined}
17
- */
18
- function noop() {}
19
-
20
- /**
21
- * TODO: add function description.
22
- * @param {Object} options - Options for tail.
23
- * @param {function} iter - Iterator function to execute on every line.
24
- * `tail -f` a file. Options must include file.
25
- * @returns {mixed} - TODO: add return description.
26
- */
27
- module.exports = (options, iter) => {
28
- const buffer = Buffer.alloc(64 * 1024);
29
- const decode = new StringDecoder('utf8');
30
- const stream = new Stream();
31
- let buff = '';
32
- let pos = 0;
33
- let row = 0;
34
-
35
- if (options.start === -1) {
36
- delete options.start;
37
- }
38
-
39
- stream.readable = true;
40
- stream.destroy = () => {
41
- stream.destroyed = true;
42
- stream.emit('end');
43
- stream.emit('close');
44
- };
45
-
46
- fs.open(options.file, 'a+', '0644', (err, fd) => {
47
- if (err) {
48
- if (!iter) {
49
- stream.emit('error', err);
50
- } else {
51
- iter(err);
52
- }
53
- stream.destroy();
54
- return;
55
- }
56
-
57
- (function read() {
58
- if (stream.destroyed) {
59
- fs.close(fd, noop);
60
- return;
61
- }
62
-
63
- return fs.read(fd, buffer, 0, buffer.length, pos, (error, bytes) => {
64
- if (error) {
65
- if (!iter) {
66
- stream.emit('error', error);
67
- } else {
68
- iter(error);
69
- }
70
- stream.destroy();
71
- return;
72
- }
73
-
74
- if (!bytes) {
75
- if (buff) {
76
- // eslint-disable-next-line eqeqeq
77
- if (options.start == null || row > options.start) {
78
- if (!iter) {
79
- stream.emit('line', buff);
80
- } else {
81
- iter(null, buff);
82
- }
83
- }
84
- row++;
85
- buff = '';
86
- }
87
- return setTimeout(read, 1000);
88
- }
89
-
90
- let data = decode.write(buffer.slice(0, bytes));
91
- if (!iter) {
92
- stream.emit('data', data);
93
- }
94
-
95
- data = (buff + data).split(/\n+/);
96
-
97
- const l = data.length - 1;
98
- let i = 0;
99
-
100
- for (; i < l; i++) {
101
- // eslint-disable-next-line eqeqeq
102
- if (options.start == null || row > options.start) {
103
- if (!iter) {
104
- stream.emit('line', data[i]);
105
- } else {
106
- iter(null, data[i]);
107
- }
108
- }
109
- row++;
110
- }
111
-
112
- buff = data[l];
113
- pos += bytes;
114
- return read();
115
- });
116
- }());
117
- });
118
-
119
- if (!iter) {
120
- return stream;
121
- }
122
-
123
- return stream.destroy;
124
- };
1
+ /**
2
+ * tail-file.js: TODO: add file header description.
3
+ *
4
+ * (C) 2010 Charlie Robbins
5
+ * MIT LICENCE
6
+ */
7
+
8
+ 'use strict';
9
+
10
+ const fs = require('fs');
11
+ const { StringDecoder } = require('string_decoder');
12
+ const { Stream } = require('readable-stream');
13
+
14
+ /**
15
+ * Simple no-op function.
16
+ * @returns {undefined}
17
+ */
18
+ function noop() {}
19
+
20
+ /**
21
+ * TODO: add function description.
22
+ * @param {Object} options - Options for tail.
23
+ * @param {function} iter - Iterator function to execute on every line.
24
+ * `tail -f` a file. Options must include file.
25
+ * @returns {mixed} - TODO: add return description.
26
+ */
27
+ module.exports = (options, iter) => {
28
+ const buffer = Buffer.alloc(64 * 1024);
29
+ const decode = new StringDecoder('utf8');
30
+ const stream = new Stream();
31
+ let buff = '';
32
+ let pos = 0;
33
+ let row = 0;
34
+
35
+ if (options.start === -1) {
36
+ delete options.start;
37
+ }
38
+
39
+ stream.readable = true;
40
+ stream.destroy = () => {
41
+ stream.destroyed = true;
42
+ stream.emit('end');
43
+ stream.emit('close');
44
+ };
45
+
46
+ fs.open(options.file, 'a+', '0644', (err, fd) => {
47
+ if (err) {
48
+ if (!iter) {
49
+ stream.emit('error', err);
50
+ } else {
51
+ iter(err);
52
+ }
53
+ stream.destroy();
54
+ return;
55
+ }
56
+
57
+ (function read() {
58
+ if (stream.destroyed) {
59
+ fs.close(fd, noop);
60
+ return;
61
+ }
62
+
63
+ return fs.read(fd, buffer, 0, buffer.length, pos, (error, bytes) => {
64
+ if (error) {
65
+ if (!iter) {
66
+ stream.emit('error', error);
67
+ } else {
68
+ iter(error);
69
+ }
70
+ stream.destroy();
71
+ return;
72
+ }
73
+
74
+ if (!bytes) {
75
+ if (buff) {
76
+ // eslint-disable-next-line eqeqeq
77
+ if (options.start == null || row > options.start) {
78
+ if (!iter) {
79
+ stream.emit('line', buff);
80
+ } else {
81
+ iter(null, buff);
82
+ }
83
+ }
84
+ row++;
85
+ buff = '';
86
+ }
87
+ return setTimeout(read, 1000);
88
+ }
89
+
90
+ let data = decode.write(buffer.slice(0, bytes));
91
+ if (!iter) {
92
+ stream.emit('data', data);
93
+ }
94
+
95
+ data = (buff + data).split(/\n+/);
96
+
97
+ const l = data.length - 1;
98
+ let i = 0;
99
+
100
+ for (; i < l; i++) {
101
+ // eslint-disable-next-line eqeqeq
102
+ if (options.start == null || row > options.start) {
103
+ if (!iter) {
104
+ stream.emit('line', data[i]);
105
+ } else {
106
+ iter(null, data[i]);
107
+ }
108
+ }
109
+ row++;
110
+ }
111
+
112
+ buff = data[l];
113
+ pos += bytes;
114
+ return read();
115
+ });
116
+ }());
117
+ });
118
+
119
+ if (!iter) {
120
+ return stream;
121
+ }
122
+
123
+ return stream.destroy;
124
+ };
@@ -1,117 +1,117 @@
1
- /* eslint-disable no-console */
2
- /*
3
- * console.js: Transport for outputting to the console.
4
- *
5
- * (C) 2010 Charlie Robbins
6
- * MIT LICENCE
7
- */
8
-
9
- 'use strict';
10
-
11
- const os = require('os');
12
- const { LEVEL, MESSAGE } = require('triple-beam');
13
- const TransportStream = require('winston-transport');
14
-
15
- /**
16
- * Transport for outputting to the console.
17
- * @type {Console}
18
- * @extends {TransportStream}
19
- */
20
- module.exports = class Console extends TransportStream {
21
- /**
22
- * Constructor function for the Console transport object responsible for
23
- * persisting log messages and metadata to a terminal or TTY.
24
- * @param {!Object} [options={}] - Options for this instance.
25
- */
26
- constructor(options = {}) {
27
- super(options);
28
-
29
- // Expose the name of this Transport on the prototype
30
- this.name = options.name || 'console';
31
- this.stderrLevels = this._stringArrayToSet(options.stderrLevels);
32
- this.consoleWarnLevels = this._stringArrayToSet(options.consoleWarnLevels);
33
- this.eol = options.eol || os.EOL;
34
-
35
- this.setMaxListeners(30);
36
- }
37
-
38
- /**
39
- * Core logging method exposed to Winston.
40
- * @param {Object} info - TODO: add param description.
41
- * @param {Function} callback - TODO: add param description.
42
- * @returns {undefined}
43
- */
44
- log(info, callback) {
45
- setImmediate(() => this.emit('logged', info));
46
-
47
- // Remark: what if there is no raw...?
48
- if (this.stderrLevels[info[LEVEL]]) {
49
- if (console._stderr) {
50
- // Node.js maps `process.stderr` to `console._stderr`.
51
- console._stderr.write(`${info[MESSAGE]}${this.eol}`);
52
- } else {
53
- // console.error adds a newline
54
- console.error(info[MESSAGE]);
55
- }
56
-
57
- if (callback) {
58
- callback(); // eslint-disable-line callback-return
59
- }
60
- return;
61
- } else if (this.consoleWarnLevels[info[LEVEL]]) {
62
- if (console._stderr) {
63
- // Node.js maps `process.stderr` to `console._stderr`.
64
- // in Node.js console.warn is an alias for console.error
65
- console._stderr.write(`${info[MESSAGE]}${this.eol}`);
66
- } else {
67
- // console.warn adds a newline
68
- console.warn(info[MESSAGE]);
69
- }
70
-
71
- if (callback) {
72
- callback(); // eslint-disable-line callback-return
73
- }
74
- return;
75
- }
76
-
77
- if (console._stdout) {
78
- // Node.js maps `process.stdout` to `console._stdout`.
79
- console._stdout.write(`${info[MESSAGE]}${this.eol}`);
80
- } else {
81
- // console.log adds a newline.
82
- console.log(info[MESSAGE]);
83
- }
84
-
85
- if (callback) {
86
- callback(); // eslint-disable-line callback-return
87
- }
88
- }
89
-
90
- /**
91
- * Returns a Set-like object with strArray's elements as keys (each with the
92
- * value true).
93
- * @param {Array} strArray - Array of Set-elements as strings.
94
- * @param {?string} [errMsg] - Custom error message thrown on invalid input.
95
- * @returns {Object} - TODO: add return description.
96
- * @private
97
- */
98
- _stringArrayToSet(strArray, errMsg) {
99
- if (!strArray)
100
- return {};
101
-
102
- errMsg = errMsg || 'Cannot make set from type other than Array of string elements';
103
-
104
- if (!Array.isArray(strArray)) {
105
- throw new Error(errMsg);
106
- }
107
-
108
- return strArray.reduce((set, el) => {
109
- if (typeof el !== 'string') {
110
- throw new Error(errMsg);
111
- }
112
- set[el] = true;
113
-
114
- return set;
115
- }, {});
116
- }
117
- };
1
+ /* eslint-disable no-console */
2
+ /*
3
+ * console.js: Transport for outputting to the console.
4
+ *
5
+ * (C) 2010 Charlie Robbins
6
+ * MIT LICENCE
7
+ */
8
+
9
+ 'use strict';
10
+
11
+ const os = require('os');
12
+ const { LEVEL, MESSAGE } = require('triple-beam');
13
+ const TransportStream = require('winston-transport');
14
+
15
+ /**
16
+ * Transport for outputting to the console.
17
+ * @type {Console}
18
+ * @extends {TransportStream}
19
+ */
20
+ module.exports = class Console extends TransportStream {
21
+ /**
22
+ * Constructor function for the Console transport object responsible for
23
+ * persisting log messages and metadata to a terminal or TTY.
24
+ * @param {!Object} [options={}] - Options for this instance.
25
+ */
26
+ constructor(options = {}) {
27
+ super(options);
28
+
29
+ // Expose the name of this Transport on the prototype
30
+ this.name = options.name || 'console';
31
+ this.stderrLevels = this._stringArrayToSet(options.stderrLevels);
32
+ this.consoleWarnLevels = this._stringArrayToSet(options.consoleWarnLevels);
33
+ this.eol = (typeof options.eol === 'string') ? options.eol : os.EOL;
34
+
35
+ this.setMaxListeners(30);
36
+ }
37
+
38
+ /**
39
+ * Core logging method exposed to Winston.
40
+ * @param {Object} info - TODO: add param description.
41
+ * @param {Function} callback - TODO: add param description.
42
+ * @returns {undefined}
43
+ */
44
+ log(info, callback) {
45
+ setImmediate(() => this.emit('logged', info));
46
+
47
+ // Remark: what if there is no raw...?
48
+ if (this.stderrLevels[info[LEVEL]]) {
49
+ if (console._stderr) {
50
+ // Node.js maps `process.stderr` to `console._stderr`.
51
+ console._stderr.write(`${info[MESSAGE]}${this.eol}`);
52
+ } else {
53
+ // console.error adds a newline
54
+ console.error(info[MESSAGE]);
55
+ }
56
+
57
+ if (callback) {
58
+ callback(); // eslint-disable-line callback-return
59
+ }
60
+ return;
61
+ } else if (this.consoleWarnLevels[info[LEVEL]]) {
62
+ if (console._stderr) {
63
+ // Node.js maps `process.stderr` to `console._stderr`.
64
+ // in Node.js console.warn is an alias for console.error
65
+ console._stderr.write(`${info[MESSAGE]}${this.eol}`);
66
+ } else {
67
+ // console.warn adds a newline
68
+ console.warn(info[MESSAGE]);
69
+ }
70
+
71
+ if (callback) {
72
+ callback(); // eslint-disable-line callback-return
73
+ }
74
+ return;
75
+ }
76
+
77
+ if (console._stdout) {
78
+ // Node.js maps `process.stdout` to `console._stdout`.
79
+ console._stdout.write(`${info[MESSAGE]}${this.eol}`);
80
+ } else {
81
+ // console.log adds a newline.
82
+ console.log(info[MESSAGE]);
83
+ }
84
+
85
+ if (callback) {
86
+ callback(); // eslint-disable-line callback-return
87
+ }
88
+ }
89
+
90
+ /**
91
+ * Returns a Set-like object with strArray's elements as keys (each with the
92
+ * value true).
93
+ * @param {Array} strArray - Array of Set-elements as strings.
94
+ * @param {?string} [errMsg] - Custom error message thrown on invalid input.
95
+ * @returns {Object} - TODO: add return description.
96
+ * @private
97
+ */
98
+ _stringArrayToSet(strArray, errMsg) {
99
+ if (!strArray)
100
+ return {};
101
+
102
+ errMsg = errMsg || 'Cannot make set from type other than Array of string elements';
103
+
104
+ if (!Array.isArray(strArray)) {
105
+ throw new Error(errMsg);
106
+ }
107
+
108
+ return strArray.reduce((set, el) => {
109
+ if (typeof el !== 'string') {
110
+ throw new Error(errMsg);
111
+ }
112
+ set[el] = true;
113
+
114
+ return set;
115
+ }, {});
116
+ }
117
+ };