@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
package/dist/cli.d.ts
ADDED
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* CLI initialization options
|
|
4
|
+
*/
|
|
5
|
+
interface CliOptions {
|
|
6
|
+
/**
|
|
7
|
+
* Show banner on startup
|
|
8
|
+
* @default true
|
|
9
|
+
*/
|
|
10
|
+
showBanner?: boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Minimal banner (no ASCII art)
|
|
13
|
+
* @default false
|
|
14
|
+
*/
|
|
15
|
+
minimalBanner?: boolean;
|
|
16
|
+
/**
|
|
17
|
+
* Debug mode
|
|
18
|
+
* @default false
|
|
19
|
+
*/
|
|
20
|
+
debug?: boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Verbose output
|
|
23
|
+
* @default false
|
|
24
|
+
*/
|
|
25
|
+
verbose?: boolean;
|
|
26
|
+
/**
|
|
27
|
+
* Quiet mode (minimal output)
|
|
28
|
+
* @default false
|
|
29
|
+
*/
|
|
30
|
+
quiet?: boolean;
|
|
31
|
+
/**
|
|
32
|
+
* No color output
|
|
33
|
+
* @default false
|
|
34
|
+
*/
|
|
35
|
+
noColor?: boolean;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Initialize CLI with options
|
|
39
|
+
*
|
|
40
|
+
* @param options - CLI initialization options
|
|
41
|
+
*/
|
|
42
|
+
export declare function initializeCli(options?: CliOptions): void;
|
|
43
|
+
/**
|
|
44
|
+
* Main CLI entry point
|
|
45
|
+
*
|
|
46
|
+
* @param options - CLI initialization options
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* ```typescript
|
|
50
|
+
* // Standard initialization
|
|
51
|
+
* main();
|
|
52
|
+
*
|
|
53
|
+
* // Minimal mode
|
|
54
|
+
* main({ minimalBanner: true, quiet: true });
|
|
55
|
+
*
|
|
56
|
+
* // Debug mode
|
|
57
|
+
* main({ debug: true, verbose: true });
|
|
58
|
+
* ```
|
|
59
|
+
*/
|
|
60
|
+
export declare function main(options?: CliOptions): void;
|
|
61
|
+
export {};
|
|
62
|
+
//# sourceMappingURL=cli.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AA+BA;;GAEG;AACH,UAAU,UAAU;IAClB;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;IAErB;;;OAGG;IACH,aAAa,CAAC,EAAE,OAAO,CAAC;IAExB;;;OAGG;IACH,KAAK,CAAC,EAAE,OAAO,CAAC;IAEhB;;;OAGG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;IAElB;;;OAGG;IACH,KAAK,CAAC,EAAE,OAAO,CAAC;IAEhB;;;OAGG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AA4ND;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,OAAO,GAAE,UAAe,GAAG,IAAI,CAyD5D;AAiDD;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,IAAI,CAAC,OAAO,GAAE,UAAe,GAAG,IAAI,CA0BnD"}
|
package/dist/cli.js
ADDED
|
@@ -0,0 +1,372 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
// Copyright 2026 Pipeline Builder Contributors
|
|
4
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.initializeCli = initializeCli;
|
|
7
|
+
exports.main = main;
|
|
8
|
+
const commander_1 = require("commander");
|
|
9
|
+
const bootstrap_1 = require("./commands/bootstrap");
|
|
10
|
+
const create_pipeline_1 = require("./commands/create-pipeline");
|
|
11
|
+
const deploy_1 = require("./commands/deploy");
|
|
12
|
+
const get_pipeline_1 = require("./commands/get-pipeline");
|
|
13
|
+
const get_plugin_1 = require("./commands/get-plugin");
|
|
14
|
+
const list_pipelines_1 = require("./commands/list-pipelines");
|
|
15
|
+
const list_plugins_1 = require("./commands/list-plugins");
|
|
16
|
+
const login_1 = require("./commands/login");
|
|
17
|
+
const setup_events_1 = require("./commands/setup-events");
|
|
18
|
+
const status_1 = require("./commands/status");
|
|
19
|
+
const store_token_1 = require("./commands/store-token");
|
|
20
|
+
const synth_1 = require("./commands/synth");
|
|
21
|
+
const upload_plugin_1 = require("./commands/upload-plugin");
|
|
22
|
+
const version_1 = require("./commands/version");
|
|
23
|
+
const cli_constants_1 = require("./config/cli.constants");
|
|
24
|
+
const banner_1 = require("./utils/banner");
|
|
25
|
+
const error_handler_1 = require("./utils/error-handler");
|
|
26
|
+
const output_utils_1 = require("./utils/output-utils");
|
|
27
|
+
/**
|
|
28
|
+
* Check environment and display warnings
|
|
29
|
+
*/
|
|
30
|
+
function checkEnvironment() {
|
|
31
|
+
const warnings = [];
|
|
32
|
+
// Check for required environment variables
|
|
33
|
+
if (!process.env[cli_constants_1.ENV_VARS.PLATFORM_TOKEN]) {
|
|
34
|
+
warnings.push('PLATFORM_TOKEN environment variable is not set');
|
|
35
|
+
warnings.push('Authentication will fail for API operations');
|
|
36
|
+
}
|
|
37
|
+
// Check Node version
|
|
38
|
+
const nodeVersion = process.version;
|
|
39
|
+
const majorVersion = parseInt(nodeVersion.slice(1).split('.')[0] || '0', 10);
|
|
40
|
+
if (majorVersion < 18) {
|
|
41
|
+
warnings.push(`Node.js ${nodeVersion} detected - version 18+ recommended`);
|
|
42
|
+
}
|
|
43
|
+
// Display warnings
|
|
44
|
+
if (warnings.length > 0) {
|
|
45
|
+
(0, output_utils_1.printSection)('Environment Warnings');
|
|
46
|
+
warnings.forEach(warning => {
|
|
47
|
+
(0, output_utils_1.printWarning)(warning);
|
|
48
|
+
});
|
|
49
|
+
console.log('');
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Display startup information
|
|
54
|
+
*/
|
|
55
|
+
function displayStartupInfo(options) {
|
|
56
|
+
if (options.quiet)
|
|
57
|
+
return;
|
|
58
|
+
const executionId = (0, cli_constants_1.generateExecutionId)();
|
|
59
|
+
if (options.debug || options.verbose) {
|
|
60
|
+
(0, output_utils_1.printDebug)('CLI Configuration', {
|
|
61
|
+
name: cli_constants_1.APP_NAME,
|
|
62
|
+
version: cli_constants_1.APP_VERSION,
|
|
63
|
+
executionId,
|
|
64
|
+
node: process.version,
|
|
65
|
+
platform: process.platform,
|
|
66
|
+
arch: process.arch,
|
|
67
|
+
cwd: process.cwd(),
|
|
68
|
+
env: {
|
|
69
|
+
debug: process.env.DEBUG,
|
|
70
|
+
token: process.env[cli_constants_1.ENV_VARS.PLATFORM_TOKEN] ? 'set' : 'not set',
|
|
71
|
+
url: process.env[cli_constants_1.ENV_VARS.PLATFORM_BASE_URL] || 'default',
|
|
72
|
+
},
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
(0, output_utils_1.printDebug)('Starting CLI', {
|
|
77
|
+
version: cli_constants_1.APP_VERSION,
|
|
78
|
+
executionId,
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Register all CLI commands
|
|
84
|
+
*/
|
|
85
|
+
function registerCommands() {
|
|
86
|
+
(0, output_utils_1.printDebug)('Registering commands');
|
|
87
|
+
// Configure program
|
|
88
|
+
commander_1.program
|
|
89
|
+
.name(cli_constants_1.APP_NAME)
|
|
90
|
+
.description(cli_constants_1.APP_DESCRIPTION)
|
|
91
|
+
.version(cli_constants_1.APP_VERSION, '-v, --version', 'Show CLI version')
|
|
92
|
+
.option('--debug', 'Enable debug output with stack traces', false)
|
|
93
|
+
.option('--verbose', 'Show detailed information', false)
|
|
94
|
+
.option('--quiet', 'Minimal output (errors only)', false)
|
|
95
|
+
.option('--no-color', 'Disable colored output', false)
|
|
96
|
+
.addHelpText('after', `
|
|
97
|
+
Environment Variables:
|
|
98
|
+
${cli_constants_1.ENV_VARS.PLATFORM_TOKEN} Authentication token (required)
|
|
99
|
+
${cli_constants_1.ENV_VARS.PLATFORM_BASE_URL} API base URL (optional)
|
|
100
|
+
${cli_constants_1.ENV_VARS.CLI_CONFIG_PATH} Config file path (optional)
|
|
101
|
+
${cli_constants_1.ENV_VARS.TLS_REJECT_UNAUTHORIZED} Disable SSL verification if '0'
|
|
102
|
+
${cli_constants_1.ENV_VARS.DEBUG} Enable debug mode if 'true'
|
|
103
|
+
|
|
104
|
+
Examples:
|
|
105
|
+
$ ${cli_constants_1.APP_NAME} version
|
|
106
|
+
$ ${cli_constants_1.APP_NAME} list-pipelines --project my-app
|
|
107
|
+
$ ${cli_constants_1.APP_NAME} get-pipeline --id pipe-123 --format json
|
|
108
|
+
$ ${cli_constants_1.APP_NAME} store-token --days 30 --region us-east-1
|
|
109
|
+
$ ${cli_constants_1.APP_NAME} bootstrap --account 123456789012 --region us-east-1
|
|
110
|
+
$ ${cli_constants_1.APP_NAME} deploy --id pipe-123 --profile production
|
|
111
|
+
|
|
112
|
+
`);
|
|
113
|
+
// Version command (special handling)
|
|
114
|
+
(0, version_1.version)(commander_1.program);
|
|
115
|
+
// Authentication commands
|
|
116
|
+
(0, output_utils_1.printDebug)('Registering authentication commands');
|
|
117
|
+
(0, login_1.login)(commander_1.program); // Login and obtain PLATFORM_TOKEN (also supports --refresh)
|
|
118
|
+
// Query commands
|
|
119
|
+
(0, output_utils_1.printDebug)('Registering query commands');
|
|
120
|
+
(0, get_plugin_1.getPlugin)(commander_1.program); // Single plugin by ID
|
|
121
|
+
(0, list_plugins_1.listPlugins)(commander_1.program); // Multiple plugins with filters
|
|
122
|
+
(0, get_pipeline_1.getPipeline)(commander_1.program); // Single pipeline by ID
|
|
123
|
+
(0, list_pipelines_1.listPipelines)(commander_1.program); // Multiple pipelines with filters
|
|
124
|
+
// Create/Upload commands
|
|
125
|
+
(0, output_utils_1.printDebug)('Registering create/upload commands');
|
|
126
|
+
(0, create_pipeline_1.createPipeline)(commander_1.program); // Create pipeline configuration
|
|
127
|
+
(0, upload_plugin_1.uploadPlugin)(commander_1.program); // Upload and deploy plugin
|
|
128
|
+
// Status command
|
|
129
|
+
(0, output_utils_1.printDebug)('Registering status command');
|
|
130
|
+
(0, status_1.status)(commander_1.program); // Show environment and connectivity status
|
|
131
|
+
// Deployment commands
|
|
132
|
+
(0, output_utils_1.printDebug)('Registering deployment commands');
|
|
133
|
+
(0, store_token_1.storeToken)(commander_1.program); // Generate JWT token and store in Secrets Manager
|
|
134
|
+
(0, setup_events_1.setupEvents)(commander_1.program); // Deploy EventBridge event ingestion infrastructure
|
|
135
|
+
(0, bootstrap_1.bootstrap)(commander_1.program); // Bootstrap CDK toolkit stack
|
|
136
|
+
(0, deploy_1.deploy)(commander_1.program); // Deploy pipeline with CDK (--app prints boilerplate path)
|
|
137
|
+
(0, synth_1.synth)(commander_1.program); // Run CDK synthesis
|
|
138
|
+
// Shell completions
|
|
139
|
+
(0, output_utils_1.printDebug)('Registering completions command');
|
|
140
|
+
commander_1.program
|
|
141
|
+
.command('completions')
|
|
142
|
+
.description('Generate shell completions (bash, zsh, fish)')
|
|
143
|
+
.argument('<shell>', 'Shell type: bash, zsh, or fish')
|
|
144
|
+
.action((shell) => {
|
|
145
|
+
switch (shell) {
|
|
146
|
+
case 'bash':
|
|
147
|
+
console.log(`# pipeline-manager bash completions
|
|
148
|
+
_pipeline_manager_completions() {
|
|
149
|
+
local cur="\${COMP_WORDS[COMP_CWORD]}"
|
|
150
|
+
local commands="login deploy synth upload-plugin create-pipeline status version bootstrap setup-events store-token completions"
|
|
151
|
+
COMPREPLY=($(compgen -W "\${commands}" -- "\${cur}"))
|
|
152
|
+
}
|
|
153
|
+
complete -F _pipeline_manager_completions pipeline-manager`);
|
|
154
|
+
break;
|
|
155
|
+
case 'zsh':
|
|
156
|
+
console.log(`# pipeline-manager zsh completions
|
|
157
|
+
_pipeline_manager() {
|
|
158
|
+
local commands=(login deploy synth upload-plugin create-pipeline status version bootstrap setup-events store-token completions)
|
|
159
|
+
_describe 'command' commands
|
|
160
|
+
}
|
|
161
|
+
compdef _pipeline_manager pipeline-manager`);
|
|
162
|
+
break;
|
|
163
|
+
case 'fish':
|
|
164
|
+
console.log(`# pipeline-manager fish completions
|
|
165
|
+
complete -c pipeline-manager -n '__fish_use_subcommand' -a 'login deploy synth upload-plugin create-pipeline status version bootstrap setup-events store-token completions'`);
|
|
166
|
+
break;
|
|
167
|
+
default:
|
|
168
|
+
console.error(`Unknown shell: ${shell}. Use bash, zsh, or fish.`);
|
|
169
|
+
process.exit(1);
|
|
170
|
+
}
|
|
171
|
+
});
|
|
172
|
+
(0, output_utils_1.printDebug)('All commands registered successfully');
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Handle program errors
|
|
176
|
+
*/
|
|
177
|
+
function setupErrorHandlers() {
|
|
178
|
+
// Handle uncaught exceptions
|
|
179
|
+
process.on('uncaughtException', (error) => {
|
|
180
|
+
console.error(''); // Empty line
|
|
181
|
+
(0, output_utils_1.printError)('Uncaught exception', {
|
|
182
|
+
error: error.message,
|
|
183
|
+
name: error.name,
|
|
184
|
+
});
|
|
185
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.GENERAL, {
|
|
186
|
+
debug: (0, cli_constants_1.isDebugMode)(commander_1.program.opts()),
|
|
187
|
+
exit: true,
|
|
188
|
+
context: {
|
|
189
|
+
type: 'uncaughtException',
|
|
190
|
+
},
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
// Handle unhandled promise rejections
|
|
194
|
+
process.on('unhandledRejection', (reason) => {
|
|
195
|
+
console.error(''); // Empty line
|
|
196
|
+
(0, output_utils_1.printError)('Unhandled promise rejection', {
|
|
197
|
+
reason: reason instanceof Error ? reason.message : String(reason),
|
|
198
|
+
});
|
|
199
|
+
const error = reason instanceof Error ? reason : new Error(String(reason));
|
|
200
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.GENERAL, {
|
|
201
|
+
debug: (0, cli_constants_1.isDebugMode)(commander_1.program.opts()),
|
|
202
|
+
exit: true,
|
|
203
|
+
context: {
|
|
204
|
+
type: 'unhandledRejection',
|
|
205
|
+
},
|
|
206
|
+
});
|
|
207
|
+
});
|
|
208
|
+
// Handle SIGINT (Ctrl+C)
|
|
209
|
+
process.on('SIGINT', () => {
|
|
210
|
+
console.log(''); // Empty line
|
|
211
|
+
(0, output_utils_1.printWarning)('Process interrupted by user (SIGINT)');
|
|
212
|
+
console.log(''); // Empty line
|
|
213
|
+
process.exit(130); // Standard exit code for SIGINT
|
|
214
|
+
});
|
|
215
|
+
// Handle SIGTERM
|
|
216
|
+
process.on('SIGTERM', () => {
|
|
217
|
+
console.log(''); // Empty line
|
|
218
|
+
(0, output_utils_1.printWarning)('Process terminated (SIGTERM)');
|
|
219
|
+
console.log(''); // Empty line
|
|
220
|
+
process.exit(143); // Standard exit code for SIGTERM
|
|
221
|
+
});
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Initialize CLI with options
|
|
225
|
+
*
|
|
226
|
+
* @param options - CLI initialization options
|
|
227
|
+
*/
|
|
228
|
+
function initializeCli(options = {}) {
|
|
229
|
+
const { showBanner = true, minimalBanner = false, debug = false, verbose = false, quiet = false, noColor = false, } = options;
|
|
230
|
+
// Handle color output
|
|
231
|
+
if (noColor) {
|
|
232
|
+
process.env.NO_COLOR = '1';
|
|
233
|
+
}
|
|
234
|
+
// Display banner
|
|
235
|
+
if (showBanner && !quiet) {
|
|
236
|
+
if (minimalBanner) {
|
|
237
|
+
(0, banner_1.miniBanner)();
|
|
238
|
+
}
|
|
239
|
+
else {
|
|
240
|
+
(0, banner_1.banner)({
|
|
241
|
+
minimal: false,
|
|
242
|
+
showDescription: true,
|
|
243
|
+
showTimestamp: debug || verbose,
|
|
244
|
+
showExecutionId: debug,
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
// Display startup info
|
|
249
|
+
displayStartupInfo({ debug, verbose, quiet });
|
|
250
|
+
// Check environment
|
|
251
|
+
if (!quiet) {
|
|
252
|
+
checkEnvironment();
|
|
253
|
+
}
|
|
254
|
+
// Setup error handlers
|
|
255
|
+
setupErrorHandlers();
|
|
256
|
+
// Register commands
|
|
257
|
+
try {
|
|
258
|
+
registerCommands();
|
|
259
|
+
(0, output_utils_1.printDebug)('CLI initialization complete');
|
|
260
|
+
}
|
|
261
|
+
catch (error) {
|
|
262
|
+
(0, output_utils_1.printError)('CLI initialization failed', {
|
|
263
|
+
error: error instanceof Error ? error.message : String(error),
|
|
264
|
+
});
|
|
265
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.CONFIGURATION, {
|
|
266
|
+
debug: debug || (0, cli_constants_1.isDebugMode)(),
|
|
267
|
+
exit: true,
|
|
268
|
+
context: {
|
|
269
|
+
stage: 'initialization',
|
|
270
|
+
},
|
|
271
|
+
});
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
/**
|
|
275
|
+
* Parse command line arguments
|
|
276
|
+
*/
|
|
277
|
+
function parseArguments() {
|
|
278
|
+
try {
|
|
279
|
+
commander_1.program.parse(process.argv);
|
|
280
|
+
// Show help if no command provided
|
|
281
|
+
const args = process.argv.slice(2);
|
|
282
|
+
if (args.length === 0) {
|
|
283
|
+
(0, output_utils_1.printInfo)('No command specified - displaying help');
|
|
284
|
+
console.log(''); // Empty line
|
|
285
|
+
commander_1.program.outputHelp();
|
|
286
|
+
process.exit(0);
|
|
287
|
+
}
|
|
288
|
+
// Check if command exists
|
|
289
|
+
const command = args[0];
|
|
290
|
+
if (command && !command.startsWith('-')) {
|
|
291
|
+
const commandExists = commander_1.program.commands.some(cmd => cmd.name() === command);
|
|
292
|
+
if (!commandExists) {
|
|
293
|
+
console.log(''); // Empty line
|
|
294
|
+
(0, output_utils_1.printError)(`Unknown command: ${command}`);
|
|
295
|
+
console.log(''); // Empty line
|
|
296
|
+
(0, output_utils_1.printInfo)('Available commands:');
|
|
297
|
+
commander_1.program.commands.forEach(cmd => {
|
|
298
|
+
console.log(` • ${cmd.name()} - ${cmd.description()}`);
|
|
299
|
+
});
|
|
300
|
+
console.log(''); // Empty line
|
|
301
|
+
process.exit(1);
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
(0, output_utils_1.printDebug)('Command line arguments parsed successfully');
|
|
305
|
+
}
|
|
306
|
+
catch (error) {
|
|
307
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.GENERAL, {
|
|
308
|
+
debug: (0, cli_constants_1.isDebugMode)(commander_1.program.opts()),
|
|
309
|
+
exit: true,
|
|
310
|
+
context: {
|
|
311
|
+
stage: 'argument-parsing',
|
|
312
|
+
argv: process.argv,
|
|
313
|
+
},
|
|
314
|
+
});
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
/**
|
|
318
|
+
* Main CLI entry point
|
|
319
|
+
*
|
|
320
|
+
* @param options - CLI initialization options
|
|
321
|
+
*
|
|
322
|
+
* @example
|
|
323
|
+
* ```typescript
|
|
324
|
+
* // Standard initialization
|
|
325
|
+
* main();
|
|
326
|
+
*
|
|
327
|
+
* // Minimal mode
|
|
328
|
+
* main({ minimalBanner: true, quiet: true });
|
|
329
|
+
*
|
|
330
|
+
* // Debug mode
|
|
331
|
+
* main({ debug: true, verbose: true });
|
|
332
|
+
* ```
|
|
333
|
+
*/
|
|
334
|
+
function main(options = {}) {
|
|
335
|
+
try {
|
|
336
|
+
// Initialize CLI
|
|
337
|
+
initializeCli(options);
|
|
338
|
+
// Parse arguments and execute command
|
|
339
|
+
parseArguments();
|
|
340
|
+
// If we reach here, command completed successfully
|
|
341
|
+
(0, output_utils_1.printDebug)('CLI execution completed successfully');
|
|
342
|
+
}
|
|
343
|
+
catch (error) {
|
|
344
|
+
// Final catch-all error handler
|
|
345
|
+
console.error(''); // Empty line
|
|
346
|
+
(0, output_utils_1.printError)('Fatal CLI error', {
|
|
347
|
+
error: error instanceof Error ? error.message : String(error),
|
|
348
|
+
});
|
|
349
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.GENERAL, {
|
|
350
|
+
debug: (0, cli_constants_1.isDebugMode)(options),
|
|
351
|
+
exit: true,
|
|
352
|
+
context: {
|
|
353
|
+
stage: 'main',
|
|
354
|
+
options,
|
|
355
|
+
},
|
|
356
|
+
});
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
/**
|
|
360
|
+
* Run CLI if executed directly
|
|
361
|
+
*/
|
|
362
|
+
if (require.main === module) {
|
|
363
|
+
// Parse CLI options from environment or command line
|
|
364
|
+
const options = {
|
|
365
|
+
debug: process.env.DEBUG === 'true',
|
|
366
|
+
quiet: process.argv.includes('--quiet'),
|
|
367
|
+
verbose: process.argv.includes('--verbose'),
|
|
368
|
+
noColor: process.argv.includes('--no-color') || process.env.NO_COLOR === '1',
|
|
369
|
+
};
|
|
370
|
+
main(options);
|
|
371
|
+
}
|
|
372
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { program } from 'commander';\nimport { bootstrap } from './commands/bootstrap';\nimport { createPipeline } from './commands/create-pipeline';\nimport { deploy } from './commands/deploy';\nimport { getPipeline } from './commands/get-pipeline';\nimport { getPlugin } from './commands/get-plugin';\nimport { listPipelines } from './commands/list-pipelines';\nimport { listPlugins } from './commands/list-plugins';\nimport { login } from './commands/login';\nimport { setupEvents } from './commands/setup-events';\nimport { status } from './commands/status';\nimport { storeToken } from './commands/store-token';\nimport { synth } from './commands/synth';\nimport { uploadPlugin } from './commands/upload-plugin';\nimport { version } from './commands/version';\nimport {\n  APP_NAME,\n  APP_DESCRIPTION,\n  APP_VERSION,\n  ENV_VARS,\n  isDebugMode,\n  generateExecutionId,\n} from './config/cli.constants';\nimport { banner, miniBanner } from './utils/banner';\nimport { ERROR_CODES, handleError } from './utils/error-handler';\nimport { printInfo, printError, printWarning, printDebug, printSection } from './utils/output-utils';\n\n/**\n * CLI initialization options\n */\ninterface CliOptions {\n  /**\n   * Show banner on startup\n   * @default true\n   */\n  showBanner?: boolean;\n\n  /**\n   * Minimal banner (no ASCII art)\n   * @default false\n   */\n  minimalBanner?: boolean;\n\n  /**\n   * Debug mode\n   * @default false\n   */\n  debug?: boolean;\n\n  /**\n   * Verbose output\n   * @default false\n   */\n  verbose?: boolean;\n\n  /**\n   * Quiet mode (minimal output)\n   * @default false\n   */\n  quiet?: boolean;\n\n  /**\n   * No color output\n   * @default false\n   */\n  noColor?: boolean;\n}\n\n/**\n * Check environment and display warnings\n */\nfunction checkEnvironment(): void {\n  const warnings: string[] = [];\n\n  // Check for required environment variables\n  if (!process.env[ENV_VARS.PLATFORM_TOKEN]) {\n    warnings.push('PLATFORM_TOKEN environment variable is not set');\n    warnings.push('Authentication will fail for API operations');\n  }\n\n  // Check Node version\n  const nodeVersion = process.version;\n  const majorVersion = parseInt(nodeVersion.slice(1).split('.')[0] || '0', 10);\n  if (majorVersion < 18) {\n    warnings.push(`Node.js ${nodeVersion} detected - version 18+ recommended`);\n  }\n\n  // Display warnings\n  if (warnings.length > 0) {\n    printSection('Environment Warnings');\n    warnings.forEach(warning => {\n      printWarning(warning);\n    });\n    console.log('');\n  }\n}\n\n/**\n * Display startup information\n */\nfunction displayStartupInfo(options: CliOptions): void {\n  if (options.quiet) return;\n\n  const executionId = generateExecutionId();\n\n  if (options.debug || options.verbose) {\n    printDebug('CLI Configuration', {\n      name: APP_NAME,\n      version: APP_VERSION,\n      executionId,\n      node: process.version,\n      platform: process.platform,\n      arch: process.arch,\n      cwd: process.cwd(),\n      env: {\n        debug: process.env.DEBUG,\n        token: process.env[ENV_VARS.PLATFORM_TOKEN] ? 'set' : 'not set',\n        url: process.env[ENV_VARS.PLATFORM_BASE_URL] || 'default',\n      },\n    });\n  } else {\n    printDebug('Starting CLI', {\n      version: APP_VERSION,\n      executionId,\n    });\n  }\n}\n\n/**\n * Register all CLI commands\n */\nfunction registerCommands(): void {\n  printDebug('Registering commands');\n\n  // Configure program\n  program\n    .name(APP_NAME)\n    .description(APP_DESCRIPTION)\n    .version(APP_VERSION, '-v, --version', 'Show CLI version')\n    .option('--debug', 'Enable debug output with stack traces', false)\n    .option('--verbose', 'Show detailed information', false)\n    .option('--quiet', 'Minimal output (errors only)', false)\n    .option('--no-color', 'Disable colored output', false)\n    .addHelpText('after', `\nEnvironment Variables:\n  ${ENV_VARS.PLATFORM_TOKEN}              Authentication token (required)\n  ${ENV_VARS.PLATFORM_BASE_URL}                 API base URL (optional)\n  ${ENV_VARS.CLI_CONFIG_PATH}              Config file path (optional)\n  ${ENV_VARS.TLS_REJECT_UNAUTHORIZED}      Disable SSL verification if '0'\n  ${ENV_VARS.DEBUG}                        Enable debug mode if 'true'\n\nExamples:\n  $ ${APP_NAME} version\n  $ ${APP_NAME} list-pipelines --project my-app\n  $ ${APP_NAME} get-pipeline --id pipe-123 --format json\n  $ ${APP_NAME} store-token --days 30 --region us-east-1\n  $ ${APP_NAME} bootstrap --account 123456789012 --region us-east-1\n  $ ${APP_NAME} deploy --id pipe-123 --profile production\n\n`);\n\n  // Version command (special handling)\n  version(program);\n\n  // Authentication commands\n  printDebug('Registering authentication commands');\n  login(program); // Login and obtain PLATFORM_TOKEN (also supports --refresh)\n\n  // Query commands\n  printDebug('Registering query commands');\n  getPlugin(program); // Single plugin by ID\n  listPlugins(program); // Multiple plugins with filters\n  getPipeline(program); // Single pipeline by ID\n  listPipelines(program); // Multiple pipelines with filters\n\n  // Create/Upload commands\n  printDebug('Registering create/upload commands');\n  createPipeline(program); // Create pipeline configuration\n  uploadPlugin(program); // Upload and deploy plugin\n\n  // Status command\n  printDebug('Registering status command');\n  status(program); // Show environment and connectivity status\n\n  // Deployment commands\n  printDebug('Registering deployment commands');\n  storeToken(program); // Generate JWT token and store in Secrets Manager\n  setupEvents(program); // Deploy EventBridge event ingestion infrastructure\n  bootstrap(program); // Bootstrap CDK toolkit stack\n  deploy(program); // Deploy pipeline with CDK (--app prints boilerplate path)\n  synth(program); // Run CDK synthesis\n\n  // Shell completions\n  printDebug('Registering completions command');\n  program\n    .command('completions')\n    .description('Generate shell completions (bash, zsh, fish)')\n    .argument('<shell>', 'Shell type: bash, zsh, or fish')\n    .action((shell: string) => {\n      switch (shell) {\n        case 'bash':\n          console.log(`# pipeline-manager bash completions\n_pipeline_manager_completions() {\n  local cur=\"\\${COMP_WORDS[COMP_CWORD]}\"\n  local commands=\"login deploy synth upload-plugin create-pipeline status version bootstrap setup-events store-token completions\"\n  COMPREPLY=($(compgen -W \"\\${commands}\" -- \"\\${cur}\"))\n}\ncomplete -F _pipeline_manager_completions pipeline-manager`);\n          break;\n        case 'zsh':\n          console.log(`# pipeline-manager zsh completions\n_pipeline_manager() {\n  local commands=(login deploy synth upload-plugin create-pipeline status version bootstrap setup-events store-token completions)\n  _describe 'command' commands\n}\ncompdef _pipeline_manager pipeline-manager`);\n          break;\n        case 'fish':\n          console.log(`# pipeline-manager fish completions\ncomplete -c pipeline-manager -n '__fish_use_subcommand' -a 'login deploy synth upload-plugin create-pipeline status version bootstrap setup-events store-token completions'`);\n          break;\n        default:\n          console.error(`Unknown shell: ${shell}. Use bash, zsh, or fish.`);\n          process.exit(1);\n      }\n    });\n\n  printDebug('All commands registered successfully');\n}\n\n/**\n * Handle program errors\n */\nfunction setupErrorHandlers(): void {\n  // Handle uncaught exceptions\n  process.on('uncaughtException', (error: Error) => {\n    console.error(''); // Empty line\n    printError('Uncaught exception', {\n      error: error.message,\n      name: error.name,\n    });\n\n    handleError(error, ERROR_CODES.GENERAL, {\n      debug: isDebugMode(program.opts()),\n      exit: true,\n      context: {\n        type: 'uncaughtException',\n      },\n    });\n  });\n\n  // Handle unhandled promise rejections\n  process.on('unhandledRejection', (reason: unknown) => {\n    console.error(''); // Empty line\n    printError('Unhandled promise rejection', {\n      reason: reason instanceof Error ? reason.message : String(reason),\n    });\n\n    const error = reason instanceof Error ? reason : new Error(String(reason));\n\n    handleError(error, ERROR_CODES.GENERAL, {\n      debug: isDebugMode(program.opts()),\n      exit: true,\n      context: {\n        type: 'unhandledRejection',\n      },\n    });\n  });\n\n  // Handle SIGINT (Ctrl+C)\n  process.on('SIGINT', () => {\n    console.log(''); // Empty line\n    printWarning('Process interrupted by user (SIGINT)');\n    console.log(''); // Empty line\n    process.exit(130); // Standard exit code for SIGINT\n  });\n\n  // Handle SIGTERM\n  process.on('SIGTERM', () => {\n    console.log(''); // Empty line\n    printWarning('Process terminated (SIGTERM)');\n    console.log(''); // Empty line\n    process.exit(143); // Standard exit code for SIGTERM\n  });\n}\n\n/**\n * Initialize CLI with options\n *\n * @param options - CLI initialization options\n */\nexport function initializeCli(options: CliOptions = {}): void {\n  const {\n    showBanner = true,\n    minimalBanner = false,\n    debug = false,\n    verbose = false,\n    quiet = false,\n    noColor = false,\n  } = options;\n\n  // Handle color output\n  if (noColor) {\n    process.env.NO_COLOR = '1';\n  }\n\n  // Display banner\n  if (showBanner && !quiet) {\n    if (minimalBanner) {\n      miniBanner();\n    } else {\n      banner({\n        minimal: false,\n        showDescription: true,\n        showTimestamp: debug || verbose,\n        showExecutionId: debug,\n      });\n    }\n  }\n\n  // Display startup info\n  displayStartupInfo({ debug, verbose, quiet });\n\n  // Check environment\n  if (!quiet) {\n    checkEnvironment();\n  }\n\n  // Setup error handlers\n  setupErrorHandlers();\n\n  // Register commands\n  try {\n    registerCommands();\n    printDebug('CLI initialization complete');\n  } catch (error) {\n    printError('CLI initialization failed', {\n      error: error instanceof Error ? error.message : String(error),\n    });\n\n    handleError(error, ERROR_CODES.CONFIGURATION, {\n      debug: debug || isDebugMode(),\n      exit: true,\n      context: {\n        stage: 'initialization',\n      },\n    });\n  }\n}\n\n/**\n * Parse command line arguments\n */\nfunction parseArguments(): void {\n  try {\n    program.parse(process.argv);\n\n    // Show help if no command provided\n    const args = process.argv.slice(2);\n    if (args.length === 0) {\n      printInfo('No command specified - displaying help');\n      console.log(''); // Empty line\n      program.outputHelp();\n      process.exit(0);\n    }\n\n    // Check if command exists\n    const command = args[0];\n    if (command && !command.startsWith('-')) {\n      const commandExists = program.commands.some(cmd => cmd.name() === command);\n\n      if (!commandExists) {\n        console.log(''); // Empty line\n        printError(`Unknown command: ${command}`);\n        console.log(''); // Empty line\n        printInfo('Available commands:');\n        program.commands.forEach(cmd => {\n          console.log(`  • ${cmd.name()} - ${cmd.description()}`);\n        });\n        console.log(''); // Empty line\n        process.exit(1);\n      }\n    }\n\n    printDebug('Command line arguments parsed successfully');\n  } catch (error) {\n    handleError(error, ERROR_CODES.GENERAL, {\n      debug: isDebugMode(program.opts()),\n      exit: true,\n      context: {\n        stage: 'argument-parsing',\n        argv: process.argv,\n      },\n    });\n  }\n}\n\n/**\n * Main CLI entry point\n *\n * @param options - CLI initialization options\n *\n * @example\n * ```typescript\n * // Standard initialization\n * main();\n *\n * // Minimal mode\n * main({ minimalBanner: true, quiet: true });\n *\n * // Debug mode\n * main({ debug: true, verbose: true });\n * ```\n */\nexport function main(options: CliOptions = {}): void {\n  try {\n    // Initialize CLI\n    initializeCli(options);\n\n    // Parse arguments and execute command\n    parseArguments();\n\n    // If we reach here, command completed successfully\n    printDebug('CLI execution completed successfully');\n  } catch (error) {\n    // Final catch-all error handler\n    console.error(''); // Empty line\n    printError('Fatal CLI error', {\n      error: error instanceof Error ? error.message : String(error),\n    });\n\n    handleError(error, ERROR_CODES.GENERAL, {\n      debug: isDebugMode(options),\n      exit: true,\n      context: {\n        stage: 'main',\n        options,\n      },\n    });\n  }\n}\n\n/**\n * Run CLI if executed directly\n */\nif (require.main === module) {\n  // Parse CLI options from environment or command line\n  const options: CliOptions = {\n    debug: process.env.DEBUG === 'true',\n    quiet: process.argv.includes('--quiet'),\n    verbose: process.argv.includes('--verbose'),\n    noColor: process.argv.includes('--no-color') || process.env.NO_COLOR === '1',\n  };\n\n  main(options);\n}"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
/**
|
|
3
|
+
* Registers the `bootstrap` command with the CLI program.
|
|
4
|
+
*
|
|
5
|
+
* Provisions the CDK toolkit stack in the target AWS account/region
|
|
6
|
+
* so that CDK deployments can proceed.
|
|
7
|
+
*
|
|
8
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
9
|
+
*/
|
|
10
|
+
export declare function bootstrap(program: Command): void;
|
|
11
|
+
//# sourceMappingURL=bootstrap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootstrap.d.ts","sourceRoot":"","sources":["../../src/commands/bootstrap.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAsEpC;;;;;;;GAOG;AACH,wBAAgB,SAAS,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA+FhD"}
|