@levrbet/shared 0.2.11 → 0.2.13

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.
@@ -31,7 +31,7 @@ const dotenv_1 = require("./dotenv");
31
31
  logger.info("Using default logger")
32
32
  *
33
33
  */
34
- const { combine, timestamp, errors, json, colorize, printf, splat } = winston_1.default.format;
34
+ const { combine, timestamp, errors, json, printf, splat } = winston_1.default.format;
35
35
  // Determine log level based on environment
36
36
  const getLogLevel = () => {
37
37
  switch (dotenv_1.LEVR_ENV) {
@@ -47,13 +47,28 @@ const getLogLevel = () => {
47
47
  return "info";
48
48
  }
49
49
  };
50
+ // Color mapping for manual colorization
51
+ const colors = {
52
+ error: "\x1b[31m", // red
53
+ warn: "\x1b[33m", // yellow
54
+ info: "\x1b[36m", // cyan
55
+ http: "\x1b[35m", // magenta
56
+ verbose: "\x1b[90m", // gray
57
+ debug: "\x1b[34m", // blue
58
+ silly: "\x1b[90m", // gray
59
+ };
60
+ const reset = "\x1b[0m";
50
61
  // Custom format for console output in non-production
51
62
  const consoleFormat = printf(({ level, message, timestamp, stack, service, ...metadata }) => {
52
- let msg = `${timestamp} [${level}]`;
63
+ const color = colors[level] || "";
64
+ const coloredLevel = dotenv_1.LEVR_ENV === "prod" ? level : `${color}${level}${reset}`;
65
+ let msg = `${timestamp} [${coloredLevel}]`;
53
66
  if (service) {
54
67
  msg += ` [${service}]`;
55
68
  }
56
- msg += `: ${message}`;
69
+ // Ensure message is properly stringified
70
+ const formattedMessage = typeof message === "object" ? JSON.stringify(message) : String(message);
71
+ msg += `: ${formattedMessage}`;
57
72
  // Add stack trace if error
58
73
  if (stack) {
59
74
  msg += `\n${stack}`;
@@ -69,11 +84,12 @@ const consoleFormat = printf(({ level, message, timestamp, stack, service, ...me
69
84
  // Production format (structured JSON for OTEL)
70
85
  const productionFormat = combine(timestamp({ format: "YYYY-MM-DD HH:mm:ss" }), errors({ stack: true }), splat(), json());
71
86
  // Development format (human-readable)
72
- const developmentFormat = combine(timestamp({ format: "YYYY-MM-DD HH:mm:ss" }), errors({ stack: true }), splat(), colorize(), consoleFormat);
87
+ const developmentFormat = combine(timestamp({ format: "YYYY-MM-DD HH:mm:ss" }), errors({ stack: true }), splat(), consoleFormat);
73
88
  const createLogger = (options = {}) => {
74
89
  const { service = "@levrbet/shared", level = getLogLevel(), additionalMeta = {} } = options;
75
90
  const logger = winston_1.default.createLogger({
76
91
  level,
92
+ levels: winston_1.default.config.npm.levels,
77
93
  format: dotenv_1.LEVR_ENV === "prod" ? productionFormat : developmentFormat,
78
94
  defaultMeta: {
79
95
  service,
@@ -95,7 +111,11 @@ const logger = (0, exports.createLogger)();
95
111
  // Create stream for Morgan (HTTP logging)
96
112
  const createStream = (loggerInstance = logger) => ({
97
113
  write: (message) => {
98
- loggerInstance.info(message.trim());
114
+ // Trim and ensure message is a string, not an array or object
115
+ const msg = typeof message === "string" ? message.trim() : String(message);
116
+ if (msg.length > 0) {
117
+ loggerInstance.info(msg);
118
+ }
99
119
  },
100
120
  });
101
121
  exports.createStream = createStream;
@@ -1 +1 @@
1
- {"version":3,"file":"winston.js","sourceRoot":"","sources":["../../../src/server/config/winston.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"winston.js","sourceRoot":"","sources":["../../../src/server/config/winston.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@levrbet/shared",
3
- "version": "0.2.11",
3
+ "version": "0.2.13",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "exports": {