@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,307 @@
|
|
|
1
|
+
import type { PluginFilter, Plugin } from '@pipeline-builder/pipeline-data';
|
|
2
|
+
import type { ComputeType as CdkComputeType } from 'aws-cdk-lib/aws-codebuild';
|
|
3
|
+
import type { IFileSetProducer } from 'aws-cdk-lib/pipelines';
|
|
4
|
+
import type { Construct } from 'constructs';
|
|
5
|
+
import type { ArtifactKey, ArtifactManager } from '../core/artifact-manager';
|
|
6
|
+
import type { UniqueId } from '../core/id-generator';
|
|
7
|
+
import type { NetworkConfig } from '../core/network-types';
|
|
8
|
+
import type { ComputeType, PluginType, MetaDataType, SourceType } from '../core/pipeline-types';
|
|
9
|
+
/**
|
|
10
|
+
* Options for selecting and configuring a plugin
|
|
11
|
+
*/
|
|
12
|
+
export interface PluginOptions {
|
|
13
|
+
/**
|
|
14
|
+
* Name of the plugin to use
|
|
15
|
+
* Must match a registered plugin in the database
|
|
16
|
+
*/
|
|
17
|
+
readonly name: string;
|
|
18
|
+
/**
|
|
19
|
+
* Optional alias for the plugin instance
|
|
20
|
+
* Useful when using the same plugin multiple times with different configurations
|
|
21
|
+
*/
|
|
22
|
+
readonly alias?: string;
|
|
23
|
+
/**
|
|
24
|
+
* Optional filter criteria for plugin selection
|
|
25
|
+
* Can be used to select specific plugin versions or variants
|
|
26
|
+
*/
|
|
27
|
+
readonly filter?: PluginFilter;
|
|
28
|
+
/**
|
|
29
|
+
* Additional metadata to merge with plugin's default metadata
|
|
30
|
+
* This metadata will be available to the plugin during execution
|
|
31
|
+
*/
|
|
32
|
+
readonly metadata?: MetaDataType;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Synthesis step configuration combining source and plugin.
|
|
36
|
+
* Extends StepCustomization to support injecting custom commands and env vars
|
|
37
|
+
* into the synth CodeBuild step (same hooks available as stage steps).
|
|
38
|
+
*/
|
|
39
|
+
export interface SynthOptions extends StepCustomization {
|
|
40
|
+
/**
|
|
41
|
+
* Source configuration (S3, GitHub, or CodeStar)
|
|
42
|
+
*/
|
|
43
|
+
readonly source: SourceType;
|
|
44
|
+
/**
|
|
45
|
+
* Plugin to use for synthesis
|
|
46
|
+
*/
|
|
47
|
+
readonly plugin: PluginOptions;
|
|
48
|
+
/**
|
|
49
|
+
* Additional metadata for the synthesis step
|
|
50
|
+
* This will be merged with global metadata and plugin metadata
|
|
51
|
+
*/
|
|
52
|
+
readonly metadata?: MetaDataType;
|
|
53
|
+
/**
|
|
54
|
+
* Step-level network configuration applied only to the synth CodeBuild step.
|
|
55
|
+
* Overrides the pipeline-level `defaults.network` when both are provided.
|
|
56
|
+
*/
|
|
57
|
+
readonly network?: NetworkConfig;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Plugin spec defining plugin behavior and requirements.
|
|
61
|
+
* This is typically loaded from a plugin spec file (plugin-spec.yaml).
|
|
62
|
+
*/
|
|
63
|
+
export interface PluginSpec {
|
|
64
|
+
/**
|
|
65
|
+
* Unique identifier for the plugin
|
|
66
|
+
* @example 'nodejs-build'
|
|
67
|
+
*/
|
|
68
|
+
readonly name: string;
|
|
69
|
+
/**
|
|
70
|
+
* Human-readable description of what the plugin does
|
|
71
|
+
* @example 'Builds and tests Node.js applications'
|
|
72
|
+
*/
|
|
73
|
+
readonly description?: string;
|
|
74
|
+
/**
|
|
75
|
+
* Keywords for plugin discovery and categorization
|
|
76
|
+
* @example ['nodejs', 'typescript', 'build', 'test']
|
|
77
|
+
*/
|
|
78
|
+
readonly keywords?: string[];
|
|
79
|
+
/**
|
|
80
|
+
* Plugin category for AI-assisted selection and organization.
|
|
81
|
+
* One of: language, security, quality, testing, deploy, artifact,
|
|
82
|
+
* infrastructure, monitoring, notification, ai
|
|
83
|
+
*/
|
|
84
|
+
readonly category?: string;
|
|
85
|
+
/**
|
|
86
|
+
* Semantic version of the plugin
|
|
87
|
+
* @example '1.0.0'
|
|
88
|
+
*/
|
|
89
|
+
readonly version?: string;
|
|
90
|
+
/**
|
|
91
|
+
* Type of pipeline step this plugin creates
|
|
92
|
+
* @default PluginType.CODE_BUILD_STEP
|
|
93
|
+
*/
|
|
94
|
+
readonly pluginType?: PluginType;
|
|
95
|
+
/**
|
|
96
|
+
* CodeBuild compute resource size to use
|
|
97
|
+
* @default ComputeType.SMALL
|
|
98
|
+
*/
|
|
99
|
+
readonly computeType?: ComputeType;
|
|
100
|
+
/**
|
|
101
|
+
* Maximum execution time in minutes.
|
|
102
|
+
* Used as fallback when the pipeline step doesn't set timeout.
|
|
103
|
+
* @default 60 (AWS CodeBuild default)
|
|
104
|
+
*/
|
|
105
|
+
readonly timeout?: number;
|
|
106
|
+
/**
|
|
107
|
+
* What happens when this step fails.
|
|
108
|
+
* - 'fail': Stop the pipeline (default)
|
|
109
|
+
* - 'warn': Log a warning and continue
|
|
110
|
+
* - 'ignore': Silently continue
|
|
111
|
+
* @default 'fail'
|
|
112
|
+
*/
|
|
113
|
+
readonly failureBehavior?: 'fail' | 'warn' | 'ignore';
|
|
114
|
+
/**
|
|
115
|
+
* Secret requirements for this plugin.
|
|
116
|
+
* Declares named secrets the plugin expects at build time.
|
|
117
|
+
*/
|
|
118
|
+
readonly secrets?: Array<{
|
|
119
|
+
name: string;
|
|
120
|
+
required: boolean;
|
|
121
|
+
description?: string;
|
|
122
|
+
}>;
|
|
123
|
+
/**
|
|
124
|
+
* Directory containing the primary build output artifacts
|
|
125
|
+
* @example 'dist'
|
|
126
|
+
*/
|
|
127
|
+
readonly primaryOutputDirectory?: string;
|
|
128
|
+
/**
|
|
129
|
+
* Additional metadata that can be accessed during plugin execution
|
|
130
|
+
* Keys should use the format 'aws:cdk:{namespace}:{key}' (all lowercase)
|
|
131
|
+
*/
|
|
132
|
+
readonly metadata?: Record<string, string | number | boolean>;
|
|
133
|
+
/**
|
|
134
|
+
* Path to Dockerfile or Dockerfile content
|
|
135
|
+
* Used to build the container environment for this plugin
|
|
136
|
+
*/
|
|
137
|
+
readonly dockerfile?: string;
|
|
138
|
+
/**
|
|
139
|
+
* Commands to run during the install phase
|
|
140
|
+
* Typically used for installing dependencies
|
|
141
|
+
* @example ['npm ci', 'npm run build']
|
|
142
|
+
*/
|
|
143
|
+
readonly installCommands?: string[];
|
|
144
|
+
/**
|
|
145
|
+
* Commands to run during the build/execution phase
|
|
146
|
+
* These are the main commands that perform the plugin's work
|
|
147
|
+
* @example ['npm test', 'npm run deploy']
|
|
148
|
+
*/
|
|
149
|
+
readonly commands?: string[];
|
|
150
|
+
/**
|
|
151
|
+
* Environment variables to set in the build environment
|
|
152
|
+
* @example { API_URL: 'https://api.example.com', LOG_LEVEL: 'info' }
|
|
153
|
+
*/
|
|
154
|
+
readonly env?: Record<string, string>;
|
|
155
|
+
/**
|
|
156
|
+
* Docker build arguments passed via --build-arg at image build time.
|
|
157
|
+
* Used to parameterize Dockerfile ARG values when building the plugin image.
|
|
158
|
+
* @example { PYTHON_VERSION: '3.12', NODE_ENV: 'production' }
|
|
159
|
+
*/
|
|
160
|
+
readonly buildArgs?: Record<string, string>;
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Per-step customization options for commands and environment variables.
|
|
164
|
+
* Custom commands are injected before/after the plugin's commands.
|
|
165
|
+
* Custom env vars are merged on top of the plugin's defaults.
|
|
166
|
+
*/
|
|
167
|
+
export interface StepCustomization {
|
|
168
|
+
/** Commands to run before the plugin's install commands */
|
|
169
|
+
readonly preInstallCommands?: string[];
|
|
170
|
+
/** Commands to run after the plugin's install commands */
|
|
171
|
+
readonly postInstallCommands?: string[];
|
|
172
|
+
/** Commands to run before the plugin's build commands */
|
|
173
|
+
readonly preCommands?: string[];
|
|
174
|
+
/** Commands to run after the plugin's build commands */
|
|
175
|
+
readonly postCommands?: string[];
|
|
176
|
+
/** Custom environment variables merged on top of the plugin's env */
|
|
177
|
+
readonly env?: Record<string, string>;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* An additional input artifact with an optional mount directory.
|
|
181
|
+
* When directory is omitted, defaults to the artifact's outputDirectory.
|
|
182
|
+
*/
|
|
183
|
+
export interface AdditionalInputArtifactConfig {
|
|
184
|
+
/** Artifact key identifying the source step's output */
|
|
185
|
+
readonly artifact: ArtifactKey;
|
|
186
|
+
/** Directory to mount the input at. Defaults to artifact.outputDirectory when omitted. */
|
|
187
|
+
readonly directory?: string;
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Configuration for a single step within a pipeline stage.
|
|
191
|
+
* Uses PluginOptions for name-based plugin selection (resolved at build time).
|
|
192
|
+
*/
|
|
193
|
+
export interface StageStepOptions extends StepCustomization {
|
|
194
|
+
/** Plugin to use for this step */
|
|
195
|
+
readonly plugin: PluginOptions;
|
|
196
|
+
/** Step-level metadata merged with stage and global metadata */
|
|
197
|
+
readonly metadata?: MetaDataType;
|
|
198
|
+
/** Optional network configuration for this step's CodeBuild action */
|
|
199
|
+
readonly network?: NetworkConfig;
|
|
200
|
+
/**
|
|
201
|
+
* CodeBuild timeout in minutes.
|
|
202
|
+
* @default 60 (AWS CodeBuild default)
|
|
203
|
+
*/
|
|
204
|
+
readonly timeout?: number;
|
|
205
|
+
/**
|
|
206
|
+
* Position of this step within the pipeline wave.
|
|
207
|
+
* - 'pre': Runs before the stage deployment (default)
|
|
208
|
+
* - 'post': Runs after the stage deployment
|
|
209
|
+
* @default 'pre'
|
|
210
|
+
*/
|
|
211
|
+
readonly position?: 'pre' | 'post';
|
|
212
|
+
/** Artifact key for this step's primary input (resolved via ArtifactManager) */
|
|
213
|
+
readonly inputArtifact?: ArtifactKey;
|
|
214
|
+
/** Additional input artifacts for this step. Each entry specifies an artifact and an optional mount directory. */
|
|
215
|
+
readonly additionalInputArtifacts?: AdditionalInputArtifactConfig[];
|
|
216
|
+
/** Override the plugin's failure behavior for this step. */
|
|
217
|
+
readonly failureBehavior?: 'fail' | 'warn' | 'ignore';
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* A pipeline stage containing one or more build steps.
|
|
221
|
+
* Each stage maps to a CDK Pipeline wave, with steps executing within the wave.
|
|
222
|
+
*/
|
|
223
|
+
export interface StageOptions {
|
|
224
|
+
/** Display name for this stage */
|
|
225
|
+
readonly stageName: string;
|
|
226
|
+
/** Optional alias used for wave/construct ID generation. Defaults to stageName. */
|
|
227
|
+
readonly alias?: string;
|
|
228
|
+
/** Build steps to execute within this stage */
|
|
229
|
+
readonly steps: StageStepOptions[];
|
|
230
|
+
}
|
|
231
|
+
/**
|
|
232
|
+
* Options for creating a CodeBuild step in the pipeline
|
|
233
|
+
*/
|
|
234
|
+
export interface CodeBuildStepOptions extends StepCustomization {
|
|
235
|
+
/**
|
|
236
|
+
* Unique identifier for this CodeBuild step
|
|
237
|
+
* Should be descriptive and unique within the pipeline
|
|
238
|
+
* @example 'my-org-my-project-synth'
|
|
239
|
+
*/
|
|
240
|
+
readonly id: string;
|
|
241
|
+
/**
|
|
242
|
+
* UniqueId instance for generating unique construct IDs
|
|
243
|
+
* Used for network resource lookups (VPC, subnets, security groups)
|
|
244
|
+
*/
|
|
245
|
+
readonly uniqueId: UniqueId;
|
|
246
|
+
/**
|
|
247
|
+
* Plugin configuration from the database
|
|
248
|
+
* Contains all the plugin's spec data and runtime information
|
|
249
|
+
*/
|
|
250
|
+
readonly plugin: Plugin;
|
|
251
|
+
/**
|
|
252
|
+
* CDK scope used to create constructs (VPC/subnet/security-group lookups).
|
|
253
|
+
*/
|
|
254
|
+
readonly scope: Construct;
|
|
255
|
+
/**
|
|
256
|
+
* Input source for this step
|
|
257
|
+
* Typically the output from a previous step or the pipeline source
|
|
258
|
+
*/
|
|
259
|
+
readonly input?: IFileSetProducer;
|
|
260
|
+
/**
|
|
261
|
+
* Additional metadata to merge with plugin metadata
|
|
262
|
+
* Will override conflicting keys from plugin metadata
|
|
263
|
+
*/
|
|
264
|
+
readonly metadata?: MetaDataType;
|
|
265
|
+
/**
|
|
266
|
+
* Optional network configuration for the CodeBuild step.
|
|
267
|
+
* When provided, resolves VPC, subnet selection, and security groups
|
|
268
|
+
* so the build runs inside the specified network.
|
|
269
|
+
*/
|
|
270
|
+
readonly network?: NetworkConfig;
|
|
271
|
+
/**
|
|
272
|
+
* Fallback CodeBuild compute type when the plugin doesn't specify one.
|
|
273
|
+
* @default ComputeType.SMALL
|
|
274
|
+
*/
|
|
275
|
+
readonly defaultComputeType?: CdkComputeType;
|
|
276
|
+
/**
|
|
277
|
+
* CodeBuild timeout in minutes.
|
|
278
|
+
* @default 60 (AWS CodeBuild default)
|
|
279
|
+
*/
|
|
280
|
+
readonly timeout?: number;
|
|
281
|
+
/** Additional inputs mapped by directory path (resolved FileSets) */
|
|
282
|
+
readonly additionalInputs?: Record<string, IFileSetProducer>;
|
|
283
|
+
/**
|
|
284
|
+
* Optional artifact manager for tracking build outputs
|
|
285
|
+
* When provided and primaryOutputDirectory is set, the step will be registered
|
|
286
|
+
*/
|
|
287
|
+
readonly artifactManager?: ArtifactManager;
|
|
288
|
+
/**
|
|
289
|
+
* Stage name for artifact key generation
|
|
290
|
+
*/
|
|
291
|
+
readonly stageName?: string;
|
|
292
|
+
/**
|
|
293
|
+
* Stage alias for artifact key generation
|
|
294
|
+
*/
|
|
295
|
+
readonly stageAlias?: string;
|
|
296
|
+
/**
|
|
297
|
+
* Plugin alias for artifact key generation
|
|
298
|
+
*/
|
|
299
|
+
readonly pluginAlias?: string;
|
|
300
|
+
/**
|
|
301
|
+
* Failure behavior for this step's build commands.
|
|
302
|
+
* Applied at shell level: 'fail' = default, 'warn' = log + continue, 'ignore' = || true.
|
|
303
|
+
*/
|
|
304
|
+
readonly failureBehavior?: 'fail' | 'warn' | 'ignore';
|
|
305
|
+
/** Tenant identifier for resolving per-org secrets from AWS Secrets Manager */
|
|
306
|
+
readonly orgId?: string;
|
|
307
|
+
}
|
|
@@ -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":"step-types.js","sourceRoot":"","sources":["../../src/pipeline/step-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 { PluginFilter, Plugin } from '@pipeline-builder/pipeline-data';\nimport type { ComputeType as CdkComputeType } from 'aws-cdk-lib/aws-codebuild';\nimport type { IFileSetProducer } from 'aws-cdk-lib/pipelines';\nimport type { Construct } from 'constructs';\nimport type { ArtifactKey, ArtifactManager } from '../core/artifact-manager';\nimport type { UniqueId } from '../core/id-generator';\nimport type { NetworkConfig } from '../core/network-types';\nimport type { ComputeType, PluginType, MetaDataType, SourceType } from '../core/pipeline-types';\n\n/**\n * Options for selecting and configuring a plugin\n */\nexport interface PluginOptions {\n  /**\n   * Name of the plugin to use\n   * Must match a registered plugin in the database\n   */\n  readonly name: string;\n\n  /**\n   * Optional alias for the plugin instance\n   * Useful when using the same plugin multiple times with different configurations\n   */\n  readonly alias?: string;\n\n  /**\n   * Optional filter criteria for plugin selection\n   * Can be used to select specific plugin versions or variants\n   */\n  readonly filter?: PluginFilter;\n\n  /**\n   * Additional metadata to merge with plugin's default metadata\n   * This metadata will be available to the plugin during execution\n   */\n  readonly metadata?: MetaDataType;\n}\n\n/**\n * Synthesis step configuration combining source and plugin.\n * Extends StepCustomization to support injecting custom commands and env vars\n * into the synth CodeBuild step (same hooks available as stage steps).\n */\nexport interface SynthOptions extends StepCustomization {\n  /**\n   * Source configuration (S3, GitHub, or CodeStar)\n   */\n  readonly source: SourceType;\n\n  /**\n   * Plugin to use for synthesis\n   */\n  readonly plugin: PluginOptions;\n\n  /**\n   * Additional metadata for the synthesis step\n   * This will be merged with global metadata and plugin metadata\n   */\n  readonly metadata?: MetaDataType;\n\n  /**\n   * Step-level network configuration applied only to the synth CodeBuild step.\n   * Overrides the pipeline-level `defaults.network` when both are provided.\n   */\n  readonly network?: NetworkConfig;\n}\n\n/**\n * Plugin spec defining plugin behavior and requirements.\n * This is typically loaded from a plugin spec file (plugin-spec.yaml).\n */\nexport interface PluginSpec {\n  /**\n   * Unique identifier for the plugin\n   * @example 'nodejs-build'\n   */\n  readonly name: string;\n\n  /**\n   * Human-readable description of what the plugin does\n   * @example 'Builds and tests Node.js applications'\n   */\n  readonly description?: string;\n\n  /**\n   * Keywords for plugin discovery and categorization\n   * @example ['nodejs', 'typescript', 'build', 'test']\n   */\n  readonly keywords?: string[];\n\n  /**\n   * Plugin category for AI-assisted selection and organization.\n   * One of: language, security, quality, testing, deploy, artifact,\n   *         infrastructure, monitoring, notification, ai\n   */\n  readonly category?: string;\n\n  /**\n   * Semantic version of the plugin\n   * @example '1.0.0'\n   */\n  readonly version?: string;\n\n  /**\n   * Type of pipeline step this plugin creates\n   * @default PluginType.CODE_BUILD_STEP\n   */\n  readonly pluginType?: PluginType;\n\n  /**\n   * CodeBuild compute resource size to use\n   * @default ComputeType.SMALL\n   */\n  readonly computeType?: ComputeType;\n\n  /**\n   * Maximum execution time in minutes.\n   * Used as fallback when the pipeline step doesn't set timeout.\n   * @default 60 (AWS CodeBuild default)\n   */\n  readonly timeout?: number;\n\n  /**\n   * What happens when this step fails.\n   * - 'fail': Stop the pipeline (default)\n   * - 'warn': Log a warning and continue\n   * - 'ignore': Silently continue\n   * @default 'fail'\n   */\n  readonly failureBehavior?: 'fail' | 'warn' | 'ignore';\n\n  /**\n   * Secret requirements for this plugin.\n   * Declares named secrets the plugin expects at build time.\n   */\n  readonly secrets?: Array<{ name: string; required: boolean; description?: string }>;\n\n  /**\n   * Directory containing the primary build output artifacts\n   * @example 'dist'\n   */\n  readonly primaryOutputDirectory?: string;\n  /**\n   * Additional metadata that can be accessed during plugin execution\n   * Keys should use the format 'aws:cdk:{namespace}:{key}' (all lowercase)\n   */\n  readonly metadata?: Record<string, string | number | boolean>;\n\n  /**\n   * Path to Dockerfile or Dockerfile content\n   * Used to build the container environment for this plugin\n   */\n  readonly dockerfile?: string;\n\n  /**\n   * Commands to run during the install phase\n   * Typically used for installing dependencies\n   * @example ['npm ci', 'npm run build']\n   */\n  readonly installCommands?: string[];\n\n  /**\n   * Commands to run during the build/execution phase\n   * These are the main commands that perform the plugin's work\n   * @example ['npm test', 'npm run deploy']\n   */\n  readonly commands?: string[];\n\n  /**\n   * Environment variables to set in the build environment\n   * @example { API_URL: 'https://api.example.com', LOG_LEVEL: 'info' }\n   */\n  readonly env?: Record<string, string>;\n\n  /**\n   * Docker build arguments passed via --build-arg at image build time.\n   * Used to parameterize Dockerfile ARG values when building the plugin image.\n   * @example { PYTHON_VERSION: '3.12', NODE_ENV: 'production' }\n   */\n  readonly buildArgs?: Record<string, string>;\n}\n\n/**\n * Per-step customization options for commands and environment variables.\n * Custom commands are injected before/after the plugin's commands.\n * Custom env vars are merged on top of the plugin's defaults.\n */\nexport interface StepCustomization {\n  /** Commands to run before the plugin's install commands */\n  readonly preInstallCommands?: string[];\n\n  /** Commands to run after the plugin's install commands */\n  readonly postInstallCommands?: string[];\n\n  /** Commands to run before the plugin's build commands */\n  readonly preCommands?: string[];\n\n  /** Commands to run after the plugin's build commands */\n  readonly postCommands?: string[];\n\n  /** Custom environment variables merged on top of the plugin's env */\n  readonly env?: Record<string, string>;\n}\n\n/**\n * An additional input artifact with an optional mount directory.\n * When directory is omitted, defaults to the artifact's outputDirectory.\n */\nexport interface AdditionalInputArtifactConfig {\n  /** Artifact key identifying the source step's output */\n  readonly artifact: ArtifactKey;\n\n  /** Directory to mount the input at. Defaults to artifact.outputDirectory when omitted. */\n  readonly directory?: string;\n}\n\n/**\n * Configuration for a single step within a pipeline stage.\n * Uses PluginOptions for name-based plugin selection (resolved at build time).\n */\nexport interface StageStepOptions extends StepCustomization {\n  /** Plugin to use for this step */\n  readonly plugin: PluginOptions;\n\n  /** Step-level metadata merged with stage and global metadata */\n  readonly metadata?: MetaDataType;\n\n  /** Optional network configuration for this step's CodeBuild action */\n  readonly network?: NetworkConfig;\n\n  /**\n   * CodeBuild timeout in minutes.\n   * @default 60 (AWS CodeBuild default)\n   */\n  readonly timeout?: number;\n\n  /**\n   * Position of this step within the pipeline wave.\n   * - 'pre': Runs before the stage deployment (default)\n   * - 'post': Runs after the stage deployment\n   * @default 'pre'\n   */\n  readonly position?: 'pre' | 'post';\n\n  /** Artifact key for this step's primary input (resolved via ArtifactManager) */\n  readonly inputArtifact?: ArtifactKey;\n\n  /** Additional input artifacts for this step. Each entry specifies an artifact and an optional mount directory. */\n  readonly additionalInputArtifacts?: AdditionalInputArtifactConfig[];\n\n  /** Override the plugin's failure behavior for this step. */\n  readonly failureBehavior?: 'fail' | 'warn' | 'ignore';\n}\n\n/**\n * A pipeline stage containing one or more build steps.\n * Each stage maps to a CDK Pipeline wave, with steps executing within the wave.\n */\nexport interface StageOptions {\n  /** Display name for this stage */\n  readonly stageName: string;\n\n  /** Optional alias used for wave/construct ID generation. Defaults to stageName. */\n  readonly alias?: string;\n\n  /** Build steps to execute within this stage */\n  readonly steps: StageStepOptions[];\n}\n\n/**\n * Options for creating a CodeBuild step in the pipeline\n */\nexport interface CodeBuildStepOptions extends StepCustomization {\n  /**\n   * Unique identifier for this CodeBuild step\n   * Should be descriptive and unique within the pipeline\n   * @example 'my-org-my-project-synth'\n   */\n  readonly id: string;\n\n  /**\n   * UniqueId instance for generating unique construct IDs\n   * Used for network resource lookups (VPC, subnets, security groups)\n   */\n  readonly uniqueId: UniqueId;\n\n  /**\n   * Plugin configuration from the database\n   * Contains all the plugin's spec data and runtime information\n   */\n  readonly plugin: Plugin;\n\n  /**\n   * CDK scope used to create constructs (VPC/subnet/security-group lookups).\n   */\n  readonly scope: Construct;\n\n  /**\n   * Input source for this step\n   * Typically the output from a previous step or the pipeline source\n   */\n  readonly input?: IFileSetProducer;\n\n  /**\n   * Additional metadata to merge with plugin metadata\n   * Will override conflicting keys from plugin metadata\n   */\n  readonly metadata?: MetaDataType;\n\n  /**\n   * Optional network configuration for the CodeBuild step.\n   * When provided, resolves VPC, subnet selection, and security groups\n   * so the build runs inside the specified network.\n   */\n  readonly network?: NetworkConfig;\n\n  /**\n   * Fallback CodeBuild compute type when the plugin doesn't specify one.\n   * @default ComputeType.SMALL\n   */\n  readonly defaultComputeType?: CdkComputeType;\n\n  /**\n   * CodeBuild timeout in minutes.\n   * @default 60 (AWS CodeBuild default)\n   */\n  readonly timeout?: number;\n\n  /** Additional inputs mapped by directory path (resolved FileSets) */\n  readonly additionalInputs?: Record<string, IFileSetProducer>;\n\n  /**\n   * Optional artifact manager for tracking build outputs\n   * When provided and primaryOutputDirectory is set, the step will be registered\n   */\n  readonly artifactManager?: ArtifactManager;\n\n  /**\n   * Stage name for artifact key generation\n   */\n  readonly stageName?: string;\n\n  /**\n   * Stage alias for artifact key generation\n   */\n  readonly stageAlias?: string;\n\n  /**\n   * Plugin alias for artifact key generation\n   */\n  readonly pluginAlias?: string;\n\n  /**\n   * Failure behavior for this step's build commands.\n   * Applied at shell level: 'fail' = default, 'warn' = log + continue, 'ignore' = || true.\n   */\n  readonly failureBehavior?: 'fail' | 'warn' | 'ignore';\n\n  /** Tenant identifier for resolving per-org secrets from AWS Secrets Manager */\n  readonly orgId?: string;\n}\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@pipeline-builder/pipeline-core",
|
|
3
|
+
"description": "AWS CDK construct library for Pipeline Builder: the Builder construct that assembles plugin specs into a CodePipeline stack, PluginLookup custom resource, pipeline/plugin domain types, and shared configuration.",
|
|
4
|
+
"repository": {
|
|
5
|
+
"type": "git",
|
|
6
|
+
"url": "git+https://github.com/mwashburn160/pipeline-builder.git"
|
|
7
|
+
},
|
|
8
|
+
"devDependencies": {
|
|
9
|
+
"@aws-sdk/client-secrets-manager": "3.997.0",
|
|
10
|
+
"@jest/globals": "30.2.0",
|
|
11
|
+
"@stylistic/eslint-plugin": "^2",
|
|
12
|
+
"@types/aws-lambda": "8.10.160",
|
|
13
|
+
"@types/jest": "^30.0.0",
|
|
14
|
+
"@types/jsonwebtoken": "9.0.10",
|
|
15
|
+
"@types/node": "25.3.0",
|
|
16
|
+
"@typescript-eslint/eslint-plugin": "^8",
|
|
17
|
+
"@typescript-eslint/parser": "^8",
|
|
18
|
+
"copyfiles": "2.4.1",
|
|
19
|
+
"eslint": "^9",
|
|
20
|
+
"eslint-import-resolver-typescript": "^4.4.4",
|
|
21
|
+
"eslint-plugin-import": "^2.32.0",
|
|
22
|
+
"jest": "^30.2.0",
|
|
23
|
+
"jest-junit": "^16",
|
|
24
|
+
"ts-jest": "^29.4.6",
|
|
25
|
+
"typescript": "5.9.3"
|
|
26
|
+
},
|
|
27
|
+
"dependencies": {
|
|
28
|
+
"@pipeline-builder/api-core": "3.1.0",
|
|
29
|
+
"aws-cdk-lib": "2.240.0",
|
|
30
|
+
"axios": "1.13.5",
|
|
31
|
+
"constructs": "10.5.1",
|
|
32
|
+
"jsonwebtoken": "9.0.3",
|
|
33
|
+
"uuid": "13.0.0",
|
|
34
|
+
"@pipeline-builder/pipeline-data": "3.1.1"
|
|
35
|
+
},
|
|
36
|
+
"keywords": [
|
|
37
|
+
"aws",
|
|
38
|
+
"codepipeline",
|
|
39
|
+
"codebuild",
|
|
40
|
+
"cicd",
|
|
41
|
+
"ci-cd",
|
|
42
|
+
"devops",
|
|
43
|
+
"cdk",
|
|
44
|
+
"aws-cdk",
|
|
45
|
+
"cloudformation",
|
|
46
|
+
"pipeline",
|
|
47
|
+
"pipeline-as-code",
|
|
48
|
+
"containerized",
|
|
49
|
+
"docker",
|
|
50
|
+
"kubernetes",
|
|
51
|
+
"plugins",
|
|
52
|
+
"typescript",
|
|
53
|
+
"self-service",
|
|
54
|
+
"multi-tenant",
|
|
55
|
+
"compliance",
|
|
56
|
+
"automation",
|
|
57
|
+
"infrastructure-as-code",
|
|
58
|
+
"iac",
|
|
59
|
+
"cli"
|
|
60
|
+
],
|
|
61
|
+
"engines": {
|
|
62
|
+
"node": ">= 24.14.0"
|
|
63
|
+
},
|
|
64
|
+
"main": "lib/index.js",
|
|
65
|
+
"license": "Apache-2.0",
|
|
66
|
+
"homepage": "https://mwashburn160.github.io/pipeline-builder/",
|
|
67
|
+
"publishConfig": {
|
|
68
|
+
"access": "public",
|
|
69
|
+
"registry": "https://registry.npmjs.org/"
|
|
70
|
+
},
|
|
71
|
+
"version": "3.1.1",
|
|
72
|
+
"bugs": {
|
|
73
|
+
"url": "https://github.com/mwashburn160/pipeline-builder/issues"
|
|
74
|
+
},
|
|
75
|
+
"jest": {
|
|
76
|
+
"coverageProvider": "v8",
|
|
77
|
+
"testMatch": [
|
|
78
|
+
"<rootDir>/@(src|test)/**/*(*.)@(spec|test).ts?(x)",
|
|
79
|
+
"<rootDir>/@(src|test)/**/__tests__/**/*.ts?(x)"
|
|
80
|
+
],
|
|
81
|
+
"clearMocks": true,
|
|
82
|
+
"collectCoverage": true,
|
|
83
|
+
"coverageReporters": [
|
|
84
|
+
"json",
|
|
85
|
+
"lcov",
|
|
86
|
+
"clover",
|
|
87
|
+
"cobertura",
|
|
88
|
+
"text"
|
|
89
|
+
],
|
|
90
|
+
"coverageDirectory": "coverage",
|
|
91
|
+
"coveragePathIgnorePatterns": [
|
|
92
|
+
"/node_modules/"
|
|
93
|
+
],
|
|
94
|
+
"testPathIgnorePatterns": [
|
|
95
|
+
"/node_modules/"
|
|
96
|
+
],
|
|
97
|
+
"watchPathIgnorePatterns": [
|
|
98
|
+
"/node_modules/"
|
|
99
|
+
],
|
|
100
|
+
"reporters": [
|
|
101
|
+
"default",
|
|
102
|
+
[
|
|
103
|
+
"jest-junit",
|
|
104
|
+
{
|
|
105
|
+
"outputDirectory": "test-reports"
|
|
106
|
+
}
|
|
107
|
+
]
|
|
108
|
+
],
|
|
109
|
+
"transform": {
|
|
110
|
+
"^.+\\.[t]sx?$": [
|
|
111
|
+
"ts-jest",
|
|
112
|
+
{
|
|
113
|
+
"tsconfig": "tsconfig.dev.json"
|
|
114
|
+
}
|
|
115
|
+
]
|
|
116
|
+
},
|
|
117
|
+
"moduleNameMapper": {
|
|
118
|
+
"^uuid$": "<rootDir>/../../jest-uuid-stub.js"
|
|
119
|
+
},
|
|
120
|
+
"maxWorkers": 1
|
|
121
|
+
},
|
|
122
|
+
"types": "lib/index.d.ts",
|
|
123
|
+
"//": "~~ Generated by projen. To modify, edit .projenrc.js and run \"pnpm dlx projen\".",
|
|
124
|
+
"scripts": {
|
|
125
|
+
"build": "pnpm dlx projen build",
|
|
126
|
+
"compile": "pnpm dlx projen compile",
|
|
127
|
+
"default": "pnpm dlx projen default",
|
|
128
|
+
"eslint": "pnpm dlx projen eslint",
|
|
129
|
+
"package": "pnpm dlx projen package",
|
|
130
|
+
"post-compile": "pnpm dlx projen post-compile",
|
|
131
|
+
"pre-compile": "pnpm dlx projen pre-compile",
|
|
132
|
+
"test": "pnpm dlx projen test",
|
|
133
|
+
"test:watch": "pnpm dlx projen test:watch",
|
|
134
|
+
"watch": "pnpm dlx projen watch",
|
|
135
|
+
"projen": "pnpm dlx projen"
|
|
136
|
+
}
|
|
137
|
+
}
|