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.0 to 0.2.1

6

CHANGELOG.md
# @effect-aws/powertools-logger
## 0.2.1
### Patch Changes
- [`3d37bc9`](https://github.com/floydspace/effect-aws/commit/3d37bc931118d2b55558b54727022445b39438a9) Thanks [@floydspace](https://github.com/floydspace)! - fix breaking change occurred in powertools logger version 1.9.0 and drop support of lower versions
## 0.2.0

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

13

lib/esm/Logger.js

@@ -12,2 +12,3 @@ import { Logger } from "@aws-lambda-powertools/logger";

import * as Log from "@effect/io/Logger";
import * as LogLevel from "@effect/io/LogLevel";
export const LoggerInstanceTag = Context.Tag("@effect-aws/Powertools/Logger");

@@ -72,15 +73,17 @@ const logExtraInput = FiberRef.unsafeMake([]);

});
logger.processLogItem(options.logLevel.label === "FATAL" ? "CRITICAL" : options.logLevel.label, options.message, extraInputs);
const unsafeLogger = logger;
unsafeLogger.processLogItem(unsafeLogger.logLevelThresholds[options.logLevel.label === "FATAL" ? "CRITICAL" : options.logLevel.label], options.message, extraInputs);
});
};
export const DefaultLoggerInstanceLayer = Layer.succeed(LoggerInstanceTag, new Logger());
const PowerToolsDefaultLogger = LoggerInstanceTag.pipe(Effect.map(powerToolsImpl), Effect.provideLayer(DefaultLoggerInstanceLayer));
const PowerToolsLogger = LoggerInstanceTag.pipe(Effect.map(powerToolsImpl));
const PowerToolsDefaultLogger = PowerToolsLogger.pipe(Effect.provideLayer(DefaultLoggerInstanceLayer));
/**
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.
*/
export const PowerToolsDefaultLoggerLayer = Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger);
export const PowerToolsDefaultLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger), Log.minimumLogLevel(LogLevel.All));
/**
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.
*/
export const PowerToolsLoggerLayer = Log.replaceEffect(Log.defaultLogger, LoggerInstanceTag.pipe(Effect.map(powerToolsImpl)));
//# 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\";\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    (logger as any).processLogItem(\n      options.logLevel.label === \"FATAL\" ? \"CRITICAL\" : options.logLevel.label,\n      options.message,\n      extraInputs,\n    );\n  });\n};\n\nexport const DefaultLoggerInstanceLayer = Layer.succeed(\n  LoggerInstanceTag,\n  new Logger(),\n);\n\nconst PowerToolsDefaultLogger = LoggerInstanceTag.pipe(\n  Effect.map(powerToolsImpl),\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 = Log.replaceEffect(\n  Log.defaultLogger,\n  PowerToolsDefaultLogger,\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 = Log.replaceEffect(\n  Log.defaultLogger,\n  LoggerInstanceTag.pipe(Effect.map(powerToolsImpl)),\n);\n"]}
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"]}

@@ -38,2 +38,3 @@ "use strict";

const Log = __importStar(require("@effect/io/Logger"));
const LogLevel = __importStar(require("@effect/io/LogLevel"));
exports.LoggerInstanceTag = Context.Tag("@effect-aws/Powertools/Logger");

@@ -98,3 +99,4 @@ const logExtraInput = FiberRef.unsafeMake([]);

});
logger.processLogItem(options.logLevel.label === "FATAL" ? "CRITICAL" : options.logLevel.label, options.message, extraInputs);
const unsafeLogger = logger;
unsafeLogger.processLogItem(unsafeLogger.logLevelThresholds[options.logLevel.label === "FATAL" ? "CRITICAL" : options.logLevel.label], options.message, extraInputs);
});

@@ -104,11 +106,12 @@ };

