Skip to main content

The plugin for poetry that allows you to build zip packages suited for serverless deployment like AWS Lambda, Google App Engine, Azure App Service, and more...

Project description

Poetry Plugin Lambda Build

The plugin for poetry that allows you to build zip packages suited for serverless deployment like AWS Lambda, Google App Engine, Azure App Service, and more...

Additionally it provides docker container support for build inside container

Test

Installation

poetry self add poetry-plugin-lambda-build

Execution

Configure pyproject.toml with the following configuration. This is example for AWS Lambda configuration

[tool.poetry-plugin-lambda-build]
docker-image = "public.ecr.aws/sam/build-python3.11:latest-x86_64"
docker-network = "host"
layer-artifact-path = "artifacts/layer.zip"
layer-install-dir = "python"
function-artifact-path = "artifacts/function.zip"

Running ...

poetry build-lambda

will build function and layer packages for AWS Lambda deployment inside public.ecr.aws/sam/build-python3.11:latest-x86_64 container.

artifacts
├── function.zip
└── layer.zip

Running ...

poetry build-lambda docker-image="public.ecr.aws/sam/build-python3.12:latest-x86_64"

will override docker-image value in config

Configuration Examples

AWS Lambda - all in one - dependencies and function in the same zip package - Default

[tool.poetry-plugin-lambda-build]
package-artifact-path = "package.zip"

AWS Lambda - all in one - layer package

[tool.poetry-plugin-lambda-build]
package-install-dir = "python"
package-artifact-path = "layer.zip"

AWS Lambda - separated - separate layer package and function package

[tool.poetry-plugin-lambda-build]
layer-artifact-path = "layer.zip"
layer-install-dir = "python"
function-artifact-path = "function.zip"

AWS Lambda - separated - separate layer package and function package build in docker container

[tool.poetry-plugin-lambda-build]
docker-image = "public.ecr.aws/sam/build-python3.11:latest-x86_64"
docker-network = "host"
layer-artifact-path = "layer.zip"
layer-install-dir = "python"
function-artifact-path = "function.zip"

Help

poetry build-lambda help
Description:
  Execute to build lambda lambda artifacts

Usage:
  build-lambda [options] [--] [<docker-image> [<docker-entrypoint> [<docker-environment> [<docker-dns> [<docker-network> [<docker-network-mode> [<docker-platform> [<package-artifact-path> [<package-install-dir> [<function-artifact-path> [<function-install-dir> [<layer-artifact-path> [<layer-install-dir> [<only> [<without> [<with> [<zip-compresslevel> [<zip-compression> [<pre-install-script> [<dockerignore> [<dockerignore-file>]]]]]]]]]]]]]]]]]]]]]

Arguments:
  docker-image                   The image to run
  docker-entrypoint              The entrypoint for the container (comma separated string) [default: "/bin/bash"]
  docker-environment             Environment variables to set inside the container (comma separated string) ex. VAR_1=VALUE_1,VAR_2=VALUE_2
  docker-dns                     Set custom DNS servers (comma separated string)
  docker-network                 The name of the network this container will be connected to at creation time [default: "host"]
  docker-network-mode            Network-mode
  docker-platform                Platform in the format os[/arch[/variant]]. Only used if the method needs to pull the requested image.
  package-artifact-path          Output package path (default: package.zip). Set the '.zip' extension to wrap the artifact into a zip package otherwise, output will be created in the directory. [default: "package.zip"]
  package-install-dir            Installation directory inside artifact for single package [default: ""]
  function-artifact-path         Output function package path. Set the '.zip' extension to wrap the artifact into a zip package otherwise, output will be created in the directory.
  function-install-dir           Installation directory inside artifact for function package [default: ""]
  layer-artifact-path            Output layer package path. Set the '.zip' extension to wrap the artifact into a zip package otherwise, output will be created in the directory.
  layer-install-dir              Installation directory inside artifact for layer package [default: ""]
  only                           The only dependency groups to include
  without                        The dependency groups to ignore
  with                           The optional dependency groups to include
  zip-compresslevel              None (default for the given compression type) or an integer specifying the level to pass to the compressor. When using ZIP_STORED or ZIP_LZMA this keyword has no effect. When using ZIP_DEFLATED integers 0 through 9 are accepted. When using ZIP_BZIP2 integers 1 through 9 are accepted.
  zip-compression                ZIP_STORED (no compression), ZIP_DEFLATED (requires zlib), ZIP_BZIP2 (requires bz2) or ZIP_LZMA (requires lzma) [default: "ZIP_STORED"]
  pre-install-script             The script that is executed before installation.
  dockerignore                   Comma-separated list of patterns to ignore when copying files to container
  dockerignore-file              Path to a .dockerignore file to use for filtering files

Options:
      --no-checksum              Enable to suppress checksum checking
      --docker-network-disabled  Disable networking
  -h, --help                 Display help for the given command. When no command is given display help for the list command.
  -q, --quiet                Do not output any message.
  -V, --version              Display this application version.
      --ansi                 Force ANSI output.
      --no-ansi              Disable ANSI output.
  -n, --no-interaction       Do not ask any interactive question.
      --no-plugins           Disables plugins.
      --no-cache             Disables Poetry source caches.
  -C, --directory=DIRECTORY  The working directory for the Poetry command (defaults to the current working directory).
  -v|vv|vvv, --verbose       Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug.

Tips

Mac users with Docker Desktops

Make sure to configure DOCKER_HOST properly

export DOCKER_HOST=unix:///Users/$USER/.docker/run/docker.sock

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

poetry_plugin_lambda_build-2.1.2.tar.gz (17.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

poetry_plugin_lambda_build-2.1.2-py3-none-any.whl (20.6 kB view details)

Uploaded Python 3

File details

Details for the file poetry_plugin_lambda_build-2.1.2.tar.gz.

File metadata

  • Download URL: poetry_plugin_lambda_build-2.1.2.tar.gz
  • Upload date:
  • Size: 17.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.13.9 Linux/6.11.0-1018-azure

File hashes

Hashes for poetry_plugin_lambda_build-2.1.2.tar.gz
Algorithm Hash digest
SHA256 240fb77c872dae3b0adcebab41c7a69038f2d5a7fbc05f52d285c12347a068c9
MD5 2dbb4d9fc20da42bbd599e5a591b8aa2
BLAKE2b-256 caee137dded002bf99a51c7f98fc3199bc2730542cc4f71e202cf67e3cf490d9

See more details on using hashes here.

File details

Details for the file poetry_plugin_lambda_build-2.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for poetry_plugin_lambda_build-2.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d3f1d2b1c18477660b7c6f02f41061d6ace652f4f61755b748be30c46636413b
MD5 f268a3e159d347f261019366c8244c9f
BLAKE2b-256 adf086d7e4db6a5a17fdd7417583f6072ee6032ee5f488b26414a6f8d903f5b1

See more details on using hashes here.

Supported by

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