@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,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"}