Skip to main content

A lambda layer for AWS Powertools for python and typescript

Project description

AWS Lambda powertools layer

Why this project exists

This is a custom construct that will create AWS Lambda Layer with AWS Powertools for Python or NodeJS library. There are different ways how to create a layer and when working with CDK you need to install the library, create a zip file and wire it correctly. With this construct you don't have to care about packaging and dependency management. Create a construct and add it to your function. The construct is an extension of the existing LayerVersion construct from the CDK library, so you have access to all fields and methods.

⚠️ This construct uses docker to build and bundle the dependencies!

See the API for details.

import {LambdaPowertoolsLayer} from 'cdk-aws-lambda-powertools-layer';
import {RuntimeFamily } from "aws-cdk-lib/aws-lambda";

  const powertoolsLayerPython = new LambdaPowertoolsLayer(this, 'TestLayer', {runtimeFamily: RuntimeFamily.PYTHON});
  const powertoolsLayerNodeJS = new LambdaPowertoolsLayer(this, 'TestLayer', {runtimeFamily: RuntimeFamily.NODEJS});

Python

from cdk_aws_lambda_powertools_layer import LambdaPowertoolsLayer

powertoolsLayer = LambdaPowertoolsLayer(self, 'PowertoolsLayer')

The layer will be created during the CDK synth step and thus requires Docker.

Install

TypeSript/JavaScript:

npm i cdk-aws-lambda-powertools-layer

Python:

pip install cdk-aws-lambda-powertools-layer

Usage

Python

A single line will create a layer with powertools for python. For NodeJS you need to specifically set the runtimeFamily: Runtime.NODEJS property.

from cdk_aws_lambda_powertools_layer import LambdaPowertoolsLayer

powertoolsLayer = LambdaPowertoolsLayer(self, 'PowertoolsLayer')

You can then add the layer to your funciton:

from aws_cdk import aws_lambda

aws_lambda.Function(self, 'LambdaFunction',
                            code=aws_lambda.Code.from_asset('function'),
                            handler='app.handler',
                            layers=[powertoolsLayer])

You can specify the powertools version by passing the optional version paramter, otherwise the construct will take the latest version from pypi repository.

LambdaPowertoolsLayer(self, 'PowertoolsLayer', version='1.24.0')

Additionally, powertools have extras depenedncies such as Pydantic, documented here. This is not included by default, and you have to set this option in the construct definition if you need it:

LambdaPowertoolsLayer(self, 'PowertoolsLayer', include_extras=True)

Full example:

from aws_cdk import Stack, aws_lambda
from cdk_aws_lambda_powertools_layer import LambdaPowertoolsLayer
from constructs import Construct


class LayerTestStack(Stack):

    def __init__(self, scope: Construct, construct_id: str, **kwargs) -> None:
        super().__init__(scope, construct_id, **kwargs)

        powertoolsLayer = LambdaPowertoolsLayer(
            self, 'PowertoolsLayer', include_extras=True, version='1.24.0')

        aws_lambda.Function(self, 'LambdaFunction',
                            code=aws_lambda.Code.from_asset('function'),
                            handler='app.handler',
                            layers=[powertoolsLayer])

TypeScript

Full example for TypeScript:

import { Stack, StackProps } from 'aws-cdk-lib';
import { Construct } from 'constructs';
import { LambdaPowertoolsLayer } from 'cdk-aws-lambda-powertools-layer';
import { Code, Function, Runtime } from 'aws-cdk-lib/aws-lambda';
import * as path from 'path';

export class CdkPowertoolsExampleStack extends Stack {
  constructor(scope: Construct, id: string, props?: StackProps) {
    super(scope, id, props);

    const powertoolsLayer = new LambdaPowertoolsLayer(this, 'TestLayer', {
      version: '1.22.0',
      includeExtras: true
    });

    new Function(this, 'LambdaFunction', {
      code: Code.fromAsset(path.join('./function')),
      handler: 'app.handler',
      layers: [powertoolsLayer],
    });
  }
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cdk-aws-lambda-powertools-layer-3.2.0.tar.gz (30.8 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file cdk-aws-lambda-powertools-layer-3.2.0.tar.gz.

File metadata

File hashes

Hashes for cdk-aws-lambda-powertools-layer-3.2.0.tar.gz
Algorithm Hash digest
SHA256 75b86a6c8714c82293d754f1d799134c4159953711312e261f8b3aaf77492fa6
MD5 b1bd9544d5ce99557216e9f3193f9f03
BLAKE2b-256 5e2b69e99432ee1e9b7075020ec9c6c493895c4f7a81174e4851db1d99d88655

See more details on using hashes here.

File details

Details for the file cdk_aws_lambda_powertools_layer-3.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for cdk_aws_lambda_powertools_layer-3.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a293a2f42b459de70ccd9d2a16b0b0789f7c682aa31ab80d6696e93ff07caa92
MD5 3b305d1aab02b3ad39daaba837c90932
BLAKE2b-256 80dcc8c4e2a57d771891937594d94a46bc7dd7dd341400a3ec50c2af5584f95f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page