@pipeline-builder/pipeline-manager 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 +74 -0
- package/cdk.json +91 -0
- package/config.yml +94 -0
- package/dist/boilerplate.d.ts +3 -0
- package/dist/boilerplate.d.ts.map +1 -0
- package/dist/boilerplate.js +58 -0
- package/dist/cdk.json +91 -0
- package/dist/cli.d.ts +62 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +372 -0
- package/dist/commands/bootstrap.d.ts +11 -0
- package/dist/commands/bootstrap.d.ts.map +1 -0
- package/dist/commands/bootstrap.js +159 -0
- package/dist/commands/create-pipeline.d.ts +12 -0
- package/dist/commands/create-pipeline.d.ts.map +1 -0
- package/dist/commands/create-pipeline.js +291 -0
- package/dist/commands/deploy.d.ts +15 -0
- package/dist/commands/deploy.d.ts.map +1 -0
- package/dist/commands/deploy.js +167 -0
- package/dist/commands/get-pipeline.d.ts +13 -0
- package/dist/commands/get-pipeline.d.ts.map +1 -0
- package/dist/commands/get-pipeline.js +97 -0
- package/dist/commands/get-plugin.d.ts +13 -0
- package/dist/commands/get-plugin.d.ts.map +1 -0
- package/dist/commands/get-plugin.js +98 -0
- package/dist/commands/list-pipelines.d.ts +20 -0
- package/dist/commands/list-pipelines.d.ts.map +1 -0
- package/dist/commands/list-pipelines.js +172 -0
- package/dist/commands/list-plugins.d.ts +20 -0
- package/dist/commands/list-plugins.d.ts.map +1 -0
- package/dist/commands/list-plugins.js +167 -0
- package/dist/commands/login.d.ts +21 -0
- package/dist/commands/login.d.ts.map +1 -0
- package/dist/commands/login.js +179 -0
- package/dist/commands/setup-events.d.ts +15 -0
- package/dist/commands/setup-events.d.ts.map +1 -0
- package/dist/commands/setup-events.js +177 -0
- package/dist/commands/status.d.ts +11 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +89 -0
- package/dist/commands/store-token.d.ts +20 -0
- package/dist/commands/store-token.d.ts.map +1 -0
- package/dist/commands/store-token.js +233 -0
- package/dist/commands/synth.d.ts +21 -0
- package/dist/commands/synth.d.ts.map +1 -0
- package/dist/commands/synth.js +143 -0
- package/dist/commands/upload-plugin.d.ts +21 -0
- package/dist/commands/upload-plugin.d.ts.map +1 -0
- package/dist/commands/upload-plugin.js +311 -0
- package/dist/commands/version.d.ts +12 -0
- package/dist/commands/version.d.ts.map +1 -0
- package/dist/commands/version.js +223 -0
- package/dist/config/cli.constants.d.ts +101 -0
- package/dist/config/cli.constants.d.ts.map +1 -0
- package/dist/config/cli.constants.js +165 -0
- package/dist/config.yml +94 -0
- package/dist/templates/events-stack.json +141 -0
- package/dist/types/config.d.ts +44 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +5 -0
- package/dist/types/error.d.ts +61 -0
- package/dist/types/error.d.ts.map +1 -0
- package/dist/types/error.js +39 -0
- package/dist/types/index.d.ts +8 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +26 -0
- package/dist/types/pipeline.d.ts +144 -0
- package/dist/types/pipeline.d.ts.map +1 -0
- package/dist/types/pipeline.js +5 -0
- package/dist/types/plugin.d.ts +160 -0
- package/dist/types/plugin.d.ts.map +1 -0
- package/dist/types/plugin.js +5 -0
- package/dist/utils/api-client.d.ts +26 -0
- package/dist/utils/api-client.d.ts.map +1 -0
- package/dist/utils/api-client.js +160 -0
- package/dist/utils/audit-log.d.ts +8 -0
- package/dist/utils/audit-log.d.ts.map +1 -0
- package/dist/utils/audit-log.js +53 -0
- package/dist/utils/auth-guard.d.ts +16 -0
- package/dist/utils/auth-guard.d.ts.map +1 -0
- package/dist/utils/auth-guard.js +25 -0
- package/dist/utils/aws-secrets.d.ts +21 -0
- package/dist/utils/aws-secrets.d.ts.map +1 -0
- package/dist/utils/aws-secrets.js +74 -0
- package/dist/utils/banner.d.ts +19 -0
- package/dist/utils/banner.d.ts.map +1 -0
- package/dist/utils/banner.js +59 -0
- package/dist/utils/cdk-utils.d.ts +51 -0
- package/dist/utils/cdk-utils.d.ts.map +1 -0
- package/dist/utils/cdk-utils.js +101 -0
- package/dist/utils/command-utils.d.ts +56 -0
- package/dist/utils/command-utils.d.ts.map +1 -0
- package/dist/utils/command-utils.js +138 -0
- package/dist/utils/config-loader.d.ts +27 -0
- package/dist/utils/config-loader.d.ts.map +1 -0
- package/dist/utils/config-loader.js +166 -0
- package/dist/utils/error-handler.d.ts +29 -0
- package/dist/utils/error-handler.d.ts.map +1 -0
- package/dist/utils/error-handler.js +255 -0
- package/dist/utils/list-command-utils.d.ts +23 -0
- package/dist/utils/list-command-utils.d.ts.map +1 -0
- package/dist/utils/list-command-utils.js +60 -0
- package/dist/utils/output-utils.d.ts +60 -0
- package/dist/utils/output-utils.d.ts.map +1 -0
- package/dist/utils/output-utils.js +320 -0
- package/dist/utils/rate-limiter.d.ts +14 -0
- package/dist/utils/rate-limiter.d.ts.map +1 -0
- package/dist/utils/rate-limiter.js +73 -0
- package/package.json +144 -0
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Copyright 2026 Pipeline Builder Contributors
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
5
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
6
|
+
};
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.resolveAccount = resolveAccount;
|
|
9
|
+
exports.resolveRegion = resolveRegion;
|
|
10
|
+
exports.buildBootstrapCommand = buildBootstrapCommand;
|
|
11
|
+
exports.bootstrap = bootstrap;
|
|
12
|
+
const picocolors_1 = __importDefault(require("picocolors"));
|
|
13
|
+
const cli_constants_1 = require("../config/cli.constants");
|
|
14
|
+
const audit_log_1 = require("../utils/audit-log");
|
|
15
|
+
const cdk_utils_1 = require("../utils/cdk-utils");
|
|
16
|
+
const command_utils_1 = require("../utils/command-utils");
|
|
17
|
+
const error_handler_1 = require("../utils/error-handler");
|
|
18
|
+
const output_utils_1 = require("../utils/output-utils");
|
|
19
|
+
const { bold, cyan, dim } = picocolors_1.default;
|
|
20
|
+
/**
|
|
21
|
+
* Resolves the AWS account ID from the CLI option or environment variable.
|
|
22
|
+
* @returns The account ID string, or `undefined` if not available.
|
|
23
|
+
*/
|
|
24
|
+
/** @internal Exported for testing only */
|
|
25
|
+
function resolveAccount(optionValue) {
|
|
26
|
+
return optionValue || process.env.AWS_ACCOUNT_ID || process.env.CDK_DEFAULT_ACCOUNT;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Resolves the AWS region from the CLI option or environment variable.
|
|
30
|
+
* @returns The region string, or `undefined` if not available.
|
|
31
|
+
*/
|
|
32
|
+
/** @internal Exported for testing only */
|
|
33
|
+
function resolveRegion(optionValue) {
|
|
34
|
+
return optionValue || process.env[cli_constants_1.ENV_VARS.AWS_REGION] || process.env.CDK_DEFAULT_REGION || 'us-east-1';
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Builds the `cdk bootstrap` command string from the resolved options.
|
|
38
|
+
*/
|
|
39
|
+
/** @internal Exported for testing only */
|
|
40
|
+
function buildBootstrapCommand(options) {
|
|
41
|
+
(0, cli_constants_1.assertShellSafe)(options.account, 'account');
|
|
42
|
+
(0, cli_constants_1.assertShellSafe)(options.region, 'region');
|
|
43
|
+
if (options.profile)
|
|
44
|
+
(0, cli_constants_1.assertShellSafe)(options.profile, 'profile');
|
|
45
|
+
const parts = [
|
|
46
|
+
'cdk',
|
|
47
|
+
'bootstrap',
|
|
48
|
+
`aws://${options.account}/${options.region}`,
|
|
49
|
+
];
|
|
50
|
+
if (options.profile) {
|
|
51
|
+
parts.push(`--profile=${options.profile}`);
|
|
52
|
+
}
|
|
53
|
+
if (options.qualifier) {
|
|
54
|
+
parts.push(`--qualifier=${options.qualifier}`);
|
|
55
|
+
}
|
|
56
|
+
if (options.trust) {
|
|
57
|
+
parts.push(`--trust=${options.trust}`);
|
|
58
|
+
}
|
|
59
|
+
if (options.cloudformationExecutionPolicies) {
|
|
60
|
+
parts.push(`--cloudformation-execution-policies=${options.cloudformationExecutionPolicies}`);
|
|
61
|
+
}
|
|
62
|
+
return parts.join(' ');
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Registers the `bootstrap` command with the CLI program.
|
|
66
|
+
*
|
|
67
|
+
* Provisions the CDK toolkit stack in the target AWS account/region
|
|
68
|
+
* so that CDK deployments can proceed.
|
|
69
|
+
*
|
|
70
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
71
|
+
*/
|
|
72
|
+
function bootstrap(program) {
|
|
73
|
+
program
|
|
74
|
+
.command('bootstrap')
|
|
75
|
+
.description('Bootstrap AWS CDK toolkit stack in target account/region')
|
|
76
|
+
.option('--account <id>', 'AWS account ID (defaults to AWS_ACCOUNT_ID or CDK_DEFAULT_ACCOUNT env)')
|
|
77
|
+
.option('--region <region>', 'AWS region (defaults to AWS_REGION or CDK_DEFAULT_REGION env)')
|
|
78
|
+
.option('--profile <profile>', 'AWS CLI profile', 'default')
|
|
79
|
+
.option('--qualifier <qualifier>', 'Bootstrap qualifier for environment isolation')
|
|
80
|
+
.option('--trust <accounts>', 'Comma-separated account IDs to trust for cross-account deployments')
|
|
81
|
+
.option('--cloudformation-execution-policies <arns>', 'IAM policy ARNs for CloudFormation execution role')
|
|
82
|
+
.option('--json', 'Output result as JSON', false)
|
|
83
|
+
.action(async (options) => {
|
|
84
|
+
const executionId = (0, command_utils_1.printCommandHeader)('CDK Bootstrap');
|
|
85
|
+
try {
|
|
86
|
+
(0, audit_log_1.auditLog)('bootstrap', { executionId, account: options.account, region: options.region, profile: options.profile });
|
|
87
|
+
// Resolve account and region
|
|
88
|
+
const account = resolveAccount(options.account);
|
|
89
|
+
const region = resolveRegion(options.region);
|
|
90
|
+
if (!account) {
|
|
91
|
+
(0, output_utils_1.printError)('AWS account ID is required');
|
|
92
|
+
console.log(dim('Provide --account <id> or set AWS_ACCOUNT_ID / CDK_DEFAULT_ACCOUNT environment variable'));
|
|
93
|
+
throw new Error('AWS account ID not provided');
|
|
94
|
+
}
|
|
95
|
+
(0, output_utils_1.printInfo)('Bootstrap parameters', {
|
|
96
|
+
account,
|
|
97
|
+
region,
|
|
98
|
+
profile: options.profile,
|
|
99
|
+
qualifier: options.qualifier || '(default)',
|
|
100
|
+
trust: options.trust || '(none)',
|
|
101
|
+
cloudformationExecutionPolicies: options.cloudformationExecutionPolicies || '(none)',
|
|
102
|
+
});
|
|
103
|
+
(0, cdk_utils_1.ensureCdkAvailable)();
|
|
104
|
+
(0, output_utils_1.printSuccess)('AWS CDK is available');
|
|
105
|
+
// Build bootstrap command
|
|
106
|
+
const command = buildBootstrapCommand({
|
|
107
|
+
account,
|
|
108
|
+
region,
|
|
109
|
+
profile: options.profile,
|
|
110
|
+
qualifier: options.qualifier,
|
|
111
|
+
trust: options.trust,
|
|
112
|
+
cloudformationExecutionPolicies: options.cloudformationExecutionPolicies,
|
|
113
|
+
});
|
|
114
|
+
(0, output_utils_1.printSection)('CDK Execution');
|
|
115
|
+
console.log(cyan(bold('Command:')), dim(command));
|
|
116
|
+
console.log('');
|
|
117
|
+
// Execute bootstrap
|
|
118
|
+
const result = (0, cdk_utils_1.executeCdkShellCommand)(command, {
|
|
119
|
+
debug: program.opts().debug,
|
|
120
|
+
showOutput: true,
|
|
121
|
+
});
|
|
122
|
+
console.log('');
|
|
123
|
+
(0, output_utils_1.printSection)('Bootstrap Complete');
|
|
124
|
+
if (result.success) {
|
|
125
|
+
if (options.json) {
|
|
126
|
+
console.log(JSON.stringify({
|
|
127
|
+
success: true,
|
|
128
|
+
executionId,
|
|
129
|
+
account,
|
|
130
|
+
region,
|
|
131
|
+
duration: result.duration,
|
|
132
|
+
}, null, 2));
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
(0, output_utils_1.printKeyValue)({
|
|
136
|
+
'Execution ID': executionId,
|
|
137
|
+
'Account': account,
|
|
138
|
+
'Region': region,
|
|
139
|
+
'Duration': `${result.duration}ms`,
|
|
140
|
+
'Status': '✓ Success',
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
catch (error) {
|
|
146
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.VALIDATION, {
|
|
147
|
+
debug: program.opts().debug,
|
|
148
|
+
exit: true,
|
|
149
|
+
context: {
|
|
150
|
+
command: 'bootstrap',
|
|
151
|
+
executionId,
|
|
152
|
+
account: options.account,
|
|
153
|
+
region: options.region,
|
|
154
|
+
},
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../../src/commands/bootstrap.ts"],"names":[],"mappings":";AAAA,+CAA+C;AAC/C,sCAAsC;;;;;AAkBtC,wCAEC;AAOD,sCAEC;AAMD,sDAmCC;AAUD,8BA+FC;AA5KD,4DAA8B;AAC9B,2DAAoE;AACpE,kDAA8C;AAC9C,kDAAgF;AAChF,0DAA4D;AAC5D,0DAAkE;AAClE,wDAAyG;AAEzG,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,oBAAI,CAAC;AAEjC;;;GAGG;AACH,0CAA0C;AAC1C,SAAgB,cAAc,CAAC,WAAoB;IACjD,OAAO,WAAW,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC;AACtF,CAAC;AAED;;;GAGG;AACH,0CAA0C;AAC1C,SAAgB,aAAa,CAAC,WAAoB;IAChD,OAAO,WAAW,IAAI,OAAO,CAAC,GAAG,CAAC,wBAAQ,CAAC,UAAU,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,WAAW,CAAC;AAC1G,CAAC;AAED;;GAEG;AACH,0CAA0C;AAC1C,SAAgB,qBAAqB,CAAC,OAOrC;IACC,IAAA,+BAAe,EAAC,OAAO,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IAC5C,IAAA,+BAAe,EAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IAC1C,IAAI,OAAO,CAAC,OAAO;QAAE,IAAA,+BAAe,EAAC,OAAO,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IAEjE,MAAM,KAAK,GAAa;QACtB,KAAK;QACL,WAAW;QACX,SAAS,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,EAAE;KAC7C,CAAC;IAEF,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QACpB,KAAK,CAAC,IAAI,CAAC,aAAa,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;QACtB,KAAK,CAAC,IAAI,CAAC,eAAe,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;IACjD,CAAC;IAED,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;QAClB,KAAK,CAAC,IAAI,CAAC,WAAW,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,OAAO,CAAC,+BAA+B,EAAE,CAAC;QAC5C,KAAK,CAAC,IAAI,CAAC,uCAAuC,OAAO,CAAC,+BAA+B,EAAE,CAAC,CAAC;IAC/F,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACzB,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,SAAS,CAAC,OAAgB;IACxC,OAAO;SACJ,OAAO,CAAC,WAAW,CAAC;SACpB,WAAW,CAAC,0DAA0D,CAAC;SACvE,MAAM,CAAC,gBAAgB,EAAE,wEAAwE,CAAC;SAClG,MAAM,CAAC,mBAAmB,EAAE,+DAA+D,CAAC;SAC5F,MAAM,CAAC,qBAAqB,EAAE,iBAAiB,EAAE,SAAS,CAAC;SAC3D,MAAM,CAAC,yBAAyB,EAAE,+CAA+C,CAAC;SAClF,MAAM,CAAC,oBAAoB,EAAE,oEAAoE,CAAC;SAClG,MAAM,CAAC,4CAA4C,EAAE,mDAAmD,CAAC;SACzG,MAAM,CAAC,QAAQ,EAAE,uBAAuB,EAAE,KAAK,CAAC;SAChD,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,MAAM,WAAW,GAAG,IAAA,kCAAkB,EAAC,eAAe,CAAC,CAAC;QAExD,IAAI,CAAC;YACH,IAAA,oBAAQ,EAAC,WAAW,EAAE,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;YAEnH,6BAA6B;YAC7B,MAAM,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAChD,MAAM,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAE7C,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,IAAA,yBAAU,EAAC,4BAA4B,CAAC,CAAC;gBACzC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,yFAAyF,CAAC,CAAC,CAAC;gBAC5G,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;YACjD,CAAC;YAED,IAAA,wBAAS,EAAC,sBAAsB,EAAE;gBAChC,OAAO;gBACP,MAAM;gBACN,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,WAAW;gBAC3C,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,QAAQ;gBAChC,+BAA+B,EAAE,OAAO,CAAC,+BAA+B,IAAI,QAAQ;aACrF,CAAC,CAAC;YAEH,IAAA,8BAAkB,GAAE,CAAC;YACrB,IAAA,2BAAY,EAAC,sBAAsB,CAAC,CAAC;YAErC,0BAA0B;YAC1B,MAAM,OAAO,GAAG,qBAAqB,CAAC;gBACpC,OAAO;gBACP,MAAM;gBACN,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS,EAAE,OAAO,CAAC,SAAS;gBAC5B,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,+BAA+B,EAAE,OAAO,CAAC,+BAA+B;aACzE,CAAC,CAAC;YAEH,IAAA,2BAAY,EAAC,eAAe,CAAC,CAAC;YAC9B,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC;YAClD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEhB,oBAAoB;YACpB,MAAM,MAAM,GAAG,IAAA,kCAAsB,EAAC,OAAO,EAAE;gBAC7C,KAAK,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,KAAK;gBAC3B,UAAU,EAAE,IAAI;aACjB,CAAC,CAAC;YAEH,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAChB,IAAA,2BAAY,EAAC,oBAAoB,CAAC,CAAC;YAEnC,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACnB,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;oBACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;wBACzB,OAAO,EAAE,IAAI;wBACb,WAAW;wBACX,OAAO;wBACP,MAAM;wBACN,QAAQ,EAAE,MAAM,CAAC,QAAQ;qBAC1B,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBACf,CAAC;qBAAM,CAAC;oBACN,IAAA,4BAAa,EAAC;wBACZ,cAAc,EAAE,WAAW;wBAC3B,SAAS,EAAE,OAAO;wBAClB,QAAQ,EAAE,MAAM;wBAChB,UAAU,EAAE,GAAG,MAAM,CAAC,QAAQ,IAAI;wBAClC,QAAQ,EAAE,WAAW;qBACtB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;QAEH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAA,2BAAW,EAAC,KAAK,EAAE,2BAAW,CAAC,UAAU,EAAE;gBACzC,KAAK,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,KAAK;gBAC3B,IAAI,EAAE,IAAI;gBACV,OAAO,EAAE;oBACP,OAAO,EAAE,WAAW;oBACpB,WAAW;oBACX,OAAO,EAAE,OAAO,CAAC,OAAO;oBACxB,MAAM,EAAE,OAAO,CAAC,MAAM;iBACvB;aACF,CAAC,CAAC;QACL,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { Command } from 'commander';\nimport pico from 'picocolors';\nimport { ENV_VARS, assertShellSafe } from '../config/cli.constants';\nimport { auditLog } from '../utils/audit-log';\nimport { ensureCdkAvailable, executeCdkShellCommand } from '../utils/cdk-utils';\nimport { printCommandHeader } from '../utils/command-utils';\nimport { ERROR_CODES, handleError } from '../utils/error-handler';\nimport { printError, printInfo, printKeyValue, printSection, printSuccess } from '../utils/output-utils';\n\nconst { bold, cyan, dim } = pico;\n\n/**\n * Resolves the AWS account ID from the CLI option or environment variable.\n * @returns The account ID string, or `undefined` if not available.\n */\n/** @internal Exported for testing only */\nexport function resolveAccount(optionValue?: string): string | undefined {\n  return optionValue || process.env.AWS_ACCOUNT_ID || process.env.CDK_DEFAULT_ACCOUNT;\n}\n\n/**\n * Resolves the AWS region from the CLI option or environment variable.\n * @returns The region string, or `undefined` if not available.\n */\n/** @internal Exported for testing only */\nexport function resolveRegion(optionValue?: string): string {\n  return optionValue || process.env[ENV_VARS.AWS_REGION] || process.env.CDK_DEFAULT_REGION || 'us-east-1';\n}\n\n/**\n * Builds the `cdk bootstrap` command string from the resolved options.\n */\n/** @internal Exported for testing only */\nexport function buildBootstrapCommand(options: {\n  account: string;\n  region: string;\n  profile?: string;\n  qualifier?: string;\n  trust?: string;\n  cloudformationExecutionPolicies?: string;\n}): string {\n  assertShellSafe(options.account, 'account');\n  assertShellSafe(options.region, 'region');\n  if (options.profile) assertShellSafe(options.profile, 'profile');\n\n  const parts: string[] = [\n    'cdk',\n    'bootstrap',\n    `aws://${options.account}/${options.region}`,\n  ];\n\n  if (options.profile) {\n    parts.push(`--profile=${options.profile}`);\n  }\n\n  if (options.qualifier) {\n    parts.push(`--qualifier=${options.qualifier}`);\n  }\n\n  if (options.trust) {\n    parts.push(`--trust=${options.trust}`);\n  }\n\n  if (options.cloudformationExecutionPolicies) {\n    parts.push(`--cloudformation-execution-policies=${options.cloudformationExecutionPolicies}`);\n  }\n\n  return parts.join(' ');\n}\n\n/**\n * Registers the `bootstrap` command with the CLI program.\n *\n * Provisions the CDK toolkit stack in the target AWS account/region\n * so that CDK deployments can proceed.\n *\n * @param program - The root Commander program instance to attach the command to.\n */\nexport function bootstrap(program: Command): void {\n  program\n    .command('bootstrap')\n    .description('Bootstrap AWS CDK toolkit stack in target account/region')\n    .option('--account <id>', 'AWS account ID (defaults to AWS_ACCOUNT_ID or CDK_DEFAULT_ACCOUNT env)')\n    .option('--region <region>', 'AWS region (defaults to AWS_REGION or CDK_DEFAULT_REGION env)')\n    .option('--profile <profile>', 'AWS CLI profile', 'default')\n    .option('--qualifier <qualifier>', 'Bootstrap qualifier for environment isolation')\n    .option('--trust <accounts>', 'Comma-separated account IDs to trust for cross-account deployments')\n    .option('--cloudformation-execution-policies <arns>', 'IAM policy ARNs for CloudFormation execution role')\n    .option('--json', 'Output result as JSON', false)\n    .action(async (options) => {\n      const executionId = printCommandHeader('CDK Bootstrap');\n\n      try {\n        auditLog('bootstrap', { executionId, account: options.account, region: options.region, profile: options.profile });\n\n        // Resolve account and region\n        const account = resolveAccount(options.account);\n        const region = resolveRegion(options.region);\n\n        if (!account) {\n          printError('AWS account ID is required');\n          console.log(dim('Provide --account <id> or set AWS_ACCOUNT_ID / CDK_DEFAULT_ACCOUNT environment variable'));\n          throw new Error('AWS account ID not provided');\n        }\n\n        printInfo('Bootstrap parameters', {\n          account,\n          region,\n          profile: options.profile,\n          qualifier: options.qualifier || '(default)',\n          trust: options.trust || '(none)',\n          cloudformationExecutionPolicies: options.cloudformationExecutionPolicies || '(none)',\n        });\n\n        ensureCdkAvailable();\n        printSuccess('AWS CDK is available');\n\n        // Build bootstrap command\n        const command = buildBootstrapCommand({\n          account,\n          region,\n          profile: options.profile,\n          qualifier: options.qualifier,\n          trust: options.trust,\n          cloudformationExecutionPolicies: options.cloudformationExecutionPolicies,\n        });\n\n        printSection('CDK Execution');\n        console.log(cyan(bold('Command:')), dim(command));\n        console.log('');\n\n        // Execute bootstrap\n        const result = executeCdkShellCommand(command, {\n          debug: program.opts().debug,\n          showOutput: true,\n        });\n\n        console.log('');\n        printSection('Bootstrap Complete');\n\n        if (result.success) {\n          if (options.json) {\n            console.log(JSON.stringify({\n              success: true,\n              executionId,\n              account,\n              region,\n              duration: result.duration,\n            }, null, 2));\n          } else {\n            printKeyValue({\n              'Execution ID': executionId,\n              'Account': account,\n              'Region': region,\n              'Duration': `${result.duration}ms`,\n              'Status': '✓ Success',\n            });\n          }\n        }\n\n      } catch (error) {\n        handleError(error, ERROR_CODES.VALIDATION, {\n          debug: program.opts().debug,\n          exit: true,\n          context: {\n            command: 'bootstrap',\n            executionId,\n            account: options.account,\n            region: options.region,\n          },\n        });\n      }\n    });\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
/**
|
|
3
|
+
* Registers the `create-pipeline` command with the CLI program.
|
|
4
|
+
*
|
|
5
|
+
* Accepts a pipeline properties JSON file, validates it, resolves
|
|
6
|
+
* project/organization from CLI flags or the props file, and
|
|
7
|
+
* creates the pipeline via the platform API.
|
|
8
|
+
*
|
|
9
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
10
|
+
*/
|
|
11
|
+
export declare function createPipeline(program: Command): void;
|
|
12
|
+
//# sourceMappingURL=create-pipeline.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-pipeline.d.ts","sourceRoot":"","sources":["../../src/commands/create-pipeline.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAWpC;;;;;;;;GAQG;AACH,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA0QrD"}
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Copyright 2026 Pipeline Builder Contributors
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
5
|
+
if (k2 === undefined) k2 = k;
|
|
6
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
7
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
8
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
9
|
+
}
|
|
10
|
+
Object.defineProperty(o, k2, desc);
|
|
11
|
+
}) : (function(o, m, k, k2) {
|
|
12
|
+
if (k2 === undefined) k2 = k;
|
|
13
|
+
o[k2] = m[k];
|
|
14
|
+
}));
|
|
15
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
16
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
17
|
+
}) : function(o, v) {
|
|
18
|
+
o["default"] = v;
|
|
19
|
+
});
|
|
20
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
21
|
+
var ownKeys = function(o) {
|
|
22
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
23
|
+
var ar = [];
|
|
24
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
25
|
+
return ar;
|
|
26
|
+
};
|
|
27
|
+
return ownKeys(o);
|
|
28
|
+
};
|
|
29
|
+
return function (mod) {
|
|
30
|
+
if (mod && mod.__esModule) return mod;
|
|
31
|
+
var result = {};
|
|
32
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
33
|
+
__setModuleDefault(result, mod);
|
|
34
|
+
return result;
|
|
35
|
+
};
|
|
36
|
+
})();
|
|
37
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
38
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
39
|
+
};
|
|
40
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
41
|
+
exports.createPipeline = createPipeline;
|
|
42
|
+
const fs = __importStar(require("fs"));
|
|
43
|
+
const path = __importStar(require("path"));
|
|
44
|
+
const ora_1 = __importDefault(require("ora"));
|
|
45
|
+
const picocolors_1 = __importDefault(require("picocolors"));
|
|
46
|
+
const cli_constants_1 = require("../config/cli.constants");
|
|
47
|
+
const command_utils_1 = require("../utils/command-utils");
|
|
48
|
+
const error_handler_1 = require("../utils/error-handler");
|
|
49
|
+
const output_utils_1 = require("../utils/output-utils");
|
|
50
|
+
const { bold, cyan, dim, green } = picocolors_1.default;
|
|
51
|
+
/**
|
|
52
|
+
* Registers the `create-pipeline` command with the CLI program.
|
|
53
|
+
*
|
|
54
|
+
* Accepts a pipeline properties JSON file, validates it, resolves
|
|
55
|
+
* project/organization from CLI flags or the props file, and
|
|
56
|
+
* creates the pipeline via the platform API.
|
|
57
|
+
*
|
|
58
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
59
|
+
*/
|
|
60
|
+
function createPipeline(program) {
|
|
61
|
+
program
|
|
62
|
+
.command('create-pipeline')
|
|
63
|
+
.description('Create a new pipeline with the provided configuration')
|
|
64
|
+
.requiredOption('-f, --file <file>', 'Path to pipeline properties JSON file')
|
|
65
|
+
.option('-p, --project <project>', 'Project name (falls back to value in props file)')
|
|
66
|
+
.option('-o, --organization <organization>', 'Organization name (falls back to value in props file)')
|
|
67
|
+
.option('-n, --name <name>', 'Pipeline name')
|
|
68
|
+
.option('-a, --access <modifier>', 'Access modifier (public|private)', 'private')
|
|
69
|
+
.option('--default', 'Set as default pipeline', false)
|
|
70
|
+
.option('--active', 'Set pipeline as active', true)
|
|
71
|
+
.option('--verify-ssl', 'Enable SSL certificate verification')
|
|
72
|
+
.option('--no-verify-ssl', 'Disable SSL certificate verification')
|
|
73
|
+
.option('--dry-run', 'Validate inputs without creating pipeline', false)
|
|
74
|
+
.action(async (options) => {
|
|
75
|
+
const executionId = (0, command_utils_1.printCommandHeader)('Create Pipeline', 'Creating Pipeline');
|
|
76
|
+
const startTime = Date.now();
|
|
77
|
+
try {
|
|
78
|
+
// Display parameters
|
|
79
|
+
(0, output_utils_1.printInfo)('Configuration');
|
|
80
|
+
(0, output_utils_1.printKeyValue)({
|
|
81
|
+
'Project': options.project || '(from props file)',
|
|
82
|
+
'Organization': options.organization || '(from props file)',
|
|
83
|
+
'Name': options.name || '(not set)',
|
|
84
|
+
'Access Modifier': options.access,
|
|
85
|
+
'Default Pipeline': options.default ? 'Yes' : 'No',
|
|
86
|
+
'Active': options.active ? 'Yes' : 'No',
|
|
87
|
+
'Properties File': options.file,
|
|
88
|
+
'SSL Verification': options.verifySsl === false ? 'Disabled' : 'Enabled',
|
|
89
|
+
'Dry Run': options.dryRun ? 'Yes' : 'No',
|
|
90
|
+
});
|
|
91
|
+
// Security warning for SSL verification disabled
|
|
92
|
+
(0, command_utils_1.printSslWarning)(options.verifySsl);
|
|
93
|
+
console.log('');
|
|
94
|
+
(0, output_utils_1.printSection)('File Validation');
|
|
95
|
+
// Validate file exists
|
|
96
|
+
if (!fs.existsSync(options.file)) {
|
|
97
|
+
(0, output_utils_1.printError)('Properties file not found', { path: options.file });
|
|
98
|
+
throw new Error(`File not found: ${options.file}`);
|
|
99
|
+
}
|
|
100
|
+
// Check file extension
|
|
101
|
+
const fileExt = path.extname(options.file).toLowerCase();
|
|
102
|
+
if (fileExt !== '.json') {
|
|
103
|
+
(0, output_utils_1.printWarning)('File extension is not .json', { extension: fileExt });
|
|
104
|
+
}
|
|
105
|
+
const fileStats = fs.statSync(options.file);
|
|
106
|
+
// Check file size
|
|
107
|
+
if (fileStats.size > cli_constants_1.FILE_SIZE_LIMITS.PIPELINE_PROPS) {
|
|
108
|
+
(0, output_utils_1.printError)('Properties file is too large', {
|
|
109
|
+
size: (0, cli_constants_1.formatFileSize)(fileStats.size),
|
|
110
|
+
limit: (0, cli_constants_1.formatFileSize)(cli_constants_1.FILE_SIZE_LIMITS.PIPELINE_PROPS),
|
|
111
|
+
});
|
|
112
|
+
throw new Error('Properties file exceeds size limit');
|
|
113
|
+
}
|
|
114
|
+
(0, output_utils_1.printSuccess)('File validation passed');
|
|
115
|
+
(0, output_utils_1.printKeyValue)({
|
|
116
|
+
'File Path': options.file,
|
|
117
|
+
'File Size': (0, cli_constants_1.formatFileSize)(fileStats.size),
|
|
118
|
+
'Extension': fileExt,
|
|
119
|
+
});
|
|
120
|
+
// Read and parse properties file
|
|
121
|
+
console.log('');
|
|
122
|
+
(0, output_utils_1.printInfo)('Reading pipeline properties...');
|
|
123
|
+
const fileContent = fs.readFileSync(options.file, 'utf-8');
|
|
124
|
+
let props;
|
|
125
|
+
try {
|
|
126
|
+
props = JSON.parse(fileContent);
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
(0, output_utils_1.printError)('Invalid JSON in properties file', {
|
|
130
|
+
error: error instanceof Error ? error.message : String(error),
|
|
131
|
+
hint: 'Ensure the file contains valid JSON syntax',
|
|
132
|
+
});
|
|
133
|
+
throw new Error('Properties file must contain valid JSON');
|
|
134
|
+
}
|
|
135
|
+
// Validate properties structure
|
|
136
|
+
if (typeof props !== 'object' || props === null) {
|
|
137
|
+
(0, output_utils_1.printError)('Invalid properties format', {
|
|
138
|
+
type: typeof props,
|
|
139
|
+
hint: 'Properties must be a JSON object',
|
|
140
|
+
});
|
|
141
|
+
throw new Error('Properties must be a valid object');
|
|
142
|
+
}
|
|
143
|
+
const propCount = Object.keys(props).length;
|
|
144
|
+
(0, output_utils_1.printSuccess)('Properties parsed successfully');
|
|
145
|
+
(0, output_utils_1.printKeyValue)({
|
|
146
|
+
'Total Keys': propCount.toString(),
|
|
147
|
+
'Sample Keys': Object.keys(props).slice(0, 5).join(', ') + (propCount > 5 ? '...' : ''),
|
|
148
|
+
});
|
|
149
|
+
// Validate properties content
|
|
150
|
+
if (propCount === 0) {
|
|
151
|
+
(0, output_utils_1.printWarning)('Properties object is empty - pipeline will have no configuration');
|
|
152
|
+
}
|
|
153
|
+
// Resolve project & organization: prefer CLI flags, fall back to
|
|
154
|
+
// values embedded inside the props file (builderProps).
|
|
155
|
+
const resolvedProject = options.project ?? props.project;
|
|
156
|
+
const resolvedOrganization = options.organization ?? props.organization;
|
|
157
|
+
if (!resolvedProject) {
|
|
158
|
+
(0, output_utils_1.printError)('Project is required', {
|
|
159
|
+
hint: 'Provide -p/--project flag or include "project" in the props file',
|
|
160
|
+
});
|
|
161
|
+
throw new Error('Project is required');
|
|
162
|
+
}
|
|
163
|
+
if (!resolvedOrganization) {
|
|
164
|
+
(0, output_utils_1.printError)('Organization is required', {
|
|
165
|
+
hint: 'Provide -o/--organization flag or include "organization" in the props file',
|
|
166
|
+
});
|
|
167
|
+
throw new Error('Organization is required');
|
|
168
|
+
}
|
|
169
|
+
// Build request payload — resolve pipelineName using same strategy as pipeline-builder.ts:
|
|
170
|
+
// props.pipelineName ?? `${organization}-${project}-pipeline`
|
|
171
|
+
const sanitize = (s) => s.replace(/[^a-zA-Z0-9]/g, '_').toLowerCase();
|
|
172
|
+
const resolvedPipelineName = options.name
|
|
173
|
+
?? props.pipelineName
|
|
174
|
+
?? `${sanitize(resolvedOrganization)}-${sanitize(resolvedProject)}-pipeline`;
|
|
175
|
+
const payload = {
|
|
176
|
+
project: resolvedProject,
|
|
177
|
+
organization: resolvedOrganization,
|
|
178
|
+
pipelineName: resolvedPipelineName,
|
|
179
|
+
props,
|
|
180
|
+
};
|
|
181
|
+
// Add optional fields only if provided
|
|
182
|
+
if (options.access) {
|
|
183
|
+
payload.accessModifier = options.access;
|
|
184
|
+
}
|
|
185
|
+
if (options.default !== undefined) {
|
|
186
|
+
payload.isDefault = options.default;
|
|
187
|
+
}
|
|
188
|
+
if (options.active !== undefined) {
|
|
189
|
+
payload.isActive = options.active;
|
|
190
|
+
}
|
|
191
|
+
// Dry run mode
|
|
192
|
+
if (options.dryRun) {
|
|
193
|
+
console.log('');
|
|
194
|
+
(0, output_utils_1.printSection)('Dry Run - Request Preview');
|
|
195
|
+
console.log(JSON.stringify(payload, null, 2));
|
|
196
|
+
console.log('');
|
|
197
|
+
(0, output_utils_1.printSuccess)('✓ Validation complete - no pipeline created (dry run mode)');
|
|
198
|
+
console.log('');
|
|
199
|
+
(0, output_utils_1.printInfo)('To create the pipeline, run the command without --dry-run');
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
// Create authenticated API client
|
|
203
|
+
const client = (0, command_utils_1.createAuthenticatedClient)(options);
|
|
204
|
+
const config = client.getConfig();
|
|
205
|
+
// Create pipeline
|
|
206
|
+
console.log('');
|
|
207
|
+
(0, output_utils_1.printSection)('Creating Pipeline');
|
|
208
|
+
const spinner = (0, ora_1.default)('Creating pipeline...').start();
|
|
209
|
+
let rawResponse;
|
|
210
|
+
let requestDuration;
|
|
211
|
+
try {
|
|
212
|
+
const requestStart = Date.now();
|
|
213
|
+
rawResponse = await client.post(config.api.pipelineUrl, payload);
|
|
214
|
+
requestDuration = Date.now() - requestStart;
|
|
215
|
+
spinner.succeed('Pipeline created');
|
|
216
|
+
}
|
|
217
|
+
catch (error) {
|
|
218
|
+
spinner.fail('Pipeline creation failed');
|
|
219
|
+
throw error;
|
|
220
|
+
}
|
|
221
|
+
const pipeline = (0, output_utils_1.extractSingleResponse)(rawResponse, 'pipeline', 'id');
|
|
222
|
+
if (!pipeline?.id) {
|
|
223
|
+
(0, output_utils_1.printError)('Invalid pipeline response', {
|
|
224
|
+
responseKeys: rawResponse ? Object.keys(rawResponse) : '(null)',
|
|
225
|
+
});
|
|
226
|
+
throw new Error('Pipeline creation failed - no valid pipeline data received');
|
|
227
|
+
}
|
|
228
|
+
console.log('');
|
|
229
|
+
(0, output_utils_1.printSection)('✓ Pipeline Created Successfully');
|
|
230
|
+
// Display created pipeline info
|
|
231
|
+
(0, output_utils_1.printKeyValue)({
|
|
232
|
+
'Pipeline ID': green(bold(pipeline.id)),
|
|
233
|
+
'Project': pipeline.project,
|
|
234
|
+
'Organization': pipeline.organization,
|
|
235
|
+
'Name': pipeline.pipelineName || '(not set)',
|
|
236
|
+
'Access': pipeline.accessModifier || 'private',
|
|
237
|
+
'Default': pipeline.isDefault ? 'Yes' : 'No',
|
|
238
|
+
'Active': pipeline.isActive ? 'Yes' : 'No',
|
|
239
|
+
'Properties': pipeline.props ? `${Object.keys(pipeline.props).length} keys` : '(not returned)',
|
|
240
|
+
});
|
|
241
|
+
if (pipeline.createdAt) {
|
|
242
|
+
console.log('');
|
|
243
|
+
(0, output_utils_1.printKeyValue)({
|
|
244
|
+
'Created At': pipeline.createdAt,
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
// Performance metrics
|
|
248
|
+
console.log('');
|
|
249
|
+
(0, output_utils_1.printKeyValue)({
|
|
250
|
+
'Execution ID': executionId,
|
|
251
|
+
'Request Duration': (0, cli_constants_1.formatDuration)(requestDuration),
|
|
252
|
+
'Total Duration': (0, cli_constants_1.formatDuration)(Date.now() - startTime),
|
|
253
|
+
});
|
|
254
|
+
// Save pipeline info to file
|
|
255
|
+
const outputDir = './output';
|
|
256
|
+
(0, output_utils_1.ensureOutputDirectory)(outputDir);
|
|
257
|
+
const outputFile = path.join(outputDir, `pipeline-${pipeline.id}.json`);
|
|
258
|
+
fs.writeFileSync(outputFile, JSON.stringify(pipeline, null, 2));
|
|
259
|
+
console.log('');
|
|
260
|
+
(0, output_utils_1.printSuccess)('Pipeline details saved to file');
|
|
261
|
+
(0, output_utils_1.printKeyValue)({
|
|
262
|
+
'Output File': outputFile,
|
|
263
|
+
'File Size': (0, cli_constants_1.formatFileSize)(fs.statSync(outputFile).size),
|
|
264
|
+
});
|
|
265
|
+
// Next steps
|
|
266
|
+
console.log('');
|
|
267
|
+
(0, output_utils_1.printSection)('Next Steps');
|
|
268
|
+
console.log(dim('You can now:'));
|
|
269
|
+
console.log(` ${cyan('•')} Deploy: ${bold(`deploy --id ${pipeline.id}`)}`);
|
|
270
|
+
console.log(` ${cyan('•')} View: ${bold(`get-pipeline --id ${pipeline.id}`)}`);
|
|
271
|
+
console.log(` ${cyan('•')} API: ${config.api.baseUrl}${config.api.pipelineUrl}/${pipeline.id}`);
|
|
272
|
+
console.log('');
|
|
273
|
+
}
|
|
274
|
+
catch (error) {
|
|
275
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.API_REQUEST, {
|
|
276
|
+
debug: program.opts().debug,
|
|
277
|
+
exit: true,
|
|
278
|
+
context: {
|
|
279
|
+
command: 'create-pipeline',
|
|
280
|
+
executionId,
|
|
281
|
+
project: options.project,
|
|
282
|
+
organization: options.organization,
|
|
283
|
+
file: options.file,
|
|
284
|
+
verifySsl: options.verifySsl,
|
|
285
|
+
dryRun: options.dryRun,
|
|
286
|
+
},
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
});
|
|
290
|
+
}
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-pipeline.js","sourceRoot":"","sources":["../../src/commands/create-pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { Command } from 'commander';\nimport ora from 'ora';\nimport pico from 'picocolors';\nimport { formatDuration, formatFileSize, FILE_SIZE_LIMITS } from '../config/cli.constants';\nimport { Pipeline, PipelineResponse, CreatePipelineRequest } from '../types';\nimport { printCommandHeader, printSslWarning, createAuthenticatedClient } from '../utils/command-utils';\nimport { ERROR_CODES, handleError } from '../utils/error-handler';\nimport { ensureOutputDirectory, extractSingleResponse, printError, printInfo, printKeyValue, printSection, printSuccess, printWarning } from '../utils/output-utils';\n\nconst { bold, cyan, dim, green } = pico;\n\n/**\n * Registers the `create-pipeline` command with the CLI program.\n *\n * Accepts a pipeline properties JSON file, validates it, resolves\n * project/organization from CLI flags or the props file, and\n * creates the pipeline via the platform API.\n *\n * @param program - The root Commander program instance to attach the command to.\n */\nexport function createPipeline(program: Command): void {\n  program\n    .command('create-pipeline')\n    .description('Create a new pipeline with the provided configuration')\n    .requiredOption('-f, --file <file>', 'Path to pipeline properties JSON file')\n    .option('-p, --project <project>', 'Project name (falls back to value in props file)')\n    .option('-o, --organization <organization>', 'Organization name (falls back to value in props file)')\n    .option('-n, --name <name>', 'Pipeline name')\n    .option('-a, --access <modifier>', 'Access modifier (public|private)', 'private')\n    .option('--default', 'Set as default pipeline', false)\n    .option('--active', 'Set pipeline as active', true)\n    .option('--verify-ssl', 'Enable SSL certificate verification')\n    .option('--no-verify-ssl', 'Disable SSL certificate verification')\n    .option('--dry-run', 'Validate inputs without creating pipeline', false)\n    .action(async (options) => {\n      const executionId = printCommandHeader('Create Pipeline', 'Creating Pipeline');\n      const startTime = Date.now();\n\n      try {\n\n        // Display parameters\n        printInfo('Configuration');\n        printKeyValue({\n          'Project': options.project || '(from props file)',\n          'Organization': options.organization || '(from props file)',\n          'Name': options.name || '(not set)',\n          'Access Modifier': options.access,\n          'Default Pipeline': options.default ? 'Yes' : 'No',\n          'Active': options.active ? 'Yes' : 'No',\n          'Properties File': options.file,\n          'SSL Verification': options.verifySsl === false ? 'Disabled' : 'Enabled',\n          'Dry Run': options.dryRun ? 'Yes' : 'No',\n        });\n\n        // Security warning for SSL verification disabled\n        printSslWarning(options.verifySsl);\n\n        console.log('');\n        printSection('File Validation');\n\n        // Validate file exists\n        if (!fs.existsSync(options.file)) {\n          printError('Properties file not found', { path: options.file });\n          throw new Error(`File not found: ${options.file}`);\n        }\n\n        // Check file extension\n        const fileExt = path.extname(options.file).toLowerCase();\n        if (fileExt !== '.json') {\n          printWarning('File extension is not .json', { extension: fileExt });\n        }\n\n        const fileStats = fs.statSync(options.file);\n\n        // Check file size\n        if (fileStats.size > FILE_SIZE_LIMITS.PIPELINE_PROPS) {\n          printError('Properties file is too large', {\n            size: formatFileSize(fileStats.size),\n            limit: formatFileSize(FILE_SIZE_LIMITS.PIPELINE_PROPS),\n          });\n          throw new Error('Properties file exceeds size limit');\n        }\n\n        printSuccess('File validation passed');\n        printKeyValue({\n          'File Path': options.file,\n          'File Size': formatFileSize(fileStats.size),\n          'Extension': fileExt,\n        });\n\n        // Read and parse properties file\n        console.log('');\n        printInfo('Reading pipeline properties...');\n\n        const fileContent = fs.readFileSync(options.file, 'utf-8');\n\n        let props: Record<string, unknown>;\n        try {\n          props = JSON.parse(fileContent);\n        } catch (error) {\n          printError('Invalid JSON in properties file', {\n            error: error instanceof Error ? error.message : String(error),\n            hint: 'Ensure the file contains valid JSON syntax',\n          });\n          throw new Error('Properties file must contain valid JSON');\n        }\n\n        // Validate properties structure\n        if (typeof props !== 'object' || props === null) {\n          printError('Invalid properties format', {\n            type: typeof props,\n            hint: 'Properties must be a JSON object',\n          });\n          throw new Error('Properties must be a valid object');\n        }\n\n        const propCount = Object.keys(props).length;\n\n        printSuccess('Properties parsed successfully');\n        printKeyValue({\n          'Total Keys': propCount.toString(),\n          'Sample Keys': Object.keys(props).slice(0, 5).join(', ') + (propCount > 5 ? '...' : ''),\n        });\n\n        // Validate properties content\n        if (propCount === 0) {\n          printWarning('Properties object is empty - pipeline will have no configuration');\n        }\n\n        // Resolve project & organization: prefer CLI flags, fall back to\n        // values embedded inside the props file (builderProps).\n        const resolvedProject = options.project ?? (props.project as string | undefined);\n        const resolvedOrganization = options.organization ?? (props.organization as string | undefined);\n\n        if (!resolvedProject) {\n          printError('Project is required', {\n            hint: 'Provide -p/--project flag or include \"project\" in the props file',\n          });\n          throw new Error('Project is required');\n        }\n        if (!resolvedOrganization) {\n          printError('Organization is required', {\n            hint: 'Provide -o/--organization flag or include \"organization\" in the props file',\n          });\n          throw new Error('Organization is required');\n        }\n\n        // Build request payload — resolve pipelineName using same strategy as pipeline-builder.ts:\n        //   props.pipelineName ?? `${organization}-${project}-pipeline`\n        const sanitize = (s: string) => s.replace(/[^a-zA-Z0-9]/g, '_').toLowerCase();\n        const resolvedPipelineName = options.name\n          ?? (props.pipelineName as string | undefined)\n          ?? `${sanitize(resolvedOrganization)}-${sanitize(resolvedProject)}-pipeline`;\n\n        const payload: CreatePipelineRequest = {\n          project: resolvedProject,\n          organization: resolvedOrganization,\n          pipelineName: resolvedPipelineName,\n          props,\n        };\n\n        // Add optional fields only if provided\n        if (options.access) {\n          payload.accessModifier = options.access;\n        }\n        if (options.default !== undefined) {\n          payload.isDefault = options.default;\n        }\n        if (options.active !== undefined) {\n          payload.isActive = options.active;\n        }\n\n        // Dry run mode\n        if (options.dryRun) {\n          console.log('');\n          printSection('Dry Run - Request Preview');\n          console.log(JSON.stringify(payload, null, 2));\n          console.log('');\n          printSuccess('✓ Validation complete - no pipeline created (dry run mode)');\n          console.log('');\n          printInfo('To create the pipeline, run the command without --dry-run');\n          return;\n        }\n\n        // Create authenticated API client\n        const client = createAuthenticatedClient(options);\n        const config = client.getConfig();\n\n        // Create pipeline\n        console.log('');\n        printSection('Creating Pipeline');\n\n        const spinner = ora('Creating pipeline...').start();\n        let rawResponse: PipelineResponse;\n        let requestDuration: number;\n        try {\n          const requestStart = Date.now();\n          rawResponse = await client.post<PipelineResponse>(\n            config.api.pipelineUrl,\n            payload,\n          );\n          requestDuration = Date.now() - requestStart;\n          spinner.succeed('Pipeline created');\n        } catch (error) {\n          spinner.fail('Pipeline creation failed');\n          throw error;\n        }\n\n        const pipeline = extractSingleResponse<Pipeline>(rawResponse, 'pipeline', 'id');\n\n        if (!pipeline?.id) {\n          printError('Invalid pipeline response', {\n            responseKeys: rawResponse ? Object.keys(rawResponse) : '(null)',\n          });\n          throw new Error('Pipeline creation failed - no valid pipeline data received');\n        }\n\n        console.log('');\n        printSection('✓ Pipeline Created Successfully');\n\n        // Display created pipeline info\n        printKeyValue({\n          'Pipeline ID': green(bold(pipeline.id)),\n          'Project': pipeline.project,\n          'Organization': pipeline.organization,\n          'Name': pipeline.pipelineName || '(not set)',\n          'Access': pipeline.accessModifier || 'private',\n          'Default': pipeline.isDefault ? 'Yes' : 'No',\n          'Active': pipeline.isActive ? 'Yes' : 'No',\n          'Properties': pipeline.props ? `${Object.keys(pipeline.props).length} keys` : '(not returned)',\n        });\n\n        if (pipeline.createdAt) {\n          console.log('');\n          printKeyValue({\n            'Created At': pipeline.createdAt,\n          });\n        }\n\n        // Performance metrics\n        console.log('');\n        printKeyValue({\n          'Execution ID': executionId,\n          'Request Duration': formatDuration(requestDuration),\n          'Total Duration': formatDuration(Date.now() - startTime),\n        });\n\n        // Save pipeline info to file\n        const outputDir = './output';\n        ensureOutputDirectory(outputDir);\n\n        const outputFile = path.join(outputDir, `pipeline-${pipeline.id}.json`);\n        fs.writeFileSync(outputFile, JSON.stringify(pipeline, null, 2));\n\n        console.log('');\n        printSuccess('Pipeline details saved to file');\n        printKeyValue({\n          'Output File': outputFile,\n          'File Size': formatFileSize(fs.statSync(outputFile).size),\n        });\n\n        // Next steps\n        console.log('');\n        printSection('Next Steps');\n        console.log(dim('You can now:'));\n        console.log(`  ${cyan('•')} Deploy: ${bold(`deploy --id ${pipeline.id}`)}`);\n        console.log(`  ${cyan('•')} View: ${bold(`get-pipeline --id ${pipeline.id}`)}`);\n        console.log(`  ${cyan('•')} API: ${config.api.baseUrl}${config.api.pipelineUrl}/${pipeline.id}`);\n        console.log('');\n\n      } catch (error) {\n        handleError(error, ERROR_CODES.API_REQUEST, {\n          debug: program.opts().debug,\n          exit: true,\n          context: {\n            command: 'create-pipeline',\n            executionId,\n            project: options.project,\n            organization: options.organization,\n            file: options.file,\n            verifySsl: options.verifySsl,\n            dryRun: options.dryRun,\n          },\n        });\n      }\n    });\n}"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
/**
|
|
3
|
+
* Registers the `deploy` command with the CLI program.
|
|
4
|
+
*
|
|
5
|
+
* Fetches pipeline properties by ID from the platform API, then
|
|
6
|
+
* runs `cdk deploy` to provision the pipeline infrastructure in AWS.
|
|
7
|
+
* For synthesis only, use `pipeline-manager synth`.
|
|
8
|
+
*
|
|
9
|
+
* Requires service credentials to be pre-stored in AWS Secrets Manager.
|
|
10
|
+
* Create them first with: `pipeline-manager store-token`
|
|
11
|
+
*
|
|
12
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
13
|
+
*/
|
|
14
|
+
export declare function deploy(program: Command): void;
|
|
15
|
+
//# sourceMappingURL=deploy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deploy.d.ts","sourceRoot":"","sources":["../../src/commands/deploy.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAYpC;;;;;;;;;;;GAWG;AACH,wBAAgB,MAAM,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAiK7C"}
|