@zigrivers/mmr 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.
Files changed (82) hide show
  1. package/dist/cli.d.ts +2 -0
  2. package/dist/cli.d.ts.map +1 -0
  3. package/dist/cli.js +21 -0
  4. package/dist/cli.js.map +1 -0
  5. package/dist/commands/config.d.ts +7 -0
  6. package/dist/commands/config.d.ts.map +1 -0
  7. package/dist/commands/config.js +98 -0
  8. package/dist/commands/config.js.map +1 -0
  9. package/dist/commands/jobs.d.ts +7 -0
  10. package/dist/commands/jobs.d.ts.map +1 -0
  11. package/dist/commands/jobs.js +48 -0
  12. package/dist/commands/jobs.js.map +1 -0
  13. package/dist/commands/results.d.ts +9 -0
  14. package/dist/commands/results.d.ts.map +1 -0
  15. package/dist/commands/results.js +145 -0
  16. package/dist/commands/results.js.map +1 -0
  17. package/dist/commands/review.d.ts +18 -0
  18. package/dist/commands/review.d.ts.map +1 -0
  19. package/dist/commands/review.js +203 -0
  20. package/dist/commands/review.js.map +1 -0
  21. package/dist/commands/status.d.ts +7 -0
  22. package/dist/commands/status.d.ts.map +1 -0
  23. package/dist/commands/status.js +56 -0
  24. package/dist/commands/status.js.map +1 -0
  25. package/dist/config/defaults.d.ts +12 -0
  26. package/dist/config/defaults.d.ts.map +1 -0
  27. package/dist/config/defaults.js +69 -0
  28. package/dist/config/defaults.js.map +1 -0
  29. package/dist/config/loader.d.ts +23 -0
  30. package/dist/config/loader.d.ts.map +1 -0
  31. package/dist/config/loader.js +100 -0
  32. package/dist/config/loader.js.map +1 -0
  33. package/dist/config/schema.d.ts +207 -0
  34. package/dist/config/schema.d.ts.map +1 -0
  35. package/dist/config/schema.js +38 -0
  36. package/dist/config/schema.js.map +1 -0
  37. package/dist/core/auth.d.ts +17 -0
  38. package/dist/core/auth.d.ts.map +1 -0
  39. package/dist/core/auth.js +60 -0
  40. package/dist/core/auth.js.map +1 -0
  41. package/dist/core/dispatcher.d.ts +15 -0
  42. package/dist/core/dispatcher.d.ts.map +1 -0
  43. package/dist/core/dispatcher.js +107 -0
  44. package/dist/core/dispatcher.js.map +1 -0
  45. package/dist/core/job-store.d.ts +46 -0
  46. package/dist/core/job-store.d.ts.map +1 -0
  47. package/dist/core/job-store.js +141 -0
  48. package/dist/core/job-store.js.map +1 -0
  49. package/dist/core/parser.d.ts +16 -0
  50. package/dist/core/parser.d.ts.map +1 -0
  51. package/dist/core/parser.js +123 -0
  52. package/dist/core/parser.js.map +1 -0
  53. package/dist/core/prompt.d.ts +26 -0
  54. package/dist/core/prompt.d.ts.map +1 -0
  55. package/dist/core/prompt.js +53 -0
  56. package/dist/core/prompt.js.map +1 -0
  57. package/dist/core/reconciler.d.ts +17 -0
  58. package/dist/core/reconciler.d.ts.map +1 -0
  59. package/dist/core/reconciler.js +84 -0
  60. package/dist/core/reconciler.js.map +1 -0
  61. package/dist/formatters/json.d.ts +3 -0
  62. package/dist/formatters/json.d.ts.map +1 -0
  63. package/dist/formatters/json.js +4 -0
  64. package/dist/formatters/json.js.map +1 -0
  65. package/dist/formatters/markdown.d.ts +3 -0
  66. package/dist/formatters/markdown.d.ts.map +1 -0
  67. package/dist/formatters/markdown.js +36 -0
  68. package/dist/formatters/markdown.js.map +1 -0
  69. package/dist/formatters/text.d.ts +3 -0
  70. package/dist/formatters/text.d.ts.map +1 -0
  71. package/dist/formatters/text.js +31 -0
  72. package/dist/formatters/text.js.map +1 -0
  73. package/dist/index.d.ts +3 -0
  74. package/dist/index.d.ts.map +1 -0
  75. package/dist/index.js +7 -0
  76. package/dist/index.js.map +1 -0
  77. package/dist/types.d.ts +59 -0
  78. package/dist/types.d.ts.map +1 -0
  79. package/dist/types.js +7 -0
  80. package/dist/types.js.map +1 -0
  81. package/package.json +45 -0
  82. package/templates/core-prompt.md +33 -0
