Skip to main content

This repository contains the infrastructure as code to wrap your AWS CDK project with CI/CD around it.

Project description

CDK CI/CD Wrapper

License

The CDK CI/CD Wrapper is a comprehensive solution that streamlines the delivery of your AWS Cloud Development Kit (CDK) applications. It provides a robust and standardized multi-stage CI/CD pipeline, ensuring high quality and confidence throughout the development and deployment process.

Table of Contents

Introduction

The CDK CI/CD Wrapper builds upon the success of the aws-cdk-cicd-boot-sample and takes it a step further by providing additional tools and features to simplify and standardize the multi-stage CI/CD process for your Infrastructure as Code (IaC) projects.

Features

  • Multi-staged CI/CD Pipeline: Seamlessly deploy your CDK applications across multiple stages (e.g., DEV, INT, PROD) and AWS accounts.
  • Security Scanning: Perform security scanning on dependencies and codebase, blocking the pipeline in case of CVE findings.
  • License Management: Manage licenses for NPM and Python dependencies, ensuring compliance with your organization's policies.
  • Private NPM Registry: Securely store and utilize private NPM libraries.
  • Customizable Pipeline: Tailor the CI/CD pipeline to your project's specific needs with built-in dependency injection.
  • Workbench Deployment: Develop and experiment with your solutions in isolation before introducing them to the delivery pipeline.
  • Pre/Post Deploy Hooks: Execute custom scripts before and after deployments in each stage (e.g., unit tests, functional tests, load testing).
  • Centralized Compliance Logs: Store compliance logs in pre-configured S3 buckets on a per-stage/environment basis.
  • Lambda Layer Support: Build and scan dependencies for Python Lambda Layers.

Getting Started

Prerequisites

Before you begin, ensure that you have the following dependencies installed:

  • AWS Account (RES/DEV/INT/PROD)
  • macOS or Cloud9 with Ubuntu Server 22.04 LTS Platform in the RES Account
  • Bash/ZSH terminal
  • Docker version >= 24.0.x
  • AWS CLI v2 (installation guide)
  • AWS credentials and profiles for each environment in ~/.aws/config (configuration guide)
  • Node.js >= v18.17._ && NPM >= v10.2._
  • jq command-line JSON processor (jq-1.7)

For developing Python Lambdas, you'll also need:

Installation

  1. Clone the CDK CI/CD Wrapper repository:

    git clone https://github.com/your-repo/cdk-cicd-wrapper.git
    cd cdk-cicd-wrapper
    
  2. Install the required dependencies:

    npm install
    

Usage

Defining Stages

The CDK CI/CD Wrapper comes with a default set of stages (DEV, INT, PROD), but you can easily extend or modify these stages to suit your project's needs. Follow the step-by-step guide in the documentation to define your desired stages.

Configuring Stacks

Configure the CDK stacks you want to deploy in each stage. The CDK CI/CD Wrapper allows you to specify which stacks should be deployed in each stage, giving you granular control over your deployment process.

Customizing CI/CD Steps

Tailor the CI/CD pipeline to meet your project's specific requirements. The CDK CI/CD Wrapper provides built-in dependency injection, allowing you to customize the CI/CD steps seamlessly.

Contributing

Contributions to the CDK CI/CD Wrapper are welcome! If you'd like to contribute, please follow the guidelines outlined in the CONTRIBUTING.md file.

License

This project is licensed under the Apache 2.0 License.

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

cdklabs_cdk_cicd_wrapper-0.3.4.tar.gz (780.7 kB view details)

Uploaded Source

Built Distribution

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

cdklabs_cdk_cicd_wrapper-0.3.4-py3-none-any.whl (779.5 kB view details)

Uploaded Python 3

File details

Details for the file cdklabs_cdk_cicd_wrapper-0.3.4.tar.gz.

File metadata

  • Download URL: cdklabs_cdk_cicd_wrapper-0.3.4.tar.gz
  • Upload date:
  • Size: 780.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.14.4

File hashes

Hashes for cdklabs_cdk_cicd_wrapper-0.3.4.tar.gz
Algorithm Hash digest
SHA256 a42992f960232c8a7a6a40cdae5f2b58becc81cef2e9252cf0c5902c48ddc2e1
MD5 9a086f7ff0ec68c6a31ff5d0f6aaf0d2
BLAKE2b-256 a549e1c544aae8f4ac6af5ecb9c21a3bbee96ffb20bd08cfb92c65946affce34

See more details on using hashes here.

Provenance

The following attestation bundles were made for cdklabs_cdk_cicd_wrapper-0.3.4.tar.gz:

Publisher: release.yml on cdklabs/cdk-cicd-wrapper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cdklabs_cdk_cicd_wrapper-0.3.4-py3-none-any.whl.

File metadata

File hashes

Hashes for cdklabs_cdk_cicd_wrapper-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 d2f1f26238ea5ae7651df207117257a998975f25ca8fa027bde2de9d788ff60a
MD5 405f60250ae417746eda9d2f8fefca0b
BLAKE2b-256 b36b2813f04542538e870d2958cdde7c35d530313a800ecb7bdad716d9340b1c

See more details on using hashes here.

Provenance

The following attestation bundles were made for cdklabs_cdk_cicd_wrapper-0.3.4-py3-none-any.whl:

Publisher: release.yml on cdklabs/cdk-cicd-wrapper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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