Package software.aws.awsprototypingsdk.pipeline
The architecture for the PDKPipeline is as follows:
CodeCommit repository -> CodePipeline
|-> EventBridge Rule (On Build Succeded) -> CodeBuild (Sonar Scan)
|-> Secret (sonarqube token)
This module additionally vends multiple Projen Projects, one for each of the supported languages. These projects aim to bootstrap your project by providing sample code which uses the PDKPipeline construct.
For example, in .projenrc.ts:
new PDKPipelineTsProject({
cdkVersion: "2.1.0",
defaultReleaseBranch: "mainline",
devDeps: ["aws-prototyping-sdk"],
name: "my-pipeline",
});
This will generate a package in typescript containing CDK boilerplate for a pipeline stack (which instantiates PDKPipeline), sets up a Dev stage with an Application Stage containing an empty ApplicationStack (to be implemented). Once this package is synthesized, you can run npx projen and projen will synthesize your cloudformation.
Alternatively, you can initialize a project using the cli (in an empty directory) for each of the supported languages as follows:
# Typescript npx projen new --from aws-prototyping-sdk pdk-pipeline-ts
# Python npx projen new --from aws-prototyping-sdk pdk-pipeline-py
# Java npx projen new --from aws-prototyping-sdk pdk-pipeline-java
CDK Nag
In order to keep CDK Nag happy, make sure you build the pipeline before synth as per https://github.com/aws/aws-cdk/issues/18440.
-
Interface Summary Interface Description PDKPipelineJavaProjectOptions Configuration options for the PDKPipelineJavaProject.PDKPipelineProps Properties to configure the PDKPipeline.PDKPipelinePyProjectOptions Configuration options for the PDKPipelinePyProject.PDKPipelineTsProjectOptions Configuration options for the PDKPipelineTsProject.SonarCodeScannerConfig SonarCodeScannerProps SonarCodeScanners properties.