package/dist/cli.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export declare function runCli(argv: string[]): Promise<void>;
2
+ //# sourceMappingURL=cli.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"AAOA,wBAAsB,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAa1D"}
package/dist/cli.js ADDED
@@ -0,0 +1,21 @@
1
+ import yargs from 'yargs';
2
+ import { reviewCommand } from './commands/review.js';
3
+ import { statusCommand } from './commands/status.js';
4
+ import { resultsCommand } from './commands/results.js';
5
+ import { configCommand } from './commands/config.js';
6
+ import { jobsCommand } from './commands/jobs.js';
7
+ export async function runCli(argv) {
8
+ await yargs(argv)
9
+ .scriptName('mmr')
10
+ .usage('$0 <command> [options]')
11
+ .command(reviewCommand)
12
+ .command(statusCommand)
13
+ .command(resultsCommand)
14
+ .command(configCommand)
15
+ .command(jobsCommand)
16
+ .demandCommand(1, 'Run mmr --help for usage')
17
+ .strict()
18
+ .help()
19
+ .argv;
20
+ }
21
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAEhD,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,IAAc;IACzC,MAAM,KAAK,CAAC,IAAI,CAAC;SACd,UAAU,CAAC,KAAK,CAAC;SACjB,KAAK,CAAC,wBAAwB,CAAC;SAC/B,OAAO,CAAC,aAAa,CAAC;SACtB,OAAO,CAAC,aAAa,CAAC;SACtB,OAAO,CAAC,cAAc,CAAC;SACvB,OAAO,CAAC,aAAa,CAAC;SACtB,OAAO,CAAC,WAAW,CAAC;SACpB,aAAa,CAAC,CAAC,EAAE,0BAA0B,CAAC;SAC5C,MAAM,EAAE;SACR,IAAI,EAAE;SACN,IAAI,CAAA;AACT,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { CommandModule } from 'yargs';
2
+ interface ConfigArgs {
3
+ action: string;
4
+ }
5
+ export declare const configCommand: CommandModule<object, ConfigArgs>;
6
+ export {};
7
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/commands/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAsB,MAAM,OAAO,CAAA;AAQ9D,UAAU,UAAU;IAClB,MAAM,EAAE,MAAM,CAAA;CACf;AA6ED,eAAO,MAAM,aAAa,EAAE,aAAa,CAAC,MAAM,EAAE,UAAU,CA0B3D,CAAA"}
@@ -0,0 +1,98 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import yaml from 'js-yaml';
4
+ import { loadConfig } from '../config/loader.js';
5
+ import { BUILTIN_CHANNELS } from '../config/defaults.js';
6
+ import { checkInstalled, checkAuth } from '../core/auth.js';
7
+ async function configInit() {
8
+ const configPath = path.join(process.cwd(), '.mmr.yaml');
9
+ if (fs.existsSync(configPath)) {
10
+ console.error('.mmr.yaml already exists. Remove it first to re-initialize.');
11
+ process.exit(1);
12
+ }
13
+ // Auto-detect which CLIs are installed
14
+ const channels = {};
15
+ for (const [name, chConfig] of Object.entries(BUILTIN_CHANNELS)) {
16
+ const cmd = chConfig.command.split(' ')[0];
17
+ const installed = await checkInstalled(cmd);
18
+ channels[name] = { enabled: installed };
19
+ console.log(` ${name}: ${installed ? 'detected' : 'not found'}`);
20
+ }
21
+ const config = {
22
+ version: 1,
23
+ defaults: {
24
+ fix_threshold: 'P2',
25
+ timeout: 300,
26
+ format: 'json',
27
+ },
28
+ channels,
29
+ };
30
+ fs.writeFileSync(configPath, yaml.dump(config, { lineWidth: 120 }));
31
+ console.log(`\nCreated ${configPath}`);
32
+ }
33
+ async function configTest() {
34
+ const config = loadConfig({ projectRoot: process.cwd() });
35
+ const results = {};
36
+ let allOk = true;
37
+ for (const [name, chConfig] of Object.entries(config.channels)) {
38
+ if (!chConfig.enabled) {
39
+ results[name] = { installed: false, auth: 'disabled' };
40
+ continue;
41
+ }
42
+ const cmd = chConfig.command.split(' ')[0];
43
+ const installed = await checkInstalled(cmd);
44
+ if (!installed) {
45
+ results[name] = { installed: false, auth: 'skipped' };
46
+ allOk = false;
47
+ continue;
48
+ }
49
+ const authResult = await checkAuth(chConfig);
50
+ results[name] = {
51
+ installed: true,
52
+ auth: authResult.status,
53
+ recovery: authResult.recovery,
54
+ };
55
+ if (authResult.status !== 'ok') {
56
+ allOk = false;
57
+ }
58
+ }
59
+ console.log(JSON.stringify(results, null, 2));
60
+ process.exit(allOk ? 0 : 1);
61
+ }
62
+ function configChannels() {
63
+ const config = loadConfig({ projectRoot: process.cwd() });
64
+ const channels = Object.entries(config.channels).map(([name, ch]) => ({
65
+ name,
66
+ enabled: ch.enabled,
67
+ command: ch.command,
68
+ parser: ch.output_parser,
69
+ }));
70
+ console.log(JSON.stringify(channels, null, 2));
71
+ }
72
+ export const configCommand = {
73
+ command: 'config <action>',
74
+ describe: 'Manage mmr configuration',
75
+ builder: (yargs) => yargs.positional('action', {
76
+ type: 'string',
77
+ demandOption: true,
78
+ describe: 'Config action',
79
+ choices: ['init', 'test', 'channels'],
80
+ }),
81
+ handler: async (args) => {
82
+ switch (args.action) {
83
+ case 'init':
84
+ await configInit();
85
+ break;
86
+ case 'test':
87
+ await configTest();
88
+ break;
89
+ case 'channels':
90
+ configChannels();
91
+ break;
92
+ default:
93
+ console.error(`Unknown config action: ${args.action}`);
94
+ process.exit(1);
95
+ }
96
+ },
97
+ };
98
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/commands/config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { CommandModule } from 'yargs';
2
+ interface JobsArgs {
3
+ action: string;
4
+ }
5
+ export declare const jobsCommand: CommandModule<object, JobsArgs>;
6
+ export {};
7
+ //# sourceMappingURL=jobs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jobs.d.ts","sourceRoot":"","sources":["../../src/commands/jobs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAsB,MAAM,OAAO,CAAA;AAM9D,UAAU,QAAQ;IAChB,MAAM,EAAE,MAAM,CAAA;CACf;AA4BD,eAAO,MAAM,WAAW,EAAE,aAAa,CAAC,MAAM,EAAE,QAAQ,CAuBvD,CAAA"}
@@ -0,0 +1,48 @@
1
+ import path from 'node:path';
2
+ import os from 'node:os';
3
+ import { JobStore } from '../core/job-store.js';
4
+ import { loadConfig } from '../config/loader.js';
5
+ function jobsList() {
6
+ const jobsDir = path.join(os.homedir(), '.mmr', 'jobs');
7
+ const store = new JobStore(jobsDir);
8
+ const jobs = store.listJobs();
9
+ const output = jobs.map((job) => ({
10
+ job_id: job.job_id,
11
+ status: job.status,
12
+ created_at: job.created_at,
13
+ channels: Object.keys(job.channels).length,
14
+ }));
15
+ console.log(JSON.stringify(output, null, 2));
16
+ }
17
+ function jobsPrune() {
18
+ const config = loadConfig({ projectRoot: process.cwd() });
19
+ const retentionDays = config.defaults.job_retention_days;
20
+ const jobsDir = path.join(os.homedir(), '.mmr', 'jobs');
21
+ const store = new JobStore(jobsDir);
22
+ const pruned = store.pruneJobs(retentionDays);
23
+ console.log(JSON.stringify({ pruned, retention_days: retentionDays }));
24
+ }
25
+ export const jobsCommand = {
26
+ command: 'jobs <action>',
27
+ describe: 'Manage review jobs',
28
+ builder: (yargs) => yargs.positional('action', {
29
+ type: 'string',
30
+ demandOption: true,
31
+ describe: 'Jobs action',
32
+ choices: ['list', 'prune'],
33
+ }),
34
+ handler: (args) => {
35
+ switch (args.action) {
36
+ case 'list':
37
+ jobsList();
38
+ break;
39
+ case 'prune':
40
+ jobsPrune();
41
+ break;
42
+ default:
43
+ console.error(`Unknown jobs action: ${args.action}`);
44
+ process.exit(1);
45
+ }
46
+ },
47
+ };
48
+ //# sourceMappingURL=jobs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jobs.js","sourceRoot":"","sources":["../../src/commands/jobs.ts"],"names":[],"mappings":"AACA,OAAO,IAAI,MAAM,WAAW,CAAA;AAC5B,OAAO,EAAE,MAAM,SAAS,CAAA;AACxB,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAA;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAMhD,SAAS,QAAQ;IACf,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,CAAA;IACvD,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAA;IACnC,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAA;IAE7B,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAChC,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,MAAM;KAC3C,CAAC,CAAC,CAAA;IAEH,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;AAC9C,CAAC;AAED,SAAS,SAAS;IAChB,MAAM,MAAM,GAAG,UAAU,CAAC,EAAE,WAAW,EAAE,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;IACzD,MAAM,aAAa,GAAG,MAAM,CAAC,QAAQ,CAAC,kBAAkB,CAAA;IAExD,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,CAAA;IACvD,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAA;IACnC,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,CAAA;IAE7C,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,cAAc,EAAE,aAAa,EAAE,CAAC,CAAC,CAAA;AACxE,CAAC;AAED,MAAM,CAAC,MAAM,WAAW,GAAoC;IAC1D,OAAO,EAAE,eAAe;IACxB,QAAQ,EAAE,oBAAoB;IAC9B,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE,CACjB,KAAK,CAAC,UAAU,CAAC,QAAQ,EAAE;QACzB,IAAI,EAAE,QAAQ;QACd,YAAY,EAAE,IAAI;QAClB,QAAQ,EAAE,aAAa;QACvB,OAAO,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;KAC3B,CAAC;IACJ,OAAO,EAAE,CAAC,IAAkC,EAAE,EAAE;QAC9C,QAAQ,IAAI,CAAC,MAAM,EAAE,CAAC;YACtB,KAAK,MAAM;gBACT,QAAQ,EAAE,CAAA;gBACV,MAAK;YACP,KAAK,OAAO;gBACV,SAAS,EAAE,CAAA;gBACX,MAAK;YACP;gBACE,OAAO,CAAC,KAAK,CAAC,wBAAwB,IAAI,CAAC,MAAM,EAAE,CAAC,CAAA;gBACpD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;IACH,CAAC;CACF,CAAA"}
@@ -0,0 +1,9 @@
1
+ import type { CommandModule } from 'yargs';
2
+ interface ResultsArgs {
3
+ 'job-id': string;
4
+ format?: string;
5
+ raw?: boolean;
6
+ }
7
+ export declare const resultsCommand: CommandModule<object, ResultsArgs>;
8
+ export {};
9
+ //# sourceMappingURL=results.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"results.d.ts","sourceRoot":"","sources":["../../src/commands/results.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAsB,MAAM,OAAO,CAAA;AAW9D,UAAU,WAAW;IACnB,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,GAAG,CAAC,EAAE,OAAO,CAAA;CACd;AAED,eAAO,MAAM,cAAc,EAAE,aAAa,CAAC,MAAM,EAAE,WAAW,CAuJ7D,CAAA"}
@@ -0,0 +1,145 @@
1
+ import path from 'node:path';
2
+ import os from 'node:os';
3
+ import { JobStore } from '../core/job-store.js';
4
+ import { parseChannelOutput } from '../core/parser.js';
5
+ import { reconcile, evaluateGate } from '../core/reconciler.js';
6
+ import { formatJson } from '../formatters/json.js';
7
+ import { formatText } from '../formatters/text.js';
8
+ import { formatMarkdown } from '../formatters/markdown.js';
9
+ export const resultsCommand = {
10
+ command: 'results <job-id>',
11
+ describe: 'Collect and reconcile results from a completed review job',
12
+ builder: (yargs) => yargs
13
+ .positional('job-id', {
14
+ type: 'string',
15
+ demandOption: true,
16
+ describe: 'Job ID (e.g. mmr-abc123)',
17
+ })
18
+ .option('format', {
19
+ type: 'string',
20
+ describe: 'Output format',
21
+ choices: ['json', 'text', 'markdown'],
22
+ })
23
+ .option('raw', {
24
+ type: 'boolean',
25
+ describe: 'Include raw channel output in results',
26
+ default: false,
27
+ }),
28
+ handler: (args) => {
29
+ const jobsDir = path.join(os.homedir(), '.mmr', 'jobs');
30
+ const store = new JobStore(jobsDir);
31
+ // 1. Load job
32
+ let job;
33
+ try {
34
+ job = store.loadJob(args['job-id']);
35
+ }
36
+ catch {
37
+ console.error(`Job not found: ${args['job-id']}`);
38
+ process.exit(2);
39
+ }
40
+ // Check all channels done
41
+ const incompleteChannels = Object.entries(job.channels)
42
+ .filter(([, entry]) => !['completed', 'failed', 'timeout', 'auth_failed', 'skipped'].includes(entry.status))
43
+ .map(([name]) => name);
44
+ if (incompleteChannels.length > 0) {
45
+ console.error(`Channels still running: ${incompleteChannels.join(', ')}`);
46
+ console.error('Wait for completion or use `mmr status` to check progress.');
47
+ process.exit(1);
48
+ }
49
+ // 2. Parse each channel's output
50
+ const channelFindings = {};
51
+ const perChannel = {};
52
+ const startTimes = [];
53
+ const endTimes = [];
54
+ for (const [name, entry] of Object.entries(job.channels)) {
55
+ if (entry.status !== 'completed') {
56
+ perChannel[name] = {
57
+ status: entry.status,
58
+ elapsed: entry.elapsed ?? '0s',
59
+ findings: [],
60
+ error: entry.status === 'failed' ? 'Channel failed' : undefined,
61
+ };
62
+ continue;
63
+ }
64
+ // Try to load and parse channel output
65
+ let raw;
66
+ let findings = [];
67
+ try {
68
+ const output = store.loadChannelOutput(job.job_id, name);
69
+ raw = output;
70
+ const parserName = entry.output_parser ?? 'default';
71
+ const parsed = parseChannelOutput(raw, parserName);
72
+ findings = parsed.findings;
73
+ }
74
+ catch {
75
+ // Fall back: no parseable output
76
+ raw = '';
77
+ }
78
+ channelFindings[name] = findings;
79
+ const elapsed = entry.started_at && entry.completed_at
80
+ ? `${((new Date(entry.completed_at).getTime() - new Date(entry.started_at).getTime()) / 1000).toFixed(1)}s`
81
+ : '0s';
82
+ if (entry.started_at)
83
+ startTimes.push(new Date(entry.started_at).getTime());
84
+ if (entry.completed_at)
85
+ endTimes.push(new Date(entry.completed_at).getTime());
86
+ perChannel[name] = {
87
+ status: entry.status,
88
+ elapsed,
89
+ findings,
90
+ raw_output: args.raw ? raw : undefined,
91
+ };
92
+ }
93
+ // 3. Reconcile findings
94
+ const reconciledFindings = reconcile(channelFindings);
95
+ // 4. Evaluate gate (fail-safe: if no channels completed, gate fails)
96
+ const fixThreshold = job.fix_threshold;
97
+ const completedChannels = Object.values(job.channels)
98
+ .filter((ch) => ch.status === 'completed').length;
99
+ const gatePassed = completedChannels > 0
100
+ ? evaluateGate(reconciledFindings, fixThreshold)
101
+ : false;
102
+ // 5. Build ReconciledResults
103
+ const totalElapsed = startTimes.length > 0 && endTimes.length > 0
104
+ ? `${((Math.max(...endTimes) - Math.min(...startTimes)) / 1000).toFixed(1)}s`
105
+ : '0s';
106
+ const completedCount = Object.values(job.channels)
107
+ .filter((ch) => ch.status === 'completed').length;
108
+ const partialCount = Object.values(job.channels)
109
+ .filter((ch) => ['failed', 'timeout'].includes(ch.status)).length;
110
+ const results = {
111
+ job_id: job.job_id,
112
+ gate_passed: gatePassed,
113
+ fix_threshold: fixThreshold,
114
+ reconciled_findings: reconciledFindings,
115
+ per_channel: perChannel,
116
+ metadata: {
117
+ channels_dispatched: Object.keys(job.channels).length,
118
+ channels_completed: completedCount,
119
+ channels_partial: partialCount,
120
+ total_elapsed: totalElapsed,
121
+ },
122
+ };
123
+ // 6. Format output
124
+ const outputFormat = (args.format ?? job.format ?? 'json');
125
+ let formatted;
126
+ switch (outputFormat) {
127
+ case 'text':
128
+ formatted = formatText(results);
129
+ break;
130
+ case 'markdown':
131
+ formatted = formatMarkdown(results);
132
+ break;
133
+ case 'json':
134
+ default:
135
+ formatted = formatJson(results);
136
+ break;
137
+ }
138
+ // 7. Save results + output to stdout
139
+ store.saveResults(job.job_id, results);
140
+ console.log(formatted);
141
+ // Exit codes: 0 = gate passed, 1 = gate failed
142
+ process.exit(gatePassed ? 0 : 1);
143
+ },
144
+ };
145
+ //# sourceMappingURL=results.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"results.js","sourceRoot":"","sources":["../../src/commands/results.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import type { CommandModule } from 'yargs';
2
+ interface ReviewArgs {
3
+ diff?: string;
4
+ pr?: number;
5
+ staged?: boolean;
6
+ base?: string;
7
+ head?: string;
8
+ focus?: string;
9
+ 'fix-threshold'?: string;
10
+ channels?: string[];
11
+ timeout?: number;
12
+ template?: string;
13
+ format?: string;
14
+ sync?: boolean;
15
+ }
16
+ export declare const reviewCommand: CommandModule<object, ReviewArgs>;
17
+ export {};
18
+ //# sourceMappingURL=review.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review.d.ts","sourceRoot":"","sources":["../../src/commands/review.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAsB,MAAM,OAAO,CAAA;AAY9D,UAAU,UAAU;IAClB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;IACnB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,OAAO,CAAA;CACf;AAkCD,eAAO,MAAM,aAAa,EAAE,aAAa,CAAC,MAAM,EAAE,UAAU,CA2L3D,CAAA"}
@@ -0,0 +1,203 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import os from 'node:os';
4
+ import { execFileSync } from 'node:child_process';
5
+ import { loadConfig } from '../config/loader.js';
6
+ import { JobStore } from '../core/job-store.js';
7
+ import { checkInstalled, checkAuth } from '../core/auth.js';
8
+ import { assemblePrompt } from '../core/prompt.js';
9
+ import { dispatchChannel } from '../core/dispatcher.js';
10
+ /**
11
+ * Resolve diff content from the various input modes.
12
+ * Priority: --diff file/stdin > --pr > --staged > --base/--head > default (unstaged)
13
+ */
14
+ function resolveDiff(args) {
15
+ if (args.diff !== undefined) {
16
+ if (args.diff === '-') {
17
+ return fs.readFileSync(0, 'utf-8');
18
+ }
19
+ return fs.readFileSync(args.diff, 'utf-8');
20
+ }
21
+ if (args.pr !== undefined) {
22
+ return execFileSync('gh', ['pr', 'diff', String(args.pr)], { encoding: 'utf-8' });
23
+ }
24
+ if (args.staged) {
25
+ return execFileSync('git', ['diff', '--cached'], { encoding: 'utf-8' });
26
+ }
27
+ if (args.base && args.head) {
28
+ return execFileSync('git', ['diff', `${args.base}...${args.head}`], { encoding: 'utf-8' });
29
+ }
30
+ if (args.base) {
31
+ return execFileSync('git', ['diff', `${args.base}...HEAD`], { encoding: 'utf-8' });
32
+ }
33
+ // Default: unstaged changes
34
+ return execFileSync('git', ['diff'], { encoding: 'utf-8' });
35
+ }
36
+ export const reviewCommand = {
37
+ command: 'review',
38
+ describe: 'Dispatch a multi-model code review',
39
+ builder: (yargs) => yargs
40
+ .option('diff', {
41
+ type: 'string',
42
+ describe: 'Path to diff file, or - for stdin',
43
+ })
44
+ .option('pr', {
45
+ type: 'number',
46
+ describe: 'GitHub PR number (uses gh pr diff)',
47
+ })
48
+ .option('staged', {
49
+ type: 'boolean',
50
+ describe: 'Review staged changes (git diff --cached)',
51
+ })
52
+ .option('base', {
53
+ type: 'string',
54
+ describe: 'Base ref for git diff (e.g. main)',
55
+ })
56
+ .option('head', {
57
+ type: 'string',
58
+ describe: 'Head ref for git diff (default: HEAD)',
59
+ })
60
+ .option('focus', {
61
+ type: 'string',
62
+ describe: 'Free-text focus areas for this review',
63
+ })
64
+ .option('fix-threshold', {
65
+ type: 'string',
66
+ describe: 'Severity gate threshold (P0-P3)',
67
+ choices: ['P0', 'P1', 'P2', 'P3'],
68
+ })
69
+ .option('channels', {
70
+ type: 'array',
71
+ string: true,
72
+ describe: 'Channels to dispatch (overrides config)',
73
+ })
74
+ .option('timeout', {
75
+ type: 'number',
76
+ describe: 'Per-channel timeout in seconds',
77
+ })
78
+ .option('template', {
79
+ type: 'string',
80
+ describe: 'Named template from config',
81
+ })
82
+ .option('format', {
83
+ type: 'string',
84
+ describe: 'Output format',
85
+ choices: ['json', 'text', 'markdown', 'sarif'],
86
+ })
87
+ .option('sync', {
88
+ type: 'boolean',
89
+ describe: 'Wait for all channels to complete (blocking)',
90
+ default: false,
91
+ }),
92
+ handler: async (args) => {
93
+ // 1. Load config with CLI overrides
94
+ const config = loadConfig({
95
+ projectRoot: process.cwd(),
96
+ cliOverrides: {
97
+ fix_threshold: args['fix-threshold'],
98
+ timeout: args.timeout,
99
+ format: args.format,
100
+ },
101
+ });
102
+ // 2. Resolve diff input
103
+ const diff = resolveDiff(args);
104
+ if (!diff.trim()) {
105
+ console.error('No diff content found. Provide --diff, --pr, --staged, or --base/--head.');
106
+ process.exit(1);
107
+ }
108
+ // 3. Determine enabled channels
109
+ const channelNames = args.channels ?? Object.entries(config.channels)
110
+ .filter(([, ch]) => ch.enabled)
111
+ .map(([name]) => name);
112
+ if (channelNames.length === 0) {
113
+ console.error('No channels enabled. Configure channels or pass --channels.');
114
+ process.exit(1);
115
+ }
116
+ // 4. Auth-check each channel
117
+ const validChannels = [];
118
+ const authResults = {};
119
+ for (const name of channelNames) {
120
+ const chConfig = config.channels[name];
121
+ if (!chConfig) {
122
+ authResults[name] = { status: 'skipped', recovery: `Channel "${name}" not found in config` };
123
+ continue;
124
+ }
125
+ const cmd = chConfig.command.split(' ')[0];
126
+ const installed = await checkInstalled(cmd);
127
+ if (!installed) {
128
+ authResults[name] = { status: 'skipped', recovery: `${cmd} not found on PATH` };
129
+ continue;
130
+ }
131
+ const authResult = await checkAuth(chConfig);
132
+ authResults[name] = authResult;
133
+ if (authResult.status === 'ok') {
134
+ validChannels.push(name);
135
+ }
136
+ }
137
+ if (validChannels.length === 0) {
138
+ console.error('No channels passed auth check:');
139
+ for (const [name, result] of Object.entries(authResults)) {
140
+ console.error(` ${name}: ${result.status}${result.recovery ? ` — ${result.recovery}` : ''}`);
141
+ }
142
+ process.exit(1);
143
+ }
144
+ // 5. Create job
145
+ const jobsDir = path.join(os.homedir(), '.mmr', 'jobs');
146
+ const store = new JobStore(jobsDir);
147
+ const job = store.createJob({
148
+ fix_threshold: config.defaults.fix_threshold,
149
+ format: config.defaults.format,
150
+ channels: validChannels,
151
+ });
152
+ // Update skipped/failed channels in job metadata
153
+ for (const name of channelNames) {
154
+ if (!validChannels.includes(name) && job.channels[name] === undefined) {
155
+ // Channel was skipped at auth — not in job, skip
156
+ }
157
+ }
158
+ // 6. Assemble prompt
159
+ const templateCriteria = args.template && config.templates?.[args.template]
160
+ ? config.templates[args.template].criteria
161
+ : undefined;
162
+ const prompt = assemblePrompt({
163
+ diff,
164
+ reviewCriteria: config.review_criteria,
165
+ templateCriteria,
166
+ focus: args.focus,
167
+ });
168
+ // 7. Save prompt + diff to job store
169
+ store.savePrompt(job.job_id, prompt);
170
+ store.saveDiff(job.job_id, diff);
171
+ // 8. Dispatch channels (save output_parser in job metadata for results)
172
+ const dispatches = [];
173
+ for (const name of validChannels) {
174
+ const chConfig = config.channels[name];
175
+ store.updateChannel(job.job_id, name, { output_parser: chConfig.output_parser });
176
+ dispatches.push(dispatchChannel(store, job.job_id, name, {
177
+ command: chConfig.command,
178
+ prompt,
179
+ flags: chConfig.flags,
180
+ env: chConfig.env,
181
+ timeout: chConfig.timeout ?? config.defaults.timeout,
182
+ stderr: chConfig.stderr,
183
+ }));
184
+ }
185
+ if (config.defaults.parallel) {
186
+ await Promise.all(dispatches);
187
+ }
188
+ else {
189
+ for (const dispatch of dispatches) {
190
+ await dispatch;
191
+ }
192
+ }
193
+ // 9. Output dispatch result
194
+ const result = {
195
+ job_id: job.job_id,
196
+ status: 'dispatched',
197
+ channels: Object.fromEntries(channelNames.map((name) => [name, authResults[name]?.status ?? 'dispatched'])),
198
+ valid_channels: validChannels,
199
+ };
200
+ console.log(JSON.stringify(result, null, 2));
201
+ },
202
+ };
203
+ //# sourceMappingURL=review.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review.js","sourceRoot":"","sources":["../../src/commands/review.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,SAAS,CAAA;AACxB,OAAO,IAAI,MAAM,WAAW,CAAA;AAC5B,OAAO,EAAE,MAAM,SAAS,CAAA;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AAkBvD;;;GAGG;AACH,SAAS,WAAW,CAAC,IAAgB;IACnC,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC5B,IAAI,IAAI,CAAC,IAAI,KAAK,GAAG,EAAE,CAAC;YACtB,OAAO,EAAE,CAAC,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,CAAA;QACpC,CAAC;QACD,OAAO,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;IAC5C,CAAC;IAED,IAAI,IAAI,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;QAC1B,OAAO,YAAY,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAA;IACnF,CAAC;IAED,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,OAAO,YAAY,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAA;IACzE,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;QAC3B,OAAO,YAAY,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAA;IAC5F,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,OAAO,YAAY,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,SAAS,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAA;IACpF,CAAC;IAED,4BAA4B;IAC5B,OAAO,YAAY,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAA;AAC7D,CAAC;AAED,MAAM,CAAC,MAAM,aAAa,GAAsC;IAC9D,OAAO,EAAE,QAAQ;IACjB,QAAQ,EAAE,oCAAoC;IAC9C,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE,CACjB,KAAK;SACF,MAAM,CAAC,MAAM,EAAE;QACd,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,mCAAmC;KAC9C,CAAC;SACD,MAAM,CAAC,IAAI,EAAE;QACZ,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,oCAAoC;KAC/C,CAAC;SACD,MAAM,CAAC,QAAQ,EAAE;QAChB,IAAI,EAAE,SAAS;QACf,QAAQ,EAAE,2CAA2C;KACtD,CAAC;SACD,MAAM,CAAC,MAAM,EAAE;QACd,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,mCAAmC;KAC9C,CAAC;SACD,MAAM,CAAC,MAAM,EAAE;QACd,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,uCAAuC;KAClD,CAAC;SACD,MAAM,CAAC,OAAO,EAAE;QACf,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,uCAAuC;KAClD,CAAC;SACD,MAAM,CAAC,eAAe,EAAE;QACvB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,iCAAiC;QAC3C,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;KAClC,CAAC;SACD,MAAM,CAAC,UAAU,EAAE;QAClB,IAAI,EAAE,OAAO;QACb,MAAM,EAAE,IAAI;QACZ,QAAQ,EAAE,yCAAyC;KACpD,CAAC;SACD,MAAM,CAAC,SAAS,EAAE;QACjB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,gCAAgC;KAC3C,CAAC;SACD,MAAM,CAAC,UAAU,EAAE;QAClB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,4BAA4B;KACvC,CAAC;SACD,MAAM,CAAC,QAAQ,EAAE;QAChB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,eAAe;QACzB,OAAO,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC;KAC/C,CAAC;SACD,MAAM,CAAC,MAAM,EAAE;QACd,IAAI,EAAE,SAAS;QACf,QAAQ,EAAE,8CAA8C;QACxD,OAAO,EAAE,KAAK;KACf,CAAC;IACN,OAAO,EAAE,KAAK,EAAE,IAAoC,EAAE,EAAE;QACtD,oCAAoC;QACpC,MAAM,MAAM,GAAG,UAAU,CAAC;YACxB,WAAW,EAAE,OAAO,CAAC,GAAG,EAAE;YAC1B,YAAY,EAAE;gBACZ,aAAa,EAAE,IAAI,CAAC,eAAe,CAAuB;gBAC1D,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,MAAM,EAAE,IAAI,CAAC,MAAM;aACpB;SACF,CAAC,CAAA;QAEF,wBAAwB;QACxB,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,CAAA;QAC9B,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;YACjB,OAAO,CAAC,KAAK,CAAC,0EAA0E,CAAC,CAAA;YACzF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;QAED,gCAAgC;QAChC,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC;aAClE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC;aAC9B,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAA;QAExB,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,KAAK,CAAC,6DAA6D,CAAC,CAAA;YAC5E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;QAED,6BAA6B;QAC7B,MAAM,aAAa,GAAa,EAAE,CAAA;QAClC,MAAM,WAAW,GAA0D,EAAE,CAAA;QAE7E,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE,CAAC;YAChC,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;YACtC,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,YAAY,IAAI,uBAAuB,EAAE,CAAA;gBAC5F,SAAQ;YACV,CAAC;YAED,MAAM,GAAG,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;YAC1C,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,GAAG,CAAC,CAAA;YAC3C,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,GAAG,oBAAoB,EAAE,CAAA;gBAC/E,SAAQ;YACV,CAAC;YAED,MAAM,UAAU,GAAG,MAAM,SAAS,CAAC,QAAQ,CAAC,CAAA;YAC5C,WAAW,CAAC,IAAI,CAAC,GAAG,UAAU,CAAA;YAC9B,IAAI,UAAU,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;gBAC/B,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAC1B,CAAC;QACH,CAAC;QAED,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC/B,OAAO,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAA;YAC/C,KAAK,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;gBACzD,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;YAC/F,CAAC;YACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;QAED,gBAAgB;QAChB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,CAAA;QACvD,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAA;QACnC,MAAM,GAAG,GAAG,KAAK,CAAC,SAAS,CAAC;YAC1B,aAAa,EAAE,MAAM,CAAC,QAAQ,CAAC,aAAyB;YACxD,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAsB;YAC9C,QAAQ,EAAE,aAAa;SACxB,CAAC,CAAA;QAEF,iDAAiD;QACjD,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE,CAAC;YAChC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,SAAS,EAAE,CAAC;gBACtE,iDAAiD;YACnD,CAAC;QACH,CAAC;QAED,qBAAqB;QACrB,MAAM,gBAAgB,GAAG,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;YACzE,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,QAAQ;YAC1C,CAAC,CAAC,SAAS,CAAA;QAEb,MAAM,MAAM,GAAG,cAAc,CAAC;YAC5B,IAAI;YACJ,cAAc,EAAE,MAAM,CAAC,eAAe;YACtC,gBAAgB;YAChB,KAAK,EAAE,IAAI,CAAC,KAAK;SAClB,CAAC,CAAA;QAEF,qCAAqC;QACrC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QACpC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;QAEhC,wEAAwE;QACxE,MAAM,UAAU,GAAoB,EAAE,CAAA;QACtC,KAAK,MAAM,IAAI,IAAI,aAAa,EAAE,CAAC;YACjC,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;YACtC,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE,aAAa,EAAE,QAAQ,CAAC,aAAa,EAAE,CAAC,CAAA;YAChF,UAAU,CAAC,IAAI,CACb,eAAe,CAAC,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,IAAI,EAAE;gBACvC,OAAO,EAAE,QAAQ,CAAC,OAAO;gBACzB,MAAM;gBACN,KAAK,EAAE,QAAQ,CAAC,KAAK;gBACrB,GAAG,EAAE,QAAQ,CAAC,GAAG;gBACjB,OAAO,EAAE,QAAQ,CAAC,OAAO,IAAI,MAAM,CAAC,QAAQ,CAAC,OAAO;gBACpD,MAAM,EAAE,QAAQ,CAAC,MAA8B;aAChD,CAAC,CACH,CAAA;QACH,CAAC;QAED,IAAI,MAAM,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;YAC7B,MAAM,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;QAC/B,CAAC;aAAM,CAAC;YACN,KAAK,MAAM,QAAQ,IAAI,UAAU,EAAE,CAAC;gBAClC,MAAM,QAAQ,CAAA;YAChB,CAAC;QACH,CAAC;QAED,4BAA4B;QAC5B,MAAM,MAAM,GAAG;YACb,MAAM,EAAE,GAAG,CAAC,MAAM;YAClB,MAAM,EAAE,YAAY;YACpB,QAAQ,EAAE,MAAM,CAAC,WAAW,CAC1B,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,EAAE,MAAM,IAAI,YAAY,CAAC,CAAC,CAC9E;YACD,cAAc,EAAE,aAAa;SAC9B,CAAA;QAED,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;IAC9C,CAAC;CACF,CAAA"}
@@ -0,0 +1,7 @@
1
+ import type { CommandModule } from 'yargs';
2
+ interface StatusArgs {
3
+ 'job-id': string;
4
+ }
5
+ export declare const statusCommand: CommandModule<object, StatusArgs>;
6
+ export {};
7
+ //# sourceMappingURL=status.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAsB,MAAM,OAAO,CAAA;AAK9D,UAAU,UAAU;IAClB,QAAQ,EAAE,MAAM,CAAA;CACjB;AAED,eAAO,MAAM,aAAa,EAAE,aAAa,CAAC,MAAM,EAAE,UAAU,CA2D3D,CAAA"}