exports.DefaultLoggerInstanceLayer = Layer.succeed(exports.LoggerInstanceTag, new logger_1.Logger());
const PowerToolsDefaultLogger = exports.LoggerInstanceTag.pipe(Effect.map(exports.powerToolsImpl), Effect.provideLayer(exports.DefaultLoggerInstanceLayer));
const PowerToolsLogger = exports.LoggerInstanceTag.pipe(Effect.map(exports.powerToolsImpl));
const PowerToolsDefaultLogger = PowerToolsLogger.pipe(Effect.provideLayer(exports.DefaultLoggerInstanceLayer));
/**
* Creates a logger layer implementation that uses the default AWS Lambda Powertools Logger instance.
*/
exports.PowerToolsDefaultLoggerLayer = Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger);
exports.PowerToolsDefaultLoggerLayer = Layer.merge(Log.replaceEffect(Log.defaultLogger, PowerToolsDefaultLogger), Log.minimumLogLevel(LogLevel.All));
/**
* Creates a logger layer implementation that uses the AWS Lambda Powertools Logger instance provided by implementation layer.
*/
exports.PowerToolsLoggerLayer = Log.replaceEffect(Log.defaultLogger, exports.LoggerInstanceTag.pipe(Effect.map(exports.powerToolsImpl)));
//# 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\";\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    (logger as any).processLogItem(\n      options.logLevel.label === \"FATAL\" ? \"CRITICAL\" : options.logLevel.label,\n      options.message,\n      extraInputs,\n    );\n  });\n};\n\nexport const DefaultLoggerInstanceLayer = Layer.succeed(\n  LoggerInstanceTag,\n  new Logger(),\n);\n\nconst PowerToolsDefaultLogger = LoggerInstanceTag.pipe(\n  Effect.map(powerToolsImpl),\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 = Log.replaceEffect(\n  Log.defaultLogger,\n  PowerToolsDefaultLogger,\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 = Log.replaceEffect(\n  Log.defaultLogger,\n  LoggerInstanceTag.pipe(Effect.map(powerToolsImpl)),\n);\n"]}
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"]}

@@ -12,2 +12,3 @@ {

"@types/aws-lambda": "^8.10.121",
"@types/jest": "^29.5.5",
"@types/node": "^16",

@@ -22,4 +23,6 @@ "@typescript-eslint/eslint-plugin": "^6",

"eslint-plugin-prettier": "^5.0.0",
"jest": "^29.7.0",
"prettier": "^3.0.3",
"projen": "^0.73.24",
"ts-jest": "^29.1.1",
"typescript": "^5.2.2"

@@ -32,3 +35,3 @@ },

"dependencies": {
"@aws-lambda-powertools/logger": "^1"
"@aws-lambda-powertools/logger": "^1.9.0"
},

@@ -40,3 +43,3 @@ "main": "lib/index.js",

},
"version": "0.2.0",
"version": "0.2.1",
"types": "lib/index.d.ts",

@@ -54,4 +57,5 @@ "module": "lib/esm/index.js",

"test": "npx projen test",
"test:watch": "npx projen test:watch",
"watch": "npx projen watch"
}
}

@@ -54,2 +54,9 @@ {

},
"test:watch": {
"executor": "nx:run-commands",
"options": {
"command": "pnpm exec projen test:watch",
"cwd": "packages/powertools-logger"
}
},
"watch": {

@@ -56,0 +63,0 @@ "executor": "nx:run-commands",

@@ -11,10 +11,43 @@ # @effect-aws/powertools-logger

With default PowerTools Logger instance:
```typescript
import { PowerToolsDefaultLoggerLayer } from "@effect-aws/powertools-logger";
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.logInfo("Info message with log meta", { foo: "bar" }),
Effect.tap(() => Effect.logInfo("Native effect info message")),
);
const result = pipe(
program,
Effect.provideLayer(PowerToolsDefaultLoggerLayer),
Effect.provideLayer(Logger.PowerToolsDefaultLoggerLayer),
Effect.runPromise,
);
```
With custom PowerTools Logger instance:
```typescript
import { Logger as LoggerCtor } from "@aws-lambda-powertools/logger";
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.LoggerInstanceTag,
new LoggerCtor({ logLevel: "DEBUG" }),
),
Effect.runPromise,
);
```

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