@pipeline-builder/pipeline-core 3.1.0

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.
Files changed (54) hide show
  1. package/LICENSE +202 -0
  2. package/README.md +32 -0
  3. package/lib/config/app-config.d.ts +81 -0
  4. package/lib/config/app-config.js +151 -0
  5. package/lib/config/billing-config.d.ts +17 -0
  6. package/lib/config/billing-config.js +95 -0
  7. package/lib/config/config-types.d.ts +213 -0
  8. package/lib/config/config-types.js +5 -0
  9. package/lib/config/infrastructure-config.d.ts +55 -0
  10. package/lib/config/infrastructure-config.js +200 -0
  11. package/lib/config/server-config.d.ts +53 -0
  12. package/lib/config/server-config.js +180 -0
  13. package/lib/core/artifact-manager.d.ts +62 -0
  14. package/lib/core/artifact-manager.js +86 -0
  15. package/lib/core/id-generator.d.ts +26 -0
  16. package/lib/core/id-generator.js +44 -0
  17. package/lib/core/metadata-builder.d.ts +13 -0
  18. package/lib/core/metadata-builder.js +81 -0
  19. package/lib/core/network-types.d.ts +200 -0
  20. package/lib/core/network-types.js +5 -0
  21. package/lib/core/network.d.ts +20 -0
  22. package/lib/core/network.js +84 -0
  23. package/lib/core/pipeline-helpers.d.ts +53 -0
  24. package/lib/core/pipeline-helpers.js +273 -0
  25. package/lib/core/pipeline-types.d.ts +136 -0
  26. package/lib/core/pipeline-types.js +140 -0
  27. package/lib/core/role-types.d.ts +254 -0
  28. package/lib/core/role-types.js +5 -0
  29. package/lib/core/role.d.ts +14 -0
  30. package/lib/core/role.js +118 -0
  31. package/lib/core/security-group-types.d.ts +84 -0
  32. package/lib/core/security-group-types.js +5 -0
  33. package/lib/core/security-group.d.ts +14 -0
  34. package/lib/core/security-group.js +34 -0
  35. package/lib/handlers/plugin-lookup-handler.d.ts +32 -0
  36. package/lib/handlers/plugin-lookup-handler.js +313 -0
  37. package/lib/handlers/pnpm-lock.yaml +12 -0
  38. package/lib/index.d.ts +54 -0
  39. package/lib/index.js +112 -0
  40. package/lib/pipeline/pipeline-builder.d.ts +82 -0
  41. package/lib/pipeline/pipeline-builder.js +292 -0
  42. package/lib/pipeline/pipeline-configuration.d.ts +72 -0
  43. package/lib/pipeline/pipeline-configuration.js +196 -0
  44. package/lib/pipeline/plugin-lookup.d.ts +100 -0
  45. package/lib/pipeline/plugin-lookup.js +247 -0
  46. package/lib/pipeline/source-builder.d.ts +47 -0
  47. package/lib/pipeline/source-builder.js +111 -0
  48. package/lib/pipeline/source-types.d.ts +191 -0
  49. package/lib/pipeline/source-types.js +5 -0
  50. package/lib/pipeline/stage-builder.d.ts +71 -0
  51. package/lib/pipeline/stage-builder.js +118 -0
  52. package/lib/pipeline/step-types.d.ts +307 -0
  53. package/lib/pipeline/step-types.js +5 -0
  54. package/package.json +137 -0
