@posthog/agent 1.21.0 → 1.24.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 (119) hide show
  1. package/CLAUDE.md +3 -3
  2. package/README.md +3 -3
  3. package/dist/claude-cli/cli.js +1396 -1347
  4. package/dist/index.d.ts +11 -11
  5. package/dist/index.d.ts.map +1 -1
  6. package/dist/index.js +3 -3
  7. package/dist/src/adapters/claude/claude-adapter.d.ts +3 -3
  8. package/dist/src/adapters/claude/claude-adapter.d.ts.map +1 -1
  9. package/dist/src/adapters/claude/claude-adapter.js +156 -111
  10. package/dist/src/adapters/claude/claude-adapter.js.map +1 -1
  11. package/dist/src/adapters/claude/tool-mapper.d.ts +1 -1
  12. package/dist/src/adapters/claude/tool-mapper.d.ts.map +1 -1
  13. package/dist/src/adapters/claude/tool-mapper.js.map +1 -1
  14. package/dist/src/adapters/types.d.ts +1 -1
  15. package/dist/src/adapters/types.d.ts.map +1 -1
  16. package/dist/src/agent.d.ts +7 -7
  17. package/dist/src/agent.d.ts.map +1 -1
  18. package/dist/src/agent.js +143 -85
  19. package/dist/src/agent.js.map +1 -1
  20. package/dist/src/agents/execution.js.map +1 -1
  21. package/dist/src/agents/planning.js.map +1 -1
  22. package/dist/src/agents/research.js.map +1 -1
  23. package/dist/src/file-manager.d.ts +4 -4
  24. package/dist/src/file-manager.d.ts.map +1 -1
  25. package/dist/src/file-manager.js +59 -58
  26. package/dist/src/file-manager.js.map +1 -1
  27. package/dist/src/git-manager.d.ts +2 -1
  28. package/dist/src/git-manager.d.ts.map +1 -1
  29. package/dist/src/git-manager.js +99 -68
  30. package/dist/src/git-manager.js.map +1 -1
  31. package/dist/src/posthog-api.d.ts +2 -3
  32. package/dist/src/posthog-api.d.ts.map +1 -1
  33. package/dist/src/posthog-api.js +22 -22
  34. package/dist/src/posthog-api.js.map +1 -1
  35. package/dist/src/prompt-builder.d.ts +3 -3
  36. package/dist/src/prompt-builder.d.ts.map +1 -1
  37. package/dist/src/prompt-builder.js +123 -93
  38. package/dist/src/prompt-builder.js.map +1 -1
  39. package/dist/src/task-manager.d.ts +4 -4
  40. package/dist/src/task-manager.d.ts.map +1 -1
  41. package/dist/src/task-manager.js +19 -18
  42. package/dist/src/task-manager.js.map +1 -1
  43. package/dist/src/task-progress-reporter.d.ts +3 -4
  44. package/dist/src/task-progress-reporter.d.ts.map +1 -1
  45. package/dist/src/task-progress-reporter.js +69 -53
  46. package/dist/src/task-progress-reporter.js.map +1 -1
  47. package/dist/src/template-manager.d.ts +1 -1
  48. package/dist/src/template-manager.d.ts.map +1 -1
  49. package/dist/src/template-manager.js +30 -28
  50. package/dist/src/template-manager.js.map +1 -1
  51. package/dist/src/todo-manager.d.ts +3 -3
  52. package/dist/src/todo-manager.d.ts.map +1 -1
  53. package/dist/src/todo-manager.js +29 -24
  54. package/dist/src/todo-manager.js.map +1 -1
  55. package/dist/src/tools/registry.d.ts +1 -1
  56. package/dist/src/tools/registry.js +60 -60
  57. package/dist/src/tools/registry.js.map +1 -1
  58. package/dist/src/tools/types.d.ts +31 -31
  59. package/dist/src/types.d.ts +33 -33
  60. package/dist/src/types.d.ts.map +1 -1
  61. package/dist/src/types.js.map +1 -1
  62. package/dist/src/utils/logger.d.ts +4 -4
  63. package/dist/src/utils/logger.d.ts.map +1 -1
  64. package/dist/src/utils/logger.js +8 -8
  65. package/dist/src/utils/logger.js.map +1 -1
  66. package/dist/src/workflow/config.d.ts +1 -1
  67. package/dist/src/workflow/config.d.ts.map +1 -1
  68. package/dist/src/workflow/config.js +18 -18
  69. package/dist/src/workflow/config.js.map +1 -1
  70. package/dist/src/workflow/steps/build.d.ts +1 -1
  71. package/dist/src/workflow/steps/build.d.ts.map +1 -1
  72. package/dist/src/workflow/steps/build.js +46 -38
  73. package/dist/src/workflow/steps/build.js.map +1 -1
  74. package/dist/src/workflow/steps/finalize.d.ts +1 -1
  75. package/dist/src/workflow/steps/finalize.d.ts.map +1 -1
  76. package/dist/src/workflow/steps/finalize.js +62 -47
  77. package/dist/src/workflow/steps/finalize.js.map +1 -1
  78. package/dist/src/workflow/steps/plan.d.ts +1 -1
  79. package/dist/src/workflow/steps/plan.d.ts.map +1 -1
  80. package/dist/src/workflow/steps/plan.js +58 -46
  81. package/dist/src/workflow/steps/plan.js.map +1 -1
  82. package/dist/src/workflow/steps/research.d.ts +1 -1
  83. package/dist/src/workflow/steps/research.d.ts.map +1 -1
  84. package/dist/src/workflow/steps/research.js +68 -56
  85. package/dist/src/workflow/steps/research.js.map +1 -1
  86. package/dist/src/workflow/types.d.ts +12 -12
  87. package/dist/src/workflow/types.d.ts.map +1 -1
  88. package/dist/src/workflow/utils.d.ts +1 -1
  89. package/dist/src/workflow/utils.d.ts.map +1 -1
  90. package/dist/src/workflow/utils.js +7 -4
  91. package/dist/src/workflow/utils.js.map +1 -1
  92. package/package.json +9 -9
  93. package/src/adapters/claude/claude-adapter.ts +220 -168
  94. package/src/adapters/claude/tool-mapper.ts +2 -2
  95. package/src/adapters/types.ts +1 -1
  96. package/src/agent.ts +579 -444
  97. package/src/agents/execution.ts +1 -1
  98. package/src/agents/planning.ts +1 -1
  99. package/src/agents/research.ts +0 -1
  100. package/src/file-manager.ts +64 -63
  101. package/src/git-manager.ts +159 -86
  102. package/src/posthog-api.ts +122 -82
  103. package/src/prompt-builder.ts +180 -135
  104. package/src/task-manager.ts +38 -30
  105. package/src/task-progress-reporter.ts +80 -58
  106. package/src/template-manager.ts +98 -45
  107. package/src/todo-manager.ts +35 -30
  108. package/src/tools/registry.ts +62 -62
  109. package/src/tools/types.ts +36 -36
  110. package/src/types.ts +93 -71
  111. package/src/utils/logger.ts +62 -56
  112. package/src/workflow/config.ts +48 -48
  113. package/src/workflow/steps/build.ts +122 -113
  114. package/src/workflow/steps/finalize.ts +218 -177
  115. package/src/workflow/steps/plan.ts +151 -131
  116. package/src/workflow/steps/research.ts +205 -186
  117. package/src/workflow/types.ts +38 -36
  118. package/src/workflow/utils.ts +37 -34
  119. package/LICENSE +0 -33
@@ -1,15 +1,15 @@
1
- import { randomBytes } from 'crypto';
1
+ import { randomBytes } from 'node:crypto';
2
2
 
