@falai/agent 0.3.25 → 0.4.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 (86) hide show
  1. package/README.md +97 -3
  2. package/dist/cjs/core/Agent.d.ts +1 -0
  3. package/dist/cjs/core/Agent.d.ts.map +1 -1
  4. package/dist/cjs/core/Agent.js +51 -12
  5. package/dist/cjs/core/Agent.js.map +1 -1
  6. package/dist/cjs/core/ConditionEvaluator.d.ts +72 -0
  7. package/dist/cjs/core/ConditionEvaluator.d.ts.map +1 -0
  8. package/dist/cjs/core/ConditionEvaluator.js +272 -0
  9. package/dist/cjs/core/ConditionEvaluator.js.map +1 -0
  10. package/dist/cjs/core/PreparationEngine.d.ts +105 -0
  11. package/dist/cjs/core/PreparationEngine.d.ts.map +1 -0
  12. package/dist/cjs/core/PreparationEngine.js +320 -0
  13. package/dist/cjs/core/PreparationEngine.js.map +1 -0
  14. package/dist/cjs/core/PromptBuilder.d.ts +3 -0
  15. package/dist/cjs/core/PromptBuilder.d.ts.map +1 -1
  16. package/dist/cjs/core/PromptBuilder.js +10 -10
  17. package/dist/cjs/core/PromptBuilder.js.map +1 -1
  18. package/dist/cjs/core/Route.d.ts +6 -0
  19. package/dist/cjs/core/Route.d.ts.map +1 -1
  20. package/dist/cjs/core/Route.js +9 -0
  21. package/dist/cjs/core/Route.js.map +1 -1
  22. package/dist/cjs/providers/AnthropicProvider.d.ts +3 -3
  23. package/dist/cjs/providers/AnthropicProvider.d.ts.map +1 -1
  24. package/dist/cjs/providers/AnthropicProvider.js.map +1 -1
  25. package/dist/cjs/providers/GeminiProvider.d.ts +3 -3
  26. package/dist/cjs/providers/GeminiProvider.d.ts.map +1 -1
  27. package/dist/cjs/providers/GeminiProvider.js +43 -18
  28. package/dist/cjs/providers/GeminiProvider.js.map +1 -1
  29. package/dist/cjs/providers/OpenAIProvider.d.ts +3 -3
  30. package/dist/cjs/providers/OpenAIProvider.d.ts.map +1 -1
  31. package/dist/cjs/providers/OpenAIProvider.js.map +1 -1
  32. package/dist/cjs/providers/OpenRouterProvider.d.ts +3 -3
  33. package/dist/cjs/providers/OpenRouterProvider.d.ts.map +1 -1
  34. package/dist/cjs/providers/OpenRouterProvider.js.map +1 -1
  35. package/dist/cjs/types/ai.d.ts +6 -6
  36. package/dist/cjs/types/ai.d.ts.map +1 -1
  37. package/dist/core/Agent.d.ts +1 -0
  38. package/dist/core/Agent.d.ts.map +1 -1
  39. package/dist/core/Agent.js +51 -12
  40. package/dist/core/Agent.js.map +1 -1
  41. package/dist/core/ConditionEvaluator.d.ts +72 -0
  42. package/dist/core/ConditionEvaluator.d.ts.map +1 -0
  43. package/dist/core/ConditionEvaluator.js +268 -0
  44. package/dist/core/ConditionEvaluator.js.map +1 -0
  45. package/dist/core/PreparationEngine.d.ts +105 -0
  46. package/dist/core/PreparationEngine.d.ts.map +1 -0
  47. package/dist/core/PreparationEngine.js +316 -0
  48. package/dist/core/PreparationEngine.js.map +1 -0
  49. package/dist/core/PromptBuilder.d.ts +3 -0
  50. package/dist/core/PromptBuilder.d.ts.map +1 -1
  51. package/dist/core/PromptBuilder.js +10 -10
  52. package/dist/core/PromptBuilder.js.map +1 -1
  53. package/dist/core/Route.d.ts +6 -0
  54. package/dist/core/Route.d.ts.map +1 -1
  55. package/dist/core/Route.js +9 -0
  56. package/dist/core/Route.js.map +1 -1
  57. package/dist/providers/AnthropicProvider.d.ts +3 -3
  58. package/dist/providers/AnthropicProvider.d.ts.map +1 -1
  59. package/dist/providers/AnthropicProvider.js.map +1 -1
  60. package/dist/providers/GeminiProvider.d.ts +3 -3
  61. package/dist/providers/GeminiProvider.d.ts.map +1 -1
  62. package/dist/providers/GeminiProvider.js +43 -18
  63. package/dist/providers/GeminiProvider.js.map +1 -1
  64. package/dist/providers/OpenAIProvider.d.ts +3 -3
  65. package/dist/providers/OpenAIProvider.d.ts.map +1 -1
  66. package/dist/providers/OpenAIProvider.js.map +1 -1
  67. package/dist/providers/OpenRouterProvider.d.ts +3 -3
  68. package/dist/providers/OpenRouterProvider.d.ts.map +1 -1
  69. package/dist/providers/OpenRouterProvider.js.map +1 -1
  70. package/dist/types/ai.d.ts +6 -6
  71. package/dist/types/ai.d.ts.map +1 -1
  72. package/docs/ARCHITECTURE.md +386 -0
  73. package/docs/DOMAINS.md +674 -0
  74. package/docs/README.md +17 -3
  75. package/examples/domain-scoping.ts +18 -10
  76. package/package.json +1 -1
  77. package/src/core/Agent.ts +63 -12
  78. package/src/core/ConditionEvaluator.ts +381 -0
  79. package/src/core/PreparationEngine.ts +500 -0
  80. package/src/core/PromptBuilder.ts +16 -16
  81. package/src/core/Route.ts +10 -0
  82. package/src/providers/AnthropicProvider.ts +51 -21
  83. package/src/providers/GeminiProvider.ts +86 -40
  84. package/src/providers/OpenAIProvider.ts +48 -21
  85. package/src/providers/OpenRouterProvider.ts +36 -18
  86. package/src/types/ai.ts +13 -8
