@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.
Files changed (110) hide show
  1. package/LICENSE +202 -0
  2. package/README.md +74 -0
  3. package/cdk.json +91 -0
  4. package/config.yml +94 -0
  5. package/dist/boilerplate.d.ts +3 -0
  6. package/dist/boilerplate.d.ts.map +1 -0
  7. package/dist/boilerplate.js +58 -0
  8. package/dist/cdk.json +91 -0
  9. package/dist/cli.d.ts +62 -0
  10. package/dist/cli.d.ts.map +1 -0
  11. package/dist/cli.js +372 -0
  12. package/dist/commands/bootstrap.d.ts +11 -0
  13. package/dist/commands/bootstrap.d.ts.map +1 -0
  14. package/dist/commands/bootstrap.js +159 -0
  15. package/dist/commands/create-pipeline.d.ts +12 -0
  16. package/dist/commands/create-pipeline.d.ts.map +1 -0
  17. package/dist/commands/create-pipeline.js +291 -0
  18. package/dist/commands/deploy.d.ts +15 -0
  19. package/dist/commands/deploy.d.ts.map +1 -0
  20. package/dist/commands/deploy.js +167 -0
  21. package/dist/commands/get-pipeline.d.ts +13 -0
  22. package/dist/commands/get-pipeline.d.ts.map +1 -0
  23. package/dist/commands/get-pipeline.js +97 -0
  24. package/dist/commands/get-plugin.d.ts +13 -0
  25. package/dist/commands/get-plugin.d.ts.map +1 -0
  26. package/dist/commands/get-plugin.js +98 -0
  27. package/dist/commands/list-pipelines.d.ts +20 -0
  28. package/dist/commands/list-pipelines.d.ts.map +1 -0
  29. package/dist/commands/list-pipelines.js +172 -0
  30. package/dist/commands/list-plugins.d.ts +20 -0
  31. package/dist/commands/list-plugins.d.ts.map +1 -0
  32. package/dist/commands/list-plugins.js +167 -0
  33. package/dist/commands/login.d.ts +21 -0
  34. package/dist/commands/login.d.ts.map +1 -0
  35. package/dist/commands/login.js +179 -0
  36. package/dist/commands/setup-events.d.ts +15 -0
  37. package/dist/commands/setup-events.d.ts.map +1 -0
  38. package/dist/commands/setup-events.js +177 -0
  39. package/dist/commands/status.d.ts +11 -0
  40. package/dist/commands/status.d.ts.map +1 -0
  41. package/dist/commands/status.js +89 -0
  42. package/dist/commands/store-token.d.ts +20 -0
  43. package/dist/commands/store-token.d.ts.map +1 -0
  44. package/dist/commands/store-token.js +233 -0
  45. package/dist/commands/synth.d.ts +21 -0
  46. package/dist/commands/synth.d.ts.map +1 -0
  47. package/dist/commands/synth.js +143 -0
  48. package/dist/commands/upload-plugin.d.ts +21 -0
  49. package/dist/commands/upload-plugin.d.ts.map +1 -0
  50. package/dist/commands/upload-plugin.js +311 -0
  51. package/dist/commands/version.d.ts +12 -0
  52. package/dist/commands/version.d.ts.map +1 -0
  53. package/dist/commands/version.js +223 -0
  54. package/dist/config/cli.constants.d.ts +101 -0
  55. package/dist/config/cli.constants.d.ts.map +1 -0
  56. package/dist/config/cli.constants.js +165 -0
  57. package/dist/config.yml +94 -0
  58. package/dist/templates/events-stack.json +141 -0
  59. package/dist/types/config.d.ts +44 -0
  60. package/dist/types/config.d.ts.map +1 -0
  61. package/dist/types/config.js +5 -0
  62. package/dist/types/error.d.ts +61 -0
  63. package/dist/types/error.d.ts.map +1 -0
  64. package/dist/types/error.js +39 -0
  65. package/dist/types/index.d.ts +8 -0
  66. package/dist/types/index.d.ts.map +1 -0
  67. package/dist/types/index.js +26 -0
  68. package/dist/types/pipeline.d.ts +144 -0
  69. package/dist/types/pipeline.d.ts.map +1 -0
  70. package/dist/types/pipeline.js +5 -0
  71. package/dist/types/plugin.d.ts +160 -0
  72. package/dist/types/plugin.d.ts.map +1 -0
  73. package/dist/types/plugin.js +5 -0
  74. package/dist/utils/api-client.d.ts +26 -0
  75. package/dist/utils/api-client.d.ts.map +1 -0
  76. package/dist/utils/api-client.js +160 -0
  77. package/dist/utils/audit-log.d.ts +8 -0
  78. package/dist/utils/audit-log.d.ts.map +1 -0
  79. package/dist/utils/audit-log.js +53 -0
  80. package/dist/utils/auth-guard.d.ts +16 -0
  81. package/dist/utils/auth-guard.d.ts.map +1 -0
  82. package/dist/utils/auth-guard.js +25 -0
  83. package/dist/utils/aws-secrets.d.ts +21 -0
  84. package/dist/utils/aws-secrets.d.ts.map +1 -0
  85. package/dist/utils/aws-secrets.js +74 -0
  86. package/dist/utils/banner.d.ts +19 -0
  87. package/dist/utils/banner.d.ts.map +1 -0
  88. package/dist/utils/banner.js +59 -0
  89. package/dist/utils/cdk-utils.d.ts +51 -0
  90. package/dist/utils/cdk-utils.d.ts.map +1 -0
  91. package/dist/utils/cdk-utils.js +101 -0
  92. package/dist/utils/command-utils.d.ts +56 -0
  93. package/dist/utils/command-utils.d.ts.map +1 -0
  94. package/dist/utils/command-utils.js +138 -0
  95. package/dist/utils/config-loader.d.ts +27 -0
  96. package/dist/utils/config-loader.d.ts.map +1 -0
  97. package/dist/utils/config-loader.js +166 -0
  98. package/dist/utils/error-handler.d.ts +29 -0
  99. package/dist/utils/error-handler.d.ts.map +1 -0
  100. package/dist/utils/error-handler.js +255 -0
  101. package/dist/utils/list-command-utils.d.ts +23 -0
  102. package/dist/utils/list-command-utils.d.ts.map +1 -0
  103. package/dist/utils/list-command-utils.js +60 -0
  104. package/dist/utils/output-utils.d.ts +60 -0
  105. package/dist/utils/output-utils.d.ts.map +1 -0
  106. package/dist/utils/output-utils.js +320 -0
  107. package/dist/utils/rate-limiter.d.ts +14 -0
  108. package/dist/utils/rate-limiter.d.ts.map +1 -0
  109. package/dist/utils/rate-limiter.js +73 -0
  110. package/package.json +144 -0
