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.
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const costsCommand: Command;
@@ -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"]}
@@ -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":";;;;;;AAAA,yCAA2C;AAC3C,4CAAmB;AACnB,gDAAuB;AACvB,kCAA6E;AAC7E,sCAA2C;AAC3C,4CAAiF;AAEjF,SAAS,kBAAkB,CAAC,KAAa;IACvC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1C,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QAC5C,MAAM,IAAA,wBAAe,EACnB,uDAAuD,EACvD,mBAAmB,CACpB,CAAA;IACH,CAAC;IACD,MAAM,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,GAAG,KAAK,CAAA;IACpC,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,EAAE,CAAC,CAAA;AACzD,CAAC;AAGY,QAAA,iBAAiB,GAAG,IAAI,mBAAO,CAAC,YAAY,CAAC;KACvD,WAAW,CAAC,6BAA6B,CAAC,CAAA;AAE7C,yBAAiB;KACd,OAAO,CAAC,MAAM,CAAC;KACf,WAAW,CAAC,kBAAkB,CAAC;KAC/B,MAAM,CAAC,mBAAmB,EAAE,iDAAiD,CAAC;KAC9E,MAAM,CAAC,aAAa,EAAE,qCAAqC,EAAE,IAAI,CAAC;KAClE,SAAS,CAAC,IAAI,kBAAM,CAAC,mBAAmB,EAAE,eAAe,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;KAC9G,MAAM,CAAC,KAAK,EAAE,IAA8D,EAAE,EAAE;IAC/E,MAAM,MAAM,GAAG,IAAI,eAAe,EAAE,CAAA;IACpC,IAAI,IAAI,CAAC,MAAM;QAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IAClD,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAA;IAC/B,MAAM,IAAI,GAAG,MAAM,IAAA,gBAAS,EAAC,IAAA,aAAM,EAAC,gBAAgB,MAAM,EAAE,CAAC,CAAyB,CAAA;IACtF,IAAA,wBAAY,EAAC,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,6BAAiB,CAAC,CAAA;AAC1F,CAAC,CAAC,CAAA;AAEJ,yBAAiB;KACd,OAAO,CAAC,UAAU,CAAC;KACnB,WAAW,CAAC,wBAAwB,CAAC;KACrC,SAAS,CAAC,IAAI,kBAAM,CAAC,mBAAmB,EAAE,eAAe,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;KAC9G,MAAM,CAAC,KAAK,EAAE,EAAU,EAAE,IAA8B,EAAE,EAAE;IAC3D,MAAM,IAAI,GAAG,MAAM,IAAA,gBAAS,EAAC,IAAA,aAAM,EAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC,CAAA;IAC1D,IAAA,wBAAY,EAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,6BAAiB,CAAC,CAAA;AACpD,CAAC,CAAC,CAAA;AAEJ,yBAAiB;KACd,OAAO,CAAC,QAAQ,CAAC;KACjB,WAAW,CAAC,uBAAuB,CAAC;KACpC,cAAc,CAAC,wBAAwB,EAAE,eAAe,CAAC;KACzD,MAAM,CAAC,8BAA8B,EAAE,kBAAkB,CAAC;KAC1D,cAAc,CAAC,sBAAsB,EAAE,wCAAwC,CAAC;KAChF,cAAc,CAAC,kBAAkB,EAAE,WAAW,CAAC;KAC/C,cAAc,CAAC,iBAAiB,EAAE,UAAU,CAAC;KAC7C,cAAc,CAAC,0BAA0B,EAAE,wEAAwE,CAAC;KACpH,MAAM,CAAC,yBAAyB,EAAE,gCAAgC,CAAC;KACnE,MAAM,CAAC,0BAA0B,EAAE,iCAAiC,CAAC;KACrE,SAAS,CAAC,IAAI,kBAAM,CAAC,mBAAmB,EAAE,eAAe,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;KAC9G,MAAM,CAAC,KAAK,EAAE,IAUd,EAAE,EAAE;IACH,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAA;IAC3B,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;IAC9C,IAAI,IAAI,CAAC,eAAe;QAAE,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAA;IAC9E,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;IACtC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;IACpC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;IACxC,IAAI,IAAI,CAAC,SAAS;QAAE,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,MAAM,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAA;IAC/F,IAAI,IAAI,CAAC,UAAU;QAAE,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE,MAAM,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;IAClG,MAAM,YAAY,GAAG,MAAM,YAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;IAChE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,EAAE,cAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAA;IAE/E,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,IAAA,aAAM,EAAC,cAAc,CAAC,EAAE;QAC9C,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,IAAA,qBAAc,GAAE;QACzB,IAAI,EAAE,IAAI;KACX,CAAC,CAAA;IACF,MAAM,IAAI,GAAG,MAAM,IAAA,uBAAgB,EAAC,GAAG,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,IAAA,aAAM,EAAC,cAAc,CAAC,EAAE,CAAC,CAAA;IACzF,IAAA,wBAAY,EAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,6BAAiB,CAAC,CAAA;AACpD,CAAC,CAAC,CAAA;AAEJ,yBAAiB;KACd,OAAO,CAAC,aAAa,CAAC;KACtB,WAAW,CAAC,6BAA6B,CAAC;KAC1C,MAAM,CAAC,KAAK,EAAE,EAAU,EAAE,EAAE;IAC3B,MAAM,GAAG,GAAG,IAAA,aAAM,EAAC,gBAAgB,EAAE,SAAS,CAAC,CAAA;IAC/C,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;QAC3B,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,IAAA,qBAAc,GAAE;KAC1B,CAAC,CAAA;IACF,MAAM,IAAI,GAAG,MAAM,IAAA,uBAAgB,EAAC,GAAG,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,CAA8C,CAAA;IAC9G,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,YAAY,GAAG,CAAC,CAAA;AACvD,CAAC,CAAC,CAAA;AAEJ,yBAAiB;KACd,OAAO,CAAC,YAAY,CAAC;KACrB,WAAW,CAAC,2BAA2B,CAAC;KACxC,MAAM,CAAC,kBAAkB,EAAE,wBAAwB,CAAC;KACpD,MAAM,CAAC,iBAAiB,EAAE,uBAAuB,CAAC;KAClD,MAAM,CAAC,KAAK,EAAE,EAAU,EAAE,IAA6C,EAAE,EAAE;IAC1E,MAAM,GAAG,GAAG,IAAA,aAAM,EAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAA;IAC9C,MAAM,IAAI,GAA2B,EAAE,CAAA;IACvC,IAAI,IAAI,CAAC,QAAQ;QAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAA;IAChD,IAAI,IAAI,CAAC,OAAO;QAAE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA;IAC7C,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;QAC3B,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,EAAE,GAAG,IAAA,qBAAc,GAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE;QACpE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;KAC3B,CAAC,CAAA;IACF,MAAM,IAAI,GAAG,MAAM,IAAA,uBAAgB,EAAC,GAAG,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,CAA8C,CAAA;IAC9G,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,YAAY,GAAG,CAAC,CAAA;AACvD,CAAC,CAAC,CAAA","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,2 @@
1
+ import { Command } from 'commander';
2
+ export declare const workflowVersionCommand: Command;
@@ -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":"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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 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 analytics_1 = require("./commands/analytics");
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(analytics_1.analyticsCommand);
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,{"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 { 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 { analyticsCommand } from './commands/analytics'\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(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(analyticsCommand)\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"]}
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
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "geni-bioinfo",
3
- "version": "0.1.4",
3
+ "version": "0.1.6",
4
4
  "description": "CLI for GENI — a control plane for running Nextflow bioinformatics pipelines on AWS",
5
5
  "license": "MIT",
6
6
  "repository": {