dispatch-ai 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 (91) hide show
  1. package/LICENSE +229 -0
  2. package/README.md +177 -0
  3. package/dist/bin/dispatch.d.ts +3 -0
  4. package/dist/bin/dispatch.d.ts.map +1 -0
  5. package/dist/bin/dispatch.js +42 -0
  6. package/dist/bin/dispatch.js.map +1 -0
  7. package/dist/src/commands/create.d.ts +3 -0
  8. package/dist/src/commands/create.d.ts.map +1 -0
  9. package/dist/src/commands/create.js +154 -0
  10. package/dist/src/commands/create.js.map +1 -0
  11. package/dist/src/commands/init.d.ts +3 -0
  12. package/dist/src/commands/init.d.ts.map +1 -0
  13. package/dist/src/commands/init.js +100 -0
  14. package/dist/src/commands/init.js.map +1 -0
  15. package/dist/src/commands/run.d.ts +3 -0
  16. package/dist/src/commands/run.d.ts.map +1 -0
  17. package/dist/src/commands/run.js +72 -0
  18. package/dist/src/commands/run.js.map +1 -0
  19. package/dist/src/commands/status.d.ts +3 -0
  20. package/dist/src/commands/status.d.ts.map +1 -0
  21. package/dist/src/commands/status.js +34 -0
  22. package/dist/src/commands/status.js.map +1 -0
  23. package/dist/src/engine/base.d.ts +12 -0
  24. package/dist/src/engine/base.d.ts.map +1 -0
  25. package/dist/src/engine/base.js +161 -0
  26. package/dist/src/engine/base.js.map +1 -0
  27. package/dist/src/engine/claude.d.ts +25 -0
  28. package/dist/src/engine/claude.d.ts.map +1 -0
  29. package/dist/src/engine/claude.js +215 -0
  30. package/dist/src/engine/claude.js.map +1 -0
  31. package/dist/src/engine/types.d.ts +88 -0
  32. package/dist/src/engine/types.d.ts.map +1 -0
  33. package/dist/src/engine/types.js +2 -0
  34. package/dist/src/engine/types.js.map +1 -0
  35. package/dist/src/github/client.d.ts +58 -0
  36. package/dist/src/github/client.d.ts.map +1 -0
  37. package/dist/src/github/client.js +189 -0
  38. package/dist/src/github/client.js.map +1 -0
  39. package/dist/src/github/issues.d.ts +13 -0
  40. package/dist/src/github/issues.d.ts.map +1 -0
  41. package/dist/src/github/issues.js +67 -0
  42. package/dist/src/github/issues.js.map +1 -0
  43. package/dist/src/github/pulls.d.ts +15 -0
  44. package/dist/src/github/pulls.d.ts.map +1 -0
  45. package/dist/src/github/pulls.js +65 -0
  46. package/dist/src/github/pulls.js.map +1 -0
  47. package/dist/src/index.d.ts +7 -0
  48. package/dist/src/index.d.ts.map +1 -0
  49. package/dist/src/index.js +5 -0
  50. package/dist/src/index.js.map +1 -0
  51. package/dist/src/orchestrator/classifier.d.ts +4 -0
  52. package/dist/src/orchestrator/classifier.d.ts.map +1 -0
  53. package/dist/src/orchestrator/classifier.js +45 -0
  54. package/dist/src/orchestrator/classifier.js.map +1 -0
  55. package/dist/src/orchestrator/pipeline.d.ts +13 -0
  56. package/dist/src/orchestrator/pipeline.d.ts.map +1 -0
  57. package/dist/src/orchestrator/pipeline.js +246 -0
  58. package/dist/src/orchestrator/pipeline.js.map +1 -0
  59. package/dist/src/orchestrator/planner.d.ts +13 -0
  60. package/dist/src/orchestrator/planner.d.ts.map +1 -0
  61. package/dist/src/orchestrator/planner.js +95 -0
  62. package/dist/src/orchestrator/planner.js.map +1 -0
  63. package/dist/src/orchestrator/scorer.d.ts +8 -0
  64. package/dist/src/orchestrator/scorer.d.ts.map +1 -0
  65. package/dist/src/orchestrator/scorer.js +41 -0
  66. package/dist/src/orchestrator/scorer.js.map +1 -0
  67. package/dist/src/reporter/summary.d.ts +29 -0
  68. package/dist/src/reporter/summary.d.ts.map +1 -0
  69. package/dist/src/reporter/summary.js +77 -0
  70. package/dist/src/reporter/summary.js.map +1 -0
  71. package/dist/src/utils/config.d.ts +37 -0
  72. package/dist/src/utils/config.d.ts.map +1 -0
  73. package/dist/src/utils/config.js +60 -0
  74. package/dist/src/utils/config.js.map +1 -0
  75. package/dist/src/utils/git.d.ts +30 -0
  76. package/dist/src/utils/git.d.ts.map +1 -0
  77. package/dist/src/utils/git.js +95 -0
  78. package/dist/src/utils/git.js.map +1 -0
  79. package/dist/src/utils/logger.d.ts +22 -0
  80. package/dist/src/utils/logger.d.ts.map +1 -0
  81. package/dist/src/utils/logger.js +109 -0
  82. package/dist/src/utils/logger.js.map +1 -0
  83. package/dist/src/utils/semaphore.d.ts +19 -0
  84. package/dist/src/utils/semaphore.d.ts.map +1 -0
  85. package/dist/src/utils/semaphore.js +41 -0
  86. package/dist/src/utils/semaphore.js.map +1 -0
  87. package/dist/src/utils/worktree.d.ts +20 -0
  88. package/dist/src/utils/worktree.d.ts.map +1 -0
  89. package/dist/src/utils/worktree.js +92 -0
  90. package/dist/src/utils/worktree.js.map +1 -0
  91. package/package.json +62 -0