@@ -0,0 +1,167 @@
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.deploy = deploy;
9
+ const crypto_1 = require("crypto");
10
+ const client_sts_1 = require("@aws-sdk/client-sts");
11
+ const picocolors_1 = __importDefault(require("picocolors"));
12
+ const cli_constants_1 = require("../config/cli.constants");
13
+ const audit_log_1 = require("../utils/audit-log");
14
+ const cdk_utils_1 = require("../utils/cdk-utils");
15
+ const command_utils_1 = require("../utils/command-utils");
16
+ const error_handler_1 = require("../utils/error-handler");
17
+ const output_utils_1 = require("../utils/output-utils");
18
+ const { bold, cyan, dim } = picocolors_1.default;
19
+ /**
20
+ * Registers the `deploy` command with the CLI program.
21
+ *
22
+ * Fetches pipeline properties by ID from the platform API, then
23
+ * runs `cdk deploy` to provision the pipeline infrastructure in AWS.
24
+ * For synthesis only, use `pipeline-manager synth`.
25
+ *
26
+ * Requires service credentials to be pre-stored in AWS Secrets Manager.
27
+ * Create them first with: `pipeline-manager store-token`
28
+ *
29
+ * @param program - The root Commander program instance to attach the command to.
30
+ */
31
+ function deploy(program) {
32
+ program
33
+ .command('deploy')
34
+ .description('Deploy pipeline by ID using AWS CDK')
35
+ .requiredOption('-i, --id <id>', 'Pipeline ID')
36
+ .option('--profile <profile>', 'AWS profile', 'default')
37
+ .option('--require-approval <approval>', 'Approval level: never|any-change|broadening', 'never')
38
+ .option('--output <dir>', 'CDK output directory', 'cdk.out')
39
+ .option('--store-tokens', 'Authenticate using token from AWS Secrets Manager (requires PLATFORM_SECRET_NAME env var)', false)
40
+ .option('--region <region>', 'AWS region (for --store-tokens)')
41
+ .option('--verify-ssl', 'Enable SSL certificate verification')
42
+ .option('--no-verify-ssl', 'Disable SSL certificate verification')
43
+ .action(async (options) => {
44
+ const executionId = (0, command_utils_1.printCommandHeader)('Pipeline Deploy');
45
+ try {
46
+ (0, audit_log_1.auditLog)('deploy', { executionId, pipelineId: options.id, profile: options.profile });
47
+ (0, output_utils_1.printInfo)('Deployment parameters', {
48
+ id: options.id,
49
+ awsProfile: options.profile,
50
+ outputDir: options.output,
51
+ requireApproval: options.requireApproval,
52
+ verifySsl: options.verifySsl,
53
+ });
54
+ // Security warning for SSL verification disabled
55
+ (0, command_utils_1.printSslWarning)(options.verifySsl);
56
+ // Propagate to process.env so CDK constructs (Lambda, CodeBuild) inherit it
57
+ if (options.verifySsl === false) {
58
+ process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
59
+ }
60
+ (0, cdk_utils_1.ensureCdkAvailable)();
61
+ (0, output_utils_1.printSuccess)('AWS CDK is available');
62
+ // Create authenticated API client (supports PLATFORM_TOKEN or --store-tokens)
63
+ const client = await (0, command_utils_1.createAuthenticatedClientAsync)(options);
64
+ const config = client.getConfig();
65
+ // Fetch pipeline from API
66
+ (0, output_utils_1.printInfo)('Fetching pipeline configuration', { id: options.id });
67
+ const response = await client.get(`${config.api.pipelineUrl}/${options.id}`);
68
+ const pipeline = (0, output_utils_1.extractSingleResponse)(response, 'pipeline', 'props');
69
+ if (!pipeline?.props) {
70
+ (0, output_utils_1.printError)('Invalid pipeline response', {
71
+ id: options.id,
72
+ hasProps: !!pipeline?.props,
73
+ responseKeys: response ? Object.keys(response) : '(null)',
74
+ });
75
+ throw new Error(`Failed to retrieve valid pipeline properties for ID: ${options.id}`);
76
+ }
77
+ (0, output_utils_1.printSuccess)('Pipeline configuration retrieved');
78
+ (0, output_utils_1.printKeyValue)({
79
+ 'ID': pipeline.id,
80
+ 'Project': pipeline.project,
81
+ 'Organization': pipeline.organization,
82
+ 'Is Default': pipeline.isDefault,
83
+ 'Is Active': pipeline.isActive,
84
+ });
85
+ // Encode pipeline props (inject orgId and pipelineId for autonomous synth)
86
+ const propsWithIds = {
87
+ ...pipeline.props,
88
+ ...(pipeline.orgId && { orgId: pipeline.orgId }),
89
+ pipelineId: pipeline.id,
90
+ };
91
+ const encoded = Buffer.from(JSON.stringify(propsWithIds), 'utf-8').toString('base64');
92
+ const outputPath = options.output;
93
+ // Ensure output directory exists
94
+ (0, output_utils_1.printInfo)('Preparing output directory', { path: outputPath });
95
+ (0, output_utils_1.ensureOutputDirectory)(outputPath);
96
+ // Build CDK command (validate inputs that flow into shell)
97
+ if (options.profile)
98
+ (0, cli_constants_1.assertShellSafe)(options.profile, 'profile');
99
+ (0, cli_constants_1.assertShellSafe)(outputPath, 'output');
100
+ const scriptPath = (0, cdk_utils_1.resolveBoilerplatePath)(__dirname);
101
+ const profileArg = options.profile ? `--profile=${options.profile}` : '';
102
+ const outputArg = `--output=${outputPath}`;
103
+ const appArg = `--app="node ${scriptPath}"`;
104
+ const command = `cdk deploy ${profileArg} --require-approval=${options.requireApproval} ${outputArg} --notices=false ${appArg}`;
105
+ (0, output_utils_1.printSection)('CDK Execution');
106
+ console.log(cyan(bold('Command:')), dim(command.split(' --')[0] + ' ...'));
107
+ console.log(''); // Empty line
108
+ // Execute CDK command
109
+ const result = (0, cdk_utils_1.executeCdkShellCommand)(command, {
110
+ debug: program.opts().debug,
111
+ showOutput: true,
112
+ env: { PIPELINE_PROPS: encoded },
113
+ });
114
+ console.log(''); // Empty line
115
+ (0, output_utils_1.printSection)('Deployment Complete');
116
+ if (result.success) {
117
+ (0, output_utils_1.printKeyValue)({
118
+ 'Execution ID': executionId,
119
+ 'Duration': `${result.duration}ms`,
120
+ 'Output Directory': outputPath,
121
+ 'Status': '✓ Success',
122
+ });
123
+ // Register pipeline ARN for event reporting (non-blocking)
124
+ try {
125
+ const stsClient = new client_sts_1.STSClient({ region: process.env.AWS_REGION || process.env.CDK_DEFAULT_REGION });
126
+ const identity = await stsClient.send(new client_sts_1.GetCallerIdentityCommand({}));
127
+ const account = identity.Account ?? '';
128
+ const region = options.region || process.env.AWS_REGION || process.env.CDK_DEFAULT_REGION || 'us-east-1';
129
+ const pipelineName = pipeline.pipelineName
130
+ || `${pipeline.organization}-${pipeline.project}-pipeline`.toLowerCase();
131
+ const hashedAccount = (0, crypto_1.createHash)('sha256').update(account).digest('hex').slice(0, 12);
132
+ const pipelineArn = `arn:aws:codepipeline:${region}:${hashedAccount}:${pipelineName}`;
133
+ await client.post(`${config.api.pipelineUrl}/registry`, {
134
+ pipelineId: pipeline.id,
135
+ orgId: pipeline.orgId,
136
+ pipelineArn,
137
+ pipelineName,
138
+ accountId: hashedAccount,
139
+ region,
140
+ project: pipeline.project,
141
+ organization: pipeline.organization,
142
+ stackName: `${pipeline.project}-${pipeline.organization}`.toLowerCase(),
143
+ });
144
+ (0, output_utils_1.printSuccess)('Pipeline registered for event reporting', { arn: pipelineArn });
145
+ }
146
+ catch (regError) {
147
+ (0, output_utils_1.printWarning)('Pipeline registry update failed (reporting may be incomplete)', {
148
+ error: regError instanceof Error ? regError.message : String(regError),
149
+ });
150
+ }
151
+ }
152
+ }
153
+ catch (error) {
154
+ (0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.API_REQUEST, {
155
+ debug: program.opts().debug,
156
+ exit: true,
157
+ context: {
158
+ command: 'deploy',
159
+ executionId,
160
+ pipelineId: options.id,
161
+ verifySsl: options.verifySsl,
162
+ },
163
+ });
164
+ }
165
+ });
166
+ }
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deploy.js","sourceRoot":"","sources":["../../src/commands/deploy.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { createHash } from 'crypto';\nimport { STSClient, GetCallerIdentityCommand } from '@aws-sdk/client-sts';\nimport { Command } from 'commander';\nimport pico from 'picocolors';\nimport { assertShellSafe } from '../config/cli.constants';\nimport { Pipeline, PipelineResponse } from '../types';\nimport { auditLog } from '../utils/audit-log';\nimport { ensureCdkAvailable, executeCdkShellCommand, resolveBoilerplatePath } from '../utils/cdk-utils';\nimport { printCommandHeader, printSslWarning, createAuthenticatedClientAsync } 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 } = pico;\n\n/**\n * Registers the `deploy` command with the CLI program.\n *\n * Fetches pipeline properties by ID from the platform API, then\n * runs `cdk deploy` to provision the pipeline infrastructure in AWS.\n * For synthesis only, use `pipeline-manager synth`.\n *\n * Requires service credentials to be pre-stored in AWS Secrets Manager.\n * Create them first with: `pipeline-manager store-token`\n *\n * @param program - The root Commander program instance to attach the command to.\n */\nexport function deploy(program: Command): void {\n  program\n    .command('deploy')\n    .description('Deploy pipeline by ID using AWS CDK')\n    .requiredOption('-i, --id <id>', 'Pipeline ID')\n    .option('--profile <profile>', 'AWS profile', 'default')\n    .option('--require-approval <approval>', 'Approval level: never|any-change|broadening', 'never')\n    .option('--output <dir>', 'CDK output directory', 'cdk.out')\n    .option('--store-tokens', 'Authenticate using token from AWS Secrets Manager (requires PLATFORM_SECRET_NAME env var)', false)\n    .option('--region <region>', 'AWS region (for --store-tokens)')\n    .option('--verify-ssl', 'Enable SSL certificate verification')\n    .option('--no-verify-ssl', 'Disable SSL certificate verification')\n    .action(async (options) => {\n\n      const executionId = printCommandHeader('Pipeline Deploy');\n\n      try {\n        auditLog('deploy', { executionId, pipelineId: options.id, profile: options.profile });\n\n        printInfo('Deployment parameters', {\n          id: options.id,\n          awsProfile: options.profile,\n          outputDir: options.output,\n          requireApproval: options.requireApproval,\n          verifySsl: options.verifySsl,\n        });\n\n        // Security warning for SSL verification disabled\n        printSslWarning(options.verifySsl);\n\n        // Propagate to process.env so CDK constructs (Lambda, CodeBuild) inherit it\n        if (options.verifySsl === false) {\n          process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';\n        }\n\n        ensureCdkAvailable();\n        printSuccess('AWS CDK is available');\n\n        // Create authenticated API client (supports PLATFORM_TOKEN or --store-tokens)\n        const client = await createAuthenticatedClientAsync(options);\n        const config = client.getConfig();\n\n        // Fetch pipeline from API\n        printInfo('Fetching pipeline configuration', { id: options.id });\n        const response = await client.get<PipelineResponse>(\n          `${config.api.pipelineUrl}/${options.id}`,\n        );\n\n        const pipeline = extractSingleResponse<Pipeline>(response, 'pipeline', 'props');\n\n        if (!pipeline?.props) {\n          printError('Invalid pipeline response', {\n            id: options.id,\n            hasProps: !!pipeline?.props,\n            responseKeys: response ? Object.keys(response) : '(null)',\n          });\n          throw new Error(`Failed to retrieve valid pipeline properties for ID: ${options.id}`);\n        }\n\n        printSuccess('Pipeline configuration retrieved');\n        printKeyValue({\n          'ID': pipeline.id,\n          'Project': pipeline.project,\n          'Organization': pipeline.organization,\n          'Is Default': pipeline.isDefault,\n          'Is Active': pipeline.isActive,\n        });\n\n        // Encode pipeline props (inject orgId and pipelineId for autonomous synth)\n        const propsWithIds = {\n          ...pipeline.props,\n          ...(pipeline.orgId && { orgId: pipeline.orgId }),\n          pipelineId: pipeline.id,\n        };\n\n        const encoded = Buffer.from(JSON.stringify(propsWithIds), 'utf-8').toString('base64');\n        const outputPath = options.output;\n\n        // Ensure output directory exists\n        printInfo('Preparing output directory', { path: outputPath });\n        ensureOutputDirectory(outputPath);\n\n        // Build CDK command (validate inputs that flow into shell)\n        if (options.profile) assertShellSafe(options.profile, 'profile');\n        assertShellSafe(outputPath, 'output');\n\n        const scriptPath = resolveBoilerplatePath(__dirname);\n        const profileArg = options.profile ? `--profile=${options.profile}` : '';\n        const outputArg = `--output=${outputPath}`;\n        const appArg = `--app=\"node ${scriptPath}\"`;\n\n        const command = `cdk deploy ${profileArg} --require-approval=${options.requireApproval} ${outputArg} --notices=false ${appArg}`;\n\n        printSection('CDK Execution');\n        console.log(cyan(bold('Command:')), dim(command.split(' --')[0] + ' ...'));\n        console.log(''); // Empty line\n\n        // Execute CDK command\n        const result = executeCdkShellCommand(command, {\n          debug: program.opts().debug,\n          showOutput: true,\n          env: { PIPELINE_PROPS: encoded },\n        });\n\n        console.log(''); // Empty line\n        printSection('Deployment Complete');\n\n        if (result.success) {\n          printKeyValue({\n            'Execution ID': executionId,\n            'Duration': `${result.duration}ms`,\n            'Output Directory': outputPath,\n            'Status': '✓ Success',\n          });\n\n          // Register pipeline ARN for event reporting (non-blocking)\n          try {\n            const stsClient = new STSClient({ region: process.env.AWS_REGION || process.env.CDK_DEFAULT_REGION });\n            const identity = await stsClient.send(new GetCallerIdentityCommand({}));\n            const account = identity.Account ?? '';\n            const region = options.region || process.env.AWS_REGION || process.env.CDK_DEFAULT_REGION || 'us-east-1';\n\n            const pipelineName = pipeline.pipelineName\n              || `${pipeline.organization}-${pipeline.project}-pipeline`.toLowerCase();\n\n            const hashedAccount = createHash('sha256').update(account).digest('hex').slice(0, 12);\n            const pipelineArn = `arn:aws:codepipeline:${region}:${hashedAccount}:${pipelineName}`;\n\n            await client.post(`${config.api.pipelineUrl}/registry`, {\n              pipelineId: pipeline.id,\n              orgId: pipeline.orgId,\n              pipelineArn,\n              pipelineName,\n              accountId: hashedAccount,\n              region,\n              project: pipeline.project,\n              organization: pipeline.organization,\n              stackName: `${pipeline.project}-${pipeline.organization}`.toLowerCase(),\n            });\n\n            printSuccess('Pipeline registered for event reporting', { arn: pipelineArn });\n          } catch (regError) {\n            printWarning('Pipeline registry update failed (reporting may be incomplete)', {\n              error: regError instanceof Error ? regError.message : String(regError),\n            });\n          }\n        }\n\n      } catch (error) {\n        handleError(error, ERROR_CODES.API_REQUEST, {\n          debug: program.opts().debug,\n          exit: true,\n          context: {\n            command: 'deploy',\n            executionId,\n            pipelineId: options.id,\n            verifySsl: options.verifySsl,\n          },\n        });\n      }\n    });\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { Command } from 'commander';
2
+ /**
3
+ * Registers the `get-pipeline` command with the CLI program.
4
+ *
5
+ * @example
6
+ * ```bash
7
+ * pipeline-manager get-pipeline --id <pipeline-id>
8
+ * pipeline-manager get-pipeline --id <pipeline-id> --format json
9
+ * pipeline-manager get-pipeline --id <pipeline-id> --output pipeline.json
10
+ * ```
11
+ */
12
+ export declare function getPipeline(program: Command): void;
13
+ //# sourceMappingURL=get-pipeline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-pipeline.d.ts","sourceRoot":"","sources":["../../src/commands/get-pipeline.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AASpC;;;;;;;;;GASG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAqFlD"}
@@ -0,0 +1,97 @@
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.getPipeline = getPipeline;
9
+ const picocolors_1 = __importDefault(require("picocolors"));
10
+ const command_utils_1 = require("../utils/command-utils");
11
+ const error_handler_1 = require("../utils/error-handler");
12
+ const output_utils_1 = require("../utils/output-utils");
13
+ const { bold, dim, green } = picocolors_1.default;
14
+ /**
15
+ * Registers the `get-pipeline` command with the CLI program.
16
+ *
17
+ * @example
18
+ * ```bash
19
+ * pipeline-manager get-pipeline --id <pipeline-id>
20
+ * pipeline-manager get-pipeline --id <pipeline-id> --format json
21
+ * pipeline-manager get-pipeline --id <pipeline-id> --output pipeline.json
22
+ * ```
23
+ */
24
+ function getPipeline(program) {
25
+ program
26
+ .command('get-pipeline')
27
+ .description('Get a single pipeline by ID')
28
+ .requiredOption('-i, --id <id>', 'Pipeline ID')
29
+ .option('-f, --format <format>', 'Output format (json, yaml, table)', 'json')
30
+ .option('-o, --output <file>', 'Save output to file')
31
+ .option('--verify-ssl', 'Enable SSL certificate verification')
32
+ .option('--no-verify-ssl', 'Disable SSL certificate verification')
33
+ .option('--show-props', 'Show full pipeline properties in table format', false)
34
+ .action(async (options) => {
35
+ const executionId = (0, command_utils_1.printCommandHeader)('Get Pipeline');
36
+ try {
37
+ (0, command_utils_1.printSslWarning)(options.verifySsl);
38
+ (0, output_utils_1.printInfo)('Request parameters', {
39
+ id: options.id,
40
+ format: options.format,
41
+ output: options.output || '(console)',
42
+ });
43
+ const pipelineId = (0, command_utils_1.validateEntityId)(options.id, 'Pipeline');
44
+ const client = (0, command_utils_1.createAuthenticatedClient)(options);
45
+ // Fetch pipeline
46
+ console.log('');
47
+ (0, output_utils_1.printSection)('Fetching Pipeline');
48
+ const startTime = Date.now();
49
+ const response = await client.get(`${client.getConfig().api.pipelineUrl}/${pipelineId}`);
50
+ const duration = Date.now() - startTime;
51
+ const pipeline = (0, output_utils_1.extractSingleResponse)(response, 'pipeline', 'id');
52
+ if (!pipeline) {
53
+ (0, output_utils_1.printError)('No pipeline returned from API');
54
+ throw new Error(`Failed to retrieve pipeline with ID: ${pipelineId}`);
55
+ }
56
+ console.log('');
57
+ (0, output_utils_1.printSection)('Pipeline Retrieved Successfully');
58
+ (0, output_utils_1.printKeyValue)({
59
+ 'Pipeline ID': green(bold(pipeline.id)),
60
+ 'Project': pipeline.project,
61
+ 'Organization': pipeline.organization,
62
+ 'Name': pipeline.pipelineName || '(not set)',
63
+ 'Access': pipeline.accessModifier || 'private',
64
+ 'Default': pipeline.isDefault ? 'Yes' : 'No',
65
+ 'Active': pipeline.isActive ? 'Yes' : 'No',
66
+ 'Created At': pipeline.createdAt || '(not available)',
67
+ 'Updated At': pipeline.updatedAt || '(not available)',
68
+ });
69
+ // Show properties if requested
70
+ if (options.showProps && options.format === 'table' && pipeline.props && Object.keys(pipeline.props).length > 0) {
71
+ console.log('');
72
+ (0, output_utils_1.printInfo)('Pipeline Properties', { keys: Object.keys(pipeline.props).length });
73
+ console.log(dim('─'.repeat(process.stdout.columns || 80)));
74
+ console.log(JSON.stringify(pipeline.props, null, 2));
75
+ console.log(dim('─'.repeat(process.stdout.columns || 80)));
76
+ }
77
+ (0, command_utils_1.printExecutionSummary)(executionId, duration);
78
+ (0, output_utils_1.outputData)(pipeline, {
79
+ format: options.format,
80
+ file: options.output,
81
+ silent: false,
82
+ });
83
+ if (options.output) {
84
+ console.log('');
85
+ (0, output_utils_1.printSuccess)('Pipeline data saved', { path: options.output });
86
+ }
87
+ }
88
+ catch (error) {
89
+ (0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.API_REQUEST, {
90
+ debug: program.opts().debug,
91
+ exit: true,
92
+ context: { command: 'get-pipeline', executionId, pipelineId: options.id },
93
+ });
94
+ }
95
+ });
96
+ }
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-pipeline.js","sourceRoot":"","sources":["../../src/commands/get-pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { Command } from 'commander';\nimport pico from 'picocolors';\nimport { Pipeline, PipelineResponse } from '../types';\nimport { createAuthenticatedClient, printCommandHeader, printExecutionSummary, printSslWarning, validateEntityId } from '../utils/command-utils';\nimport { ERROR_CODES, handleError } from '../utils/error-handler';\nimport { extractSingleResponse, outputData, printError, printInfo, printKeyValue, printSection, printSuccess } from '../utils/output-utils';\n\nconst { bold, dim, green } = pico;\n\n/**\n * Registers the `get-pipeline` command with the CLI program.\n *\n * @example\n * ```bash\n * pipeline-manager get-pipeline --id <pipeline-id>\n * pipeline-manager get-pipeline --id <pipeline-id> --format json\n * pipeline-manager get-pipeline --id <pipeline-id> --output pipeline.json\n * ```\n */\nexport function getPipeline(program: Command): void {\n  program\n    .command('get-pipeline')\n    .description('Get a single pipeline by ID')\n    .requiredOption('-i, --id <id>', 'Pipeline ID')\n    .option('-f, --format <format>', 'Output format (json, yaml, table)', 'json')\n    .option('-o, --output <file>', 'Save output to file')\n    .option('--verify-ssl', 'Enable SSL certificate verification')\n    .option('--no-verify-ssl', 'Disable SSL certificate verification')\n    .option('--show-props', 'Show full pipeline properties in table format', false)\n    .action(async (options) => {\n      const executionId = printCommandHeader('Get Pipeline');\n\n      try {\n        printSslWarning(options.verifySsl);\n        printInfo('Request parameters', {\n          id: options.id,\n          format: options.format,\n          output: options.output || '(console)',\n        });\n\n        const pipelineId = validateEntityId(options.id, 'Pipeline');\n        const client = createAuthenticatedClient(options);\n\n        // Fetch pipeline\n        console.log('');\n        printSection('Fetching Pipeline');\n\n        const startTime = Date.now();\n        const response = await client.get<PipelineResponse>(\n          `${client.getConfig().api.pipelineUrl}/${pipelineId}`,\n        );\n        const duration = Date.now() - startTime;\n\n        const pipeline = extractSingleResponse<Pipeline>(response, 'pipeline', 'id');\n        if (!pipeline) {\n          printError('No pipeline returned from API');\n          throw new Error(`Failed to retrieve pipeline with ID: ${pipelineId}`);\n        }\n\n        console.log('');\n        printSection('Pipeline Retrieved Successfully');\n\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          'Created At': pipeline.createdAt || '(not available)',\n          'Updated At': pipeline.updatedAt || '(not available)',\n        });\n\n        // Show properties if requested\n        if (options.showProps && options.format === 'table' && pipeline.props && Object.keys(pipeline.props).length > 0) {\n          console.log('');\n          printInfo('Pipeline Properties', { keys: Object.keys(pipeline.props).length });\n          console.log(dim('─'.repeat(process.stdout.columns || 80)));\n          console.log(JSON.stringify(pipeline.props, null, 2));\n          console.log(dim('─'.repeat(process.stdout.columns || 80)));\n        }\n\n        printExecutionSummary(executionId, duration);\n\n        outputData(pipeline, {\n          format: options.format,\n          file: options.output,\n          silent: false,\n        });\n\n        if (options.output) {\n          console.log('');\n          printSuccess('Pipeline data saved', { path: options.output });\n        }\n\n      } catch (error) {\n        handleError(error, ERROR_CODES.API_REQUEST, {\n          debug: program.opts().debug,\n          exit: true,\n          context: { command: 'get-pipeline', executionId, pipelineId: options.id },\n        });\n      }\n    });\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { Command } from 'commander';
2
+ /**
3
+ * Registers the `get-plugin` command with the CLI program.
4
+ *
5
+ * @example
6
+ * ```bash
7
+ * pipeline-manager get-plugin --id <plugin-id>
8
+ * pipeline-manager get-plugin --id <plugin-id> --format json
9
+ * pipeline-manager get-plugin --id <plugin-id> --output plugin.json
10
+ * ```
11
+ */
12
+ export declare function getPlugin(program: Command): void;
13
+ //# sourceMappingURL=get-plugin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-plugin.d.ts","sourceRoot":"","sources":["../../src/commands/get-plugin.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AASpC;;;;;;;;;GASG;AACH,wBAAgB,SAAS,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAsFhD"}
@@ -0,0 +1,98 @@
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.getPlugin = getPlugin;
9
+ const picocolors_1 = __importDefault(require("picocolors"));
10
+ const command_utils_1 = require("../utils/command-utils");
11
+ const error_handler_1 = require("../utils/error-handler");
12
+ const output_utils_1 = require("../utils/output-utils");
13
+ const { bold, dim, green } = picocolors_1.default;
14
+ /**
15
+ * Registers the `get-plugin` command with the CLI program.
16
+ *
17
+ * @example
18
+ * ```bash
19
+ * pipeline-manager get-plugin --id <plugin-id>
20
+ * pipeline-manager get-plugin --id <plugin-id> --format json
21
+ * pipeline-manager get-plugin --id <plugin-id> --output plugin.json
22
+ * ```
23
+ */
24
+ function getPlugin(program) {
25
+ program
26
+ .command('get-plugin')
27
+ .description('Get a single plugin by ID')
28
+ .requiredOption('-i, --id <id>', 'Plugin ID')
29
+ .option('-f, --format <format>', 'Output format (json, yaml, table)', 'json')
30
+ .option('-o, --output <file>', 'Save output to file')
31
+ .option('--verify-ssl', 'Enable SSL certificate verification')
32
+ .option('--no-verify-ssl', 'Disable SSL certificate verification')
33
+ .option('--show-metadata', 'Show full plugin metadata in table format', false)
34
+ .action(async (options) => {
35
+ const executionId = (0, command_utils_1.printCommandHeader)('Get Plugin');
36
+ try {
37
+ (0, command_utils_1.printSslWarning)(options.verifySsl);
38
+ (0, output_utils_1.printInfo)('Request parameters', {
39
+ id: options.id,
40
+ format: options.format,
41
+ output: options.output || '(console)',
42
+ });
43
+ const pluginId = (0, command_utils_1.validateEntityId)(options.id, 'Plugin');
44
+ const client = (0, command_utils_1.createAuthenticatedClient)(options);
45
+ // Fetch plugin
46
+ console.log('');
47
+ (0, output_utils_1.printSection)('Fetching Plugin');
48
+ const startTime = Date.now();
49
+ const response = await client.get(`${client.getConfig().api.pluginUrl}/${pluginId}`);
50
+ const duration = Date.now() - startTime;
51
+ const plugin = (0, output_utils_1.extractSingleResponse)(response, 'plugin', 'id');
52
+ if (!plugin) {
53
+ (0, output_utils_1.printError)('No plugin returned from API');
54
+ throw new Error(`Failed to retrieve plugin with ID: ${pluginId}`);
55
+ }
56
+ console.log('');
57
+ (0, output_utils_1.printSection)('Plugin Retrieved Successfully');
58
+ (0, output_utils_1.printKeyValue)({
59
+ 'Plugin ID': green(bold(plugin.id)),
60
+ 'Name': plugin.name,
61
+ 'Version': plugin.version,
62
+ 'Organization': plugin.organization,
63
+ 'Description': plugin.description || '(not set)',
64
+ 'File Size': plugin.fileSize ? `${(plugin.fileSize / 1024).toFixed(2)} KB` : '(not available)',
65
+ 'Public': plugin.isPublic ? 'Yes' : 'No',
66
+ 'Active': plugin.isActive ? 'Yes' : 'No',
67
+ 'Created At': plugin.createdAt || '(not available)',
68
+ 'Updated At': plugin.updatedAt || '(not available)',
69
+ });
70
+ // Show metadata if requested
71
+ if (options.showMetadata && options.format === 'table' && plugin.metadata && Object.keys(plugin.metadata).length > 0) {
72
+ console.log('');
73
+ (0, output_utils_1.printInfo)('Plugin Metadata', { keys: Object.keys(plugin.metadata).length });
74
+ console.log(dim('─'.repeat(process.stdout.columns || 80)));
75
+ console.log(JSON.stringify(plugin.metadata, null, 2));
76
+ console.log(dim('─'.repeat(process.stdout.columns || 80)));
77
+ }
78
+ (0, command_utils_1.printExecutionSummary)(executionId, duration);
79
+ (0, output_utils_1.outputData)(plugin, {
80
+ format: options.format,
81
+ file: options.output,
82
+ silent: false,
83
+ });
84
+ if (options.output) {
85
+ console.log('');
86
+ (0, output_utils_1.printSuccess)('Plugin data saved', { path: options.output });
87
+ }
88
+ }
89
+ catch (error) {
90
+ (0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.API_REQUEST, {
91
+ debug: program.opts().debug,
92
+ exit: true,
93
+ context: { command: 'get-plugin', executionId, pluginId: options.id },
94
+ });
95
+ }
96
+ });
97
+ }
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-plugin.js","sourceRoot":"","sources":["../../src/commands/get-plugin.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { Command } from 'commander';\nimport pico from 'picocolors';\nimport { Plugin, PluginResponse } from '../types';\nimport { createAuthenticatedClient, printCommandHeader, printExecutionSummary, printSslWarning, validateEntityId } from '../utils/command-utils';\nimport { ERROR_CODES, handleError } from '../utils/error-handler';\nimport { extractSingleResponse, outputData, printError, printInfo, printKeyValue, printSection, printSuccess } from '../utils/output-utils';\n\nconst { bold, dim, green } = pico;\n\n/**\n * Registers the `get-plugin` command with the CLI program.\n *\n * @example\n * ```bash\n * pipeline-manager get-plugin --id <plugin-id>\n * pipeline-manager get-plugin --id <plugin-id> --format json\n * pipeline-manager get-plugin --id <plugin-id> --output plugin.json\n * ```\n */\nexport function getPlugin(program: Command): void {\n  program\n    .command('get-plugin')\n    .description('Get a single plugin by ID')\n    .requiredOption('-i, --id <id>', 'Plugin ID')\n    .option('-f, --format <format>', 'Output format (json, yaml, table)', 'json')\n    .option('-o, --output <file>', 'Save output to file')\n    .option('--verify-ssl', 'Enable SSL certificate verification')\n    .option('--no-verify-ssl', 'Disable SSL certificate verification')\n    .option('--show-metadata', 'Show full plugin metadata in table format', false)\n    .action(async (options) => {\n      const executionId = printCommandHeader('Get Plugin');\n\n      try {\n        printSslWarning(options.verifySsl);\n        printInfo('Request parameters', {\n          id: options.id,\n          format: options.format,\n          output: options.output || '(console)',\n        });\n\n        const pluginId = validateEntityId(options.id, 'Plugin');\n        const client = createAuthenticatedClient(options);\n\n        // Fetch plugin\n        console.log('');\n        printSection('Fetching Plugin');\n\n        const startTime = Date.now();\n        const response = await client.get<PluginResponse>(\n          `${client.getConfig().api.pluginUrl}/${pluginId}`,\n        );\n        const duration = Date.now() - startTime;\n\n        const plugin = extractSingleResponse<Plugin>(response, 'plugin', 'id');\n        if (!plugin) {\n          printError('No plugin returned from API');\n          throw new Error(`Failed to retrieve plugin with ID: ${pluginId}`);\n        }\n\n        console.log('');\n        printSection('Plugin Retrieved Successfully');\n\n        printKeyValue({\n          'Plugin ID': green(bold(plugin.id)),\n          'Name': plugin.name,\n          'Version': plugin.version,\n          'Organization': plugin.organization,\n          'Description': plugin.description || '(not set)',\n          'File Size': plugin.fileSize ? `${(plugin.fileSize / 1024).toFixed(2)} KB` : '(not available)',\n          'Public': plugin.isPublic ? 'Yes' : 'No',\n          'Active': plugin.isActive ? 'Yes' : 'No',\n          'Created At': plugin.createdAt || '(not available)',\n          'Updated At': plugin.updatedAt || '(not available)',\n        });\n\n        // Show metadata if requested\n        if (options.showMetadata && options.format === 'table' && plugin.metadata && Object.keys(plugin.metadata).length > 0) {\n          console.log('');\n          printInfo('Plugin Metadata', { keys: Object.keys(plugin.metadata).length });\n          console.log(dim('─'.repeat(process.stdout.columns || 80)));\n          console.log(JSON.stringify(plugin.metadata, null, 2));\n          console.log(dim('─'.repeat(process.stdout.columns || 80)));\n        }\n\n        printExecutionSummary(executionId, duration);\n\n        outputData(plugin, {\n          format: options.format,\n          file: options.output,\n          silent: false,\n        });\n\n        if (options.output) {\n          console.log('');\n          printSuccess('Plugin data saved', { path: options.output });\n        }\n\n      } catch (error) {\n        handleError(error, ERROR_CODES.API_REQUEST, {\n          debug: program.opts().debug,\n          exit: true,\n          context: { command: 'get-plugin', executionId, pluginId: options.id },\n        });\n      }\n    });\n}\n"]}
@@ -0,0 +1,20 @@
1
+ import { Command } from 'commander';
2
+ /**
3
+ * Registers the `list-pipelines` command with the CLI program.
4
+ *
5
+ * Queries pipelines with filters for project, organization, name,
6
+ * access modifier, active/default status, plus pagination and sorting.
7
+ *
8
+ * @param program - The root Commander program instance to attach the command to.
9
+ *
10
+ * @example
11
+ * ```bash
12
+ * cli list-pipelines
13
+ * cli list-pipelines --project my-app --is-active true
14
+ * cli list-pipelines --organization my-org
15
+ * cli list-pipelines --limit 50 --offset 100 --sort "pipelineName:asc"
16
+ * cli list-pipelines --format json --output pipelines.json
17
+ * ```
18
+ */
19
+ export declare function listPipelines(program: Command): void;
20
+ //# sourceMappingURL=list-pipelines.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-pipelines.d.ts","sourceRoot":"","sources":["../../src/commands/list-pipelines.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAsBpC;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAsKpD"}