3
3
  class TaskManager {
4
4
  executionStates = new Map();
5
5
  defaultTimeout = 10 * 60 * 1000; // 10 minutes
6
6
  generateExecutionId() {
7
- return randomBytes(16).toString('hex');
7
+ return randomBytes(16).toString("hex");
8
8
  }
9
9
  startExecution(taskId, mode, executionId = this.generateExecutionId()) {
10
10
  const executionState = {
11
11
  taskId,
12
- status: 'running',
12
+ status: "running",
13
13
  mode,
14
14
  startedAt: Date.now(),
15
15
  abortController: new AbortController(),
@@ -23,7 +23,7 @@ class TaskManager {
23
23
  if (!execution) {
24
24
  throw new Error(`Execution ${executionId} not found`);
25
25
  }
26
- if (execution.result && execution.status === 'completed') {
26
+ if (execution.result && execution.status === "completed") {
27
27
  return execution.result;
28
28
  }
29
29
  return new Promise((resolve, reject) => {
@@ -34,13 +34,14 @@ class TaskManager {
34
34
  reject(new Error(`Execution ${executionId} disappeared`));
35
35
  return;
36
36
  }
37
- if (currentExecution.status === 'completed' && currentExecution.result) {
37
+ if (currentExecution.status === "completed" &&
38
+ currentExecution.result) {
38
39
  clearInterval(checkInterval);
39
40
  resolve(currentExecution.result);
40
41
  }
41
- else if (currentExecution.status === 'failed' ||
42
- currentExecution.status === 'canceled' ||
43
- currentExecution.status === 'timeout') {
42
+ else if (currentExecution.status === "failed" ||
43
+ currentExecution.status === "canceled" ||
44
+ currentExecution.status === "timeout") {
44
45
  clearInterval(checkInterval);
45
46
  reject(new Error(`Execution ${executionId} ${currentExecution.status}`));
46
47
  }
@@ -52,7 +53,7 @@ class TaskManager {
52
53
  if (!execution) {
53
54
  throw new Error(`Execution ${executionId} not found`);
54
55
  }
55
- execution.status = 'completed';
56
+ execution.status = "completed";
56
57
  execution.result = result;
57
58
  execution.completedAt = Date.now();
58
59
  }
@@ -61,11 +62,11 @@ class TaskManager {
61
62
  if (!execution) {
62
63
  throw new Error(`Execution ${executionId} not found`);
63
64
  }
64
- execution.status = 'failed';
65
+ execution.status = "failed";
65
66
  execution.completedAt = Date.now();
66
67
  execution.result = {
67
68
  error: error.message,
68
- status: 'failed',
69
+ status: "failed",
69
70
  };
70
71
  }
71
72
  cancelExecution(executionId) {
@@ -73,13 +74,13 @@ class TaskManager {
73
74
  if (!execution) {
74
75
  throw new Error(`Execution ${executionId} not found`);
75
76
  }
76
- execution.status = 'canceled';
77
+ execution.status = "canceled";
77
78
  execution.completedAt = Date.now();
78
79
  execution.abortController?.abort();
79
80
  if (!execution.result) {
80
81
  execution.result = {
81
- status: 'canceled',
82
- message: 'Execution was canceled',
82
+ status: "canceled",
83
+ message: "Execution was canceled",
83
84
  };
84
85
  }
85
86
  }
@@ -95,14 +96,14 @@ class TaskManager {
95
96
  scheduleTimeout(executionId, timeout = this.defaultTimeout) {
96
97
  setTimeout(() => {
97
98
  const execution = this.executionStates.get(executionId);
98
- if (execution && execution.status === 'running') {
99
- execution.status = 'timeout';
99
+ if (execution && execution.status === "running") {
100
+ execution.status = "timeout";
100
101
  execution.completedAt = Date.now();
101
102
  execution.abortController?.abort();
102
103
  if (!execution.result) {
103
104
  execution.result = {
104
- status: 'timeout',
105
- message: 'Execution timed out',
105
+ status: "timeout",
106
+ message: "Execution timed out",
106
107
  };
107
108
  }
108
109
  }
@@ -1 +1 @@
1
- {"version":3,"file":"task-manager.js","sources":["../../src/task-manager.ts"],"sourcesContent":["import { randomBytes } from 'crypto';\n\nexport interface TaskExecutionState {\n taskId: string;\n status: 'running' | 'completed' | 'failed' | 'canceled' | 'timeout';\n mode: 'plan_only' | 'plan_and_build' | 'build_only';\n result?: any;\n startedAt: number;\n completedAt?: number;\n abortController?: AbortController;\n}\n\nexport class TaskManager {\n private executionStates = new Map<string, TaskExecutionState>();\n private defaultTimeout = 10 * 60 * 1000; // 10 minutes\n\n generateExecutionId(): string {\n return randomBytes(16).toString('hex');\n }\n\n startExecution(\n taskId: string, \n mode: 'plan_only' | 'plan_and_build' | 'build_only',\n executionId: string = this.generateExecutionId()\n ): TaskExecutionState {\n const executionState: TaskExecutionState = {\n taskId,\n status: 'running',\n mode,\n startedAt: Date.now(),\n abortController: new AbortController(),\n };\n\n this.executionStates.set(executionId, executionState);\n this.scheduleTimeout(executionId);\n \n return executionState;\n }\n\n async waitForCompletion(executionId: string): Promise<any> {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n if (execution.result && execution.status === 'completed') {\n return execution.result;\n }\n\n return new Promise((resolve, reject) => {\n const checkInterval = setInterval(() => {\n const currentExecution = this.executionStates.get(executionId);\n if (!currentExecution) {\n clearInterval(checkInterval);\n reject(new Error(`Execution ${executionId} disappeared`));\n return;\n }\n\n if (currentExecution.status === 'completed' && currentExecution.result) {\n clearInterval(checkInterval);\n resolve(currentExecution.result);\n } else if (\n currentExecution.status === 'failed' || \n currentExecution.status === 'canceled' || \n currentExecution.status === 'timeout'\n ) {\n clearInterval(checkInterval);\n reject(new Error(`Execution ${executionId} ${currentExecution.status}`));\n }\n }, 100);\n });\n }\n\n completeExecution(executionId: string, result: any): void {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n execution.status = 'completed';\n execution.result = result;\n execution.completedAt = Date.now();\n }\n\n failExecution(executionId: string, error: Error): void {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n execution.status = 'failed';\n execution.completedAt = Date.now();\n execution.result = {\n error: error.message,\n status: 'failed',\n };\n }\n\n cancelExecution(executionId: string): void {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n execution.status = 'canceled';\n execution.completedAt = Date.now();\n execution.abortController?.abort();\n \n if (!execution.result) {\n execution.result = {\n status: 'canceled',\n message: 'Execution was canceled',\n };\n }\n }\n\n getExecution(executionId: string): TaskExecutionState | undefined {\n return this.executionStates.get(executionId);\n }\n\n getAbortSignal(executionId: string): AbortSignal | undefined {\n return this.executionStates.get(executionId)?.abortController?.signal;\n }\n\n getAbortController(executionId: string): AbortController | undefined {\n return this.executionStates.get(executionId)?.abortController;\n }\n\n private scheduleTimeout(executionId: string, timeout: number = this.defaultTimeout): void {\n setTimeout(() => {\n const execution = this.executionStates.get(executionId);\n if (execution && execution.status === 'running') {\n execution.status = 'timeout';\n execution.completedAt = Date.now();\n execution.abortController?.abort();\n \n if (!execution.result) {\n execution.result = {\n status: 'timeout',\n message: 'Execution timed out',\n };\n }\n }\n }, timeout);\n }\n\n cleanup(olderThan: number = 60 * 60 * 1000): void {\n const cutoff = Date.now() - olderThan;\n for (const [executionId, execution] of this.executionStates) {\n if (execution.completedAt && execution.completedAt < cutoff) {\n this.executionStates.delete(executionId);\n }\n }\n }\n}"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"task-manager.js","sources":["../../src/task-manager.ts"],"sourcesContent":["import { randomBytes } from \"node:crypto\";\n\nexport interface TaskExecutionState {\n taskId: string;\n status: \"running\" | \"completed\" | \"failed\" | \"canceled\" | \"timeout\";\n mode: \"plan_only\" | \"plan_and_build\" | \"build_only\";\n result?: any;\n startedAt: number;\n completedAt?: number;\n abortController?: AbortController;\n}\n\nexport class TaskManager {\n public executionStates = new Map<string, TaskExecutionState>();\n private defaultTimeout = 10 * 60 * 1000; // 10 minutes\n\n generateExecutionId(): string {\n return randomBytes(16).toString(\"hex\");\n }\n\n startExecution(\n taskId: string,\n mode: \"plan_only\" | \"plan_and_build\" | \"build_only\",\n executionId: string = this.generateExecutionId(),\n ): TaskExecutionState {\n const executionState: TaskExecutionState = {\n taskId,\n status: \"running\",\n mode,\n startedAt: Date.now(),\n abortController: new AbortController(),\n };\n\n this.executionStates.set(executionId, executionState);\n this.scheduleTimeout(executionId);\n\n return executionState;\n }\n\n async waitForCompletion(executionId: string): Promise<any> {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n if (execution.result && execution.status === \"completed\") {\n return execution.result;\n }\n\n return new Promise((resolve, reject) => {\n const checkInterval = setInterval(() => {\n const currentExecution = this.executionStates.get(executionId);\n if (!currentExecution) {\n clearInterval(checkInterval);\n reject(new Error(`Execution ${executionId} disappeared`));\n return;\n }\n\n if (\n currentExecution.status === \"completed\" &&\n currentExecution.result\n ) {\n clearInterval(checkInterval);\n resolve(currentExecution.result);\n } else if (\n currentExecution.status === \"failed\" ||\n currentExecution.status === \"canceled\" ||\n currentExecution.status === \"timeout\"\n ) {\n clearInterval(checkInterval);\n reject(\n new Error(`Execution ${executionId} ${currentExecution.status}`),\n );\n }\n }, 100);\n });\n }\n\n completeExecution(executionId: string, result: any): void {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n execution.status = \"completed\";\n execution.result = result;\n execution.completedAt = Date.now();\n }\n\n failExecution(executionId: string, error: Error): void {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n execution.status = \"failed\";\n execution.completedAt = Date.now();\n execution.result = {\n error: error.message,\n status: \"failed\",\n };\n }\n\n cancelExecution(executionId: string): void {\n const execution = this.executionStates.get(executionId);\n if (!execution) {\n throw new Error(`Execution ${executionId} not found`);\n }\n\n execution.status = \"canceled\";\n execution.completedAt = Date.now();\n execution.abortController?.abort();\n\n if (!execution.result) {\n execution.result = {\n status: \"canceled\",\n message: \"Execution was canceled\",\n };\n }\n }\n\n getExecution(executionId: string): TaskExecutionState | undefined {\n return this.executionStates.get(executionId);\n }\n\n getAbortSignal(executionId: string): AbortSignal | undefined {\n return this.executionStates.get(executionId)?.abortController?.signal;\n }\n\n getAbortController(executionId: string): AbortController | undefined {\n return this.executionStates.get(executionId)?.abortController;\n }\n\n private scheduleTimeout(\n executionId: string,\n timeout: number = this.defaultTimeout,\n ): void {\n setTimeout(() => {\n const execution = this.executionStates.get(executionId);\n if (execution && execution.status === \"running\") {\n execution.status = \"timeout\";\n execution.completedAt = Date.now();\n execution.abortController?.abort();\n\n if (!execution.result) {\n execution.result = {\n status: \"timeout\",\n message: \"Execution timed out\",\n };\n }\n }\n }, timeout);\n }\n\n cleanup(olderThan: number = 60 * 60 * 1000): void {\n const cutoff = Date.now() - olderThan;\n for (const [executionId, execution] of this.executionStates) {\n if (execution.completedAt && execution.completedAt < cutoff) {\n this.executionStates.delete(executionId);\n }\n }\n }\n}\n"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import type { Logger } from './utils/logger.js';
2
- import type { PostHogAPIClient } from './posthog-api.js';
3
- import type { AgentEvent } from './types.js';
1
+ import type { PostHogAPIClient } from "./posthog-api.js";
2
+ import type { AgentEvent } from "./types.js";
3
+ import type { Logger } from "./utils/logger.js";
4
4
  interface ProgressMetadata {
5
5
  totalSteps?: number;
6
6
  }
@@ -15,7 +15,6 @@ export declare class TaskProgressReporter {
15
15
  private logger;
16
16
  private taskRun?;
17
17
  private taskId?;
18
- private outputLog;
19
18
  private totalSteps?;
20
19
  private lastLogEntry?;
21
20
  private tokenBuffer;
@@ -1 +1 @@
1
- {"version":3,"file":"task-progress-reporter.d.ts","sourceRoot":"","sources":["../../src/task-progress-reporter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,KAAK,EAAE,gBAAgB,EAAiB,MAAM,kBAAkB,CAAC;AACxE,OAAO,KAAK,EAAE,UAAU,EAAqB,MAAM,YAAY,CAAC;AAEhE,UAAU,gBAAgB;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;;;;GAKG;AACH,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,UAAU,CAAC,CAAmB;IACtC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAC,CAAU;IAC1B,OAAO,CAAC,MAAM,CAAC,CAAS;IACxB,OAAO,CAAC,SAAS,CAAgB;IACjC,OAAO,CAAC,UAAU,CAAC,CAAS;IAC5B,OAAO,CAAC,YAAY,CAAC,CAAS;IAC9B,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,eAAe,CAAC,CAAiB;IACzC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAO;IACxC,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAAQ;IAChD,OAAO,CAAC,aAAa,CAAoC;IACzD,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAK;IAC5C,OAAO,CAAC,QAAQ,CAAC,8BAA8B,CAAO;gBAE1C,UAAU,EAAE,gBAAgB,GAAG,SAAS,EAAE,MAAM,EAAE,MAAM;IAKpE,IAAI,KAAK,IAAI,MAAM,GAAG,SAAS,CAE9B;IAEK,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,GAAE,gBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;IAoBrE,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IASzB,IAAI,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK1C,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAI9B,WAAW;IAezB,OAAO,CAAC,kBAAkB;IAa1B,OAAO,CAAC,cAAc;YAsBR,aAAa;IAiCrB,WAAW,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;YA0OrC,MAAM;CAoCrB"}
1
+ {"version":3,"file":"task-progress-reporter.d.ts","sourceRoot":"","sources":["../../src/task-progress-reporter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAiB,MAAM,kBAAkB,CAAC;AACxE,OAAO,KAAK,EAAE,UAAU,EAAqB,MAAM,YAAY,CAAC;AAChE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,UAAU,gBAAgB;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;;;;GAKG;AACH,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,UAAU,CAAC,CAAmB;IACtC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAC,CAAU;IAC1B,OAAO,CAAC,MAAM,CAAC,CAAS;IACxB,OAAO,CAAC,UAAU,CAAC,CAAS;IAC5B,OAAO,CAAC,YAAY,CAAC,CAAS;IAC9B,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,eAAe,CAAC,CAAiB;IACzC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAO;IACxC,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAAQ;IAChD,OAAO,CAAC,aAAa,CAAoC;IACzD,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAK;IAC5C,OAAO,CAAC,QAAQ,CAAC,8BAA8B,CAAO;gBAE1C,UAAU,EAAE,gBAAgB,GAAG,SAAS,EAAE,MAAM,EAAE,MAAM;IAKpE,IAAI,KAAK,IAAI,MAAM,GAAG,SAAS,CAE9B;IAEK,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,GAAE,gBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;IAsBrE,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAiBzB,IAAI,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAgB1C,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAI9B,WAAW;IAezB,OAAO,CAAC,kBAAkB;IAa1B,OAAO,CAAC,cAAc;YAqBR,aAAa;IAiCrB,WAAW,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;YA0OrC,MAAM;CAuCrB"}
@@ -9,10 +9,9 @@ class TaskProgressReporter {
9
9
  logger;
10
10
  taskRun;
11
11
  taskId;
12
- outputLog = [];
13
12
  totalSteps;
14
13
  lastLogEntry;
15
- tokenBuffer = '';
14
+ tokenBuffer = "";
16
15
  tokenCount = 0;
17
16
  tokenFlushTimer;
18
17
  TOKEN_BATCH_SIZE = 100;
@@ -22,7 +21,7 @@ class TaskProgressReporter {
22
21
  LOG_APPEND_RETRY_BASE_DELAY_MS = 200;
23
22
  constructor(posthogAPI, logger) {
24
23
  this.posthogAPI = posthogAPI;
25
- this.logger = logger.child('TaskProgressReporter');
24
+ this.logger = logger.child("TaskProgressReporter");
26
25
  }
27
26
  get runId() {
28
27
  return this.taskRun?.id;
@@ -35,27 +34,45 @@ class TaskProgressReporter {
35
34
  this.totalSteps = metadata.totalSteps;
36
35
  try {
37
36
  const run = await this.posthogAPI.createTaskRun(taskId, {
38
- status: 'started',
37
+ status: "started",
39
38
  });
40
39
  this.taskRun = run;
41
- this.outputLog = [];
42
- this.logger.debug('Created task run', { taskId, runId: run.id });
40
+ this.logger.debug("Created task run", { taskId, runId: run.id });
43
41
  }
44
42
  catch (error) {
45
- this.logger.warn('Failed to create task run', { taskId, error: error.message });
43
+ this.logger.warn("Failed to create task run", {
44
+ taskId,
45
+ error: error.message,
46
+ });
46
47
  }
47
48
  }
48
49
  async complete() {
49
50
  await this.flushTokens(); // Flush any remaining tokens before completion
51
+ try {
52
+ await this.logWriteQueue;
53
+ }
54
+ catch (error) {
55
+ this.logger.debug("Pending logs failed to write during completion", {
56
+ error,
57
+ });
58
+ }
50
59
  if (this.tokenFlushTimer) {
51
60
  clearTimeout(this.tokenFlushTimer);
52
61
  this.tokenFlushTimer = undefined;
53
62
  }
54
- await this.update({ status: 'completed' }, 'Task execution completed');
63
+ await this.update({ status: "completed" }, "Task execution completed");
55
64
  }
56
65
  async fail(error) {
57
- const message = typeof error === 'string' ? error : error.message;
58
- await this.update({ status: 'failed', error_message: message }, `Task execution failed: ${message}`);
66
+ try {
67
+ await this.logWriteQueue;
68
+ }
69
+ catch (logError) {
70
+ this.logger.debug("Pending logs failed to write during fail", {
71
+ error: logError,
72
+ });
73
+ }
74
+ const message = typeof error === "string" ? error : error.message;
75
+ await this.update({ status: "failed", error_message: message }, `Task execution failed: ${message}`);
59
76
  }
60
77
  async appendLog(line) {
61
78
  await this.update({}, line);
@@ -65,10 +82,10 @@ class TaskProgressReporter {
65
82
  return;
66
83
  }
67
84
  const buffer = this.tokenBuffer;
68
- this.tokenBuffer = '';
85
+ this.tokenBuffer = "";
69
86
  this.tokenCount = 0;
70
87
  await this.appendLogEntry({
71
- type: 'token',
88
+ type: "token",
72
89
  message: buffer,
73
90
  });
74
91
  }
@@ -79,7 +96,7 @@ class TaskProgressReporter {
79
96
  this.tokenFlushTimer = setTimeout(() => {
80
97
  this.tokenFlushTimer = undefined;
81
98
  this.flushTokens().catch((err) => {
82
- this.logger.warn('Failed to flush tokens', { error: err });
99
+ this.logger.warn("Failed to flush tokens", { error: err });
83
100
  });
84
101
  }, this.TOKEN_FLUSH_INTERVAL_MS);
85
102
  }
@@ -91,8 +108,7 @@ class TaskProgressReporter {
91
108
  const runId = this.runId;
92
109
  this.logWriteQueue = this.logWriteQueue
93
110
  .catch((error) => {
94
- // Ensure previous failures don't block subsequent writes
95
- this.logger.debug('Previous log append failed', {
111
+ this.logger.debug("Previous log append failed", {
96
112
  taskId,
97
113
  runId,
98
114
  error: error instanceof Error ? error.message : String(error),
@@ -111,7 +127,7 @@ class TaskProgressReporter {
111
127
  return;
112
128
  }
113
129
  catch (error) {
114
- this.logger.warn('Failed to append log entry', {
130
+ this.logger.warn("Failed to append log entry", {
115
131
  taskId,
116
132
  runId,
117
133
  attempt,
@@ -121,7 +137,7 @@ class TaskProgressReporter {
121
137
  if (attempt === this.LOG_APPEND_MAX_RETRIES) {
122
138
  return;
123
139
  }
124
- const delayMs = this.LOG_APPEND_RETRY_BASE_DELAY_MS * Math.pow(2, attempt - 1);
140
+ const delayMs = this.LOG_APPEND_RETRY_BASE_DELAY_MS * 2 ** (attempt - 1);
125
141
  await new Promise((resolve) => setTimeout(resolve, delayMs));
126
142
  }
127
143
  }
@@ -131,7 +147,7 @@ class TaskProgressReporter {
131
147
  return;
132
148
  }
133
149
  switch (event.type) {
134
- case 'token': {
150
+ case "token": {
135
151
  // Batch tokens for efficiency
136
152
  this.tokenBuffer += event.content;
137
153
  this.tokenCount++;
@@ -147,9 +163,9 @@ class TaskProgressReporter {
147
163
  }
148
164
  return;
149
165
  }
150
- case 'content_block_start': {
166
+ case "content_block_start": {
151
167
  await this.appendLogEntry({
152
- type: 'content_block_start',
168
+ type: "content_block_start",
153
169
  message: JSON.stringify({
154
170
  index: event.index,
155
171
  contentType: event.contentType,
@@ -160,9 +176,9 @@ class TaskProgressReporter {
160
176
  });
161
177
  return;
162
178
  }
163
- case 'content_block_stop': {
179
+ case "content_block_stop": {
164
180
  await this.appendLogEntry({
165
- type: 'content_block_stop',
181
+ type: "content_block_stop",
166
182
  message: JSON.stringify({
167
183
  index: event.index,
168
184
  ts: event.ts,
@@ -170,9 +186,9 @@ class TaskProgressReporter {
170
186
  });
171
187
  return;
172
188
  }
173
- case 'message_start': {
189
+ case "message_start": {
174
190
  await this.appendLogEntry({
175
- type: 'message_start',
191
+ type: "message_start",
176
192
  message: JSON.stringify({
177
193
  messageId: event.messageId,
178
194
  model: event.model,
@@ -181,9 +197,9 @@ class TaskProgressReporter {
181
197
  });
182
198
  return;
183
199
  }
184
- case 'message_delta': {
200
+ case "message_delta": {
185
201
  await this.appendLogEntry({
186
- type: 'message_delta',
202
+ type: "message_delta",
187
203
  message: JSON.stringify({
188
204
  stopReason: event.stopReason,
189
205
  stopSequence: event.stopSequence,
@@ -193,16 +209,16 @@ class TaskProgressReporter {
193
209
  });
194
210
  return;
195
211
  }
196
- case 'message_stop': {
212
+ case "message_stop": {
197
213
  await this.appendLogEntry({
198
- type: 'message_stop',
214
+ type: "message_stop",
199
215
  message: JSON.stringify({ ts: event.ts }),
200
216
  });
201
217
  return;
202
218
  }
203
- case 'status': {
219
+ case "status": {
204
220
  await this.appendLogEntry({
205
- type: 'status',
221
+ type: "status",
206
222
  message: JSON.stringify({
207
223
  phase: event.phase,
208
224
  kind: event.kind,
@@ -216,9 +232,9 @@ class TaskProgressReporter {
216
232
  });
217
233
  return;
218
234
  }
219
- case 'artifact': {
235
+ case "artifact": {
220
236
  await this.appendLogEntry({
221
- type: 'artifact',
237
+ type: "artifact",
222
238
  message: JSON.stringify({
223
239
  kind: event.kind,
224
240
  content: event.content,
@@ -227,9 +243,9 @@ class TaskProgressReporter {
227
243
  });
228
244
  return;
229
245
  }
230
- case 'init': {
246
+ case "init": {
231
247
  await this.appendLogEntry({
232
- type: 'init',
248
+ type: "init",
233
249
  message: JSON.stringify({
234
250
  model: event.model,
235
251
  tools: event.tools,
@@ -241,9 +257,9 @@ class TaskProgressReporter {
241
257
  });
242
258
  return;
243
259
  }
244
- case 'metric': {
260
+ case "metric": {
245
261
  await this.appendLogEntry({
246
- type: 'metric',
262
+ type: "metric",
247
263
  message: JSON.stringify({
248
264
  key: event.key,
249
265
  value: event.value,
@@ -253,9 +269,9 @@ class TaskProgressReporter {
253
269
  });
254
270
  return;
255
271
  }
256
- case 'compact_boundary': {
272
+ case "compact_boundary": {
257
273
  await this.appendLogEntry({
258
- type: 'compact_boundary',
274
+ type: "compact_boundary",
259
275
  message: JSON.stringify({
260
276
  trigger: event.trigger,
261
277
  preTokens: event.preTokens,
@@ -264,9 +280,9 @@ class TaskProgressReporter {
264
280
  });
265
281
  return;
266
282
  }
267
- case 'tool_call': {
283
+ case "tool_call": {
268
284
  await this.appendLogEntry({
269
- type: 'tool_call',
285
+ type: "tool_call",
270
286
  message: JSON.stringify({
271
287
  toolName: event.toolName,
272
288
  callId: event.callId,
@@ -277,9 +293,9 @@ class TaskProgressReporter {
277
293
  });
278
294
  return;
279
295
  }
280
- case 'tool_result': {
296
+ case "tool_result": {
281
297
  await this.appendLogEntry({
282
- type: 'tool_result',
298
+ type: "tool_result",
283
299
  message: JSON.stringify({
284
300
  toolName: event.toolName,
285
301
  callId: event.callId,
@@ -291,9 +307,9 @@ class TaskProgressReporter {
291
307
  });
292
308
  return;
293
309
  }
294
- case 'error': {
310
+ case "error": {
295
311
  await this.appendLogEntry({
296
- type: 'error',
312
+ type: "error",
297
313
  message: JSON.stringify({
298
314
  message: event.message,
299
315
  errorType: event.errorType,
@@ -303,9 +319,9 @@ class TaskProgressReporter {
303
319
  });
304
320
  return;
305
321
  }
306
- case 'done': {
322
+ case "done": {
307
323
  await this.appendLogEntry({
308
- type: 'done',
324
+ type: "done",
309
325
  message: JSON.stringify({
310
326
  result: event.result,
311
327
  durationMs: event.durationMs,
@@ -320,9 +336,9 @@ class TaskProgressReporter {
320
336
  });
321
337
  return;
322
338
  }
323
- case 'user_message': {
339
+ case "user_message": {
324
340
  await this.appendLogEntry({
325
- type: 'user_message',
341
+ type: "user_message",
326
342
  message: JSON.stringify({
327
343
  content: event.content,
328
344
  isSynthetic: event.isSynthetic,
@@ -331,13 +347,13 @@ class TaskProgressReporter {
331
347
  });
332
348
  return;
333
349
  }
334
- case 'raw_sdk_event': {
350
+ case "raw_sdk_event": {
335
351
  // Skip raw SDK events - too verbose for persistence
336
352
  return;
337
353
  }
338
354
  default:
339
355
  // For any unfamiliar event types, log them as-is
340
- this.logger.debug('Unknown event type', { type: event.type });
356
+ this.logger.debug("Unknown event type", { type: event.type });
341
357
  return;
342
358
  }
343
359
  }
@@ -349,12 +365,12 @@ class TaskProgressReporter {
349
365
  if (logLine && logLine !== this.lastLogEntry) {
350
366
  try {
351
367
  await this.posthogAPI.appendTaskRunLog(this.taskId, this.runId, [
352
- { type: 'info', message: logLine }
368
+ { type: "info", message: logLine },
353
369
  ]);
354
370
  this.lastLogEntry = logLine;
355
371
  }
356
372
  catch (error) {
357
- this.logger.warn('Failed to append log entry', {
373
+ this.logger.warn("Failed to append log entry", {
358
374
  taskId: this.taskId,
359
375
  runId: this.runId,
360
376
  error: error.message,
@@ -368,7 +384,7 @@ class TaskProgressReporter {
368
384
  this.taskRun = run;
369
385
  }
370
386
  catch (error) {
371
- this.logger.warn('Failed to update task run', {
387
+ this.logger.warn("Failed to update task run", {
372
388
  taskId: this.taskId,
373
389
  runId: this.runId,
374
390
  error: error.message,
@@ -1 +1 @@
1
- {"version":3,"file":"task-progress-reporter.js","sources":["../../src/task-progress-reporter.ts"],"sourcesContent":["import type { Logger } from './utils/logger.js';\nimport type { PostHogAPIClient, TaskRunUpdate } from './posthog-api.js';\nimport type { AgentEvent, TaskRun, LogEntry } from './types.js';\n\ninterface ProgressMetadata {\n totalSteps?: number;\n}\n\n/**\n * Persists task execution progress to PostHog so clients can poll for updates.\n *\n * The reporter is intentionally best-effort – failures are logged but never\n * allowed to break the agent execution flow.\n */\nexport class TaskProgressReporter {\n private posthogAPI?: PostHogAPIClient;\n private logger: Logger;\n private taskRun?: TaskRun;\n private taskId?: string;\n private outputLog: string[] = [];\n private totalSteps?: number;\n private lastLogEntry?: string;\n private tokenBuffer: string = '';\n private tokenCount: number = 0;\n private tokenFlushTimer?: NodeJS.Timeout;\n private readonly TOKEN_BATCH_SIZE = 100;\n private readonly TOKEN_FLUSH_INTERVAL_MS = 1000;\n private logWriteQueue: Promise<void> = Promise.resolve();\n private readonly LOG_APPEND_MAX_RETRIES = 3;\n private readonly LOG_APPEND_RETRY_BASE_DELAY_MS = 200;\n\n constructor(posthogAPI: PostHogAPIClient | undefined, logger: Logger) {\n this.posthogAPI = posthogAPI;\n this.logger = logger.child('TaskProgressReporter');\n }\n\n get runId(): string | undefined {\n return this.taskRun?.id;\n }\n\n async start(taskId: string, metadata: ProgressMetadata = {}): Promise<void> {\n if (!this.posthogAPI) {\n return;\n }\n\n this.taskId = taskId;\n this.totalSteps = metadata.totalSteps;\n\n try {\n const run = await this.posthogAPI.createTaskRun(taskId, {\n status: 'started',\n });\n this.taskRun = run;\n this.outputLog = [];\n this.logger.debug('Created task run', { taskId, runId: run.id });\n } catch (error) {\n this.logger.warn('Failed to create task run', { taskId, error: (error as Error).message });\n }\n }\n\n async complete(): Promise<void> {\n await this.flushTokens(); // Flush any remaining tokens before completion\n if (this.tokenFlushTimer) {\n clearTimeout(this.tokenFlushTimer);\n this.tokenFlushTimer = undefined;\n }\n await this.update({ status: 'completed' }, 'Task execution completed');\n }\n\n async fail(error: Error | string): Promise<void> {\n const message = typeof error === 'string' ? error : error.message;\n await this.update({ status: 'failed', error_message: message }, `Task execution failed: ${message}`);\n }\n\n async appendLog(line: string): Promise<void> {\n await this.update({}, line);\n }\n\n private async flushTokens(): Promise<void> {\n if (!this.tokenBuffer || this.tokenCount === 0) {\n return;\n }\n\n const buffer = this.tokenBuffer;\n this.tokenBuffer = '';\n this.tokenCount = 0;\n\n await this.appendLogEntry({\n type: 'token',\n message: buffer,\n });\n }\n\n private scheduleTokenFlush(): void {\n if (this.tokenFlushTimer) {\n return;\n }\n\n this.tokenFlushTimer = setTimeout(() => {\n this.tokenFlushTimer = undefined;\n this.flushTokens().catch((err) => {\n this.logger.warn('Failed to flush tokens', { error: err });\n });\n }, this.TOKEN_FLUSH_INTERVAL_MS);\n }\n\n private appendLogEntry(entry: LogEntry): Promise<void> {\n if (!this.posthogAPI || !this.runId || !this.taskId) {\n return Promise.resolve();\n }\n\n const taskId = this.taskId;\n const runId = this.runId;\n\n this.logWriteQueue = this.logWriteQueue\n .catch((error) => {\n // Ensure previous failures don't block subsequent writes\n this.logger.debug('Previous log append failed', {\n taskId,\n runId,\n error: error instanceof Error ? error.message : String(error),\n });\n })\n .then(() => this.writeLogEntry(taskId, runId, entry));\n\n return this.logWriteQueue;\n }\n\n private async writeLogEntry(\n taskId: string,\n runId: string,\n entry: LogEntry,\n ): Promise<void> {\n if (!this.posthogAPI) {\n return;\n }\n\n for (let attempt = 1; attempt <= this.LOG_APPEND_MAX_RETRIES; attempt++) {\n try {\n await this.posthogAPI.appendTaskRunLog(taskId, runId, [entry]);\n return;\n } catch (error) {\n this.logger.warn('Failed to append log entry', {\n taskId,\n runId,\n attempt,\n maxAttempts: this.LOG_APPEND_MAX_RETRIES,\n error: (error as Error).message,\n });\n\n if (attempt === this.LOG_APPEND_MAX_RETRIES) {\n return;\n }\n\n const delayMs =\n this.LOG_APPEND_RETRY_BASE_DELAY_MS * Math.pow(2, attempt - 1);\n await new Promise((resolve) => setTimeout(resolve, delayMs));\n }\n }\n }\n\n async recordEvent(event: AgentEvent): Promise<void> {\n if (!this.posthogAPI || !this.runId || !this.taskId) {\n return;\n }\n\n switch (event.type) {\n case 'token': {\n // Batch tokens for efficiency\n this.tokenBuffer += event.content;\n this.tokenCount++;\n\n if (this.tokenCount >= this.TOKEN_BATCH_SIZE) {\n await this.flushTokens();\n if (this.tokenFlushTimer) {\n clearTimeout(this.tokenFlushTimer);\n this.tokenFlushTimer = undefined;\n }\n } else {\n this.scheduleTokenFlush();\n }\n return;\n }\n\n case 'content_block_start': {\n await this.appendLogEntry({\n type: 'content_block_start',\n message: JSON.stringify({\n index: event.index,\n contentType: event.contentType,\n toolName: event.toolName,\n toolId: event.toolId,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'content_block_stop': {\n await this.appendLogEntry({\n type: 'content_block_stop',\n message: JSON.stringify({\n index: event.index,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'message_start': {\n await this.appendLogEntry({\n type: 'message_start',\n message: JSON.stringify({\n messageId: event.messageId,\n model: event.model,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'message_delta': {\n await this.appendLogEntry({\n type: 'message_delta',\n message: JSON.stringify({\n stopReason: event.stopReason,\n stopSequence: event.stopSequence,\n usage: event.usage,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'message_stop': {\n await this.appendLogEntry({\n type: 'message_stop',\n message: JSON.stringify({ ts: event.ts }),\n });\n return;\n }\n\n case 'status': {\n await this.appendLogEntry({\n type: 'status',\n message: JSON.stringify({\n phase: event.phase,\n kind: event.kind,\n branch: event.branch,\n prUrl: event.prUrl,\n taskId: event.taskId,\n messageId: event.messageId,\n model: event.model,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'artifact': {\n await this.appendLogEntry({\n type: 'artifact',\n message: JSON.stringify({\n kind: event.kind,\n content: event.content,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'init': {\n await this.appendLogEntry({\n type: 'init',\n message: JSON.stringify({\n model: event.model,\n tools: event.tools,\n permissionMode: event.permissionMode,\n cwd: event.cwd,\n apiKeySource: event.apiKeySource,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'metric': {\n await this.appendLogEntry({\n type: 'metric',\n message: JSON.stringify({\n key: event.key,\n value: event.value,\n unit: event.unit,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'compact_boundary': {\n await this.appendLogEntry({\n type: 'compact_boundary',\n message: JSON.stringify({\n trigger: event.trigger,\n preTokens: event.preTokens,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'tool_call': {\n await this.appendLogEntry({\n type: 'tool_call',\n message: JSON.stringify({\n toolName: event.toolName,\n callId: event.callId,\n args: event.args,\n parentToolUseId: event.parentToolUseId,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'tool_result': {\n await this.appendLogEntry({\n type: 'tool_result',\n message: JSON.stringify({\n toolName: event.toolName,\n callId: event.callId,\n result: event.result,\n isError: event.isError,\n parentToolUseId: event.parentToolUseId,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'error': {\n await this.appendLogEntry({\n type: 'error',\n message: JSON.stringify({\n message: event.message,\n errorType: event.errorType,\n context: event.context,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'done': {\n await this.appendLogEntry({\n type: 'done',\n message: JSON.stringify({\n result: event.result,\n durationMs: event.durationMs,\n durationApiMs: event.durationApiMs,\n numTurns: event.numTurns,\n totalCostUsd: event.totalCostUsd,\n usage: event.usage,\n modelUsage: event.modelUsage,\n permissionDenials: event.permissionDenials,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'user_message': {\n await this.appendLogEntry({\n type: 'user_message',\n message: JSON.stringify({\n content: event.content,\n isSynthetic: event.isSynthetic,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case 'raw_sdk_event': {\n // Skip raw SDK events - too verbose for persistence\n return;\n }\n\n default:\n // For any unfamiliar event types, log them as-is\n this.logger.debug('Unknown event type', { type: (event as any).type });\n return;\n }\n }\n\n private async update(update: TaskRunUpdate, logLine?: string): Promise<void> {\n if (!this.posthogAPI || !this.runId || !this.taskId) {\n return;\n }\n\n // If there's a log line, append it separately using the append_log endpoint\n if (logLine && logLine !== this.lastLogEntry) {\n try {\n await this.posthogAPI.appendTaskRunLog(this.taskId, this.runId, [\n { type: 'info', message: logLine }\n ]);\n this.lastLogEntry = logLine;\n } catch (error) {\n this.logger.warn('Failed to append log entry', {\n taskId: this.taskId,\n runId: this.runId,\n error: (error as Error).message,\n });\n }\n }\n\n // Update other fields if provided\n if (Object.keys(update).length > 0) {\n try {\n const run = await this.posthogAPI.updateTaskRun(this.taskId, this.runId, update);\n this.taskRun = run;\n } catch (error) {\n this.logger.warn('Failed to update task run', {\n taskId: this.taskId,\n runId: this.runId,\n error: (error as Error).message,\n });\n }\n }\n }\n\n}\n"],"names":[],"mappings":"AAQA;;;;;AAKG;MACU,oBAAoB,CAAA;AACvB,IAAA,UAAU;AACV,IAAA,MAAM;AACN,IAAA,OAAO;AACP,IAAA,MAAM;IACN,SAAS,GAAa,EAAE;AACxB,IAAA,UAAU;AACV,IAAA,YAAY;IACZ,WAAW,GAAW,EAAE;IACxB,UAAU,GAAW,CAAC;AACtB,IAAA,eAAe;IACN,gBAAgB,GAAG,GAAG;IACtB,uBAAuB,GAAG,IAAI;AACvC,IAAA,aAAa,GAAkB,OAAO,CAAC,OAAO,EAAE;IACvC,sBAAsB,GAAG,CAAC;IAC1B,8BAA8B,GAAG,GAAG;IAErD,WAAA,CAAY,UAAwC,EAAE,MAAc,EAAA;AAClE,QAAA,IAAI,CAAC,UAAU,GAAG,UAAU;QAC5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,sBAAsB,CAAC;IACpD;AAEA,IAAA,IAAI,KAAK,GAAA;AACP,QAAA,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE;IACzB;AAEA,IAAA,MAAM,KAAK,CAAC,MAAc,EAAE,WAA6B,EAAE,EAAA;AACzD,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB;QACF;AAEA,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM;AACpB,QAAA,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,UAAU;AAErC,QAAA,IAAI;YACF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,EAAE;AACtD,gBAAA,MAAM,EAAE,SAAS;AAClB,aAAA,CAAC;AACF,YAAA,IAAI,CAAC,OAAO,GAAG,GAAG;AAClB,YAAA,IAAI,CAAC,SAAS,GAAG,EAAE;AACnB,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC;QAClE;QAAE,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,EAAE,EAAE,MAAM,EAAE,KAAK,EAAG,KAAe,CAAC,OAAO,EAAE,CAAC;QAC5F;IACF;AAEA,IAAA,MAAM,QAAQ,GAAA;AACZ,QAAA,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;AACzB,QAAA,IAAI,IAAI,CAAC,eAAe,EAAE;AACxB,YAAA,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC;AAClC,YAAA,IAAI,CAAC,eAAe,GAAG,SAAS;QAClC;AACA,QAAA,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,EAAE,0BAA0B,CAAC;IACxE;IAEA,MAAM,IAAI,CAAC,KAAqB,EAAA;AAC9B,QAAA,MAAM,OAAO,GAAG,OAAO,KAAK,KAAK,QAAQ,GAAG,KAAK,GAAG,KAAK,CAAC,OAAO;AACjE,QAAA,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,OAAO,EAAE,EAAE,0BAA0B,OAAO,CAAA,CAAE,CAAC;IACtG;IAEA,MAAM,SAAS,CAAC,IAAY,EAAA;QAC1B,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC;IAC7B;AAEQ,IAAA,MAAM,WAAW,GAAA;QACvB,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,UAAU,KAAK,CAAC,EAAE;YAC9C;QACF;AAEA,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW;AAC/B,QAAA,IAAI,CAAC,WAAW,GAAG,EAAE;AACrB,QAAA,IAAI,CAAC,UAAU,GAAG,CAAC;QAEnB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,YAAA,IAAI,EAAE,OAAO;AACb,YAAA,OAAO,EAAE,MAAM;AAChB,SAAA,CAAC;IACJ;IAEQ,kBAAkB,GAAA;AACxB,QAAA,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB;QACF;AAEA,QAAA,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC,MAAK;AACrC,YAAA,IAAI,CAAC,eAAe,GAAG,SAAS;YAChC,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,KAAI;AAC/B,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;AAC5D,YAAA,CAAC,CAAC;AACJ,QAAA,CAAC,EAAE,IAAI,CAAC,uBAAuB,CAAC;IAClC;AAEQ,IAAA,cAAc,CAAC,KAAe,EAAA;AACpC,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AACnD,YAAA,OAAO,OAAO,CAAC,OAAO,EAAE;QAC1B;AAEA,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM;AAC1B,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK;AAExB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AACvB,aAAA,KAAK,CAAC,CAAC,KAAK,KAAI;;AAEf,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,EAAE;gBAC9C,MAAM;gBACN,KAAK;AACL,gBAAA,KAAK,EAAE,KAAK,YAAY,KAAK,GAAG,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC;AAC9D,aAAA,CAAC;AACJ,QAAA,CAAC;AACA,aAAA,IAAI,CAAC,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAEvD,OAAO,IAAI,CAAC,aAAa;IAC3B;AAEQ,IAAA,MAAM,aAAa,CACzB,MAAc,EACd,KAAa,EACb,KAAe,EAAA;AAEf,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB;QACF;AAEA,QAAA,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,IAAI,CAAC,sBAAsB,EAAE,OAAO,EAAE,EAAE;AACvE,YAAA,IAAI;AACF,gBAAA,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC;gBAC9D;YACF;YAAE,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,EAAE;oBAC7C,MAAM;oBACN,KAAK;oBACL,OAAO;oBACP,WAAW,EAAE,IAAI,CAAC,sBAAsB;oBACxC,KAAK,EAAG,KAAe,CAAC,OAAO;AAChC,iBAAA,CAAC;AAEF,gBAAA,IAAI,OAAO,KAAK,IAAI,CAAC,sBAAsB,EAAE;oBAC3C;gBACF;AAEA,gBAAA,MAAM,OAAO,GACX,IAAI,CAAC,8BAA8B,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,GAAG,CAAC,CAAC;AAChE,gBAAA,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,KAAK,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAC9D;QACF;IACF;IAEA,MAAM,WAAW,CAAC,KAAiB,EAAA;AACjC,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACnD;QACF;AAEA,QAAA,QAAQ,KAAK,CAAC,IAAI;YAChB,KAAK,OAAO,EAAE;;AAEZ,gBAAA,IAAI,CAAC,WAAW,IAAI,KAAK,CAAC,OAAO;gBACjC,IAAI,CAAC,UAAU,EAAE;gBAEjB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,gBAAgB,EAAE;AAC5C,oBAAA,MAAM,IAAI,CAAC,WAAW,EAAE;AACxB,oBAAA,IAAI,IAAI,CAAC,eAAe,EAAE;AACxB,wBAAA,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC;AAClC,wBAAA,IAAI,CAAC,eAAe,GAAG,SAAS;oBAClC;gBACF;qBAAO;oBACL,IAAI,CAAC,kBAAkB,EAAE;gBAC3B;gBACA;YACF;YAEA,KAAK,qBAAqB,EAAE;gBAC1B,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,qBAAqB;AAC3B,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,WAAW,EAAE,KAAK,CAAC,WAAW;wBAC9B,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,oBAAoB,EAAE;gBACzB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,oBAAoB;AAC1B,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,eAAe,EAAE;gBACpB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,eAAe;AACrB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,eAAe,EAAE;gBACpB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,eAAe;AACrB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,cAAc,EAAE;gBACnB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,cAAc;AACpB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC;AAC1C,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,QAAQ,EAAE;gBACb,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,QAAQ;AACd,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,UAAU,EAAE;gBACf,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,UAAU;AAChB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,MAAM,EAAE;gBACX,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,cAAc,EAAE,KAAK,CAAC,cAAc;wBACpC,GAAG,EAAE,KAAK,CAAC,GAAG;wBACd,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,QAAQ,EAAE;gBACb,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,QAAQ;AACd,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,GAAG,EAAE,KAAK,CAAC,GAAG;wBACd,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,kBAAkB,EAAE;gBACvB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,kBAAkB;AACxB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,WAAW,EAAE;gBAChB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,WAAW;AACjB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,eAAe,EAAE,KAAK,CAAC,eAAe;wBACtC,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,aAAa,EAAE;gBAClB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,aAAa;AACnB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,eAAe,EAAE,KAAK,CAAC,eAAe;wBACtC,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,OAAO,EAAE;gBACZ,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,OAAO;AACb,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,MAAM,EAAE;gBACX,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,aAAa,EAAE,KAAK,CAAC,aAAa;wBAClC,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;wBAC1C,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,cAAc,EAAE;gBACnB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,cAAc;AACpB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,WAAW,EAAE,KAAK,CAAC,WAAW;wBAC9B,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,eAAe,EAAE;;gBAEpB;YACF;AAEA,YAAA;;AAEE,gBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,EAAE,EAAE,IAAI,EAAG,KAAa,CAAC,IAAI,EAAE,CAAC;gBACtE;;IAEN;AAEQ,IAAA,MAAM,MAAM,CAAC,MAAqB,EAAE,OAAgB,EAAA;AAC1D,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACnD;QACF;;QAGA,IAAI,OAAO,IAAI,OAAO,KAAK,IAAI,CAAC,YAAY,EAAE;AAC5C,YAAA,IAAI;AACF,gBAAA,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE;AAC9D,oBAAA,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO;AACjC,iBAAA,CAAC;AACF,gBAAA,IAAI,CAAC,YAAY,GAAG,OAAO;YAC7B;YAAE,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,EAAE;oBAC7C,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,KAAK,EAAG,KAAe,CAAC,OAAO;AAChC,iBAAA,CAAC;YACJ;QACF;;QAGA,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;AAClC,YAAA,IAAI;AACF,gBAAA,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC;AAChF,gBAAA,IAAI,CAAC,OAAO,GAAG,GAAG;YACpB;YAAE,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,EAAE;oBAC5C,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,KAAK,EAAG,KAAe,CAAC,OAAO;AAChC,iBAAA,CAAC;YACJ;QACF;IACF;AAED;;;;"}
1
+ {"version":3,"file":"task-progress-reporter.js","sources":["../../src/task-progress-reporter.ts"],"sourcesContent":["import type { PostHogAPIClient, TaskRunUpdate } from \"./posthog-api.js\";\nimport type { AgentEvent, LogEntry, TaskRun } from \"./types.js\";\nimport type { Logger } from \"./utils/logger.js\";\n\ninterface ProgressMetadata {\n totalSteps?: number;\n}\n\n/**\n * Persists task execution progress to PostHog so clients can poll for updates.\n *\n * The reporter is intentionally best-effort – failures are logged but never\n * allowed to break the agent execution flow.\n */\nexport class TaskProgressReporter {\n private posthogAPI?: PostHogAPIClient;\n private logger: Logger;\n private taskRun?: TaskRun;\n private taskId?: string;\n private totalSteps?: number;\n private lastLogEntry?: string;\n private tokenBuffer: string = \"\";\n private tokenCount: number = 0;\n private tokenFlushTimer?: NodeJS.Timeout;\n private readonly TOKEN_BATCH_SIZE = 100;\n private readonly TOKEN_FLUSH_INTERVAL_MS = 1000;\n private logWriteQueue: Promise<void> = Promise.resolve();\n private readonly LOG_APPEND_MAX_RETRIES = 3;\n private readonly LOG_APPEND_RETRY_BASE_DELAY_MS = 200;\n\n constructor(posthogAPI: PostHogAPIClient | undefined, logger: Logger) {\n this.posthogAPI = posthogAPI;\n this.logger = logger.child(\"TaskProgressReporter\");\n }\n\n get runId(): string | undefined {\n return this.taskRun?.id;\n }\n\n async start(taskId: string, metadata: ProgressMetadata = {}): Promise<void> {\n if (!this.posthogAPI) {\n return;\n }\n\n this.taskId = taskId;\n this.totalSteps = metadata.totalSteps;\n\n try {\n const run = await this.posthogAPI.createTaskRun(taskId, {\n status: \"started\",\n });\n this.taskRun = run;\n this.logger.debug(\"Created task run\", { taskId, runId: run.id });\n } catch (error) {\n this.logger.warn(\"Failed to create task run\", {\n taskId,\n error: (error as Error).message,\n });\n }\n }\n\n async complete(): Promise<void> {\n await this.flushTokens(); // Flush any remaining tokens before completion\n try {\n await this.logWriteQueue;\n } catch (error) {\n this.logger.debug(\"Pending logs failed to write during completion\", {\n error,\n });\n }\n\n if (this.tokenFlushTimer) {\n clearTimeout(this.tokenFlushTimer);\n this.tokenFlushTimer = undefined;\n }\n await this.update({ status: \"completed\" }, \"Task execution completed\");\n }\n\n async fail(error: Error | string): Promise<void> {\n try {\n await this.logWriteQueue;\n } catch (logError) {\n this.logger.debug(\"Pending logs failed to write during fail\", {\n error: logError,\n });\n }\n\n const message = typeof error === \"string\" ? error : error.message;\n await this.update(\n { status: \"failed\", error_message: message },\n `Task execution failed: ${message}`,\n );\n }\n\n async appendLog(line: string): Promise<void> {\n await this.update({}, line);\n }\n\n private async flushTokens(): Promise<void> {\n if (!this.tokenBuffer || this.tokenCount === 0) {\n return;\n }\n\n const buffer = this.tokenBuffer;\n this.tokenBuffer = \"\";\n this.tokenCount = 0;\n\n await this.appendLogEntry({\n type: \"token\",\n message: buffer,\n });\n }\n\n private scheduleTokenFlush(): void {\n if (this.tokenFlushTimer) {\n return;\n }\n\n this.tokenFlushTimer = setTimeout(() => {\n this.tokenFlushTimer = undefined;\n this.flushTokens().catch((err) => {\n this.logger.warn(\"Failed to flush tokens\", { error: err });\n });\n }, this.TOKEN_FLUSH_INTERVAL_MS);\n }\n\n private appendLogEntry(entry: LogEntry): Promise<void> {\n if (!this.posthogAPI || !this.runId || !this.taskId) {\n return Promise.resolve();\n }\n\n const taskId = this.taskId;\n const runId = this.runId;\n\n this.logWriteQueue = this.logWriteQueue\n .catch((error) => {\n this.logger.debug(\"Previous log append failed\", {\n taskId,\n runId,\n error: error instanceof Error ? error.message : String(error),\n });\n })\n .then(() => this.writeLogEntry(taskId, runId, entry));\n\n return this.logWriteQueue;\n }\n\n private async writeLogEntry(\n taskId: string,\n runId: string,\n entry: LogEntry,\n ): Promise<void> {\n if (!this.posthogAPI) {\n return;\n }\n\n for (let attempt = 1; attempt <= this.LOG_APPEND_MAX_RETRIES; attempt++) {\n try {\n await this.posthogAPI.appendTaskRunLog(taskId, runId, [entry]);\n return;\n } catch (error) {\n this.logger.warn(\"Failed to append log entry\", {\n taskId,\n runId,\n attempt,\n maxAttempts: this.LOG_APPEND_MAX_RETRIES,\n error: (error as Error).message,\n });\n\n if (attempt === this.LOG_APPEND_MAX_RETRIES) {\n return;\n }\n\n const delayMs =\n this.LOG_APPEND_RETRY_BASE_DELAY_MS * 2 ** (attempt - 1);\n await new Promise((resolve) => setTimeout(resolve, delayMs));\n }\n }\n }\n\n async recordEvent(event: AgentEvent): Promise<void> {\n if (!this.posthogAPI || !this.runId || !this.taskId) {\n return;\n }\n\n switch (event.type) {\n case \"token\": {\n // Batch tokens for efficiency\n this.tokenBuffer += event.content;\n this.tokenCount++;\n\n if (this.tokenCount >= this.TOKEN_BATCH_SIZE) {\n await this.flushTokens();\n if (this.tokenFlushTimer) {\n clearTimeout(this.tokenFlushTimer);\n this.tokenFlushTimer = undefined;\n }\n } else {\n this.scheduleTokenFlush();\n }\n return;\n }\n\n case \"content_block_start\": {\n await this.appendLogEntry({\n type: \"content_block_start\",\n message: JSON.stringify({\n index: event.index,\n contentType: event.contentType,\n toolName: event.toolName,\n toolId: event.toolId,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"content_block_stop\": {\n await this.appendLogEntry({\n type: \"content_block_stop\",\n message: JSON.stringify({\n index: event.index,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"message_start\": {\n await this.appendLogEntry({\n type: \"message_start\",\n message: JSON.stringify({\n messageId: event.messageId,\n model: event.model,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"message_delta\": {\n await this.appendLogEntry({\n type: \"message_delta\",\n message: JSON.stringify({\n stopReason: event.stopReason,\n stopSequence: event.stopSequence,\n usage: event.usage,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"message_stop\": {\n await this.appendLogEntry({\n type: \"message_stop\",\n message: JSON.stringify({ ts: event.ts }),\n });\n return;\n }\n\n case \"status\": {\n await this.appendLogEntry({\n type: \"status\",\n message: JSON.stringify({\n phase: event.phase,\n kind: event.kind,\n branch: event.branch,\n prUrl: event.prUrl,\n taskId: event.taskId,\n messageId: event.messageId,\n model: event.model,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"artifact\": {\n await this.appendLogEntry({\n type: \"artifact\",\n message: JSON.stringify({\n kind: event.kind,\n content: event.content,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"init\": {\n await this.appendLogEntry({\n type: \"init\",\n message: JSON.stringify({\n model: event.model,\n tools: event.tools,\n permissionMode: event.permissionMode,\n cwd: event.cwd,\n apiKeySource: event.apiKeySource,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"metric\": {\n await this.appendLogEntry({\n type: \"metric\",\n message: JSON.stringify({\n key: event.key,\n value: event.value,\n unit: event.unit,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"compact_boundary\": {\n await this.appendLogEntry({\n type: \"compact_boundary\",\n message: JSON.stringify({\n trigger: event.trigger,\n preTokens: event.preTokens,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"tool_call\": {\n await this.appendLogEntry({\n type: \"tool_call\",\n message: JSON.stringify({\n toolName: event.toolName,\n callId: event.callId,\n args: event.args,\n parentToolUseId: event.parentToolUseId,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"tool_result\": {\n await this.appendLogEntry({\n type: \"tool_result\",\n message: JSON.stringify({\n toolName: event.toolName,\n callId: event.callId,\n result: event.result,\n isError: event.isError,\n parentToolUseId: event.parentToolUseId,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"error\": {\n await this.appendLogEntry({\n type: \"error\",\n message: JSON.stringify({\n message: event.message,\n errorType: event.errorType,\n context: event.context,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"done\": {\n await this.appendLogEntry({\n type: \"done\",\n message: JSON.stringify({\n result: event.result,\n durationMs: event.durationMs,\n durationApiMs: event.durationApiMs,\n numTurns: event.numTurns,\n totalCostUsd: event.totalCostUsd,\n usage: event.usage,\n modelUsage: event.modelUsage,\n permissionDenials: event.permissionDenials,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"user_message\": {\n await this.appendLogEntry({\n type: \"user_message\",\n message: JSON.stringify({\n content: event.content,\n isSynthetic: event.isSynthetic,\n ts: event.ts,\n }),\n });\n return;\n }\n\n case \"raw_sdk_event\": {\n // Skip raw SDK events - too verbose for persistence\n return;\n }\n\n default:\n // For any unfamiliar event types, log them as-is\n this.logger.debug(\"Unknown event type\", { type: (event as any).type });\n return;\n }\n }\n\n private async update(update: TaskRunUpdate, logLine?: string): Promise<void> {\n if (!this.posthogAPI || !this.runId || !this.taskId) {\n return;\n }\n\n // If there's a log line, append it separately using the append_log endpoint\n if (logLine && logLine !== this.lastLogEntry) {\n try {\n await this.posthogAPI.appendTaskRunLog(this.taskId, this.runId, [\n { type: \"info\", message: logLine },\n ]);\n this.lastLogEntry = logLine;\n } catch (error) {\n this.logger.warn(\"Failed to append log entry\", {\n taskId: this.taskId,\n runId: this.runId,\n error: (error as Error).message,\n });\n }\n }\n\n // Update other fields if provided\n if (Object.keys(update).length > 0) {\n try {\n const run = await this.posthogAPI.updateTaskRun(\n this.taskId,\n this.runId,\n update,\n );\n this.taskRun = run;\n } catch (error) {\n this.logger.warn(\"Failed to update task run\", {\n taskId: this.taskId,\n runId: this.runId,\n error: (error as Error).message,\n });\n }\n }\n }\n}\n"],"names":[],"mappings":"AAQA;;;;;AAKG;MACU,oBAAoB,CAAA;AACvB,IAAA,UAAU;AACV,IAAA,MAAM;AACN,IAAA,OAAO;AACP,IAAA,MAAM;AACN,IAAA,UAAU;AACV,IAAA,YAAY;IACZ,WAAW,GAAW,EAAE;IACxB,UAAU,GAAW,CAAC;AACtB,IAAA,eAAe;IACN,gBAAgB,GAAG,GAAG;IACtB,uBAAuB,GAAG,IAAI;AACvC,IAAA,aAAa,GAAkB,OAAO,CAAC,OAAO,EAAE;IACvC,sBAAsB,GAAG,CAAC;IAC1B,8BAA8B,GAAG,GAAG;IAErD,WAAA,CAAY,UAAwC,EAAE,MAAc,EAAA;AAClE,QAAA,IAAI,CAAC,UAAU,GAAG,UAAU;QAC5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,sBAAsB,CAAC;IACpD;AAEA,IAAA,IAAI,KAAK,GAAA;AACP,QAAA,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE;IACzB;AAEA,IAAA,MAAM,KAAK,CAAC,MAAc,EAAE,WAA6B,EAAE,EAAA;AACzD,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB;QACF;AAEA,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM;AACpB,QAAA,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,UAAU;AAErC,QAAA,IAAI;YACF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,EAAE;AACtD,gBAAA,MAAM,EAAE,SAAS;AAClB,aAAA,CAAC;AACF,YAAA,IAAI,CAAC,OAAO,GAAG,GAAG;AAClB,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC;QAClE;QAAE,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,EAAE;gBAC5C,MAAM;gBACN,KAAK,EAAG,KAAe,CAAC,OAAO;AAChC,aAAA,CAAC;QACJ;IACF;AAEA,IAAA,MAAM,QAAQ,GAAA;AACZ,QAAA,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;AACzB,QAAA,IAAI;YACF,MAAM,IAAI,CAAC,aAAa;QAC1B;QAAE,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gDAAgD,EAAE;gBAClE,KAAK;AACN,aAAA,CAAC;QACJ;AAEA,QAAA,IAAI,IAAI,CAAC,eAAe,EAAE;AACxB,YAAA,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC;AAClC,YAAA,IAAI,CAAC,eAAe,GAAG,SAAS;QAClC;AACA,QAAA,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,EAAE,0BAA0B,CAAC;IACxE;IAEA,MAAM,IAAI,CAAC,KAAqB,EAAA;AAC9B,QAAA,IAAI;YACF,MAAM,IAAI,CAAC,aAAa;QAC1B;QAAE,OAAO,QAAQ,EAAE;AACjB,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0CAA0C,EAAE;AAC5D,gBAAA,KAAK,EAAE,QAAQ;AAChB,aAAA,CAAC;QACJ;AAEA,QAAA,MAAM,OAAO,GAAG,OAAO,KAAK,KAAK,QAAQ,GAAG,KAAK,GAAG,KAAK,CAAC,OAAO;AACjE,QAAA,MAAM,IAAI,CAAC,MAAM,CACf,EAAE,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,OAAO,EAAE,EAC5C,0BAA0B,OAAO,CAAA,CAAE,CACpC;IACH;IAEA,MAAM,SAAS,CAAC,IAAY,EAAA;QAC1B,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC;IAC7B;AAEQ,IAAA,MAAM,WAAW,GAAA;QACvB,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,UAAU,KAAK,CAAC,EAAE;YAC9C;QACF;AAEA,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW;AAC/B,QAAA,IAAI,CAAC,WAAW,GAAG,EAAE;AACrB,QAAA,IAAI,CAAC,UAAU,GAAG,CAAC;QAEnB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,YAAA,IAAI,EAAE,OAAO;AACb,YAAA,OAAO,EAAE,MAAM;AAChB,SAAA,CAAC;IACJ;IAEQ,kBAAkB,GAAA;AACxB,QAAA,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB;QACF;AAEA,QAAA,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC,MAAK;AACrC,YAAA,IAAI,CAAC,eAAe,GAAG,SAAS;YAChC,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,KAAI;AAC/B,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;AAC5D,YAAA,CAAC,CAAC;AACJ,QAAA,CAAC,EAAE,IAAI,CAAC,uBAAuB,CAAC;IAClC;AAEQ,IAAA,cAAc,CAAC,KAAe,EAAA;AACpC,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AACnD,YAAA,OAAO,OAAO,CAAC,OAAO,EAAE;QAC1B;AAEA,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM;AAC1B,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK;AAExB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AACvB,aAAA,KAAK,CAAC,CAAC,KAAK,KAAI;AACf,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,EAAE;gBAC9C,MAAM;gBACN,KAAK;AACL,gBAAA,KAAK,EAAE,KAAK,YAAY,KAAK,GAAG,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC;AAC9D,aAAA,CAAC;AACJ,QAAA,CAAC;AACA,aAAA,IAAI,CAAC,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAEvD,OAAO,IAAI,CAAC,aAAa;IAC3B;AAEQ,IAAA,MAAM,aAAa,CACzB,MAAc,EACd,KAAa,EACb,KAAe,EAAA;AAEf,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB;QACF;AAEA,QAAA,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,IAAI,CAAC,sBAAsB,EAAE,OAAO,EAAE,EAAE;AACvE,YAAA,IAAI;AACF,gBAAA,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC;gBAC9D;YACF;YAAE,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,EAAE;oBAC7C,MAAM;oBACN,KAAK;oBACL,OAAO;oBACP,WAAW,EAAE,IAAI,CAAC,sBAAsB;oBACxC,KAAK,EAAG,KAAe,CAAC,OAAO;AAChC,iBAAA,CAAC;AAEF,gBAAA,IAAI,OAAO,KAAK,IAAI,CAAC,sBAAsB,EAAE;oBAC3C;gBACF;AAEA,gBAAA,MAAM,OAAO,GACX,IAAI,CAAC,8BAA8B,GAAG,CAAC,KAAK,OAAO,GAAG,CAAC,CAAC;AAC1D,gBAAA,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,KAAK,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAC9D;QACF;IACF;IAEA,MAAM,WAAW,CAAC,KAAiB,EAAA;AACjC,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACnD;QACF;AAEA,QAAA,QAAQ,KAAK,CAAC,IAAI;YAChB,KAAK,OAAO,EAAE;;AAEZ,gBAAA,IAAI,CAAC,WAAW,IAAI,KAAK,CAAC,OAAO;gBACjC,IAAI,CAAC,UAAU,EAAE;gBAEjB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,gBAAgB,EAAE;AAC5C,oBAAA,MAAM,IAAI,CAAC,WAAW,EAAE;AACxB,oBAAA,IAAI,IAAI,CAAC,eAAe,EAAE;AACxB,wBAAA,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC;AAClC,wBAAA,IAAI,CAAC,eAAe,GAAG,SAAS;oBAClC;gBACF;qBAAO;oBACL,IAAI,CAAC,kBAAkB,EAAE;gBAC3B;gBACA;YACF;YAEA,KAAK,qBAAqB,EAAE;gBAC1B,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,qBAAqB;AAC3B,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,WAAW,EAAE,KAAK,CAAC,WAAW;wBAC9B,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,oBAAoB,EAAE;gBACzB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,oBAAoB;AAC1B,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,eAAe,EAAE;gBACpB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,eAAe;AACrB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,eAAe,EAAE;gBACpB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,eAAe;AACrB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,cAAc,EAAE;gBACnB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,cAAc;AACpB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC;AAC1C,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,QAAQ,EAAE;gBACb,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,QAAQ;AACd,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,UAAU,EAAE;gBACf,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,UAAU;AAChB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,MAAM,EAAE;gBACX,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,cAAc,EAAE,KAAK,CAAC,cAAc;wBACpC,GAAG,EAAE,KAAK,CAAC,GAAG;wBACd,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,QAAQ,EAAE;gBACb,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,QAAQ;AACd,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,GAAG,EAAE,KAAK,CAAC,GAAG;wBACd,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,kBAAkB,EAAE;gBACvB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,kBAAkB;AACxB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,WAAW,EAAE;gBAChB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,WAAW;AACjB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,eAAe,EAAE,KAAK,CAAC,eAAe;wBACtC,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,aAAa,EAAE;gBAClB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,aAAa;AACnB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,eAAe,EAAE,KAAK,CAAC,eAAe;wBACtC,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,OAAO,EAAE;gBACZ,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,OAAO;AACb,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;wBAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,MAAM,EAAE;gBACX,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,MAAM,EAAE,KAAK,CAAC,MAAM;wBACpB,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,aAAa,EAAE,KAAK,CAAC,aAAa;wBAClC,QAAQ,EAAE,KAAK,CAAC,QAAQ;wBACxB,YAAY,EAAE,KAAK,CAAC,YAAY;wBAChC,KAAK,EAAE,KAAK,CAAC,KAAK;wBAClB,UAAU,EAAE,KAAK,CAAC,UAAU;wBAC5B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;wBAC1C,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,cAAc,EAAE;gBACnB,MAAM,IAAI,CAAC,cAAc,CAAC;AACxB,oBAAA,IAAI,EAAE,cAAc;AACpB,oBAAA,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;wBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;wBACtB,WAAW,EAAE,KAAK,CAAC,WAAW;wBAC9B,EAAE,EAAE,KAAK,CAAC,EAAE;qBACb,CAAC;AACH,iBAAA,CAAC;gBACF;YACF;YAEA,KAAK,eAAe,EAAE;;gBAEpB;YACF;AAEA,YAAA;;AAEE,gBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,EAAE,EAAE,IAAI,EAAG,KAAa,CAAC,IAAI,EAAE,CAAC;gBACtE;;IAEN;AAEQ,IAAA,MAAM,MAAM,CAAC,MAAqB,EAAE,OAAgB,EAAA;AAC1D,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACnD;QACF;;QAGA,IAAI,OAAO,IAAI,OAAO,KAAK,IAAI,CAAC,YAAY,EAAE;AAC5C,YAAA,IAAI;AACF,gBAAA,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE;AAC9D,oBAAA,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE;AACnC,iBAAA,CAAC;AACF,gBAAA,IAAI,CAAC,YAAY,GAAG,OAAO;YAC7B;YAAE,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA4B,EAAE;oBAC7C,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,KAAK,EAAG,KAAe,CAAC,OAAO;AAChC,iBAAA,CAAC;YACJ;QACF;;QAGA,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;AAClC,YAAA,IAAI;AACF,gBAAA,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CAC7C,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,KAAK,EACV,MAAM,CACP;AACD,gBAAA,IAAI,CAAC,OAAO,GAAG,GAAG;YACpB;YAAE,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,EAAE;oBAC5C,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,KAAK,EAAG,KAAe,CAAC,OAAO;AAChC,iBAAA,CAAC;YACJ;QACF;IACF;AACD;;;;"}
@@ -23,7 +23,7 @@ export declare class TemplateManager {
23
23
  }): Promise<Array<{
24
24
  name: string;
25
25
  content: string;
26
- type: 'plan' | 'context' | 'reference' | 'output';
26
+ type: "plan" | "context" | "reference" | "output";
27
27
  }>>;
28
28
  generatePostHogReadme(): string;
29
29
  }