@@ -0,0 +1,67 @@
1
+ import { log } from "../utils/logger.js";
2
+ /** Fetch and hydrate issues with comments and metadata */
3
+ export async function fetchAndHydrateIssues(client, options) {
4
+ log.info(`Fetching open issues from ${client.owner}/${client.repo}...`);
5
+ const rawIssues = await client.fetchOpenIssues(options);
6
+ if (rawIssues.length === 0) {
7
+ log.info("No open issues found matching filters.");
8
+ return [];
9
+ }
10
+ log.info(`Found ${rawIssues.length} open issues. Fetching comments...`);
11
+ const issues = await Promise.all(rawIssues.map(async (raw) => {
12
+ const comments = raw.comments > 0
13
+ ? await client.fetchIssueComments(raw.number)
14
+ : [];
15
+ return {
16
+ number: raw.number,
17
+ title: raw.title,
18
+ body: raw.body || "",
19
+ labels: raw.labels,
20
+ comments,
21
+ author: raw.user,
22
+ url: raw.html_url,
23
+ createdAt: raw.created_at,
24
+ reactions: raw.reactions,
25
+ };
26
+ }));
27
+ return issues;
28
+ }
29
+ /** Sort issues by priority */
30
+ export function prioritizeIssues(issues) {
31
+ return [...issues].sort((a, b) => {
32
+ // Priority labels first
33
+ const getPriority = (issue) => {
34
+ for (const label of issue.labels) {
35
+ const lower = label.toLowerCase();
36
+ if (lower === "p0" || lower === "critical" || lower === "urgent")
37
+ return 0;
38
+ if (lower === "p1" || lower === "high")
39
+ return 1;
40
+ if (lower === "p2" || lower === "medium")
41
+ return 2;
42
+ if (lower === "p3" || lower === "low")
43
+ return 3;
44
+ }
45
+ return 4; // No priority label
46
+ };
47
+ const priorityDiff = getPriority(a) - getPriority(b);
48
+ if (priorityDiff !== 0)
49
+ return priorityDiff;
50
+ // Then by reactions (more reactions = more important)
51
+ if (b.reactions !== a.reactions)
52
+ return b.reactions - a.reactions;
53
+ // Then by age (older first)
54
+ return new Date(a.createdAt).getTime() - new Date(b.createdAt).getTime();
55
+ });
56
+ }
57
+ /** Create a slug from issue title for branch names */
58
+ export function slugifyTitle(title) {
59
+ return title
60
+ .toLowerCase()
61
+ .replace(/[^a-z0-9\s-]/g, "")
62
+ .replace(/\s+/g, "-")
63
+ .replace(/-+/g, "-")
64
+ .substring(0, 40)
65
+ .replace(/-$/, "");
66
+ }
67
+ //# sourceMappingURL=issues.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"issues.js","sourceRoot":"","sources":["../../../src/github/issues.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type { Issue, SolveResult } from "../engine/types.js";
2
+ import type { GitHubClient } from "./client.js";
3
+ /** Build a well-formatted PR body */
4
+ export declare function buildPRBody(issue: Issue, result: SolveResult, diffSummary: string): string;
5
+ /** Create a PR for a solved issue */
6
+ export declare function createPRForIssue(client: GitHubClient, issue: Issue, result: SolveResult, options: {
7
+ branchName: string;
8
+ baseBranch: string;
9
+ diffSummary: string;
10
+ draft: boolean;
11
+ }): Promise<{
12
+ number: number;
13
+ url: string;
14
+ }>;
15
+ //# sourceMappingURL=pulls.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pulls.d.ts","sourceRoot":"","sources":["../../../src/github/pulls.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAC7D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGhD,qCAAqC;AACrC,wBAAgB,WAAW,CACzB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,WAAW,EACnB,WAAW,EAAE,MAAM,GAClB,MAAM,CAuCR;AAED,qCAAqC;AACrC,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,YAAY,EACpB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,WAAW,EACnB,OAAO,EAAE;IACP,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,OAAO,CAAC;CAChB,GACA,OAAO,CAAC;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,CAAA;CAAE,CAAC,CAgC1C"}
@@ -0,0 +1,65 @@
1
+ import { log } from "../utils/logger.js";
2
+ /** Build a well-formatted PR body */
3
+ export function buildPRBody(issue, result, diffSummary) {
4
+ const confidenceEmoji = result.confidence >= 8 ? "🟢" :
5
+ result.confidence >= 5 ? "🟡" :
6
+ "🔴";
7
+ let body = `## ⚡ Solved by Dispatch\n\n`;
8
+ body += `**Issue:** #${issue.number} — ${issue.title}\n`;
9
+ body += `**Confidence:** ${confidenceEmoji} ${result.confidence}/10\n`;
10
+ body += `**Type:** ${issue.classification || "unknown"}\n\n`;
11
+ body += `### Summary\n\n${result.summary}\n\n`;
12
+ if (result.uncertainties.length > 0) {
13
+ body += `### ⚠️ Areas of Uncertainty\n\n`;
14
+ for (const u of result.uncertainties) {
15
+ body += `- ${u}\n`;
16
+ }
17
+ body += `\n`;
18
+ }
19
+ if (result.changedFiles.length > 0) {
20
+ body += `### Changed Files\n\n`;
21
+ for (const f of result.changedFiles) {
22
+ body += `- \`${f}\`\n`;
23
+ }
24
+ body += `\n`;
25
+ }
26
+ if (diffSummary) {
27
+ body += `### Diff Stats\n\n\`\`\`\n${diffSummary}\n\`\`\`\n\n`;
28
+ }
29
+ body += `---\n`;
30
+ body += `Closes #${issue.number}\n\n`;
31
+ body += `> 🤖 This PR was automatically generated by [Dispatch](https://github.com/dispatch-cli/dispatch).\n`;
32
+ body += `> Review carefully before merging.`;
33
+ return body;
34
+ }
35
+ /** Create a PR for a solved issue */
36
+ export async function createPRForIssue(client, issue, result, options) {
37
+ const body = buildPRBody(issue, result, options.diffSummary);
38
+ // Build a concise PR title from the commit message:
39
+ // - Use only the first line (subject line) of the commit message
40
+ // - Truncate to 72 chars max (GitHub convention) after the prefix
41
+ const firstLine = result.commitMessage.split("\n")[0].trim();
42
+ const maxLen = 72 - "[dispatch] ".length; // ~61 chars for the message
43
+ const truncated = firstLine.length > maxLen
44
+ ? firstLine.substring(0, maxLen - 1).trimEnd() + "…"
45
+ : firstLine;
46
+ const prTitle = `[dispatch] ${truncated}`;
47
+ const labels = ["dispatch"];
48
+ if (result.confidence < 5) {
49
+ labels.push("needs-review");
50
+ }
51
+ if (issue.classification) {
52
+ labels.push(`type:${issue.classification}`);
53
+ }
54
+ const pr = await client.createPullRequest({
55
+ title: prTitle,
56
+ body,
57
+ head: options.branchName,
58
+ base: options.baseBranch,
59
+ draft: options.draft || result.confidence < 5,
60
+ labels,
61
+ });
62
+ log.success(`PR #${pr.number} created: ${pr.url}`);
63
+ return pr;
64
+ }
65
+ //# sourceMappingURL=pulls.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pulls.js","sourceRoot":"","sources":["../../../src/github/pulls.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export { runPipeline } from "./orchestrator/pipeline.js";
2
+ export { ClaudeEngine } from "./engine/claude.js";
3
+ export { GitHubClient } from "./github/client.js";
4
+ export { loadConfig } from "./utils/config.js";
5
+ export type { DispatchConfig } from "./utils/config.js";
6
+ export type { AIEngine, EngineEvent, Issue, IssueClassification } from "./engine/types.js";
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,YAAY,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACxD,YAAY,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { runPipeline } from "./orchestrator/pipeline.js";
2
+ export { ClaudeEngine } from "./engine/claude.js";
3
+ export { GitHubClient } from "./github/client.js";
4
+ export { loadConfig } from "./utils/config.js";
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Issue, IssueClassification } from "../engine/types.js";
2
+ /** Quick heuristic classification based on labels and keywords (fallback) */
3
+ export declare function heuristicClassify(issue: Issue): IssueClassification;
4
+ //# sourceMappingURL=classifier.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"classifier.d.ts","sourceRoot":"","sources":["../../../src/orchestrator/classifier.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAErE,6EAA6E;AAC7E,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,KAAK,GAAG,mBAAmB,CA6CnE"}
@@ -0,0 +1,45 @@
1
+ /** Quick heuristic classification based on labels and keywords (fallback) */
2
+ export function heuristicClassify(issue) {
3
+ const text = `${issue.title} ${issue.body}`.toLowerCase();
4
+ const labels = issue.labels.map((l) => l.toLowerCase());
5
+ // Check labels first
6
+ if (labels.some((l) => ["bug", "fix", "error", "crash", "broken"].includes(l))) {
7
+ return "code-fix";
8
+ }
9
+ if (labels.some((l) => ["enhancement", "feature", "feature-request"].includes(l))) {
10
+ return "feature";
11
+ }
12
+ if (labels.some((l) => ["documentation", "docs"].includes(l))) {
13
+ return "documentation";
14
+ }
15
+ if (labels.some((l) => ["investigation", "research", "question"].includes(l))) {
16
+ return "investigation";
17
+ }
18
+ if (labels.some((l) => ["security", "audit", "accessibility", "a11y"].includes(l))) {
19
+ return "audit";
20
+ }
21
+ if (labels.some((l) => ["refactor", "tech-debt", "cleanup"].includes(l))) {
22
+ return "refactor";
23
+ }
24
+ // Check keywords in title/body
25
+ if (text.match(/\b(figure out|investigate|research|why is|analyze|look into)\b/)) {
26
+ return "investigation";
27
+ }
28
+ if (text.match(/\b(audit|review|check for|scan|assess)\b/)) {
29
+ return "audit";
30
+ }
31
+ if (text.match(/\b(document|readme|docs|write up|explain)\b/)) {
32
+ return "documentation";
33
+ }
34
+ if (text.match(/\b(bug|fix|broken|error|crash|doesn't work|not working)\b/)) {
35
+ return "code-fix";
36
+ }
37
+ if (text.match(/\b(add|implement|create|new|feature|support)\b/)) {
38
+ return "feature";
39
+ }
40
+ if (text.match(/\b(refactor|restructure|clean up|reorganize|simplify)\b/)) {
41
+ return "refactor";
42
+ }
43
+ return "unknown";
44
+ }
45
+ //# sourceMappingURL=classifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"classifier.js","sourceRoot":"","sources":["../../../src/orchestrator/classifier.ts"],"names":[],"mappings":"AAEA,6EAA6E;AAC7E,MAAM,UAAU,iBAAiB,CAAC,KAAY;IAC5C,MAAM,IAAI,GAAG,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC1D,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAExD,qBAAqB;IACrB,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/E,OAAO,UAAU,CAAC;IACpB,CAAC;IACD,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,aAAa,EAAE,SAAS,EAAE,iBAAiB,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAClF,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9D,OAAO,eAAe,CAAC;IACzB,CAAC;IACD,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,eAAe,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9E,OAAO,eAAe,CAAC;IACzB,CAAC;IACD,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,UAAU,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACnF,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,UAAU,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACzE,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,+BAA+B;IAC/B,IAAI,IAAI,CAAC,KAAK,CAAC,gEAAgE,CAAC,EAAE,CAAC;QACjF,OAAO,eAAe,CAAC;IACzB,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,CAAC,0CAA0C,CAAC,EAAE,CAAC;QAC3D,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,CAAC,6CAA6C,CAAC,EAAE,CAAC;QAC9D,OAAO,eAAe,CAAC;IACzB,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,CAAC,2DAA2D,CAAC,EAAE,CAAC;QAC5E,OAAO,UAAU,CAAC;IACpB,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,CAAC,gDAAgD,CAAC,EAAE,CAAC;QACjE,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,CAAC,yDAAyD,CAAC,EAAE,CAAC;QAC1E,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { AIEngine } from "../engine/types.js";
2
+ import type { GitHubClient } from "../github/client.js";
3
+ import type { DispatchConfig } from "../utils/config.js";
4
+ import { type RunSummary } from "../reporter/summary.js";
5
+ export interface PipelineOptions {
6
+ config: DispatchConfig;
7
+ engine: AIEngine;
8
+ github: GitHubClient;
9
+ cwd: string;
10
+ dryRun?: boolean;
11
+ }
12
+ export declare function runPipeline(options: PipelineOptions): Promise<RunSummary>;
13
+ //# sourceMappingURL=pipeline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.d.ts","sourceRoot":"","sources":["../../../src/orchestrator/pipeline.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAsB,MAAM,oBAAoB,CAAC;AACvE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAQzD,OAAO,EAAe,KAAK,UAAU,EAAqB,MAAM,wBAAwB,CAAC;AAMzF,MAAM,WAAW,eAAe;IAC9B,MAAM,EAAE,cAAc,CAAC;IACvB,MAAM,EAAE,QAAQ,CAAC;IACjB,MAAM,EAAE,YAAY,CAAC;IACrB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,wBAAsB,WAAW,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,UAAU,CAAC,CAiP/E"}
@@ -0,0 +1,246 @@
1
+ import chalk from "chalk";
2
+ import ora from "ora";
3
+ import { fetchAndHydrateIssues, prioritizeIssues, slugifyTitle } from "../github/issues.js";
4
+ import { createPRForIssue } from "../github/pulls.js";
5
+ import { commitAndPush, getDiffSummary, } from "../utils/git.js";
6
+ import { log, initFileLogging, getLogDir } from "../utils/logger.js";
7
+ import { saveSummary } from "../reporter/summary.js";
8
+ import { heuristicClassify } from "../orchestrator/classifier.js";
9
+ import { adjustConfidence } from "../orchestrator/scorer.js";
10
+ import { Semaphore } from "../utils/semaphore.js";
11
+ import { createWorktree, removeWorktree, getWorktreePath, cleanupAllWorktrees } from "../utils/worktree.js";
12
+ export async function runPipeline(options) {
13
+ const { config, engine, github, cwd, dryRun = false } = options;
14
+ const startTime = Date.now();
15
+ // Initialize file-based logging
16
+ await initFileLogging(config.stateDir, cwd);
17
+ log.header("Dispatch — Solving Issues");
18
+ if (dryRun) {
19
+ log.warn("DRY RUN — no branches, commits, or PRs will be created\n");
20
+ }
21
+ // 1. Fetch and prioritize issues
22
+ const allIssues = await fetchAndHydrateIssues(github, {
23
+ labels: config.labels,
24
+ excludeLabels: config.exclude,
25
+ maxIssues: config.maxIssues,
26
+ });
27
+ if (allIssues.length === 0) {
28
+ log.info("No issues to process. All done! 🎉");
29
+ return {
30
+ startedAt: new Date(startTime).toISOString(),
31
+ duration: Date.now() - startTime,
32
+ issues: [],
33
+ totalAttempted: 0,
34
+ totalSolved: 0,
35
+ totalFailed: 0,
36
+ prsCreated: [],
37
+ };
38
+ }
39
+ // 2. Classify issues — heuristic first, AI only for "unknown"
40
+ {
41
+ const spinner = ora("Classifying issues...").start();
42
+ for (const issue of allIssues) {
43
+ issue.classification = heuristicClassify(issue);
44
+ }
45
+ if (!dryRun) {
46
+ // Only invoke AI for issues the heuristic couldn't classify
47
+ const unknowns = allIssues.filter((i) => i.classification === "unknown");
48
+ if (unknowns.length > 0) {
49
+ spinner.text = `Classifying ${unknowns.length} ambiguous issue(s) with AI...`;
50
+ await Promise.all(unknowns.map(async (issue) => {
51
+ try {
52
+ issue.classification = await engine.classifyIssue(issue);
53
+ }
54
+ catch {
55
+ // leave as "unknown" — pipeline will still process it
56
+ }
57
+ }));
58
+ }
59
+ }
60
+ spinner.stop();
61
+ }
62
+ // 3. Prioritize
63
+ const issues = prioritizeIssues(allIssues);
64
+ log.info(`Processing ${issues.length} issues:\n`);
65
+ for (const issue of issues) {
66
+ log.issue(issue.number, issue.title, "pending");
67
+ console.log(chalk.gray(` Type: ${issue.classification} | Priority: ${issue.labels.join(", ") || "none"}`));
68
+ }
69
+ console.log();
70
+ if (dryRun) {
71
+ log.info("Dry run complete — would process the issues above.");
72
+ return {
73
+ startedAt: new Date(startTime).toISOString(),
74
+ duration: Date.now() - startTime,
75
+ issues: issues.map((i) => ({
76
+ number: i.number,
77
+ title: i.title,
78
+ classification: i.classification || "unknown",
79
+ status: "skipped",
80
+ })),
81
+ totalAttempted: 0,
82
+ totalSolved: 0,
83
+ totalFailed: 0,
84
+ prsCreated: [],
85
+ };
86
+ }
87
+ // 4. Process issues in parallel with concurrency control
88
+ const issueSummaries = [];
89
+ const prsCreated = [];
90
+ const semaphore = new Semaphore(config.concurrency);
91
+ // Clean up any leftover worktrees from a previous crashed run
92
+ await cleanupAllWorktrees(cwd, config.stateDir);
93
+ const processIssue = async (issue) => {
94
+ await semaphore.acquire();
95
+ const branchName = `${config.branchPrefix}issue-${issue.number}-${slugifyTitle(issue.title)}`;
96
+ const worktreePath = getWorktreePath(cwd, config.stateDir, issue.number);
97
+ let issueStatus = "failed";
98
+ try {
99
+ log.info(`[#${issue.number}] ${issue.title} (${issue.classification || "unknown"})`);
100
+ log.info(`[#${issue.number}] Creating worktree: ${chalk.cyan(branchName)}`);
101
+ await createWorktree(worktreePath, branchName, config.baseBranch, cwd);
102
+ // Solve the issue
103
+ const isInvestigation = ["investigation", "audit", "documentation"].includes(issue.classification || "");
104
+ const solveStart = Date.now();
105
+ log.info(`[#${issue.number}] Solving...`);
106
+ const progressInterval = setInterval(() => {
107
+ const secs = Math.round((Date.now() - solveStart) / 1000);
108
+ log.info(`[#${issue.number}] Still solving... (${secs}s)`);
109
+ }, 30_000);
110
+ let result;
111
+ try {
112
+ const logDir = getLogDir();
113
+ const issueLogFile = logDir ? `${logDir}/issue-${issue.number}.log` : undefined;
114
+ const context = {
115
+ owner: github.owner,
116
+ repo: github.repo,
117
+ baseBranch: config.baseBranch,
118
+ cwd: worktreePath,
119
+ timeout: config.timeoutPerIssue,
120
+ issueLogFile,
121
+ };
122
+ if (isInvestigation) {
123
+ result = await engine.investigate(issue, context);
124
+ }
125
+ else {
126
+ result = await engine.solve(issue, context);
127
+ }
128
+ const elapsed = Math.round((Date.now() - solveStart) / 1000);
129
+ log.success(`[#${issue.number}] Solved in ${elapsed}s (confidence: ${result.confidence}/10)`);
130
+ }
131
+ catch (solveErr) {
132
+ log.error(`[#${issue.number}] Solving failed`);
133
+ throw solveErr;
134
+ }
135
+ finally {
136
+ clearInterval(progressInterval);
137
+ }
138
+ // Adjust confidence with heuristics
139
+ result = adjustConfidence(result);
140
+ // Commit and push (operates within the worktree directory)
141
+ const { hasChanges } = await commitAndPush(branchName, result.commitMessage, worktreePath);
142
+ if (!hasChanges) {
143
+ log.warn(`[#${issue.number}] No changes produced`);
144
+ issueStatus = "no-changes";
145
+ issueSummaries.push({
146
+ number: issue.number,
147
+ title: issue.title,
148
+ classification: issue.classification || "unknown",
149
+ status: "no-changes",
150
+ });
151
+ return;
152
+ }
153
+ // Get diff summary (from within the worktree)
154
+ const diffSummary = await getDiffSummary(config.baseBranch, worktreePath);
155
+ // Create PR
156
+ const shouldDraft = config.createDraftPRs || result.confidence < config.draftThreshold;
157
+ const pr = await createPRForIssue(github, issue, result, {
158
+ branchName,
159
+ baseBranch: config.baseBranch,
160
+ diffSummary,
161
+ draft: shouldDraft,
162
+ });
163
+ prsCreated.push({ ...pr, issueNumber: issue.number });
164
+ if (config.autoLabel && issue.classification) {
165
+ await github.addLabel(issue.number, `dispatch:${issue.classification}`);
166
+ }
167
+ issueStatus = "solved";
168
+ issueSummaries.push({
169
+ number: issue.number,
170
+ title: issue.title,
171
+ classification: issue.classification || "unknown",
172
+ status: "solved",
173
+ confidence: result.confidence,
174
+ prNumber: pr.number,
175
+ prUrl: pr.url,
176
+ summary: result.summary,
177
+ });
178
+ log.success(`[#${issue.number}] PR #${pr.number} created (confidence: ${result.confidence}/10)`);
179
+ }
180
+ catch (err) {
181
+ const errorMsg = err instanceof Error ? err.message : String(err);
182
+ log.error(`[#${issue.number}] Failed: ${errorMsg}`);
183
+ issueSummaries.push({
184
+ number: issue.number,
185
+ title: issue.title,
186
+ classification: issue.classification || "unknown",
187
+ status: "failed",
188
+ error: errorMsg,
189
+ });
190
+ }
191
+ finally {
192
+ // Always clean up the worktree
193
+ try {
194
+ await removeWorktree(worktreePath, cwd, {
195
+ deleteBranch: issueStatus !== "solved" ? branchName : undefined,
196
+ });
197
+ }
198
+ catch {
199
+ log.debug(`[#${issue.number}] Worktree cleanup failed (non-fatal)`);
200
+ }
201
+ semaphore.release();
202
+ }
203
+ };
204
+ await Promise.all(issues.map(processIssue));
205
+ // 5. Generate summary
206
+ const summary = {
207
+ startedAt: new Date(startTime).toISOString(),
208
+ duration: Date.now() - startTime,
209
+ issues: issueSummaries,
210
+ totalAttempted: issueSummaries.filter((i) => i.status !== "skipped").length,
211
+ totalSolved: issueSummaries.filter((i) => i.status === "solved").length,
212
+ totalFailed: issueSummaries.filter((i) => i.status === "failed").length,
213
+ prsCreated,
214
+ };
215
+ await saveSummary(summary, cwd, config.stateDir);
216
+ printSummary(summary);
217
+ return summary;
218
+ }
219
+ function printSummary(summary) {
220
+ log.header("Run Complete");
221
+ const duration = Math.round(summary.duration / 1000 / 60);
222
+ console.log(chalk.gray(` Duration: ${duration} minutes`));
223
+ console.log(` ${chalk.green(`✓ ${summary.totalSolved} solved`)} ` +
224
+ `${chalk.red(`✗ ${summary.totalFailed} failed`)} ` +
225
+ `${chalk.gray(`${summary.issues.length} total`)}`);
226
+ console.log();
227
+ if (summary.prsCreated.length > 0) {
228
+ console.log(chalk.bold(" Pull Requests:"));
229
+ for (const pr of summary.prsCreated) {
230
+ console.log(` ${chalk.green("→")} PR #${pr.number} (issue #${pr.issueNumber}): ${pr.url}`);
231
+ }
232
+ console.log();
233
+ }
234
+ const failed = summary.issues.filter((i) => i.status === "failed");
235
+ if (failed.length > 0) {
236
+ console.log(chalk.bold(" Failed Issues:"));
237
+ for (const issue of failed) {
238
+ console.log(` ${chalk.red("✗")} #${issue.number}: ${issue.title}`);
239
+ if (issue.error) {
240
+ console.log(chalk.gray(` ${issue.error}`));
241
+ }
242
+ }
243
+ console.log();
244
+ }
245
+ }
246
+ //# sourceMappingURL=pipeline.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.js","sourceRoot":"","sources":["../../../src/orchestrator/pipeline.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { Issue, IssueClassification } from "../engine/types.js";
2
+ /** Strategy hints for the AI engine based on issue type */
3
+ export interface SolveStrategy {
4
+ classification: IssueClassification;
5
+ /** Suggested approach steps */
6
+ steps: string[];
7
+ /** Tools the AI should prioritize */
8
+ preferredTools: string[];
9
+ /** Expected output type */
10
+ expectedOutput: "code-changes" | "document" | "mixed";
11
+ }
12
+ export declare function planStrategy(issue: Issue): SolveStrategy;
13
+ //# sourceMappingURL=planner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"planner.d.ts","sourceRoot":"","sources":["../../../src/orchestrator/planner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAErE,2DAA2D;AAC3D,MAAM,WAAW,aAAa;IAC5B,cAAc,EAAE,mBAAmB,CAAC;IACpC,+BAA+B;IAC/B,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,qCAAqC;IACrC,cAAc,EAAE,MAAM,EAAE,CAAC;IACzB,2BAA2B;IAC3B,cAAc,EAAE,cAAc,GAAG,UAAU,GAAG,OAAO,CAAC;CACvD;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,KAAK,GAAG,aAAa,CAoGxD"}