geni-bioinfo 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/auth.d.ts +8 -0
- package/dist/auth.js +76 -0
- package/dist/aws/clients.d.ts +18 -0
- package/dist/aws/clients.js +34 -0
- package/dist/commands/activate.d.ts +2 -0
- package/dist/commands/activate.js +20 -0
- package/dist/commands/activity-log.d.ts +2 -0
- package/dist/commands/activity-log.js +31 -0
- package/dist/commands/api-token.d.ts +2 -0
- package/dist/commands/api-token.js +96 -0
- package/dist/commands/auth.d.ts +2 -0
- package/dist/commands/auth.js +55 -0
- package/dist/commands/engine.d.ts +2 -0
- package/dist/commands/engine.js +83 -0
- package/dist/commands/environment.d.ts +2 -0
- package/dist/commands/environment.js +69 -0
- package/dist/commands/image.d.ts +2 -0
- package/dist/commands/image.js +40 -0
- package/dist/commands/instance.d.ts +2 -0
- package/dist/commands/instance.js +39 -0
- package/dist/commands/log.d.ts +3 -0
- package/dist/commands/log.js +43 -0
- package/dist/commands/login.d.ts +2 -0
- package/dist/commands/login.js +24 -0
- package/dist/commands/plugin.d.ts +2 -0
- package/dist/commands/plugin.js +80 -0
- package/dist/commands/queue.d.ts +2 -0
- package/dist/commands/queue.js +74 -0
- package/dist/commands/registry.d.ts +2 -0
- package/dist/commands/registry.js +72 -0
- package/dist/commands/setup/create.d.ts +2 -0
- package/dist/commands/setup/create.js +254 -0
- package/dist/commands/setup/delete.d.ts +2 -0
- package/dist/commands/setup/delete.js +97 -0
- package/dist/commands/setup/status.d.ts +2 -0
- package/dist/commands/setup/status.js +46 -0
- package/dist/commands/setup.d.ts +2 -0
- package/dist/commands/setup.js +13 -0
- package/dist/commands/storage.d.ts +2 -0
- package/dist/commands/storage.js +67 -0
- package/dist/commands/submission.d.ts +2 -0
- package/dist/commands/submission.js +87 -0
- package/dist/commands/task.d.ts +2 -0
- package/dist/commands/task.js +21 -0
- package/dist/commands/tenant.d.ts +2 -0
- package/dist/commands/tenant.js +68 -0
- package/dist/commands/user.d.ts +2 -0
- package/dist/commands/user.js +82 -0
- package/dist/commands/workflow.d.ts +2 -0
- package/dist/commands/workflow.js +80 -0
- package/dist/errors.d.ts +38 -0
- package/dist/errors.js +194 -0
- package/dist/format.d.ts +22 -0
- package/dist/format.js +155 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +91 -0
- package/dist/templates/setup.yaml +503 -0
- package/package.json +49 -0
package/dist/errors.js
ADDED
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HttpRequestError = exports.CliError = void 0;
|
|
4
|
+
exports.invalidArgument = invalidArgument;
|
|
5
|
+
exports.notFound = notFound;
|
|
6
|
+
exports.isDebugEnabled = isDebugEnabled;
|
|
7
|
+
exports.wantsJsonError = wantsJsonError;
|
|
8
|
+
exports.toCliError = toCliError;
|
|
9
|
+
exports.printCliError = printCliError;
|
|
10
|
+
class CliError extends Error {
|
|
11
|
+
code;
|
|
12
|
+
exitCode;
|
|
13
|
+
hint;
|
|
14
|
+
details;
|
|
15
|
+
constructor(params) {
|
|
16
|
+
super(params.message, { cause: params.cause });
|
|
17
|
+
this.name = 'CliError';
|
|
18
|
+
this.code = params.code;
|
|
19
|
+
this.exitCode = params.exitCode;
|
|
20
|
+
this.hint = params.hint;
|
|
21
|
+
this.details = params.details;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.CliError = CliError;
|
|
25
|
+
class HttpRequestError extends Error {
|
|
26
|
+
status;
|
|
27
|
+
method;
|
|
28
|
+
url;
|
|
29
|
+
body;
|
|
30
|
+
parsedBody;
|
|
31
|
+
constructor(params) {
|
|
32
|
+
super(`HTTP ${params.status}`);
|
|
33
|
+
this.name = 'HttpRequestError';
|
|
34
|
+
this.status = params.status;
|
|
35
|
+
this.method = params.method;
|
|
36
|
+
this.url = params.url;
|
|
37
|
+
this.body = params.body;
|
|
38
|
+
this.parsedBody = params.parsedBody;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.HttpRequestError = HttpRequestError;
|
|
42
|
+
function extractMessageFromPayload(payload) {
|
|
43
|
+
if (!payload || typeof payload !== 'object')
|
|
44
|
+
return null;
|
|
45
|
+
const body = payload;
|
|
46
|
+
const keys = ['message', 'error', 'detail'];
|
|
47
|
+
for (const key of keys) {
|
|
48
|
+
const value = body[key];
|
|
49
|
+
if (typeof value === 'string' && value.trim())
|
|
50
|
+
return value;
|
|
51
|
+
}
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
function normalizeMessage(err) {
|
|
55
|
+
if (err instanceof Error && err.message)
|
|
56
|
+
return err.message;
|
|
57
|
+
if (typeof err === 'string' && err.trim())
|
|
58
|
+
return err;
|
|
59
|
+
return 'Unexpected error';
|
|
60
|
+
}
|
|
61
|
+
function cleanMessage(message) {
|
|
62
|
+
return message.replace(/^error:\s*/i, '');
|
|
63
|
+
}
|
|
64
|
+
function asRecord(value) {
|
|
65
|
+
if (!value || typeof value !== 'object')
|
|
66
|
+
return null;
|
|
67
|
+
return value;
|
|
68
|
+
}
|
|
69
|
+
function invalidArgument(message, hint) {
|
|
70
|
+
return new CliError({ code: 'INVALID_ARGUMENT', message, hint, exitCode: 2 });
|
|
71
|
+
}
|
|
72
|
+
function notFound(message) {
|
|
73
|
+
return new CliError({ code: 'NOT_FOUND', message, exitCode: 4 });
|
|
74
|
+
}
|
|
75
|
+
function isDebugEnabled(argv = process.argv) {
|
|
76
|
+
return argv.includes('--debug') || process.env.GENI_DEBUG === '1';
|
|
77
|
+
}
|
|
78
|
+
function wantsJsonError(argv = process.argv) {
|
|
79
|
+
for (let i = 0; i < argv.length; i += 1) {
|
|
80
|
+
const token = argv[i];
|
|
81
|
+
if (token === '--format' && argv[i + 1] === 'json')
|
|
82
|
+
return true;
|
|
83
|
+
if (token === '--format=json')
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
function toCliError(err) {
|
|
89
|
+
if (err instanceof CliError)
|
|
90
|
+
return err;
|
|
91
|
+
const commanderError = asRecord(err);
|
|
92
|
+
if (commanderError &&
|
|
93
|
+
typeof commanderError.code === 'string' &&
|
|
94
|
+
commanderError.code.startsWith('commander.')) {
|
|
95
|
+
return new CliError({
|
|
96
|
+
code: 'INVALID_ARGUMENT',
|
|
97
|
+
message: cleanMessage(normalizeMessage(err)),
|
|
98
|
+
exitCode: 2,
|
|
99
|
+
cause: err,
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
if (err instanceof HttpRequestError) {
|
|
103
|
+
const payloadMessage = extractMessageFromPayload(err.parsedBody);
|
|
104
|
+
const fallback = payloadMessage ?? (err.body.trim() || `Request failed with status ${err.status}.`);
|
|
105
|
+
if (err.status === 401 || err.status === 403) {
|
|
106
|
+
return new CliError({
|
|
107
|
+
code: 'AUTH',
|
|
108
|
+
message: `Authentication/authorization failed: ${fallback}`,
|
|
109
|
+
hint: 'Run `geni login` again or verify your token permissions.',
|
|
110
|
+
exitCode: 3,
|
|
111
|
+
details: { status: err.status, method: err.method, url: err.url, body: err.body },
|
|
112
|
+
cause: err,
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
if (err.status === 404) {
|
|
116
|
+
return new CliError({
|
|
117
|
+
code: 'NOT_FOUND',
|
|
118
|
+
message: fallback,
|
|
119
|
+
exitCode: 4,
|
|
120
|
+
details: { status: err.status, method: err.method, url: err.url, body: err.body },
|
|
121
|
+
cause: err,
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
return new CliError({
|
|
125
|
+
code: 'UPSTREAM',
|
|
126
|
+
message: fallback,
|
|
127
|
+
exitCode: 5,
|
|
128
|
+
details: { status: err.status, method: err.method, url: err.url, body: err.body },
|
|
129
|
+
cause: err,
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
const message = normalizeMessage(err);
|
|
133
|
+
if (message.toLowerCase().includes('not found')) {
|
|
134
|
+
return new CliError({
|
|
135
|
+
code: 'NOT_FOUND',
|
|
136
|
+
message,
|
|
137
|
+
exitCode: 4,
|
|
138
|
+
cause: err,
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
if (message.includes('No authentication token found')) {
|
|
142
|
+
return new CliError({
|
|
143
|
+
code: 'AUTH',
|
|
144
|
+
message,
|
|
145
|
+
hint: 'Run `geni login --email <email> --password <password>` first.',
|
|
146
|
+
exitCode: 3,
|
|
147
|
+
cause: err,
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
if (err instanceof TypeError && message.toLowerCase().includes('fetch')) {
|
|
151
|
+
return new CliError({
|
|
152
|
+
code: 'UPSTREAM',
|
|
153
|
+
message: `Network error while contacting API: ${message}`,
|
|
154
|
+
exitCode: 5,
|
|
155
|
+
cause: err,
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
return new CliError({
|
|
159
|
+
code: 'INTERNAL',
|
|
160
|
+
message,
|
|
161
|
+
exitCode: 1,
|
|
162
|
+
cause: err,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
function printCliError(err, opts) {
|
|
166
|
+
if (opts.json) {
|
|
167
|
+
const payload = {
|
|
168
|
+
error: {
|
|
169
|
+
code: err.code,
|
|
170
|
+
message: err.message,
|
|
171
|
+
},
|
|
172
|
+
};
|
|
173
|
+
if (err.hint)
|
|
174
|
+
payload.error.hint = err.hint;
|
|
175
|
+
if (opts.debug && err.details !== undefined)
|
|
176
|
+
payload.error.details = err.details;
|
|
177
|
+
process.stderr.write(`${JSON.stringify(payload)}\n`);
|
|
178
|
+
if (opts.debug && err.stack) {
|
|
179
|
+
process.stderr.write(`${err.stack}\n`);
|
|
180
|
+
}
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
process.stderr.write(`Error: ${err.message}\n`);
|
|
184
|
+
if (err.hint) {
|
|
185
|
+
process.stderr.write(`Hint: ${err.hint}\n`);
|
|
186
|
+
}
|
|
187
|
+
if (opts.debug && err.details !== undefined) {
|
|
188
|
+
process.stderr.write(`Details: ${JSON.stringify(err.details, null, 2)}\n`);
|
|
189
|
+
}
|
|
190
|
+
if (opts.debug && err.stack) {
|
|
191
|
+
process.stderr.write(`${err.stack}\n`);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"errors.js","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"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","sourcesContent":["export type CliErrorCode =\n  | 'INVALID_ARGUMENT'\n  | 'AUTH'\n  | 'NOT_FOUND'\n  | 'UPSTREAM'\n  | 'INTERNAL';\n\nexport class CliError extends Error {\n  code: CliErrorCode;\n  exitCode: number;\n  hint?: string;\n  details?: unknown;\n\n  constructor(params: {\n    code: CliErrorCode;\n    message: string;\n    exitCode: number;\n    hint?: string;\n    details?: unknown;\n    cause?: unknown;\n  }) {\n    super(params.message, { cause: params.cause });\n    this.name = 'CliError';\n    this.code = params.code;\n    this.exitCode = params.exitCode;\n    this.hint = params.hint;\n    this.details = params.details;\n  }\n}\n\nexport class HttpRequestError extends Error {\n  status: number;\n  method: string;\n  url: string;\n  body: string;\n  parsedBody?: unknown;\n\n  constructor(params: {\n    status: number;\n    method: string;\n    url: string;\n    body: string;\n    parsedBody?: unknown;\n  }) {\n    super(`HTTP ${params.status}`);\n    this.name = 'HttpRequestError';\n    this.status = params.status;\n    this.method = params.method;\n    this.url = params.url;\n    this.body = params.body;\n    this.parsedBody = params.parsedBody;\n  }\n}\n\nfunction extractMessageFromPayload(payload: unknown): string | null {\n  if (!payload || typeof payload !== 'object') return null;\n  const body = payload as Record<string, unknown>;\n  const keys = ['message', 'error', 'detail'];\n  for (const key of keys) {\n    const value = body[key];\n    if (typeof value === 'string' && value.trim()) return value;\n  }\n  return null;\n}\n\nfunction normalizeMessage(err: unknown): string {\n  if (err instanceof Error && err.message) return err.message;\n  if (typeof err === 'string' && err.trim()) return err;\n  return 'Unexpected error';\n}\n\nfunction cleanMessage(message: string): string {\n  return message.replace(/^error:\\s*/i, '');\n}\n\nfunction asRecord(value: unknown): Record<string, unknown> | null {\n  if (!value || typeof value !== 'object') return null;\n  return value as Record<string, unknown>;\n}\n\nexport function invalidArgument(message: string, hint?: string): CliError {\n  return new CliError({ code: 'INVALID_ARGUMENT', message, hint, exitCode: 2 });\n}\n\nexport function notFound(message: string): CliError {\n  return new CliError({ code: 'NOT_FOUND', message, exitCode: 4 });\n}\n\nexport function isDebugEnabled(argv: string[] = process.argv): boolean {\n  return argv.includes('--debug') || process.env.GENI_DEBUG === '1';\n}\n\nexport function wantsJsonError(argv: string[] = process.argv): boolean {\n  for (let i = 0; i < argv.length; i += 1) {\n    const token = argv[i];\n    if (token === '--format' && argv[i + 1] === 'json') return true;\n    if (token === '--format=json') return true;\n  }\n  return false;\n}\n\nexport function toCliError(err: unknown): CliError {\n  if (err instanceof CliError) return err;\n\n  const commanderError = asRecord(err);\n  if (\n    commanderError &&\n    typeof commanderError.code === 'string' &&\n    commanderError.code.startsWith('commander.')\n  ) {\n    return new CliError({\n      code: 'INVALID_ARGUMENT',\n      message: cleanMessage(normalizeMessage(err)),\n      exitCode: 2,\n      cause: err,\n    });\n  }\n\n  if (err instanceof HttpRequestError) {\n    const payloadMessage = extractMessageFromPayload(err.parsedBody);\n    const fallback = payloadMessage ?? (err.body.trim() || `Request failed with status ${err.status}.`);\n\n    if (err.status === 401 || err.status === 403) {\n      return new CliError({\n        code: 'AUTH',\n        message: `Authentication/authorization failed: ${fallback}`,\n        hint: 'Run `geni login` again or verify your token permissions.',\n        exitCode: 3,\n        details: { status: err.status, method: err.method, url: err.url, body: err.body },\n        cause: err,\n      });\n    }\n    if (err.status === 404) {\n      return new CliError({\n        code: 'NOT_FOUND',\n        message: fallback,\n        exitCode: 4,\n        details: { status: err.status, method: err.method, url: err.url, body: err.body },\n        cause: err,\n      });\n    }\n    return new CliError({\n      code: 'UPSTREAM',\n      message: fallback,\n      exitCode: 5,\n      details: { status: err.status, method: err.method, url: err.url, body: err.body },\n      cause: err,\n    });\n  }\n\n  const message = normalizeMessage(err);\n  if (message.toLowerCase().includes('not found')) {\n    return new CliError({\n      code: 'NOT_FOUND',\n      message,\n      exitCode: 4,\n      cause: err,\n    });\n  }\n  if (message.includes('No authentication token found')) {\n    return new CliError({\n      code: 'AUTH',\n      message,\n      hint: 'Run `geni login --email <email> --password <password>` first.',\n      exitCode: 3,\n      cause: err,\n    });\n  }\n\n  if (err instanceof TypeError && message.toLowerCase().includes('fetch')) {\n    return new CliError({\n      code: 'UPSTREAM',\n      message: `Network error while contacting API: ${message}`,\n      exitCode: 5,\n      cause: err,\n    });\n  }\n\n  return new CliError({\n    code: 'INTERNAL',\n    message,\n    exitCode: 1,\n    cause: err,\n  });\n}\n\nexport function printCliError(err: CliError, opts: { json: boolean; debug: boolean }): void {\n  if (opts.json) {\n    const payload: {\n      error: {\n        code: CliErrorCode;\n        message: string;\n        hint?: string;\n        details?: unknown;\n      };\n    } = {\n      error: {\n        code: err.code,\n        message: err.message,\n      },\n    };\n    if (err.hint) payload.error.hint = err.hint;\n    if (opts.debug && err.details !== undefined) payload.error.details = err.details;\n    process.stderr.write(`${JSON.stringify(payload)}\\n`);\n    if (opts.debug && err.stack) {\n      process.stderr.write(`${err.stack}\\n`);\n    }\n    return;\n  }\n\n  process.stderr.write(`Error: ${err.message}\\n`);\n  if (err.hint) {\n    process.stderr.write(`Hint: ${err.hint}\\n`);\n  }\n  if (opts.debug && err.details !== undefined) {\n    process.stderr.write(`Details: ${JSON.stringify(err.details, null, 2)}\\n`);\n  }\n  if (opts.debug && err.stack) {\n    process.stderr.write(`${err.stack}\\n`);\n  }\n}\n"]}
|
package/dist/format.d.ts
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export type OutputFormat = 'table' | 'json' | 'csv';
|
|
2
|
+
interface ColumnDef {
|
|
3
|
+
header: string;
|
|
4
|
+
value: (item: Record<string, unknown>) => unknown;
|
|
5
|
+
}
|
|
6
|
+
export declare function formatOutput(data: unknown, format: OutputFormat, columns: ColumnDef[]): void;
|
|
7
|
+
export declare const workflowColumns: ColumnDef[];
|
|
8
|
+
export declare const submissionColumns: ColumnDef[];
|
|
9
|
+
export declare const environmentColumns: ColumnDef[];
|
|
10
|
+
export declare const queueColumns: ColumnDef[];
|
|
11
|
+
export declare const engineColumns: ColumnDef[];
|
|
12
|
+
export declare const storageColumns: ColumnDef[];
|
|
13
|
+
export declare const taskColumns: ColumnDef[];
|
|
14
|
+
export declare const submissionLogColumns: ColumnDef[];
|
|
15
|
+
export declare const taskLogColumns: ColumnDef[];
|
|
16
|
+
export declare const registryColumns: ColumnDef[];
|
|
17
|
+
export declare const instanceColumns: ColumnDef[];
|
|
18
|
+
export declare const activityLogColumns: ColumnDef[];
|
|
19
|
+
export declare const imageColumns: ColumnDef[];
|
|
20
|
+
export declare const pluginColumns: ColumnDef[];
|
|
21
|
+
export declare const tenantColumns: ColumnDef[];
|
|
22
|
+
export {};
|
package/dist/format.js
ADDED
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
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;
|
|
7
|
+
exports.formatOutput = formatOutput;
|
|
8
|
+
const cli_table3_1 = __importDefault(require("cli-table3"));
|
|
9
|
+
function formatOutput(data, format, columns) {
|
|
10
|
+
const items = Array.isArray(data) ? data : [data];
|
|
11
|
+
const headers = columns.map(c => c.header);
|
|
12
|
+
const rows = items.map(item => columns.map(c => {
|
|
13
|
+
const val = c.value(item);
|
|
14
|
+
return val === null || val === undefined ? '' : String(val);
|
|
15
|
+
}));
|
|
16
|
+
if (format === 'json') {
|
|
17
|
+
console.log(JSON.stringify(data, null, 2));
|
|
18
|
+
}
|
|
19
|
+
else if (format === 'csv') {
|
|
20
|
+
console.log(headers.join(','));
|
|
21
|
+
rows.forEach(row => console.log(row.map(v => `"${v.replace(/"/g, '""')}"`).join(',')));
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
const table = new cli_table3_1.default({ head: headers });
|
|
25
|
+
rows.forEach(row => table.push(row));
|
|
26
|
+
console.log(table.toString());
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
exports.workflowColumns = [
|
|
30
|
+
{ header: 'Name', value: r => r.name },
|
|
31
|
+
{ header: 'Version', value: r => r.version },
|
|
32
|
+
{ header: 'Engine', value: r => r.engine },
|
|
33
|
+
{ header: 'File Type', value: r => r.fileType },
|
|
34
|
+
{ header: 'Latest', value: r => r.latest },
|
|
35
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
36
|
+
];
|
|
37
|
+
exports.submissionColumns = [
|
|
38
|
+
{ header: 'ID', value: r => r.submissionId },
|
|
39
|
+
{ header: 'Status', value: r => r.status },
|
|
40
|
+
{ header: 'Workflow', value: r => r.workflowName },
|
|
41
|
+
{ header: 'Version', value: r => r.workflowVersion },
|
|
42
|
+
{ header: 'Engine ID', value: r => r.engineId },
|
|
43
|
+
{ header: 'Queue ID', value: r => r.queueId },
|
|
44
|
+
{ header: 'Output', value: r => r.output },
|
|
45
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
46
|
+
];
|
|
47
|
+
exports.environmentColumns = [
|
|
48
|
+
{ header: 'ID', value: r => r.id },
|
|
49
|
+
{ header: 'Name', value: r => r.name },
|
|
50
|
+
{ header: 'Cloud ID', value: r => r.cloudId },
|
|
51
|
+
{ header: 'Region', value: r => r.cloudRegion },
|
|
52
|
+
{ header: 'Status', value: r => r.status },
|
|
53
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
54
|
+
];
|
|
55
|
+
exports.queueColumns = [
|
|
56
|
+
{ header: 'ID', value: r => r.id },
|
|
57
|
+
{ header: 'Name', value: r => r.name },
|
|
58
|
+
{ header: 'Environment ID', value: r => r.environmentId },
|
|
59
|
+
{ header: 'Mode', value: r => r.executionMode },
|
|
60
|
+
{ header: 'Max vCPUs', value: r => r.maxvCpus },
|
|
61
|
+
{ header: 'Storage GB', value: r => r.storageSizeGb },
|
|
62
|
+
{ header: 'Status', value: r => r.status },
|
|
63
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
64
|
+
];
|
|
65
|
+
exports.engineColumns = [
|
|
66
|
+
{ header: 'ID', value: r => r.id },
|
|
67
|
+
{ header: 'Name', value: r => r.name },
|
|
68
|
+
{ header: 'Environment ID', value: r => r.environmentId },
|
|
69
|
+
{ header: 'Engine', value: r => r.engine },
|
|
70
|
+
{ header: 'Engine Version', value: r => r.engineVersion },
|
|
71
|
+
{ header: 'Status', value: r => r.status },
|
|
72
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
73
|
+
];
|
|
74
|
+
exports.storageColumns = [
|
|
75
|
+
{ header: 'ID', value: r => r.id },
|
|
76
|
+
{ header: 'Name', value: r => r.name },
|
|
77
|
+
{ header: 'Environment ID', value: r => r.environmentId },
|
|
78
|
+
{ header: 'Permission Mode', value: r => r.permissionMode },
|
|
79
|
+
{ header: 'Bucket Name', value: r => r.bucketName },
|
|
80
|
+
{ header: 'Status', value: r => r.status },
|
|
81
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
82
|
+
];
|
|
83
|
+
exports.taskColumns = [
|
|
84
|
+
{ header: 'ID', value: r => r.id },
|
|
85
|
+
{ header: 'Submission ID', value: r => r.submissionId },
|
|
86
|
+
{ header: 'Job Name', value: r => r.jobName },
|
|
87
|
+
{ header: 'Status', value: r => r.status },
|
|
88
|
+
{ header: 'Exit Code', value: r => r.exitCode },
|
|
89
|
+
{ header: 'Instance ID', value: r => r.instanceId },
|
|
90
|
+
{ header: 'Instance Type', value: r => r.instanceType },
|
|
91
|
+
{ header: 'Started At', value: r => r.startedAt },
|
|
92
|
+
{ header: 'Stopped At', value: r => r.stoppedAt },
|
|
93
|
+
];
|
|
94
|
+
exports.submissionLogColumns = [
|
|
95
|
+
{ header: 'Timestamp', value: r => r.timestamp },
|
|
96
|
+
{ header: 'Message', value: r => r.message },
|
|
97
|
+
];
|
|
98
|
+
exports.taskLogColumns = [
|
|
99
|
+
{ header: 'Job Name', value: r => r.jobName },
|
|
100
|
+
{ header: 'Timestamp', value: r => r.timestamp },
|
|
101
|
+
{ header: 'Message', value: r => r.message },
|
|
102
|
+
];
|
|
103
|
+
exports.registryColumns = [
|
|
104
|
+
{ header: 'ID', value: r => r.id },
|
|
105
|
+
{ header: 'Name', value: r => r.name },
|
|
106
|
+
{ header: 'Mutability', value: r => r.imageTagMutability },
|
|
107
|
+
{ header: 'Repository URI', value: r => r.repositoryUri },
|
|
108
|
+
{ header: 'Status', value: r => r.status },
|
|
109
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
110
|
+
];
|
|
111
|
+
exports.instanceColumns = [
|
|
112
|
+
{ header: 'ID', value: r => r.id },
|
|
113
|
+
{ header: 'EC2 Instance', value: r => r.ec2InstanceId },
|
|
114
|
+
{ header: 'Type', value: r => r.instanceType },
|
|
115
|
+
{ header: 'Market', value: r => r.marketType },
|
|
116
|
+
{ header: 'Status', value: r => r.status },
|
|
117
|
+
{ header: 'Duration (s)', value: r => r.durationSeconds },
|
|
118
|
+
{ header: 'Total Cost ($)', value: r => r.totalCost },
|
|
119
|
+
{ header: 'Launch Time', value: r => r.launchTime },
|
|
120
|
+
{ header: 'Environment ID', value: r => r.environmentId },
|
|
121
|
+
];
|
|
122
|
+
exports.activityLogColumns = [
|
|
123
|
+
{ header: 'ID', value: r => r.id },
|
|
124
|
+
{ header: 'User', value: r => r.principal?.user?.email ?? r.principal?.id ?? r.principalId },
|
|
125
|
+
{ header: 'Action', value: r => r.action },
|
|
126
|
+
{ header: 'Entity Type', value: r => r.entityType },
|
|
127
|
+
{ header: 'Entity ID', value: r => r.entityId },
|
|
128
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
129
|
+
];
|
|
130
|
+
exports.imageColumns = [
|
|
131
|
+
{ header: 'ID', value: r => r.id },
|
|
132
|
+
{ header: 'Tag', value: r => r.tag },
|
|
133
|
+
{ header: 'Digest', value: r => r.digest },
|
|
134
|
+
{ header: 'Size (bytes)', value: r => r.sizeBytes },
|
|
135
|
+
{ header: 'Status', value: r => r.status },
|
|
136
|
+
{ header: 'Image URI', value: r => r.imageUri },
|
|
137
|
+
{ header: 'Pushed At', value: r => r.pushedAt },
|
|
138
|
+
];
|
|
139
|
+
exports.pluginColumns = [
|
|
140
|
+
{ header: 'ID', value: r => r.id },
|
|
141
|
+
{ header: 'Name', value: r => r.name },
|
|
142
|
+
{ header: 'Type', value: r => r.type },
|
|
143
|
+
{ header: 'Environment ID', value: r => r.environmentId },
|
|
144
|
+
{ header: 'Status', value: r => r.status },
|
|
145
|
+
{ header: 'LB DNS', value: r => r.loadBalancerDns },
|
|
146
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
147
|
+
];
|
|
148
|
+
exports.tenantColumns = [
|
|
149
|
+
{ header: 'ID', value: r => r.id },
|
|
150
|
+
{ header: 'Name', value: r => r.name },
|
|
151
|
+
{ header: 'Contact Email', value: r => r.contactEmail },
|
|
152
|
+
{ header: 'Status', value: r => r.status },
|
|
153
|
+
{ header: 'Created At', value: r => r.createdAt },
|
|
154
|
+
];
|
|
155
|
+
//# 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 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 => r.createdAt },\n]\n\nexport const submissionColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.submissionId },\n  { header: 'Status', value: r => r.status },\n  { header: 'Workflow', value: r => r.workflowName },\n  { header: 'Version', value: r => r.workflowVersion },\n  { header: 'Engine ID', value: r => r.engineId },\n  { header: 'Queue ID', value: r => r.queueId },\n  { header: 'Output', value: r => r.output },\n  { header: 'Created At', value: r => 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 => 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 ID', value: r => 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 => 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 ID', value: r => 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 => 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 ID', value: r => 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 => r.createdAt },\n]\n\nexport const taskColumns: ColumnDef[] = [\n  { header: 'ID', value: r => r.id },\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: 'Exit Code', value: r => r.exitCode },\n  { header: 'Instance ID', value: r => r.instanceId },\n  { header: 'Instance Type', value: r => r.instanceType },\n  { header: 'Started At', value: r => r.startedAt },\n  { header: 'Stopped At', value: r => r.stoppedAt },\n]\n\nexport const submissionLogColumns: ColumnDef[] = [\n  { header: 'Timestamp', value: r => 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 => 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 => 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 (s)', value: r => r.durationSeconds },\n  { header: 'Total Cost ($)', value: r => r.totalCost },\n  { header: 'Launch Time', value: r => 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 => 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 => 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 ID', value: r => r.environmentId },\n  { header: 'Status', value: r => r.status },\n  { header: 'LB DNS', value: r => r.loadBalancerDns },\n  { header: 'Created At', value: r => 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 => r.createdAt },\n]\n"]}
|
package/dist/index.d.ts
ADDED
package/dist/index.js
ADDED
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
const commander_1 = require("commander");
|
|
5
|
+
const auth_1 = require("./commands/auth");
|
|
6
|
+
const user_1 = require("./commands/user");
|
|
7
|
+
const workflow_1 = require("./commands/workflow");
|
|
8
|
+
const submission_1 = require("./commands/submission");
|
|
9
|
+
const queue_1 = require("./commands/queue");
|
|
10
|
+
const environment_1 = require("./commands/environment");
|
|
11
|
+
const engine_1 = require("./commands/engine");
|
|
12
|
+
const setup_1 = require("./commands/setup");
|
|
13
|
+
const storage_1 = require("./commands/storage");
|
|
14
|
+
const task_1 = require("./commands/task");
|
|
15
|
+
const log_1 = require("./commands/log");
|
|
16
|
+
const registry_1 = require("./commands/registry");
|
|
17
|
+
const image_1 = require("./commands/image");
|
|
18
|
+
const instance_1 = require("./commands/instance");
|
|
19
|
+
const activity_log_1 = require("./commands/activity-log");
|
|
20
|
+
const api_token_1 = require("./commands/api-token");
|
|
21
|
+
const tenant_1 = require("./commands/tenant");
|
|
22
|
+
const plugin_1 = require("./commands/plugin");
|
|
23
|
+
const errors_1 = require("./errors");
|
|
24
|
+
const program = new commander_1.Command();
|
|
25
|
+
program
|
|
26
|
+
.name('geni')
|
|
27
|
+
.description('Geni Workflows — Bioinformatics')
|
|
28
|
+
.version('0.1.0')
|
|
29
|
+
.option('--debug', 'Show debug error details')
|
|
30
|
+
.option('--api-token <token>', 'Authenticate with an API token (sets X-API-Key header)')
|
|
31
|
+
.configureOutput({ writeErr: () => { } });
|
|
32
|
+
program.hook('preAction', () => {
|
|
33
|
+
const token = program.opts().apiToken;
|
|
34
|
+
if (token) {
|
|
35
|
+
process.env.GENI_API_TOKEN = token;
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
program.addCommand(auth_1.authCommand);
|
|
39
|
+
program.addCommand(user_1.userCommand);
|
|
40
|
+
program.addCommand(workflow_1.workflowCommand);
|
|
41
|
+
program.addCommand(submission_1.submissionCommand);
|
|
42
|
+
program.addCommand(queue_1.queueCommand);
|
|
43
|
+
program.addCommand(environment_1.environmentCommand);
|
|
44
|
+
program.addCommand(engine_1.engineCommand);
|
|
45
|
+
program.addCommand(setup_1.setupCommand);
|
|
46
|
+
program.addCommand(storage_1.storageCommand);
|
|
47
|
+
program.addCommand(task_1.taskCommand);
|
|
48
|
+
program.addCommand(log_1.submissionLogCommand);
|
|
49
|
+
program.addCommand(log_1.taskLogCommand);
|
|
50
|
+
program.addCommand(registry_1.registryCommand);
|
|
51
|
+
program.addCommand(image_1.imageCommand);
|
|
52
|
+
program.addCommand(instance_1.instanceCommand);
|
|
53
|
+
program.addCommand(activity_log_1.activityLogCommand);
|
|
54
|
+
program.addCommand(api_token_1.apiTokenCommand);
|
|
55
|
+
program.addCommand(tenant_1.tenantCommand);
|
|
56
|
+
program.addCommand(plugin_1.pluginCommand);
|
|
57
|
+
applyHelpOnNoArgs(program);
|
|
58
|
+
applyExitOverride(program);
|
|
59
|
+
async function main() {
|
|
60
|
+
try {
|
|
61
|
+
await program.parseAsync(process.argv);
|
|
62
|
+
}
|
|
63
|
+
catch (err) {
|
|
64
|
+
const maybeCommander = err;
|
|
65
|
+
const commanderDisplayCode = maybeCommander.code;
|
|
66
|
+
if (commanderDisplayCode === 'commander.help' ||
|
|
67
|
+
commanderDisplayCode === 'commander.helpDisplayed' ||
|
|
68
|
+
commanderDisplayCode === 'commander.version') {
|
|
69
|
+
process.exit(0);
|
|
70
|
+
}
|
|
71
|
+
const cliError = (0, errors_1.toCliError)(err);
|
|
72
|
+
(0, errors_1.printCliError)(cliError, {
|
|
73
|
+
json: (0, errors_1.wantsJsonError)(process.argv),
|
|
74
|
+
debug: (0, errors_1.isDebugEnabled)(process.argv),
|
|
75
|
+
});
|
|
76
|
+
process.exit(cliError.exitCode);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
void main();
|
|
80
|
+
function applyHelpOnNoArgs(command) {
|
|
81
|
+
if (command.commands.length > 0 && !command._actionHandler) {
|
|
82
|
+
command.action(() => command.help());
|
|
83
|
+
}
|
|
84
|
+
command.commands.forEach(applyHelpOnNoArgs);
|
|
85
|
+
}
|
|
86
|
+
function applyExitOverride(command) {
|
|
87
|
+
command.configureOutput({ writeErr: () => { } });
|
|
88
|
+
command.exitOverride();
|
|
89
|
+
command.commands.forEach(applyExitOverride);
|
|
90
|
+
}
|
|
91
|
+
//# 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 { 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.0')\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)\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"]}
|