@@ -0,0 +1,72 @@
1
+ /**
2
+ * ConditionEvaluator - Handles AI-powered condition evaluation
3
+ *
4
+ * This class is responsible for:
5
+ * - Evaluating guideline conditions
6
+ * - Evaluating transition conditions
7
+ * - Extracting tool arguments from context and history
8
+ */
9
+ import type { Event, AiProvider } from "../types/index";
10
+ import type { Guideline } from "../types/agent";
11
+ import type { ToolRef } from "../types/tool";
12
+ /**
13
+ * Result of guideline condition evaluation
14
+ */
15
+ export interface GuidelineEvaluationResult {
16
+ matches: boolean;
17
+ rationale?: string;
18
+ }
19
+ /**
20
+ * Result of transition condition evaluation
21
+ */
22
+ export interface TransitionEvaluationResult {
23
+ shouldFollow: boolean;
24
+ rationale?: string;
25
+ }
26
+ /**
27
+ * Result of tool argument extraction
28
+ */
29
+ export interface ArgumentExtractionResult {
30
+ arguments: unknown[];
31
+ rationale?: string;
32
+ }
33
+ /**
34
+ * ConditionEvaluator - Evaluates conditions using AI
35
+ */
36
+ export declare class ConditionEvaluator<TContext = unknown> {
37
+ private readonly ai;
38
+ constructor(ai: AiProvider);
39
+ /**
40
+ * Evaluate a guideline condition against context and history
41
+ */
42
+ evaluateGuidelineCondition(guideline: Guideline, context: TContext, history: Event[]): Promise<GuidelineEvaluationResult>;
43
+ /**
44
+ * Evaluate a transition condition
45
+ */
46
+ evaluateTransitionCondition(condition: string, context: TContext, history: Event[]): Promise<TransitionEvaluationResult>;
47
+ /**
48
+ * Extract tool arguments from context and history
49
+ */
50
+ extractToolArguments(tool: ToolRef<TContext, unknown[], unknown>, context: TContext, history: Event[]): Promise<ArgumentExtractionResult>;
51
+ /**
52
+ * Simple argument extraction from context (fallback)
53
+ */
54
+ simpleArgumentExtraction(tool: ToolRef<TContext, unknown[], unknown>, context: TContext): unknown[];
55
+ /**
56
+ * Extract recent messages from history
57
+ */
58
+ private extractRecentMessages;
59
+ /**
60
+ * Parse guideline evaluation from text response (fallback)
61
+ */
62
+ private parseGuidelineResponse;
63
+ /**
64
+ * Parse transition evaluation from text response (fallback)
65
+ */
66
+ private parseTransitionResponse;
67
+ /**
68
+ * Parse argument extraction from text response (fallback)
69
+ */
70
+ private parseArgumentResponse;
71
+ }
72
+ //# sourceMappingURL=ConditionEvaluator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConditionEvaluator.d.ts","sourceRoot":"","sources":["../../src/core/ConditionEvaluator.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAoB,MAAM,gBAAgB,CAAC;AAE1E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAE7C;;GAEG;AACH,MAAM,WAAW,yBAAyB;IACxC,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,0BAA0B;IACzC,YAAY,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,wBAAwB;IACvC,SAAS,EAAE,OAAO,EAAE,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AA0BD;;GAEG;AACH,qBAAa,kBAAkB,CAAC,QAAQ,GAAG,OAAO;IACpC,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,EAAE,UAAU;IAE3C;;OAEG;IACG,0BAA0B,CAC9B,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,QAAQ,EACjB,OAAO,EAAE,KAAK,EAAE,GACf,OAAO,CAAC,yBAAyB,CAAC;IA0DrC;;OAEG;IACG,2BAA2B,CAC/B,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,QAAQ,EACjB,OAAO,EAAE,KAAK,EAAE,GACf,OAAO,CAAC,0BAA0B,CAAC;IAyDtC;;OAEG;IACG,oBAAoB,CACxB,IAAI,EAAE,OAAO,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAC3C,OAAO,EAAE,QAAQ,EACjB,OAAO,EAAE,KAAK,EAAE,GACf,OAAO,CAAC,wBAAwB,CAAC;IAiEpC;;OAEG;IACH,wBAAwB,CACtB,IAAI,EAAE,OAAO,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAC3C,OAAO,EAAE,QAAQ,GAChB,OAAO,EAAE;IAgCZ;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAc7B;;OAEG;IACH,OAAO,CAAC,sBAAsB;IAW9B;;OAEG;IACH,OAAO,CAAC,uBAAuB;IAc/B;;OAEG;IACH,OAAO,CAAC,qBAAqB;CAsB9B"}
@@ -0,0 +1,268 @@
1
+ /**
2
+ * ConditionEvaluator - Handles AI-powered condition evaluation
3
+ *
4
+ * This class is responsible for:
5
+ * - Evaluating guideline conditions
6
+ * - Evaluating transition conditions
7
+ * - Extracting tool arguments from context and history
8
+ */
9
+ import { EventKind } from "../types/history";
10
+ /**
11
+ * ConditionEvaluator - Evaluates conditions using AI
12
+ */
13
+ export class ConditionEvaluator {
14
+ constructor(ai) {
15
+ this.ai = ai;
16
+ }
17
+ /**
18
+ * Evaluate a guideline condition against context and history
19
+ */
20
+ async evaluateGuidelineCondition(guideline, context, history) {
21
+ try {
22
+ const recentMessages = this.extractRecentMessages(history);
23
+ const prompt = `You are evaluating whether a guideline condition is met.
24
+
25
+ Guideline Condition: ${guideline.condition}
26
+ Action: ${guideline.action}
27
+
28
+ Current Context:
29
+ ${JSON.stringify(context, null, 2)}
30
+
31
+ Recent Conversation:
32
+ ${recentMessages || "(No recent messages)"}
33
+
34
+ Evaluate whether the guideline condition is currently met based on the context and conversation.
35
+
36
+ Your response must be a JSON object with this exact structure:
37
+ {
38
+ "matches": boolean (true or false),
39
+ "rationale": string (brief explanation)
40
+ }`;
41
+ const result = await this.ai.generateMessage({
42
+ prompt,
43
+ history,
44
+ context,
45
+ parameters: {
46
+ jsonMode: true,
47
+ maxOutputTokens: 500,
48
+ },
49
+ });
50
+ // Parse structured response
51
+ if (result.structured) {
52
+ return {
53
+ matches: result.structured.matches === true,
54
+ rationale: result.structured.rationale,
55
+ };
56
+ }
57
+ // Fallback parsing
58
+ return this.parseGuidelineResponse(result.message);
59
+ }
60
+ catch (error) {
61
+ console.error(`[ConditionEvaluator] Failed to evaluate guideline condition: ${guideline.id}`, error);
62
+ return {
63
+ matches: false,
64
+ rationale: "Failed to evaluate condition",
65
+ };
66
+ }
67
+ }
68
+ /**
69
+ * Evaluate a transition condition
70
+ */
71
+ async evaluateTransitionCondition(condition, context, history) {
72
+ try {
73
+ const recentMessages = this.extractRecentMessages(history);
74
+ const prompt = `You are evaluating whether a state transition condition is met.
75
+
76
+ Transition Condition: ${condition}
77
+
78
+ Current Context:
79
+ ${JSON.stringify(context, null, 2)}
80
+
81
+ Recent Conversation:
82
+ ${recentMessages || "(No recent messages)"}
83
+
84
+ Evaluate whether this transition should be followed based on the condition, context, and conversation.
85
+
86
+ Your response must be a JSON object with this exact structure:
87
+ {
88
+ "shouldFollow": boolean (true or false),
89
+ "rationale": string (brief explanation)
90
+ }`;
91
+ const result = await this.ai.generateMessage({
92
+ prompt,
93
+ history,
94
+ context,
95
+ parameters: {
96
+ jsonMode: true,
97
+ maxOutputTokens: 300,
98
+ },
99
+ });
100
+ // Parse structured response
101
+ if (result.structured) {
102
+ return {
103
+ shouldFollow: result.structured.shouldFollow === true,
104
+ rationale: result.structured.rationale,
105
+ };
106
+ }
107
+ // Fallback parsing
108
+ return this.parseTransitionResponse(result.message);
109
+ }
110
+ catch (error) {
111
+ console.error(`[ConditionEvaluator] Failed to evaluate transition condition`, error);
112
+ return {
113
+ shouldFollow: false,
114
+ rationale: "Failed to evaluate condition",
115
+ };
116
+ }
117
+ }
118
+ /**
119
+ * Extract tool arguments from context and history
120
+ */
121
+ async extractToolArguments(tool, context, history) {
122
+ try {
123
+ const recentMessages = this.extractRecentMessages(history);
124
+ const prompt = `You are extracting arguments for a tool call.
125
+
126
+ Tool: ${tool.name}
127
+ Description: ${tool.description || "No description"}
128
+ Parameters: ${JSON.stringify(tool.parameters, null, 2)}
129
+
130
+ Current Context:
131
+ ${JSON.stringify(context, null, 2)}
132
+
133
+ Recent Conversation:
134
+ ${recentMessages || "(No recent messages)"}
135
+
136
+ Extract the arguments needed to call this tool based on the context and conversation.
137
+ If a parameter is not available, use null or a reasonable default value.
138
+
139
+ Your response must be a JSON object with this exact structure:
140
+ {
141
+ "arguments": [arg1, arg2, ...] (array of argument values),
142
+ "rationale": string (optional explanation)
143
+ }`;
144
+ const result = await this.ai.generateMessage({
145
+ prompt,
146
+ history,
147
+ context,
148
+ parameters: {
149
+ jsonMode: true,
150
+ maxOutputTokens: 500,
151
+ },
152
+ });
153
+ // Parse structured response
154
+ if (result.structured) {
155
+ if (result.structured.arguments &&
156
+ Array.isArray(result.structured.arguments)) {
157
+ return {
158
+ arguments: result.structured.arguments,
159
+ rationale: result.structured.rationale,
160
+ };
161
+ }
162
+ }
163
+ // Fallback: try to parse from message
164
+ return this.parseArgumentResponse(result.message);
165
+ }
166
+ catch (error) {
167
+ console.error(`[ConditionEvaluator] Failed to extract tool arguments: ${tool.name}`, error);
168
+ return {
169
+ arguments: [],
170
+ rationale: "Failed to extract arguments",
171
+ };
172
+ }
173
+ }
174
+ /**
175
+ * Simple argument extraction from context (fallback)
176
+ */
177
+ simpleArgumentExtraction(tool, context) {
178
+ const contextObj = context;
179
+ const args = [];
180
+ // If parameters is an object with properties, try to match context keys
181
+ if (tool.parameters &&
182
+ typeof tool.parameters === "object" &&
183
+ !Array.isArray(tool.parameters)) {
184
+ const params = tool.parameters;
185
+ // Try to match parameter names with context keys
186
+ for (const [paramName, paramDef] of Object.entries(params)) {
187
+ if (contextObj[paramName] !== undefined) {
188
+ args.push(contextObj[paramName]);
189
+ }
190
+ else if (typeof paramDef === "object" &&
191
+ paramDef !== null &&
192
+ "default" in paramDef &&
193
+ typeof paramDef.default !== "undefined") {
194
+ args.push(paramDef.default);
195
+ }
196
+ }
197
+ }
198
+ return args;
199
+ }
200
+ // Private helper methods
201
+ /**
202
+ * Extract recent messages from history
203
+ */
204
+ extractRecentMessages(history, count = 5) {
205
+ return history
206
+ .slice(-count)
207
+ .map((event) => {
208
+ if (event.kind === EventKind.MESSAGE) {
209
+ const data = event.data;
210
+ return `${data.participant.display_name}: ${data.message}`;
211
+ }
212
+ return null;
213
+ })
214
+ .filter((msg) => msg !== null)
215
+ .join("\n");
216
+ }
217
+ /**
218
+ * Parse guideline evaluation from text response (fallback)
219
+ */
220
+ parseGuidelineResponse(message) {
221
+ const lowerMessage = message.toLowerCase();
222
+ const matches = lowerMessage.includes("true") || lowerMessage.includes('"matches": true');
223
+ return {
224
+ matches,
225
+ rationale: matches ? "Parsed from text response" : "Condition not met",
226
+ };
227
+ }
228
+ /**
229
+ * Parse transition evaluation from text response (fallback)
230
+ */
231
+ parseTransitionResponse(message) {
232
+ const lowerMessage = message.toLowerCase();
233
+ const shouldFollow = lowerMessage.includes("true") ||
234
+ lowerMessage.includes('"shouldfollow": true');
235
+ return {
236
+ shouldFollow,
237
+ rationale: shouldFollow
238
+ ? "Parsed from text response"
239
+ : "Condition not met",
240
+ };
241
+ }
242
+ /**
243
+ * Parse argument extraction from text response (fallback)
244
+ */
245
+ parseArgumentResponse(message) {
246
+ try {
247
+ // Try to extract JSON from the message
248
+ const jsonMatch = message.match(/\{[\s\S]*\}/);
249
+ if (jsonMatch) {
250
+ const parsed = JSON.parse(jsonMatch[0]);
251
+ if (parsed.arguments && Array.isArray(parsed.arguments)) {
252
+ return {
253
+ arguments: parsed.arguments,
254
+ rationale: parsed.rationale,
255
+ };
256
+ }
257
+ }
258
+ }
259
+ catch {
260
+ // Ignore parse errors
261
+ }
262
+ return {
263
+ arguments: [],
264
+ rationale: "Failed to parse arguments from response",
265
+ };
266
+ }
267
+ }
268
+ //# sourceMappingURL=ConditionEvaluator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConditionEvaluator.js","sourceRoot":"","sources":["../../src/core/ConditionEvaluator.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAoD7C;;GAEG;AACH,MAAM,OAAO,kBAAkB;IAC7B,YAA6B,EAAc;QAAd,OAAE,GAAF,EAAE,CAAY;IAAG,CAAC;IAE/C;;OAEG;IACH,KAAK,CAAC,0BAA0B,CAC9B,SAAoB,EACpB,OAAiB,EACjB,OAAgB;QAEhB,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;YAE3D,MAAM,MAAM,GAAG;;uBAEE,SAAS,CAAC,SAAS;UAChC,SAAS,CAAC,MAAM;;;EAGxB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;;;EAGhC,cAAc,IAAI,sBAAsB;;;;;;;;EAQxC,CAAC;YAEG,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,eAAe,CAG1C;gBACA,MAAM;gBACN,OAAO;gBACP,OAAO;gBACP,UAAU,EAAE;oBACV,QAAQ,EAAE,IAAI;oBACd,eAAe,EAAE,GAAG;iBACrB;aACF,CAAC,CAAC;YAEH,4BAA4B;YAC5B,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;gBACtB,OAAO;oBACL,OAAO,EAAE,MAAM,CAAC,UAAU,CAAC,OAAO,KAAK,IAAI;oBAC3C,SAAS,EAAE,MAAM,CAAC,UAAU,CAAC,SAAS;iBACvC,CAAC;YACJ,CAAC;YAED,mBAAmB;YACnB,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACrD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CACX,gEAAgE,SAAS,CAAC,EAAE,EAAE,EAC9E,KAAK,CACN,CAAC;YACF,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,SAAS,EAAE,8BAA8B;aAC1C,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,2BAA2B,CAC/B,SAAiB,EACjB,OAAiB,EACjB,OAAgB;QAEhB,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;YAE3D,MAAM,MAAM,GAAG;;wBAEG,SAAS;;;EAG/B,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;;;EAGhC,cAAc,IAAI,sBAAsB;;;;;;;;EAQxC,CAAC;YAEG,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,eAAe,CAG1C;gBACA,MAAM;gBACN,OAAO;gBACP,OAAO;gBACP,UAAU,EAAE;oBACV,QAAQ,EAAE,IAAI;oBACd,eAAe,EAAE,GAAG;iBACrB;aACF,CAAC,CAAC;YAEH,4BAA4B;YAC5B,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;gBACtB,OAAO;oBACL,YAAY,EAAE,MAAM,CAAC,UAAU,CAAC,YAAY,KAAK,IAAI;oBACrD,SAAS,EAAE,MAAM,CAAC,UAAU,CAAC,SAAS;iBACvC,CAAC;YACJ,CAAC;YAED,mBAAmB;YACnB,OAAO,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACtD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CACX,8DAA8D,EAC9D,KAAK,CACN,CAAC;YACF,OAAO;gBACL,YAAY,EAAE,KAAK;gBACnB,SAAS,EAAE,8BAA8B;aAC1C,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,oBAAoB,CACxB,IAA2C,EAC3C,OAAiB,EACjB,OAAgB;QAEhB,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;YAE3D,MAAM,MAAM,GAAG;;QAEb,IAAI,CAAC,IAAI;eACF,IAAI,CAAC,WAAW,IAAI,gBAAgB;cACrC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;;;EAGpD,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;;;EAGhC,cAAc,IAAI,sBAAsB;;;;;;;;;EASxC,CAAC;YAEG,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,eAAe,CAG1C;gBACA,MAAM;gBACN,OAAO;gBACP,OAAO;gBACP,UAAU,EAAE;oBACV,QAAQ,EAAE,IAAI;oBACd,eAAe,EAAE,GAAG;iBACrB;aACF,CAAC,CAAC;YAEH,4BAA4B;YAC5B,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;gBACtB,IACE,MAAM,CAAC,UAAU,CAAC,SAAS;oBAC3B,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,EAC1C,CAAC;oBACD,OAAO;wBACL,SAAS,EAAE,MAAM,CAAC,UAAU,CAAC,SAAS;wBACtC,SAAS,EAAE,MAAM,CAAC,UAAU,CAAC,SAAS;qBACvC,CAAC;gBACJ,CAAC;YACH,CAAC;YAED,sCAAsC;YACtC,OAAO,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACpD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CACX,0DAA0D,IAAI,CAAC,IAAI,EAAE,EACrE,KAAK,CACN,CAAC;YACF,OAAO;gBACL,SAAS,EAAE,EAAE;gBACb,SAAS,EAAE,6BAA6B;aACzC,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACH,wBAAwB,CACtB,IAA2C,EAC3C,OAAiB;QAEjB,MAAM,UAAU,GAAG,OAAkC,CAAC;QACtD,MAAM,IAAI,GAAc,EAAE,CAAC;QAE3B,wEAAwE;QACxE,IACE,IAAI,CAAC,UAAU;YACf,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ;YACnC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,EAC/B,CAAC;YACD,MAAM,MAAM,GAAG,IAAI,CAAC,UAAqC,CAAC;YAE1D,iDAAiD;YACjD,KAAK,MAAM,CAAC,SAAS,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC3D,IAAI,UAAU,CAAC,SAAS,CAAC,KAAK,SAAS,EAAE,CAAC;oBACxC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;gBACnC,CAAC;qBAAM,IACL,OAAO,QAAQ,KAAK,QAAQ;oBAC5B,QAAQ,KAAK,IAAI;oBACjB,SAAS,IAAI,QAAQ;oBACrB,OAAQ,QAAkC,CAAC,OAAO,KAAK,WAAW,EAClE,CAAC;oBACD,IAAI,CAAC,IAAI,CAAE,QAAiC,CAAC,OAAO,CAAC,CAAC;gBACxD,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,yBAAyB;IAEzB;;OAEG;IACK,qBAAqB,CAAC,OAAgB,EAAE,KAAK,GAAG,CAAC;QACvD,OAAO,OAAO;aACX,KAAK,CAAC,CAAC,KAAK,CAAC;aACb,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACb,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,OAAO,EAAE,CAAC;gBACrC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAwB,CAAC;gBAC5C,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,KAAK,IAAI,CAAC,OAAO,EAAE,CAAC;YAC7D,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,GAAG,EAAiB,EAAE,CAAC,GAAG,KAAK,IAAI,CAAC;aAC5C,IAAI,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC;IAED;;OAEG;IACK,sBAAsB,CAAC,OAAe;QAC5C,MAAM,YAAY,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;QAC3C,MAAM,OAAO,GACX,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAE5E,OAAO;YACL,OAAO;YACP,SAAS,EAAE,OAAO,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC,CAAC,mBAAmB;SACvE,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,uBAAuB,CAAC,OAAe;QAC7C,MAAM,YAAY,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;QAC3C,MAAM,YAAY,GAChB,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC;YAC7B,YAAY,CAAC,QAAQ,CAAC,sBAAsB,CAAC,CAAC;QAEhD,OAAO;YACL,YAAY;YACZ,SAAS,EAAE,YAAY;gBACrB,CAAC,CAAC,2BAA2B;gBAC7B,CAAC,CAAC,mBAAmB;SACxB,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,qBAAqB,CAAC,OAAe;QAC3C,IAAI,CAAC;YACH,uCAAuC;YACvC,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YAC/C,IAAI,SAAS,EAAE,CAAC;gBACd,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAA6B,CAAC;gBACpE,IAAI,MAAM,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;oBACxD,OAAO;wBACL,SAAS,EAAE,MAAM,CAAC,SAAS;wBAC3B,SAAS,EAAE,MAAM,CAAC,SAAS;qBAC5B,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,sBAAsB;QACxB,CAAC;QAED,OAAO;YACL,SAAS,EAAE,EAAE;YACb,SAAS,EAAE,yCAAyC;SACrD,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,105 @@
1
+ /**
2
+ * PreparationEngine - Handles the preparation iteration loop
3
+ *
4
+ * This engine implements the core Parlant/Emcie architecture:
5
+ * 1. Before generating a message, run preparation iterations
6
+ * 2. Each iteration:
7
+ * - Match guidelines against current context
8
+ * - Walk the state machine and execute tool transitions
9
+ * - Execute tools when conditions are met
10
+ * - Update context from tool results
11
+ * - Check if prepared to respond
12
+ * 3. After preparation, the AI generates the final message
13
+ *
14
+ * The AI NEVER sees tools - tools execute automatically based on:
15
+ * - State machine transitions ({ toolState: tool })
16
+ * - Guideline matching with associated tools
17
+ */
18
+ import type { Event, StateRef, AiProvider } from "../types/index";
19
+ import type { Guideline, GuidelineMatch } from "../types/agent";
20
+ import type { Route } from "./Route";
21
+ /**
22
+ * Tool execution result
23
+ */
24
+ export interface ToolExecutionResult {
25
+ toolName: string;
26
+ arguments: Record<string, unknown>;
27
+ result: unknown;
28
+ success: boolean;
29
+ error?: string;
30
+ }
31
+ /**
32
+ * Preparation iteration state
33
+ */
34
+ export interface IterationState {
35
+ iterationNumber: number;
36
+ matchedGuidelines: GuidelineMatch[];
37
+ executedTools: ToolExecutionResult[];
38
+ contextUpdates: Record<string, unknown>;
39
+ preparedToRespond: boolean;
40
+ }
41
+ /**
42
+ * Preparation context
43
+ */
44
+ export interface PreparationContext<TContext = unknown> {
45
+ history: Event[];
46
+ currentState?: StateRef;
47
+ context: TContext;
48
+ routes: Route<TContext>[];
49
+ guidelines: Guideline[];
50
+ maxIterations: number;
51
+ }
52
+ /**
53
+ * Preparation result
54
+ */
55
+ export interface PreparationResult<TContext = unknown> {
56
+ iterations: IterationState[];
57
+ finalContext: TContext;
58
+ toolExecutions: ToolExecutionResult[];
59
+ preparedToRespond: boolean;
60
+ }
61
+ /**
62
+ * PreparationEngine - Executes the preparation iteration loop
63
+ */
64
+ export declare class PreparationEngine<TContext = unknown> {
65
+ private readonly conditionEvaluator?;
66
+ constructor(ai?: AiProvider);
67
+ /**
68
+ * Run preparation iterations before message generation
69
+ *
70
+ * This is the core engine that executes tools automatically
71
+ * based on state machine transitions and guideline matching.
72
+ */
73
+ prepare(preparationContext: PreparationContext<TContext>): Promise<PreparationResult<TContext>>;
74
+ /**
75
+ * Run a single preparation iteration
76
+ */
77
+ private runIteration;
78
+ /**
79
+ * Match guidelines against current context
80
+ *
81
+ * Evaluates guideline conditions against the current context and history
82
+ * using AI to determine relevance and priority
83
+ */
84
+ private matchGuidelines;
85
+ /**
86
+ * Execute a single tool
87
+ */
88
+ private executeTool;
89
+ /**
90
+ * Execute tool transitions in the state machine
91
+ *
92
+ * Walks through state transitions and executes tools when
93
+ * reaching a { toolState: tool } transition
94
+ */
95
+ private executeStateToolTransitions;
96
+ /**
97
+ * Walk through a chain of states, executing tools along the way
98
+ */
99
+ private walkStateChain;
100
+ /**
101
+ * Evaluate a transition condition
102
+ */
103
+ private evaluateTransitionCondition;
104
+ }
105
+ //# sourceMappingURL=PreparationEngine.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PreparationEngine.d.ts","sourceRoot":"","sources":["../../src/core/PreparationEngine.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEhE,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAIrC;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,cAAc,EAAE,CAAC;IACpC,aAAa,EAAE,mBAAmB,EAAE,CAAC;IACrC,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACxC,iBAAiB,EAAE,OAAO,CAAC;CAC5B;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB,CAAC,QAAQ,GAAG,OAAO;IACpD,OAAO,EAAE,KAAK,EAAE,CAAC;IACjB,YAAY,CAAC,EAAE,QAAQ,CAAC;IACxB,OAAO,EAAE,QAAQ,CAAC;IAClB,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;IAC1B,UAAU,EAAE,SAAS,EAAE,CAAC;IACxB,aAAa,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB,CAAC,QAAQ,GAAG,OAAO;IACnD,UAAU,EAAE,cAAc,EAAE,CAAC;IAC7B,YAAY,EAAE,QAAQ,CAAC;IACvB,cAAc,EAAE,mBAAmB,EAAE,CAAC;IACtC,iBAAiB,EAAE,OAAO,CAAC;CAC5B;AAED;;GAEG;AACH,qBAAa,iBAAiB,CAAC,QAAQ,GAAG,OAAO;IAC/C,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAA+B;gBAEvD,EAAE,CAAC,EAAE,UAAU;IAM3B;;;;;OAKG;IACG,OAAO,CACX,kBAAkB,EAAE,kBAAkB,CAAC,QAAQ,CAAC,GAC/C,OAAO,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;IAsDvC;;OAEG;YACW,YAAY;IAkF1B;;;;;OAKG;YACW,eAAe;IAkD7B;;OAEG;YACW,WAAW;IA0DzB;;;;;OAKG;YACW,2BAA2B;IAoCzC;;OAEG;YACW,cAAc;IA0E5B;;OAEG;YACW,2BAA2B;CAgC1C"}