@effect-aws/powertools-logger
Advanced tools
Comparing version 0.2.1 to 0.3.0
# @effect-aws/powertools-logger | ||
## 0.3.0 | ||
### Minor Changes | ||
- [`d43c957`](https://github.com/floydspace/effect-aws/commit/d43c95706d5798502d1794c3ed92fa301afd4a02) Thanks [@floydspace](https://github.com/floydspace)! - add an ability provide config options through layer, renamed the layer variables | ||
## 0.2.1 | ||
@@ -4,0 +10,0 @@ |
@@ -0,2 +1,3 @@ | ||
export * from "./Context"; | ||
export * from "./Logger"; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9Mb2dnZXJcIjtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9Db250ZXh0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9Mb2dnZXJcIjtcbiJdfQ== |
@@ -1,3 +0,1 @@ | ||
import { Logger } from "@aws-lambda-powertools/logger"; | ||
import * as Context from "@effect/data/Context"; | ||
import * as HashMap from "@effect/data/HashMap"; | ||
@@ -13,3 +11,3 @@ import * as List from "@effect/data/List"; | ||
import * as LogLevel from "@effect/io/LogLevel"; | ||
export const LoggerInstanceTag = Context.Tag("@effect-aws/Powertools/Logger"); | ||
import { DefaultLoggerOptionsLayer, LoggerInstanceLayer, LoggerInstanceTag, } from "./Context"; | ||
const logExtraInput = FiberRef.unsafeMake([]); | ||
@@ -54,3 +52,3 @@ const processLog = (effect) => { | ||
export const logCritical = processLog(Effect.logFatal); | ||
export const powerToolsImpl = (logger) => { | ||
const powerToolsImpl = (logger) => { | ||
return Log.make((options) => { | ||
@@ -78,13 +76,15 @@ const [...extraInputs] = FiberRefs.getOrDefault(options.context, logExtraInput); | ||
}; | ||
export const DefaultLoggerInstanceLayer = Layer.succeed(LoggerInstanceTag, new Logger()); | ||
const PowerToolsLogger = LoggerInstanceTag.pipe(Effect.map(powerToolsImpl)); | ||
const PowerToolsDefaultLogger = PowerToolsLogger.pipe(Effect.provideLayer(DefaultLoggerInstanceLayer)); | ||
const PowerToolsLoggerEffect = LoggerInstanceTag.pipe(Effect.map(powerToolsImpl)); | ||
/** | ||
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance. | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer. | ||
*/ | ||
export const PowerToolsDefaultLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger), Log.minimumLogLevel(LogLevel.All)); | ||
export const BasePowerToolsLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsLoggerEffect), Log.minimumLogLevel(LogLevel.All)); | ||
/** | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer. | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance configured by logger options layer. | ||
*/ | ||
export const PowerToolsLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsLogger), Log.minimumLogLevel(LogLevel.All)); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../../src/Logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from \"@aws-lambda-powertools/logger\";\nimport type {\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport * as Context from \"@effect/data/Context\";\nimport * as HashMap from \"@effect/data/HashMap\";\nimport * as List from \"@effect/data/List\";\nimport * as Cause from \"@effect/io/Cause\";\nimport * as Effect from \"@effect/io/Effect\";\nimport * as FiberId from \"@effect/io/FiberId\";\nimport * as FiberRef from \"@effect/io/FiberRef\";\nimport * as FiberRefs from \"@effect/io/FiberRefs\";\nimport * as Layer from \"@effect/io/Layer\";\nimport * as Log from \"@effect/io/Logger\";\nimport * as LogLevel from \"@effect/io/LogLevel\";\n\nexport const LoggerInstanceTag = Context.Tag<Logger>(\n  \"@effect-aws/Powertools/Logger\",\n);\n\nconst logExtraInput = FiberRef.unsafeMake<LogItemExtraInput>([]);\n\nconst processLog = (\n  effect: (message: string) => Effect.Effect<never, never, void>,\n) => {\n  return (input: LogItemMessage, ...extraInput: LogItemExtraInput) => {\n    const message = typeof input === \"string\" ? input : input.message;\n\n    const extraInputs =\n      typeof input === \"string\" ? extraInput : [input, ...extraInput];\n\n    return Effect.locally(effect(message), logExtraInput, extraInputs);\n  };\n};\n\n/**\n * Logs the specified message at the debug log level.\n * It prints a log item with level DEBUG.\n */\nexport const logDebug = processLog(Effect.logDebug);\n/**\n * Logs the specified message at the info log level.\n * It prints a log item with level INFO.\n */\nexport const logInfo = processLog(Effect.logInfo);\n/**\n * Logs the specified message at the warning log level.\n * It prints a log item with level WARN.\n */\nexport const logWarning = processLog(Effect.logWarning);\n/**\n * Logs the specified message at the error log level.\n * It prints a log item with level ERROR.\n */\nexport const logError = processLog(Effect.logError);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n */\nexport const logFatal = processLog(Effect.logFatal);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n * @alias logFatal\n */\nexport const logCritical = processLog(Effect.logFatal);\n\nexport const powerToolsImpl = (logger: Logger) => {\n  return Log.make<unknown, void>((options) => {\n    const [...extraInputs] = FiberRefs.getOrDefault(\n      options.context,\n      logExtraInput,\n    );\n\n    const nowMillis = options.date.getTime();\n\n    extraInputs.push({\n      fiber: FiberId.threadName(options.fiberId),\n      timestamp: options.date.toISOString(),\n      ...(Cause.isEmpty(options.cause)\n        ? {}\n        : { cause: Cause.pretty(options.cause) }),\n      ...List.reduce(options.spans, {}, (acc, span) => ({\n        ...acc,\n        [span.label]: `${nowMillis - span.startTime}ms`,\n      })),\n      ...HashMap.reduce(options.annotations, {}, (acc, value, key) => ({\n        ...acc,\n        [key]: value,\n      })),\n    });\n\n    const unsafeLogger = logger as any;\n\n    unsafeLogger.processLogItem(\n      unsafeLogger.logLevelThresholds[\n        options.logLevel.label === \"FATAL\" ? \"CRITICAL\" : options.logLevel.label\n      ],\n      options.message,\n      extraInputs,\n    );\n  });\n};\n\nexport const DefaultLoggerInstanceLayer = Layer.succeed(\n  LoggerInstanceTag,\n  new Logger(),\n);\n\nconst PowerToolsLogger = LoggerInstanceTag.pipe(Effect.map(powerToolsImpl));\n\nconst PowerToolsDefaultLogger = PowerToolsLogger.pipe(\n  Effect.provideLayer(DefaultLoggerInstanceLayer),\n);\n\n/**\n * Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.\n */\nexport const PowerToolsDefaultLoggerLayer = Layer.merge(\n  Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger),\n  Log.minimumLogLevel(LogLevel.All), // Log level is controlled by the PowerTools Logger instance\n);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.\n */\nexport const PowerToolsLoggerLayer = Layer.merge(\n  Log.replaceEffect(Log.defaultLogger, PowerToolsLogger),\n  Log.minimumLogLevel(LogLevel.All),\n);\n"]} | ||
export const PowerToolsLoggerLayer = BasePowerToolsLoggerLayer.pipe(Layer.use(LoggerInstanceLayer)); | ||
/** | ||
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance. | ||
*/ | ||
export const DefaultPowerToolsLoggerLayer = PowerToolsLoggerLayer.pipe(Layer.use(DefaultLoggerOptionsLayer)); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../../src/Logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from \"@aws-lambda-powertools/logger\";\nimport type {\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport * as HashMap from \"@effect/data/HashMap\";\nimport * as List from \"@effect/data/List\";\nimport * as Cause from \"@effect/io/Cause\";\nimport * as Effect from \"@effect/io/Effect\";\nimport * as FiberId from \"@effect/io/FiberId\";\nimport * as FiberRef from \"@effect/io/FiberRef\";\nimport * as FiberRefs from \"@effect/io/FiberRefs\";\nimport * as Layer from \"@effect/io/Layer\";\nimport * as Log from \"@effect/io/Logger\";\nimport * as LogLevel from \"@effect/io/LogLevel\";\nimport {\n  DefaultLoggerOptionsLayer,\n  LoggerInstanceLayer,\n  LoggerInstanceTag,\n} from \"./Context\";\n\nconst logExtraInput = FiberRef.unsafeMake<LogItemExtraInput>([]);\n\nconst processLog = (\n  effect: (message: string) => Effect.Effect<never, never, void>,\n) => {\n  return (input: LogItemMessage, ...extraInput: LogItemExtraInput) => {\n    const message = typeof input === \"string\" ? input : input.message;\n\n    const extraInputs =\n      typeof input === \"string\" ? extraInput : [input, ...extraInput];\n\n    return Effect.locally(effect(message), logExtraInput, extraInputs);\n  };\n};\n\n/**\n * Logs the specified message at the debug log level.\n * It prints a log item with level DEBUG.\n */\nexport const logDebug = processLog(Effect.logDebug);\n/**\n * Logs the specified message at the info log level.\n * It prints a log item with level INFO.\n */\nexport const logInfo = processLog(Effect.logInfo);\n/**\n * Logs the specified message at the warning log level.\n * It prints a log item with level WARN.\n */\nexport const logWarning = processLog(Effect.logWarning);\n/**\n * Logs the specified message at the error log level.\n * It prints a log item with level ERROR.\n */\nexport const logError = processLog(Effect.logError);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n */\nexport const logFatal = processLog(Effect.logFatal);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n * @alias logFatal\n */\nexport const logCritical = processLog(Effect.logFatal);\n\nconst powerToolsImpl = (logger: Logger) => {\n  return Log.make<unknown, void>((options) => {\n    const [...extraInputs] = FiberRefs.getOrDefault(\n      options.context,\n      logExtraInput,\n    );\n\n    const nowMillis = options.date.getTime();\n\n    extraInputs.push({\n      fiber: FiberId.threadName(options.fiberId),\n      timestamp: options.date.toISOString(),\n      ...(Cause.isEmpty(options.cause)\n        ? {}\n        : { cause: Cause.pretty(options.cause) }),\n      ...List.reduce(options.spans, {}, (acc, span) => ({\n        ...acc,\n        [span.label]: `${nowMillis - span.startTime}ms`,\n      })),\n      ...HashMap.reduce(options.annotations, {}, (acc, value, key) => ({\n        ...acc,\n        [key]: value,\n      })),\n    });\n\n    const unsafeLogger = logger as any;\n\n    unsafeLogger.processLogItem(\n      unsafeLogger.logLevelThresholds[\n        options.logLevel.label === \"FATAL\" ? \"CRITICAL\" : options.logLevel.label\n      ],\n      options.message,\n      extraInputs,\n    );\n  });\n};\n\nconst PowerToolsLoggerEffect = LoggerInstanceTag.pipe(\n  Effect.map(powerToolsImpl),\n);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.\n */\nexport const BasePowerToolsLoggerLayer = Layer.merge(\n  Log.replaceEffect(Log.defaultLogger, PowerToolsLoggerEffect),\n  Log.minimumLogLevel(LogLevel.All),\n);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance configured by logger options layer.\n */\nexport const PowerToolsLoggerLayer = BasePowerToolsLoggerLayer.pipe(\n  Layer.use(LoggerInstanceLayer),\n);\n\n/**\n * Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.\n */\nexport const DefaultPowerToolsLoggerLayer = PowerToolsLoggerLayer.pipe(\n  Layer.use(DefaultLoggerOptionsLayer),\n);\n"]} |
@@ -0,1 +1,2 @@ | ||
export * from "./Context"; | ||
export * from "./Logger"; |
@@ -17,3 +17,4 @@ "use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
__exportStar(require("./Context"), exports); | ||
__exportStar(require("./Logger"), exports); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL0xvZ2dlclwiO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDRDQUEwQjtBQUMxQiwyQ0FBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9Db250ZXh0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9Mb2dnZXJcIjtcbiJdfQ== |
import { Logger } from "@aws-lambda-powertools/logger"; | ||
import type { LogItemExtraInput, LogItemMessage } from "@aws-lambda-powertools/logger/lib/types"; | ||
import * as Context from "@effect/data/Context"; | ||
import * as Effect from "@effect/io/Effect"; | ||
import * as Layer from "@effect/io/Layer"; | ||
import * as Log from "@effect/io/Logger"; | ||
export declare const LoggerInstanceTag: Context.Tag<Logger, Logger>; | ||
/** | ||
@@ -39,11 +36,13 @@ * Logs the specified message at the debug log level. | ||
export declare const logCritical: (input: LogItemMessage, ...extraInput: LogItemExtraInput) => Effect.Effect<never, never, void>; | ||
export declare const powerToolsImpl: (logger: Logger) => Log.Logger<unknown, void>; | ||
export declare const DefaultLoggerInstanceLayer: Layer.Layer<never, never, Logger>; | ||
/** | ||
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance. | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer. | ||
*/ | ||
export declare const PowerToolsDefaultLoggerLayer: Layer.Layer<never, never, never>; | ||
export declare const BasePowerToolsLoggerLayer: Layer.Layer<Logger, never, never>; | ||
/** | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer. | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance configured by logger options layer. | ||
*/ | ||
export declare const PowerToolsLoggerLayer: Layer.Layer<Logger, never, never>; | ||
export declare const PowerToolsLoggerLayer: Layer.Layer<import("./Context").LoggerOptions, never, never>; | ||
/** | ||
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance. | ||
*/ | ||
export declare const DefaultPowerToolsLoggerLayer: Layer.Layer<never, never, never>; |
@@ -26,5 +26,3 @@ "use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.PowerToolsLoggerLayer = exports.PowerToolsDefaultLoggerLayer = exports.DefaultLoggerInstanceLayer = exports.powerToolsImpl = exports.logCritical = exports.logFatal = exports.logError = exports.logWarning = exports.logInfo = exports.logDebug = exports.LoggerInstanceTag = void 0; | ||
const logger_1 = require("@aws-lambda-powertools/logger"); | ||
const Context = __importStar(require("@effect/data/Context")); | ||
exports.DefaultPowerToolsLoggerLayer = exports.PowerToolsLoggerLayer = exports.BasePowerToolsLoggerLayer = exports.logCritical = exports.logFatal = exports.logError = exports.logWarning = exports.logInfo = exports.logDebug = void 0; | ||
const HashMap = __importStar(require("@effect/data/HashMap")); | ||
@@ -40,3 +38,3 @@ const List = __importStar(require("@effect/data/List")); | ||
const LogLevel = __importStar(require("@effect/io/LogLevel")); | ||
exports.LoggerInstanceTag = Context.Tag("@effect-aws/Powertools/Logger"); | ||
const Context_1 = require("./Context"); | ||
const logExtraInput = FiberRef.unsafeMake([]); | ||
@@ -104,14 +102,15 @@ const processLog = (effect) => { | ||
}; | ||
exports.powerToolsImpl = powerToolsImpl; | ||
exports.DefaultLoggerInstanceLayer = Layer.succeed(exports.LoggerInstanceTag, new logger_1.Logger()); | ||
const PowerToolsLogger = exports.LoggerInstanceTag.pipe(Effect.map(exports.powerToolsImpl)); | ||
const PowerToolsDefaultLogger = PowerToolsLogger.pipe(Effect.provideLayer(exports.DefaultLoggerInstanceLayer)); | ||
const PowerToolsLoggerEffect = Context_1.LoggerInstanceTag.pipe(Effect.map(powerToolsImpl)); | ||
/** | ||
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance. | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer. | ||
*/ | ||
exports.PowerToolsDefaultLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger), Log.minimumLogLevel(LogLevel.All)); | ||
exports.BasePowerToolsLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsLoggerEffect), Log.minimumLogLevel(LogLevel.All)); | ||
/** | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer. | ||
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance configured by logger options layer. | ||
*/ | ||
exports.PowerToolsLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsLogger), Log.minimumLogLevel(LogLevel.All)); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from \"@aws-lambda-powertools/logger\";\nimport type {\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport * as Context from \"@effect/data/Context\";\nimport * as HashMap from \"@effect/data/HashMap\";\nimport * as List from \"@effect/data/List\";\nimport * as Cause from \"@effect/io/Cause\";\nimport * as Effect from \"@effect/io/Effect\";\nimport * as FiberId from \"@effect/io/FiberId\";\nimport * as FiberRef from \"@effect/io/FiberRef\";\nimport * as FiberRefs from \"@effect/io/FiberRefs\";\nimport * as Layer from \"@effect/io/Layer\";\nimport * as Log from \"@effect/io/Logger\";\nimport * as LogLevel from \"@effect/io/LogLevel\";\n\nexport const LoggerInstanceTag = Context.Tag<Logger>(\n  \"@effect-aws/Powertools/Logger\",\n);\n\nconst logExtraInput = FiberRef.unsafeMake<LogItemExtraInput>([]);\n\nconst processLog = (\n  effect: (message: string) => Effect.Effect<never, never, void>,\n) => {\n  return (input: LogItemMessage, ...extraInput: LogItemExtraInput) => {\n    const message = typeof input === \"string\" ? input : input.message;\n\n    const extraInputs =\n      typeof input === \"string\" ? extraInput : [input, ...extraInput];\n\n    return Effect.locally(effect(message), logExtraInput, extraInputs);\n  };\n};\n\n/**\n * Logs the specified message at the debug log level.\n * It prints a log item with level DEBUG.\n */\nexport const logDebug = processLog(Effect.logDebug);\n/**\n * Logs the specified message at the info log level.\n * It prints a log item with level INFO.\n */\nexport const logInfo = processLog(Effect.logInfo);\n/**\n * Logs the specified message at the warning log level.\n * It prints a log item with level WARN.\n */\nexport const logWarning = processLog(Effect.logWarning);\n/**\n * Logs the specified message at the error log level.\n * It prints a log item with level ERROR.\n */\nexport const logError = processLog(Effect.logError);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n */\nexport const logFatal = processLog(Effect.logFatal);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n * @alias logFatal\n */\nexport const logCritical = processLog(Effect.logFatal);\n\nexport const powerToolsImpl = (logger: Logger) => {\n  return Log.make<unknown, void>((options) => {\n    const [...extraInputs] = FiberRefs.getOrDefault(\n      options.context,\n      logExtraInput,\n    );\n\n    const nowMillis = options.date.getTime();\n\n    extraInputs.push({\n      fiber: FiberId.threadName(options.fiberId),\n      timestamp: options.date.toISOString(),\n      ...(Cause.isEmpty(options.cause)\n        ? {}\n        : { cause: Cause.pretty(options.cause) }),\n      ...List.reduce(options.spans, {}, (acc, span) => ({\n        ...acc,\n        [span.label]: `${nowMillis - span.startTime}ms`,\n      })),\n      ...HashMap.reduce(options.annotations, {}, (acc, value, key) => ({\n        ...acc,\n        [key]: value,\n      })),\n    });\n\n    const unsafeLogger = logger as any;\n\n    unsafeLogger.processLogItem(\n      unsafeLogger.logLevelThresholds[\n        options.logLevel.label === \"FATAL\" ? \"CRITICAL\" : options.logLevel.label\n      ],\n      options.message,\n      extraInputs,\n    );\n  });\n};\n\nexport const DefaultLoggerInstanceLayer = Layer.succeed(\n  LoggerInstanceTag,\n  new Logger(),\n);\n\nconst PowerToolsLogger = LoggerInstanceTag.pipe(Effect.map(powerToolsImpl));\n\nconst PowerToolsDefaultLogger = PowerToolsLogger.pipe(\n  Effect.provideLayer(DefaultLoggerInstanceLayer),\n);\n\n/**\n * Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.\n */\nexport const PowerToolsDefaultLoggerLayer = Layer.merge(\n  Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger),\n  Log.minimumLogLevel(LogLevel.All), // Log level is controlled by the PowerTools Logger instance\n);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.\n */\nexport const PowerToolsLoggerLayer = Layer.merge(\n  Log.replaceEffect(Log.defaultLogger, PowerToolsLogger),\n  Log.minimumLogLevel(LogLevel.All),\n);\n"]} | ||
exports.PowerToolsLoggerLayer = exports.BasePowerToolsLoggerLayer.pipe(Layer.use(Context_1.LoggerInstanceLayer)); | ||
/** | ||
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance. | ||
*/ | ||
exports.DefaultPowerToolsLoggerLayer = exports.PowerToolsLoggerLayer.pipe(Layer.use(Context_1.DefaultLoggerOptionsLayer)); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from \"@aws-lambda-powertools/logger\";\nimport type {\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport * as HashMap from \"@effect/data/HashMap\";\nimport * as List from \"@effect/data/List\";\nimport * as Cause from \"@effect/io/Cause\";\nimport * as Effect from \"@effect/io/Effect\";\nimport * as FiberId from \"@effect/io/FiberId\";\nimport * as FiberRef from \"@effect/io/FiberRef\";\nimport * as FiberRefs from \"@effect/io/FiberRefs\";\nimport * as Layer from \"@effect/io/Layer\";\nimport * as Log from \"@effect/io/Logger\";\nimport * as LogLevel from \"@effect/io/LogLevel\";\nimport {\n  DefaultLoggerOptionsLayer,\n  LoggerInstanceLayer,\n  LoggerInstanceTag,\n} from \"./Context\";\n\nconst logExtraInput = FiberRef.unsafeMake<LogItemExtraInput>([]);\n\nconst processLog = (\n  effect: (message: string) => Effect.Effect<never, never, void>,\n) => {\n  return (input: LogItemMessage, ...extraInput: LogItemExtraInput) => {\n    const message = typeof input === \"string\" ? input : input.message;\n\n    const extraInputs =\n      typeof input === \"string\" ? extraInput : [input, ...extraInput];\n\n    return Effect.locally(effect(message), logExtraInput, extraInputs);\n  };\n};\n\n/**\n * Logs the specified message at the debug log level.\n * It prints a log item with level DEBUG.\n */\nexport const logDebug = processLog(Effect.logDebug);\n/**\n * Logs the specified message at the info log level.\n * It prints a log item with level INFO.\n */\nexport const logInfo = processLog(Effect.logInfo);\n/**\n * Logs the specified message at the warning log level.\n * It prints a log item with level WARN.\n */\nexport const logWarning = processLog(Effect.logWarning);\n/**\n * Logs the specified message at the error log level.\n * It prints a log item with level ERROR.\n */\nexport const logError = processLog(Effect.logError);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n */\nexport const logFatal = processLog(Effect.logFatal);\n/**\n * Logs the specified message at the fatal log level.\n * It prints a log item with level CRITICAL.\n * @alias logFatal\n */\nexport const logCritical = processLog(Effect.logFatal);\n\nconst powerToolsImpl = (logger: Logger) => {\n  return Log.make<unknown, void>((options) => {\n    const [...extraInputs] = FiberRefs.getOrDefault(\n      options.context,\n      logExtraInput,\n    );\n\n    const nowMillis = options.date.getTime();\n\n    extraInputs.push({\n      fiber: FiberId.threadName(options.fiberId),\n      timestamp: options.date.toISOString(),\n      ...(Cause.isEmpty(options.cause)\n        ? {}\n        : { cause: Cause.pretty(options.cause) }),\n      ...List.reduce(options.spans, {}, (acc, span) => ({\n        ...acc,\n        [span.label]: `${nowMillis - span.startTime}ms`,\n      })),\n      ...HashMap.reduce(options.annotations, {}, (acc, value, key) => ({\n        ...acc,\n        [key]: value,\n      })),\n    });\n\n    const unsafeLogger = logger as any;\n\n    unsafeLogger.processLogItem(\n      unsafeLogger.logLevelThresholds[\n        options.logLevel.label === \"FATAL\" ? \"CRITICAL\" : options.logLevel.label\n      ],\n      options.message,\n      extraInputs,\n    );\n  });\n};\n\nconst PowerToolsLoggerEffect = LoggerInstanceTag.pipe(\n  Effect.map(powerToolsImpl),\n);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.\n */\nexport const BasePowerToolsLoggerLayer = Layer.merge(\n  Log.replaceEffect(Log.defaultLogger, PowerToolsLoggerEffect),\n  Log.minimumLogLevel(LogLevel.All),\n);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance configured by logger options layer.\n */\nexport const PowerToolsLoggerLayer = BasePowerToolsLoggerLayer.pipe(\n  Layer.use(LoggerInstanceLayer),\n);\n\n/**\n * Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.\n */\nexport const DefaultPowerToolsLoggerLayer = PowerToolsLoggerLayer.pipe(\n  Layer.use(DefaultLoggerOptionsLayer),\n);\n"]} |
@@ -24,3 +24,3 @@ { | ||
"prettier": "^3.0.3", | ||
"projen": "^0.73.24", | ||
"projen": "^0.73.25", | ||
"ts-jest": "^29.1.1", | ||
@@ -41,3 +41,3 @@ "typescript": "^5.2.2" | ||
}, | ||
"version": "0.2.1", | ||
"version": "0.3.0", | ||
"types": "lib/index.d.ts", | ||
@@ -44,0 +44,0 @@ "module": "lib/esm/index.js", |
@@ -25,3 +25,3 @@ # @effect-aws/powertools-logger | ||
program, | ||
Effect.provideLayer(Logger.PowerToolsDefaultLoggerLayer), | ||
Effect.provideLayer(Logger.DefaultPowerToolsLoggerLayer), | ||
Effect.runPromise, | ||
@@ -31,2 +31,25 @@ ); | ||
With custom PowerTools Logger options: | ||
```typescript | ||
import { pipe } from "@effect/data/Function"; | ||
import * as Effect from "@effect/io/Effect"; | ||
import * as Logger from "@effect-aws/powertools-logger"; | ||
const program = pipe( | ||
Logger.logDebug("Debug message with log meta", { foo: "bar" }), | ||
Effect.tap(() => Effect.logDebug("Native effect debug message")), | ||
); | ||
const result = pipe( | ||
program, | ||
Effect.provideLayer(Logger.PowerToolsLoggerLayer), | ||
Effect.provideService( | ||
Logger.LoggerOptionsTag, | ||
new Logger.LoggerOptions({ logLevel: "DEBUG" }), | ||
), | ||
Effect.runPromise, | ||
); | ||
``` | ||
With custom PowerTools Logger instance: | ||
@@ -47,3 +70,3 @@ | ||
program, | ||
Effect.provideLayer(Logger.PowerToolsLoggerLayer), | ||
Effect.provideLayer(Logger.BasePowerToolsLoggerLayer), | ||
Effect.provideService( | ||
@@ -50,0 +73,0 @@ Logger.LoggerInstanceTag, |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
49687
17
414
76