geni-bioinfo 0.1.4 → 0.1.6
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/dist/commands/costs.d.ts +2 -0
- package/dist/commands/costs.js +111 -0
- package/dist/commands/queue.js +49 -1
- package/dist/commands/submission.js +21 -1
- package/dist/commands/workflow-version.d.ts +2 -0
- package/dist/commands/workflow-version.js +17 -0
- package/dist/format.d.ts +3 -0
- package/dist/format.js +50 -23
- package/dist/index.js +5 -3
- package/dist/templates/setup.yaml +2 -1
- package/package.json +1 -1
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.costsCommand = void 0;
|
|
4
|
+
const commander_1 = require("commander");
|
|
5
|
+
const auth_1 = require("../auth");
|
|
6
|
+
const format_js_1 = require("../format.js");
|
|
7
|
+
const DATE_RE = /^\d{4}-\d{2}-\d{2}$/;
|
|
8
|
+
function parseDate(value) {
|
|
9
|
+
if (!DATE_RE.test(value))
|
|
10
|
+
throw new Error(`Expected YYYY-MM-DD, got "${value}"`);
|
|
11
|
+
return value;
|
|
12
|
+
}
|
|
13
|
+
function addCommonOptions(cmd) {
|
|
14
|
+
return cmd
|
|
15
|
+
.option('--start-date <YYYY-MM-DD>', 'Start date (UTC, inclusive)', parseDate)
|
|
16
|
+
.option('--end-date <YYYY-MM-DD>', 'End date (UTC, inclusive)', parseDate)
|
|
17
|
+
.option('--submission-status <status>', 'Filter by submission status (e.g. SUCCEEDED, FAILED, RUNNING)');
|
|
18
|
+
}
|
|
19
|
+
function buildParams(opts) {
|
|
20
|
+
const params = new URLSearchParams();
|
|
21
|
+
if (opts.startDate)
|
|
22
|
+
params.set('from', `${opts.startDate}T00:00:00.000Z`);
|
|
23
|
+
if (opts.endDate) {
|
|
24
|
+
const d = new Date(`${opts.endDate}T00:00:00.000Z`);
|
|
25
|
+
d.setUTCDate(d.getUTCDate() + 1);
|
|
26
|
+
params.set('to', d.toISOString());
|
|
27
|
+
}
|
|
28
|
+
if (opts.submissionStatus)
|
|
29
|
+
params.set('submissionStatus', opts.submissionStatus);
|
|
30
|
+
return params;
|
|
31
|
+
}
|
|
32
|
+
function qs(params) {
|
|
33
|
+
const s = params.toString();
|
|
34
|
+
return s ? `?${s}` : '';
|
|
35
|
+
}
|
|
36
|
+
exports.costsCommand = new commander_1.Command('costs')
|
|
37
|
+
.description('View cost analytics');
|
|
38
|
+
addCommonOptions(exports.costsCommand
|
|
39
|
+
.command('summary')
|
|
40
|
+
.description('Overall cost totals for the tenant')
|
|
41
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (opts) => {
|
|
42
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/summary${qs(buildParams(opts))}`));
|
|
43
|
+
(0, format_js_1.formatOutput)(data, opts.format, format_js_1.analyticsSummaryColumns);
|
|
44
|
+
});
|
|
45
|
+
addCommonOptions(exports.costsCommand
|
|
46
|
+
.command('submission')
|
|
47
|
+
.description('Per-submission cost breakdown')
|
|
48
|
+
.argument('[ids...]', 'Filter by submission IDs')
|
|
49
|
+
.option('--limit <n>', 'Max results (1–200)', '50')
|
|
50
|
+
.option('--offset <n>', 'Pagination offset', '0')
|
|
51
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (ids, opts) => {
|
|
52
|
+
const params = buildParams(opts);
|
|
53
|
+
ids.forEach(id => params.append('id', id));
|
|
54
|
+
params.set('limit', opts.limit);
|
|
55
|
+
params.set('offset', opts.offset);
|
|
56
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/submission${qs(params)}`));
|
|
57
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.analyticsBySubmissionColumns);
|
|
58
|
+
});
|
|
59
|
+
addCommonOptions(exports.costsCommand
|
|
60
|
+
.command('environment')
|
|
61
|
+
.description('Cost grouped by environment')
|
|
62
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (opts) => {
|
|
63
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/environment${qs(buildParams(opts))}`));
|
|
64
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.analyticsByEnvironmentColumns);
|
|
65
|
+
});
|
|
66
|
+
addCommonOptions(exports.costsCommand
|
|
67
|
+
.command('queue')
|
|
68
|
+
.description('Cost grouped by queue')
|
|
69
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (opts) => {
|
|
70
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/queue${qs(buildParams(opts))}`));
|
|
71
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.analyticsByQueueColumns);
|
|
72
|
+
});
|
|
73
|
+
addCommonOptions(exports.costsCommand
|
|
74
|
+
.command('instance-type')
|
|
75
|
+
.description('Cost grouped by EC2 instance type and market type')
|
|
76
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (opts) => {
|
|
77
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/instance-type${qs(buildParams(opts))}`));
|
|
78
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.analyticsByInstanceTypeColumns);
|
|
79
|
+
});
|
|
80
|
+
addCommonOptions(exports.costsCommand
|
|
81
|
+
.command('engine')
|
|
82
|
+
.description('Cost grouped by engine')
|
|
83
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (opts) => {
|
|
84
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/engine${qs(buildParams(opts))}`));
|
|
85
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.costsByEngineColumns);
|
|
86
|
+
});
|
|
87
|
+
addCommonOptions(exports.costsCommand
|
|
88
|
+
.command('execution-mode')
|
|
89
|
+
.description('Cost grouped by execution mode (spot / on-demand)')
|
|
90
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (opts) => {
|
|
91
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/execution-mode${qs(buildParams(opts))}`));
|
|
92
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.costsByExecutionModeColumns);
|
|
93
|
+
});
|
|
94
|
+
addCommonOptions(exports.costsCommand
|
|
95
|
+
.command('over-time')
|
|
96
|
+
.description('Cost bucketed by time period')
|
|
97
|
+
.addOption(new commander_1.Option('--interval <interval>', 'Time bucket size').choices(['day', 'week', 'month']).default('day'))
|
|
98
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))).action(async (opts) => {
|
|
99
|
+
const params = buildParams(opts);
|
|
100
|
+
params.set('interval', opts.interval);
|
|
101
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/costs/over-time${qs(params)}`));
|
|
102
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.analyticsOverTimeColumns);
|
|
103
|
+
});
|
|
104
|
+
exports.costsCommand
|
|
105
|
+
.command('sync')
|
|
106
|
+
.description('Trigger a CUR actual-cost sync')
|
|
107
|
+
.action(async () => {
|
|
108
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)('/costs/sync'), { method: 'POST' });
|
|
109
|
+
console.log(`Sync job enqueued: ${data.jobId}`);
|
|
110
|
+
});
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"costs.js","sourceRoot":"","sources":["../../src/commands/costs.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command, Option } from 'commander'\nimport { apiUrl, fetchJson } from '../auth'\nimport {\n  formatOutput,\n  analyticsSummaryColumns,\n  analyticsBySubmissionColumns,\n  analyticsByEnvironmentColumns,\n  analyticsByQueueColumns,\n  analyticsByInstanceTypeColumns,\n  analyticsOverTimeColumns,\n  costsByEngineColumns,\n  costsByExecutionModeColumns,\n  type OutputFormat,\n} from '../format.js'\n\ntype BaseOpts = {\n  startDate?: string\n  endDate?: string\n  submissionStatus?: string\n}\n\nconst DATE_RE = /^\\d{4}-\\d{2}-\\d{2}$/\n\nfunction parseDate(value: string): string {\n  if (!DATE_RE.test(value)) throw new Error(`Expected YYYY-MM-DD, got \"${value}\"`)\n  return value\n}\n\nfunction addCommonOptions(cmd: Command): Command {\n  return cmd\n    .option('--start-date <YYYY-MM-DD>', 'Start date (UTC, inclusive)', parseDate)\n    .option('--end-date <YYYY-MM-DD>', 'End date (UTC, inclusive)', parseDate)\n    .option('--submission-status <status>', 'Filter by submission status (e.g. SUCCEEDED, FAILED, RUNNING)')\n}\n\nfunction buildParams(opts: BaseOpts): URLSearchParams {\n  const params = new URLSearchParams()\n\n  if (opts.startDate) params.set('from', `${opts.startDate}T00:00:00.000Z`)\n\n  if (opts.endDate) {\n    const d = new Date(`${opts.endDate}T00:00:00.000Z`)\n    d.setUTCDate(d.getUTCDate() + 1)\n    params.set('to', d.toISOString())\n  }\n\n  if (opts.submissionStatus) params.set('submissionStatus', opts.submissionStatus)\n  return params\n}\n\nfunction qs(params: URLSearchParams): string {\n  const s = params.toString()\n  return s ? `?${s}` : ''\n}\n\nexport const costsCommand = new Command('costs')\n  .description('View cost analytics')\n\naddCommonOptions(\n  costsCommand\n    .command('summary')\n    .description('Overall cost totals for the tenant')\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (opts: BaseOpts & { format: OutputFormat }) => {\n  const data = await fetchJson(apiUrl(`/costs/summary${qs(buildParams(opts))}`))\n  formatOutput(data, opts.format, analyticsSummaryColumns)\n})\n\naddCommonOptions(\n  costsCommand\n    .command('submission')\n    .description('Per-submission cost breakdown')\n    .argument('[ids...]', 'Filter by submission IDs')\n    .option('--limit <n>', 'Max results (1–200)', '50')\n    .option('--offset <n>', 'Pagination offset', '0')\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (ids: string[], opts: BaseOpts & { limit: string; offset: string; format: OutputFormat }) => {\n  const params = buildParams(opts)\n  ids.forEach(id => params.append('id', id))\n  params.set('limit', opts.limit)\n  params.set('offset', opts.offset)\n  const data = await fetchJson(apiUrl(`/costs/submission${qs(params)}`)) as { items: unknown[] }\n  formatOutput(opts.format === 'json' ? data : data.items, opts.format, analyticsBySubmissionColumns)\n})\n\naddCommonOptions(\n  costsCommand\n    .command('environment')\n    .description('Cost grouped by environment')\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (opts: BaseOpts & { format: OutputFormat }) => {\n  const data = await fetchJson(apiUrl(`/costs/environment${qs(buildParams(opts))}`)) as { items: unknown[] }\n  formatOutput(opts.format === 'json' ? data : data.items, opts.format, analyticsByEnvironmentColumns)\n})\n\naddCommonOptions(\n  costsCommand\n    .command('queue')\n    .description('Cost grouped by queue')\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (opts: BaseOpts & { format: OutputFormat }) => {\n  const data = await fetchJson(apiUrl(`/costs/queue${qs(buildParams(opts))}`)) as { items: unknown[] }\n  formatOutput(opts.format === 'json' ? data : data.items, opts.format, analyticsByQueueColumns)\n})\n\naddCommonOptions(\n  costsCommand\n    .command('instance-type')\n    .description('Cost grouped by EC2 instance type and market type')\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (opts: BaseOpts & { format: OutputFormat }) => {\n  const data = await fetchJson(apiUrl(`/costs/instance-type${qs(buildParams(opts))}`)) as { items: unknown[] }\n  formatOutput(opts.format === 'json' ? data : data.items, opts.format, analyticsByInstanceTypeColumns)\n})\n\naddCommonOptions(\n  costsCommand\n    .command('engine')\n    .description('Cost grouped by engine')\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (opts: BaseOpts & { format: OutputFormat }) => {\n  const data = await fetchJson(apiUrl(`/costs/engine${qs(buildParams(opts))}`)) as { items: unknown[] }\n  formatOutput(opts.format === 'json' ? data : data.items, opts.format, costsByEngineColumns)\n})\n\naddCommonOptions(\n  costsCommand\n    .command('execution-mode')\n    .description('Cost grouped by execution mode (spot / on-demand)')\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (opts: BaseOpts & { format: OutputFormat }) => {\n  const data = await fetchJson(apiUrl(`/costs/execution-mode${qs(buildParams(opts))}`)) as { items: unknown[] }\n  formatOutput(opts.format === 'json' ? data : data.items, opts.format, costsByExecutionModeColumns)\n})\n\naddCommonOptions(\n  costsCommand\n    .command('over-time')\n    .description('Cost bucketed by time period')\n    .addOption(new Option('--interval <interval>', 'Time bucket size').choices(['day', 'week', 'month']).default('day'))\n    .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n).action(async (opts: BaseOpts & { interval: string; format: OutputFormat }) => {\n  const params = buildParams(opts)\n  params.set('interval', opts.interval)\n  const data = await fetchJson(apiUrl(`/costs/over-time${qs(params)}`)) as { items: unknown[] }\n  formatOutput(opts.format === 'json' ? data : data.items, opts.format, analyticsOverTimeColumns)\n})\n\ncostsCommand\n  .command('sync')\n  .description('Trigger a CUR actual-cost sync')\n  .action(async () => {\n    const data = await fetchJson(apiUrl('/costs/sync'), { method: 'POST' }) as { jobId: string }\n    console.log(`Sync job enqueued: ${data.jobId}`)\n  })\n"]}
|
package/dist/commands/queue.js
CHANGED
|
@@ -31,6 +31,39 @@ exports.queueCommand
|
|
|
31
31
|
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/admin/queues/${id}${query}`));
|
|
32
32
|
(0, format_js_1.formatOutput)(data, opts.format, format_js_1.queueColumns);
|
|
33
33
|
});
|
|
34
|
+
exports.queueCommand
|
|
35
|
+
.command('update <id>')
|
|
36
|
+
.description('Update queue with the latest AMI and optionally new IOPS/throughput settings')
|
|
37
|
+
.option('--volume-iops <n>', 'IOPS for the gp3 EBS volume (3000-80000)')
|
|
38
|
+
.option('--volume-throughput <n>', 'Throughput in MiB/s for the gp3 EBS volume (125-2000)')
|
|
39
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))
|
|
40
|
+
.action(async (id, opts) => {
|
|
41
|
+
const volumeIops = opts.volumeIops !== undefined ? parseInt(opts.volumeIops, 10) : undefined;
|
|
42
|
+
const volumeThroughput = opts.volumeThroughput !== undefined ? parseInt(opts.volumeThroughput, 10) : undefined;
|
|
43
|
+
if (volumeIops !== undefined && (volumeIops < 3000 || volumeIops > 80000)) {
|
|
44
|
+
throw (0, errors_1.invalidArgument)('--volume-iops must be between 3000 and 80000');
|
|
45
|
+
}
|
|
46
|
+
if (volumeThroughput !== undefined && (volumeThroughput < 125 || volumeThroughput > 2000)) {
|
|
47
|
+
throw (0, errors_1.invalidArgument)('--volume-throughput must be between 125 and 2000');
|
|
48
|
+
}
|
|
49
|
+
if (volumeIops !== undefined && volumeThroughput !== undefined && volumeThroughput > volumeIops * 0.25) {
|
|
50
|
+
throw (0, errors_1.invalidArgument)('--volume-throughput must not exceed --volume-iops × 0.25 (gp3 ratio rule)');
|
|
51
|
+
}
|
|
52
|
+
const query = process.env.GENI_TENANT_ID ? `?tenantId=${process.env.GENI_TENANT_ID}` : '';
|
|
53
|
+
const body = {};
|
|
54
|
+
if (process.env.GENI_TENANT_ID)
|
|
55
|
+
body.tenantId = process.env.GENI_TENANT_ID;
|
|
56
|
+
if (volumeIops !== undefined)
|
|
57
|
+
body.volumeIops = volumeIops;
|
|
58
|
+
if (volumeThroughput !== undefined)
|
|
59
|
+
body.volumeThroughput = volumeThroughput;
|
|
60
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/admin/queues/${id}/update-ami${query}`), {
|
|
61
|
+
method: 'POST',
|
|
62
|
+
headers: { 'Content-Type': 'application/json' },
|
|
63
|
+
body: JSON.stringify(body),
|
|
64
|
+
});
|
|
65
|
+
(0, format_js_1.formatOutput)(data, opts.format, format_js_1.queueColumns);
|
|
66
|
+
});
|
|
34
67
|
exports.queueCommand
|
|
35
68
|
.command('delete <id>')
|
|
36
69
|
.description('Delete a queue')
|
|
@@ -51,6 +84,8 @@ exports.queueCommand
|
|
|
51
84
|
.option('--instance-type <type>', 'Instance type (repeatable)', (val, acc) => [...acc, val], [])
|
|
52
85
|
.option('--max-vcpus <n>', 'Maximum vCPUs', '256')
|
|
53
86
|
.option('--storage-size-gb <n>', 'Initial size in GB of the EBS-autoscale pool (per-instance)', '100')
|
|
87
|
+
.option('--volume-iops <n>', 'IOPS for the gp3 EBS volume (3000-80000)', '4000')
|
|
88
|
+
.option('--volume-throughput <n>', 'Throughput in MiB/s for the gp3 EBS volume (125-2000)', '1000')
|
|
54
89
|
.option('--enable-ebs-autoscaling <bool>', 'Mount EBS-autoscale volume at /var/lib/docker on instance boot (true or false)', 'true')
|
|
55
90
|
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))
|
|
56
91
|
.action(async (opts) => {
|
|
@@ -60,6 +95,17 @@ exports.queueCommand
|
|
|
60
95
|
if (opts.enableEbsAutoscaling !== 'true' && opts.enableEbsAutoscaling !== 'false') {
|
|
61
96
|
throw (0, errors_1.invalidArgument)('Invalid --enable-ebs-autoscaling value. Expected "true" or "false".');
|
|
62
97
|
}
|
|
98
|
+
const volumeIops = parseInt(opts.volumeIops, 10);
|
|
99
|
+
const volumeThroughput = parseInt(opts.volumeThroughput, 10);
|
|
100
|
+
if (volumeIops < 3000 || volumeIops > 80000) {
|
|
101
|
+
throw (0, errors_1.invalidArgument)('--volume-iops must be between 3000 and 80000');
|
|
102
|
+
}
|
|
103
|
+
if (volumeThroughput < 125 || volumeThroughput > 2000) {
|
|
104
|
+
throw (0, errors_1.invalidArgument)('--volume-throughput must be between 125 and 2000');
|
|
105
|
+
}
|
|
106
|
+
if (volumeThroughput > volumeIops * 0.25) {
|
|
107
|
+
throw (0, errors_1.invalidArgument)('--volume-throughput must not exceed --volume-iops × 0.25 (gp3 ratio rule)');
|
|
108
|
+
}
|
|
63
109
|
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)('/admin/queues'), {
|
|
64
110
|
method: 'POST',
|
|
65
111
|
headers: { 'Content-Type': 'application/json' },
|
|
@@ -70,10 +116,12 @@ exports.queueCommand
|
|
|
70
116
|
...(opts.instanceType.length > 0 ? { instanceTypes: opts.instanceType } : {}),
|
|
71
117
|
maxvCpus: parseInt(opts.maxVcpus, 10),
|
|
72
118
|
storageSizeGb: parseInt(opts.storageSizeGb, 10),
|
|
119
|
+
volumeIops,
|
|
120
|
+
volumeThroughput,
|
|
73
121
|
ebsAutoscalingEnabled: opts.enableEbsAutoscaling === 'true',
|
|
74
122
|
...(process.env.GENI_TENANT_ID ? { tenantId: process.env.GENI_TENANT_ID } : {}),
|
|
75
123
|
}),
|
|
76
124
|
});
|
|
77
125
|
(0, format_js_1.formatOutput)(data, opts.format, format_js_1.queueColumns);
|
|
78
126
|
});
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../src/commands/queue.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command, Option } from 'commander'\nimport { apiUrl, fetchJson } from '../auth'\nimport { invalidArgument } from '../errors'\nimport { formatOutput, queueColumns, type OutputFormat } from '../format.js'\n\nexport const queueCommand = new Command('queue')\n  .description('Manage queues')\n\nqueueCommand\n  .command('list')\n  .description('List queues')\n  .option('--status <status>', 'Filter by status (e.g. ACTIVE, PENDING, FAILED, DELETED)')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: { status?: string; format: OutputFormat }) => {\n    const params = new URLSearchParams()\n    if (opts.status) params.set('status', opts.status.toUpperCase())\n    if (process.env.GENI_TENANT_ID) params.set('tenantId', process.env.GENI_TENANT_ID)\n    const query = params.size ? `?${params}` : ''\n    const data = await fetchJson(apiUrl(`/admin/queues${query}`)) as { items: unknown[] }\n    formatOutput(opts.format === 'json' ? data : data.items, opts.format, queueColumns)\n  })\n\nqueueCommand\n  .command('get <id>')\n  .description('Get a queue by ID')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (id: string, opts: { format: OutputFormat }) => {\n    const query = process.env.GENI_TENANT_ID ? `?tenantId=${process.env.GENI_TENANT_ID}` : ''\n    const data = await fetchJson(apiUrl(`/admin/queues/${id}${query}`))\n    formatOutput(data, opts.format, queueColumns)\n  })\n\nqueueCommand\n  .command('delete <id>')\n  .description('Delete a queue')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (id: string, opts: { format: OutputFormat }) => {\n    const query = process.env.GENI_TENANT_ID ? `?tenantId=${process.env.GENI_TENANT_ID}` : ''\n    const data = await fetchJson(apiUrl(`/admin/queues/${id}${query}`), {\n      method: 'DELETE',\n    })\n    formatOutput(data, opts.format, queueColumns)\n  })\n\nqueueCommand\n  .command('create')\n  .description('Create a queue')\n  .requiredOption('--name <name>', 'Queue name')\n  .requiredOption('--environment-id <id>', 'Environment ID')\n  .option('--execution-mode <mode>', 'Execution mode (spot or on-demand)', 'spot')\n  .option('--instance-type <type>', 'Instance type (repeatable)', (val, acc: string[]) => [...acc, val], [] as string[])\n  .option('--max-vcpus <n>', 'Maximum vCPUs', '256')\n  .option('--storage-size-gb <n>', 'Initial size in GB of the EBS-autoscale pool (per-instance)', '100')\n  .option('--enable-ebs-autoscaling <bool>', 'Mount EBS-autoscale volume at /var/lib/docker on instance boot (true or false)', 'true')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: {\n    name: string\n    environmentId: string\n    executionMode: string\n    instanceType: string[]\n    maxVcpus: string\n    storageSizeGb: string\n    enableEbsAutoscaling: string\n    format: OutputFormat\n  }) => {\n    if (opts.executionMode !== 'spot' && opts.executionMode !== 'on-demand') {\n      throw invalidArgument(\n        'Invalid --execution-mode value. Expected \"spot\" or \"on-demand\".',\n      )\n    }\n\n    if (opts.enableEbsAutoscaling !== 'true' && opts.enableEbsAutoscaling !== 'false') {\n      throw invalidArgument(\n        'Invalid --enable-ebs-autoscaling value. Expected \"true\" or \"false\".',\n      )\n    }\n\n    const data = await fetchJson(apiUrl('/admin/queues'), {\n      method: 'POST',\n      headers: { 'Content-Type': 'application/json' },\n      body: JSON.stringify({\n        name: opts.name,\n        environmentId: opts.environmentId,\n        executionMode: opts.executionMode,\n        ...(opts.instanceType.length > 0 ? { instanceTypes: opts.instanceType } : {}),\n        maxvCpus: parseInt(opts.maxVcpus, 10),\n        storageSizeGb: parseInt(opts.storageSizeGb, 10),\n        ebsAutoscalingEnabled: opts.enableEbsAutoscaling === 'true',\n        ...(process.env.GENI_TENANT_ID ? { tenantId: process.env.GENI_TENANT_ID } : {}),\n      }),\n    })\n    formatOutput(data, opts.format, queueColumns)\n  })\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../src/commands/queue.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command, Option } from 'commander'\nimport { apiUrl, fetchJson } from '../auth'\nimport { invalidArgument } from '../errors'\nimport { formatOutput, queueColumns, type OutputFormat } from '../format.js'\n\nexport const queueCommand = new Command('queue')\n  .description('Manage queues')\n\nqueueCommand\n  .command('list')\n  .description('List queues')\n  .option('--status <status>', 'Filter by status (e.g. ACTIVE, PENDING, FAILED, DELETED)')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: { status?: string; format: OutputFormat }) => {\n    const params = new URLSearchParams()\n    if (opts.status) params.set('status', opts.status.toUpperCase())\n    if (process.env.GENI_TENANT_ID) params.set('tenantId', process.env.GENI_TENANT_ID)\n    const query = params.size ? `?${params}` : ''\n    const data = await fetchJson(apiUrl(`/admin/queues${query}`)) as { items: unknown[] }\n    formatOutput(opts.format === 'json' ? data : data.items, opts.format, queueColumns)\n  })\n\nqueueCommand\n  .command('get <id>')\n  .description('Get a queue by ID')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (id: string, opts: { format: OutputFormat }) => {\n    const query = process.env.GENI_TENANT_ID ? `?tenantId=${process.env.GENI_TENANT_ID}` : ''\n    const data = await fetchJson(apiUrl(`/admin/queues/${id}${query}`))\n    formatOutput(data, opts.format, queueColumns)\n  })\n\nqueueCommand\n  .command('update <id>')\n  .description('Update queue with the latest AMI and optionally new IOPS/throughput settings')\n  .option('--volume-iops <n>', 'IOPS for the gp3 EBS volume (3000-80000)')\n  .option('--volume-throughput <n>', 'Throughput in MiB/s for the gp3 EBS volume (125-2000)')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (id: string, opts: { volumeIops?: string; volumeThroughput?: string; format: OutputFormat }) => {\n    const volumeIops = opts.volumeIops !== undefined ? parseInt(opts.volumeIops, 10) : undefined\n    const volumeThroughput = opts.volumeThroughput !== undefined ? parseInt(opts.volumeThroughput, 10) : undefined\n\n    if (volumeIops !== undefined && (volumeIops < 3000 || volumeIops > 80000)) {\n      throw invalidArgument('--volume-iops must be between 3000 and 80000')\n    }\n    if (volumeThroughput !== undefined && (volumeThroughput < 125 || volumeThroughput > 2000)) {\n      throw invalidArgument('--volume-throughput must be between 125 and 2000')\n    }\n    if (volumeIops !== undefined && volumeThroughput !== undefined && volumeThroughput > volumeIops * 0.25) {\n      throw invalidArgument('--volume-throughput must not exceed --volume-iops × 0.25 (gp3 ratio rule)')\n    }\n\n    const query = process.env.GENI_TENANT_ID ? `?tenantId=${process.env.GENI_TENANT_ID}` : ''\n    const body: Record<string, unknown> = {}\n    if (process.env.GENI_TENANT_ID) body.tenantId = process.env.GENI_TENANT_ID\n    if (volumeIops !== undefined) body.volumeIops = volumeIops\n    if (volumeThroughput !== undefined) body.volumeThroughput = volumeThroughput\n\n    const data = await fetchJson(apiUrl(`/admin/queues/${id}/update-ami${query}`), {\n      method: 'POST',\n      headers: { 'Content-Type': 'application/json' },\n      body: JSON.stringify(body),\n    })\n    formatOutput(data, opts.format, queueColumns)\n  })\n\nqueueCommand\n  .command('delete <id>')\n  .description('Delete a queue')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (id: string, opts: { format: OutputFormat }) => {\n    const query = process.env.GENI_TENANT_ID ? `?tenantId=${process.env.GENI_TENANT_ID}` : ''\n    const data = await fetchJson(apiUrl(`/admin/queues/${id}${query}`), {\n      method: 'DELETE',\n    })\n    formatOutput(data, opts.format, queueColumns)\n  })\n\nqueueCommand\n  .command('create')\n  .description('Create a queue')\n  .requiredOption('--name <name>', 'Queue name')\n  .requiredOption('--environment-id <id>', 'Environment ID')\n  .option('--execution-mode <mode>', 'Execution mode (spot or on-demand)', 'spot')\n  .option('--instance-type <type>', 'Instance type (repeatable)', (val, acc: string[]) => [...acc, val], [] as string[])\n  .option('--max-vcpus <n>', 'Maximum vCPUs', '256')\n  .option('--storage-size-gb <n>', 'Initial size in GB of the EBS-autoscale pool (per-instance)', '100')\n  .option('--volume-iops <n>', 'IOPS for the gp3 EBS volume (3000-80000)', '4000')\n  .option('--volume-throughput <n>', 'Throughput in MiB/s for the gp3 EBS volume (125-2000)', '1000')\n  .option('--enable-ebs-autoscaling <bool>', 'Mount EBS-autoscale volume at /var/lib/docker on instance boot (true or false)', 'true')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: {\n    name: string\n    environmentId: string\n    executionMode: string\n    instanceType: string[]\n    maxVcpus: string\n    storageSizeGb: string\n    volumeIops: string\n    volumeThroughput: string\n    enableEbsAutoscaling: string\n    format: OutputFormat\n  }) => {\n    if (opts.executionMode !== 'spot' && opts.executionMode !== 'on-demand') {\n      throw invalidArgument(\n        'Invalid --execution-mode value. Expected \"spot\" or \"on-demand\".',\n      )\n    }\n\n    if (opts.enableEbsAutoscaling !== 'true' && opts.enableEbsAutoscaling !== 'false') {\n      throw invalidArgument(\n        'Invalid --enable-ebs-autoscaling value. Expected \"true\" or \"false\".',\n      )\n    }\n\n    const volumeIops = parseInt(opts.volumeIops, 10)\n    const volumeThroughput = parseInt(opts.volumeThroughput, 10)\n    if (volumeIops < 3000 || volumeIops > 80000) {\n      throw invalidArgument('--volume-iops must be between 3000 and 80000')\n    }\n    if (volumeThroughput < 125 || volumeThroughput > 2000) {\n      throw invalidArgument('--volume-throughput must be between 125 and 2000')\n    }\n    if (volumeThroughput > volumeIops * 0.25) {\n      throw invalidArgument('--volume-throughput must not exceed --volume-iops × 0.25 (gp3 ratio rule)')\n    }\n\n    const data = await fetchJson(apiUrl('/admin/queues'), {\n      method: 'POST',\n      headers: { 'Content-Type': 'application/json' },\n      body: JSON.stringify({\n        name: opts.name,\n        environmentId: opts.environmentId,\n        executionMode: opts.executionMode,\n        ...(opts.instanceType.length > 0 ? { instanceTypes: opts.instanceType } : {}),\n        maxvCpus: parseInt(opts.maxVcpus, 10),\n        storageSizeGb: parseInt(opts.storageSizeGb, 10),\n        volumeIops,\n        volumeThroughput,\n        ebsAutoscalingEnabled: opts.enableEbsAutoscaling === 'true',\n        ...(process.env.GENI_TENANT_ID ? { tenantId: process.env.GENI_TENANT_ID } : {}),\n      }),\n    })\n    formatOutput(data, opts.format, queueColumns)\n  })\n"]}
|
|
@@ -88,4 +88,24 @@ exports.submissionCommand
|
|
|
88
88
|
const data = await (0, auth_1.readJsonResponse)(res, { method: 'POST', url });
|
|
89
89
|
console.log(`${data.message} (${data.submissionId})`);
|
|
90
90
|
});
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"submission.js","sourceRoot":"","sources":["../../src/commands/submission.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command, Option } from 'commander'\nimport fs from 'fs'\nimport path from 'path'\nimport { apiUrl, fetchJson, getAuthHeaders, readJsonResponse } from '../auth'\nimport { invalidArgument } from '../errors'\nimport { formatOutput, submissionColumns, type OutputFormat } from '../format.js'\n\nfunction parseTimeToSeconds(value: string): number {\n  const parts = value.split(':').map(Number)\n  if (parts.length !== 3 || parts.some(isNaN)) {\n    throw invalidArgument(\n      'Time must be in DD:HH:MM format (days:hours:minutes).',\n      'Example: 00:12:30',\n    )\n  }\n  const [days, hours, minutes] = parts\n  return (days * 86400) + (hours * 3600) + (minutes * 60)\n}\n\n\nexport const submissionCommand = new Command('submission')\n  .description('Manage workflow submissions')\n\nsubmissionCommand\n  .command('list')\n  .description('List submissions')\n  .option('--status <status>', 'Filter by status (SUBMITTED, SUCCEEDED, FAILED)')\n  .option('--limit <n>', 'Maximum number of results to return', '10')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: { status?: string; limit: string; format: OutputFormat }) => {\n    const params = new URLSearchParams()\n    if (opts.status) params.set('status', opts.status)\n    params.set('limit', opts.limit)\n    const data = await fetchJson(apiUrl(`/submissions?${params}`)) as { items: unknown[] }\n    formatOutput(opts.format === 'json' ? data : data.items, opts.format, submissionColumns)\n  })\n\nsubmissionCommand\n  .command('get <id>')\n  .description('Get a submission by ID')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (id: string, opts: { format: OutputFormat }) => {\n    const data = await fetchJson(apiUrl(`/submissions/${id}`))\n    formatOutput(data, opts.format, submissionColumns)\n  })\n\nsubmissionCommand\n  .command('create')\n  .description('Submit a workflow run')\n  .requiredOption('--workflow-name <name>', 'Workflow name')\n  .option('--workflow-version <version>', 'Workflow version')\n  .requiredOption('--params-file <file>', 'Path to params file (.json/.yaml/.yml)')\n  .requiredOption('--engine-id <id>', 'Engine ID')\n  .requiredOption('--queue-id <id>', 'Queue ID')\n  .requiredOption('--output-folder <s3-uri>', 'S3 URI prefix for workflow output files (e.g. s3://my-bucket/outputs/)')\n  .option('--alert-time <DD:HH:MM>', 'Alert time override (DD:HH:MM)')\n  .option('--cancel-time <DD:HH:MM>', 'Cancel time override (DD:HH:MM)')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: {\n    workflowName: string\n    workflowVersion?: string\n    paramsFile: string\n    engineId: string\n    queueId: string\n    outputFolder: string\n    alertTime?: string\n    cancelTime?: string\n    format: OutputFormat\n  }) => {\n    const form = new FormData()\n    form.append('workflowName', opts.workflowName)\n    if (opts.workflowVersion) form.append('workflowVersion', opts.workflowVersion)\n    form.append('engineId', opts.engineId)\n    form.append('queueId', opts.queueId)\n    form.append('output', opts.outputFolder)\n    if (opts.alertTime) form.append('alertTimeSeconds', String(parseTimeToSeconds(opts.alertTime)))\n    if (opts.cancelTime) form.append('cancelTimeSeconds', String(parseTimeToSeconds(opts.cancelTime)))\n    const paramsBuffer = await fs.promises.readFile(opts.paramsFile)\n    form.append('params', new Blob([paramsBuffer]), path.basename(opts.paramsFile))\n\n    const res = await fetch(apiUrl('/submissions'), {\n      method: 'POST',\n      headers: getAuthHeaders(),\n      body: form,\n    })\n    const data = await readJsonResponse(res, { method: 'POST', url: apiUrl('/submissions') })\n    formatOutput(data, opts.format, submissionColumns)\n  })\n\nsubmissionCommand\n  .command('cancel <id>')\n  .description('Cancel a running submission')\n  .action(async (id: string) => {\n    const url = apiUrl(`/submissions/${id}/cancel`)\n    const res = await fetch(url, {\n      method: 'POST',\n      headers: getAuthHeaders(),\n    })\n    const data = await readJsonResponse(res, { method: 'POST', url }) as { submissionId: string; message: string }\n    console.log(`${data.message} (${data.submissionId})`)\n  })\n"]}
|
|
91
|
+
exports.submissionCommand
|
|
92
|
+
.command('retry <id>')
|
|
93
|
+
.description('Retry a failed submission')
|
|
94
|
+
.option('--engine-id <id>', 'Use a different engine')
|
|
95
|
+
.option('--queue-id <id>', 'Use a different queue')
|
|
96
|
+
.action(async (id, opts) => {
|
|
97
|
+
const url = (0, auth_1.apiUrl)(`/submissions/${id}/retry`);
|
|
98
|
+
const body = {};
|
|
99
|
+
if (opts.engineId)
|
|
100
|
+
body.engineId = opts.engineId;
|
|
101
|
+
if (opts.queueId)
|
|
102
|
+
body.queueId = opts.queueId;
|
|
103
|
+
const res = await fetch(url, {
|
|
104
|
+
method: 'POST',
|
|
105
|
+
headers: { ...(0, auth_1.getAuthHeaders)(), 'Content-Type': 'application/json' },
|
|
106
|
+
body: JSON.stringify(body),
|
|
107
|
+
});
|
|
108
|
+
const data = await (0, auth_1.readJsonResponse)(res, { method: 'POST', url });
|
|
109
|
+
console.log(`${data.message} (${data.submissionId})`);
|
|
110
|
+
});
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"submission.js","sourceRoot":"","sources":["../../src/commands/submission.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command, Option } from 'commander'\nimport fs from 'fs'\nimport path from 'path'\nimport { apiUrl, fetchJson, getAuthHeaders, readJsonResponse } from '../auth'\nimport { invalidArgument } from '../errors'\nimport { formatOutput, submissionColumns, type OutputFormat } from '../format.js'\n\nfunction parseTimeToSeconds(value: string): number {\n  const parts = value.split(':').map(Number)\n  if (parts.length !== 3 || parts.some(isNaN)) {\n    throw invalidArgument(\n      'Time must be in DD:HH:MM format (days:hours:minutes).',\n      'Example: 00:12:30',\n    )\n  }\n  const [days, hours, minutes] = parts\n  return (days * 86400) + (hours * 3600) + (minutes * 60)\n}\n\n\nexport const submissionCommand = new Command('submission')\n  .description('Manage workflow submissions')\n\nsubmissionCommand\n  .command('list')\n  .description('List submissions')\n  .option('--status <status>', 'Filter by status (SUBMITTED, SUCCEEDED, FAILED)')\n  .option('--limit <n>', 'Maximum number of results to return', '10')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: { status?: string; limit: string; format: OutputFormat }) => {\n    const params = new URLSearchParams()\n    if (opts.status) params.set('status', opts.status)\n    params.set('limit', opts.limit)\n    const data = await fetchJson(apiUrl(`/submissions?${params}`)) as { items: unknown[] }\n    formatOutput(opts.format === 'json' ? data : data.items, opts.format, submissionColumns)\n  })\n\nsubmissionCommand\n  .command('get <id>')\n  .description('Get a submission by ID')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (id: string, opts: { format: OutputFormat }) => {\n    const data = await fetchJson(apiUrl(`/submissions/${id}`))\n    formatOutput(data, opts.format, submissionColumns)\n  })\n\nsubmissionCommand\n  .command('create')\n  .description('Submit a workflow run')\n  .requiredOption('--workflow-name <name>', 'Workflow name')\n  .option('--workflow-version <version>', 'Workflow version')\n  .requiredOption('--params-file <file>', 'Path to params file (.json/.yaml/.yml)')\n  .requiredOption('--engine-id <id>', 'Engine ID')\n  .requiredOption('--queue-id <id>', 'Queue ID')\n  .requiredOption('--output-folder <s3-uri>', 'S3 URI prefix for workflow output files (e.g. s3://my-bucket/outputs/)')\n  .option('--alert-time <DD:HH:MM>', 'Alert time override (DD:HH:MM)')\n  .option('--cancel-time <DD:HH:MM>', 'Cancel time override (DD:HH:MM)')\n  .addOption(new Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))\n  .action(async (opts: {\n    workflowName: string\n    workflowVersion?: string\n    paramsFile: string\n    engineId: string\n    queueId: string\n    outputFolder: string\n    alertTime?: string\n    cancelTime?: string\n    format: OutputFormat\n  }) => {\n    const form = new FormData()\n    form.append('workflowName', opts.workflowName)\n    if (opts.workflowVersion) form.append('workflowVersion', opts.workflowVersion)\n    form.append('engineId', opts.engineId)\n    form.append('queueId', opts.queueId)\n    form.append('output', opts.outputFolder)\n    if (opts.alertTime) form.append('alertTimeSeconds', String(parseTimeToSeconds(opts.alertTime)))\n    if (opts.cancelTime) form.append('cancelTimeSeconds', String(parseTimeToSeconds(opts.cancelTime)))\n    const paramsBuffer = await fs.promises.readFile(opts.paramsFile)\n    form.append('params', new Blob([paramsBuffer]), path.basename(opts.paramsFile))\n\n    const res = await fetch(apiUrl('/submissions'), {\n      method: 'POST',\n      headers: getAuthHeaders(),\n      body: form,\n    })\n    const data = await readJsonResponse(res, { method: 'POST', url: apiUrl('/submissions') })\n    formatOutput(data, opts.format, submissionColumns)\n  })\n\nsubmissionCommand\n  .command('cancel <id>')\n  .description('Cancel a running submission')\n  .action(async (id: string) => {\n    const url = apiUrl(`/submissions/${id}/cancel`)\n    const res = await fetch(url, {\n      method: 'POST',\n      headers: getAuthHeaders(),\n    })\n    const data = await readJsonResponse(res, { method: 'POST', url }) as { submissionId: string; message: string }\n    console.log(`${data.message} (${data.submissionId})`)\n  })\n\nsubmissionCommand\n  .command('retry <id>')\n  .description('Retry a failed submission')\n  .option('--engine-id <id>', 'Use a different engine')\n  .option('--queue-id <id>', 'Use a different queue')\n  .action(async (id: string, opts: { engineId?: string; queueId?: string }) => {\n    const url = apiUrl(`/submissions/${id}/retry`)\n    const body: Record<string, string> = {}\n    if (opts.engineId) body.engineId = opts.engineId\n    if (opts.queueId) body.queueId = opts.queueId\n    const res = await fetch(url, {\n      method: 'POST',\n      headers: { ...getAuthHeaders(), 'Content-Type': 'application/json' },\n      body: JSON.stringify(body),\n    })\n    const data = await readJsonResponse(res, { method: 'POST', url }) as { submissionId: string; message: string }\n    console.log(`${data.message} (${data.submissionId})`)\n  })\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.workflowVersionCommand = void 0;
|
|
4
|
+
const commander_1 = require("commander");
|
|
5
|
+
const auth_1 = require("../auth");
|
|
6
|
+
const format_js_1 = require("../format.js");
|
|
7
|
+
exports.workflowVersionCommand = new commander_1.Command('workflow-version')
|
|
8
|
+
.description('Manage workflow versions');
|
|
9
|
+
exports.workflowVersionCommand
|
|
10
|
+
.command('list <workflow-name>')
|
|
11
|
+
.description('List all versions of a workflow')
|
|
12
|
+
.addOption(new commander_1.Option('--format <format>', 'Output format').choices(['table', 'json', 'csv']).default('table'))
|
|
13
|
+
.action(async (workflowName, opts) => {
|
|
14
|
+
const data = await (0, auth_1.fetchJson)((0, auth_1.apiUrl)(`/workflows/${workflowName}/versions`));
|
|
15
|
+
(0, format_js_1.formatOutput)(opts.format === 'json' ? data : data.items, opts.format, format_js_1.workflowVersionColumns);
|
|
16
|
+
});
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctdmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21tYW5kcy93b3JrZmxvdy12ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQUEyQztBQUMzQyxrQ0FBMkM7QUFDM0MsNENBQXNGO0FBRXpFLFFBQUEsc0JBQXNCLEdBQUcsSUFBSSxtQkFBTyxDQUFDLGtCQUFrQixDQUFDO0tBQ2xFLFdBQVcsQ0FBQywwQkFBMEIsQ0FBQyxDQUFBO0FBRTFDLDhCQUFzQjtLQUNuQixPQUFPLENBQUMsc0JBQXNCLENBQUM7S0FDL0IsV0FBVyxDQUFDLGlDQUFpQyxDQUFDO0tBQzlDLFNBQVMsQ0FBQyxJQUFJLGtCQUFNLENBQUMsbUJBQW1CLEVBQUUsZUFBZSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUM5RyxNQUFNLENBQUMsS0FBSyxFQUFFLFlBQW9CLEVBQUUsSUFBOEIsRUFBRSxFQUFFO0lBQ3JFLE1BQU0sSUFBSSxHQUFHLE1BQU0sSUFBQSxnQkFBUyxFQUFDLElBQUEsYUFBTSxFQUFDLGNBQWMsWUFBWSxXQUFXLENBQUMsQ0FBeUIsQ0FBQTtJQUNuRyxJQUFBLHdCQUFZLEVBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLGtDQUFzQixDQUFDLENBQUE7QUFDL0YsQ0FBQyxDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tYW5kLCBPcHRpb24gfSBmcm9tICdjb21tYW5kZXInXG5pbXBvcnQgeyBhcGlVcmwsIGZldGNoSnNvbiB9IGZyb20gJy4uL2F1dGgnXG5pbXBvcnQgeyBmb3JtYXRPdXRwdXQsIHdvcmtmbG93VmVyc2lvbkNvbHVtbnMsIHR5cGUgT3V0cHV0Rm9ybWF0IH0gZnJvbSAnLi4vZm9ybWF0LmpzJ1xuXG5leHBvcnQgY29uc3Qgd29ya2Zsb3dWZXJzaW9uQ29tbWFuZCA9IG5ldyBDb21tYW5kKCd3b3JrZmxvdy12ZXJzaW9uJylcbiAgLmRlc2NyaXB0aW9uKCdNYW5hZ2Ugd29ya2Zsb3cgdmVyc2lvbnMnKVxuXG53b3JrZmxvd1ZlcnNpb25Db21tYW5kXG4gIC5jb21tYW5kKCdsaXN0IDx3b3JrZmxvdy1uYW1lPicpXG4gIC5kZXNjcmlwdGlvbignTGlzdCBhbGwgdmVyc2lvbnMgb2YgYSB3b3JrZmxvdycpXG4gIC5hZGRPcHRpb24obmV3IE9wdGlvbignLS1mb3JtYXQgPGZvcm1hdD4nLCAnT3V0cHV0IGZvcm1hdCcpLmNob2ljZXMoWyd0YWJsZScsICdqc29uJywgJ2NzdiddKS5kZWZhdWx0KCd0YWJsZScpKVxuICAuYWN0aW9uKGFzeW5jICh3b3JrZmxvd05hbWU6IHN0cmluZywgb3B0czogeyBmb3JtYXQ6IE91dHB1dEZvcm1hdCB9KSA9PiB7XG4gICAgY29uc3QgZGF0YSA9IGF3YWl0IGZldGNoSnNvbihhcGlVcmwoYC93b3JrZmxvd3MvJHt3b3JrZmxvd05hbWV9L3ZlcnNpb25zYCkpIGFzIHsgaXRlbXM6IHVua25vd25bXSB9XG4gICAgZm9ybWF0T3V0cHV0KG9wdHMuZm9ybWF0ID09PSAnanNvbicgPyBkYXRhIDogZGF0YS5pdGVtcywgb3B0cy5mb3JtYXQsIHdvcmtmbG93VmVyc2lvbkNvbHVtbnMpXG4gIH0pXG4iXX0=
|
package/dist/format.d.ts
CHANGED
|
@@ -6,6 +6,7 @@ interface ColumnDef {
|
|
|
6
6
|
}
|
|
7
7
|
export declare function formatOutput(data: unknown, format: OutputFormat, columns: ColumnDef[]): void;
|
|
8
8
|
export declare const workflowColumns: ColumnDef[];
|
|
9
|
+
export declare const workflowVersionColumns: ColumnDef[];
|
|
9
10
|
export declare const submissionColumns: ColumnDef[];
|
|
10
11
|
export declare const environmentColumns: ColumnDef[];
|
|
11
12
|
export declare const queueColumns: ColumnDef[];
|
|
@@ -26,4 +27,6 @@ export declare const analyticsByEnvironmentColumns: ColumnDef[];
|
|
|
26
27
|
export declare const analyticsByQueueColumns: ColumnDef[];
|
|
27
28
|
export declare const analyticsByInstanceTypeColumns: ColumnDef[];
|
|
28
29
|
export declare const analyticsOverTimeColumns: ColumnDef[];
|
|
30
|
+
export declare const costsByEngineColumns: ColumnDef[];
|
|
31
|
+
export declare const costsByExecutionModeColumns: ColumnDef[];
|
|
29
32
|
export {};
|
package/dist/format.js
CHANGED
|
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.analyticsOverTimeColumns = exports.analyticsByInstanceTypeColumns = exports.analyticsByQueueColumns = exports.analyticsByEnvironmentColumns = exports.analyticsBySubmissionColumns = exports.analyticsSummaryColumns = exports.tenantColumns = exports.pluginColumns = exports.imageColumns = exports.activityLogColumns = exports.instanceColumns = exports.registryColumns = exports.taskLogColumns = exports.submissionLogColumns = exports.taskColumns = exports.storageColumns = exports.engineColumns = exports.queueColumns = exports.environmentColumns = exports.submissionColumns = exports.workflowColumns = void 0;
|
|
6
|
+
exports.costsByExecutionModeColumns = exports.costsByEngineColumns = exports.analyticsOverTimeColumns = exports.analyticsByInstanceTypeColumns = exports.analyticsByQueueColumns = exports.analyticsByEnvironmentColumns = exports.analyticsBySubmissionColumns = exports.analyticsSummaryColumns = exports.tenantColumns = exports.pluginColumns = exports.imageColumns = exports.activityLogColumns = exports.instanceColumns = exports.registryColumns = exports.taskLogColumns = exports.submissionLogColumns = exports.taskColumns = exports.storageColumns = exports.engineColumns = exports.queueColumns = exports.environmentColumns = exports.submissionColumns = exports.workflowVersionColumns = exports.workflowColumns = void 0;
|
|
7
7
|
exports.formatDateTime = formatDateTime;
|
|
8
8
|
exports.formatOutput = formatOutput;
|
|
9
9
|
const cli_table3_1 = __importDefault(require("cli-table3"));
|
|
@@ -16,6 +16,14 @@ function formatDateTime(value) {
|
|
|
16
16
|
const pad = (n) => String(n).padStart(2, '0');
|
|
17
17
|
return `${d.getFullYear()}-${pad(d.getMonth() + 1)}-${pad(d.getDate())} ${pad(d.getHours())}:${pad(d.getMinutes())}:${pad(d.getSeconds())}`;
|
|
18
18
|
}
|
|
19
|
+
function formatCurrency(value) {
|
|
20
|
+
if (value === null || value === undefined || value === '')
|
|
21
|
+
return '';
|
|
22
|
+
const n = Number(value);
|
|
23
|
+
if (isNaN(n))
|
|
24
|
+
return String(value);
|
|
25
|
+
return n.toFixed(2);
|
|
26
|
+
}
|
|
19
27
|
function formatDuration(ms) {
|
|
20
28
|
if (ms === null || ms === undefined || ms === '')
|
|
21
29
|
return '';
|
|
@@ -53,6 +61,12 @@ exports.workflowColumns = [
|
|
|
53
61
|
{ header: 'Latest', value: r => r.latest },
|
|
54
62
|
{ header: 'Created At', value: r => formatDateTime(r.createdAt) },
|
|
55
63
|
];
|
|
64
|
+
exports.workflowVersionColumns = [
|
|
65
|
+
{ header: 'Version', value: r => r.version },
|
|
66
|
+
{ header: 'File Type', value: r => r.fileType },
|
|
67
|
+
{ header: 'Latest', value: r => r.latest },
|
|
68
|
+
{ header: 'Created At', value: r => formatDateTime(r.createdAt) },
|
|
69
|
+
];
|
|
56
70
|
exports.submissionColumns = [
|
|
57
71
|
{ header: 'ID', value: r => r.submissionId },
|
|
58
72
|
{ header: 'Status', value: r => r.status },
|
|
@@ -137,12 +151,12 @@ exports.instanceColumns = [
|
|
|
137
151
|
{ header: 'Market', value: r => r.marketType },
|
|
138
152
|
{ header: 'Status', value: r => r.status },
|
|
139
153
|
{ header: 'Duration', value: r => formatDuration(r.durationMs) },
|
|
140
|
-
{ header: 'Est. Instance ($)', value: r => r.estimatedInstanceCost },
|
|
141
|
-
{ header: 'Est. EBS ($)', value: r => r.estimatedEbsCost },
|
|
142
|
-
{ header: 'Est. Total ($)', value: r => r.estimatedTotalCost },
|
|
143
|
-
{ header: 'Actual Instance ($)', value: r => r.actualInstanceCost },
|
|
144
|
-
{ header: 'Actual EBS ($)', value: r => r.actualEbsCost },
|
|
145
|
-
{ header: 'Actual Total ($)', value: r => r.actualTotalCost },
|
|
154
|
+
{ header: 'Est. Instance ($)', value: r => formatCurrency(r.estimatedInstanceCost) },
|
|
155
|
+
{ header: 'Est. EBS ($)', value: r => formatCurrency(r.estimatedEbsCost) },
|
|
156
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
157
|
+
{ header: 'Actual Instance ($)', value: r => formatCurrency(r.actualInstanceCost) },
|
|
158
|
+
{ header: 'Actual EBS ($)', value: r => formatCurrency(r.actualEbsCost) },
|
|
159
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
146
160
|
{ header: 'Launch Time', value: r => formatDateTime(r.launchTime) },
|
|
147
161
|
{ header: 'Environment ID', value: r => r.environmentId },
|
|
148
162
|
];
|
|
@@ -180,46 +194,59 @@ exports.tenantColumns = [
|
|
|
180
194
|
{ header: 'Created At', value: r => formatDateTime(r.createdAt) },
|
|
181
195
|
];
|
|
182
196
|
exports.analyticsSummaryColumns = [
|
|
183
|
-
{ header: 'Est. Instance ($)', value: r => r.totalEstimatedInstanceCost },
|
|
184
|
-
{ header: 'Est. EBS ($)', value: r => r.totalEstimatedEbsCost },
|
|
185
|
-
{ header: 'Est. ECS ($)', value: r => r.totalEstimatedEcsCost },
|
|
186
|
-
{ header: 'Est. Total ($)', value: r => r.totalEstimatedCost },
|
|
187
|
-
{ header: 'Actual Total ($)', value: r => r.totalActualCost },
|
|
197
|
+
{ header: 'Est. Instance ($)', value: r => formatCurrency(r.totalEstimatedInstanceCost) },
|
|
198
|
+
{ header: 'Est. EBS ($)', value: r => formatCurrency(r.totalEstimatedEbsCost) },
|
|
199
|
+
{ header: 'Est. ECS ($)', value: r => formatCurrency(r.totalEstimatedEcsCost) },
|
|
200
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.totalEstimatedCost) },
|
|
201
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.totalActualCost) },
|
|
188
202
|
{ header: 'Instances', value: r => r.instanceCount },
|
|
189
203
|
{ header: 'Submissions', value: r => r.submissionCount },
|
|
190
204
|
];
|
|
191
205
|
exports.analyticsBySubmissionColumns = [
|
|
192
206
|
{ header: 'Submission ID', value: r => r.submissionId },
|
|
193
207
|
{ header: 'Status', value: r => r.submissionStatus },
|
|
194
|
-
{ header: 'Est. Total ($)', value: r => r.estimatedTotalCost },
|
|
195
|
-
{ header: 'Actual Total ($)', value: r => r.actualTotalCost },
|
|
208
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
209
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
196
210
|
{ header: 'Instances', value: r => r.instanceCount },
|
|
197
211
|
];
|
|
198
212
|
exports.analyticsByEnvironmentColumns = [
|
|
199
213
|
{ header: 'Environment ID', value: r => r.environmentId },
|
|
200
214
|
{ header: 'Name', value: r => r.environmentName },
|
|
201
|
-
{ header: 'Est. Total ($)', value: r => r.estimatedTotalCost },
|
|
202
|
-
{ header: 'Actual Total ($)', value: r => r.actualTotalCost },
|
|
215
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
216
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
203
217
|
{ header: 'Instances', value: r => r.instanceCount },
|
|
204
218
|
];
|
|
205
219
|
exports.analyticsByQueueColumns = [
|
|
206
220
|
{ header: 'Queue ID', value: r => r.queueId },
|
|
207
221
|
{ header: 'Name', value: r => r.queueName },
|
|
208
|
-
{ header: 'Est. Total ($)', value: r => r.estimatedTotalCost },
|
|
209
|
-
{ header: 'Actual Total ($)', value: r => r.actualTotalCost },
|
|
222
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
223
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
210
224
|
{ header: 'Instances', value: r => r.instanceCount },
|
|
211
225
|
];
|
|
212
226
|
exports.analyticsByInstanceTypeColumns = [
|
|
213
227
|
{ header: 'Instance Type', value: r => r.instanceType },
|
|
214
228
|
{ header: 'Market', value: r => r.marketType },
|
|
215
|
-
{ header: 'Est. Total ($)', value: r => r.estimatedTotalCost },
|
|
216
|
-
{ header: 'Actual Total ($)', value: r => r.actualTotalCost },
|
|
229
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
230
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
217
231
|
{ header: 'Instances', value: r => r.instanceCount },
|
|
218
232
|
];
|
|
219
233
|
exports.analyticsOverTimeColumns = [
|
|
220
234
|
{ header: 'Period', value: r => r.period },
|
|
221
|
-
{ header: 'Est. Total ($)', value: r => r.estimatedTotalCost },
|
|
222
|
-
{ header: 'Actual Total ($)', value: r => r.actualTotalCost },
|
|
235
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
236
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
237
|
+
{ header: 'Instances', value: r => r.instanceCount },
|
|
238
|
+
];
|
|
239
|
+
exports.costsByEngineColumns = [
|
|
240
|
+
{ header: 'Engine ID', value: r => r.engineId },
|
|
241
|
+
{ header: 'Name', value: r => r.engineName },
|
|
242
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
243
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
244
|
+
{ header: 'Instances', value: r => r.instanceCount },
|
|
245
|
+
];
|
|
246
|
+
exports.costsByExecutionModeColumns = [
|
|
247
|
+
{ header: 'Execution Mode', value: r => r.executionMode },
|
|
248
|
+
{ header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },
|
|
249
|
+
{ header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },
|
|
223
250
|
{ header: 'Instances', value: r => r.instanceCount },
|
|
224
251
|
];
|
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"format.js","sourceRoot":"","sources":["../src/format.ts"],"names":[],"mappings":"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","sourcesContent":["import Table from 'cli-table3'\n\nexport function formatDateTime(value: unknown): string {\n  if (value === null || value === undefined || value === '') return '';\n  const d = new Date(String(value));\n  if (isNaN(d.getTime())) return String(value);\n  const pad = (n: number) => String(n).padStart(2, '0');\n  return `${d.getFullYear()}-${pad(d.getMonth() + 1)}-${pad(d.getDate())} ${pad(d.getHours())}:${pad(d.getMinutes())}:${pad(d.getSeconds())}`;\n}\n\nfunction formatDuration(ms: unknown): string {\n  if (ms === null || ms === undefined || ms === '') return '';\n  const totalSec = Math.floor(Number(ms) / 1000);\n  const h = Math.floor(totalSec / 3600);\n  const m = Math.floor((totalSec % 3600) / 60);\n  const s = totalSec % 60;\n  return `${String(h).padStart(2, '0')}:${String(m).padStart(2, '0')}:${String(s).padStart(2, '0')}`;\n}\n\nexport type OutputFormat = 'table' | 'json' | 'csv'\n\ninterface ColumnDef {\n  header: string\n  value: (item: Record<string, unknown>) => unknown\n}\n\nexport function formatOutput(data: unknown, format: OutputFormat, columns: ColumnDef[]): void {\n  const items = Array.isArray(data) ? data : [data]\n  const headers = columns.map(c => c.header)\n  const rows = items.map(item =>\n    columns.map(c => {\n      const val = c.value(item as Record<string, unknown>)\n      return val === null || val === undefined ? '' : String(val)\n    })\n  )\n\n  if (format === 'json') {\n    console.log(JSON.stringify(data, null, 2))\n  } else if (format === 'csv') {\n    console.log(headers.join(','))\n    rows.forEach(row => console.log(row.map(v => `\"${v.replace(/\"/g, '\"\"')}\"`).join(',')))\n  } else {\n    const table = new Table({ head: headers })\n    rows.forEach(row => table.push(row))\n    console.log(table.toString())\n  }\n}\n\nexport const workflowColumns: ColumnDef[] = [\n  { header: 'Name', value: r => r.name },\n  { header: 'Version', value: r => r.version },\n  { header: 'Engine', value: r => r.engine },\n  { header: 'File Type', value: r => r.fileType },\n  { header: 'Latest', value: r => r.latest },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const submissionColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.submissionId },\n  { header: 'Status', value: r => r.status },\n  { header: 'Duration', value: r => formatDuration(r.durationMs) },\n  { header: 'Workflow', value: r => r.workflowName },\n  { header: 'Version', value: r => r.workflowVersion },\n  { header: 'Engine', value: r => (r.engine as Record<string, unknown> | null)?.name ?? r.engineId },\n  { header: 'Queue', value: r => (r.queue as Record<string, unknown> | null)?.name ?? r.queueId },\n  { header: 'Output', value: r => r.output },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const environmentColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Cloud ID', value: r => r.cloudId },\n  { header: 'Region', value: r => r.cloudRegion },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const queueColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Mode', value: r => r.executionMode },\n  { header: 'Max vCPUs', value: r => r.maxvCpus },\n  { header: 'Storage GB', value: r => r.storageSizeGb },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const engineColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Engine', value: r => r.engine },\n  { header: 'Engine Version', value: r => r.engineVersion },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const storageColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Permission Mode', value: r => r.permissionMode },\n  { header: 'Bucket Name', value: r => r.bucketName },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const taskColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Job ID', value: r => r.jobId },\n  { header: 'Submission ID', value: r => r.submissionId },\n  { header: 'Job Name', value: r => r.jobName },\n  { header: 'Status', value: r => r.status },\n  { header: 'Status Reason', value: r => r.statusReason },\n  { header: 'Duration', value: r => formatDuration(r.durationMs) },\n  { header: 'Exit Code', value: r => r.exitCode },\n  { header: 'Instance Type', value: r => (r.instance as Record<string, unknown> | null)?.instanceType ?? null },\n  { header: 'Started At', value: r => formatDateTime(r.startedAt) },\n  { header: 'Stopped At', value: r => formatDateTime(r.stoppedAt) },\n]\n\nexport const submissionLogColumns: ColumnDef[] = [\n  { header: 'Timestamp', value: r => formatDateTime(r.timestamp) },\n  { header: 'Message', value: r => r.message },\n]\n\nexport const taskLogColumns: ColumnDef[] = [\n  { header: 'Job Name', value: r => r.jobName },\n  { header: 'Timestamp', value: r => formatDateTime(r.timestamp) },\n  { header: 'Message', value: r => r.message },\n]\n\nexport const registryColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Mutability', value: r => r.imageTagMutability },\n  { header: 'Repository URI', value: r => r.repositoryUri },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const instanceColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'EC2 Instance', value: r => r.ec2InstanceId },\n  { header: 'Type', value: r => r.instanceType },\n  { header: 'Market', value: r => r.marketType },\n  { header: 'Status', value: r => r.status },\n  { header: 'Duration', value: r => formatDuration(r.durationMs) },\n  { header: 'Est. Instance ($)', value: r => r.estimatedInstanceCost },\n  { header: 'Est. EBS ($)', value: r => r.estimatedEbsCost },\n  { header: 'Est. Total ($)', value: r => r.estimatedTotalCost },\n  { header: 'Actual Instance ($)', value: r => r.actualInstanceCost },\n  { header: 'Actual EBS ($)', value: r => r.actualEbsCost },\n  { header: 'Actual Total ($)', value: r => r.actualTotalCost },\n  { header: 'Launch Time', value: r => formatDateTime(r.launchTime) },\n  { header: 'Environment ID', value: r => r.environmentId },\n]\n\nexport const activityLogColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'User', value: r => ((r.principal as Record<string, unknown>)?.user as Record<string, unknown>)?.email ?? (r.principal as Record<string, unknown>)?.id ?? r.principalId },\n  { header: 'Action', value: r => r.action },\n  { header: 'Entity Type', value: r => r.entityType },\n  { header: 'Entity ID', value: r => r.entityId },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const imageColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Tag', value: r => r.tag },\n  { header: 'Digest', value: r => r.digest },\n  { header: 'Size (bytes)', value: r => r.sizeBytes },\n  { header: 'Status', value: r => r.status },\n  { header: 'Image URI', value: r => r.imageUri },\n  { header: 'Pushed At', value: r => formatDateTime(r.pushedAt) },\n]\n\nexport const pluginColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Type', value: r => r.type },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Status', value: r => r.status },\n  { header: 'LB DNS', value: r => r.loadBalancerDns },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const tenantColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Contact Email', value: r => r.contactEmail },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const analyticsSummaryColumns: ColumnDef[] = [\n  { header: 'Est. Instance ($)', value: r => r.totalEstimatedInstanceCost },\n  { header: 'Est. EBS ($)', value: r => r.totalEstimatedEbsCost },\n  { header: 'Est. ECS ($)', value: r => r.totalEstimatedEcsCost },\n  { header: 'Est. Total ($)', value: r => r.totalEstimatedCost },\n  { header: 'Actual Total ($)', value: r => r.totalActualCost },\n  { header: 'Instances', value: r => r.instanceCount },\n  { header: 'Submissions', value: r => r.submissionCount },\n]\n\nexport const analyticsBySubmissionColumns: ColumnDef[] = [\n  { header: 'Submission ID', value: r => r.submissionId },\n  { header: 'Status', value: r => r.submissionStatus },\n  { header: 'Est. Total ($)', value: r => r.estimatedTotalCost },\n  { header: 'Actual Total ($)', value: r => r.actualTotalCost },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsByEnvironmentColumns: ColumnDef[] = [\n  { header: 'Environment ID', value: r => r.environmentId },\n  { header: 'Name', value: r => r.environmentName },\n  { header: 'Est. Total ($)', value: r => r.estimatedTotalCost },\n  { header: 'Actual Total ($)', value: r => r.actualTotalCost },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsByQueueColumns: ColumnDef[] = [\n  { header: 'Queue ID', value: r => r.queueId },\n  { header: 'Name', value: r => r.queueName },\n  { header: 'Est. Total ($)', value: r => r.estimatedTotalCost },\n  { header: 'Actual Total ($)', value: r => r.actualTotalCost },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsByInstanceTypeColumns: ColumnDef[] = [\n  { header: 'Instance Type', value: r => r.instanceType },\n  { header: 'Market', value: r => r.marketType },\n  { header: 'Est. Total ($)', value: r => r.estimatedTotalCost },\n  { header: 'Actual Total ($)', value: r => r.actualTotalCost },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsOverTimeColumns: ColumnDef[] = [\n  { header: 'Period', value: r => r.period },\n  { header: 'Est. Total ($)', value: r => r.estimatedTotalCost },\n  { header: 'Actual Total ($)', value: r => r.actualTotalCost },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n"]}
|
|
252
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"format.js","sourceRoot":"","sources":["../src/format.ts"],"names":[],"mappings":";;;;;;AAEA,wCAMC;AAyBD,oCAoBC;AArDD,4DAA8B;AAE9B,SAAgB,cAAc,CAAC,KAAc;IAC3C,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,EAAE;QAAE,OAAO,EAAE,CAAC;IACrE,MAAM,CAAC,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;IAClC,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;QAAE,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IAC7C,MAAM,GAAG,GAAG,CAAC,CAAS,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACtD,OAAO,GAAG,CAAC,CAAC,WAAW,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC;AAC9I,CAAC;AAED,SAAS,cAAc,CAAC,KAAc;IACpC,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,EAAE;QAAE,OAAO,EAAE,CAAC;IACrE,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACxB,IAAI,KAAK,CAAC,CAAC,CAAC;QAAE,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACnC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;AACtB,CAAC;AAED,SAAS,cAAc,CAAC,EAAW;IACjC,IAAI,EAAE,KAAK,IAAI,IAAI,EAAE,KAAK,SAAS,IAAI,EAAE,KAAK,EAAE;QAAE,OAAO,EAAE,CAAC;IAC5D,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;IAC/C,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;IACtC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;IAC7C,MAAM,CAAC,GAAG,QAAQ,GAAG,EAAE,CAAC;IACxB,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;AACrG,CAAC;AASD,SAAgB,YAAY,CAAC,IAAa,EAAE,MAAoB,EAAE,OAAoB;IACpF,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IACjD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAA;IAC1C,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAC5B,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;QACd,MAAM,GAAG,GAAG,CAAC,CAAC,KAAK,CAAC,IAA+B,CAAC,CAAA;QACpD,OAAO,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;IAC7D,CAAC,CAAC,CACH,CAAA;IAED,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;IAC5C,CAAC;SAAM,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;QAC9B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IACxF,CAAC;SAAM,CAAC;QACN,MAAM,KAAK,GAAG,IAAI,oBAAK,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAA;QAC1C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;QACpC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAA;IAC/B,CAAC;AACH,CAAC;AAEY,QAAA,eAAe,GAAgB;IAC1C,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;IAC5C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,sBAAsB,GAAgB;IACjD,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;IAC5C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,iBAAiB,GAAgB;IAC5C,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IAC5C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE;IAChE,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IAClD,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE;IACpD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,MAAyC,EAAE,IAAI,IAAI,CAAC,CAAC,QAAQ,EAAE;IAClG,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,KAAwC,EAAE,IAAI,IAAI,CAAC,CAAC,OAAO,EAAE;IAC/F,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,kBAAkB,GAAgB;IAC7C,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;IAC7C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE;IAC/C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,YAAY,GAAgB;IACvC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,WAA8C,EAAE,IAAI,IAAI,CAAC,CAAC,aAAa,EAAE;IACjH,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IAC/C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IACrD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,aAAa,GAAgB;IACxC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,WAA8C,EAAE,IAAI,IAAI,CAAC,CAAC,aAAa,EAAE;IACjH,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IACzD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,cAAc,GAAgB;IACzC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,WAA8C,EAAE,IAAI,IAAI,CAAC,CAAC,aAAa,EAAE;IACjH,EAAE,MAAM,EAAE,iBAAiB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE;IAC3D,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,EAAE;IACnD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,WAAW,GAAgB;IACtC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE;IACzC,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IACvD,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;IAC7C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IACvD,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE;IAChE,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,QAA2C,EAAE,YAAY,IAAI,IAAI,EAAE;IAC7G,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;IACjE,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,oBAAoB,GAAgB;IAC/C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;IAChE,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;CAC7C,CAAA;AAEY,QAAA,cAAc,GAAgB;IACzC,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;IAC7C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;IAChE,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;CAC7C,CAAA;AAEY,QAAA,eAAe,GAAgB;IAC1C,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,kBAAkB,EAAE;IAC1D,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IACzD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,eAAe,GAAgB;IAC1C,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IACvD,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IAC9C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,EAAE;IAC9C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE;IAChE,EAAE,MAAM,EAAE,mBAAmB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,qBAAqB,CAAC,EAAE;IACpF,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,gBAAgB,CAAC,EAAE;IAC1E,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,qBAAqB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IACnF,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,aAAa,CAAC,EAAE;IACzE,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE;IACnE,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CAC1D,CAAA;AAEY,QAAA,kBAAkB,GAAgB;IAC7C,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAG,CAAC,CAAC,SAAqC,EAAE,IAAgC,EAAE,KAAK,IAAK,CAAC,CAAC,SAAqC,EAAE,EAAE,IAAI,CAAC,CAAC,WAAW,EAAE;IACnL,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,EAAE;IACnD,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,YAAY,GAAgB;IACvC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,EAAE;IACpC,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,EAAE;IACnD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE;CAChE,CAAA;AAEY,QAAA,aAAa,GAAgB;IACxC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAE,CAAC,CAAC,WAA8C,EAAE,IAAI,IAAI,CAAC,CAAC,aAAa,EAAE;IACjH,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE;IACnD,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,aAAa,GAAgB;IACxC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;IAClC,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;IACtC,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IACvD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE;CAClE,CAAA;AAEY,QAAA,uBAAuB,GAAgB;IAClD,EAAE,MAAM,EAAE,mBAAmB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,0BAA0B,CAAC,EAAE;IACzF,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,qBAAqB,CAAC,EAAE;IAC/E,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,qBAAqB,CAAC,EAAE;IAC/E,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IACpD,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE;CACzD,CAAA;AAEY,QAAA,4BAA4B,GAAgB;IACvD,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IACvD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,gBAAgB,EAAE;IACpD,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CACrD,CAAA;AAEY,QAAA,6BAA6B,GAAgB;IACxD,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IACzD,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE;IACjD,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CACrD,CAAA;AAEY,QAAA,uBAAuB,GAAgB;IAClD,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE;IAC7C,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,EAAE;IAC3C,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CACrD,CAAA;AAEY,QAAA,8BAA8B,GAAgB;IACzD,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,EAAE;IACvD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,EAAE;IAC9C,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CACrD,CAAA;AAEY,QAAA,wBAAwB,GAAgB;IACnD,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE;IAC1C,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CACrD,CAAA;AAEY,QAAA,oBAAoB,GAAgB;IAC/C,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,EAAE;IAC5C,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CACrD,CAAA;AAEY,QAAA,2BAA2B,GAAgB;IACtD,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;IACzD,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,EAAE;IAC9E,EAAE,MAAM,EAAE,kBAAkB,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE;IAC7E,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE;CACrD,CAAA","sourcesContent":["import Table from 'cli-table3'\n\nexport function formatDateTime(value: unknown): string {\n  if (value === null || value === undefined || value === '') return '';\n  const d = new Date(String(value));\n  if (isNaN(d.getTime())) return String(value);\n  const pad = (n: number) => String(n).padStart(2, '0');\n  return `${d.getFullYear()}-${pad(d.getMonth() + 1)}-${pad(d.getDate())} ${pad(d.getHours())}:${pad(d.getMinutes())}:${pad(d.getSeconds())}`;\n}\n\nfunction formatCurrency(value: unknown): string {\n  if (value === null || value === undefined || value === '') return '';\n  const n = Number(value);\n  if (isNaN(n)) return String(value);\n  return n.toFixed(2);\n}\n\nfunction formatDuration(ms: unknown): string {\n  if (ms === null || ms === undefined || ms === '') return '';\n  const totalSec = Math.floor(Number(ms) / 1000);\n  const h = Math.floor(totalSec / 3600);\n  const m = Math.floor((totalSec % 3600) / 60);\n  const s = totalSec % 60;\n  return `${String(h).padStart(2, '0')}:${String(m).padStart(2, '0')}:${String(s).padStart(2, '0')}`;\n}\n\nexport type OutputFormat = 'table' | 'json' | 'csv'\n\ninterface ColumnDef {\n  header: string\n  value: (item: Record<string, unknown>) => unknown\n}\n\nexport function formatOutput(data: unknown, format: OutputFormat, columns: ColumnDef[]): void {\n  const items = Array.isArray(data) ? data : [data]\n  const headers = columns.map(c => c.header)\n  const rows = items.map(item =>\n    columns.map(c => {\n      const val = c.value(item as Record<string, unknown>)\n      return val === null || val === undefined ? '' : String(val)\n    })\n  )\n\n  if (format === 'json') {\n    console.log(JSON.stringify(data, null, 2))\n  } else if (format === 'csv') {\n    console.log(headers.join(','))\n    rows.forEach(row => console.log(row.map(v => `\"${v.replace(/\"/g, '\"\"')}\"`).join(',')))\n  } else {\n    const table = new Table({ head: headers })\n    rows.forEach(row => table.push(row))\n    console.log(table.toString())\n  }\n}\n\nexport const workflowColumns: ColumnDef[] = [\n  { header: 'Name', value: r => r.name },\n  { header: 'Version', value: r => r.version },\n  { header: 'Engine', value: r => r.engine },\n  { header: 'File Type', value: r => r.fileType },\n  { header: 'Latest', value: r => r.latest },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const workflowVersionColumns: ColumnDef[] = [\n  { header: 'Version', value: r => r.version },\n  { header: 'File Type', value: r => r.fileType },\n  { header: 'Latest', value: r => r.latest },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const submissionColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.submissionId },\n  { header: 'Status', value: r => r.status },\n  { header: 'Duration', value: r => formatDuration(r.durationMs) },\n  { header: 'Workflow', value: r => r.workflowName },\n  { header: 'Version', value: r => r.workflowVersion },\n  { header: 'Engine', value: r => (r.engine as Record<string, unknown> | null)?.name ?? r.engineId },\n  { header: 'Queue', value: r => (r.queue as Record<string, unknown> | null)?.name ?? r.queueId },\n  { header: 'Output', value: r => r.output },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const environmentColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Cloud ID', value: r => r.cloudId },\n  { header: 'Region', value: r => r.cloudRegion },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const queueColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Mode', value: r => r.executionMode },\n  { header: 'Max vCPUs', value: r => r.maxvCpus },\n  { header: 'Storage GB', value: r => r.storageSizeGb },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const engineColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Engine', value: r => r.engine },\n  { header: 'Engine Version', value: r => r.engineVersion },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const storageColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Permission Mode', value: r => r.permissionMode },\n  { header: 'Bucket Name', value: r => r.bucketName },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const taskColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Job ID', value: r => r.jobId },\n  { header: 'Submission ID', value: r => r.submissionId },\n  { header: 'Job Name', value: r => r.jobName },\n  { header: 'Status', value: r => r.status },\n  { header: 'Status Reason', value: r => r.statusReason },\n  { header: 'Duration', value: r => formatDuration(r.durationMs) },\n  { header: 'Exit Code', value: r => r.exitCode },\n  { header: 'Instance Type', value: r => (r.instance as Record<string, unknown> | null)?.instanceType ?? null },\n  { header: 'Started At', value: r => formatDateTime(r.startedAt) },\n  { header: 'Stopped At', value: r => formatDateTime(r.stoppedAt) },\n]\n\nexport const submissionLogColumns: ColumnDef[] = [\n  { header: 'Timestamp', value: r => formatDateTime(r.timestamp) },\n  { header: 'Message', value: r => r.message },\n]\n\nexport const taskLogColumns: ColumnDef[] = [\n  { header: 'Job Name', value: r => r.jobName },\n  { header: 'Timestamp', value: r => formatDateTime(r.timestamp) },\n  { header: 'Message', value: r => r.message },\n]\n\nexport const registryColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Mutability', value: r => r.imageTagMutability },\n  { header: 'Repository URI', value: r => r.repositoryUri },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const instanceColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'EC2 Instance', value: r => r.ec2InstanceId },\n  { header: 'Type', value: r => r.instanceType },\n  { header: 'Market', value: r => r.marketType },\n  { header: 'Status', value: r => r.status },\n  { header: 'Duration', value: r => formatDuration(r.durationMs) },\n  { header: 'Est. Instance ($)', value: r => formatCurrency(r.estimatedInstanceCost) },\n  { header: 'Est. EBS ($)', value: r => formatCurrency(r.estimatedEbsCost) },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Instance ($)', value: r => formatCurrency(r.actualInstanceCost) },\n  { header: 'Actual EBS ($)', value: r => formatCurrency(r.actualEbsCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Launch Time', value: r => formatDateTime(r.launchTime) },\n  { header: 'Environment ID', value: r => r.environmentId },\n]\n\nexport const activityLogColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'User', value: r => ((r.principal as Record<string, unknown>)?.user as Record<string, unknown>)?.email ?? (r.principal as Record<string, unknown>)?.id ?? r.principalId },\n  { header: 'Action', value: r => r.action },\n  { header: 'Entity Type', value: r => r.entityType },\n  { header: 'Entity ID', value: r => r.entityId },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const imageColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Tag', value: r => r.tag },\n  { header: 'Digest', value: r => r.digest },\n  { header: 'Size (bytes)', value: r => r.sizeBytes },\n  { header: 'Status', value: r => r.status },\n  { header: 'Image URI', value: r => r.imageUri },\n  { header: 'Pushed At', value: r => formatDateTime(r.pushedAt) },\n]\n\nexport const pluginColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Type', value: r => r.type },\n  { header: 'Environment', value: r => (r.environment as Record<string, unknown> | null)?.name ?? r.environmentId },\n  { header: 'Status', value: r => r.status },\n  { header: 'LB DNS', value: r => r.loadBalancerDns },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const tenantColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\n  { header: 'Name', value: r => r.name },\n  { header: 'Contact Email', value: r => r.contactEmail },\n  { header: 'Status', value: r => r.status },\n  { header: 'Created At', value: r => formatDateTime(r.createdAt) },\n]\n\nexport const analyticsSummaryColumns: ColumnDef[] = [\n  { header: 'Est. Instance ($)', value: r => formatCurrency(r.totalEstimatedInstanceCost) },\n  { header: 'Est. EBS ($)', value: r => formatCurrency(r.totalEstimatedEbsCost) },\n  { header: 'Est. ECS ($)', value: r => formatCurrency(r.totalEstimatedEcsCost) },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.totalEstimatedCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.totalActualCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n  { header: 'Submissions', value: r => r.submissionCount },\n]\n\nexport const analyticsBySubmissionColumns: ColumnDef[] = [\n  { header: 'Submission ID', value: r => r.submissionId },\n  { header: 'Status', value: r => r.submissionStatus },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsByEnvironmentColumns: ColumnDef[] = [\n  { header: 'Environment ID', value: r => r.environmentId },\n  { header: 'Name', value: r => r.environmentName },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsByQueueColumns: ColumnDef[] = [\n  { header: 'Queue ID', value: r => r.queueId },\n  { header: 'Name', value: r => r.queueName },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsByInstanceTypeColumns: ColumnDef[] = [\n  { header: 'Instance Type', value: r => r.instanceType },\n  { header: 'Market', value: r => r.marketType },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const analyticsOverTimeColumns: ColumnDef[] = [\n  { header: 'Period', value: r => r.period },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const costsByEngineColumns: ColumnDef[] = [\n  { header: 'Engine ID', value: r => r.engineId },\n  { header: 'Name', value: r => r.engineName },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n\nexport const costsByExecutionModeColumns: ColumnDef[] = [\n  { header: 'Execution Mode', value: r => r.executionMode },\n  { header: 'Est. Total ($)', value: r => formatCurrency(r.estimatedTotalCost) },\n  { header: 'Actual Total ($)', value: r => formatCurrency(r.actualTotalCost) },\n  { header: 'Instances', value: r => r.instanceCount },\n]\n"]}
|
package/dist/index.js
CHANGED
|
@@ -5,6 +5,7 @@ const commander_1 = require("commander");
|
|
|
5
5
|
const auth_1 = require("./commands/auth");
|
|
6
6
|
const user_1 = require("./commands/user");
|
|
7
7
|
const workflow_1 = require("./commands/workflow");
|
|
8
|
+
const workflow_version_1 = require("./commands/workflow-version");
|
|
8
9
|
const submission_1 = require("./commands/submission");
|
|
9
10
|
const queue_1 = require("./commands/queue");
|
|
10
11
|
const environment_1 = require("./commands/environment");
|
|
@@ -20,7 +21,7 @@ const activity_log_1 = require("./commands/activity-log");
|
|
|
20
21
|
const api_token_1 = require("./commands/api-token");
|
|
21
22
|
const tenant_1 = require("./commands/tenant");
|
|
22
23
|
const plugin_1 = require("./commands/plugin");
|
|
23
|
-
const
|
|
24
|
+
const costs_1 = require("./commands/costs");
|
|
24
25
|
const errors_1 = require("./errors");
|
|
25
26
|
const program = new commander_1.Command();
|
|
26
27
|
program
|
|
@@ -39,6 +40,7 @@ program.hook('preAction', () => {
|
|
|
39
40
|
program.addCommand(auth_1.authCommand);
|
|
40
41
|
program.addCommand(user_1.userCommand);
|
|
41
42
|
program.addCommand(workflow_1.workflowCommand);
|
|
43
|
+
program.addCommand(workflow_version_1.workflowVersionCommand);
|
|
42
44
|
program.addCommand(submission_1.submissionCommand);
|
|
43
45
|
program.addCommand(queue_1.queueCommand);
|
|
44
46
|
program.addCommand(environment_1.environmentCommand);
|
|
@@ -55,7 +57,7 @@ program.addCommand(activity_log_1.activityLogCommand);
|
|
|
55
57
|
program.addCommand(api_token_1.apiTokenCommand);
|
|
56
58
|
program.addCommand(tenant_1.tenantCommand);
|
|
57
59
|
program.addCommand(plugin_1.pluginCommand);
|
|
58
|
-
program.addCommand(
|
|
60
|
+
program.addCommand(costs_1.costsCommand);
|
|
59
61
|
applyHelpOnNoArgs(program);
|
|
60
62
|
applyExitOverride(program);
|
|
61
63
|
async function main() {
|
|
@@ -90,4 +92,4 @@ function applyExitOverride(command) {
|
|
|
90
92
|
command.exitOverride();
|
|
91
93
|
command.commands.forEach(applyExitOverride);
|
|
92
94
|
}
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport { Command } from 'commander'\nimport { authCommand } from './commands/auth'\nimport { userCommand } from './commands/user'\nimport { workflowCommand } from './commands/workflow'\nimport { workflowVersionCommand } from './commands/workflow-version'\nimport { submissionCommand } from './commands/submission'\nimport { queueCommand } from './commands/queue'\nimport { environmentCommand } from './commands/environment'\nimport { engineCommand } from './commands/engine'\nimport { setupCommand } from './commands/setup'\nimport { storageCommand } from './commands/storage'\nimport { taskCommand } from './commands/task'\nimport { submissionLogCommand, taskLogCommand } from './commands/log'\nimport { registryCommand } from './commands/registry'\nimport { imageCommand } from './commands/image'\nimport { instanceCommand } from './commands/instance'\nimport { activityLogCommand } from './commands/activity-log'\nimport { apiTokenCommand } from './commands/api-token'\nimport { tenantCommand } from './commands/tenant'\nimport { pluginCommand } from './commands/plugin'\nimport { costsCommand } from './commands/costs'\nimport { isDebugEnabled, printCliError, toCliError, wantsJsonError } from './errors'\n\nconst program = new Command()\n\nprogram\n  .name('geni')\n  .description('Geni Workflows — Bioinformatics')\n  .version('0.1.3')\n  .option('--debug', 'Show debug error details')\n  .option('--api-token <token>', 'Authenticate with an API token (sets X-API-Key header)')\n  .configureOutput({ writeErr: () => { } })\n\nprogram.hook('preAction', () => {\n  const token = (program.opts() as { apiToken?: string }).apiToken\n  if (token) {\n    process.env.GENI_API_TOKEN = token\n  }\n})\n\nprogram.addCommand(authCommand)\nprogram.addCommand(userCommand)\nprogram.addCommand(workflowCommand)\nprogram.addCommand(workflowVersionCommand)\nprogram.addCommand(submissionCommand)\nprogram.addCommand(queueCommand)\nprogram.addCommand(environmentCommand)\nprogram.addCommand(engineCommand)\nprogram.addCommand(setupCommand)\nprogram.addCommand(storageCommand)\nprogram.addCommand(taskCommand)\nprogram.addCommand(submissionLogCommand)\nprogram.addCommand(taskLogCommand)\nprogram.addCommand(registryCommand)\nprogram.addCommand(imageCommand)\nprogram.addCommand(instanceCommand)\nprogram.addCommand(activityLogCommand)\nprogram.addCommand(apiTokenCommand)\nprogram.addCommand(tenantCommand)\nprogram.addCommand(pluginCommand)\nprogram.addCommand(costsCommand)\n\napplyHelpOnNoArgs(program)\napplyExitOverride(program)\n\nasync function main(): Promise<void> {\n  try {\n    await program.parseAsync(process.argv)\n  } catch (err: unknown) {\n    const maybeCommander = err as { code?: string; exitCode?: number }\n    const commanderDisplayCode = maybeCommander.code\n    if (\n      commanderDisplayCode === 'commander.help' ||\n      commanderDisplayCode === 'commander.helpDisplayed' ||\n      commanderDisplayCode === 'commander.version'\n    ) {\n      process.exit(0)\n    }\n    const cliError = toCliError(err)\n    printCliError(cliError, {\n      json: wantsJsonError(process.argv),\n      debug: isDebugEnabled(process.argv),\n    })\n    process.exit(cliError.exitCode)\n  }\n}\n\nvoid main()\n\nfunction applyHelpOnNoArgs(command: Command): void {\n  if (command.commands.length > 0 && !(command as unknown as { _actionHandler: unknown })._actionHandler) {\n    command.action(() => command.help())\n  }\n  command.commands.forEach(applyHelpOnNoArgs)\n}\n\nfunction applyExitOverride(command: Command): void {\n  command.configureOutput({ writeErr: () => { } })\n  command.exitOverride()\n  command.commands.forEach(applyExitOverride)\n}\n"]}
|
|
@@ -86,7 +86,7 @@ Resources:
|
|
|
86
86
|
{
|
|
87
87
|
"Sid": "BatchOperations",
|
|
88
88
|
"Effect": "Allow",
|
|
89
|
-
"Action": ["batch:SubmitJob", "batch:DescribeJobs", "batch:TerminateJob"],
|
|
89
|
+
"Action": ["batch:SubmitJob", "batch:DescribeJobs", "batch:TerminateJob", "batch:DescribeComputeEnvironments", "batch:UpdateComputeEnvironment"],
|
|
90
90
|
"Resource": "*"
|
|
91
91
|
},
|
|
92
92
|
{
|
|
@@ -282,6 +282,7 @@ Resources:
|
|
|
282
282
|
Effect: Allow
|
|
283
283
|
Action:
|
|
284
284
|
- ec2:CreateLaunchTemplate
|
|
285
|
+
- ec2:CreateLaunchTemplateVersion
|
|
285
286
|
- ec2:DeleteLaunchTemplate
|
|
286
287
|
- ec2:RunInstances
|
|
287
288
|
- ec2:TerminateInstances
|