@rajat-rastogi/maestro 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/LICENSE +21 -0
- package/README.md +254 -0
- package/defaults/agents/documentation.txt +18 -0
- package/defaults/agents/implementation.txt +16 -0
- package/defaults/agents/quality.txt +19 -0
- package/defaults/agents/simplification.txt +19 -0
- package/defaults/agents/testing.txt +16 -0
- package/defaults/config +46 -0
- package/defaults/plan-tips.md +50 -0
- package/defaults/prompts/finalize.txt +14 -0
- package/defaults/prompts/hint_analysis.txt +38 -0
- package/defaults/prompts/plan_create.txt +36 -0
- package/defaults/prompts/review_first.txt +37 -0
- package/defaults/prompts/review_second.txt +36 -0
- package/defaults/prompts/task.txt +23 -0
- package/dist/backend/backend.d.ts +29 -0
- package/dist/backend/backend.d.ts.map +1 -0
- package/dist/backend/backend.js +9 -0
- package/dist/backend/backend.js.map +1 -0
- package/dist/backend/claude.d.ts +12 -0
- package/dist/backend/claude.d.ts.map +1 -0
- package/dist/backend/claude.js +155 -0
- package/dist/backend/claude.js.map +1 -0
- package/dist/backend/copilot.d.ts +11 -0
- package/dist/backend/copilot.d.ts.map +1 -0
- package/dist/backend/copilot.js +110 -0
- package/dist/backend/copilot.js.map +1 -0
- package/dist/backend/factory.d.ts +4 -0
- package/dist/backend/factory.d.ts.map +1 -0
- package/dist/backend/factory.js +13 -0
- package/dist/backend/factory.js.map +1 -0
- package/dist/config/configserver.d.ts +9 -0
- package/dist/config/configserver.d.ts.map +1 -0
- package/dist/config/configserver.js +141 -0
- package/dist/config/configserver.js.map +1 -0
- package/dist/config/dump.d.ts +2 -0
- package/dist/config/dump.d.ts.map +1 -0
- package/dist/config/dump.js +24 -0
- package/dist/config/dump.js.map +1 -0
- package/dist/config/loader.d.ts +11 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +119 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/prompts.d.ts +19 -0
- package/dist/config/prompts.d.ts.map +1 -0
- package/dist/config/prompts.js +128 -0
- package/dist/config/prompts.js.map +1 -0
- package/dist/config/reset.d.ts +3 -0
- package/dist/config/reset.d.ts.map +1 -0
- package/dist/config/reset.js +23 -0
- package/dist/config/reset.js.map +1 -0
- package/dist/config/template.d.ts +5 -0
- package/dist/config/template.d.ts.map +1 -0
- package/dist/config/template.js +11 -0
- package/dist/config/template.js.map +1 -0
- package/dist/config/types.d.ts +35 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +42 -0
- package/dist/config/types.js.map +1 -0
- package/dist/config/write.d.ts +5 -0
- package/dist/config/write.d.ts.map +1 -0
- package/dist/config/write.js +59 -0
- package/dist/config/write.js.map +1 -0
- package/dist/dashboard/assets/config.html +1012 -0
- package/dist/dashboard/assets/dashboard.html +871 -0
- package/dist/dashboard/assets/help.html +657 -0
- package/dist/dashboard/assets.d.ts +2 -0
- package/dist/dashboard/assets.d.ts.map +1 -0
- package/dist/dashboard/assets.js +5 -0
- package/dist/dashboard/assets.js.map +1 -0
- package/dist/dashboard/event-bus.d.ts +11 -0
- package/dist/dashboard/event-bus.d.ts.map +1 -0
- package/dist/dashboard/event-bus.js +4 -0
- package/dist/dashboard/event-bus.js.map +1 -0
- package/dist/dashboard/replay-parser.d.ts +6 -0
- package/dist/dashboard/replay-parser.d.ts.map +1 -0
- package/dist/dashboard/replay-parser.js +56 -0
- package/dist/dashboard/replay-parser.js.map +1 -0
- package/dist/dashboard/server.d.ts +14 -0
- package/dist/dashboard/server.d.ts.map +1 -0
- package/dist/dashboard/server.js +178 -0
- package/dist/dashboard/server.js.map +1 -0
- package/dist/dashboard/watcher.d.ts +17 -0
- package/dist/dashboard/watcher.d.ts.map +1 -0
- package/dist/dashboard/watcher.js +73 -0
- package/dist/dashboard/watcher.js.map +1 -0
- package/dist/executor/hints.d.ts +21 -0
- package/dist/executor/hints.d.ts.map +1 -0
- package/dist/executor/hints.js +102 -0
- package/dist/executor/hints.js.map +1 -0
- package/dist/executor/task.d.ts +19 -0
- package/dist/executor/task.d.ts.map +1 -0
- package/dist/executor/task.js +119 -0
- package/dist/executor/task.js.map +1 -0
- package/dist/executor/validation.d.ts +18 -0
- package/dist/executor/validation.d.ts.map +1 -0
- package/dist/executor/validation.js +73 -0
- package/dist/executor/validation.js.map +1 -0
- package/dist/git/branch.d.ts +23 -0
- package/dist/git/branch.d.ts.map +1 -0
- package/dist/git/branch.js +64 -0
- package/dist/git/branch.js.map +1 -0
- package/dist/git/commit.d.ts +21 -0
- package/dist/git/commit.d.ts.map +1 -0
- package/dist/git/commit.js +37 -0
- package/dist/git/commit.js.map +1 -0
- package/dist/git/diff.d.ts +15 -0
- package/dist/git/diff.d.ts.map +1 -0
- package/dist/git/diff.js +26 -0
- package/dist/git/diff.js.map +1 -0
- package/dist/git/git.d.ts +9 -0
- package/dist/git/git.d.ts.map +1 -0
- package/dist/git/git.js +20 -0
- package/dist/git/git.js.map +1 -0
- package/dist/git/gitignore.d.ts +2 -0
- package/dist/git/gitignore.d.ts.map +1 -0
- package/dist/git/gitignore.js +66 -0
- package/dist/git/gitignore.js.map +1 -0
- package/dist/git/worktree.d.ts +3 -0
- package/dist/git/worktree.d.ts.map +1 -0
- package/dist/git/worktree.js +17 -0
- package/dist/git/worktree.js.map +1 -0
- package/dist/main.d.ts +3 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +212 -0
- package/dist/main.js.map +1 -0
- package/dist/orchestrator/orchestrator.d.ts +21 -0
- package/dist/orchestrator/orchestrator.d.ts.map +1 -0
- package/dist/orchestrator/orchestrator.js +218 -0
- package/dist/orchestrator/orchestrator.js.map +1 -0
- package/dist/plan/creator.d.ts +27 -0
- package/dist/plan/creator.d.ts.map +1 -0
- package/dist/plan/creator.js +251 -0
- package/dist/plan/creator.js.map +1 -0
- package/dist/plan/parser.d.ts +11 -0
- package/dist/plan/parser.d.ts.map +1 -0
- package/dist/plan/parser.js +151 -0
- package/dist/plan/parser.js.map +1 -0
- package/dist/plan/types.d.ts +23 -0
- package/dist/plan/types.d.ts.map +1 -0
- package/dist/plan/types.js +2 -0
- package/dist/plan/types.js.map +1 -0
- package/dist/plan/updater.d.ts +16 -0
- package/dist/plan/updater.d.ts.map +1 -0
- package/dist/plan/updater.js +59 -0
- package/dist/plan/updater.js.map +1 -0
- package/dist/progress/colors.d.ts +9 -0
- package/dist/progress/colors.d.ts.map +1 -0
- package/dist/progress/colors.js +39 -0
- package/dist/progress/colors.js.map +1 -0
- package/dist/progress/logger.d.ts +17 -0
- package/dist/progress/logger.d.ts.map +1 -0
- package/dist/progress/logger.js +101 -0
- package/dist/progress/logger.js.map +1 -0
- package/dist/progress/notify.d.ts +2 -0
- package/dist/progress/notify.d.ts.map +1 -0
- package/dist/progress/notify.js +37 -0
- package/dist/progress/notify.js.map +1 -0
- package/dist/progress/timestamp.d.ts +5 -0
- package/dist/progress/timestamp.d.ts.map +1 -0
- package/dist/progress/timestamp.js +13 -0
- package/dist/progress/timestamp.js.map +1 -0
- package/dist/review/agents.d.ts +18 -0
- package/dist/review/agents.d.ts.map +1 -0
- package/dist/review/agents.js +43 -0
- package/dist/review/agents.js.map +1 -0
- package/dist/review/pipeline.d.ts +36 -0
- package/dist/review/pipeline.d.ts.map +1 -0
- package/dist/review/pipeline.js +210 -0
- package/dist/review/pipeline.js.map +1 -0
- package/dist/sea.d.ts +19 -0
- package/dist/sea.d.ts.map +1 -0
- package/dist/sea.js +41 -0
- package/dist/sea.js.map +1 -0
- package/package.json +57 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export type OutputLineType = 'text' | 'tool_use' | 'result' | 'error' | 'debug';
|
|
2
|
+
export interface OutputLine {
|
|
3
|
+
type: OutputLineType;
|
|
4
|
+
text: string;
|
|
5
|
+
raw: string;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* AIProvider is the only contract the rest of maestro depends on for AI execution.
|
|
9
|
+
*/
|
|
10
|
+
export interface AIProvider {
|
|
11
|
+
/**
|
|
12
|
+
* Execute a prompt, streaming output lines via the callback.
|
|
13
|
+
* Resolves when the subprocess exits successfully.
|
|
14
|
+
* Rejects on auth error or non-zero exit after retries.
|
|
15
|
+
*/
|
|
16
|
+
run(prompt: string, onLine: (line: OutputLine) => void): Promise<void>;
|
|
17
|
+
/**
|
|
18
|
+
* Whether this backend handles agent parallelism internally via Task-tool pattern.
|
|
19
|
+
* true = claude (uses Task tool); false = copilot (orchestrator spawns parallel subprocesses).
|
|
20
|
+
*/
|
|
21
|
+
supportsParallelAgents(): boolean;
|
|
22
|
+
/** Returns "claude" or "copilot" for logging. */
|
|
23
|
+
name(): string;
|
|
24
|
+
}
|
|
25
|
+
export declare class AIProviderError extends Error {
|
|
26
|
+
readonly isAuthError: boolean;
|
|
27
|
+
constructor(message: string, isAuthError?: boolean);
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=backend.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backend.d.ts","sourceRoot":"","sources":["../../src/backend/backend.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG,MAAM,GAAG,UAAU,GAAG,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC;AAEhF,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,cAAc,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;CACb;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB;;;;OAIG;IACH,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvE;;;OAGG;IACH,sBAAsB,IAAI,OAAO,CAAC;IAElC,iDAAiD;IACjD,IAAI,IAAI,MAAM,CAAC;CAChB;AAED,qBAAa,eAAgB,SAAQ,KAAK;aAGtB,WAAW,EAAE,OAAO;gBADpC,OAAO,EAAE,MAAM,EACC,WAAW,GAAE,OAAe;CAK/C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backend.js","sourceRoot":"","sources":["../../src/backend/backend.ts"],"names":[],"mappings":"AA6BA,MAAM,OAAO,eAAgB,SAAQ,KAAK;IAGtB;IAFlB,YACE,OAAe,EACC,cAAuB,KAAK;QAE5C,KAAK,CAAC,OAAO,CAAC,CAAC;QAFC,gBAAW,GAAX,WAAW,CAAiB;QAG5C,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC;IAChC,CAAC;CACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { AIProvider, OutputLine } from './backend.js';
|
|
2
|
+
import { Config } from '../config/types.js';
|
|
3
|
+
export declare class ClaudeProvider implements AIProvider {
|
|
4
|
+
private readonly config;
|
|
5
|
+
constructor(config: Config);
|
|
6
|
+
run(prompt: string, onLine: (line: OutputLine) => void): Promise<void>;
|
|
7
|
+
private processLine;
|
|
8
|
+
private checkErrorPatterns;
|
|
9
|
+
supportsParallelAgents(): boolean;
|
|
10
|
+
name(): string;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=claude.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"claude.d.ts","sourceRoot":"","sources":["../../src/backend/claude.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAmB,UAAU,EAAE,MAAM,cAAc,CAAC;AACvE,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAW5C,qBAAa,cAAe,YAAW,UAAU;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAErC,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAsF5E,OAAO,CAAC,WAAW;IA+CnB,OAAO,CAAC,kBAAkB;IAW1B,sBAAsB,IAAI,OAAO;IAIjC,IAAI,IAAI,MAAM;CAGf"}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { spawn } from 'child_process';
|
|
2
|
+
import { AIProviderError } from './backend.js';
|
|
3
|
+
export class ClaudeProvider {
|
|
4
|
+
config;
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this.config = config;
|
|
7
|
+
}
|
|
8
|
+
async run(prompt, onLine) {
|
|
9
|
+
const args = [
|
|
10
|
+
...this.config.claude_args.split(/\s+/).filter(Boolean),
|
|
11
|
+
'--print', '-',
|
|
12
|
+
];
|
|
13
|
+
return new Promise((resolve, reject) => {
|
|
14
|
+
// Guard against double-settle (e.g. error pattern detected then close fires)
|
|
15
|
+
let settled = false;
|
|
16
|
+
const rejectOnce = (err) => { if (!settled) {
|
|
17
|
+
settled = true;
|
|
18
|
+
reject(err);
|
|
19
|
+
} };
|
|
20
|
+
const resolveOnce = () => { if (!settled) {
|
|
21
|
+
settled = true;
|
|
22
|
+
resolve();
|
|
23
|
+
} };
|
|
24
|
+
const proc = spawn(this.config.claude_command, args, {
|
|
25
|
+
stdio: ['pipe', 'pipe', 'pipe'],
|
|
26
|
+
windowsHide: true,
|
|
27
|
+
shell: false,
|
|
28
|
+
});
|
|
29
|
+
// Write prompt via stdin to avoid OS command-line length limits (ENAMETOOLONG on Windows)
|
|
30
|
+
proc.stdin.on('error', (err) => {
|
|
31
|
+
if (this.config.debug) {
|
|
32
|
+
onLine({ type: 'debug', text: `stdin write error: ${err.message}`, raw: '' });
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
proc.stdin.write(prompt, 'utf8');
|
|
36
|
+
proc.stdin.end();
|
|
37
|
+
let buffer = '';
|
|
38
|
+
proc.stdout.on('data', (chunk) => {
|
|
39
|
+
buffer += chunk.toString('utf8');
|
|
40
|
+
const lines = buffer.split('\n');
|
|
41
|
+
buffer = lines.pop() ?? '';
|
|
42
|
+
for (const rawLine of lines) {
|
|
43
|
+
if (!rawLine.trim())
|
|
44
|
+
continue;
|
|
45
|
+
try {
|
|
46
|
+
this.processLine(rawLine, onLine);
|
|
47
|
+
}
|
|
48
|
+
catch (err) {
|
|
49
|
+
rejectOnce(err);
|
|
50
|
+
proc.kill();
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
proc.stderr.on('data', (chunk) => {
|
|
56
|
+
const text = chunk.toString('utf8').trim();
|
|
57
|
+
if (!text)
|
|
58
|
+
return;
|
|
59
|
+
try {
|
|
60
|
+
this.checkErrorPatterns(text);
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
rejectOnce(err);
|
|
64
|
+
proc.kill();
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
if (this.config.debug) {
|
|
68
|
+
onLine({ type: 'debug', text, raw: text });
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
proc.on('close', (code) => {
|
|
72
|
+
if (buffer.trim()) {
|
|
73
|
+
try {
|
|
74
|
+
this.processLine(buffer.trim(), onLine);
|
|
75
|
+
}
|
|
76
|
+
catch (err) {
|
|
77
|
+
rejectOnce(err);
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
if (settled)
|
|
82
|
+
return;
|
|
83
|
+
if ((code ?? 0) !== 0) {
|
|
84
|
+
rejectOnce(new AIProviderError(`claude exited with code ${code}`));
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
resolveOnce();
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
proc.on('error', (err) => {
|
|
91
|
+
rejectOnce(new AIProviderError(`Failed to spawn claude: ${err.message}. Is claude installed and on PATH?`));
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
processLine(rawLine, onLine) {
|
|
96
|
+
// Try to parse as stream-json
|
|
97
|
+
let parsed = null;
|
|
98
|
+
try {
|
|
99
|
+
parsed = JSON.parse(rawLine);
|
|
100
|
+
}
|
|
101
|
+
catch {
|
|
102
|
+
// Not JSON — forward as plain text
|
|
103
|
+
onLine({ type: 'text', text: rawLine, raw: rawLine });
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
switch (parsed.type) {
|
|
107
|
+
case 'assistant': {
|
|
108
|
+
// Extract text from content blocks
|
|
109
|
+
const content = parsed.message?.content ?? [];
|
|
110
|
+
for (const block of content) {
|
|
111
|
+
if (block.type === 'text' && block.text) {
|
|
112
|
+
// Check for auth/error patterns
|
|
113
|
+
this.checkErrorPatterns(block.text);
|
|
114
|
+
onLine({ type: 'text', text: block.text, raw: rawLine });
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
break;
|
|
118
|
+
}
|
|
119
|
+
case 'result': {
|
|
120
|
+
if (parsed.result) {
|
|
121
|
+
onLine({ type: 'result', text: parsed.result, raw: rawLine });
|
|
122
|
+
}
|
|
123
|
+
break;
|
|
124
|
+
}
|
|
125
|
+
case 'tool_use': {
|
|
126
|
+
onLine({ type: 'tool_use', text: '', raw: rawLine });
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
case 'error': {
|
|
130
|
+
const errorText = parsed.error ?? rawLine;
|
|
131
|
+
this.checkErrorPatterns(errorText);
|
|
132
|
+
onLine({ type: 'error', text: errorText, raw: rawLine });
|
|
133
|
+
break;
|
|
134
|
+
}
|
|
135
|
+
default: {
|
|
136
|
+
// Unknown type — forward raw
|
|
137
|
+
onLine({ type: 'debug', text: rawLine, raw: rawLine });
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
checkErrorPatterns(text) {
|
|
142
|
+
for (const pattern of this.config.claude_error_patterns) {
|
|
143
|
+
if (text.includes(pattern)) {
|
|
144
|
+
throw new AIProviderError(`Detected Claude error: "${pattern}". Check your usage or re-run \`claude login\`. Run \`maestro\` again to resume.`, true);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
supportsParallelAgents() {
|
|
149
|
+
return true;
|
|
150
|
+
}
|
|
151
|
+
name() {
|
|
152
|
+
return 'claude';
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
//# sourceMappingURL=claude.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"claude.js","sourceRoot":"","sources":["../../src/backend/claude.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AIProvider, OutputLine } from './backend.js';
|
|
2
|
+
import { Config } from '../config/types.js';
|
|
3
|
+
export declare class CopilotProvider implements AIProvider {
|
|
4
|
+
private readonly config;
|
|
5
|
+
constructor(config: Config);
|
|
6
|
+
run(prompt: string, onLine: (line: OutputLine) => void): Promise<void>;
|
|
7
|
+
private checkErrorPatterns;
|
|
8
|
+
supportsParallelAgents(): boolean;
|
|
9
|
+
name(): string;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=copilot.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"copilot.d.ts","sourceRoot":"","sources":["../../src/backend/copilot.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAmB,UAAU,EAAE,MAAM,cAAc,CAAC;AACvE,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,qBAAa,eAAgB,YAAW,UAAU;IACpC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAErC,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAuF5E,OAAO,CAAC,kBAAkB;IAW1B,sBAAsB,IAAI,OAAO;IAIjC,IAAI,IAAI,MAAM;CAGf"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { spawn } from 'child_process';
|
|
2
|
+
import { AIProviderError } from './backend.js';
|
|
3
|
+
export class CopilotProvider {
|
|
4
|
+
config;
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this.config = config;
|
|
7
|
+
}
|
|
8
|
+
async run(prompt, onLine) {
|
|
9
|
+
// Pass the prompt via stdin. Copilot does not support '--prompt -' as a stdin indicator
|
|
10
|
+
// (it treats '-' as a literal dash). We write the prompt to the stdin pipe directly and
|
|
11
|
+
// omit any --prompt flag so the CLI reads from stdin in autopilot mode.
|
|
12
|
+
const args = this.config.copilot_args.split(/\s+/).filter(Boolean);
|
|
13
|
+
return new Promise((resolve, reject) => {
|
|
14
|
+
// Guard against double-settle (e.g. error pattern detected then close fires)
|
|
15
|
+
let settled = false;
|
|
16
|
+
const rejectOnce = (err) => { if (!settled) {
|
|
17
|
+
settled = true;
|
|
18
|
+
reject(err);
|
|
19
|
+
} };
|
|
20
|
+
const resolveOnce = () => { if (!settled) {
|
|
21
|
+
settled = true;
|
|
22
|
+
resolve();
|
|
23
|
+
} };
|
|
24
|
+
const proc = spawn(this.config.copilot_command, args, {
|
|
25
|
+
stdio: ['pipe', 'pipe', 'pipe'],
|
|
26
|
+
windowsHide: true,
|
|
27
|
+
shell: false,
|
|
28
|
+
});
|
|
29
|
+
proc.stdin.on('error', (err) => {
|
|
30
|
+
if (this.config.debug) {
|
|
31
|
+
onLine({ type: 'debug', text: `stdin write error: ${err.message}`, raw: '' });
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
proc.stdin.write(prompt, 'utf8');
|
|
35
|
+
proc.stdin.end();
|
|
36
|
+
let buffer = '';
|
|
37
|
+
proc.stdout.on('data', (chunk) => {
|
|
38
|
+
buffer += chunk.toString('utf8');
|
|
39
|
+
const lines = buffer.split('\n');
|
|
40
|
+
buffer = lines.pop() ?? '';
|
|
41
|
+
for (const rawLine of lines) {
|
|
42
|
+
if (!rawLine.trim())
|
|
43
|
+
continue;
|
|
44
|
+
try {
|
|
45
|
+
this.checkErrorPatterns(rawLine);
|
|
46
|
+
}
|
|
47
|
+
catch (err) {
|
|
48
|
+
rejectOnce(err);
|
|
49
|
+
proc.kill();
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
onLine({ type: 'text', text: rawLine, raw: rawLine });
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
proc.stderr.on('data', (chunk) => {
|
|
56
|
+
const text = chunk.toString('utf8').trim();
|
|
57
|
+
if (!text)
|
|
58
|
+
return;
|
|
59
|
+
try {
|
|
60
|
+
this.checkErrorPatterns(text);
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
rejectOnce(err);
|
|
64
|
+
proc.kill();
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
if (this.config.debug) {
|
|
68
|
+
onLine({ type: 'debug', text, raw: text });
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
proc.on('close', (code) => {
|
|
72
|
+
if (buffer.trim()) {
|
|
73
|
+
try {
|
|
74
|
+
this.checkErrorPatterns(buffer.trim());
|
|
75
|
+
}
|
|
76
|
+
catch (err) {
|
|
77
|
+
rejectOnce(err);
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
onLine({ type: 'text', text: buffer.trim(), raw: buffer.trim() });
|
|
81
|
+
}
|
|
82
|
+
if (settled)
|
|
83
|
+
return;
|
|
84
|
+
if ((code ?? 0) !== 0) {
|
|
85
|
+
rejectOnce(new AIProviderError(`copilot exited with code ${code}`));
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
resolveOnce();
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
proc.on('error', (err) => {
|
|
92
|
+
rejectOnce(new AIProviderError(`Failed to spawn copilot: ${err.message}. Is @github/copilot installed? Run: npm install -g @github/copilot`));
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
checkErrorPatterns(text) {
|
|
97
|
+
for (const pattern of this.config.copilot_error_patterns) {
|
|
98
|
+
if (text.includes(pattern)) {
|
|
99
|
+
throw new AIProviderError(`Detected Copilot error: "${pattern}". Check your subscription or re-run \`gh auth login\`. Run \`maestro\` again to resume.`, true);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
supportsParallelAgents() {
|
|
104
|
+
return false;
|
|
105
|
+
}
|
|
106
|
+
name() {
|
|
107
|
+
return 'copilot';
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=copilot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"copilot.js","sourceRoot":"","sources":["../../src/backend/copilot.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/backend/factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,CASzD"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ClaudeProvider } from './claude.js';
|
|
2
|
+
import { CopilotProvider } from './copilot.js';
|
|
3
|
+
export function createProvider(config) {
|
|
4
|
+
switch (config.ai_provider) {
|
|
5
|
+
case 'claude':
|
|
6
|
+
return new ClaudeProvider(config);
|
|
7
|
+
case 'copilot':
|
|
8
|
+
return new CopilotProvider(config);
|
|
9
|
+
default:
|
|
10
|
+
throw new Error(`Unknown AI provider: '${config.ai_provider}'. Use 'claude' or 'copilot'.`);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../src/backend/factory.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAG/C,MAAM,UAAU,cAAc,CAAC,MAAc;IAC3C,QAAQ,MAAM,CAAC,WAAW,EAAE,CAAC;QAC3B,KAAK,QAAQ;YACX,OAAO,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;QACpC,KAAK,SAAS;YACZ,OAAO,IAAI,eAAe,CAAC,MAAM,CAAC,CAAC;QACrC;YACE,MAAM,IAAI,KAAK,CAAC,yBAAyB,MAAM,CAAC,WAAW,+BAA+B,CAAC,CAAC;IAChG,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare class ConfigServer {
|
|
2
|
+
private server;
|
|
3
|
+
private clients;
|
|
4
|
+
private shutdownTimer;
|
|
5
|
+
private readonly GRACE_MS;
|
|
6
|
+
start(port: number, globalConfigPath: string, projectConfigPath: string, onIdle?: () => void): void;
|
|
7
|
+
stop(): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=configserver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configserver.d.ts","sourceRoot":"","sources":["../../src/config/configserver.ts"],"names":[],"mappings":"AAoDA,qBAAa,YAAY;IACvB,OAAO,CAAC,MAAM,CAA4B;IAC1C,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,aAAa,CAA8C;IACnE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAQ;IAEjC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,IAAI,GAAG,IAAI;IA6FnG,IAAI,IAAI,IAAI;CAOb"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import * as http from 'http';
|
|
2
|
+
import * as fs from 'fs';
|
|
3
|
+
import { EMBEDDED_DEFAULTS } from './types.js';
|
|
4
|
+
import { loadConfigLayer } from './loader.js';
|
|
5
|
+
import { computeOverrides, writeConfigFile } from './write.js';
|
|
6
|
+
import { readHtmlAsset } from '../sea.js';
|
|
7
|
+
function buildConfigState(globalConfigPath, projectConfigPath) {
|
|
8
|
+
const globalOverrides = loadConfigLayer(globalConfigPath);
|
|
9
|
+
const projectOverrides = loadConfigLayer(projectConfigPath);
|
|
10
|
+
// Merge: defaults < global < project
|
|
11
|
+
const merged = { ...EMBEDDED_DEFAULTS };
|
|
12
|
+
for (const [k, v] of Object.entries(globalOverrides)) {
|
|
13
|
+
if (v !== undefined && v !== null) {
|
|
14
|
+
merged[k] = v;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
for (const [k, v] of Object.entries(projectOverrides)) {
|
|
18
|
+
if (v !== undefined && v !== null) {
|
|
19
|
+
merged[k] = v;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
return {
|
|
23
|
+
merged,
|
|
24
|
+
defaults: EMBEDDED_DEFAULTS,
|
|
25
|
+
globalOverrides,
|
|
26
|
+
projectOverrides,
|
|
27
|
+
globalConfigPath,
|
|
28
|
+
projectConfigPath,
|
|
29
|
+
globalExists: fs.existsSync(globalConfigPath),
|
|
30
|
+
projectExists: fs.existsSync(projectConfigPath),
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
export class ConfigServer {
|
|
34
|
+
server = null;
|
|
35
|
+
clients = new Set();
|
|
36
|
+
shutdownTimer = null;
|
|
37
|
+
GRACE_MS = 4000;
|
|
38
|
+
start(port, globalConfigPath, projectConfigPath, onIdle) {
|
|
39
|
+
this.server = http.createServer((req, res) => {
|
|
40
|
+
const url = req.url ?? '/';
|
|
41
|
+
const method = req.method ?? 'GET';
|
|
42
|
+
if (method === 'GET' && url === '/') {
|
|
43
|
+
let html;
|
|
44
|
+
try {
|
|
45
|
+
html = readHtmlAsset('config.html');
|
|
46
|
+
}
|
|
47
|
+
catch {
|
|
48
|
+
res.writeHead(500, { 'Content-Type': 'text/plain' });
|
|
49
|
+
res.end('config.html not found. Run npm run build first.');
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
res.writeHead(200, { 'Content-Type': 'text/html; charset=utf-8' });
|
|
53
|
+
res.end(html);
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (method === 'GET' && url === '/config') {
|
|
57
|
+
const state = buildConfigState(globalConfigPath, projectConfigPath);
|
|
58
|
+
res.writeHead(200, {
|
|
59
|
+
'Content-Type': 'application/json',
|
|
60
|
+
'Access-Control-Allow-Origin': '*',
|
|
61
|
+
});
|
|
62
|
+
res.end(JSON.stringify(state));
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
if (method === 'POST' && url === '/config') {
|
|
66
|
+
let body = '';
|
|
67
|
+
req.on('data', (chunk) => { body += chunk.toString(); });
|
|
68
|
+
req.on('end', () => {
|
|
69
|
+
try {
|
|
70
|
+
const payload = JSON.parse(body);
|
|
71
|
+
const targetPath = payload.target === 'project' ? projectConfigPath : globalConfigPath;
|
|
72
|
+
const diff = computeOverrides(payload.overrides);
|
|
73
|
+
writeConfigFile(targetPath, diff);
|
|
74
|
+
res.writeHead(200, {
|
|
75
|
+
'Content-Type': 'application/json',
|
|
76
|
+
'Access-Control-Allow-Origin': '*',
|
|
77
|
+
});
|
|
78
|
+
res.end(JSON.stringify({ ok: true }));
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
82
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
83
|
+
res.end(JSON.stringify({ ok: false, error: msg }));
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
if (method === 'GET' && url === '/events') {
|
|
89
|
+
res.writeHead(200, {
|
|
90
|
+
'Content-Type': 'text/event-stream',
|
|
91
|
+
'Cache-Control': 'no-cache',
|
|
92
|
+
'Connection': 'keep-alive',
|
|
93
|
+
});
|
|
94
|
+
res.write('\n');
|
|
95
|
+
this.clients.add(res);
|
|
96
|
+
if (this.shutdownTimer) {
|
|
97
|
+
clearTimeout(this.shutdownTimer);
|
|
98
|
+
this.shutdownTimer = null;
|
|
99
|
+
}
|
|
100
|
+
req.on('close', () => {
|
|
101
|
+
this.clients.delete(res);
|
|
102
|
+
if (this.clients.size === 0 && onIdle) {
|
|
103
|
+
this.shutdownTimer = setTimeout(() => onIdle(), this.GRACE_MS);
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
// CORS preflight
|
|
109
|
+
if (method === 'OPTIONS') {
|
|
110
|
+
res.writeHead(204, {
|
|
111
|
+
'Access-Control-Allow-Origin': '*',
|
|
112
|
+
'Access-Control-Allow-Methods': 'GET, POST, OPTIONS',
|
|
113
|
+
'Access-Control-Allow-Headers': 'Content-Type',
|
|
114
|
+
});
|
|
115
|
+
res.end();
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
res.writeHead(404, { 'Content-Type': 'text/plain' });
|
|
119
|
+
res.end('Not found');
|
|
120
|
+
});
|
|
121
|
+
this.server.listen(port, () => {
|
|
122
|
+
// Server started
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
stop() {
|
|
126
|
+
if (this.shutdownTimer) {
|
|
127
|
+
clearTimeout(this.shutdownTimer);
|
|
128
|
+
this.shutdownTimer = null;
|
|
129
|
+
}
|
|
130
|
+
for (const client of this.clients) {
|
|
131
|
+
try {
|
|
132
|
+
client.end();
|
|
133
|
+
}
|
|
134
|
+
catch { /* ignore */ }
|
|
135
|
+
}
|
|
136
|
+
this.clients.clear();
|
|
137
|
+
this.server?.close();
|
|
138
|
+
this.server = null;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
//# sourceMappingURL=configserver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configserver.js","sourceRoot":"","sources":["../../src/config/configserver.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dump.d.ts","sourceRoot":"","sources":["../../src/config/dump.ts"],"names":[],"mappings":"AAOA,wBAAsB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAIjE"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as fs from 'fs';
|
|
2
|
+
import * as path from 'path';
|
|
3
|
+
import * as url from 'url';
|
|
4
|
+
const __dirname = path.dirname(url.fileURLToPath(import.meta.url));
|
|
5
|
+
const DEFAULTS_DIR = path.resolve(__dirname, '..', '..', 'defaults');
|
|
6
|
+
export async function dumpDefaults(destDir) {
|
|
7
|
+
fs.mkdirSync(destDir, { recursive: true });
|
|
8
|
+
copyDir(DEFAULTS_DIR, destDir);
|
|
9
|
+
console.log(`Defaults written to ${destDir}`);
|
|
10
|
+
}
|
|
11
|
+
function copyDir(src, dest) {
|
|
12
|
+
fs.mkdirSync(dest, { recursive: true });
|
|
13
|
+
for (const entry of fs.readdirSync(src, { withFileTypes: true })) {
|
|
14
|
+
const srcPath = path.join(src, entry.name);
|
|
15
|
+
const destPath = path.join(dest, entry.name);
|
|
16
|
+
if (entry.isDirectory()) {
|
|
17
|
+
copyDir(srcPath, destPath);
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
fs.copyFileSync(srcPath, destPath);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=dump.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dump.js","sourceRoot":"","sources":["../../src/config/dump.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,GAAG,MAAM,KAAK,CAAC;AAE3B,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AACnE,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;AAErE,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAAe;IAChD,EAAE,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3C,OAAO,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;IAC/B,OAAO,CAAC,GAAG,CAAC,uBAAuB,OAAO,EAAE,CAAC,CAAC;AAChD,CAAC;AAED,SAAS,OAAO,CAAC,GAAW,EAAE,IAAY;IACxC,EAAE,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACxC,KAAK,MAAM,KAAK,IAAI,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;QACjE,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;YACxB,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Config } from './types.js';
|
|
2
|
+
export interface LoadConfigOptions {
|
|
3
|
+
configDir?: string;
|
|
4
|
+
cliOverrides?: Partial<Config>;
|
|
5
|
+
noColor?: boolean;
|
|
6
|
+
debug?: boolean;
|
|
7
|
+
port?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare function loadConfig(options?: LoadConfigOptions): Config;
|
|
10
|
+
export declare function loadConfigLayer(filePath: string): Partial<Config>;
|
|
11
|
+
//# sourceMappingURL=loader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/config/loader.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,MAAM,EAAqB,MAAM,YAAY,CAAC;AAEvD,MAAM,WAAW,iBAAiB;IAChC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IAC/B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,wBAAgB,UAAU,CAAC,OAAO,GAAE,iBAAsB,GAAG,MAAM,CAoClE;AAGD,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAEjE"}
|