Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@effect-aws/powertools-logger

Package Overview
Dependencies
Maintainers
1
Versions
18
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@effect-aws/powertools-logger - npm Package Compare versions

Comparing version 0.2.1 to 0.3.0

lib/Context.d.ts

6

CHANGELOG.md
# @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 @@

3

lib/esm/index.js

@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,0DAAuD;AAKvD,8DAAgD;AAChD,8DAAgD;AAChD,wDAA0C;AAC1C,wDAA0C;AAC1C,0DAA4C;AAC5C,4DAA8C;AAC9C,8DAAgD;AAChD,gEAAkD;AAClD,wDAA0C;AAC1C,uDAAyC;AACzC,8DAAgD;AAEnC,QAAA,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAC1C,+BAA+B,CAChC,CAAC;AAEF,MAAM,aAAa,GAAG,QAAQ,CAAC,UAAU,CAAoB,EAAE,CAAC,CAAC;AAEjE,MAAM,UAAU,GAAG,CACjB,MAA8D,EAC9D,EAAE;IACF,OAAO,CAAC,KAAqB,EAAE,GAAG,UAA6B,EAAE,EAAE;QACjE,MAAM,OAAO,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC;QAElE,MAAM,WAAW,GACf,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,GAAG,UAAU,CAAC,CAAC;QAElE,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;IACrE,CAAC,CAAC;AACJ,CAAC,CAAC;AAEF;;;GAGG;AACU,QAAA,QAAQ,GAAG,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AACpD;;;GAGG;AACU,QAAA,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;AAClD;;;GAGG;AACU,QAAA,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;AACxD;;;GAGG;AACU,QAAA,QAAQ,GAAG,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AACpD;;;GAGG;AACU,QAAA,QAAQ,GAAG,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AACpD;;;;GAIG;AACU,QAAA,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AAEhD,MAAM,cAAc,GAAG,CAAC,MAAc,EAAE,EAAE;IAC/C,OAAO,GAAG,CAAC,IAAI,CAAgB,CAAC,OAAO,EAAE,EAAE;QACzC,MAAM,CAAC,GAAG,WAAW,CAAC,GAAG,SAAS,CAAC,YAAY,CAC7C,OAAO,CAAC,OAAO,EACf,aAAa,CACd,CAAC;QAEF,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;QAEzC,WAAW,CAAC,IAAI,CAAC;YACf,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC;YAC1C,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE;YACrC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC;gBAC9B,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3C,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;gBAChD,GAAG,GAAG;gBACN,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI;aAChD,CAAC,CAAC;YACH,GAAG,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;gBAC/D,GAAG,GAAG;gBACN,CAAC,GAAG,CAAC,EAAE,KAAK;aACb,CAAC,CAAC;SACJ,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,MAAa,CAAC;QAEnC,YAAY,CAAC,cAAc,CACzB,YAAY,CAAC,kBAAkB,CAC7B,OAAO,CAAC,QAAQ,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CACzE,EACD,OAAO,CAAC,OAAO,EACf,WAAW,CACZ,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAnCW,QAAA,cAAc,kBAmCzB;AAEW,QAAA,0BAA0B,GAAG,KAAK,CAAC,OAAO,CACrD,yBAAiB,EACjB,IAAI,eAAM,EAAE,CACb,CAAC;AAEF,MAAM,gBAAgB,GAAG,yBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,sBAAc,CAAC,CAAC,CAAC;AAE5E,MAAM,uBAAuB,GAAG,gBAAgB,CAAC,IAAI,CACnD,MAAM,CAAC,YAAY,CAAC,kCAA0B,CAAC,CAChD,CAAC;AAEF;;GAEG;AACU,QAAA,4BAA4B,GAAG,KAAK,CAAC,KAAK,CACrD,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,aAAa,EAAE,uBAAuB,CAAC,EAC7D,GAAG,CAAC,eAAe,CAAC,QAAQ,CAAC,GAAG,CAAC,CAClC,CAAC;AAEF;;GAEG;AACU,QAAA,qBAAqB,GAAG,KAAK,CAAC,KAAK,CAC9C,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,aAAa,EAAE,gBAAgB,CAAC,EACtD,GAAG,CAAC,eAAe,CAAC,QAAQ,CAAC,GAAG,CAAC,CAClC,CAAC","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,

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc