@groundbrick/logger 0.3.4 → 0.4.1

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.
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Request context for propagating metadata (requestId, etc.) across async boundaries.
3
+ *
4
+ * The consumer (e.g., backend) must call setContextStorage() with an AsyncLocalStorage
5
+ * instance before any requests are processed. The logger package itself has zero
6
+ * Node.js-specific imports, so it works in any environment.
7
+ */
8
+ interface ContextStorage {
9
+ run(context: Record<string, any>, fn: () => void): void;
10
+ getStore(): Record<string, any> | undefined;
11
+ }
12
+ /**
13
+ * Inject the async context storage (call once at app startup).
14
+ * In Node.js: pass `new AsyncLocalStorage()` from `node:async_hooks`.
15
+ */
16
+ export declare function setContextStorage(s: ContextStorage): void;
17
+ /**
18
+ * Run a function within a request context.
19
+ * All loggers called within fn will automatically include the context metadata.
20
+ */
21
+ export declare function runWithContext(context: Record<string, any>, fn: () => void): void;
22
+ /**
23
+ * Get the current request context (if any).
24
+ */
25
+ export declare function getContext(): Record<string, any> | undefined;
26
+ export {};
27
+ //# sourceMappingURL=async-context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"async-context.d.ts","sourceRoot":"","sources":["../src/async-context.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,UAAU,cAAc;IACpB,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,MAAM,IAAI,GAAG,IAAI,CAAC;IACxD,QAAQ,IAAI,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC;CAC/C;AAID;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,cAAc,GAAG,IAAI,CAEzD;AAED;;;GAGG;AACH,wBAAgB,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,MAAM,IAAI,GAAG,IAAI,CAMjF;AAED;;GAEG;AACH,wBAAgB,UAAU,IAAI,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,CAE5D"}
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Request context for propagating metadata (requestId, etc.) across async boundaries.
3
+ *
4
+ * The consumer (e.g., backend) must call setContextStorage() with an AsyncLocalStorage
5
+ * instance before any requests are processed. The logger package itself has zero
6
+ * Node.js-specific imports, so it works in any environment.
7
+ */
8
+ let storage = null;
9
+ /**
10
+ * Inject the async context storage (call once at app startup).
11
+ * In Node.js: pass `new AsyncLocalStorage()` from `node:async_hooks`.
12
+ */
13
+ export function setContextStorage(s) {
14
+ storage = s;
15
+ }
16
+ /**
17
+ * Run a function within a request context.
18
+ * All loggers called within fn will automatically include the context metadata.
19
+ */
20
+ export function runWithContext(context, fn) {
21
+ if (storage) {
22
+ storage.run(context, fn);
23
+ }
24
+ else {
25
+ fn();
26
+ }
27
+ }
28
+ /**
29
+ * Get the current request context (if any).
30
+ */
31
+ export function getContext() {
32
+ return storage?.getStore();
33
+ }
34
+ //# sourceMappingURL=async-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"async-context.js","sourceRoot":"","sources":["../src/async-context.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAOH,IAAI,OAAO,GAA0B,IAAI,CAAC;AAE1C;;;GAGG;AACH,MAAM,UAAU,iBAAiB,CAAC,CAAiB;IAC/C,OAAO,GAAG,CAAC,CAAC;AAChB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,cAAc,CAAC,OAA4B,EAAE,EAAc;IACvE,IAAI,OAAO,EAAE,CAAC;QACV,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAC7B,CAAC;SAAM,CAAC;QACJ,EAAE,EAAE,CAAC;IACT,CAAC;AACL,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,UAAU;IACtB,OAAO,OAAO,EAAE,QAAQ,EAAE,CAAC;AAC/B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"formatter.d.ts","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAY,MAAM,YAAY,CAAC;AAEhD,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAQrB;IAEF,UAAU,CAAC,KAAK,EAAE,QAAQ,GAAG,MAAM;IAInC,YAAY,CAAC,KAAK,EAAE,QAAQ,GAAG,MAAM;IA6BrC,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,WAAW;CAKpB;AAED,eAAO,MAAM,gBAAgB,cAAqB,CAAC"}
1
+ {"version":3,"file":"formatter.d.ts","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAY,MAAM,YAAY,CAAC;AAEhD,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAQrB;IAEF,UAAU,CAAC,KAAK,EAAE,QAAQ,GAAG,MAAM;IAInC,YAAY,CAAC,KAAK,EAAE,QAAQ,GAAG,MAAM;IAoCrC,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,WAAW;CAKpB;AAED,eAAO,MAAM,gBAAgB,cAAqB,CAAC"}
package/dist/formatter.js CHANGED
@@ -15,10 +15,17 @@ export class LogFormatter {
15
15
  const timestamp = this.formatTimestamp(entry.timestamp);
16
16
  const level = this.formatLevel(entry.level);
17
17
  const context = entry.context ? `[${entry.context}]` : '';
18
+ const reqId = entry.metadata?.requestId
19
+ ? `${this.colors.dim}[${entry.metadata.requestId}]${this.colors.reset}`
20
+ : '';
18
21
  const message = entry.message;
19
- let output = `${timestamp} ${level} ${context} ${message}`.trim();
22
+ let output = `${timestamp} ${level} ${context}${reqId ? ` ${reqId}` : ''} ${message}`.trim();
23
+ // Show metadata excluding requestId (already shown as prefix)
20
24
  if (entry.metadata && Object.keys(entry.metadata).length > 0) {
21
- output += `\n${this.colors.dim}${JSON.stringify(entry.metadata, null, 2)}${this.colors.reset}`;
25
+ const { requestId, ...rest } = entry.metadata;
26
+ if (Object.keys(rest).length > 0) {
27
+ output += `\n${this.colors.dim}${JSON.stringify(rest, null, 2)}${this.colors.reset}`;
28
+ }
22
29
  }
23
30
  if (entry.error?.stack) {
24
31
  output += `\n${this.colors.dim}${entry.error.stack}${this.colors.reset}`;
@@ -1 +1 @@
1
- {"version":3,"file":"formatter.js","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"formatter.js","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -3,5 +3,6 @@ export { detectEnvironment, ENV } from './environment.js';
3
3
  export type { Logger, LogEntry, LogLevel, LoggerConfig, LogOutput, ConsoleOutputOptions, FileOutputOptions, CustomOutputOptions, RemoteOutputOptions } from './types.js';
4
4
  export { BaseOutput, ConsoleOutput, FileOutput, CustomOutput, BrowserConsoleOutput, RemoteOutput } from './outputs.js';
5
5
  export { createFileHandler, NodeFileHandler, BrowserStorageHandler, NoOpFileHandler } from './file-handlers.js';
6
+ export { setContextStorage, runWithContext, getContext } from './async-context.js';
6
7
  export declare const VERSION = "1.1.0";
7
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAC1D,YAAY,EACV,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,SAAS,EACT,oBAAoB,EACpB,iBAAiB,EACjB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,YAAY,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAGvH,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGhH,eAAO,MAAM,OAAO,UAAU,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAC1D,YAAY,EACV,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,SAAS,EACT,oBAAoB,EACpB,iBAAiB,EACjB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,YAAY,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAGvH,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGhH,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAGnF,eAAO,MAAM,OAAO,UAAU,CAAC"}
package/dist/index.js CHANGED
@@ -4,6 +4,8 @@ export { detectEnvironment, ENV } from './environment.js';
4
4
  export { BaseOutput, ConsoleOutput, FileOutput, CustomOutput, BrowserConsoleOutput, RemoteOutput } from './outputs.js';
5
5
  // File handler utilities for advanced use cases
6
6
  export { createFileHandler, NodeFileHandler, BrowserStorageHandler, NoOpFileHandler } from './file-handlers.js';
7
+ // Async context for request-scoped metadata (requestId, etc.)
8
+ export { setContextStorage, runWithContext, getContext } from './async-context.js';
7
9
  // Package info
8
10
  export const VERSION = '1.1.0';
9
11
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAa1D,4BAA4B;AAC5B,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,YAAY,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAEvH,gDAAgD;AAChD,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAEhH,eAAe;AACf,MAAM,CAAC,MAAM,OAAO,GAAG,OAAO,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAa1D,4BAA4B;AAC5B,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,YAAY,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAEvH,gDAAgD;AAChD,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAEhH,8DAA8D;AAC9D,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEnF,eAAe;AACf,MAAM,CAAC,MAAM,OAAO,GAAG,OAAO,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AACA,OAAO,EAAsB,MAAM,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAmNtE,wBAAgB,YAAY,CAAC,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,MAAM,CAQvE;AAGD,wBAAgB,mBAAmB,CAAC,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,MAAM,CAY9E;AAGD,wBAAgB,kBAAkB,CAAC,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,MAAM,CAiB7E;AAGD,eAAO,MAAM,aAAa,cAAqB,CAAC"}
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AACA,OAAO,EAAsB,MAAM,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AA6LtE,wBAAgB,YAAY,CAAC,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,MAAM,CAQvE;AAGD,wBAAgB,mBAAmB,CAAC,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,MAAM,CAY9E;AAGD,wBAAgB,kBAAkB,CAAC,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,MAAM,CAiB7E;AAGD,eAAO,MAAM,aAAa,cAAqB,CAAC"}
package/dist/logger.js CHANGED
@@ -1,6 +1,7 @@
1
1
  import { createOutput } from './outputs.js';
2
2
  import { defaultFormatter } from './formatter.js';
3
3
  import { ENV } from './environment.js';
4
+ import { getContext } from './async-context.js';
4
5
  class MicroLogger {
5
6
  config;
6
7
  persistentMetadata = {};
@@ -51,25 +52,9 @@ class MicroLogger {
51
52
  }
52
53
  startTimer(name) {
53
54
  const startTime = performance.now();
54
- const startMemory = ENV.isNode && typeof process !== 'undefined'
55
- ? process.memoryUsage()
56
- : undefined;
57
55
  return () => {
58
- const duration = performance.now() - startTime;
59
- const endMemory = ENV.isNode && typeof process !== 'undefined'
60
- ? process.memoryUsage()
61
- : undefined;
62
- this.info(`Timer ${name} completed`, {
63
- timer: name,
64
- duration: Math.round(duration * 100) / 100, // Round to 2 decimal places
65
- ...(startMemory && endMemory && {
66
- memoryDelta: {
67
- rss: endMemory.rss - startMemory.rss,
68
- heapUsed: endMemory.heapUsed - startMemory.heapUsed,
69
- heapTotal: endMemory.heapTotal - startMemory.heapTotal
70
- }
71
- })
72
- });
56
+ const duration = Math.round((performance.now() - startTime) * 100) / 100;
57
+ this.debug(`Timer ${name} completed`, { timer: name, duration });
73
58
  };
74
59
  }
75
60
  // Browser-specific utility methods
@@ -124,8 +109,9 @@ class MicroLogger {
124
109
  if (this.config.context) {
125
110
  entry.context = this.config.context;
126
111
  }
127
- // Merge persistent metadata with provided metadata
128
- const allMetadata = { ...this.persistentMetadata, ...metadata };
112
+ // Merge async context + persistent metadata + provided metadata
113
+ const asyncCtx = getContext();
114
+ const allMetadata = { ...asyncCtx, ...this.persistentMetadata, ...metadata };
129
115
  if (Object.keys(allMetadata).length > 0) {
130
116
  entry.metadata = allMetadata;
131
117
  }
@@ -139,12 +125,6 @@ class MicroLogger {
139
125
  entry.error.stack = error.stack;
140
126
  }
141
127
  }
142
- // Add memory usage if available and enabled
143
- if (ENV.isNode && typeof process !== 'undefined' && process.memoryUsage) {
144
- entry.performance = {
145
- memory: process.memoryUsage(),
146
- };
147
- }
148
128
  return entry;
149
129
  }
150
130
  formatEntry(entry) {
@@ -1 +1 @@
1
- {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
package/dist/types.d.ts CHANGED
@@ -20,7 +20,6 @@ export interface LogEntry {
20
20
  };
21
21
  performance?: {
22
22
  duration?: number;
23
- memory?: NodeJS.MemoryUsage;
24
23
  };
25
24
  }
26
25
  export interface LoggerConfig {
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@groundbrick/logger",
3
- "version": "0.3.4",
3
+ "version": "0.4.1",
4
4
  "description": "Structured logging with multiple outputs and performance timing for TypeScript applications",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",