@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 +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +3 -2
- package/dist/index.d.ts +3 -2
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
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
|
package/dist/index.cjs.map
CHANGED
|
@@ -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?:
|
|
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?:
|
|
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}
|
|
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?:
|
|
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}
|
|
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?:
|
|
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"}
|