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.6.0 to 1.0.0

lib/esm/LoggerInstance.js

6

CHANGELOG.md
# @effect-aws/powertools-logger
## 1.0.0
### Major Changes
- [`3e5d0b3`](https://github.com/floydspace/effect-aws/commit/3e5d0b3b3882e0aa6d07bc06432990551316ac30) Thanks [@floydspace](https://github.com/floydspace)! - Upgrade to effect v2 and release stable version
## 0.6.0

@@ -4,0 +10,0 @@

5

lib/esm/index.js

@@ -1,3 +0,4 @@

export * from "./Context";
export * from "./LoggerOptions";
export * from "./LoggerInstance";
export * from "./Logger";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9Db250ZXh0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9Mb2dnZXJcIjtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vTG9nZ2VyT3B0aW9uc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vTG9nZ2VySW5zdGFuY2VcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0xvZ2dlclwiO1xuIl19

33

lib/esm/Logger.js

@@ -1,12 +0,4 @@

import * as Cause from "effect/Cause";
import * as Effect from "effect/Effect";
import * as FiberId from "effect/FiberId";
import * as FiberRef from "effect/FiberRef";
import * as FiberRefs from "effect/FiberRefs";
import * as HashMap from "effect/HashMap";
import * as Layer from "effect/Layer";
import * as List from "effect/List";
import * as Log from "effect/Logger";
import * as LogLevel from "effect/LogLevel";
import { DefaultLoggerOptionsLayer, LoggerInstanceLayer, LoggerInstanceTag, } from "./Context";
import { Cause, Effect, FiberId, FiberRef, FiberRefs, HashMap, Layer, List, Logger as Log, LogLevel, } from "effect";
import { LoggerInstance, LoggerInstanceLayer } from "./LoggerInstance";
import { DefaultLoggerOptionsLayer } from "./LoggerOptions";
const logExtraInput = FiberRef.unsafeMake([]);

@@ -51,3 +43,7 @@ const processLog = (effect) => {

export const logCritical = processLog(Effect.logFatal);
const powerToolsImpl = (logger) => {
/**
* @since 1.0.0
* @category constructors
*/
const makeLoggerInstance = (logger) => {
return Log.make((options) => {

@@ -75,5 +71,8 @@ const [...extraInputs] = FiberRefs.getOrDefault(options.context, logExtraInput);

};
const PowerToolsLoggerEffect = LoggerInstanceTag.pipe(Effect.map(powerToolsImpl));
const PowerToolsLoggerEffect = Effect.map(LoggerInstance, makeLoggerInstance);
/**
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.
*
* @since 1.0.0
* @category layers
*/

@@ -83,2 +82,5 @@ 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 configured by logger options layer.
*
* @since 1.0.0
* @category layers
*/

@@ -88,4 +90,7 @@ export const PowerToolsLoggerLayer = BasePowerToolsLoggerLayer.pipe(Layer.provide(LoggerInstanceLayer));

* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.
*
* @since 1.0.0
* @category layers
*/
export const DefaultPowerToolsLoggerLayer = PowerToolsLoggerLayer.pipe(Layer.provide(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  LogAttributes,\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport * as Cause from \"effect/Cause\";\nimport * as Effect from \"effect/Effect\";\nimport * as FiberId from \"effect/FiberId\";\nimport * as FiberRef from \"effect/FiberRef\";\nimport * as FiberRefs from \"effect/FiberRefs\";\nimport * as HashMap from \"effect/HashMap\";\nimport * as Layer from \"effect/Layer\";\nimport * as List from \"effect/List\";\nimport * as Log from \"effect/Logger\";\nimport * as LogLevel from \"effect/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: LogAttributes[]) => {\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.provide(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.provide(DefaultLoggerOptionsLayer),\n);\n"]}
//# 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  LogAttributes,\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport {\n  Cause,\n  Effect,\n  FiberId,\n  FiberRef,\n  FiberRefs,\n  HashMap,\n  Layer,\n  List,\n  Logger as Log,\n  LogLevel,\n} from \"effect\";\nimport { LoggerInstance, LoggerInstanceLayer } from \"./LoggerInstance\";\nimport { DefaultLoggerOptionsLayer } from \"./LoggerOptions\";\n\nconst logExtraInput = FiberRef.unsafeMake<LogItemExtraInput>([]);\n\nconst processLog = (\n  effect: (message: string) => Effect.Effect<never, never, void>,\n) => {\n  return (input: LogItemMessage, ...extraInput: LogAttributes[]) => {\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\n/**\n * @since 1.0.0\n * @category constructors\n */\nconst makeLoggerInstance = (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 = Effect.map(LoggerInstance, makeLoggerInstance);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.\n *\n * @since 1.0.0\n * @category layers\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 *\n * @since 1.0.0\n * @category layers\n */\nexport const PowerToolsLoggerLayer = BasePowerToolsLoggerLayer.pipe(\n  Layer.provide(LoggerInstanceLayer),\n);\n\n/**\n * Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.\n *\n * @since 1.0.0\n * @category layers\n */\nexport const DefaultPowerToolsLoggerLayer = PowerToolsLoggerLayer.pipe(\n  Layer.provide(DefaultLoggerOptionsLayer),\n);\n"]}

@@ -1,2 +0,3 @@

export * from "./Context";
export * from "./LoggerOptions";
export * from "./LoggerInstance";
export * from "./Logger";

@@ -17,4 +17,5 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
__exportStar(require("./Context"), exports);
__exportStar(require("./LoggerOptions"), exports);
__exportStar(require("./LoggerInstance"), exports);
__exportStar(require("./Logger"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDRDQUEwQjtBQUMxQiwyQ0FBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9Db250ZXh0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9Mb2dnZXJcIjtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGtEQUFnQztBQUNoQyxtREFBaUM7QUFDakMsMkNBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vTG9nZ2VyT3B0aW9uc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vTG9nZ2VySW5zdGFuY2VcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0xvZ2dlclwiO1xuIl19

@@ -1,5 +0,4 @@

import { Logger } from "@aws-lambda-powertools/logger";
import type { LogAttributes, LogItemMessage } from "@aws-lambda-powertools/logger/lib/types";
import * as Effect from "effect/Effect";
import * as Layer from "effect/Layer";
import { Effect, Layer } from "effect";
import { LoggerInstance } from "./LoggerInstance";
/**

@@ -38,11 +37,20 @@ * Logs the specified message at the debug log level.

* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.
*
* @since 1.0.0
* @category layers
*/
export declare const BasePowerToolsLoggerLayer: Layer.Layer<Logger, never, never>;
export declare const BasePowerToolsLoggerLayer: Layer.Layer<LoggerInstance, never, never>;
/**
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance configured by logger options layer.
*
* @since 1.0.0
* @category layers
*/
export declare const PowerToolsLoggerLayer: Layer.Layer<import("./Context").LoggerOptions, never, never>;
export declare const PowerToolsLoggerLayer: Layer.Layer<import("./LoggerOptions").LoggerOptions, never, never>;
/**
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.
*
* @since 1.0.0
* @category layers
*/
export declare const DefaultPowerToolsLoggerLayer: Layer.Layer<never, never, never>;
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.DefaultPowerToolsLoggerLayer = exports.PowerToolsLoggerLayer = exports.BasePowerToolsLoggerLayer = exports.logCritical = exports.logFatal = exports.logError = exports.logWarning = exports.logInfo = exports.logDebug = void 0;
const Cause = __importStar(require("effect/Cause"));
const Effect = __importStar(require("effect/Effect"));
const FiberId = __importStar(require("effect/FiberId"));
const FiberRef = __importStar(require("effect/FiberRef"));
const FiberRefs = __importStar(require("effect/FiberRefs"));
const HashMap = __importStar(require("effect/HashMap"));
const Layer = __importStar(require("effect/Layer"));
const List = __importStar(require("effect/List"));
const Log = __importStar(require("effect/Logger"));
const LogLevel = __importStar(require("effect/LogLevel"));
const Context_1 = require("./Context");
const logExtraInput = FiberRef.unsafeMake([]);
const effect_1 = require("effect");
const LoggerInstance_1 = require("./LoggerInstance");
const LoggerOptions_1 = require("./LoggerOptions");
const logExtraInput = effect_1.FiberRef.unsafeMake([]);
const processLog = (effect) => {

@@ -43,3 +12,3 @@ return (input, ...extraInput) => {

const extraInputs = typeof input === "string" ? extraInput : [input, ...extraInput];
return Effect.locally(effect(message), logExtraInput, extraInputs);
return effect_1.Effect.locally(effect(message), logExtraInput, extraInputs);
};

@@ -51,3 +20,3 @@ };

*/
exports.logDebug = processLog(Effect.logDebug);
exports.logDebug = processLog(effect_1.Effect.logDebug);
/**

@@ -57,3 +26,3 @@ * Logs the specified message at the info log level.

*/
exports.logInfo = processLog(Effect.logInfo);
exports.logInfo = processLog(effect_1.Effect.logInfo);
/**

@@ -63,3 +32,3 @@ * Logs the specified message at the warning log level.

*/
exports.logWarning = processLog(Effect.logWarning);
exports.logWarning = processLog(effect_1.Effect.logWarning);
/**

@@ -69,3 +38,3 @@ * Logs the specified message at the error log level.

*/
exports.logError = processLog(Effect.logError);
exports.logError = processLog(effect_1.Effect.logError);
/**

@@ -75,3 +44,3 @@ * Logs the specified message at the fatal log level.

*/
exports.logFatal = processLog(Effect.logFatal);
exports.logFatal = processLog(effect_1.Effect.logFatal);
/**

@@ -82,18 +51,22 @@ * Logs the specified message at the fatal log level.

*/
exports.logCritical = processLog(Effect.logFatal);
const powerToolsImpl = (logger) => {
return Log.make((options) => {
const [...extraInputs] = FiberRefs.getOrDefault(options.context, logExtraInput);
exports.logCritical = processLog(effect_1.Effect.logFatal);
/**
* @since 1.0.0
* @category constructors
*/
const makeLoggerInstance = (logger) => {
return effect_1.Logger.make((options) => {
const [...extraInputs] = effect_1.FiberRefs.getOrDefault(options.context, logExtraInput);
const nowMillis = options.date.getTime();
extraInputs.push({
fiber: FiberId.threadName(options.fiberId),
fiber: effect_1.FiberId.threadName(options.fiberId),
timestamp: options.date.toISOString(),
...(Cause.isEmpty(options.cause)
...(effect_1.Cause.isEmpty(options.cause)
? {}
: { cause: Cause.pretty(options.cause) }),
...List.reduce(options.spans, {}, (acc, span) => ({
: { cause: effect_1.Cause.pretty(options.cause) }),
...effect_1.List.reduce(options.spans, {}, (acc, span) => ({
...acc,
[span.label]: `${nowMillis - span.startTime}ms`,
})),
...HashMap.reduce(options.annotations, {}, (acc, value, key) => ({
...effect_1.HashMap.reduce(options.annotations, {}, (acc, value, key) => ({
...acc,

@@ -107,15 +80,24 @@ [key]: value,

};
const PowerToolsLoggerEffect = Context_1.LoggerInstanceTag.pipe(Effect.map(powerToolsImpl));
const PowerToolsLoggerEffect = effect_1.Effect.map(LoggerInstance_1.LoggerInstance, makeLoggerInstance);
/**
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.
*
* @since 1.0.0
* @category layers
*/
exports.BasePowerToolsLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsLoggerEffect), Log.minimumLogLevel(LogLevel.All));
exports.BasePowerToolsLoggerLayer = effect_1.Layer.merge(effect_1.Logger.replaceEffect(effect_1.Logger.defaultLogger, PowerToolsLoggerEffect), effect_1.Logger.minimumLogLevel(effect_1.LogLevel.All));
/**
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance configured by logger options layer.
*
* @since 1.0.0
* @category layers
*/
exports.PowerToolsLoggerLayer = exports.BasePowerToolsLoggerLayer.pipe(Layer.provide(Context_1.LoggerInstanceLayer));
exports.PowerToolsLoggerLayer = exports.BasePowerToolsLoggerLayer.pipe(effect_1.Layer.provide(LoggerInstance_1.LoggerInstanceLayer));
/**
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.
*
* @since 1.0.0
* @category layers
*/
exports.DefaultPowerToolsLoggerLayer = exports.PowerToolsLoggerLayer.pipe(Layer.provide(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  LogAttributes,\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport * as Cause from \"effect/Cause\";\nimport * as Effect from \"effect/Effect\";\nimport * as FiberId from \"effect/FiberId\";\nimport * as FiberRef from \"effect/FiberRef\";\nimport * as FiberRefs from \"effect/FiberRefs\";\nimport * as HashMap from \"effect/HashMap\";\nimport * as Layer from \"effect/Layer\";\nimport * as List from \"effect/List\";\nimport * as Log from \"effect/Logger\";\nimport * as LogLevel from \"effect/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: LogAttributes[]) => {\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.provide(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.provide(DefaultLoggerOptionsLayer),\n);\n"]}
exports.DefaultPowerToolsLoggerLayer = exports.PowerToolsLoggerLayer.pipe(effect_1.Layer.provide(LoggerOptions_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  LogAttributes,\n  LogItemExtraInput,\n  LogItemMessage,\n} from \"@aws-lambda-powertools/logger/lib/types\";\nimport {\n  Cause,\n  Effect,\n  FiberId,\n  FiberRef,\n  FiberRefs,\n  HashMap,\n  Layer,\n  List,\n  Logger as Log,\n  LogLevel,\n} from \"effect\";\nimport { LoggerInstance, LoggerInstanceLayer } from \"./LoggerInstance\";\nimport { DefaultLoggerOptionsLayer } from \"./LoggerOptions\";\n\nconst logExtraInput = FiberRef.unsafeMake<LogItemExtraInput>([]);\n\nconst processLog = (\n  effect: (message: string) => Effect.Effect<never, never, void>,\n) => {\n  return (input: LogItemMessage, ...extraInput: LogAttributes[]) => {\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\n/**\n * @since 1.0.0\n * @category constructors\n */\nconst makeLoggerInstance = (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 = Effect.map(LoggerInstance, makeLoggerInstance);\n\n/**\n * Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.\n *\n * @since 1.0.0\n * @category layers\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 *\n * @since 1.0.0\n * @category layers\n */\nexport const PowerToolsLoggerLayer = BasePowerToolsLoggerLayer.pipe(\n  Layer.provide(LoggerInstanceLayer),\n);\n\n/**\n * Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.\n *\n * @since 1.0.0\n * @category layers\n */\nexport const DefaultPowerToolsLoggerLayer = PowerToolsLoggerLayer.pipe(\n  Layer.provide(DefaultLoggerOptionsLayer),\n);\n"]}

@@ -14,3 +14,3 @@ {

"@typescript-eslint/parser": "^6",
"effect": "2.0.0-next.60",
"effect": "2.0.1",
"eslint": "^8",

@@ -29,3 +29,3 @@ "eslint-config-prettier": "^9.0.0",

"peerDependencies": {
"effect": "^2.0.0-next.60"
"effect": "^2.0.1"
},

@@ -40,3 +40,3 @@ "dependencies": {

},
"version": "0.6.0",
"version": "1.0.0",
"types": "lib/index.d.ts",

@@ -43,0 +43,0 @@ "module": "lib/esm/index.js",

Sorry, the diff of this file is not supported yet

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