@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,172 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Copyright 2026 Pipeline Builder Contributors
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.listPipelines = listPipelines;
|
|
6
|
+
const cli_constants_1 = require("../config/cli.constants");
|
|
7
|
+
const command_utils_1 = require("../utils/command-utils");
|
|
8
|
+
const error_handler_1 = require("../utils/error-handler");
|
|
9
|
+
const list_command_utils_1 = require("../utils/list-command-utils");
|
|
10
|
+
const output_utils_1 = require("../utils/output-utils");
|
|
11
|
+
/**
|
|
12
|
+
* Registers the `list-pipelines` command with the CLI program.
|
|
13
|
+
*
|
|
14
|
+
* Queries pipelines with filters for project, organization, name,
|
|
15
|
+
* access modifier, active/default status, plus pagination and sorting.
|
|
16
|
+
*
|
|
17
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```bash
|
|
21
|
+
* cli list-pipelines
|
|
22
|
+
* cli list-pipelines --project my-app --is-active true
|
|
23
|
+
* cli list-pipelines --organization my-org
|
|
24
|
+
* cli list-pipelines --limit 50 --offset 100 --sort "pipelineName:asc"
|
|
25
|
+
* cli list-pipelines --format json --output pipelines.json
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
function listPipelines(program) {
|
|
29
|
+
program
|
|
30
|
+
.command('list-pipelines')
|
|
31
|
+
.description('Query pipelines with comprehensive filters')
|
|
32
|
+
// Common filter options
|
|
33
|
+
.option('--id <id>', 'Filter by pipeline ID (can specify multiple with commas)')
|
|
34
|
+
.option('--access-modifier <modifier>', 'Filter by access modifier (public/private)')
|
|
35
|
+
.option('--is-default <boolean>', 'Filter by default status (true/false)')
|
|
36
|
+
.option('--is-active <boolean>', 'Filter by active status (true/false)')
|
|
37
|
+
.option('--limit <number>', 'Maximum number of results (1-1000)', parseInt, 50)
|
|
38
|
+
.option('--offset <number>', 'Number of results to skip', parseInt, 0)
|
|
39
|
+
.option('--sort <sort>', 'Sort format: field:direction (e.g., pipelineName:asc, createdAt:desc)')
|
|
40
|
+
// Pipeline-specific filter options
|
|
41
|
+
.option('--project <project>', 'Filter by exact project name')
|
|
42
|
+
.option('--organization <organization>', 'Filter by exact organization name')
|
|
43
|
+
.option('--pipeline-name <name>', 'Filter by exact pipeline name')
|
|
44
|
+
// Output options
|
|
45
|
+
.option('-f, --format <format>', 'Output format (json, yaml, table, csv)', 'table')
|
|
46
|
+
.option('-o, --output <file>', 'Save output to file')
|
|
47
|
+
.option('--show-props', 'Include pipeline properties in output (json/yaml only)', false)
|
|
48
|
+
.option('--verify-ssl', 'Enable SSL certificate verification')
|
|
49
|
+
.option('--no-verify-ssl', 'Disable SSL certificate verification')
|
|
50
|
+
.action(async (options) => {
|
|
51
|
+
const executionId = (0, command_utils_1.printCommandHeader)('List Pipelines', 'Query Pipelines');
|
|
52
|
+
const startTime = Date.now();
|
|
53
|
+
try {
|
|
54
|
+
// Build filter parameters (common + pipeline-specific)
|
|
55
|
+
const filterParams = {
|
|
56
|
+
...(0, list_command_utils_1.buildCommonFilters)(options),
|
|
57
|
+
};
|
|
58
|
+
// Pipeline-specific filters
|
|
59
|
+
if (options.accessModifier) {
|
|
60
|
+
filterParams.accessModifier = options.accessModifier;
|
|
61
|
+
}
|
|
62
|
+
if (options.isDefault !== undefined) {
|
|
63
|
+
filterParams.isDefault = (0, cli_constants_1.validateBoolean)(options.isDefault, 'is-default');
|
|
64
|
+
}
|
|
65
|
+
if (options.project) {
|
|
66
|
+
filterParams.project = options.project;
|
|
67
|
+
}
|
|
68
|
+
if (options.organization) {
|
|
69
|
+
filterParams.organization = options.organization;
|
|
70
|
+
}
|
|
71
|
+
if (options.pipelineName) {
|
|
72
|
+
filterParams.pipelineName = options.pipelineName;
|
|
73
|
+
}
|
|
74
|
+
// Display active filters
|
|
75
|
+
const activeFilters = {};
|
|
76
|
+
if (filterParams.id)
|
|
77
|
+
activeFilters.ID = filterParams.id;
|
|
78
|
+
if (filterParams.accessModifier)
|
|
79
|
+
activeFilters['Access Modifier'] = filterParams.accessModifier;
|
|
80
|
+
if (filterParams.isDefault !== undefined)
|
|
81
|
+
activeFilters['Is Default'] = filterParams.isDefault;
|
|
82
|
+
if (filterParams.isActive !== undefined)
|
|
83
|
+
activeFilters['Is Active'] = filterParams.isActive;
|
|
84
|
+
if (filterParams.project)
|
|
85
|
+
activeFilters.Project = filterParams.project;
|
|
86
|
+
if (filterParams.organization)
|
|
87
|
+
activeFilters.Organization = filterParams.organization;
|
|
88
|
+
if (filterParams.pipelineName)
|
|
89
|
+
activeFilters['Pipeline Name'] = filterParams.pipelineName;
|
|
90
|
+
if (Object.keys(activeFilters).length > 0) {
|
|
91
|
+
(0, output_utils_1.printInfo)('Active Filters');
|
|
92
|
+
(0, output_utils_1.printKeyValue)(activeFilters);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
(0, output_utils_1.printInfo)('No filters applied - fetching all pipelines');
|
|
96
|
+
}
|
|
97
|
+
(0, list_command_utils_1.displayPaginationInfo)(filterParams);
|
|
98
|
+
// Security warning for SSL verification disabled
|
|
99
|
+
(0, command_utils_1.printSslWarning)(options.verifySsl);
|
|
100
|
+
// Create authenticated API client
|
|
101
|
+
const client = (0, command_utils_1.createAuthenticatedClient)(options);
|
|
102
|
+
const config = client.getConfig();
|
|
103
|
+
// Query pipelines
|
|
104
|
+
console.log('');
|
|
105
|
+
(0, output_utils_1.printSection)('Querying Pipelines');
|
|
106
|
+
(0, output_utils_1.printInfo)('Sending request to API...');
|
|
107
|
+
const requestStart = Date.now();
|
|
108
|
+
const response = await client.get(config.api.pipelineListUrl, filterParams);
|
|
109
|
+
const requestDuration = Date.now() - requestStart;
|
|
110
|
+
// Handle response
|
|
111
|
+
const { items: pipelines, total, hasMore } = (0, output_utils_1.extractListResponse)(response, 'pipelines');
|
|
112
|
+
console.log('');
|
|
113
|
+
(0, output_utils_1.printSection)('✓ Query Complete');
|
|
114
|
+
// Display results summary
|
|
115
|
+
(0, list_command_utils_1.displayListResults)(pipelines, total, hasMore, 'Pipelines', requestDuration, filterParams);
|
|
116
|
+
// Display statistics
|
|
117
|
+
if (pipelines.length > 0 && options.format === 'table') {
|
|
118
|
+
const activeCount = pipelines.filter(p => p.isActive).length;
|
|
119
|
+
const defaultCount = pipelines.filter(p => p.isDefault).length;
|
|
120
|
+
console.log('');
|
|
121
|
+
(0, output_utils_1.printInfo)('Statistics');
|
|
122
|
+
(0, output_utils_1.printKeyValue)({
|
|
123
|
+
'Active Pipelines': `${activeCount}/${pipelines.length}`,
|
|
124
|
+
'Default Pipelines': `${defaultCount}/${pipelines.length}`,
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
// Output data in requested format
|
|
128
|
+
console.log('');
|
|
129
|
+
if (options.output) {
|
|
130
|
+
(0, output_utils_1.printInfo)('Saving to file', {
|
|
131
|
+
path: options.output,
|
|
132
|
+
format: options.format,
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
// Format output data
|
|
136
|
+
const outputPipelines = options.showProps ? pipelines : pipelines.map(p => ({
|
|
137
|
+
'ID': p.id,
|
|
138
|
+
'Project': p.project,
|
|
139
|
+
'Organization': p.organization,
|
|
140
|
+
'Name': p.pipelineName || 'N/A',
|
|
141
|
+
'Access Modifier': p.accessModifier || 'private',
|
|
142
|
+
'Default': p.isDefault ? 'Yes' : 'No',
|
|
143
|
+
'Active': p.isActive ? 'Yes' : 'No',
|
|
144
|
+
'Created At': p.createdAt || 'N/A',
|
|
145
|
+
}));
|
|
146
|
+
(0, output_utils_1.outputData)(outputPipelines, {
|
|
147
|
+
format: options.format,
|
|
148
|
+
file: options.output,
|
|
149
|
+
});
|
|
150
|
+
// Performance metrics
|
|
151
|
+
console.log('');
|
|
152
|
+
(0, output_utils_1.printKeyValue)({
|
|
153
|
+
'Execution ID': executionId,
|
|
154
|
+
'Total Duration': (0, cli_constants_1.formatDuration)(Date.now() - startTime),
|
|
155
|
+
});
|
|
156
|
+
console.log('');
|
|
157
|
+
}
|
|
158
|
+
catch (error) {
|
|
159
|
+
(0, error_handler_1.handleError)(error, error_handler_1.ERROR_CODES.API_REQUEST, {
|
|
160
|
+
debug: program.opts().debug,
|
|
161
|
+
exit: true,
|
|
162
|
+
context: {
|
|
163
|
+
command: 'list-pipelines',
|
|
164
|
+
executionId,
|
|
165
|
+
filters: options,
|
|
166
|
+
verifySsl: options.verifySsl,
|
|
167
|
+
},
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-pipelines.js","sourceRoot":"","sources":["../../src/commands/list-pipelines.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 { formatDuration, validateBoolean } from '../config/cli.constants';\nimport { PipelineListResponse, Pipeline } from '../types';\nimport { printCommandHeader, printSslWarning, createAuthenticatedClient } from '../utils/command-utils';\nimport { ERROR_CODES, handleError } from '../utils/error-handler';\nimport { buildCommonFilters, CommonFilterParams, displayPaginationInfo, displayListResults } from '../utils/list-command-utils';\nimport { outputData, extractListResponse, printInfo, printKeyValue, printSection } from '../utils/output-utils';\n\n/**\n * Query parameters for the pipeline list API endpoint.\n * Combines common filters (pagination, sort, access) with pipeline-specific filters.\n */\ninterface PipelineFilterParams extends CommonFilterParams {\n  accessModifier?: string;\n  isDefault?: boolean;\n\n  // Pipeline-specific filters\n  project?: string;\n  organization?: string;\n  pipelineName?: string;\n}\n\n/**\n * Registers the `list-pipelines` command with the CLI program.\n *\n * Queries pipelines with filters for project, organization, name,\n * access modifier, active/default status, plus pagination and sorting.\n *\n * @param program - The root Commander program instance to attach the command to.\n *\n * @example\n * ```bash\n * cli list-pipelines\n * cli list-pipelines --project my-app --is-active true\n * cli list-pipelines --organization my-org\n * cli list-pipelines --limit 50 --offset 100 --sort \"pipelineName:asc\"\n * cli list-pipelines --format json --output pipelines.json\n * ```\n */\nexport function listPipelines(program: Command): void {\n  program\n    .command('list-pipelines')\n    .description('Query pipelines with comprehensive filters')\n\n    // Common filter options\n    .option('--id <id>', 'Filter by pipeline ID (can specify multiple with commas)')\n    .option('--access-modifier <modifier>', 'Filter by access modifier (public/private)')\n    .option('--is-default <boolean>', 'Filter by default status (true/false)')\n    .option('--is-active <boolean>', 'Filter by active status (true/false)')\n    .option('--limit <number>', 'Maximum number of results (1-1000)', parseInt, 50)\n    .option('--offset <number>', 'Number of results to skip', parseInt, 0)\n    .option('--sort <sort>', 'Sort format: field:direction (e.g., pipelineName:asc, createdAt:desc)')\n\n    // Pipeline-specific filter options\n    .option('--project <project>', 'Filter by exact project name')\n    .option('--organization <organization>', 'Filter by exact organization name')\n    .option('--pipeline-name <name>', 'Filter by exact pipeline name')\n\n    // Output options\n    .option('-f, --format <format>', 'Output format (json, yaml, table, csv)', 'table')\n    .option('-o, --output <file>', 'Save output to file')\n    .option('--show-props', 'Include pipeline properties in output (json/yaml only)', false)\n    .option('--verify-ssl', 'Enable SSL certificate verification')\n    .option('--no-verify-ssl', 'Disable SSL certificate verification')\n\n    .action(async (options) => {\n      const executionId = printCommandHeader('List Pipelines', 'Query Pipelines');\n      const startTime = Date.now();\n\n      try {\n\n        // Build filter parameters (common + pipeline-specific)\n        const filterParams: PipelineFilterParams = {\n          ...buildCommonFilters(options),\n        };\n\n        // Pipeline-specific filters\n        if (options.accessModifier) {\n          filterParams.accessModifier = options.accessModifier;\n        }\n\n        if (options.isDefault !== undefined) {\n          filterParams.isDefault = validateBoolean(options.isDefault, 'is-default');\n        }\n\n        if (options.project) {\n          filterParams.project = options.project;\n        }\n\n        if (options.organization) {\n          filterParams.organization = options.organization;\n        }\n\n        if (options.pipelineName) {\n          filterParams.pipelineName = options.pipelineName;\n        }\n\n        // Display active filters\n        const activeFilters: Record<string, unknown> = {};\n        if (filterParams.id) activeFilters.ID = filterParams.id;\n        if (filterParams.accessModifier) activeFilters['Access Modifier'] = filterParams.accessModifier;\n        if (filterParams.isDefault !== undefined) activeFilters['Is Default'] = filterParams.isDefault;\n        if (filterParams.isActive !== undefined) activeFilters['Is Active'] = filterParams.isActive;\n        if (filterParams.project) activeFilters.Project = filterParams.project;\n        if (filterParams.organization) activeFilters.Organization = filterParams.organization;\n        if (filterParams.pipelineName) activeFilters['Pipeline Name'] = filterParams.pipelineName;\n\n        if (Object.keys(activeFilters).length > 0) {\n          printInfo('Active Filters');\n          printKeyValue(activeFilters);\n        } else {\n          printInfo('No filters applied - fetching all pipelines');\n        }\n\n        displayPaginationInfo(filterParams);\n\n        // Security warning for SSL verification disabled\n        printSslWarning(options.verifySsl);\n\n        // Create authenticated API client\n        const client = createAuthenticatedClient(options);\n        const config = client.getConfig();\n\n        // Query pipelines\n        console.log('');\n        printSection('Querying Pipelines');\n        printInfo('Sending request to API...');\n\n        const requestStart = Date.now();\n        const response = await client.get<PipelineListResponse>(\n          config.api.pipelineListUrl,\n          filterParams as Record<string, unknown>,\n        );\n        const requestDuration = Date.now() - requestStart;\n\n        // Handle response\n        const { items: pipelines, total, hasMore } = extractListResponse<Pipeline>(response, 'pipelines');\n\n        console.log('');\n        printSection('✓ Query Complete');\n\n        // Display results summary\n        displayListResults(pipelines, total, hasMore, 'Pipelines', requestDuration, filterParams);\n\n        // Display statistics\n        if (pipelines.length > 0 && options.format === 'table') {\n          const activeCount = pipelines.filter(p => p.isActive).length;\n          const defaultCount = pipelines.filter(p => p.isDefault).length;\n\n          console.log('');\n          printInfo('Statistics');\n          printKeyValue({\n            'Active Pipelines': `${activeCount}/${pipelines.length}`,\n            'Default Pipelines': `${defaultCount}/${pipelines.length}`,\n          });\n        }\n\n        // Output data in requested format\n        console.log('');\n        if (options.output) {\n          printInfo('Saving to file', {\n            path: options.output,\n            format: options.format,\n          });\n        }\n\n        // Format output data\n        const outputPipelines = options.showProps ? pipelines : pipelines.map(p => ({\n          'ID': p.id,\n          'Project': p.project,\n          'Organization': p.organization,\n          'Name': p.pipelineName || 'N/A',\n          'Access Modifier': p.accessModifier || 'private',\n          'Default': p.isDefault ? 'Yes' : 'No',\n          'Active': p.isActive ? 'Yes' : 'No',\n          'Created At': p.createdAt || 'N/A',\n        }));\n\n        outputData(outputPipelines, {\n          format: options.format,\n          file: options.output,\n        });\n\n        // Performance metrics\n        console.log('');\n        printKeyValue({\n          'Execution ID': executionId,\n          'Total Duration': formatDuration(Date.now() - startTime),\n        });\n\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: 'list-pipelines',\n            executionId,\n            filters: options,\n            verifySsl: options.verifySsl,\n          },\n        });\n      }\n    });\n}\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
/**
|
|
3
|
+
* Registers the `list-plugins` command with the CLI program.
|
|
4
|
+
*
|
|
5
|
+
* Queries plugins with filters for name, version, image tag,
|
|
6
|
+
* active 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-plugins
|
|
13
|
+
* cli list-plugins --name auth-plugin --is-active true
|
|
14
|
+
* cli list-plugins --version "^1.0.0"
|
|
15
|
+
* cli list-plugins --limit 50 --offset 100 --sort "name:asc"
|
|
16
|
+
* cli list-plugins --format json --output plugins.json
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
export declare function listPlugins(program: Command): void;
|
|
20
|
+
//# sourceMappingURL=list-plugins.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-plugins.d.ts","sourceRoot":"","sources":["../../src/commands/list-plugins.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAmBpC;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAiKlD"}
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Copyright 2026 Pipeline Builder Contributors
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.listPlugins = listPlugins;
|
|
6
|
+
const cli_constants_1 = require("../config/cli.constants");
|
|
7
|
+
const command_utils_1 = require("../utils/command-utils");
|
|
8
|
+
const error_handler_1 = require("../utils/error-handler");
|
|
9
|
+
const list_command_utils_1 = require("../utils/list-command-utils");
|
|
10
|
+
const output_utils_1 = require("../utils/output-utils");
|
|
11
|
+
/**
|
|
12
|
+
* Registers the `list-plugins` command with the CLI program.
|
|
13
|
+
*
|
|
14
|
+
* Queries plugins with filters for name, version, image tag,
|
|
15
|
+
* active status, plus pagination and sorting.
|
|
16
|
+
*
|
|
17
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```bash
|
|
21
|
+
* cli list-plugins
|
|
22
|
+
* cli list-plugins --name auth-plugin --is-active true
|
|
23
|
+
* cli list-plugins --version "^1.0.0"
|
|
24
|
+
* cli list-plugins --limit 50 --offset 100 --sort "name:asc"
|
|
25
|
+
* cli list-plugins --format json --output plugins.json
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
function listPlugins(program) {
|
|
29
|
+
program
|
|
30
|
+
.command('list-plugins')
|
|
31
|
+
.description('Query plugins with comprehensive filters')
|
|
32
|
+
// Common filter options
|
|
33
|
+
.option('--id <id>', 'Filter by plugin ID (can specify multiple with commas)')
|
|
34
|
+
.option('--is-active <boolean>', 'Filter by active status (true/false)')
|
|
35
|
+
.option('--limit <number>', 'Maximum number of results (1-1000)', parseInt, 50)
|
|
36
|
+
.option('--offset <number>', 'Number of results to skip', parseInt, 0)
|
|
37
|
+
.option('--sort <sort>', 'Sort format: field:direction (e.g., name:asc, createdAt:desc)')
|
|
38
|
+
// Plugin-specific filter options
|
|
39
|
+
.option('--name <name>', 'Filter by exact plugin name')
|
|
40
|
+
.option('--version <version>', 'Filter by version (supports semver, e.g., "^1.0.0")')
|
|
41
|
+
.option('--image-tag <tag>', 'Filter by Docker image tag')
|
|
42
|
+
// Output options
|
|
43
|
+
.option('-f, --format <format>', 'Output format (json, yaml, table, csv)', 'table')
|
|
44
|
+
.option('-o, --output <file>', 'Save output to file')
|
|
45
|
+
.option('--show-metadata', 'Include full metadata in output (json/yaml only)', false)
|
|
46
|
+
.option('--verify-ssl', 'Enable SSL certificate verification')
|
|
47
|
+
.option('--no-verify-ssl', 'Disable SSL certificate verification')
|
|
48
|
+
.action(async (options) => {
|
|
49
|
+
const executionId = (0, command_utils_1.printCommandHeader)('List Plugins', 'Query Plugins');
|
|
50
|
+
const startTime = Date.now();
|
|
51
|
+
try {
|
|
52
|
+
// Build filter parameters (common + plugin-specific)
|
|
53
|
+
const filterParams = {
|
|
54
|
+
...(0, list_command_utils_1.buildCommonFilters)(options),
|
|
55
|
+
};
|
|
56
|
+
// Plugin-specific filters
|
|
57
|
+
if (options.name) {
|
|
58
|
+
filterParams.name = options.name;
|
|
59
|
+
}
|
|
60
|
+
if (options.version) {
|
|
61
|
+
// Validate semver format
|
|
62
|
+
const versionPattern = /^(\^|~)?(\d+)\.(\d+)\.(\d+)(-[a-zA-Z0-9.-]+)?(\+[a-zA-Z0-9.-]+)?$/;
|
|
63
|
+
if (!versionPattern.test(options.version)) {
|
|
64
|
+
(0, output_utils_1.printWarning)(`Version "${options.version}" may not be valid semver format`);
|
|
65
|
+
}
|
|
66
|
+
filterParams.version = options.version;
|
|
67
|
+
}
|
|
68
|
+
if (options.imageTag) {
|
|
69
|
+
filterParams.imageTag = options.imageTag;
|
|
70
|
+
}
|
|
71
|
+
// Display active filters
|
|
72
|
+
const activeFilters = {};
|
|
73
|
+
if (filterParams.id)
|
|
74
|
+
activeFilters.ID = filterParams.id;
|
|
75
|
+
if (filterParams.isActive !== undefined)
|
|
76
|
+
activeFilters['Is Active'] = filterParams.isActive;
|
|
77
|
+
if (filterParams.name)
|
|
78
|
+
activeFilters.Name = filterParams.name;
|
|
79
|
+
if (filterParams.version)
|
|
80
|
+
activeFilters.Version = filterParams.version;
|
|
81
|
+
if (filterParams.imageTag)
|
|
82
|
+
activeFilters['Image Tag'] = filterParams.imageTag;
|
|
83
|
+
if (Object.keys(activeFilters).length > 0) {
|
|
84
|
+
(0, output_utils_1.printInfo)('Active Filters');
|
|
85
|
+
(0, output_utils_1.printKeyValue)(activeFilters);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
(0, output_utils_1.printInfo)('No filters applied - fetching all plugins');
|
|
89
|
+
}
|
|
90
|
+
(0, list_command_utils_1.displayPaginationInfo)(filterParams);
|
|
91
|
+
// Security warning for SSL verification disabled
|
|
92
|
+
(0, command_utils_1.printSslWarning)(options.verifySsl);
|
|
93
|
+
// Create authenticated API client
|
|
94
|
+
const client = (0, command_utils_1.createAuthenticatedClient)(options);
|
|
95
|
+
const config = client.getConfig();
|
|
96
|
+
// Query plugins
|
|
97
|
+
console.log('');
|
|
98
|
+
(0, output_utils_1.printSection)('Querying Plugins');
|
|
99
|
+
(0, output_utils_1.printInfo)('Sending request to API...');
|
|
100
|
+
const requestStart = Date.now();
|
|
101
|
+
const response = await client.get(config.api.pluginListUrl, filterParams);
|
|
102
|
+
const requestDuration = Date.now() - requestStart;
|
|
103
|
+
// Handle response
|
|
104
|
+
const { items: plugins, total, hasMore } = (0, output_utils_1.extractListResponse)(response, 'plugins');
|
|
105
|
+
console.log('');
|
|
106
|
+
(0, output_utils_1.printSection)('✓ Query Complete');
|
|
107
|
+
// Display results summary
|
|
108
|
+
(0, list_command_utils_1.displayListResults)(plugins, total, hasMore, 'Plugins', requestDuration, filterParams);
|
|
109
|
+
// Display statistics
|
|
110
|
+
if (plugins.length > 0 && options.format === 'table') {
|
|
111
|
+
const activeCount = plugins.filter(p => p.isActive).length;
|
|
112
|
+
const publicCount = plugins.filter(p => p.isPublic === true).length;
|
|
113
|
+
const totalSize = plugins.reduce((sum, p) => sum + (p.fileSize || 0), 0);
|
|
114
|
+
console.log('');
|
|
115
|
+
(0, output_utils_1.printInfo)('Statistics');
|
|
116
|
+
(0, output_utils_1.printKeyValue)({
|
|
117
|
+
'Active Plugins': `${activeCount}/${plugins.length}`,
|
|
118
|
+
'Public Plugins': `${publicCount}/${plugins.length}`,
|
|
119
|
+
'Total Size': (0, cli_constants_1.formatFileSize)(totalSize),
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
// Output data in requested format
|
|
123
|
+
console.log('');
|
|
124
|
+
if (options.output) {
|
|
125
|
+
(0, output_utils_1.printInfo)('Saving to file', {
|
|
126
|
+
path: options.output,
|
|
127
|
+
format: options.format,
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
// Format output data
|
|
131
|
+
const outputPlugins = options.showMetadata ? plugins : plugins.map(p => ({
|
|
132
|
+
'ID': p.id,
|
|
133
|
+
'Name': p.name,
|
|
134
|
+
'Version': p.version,
|
|
135
|
+
'Organization': p.organization,
|
|
136
|
+
'Active': p.isActive ? 'Yes' : 'No',
|
|
137
|
+
'Public': p.isPublic ? 'Yes' : 'No',
|
|
138
|
+
'Size': p.fileSize ? (0, cli_constants_1.formatFileSize)(p.fileSize) : 'N/A',
|
|
139
|
+
'Created At': p.createdAt || 'N/A',
|
|
140
|
+
}));
|
|
141
|
+
(0, output_utils_1.outputData)(outputPlugins, {
|
|
142
|
+
format: options.format,
|
|
143
|
+
file: options.output,
|
|
144
|
+
});
|
|
145
|
+
// Performance metrics
|
|
146
|
+
console.log('');
|
|
147
|
+
(0, output_utils_1.printKeyValue)({
|
|
148
|
+
'Execution ID': executionId,
|
|
149
|
+
'Total Duration': (0, cli_constants_1.formatDuration)(Date.now() - startTime),
|
|
150
|
+
});
|
|
151
|
+
console.log('');
|
|
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: 'list-plugins',
|
|
159
|
+
executionId,
|
|
160
|
+
filters: options,
|
|
161
|
+
verifySsl: options.verifySsl,
|
|
162
|
+
},
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-plugins.js","sourceRoot":"","sources":["../../src/commands/list-plugins.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 { formatDuration, formatFileSize } from '../config/cli.constants';\nimport { PluginListResponse, Plugin } from '../types';\nimport { printCommandHeader, printSslWarning, createAuthenticatedClient } from '../utils/command-utils';\nimport { ERROR_CODES, handleError } from '../utils/error-handler';\nimport { buildCommonFilters, CommonFilterParams, displayPaginationInfo, displayListResults } from '../utils/list-command-utils';\nimport { outputData, extractListResponse, printInfo, printKeyValue, printSection, printWarning } from '../utils/output-utils';\n\n/**\n * Query parameters for the plugin list API endpoint.\n * Combines common filters (pagination, sort) with plugin-specific filters.\n */\ninterface PluginFilterParams extends CommonFilterParams {\n  // Plugin-specific filters\n  name?: string;\n  version?: string;\n  imageTag?: string;\n}\n\n/**\n * Registers the `list-plugins` command with the CLI program.\n *\n * Queries plugins with filters for name, version, image tag,\n * active status, plus pagination and sorting.\n *\n * @param program - The root Commander program instance to attach the command to.\n *\n * @example\n * ```bash\n * cli list-plugins\n * cli list-plugins --name auth-plugin --is-active true\n * cli list-plugins --version \"^1.0.0\"\n * cli list-plugins --limit 50 --offset 100 --sort \"name:asc\"\n * cli list-plugins --format json --output plugins.json\n * ```\n */\nexport function listPlugins(program: Command): void {\n  program\n    .command('list-plugins')\n    .description('Query plugins with comprehensive filters')\n\n    // Common filter options\n    .option('--id <id>', 'Filter by plugin ID (can specify multiple with commas)')\n    .option('--is-active <boolean>', 'Filter by active status (true/false)')\n    .option('--limit <number>', 'Maximum number of results (1-1000)', parseInt, 50)\n    .option('--offset <number>', 'Number of results to skip', parseInt, 0)\n    .option('--sort <sort>', 'Sort format: field:direction (e.g., name:asc, createdAt:desc)')\n\n    // Plugin-specific filter options\n    .option('--name <name>', 'Filter by exact plugin name')\n    .option('--version <version>', 'Filter by version (supports semver, e.g., \"^1.0.0\")')\n    .option('--image-tag <tag>', 'Filter by Docker image tag')\n\n    // Output options\n    .option('-f, --format <format>', 'Output format (json, yaml, table, csv)', 'table')\n    .option('-o, --output <file>', 'Save output to file')\n    .option('--show-metadata', 'Include full metadata in output (json/yaml only)', false)\n    .option('--verify-ssl', 'Enable SSL certificate verification')\n    .option('--no-verify-ssl', 'Disable SSL certificate verification')\n\n    .action(async (options) => {\n      const executionId = printCommandHeader('List Plugins', 'Query Plugins');\n      const startTime = Date.now();\n\n      try {\n\n        // Build filter parameters (common + plugin-specific)\n        const filterParams: PluginFilterParams = {\n          ...buildCommonFilters(options),\n        };\n\n        // Plugin-specific filters\n        if (options.name) {\n          filterParams.name = options.name;\n        }\n\n        if (options.version) {\n          // Validate semver format\n          const versionPattern = /^(\\^|~)?(\\d+)\\.(\\d+)\\.(\\d+)(-[a-zA-Z0-9.-]+)?(\\+[a-zA-Z0-9.-]+)?$/;\n          if (!versionPattern.test(options.version)) {\n            printWarning(`Version \"${options.version}\" may not be valid semver format`);\n          }\n          filterParams.version = options.version;\n        }\n\n        if (options.imageTag) {\n          filterParams.imageTag = options.imageTag;\n        }\n\n        // Display active filters\n        const activeFilters: Record<string, unknown> = {};\n        if (filterParams.id) activeFilters.ID = filterParams.id;\n        if (filterParams.isActive !== undefined) activeFilters['Is Active'] = filterParams.isActive;\n        if (filterParams.name) activeFilters.Name = filterParams.name;\n        if (filterParams.version) activeFilters.Version = filterParams.version;\n        if (filterParams.imageTag) activeFilters['Image Tag'] = filterParams.imageTag;\n\n        if (Object.keys(activeFilters).length > 0) {\n          printInfo('Active Filters');\n          printKeyValue(activeFilters);\n        } else {\n          printInfo('No filters applied - fetching all plugins');\n        }\n\n        displayPaginationInfo(filterParams);\n\n        // Security warning for SSL verification disabled\n        printSslWarning(options.verifySsl);\n\n        // Create authenticated API client\n        const client = createAuthenticatedClient(options);\n        const config = client.getConfig();\n\n        // Query plugins\n        console.log('');\n        printSection('Querying Plugins');\n        printInfo('Sending request to API...');\n\n        const requestStart = Date.now();\n        const response = await client.get<PluginListResponse>(\n          config.api.pluginListUrl,\n          filterParams as Record<string, unknown>,\n        );\n        const requestDuration = Date.now() - requestStart;\n\n        // Handle response\n        const { items: plugins, total, hasMore } = extractListResponse<Plugin>(response, 'plugins');\n\n        console.log('');\n        printSection('✓ Query Complete');\n\n        // Display results summary\n        displayListResults(plugins, total, hasMore, 'Plugins', requestDuration, filterParams);\n\n        // Display statistics\n        if (plugins.length > 0 && options.format === 'table') {\n          const activeCount = plugins.filter(p => p.isActive).length;\n          const publicCount = plugins.filter(p => p.isPublic === true).length;\n          const totalSize = plugins.reduce((sum, p) => sum + (p.fileSize || 0), 0);\n\n          console.log('');\n          printInfo('Statistics');\n          printKeyValue({\n            'Active Plugins': `${activeCount}/${plugins.length}`,\n            'Public Plugins': `${publicCount}/${plugins.length}`,\n            'Total Size': formatFileSize(totalSize),\n          });\n        }\n\n        // Output data in requested format\n        console.log('');\n        if (options.output) {\n          printInfo('Saving to file', {\n            path: options.output,\n            format: options.format,\n          });\n        }\n\n        // Format output data\n        const outputPlugins = options.showMetadata ? plugins : plugins.map(p => ({\n          'ID': p.id,\n          'Name': p.name,\n          'Version': p.version,\n          'Organization': p.organization,\n          'Active': p.isActive ? 'Yes' : 'No',\n          'Public': p.isPublic ? 'Yes' : 'No',\n          'Size': p.fileSize ? formatFileSize(p.fileSize) : 'N/A',\n          'Created At': p.createdAt || 'N/A',\n        }));\n\n        outputData(outputPlugins, {\n          format: options.format,\n          file: options.output,\n        });\n\n        // Performance metrics\n        console.log('');\n        printKeyValue({\n          'Execution ID': executionId,\n          'Total Duration': formatDuration(Date.now() - startTime),\n        });\n\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: 'list-plugins',\n            executionId,\n            filters: options,\n            verifySsl: options.verifySsl,\n          },\n        });\n      }\n    });\n}\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
/**
|
|
3
|
+
* Registers the `login` command with the CLI program.
|
|
4
|
+
*
|
|
5
|
+
* Authenticates against the platform API and prints an export statement
|
|
6
|
+
* for `PLATFORM_TOKEN` on success. Does NOT require `PLATFORM_TOKEN`
|
|
7
|
+
* to be set beforehand (unlike other commands).
|
|
8
|
+
*
|
|
9
|
+
* @param program - The root Commander program instance to attach the command to.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```bash
|
|
13
|
+
* pipeline-manager login --identifier admin@example.com --password secret
|
|
14
|
+
* pipeline-manager login -u admin@example.com -p secret
|
|
15
|
+
* pipeline-manager login -u admin@example.com -p secret --url https://myhost:8443
|
|
16
|
+
* eval $(pipeline-manager login -u admin@example.com -p secret --quiet)
|
|
17
|
+
* pipeline-manager login --refresh <refresh-token>
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export declare function login(program: Command): void;
|
|
21
|
+
//# sourceMappingURL=login.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../src/commands/login.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAoBpC;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,KAAK,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA8K5C"}
|