Class BundlingOptions.Builder

java.lang.Object
software.amazon.awscdk.services.lambda.python.alpha.BundlingOptions.Builder
All Implemented Interfaces:
software.amazon.jsii.Builder<BundlingOptions>
Enclosing interface:
BundlingOptions

@Stability(Experimental) public static final class BundlingOptions.Builder extends Object implements software.amazon.jsii.Builder<BundlingOptions>
A builder for BundlingOptions
  • Constructor Details

    • Builder

      public Builder()
  • Method Details

    • assetExcludes

      @Stability(Experimental) public BundlingOptions.Builder assetExcludes(List<String> assetExcludes)
      Parameters:
      assetExcludes - List of file patterns to exclude when copying assets from source for bundling.
      Returns:
      this
    • assetHash

      @Stability(Experimental) public BundlingOptions.Builder assetHash(String assetHash)
      Parameters:
      assetHash - Specify a custom hash for this asset. If assetHashType is set it must be set to AssetHashType.CUSTOM. For consistency, this custom hash will be SHA256 hashed and encoded as hex. The resulting hash will be the asset hash.

      NOTE: the hash is used in order to identify a specific revision of the asset, and used for optimizing and caching deployment activities related to this asset such as packaging, uploading to Amazon S3, etc. If you chose to customize the hash, you will need to make sure it is updated every time the asset changes, or otherwise it is possible that some deployments will not be invalidated.

      Returns:
      this
    • assetHashType

      @Stability(Experimental) public BundlingOptions.Builder assetHashType(AssetHashType assetHashType)
      Parameters:
      assetHashType - Determines how asset hash is calculated. Assets will get rebuild and uploaded only if their hash has changed. If asset hash is set to SOURCE (default), then only changes to the source directory will cause the asset to rebuild. This means, for example, that in order to pick up a new dependency version, a change must be made to the source tree. Ideally, this can be implemented by including a dependency lockfile in your source tree or using fixed dependencies.

      If the asset hash is set to OUTPUT, the hash is calculated after bundling. This means that any change in the output will cause the asset to be invalidated and uploaded. Bear in mind that pip adds timestamps to dependencies it installs, which implies that in this mode Python bundles will always get rebuild and uploaded. Normally this is an anti-pattern since build

      Returns:
      this
    • buildArgs

      @Stability(Experimental) public BundlingOptions.Builder buildArgs(Map<String,String> buildArgs)
      Parameters:
      buildArgs - Optional build arguments to pass to the default container. This can be used to customize the index URLs used for installing dependencies. This is not used if a custom image is provided.
      Returns:
      this
    • bundlingFileAccess

      @Stability(Experimental) public BundlingOptions.Builder bundlingFileAccess(BundlingFileAccess bundlingFileAccess)
      Parameters:
      bundlingFileAccess - Which option to use to copy the source files to the docker container and output files back.
      Returns:
      this
    • commandHooks

      @Stability(Experimental) public BundlingOptions.Builder commandHooks(ICommandHooks commandHooks)
      Parameters:
      commandHooks - Command hooks.
      Returns:
      this
    • image

      @Stability(Experimental) public BundlingOptions.Builder image(DockerImage image)
      Sets the value of BundlingOptions.getImage()
      Parameters:
      image - Docker image to use for bundling. If no options are provided, the default bundling image will be used. Dependencies will be installed using the default packaging commands and copied over from into the Lambda asset.
      Returns:
      this
    • outputPathSuffix

      @Stability(Experimental) public BundlingOptions.Builder outputPathSuffix(String outputPathSuffix)
      Parameters:
      outputPathSuffix - Output path suffix: the suffix for the directory into which the bundled output is written.
      Returns:
      this
    • poetryIncludeHashes

      @Stability(Experimental) public BundlingOptions.Builder poetryIncludeHashes(Boolean poetryIncludeHashes)
      Parameters:
      poetryIncludeHashes - Whether to export Poetry dependencies with hashes. Note that this can cause builds to fail if not all dependencies export with a hash.
      Returns:
      this
    • command

      @Stability(Stable) public BundlingOptions.Builder command(List<String> command)
      Parameters:
      command - The command to run in the container.
      Returns:
      this
    • entrypoint

      @Stability(Stable) public BundlingOptions.Builder entrypoint(List<String> entrypoint)
      Parameters:
      entrypoint - The entrypoint to run in the container.
      Returns:
      this
    • environment

      @Stability(Stable) public BundlingOptions.Builder environment(Map<String,String> environment)
      Parameters:
      environment - The environment variables to pass to the container.
      Returns:
      this
    • network

      @Stability(Stable) public BundlingOptions.Builder network(String network)
      Parameters:
      network - Docker Networking options.
      Returns:
      this
    • platform

      @Stability(Stable) public BundlingOptions.Builder platform(String platform)
      Parameters:
      platform - Set platform if server is multi-platform capable. Requires Docker Engine API v1.38+. Example value: linux/amd64
      Returns:
      this
    • securityOpt

      @Stability(Stable) public BundlingOptions.Builder securityOpt(String securityOpt)
      Parameters:
      securityOpt - Security configuration when running the docker container.
      Returns:
      this
    • user

      @Stability(Stable) public BundlingOptions.Builder user(String user)
      Sets the value of DockerRunOptions.getUser()
      Parameters:
      user - The user to use when running the container.
      Returns:
      this
    • volumes

      @Stability(Stable) public BundlingOptions.Builder volumes(List<? extends DockerVolume> volumes)
      Parameters:
      volumes - Docker volumes to mount.
      Returns:
      this
    • volumesFrom

      @Stability(Stable) public BundlingOptions.Builder volumesFrom(List<String> volumesFrom)
      Parameters:
      volumesFrom - Where to mount the specified volumes from.
      Returns:
      this
    • workingDirectory

      @Stability(Stable) public BundlingOptions.Builder workingDirectory(String workingDirectory)
      Parameters:
      workingDirectory - Working directory inside the container.
      Returns:
      this
    • build

      @Stability(Experimental) public BundlingOptions build()
      Builds the configured instance.
      Specified by:
      build in interface software.amazon.jsii.Builder<BundlingOptions>
      Returns:
      a new instance of BundlingOptions
      Throws:
      NullPointerException - if any required attribute was not provided