@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.
- 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,200 @@
|
|
|
1
|
+
import type { SecretValue } from 'aws-cdk-lib';
|
|
2
|
+
import type { MetaDataType } from './pipeline-types';
|
|
3
|
+
import type { SecurityGroupConfig } from './security-group-types';
|
|
4
|
+
/**
|
|
5
|
+
* Network configuration using explicit subnet IDs
|
|
6
|
+
*
|
|
7
|
+
* Use when you know the exact subnet IDs where CodeBuild should run.
|
|
8
|
+
* Subnets are selected directly by ID; VPC is looked up from the provided vpcId.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```typescript
|
|
12
|
+
* const network: SubnetIdsNetwork = {
|
|
13
|
+
* type: 'subnetIds',
|
|
14
|
+
* options: {
|
|
15
|
+
* vpcId: 'vpc-0a1b2c3d4e5f6a7b8',
|
|
16
|
+
* subnetIds: ['subnet-0a1b2c3d', 'subnet-4e5f6a7b'],
|
|
17
|
+
* securityGroupIds: ['sg-12345678']
|
|
18
|
+
* }
|
|
19
|
+
* };
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
export interface SubnetIdsNetwork {
|
|
23
|
+
readonly type: 'subnetIds';
|
|
24
|
+
readonly options: SubnetIdsNetworkOptions;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Network configuration using VPC lookup by ID
|
|
28
|
+
*
|
|
29
|
+
* Looks up an existing VPC by its ID and resolves subnets via subnetSelection filters.
|
|
30
|
+
*
|
|
31
|
+
* @example
|
|
32
|
+
* ```typescript
|
|
33
|
+
* const network: VpcIdNetwork = {
|
|
34
|
+
* type: 'vpcId',
|
|
35
|
+
* options: {
|
|
36
|
+
* vpcId: 'vpc-0a1b2c3d4e5f6a7b8',
|
|
37
|
+
* subnetType: 'PRIVATE_WITH_EGRESS',
|
|
38
|
+
* securityGroupIds: ['sg-12345678']
|
|
39
|
+
* }
|
|
40
|
+
* };
|
|
41
|
+
* ```
|
|
42
|
+
*/
|
|
43
|
+
export interface VpcIdNetwork {
|
|
44
|
+
readonly type: 'vpcId';
|
|
45
|
+
readonly options: VpcIdNetworkOptions;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Network configuration using VPC lookup by tags
|
|
49
|
+
*
|
|
50
|
+
* Looks up an existing VPC by tag filters and resolves subnets via subnetSelection filters.
|
|
51
|
+
*
|
|
52
|
+
* @example
|
|
53
|
+
* ```typescript
|
|
54
|
+
* const network: VpcLookupNetwork = {
|
|
55
|
+
* type: 'vpcLookup',
|
|
56
|
+
* options: {
|
|
57
|
+
* tags: { 'aws:cloudformation:stack-name': 'NetworkStack' },
|
|
58
|
+
* subnetType: 'PRIVATE_WITH_EGRESS',
|
|
59
|
+
* availabilityZones: ['us-east-1a', 'us-east-1b']
|
|
60
|
+
* }
|
|
61
|
+
* };
|
|
62
|
+
* ```
|
|
63
|
+
*/
|
|
64
|
+
export interface VpcLookupNetwork {
|
|
65
|
+
readonly type: 'vpcLookup';
|
|
66
|
+
readonly options: VpcLookupNetworkOptions;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Common subnet selection filters shared by VPC-based network options
|
|
70
|
+
*/
|
|
71
|
+
interface SubnetSelectionOptions {
|
|
72
|
+
/**
|
|
73
|
+
* Subnet type filter for subnet selection
|
|
74
|
+
* Maps to CDK SubnetType values
|
|
75
|
+
* @default 'PRIVATE_WITH_EGRESS'
|
|
76
|
+
*/
|
|
77
|
+
readonly subnetType?: SubnetTypeName;
|
|
78
|
+
/**
|
|
79
|
+
* Filter subnets to specific availability zones
|
|
80
|
+
* @example ['us-east-1a', 'us-east-1b']
|
|
81
|
+
*/
|
|
82
|
+
readonly availabilityZones?: string[];
|
|
83
|
+
/**
|
|
84
|
+
* Filter subnets by CDK subnet group name
|
|
85
|
+
* Matches the groupName assigned during VPC creation
|
|
86
|
+
*/
|
|
87
|
+
readonly subnetGroupName?: string;
|
|
88
|
+
/**
|
|
89
|
+
* Security group IDs to attach to CodeBuild projects
|
|
90
|
+
* @example ['sg-12345678']
|
|
91
|
+
*/
|
|
92
|
+
readonly securityGroupIds?: string[];
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Configuration options for explicit subnet ID network
|
|
96
|
+
*/
|
|
97
|
+
export interface SubnetIdsNetworkOptions {
|
|
98
|
+
/**
|
|
99
|
+
* VPC ID that contains the subnets.
|
|
100
|
+
* Required because CDK CodeBuildStep needs a vpc reference.
|
|
101
|
+
* Can be a plain string or a SecretValue (e.g. from Secrets Manager).
|
|
102
|
+
* @example 'vpc-0a1b2c3d4e5f6a7b8'
|
|
103
|
+
*/
|
|
104
|
+
readonly vpcId: SecretValue | string;
|
|
105
|
+
/**
|
|
106
|
+
* Explicit list of subnet IDs where CodeBuild projects will run
|
|
107
|
+
* @example ['subnet-0a1b2c3d', 'subnet-4e5f6a7b']
|
|
108
|
+
*/
|
|
109
|
+
readonly subnetIds: string[];
|
|
110
|
+
/**
|
|
111
|
+
* Security group IDs to attach to CodeBuild projects
|
|
112
|
+
* @example ['sg-12345678']
|
|
113
|
+
*/
|
|
114
|
+
readonly securityGroupIds?: string[];
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Configuration options for VPC lookup by ID
|
|
118
|
+
*/
|
|
119
|
+
export interface VpcIdNetworkOptions extends SubnetSelectionOptions {
|
|
120
|
+
/**
|
|
121
|
+
* VPC ID to look up
|
|
122
|
+
* Can be a plain string or a SecretValue (e.g. from Secrets Manager).
|
|
123
|
+
* @example 'vpc-0a1b2c3d4e5f6a7b8'
|
|
124
|
+
*/
|
|
125
|
+
readonly vpcId: SecretValue | string;
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Configuration options for VPC lookup by tags
|
|
129
|
+
*/
|
|
130
|
+
export interface VpcLookupNetworkOptions extends SubnetSelectionOptions {
|
|
131
|
+
/**
|
|
132
|
+
* Tag key-value pairs to identify the VPC
|
|
133
|
+
* All tags must match for lookup to succeed
|
|
134
|
+
* @example { Environment: 'production', Team: 'platform' }
|
|
135
|
+
*/
|
|
136
|
+
readonly tags: Record<string, string>;
|
|
137
|
+
/**
|
|
138
|
+
* Optional VPC name (value of the 'Name' tag) for additional filtering
|
|
139
|
+
*/
|
|
140
|
+
readonly vpcName?: string;
|
|
141
|
+
/**
|
|
142
|
+
* Optional AWS region override for cross-region VPC lookup
|
|
143
|
+
* @example 'us-west-2'
|
|
144
|
+
*/
|
|
145
|
+
readonly region?: string;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Subnet type names corresponding to CDK SubnetType enum values
|
|
149
|
+
*
|
|
150
|
+
* @see https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.SubnetType.html
|
|
151
|
+
*/
|
|
152
|
+
export type SubnetTypeName = 'PRIVATE_WITH_EGRESS' | 'PRIVATE_WITH_NAT' | 'PRIVATE_ISOLATED' | 'PUBLIC';
|
|
153
|
+
/**
|
|
154
|
+
* Union type of all supported network configurations.
|
|
155
|
+
*
|
|
156
|
+
* Used at two independent levels:
|
|
157
|
+
* - Pipeline-level (`defaults.network`) — applies to all CodeBuild actions
|
|
158
|
+
* - Step-level (`synth.network`, `CodeBuildStepOptions.network`) — applies to an individual build step
|
|
159
|
+
*
|
|
160
|
+
* Each variant resolves to vpc, subnetSelection, and optional securityGroups:
|
|
161
|
+
* - SubnetIdsNetwork: VPC looked up by ID, subnets selected explicitly by ID
|
|
162
|
+
* - VpcIdNetwork: VPC looked up by ID, subnets resolved via subnetSelection filters
|
|
163
|
+
* - VpcLookupNetwork: VPC looked up by tags, subnets resolved via subnetSelection filters
|
|
164
|
+
*/
|
|
165
|
+
export type NetworkConfig = SubnetIdsNetwork | VpcIdNetwork | VpcLookupNetwork;
|
|
166
|
+
/**
|
|
167
|
+
* Pipeline-level CodeBuild defaults applied to every CodeBuild action
|
|
168
|
+
* (synth, self-mutation, asset publishing) via `codeBuildDefaults`.
|
|
169
|
+
*
|
|
170
|
+
* @example
|
|
171
|
+
* ```typescript
|
|
172
|
+
* const defaults: CodeBuildDefaults = {
|
|
173
|
+
* network: {
|
|
174
|
+
* type: 'vpcId',
|
|
175
|
+
* options: { vpcId: 'vpc-abc123', subnetType: 'PRIVATE_WITH_EGRESS' }
|
|
176
|
+
* },
|
|
177
|
+
* metadata: {
|
|
178
|
+
* [MetadataKeys.PRIVILEGED]: true,
|
|
179
|
+
* },
|
|
180
|
+
* };
|
|
181
|
+
* ```
|
|
182
|
+
*/
|
|
183
|
+
export interface CodeBuildDefaults {
|
|
184
|
+
/**
|
|
185
|
+
* Network configuration for all CodeBuild actions.
|
|
186
|
+
* Resolves to vpc, subnetSelection, and optional securityGroups.
|
|
187
|
+
*/
|
|
188
|
+
readonly network?: NetworkConfig;
|
|
189
|
+
/**
|
|
190
|
+
* Standalone security groups for all CodeBuild actions.
|
|
191
|
+
* Merged with any security groups resolved from network config.
|
|
192
|
+
*/
|
|
193
|
+
readonly securityGroups?: SecurityGroupConfig;
|
|
194
|
+
/**
|
|
195
|
+
* Metadata applied to all CodeBuild actions.
|
|
196
|
+
* Merged with step-level metadata; step-level keys take precedence.
|
|
197
|
+
*/
|
|
198
|
+
readonly metadata?: MetaDataType;
|
|
199
|
+
}
|
|
200
|
+
export {};
|
|
@@ -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,{"version":3,"file":"network-types.js","sourceRoot":"","sources":["../../src/core/network-types.ts"],"names":[],"mappings":";AAAA,+CAA+C;AAC/C,sCAAsC","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { SecretValue } from 'aws-cdk-lib';\nimport type { MetaDataType } from './pipeline-types';\nimport type { SecurityGroupConfig } from './security-group-types';\n\n/**\n * Network configuration using explicit subnet IDs\n *\n * Use when you know the exact subnet IDs where CodeBuild should run.\n * Subnets are selected directly by ID; VPC is looked up from the provided vpcId.\n *\n * @example\n * ```typescript\n * const network: SubnetIdsNetwork = {\n *   type: 'subnetIds',\n *   options: {\n *     vpcId: 'vpc-0a1b2c3d4e5f6a7b8',\n *     subnetIds: ['subnet-0a1b2c3d', 'subnet-4e5f6a7b'],\n *     securityGroupIds: ['sg-12345678']\n *   }\n * };\n * ```\n */\nexport interface SubnetIdsNetwork {\n  readonly type: 'subnetIds';\n  readonly options: SubnetIdsNetworkOptions;\n}\n\n/**\n * Network configuration using VPC lookup by ID\n *\n * Looks up an existing VPC by its ID and resolves subnets via subnetSelection filters.\n *\n * @example\n * ```typescript\n * const network: VpcIdNetwork = {\n *   type: 'vpcId',\n *   options: {\n *     vpcId: 'vpc-0a1b2c3d4e5f6a7b8',\n *     subnetType: 'PRIVATE_WITH_EGRESS',\n *     securityGroupIds: ['sg-12345678']\n *   }\n * };\n * ```\n */\nexport interface VpcIdNetwork {\n  readonly type: 'vpcId';\n  readonly options: VpcIdNetworkOptions;\n}\n\n/**\n * Network configuration using VPC lookup by tags\n *\n * Looks up an existing VPC by tag filters and resolves subnets via subnetSelection filters.\n *\n * @example\n * ```typescript\n * const network: VpcLookupNetwork = {\n *   type: 'vpcLookup',\n *   options: {\n *     tags: { 'aws:cloudformation:stack-name': 'NetworkStack' },\n *     subnetType: 'PRIVATE_WITH_EGRESS',\n *     availabilityZones: ['us-east-1a', 'us-east-1b']\n *   }\n * };\n * ```\n */\nexport interface VpcLookupNetwork {\n  readonly type: 'vpcLookup';\n  readonly options: VpcLookupNetworkOptions;\n}\n\n/**\n * Common subnet selection filters shared by VPC-based network options\n */\ninterface SubnetSelectionOptions {\n  /**\n   * Subnet type filter for subnet selection\n   * Maps to CDK SubnetType values\n   * @default 'PRIVATE_WITH_EGRESS'\n   */\n  readonly subnetType?: SubnetTypeName;\n\n  /**\n   * Filter subnets to specific availability zones\n   * @example ['us-east-1a', 'us-east-1b']\n   */\n  readonly availabilityZones?: string[];\n\n  /**\n   * Filter subnets by CDK subnet group name\n   * Matches the groupName assigned during VPC creation\n   */\n  readonly subnetGroupName?: string;\n\n  /**\n   * Security group IDs to attach to CodeBuild projects\n   * @example ['sg-12345678']\n   */\n  readonly securityGroupIds?: string[];\n}\n\n/**\n * Configuration options for explicit subnet ID network\n */\nexport interface SubnetIdsNetworkOptions {\n  /**\n   * VPC ID that contains the subnets.\n   * Required because CDK CodeBuildStep needs a vpc reference.\n   * Can be a plain string or a SecretValue (e.g. from Secrets Manager).\n   * @example 'vpc-0a1b2c3d4e5f6a7b8'\n   */\n  readonly vpcId: SecretValue | string;\n\n  /**\n   * Explicit list of subnet IDs where CodeBuild projects will run\n   * @example ['subnet-0a1b2c3d', 'subnet-4e5f6a7b']\n   */\n  readonly subnetIds: string[];\n\n  /**\n   * Security group IDs to attach to CodeBuild projects\n   * @example ['sg-12345678']\n   */\n  readonly securityGroupIds?: string[];\n}\n\n/**\n * Configuration options for VPC lookup by ID\n */\nexport interface VpcIdNetworkOptions extends SubnetSelectionOptions {\n  /**\n   * VPC ID to look up\n   * Can be a plain string or a SecretValue (e.g. from Secrets Manager).\n   * @example 'vpc-0a1b2c3d4e5f6a7b8'\n   */\n  readonly vpcId: SecretValue | string;\n}\n\n/**\n * Configuration options for VPC lookup by tags\n */\nexport interface VpcLookupNetworkOptions extends SubnetSelectionOptions {\n  /**\n   * Tag key-value pairs to identify the VPC\n   * All tags must match for lookup to succeed\n   * @example { Environment: 'production', Team: 'platform' }\n   */\n  readonly tags: Record<string, string>;\n\n  /**\n   * Optional VPC name (value of the 'Name' tag) for additional filtering\n   */\n  readonly vpcName?: string;\n\n  /**\n   * Optional AWS region override for cross-region VPC lookup\n   * @example 'us-west-2'\n   */\n  readonly region?: string;\n}\n\n/**\n * Subnet type names corresponding to CDK SubnetType enum values\n *\n * @see https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.SubnetType.html\n */\nexport type SubnetTypeName =\n  | 'PRIVATE_WITH_EGRESS'\n  | 'PRIVATE_WITH_NAT'\n  | 'PRIVATE_ISOLATED'\n  | 'PUBLIC';\n\n/**\n * Union type of all supported network configurations.\n *\n * Used at two independent levels:\n * - Pipeline-level (`defaults.network`) — applies to all CodeBuild actions\n * - Step-level (`synth.network`, `CodeBuildStepOptions.network`) — applies to an individual build step\n *\n * Each variant resolves to vpc, subnetSelection, and optional securityGroups:\n * - SubnetIdsNetwork: VPC looked up by ID, subnets selected explicitly by ID\n * - VpcIdNetwork: VPC looked up by ID, subnets resolved via subnetSelection filters\n * - VpcLookupNetwork: VPC looked up by tags, subnets resolved via subnetSelection filters\n */\nexport type NetworkConfig = SubnetIdsNetwork | VpcIdNetwork | VpcLookupNetwork;\n\n/**\n * Pipeline-level CodeBuild defaults applied to every CodeBuild action\n * (synth, self-mutation, asset publishing) via `codeBuildDefaults`.\n *\n * @example\n * ```typescript\n * const defaults: CodeBuildDefaults = {\n *   network: {\n *     type: 'vpcId',\n *     options: { vpcId: 'vpc-abc123', subnetType: 'PRIVATE_WITH_EGRESS' }\n *   },\n *   metadata: {\n *     [MetadataKeys.PRIVILEGED]: true,\n *   },\n * };\n * ```\n */\nexport interface CodeBuildDefaults {\n  /**\n   * Network configuration for all CodeBuild actions.\n   * Resolves to vpc, subnetSelection, and optional securityGroups.\n   */\n  readonly network?: NetworkConfig;\n\n  /**\n   * Standalone security groups for all CodeBuild actions.\n   * Merged with any security groups resolved from network config.\n   */\n  readonly securityGroups?: SecurityGroupConfig;\n\n  /**\n   * Metadata applied to all CodeBuild actions.\n   * Merged with step-level metadata; step-level keys take precedence.\n   */\n  readonly metadata?: MetaDataType;\n}\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ISecurityGroup, IVpc, SubnetSelection } from 'aws-cdk-lib/aws-ec2';
|
|
2
|
+
import { Construct } from 'constructs';
|
|
3
|
+
import { UniqueId } from './id-generator';
|
|
4
|
+
import type { NetworkConfig } from './network-types';
|
|
5
|
+
/** Resolved CDK network props ready to spread into CodeBuildStep or codeBuildDefaults */
|
|
6
|
+
export interface ResolvedNetwork {
|
|
7
|
+
vpc: IVpc;
|
|
8
|
+
subnetSelection: SubnetSelection;
|
|
9
|
+
securityGroups?: ISecurityGroup[];
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Resolve a NetworkConfig into CDK props for CodeBuildStep or codeBuildDefaults.
|
|
13
|
+
* Uses discriminated union narrowing to delegate to the appropriate CDK lookups.
|
|
14
|
+
*
|
|
15
|
+
* @param scope - CDK construct scope
|
|
16
|
+
* @param id - UniqueId instance for generating unique construct IDs
|
|
17
|
+
* @param network - Network configuration to resolve
|
|
18
|
+
* @returns Resolved network props ready to spread into CDK constructs
|
|
19
|
+
*/
|
|
20
|
+
export declare function resolveNetwork(scope: Construct, id: UniqueId, network: NetworkConfig): ResolvedNetwork;
|
|
@@ -0,0 +1,84 @@
|
|
|
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.resolveNetwork = resolveNetwork;
|
|
6
|
+
const aws_ec2_1 = require("aws-cdk-lib/aws-ec2");
|
|
7
|
+
const pipeline_helpers_1 = require("./pipeline-helpers");
|
|
8
|
+
/**
|
|
9
|
+
* Mapping from string subnet type names to CDK SubnetType enum values
|
|
10
|
+
*/
|
|
11
|
+
const SUBNET_TYPE_MAP = {
|
|
12
|
+
PRIVATE_WITH_EGRESS: aws_ec2_1.SubnetType.PRIVATE_WITH_EGRESS,
|
|
13
|
+
PRIVATE_WITH_NAT: aws_ec2_1.SubnetType.PRIVATE_WITH_NAT,
|
|
14
|
+
PRIVATE_ISOLATED: aws_ec2_1.SubnetType.PRIVATE_ISOLATED,
|
|
15
|
+
PUBLIC: aws_ec2_1.SubnetType.PUBLIC,
|
|
16
|
+
};
|
|
17
|
+
const DEFAULT_SUBNET_TYPE = 'PRIVATE_WITH_EGRESS';
|
|
18
|
+
/**
|
|
19
|
+
* Resolve a NetworkConfig into CDK props for CodeBuildStep or codeBuildDefaults.
|
|
20
|
+
* Uses discriminated union narrowing to delegate to the appropriate CDK lookups.
|
|
21
|
+
*
|
|
22
|
+
* @param scope - CDK construct scope
|
|
23
|
+
* @param id - UniqueId instance for generating unique construct IDs
|
|
24
|
+
* @param network - Network configuration to resolve
|
|
25
|
+
* @returns Resolved network props ready to spread into CDK constructs
|
|
26
|
+
*/
|
|
27
|
+
function resolveNetwork(scope, id, network) {
|
|
28
|
+
switch (network.type) {
|
|
29
|
+
case 'subnetIds': {
|
|
30
|
+
const vpc = aws_ec2_1.Vpc.fromLookup(scope, id.generate('network:vpc'), {
|
|
31
|
+
vpcId: (0, pipeline_helpers_1.unwrapSecret)(network.options.vpcId),
|
|
32
|
+
});
|
|
33
|
+
const subnets = network.options.subnetIds.map((subnetId) => aws_ec2_1.Subnet.fromSubnetId(scope, id.generate('network:subnet'), subnetId));
|
|
34
|
+
return withSecurityGroups({ vpc, subnetSelection: { subnets } }, scope, id, network.options.securityGroupIds);
|
|
35
|
+
}
|
|
36
|
+
case 'vpcId': {
|
|
37
|
+
const vpc = aws_ec2_1.Vpc.fromLookup(scope, id.generate('network:vpc'), {
|
|
38
|
+
vpcId: (0, pipeline_helpers_1.unwrapSecret)(network.options.vpcId),
|
|
39
|
+
});
|
|
40
|
+
return withSecurityGroups({ vpc, subnetSelection: resolveSubnetSelection(network.options) }, scope, id, network.options.securityGroupIds);
|
|
41
|
+
}
|
|
42
|
+
case 'vpcLookup': {
|
|
43
|
+
const vpc = aws_ec2_1.Vpc.fromLookup(scope, id.generate('network:vpc'), {
|
|
44
|
+
tags: network.options.tags,
|
|
45
|
+
...(network.options.vpcName && { vpcName: network.options.vpcName }),
|
|
46
|
+
...(network.options.region && { region: network.options.region }),
|
|
47
|
+
});
|
|
48
|
+
return withSecurityGroups({ vpc, subnetSelection: resolveSubnetSelection(network.options) }, scope, id, network.options.securityGroupIds);
|
|
49
|
+
}
|
|
50
|
+
default: {
|
|
51
|
+
const _exhaustive = network;
|
|
52
|
+
throw new Error(`Unknown network config type: ${_exhaustive.type}`);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Attach resolved security groups to a network result when present.
|
|
58
|
+
*/
|
|
59
|
+
function withSecurityGroups(result, scope, id, securityGroupIds) {
|
|
60
|
+
const securityGroups = resolveSecurityGroups(scope, id, securityGroupIds);
|
|
61
|
+
return securityGroups ? { ...result, securityGroups } : result;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Build a SubnetSelection from options that carry subnetType, availabilityZones,
|
|
65
|
+
* and subnetGroupName. Shared by vpcId and vpcLookup branches.
|
|
66
|
+
*/
|
|
67
|
+
function resolveSubnetSelection(options) {
|
|
68
|
+
return {
|
|
69
|
+
subnetType: SUBNET_TYPE_MAP[options.subnetType ?? DEFAULT_SUBNET_TYPE],
|
|
70
|
+
...(options.availabilityZones && { availabilityZones: options.availabilityZones }),
|
|
71
|
+
...(options.subnetGroupName && { subnetGroupName: options.subnetGroupName }),
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Resolve security group IDs into CDK security group references.
|
|
76
|
+
* Returns undefined when no IDs are provided.
|
|
77
|
+
*/
|
|
78
|
+
function resolveSecurityGroups(scope, id, securityGroupIds) {
|
|
79
|
+
if (!securityGroupIds?.length) {
|
|
80
|
+
return undefined;
|
|
81
|
+
}
|
|
82
|
+
return securityGroupIds.map((sgId) => aws_ec2_1.SecurityGroup.fromSecurityGroupId(scope, id.generate('network:sg'), sgId));
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network.js","sourceRoot":"","sources":["../../src/core/network.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { ISecurityGroup, IVpc, SecurityGroup, Subnet, SubnetSelection, SubnetType, Vpc } from 'aws-cdk-lib/aws-ec2';\nimport { Construct } from 'constructs';\nimport { UniqueId } from './id-generator';\nimport type {\n  NetworkConfig,\n  SubnetTypeName,\n} from './network-types';\nimport { unwrapSecret } from './pipeline-helpers';\n\n/**\n * Mapping from string subnet type names to CDK SubnetType enum values\n */\nconst SUBNET_TYPE_MAP: Record<SubnetTypeName, SubnetType> = {\n  PRIVATE_WITH_EGRESS: SubnetType.PRIVATE_WITH_EGRESS,\n  PRIVATE_WITH_NAT: SubnetType.PRIVATE_WITH_NAT,\n  PRIVATE_ISOLATED: SubnetType.PRIVATE_ISOLATED,\n  PUBLIC: SubnetType.PUBLIC,\n};\n\nconst DEFAULT_SUBNET_TYPE: SubnetTypeName = 'PRIVATE_WITH_EGRESS';\n\n/** Resolved CDK network props ready to spread into CodeBuildStep or codeBuildDefaults */\nexport interface ResolvedNetwork {\n  vpc: IVpc;\n  subnetSelection: SubnetSelection;\n  securityGroups?: ISecurityGroup[];\n}\n\n/**\n * Resolve a NetworkConfig into CDK props for CodeBuildStep or codeBuildDefaults.\n * Uses discriminated union narrowing to delegate to the appropriate CDK lookups.\n *\n * @param scope - CDK construct scope\n * @param id - UniqueId instance for generating unique construct IDs\n * @param network - Network configuration to resolve\n * @returns Resolved network props ready to spread into CDK constructs\n */\nexport function resolveNetwork(\n  scope: Construct,\n  id: UniqueId,\n  network: NetworkConfig,\n): ResolvedNetwork {\n  switch (network.type) {\n    case 'subnetIds': {\n      const vpc = Vpc.fromLookup(scope, id.generate('network:vpc'), {\n        vpcId: unwrapSecret(network.options.vpcId),\n      });\n\n      const subnets = network.options.subnetIds.map(\n        (subnetId) => Subnet.fromSubnetId(scope, id.generate('network:subnet'), subnetId),\n      );\n\n      return withSecurityGroups(\n        { vpc, subnetSelection: { subnets } },\n        scope,\n        id,\n        network.options.securityGroupIds,\n      );\n    }\n    case 'vpcId': {\n      const vpc = Vpc.fromLookup(scope, id.generate('network:vpc'), {\n        vpcId: unwrapSecret(network.options.vpcId),\n      });\n\n      return withSecurityGroups(\n        { vpc, subnetSelection: resolveSubnetSelection(network.options) },\n        scope,\n        id,\n        network.options.securityGroupIds,\n      );\n    }\n    case 'vpcLookup': {\n      const vpc = Vpc.fromLookup(scope, id.generate('network:vpc'), {\n        tags: network.options.tags,\n        ...(network.options.vpcName && { vpcName: network.options.vpcName }),\n        ...(network.options.region && { region: network.options.region }),\n      });\n\n      return withSecurityGroups(\n        { vpc, subnetSelection: resolveSubnetSelection(network.options) },\n        scope,\n        id,\n        network.options.securityGroupIds,\n      );\n    }\n    default: {\n      const _exhaustive: never = network;\n      throw new Error(`Unknown network config type: ${(_exhaustive as NetworkConfig).type}`);\n    }\n  }\n}\n\n/**\n * Attach resolved security groups to a network result when present.\n */\nfunction withSecurityGroups(\n  result: Omit<ResolvedNetwork, 'securityGroups'>,\n  scope: Construct,\n  id: UniqueId,\n  securityGroupIds?: string[],\n): ResolvedNetwork {\n  const securityGroups = resolveSecurityGroups(scope, id, securityGroupIds);\n  return securityGroups ? { ...result, securityGroups } : result;\n}\n\n/**\n * Build a SubnetSelection from options that carry subnetType, availabilityZones,\n * and subnetGroupName. Shared by vpcId and vpcLookup branches.\n */\nfunction resolveSubnetSelection(\n  options: { subnetType?: SubnetTypeName; availabilityZones?: string[]; subnetGroupName?: string },\n): SubnetSelection {\n  return {\n    subnetType: SUBNET_TYPE_MAP[options.subnetType ?? DEFAULT_SUBNET_TYPE],\n    ...(options.availabilityZones && { availabilityZones: options.availabilityZones }),\n    ...(options.subnetGroupName && { subnetGroupName: options.subnetGroupName }),\n  };\n}\n\n/**\n * Resolve security group IDs into CDK security group references.\n * Returns undefined when no IDs are provided.\n */\nfunction resolveSecurityGroups(\n  scope: Construct,\n  id: UniqueId,\n  securityGroupIds?: string[],\n): ISecurityGroup[] | undefined {\n  if (!securityGroupIds?.length) {\n    return undefined;\n  }\n  return securityGroupIds.map(\n    (sgId) => SecurityGroup.fromSecurityGroupId(scope, id.generate('network:sg'), sgId),\n  );\n}\n"]}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { SecretValue } from 'aws-cdk-lib';
|
|
2
|
+
import { ComputeType as CDKComputeType } from 'aws-cdk-lib/aws-codebuild';
|
|
3
|
+
import { CodeBuildStep, ManualApprovalStep, ShellStep } from 'aws-cdk-lib/pipelines';
|
|
4
|
+
import { MetaDataType } from './pipeline-types';
|
|
5
|
+
import type { CodeBuildStepOptions } from '../pipeline/step-types';
|
|
6
|
+
/**
|
|
7
|
+
* Merge multiple metadata objects into one. Later sources override earlier ones.
|
|
8
|
+
*/
|
|
9
|
+
export declare function merge(...sources: Array<Partial<MetaDataType>>): MetaDataType;
|
|
10
|
+
/**
|
|
11
|
+
* Extract non-namespaced metadata keys as environment variable strings.
|
|
12
|
+
* Keys starting with 'aws:cdk:' are reserved for CDK construct props
|
|
13
|
+
* (processed by metadata extraction functions) and are excluded here.
|
|
14
|
+
*
|
|
15
|
+
* All values are converted to strings for CodeBuild compatibility.
|
|
16
|
+
*/
|
|
17
|
+
export declare function extractMetadataEnv(metadata: MetaDataType): Record<string, string>;
|
|
18
|
+
/**
|
|
19
|
+
* Create a CodeBuild step or Shell step based on plugin configuration.
|
|
20
|
+
*
|
|
21
|
+
* Metadata merge order (last wins):
|
|
22
|
+
* 1. Step-level metadata (from options.metadata)
|
|
23
|
+
* 2. Plugin metadata (from plugin.metadata in database)
|
|
24
|
+
*
|
|
25
|
+
* Environment merge order (last wins):
|
|
26
|
+
* 1. Plugin env vars (from plugin.env)
|
|
27
|
+
* 2. Custom env vars (from options.env)
|
|
28
|
+
* 3. WORKDIR from merged metadata
|
|
29
|
+
*
|
|
30
|
+
* CDK prop spread order (last wins):
|
|
31
|
+
* programmatic defaults (input, commands, env, network) → metadata overrides
|
|
32
|
+
*
|
|
33
|
+
* This means metadata keys like `aws:cdk:pipelines:codebuildstep:commands`
|
|
34
|
+
* will override the plugin-derived commands when explicitly set.
|
|
35
|
+
*/
|
|
36
|
+
export declare function createCodeBuildStep(options: CodeBuildStepOptions): ShellStep | CodeBuildStep | ManualApprovalStep;
|
|
37
|
+
/**
|
|
38
|
+
* Convert string or ComputeType enum to CDK ComputeType
|
|
39
|
+
*/
|
|
40
|
+
export declare function getComputeType(input?: string | CDKComputeType): CDKComputeType;
|
|
41
|
+
/**
|
|
42
|
+
* Replaces all characters that are not letters or numbers with the specified value
|
|
43
|
+
* @param input - The string to process
|
|
44
|
+
* @param replaceValue - The character(s) to replace non-alphanumeric characters with (default: '_')
|
|
45
|
+
* @returns The string with non-alphanumeric characters replaced
|
|
46
|
+
*/
|
|
47
|
+
export declare function replaceNonAlphanumeric(input: string, replaceValue?: string): string;
|
|
48
|
+
/**
|
|
49
|
+
* Unwrap a SecretValue | string into a plain string.
|
|
50
|
+
* When a SecretValue is provided (e.g. from Secrets Manager), calls unsafeUnwrap()
|
|
51
|
+
* to extract the underlying value.
|
|
52
|
+
*/
|
|
53
|
+
export declare function unwrapSecret(value: SecretValue | string): string;
|