@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.
Files changed (175) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +254 -0
  3. package/defaults/agents/documentation.txt +18 -0
  4. package/defaults/agents/implementation.txt +16 -0
  5. package/defaults/agents/quality.txt +19 -0
  6. package/defaults/agents/simplification.txt +19 -0
  7. package/defaults/agents/testing.txt +16 -0
  8. package/defaults/config +46 -0
  9. package/defaults/plan-tips.md +50 -0
  10. package/defaults/prompts/finalize.txt +14 -0
  11. package/defaults/prompts/hint_analysis.txt +38 -0
  12. package/defaults/prompts/plan_create.txt +36 -0
  13. package/defaults/prompts/review_first.txt +37 -0
  14. package/defaults/prompts/review_second.txt +36 -0
  15. package/defaults/prompts/task.txt +23 -0
  16. package/dist/backend/backend.d.ts +29 -0
  17. package/dist/backend/backend.d.ts.map +1 -0
  18. package/dist/backend/backend.js +9 -0
  19. package/dist/backend/backend.js.map +1 -0
  20. package/dist/backend/claude.d.ts +12 -0
  21. package/dist/backend/claude.d.ts.map +1 -0
  22. package/dist/backend/claude.js +155 -0
  23. package/dist/backend/claude.js.map +1 -0
  24. package/dist/backend/copilot.d.ts +11 -0
  25. package/dist/backend/copilot.d.ts.map +1 -0
  26. package/dist/backend/copilot.js +110 -0
  27. package/dist/backend/copilot.js.map +1 -0
  28. package/dist/backend/factory.d.ts +4 -0
  29. package/dist/backend/factory.d.ts.map +1 -0
  30. package/dist/backend/factory.js +13 -0
  31. package/dist/backend/factory.js.map +1 -0
  32. package/dist/config/configserver.d.ts +9 -0
  33. package/dist/config/configserver.d.ts.map +1 -0
  34. package/dist/config/configserver.js +141 -0
  35. package/dist/config/configserver.js.map +1 -0
  36. package/dist/config/dump.d.ts +2 -0
  37. package/dist/config/dump.d.ts.map +1 -0
  38. package/dist/config/dump.js +24 -0
  39. package/dist/config/dump.js.map +1 -0
  40. package/dist/config/loader.d.ts +11 -0
  41. package/dist/config/loader.d.ts.map +1 -0
  42. package/dist/config/loader.js +119 -0
  43. package/dist/config/loader.js.map +1 -0
  44. package/dist/config/prompts.d.ts +19 -0
  45. package/dist/config/prompts.d.ts.map +1 -0
  46. package/dist/config/prompts.js +128 -0
  47. package/dist/config/prompts.js.map +1 -0
  48. package/dist/config/reset.d.ts +3 -0
  49. package/dist/config/reset.d.ts.map +1 -0
  50. package/dist/config/reset.js +23 -0
  51. package/dist/config/reset.js.map +1 -0
  52. package/dist/config/template.d.ts +5 -0
  53. package/dist/config/template.d.ts.map +1 -0
  54. package/dist/config/template.js +11 -0
  55. package/dist/config/template.js.map +1 -0
  56. package/dist/config/types.d.ts +35 -0
  57. package/dist/config/types.d.ts.map +1 -0
  58. package/dist/config/types.js +42 -0
  59. package/dist/config/types.js.map +1 -0
  60. package/dist/config/write.d.ts +5 -0
  61. package/dist/config/write.d.ts.map +1 -0
  62. package/dist/config/write.js +59 -0
  63. package/dist/config/write.js.map +1 -0
  64. package/dist/dashboard/assets/config.html +1012 -0
  65. package/dist/dashboard/assets/dashboard.html +871 -0
  66. package/dist/dashboard/assets/help.html +657 -0
  67. package/dist/dashboard/assets.d.ts +2 -0
  68. package/dist/dashboard/assets.d.ts.map +1 -0
  69. package/dist/dashboard/assets.js +5 -0
  70. package/dist/dashboard/assets.js.map +1 -0
  71. package/dist/dashboard/event-bus.d.ts +11 -0
  72. package/dist/dashboard/event-bus.d.ts.map +1 -0
  73. package/dist/dashboard/event-bus.js +4 -0
  74. package/dist/dashboard/event-bus.js.map +1 -0
  75. package/dist/dashboard/replay-parser.d.ts +6 -0
  76. package/dist/dashboard/replay-parser.d.ts.map +1 -0
  77. package/dist/dashboard/replay-parser.js +56 -0
  78. package/dist/dashboard/replay-parser.js.map +1 -0
  79. package/dist/dashboard/server.d.ts +14 -0
  80. package/dist/dashboard/server.d.ts.map +1 -0
  81. package/dist/dashboard/server.js +178 -0
  82. package/dist/dashboard/server.js.map +1 -0
  83. package/dist/dashboard/watcher.d.ts +17 -0
  84. package/dist/dashboard/watcher.d.ts.map +1 -0
  85. package/dist/dashboard/watcher.js +73 -0
  86. package/dist/dashboard/watcher.js.map +1 -0
  87. package/dist/executor/hints.d.ts +21 -0
  88. package/dist/executor/hints.d.ts.map +1 -0
  89. package/dist/executor/hints.js +102 -0
  90. package/dist/executor/hints.js.map +1 -0
  91. package/dist/executor/task.d.ts +19 -0
  92. package/dist/executor/task.d.ts.map +1 -0
  93. package/dist/executor/task.js +119 -0
  94. package/dist/executor/task.js.map +1 -0
  95. package/dist/executor/validation.d.ts +18 -0
  96. package/dist/executor/validation.d.ts.map +1 -0
  97. package/dist/executor/validation.js +73 -0
  98. package/dist/executor/validation.js.map +1 -0
  99. package/dist/git/branch.d.ts +23 -0
  100. package/dist/git/branch.d.ts.map +1 -0
  101. package/dist/git/branch.js +64 -0
  102. package/dist/git/branch.js.map +1 -0
  103. package/dist/git/commit.d.ts +21 -0
  104. package/dist/git/commit.d.ts.map +1 -0
  105. package/dist/git/commit.js +37 -0
  106. package/dist/git/commit.js.map +1 -0
  107. package/dist/git/diff.d.ts +15 -0
  108. package/dist/git/diff.d.ts.map +1 -0
  109. package/dist/git/diff.js +26 -0
  110. package/dist/git/diff.js.map +1 -0
  111. package/dist/git/git.d.ts +9 -0
  112. package/dist/git/git.d.ts.map +1 -0
  113. package/dist/git/git.js +20 -0
  114. package/dist/git/git.js.map +1 -0
  115. package/dist/git/gitignore.d.ts +2 -0
  116. package/dist/git/gitignore.d.ts.map +1 -0
  117. package/dist/git/gitignore.js +66 -0
  118. package/dist/git/gitignore.js.map +1 -0
  119. package/dist/git/worktree.d.ts +3 -0
  120. package/dist/git/worktree.d.ts.map +1 -0
  121. package/dist/git/worktree.js +17 -0
  122. package/dist/git/worktree.js.map +1 -0
  123. package/dist/main.d.ts +3 -0
  124. package/dist/main.d.ts.map +1 -0
  125. package/dist/main.js +212 -0
  126. package/dist/main.js.map +1 -0
  127. package/dist/orchestrator/orchestrator.d.ts +21 -0
  128. package/dist/orchestrator/orchestrator.d.ts.map +1 -0
  129. package/dist/orchestrator/orchestrator.js +218 -0
  130. package/dist/orchestrator/orchestrator.js.map +1 -0
  131. package/dist/plan/creator.d.ts +27 -0
  132. package/dist/plan/creator.d.ts.map +1 -0
  133. package/dist/plan/creator.js +251 -0
  134. package/dist/plan/creator.js.map +1 -0
  135. package/dist/plan/parser.d.ts +11 -0
  136. package/dist/plan/parser.d.ts.map +1 -0
  137. package/dist/plan/parser.js +151 -0
  138. package/dist/plan/parser.js.map +1 -0
  139. package/dist/plan/types.d.ts +23 -0
  140. package/dist/plan/types.d.ts.map +1 -0
  141. package/dist/plan/types.js +2 -0
  142. package/dist/plan/types.js.map +1 -0
  143. package/dist/plan/updater.d.ts +16 -0
  144. package/dist/plan/updater.d.ts.map +1 -0
  145. package/dist/plan/updater.js +59 -0
  146. package/dist/plan/updater.js.map +1 -0
  147. package/dist/progress/colors.d.ts +9 -0
  148. package/dist/progress/colors.d.ts.map +1 -0
  149. package/dist/progress/colors.js +39 -0
  150. package/dist/progress/colors.js.map +1 -0
  151. package/dist/progress/logger.d.ts +17 -0
  152. package/dist/progress/logger.d.ts.map +1 -0
  153. package/dist/progress/logger.js +101 -0
  154. package/dist/progress/logger.js.map +1 -0
  155. package/dist/progress/notify.d.ts +2 -0
  156. package/dist/progress/notify.d.ts.map +1 -0
  157. package/dist/progress/notify.js +37 -0
  158. package/dist/progress/notify.js.map +1 -0
  159. package/dist/progress/timestamp.d.ts +5 -0
  160. package/dist/progress/timestamp.d.ts.map +1 -0
  161. package/dist/progress/timestamp.js +13 -0
  162. package/dist/progress/timestamp.js.map +1 -0
  163. package/dist/review/agents.d.ts +18 -0
  164. package/dist/review/agents.d.ts.map +1 -0
  165. package/dist/review/agents.js +43 -0
  166. package/dist/review/agents.js.map +1 -0
  167. package/dist/review/pipeline.d.ts +36 -0
  168. package/dist/review/pipeline.d.ts.map +1 -0
  169. package/dist/review/pipeline.js +210 -0
  170. package/dist/review/pipeline.js.map +1 -0
  171. package/dist/sea.d.ts +19 -0
  172. package/dist/sea.d.ts.map +1 -0
  173. package/dist/sea.js +41 -0
  174. package/dist/sea.js.map +1 -0
  175. 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,9 @@
1
+ export class AIProviderError extends Error {
2
+ isAuthError;
3
+ constructor(message, isAuthError = false) {
4
+ super(message);
5
+ this.isAuthError = isAuthError;
6
+ this.name = 'AIProviderError';
7
+ }
8
+ }
9
+ //# sourceMappingURL=backend.js.map
@@ -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,4 @@
1
+ import { AIProvider } from './backend.js';
2
+ import { Config } from '../config/types.js';
3
+ export declare function createProvider(config: Config): AIProvider;
4
+ //# sourceMappingURL=factory.d.ts.map
@@ -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,2 @@
1
+ export declare function dumpDefaults(destDir: string): Promise<void>;
2
+ //# sourceMappingURL=dump.d.ts.map
@@ -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"}