@@ -0,0 +1,47 @@
1
+ import { CodePipelineSource } from 'aws-cdk-lib/pipelines';
2
+ import { Construct } from 'constructs';
3
+ import type { PipelineConfiguration } from './pipeline-configuration';
4
+ import { UniqueId } from '../core/id-generator';
5
+ /**
6
+ * Creates the appropriate CodePipelineSource based on the pipeline configuration.
7
+ *
8
+ * Supports S3, GitHub, CodeStar connection, and CodeCommit sources.
9
+ *
10
+ * **Note on SCHEDULE triggers:** Scheduled pipelines require an EventBridge rule
11
+ * that starts the pipeline on a cron schedule. The source trigger is set to NONE
12
+ * (no polling/webhook). The EventBridge rule must be created separately as a
13
+ * pipeline-level construct, not at the source level. The `schedule` field on
14
+ * source options captures the cron expression for API/frontend use, but the
15
+ * actual EventBridge rule creation is not yet implemented in this builder.
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * const sourceBuilder = new SourceBuilder(this, config);
20
+ * const source = sourceBuilder.create(uniqueId);
21
+ * ```
22
+ */
23
+ export declare class SourceBuilder {
24
+ private readonly scope;
25
+ private readonly config;
26
+ constructor(scope: Construct, config: PipelineConfiguration);
27
+ /**
28
+ * Creates the appropriate CodePipelineSource based on source type
29
+ */
30
+ create(id: UniqueId): CodePipelineSource;
31
+ /**
32
+ * Creates an S3 source for the pipeline
33
+ */
34
+ private createS3Source;
35
+ /**
36
+ * Creates a GitHub source for the pipeline
37
+ */
38
+ private createGitHubSource;
39
+ /**
40
+ * Creates a CodeStar connection source for the pipeline
41
+ */
42
+ private createCodeStarSource;
43
+ /**
44
+ * Creates a CodeCommit source for the pipeline
45
+ */
46
+ private createCodeCommitSource;
47
+ }
@@ -0,0 +1,111 @@
1
+ "use strict";
2
+ // Copyright 2026 Pipeline Builder Contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.SourceBuilder = void 0;
6
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ const aws_codecommit_1 = require("aws-cdk-lib/aws-codecommit");
8
+ const aws_codepipeline_actions_1 = require("aws-cdk-lib/aws-codepipeline-actions");
9
+ const aws_s3_1 = require("aws-cdk-lib/aws-s3");
10
+ const pipelines_1 = require("aws-cdk-lib/pipelines");
11
+ const pipeline_helpers_1 = require("../core/pipeline-helpers");
12
+ const pipeline_types_1 = require("../core/pipeline-types");
13
+ /**
14
+ * Creates the appropriate CodePipelineSource based on the pipeline configuration.
15
+ *
16
+ * Supports S3, GitHub, CodeStar connection, and CodeCommit sources.
17
+ *
18
+ * **Note on SCHEDULE triggers:** Scheduled pipelines require an EventBridge rule
19
+ * that starts the pipeline on a cron schedule. The source trigger is set to NONE
20
+ * (no polling/webhook). The EventBridge rule must be created separately as a
21
+ * pipeline-level construct, not at the source level. The `schedule` field on
22
+ * source options captures the cron expression for API/frontend use, but the
23
+ * actual EventBridge rule creation is not yet implemented in this builder.
24
+ *
25
+ * @example
26
+ * ```typescript
27
+ * const sourceBuilder = new SourceBuilder(this, config);
28
+ * const source = sourceBuilder.create(uniqueId);
29
+ * ```
30
+ */
31
+ class SourceBuilder {
32
+ scope;
33
+ config;
34
+ constructor(scope, config) {
35
+ this.scope = scope;
36
+ this.config = config;
37
+ }
38
+ /**
39
+ * Creates the appropriate CodePipelineSource based on source type
40
+ */
41
+ create(id) {
42
+ switch (this.config.source.type) {
43
+ case 's3':
44
+ return this.createS3Source(id);
45
+ case 'github':
46
+ return this.createGitHubSource();
47
+ case 'codestar':
48
+ return this.createCodeStarSource();
49
+ case 'codecommit':
50
+ return this.createCodeCommitSource(id);
51
+ default: {
52
+ const _exhaustive = this.config.source;
53
+ throw new Error(`Unsupported source type: ${_exhaustive.type}`);
54
+ }
55
+ }
56
+ }
57
+ /**
58
+ * Creates an S3 source for the pipeline
59
+ */
60
+ createS3Source(id) {
61
+ const options = this.config.getS3Options();
62
+ const bucket = aws_s3_1.Bucket.fromBucketName(this.scope, id.generate('source:bucket'), options.bucketName);
63
+ let trigger;
64
+ switch (options.trigger) {
65
+ case pipeline_types_1.TriggerType.AUTO:
66
+ trigger = aws_codepipeline_actions_1.S3Trigger.EVENTS;
67
+ break;
68
+ case pipeline_types_1.TriggerType.SCHEDULE:
69
+ trigger = aws_codepipeline_actions_1.S3Trigger.NONE;
70
+ break;
71
+ default: trigger = aws_codepipeline_actions_1.S3Trigger.NONE;
72
+ }
73
+ return pipelines_1.CodePipelineSource.s3(bucket, options.objectKey, { trigger });
74
+ }
75
+ /**
76
+ * Creates a GitHub source for the pipeline
77
+ */
78
+ createGitHubSource() {
79
+ const options = this.config.getGitHubOptions();
80
+ const authentication = options.token
81
+ ? (typeof options.token === 'string' ? aws_cdk_lib_1.SecretValue.unsafePlainText(options.token) : options.token)
82
+ : undefined;
83
+ return pipelines_1.CodePipelineSource.gitHub(options.repo, options.branch, {
84
+ trigger: options.trigger === pipeline_types_1.TriggerType.AUTO ? aws_codepipeline_actions_1.GitHubTrigger.POLL : aws_codepipeline_actions_1.GitHubTrigger.NONE,
85
+ authentication,
86
+ });
87
+ }
88
+ /**
89
+ * Creates a CodeStar connection source for the pipeline
90
+ */
91
+ createCodeStarSource() {
92
+ const options = this.config.getCodeStarOptions();
93
+ return pipelines_1.CodePipelineSource.connection(options.repo, options.branch, {
94
+ connectionArn: (0, pipeline_helpers_1.unwrapSecret)(options.connectionArn),
95
+ triggerOnPush: options.trigger === pipeline_types_1.TriggerType.AUTO,
96
+ codeBuildCloneOutput: options.codeBuildCloneOutput,
97
+ });
98
+ }
99
+ /**
100
+ * Creates a CodeCommit source for the pipeline
101
+ */
102
+ createCodeCommitSource(id) {
103
+ const options = this.config.getCodeCommitOptions();
104
+ const repository = aws_codecommit_1.Repository.fromRepositoryName(this.scope, id.generate('source:repo'), options.repositoryName);
105
+ return pipelines_1.CodePipelineSource.codeCommit(repository, options.branch ?? 'main', {
106
+ trigger: options.trigger === pipeline_types_1.TriggerType.AUTO ? aws_codepipeline_actions_1.CodeCommitTrigger.EVENTS : aws_codepipeline_actions_1.CodeCommitTrigger.NONE,
107
+ });
108
+ }
109
+ }
110
+ exports.SourceBuilder = SourceBuilder;
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source-builder.js","sourceRoot":"","sources":["../../src/pipeline/source-builder.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { SecretValue } from 'aws-cdk-lib';\nimport { Repository } from 'aws-cdk-lib/aws-codecommit';\nimport { CodeCommitTrigger, GitHubTrigger, S3Trigger } from 'aws-cdk-lib/aws-codepipeline-actions';\nimport { Bucket } from 'aws-cdk-lib/aws-s3';\nimport { CodePipelineSource } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport type { PipelineConfiguration } from './pipeline-configuration';\nimport { UniqueId } from '../core/id-generator';\nimport { unwrapSecret } from '../core/pipeline-helpers';\nimport { TriggerType, type SourceType } from '../core/pipeline-types';\n\n/**\n * Creates the appropriate CodePipelineSource based on the pipeline configuration.\n *\n * Supports S3, GitHub, CodeStar connection, and CodeCommit sources.\n *\n * **Note on SCHEDULE triggers:** Scheduled pipelines require an EventBridge rule\n * that starts the pipeline on a cron schedule. The source trigger is set to NONE\n * (no polling/webhook). The EventBridge rule must be created separately as a\n * pipeline-level construct, not at the source level. The `schedule` field on\n * source options captures the cron expression for API/frontend use, but the\n * actual EventBridge rule creation is not yet implemented in this builder.\n *\n * @example\n * ```typescript\n * const sourceBuilder = new SourceBuilder(this, config);\n * const source = sourceBuilder.create(uniqueId);\n * ```\n */\nexport class SourceBuilder {\n  constructor(\n    private readonly scope: Construct,\n    private readonly config: PipelineConfiguration,\n  ) {}\n\n  /**\n   * Creates the appropriate CodePipelineSource based on source type\n   */\n  create(id: UniqueId): CodePipelineSource {\n    switch (this.config.source.type) {\n      case 's3':\n        return this.createS3Source(id);\n      case 'github':\n        return this.createGitHubSource();\n      case 'codestar':\n        return this.createCodeStarSource();\n      case 'codecommit':\n        return this.createCodeCommitSource(id);\n      default: {\n        const _exhaustive: never = this.config.source;\n        throw new Error(`Unsupported source type: ${(_exhaustive as SourceType).type}`);\n      }\n    }\n  }\n\n  /**\n   * Creates an S3 source for the pipeline\n   */\n  private createS3Source(id: UniqueId): CodePipelineSource {\n    const options = this.config.getS3Options();\n\n    const bucket = Bucket.fromBucketName(\n      this.scope,\n      id.generate('source:bucket'),\n      options.bucketName,\n    );\n\n    let trigger: S3Trigger;\n    switch (options.trigger) {\n      case TriggerType.AUTO: trigger = S3Trigger.EVENTS; break;\n      case TriggerType.SCHEDULE: trigger = S3Trigger.NONE; break;\n      default: trigger = S3Trigger.NONE;\n    }\n\n    return CodePipelineSource.s3(bucket, options.objectKey, { trigger });\n  }\n\n  /**\n   * Creates a GitHub source for the pipeline\n   */\n  private createGitHubSource(): CodePipelineSource {\n    const options = this.config.getGitHubOptions();\n\n    const authentication = options.token\n      ? (typeof options.token === 'string' ? SecretValue.unsafePlainText(options.token) : options.token)\n      : undefined;\n\n    return CodePipelineSource.gitHub(options.repo, options.branch, {\n      trigger: options.trigger === TriggerType.AUTO ? GitHubTrigger.POLL : GitHubTrigger.NONE,\n      authentication,\n    });\n  }\n\n  /**\n   * Creates a CodeStar connection source for the pipeline\n   */\n  private createCodeStarSource(): CodePipelineSource {\n    const options = this.config.getCodeStarOptions();\n\n    return CodePipelineSource.connection(options.repo, options.branch, {\n      connectionArn: unwrapSecret(options.connectionArn),\n      triggerOnPush: options.trigger === TriggerType.AUTO,\n      codeBuildCloneOutput: options.codeBuildCloneOutput,\n    });\n  }\n\n  /**\n   * Creates a CodeCommit source for the pipeline\n   */\n  private createCodeCommitSource(id: UniqueId): CodePipelineSource {\n    const options = this.config.getCodeCommitOptions();\n\n    const repository = Repository.fromRepositoryName(\n      this.scope,\n      id.generate('source:repo'),\n      options.repositoryName,\n    );\n\n    return CodePipelineSource.codeCommit(repository, options.branch ?? 'main', {\n      trigger: options.trigger === TriggerType.AUTO ? CodeCommitTrigger.EVENTS : CodeCommitTrigger.NONE,\n    });\n  }\n}\n"]}
@@ -0,0 +1,191 @@
1
+ import type { SecretValue } from 'aws-cdk-lib';
2
+ import type { TriggerType } from '../core/pipeline-types';
3
+ /**
4
+ * S3 source configuration for CodePipeline
5
+ *
6
+ * @example
7
+ * ```typescript
8
+ * const source: S3SourceConfig = {
9
+ * type: 's3',
10
+ * options: {
11
+ * bucketName: 'my-source-bucket',
12
+ * objectKey: 'source.zip',
13
+ * trigger: TriggerType.AUTO
14
+ * }
15
+ * };
16
+ * ```
17
+ */
18
+ export interface S3SourceConfig {
19
+ readonly type: 's3';
20
+ readonly options: S3Options;
21
+ }
22
+ /**
23
+ * GitHub source configuration for CodePipeline
24
+ *
25
+ * @example
26
+ * ```typescript
27
+ * const source: GitHubSourceConfig = {
28
+ * type: 'github',
29
+ * options: {
30
+ * repo: 'owner/repository',
31
+ * branch: 'main',
32
+ * trigger: TriggerType.AUTO
33
+ * }
34
+ * };
35
+ * ```
36
+ */
37
+ export interface GitHubSourceConfig {
38
+ readonly type: 'github';
39
+ readonly options: GitHubOptions;
40
+ }
41
+ /**
42
+ * CodeStar connection source configuration for CodePipeline
43
+ *
44
+ * @example
45
+ * ```typescript
46
+ * const source: CodeStarSourceConfig = {
47
+ * type: 'codestar',
48
+ * options: {
49
+ * repo: 'owner/repository',
50
+ * branch: 'main',
51
+ * connectionArn: 'arn:aws:codestar-connections:...',
52
+ * trigger: TriggerType.AUTO
53
+ * }
54
+ * };
55
+ * ```
56
+ */
57
+ export interface CodeStarSourceConfig {
58
+ readonly type: 'codestar';
59
+ readonly options: CodeStarOptions;
60
+ }
61
+ /**
62
+ * Configuration options for S3 pipeline source
63
+ */
64
+ export interface S3Options {
65
+ /**
66
+ * Name of the S3 bucket containing the source code
67
+ * @example 'my-pipeline-source-bucket'
68
+ */
69
+ readonly bucketName: string;
70
+ /**
71
+ * Object key (path) to the source archive within the bucket
72
+ * @default 'source.zip'
73
+ */
74
+ readonly objectKey?: string;
75
+ /**
76
+ * Pipeline trigger behavior
77
+ * @default TriggerType.NONE
78
+ */
79
+ readonly trigger?: TriggerType;
80
+ /**
81
+ * Cron expression for scheduled trigger (e.g., 'cron(0 0 * * ? *)' for daily).
82
+ * Only used when trigger is SCHEDULE.
83
+ */
84
+ readonly schedule?: string;
85
+ }
86
+ /**
87
+ * Configuration options for GitHub pipeline source
88
+ */
89
+ export interface GitHubOptions {
90
+ /**
91
+ * GitHub repository in the format "owner/repo"
92
+ * @example 'myorg/myrepo'
93
+ */
94
+ readonly repo: string;
95
+ /**
96
+ * Branch to track
97
+ * @default 'main'
98
+ */
99
+ readonly branch?: string;
100
+ /**
101
+ * GitHub personal access token or SecretValue
102
+ * If not provided, uses default GitHub authentication
103
+ */
104
+ readonly token?: SecretValue | string;
105
+ /**
106
+ * Pipeline trigger behavior
107
+ * @default TriggerType.NONE
108
+ */
109
+ readonly trigger?: TriggerType;
110
+ /**
111
+ * Cron expression for scheduled trigger (e.g., 'cron(0 0 * * ? *)' for daily).
112
+ * Only used when trigger is SCHEDULE.
113
+ */
114
+ readonly schedule?: string;
115
+ }
116
+ /**
117
+ * Configuration options for CodeStar connection pipeline source
118
+ */
119
+ export interface CodeStarOptions {
120
+ /**
121
+ * Repository identifier in the format "owner/repo"
122
+ * @example 'myorg/myrepo'
123
+ */
124
+ readonly repo: string;
125
+ /**
126
+ * Branch to track
127
+ * @default 'main'
128
+ */
129
+ readonly branch?: string;
130
+ /**
131
+ * ARN of the CodeStar connection to use
132
+ * Can be a string ARN or SecretValue
133
+ * @example 'arn:aws:codestar-connections:us-east-1:123456789012:connection/abc123'
134
+ */
135
+ readonly connectionArn: SecretValue | string;
136
+ /**
137
+ * Pipeline trigger behavior
138
+ * @default TriggerType.NONE
139
+ */
140
+ readonly trigger?: TriggerType;
141
+ /**
142
+ * Cron expression for scheduled trigger (e.g., 'cron(0 0 * * ? *)' for daily).
143
+ * Only used when trigger is SCHEDULE.
144
+ */
145
+ readonly schedule?: string;
146
+ /**
147
+ * Whether to enable full clone capability in CodeBuild
148
+ * When true, CodeBuild can perform git operations on the full repository
149
+ * @default false
150
+ */
151
+ readonly codeBuildCloneOutput?: boolean;
152
+ }
153
+ /**
154
+ * CodeCommit source configuration for CodePipeline
155
+ *
156
+ * @example
157
+ * ```typescript
158
+ * const source: CodeCommitSourceConfig = {
159
+ * type: 'codecommit',
160
+ * options: {
161
+ * repositoryName: 'my-repo',
162
+ * branch: 'main',
163
+ * trigger: TriggerType.AUTO
164
+ * }
165
+ * };
166
+ * ```
167
+ */
168
+ export interface CodeCommitSourceConfig {
169
+ readonly type: 'codecommit';
170
+ readonly options: CodeCommitOptions;
171
+ }
172
+ /**
173
+ * Configuration options for CodeCommit pipeline source
174
+ */
175
+ export interface CodeCommitOptions {
176
+ /**
177
+ * Name of the CodeCommit repository
178
+ * @example 'my-repo'
179
+ */
180
+ readonly repositoryName: string;
181
+ /**
182
+ * Branch to track
183
+ * @default 'main'
184
+ */
185
+ readonly branch?: string;
186
+ /**
187
+ * Pipeline trigger behavior
188
+ * @default TriggerType.NONE
189
+ */
190
+ readonly trigger?: TriggerType;
191
+ }
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ // Copyright 2026 Pipeline Builder Contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic291cmNlLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BpcGVsaW5lL3NvdXJjZS10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsK0NBQStDO0FBQy9DLHNDQUFzQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAyMDI2IFBpcGVsaW5lIEJ1aWxkZXIgQ29udHJpYnV0b3JzXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuXG5pbXBvcnQgdHlwZSB7IFNlY3JldFZhbHVlIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHR5cGUgeyBUcmlnZ2VyVHlwZSB9IGZyb20gJy4uL2NvcmUvcGlwZWxpbmUtdHlwZXMnO1xuXG4vKipcbiAqIFMzIHNvdXJjZSBjb25maWd1cmF0aW9uIGZvciBDb2RlUGlwZWxpbmVcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogY29uc3Qgc291cmNlOiBTM1NvdXJjZUNvbmZpZyA9IHtcbiAqICAgdHlwZTogJ3MzJyxcbiAqICAgb3B0aW9uczoge1xuICogICAgIGJ1Y2tldE5hbWU6ICdteS1zb3VyY2UtYnVja2V0JyxcbiAqICAgICBvYmplY3RLZXk6ICdzb3VyY2UuemlwJyxcbiAqICAgICB0cmlnZ2VyOiBUcmlnZ2VyVHlwZS5BVVRPXG4gKiAgIH1cbiAqIH07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTM1NvdXJjZUNvbmZpZyB7XG4gIHJlYWRvbmx5IHR5cGU6ICdzMyc7XG4gIHJlYWRvbmx5IG9wdGlvbnM6IFMzT3B0aW9ucztcbn1cblxuLyoqXG4gKiBHaXRIdWIgc291cmNlIGNvbmZpZ3VyYXRpb24gZm9yIENvZGVQaXBlbGluZVxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBjb25zdCBzb3VyY2U6IEdpdEh1YlNvdXJjZUNvbmZpZyA9IHtcbiAqICAgdHlwZTogJ2dpdGh1YicsXG4gKiAgIG9wdGlvbnM6IHtcbiAqICAgICByZXBvOiAnb3duZXIvcmVwb3NpdG9yeScsXG4gKiAgICAgYnJhbmNoOiAnbWFpbicsXG4gKiAgICAgdHJpZ2dlcjogVHJpZ2dlclR5cGUuQVVUT1xuICogICB9XG4gKiB9O1xuICogYGBgXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgR2l0SHViU291cmNlQ29uZmlnIHtcbiAgcmVhZG9ubHkgdHlwZTogJ2dpdGh1Yic7XG4gIHJlYWRvbmx5IG9wdGlvbnM6IEdpdEh1Yk9wdGlvbnM7XG59XG5cbi8qKlxuICogQ29kZVN0YXIgY29ubmVjdGlvbiBzb3VyY2UgY29uZmlndXJhdGlvbiBmb3IgQ29kZVBpcGVsaW5lXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGNvbnN0IHNvdXJjZTogQ29kZVN0YXJTb3VyY2VDb25maWcgPSB7XG4gKiAgIHR5cGU6ICdjb2Rlc3RhcicsXG4gKiAgIG9wdGlvbnM6IHtcbiAqICAgICByZXBvOiAnb3duZXIvcmVwb3NpdG9yeScsXG4gKiAgICAgYnJhbmNoOiAnbWFpbicsXG4gKiAgICAgY29ubmVjdGlvbkFybjogJ2Fybjphd3M6Y29kZXN0YXItY29ubmVjdGlvbnM6Li4uJyxcbiAqICAgICB0cmlnZ2VyOiBUcmlnZ2VyVHlwZS5BVVRPXG4gKiAgIH1cbiAqIH07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDb2RlU3RhclNvdXJjZUNvbmZpZyB7XG4gIHJlYWRvbmx5IHR5cGU6ICdjb2Rlc3Rhcic7XG4gIHJlYWRvbmx5IG9wdGlvbnM6IENvZGVTdGFyT3B0aW9ucztcbn1cblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIFMzIHBpcGVsaW5lIHNvdXJjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFMzT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBTMyBidWNrZXQgY29udGFpbmluZyB0aGUgc291cmNlIGNvZGVcbiAgICogQGV4YW1wbGUgJ215LXBpcGVsaW5lLXNvdXJjZS1idWNrZXQnXG4gICAqL1xuICByZWFkb25seSBidWNrZXROYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIE9iamVjdCBrZXkgKHBhdGgpIHRvIHRoZSBzb3VyY2UgYXJjaGl2ZSB3aXRoaW4gdGhlIGJ1Y2tldFxuICAgKiBAZGVmYXVsdCAnc291cmNlLnppcCdcbiAgICovXG4gIHJlYWRvbmx5IG9iamVjdEtleT86IHN0cmluZztcblxuICAvKipcbiAgICogUGlwZWxpbmUgdHJpZ2dlciBiZWhhdmlvclxuICAgKiBAZGVmYXVsdCBUcmlnZ2VyVHlwZS5OT05FXG4gICAqL1xuICByZWFkb25seSB0cmlnZ2VyPzogVHJpZ2dlclR5cGU7XG5cbiAgLyoqXG4gICAqIENyb24gZXhwcmVzc2lvbiBmb3Igc2NoZWR1bGVkIHRyaWdnZXIgKGUuZy4sICdjcm9uKDAgMCAqICogPyAqKScgZm9yIGRhaWx5KS5cbiAgICogT25seSB1c2VkIHdoZW4gdHJpZ2dlciBpcyBTQ0hFRFVMRS5cbiAgICovXG4gIHJlYWRvbmx5IHNjaGVkdWxlPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gb3B0aW9ucyBmb3IgR2l0SHViIHBpcGVsaW5lIHNvdXJjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEdpdEh1Yk9wdGlvbnMge1xuICAvKipcbiAgICogR2l0SHViIHJlcG9zaXRvcnkgaW4gdGhlIGZvcm1hdCBcIm93bmVyL3JlcG9cIlxuICAgKiBAZXhhbXBsZSAnbXlvcmcvbXlyZXBvJ1xuICAgKi9cbiAgcmVhZG9ubHkgcmVwbzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBCcmFuY2ggdG8gdHJhY2tcbiAgICogQGRlZmF1bHQgJ21haW4nXG4gICAqL1xuICByZWFkb25seSBicmFuY2g/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEdpdEh1YiBwZXJzb25hbCBhY2Nlc3MgdG9rZW4gb3IgU2VjcmV0VmFsdWVcbiAgICogSWYgbm90IHByb3ZpZGVkLCB1c2VzIGRlZmF1bHQgR2l0SHViIGF1dGhlbnRpY2F0aW9uXG4gICAqL1xuICByZWFkb25seSB0b2tlbj86IFNlY3JldFZhbHVlIHwgc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBQaXBlbGluZSB0cmlnZ2VyIGJlaGF2aW9yXG4gICAqIEBkZWZhdWx0IFRyaWdnZXJUeXBlLk5PTkVcbiAgICovXG4gIHJlYWRvbmx5IHRyaWdnZXI/OiBUcmlnZ2VyVHlwZTtcblxuICAvKipcbiAgICogQ3JvbiBleHByZXNzaW9uIGZvciBzY2hlZHVsZWQgdHJpZ2dlciAoZS5nLiwgJ2Nyb24oMCAwICogKiA/ICopJyBmb3IgZGFpbHkpLlxuICAgKiBPbmx5IHVzZWQgd2hlbiB0cmlnZ2VyIGlzIFNDSEVEVUxFLlxuICAgKi9cbiAgcmVhZG9ubHkgc2NoZWR1bGU/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBvcHRpb25zIGZvciBDb2RlU3RhciBjb25uZWN0aW9uIHBpcGVsaW5lIHNvdXJjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvZGVTdGFyT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBSZXBvc2l0b3J5IGlkZW50aWZpZXIgaW4gdGhlIGZvcm1hdCBcIm93bmVyL3JlcG9cIlxuICAgKiBAZXhhbXBsZSAnbXlvcmcvbXlyZXBvJ1xuICAgKi9cbiAgcmVhZG9ubHkgcmVwbzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBCcmFuY2ggdG8gdHJhY2tcbiAgICogQGRlZmF1bHQgJ21haW4nXG4gICAqL1xuICByZWFkb25seSBicmFuY2g/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEFSTiBvZiB0aGUgQ29kZVN0YXIgY29ubmVjdGlvbiB0byB1c2VcbiAgICogQ2FuIGJlIGEgc3RyaW5nIEFSTiBvciBTZWNyZXRWYWx1ZVxuICAgKiBAZXhhbXBsZSAnYXJuOmF3czpjb2Rlc3Rhci1jb25uZWN0aW9uczp1cy1lYXN0LTE6MTIzNDU2Nzg5MDEyOmNvbm5lY3Rpb24vYWJjMTIzJ1xuICAgKi9cbiAgcmVhZG9ubHkgY29ubmVjdGlvbkFybjogU2VjcmV0VmFsdWUgfCBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFBpcGVsaW5lIHRyaWdnZXIgYmVoYXZpb3JcbiAgICogQGRlZmF1bHQgVHJpZ2dlclR5cGUuTk9ORVxuICAgKi9cbiAgcmVhZG9ubHkgdHJpZ2dlcj86IFRyaWdnZXJUeXBlO1xuXG4gIC8qKlxuICAgKiBDcm9uIGV4cHJlc3Npb24gZm9yIHNjaGVkdWxlZCB0cmlnZ2VyIChlLmcuLCAnY3JvbigwIDAgKiAqID8gKiknIGZvciBkYWlseSkuXG4gICAqIE9ubHkgdXNlZCB3aGVuIHRyaWdnZXIgaXMgU0NIRURVTEUuXG4gICAqL1xuICByZWFkb25seSBzY2hlZHVsZT86IHN0cmluZztcblxuICAvKipcbiAgICogV2hldGhlciB0byBlbmFibGUgZnVsbCBjbG9uZSBjYXBhYmlsaXR5IGluIENvZGVCdWlsZFxuICAgKiBXaGVuIHRydWUsIENvZGVCdWlsZCBjYW4gcGVyZm9ybSBnaXQgb3BlcmF0aW9ucyBvbiB0aGUgZnVsbCByZXBvc2l0b3J5XG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBjb2RlQnVpbGRDbG9uZU91dHB1dD86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQ29kZUNvbW1pdCBzb3VyY2UgY29uZmlndXJhdGlvbiBmb3IgQ29kZVBpcGVsaW5lXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGNvbnN0IHNvdXJjZTogQ29kZUNvbW1pdFNvdXJjZUNvbmZpZyA9IHtcbiAqICAgdHlwZTogJ2NvZGVjb21taXQnLFxuICogICBvcHRpb25zOiB7XG4gKiAgICAgcmVwb3NpdG9yeU5hbWU6ICdteS1yZXBvJyxcbiAqICAgICBicmFuY2g6ICdtYWluJyxcbiAqICAgICB0cmlnZ2VyOiBUcmlnZ2VyVHlwZS5BVVRPXG4gKiAgIH1cbiAqIH07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDb2RlQ29tbWl0U291cmNlQ29uZmlnIHtcbiAgcmVhZG9ubHkgdHlwZTogJ2NvZGVjb21taXQnO1xuICByZWFkb25seSBvcHRpb25zOiBDb2RlQ29tbWl0T3B0aW9ucztcbn1cblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIENvZGVDb21taXQgcGlwZWxpbmUgc291cmNlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29kZUNvbW1pdE9wdGlvbnMge1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgQ29kZUNvbW1pdCByZXBvc2l0b3J5XG4gICAqIEBleGFtcGxlICdteS1yZXBvJ1xuICAgKi9cbiAgcmVhZG9ubHkgcmVwb3NpdG9yeU5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogQnJhbmNoIHRvIHRyYWNrXG4gICAqIEBkZWZhdWx0ICdtYWluJ1xuICAgKi9cbiAgcmVhZG9ubHkgYnJhbmNoPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBQaXBlbGluZSB0cmlnZ2VyIGJlaGF2aW9yXG4gICAqIEBkZWZhdWx0IFRyaWdnZXJUeXBlLk5PTkVcbiAgICovXG4gIHJlYWRvbmx5IHRyaWdnZXI/OiBUcmlnZ2VyVHlwZTtcbn1cbiJdfQ==
@@ -0,0 +1,71 @@
1
+ import type { ComputeType as CdkComputeType } from 'aws-cdk-lib/aws-codebuild';
2
+ import { CodePipeline } from 'aws-cdk-lib/pipelines';
3
+ import { Construct } from 'constructs';
4
+ import { PluginLookup } from './plugin-lookup';
5
+ import type { StageOptions } from './step-types';
6
+ import type { ArtifactManager } from '../core/artifact-manager';
7
+ import { UniqueId } from '../core/id-generator';
8
+ import type { MetaDataType } from '../core/pipeline-types';
9
+ /**
10
+ * Configuration properties for the StageBuilder
11
+ */
12
+ export interface StageBuilderProps {
13
+ /** CDK construct scope for creating child constructs */
14
+ readonly scope: Construct;
15
+ /** Plugin lookup service for resolving plugin references to CDK constructs */
16
+ readonly pluginLookup: PluginLookup;
17
+ /** Unique ID generator for creating deterministic construct IDs */
18
+ readonly uniqueId: UniqueId;
19
+ /** Global metadata inherited by all stage steps */
20
+ readonly globalMetadata: MetaDataType;
21
+ /** Default CodeBuild compute type for steps that don't specify one */
22
+ readonly defaultComputeType?: CdkComputeType;
23
+ /** Artifact manager for resolving input artifact keys to FileSets */
24
+ readonly artifactManager?: ArtifactManager;
25
+ /** Tenant identifier for resolving per-org secrets from AWS Secrets Manager */
26
+ readonly orgId?: string;
27
+ }
28
+ /**
29
+ * Builds and adds pipeline stages (waves) to a CodePipeline.
30
+ *
31
+ * Each stage is resolved from high-level configuration (plugin names)
32
+ * into CDK CodeBuild steps via PluginLookup, then added as a wave.
33
+ *
34
+ * @example
35
+ * ```typescript
36
+ * const stageBuilder = new StageBuilder({
37
+ * scope: this,
38
+ * pluginLookup,
39
+ * uniqueId,
40
+ * globalMetadata: mergedMetadata,
41
+ * });
42
+ * stageBuilder.addStage(pipeline, {
43
+ * stageName: 'Integration Tests',
44
+ * alias: 'integration',
45
+ * steps: [
46
+ * { plugin: { name: 'jest-integration' } },
47
+ * { plugin: { name: 'e2e-tests', alias: 'cypress' } },
48
+ * ],
49
+ * });
50
+ * ```
51
+ */
52
+ export declare class StageBuilder {
53
+ private readonly scope;
54
+ private readonly pluginLookup;
55
+ private readonly uniqueId;
56
+ private readonly globalMetadata;
57
+ private readonly defaultComputeType?;
58
+ private readonly artifactManager?;
59
+ private readonly orgId?;
60
+ constructor(props: StageBuilderProps);
61
+ /**
62
+ * Resolves a stage's plugin-based step configs into CodeBuild steps
63
+ * and adds them as a wave to the pipeline.
64
+ */
65
+ addStage(pipeline: CodePipeline, stage: StageOptions): void;
66
+ private resolveStep;
67
+ /**
68
+ * Resolves and adds multiple stages as waves to the pipeline, in order.
69
+ */
70
+ addStages(pipeline: CodePipeline, stages: StageOptions[]): void;
71
+ }
@@ -0,0 +1,118 @@
1
+ "use strict";
2
+ // Copyright 2026 Pipeline Builder Contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.StageBuilder = void 0;
6
+ const pipeline_helpers_1 = require("../core/pipeline-helpers");
7
+ /**
8
+ * Builds and adds pipeline stages (waves) to a CodePipeline.
9
+ *
10
+ * Each stage is resolved from high-level configuration (plugin names)
11
+ * into CDK CodeBuild steps via PluginLookup, then added as a wave.
12
+ *
13
+ * @example
14
+ * ```typescript
15
+ * const stageBuilder = new StageBuilder({
16
+ * scope: this,
17
+ * pluginLookup,
18
+ * uniqueId,
19
+ * globalMetadata: mergedMetadata,
20
+ * });
21
+ * stageBuilder.addStage(pipeline, {
22
+ * stageName: 'Integration Tests',
23
+ * alias: 'integration',
24
+ * steps: [
25
+ * { plugin: { name: 'jest-integration' } },
26
+ * { plugin: { name: 'e2e-tests', alias: 'cypress' } },
27
+ * ],
28
+ * });
29
+ * ```
30
+ */
31
+ class StageBuilder {
32
+ scope;
33
+ pluginLookup;
34
+ uniqueId;
35
+ globalMetadata;
36
+ defaultComputeType;
37
+ artifactManager;
38
+ orgId;
39
+ constructor(props) {
40
+ this.scope = props.scope;
41
+ this.pluginLookup = props.pluginLookup;
42
+ this.uniqueId = props.uniqueId;
43
+ this.globalMetadata = props.globalMetadata;
44
+ this.defaultComputeType = props.defaultComputeType;
45
+ this.artifactManager = props.artifactManager;
46
+ this.orgId = props.orgId;
47
+ }
48
+ /**
49
+ * Resolves a stage's plugin-based step configs into CodeBuild steps
50
+ * and adds them as a wave to the pipeline.
51
+ */
52
+ addStage(pipeline, stage) {
53
+ const stageAlias = stage.alias ?? `${stage.stageName}-alias`;
54
+ const preSteps = stage.steps
55
+ .filter(s => (s.position ?? 'pre') === 'pre')
56
+ .map(s => this.resolveStep(s, stage.stageName, stageAlias));
57
+ const postSteps = stage.steps
58
+ .filter(s => s.position === 'post')
59
+ .map(s => this.resolveStep(s, stage.stageName, stageAlias));
60
+ pipeline.addWave(stageAlias, {
61
+ ...(preSteps.length > 0 && { pre: preSteps }),
62
+ ...(postSteps.length > 0 && { post: postSteps }),
63
+ });
64
+ }
65
+ resolveStep(stepConfig, stageName, stageAlias) {
66
+ const plugin = this.pluginLookup.plugin(stepConfig.plugin);
67
+ const stepMetadata = (0, pipeline_helpers_1.merge)(this.globalMetadata, stepConfig.metadata ?? {});
68
+ const pluginAlias = stepConfig.plugin.alias ?? stepConfig.plugin.name;
69
+ if (stepConfig.inputArtifact && !this.artifactManager) {
70
+ throw new Error(`Step "${pluginAlias}" requires inputArtifact but no artifactManager is configured.`);
71
+ }
72
+ if (stepConfig.additionalInputArtifacts?.length && !this.artifactManager) {
73
+ throw new Error(`Step "${pluginAlias}" requires additionalInputArtifacts but no artifactManager is configured.`);
74
+ }
75
+ const input = stepConfig.inputArtifact && this.artifactManager
76
+ ? this.artifactManager.getOutput(stepConfig.inputArtifact)
77
+ : undefined;
78
+ const additionalInputs = stepConfig.additionalInputArtifacts?.length && this.artifactManager
79
+ ? Object.fromEntries(stepConfig.additionalInputArtifacts.map(({ artifact, directory }) => [
80
+ directory || artifact.outputDirectory,
81
+ this.artifactManager.getOutput(artifact),
82
+ ]))
83
+ : undefined;
84
+ return (0, pipeline_helpers_1.createCodeBuildStep)({
85
+ id: this.uniqueId.generate(`stage:${stageAlias}:${pluginAlias}`),
86
+ uniqueId: this.uniqueId,
87
+ plugin,
88
+ metadata: stepMetadata,
89
+ network: stepConfig.network,
90
+ scope: this.scope,
91
+ defaultComputeType: this.defaultComputeType,
92
+ input,
93
+ additionalInputs,
94
+ artifactManager: this.artifactManager,
95
+ stageName,
96
+ stageAlias,
97
+ pluginAlias,
98
+ preInstallCommands: stepConfig.preInstallCommands,
99
+ postInstallCommands: stepConfig.postInstallCommands,
100
+ preCommands: stepConfig.preCommands,
101
+ postCommands: stepConfig.postCommands,
102
+ env: stepConfig.env,
103
+ timeout: stepConfig.timeout ?? plugin.timeout ?? undefined,
104
+ failureBehavior: (stepConfig.failureBehavior ?? plugin.failureBehavior),
105
+ orgId: this.orgId,
106
+ });
107
+ }
108
+ /**
109
+ * Resolves and adds multiple stages as waves to the pipeline, in order.
110
+ */
111
+ addStages(pipeline, stages) {
112
+ for (const stage of stages) {
113
+ this.addStage(pipeline, stage);
114
+ }
115
+ }
116
+ }
117
+ exports.StageBuilder = StageBuilder;
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stage-builder.js","sourceRoot":"","sources":["../../src/pipeline/stage-builder.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { ComputeType as CdkComputeType } from 'aws-cdk-lib/aws-codebuild';\nimport { CodePipeline } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport { PluginLookup } from './plugin-lookup';\nimport type { StageOptions } from './step-types';\nimport type { ArtifactManager } from '../core/artifact-manager';\nimport { UniqueId } from '../core/id-generator';\nimport { createCodeBuildStep, merge } from '../core/pipeline-helpers';\nimport type { MetaDataType } from '../core/pipeline-types';\n\n/**\n * Configuration properties for the StageBuilder\n */\nexport interface StageBuilderProps {\n  /** CDK construct scope for creating child constructs */\n  readonly scope: Construct;\n\n  /** Plugin lookup service for resolving plugin references to CDK constructs */\n  readonly pluginLookup: PluginLookup;\n\n  /** Unique ID generator for creating deterministic construct IDs */\n  readonly uniqueId: UniqueId;\n\n  /** Global metadata inherited by all stage steps */\n  readonly globalMetadata: MetaDataType;\n\n  /** Default CodeBuild compute type for steps that don't specify one */\n  readonly defaultComputeType?: CdkComputeType;\n\n  /** Artifact manager for resolving input artifact keys to FileSets */\n  readonly artifactManager?: ArtifactManager;\n\n  /** Tenant identifier for resolving per-org secrets from AWS Secrets Manager */\n  readonly orgId?: string;\n}\n\n/**\n * Builds and adds pipeline stages (waves) to a CodePipeline.\n *\n * Each stage is resolved from high-level configuration (plugin names)\n * into CDK CodeBuild steps via PluginLookup, then added as a wave.\n *\n * @example\n * ```typescript\n * const stageBuilder = new StageBuilder({\n *   scope: this,\n *   pluginLookup,\n *   uniqueId,\n *   globalMetadata: mergedMetadata,\n * });\n * stageBuilder.addStage(pipeline, {\n *   stageName: 'Integration Tests',\n *   alias: 'integration',\n *   steps: [\n *     { plugin: { name: 'jest-integration' } },\n *     { plugin: { name: 'e2e-tests', alias: 'cypress' } },\n *   ],\n * });\n * ```\n */\nexport class StageBuilder {\n  private readonly scope: Construct;\n  private readonly pluginLookup: PluginLookup;\n  private readonly uniqueId: UniqueId;\n  private readonly globalMetadata: MetaDataType;\n  private readonly defaultComputeType?: CdkComputeType;\n  private readonly artifactManager?: ArtifactManager;\n  private readonly orgId?: string;\n\n  constructor(props: StageBuilderProps) {\n    this.scope = props.scope;\n    this.pluginLookup = props.pluginLookup;\n    this.uniqueId = props.uniqueId;\n    this.globalMetadata = props.globalMetadata;\n    this.defaultComputeType = props.defaultComputeType;\n    this.artifactManager = props.artifactManager;\n    this.orgId = props.orgId;\n  }\n\n  /**\n   * Resolves a stage's plugin-based step configs into CodeBuild steps\n   * and adds them as a wave to the pipeline.\n   */\n  addStage(pipeline: CodePipeline, stage: StageOptions): void {\n    const stageAlias = stage.alias ?? `${stage.stageName}-alias`;\n\n    const preSteps = stage.steps\n      .filter(s => (s.position ?? 'pre') === 'pre')\n      .map(s => this.resolveStep(s, stage.stageName, stageAlias));\n    const postSteps = stage.steps\n      .filter(s => s.position === 'post')\n      .map(s => this.resolveStep(s, stage.stageName, stageAlias));\n\n    pipeline.addWave(stageAlias, {\n      ...(preSteps.length > 0 && { pre: preSteps }),\n      ...(postSteps.length > 0 && { post: postSteps }),\n    });\n  }\n\n  private resolveStep(stepConfig: StageOptions['steps'][number], stageName: string, stageAlias: string) {\n    const plugin = this.pluginLookup.plugin(stepConfig.plugin);\n    const stepMetadata = merge(this.globalMetadata, stepConfig.metadata ?? {});\n    const pluginAlias = stepConfig.plugin.alias ?? stepConfig.plugin.name;\n\n    if (stepConfig.inputArtifact && !this.artifactManager) {\n      throw new Error(\n        `Step \"${pluginAlias}\" requires inputArtifact but no artifactManager is configured.`,\n      );\n    }\n    if (stepConfig.additionalInputArtifacts?.length && !this.artifactManager) {\n      throw new Error(\n        `Step \"${pluginAlias}\" requires additionalInputArtifacts but no artifactManager is configured.`,\n      );\n    }\n\n    const input = stepConfig.inputArtifact && this.artifactManager\n      ? this.artifactManager.getOutput(stepConfig.inputArtifact)\n      : undefined;\n\n    const additionalInputs = stepConfig.additionalInputArtifacts?.length && this.artifactManager\n      ? Object.fromEntries(\n        stepConfig.additionalInputArtifacts.map(({ artifact, directory }) => [\n          directory || artifact.outputDirectory,\n          this.artifactManager!.getOutput(artifact),\n        ]),\n      )\n      : undefined;\n\n    return createCodeBuildStep({\n      id: this.uniqueId.generate(`stage:${stageAlias}:${pluginAlias}`),\n      uniqueId: this.uniqueId,\n      plugin,\n      metadata: stepMetadata,\n      network: stepConfig.network,\n      scope: this.scope,\n      defaultComputeType: this.defaultComputeType,\n      input,\n      additionalInputs,\n      artifactManager: this.artifactManager,\n      stageName,\n      stageAlias,\n      pluginAlias,\n      preInstallCommands: stepConfig.preInstallCommands,\n      postInstallCommands: stepConfig.postInstallCommands,\n      preCommands: stepConfig.preCommands,\n      postCommands: stepConfig.postCommands,\n      env: stepConfig.env,\n      timeout: stepConfig.timeout ?? plugin.timeout ?? undefined,\n      failureBehavior: (stepConfig.failureBehavior ?? plugin.failureBehavior) as 'fail' | 'warn' | 'ignore',\n      orgId: this.orgId,\n    });\n  }\n\n  /**\n   * Resolves and adds multiple stages as waves to the pipeline, in order.\n   */\n  addStages(pipeline: CodePipeline, stages: StageOptions[]): void {\n    for (const stage of stages) {\n      this.addStage(pipeline, stage);\n    }\n  }\n}\n"]}