@pipeline-builder/pipeline-core 3.1.1
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.
- package/LICENSE +202 -0
- package/README.md +32 -0
- package/lib/config/app-config.d.ts +81 -0
- package/lib/config/app-config.js +151 -0
- package/lib/config/billing-config.d.ts +17 -0
- package/lib/config/billing-config.js +95 -0
- package/lib/config/config-types.d.ts +213 -0
- package/lib/config/config-types.js +5 -0
- package/lib/config/infrastructure-config.d.ts +55 -0
- package/lib/config/infrastructure-config.js +200 -0
- package/lib/config/server-config.d.ts +53 -0
- package/lib/config/server-config.js +180 -0
- package/lib/core/artifact-manager.d.ts +62 -0
- package/lib/core/artifact-manager.js +86 -0
- package/lib/core/id-generator.d.ts +26 -0
- package/lib/core/id-generator.js +44 -0
- package/lib/core/metadata-builder.d.ts +13 -0
- package/lib/core/metadata-builder.js +81 -0
- package/lib/core/network-types.d.ts +200 -0
- package/lib/core/network-types.js +5 -0
- package/lib/core/network.d.ts +20 -0
- package/lib/core/network.js +84 -0
- package/lib/core/pipeline-helpers.d.ts +53 -0
- package/lib/core/pipeline-helpers.js +273 -0
- package/lib/core/pipeline-types.d.ts +136 -0
- package/lib/core/pipeline-types.js +140 -0
- package/lib/core/role-types.d.ts +254 -0
- package/lib/core/role-types.js +5 -0
- package/lib/core/role.d.ts +14 -0
- package/lib/core/role.js +118 -0
- package/lib/core/security-group-types.d.ts +84 -0
- package/lib/core/security-group-types.js +5 -0
- package/lib/core/security-group.d.ts +14 -0
- package/lib/core/security-group.js +34 -0
- package/lib/handlers/plugin-lookup-handler.d.ts +32 -0
- package/lib/handlers/plugin-lookup-handler.js +313 -0
- package/lib/handlers/pnpm-lock.yaml +12 -0
- package/lib/index.d.ts +54 -0
- package/lib/index.js +112 -0
- package/lib/pipeline/pipeline-builder.d.ts +82 -0
- package/lib/pipeline/pipeline-builder.js +292 -0
- package/lib/pipeline/pipeline-configuration.d.ts +72 -0
- package/lib/pipeline/pipeline-configuration.js +196 -0
- package/lib/pipeline/plugin-lookup.d.ts +100 -0
- package/lib/pipeline/plugin-lookup.js +247 -0
- package/lib/pipeline/source-builder.d.ts +47 -0
- package/lib/pipeline/source-builder.js +111 -0
- package/lib/pipeline/source-types.d.ts +191 -0
- package/lib/pipeline/source-types.js +5 -0
- package/lib/pipeline/stage-builder.d.ts +71 -0
- package/lib/pipeline/stage-builder.js +118 -0
- package/lib/pipeline/step-types.d.ts +307 -0
- package/lib/pipeline/step-types.js +5 -0
- 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"]}
|