All classes are under active development and subject to non-backward compatible changes or removal in any future version. These are not subject to the Semantic Versioning model. This means that while you may use them, you may need to update your source code when upgrading to a newer version of this package.
Due to the experimental state of this project, it is not currently published to package managers (e.g. NPM, or PyPI).
- Introduction
- CDK Versions
- Contributing
- Design guidelines and Development guide
- Getting Started
- Catalog
- Sample Use Cases
- Contributors
- License
- Legal Disclaimer
The AWS Data Transformation Pipeline Constructs Library is an open-source extension of the AWS Cloud Development Kit (AWS CDK) that provides multi-service, well-architected patterns for quickly defining solutions in code to create predictable and repeatable infrastructure, called constructs. The goal of AWS Data Transformation Pipeline CDK Constructs is to help developers build data transformation pipelines with pattern-based definitions for their architecture.
The patterns defined in AWS Data Transformation Pipeline CDK Constructs are high level, multi-service abstractions of AWS CDK constructs that have default configurations based on well-architected best practices. The library is organized into logical modules using object-oriented techniques to create each architectural pattern model.
AWS Data Transformation Pipeline CDK Constructs and the AWS CDK are independent teams and have different release schedules. Each release of AWS Data Transformation Pipeline CDK Constructs is built against a specific version of the AWS CDK. The CHANGELOG.md file lists the CDK version associated with each AWS Data Transformation Pipeline CDK Constructs release. For instance, AWS Data Transformation Pipeline CDK Constructs v0.0.0 was built against AWS CDK v2.152.0. This means that to use AWS Data Transformation Pipeline CDK Constructs v0.0.0, your application must include AWS CDK v2.152.0 or later. You can continue to use the latest AWS CDK versions and upgrade the your AWS Data Transformation Pipeline CDK Constructs version when new releases become available.
Contributions of all kinds are welcome! Check out our contributor guide
If you want to add a new construct to the library, check out our design guidelines, then follow the development guide
- Clone this project locally
- Run
git clone https://github.com/awslabs/data-transformation-pipeline-cdk-constructs.git
- Run
- Navigate to the project directory
- Install all project dependencies
- Run
npx projen install
- Run
- Create a directory within the cloned project to host your CDK project
- Note: There is a
cdk-sample
directory in the project with an example CDK project
- Note: There is a
- Create or use an existing CDK application in TypeScript.
cdk init app --language typescript
- When creating new stacks, import the 3D Data Transformation constructs by path
- e.g.
import { BatchFargateConstruct } from '../../src/constructs/aws-batch-fargate'
- e.g.
The following constructs are available in the library:
L3 constructs
Construct | Description | AWS Services used |
---|---|---|
Batch Fargate Parallel Pipeline | A fan-out pattern state machine pipeline. | AWS Batch, AWS Fargate, AWS Step Functions, AWS Lambda, Amazon S3, Amazon VPC |
Batch Fargate Series Pipeline | A series pattern state machine pipeline. | AWS Batch, AWS Fargate, AWS Step Functions, AWS Lambda, Amazon S3, Amazon VPC |
L2 Constructs
Construct | Description | AWS Services used |
---|---|---|
Batch Fargate | AWS Batch Job Queue with a Fargate compute environment | AWS Batch, AWS Fargate |
Batch Fargate Submit Job Step Function Chain | A Step Function chain that creates a Submit Job task (Fargate compute) | AWS Batch, AWS Fargate, AWS Step Functions, AWS Lambda |
Lambda Invoke Step Function Chain | A Step Function chain that creates a Lambda Invoke task | AWS Step Functions, AWS Lambda |
State Machine with Log Group from Chain | A Step Function State Machine with CloudWatch Log Group created from a chain | AWS Step Functions, Amazon Cloudwatch |
VPC for Batch Fargate | A Virtual Private Cloud (VPC) for running a Batch Fargate environment | Amazon Virtual Private Cloud |
Construct | Description | AWS Services used |
---|---|---|
Mesh Bounding Box Calculation using Batch Fargate Parallel Pipeline | Run a Blender container in parallel to calculate bounding boxes of 3D meshes | AWS Batch, AWS Fargate, AWS Step Functions, AWS Lambda, Amazon S3, Amazon VPC |
Mesh Joining using Batch Fargate Series Pipeline | Run a Blender container in series to join 3D meshes | AWS Batch, AWS Fargate, AWS Step Functions, AWS Lambda, Amazon S3, Amazon VPC |
This library is licensed under Apache License Version 2.0 and GNU General Public License Version 3.
You should consider doing your own independent assessment before using the content in this library for production purposes. This may include (amongst other things) testing, securing, and optimizing the CDK constructs and other content, provided in this library, based on your specific quality control practices and standards.
© Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.