@autofleet/logger 4.3.0-beta0 → 4.3.0-beta1

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/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- Object.defineProperty(exports,`__esModule`,{value:!0});var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));const c=s(require(`pino`)),l=s(require(`pino-cloud-logging`));let u=function(e){return e.trace=`trace`,e.debug=`debug`,e.info=`info`,e.warn=`warn`,e.error=`error`,e.fatal=`fatal`,e}({});const d=e=>e||(process.env.LOG_LEVEL?process.env.LOG_LEVEL:process.env.NODE_ENV&&[`production`,`staging`,`test`].includes(process.env.NODE_ENV)?u.info:(process.env.NODE_ENV,u.debug)),f=(e,t)=>{let n;return n=process.env.NODE_ENV===`production`?(0,c.default)((0,l.gcpLogOptions)({level:process.env.PINO_LOG_LEVEL||`info`,...t})):(0,c.default)({level:process.env.PINO_LOG_LEVEL||`info`,transport:{target:`pino-pretty`,options:{colorize:!0}},...t}),n.level=e,n};var p=class{#contextMiddlewares=[];#logger;constructor(e,t){this.addContextMiddleware=e=>this.#contextMiddlewares.push(e),this.trace=(e,t)=>this.winstonLikeLoggerCall(u.trace,e,t),this.debug=(e,t)=>this.winstonLikeLoggerCall(u.debug,e,t),this.info=(e,t)=>this.winstonLikeLoggerCall(u.info,e,t),this.warn=(e,t)=>this.winstonLikeLoggerCall(u.warn,e,t),this.error=(e,t)=>this.winstonLikeLoggerCall(u.error,e,t),this.fatal=(e,t)=>this.winstonLikeLoggerCall(u.fatal,e,t),this.child=e=>this.#logger.child(e),this.#logger=f(d(e),{mixin:()=>this.addMetadata(),serializers:{...c.stdSerializers,e:c.stdSerializers.errWithCause,err:c.stdSerializers.errWithCause,error:c.stdSerializers.errWithCause,errors(e){return Array.isArray(e)?e.map(c.stdSerializers.errWithCause):c.stdSerializers.errWithCause(e)}},...t})}winstonLikeLoggerCall(e,t,n){n?this.#logger[e](n,t):this.#logger[e](t)}addMetadata(){let e={};return this.#contextMiddlewares.forEach(t=>{let n=t();Object.assign(e,n)}),e}get level(){return this.#logger.level}},m=e=>new p(e);exports.LogLevel=u,exports.LoggerInstanceManager=p,exports.default=m;
1
+ Object.defineProperty(exports,`__esModule`,{value:!0});var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));const c=s(require(`pino`)),l=s(require(`pino-cloud-logging`));let u=function(e){return e.trace=`trace`,e.debug=`debug`,e.info=`info`,e.warn=`warn`,e.error=`error`,e.fatal=`fatal`,e}({});const d=e=>e||(process.env.LOG_LEVEL?process.env.LOG_LEVEL:process.env.NODE_ENV&&[`production`,`staging`,`test`].includes(process.env.NODE_ENV)?u.info:(process.env.NODE_ENV,u.debug)),f=(e,t)=>{let n;return n=process.env.NODE_ENV===`production`?(0,c.default)((0,l.gcpLogOptions)({level:process.env.PINO_LOG_LEVEL||`info`,...t})):(0,c.default)({level:process.env.PINO_LOG_LEVEL||`info`,transport:{target:`pino-pretty`,options:{colorize:!0}},...t}),n.level=e,n};var p=class{#contextMiddlewares=[];#logger;constructor(e,t){this.addContextMiddleware=e=>this.#contextMiddlewares.push(e),this.trace=(e,t)=>this.winstonLikeLoggerCall(u.trace,e,t),this.debug=(e,t)=>this.winstonLikeLoggerCall(u.debug,e,t),this.info=(e,t)=>this.winstonLikeLoggerCall(u.info,e,t),this.warn=(e,t)=>this.winstonLikeLoggerCall(u.warn,e,t),this.error=(e,t)=>this.winstonLikeLoggerCall(u.error,e,t),this.fatal=(e,t)=>this.winstonLikeLoggerCall(u.fatal,e,t),this.child=e=>this.#logger.child(e),this.#logger=f(d(e),{mixin:()=>this.addMetadata(),serializers:{...c.stdSerializers,e:c.stdSerializers.errWithCause,err:c.stdSerializers.errWithCause,error:c.stdSerializers.errWithCause,errors(e){return Array.isArray(e)?e.map(c.stdSerializers.errWithCause):c.stdSerializers.errWithCause(e)}},...t})}winstonLikeLoggerCall(e,t,n){n?this.#logger[e](n,t):this.#logger[e](t)}addMetadata(){let e={};return this.#contextMiddlewares.forEach(t=>{let n=t();Object.assign(e,n)}),e}get level(){return this.#logger.level}},m=(e,t)=>new p(e,t);exports.LogLevel=u,exports.LoggerInstanceManager=p,exports.default=m;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":["#contextMiddlewares","#logger","stdSerializers"],"sources":["../src/index.ts"],"sourcesContent":["import Pino, { type LoggerOptions, stdSerializers } from 'pino';\nimport { gcpLogOptions } from 'pino-cloud-logging';\n\nexport enum LogLevel {\n trace = 'trace',\n debug = 'debug',\n info = 'info',\n warn = 'warn',\n error = 'error',\n fatal = 'fatal',\n}\n\nconst getLevel = (logLevel?: LogLevel): LogLevel => {\n if (logLevel) return logLevel;\n if (process.env.LOG_LEVEL) return process.env.LOG_LEVEL as LogLevel;\n if (process.env.NODE_ENV && ['production', 'staging', 'test'].includes(process.env.NODE_ENV)) return LogLevel.info;\n if (process.env.NODE_ENV === 'development') return LogLevel.debug;\n return LogLevel.debug;\n};\n\nconst createLoggerInstance = (level: LogLevel, options: Omit<LoggerOptions, 'transport'>): Pino.Logger => {\n let loggerInstance;\n if (process.env.NODE_ENV === 'production') {\n loggerInstance = Pino(gcpLogOptions({\n level: process.env.PINO_LOG_LEVEL || 'info',\n ...options,\n } as object));\n } else {\n loggerInstance = Pino({\n level: process.env.PINO_LOG_LEVEL || 'info',\n transport: {\n target: 'pino-pretty',\n options: {\n colorize: true,\n },\n },\n ...options,\n });\n }\n loggerInstance.level = level;\n return loggerInstance;\n};\n\ntype MiddlewareFunction = () => Record<string, unknown>;\n\nexport class LoggerInstanceManager {\n #contextMiddlewares: MiddlewareFunction[] = [];\n\n #logger: Pino.Logger;\n\n constructor(logLevel?: LogLevel, options?: Pick<LoggerOptions, 'redact'>) {\n this.#logger = createLoggerInstance(getLevel(logLevel), {\n mixin: () => this.addMetadata(),\n serializers: {\n ...stdSerializers,\n e: stdSerializers.errWithCause,\n err: stdSerializers.errWithCause,\n error: stdSerializers.errWithCause,\n errors(val) {\n if (Array.isArray(val)) {\n return val.map(stdSerializers.errWithCause);\n }\n return stdSerializers.errWithCause(val);\n },\n },\n ...options,\n });\n }\n\n // To support winston like logging in pino\n private winstonLikeLoggerCall(logLevel: LogLevel, message: string, meta: unknown): void {\n if (meta) {\n this.#logger[logLevel](meta, message);\n } else {\n this.#logger[logLevel](message);\n }\n }\n\n private addMetadata(): Record<string, unknown> {\n const newMetadata = {};\n this.#contextMiddlewares.forEach((middleware) => {\n const metadata = middleware();\n Object.assign(newMetadata, metadata);\n });\n return newMetadata;\n }\n\n addContextMiddleware = (middleware: MiddlewareFunction): number => this.#contextMiddlewares.push(middleware);\n\n trace = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.trace, message, meta);\n\n debug = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.debug, message, meta);\n\n info = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.info, message, meta);\n\n warn = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.warn, message, meta);\n\n error = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.error, message, meta);\n\n fatal = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.fatal, message, meta);\n\n child = (metadata: Record<string, unknown>): Pino.Logger => this.#logger.child(metadata);\n\n get level(): Pino.LevelWithSilentOrString {\n return this.#logger.level;\n }\n}\n\nexport default (loglevel?: `${LogLevel}`): LoggerInstanceManager => new LoggerInstanceManager(loglevel as LogLevel);\n"],"mappings":"mlBAGA,IAAY,EAAA,SAAA,EAAL,OACL,GAAA,MAAA,QACA,EAAA,MAAA,QACA,EAAA,KAAA,OACA,EAAA,KAAA,OACA,EAAA,MAAA,QACA,EAAA,MAAA,eAGF,MAAM,EAAY,GACZ,IACA,QAAQ,IAAI,UAAkB,QAAQ,IAAI,UAC1C,QAAQ,IAAI,UAAY,CAAC,aAAc,UAAW,QAAQ,SAAS,QAAQ,IAAI,UAAkB,EAAS,MAC1G,QAAQ,IAAI,SAAmC,EAAS,QAIxD,GAAwB,EAAiB,IAA2D,CACxG,IAAI,EAmBJ,MAlBA,CAME,EANE,QAAQ,IAAI,WAAa,cAC3B,EAAA,EAAA,UAAA,EAAA,EAAA,eAAoC,CAClC,MAAO,QAAQ,IAAI,gBAAkB,OACrC,GAAG,MAGL,EAAA,EAAA,SAAsB,CACpB,MAAO,QAAQ,IAAI,gBAAkB,OACrC,UAAW,CACT,OAAQ,cACR,QAAS,CACP,SAAU,KAGd,GAAG,IAGP,EAAe,MAAQ,EAChB,GAKT,IAAa,EAAb,KAAmC,CACjC,oBAA4C,GAE5C,QAEA,YAAY,EAAqB,EAAyC,2BAqClD,GAA2C,MAAA,mBAAyB,KAAK,eAExF,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE/F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,cAE7F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,eAE5F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE9F,GAAmD,MAAA,OAAa,MAAM,GAlD7E,MAAA,OAAe,EAAqB,EAAS,GAAW,CACtD,UAAa,KAAK,cAClB,YAAa,CACX,GAAGE,EAAAA,eACH,EAAGA,EAAAA,eAAe,aAClB,IAAKA,EAAAA,eAAe,aACpB,MAAOA,EAAAA,eAAe,aACtB,OAAO,EAAK,CAIV,OAHI,MAAM,QAAQ,GACT,EAAI,IAAIA,EAAAA,eAAe,cAEzBA,EAAAA,eAAe,aAAa,KAGvC,GAAG,IAKP,sBAA8B,EAAoB,EAAiB,EAAqB,CAClF,EACF,MAAA,OAAa,GAAU,EAAM,GAE7B,MAAA,OAAa,GAAU,GAI3B,aAA+C,CAC7C,IAAM,EAAc,GAKpB,OAJA,MAAA,mBAAyB,QAAS,GAAe,CAC/C,IAAM,EAAW,IACjB,OAAO,OAAO,EAAa,KAEtB,EAmBT,IAAI,OAAsC,CACxC,OAAO,MAAA,OAAa,QAIxB,EAAgB,GAAoD,IAAI,EAAsB"}
1
+ {"version":3,"file":"index.cjs","names":["#contextMiddlewares","#logger","stdSerializers"],"sources":["../src/index.ts"],"sourcesContent":["import Pino, { type LoggerOptions, stdSerializers } from 'pino';\nimport { gcpLogOptions } from 'pino-cloud-logging';\n\nexport enum LogLevel {\n trace = 'trace',\n debug = 'debug',\n info = 'info',\n warn = 'warn',\n error = 'error',\n fatal = 'fatal',\n}\n\nconst getLevel = (logLevel?: LogLevel): LogLevel => {\n if (logLevel) return logLevel;\n if (process.env.LOG_LEVEL) return process.env.LOG_LEVEL as LogLevel;\n if (process.env.NODE_ENV && ['production', 'staging', 'test'].includes(process.env.NODE_ENV)) return LogLevel.info;\n if (process.env.NODE_ENV === 'development') return LogLevel.debug;\n return LogLevel.debug;\n};\n\nconst createLoggerInstance = (level: LogLevel, options: Omit<LoggerOptions, 'transport'>): Pino.Logger => {\n let loggerInstance;\n if (process.env.NODE_ENV === 'production') {\n loggerInstance = Pino(gcpLogOptions({\n level: process.env.PINO_LOG_LEVEL || 'info',\n ...options,\n } as object));\n } else {\n loggerInstance = Pino({\n level: process.env.PINO_LOG_LEVEL || 'info',\n transport: {\n target: 'pino-pretty',\n options: {\n colorize: true,\n },\n },\n ...options,\n });\n }\n loggerInstance.level = level;\n return loggerInstance;\n};\n\ntype MiddlewareFunction = () => Record<string, unknown>;\ntype LoggerInstanceManagerOptions = Pick<LoggerOptions, 'redact'>;\n\nexport class LoggerInstanceManager {\n #contextMiddlewares: MiddlewareFunction[] = [];\n\n #logger: Pino.Logger;\n\n constructor(logLevel?: LogLevel, options?: LoggerInstanceManagerOptions) {\n this.#logger = createLoggerInstance(getLevel(logLevel), {\n mixin: () => this.addMetadata(),\n serializers: {\n ...stdSerializers,\n e: stdSerializers.errWithCause,\n err: stdSerializers.errWithCause,\n error: stdSerializers.errWithCause,\n errors(val) {\n if (Array.isArray(val)) {\n return val.map(stdSerializers.errWithCause);\n }\n return stdSerializers.errWithCause(val);\n },\n },\n ...options,\n });\n }\n\n // To support winston like logging in pino\n private winstonLikeLoggerCall(logLevel: LogLevel, message: string, meta: unknown): void {\n if (meta) {\n this.#logger[logLevel](meta, message);\n } else {\n this.#logger[logLevel](message);\n }\n }\n\n private addMetadata(): Record<string, unknown> {\n const newMetadata = {};\n this.#contextMiddlewares.forEach((middleware) => {\n const metadata = middleware();\n Object.assign(newMetadata, metadata);\n });\n return newMetadata;\n }\n\n addContextMiddleware = (middleware: MiddlewareFunction): number => this.#contextMiddlewares.push(middleware);\n\n trace = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.trace, message, meta);\n\n debug = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.debug, message, meta);\n\n info = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.info, message, meta);\n\n warn = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.warn, message, meta);\n\n error = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.error, message, meta);\n\n fatal = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.fatal, message, meta);\n\n child = (metadata: Record<string, unknown>): Pino.Logger => this.#logger.child(metadata);\n\n get level(): Pino.LevelWithSilentOrString {\n return this.#logger.level;\n }\n}\n\nexport default (loglevel?: `${LogLevel}`, options?: LoggerInstanceManagerOptions): LoggerInstanceManager => new LoggerInstanceManager(loglevel as LogLevel, options);\n"],"mappings":"mlBAGA,IAAY,EAAA,SAAA,EAAL,OACL,GAAA,MAAA,QACA,EAAA,MAAA,QACA,EAAA,KAAA,OACA,EAAA,KAAA,OACA,EAAA,MAAA,QACA,EAAA,MAAA,eAGF,MAAM,EAAY,GACZ,IACA,QAAQ,IAAI,UAAkB,QAAQ,IAAI,UAC1C,QAAQ,IAAI,UAAY,CAAC,aAAc,UAAW,QAAQ,SAAS,QAAQ,IAAI,UAAkB,EAAS,MAC1G,QAAQ,IAAI,SAAmC,EAAS,QAIxD,GAAwB,EAAiB,IAA2D,CACxG,IAAI,EAmBJ,MAlBA,CAME,EANE,QAAQ,IAAI,WAAa,cAC3B,EAAA,EAAA,UAAA,EAAA,EAAA,eAAoC,CAClC,MAAO,QAAQ,IAAI,gBAAkB,OACrC,GAAG,MAGL,EAAA,EAAA,SAAsB,CACpB,MAAO,QAAQ,IAAI,gBAAkB,OACrC,UAAW,CACT,OAAQ,cACR,QAAS,CACP,SAAU,KAGd,GAAG,IAGP,EAAe,MAAQ,EAChB,GAMT,IAAa,EAAb,KAAmC,CACjC,oBAA4C,GAE5C,QAEA,YAAY,EAAqB,EAAwC,2BAqCjD,GAA2C,MAAA,mBAAyB,KAAK,eAExF,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE/F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,cAE7F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,eAE5F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE9F,GAAmD,MAAA,OAAa,MAAM,GAlD7E,MAAA,OAAe,EAAqB,EAAS,GAAW,CACtD,UAAa,KAAK,cAClB,YAAa,CACX,GAAGE,EAAAA,eACH,EAAGA,EAAAA,eAAe,aAClB,IAAKA,EAAAA,eAAe,aACpB,MAAOA,EAAAA,eAAe,aACtB,OAAO,EAAK,CAIV,OAHI,MAAM,QAAQ,GACT,EAAI,IAAIA,EAAAA,eAAe,cAEzBA,EAAAA,eAAe,aAAa,KAGvC,GAAG,IAKP,sBAA8B,EAAoB,EAAiB,EAAqB,CAClF,EACF,MAAA,OAAa,GAAU,EAAM,GAE7B,MAAA,OAAa,GAAU,GAI3B,aAA+C,CAC7C,IAAM,EAAc,GAKpB,OAJA,MAAA,mBAAyB,QAAS,GAAe,CAC/C,IAAM,EAAW,IACjB,OAAO,OAAO,EAAa,KAEtB,EAmBT,IAAI,OAAsC,CACxC,OAAO,MAAA,OAAa,QAIxB,GAAgB,EAA0B,IAAkE,IAAI,EAAsB,EAAsB"}
package/dist/index.d.cts CHANGED
@@ -10,9 +10,10 @@ declare enum LogLevel {
10
10
  fatal = "fatal",
11
11
  }
12
12
  type MiddlewareFunction = () => Record<string, unknown>;
13
+ type LoggerInstanceManagerOptions = Pick<LoggerOptions, "redact">;
13
14
  declare class LoggerInstanceManager {
14
15
  #private;
15
- constructor(logLevel?: LogLevel, options?: Pick<LoggerOptions, "redact">);
16
+ constructor(logLevel?: LogLevel, options?: LoggerInstanceManagerOptions);
16
17
  private winstonLikeLoggerCall;
17
18
  private addMetadata;
18
19
  addContextMiddleware: (middleware: MiddlewareFunction) => number;
@@ -25,7 +26,7 @@ declare class LoggerInstanceManager {
25
26
  child: (metadata: Record<string, unknown>) => Pino.Logger;
26
27
  get level(): Pino.LevelWithSilentOrString;
27
28
  }
28
- declare const _default: (loglevel?: `${LogLevel}`) => LoggerInstanceManager;
29
+ declare const _default: (loglevel?: `${LogLevel}`, options?: LoggerInstanceManagerOptions) => LoggerInstanceManager;
29
30
  //#endregion
30
31
  export { LogLevel, LoggerInstanceManager, _default as default };
31
32
  //# sourceMappingURL=index.d.cts.map
package/dist/index.d.ts CHANGED
@@ -10,9 +10,10 @@ declare enum LogLevel {
10
10
  fatal = "fatal",
11
11
  }
12
12
  type MiddlewareFunction = () => Record<string, unknown>;
13
+ type LoggerInstanceManagerOptions = Pick<LoggerOptions, "redact">;
13
14
  declare class LoggerInstanceManager {
14
15
  #private;
15
- constructor(logLevel?: LogLevel, options?: Pick<LoggerOptions, "redact">);
16
+ constructor(logLevel?: LogLevel, options?: LoggerInstanceManagerOptions);
16
17
  private winstonLikeLoggerCall;
17
18
  private addMetadata;
18
19
  addContextMiddleware: (middleware: MiddlewareFunction) => number;
@@ -25,7 +26,7 @@ declare class LoggerInstanceManager {
25
26
  child: (metadata: Record<string, unknown>) => Pino.Logger;
26
27
  get level(): Pino.LevelWithSilentOrString;
27
28
  }
28
- declare const _default: (loglevel?: `${LogLevel}`) => LoggerInstanceManager;
29
+ declare const _default: (loglevel?: `${LogLevel}`, options?: LoggerInstanceManagerOptions) => LoggerInstanceManager;
29
30
  //#endregion
30
31
  export { LogLevel, LoggerInstanceManager, _default as default };
31
32
  //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- import e,{stdSerializers as t}from"pino";import{gcpLogOptions as n}from"pino-cloud-logging";let r=function(e){return e.trace=`trace`,e.debug=`debug`,e.info=`info`,e.warn=`warn`,e.error=`error`,e.fatal=`fatal`,e}({});const i=e=>e||(process.env.LOG_LEVEL?process.env.LOG_LEVEL:process.env.NODE_ENV&&[`production`,`staging`,`test`].includes(process.env.NODE_ENV)?r.info:(process.env.NODE_ENV,r.debug)),a=(t,r)=>{let i;return i=process.env.NODE_ENV===`production`?e(n({level:process.env.PINO_LOG_LEVEL||`info`,...r})):e({level:process.env.PINO_LOG_LEVEL||`info`,transport:{target:`pino-pretty`,options:{colorize:!0}},...r}),i.level=t,i};var o=class{#contextMiddlewares=[];#logger;constructor(e,n){this.addContextMiddleware=e=>this.#contextMiddlewares.push(e),this.trace=(e,t)=>this.winstonLikeLoggerCall(r.trace,e,t),this.debug=(e,t)=>this.winstonLikeLoggerCall(r.debug,e,t),this.info=(e,t)=>this.winstonLikeLoggerCall(r.info,e,t),this.warn=(e,t)=>this.winstonLikeLoggerCall(r.warn,e,t),this.error=(e,t)=>this.winstonLikeLoggerCall(r.error,e,t),this.fatal=(e,t)=>this.winstonLikeLoggerCall(r.fatal,e,t),this.child=e=>this.#logger.child(e),this.#logger=a(i(e),{mixin:()=>this.addMetadata(),serializers:{...t,e:t.errWithCause,err:t.errWithCause,error:t.errWithCause,errors(e){return Array.isArray(e)?e.map(t.errWithCause):t.errWithCause(e)}},...n})}winstonLikeLoggerCall(e,t,n){n?this.#logger[e](n,t):this.#logger[e](t)}addMetadata(){let e={};return this.#contextMiddlewares.forEach(t=>{let n=t();Object.assign(e,n)}),e}get level(){return this.#logger.level}},s=e=>new o(e);export{r as LogLevel,o as LoggerInstanceManager,s as default};
1
+ import e,{stdSerializers as t}from"pino";import{gcpLogOptions as n}from"pino-cloud-logging";let r=function(e){return e.trace=`trace`,e.debug=`debug`,e.info=`info`,e.warn=`warn`,e.error=`error`,e.fatal=`fatal`,e}({});const i=e=>e||(process.env.LOG_LEVEL?process.env.LOG_LEVEL:process.env.NODE_ENV&&[`production`,`staging`,`test`].includes(process.env.NODE_ENV)?r.info:(process.env.NODE_ENV,r.debug)),a=(t,r)=>{let i;return i=process.env.NODE_ENV===`production`?e(n({level:process.env.PINO_LOG_LEVEL||`info`,...r})):e({level:process.env.PINO_LOG_LEVEL||`info`,transport:{target:`pino-pretty`,options:{colorize:!0}},...r}),i.level=t,i};var o=class{#contextMiddlewares=[];#logger;constructor(e,n){this.addContextMiddleware=e=>this.#contextMiddlewares.push(e),this.trace=(e,t)=>this.winstonLikeLoggerCall(r.trace,e,t),this.debug=(e,t)=>this.winstonLikeLoggerCall(r.debug,e,t),this.info=(e,t)=>this.winstonLikeLoggerCall(r.info,e,t),this.warn=(e,t)=>this.winstonLikeLoggerCall(r.warn,e,t),this.error=(e,t)=>this.winstonLikeLoggerCall(r.error,e,t),this.fatal=(e,t)=>this.winstonLikeLoggerCall(r.fatal,e,t),this.child=e=>this.#logger.child(e),this.#logger=a(i(e),{mixin:()=>this.addMetadata(),serializers:{...t,e:t.errWithCause,err:t.errWithCause,error:t.errWithCause,errors(e){return Array.isArray(e)?e.map(t.errWithCause):t.errWithCause(e)}},...n})}winstonLikeLoggerCall(e,t,n){n?this.#logger[e](n,t):this.#logger[e](t)}addMetadata(){let e={};return this.#contextMiddlewares.forEach(t=>{let n=t();Object.assign(e,n)}),e}get level(){return this.#logger.level}},s=(e,t)=>new o(e,t);export{r as LogLevel,o as LoggerInstanceManager,s as default};
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["#contextMiddlewares","#logger"],"sources":["../src/index.ts"],"sourcesContent":["import Pino, { type LoggerOptions, stdSerializers } from 'pino';\nimport { gcpLogOptions } from 'pino-cloud-logging';\n\nexport enum LogLevel {\n trace = 'trace',\n debug = 'debug',\n info = 'info',\n warn = 'warn',\n error = 'error',\n fatal = 'fatal',\n}\n\nconst getLevel = (logLevel?: LogLevel): LogLevel => {\n if (logLevel) return logLevel;\n if (process.env.LOG_LEVEL) return process.env.LOG_LEVEL as LogLevel;\n if (process.env.NODE_ENV && ['production', 'staging', 'test'].includes(process.env.NODE_ENV)) return LogLevel.info;\n if (process.env.NODE_ENV === 'development') return LogLevel.debug;\n return LogLevel.debug;\n};\n\nconst createLoggerInstance = (level: LogLevel, options: Omit<LoggerOptions, 'transport'>): Pino.Logger => {\n let loggerInstance;\n if (process.env.NODE_ENV === 'production') {\n loggerInstance = Pino(gcpLogOptions({\n level: process.env.PINO_LOG_LEVEL || 'info',\n ...options,\n } as object));\n } else {\n loggerInstance = Pino({\n level: process.env.PINO_LOG_LEVEL || 'info',\n transport: {\n target: 'pino-pretty',\n options: {\n colorize: true,\n },\n },\n ...options,\n });\n }\n loggerInstance.level = level;\n return loggerInstance;\n};\n\ntype MiddlewareFunction = () => Record<string, unknown>;\n\nexport class LoggerInstanceManager {\n #contextMiddlewares: MiddlewareFunction[] = [];\n\n #logger: Pino.Logger;\n\n constructor(logLevel?: LogLevel, options?: Pick<LoggerOptions, 'redact'>) {\n this.#logger = createLoggerInstance(getLevel(logLevel), {\n mixin: () => this.addMetadata(),\n serializers: {\n ...stdSerializers,\n e: stdSerializers.errWithCause,\n err: stdSerializers.errWithCause,\n error: stdSerializers.errWithCause,\n errors(val) {\n if (Array.isArray(val)) {\n return val.map(stdSerializers.errWithCause);\n }\n return stdSerializers.errWithCause(val);\n },\n },\n ...options,\n });\n }\n\n // To support winston like logging in pino\n private winstonLikeLoggerCall(logLevel: LogLevel, message: string, meta: unknown): void {\n if (meta) {\n this.#logger[logLevel](meta, message);\n } else {\n this.#logger[logLevel](message);\n }\n }\n\n private addMetadata(): Record<string, unknown> {\n const newMetadata = {};\n this.#contextMiddlewares.forEach((middleware) => {\n const metadata = middleware();\n Object.assign(newMetadata, metadata);\n });\n return newMetadata;\n }\n\n addContextMiddleware = (middleware: MiddlewareFunction): number => this.#contextMiddlewares.push(middleware);\n\n trace = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.trace, message, meta);\n\n debug = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.debug, message, meta);\n\n info = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.info, message, meta);\n\n warn = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.warn, message, meta);\n\n error = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.error, message, meta);\n\n fatal = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.fatal, message, meta);\n\n child = (metadata: Record<string, unknown>): Pino.Logger => this.#logger.child(metadata);\n\n get level(): Pino.LevelWithSilentOrString {\n return this.#logger.level;\n }\n}\n\nexport default (loglevel?: `${LogLevel}`): LoggerInstanceManager => new LoggerInstanceManager(loglevel as LogLevel);\n"],"mappings":"4FAGA,IAAY,EAAA,SAAA,EAAL,OACL,GAAA,MAAA,QACA,EAAA,MAAA,QACA,EAAA,KAAA,OACA,EAAA,KAAA,OACA,EAAA,MAAA,QACA,EAAA,MAAA,eAGF,MAAM,EAAY,GACZ,IACA,QAAQ,IAAI,UAAkB,QAAQ,IAAI,UAC1C,QAAQ,IAAI,UAAY,CAAC,aAAc,UAAW,QAAQ,SAAS,QAAQ,IAAI,UAAkB,EAAS,MAC1G,QAAQ,IAAI,SAAmC,EAAS,QAIxD,GAAwB,EAAiB,IAA2D,CACxG,IAAI,EAmBJ,MAlBA,CAME,EANE,QAAQ,IAAI,WAAa,aACV,EAAK,EAAc,CAClC,MAAO,QAAQ,IAAI,gBAAkB,OACrC,GAAG,KAGY,EAAK,CACpB,MAAO,QAAQ,IAAI,gBAAkB,OACrC,UAAW,CACT,OAAQ,cACR,QAAS,CACP,SAAU,KAGd,GAAG,IAGP,EAAe,MAAQ,EAChB,GAKT,IAAa,EAAb,KAAmC,CACjC,oBAA4C,GAE5C,QAEA,YAAY,EAAqB,EAAyC,2BAqClD,GAA2C,MAAA,mBAAyB,KAAK,eAExF,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE/F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,cAE7F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,eAE5F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE9F,GAAmD,MAAA,OAAa,MAAM,GAlD7E,MAAA,OAAe,EAAqB,EAAS,GAAW,CACtD,UAAa,KAAK,cAClB,YAAa,CACX,GAAG,EACH,EAAG,EAAe,aAClB,IAAK,EAAe,aACpB,MAAO,EAAe,aACtB,OAAO,EAAK,CAIV,OAHI,MAAM,QAAQ,GACT,EAAI,IAAI,EAAe,cAEzB,EAAe,aAAa,KAGvC,GAAG,IAKP,sBAA8B,EAAoB,EAAiB,EAAqB,CAClF,EACF,MAAA,OAAa,GAAU,EAAM,GAE7B,MAAA,OAAa,GAAU,GAI3B,aAA+C,CAC7C,IAAM,EAAc,GAKpB,OAJA,MAAA,mBAAyB,QAAS,GAAe,CAC/C,IAAM,EAAW,IACjB,OAAO,OAAO,EAAa,KAEtB,EAmBT,IAAI,OAAsC,CACxC,OAAO,MAAA,OAAa,QAIxB,EAAgB,GAAoD,IAAI,EAAsB"}
1
+ {"version":3,"file":"index.js","names":["#contextMiddlewares","#logger"],"sources":["../src/index.ts"],"sourcesContent":["import Pino, { type LoggerOptions, stdSerializers } from 'pino';\nimport { gcpLogOptions } from 'pino-cloud-logging';\n\nexport enum LogLevel {\n trace = 'trace',\n debug = 'debug',\n info = 'info',\n warn = 'warn',\n error = 'error',\n fatal = 'fatal',\n}\n\nconst getLevel = (logLevel?: LogLevel): LogLevel => {\n if (logLevel) return logLevel;\n if (process.env.LOG_LEVEL) return process.env.LOG_LEVEL as LogLevel;\n if (process.env.NODE_ENV && ['production', 'staging', 'test'].includes(process.env.NODE_ENV)) return LogLevel.info;\n if (process.env.NODE_ENV === 'development') return LogLevel.debug;\n return LogLevel.debug;\n};\n\nconst createLoggerInstance = (level: LogLevel, options: Omit<LoggerOptions, 'transport'>): Pino.Logger => {\n let loggerInstance;\n if (process.env.NODE_ENV === 'production') {\n loggerInstance = Pino(gcpLogOptions({\n level: process.env.PINO_LOG_LEVEL || 'info',\n ...options,\n } as object));\n } else {\n loggerInstance = Pino({\n level: process.env.PINO_LOG_LEVEL || 'info',\n transport: {\n target: 'pino-pretty',\n options: {\n colorize: true,\n },\n },\n ...options,\n });\n }\n loggerInstance.level = level;\n return loggerInstance;\n};\n\ntype MiddlewareFunction = () => Record<string, unknown>;\ntype LoggerInstanceManagerOptions = Pick<LoggerOptions, 'redact'>;\n\nexport class LoggerInstanceManager {\n #contextMiddlewares: MiddlewareFunction[] = [];\n\n #logger: Pino.Logger;\n\n constructor(logLevel?: LogLevel, options?: LoggerInstanceManagerOptions) {\n this.#logger = createLoggerInstance(getLevel(logLevel), {\n mixin: () => this.addMetadata(),\n serializers: {\n ...stdSerializers,\n e: stdSerializers.errWithCause,\n err: stdSerializers.errWithCause,\n error: stdSerializers.errWithCause,\n errors(val) {\n if (Array.isArray(val)) {\n return val.map(stdSerializers.errWithCause);\n }\n return stdSerializers.errWithCause(val);\n },\n },\n ...options,\n });\n }\n\n // To support winston like logging in pino\n private winstonLikeLoggerCall(logLevel: LogLevel, message: string, meta: unknown): void {\n if (meta) {\n this.#logger[logLevel](meta, message);\n } else {\n this.#logger[logLevel](message);\n }\n }\n\n private addMetadata(): Record<string, unknown> {\n const newMetadata = {};\n this.#contextMiddlewares.forEach((middleware) => {\n const metadata = middleware();\n Object.assign(newMetadata, metadata);\n });\n return newMetadata;\n }\n\n addContextMiddleware = (middleware: MiddlewareFunction): number => this.#contextMiddlewares.push(middleware);\n\n trace = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.trace, message, meta);\n\n debug = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.debug, message, meta);\n\n info = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.info, message, meta);\n\n warn = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.warn, message, meta);\n\n error = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.error, message, meta);\n\n fatal = (message: string, meta?: unknown): void => this.winstonLikeLoggerCall(LogLevel.fatal, message, meta);\n\n child = (metadata: Record<string, unknown>): Pino.Logger => this.#logger.child(metadata);\n\n get level(): Pino.LevelWithSilentOrString {\n return this.#logger.level;\n }\n}\n\nexport default (loglevel?: `${LogLevel}`, options?: LoggerInstanceManagerOptions): LoggerInstanceManager => new LoggerInstanceManager(loglevel as LogLevel, options);\n"],"mappings":"4FAGA,IAAY,EAAA,SAAA,EAAL,OACL,GAAA,MAAA,QACA,EAAA,MAAA,QACA,EAAA,KAAA,OACA,EAAA,KAAA,OACA,EAAA,MAAA,QACA,EAAA,MAAA,eAGF,MAAM,EAAY,GACZ,IACA,QAAQ,IAAI,UAAkB,QAAQ,IAAI,UAC1C,QAAQ,IAAI,UAAY,CAAC,aAAc,UAAW,QAAQ,SAAS,QAAQ,IAAI,UAAkB,EAAS,MAC1G,QAAQ,IAAI,SAAmC,EAAS,QAIxD,GAAwB,EAAiB,IAA2D,CACxG,IAAI,EAmBJ,MAlBA,CAME,EANE,QAAQ,IAAI,WAAa,aACV,EAAK,EAAc,CAClC,MAAO,QAAQ,IAAI,gBAAkB,OACrC,GAAG,KAGY,EAAK,CACpB,MAAO,QAAQ,IAAI,gBAAkB,OACrC,UAAW,CACT,OAAQ,cACR,QAAS,CACP,SAAU,KAGd,GAAG,IAGP,EAAe,MAAQ,EAChB,GAMT,IAAa,EAAb,KAAmC,CACjC,oBAA4C,GAE5C,QAEA,YAAY,EAAqB,EAAwC,2BAqCjD,GAA2C,MAAA,mBAAyB,KAAK,eAExF,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE/F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,cAE7F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,KAAM,EAAS,eAE5F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,eAE9F,EAAiB,IAAyB,KAAK,sBAAsB,EAAS,MAAO,EAAS,cAE9F,GAAmD,MAAA,OAAa,MAAM,GAlD7E,MAAA,OAAe,EAAqB,EAAS,GAAW,CACtD,UAAa,KAAK,cAClB,YAAa,CACX,GAAG,EACH,EAAG,EAAe,aAClB,IAAK,EAAe,aACpB,MAAO,EAAe,aACtB,OAAO,EAAK,CAIV,OAHI,MAAM,QAAQ,GACT,EAAI,IAAI,EAAe,cAEzB,EAAe,aAAa,KAGvC,GAAG,IAKP,sBAA8B,EAAoB,EAAiB,EAAqB,CAClF,EACF,MAAA,OAAa,GAAU,EAAM,GAE7B,MAAA,OAAa,GAAU,GAI3B,aAA+C,CAC7C,IAAM,EAAc,GAKpB,OAJA,MAAA,mBAAyB,QAAS,GAAe,CAC/C,IAAM,EAAW,IACjB,OAAO,OAAO,EAAa,KAEtB,EAmBT,IAAI,OAAsC,CACxC,OAAO,MAAA,OAAa,QAIxB,GAAgB,EAA0B,IAAkE,IAAI,EAAsB,EAAsB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@autofleet/logger",
3
- "version": "4.3.0-beta0",
3
+ "version": "4.3.0-beta1",
4
4
  "description": "",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",