A construct that encapsulates different building methods, e.g. for Node, Rust, Docker.
Project description
CDKTF Local Build Construct
A simple construct that runs builds for different languages locally. Currently, it supports: docker. I plan on adding rust (cargo) and node (npm) support as well.
Usage
import { Provider, DockerBuild, DockerizedBuild } from "cdktf-local-build";
// Local Build extends LocalExec which extends from the null provider,
// so if you already have the provider initialized you can skip this step
new Provider(this, "local-build");
new DockerBuild(this, "docker-backend", {
cwd: "/path/to/project/backend",
dockerfile: "Dockerfile.backend",
image: "cdktf/backend:latest",
push: false, // defaults to true
});
new DockerizedBuild(this, "my-go-backend", {
cwd: "/path/to/project/backend",
command: "go build -o /tmp/backend",
imageHomeDirectory: "/tmp/backend",
platform: "linux/arm64",
image: "go-builder-image:latest",
setUser: true,
});
DockerBuild
Builds a docker image locally.
Options
cwd
: The working directory to run the command in.dockerfile
: The Dockerfile to use.image
: The tag to use for the image.push
: If true,docker push <tag>
is executed after the run.
DockerizedBuild
Build an artifact inside a docker image.
Options
cwd
: The working directory to run the command in.command
: Build command to run int the docker image.image
: The tag to use for the building image.imageHomeDirectory
: The home directory to use inside the image.platform
: The platform to build for (sets docker platform flag).setUser
: If true, the user will be set to the current user inside docker.
CrossBuild
Builds a rust binary using cross (cross runs it inside a docker container).
Please make sure cross is installed on the host machine by running cargo install cross
.
Options
arch
: The architecture to build for (arm
orx86
).projectName
: The name specified in the Cargo.toml.cwd
: The working directory to run the command in.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
cdktf-local-build-0.0.80.tar.gz
(56.1 kB
view details)
Built Distribution
File details
Details for the file cdktf-local-build-0.0.80.tar.gz
.
File metadata
- Download URL: cdktf-local-build-0.0.80.tar.gz
- Upload date:
- Size: 56.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1fca5d4e89288035d5260eb5b5cd3f3442180275febde062eb3b3611d14c9d27 |
|
MD5 | 6fa6e532a0cca1017753cd6d152c551d |
|
BLAKE2b-256 | 7ec11b8d39f867f40feaeeaf607ddb4b4f5e2f59cb1a8d502f37ab5185cb103a |
File details
Details for the file cdktf_local_build-0.0.80-py3-none-any.whl
.
File metadata
- Download URL: cdktf_local_build-0.0.80-py3-none-any.whl
- Upload date:
- Size: 54.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 50043ed3e75b57d7fdab24010101cfc8afdfdc2c8897cc51fb70eb1715774220 |
|
MD5 | 347ee302eaa9de8f414d63f8c9a305f5 |
|
BLAKE2b-256 | a718b468e18b942757f123ee62942f7a1d2c61a7c93c2dde2883b8d0e9558e2d |