truemark-cdk-lib 1.22.2 → 1.22.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Construct } from 'constructs';
|
|
2
|
-
import {
|
|
2
|
+
import { GitPushFilter, PipelineType } from 'aws-cdk-lib/aws-codepipeline';
|
|
3
3
|
import { AddStageOpts, CodePipeline, IFileSetProducer, StageDeployment, Wave, WaveOptions } from 'aws-cdk-lib/pipelines';
|
|
4
4
|
import { ComputeType, IBuildImage } from 'aws-cdk-lib/aws-codebuild';
|
|
5
5
|
import { PipelineNotificationRule } from './pipeline-notification-rule';
|
|
@@ -230,9 +230,13 @@ export interface CdkPipelineProps {
|
|
|
230
230
|
*/
|
|
231
231
|
readonly disableAutoTrigger?: boolean;
|
|
232
232
|
/**
|
|
233
|
-
*
|
|
233
|
+
* Git push filter configuration for the pipeline trigger.
|
|
234
|
+
* Allows filtering which git events trigger the pipeline based on branch patterns,
|
|
235
|
+
* file paths, or tag patterns. Only applicable when using CodeStar connections.
|
|
236
|
+
*
|
|
237
|
+
* @default - No filtering, all pushes to the branch trigger the pipeline
|
|
234
238
|
*/
|
|
235
|
-
readonly
|
|
239
|
+
readonly gitPushFilter?: GitPushFilter[];
|
|
236
240
|
}
|
|
237
241
|
/**
|
|
238
242
|
* An abstraction to ease CDK pipeline creation and configuration.
|
|
@@ -101,7 +101,6 @@ class CdkPipeline extends constructs_1.Construct {
|
|
|
101
101
|
pipelineType: (_a = props.pipelineType) !== null && _a !== void 0 ? _a : aws_codepipeline_1.PipelineType.V2,
|
|
102
102
|
artifactBucket,
|
|
103
103
|
pipelineName: props.pipelineName,
|
|
104
|
-
triggers: props.triggers,
|
|
105
104
|
});
|
|
106
105
|
let input;
|
|
107
106
|
if (props.connectionArn !== undefined) {
|
|
@@ -260,6 +259,27 @@ class CdkPipeline extends constructs_1.Construct {
|
|
|
260
259
|
TriggerEvents: 'NONE',
|
|
261
260
|
});
|
|
262
261
|
}
|
|
262
|
+
// Apply GitPushFilter if provided
|
|
263
|
+
if (props.gitPushFilter && props.gitPushFilter.length > 0) {
|
|
264
|
+
const cfnPipeline = underlyingPipeline.node.defaultChild;
|
|
265
|
+
cfnPipeline.addPropertyOverride('Stages.0.Actions.0.Configuration.TriggerConfiguration.GitConfiguration.Push', props.gitPushFilter.map((filter) => ({
|
|
266
|
+
Branches: filter.branchesIncludes
|
|
267
|
+
? { Includes: filter.branchesIncludes }
|
|
268
|
+
: filter.branchesExcludes
|
|
269
|
+
? { Excludes: filter.branchesExcludes }
|
|
270
|
+
: undefined,
|
|
271
|
+
FilePaths: filter.filePathsIncludes
|
|
272
|
+
? { Includes: filter.filePathsIncludes }
|
|
273
|
+
: filter.filePathsExcludes
|
|
274
|
+
? { Excludes: filter.filePathsExcludes }
|
|
275
|
+
: undefined,
|
|
276
|
+
Tags: filter.tagsIncludes
|
|
277
|
+
? { Includes: filter.tagsIncludes }
|
|
278
|
+
: filter.tagsExcludes
|
|
279
|
+
? { Excludes: filter.tagsExcludes }
|
|
280
|
+
: undefined,
|
|
281
|
+
})));
|
|
282
|
+
}
|
|
263
283
|
// Handle pipeline notifications
|
|
264
284
|
if (props.slackChannelConfiguration && props.slackChannelConfigurationArn) {
|
|
265
285
|
throw new Error('Only one of slackChannelConfiguration and slackChannelConfigurationArn can be specified');
|
|
@@ -299,4 +319,4 @@ class CdkPipeline extends constructs_1.Construct {
|
|
|
299
319
|
}
|
|
300
320
|
}
|
|
301
321
|
exports.CdkPipeline = CdkPipeline;
|
|
302
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-pipeline.js","sourceRoot":"","sources":["../../../src/aws-codepipeline/lib/cdk-pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from 'constructs';\nimport {\n  CfnPipeline,\n  Pipeline,\n  PipelineType,\n  TriggerProps,\n} from 'aws-cdk-lib/aws-codepipeline';\nimport {Key} from 'aws-cdk-lib/aws-kms';\nimport {ArtifactBucket} from './artifact-bucket';\nimport {\n  AddStageOpts,\n  CodePipeline,\n  CodePipelineSource,\n  IFileSetProducer,\n  ShellStep,\n  StageDeployment,\n  Wave,\n  WaveOptions,\n} from 'aws-cdk-lib/pipelines';\nimport {\n  BuildSpec,\n  ComputeType,\n  IBuildImage,\n  LinuxBuildImage,\n} from 'aws-cdk-lib/aws-codebuild';\nimport {PipelineNotificationRule} from './pipeline-notification-rule';\nimport {Arn, Stack, Stage} from 'aws-cdk-lib';\nimport {Repository} from 'aws-cdk-lib/aws-codecommit';\nimport {NodePackageManager} from './enums';\nimport {Effect, PolicyStatement} from 'aws-cdk-lib/aws-iam';\nimport {ISlackChannelConfiguration} from 'aws-cdk-lib/aws-chatbot';\nimport {ITopic} from 'aws-cdk-lib/aws-sns';\n\n/**\n * Node runtimes supported by CodebBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.html\n */\nexport enum NodeVersion {\n  NODE_16 = '16',\n  NODE_18 = '18',\n  NODE_20 = '20',\n  NODE_22 = '22',\n  NODE_24 = '24',\n}\n\n/**\n * Go runtimes supported by CodeBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.html\n */\nexport enum GoVersion {\n  GO_1_12 = '1.12',\n  GO_1_13 = '1.13',\n  GO_1_14 = '1.14',\n  GO_1_15 = '1.15',\n  GO_1_16 = '1.16',\n  GO_1_17 = '1.17',\n  GO_1_18 = '1.18',\n  GO_1_20 = '1.20',\n  GO_1_21 = '1.21',\n  GO_1_22 = '1.22',\n  GO_1_23 = '1.23',\n  GO_1_24 = '1.24',\n}\n\n/**\n * Java runtimes supported by CodeBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.html\n */\nexport enum JavaVersion {\n  JAVA_8 = 'corretto8',\n  JAVA_11 = 'corretto11',\n  JAVA_16 = 'corretto17',\n  JAVA_21 = 'corretto21',\n  JAVA_25 = 'corretto25',\n}\n\n/**\n * Dotnet runtimes supported by CodeBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.htmldotnet\n */\nexport enum DotnetVersion {\n  DOTNET_3_1 = '3.1',\n  DOTNET_5_0 = '5.0',\n  DOTNET_6_0 = '6.0',\n  DOTNET_8_0 = '8.0',\n}\n\nexport enum PythonVersion {\n  PYTHON_3_7 = '3.7',\n  PYTHON_3_8 = '3.8',\n  PYTHON_3_9 = '3.9',\n  PYTHON_3_10 = '3.10',\n  PYTHON_3_11 = '3.11',\n  PYTHON_3_12 = '3.12',\n  PYTHON_3_13 = '3.13',\n  PYTHON_3_14 = '3.14',\n}\n\nconst DOCKER_BUILDX_SETUP_COMMANDS = [\n  \"echo '#!/bin/bash' > /usr/local/bin/buildx.sh\",\n  'echo \\'[[ \"$1\" == \"build\" ]] && docker buildx build --load \"${@:2}\" || docker \"$@\"\\' >> /usr/local/bin/buildx.sh',\n  'chmod +x /usr/local/bin/buildx.sh',\n  'echo \"Architecture: $(uname -m)\"',\n  'docker buildx create --use --name multi-arch-builder',\n  'docker buildx ls',\n];\n\n/**\n * Properties for CdkPipeline\n */\nexport interface CdkPipelineProps {\n  /**\n   * By default, CDK will name the pipeline. Set this to override the name.\n   */\n  readonly pipelineName?: string;\n\n  readonly pipelineType?: PipelineType;\n\n  /**\n   * By default, CDK will create KMS keys for cross account deployments. This\n   * can be costly if you have a large number of pipelines. This property\n   * allows a common key to be shared across pipelines.\n   *\n   * You must change @aws-cdk/aws-codepipeline:crossAccountKeysDefaultValueToFalse to false in your cdk.json\n   * file to avoid errors.\n   */\n  readonly keyArn: string;\n\n  /**\n   * List of account IDs this pipeline will deploy into.\n   */\n  readonly accountIds?: string[];\n\n  /**\n   * Arn of the CodeStar connection used to access the source code repository. If not set, this\n   * construct assumes the repository is in AWS CodeCommit.\n   */\n  readonly connectionArn?: string;\n\n  /**\n   * Source code repository.\n   */\n  readonly repository: string;\n\n  /**\n   * Branch to use inside the source code repository.\n   */\n  readonly branch: string;\n\n  /**\n   * Enable or disable self-mutation. Useful for cdk pipeline development.\n   *\n   * @default true\n   */\n  readonly selfMutation?: boolean;\n\n  /**\n   * Enable docker for the 'synth' step.\n   *\n   * @default true\n   */\n  readonly dockerEnabledForSynth?: boolean;\n\n  /**\n   * Enable docker for the self-mutate step.\n   *\n   * @default true\n   */\n  readonly dockerEnabledForSelfMutation?: boolean;\n\n  /**\n   * Type of compute to use for this build. Default is ComputeType.SMALL.\n   */\n  readonly computeType?: ComputeType;\n\n  /**\n   * The image to use for builds. If none is selected the default defined in AWS CDK is used.\n   */\n  readonly buildImage?: IBuildImage;\n\n  /**\n   * The ARN of the Slack channel configuration to use for notifications. Mutually exclusive with slackChannelConfiguration.\n   */\n  readonly slackChannelConfigurationArn?: string;\n\n  /**\n   * The Slack channel configuration to use for notifications. Mutually exclusive with slackChannelConfigurationArn.\n   */\n  readonly slackChannelConfiguration?: ISlackChannelConfiguration;\n\n  /**\n   * The SNS topic to use for notifications. Mutually exclusive with notificationTopic.\n   */\n  readonly notificationTopicArn?: string;\n\n  /**\n   * The SNS topic to use for notifications. Mutually exclusive with notificationTopicArn.\n   */\n  readonly notificationTopic?: ITopic;\n\n  /**\n   * The list of notification events to receive.Default is DEFAULT_EVENTS\n   * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline\n   */\n  readonly notificationEvents?: string[];\n\n  /**\n   * Additional FileSets to put in other directories\n   */\n  readonly additionalInputs?: Record<string, IFileSetProducer>;\n\n  /**\n   * Additional commands to run before install. If you override the commands property, this has no effect.\n   */\n  readonly preBuildCommands?: string[];\n\n  /**\n   * Overrides default commands.\n   */\n  readonly commands?: string[];\n\n  /**\n   * Public assets in multiple CodeBuild projects. Default is false.\n   */\n  readonly publishAssetsInParallel?: boolean;\n\n  /**\n   * Package manager to use when executing CDK.\n   *\n   * @default NodePackageManager.PNPM\n   */\n  readonly packageManager?: NodePackageManager;\n\n  /**\n   * The directory the CDK project is located in the repo.\n   *\n   * @default - \".\"\n   */\n  readonly cdkDirectory?: string;\n\n  /**\n   * Policy statements to add to the role used by synth.\n   */\n  readonly rolePolicy?: PolicyStatement[];\n\n  /**\n   * Grants read access to the provided AWS CodeArtifact domains.\n   */\n  readonly codeArtifactDomains?: string[];\n\n  /**\n   * Grants read access to the provided AWS CodeArtifact repositories.\n   */\n  readonly codeArtifactRepositories?: string[];\n\n  /**\n   * Version of Node to use in the pipeline. Default is NODE_20\n   */\n  readonly nodeVersion?: NodeVersion | string;\n\n  /**\n   * Version of Go to install. Default is none.\n   */\n  readonly goVersion?: GoVersion | string;\n\n  /**\n   * Version of Java to install. Default is none.\n   */\n  readonly javaVersion?: JavaVersion | string;\n\n  /**\n   * Version of Dotnet to install. Default is none.\n   */\n  readonly dotnetVersion?: DotnetVersion | string;\n\n  /**\n   * Version of Python to install. Default is none.\n   */\n  readonly pythonVersion?: PythonVersion | string;\n\n  /**\n   * Additional commands to run during the install phase.\n   */\n  readonly additionalInstallCommands?: string[];\n\n  /**\n   * Whether to clone the CodeCommit repository into the CodeBuild project.\n   */\n  readonly codeBuildCloneOutput?: boolean;\n\n  /**\n   * Enables the use of \"docker buildx\" in the asset publishing step. Default is true.\n   */\n  readonly enableDockerBuildxOnAssetPublish?: boolean;\n\n  /**\n   * Disable automatic triggering on source code changes. When true, the pipeline\n   * must be manually started. Useful for development environments.\n   *\n   * @default false (auto-trigger enabled)\n   */\n  readonly disableAutoTrigger?: boolean;\n\n  /**\n   * The trigger configuration specifying a type of event, such as Git tags, that starts the pipeline\n   */\n  readonly triggers?: TriggerProps[];\n}\n\n/**\n * An abstraction to ease CDK pipeline creation and configuration.\n */\nexport class CdkPipeline extends Construct {\n  readonly pipeline: CodePipeline;\n  readonly pipelineNotificationRule?: PipelineNotificationRule;\n\n  constructor(scope: Construct, id: string, props: CdkPipelineProps) {\n    super(scope, id);\n\n    const encryptionKey = Key.fromKeyArn(this, 'EncryptionKey', props.keyArn);\n\n    const artifactBucket = new ArtifactBucket(this, 'ArtifactBucket', {\n      encryptionKey,\n      accountIds: props.accountIds,\n    });\n\n    const underlyingPipeline = new Pipeline(this, 'Pipeline', {\n      pipelineType: props.pipelineType ?? PipelineType.V2,\n      artifactBucket,\n      pipelineName: props.pipelineName,\n      triggers: props.triggers,\n    });\n\n    let input: CodePipelineSource;\n    if (props.connectionArn !== undefined) {\n      input = CodePipelineSource.connection(props.repository, props.branch, {\n        connectionArn: props.connectionArn,\n        // Used per workaround in https://github.com/aws/aws-cdk/issues/11399#issuecomment-1367180696\n        codeBuildCloneOutput: props.codeBuildCloneOutput ?? false,\n      });\n    } else {\n      const repository = props.repository.startsWith('arn:')\n        ? Repository.fromRepositoryArn(this, 'Repository', props.repository)\n        : Repository.fromRepositoryName(this, 'Repository', props.repository);\n      input = CodePipelineSource.codeCommit(repository, props.branch, {\n        // Used per workaround in https://github.com/aws/aws-cdk/issues/11399#issuecomment-1367180696\n        codeBuildCloneOutput: props.codeBuildCloneOutput ?? false,\n      });\n    }\n\n    const stackName = Stack.of(this).stackName;\n    const cdkDirectory = props.cdkDirectory ?? '.';\n\n    let commands: string[] | undefined = props.commands;\n    if (\n      commands === undefined &&\n      props.packageManager === NodePackageManager.PNPM\n    ) {\n      commands = [\n        `cd ${cdkDirectory ?? '.'}`,\n        'npm -g i pnpm',\n        'pnpm i --frozen-lockfile --prefer-offline',\n        ...(props.preBuildCommands ?? []),\n        'pnpm run build',\n        'pnpm run test',\n        `pnpx cdk synth ${stackName}`,\n      ];\n    } else if (commands === undefined) {\n      commands = [\n        `cd ${cdkDirectory ?? '.'}`,\n        'npm ci --prefer-offline',\n        ...(props.preBuildCommands ?? []),\n        'npm run build',\n        'npm run test',\n        `npx cdk synth ${stackName}`,\n      ];\n    }\n\n    const stack = Stack.of(this);\n\n    const codeArtifactDomains = props.codeArtifactDomains?.map((domain) => {\n      return domain.startsWith('arn:aws')\n        ? domain\n        : Arn.format(\n            {\n              service: 'codeartifact',\n              resource: 'domain',\n              resourceName: domain,\n            },\n            stack,\n          );\n    });\n\n    const codeArtifactRepositories = props.codeArtifactRepositories?.map(\n      (repository) => {\n        return repository.startsWith('arn:aws')\n          ? repository\n          : Arn.format(\n              {\n                service: 'codeartifact',\n                resource: 'repository',\n                resourceName: repository,\n              },\n              stack,\n            );\n      },\n    );\n\n    const rolePolicy = props.rolePolicy ?? [];\n    if (codeArtifactDomains) {\n      rolePolicy.push(\n        new PolicyStatement({\n          resources: codeArtifactDomains,\n          actions: ['codeartifact:GetAuthorizationToken'],\n          effect: Effect.ALLOW,\n        }),\n      );\n      rolePolicy.push(\n        new PolicyStatement({\n          resources: ['*'],\n          actions: ['sts:GetServiceBearerToken'],\n          effect: Effect.ALLOW,\n        }),\n      );\n    }\n    if (codeArtifactRepositories) {\n      rolePolicy.push(\n        new PolicyStatement({\n          resources: codeArtifactRepositories,\n          actions: [\n            'codeartifact:DescribePackageVersion',\n            'codeartifact:DescribeRepository',\n            'codeartifact:GetPackageVersionReadme',\n            'codeartifact:GetRepositoryEndpoint',\n            'codeartifact:ListPackages',\n            'codeartifact:ListPackageVersions',\n            'codeartifact:ListPackageVersionAssets',\n            'codeartifact:ListPackageVersionDependencies',\n            'codeartifact:ReadFromRepository',\n          ],\n          effect: Effect.ALLOW,\n        }),\n      );\n    }\n\n    this.pipeline = new CodePipeline(this, 'CodePipeline', {\n      codePipeline: underlyingPipeline,\n      selfMutation: props.selfMutation ?? true,\n      dockerEnabledForSynth: props.dockerEnabledForSynth ?? true,\n      dockerEnabledForSelfMutation: props.dockerEnabledForSelfMutation ?? true,\n      publishAssetsInParallel: props.publishAssetsInParallel ?? false,\n      synth: new ShellStep('Synth', {\n        primaryOutputDirectory: `${cdkDirectory}/cdk.out`,\n        input,\n        commands,\n        additionalInputs: props.additionalInputs ?? {},\n      }),\n      synthCodeBuildDefaults: {\n        partialBuildSpec: BuildSpec.fromObject({\n          cache: {\n            paths: ['/root/.npm/**/*', '/root/.pnpm-store/**/*'],\n          },\n          phases: {\n            install: {\n              'runtime-versions': {\n                nodejs: props.nodeVersion ?? NodeVersion.NODE_24,\n                go: props.goVersion,\n                java: props.javaVersion,\n                dotnet: props.dotnetVersion,\n                python: props.pythonVersion,\n              },\n              'commands': ['npm config set fund false', 'npm -g i esbuild']\n                .concat(props.additionalInstallCommands ?? [])\n                .concat(['node --version']),\n            },\n          },\n        }),\n        buildEnvironment: {\n          privileged: true,\n          computeType: props.computeType ?? ComputeType.SMALL,\n          buildImage: props.buildImage ?? LinuxBuildImage.AMAZON_LINUX_2_5,\n        },\n        rolePolicy,\n      },\n      assetPublishingCodeBuildDefaults: {\n        partialBuildSpec: BuildSpec.fromObject({\n          env: {\n            variables: {\n              ...((props.enableDockerBuildxOnAssetPublish ?? true)\n                ? {CDK_DOCKER: '/usr/local/bin/buildx.sh'}\n                : {}),\n            },\n          },\n          phases: {\n            install: {\n              commands:\n                (props.enableDockerBuildxOnAssetPublish ?? true)\n                  ? DOCKER_BUILDX_SETUP_COMMANDS\n                  : [],\n            },\n          },\n        }),\n      },\n    });\n\n    // Disable automatic triggering if requested\n    if (props.disableAutoTrigger) {\n      const cfnPipeline = underlyingPipeline.node.defaultChild as CfnPipeline;\n      cfnPipeline.addPropertyOverride(\n        'Stages.0.Actions.0.Configuration.TriggerConfiguration',\n        {\n          ProviderType: 'CodeStarSourceConnection',\n          TriggerEvents: 'NONE',\n        },\n      );\n    }\n\n    // Handle pipeline notifications\n    if (props.slackChannelConfiguration && props.slackChannelConfigurationArn) {\n      throw new Error(\n        'Only one of slackChannelConfiguration and slackChannelConfigurationArn can be specified',\n      );\n    }\n    if (props.notificationTopic && props.notificationTopicArn) {\n      throw new Error(\n        'Only one of notificationTopic and notificationTopicArn can be specified',\n      );\n    }\n    if (\n      props.slackChannelConfiguration ||\n      props.slackChannelConfigurationArn ||\n      props.notificationTopicArn ||\n      props.notificationTopic\n    ) {\n      this.pipelineNotificationRule = new PipelineNotificationRule(\n        this,\n        'Notification',\n        {\n          events: props.notificationEvents,\n          source: underlyingPipeline,\n        },\n      );\n      if (props.slackChannelConfiguration) {\n        this.pipelineNotificationRule.addSlackChannel(\n          props.slackChannelConfiguration,\n        );\n      } else if (props.slackChannelConfigurationArn) {\n        this.pipelineNotificationRule.addSlackChannelArn(\n          'SlackChannel',\n          props.slackChannelConfigurationArn,\n        );\n      }\n      if (props.notificationTopic) {\n        this.pipelineNotificationRule.addTopic(props.notificationTopic);\n        props.notificationTopic.grantPublish(underlyingPipeline.role);\n      } else if (props.notificationTopicArn) {\n        const topic = this.pipelineNotificationRule.addTopicArn(\n          'NotificationTopic',\n          props.notificationTopicArn,\n        );\n        topic.grantPublish(underlyingPipeline.role);\n      }\n    }\n  }\n\n  addStage(stage: Stage, options?: AddStageOpts): StageDeployment {\n    return this.pipeline.addStage(stage, options);\n  }\n\n  addWave(id: string, options?: WaveOptions): Wave {\n    return this.pipeline.addWave(id, options);\n  }\n}\n"]}
|
|
322
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-pipeline.js","sourceRoot":"","sources":["../../../src/aws-codepipeline/lib/cdk-pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from 'constructs';\nimport {\n  CfnPipeline,\n  GitPushFilter,\n  Pipeline,\n  PipelineType,\n} from 'aws-cdk-lib/aws-codepipeline';\nimport {Key} from 'aws-cdk-lib/aws-kms';\nimport {ArtifactBucket} from './artifact-bucket';\nimport {\n  AddStageOpts,\n  CodePipeline,\n  CodePipelineSource,\n  IFileSetProducer,\n  ShellStep,\n  StageDeployment,\n  Wave,\n  WaveOptions,\n} from 'aws-cdk-lib/pipelines';\nimport {\n  BuildSpec,\n  ComputeType,\n  IBuildImage,\n  LinuxBuildImage,\n} from 'aws-cdk-lib/aws-codebuild';\nimport {PipelineNotificationRule} from './pipeline-notification-rule';\nimport {Arn, Stack, Stage} from 'aws-cdk-lib';\nimport {Repository} from 'aws-cdk-lib/aws-codecommit';\nimport {NodePackageManager} from './enums';\nimport {Effect, PolicyStatement} from 'aws-cdk-lib/aws-iam';\nimport {ISlackChannelConfiguration} from 'aws-cdk-lib/aws-chatbot';\nimport {ITopic} from 'aws-cdk-lib/aws-sns';\n\n/**\n * Node runtimes supported by CodebBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.html\n */\nexport enum NodeVersion {\n  NODE_16 = '16',\n  NODE_18 = '18',\n  NODE_20 = '20',\n  NODE_22 = '22',\n  NODE_24 = '24',\n}\n\n/**\n * Go runtimes supported by CodeBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.html\n */\nexport enum GoVersion {\n  GO_1_12 = '1.12',\n  GO_1_13 = '1.13',\n  GO_1_14 = '1.14',\n  GO_1_15 = '1.15',\n  GO_1_16 = '1.16',\n  GO_1_17 = '1.17',\n  GO_1_18 = '1.18',\n  GO_1_20 = '1.20',\n  GO_1_21 = '1.21',\n  GO_1_22 = '1.22',\n  GO_1_23 = '1.23',\n  GO_1_24 = '1.24',\n}\n\n/**\n * Java runtimes supported by CodeBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.html\n */\nexport enum JavaVersion {\n  JAVA_8 = 'corretto8',\n  JAVA_11 = 'corretto11',\n  JAVA_16 = 'corretto17',\n  JAVA_21 = 'corretto21',\n  JAVA_25 = 'corretto25',\n}\n\n/**\n * Dotnet runtimes supported by CodeBuild\n * See https://docs.aws.amazon.com/codebuild/latest/userguide/available-runtimes.htmldotnet\n */\nexport enum DotnetVersion {\n  DOTNET_3_1 = '3.1',\n  DOTNET_5_0 = '5.0',\n  DOTNET_6_0 = '6.0',\n  DOTNET_8_0 = '8.0',\n}\n\nexport enum PythonVersion {\n  PYTHON_3_7 = '3.7',\n  PYTHON_3_8 = '3.8',\n  PYTHON_3_9 = '3.9',\n  PYTHON_3_10 = '3.10',\n  PYTHON_3_11 = '3.11',\n  PYTHON_3_12 = '3.12',\n  PYTHON_3_13 = '3.13',\n  PYTHON_3_14 = '3.14',\n}\n\nconst DOCKER_BUILDX_SETUP_COMMANDS = [\n  \"echo '#!/bin/bash' > /usr/local/bin/buildx.sh\",\n  'echo \\'[[ \"$1\" == \"build\" ]] && docker buildx build --load \"${@:2}\" || docker \"$@\"\\' >> /usr/local/bin/buildx.sh',\n  'chmod +x /usr/local/bin/buildx.sh',\n  'echo \"Architecture: $(uname -m)\"',\n  'docker buildx create --use --name multi-arch-builder',\n  'docker buildx ls',\n];\n\n/**\n * Properties for CdkPipeline\n */\nexport interface CdkPipelineProps {\n  /**\n   * By default, CDK will name the pipeline. Set this to override the name.\n   */\n  readonly pipelineName?: string;\n\n  readonly pipelineType?: PipelineType;\n\n  /**\n   * By default, CDK will create KMS keys for cross account deployments. This\n   * can be costly if you have a large number of pipelines. This property\n   * allows a common key to be shared across pipelines.\n   *\n   * You must change @aws-cdk/aws-codepipeline:crossAccountKeysDefaultValueToFalse to false in your cdk.json\n   * file to avoid errors.\n   */\n  readonly keyArn: string;\n\n  /**\n   * List of account IDs this pipeline will deploy into.\n   */\n  readonly accountIds?: string[];\n\n  /**\n   * Arn of the CodeStar connection used to access the source code repository. If not set, this\n   * construct assumes the repository is in AWS CodeCommit.\n   */\n  readonly connectionArn?: string;\n\n  /**\n   * Source code repository.\n   */\n  readonly repository: string;\n\n  /**\n   * Branch to use inside the source code repository.\n   */\n  readonly branch: string;\n\n  /**\n   * Enable or disable self-mutation. Useful for cdk pipeline development.\n   *\n   * @default true\n   */\n  readonly selfMutation?: boolean;\n\n  /**\n   * Enable docker for the 'synth' step.\n   *\n   * @default true\n   */\n  readonly dockerEnabledForSynth?: boolean;\n\n  /**\n   * Enable docker for the self-mutate step.\n   *\n   * @default true\n   */\n  readonly dockerEnabledForSelfMutation?: boolean;\n\n  /**\n   * Type of compute to use for this build. Default is ComputeType.SMALL.\n   */\n  readonly computeType?: ComputeType;\n\n  /**\n   * The image to use for builds. If none is selected the default defined in AWS CDK is used.\n   */\n  readonly buildImage?: IBuildImage;\n\n  /**\n   * The ARN of the Slack channel configuration to use for notifications. Mutually exclusive with slackChannelConfiguration.\n   */\n  readonly slackChannelConfigurationArn?: string;\n\n  /**\n   * The Slack channel configuration to use for notifications. Mutually exclusive with slackChannelConfigurationArn.\n   */\n  readonly slackChannelConfiguration?: ISlackChannelConfiguration;\n\n  /**\n   * The SNS topic to use for notifications. Mutually exclusive with notificationTopic.\n   */\n  readonly notificationTopicArn?: string;\n\n  /**\n   * The SNS topic to use for notifications. Mutually exclusive with notificationTopicArn.\n   */\n  readonly notificationTopic?: ITopic;\n\n  /**\n   * The list of notification events to receive.Default is DEFAULT_EVENTS\n   * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline\n   */\n  readonly notificationEvents?: string[];\n\n  /**\n   * Additional FileSets to put in other directories\n   */\n  readonly additionalInputs?: Record<string, IFileSetProducer>;\n\n  /**\n   * Additional commands to run before install. If you override the commands property, this has no effect.\n   */\n  readonly preBuildCommands?: string[];\n\n  /**\n   * Overrides default commands.\n   */\n  readonly commands?: string[];\n\n  /**\n   * Public assets in multiple CodeBuild projects. Default is false.\n   */\n  readonly publishAssetsInParallel?: boolean;\n\n  /**\n   * Package manager to use when executing CDK.\n   *\n   * @default NodePackageManager.PNPM\n   */\n  readonly packageManager?: NodePackageManager;\n\n  /**\n   * The directory the CDK project is located in the repo.\n   *\n   * @default - \".\"\n   */\n  readonly cdkDirectory?: string;\n\n  /**\n   * Policy statements to add to the role used by synth.\n   */\n  readonly rolePolicy?: PolicyStatement[];\n\n  /**\n   * Grants read access to the provided AWS CodeArtifact domains.\n   */\n  readonly codeArtifactDomains?: string[];\n\n  /**\n   * Grants read access to the provided AWS CodeArtifact repositories.\n   */\n  readonly codeArtifactRepositories?: string[];\n\n  /**\n   * Version of Node to use in the pipeline. Default is NODE_20\n   */\n  readonly nodeVersion?: NodeVersion | string;\n\n  /**\n   * Version of Go to install. Default is none.\n   */\n  readonly goVersion?: GoVersion | string;\n\n  /**\n   * Version of Java to install. Default is none.\n   */\n  readonly javaVersion?: JavaVersion | string;\n\n  /**\n   * Version of Dotnet to install. Default is none.\n   */\n  readonly dotnetVersion?: DotnetVersion | string;\n\n  /**\n   * Version of Python to install. Default is none.\n   */\n  readonly pythonVersion?: PythonVersion | string;\n\n  /**\n   * Additional commands to run during the install phase.\n   */\n  readonly additionalInstallCommands?: string[];\n\n  /**\n   * Whether to clone the CodeCommit repository into the CodeBuild project.\n   */\n  readonly codeBuildCloneOutput?: boolean;\n\n  /**\n   * Enables the use of \"docker buildx\" in the asset publishing step. Default is true.\n   */\n  readonly enableDockerBuildxOnAssetPublish?: boolean;\n\n  /**\n   * Disable automatic triggering on source code changes. When true, the pipeline\n   * must be manually started. Useful for development environments.\n   *\n   * @default false (auto-trigger enabled)\n   */\n  readonly disableAutoTrigger?: boolean;\n\n  /**\n   * Git push filter configuration for the pipeline trigger.\n   * Allows filtering which git events trigger the pipeline based on branch patterns,\n   * file paths, or tag patterns. Only applicable when using CodeStar connections.\n   *\n   * @default - No filtering, all pushes to the branch trigger the pipeline\n   */\n  readonly gitPushFilter?: GitPushFilter[];\n}\n\n/**\n * An abstraction to ease CDK pipeline creation and configuration.\n */\nexport class CdkPipeline extends Construct {\n  readonly pipeline: CodePipeline;\n  readonly pipelineNotificationRule?: PipelineNotificationRule;\n\n  constructor(scope: Construct, id: string, props: CdkPipelineProps) {\n    super(scope, id);\n\n    const encryptionKey = Key.fromKeyArn(this, 'EncryptionKey', props.keyArn);\n\n    const artifactBucket = new ArtifactBucket(this, 'ArtifactBucket', {\n      encryptionKey,\n      accountIds: props.accountIds,\n    });\n\n    const underlyingPipeline = new Pipeline(this, 'Pipeline', {\n      pipelineType: props.pipelineType ?? PipelineType.V2,\n      artifactBucket,\n      pipelineName: props.pipelineName,\n    });\n\n    let input: CodePipelineSource;\n    if (props.connectionArn !== undefined) {\n      input = CodePipelineSource.connection(props.repository, props.branch, {\n        connectionArn: props.connectionArn,\n        // Used per workaround in https://github.com/aws/aws-cdk/issues/11399#issuecomment-1367180696\n        codeBuildCloneOutput: props.codeBuildCloneOutput ?? false,\n      });\n    } else {\n      const repository = props.repository.startsWith('arn:')\n        ? Repository.fromRepositoryArn(this, 'Repository', props.repository)\n        : Repository.fromRepositoryName(this, 'Repository', props.repository);\n      input = CodePipelineSource.codeCommit(repository, props.branch, {\n        // Used per workaround in https://github.com/aws/aws-cdk/issues/11399#issuecomment-1367180696\n        codeBuildCloneOutput: props.codeBuildCloneOutput ?? false,\n      });\n    }\n\n    const stackName = Stack.of(this).stackName;\n    const cdkDirectory = props.cdkDirectory ?? '.';\n\n    let commands: string[] | undefined = props.commands;\n    if (\n      commands === undefined &&\n      props.packageManager === NodePackageManager.PNPM\n    ) {\n      commands = [\n        `cd ${cdkDirectory ?? '.'}`,\n        'npm -g i pnpm',\n        'pnpm i --frozen-lockfile --prefer-offline',\n        ...(props.preBuildCommands ?? []),\n        'pnpm run build',\n        'pnpm run test',\n        `pnpx cdk synth ${stackName}`,\n      ];\n    } else if (commands === undefined) {\n      commands = [\n        `cd ${cdkDirectory ?? '.'}`,\n        'npm ci --prefer-offline',\n        ...(props.preBuildCommands ?? []),\n        'npm run build',\n        'npm run test',\n        `npx cdk synth ${stackName}`,\n      ];\n    }\n\n    const stack = Stack.of(this);\n\n    const codeArtifactDomains = props.codeArtifactDomains?.map((domain) => {\n      return domain.startsWith('arn:aws')\n        ? domain\n        : Arn.format(\n            {\n              service: 'codeartifact',\n              resource: 'domain',\n              resourceName: domain,\n            },\n            stack,\n          );\n    });\n\n    const codeArtifactRepositories = props.codeArtifactRepositories?.map(\n      (repository) => {\n        return repository.startsWith('arn:aws')\n          ? repository\n          : Arn.format(\n              {\n                service: 'codeartifact',\n                resource: 'repository',\n                resourceName: repository,\n              },\n              stack,\n            );\n      },\n    );\n\n    const rolePolicy = props.rolePolicy ?? [];\n    if (codeArtifactDomains) {\n      rolePolicy.push(\n        new PolicyStatement({\n          resources: codeArtifactDomains,\n          actions: ['codeartifact:GetAuthorizationToken'],\n          effect: Effect.ALLOW,\n        }),\n      );\n      rolePolicy.push(\n        new PolicyStatement({\n          resources: ['*'],\n          actions: ['sts:GetServiceBearerToken'],\n          effect: Effect.ALLOW,\n        }),\n      );\n    }\n    if (codeArtifactRepositories) {\n      rolePolicy.push(\n        new PolicyStatement({\n          resources: codeArtifactRepositories,\n          actions: [\n            'codeartifact:DescribePackageVersion',\n            'codeartifact:DescribeRepository',\n            'codeartifact:GetPackageVersionReadme',\n            'codeartifact:GetRepositoryEndpoint',\n            'codeartifact:ListPackages',\n            'codeartifact:ListPackageVersions',\n            'codeartifact:ListPackageVersionAssets',\n            'codeartifact:ListPackageVersionDependencies',\n            'codeartifact:ReadFromRepository',\n          ],\n          effect: Effect.ALLOW,\n        }),\n      );\n    }\n\n    this.pipeline = new CodePipeline(this, 'CodePipeline', {\n      codePipeline: underlyingPipeline,\n      selfMutation: props.selfMutation ?? true,\n      dockerEnabledForSynth: props.dockerEnabledForSynth ?? true,\n      dockerEnabledForSelfMutation: props.dockerEnabledForSelfMutation ?? true,\n      publishAssetsInParallel: props.publishAssetsInParallel ?? false,\n      synth: new ShellStep('Synth', {\n        primaryOutputDirectory: `${cdkDirectory}/cdk.out`,\n        input,\n        commands,\n        additionalInputs: props.additionalInputs ?? {},\n      }),\n      synthCodeBuildDefaults: {\n        partialBuildSpec: BuildSpec.fromObject({\n          cache: {\n            paths: ['/root/.npm/**/*', '/root/.pnpm-store/**/*'],\n          },\n          phases: {\n            install: {\n              'runtime-versions': {\n                nodejs: props.nodeVersion ?? NodeVersion.NODE_24,\n                go: props.goVersion,\n                java: props.javaVersion,\n                dotnet: props.dotnetVersion,\n                python: props.pythonVersion,\n              },\n              'commands': ['npm config set fund false', 'npm -g i esbuild']\n                .concat(props.additionalInstallCommands ?? [])\n                .concat(['node --version']),\n            },\n          },\n        }),\n        buildEnvironment: {\n          privileged: true,\n          computeType: props.computeType ?? ComputeType.SMALL,\n          buildImage: props.buildImage ?? LinuxBuildImage.AMAZON_LINUX_2_5,\n        },\n        rolePolicy,\n      },\n      assetPublishingCodeBuildDefaults: {\n        partialBuildSpec: BuildSpec.fromObject({\n          env: {\n            variables: {\n              ...((props.enableDockerBuildxOnAssetPublish ?? true)\n                ? {CDK_DOCKER: '/usr/local/bin/buildx.sh'}\n                : {}),\n            },\n          },\n          phases: {\n            install: {\n              commands:\n                (props.enableDockerBuildxOnAssetPublish ?? true)\n                  ? DOCKER_BUILDX_SETUP_COMMANDS\n                  : [],\n            },\n          },\n        }),\n      },\n    });\n\n    // Disable automatic triggering if requested\n    if (props.disableAutoTrigger) {\n      const cfnPipeline = underlyingPipeline.node.defaultChild as CfnPipeline;\n      cfnPipeline.addPropertyOverride(\n        'Stages.0.Actions.0.Configuration.TriggerConfiguration',\n        {\n          ProviderType: 'CodeStarSourceConnection',\n          TriggerEvents: 'NONE',\n        },\n      );\n    }\n\n    // Apply GitPushFilter if provided\n    if (props.gitPushFilter && props.gitPushFilter.length > 0) {\n      const cfnPipeline = underlyingPipeline.node.defaultChild as CfnPipeline;\n      cfnPipeline.addPropertyOverride(\n        'Stages.0.Actions.0.Configuration.TriggerConfiguration.GitConfiguration.Push',\n        props.gitPushFilter.map((filter) => ({\n          Branches: filter.branchesIncludes\n            ? {Includes: filter.branchesIncludes}\n            : filter.branchesExcludes\n              ? {Excludes: filter.branchesExcludes}\n              : undefined,\n          FilePaths: filter.filePathsIncludes\n            ? {Includes: filter.filePathsIncludes}\n            : filter.filePathsExcludes\n              ? {Excludes: filter.filePathsExcludes}\n              : undefined,\n          Tags: filter.tagsIncludes\n            ? {Includes: filter.tagsIncludes}\n            : filter.tagsExcludes\n              ? {Excludes: filter.tagsExcludes}\n              : undefined,\n        })),\n      );\n    }\n\n    // Handle pipeline notifications\n    if (props.slackChannelConfiguration && props.slackChannelConfigurationArn) {\n      throw new Error(\n        'Only one of slackChannelConfiguration and slackChannelConfigurationArn can be specified',\n      );\n    }\n    if (props.notificationTopic && props.notificationTopicArn) {\n      throw new Error(\n        'Only one of notificationTopic and notificationTopicArn can be specified',\n      );\n    }\n    if (\n      props.slackChannelConfiguration ||\n      props.slackChannelConfigurationArn ||\n      props.notificationTopicArn ||\n      props.notificationTopic\n    ) {\n      this.pipelineNotificationRule = new PipelineNotificationRule(\n        this,\n        'Notification',\n        {\n          events: props.notificationEvents,\n          source: underlyingPipeline,\n        },\n      );\n      if (props.slackChannelConfiguration) {\n        this.pipelineNotificationRule.addSlackChannel(\n          props.slackChannelConfiguration,\n        );\n      } else if (props.slackChannelConfigurationArn) {\n        this.pipelineNotificationRule.addSlackChannelArn(\n          'SlackChannel',\n          props.slackChannelConfigurationArn,\n        );\n      }\n      if (props.notificationTopic) {\n        this.pipelineNotificationRule.addTopic(props.notificationTopic);\n        props.notificationTopic.grantPublish(underlyingPipeline.role);\n      } else if (props.notificationTopicArn) {\n        const topic = this.pipelineNotificationRule.addTopicArn(\n          'NotificationTopic',\n          props.notificationTopicArn,\n        );\n        topic.grantPublish(underlyingPipeline.role);\n      }\n    }\n  }\n\n  addStage(stage: Stage, options?: AddStageOpts): StageDeployment {\n    return this.pipeline.addStage(stage, options);\n  }\n\n  addWave(id: string, options?: WaveOptions): Wave {\n    return this.pipeline.addWave(id, options);\n  }\n}\n"]}
|