@falai/agent 0.9.2 → 1.0.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 (626) hide show
  1. package/README.md +262 -38
  2. package/dist/adapters/MemoryAdapter.d.ts.map +1 -0
  3. package/dist/adapters/MemoryAdapter.js.map +1 -0
  4. package/dist/adapters/MongoAdapter.d.ts.map +1 -0
  5. package/dist/adapters/MongoAdapter.js.map +1 -0
  6. package/dist/adapters/OpenSearchAdapter.d.ts.map +1 -0
  7. package/dist/adapters/OpenSearchAdapter.js.map +1 -0
  8. package/dist/adapters/PostgreSQLAdapter.d.ts.map +1 -0
  9. package/dist/adapters/PostgreSQLAdapter.js.map +1 -0
  10. package/dist/adapters/PrismaAdapter.d.ts.map +1 -0
  11. package/dist/{src/adapters → adapters}/PrismaAdapter.js +3 -2
  12. package/dist/adapters/PrismaAdapter.js.map +1 -0
  13. package/dist/adapters/RedisAdapter.d.ts.map +1 -0
  14. package/dist/{src/adapters → adapters}/RedisAdapter.js +3 -3
  15. package/dist/adapters/RedisAdapter.js.map +1 -0
  16. package/dist/adapters/SQLiteAdapter.d.ts.map +1 -0
  17. package/dist/adapters/SQLiteAdapter.js.map +1 -0
  18. package/dist/adapters/index.d.ts.map +1 -0
  19. package/dist/adapters/index.js.map +1 -0
  20. package/dist/cjs/adapters/MemoryAdapter.js.map +1 -0
  21. package/dist/cjs/adapters/MongoAdapter.js.map +1 -0
  22. package/dist/cjs/adapters/OpenSearchAdapter.js.map +1 -0
  23. package/dist/cjs/adapters/PostgreSQLAdapter.js.map +1 -0
  24. package/dist/{src → cjs}/adapters/PrismaAdapter.d.ts.map +1 -1
  25. package/dist/cjs/{src/adapters → adapters}/PrismaAdapter.js +3 -2
  26. package/dist/cjs/adapters/PrismaAdapter.js.map +1 -0
  27. package/dist/cjs/{src/adapters → adapters}/RedisAdapter.js +2 -2
  28. package/dist/cjs/adapters/RedisAdapter.js.map +1 -0
  29. package/dist/cjs/adapters/SQLiteAdapter.js.map +1 -0
  30. package/dist/cjs/adapters/index.js.map +1 -0
  31. package/dist/cjs/constants/index.js.map +1 -0
  32. package/dist/cjs/{src/core → core}/Agent.d.ts +6 -1
  33. package/dist/cjs/core/Agent.d.ts.map +1 -0
  34. package/dist/cjs/{src/core → core}/Agent.js +42 -2
  35. package/dist/cjs/core/Agent.js.map +1 -0
  36. package/dist/cjs/core/BatchExecutor.d.ts +353 -0
  37. package/dist/cjs/core/BatchExecutor.d.ts.map +1 -0
  38. package/dist/cjs/core/BatchExecutor.js +842 -0
  39. package/dist/cjs/core/BatchExecutor.js.map +1 -0
  40. package/dist/cjs/core/BatchPromptBuilder.d.ts +86 -0
  41. package/dist/cjs/core/BatchPromptBuilder.d.ts.map +1 -0
  42. package/dist/cjs/core/BatchPromptBuilder.js +201 -0
  43. package/dist/cjs/core/BatchPromptBuilder.js.map +1 -0
  44. package/dist/cjs/core/Events.js.map +1 -0
  45. package/dist/cjs/core/PersistenceManager.js.map +1 -0
  46. package/dist/{src → cjs}/core/PromptComposer.d.ts +1 -1
  47. package/dist/cjs/core/PromptComposer.d.ts.map +1 -0
  48. package/dist/cjs/{src/core → core}/PromptComposer.js +44 -7
  49. package/dist/cjs/core/PromptComposer.js.map +1 -0
  50. package/dist/{src → cjs}/core/ResponseEngine.d.ts.map +1 -1
  51. package/dist/cjs/core/ResponseEngine.js +202 -0
  52. package/dist/cjs/core/ResponseEngine.js.map +1 -0
  53. package/dist/{src → cjs}/core/ResponseModal.d.ts +45 -0
  54. package/dist/cjs/core/ResponseModal.d.ts.map +1 -0
  55. package/dist/cjs/{src/core → core}/ResponseModal.js +686 -66
  56. package/dist/cjs/core/ResponseModal.js.map +1 -0
  57. package/dist/{src → cjs}/core/ResponsePipeline.d.ts +2 -2
  58. package/dist/cjs/core/ResponsePipeline.d.ts.map +1 -0
  59. package/dist/cjs/{src/core → core}/ResponsePipeline.js +13 -6
  60. package/dist/cjs/core/ResponsePipeline.js.map +1 -0
  61. package/dist/{src → cjs}/core/Route.d.ts +34 -5
  62. package/dist/cjs/core/Route.d.ts.map +1 -0
  63. package/dist/cjs/{src/core → core}/Route.js +196 -19
  64. package/dist/cjs/core/Route.js.map +1 -0
  65. package/dist/cjs/{src/core → core}/RoutingEngine.d.ts +30 -5
  66. package/dist/cjs/core/RoutingEngine.d.ts.map +1 -0
  67. package/dist/cjs/{src/core → core}/RoutingEngine.js +330 -80
  68. package/dist/cjs/core/RoutingEngine.js.map +1 -0
  69. package/dist/cjs/core/SessionManager.js.map +1 -0
  70. package/dist/{src → cjs}/core/Step.d.ts +31 -10
  71. package/dist/cjs/core/Step.d.ts.map +1 -0
  72. package/dist/cjs/{src/core → core}/Step.js +105 -10
  73. package/dist/cjs/core/Step.js.map +1 -0
  74. package/dist/cjs/core/ToolManager.js.map +1 -0
  75. package/dist/{src → cjs}/index.d.ts +4 -1
  76. package/dist/cjs/index.d.ts.map +1 -0
  77. package/dist/cjs/{src/index.js → index.js} +12 -1
  78. package/dist/cjs/index.js.map +1 -0
  79. package/dist/cjs/{src/providers → providers}/AnthropicProvider.js +18 -18
  80. package/dist/cjs/providers/AnthropicProvider.js.map +1 -0
  81. package/dist/{src → cjs}/providers/GeminiProvider.d.ts.map +1 -1
  82. package/dist/cjs/{src/providers → providers}/GeminiProvider.js +123 -51
  83. package/dist/cjs/providers/GeminiProvider.js.map +1 -0
  84. package/dist/cjs/{src/providers → providers}/OpenAIProvider.js +19 -19
  85. package/dist/cjs/providers/OpenAIProvider.js.map +1 -0
  86. package/dist/cjs/{src/providers → providers}/OpenRouterProvider.js +19 -19
  87. package/dist/cjs/providers/OpenRouterProvider.js.map +1 -0
  88. package/dist/cjs/providers/index.js.map +1 -0
  89. package/dist/cjs/{src/types → types}/agent.d.ts +11 -3
  90. package/dist/cjs/types/agent.d.ts.map +1 -0
  91. package/dist/cjs/types/agent.js.map +1 -0
  92. package/dist/{src → cjs}/types/ai.js.map +1 -1
  93. package/dist/cjs/types/history.js.map +1 -0
  94. package/dist/cjs/{src/types → types}/index.d.ts +2 -1
  95. package/dist/{src → cjs}/types/index.d.ts.map +1 -1
  96. package/dist/cjs/{src/types → types}/index.js +6 -1
  97. package/dist/cjs/types/index.js.map +1 -0
  98. package/dist/cjs/types/persistence.js.map +1 -0
  99. package/dist/cjs/{src/types → types}/route.d.ts +111 -12
  100. package/dist/cjs/types/route.d.ts.map +1 -0
  101. package/dist/cjs/{src/types → types}/route.js.map +1 -1
  102. package/dist/cjs/types/session.js.map +1 -0
  103. package/dist/cjs/types/template.d.ts +88 -0
  104. package/dist/cjs/types/template.d.ts.map +1 -0
  105. package/dist/cjs/types/tool.js.map +1 -0
  106. package/dist/cjs/utils/clone.js.map +1 -0
  107. package/dist/cjs/utils/condition.d.ts +38 -0
  108. package/dist/cjs/utils/condition.d.ts.map +1 -0
  109. package/dist/cjs/utils/condition.js +168 -0
  110. package/dist/cjs/utils/condition.js.map +1 -0
  111. package/dist/cjs/utils/event.js.map +1 -0
  112. package/dist/cjs/utils/history.js.map +1 -0
  113. package/dist/cjs/utils/id.js.map +1 -0
  114. package/dist/cjs/{src/utils → utils}/index.d.ts +3 -1
  115. package/dist/cjs/utils/index.d.ts.map +1 -0
  116. package/dist/cjs/{src/utils → utils}/index.js +12 -1
  117. package/dist/cjs/utils/index.js.map +1 -0
  118. package/dist/cjs/utils/json.d.ts +16 -0
  119. package/dist/cjs/utils/json.d.ts.map +1 -0
  120. package/dist/cjs/utils/json.js +47 -0
  121. package/dist/cjs/utils/json.js.map +1 -0
  122. package/dist/cjs/utils/logger.js.map +1 -0
  123. package/dist/{src → cjs}/utils/retry.d.ts +0 -3
  124. package/dist/cjs/utils/retry.d.ts.map +1 -0
  125. package/dist/cjs/{src/utils → utils}/retry.js +8 -7
  126. package/dist/cjs/utils/retry.js.map +1 -0
  127. package/dist/cjs/utils/session.js.map +1 -0
  128. package/dist/{src → cjs}/utils/template.d.ts +48 -0
  129. package/dist/cjs/utils/template.d.ts.map +1 -0
  130. package/dist/cjs/{src/utils → utils}/template.js +100 -0
  131. package/dist/cjs/utils/template.js.map +1 -0
  132. package/dist/constants/index.d.ts.map +1 -0
  133. package/dist/constants/index.js.map +1 -0
  134. package/dist/{src/core → core}/Agent.d.ts +6 -1
  135. package/dist/core/Agent.d.ts.map +1 -0
  136. package/dist/{src/core → core}/Agent.js +43 -3
  137. package/dist/core/Agent.js.map +1 -0
  138. package/dist/core/BatchExecutor.d.ts +353 -0
  139. package/dist/core/BatchExecutor.d.ts.map +1 -0
  140. package/dist/core/BatchExecutor.js +837 -0
  141. package/dist/core/BatchExecutor.js.map +1 -0
  142. package/dist/core/BatchPromptBuilder.d.ts +86 -0
  143. package/dist/core/BatchPromptBuilder.d.ts.map +1 -0
  144. package/dist/core/BatchPromptBuilder.js +197 -0
  145. package/dist/core/BatchPromptBuilder.js.map +1 -0
  146. package/dist/core/Events.d.ts.map +1 -0
  147. package/dist/core/Events.js.map +1 -0
  148. package/dist/core/PersistenceManager.d.ts.map +1 -0
  149. package/dist/core/PersistenceManager.js.map +1 -0
  150. package/dist/{cjs/src/core → core}/PromptComposer.d.ts +1 -1
  151. package/dist/core/PromptComposer.d.ts.map +1 -0
  152. package/dist/{src/core → core}/PromptComposer.js +45 -8
  153. package/dist/core/PromptComposer.js.map +1 -0
  154. package/dist/core/ResponseEngine.d.ts.map +1 -0
  155. package/dist/core/ResponseEngine.js +198 -0
  156. package/dist/core/ResponseEngine.js.map +1 -0
  157. package/dist/{cjs/src/core → core}/ResponseModal.d.ts +45 -0
  158. package/dist/core/ResponseModal.d.ts.map +1 -0
  159. package/dist/{src/core → core}/ResponseModal.js +686 -66
  160. package/dist/core/ResponseModal.js.map +1 -0
  161. package/dist/{cjs/src/core → core}/ResponsePipeline.d.ts +2 -2
  162. package/dist/core/ResponsePipeline.d.ts.map +1 -0
  163. package/dist/{src/core → core}/ResponsePipeline.js +13 -6
  164. package/dist/core/ResponsePipeline.js.map +1 -0
  165. package/dist/{cjs/src/core → core}/Route.d.ts +34 -5
  166. package/dist/core/Route.d.ts.map +1 -0
  167. package/dist/{src/core → core}/Route.js +195 -18
  168. package/dist/core/Route.js.map +1 -0
  169. package/dist/{src/core → core}/RoutingEngine.d.ts +30 -5
  170. package/dist/core/RoutingEngine.d.ts.map +1 -0
  171. package/dist/{src/core → core}/RoutingEngine.js +310 -60
  172. package/dist/core/RoutingEngine.js.map +1 -0
  173. package/dist/core/SessionManager.d.ts.map +1 -0
  174. package/dist/core/SessionManager.js.map +1 -0
  175. package/dist/{cjs/src/core → core}/Step.d.ts +31 -10
  176. package/dist/core/Step.d.ts.map +1 -0
  177. package/dist/{src/core → core}/Step.js +104 -9
  178. package/dist/core/Step.js.map +1 -0
  179. package/dist/core/ToolManager.d.ts.map +1 -0
  180. package/dist/core/ToolManager.js.map +1 -0
  181. package/dist/{cjs/src/index.d.ts → index.d.ts} +4 -1
  182. package/dist/index.d.ts.map +1 -0
  183. package/dist/{src/index.js → index.js} +3 -0
  184. package/dist/index.js.map +1 -0
  185. package/dist/providers/AnthropicProvider.d.ts.map +1 -0
  186. package/dist/{src/providers → providers}/AnthropicProvider.js +17 -17
  187. package/dist/providers/AnthropicProvider.js.map +1 -0
  188. package/dist/providers/GeminiProvider.d.ts.map +1 -0
  189. package/dist/{src/providers → providers}/GeminiProvider.js +123 -51
  190. package/dist/providers/GeminiProvider.js.map +1 -0
  191. package/dist/providers/OpenAIProvider.d.ts.map +1 -0
  192. package/dist/{src/providers → providers}/OpenAIProvider.js +18 -18
  193. package/dist/providers/OpenAIProvider.js.map +1 -0
  194. package/dist/providers/OpenRouterProvider.d.ts.map +1 -0
  195. package/dist/{src/providers → providers}/OpenRouterProvider.js +18 -18
  196. package/dist/providers/OpenRouterProvider.js.map +1 -0
  197. package/dist/providers/index.d.ts.map +1 -0
  198. package/dist/providers/index.js.map +1 -0
  199. package/dist/{src/types → types}/agent.d.ts +11 -3
  200. package/dist/types/agent.d.ts.map +1 -0
  201. package/dist/types/agent.js.map +1 -0
  202. package/dist/types/ai.d.ts.map +1 -0
  203. package/dist/types/ai.js.map +1 -0
  204. package/dist/types/history.d.ts.map +1 -0
  205. package/dist/types/history.js.map +1 -0
  206. package/dist/{src/types → types}/index.d.ts +2 -1
  207. package/dist/types/index.d.ts.map +1 -0
  208. package/dist/{src/types → types}/index.js +1 -0
  209. package/dist/types/index.js.map +1 -0
  210. package/dist/types/persistence.d.ts.map +1 -0
  211. package/dist/types/persistence.js.map +1 -0
  212. package/dist/{src/types → types}/route.d.ts +111 -12
  213. package/dist/types/route.d.ts.map +1 -0
  214. package/dist/{src/types → types}/route.js.map +1 -1
  215. package/dist/types/routing.d.ts.map +1 -0
  216. package/dist/{cjs/src/types → types}/routing.js.map +1 -1
  217. package/dist/types/schema.d.ts.map +1 -0
  218. package/dist/{cjs/src/types → types}/schema.js.map +1 -1
  219. package/dist/types/session.d.ts.map +1 -0
  220. package/dist/{src/types → types}/session.js.map +1 -1
  221. package/dist/types/template.d.ts +88 -0
  222. package/dist/types/template.d.ts.map +1 -0
  223. package/dist/{cjs/src/types → types}/template.js.map +1 -1
  224. package/dist/types/tool.d.ts.map +1 -0
  225. package/dist/types/tool.js.map +1 -0
  226. package/dist/utils/clone.d.ts.map +1 -0
  227. package/dist/utils/clone.js.map +1 -0
  228. package/dist/utils/condition.d.ts +38 -0
  229. package/dist/utils/condition.d.ts.map +1 -0
  230. package/dist/utils/condition.js +161 -0
  231. package/dist/utils/condition.js.map +1 -0
  232. package/dist/utils/event.d.ts.map +1 -0
  233. package/dist/utils/event.js.map +1 -0
  234. package/dist/utils/history.d.ts.map +1 -0
  235. package/dist/utils/history.js.map +1 -0
  236. package/dist/utils/id.d.ts.map +1 -0
  237. package/dist/utils/id.js.map +1 -0
  238. package/dist/{src/utils → utils}/index.d.ts +3 -1
  239. package/dist/utils/index.d.ts.map +1 -0
  240. package/dist/{src/utils → utils}/index.js +5 -1
  241. package/dist/utils/index.js.map +1 -0
  242. package/dist/utils/json.d.ts +16 -0
  243. package/dist/utils/json.d.ts.map +1 -0
  244. package/dist/utils/json.js +43 -0
  245. package/dist/utils/json.js.map +1 -0
  246. package/dist/utils/logger.d.ts.map +1 -0
  247. package/dist/utils/logger.js.map +1 -0
  248. package/dist/{cjs/src/utils → utils}/retry.d.ts +0 -3
  249. package/dist/utils/retry.d.ts.map +1 -0
  250. package/dist/{src/utils → utils}/retry.js +5 -4
  251. package/dist/utils/retry.js.map +1 -0
  252. package/dist/utils/session.d.ts.map +1 -0
  253. package/dist/utils/session.js.map +1 -0
  254. package/dist/{cjs/src/utils → utils}/template.d.ts +48 -0
  255. package/dist/utils/template.d.ts.map +1 -0
  256. package/dist/{src/utils → utils}/template.js +98 -0
  257. package/dist/utils/template.js.map +1 -0
  258. package/docs/api/README.md +221 -12
  259. package/docs/api/overview.md +202 -3
  260. package/docs/architecture/data-extraction-flow.md +363 -0
  261. package/docs/architecture/multi-step-execution.md +243 -0
  262. package/docs/core/agent/README.md +120 -5
  263. package/docs/core/agent/session-management.md +1 -1
  264. package/docs/core/ai-integration/prompt-composition.md +135 -0
  265. package/docs/core/ai-integration/response-processing.md +146 -0
  266. package/docs/core/conversation-flows/data-collection.md +143 -0
  267. package/docs/core/conversation-flows/routes.md +2 -2
  268. package/docs/core/conversation-flows/step-transitions.md +132 -0
  269. package/docs/core/conversation-flows/steps.md +112 -0
  270. package/docs/core/error-handling.md +193 -0
  271. package/docs/core/routing/intelligent-routing.md +118 -0
  272. package/docs/guides/getting-started/README.md +284 -3
  273. package/docs/guides/migration/README.md +23 -0
  274. package/docs/guides/migration/flexible-routing-conditions.md +375 -0
  275. package/docs/guides/migration/multi-step-execution.md +303 -0
  276. package/examples/advanced-patterns/knowledge-based-agent.ts +101 -24
  277. package/examples/advanced-patterns/persistent-onboarding.ts +40 -5
  278. package/examples/advanced-patterns/route-lifecycle-hooks.ts +82 -12
  279. package/examples/advanced-patterns/streaming-responses.ts +2 -2
  280. package/examples/ai-providers/anthropic-integration.ts +4 -4
  281. package/examples/ai-providers/openai-integration.ts +1 -1
  282. package/examples/condition-patterns/function-only-conditions.ts +365 -0
  283. package/examples/condition-patterns/mixed-array-conditions.ts +477 -0
  284. package/examples/condition-patterns/route-skipif-patterns.ts +468 -0
  285. package/examples/condition-patterns/step-skipif-patterns.ts +0 -0
  286. package/examples/condition-patterns/string-only-conditions.ts +296 -0
  287. package/examples/conversation-flows/completion-transitions.ts +48 -7
  288. package/examples/core-concepts/basic-agent.ts +54 -33
  289. package/examples/core-concepts/schema-driven-extraction.ts +33 -9
  290. package/examples/core-concepts/session-management.ts +51 -16
  291. package/examples/integrations/database-integration.ts +6 -6
  292. package/examples/integrations/healthcare-integration.ts +10 -10
  293. package/examples/integrations/search-integration.ts +8 -8
  294. package/examples/integrations/server-session-management.ts +8 -8
  295. package/examples/persistence/database-persistence.ts +15 -15
  296. package/examples/persistence/memory-sessions.ts +3 -3
  297. package/examples/persistence/redis-persistence.ts +7 -9
  298. package/examples/tools/data-enrichment-tools.ts +4 -4
  299. package/package.json +6 -4
  300. package/src/adapters/PrismaAdapter.ts +3 -2
  301. package/src/adapters/RedisAdapter.ts +3 -3
  302. package/src/core/Agent.ts +54 -2
  303. package/src/core/BatchExecutor.ts +1156 -0
  304. package/src/core/BatchPromptBuilder.ts +275 -0
  305. package/src/core/PromptComposer.ts +53 -16
  306. package/src/core/ResponseEngine.ts +143 -4
  307. package/src/core/ResponseModal.ts +888 -66
  308. package/src/core/ResponsePipeline.ts +17 -9
  309. package/src/core/Route.ts +223 -22
  310. package/src/core/RoutingEngine.ts +426 -83
  311. package/src/core/Step.ts +144 -16
  312. package/src/index.ts +19 -0
  313. package/src/providers/AnthropicProvider.ts +17 -17
  314. package/src/providers/GeminiProvider.ts +129 -60
  315. package/src/providers/OpenAIProvider.ts +18 -18
  316. package/src/providers/OpenRouterProvider.ts +18 -18
  317. package/src/types/agent.ts +11 -3
  318. package/src/types/index.ts +12 -1
  319. package/src/types/route.ts +131 -12
  320. package/src/types/template.ts +70 -2
  321. package/src/utils/condition.ts +190 -0
  322. package/src/utils/index.ts +12 -0
  323. package/src/utils/json.ts +46 -0
  324. package/src/utils/retry.ts +5 -4
  325. package/src/utils/template.ts +109 -0
  326. package/dist/cjs/src/adapters/MemoryAdapter.d.ts.map +0 -1
  327. package/dist/cjs/src/adapters/MemoryAdapter.js.map +0 -1
  328. package/dist/cjs/src/adapters/MongoAdapter.d.ts.map +0 -1
  329. package/dist/cjs/src/adapters/MongoAdapter.js.map +0 -1
  330. package/dist/cjs/src/adapters/OpenSearchAdapter.d.ts.map +0 -1
  331. package/dist/cjs/src/adapters/OpenSearchAdapter.js.map +0 -1
  332. package/dist/cjs/src/adapters/PostgreSQLAdapter.d.ts.map +0 -1
  333. package/dist/cjs/src/adapters/PostgreSQLAdapter.js.map +0 -1
  334. package/dist/cjs/src/adapters/PrismaAdapter.d.ts.map +0 -1
  335. package/dist/cjs/src/adapters/PrismaAdapter.js.map +0 -1
  336. package/dist/cjs/src/adapters/RedisAdapter.d.ts.map +0 -1
  337. package/dist/cjs/src/adapters/RedisAdapter.js.map +0 -1
  338. package/dist/cjs/src/adapters/SQLiteAdapter.d.ts.map +0 -1
  339. package/dist/cjs/src/adapters/SQLiteAdapter.js.map +0 -1
  340. package/dist/cjs/src/adapters/index.d.ts.map +0 -1
  341. package/dist/cjs/src/adapters/index.js.map +0 -1
  342. package/dist/cjs/src/constants/index.d.ts.map +0 -1
  343. package/dist/cjs/src/constants/index.js.map +0 -1
  344. package/dist/cjs/src/core/Agent.d.ts.map +0 -1
  345. package/dist/cjs/src/core/Agent.js.map +0 -1
  346. package/dist/cjs/src/core/Events.d.ts.map +0 -1
  347. package/dist/cjs/src/core/Events.js.map +0 -1
  348. package/dist/cjs/src/core/PersistenceManager.d.ts.map +0 -1
  349. package/dist/cjs/src/core/PersistenceManager.js.map +0 -1
  350. package/dist/cjs/src/core/PromptComposer.d.ts.map +0 -1
  351. package/dist/cjs/src/core/PromptComposer.js.map +0 -1
  352. package/dist/cjs/src/core/ResponseEngine.d.ts.map +0 -1
  353. package/dist/cjs/src/core/ResponseEngine.js +0 -84
  354. package/dist/cjs/src/core/ResponseEngine.js.map +0 -1
  355. package/dist/cjs/src/core/ResponseModal.d.ts.map +0 -1
  356. package/dist/cjs/src/core/ResponseModal.js.map +0 -1
  357. package/dist/cjs/src/core/ResponsePipeline.d.ts.map +0 -1
  358. package/dist/cjs/src/core/ResponsePipeline.js.map +0 -1
  359. package/dist/cjs/src/core/Route.d.ts.map +0 -1
  360. package/dist/cjs/src/core/Route.js.map +0 -1
  361. package/dist/cjs/src/core/RoutingEngine.d.ts.map +0 -1
  362. package/dist/cjs/src/core/RoutingEngine.js.map +0 -1
  363. package/dist/cjs/src/core/SessionManager.d.ts.map +0 -1
  364. package/dist/cjs/src/core/SessionManager.js.map +0 -1
  365. package/dist/cjs/src/core/Step.d.ts.map +0 -1
  366. package/dist/cjs/src/core/Step.js.map +0 -1
  367. package/dist/cjs/src/core/ToolManager.d.ts.map +0 -1
  368. package/dist/cjs/src/core/ToolManager.js.map +0 -1
  369. package/dist/cjs/src/index.d.ts.map +0 -1
  370. package/dist/cjs/src/index.js.map +0 -1
  371. package/dist/cjs/src/providers/AnthropicProvider.d.ts.map +0 -1
  372. package/dist/cjs/src/providers/AnthropicProvider.js.map +0 -1
  373. package/dist/cjs/src/providers/GeminiProvider.d.ts.map +0 -1
  374. package/dist/cjs/src/providers/GeminiProvider.js.map +0 -1
  375. package/dist/cjs/src/providers/OpenAIProvider.d.ts.map +0 -1
  376. package/dist/cjs/src/providers/OpenAIProvider.js.map +0 -1
  377. package/dist/cjs/src/providers/OpenRouterProvider.d.ts.map +0 -1
  378. package/dist/cjs/src/providers/OpenRouterProvider.js.map +0 -1
  379. package/dist/cjs/src/providers/index.d.ts.map +0 -1
  380. package/dist/cjs/src/providers/index.js.map +0 -1
  381. package/dist/cjs/src/types/agent.d.ts.map +0 -1
  382. package/dist/cjs/src/types/agent.js.map +0 -1
  383. package/dist/cjs/src/types/ai.d.ts.map +0 -1
  384. package/dist/cjs/src/types/ai.js.map +0 -1
  385. package/dist/cjs/src/types/history.d.ts.map +0 -1
  386. package/dist/cjs/src/types/history.js.map +0 -1
  387. package/dist/cjs/src/types/index.d.ts.map +0 -1
  388. package/dist/cjs/src/types/index.js.map +0 -1
  389. package/dist/cjs/src/types/persistence.d.ts.map +0 -1
  390. package/dist/cjs/src/types/persistence.js.map +0 -1
  391. package/dist/cjs/src/types/route.d.ts.map +0 -1
  392. package/dist/cjs/src/types/routing.d.ts.map +0 -1
  393. package/dist/cjs/src/types/schema.d.ts.map +0 -1
  394. package/dist/cjs/src/types/session.d.ts.map +0 -1
  395. package/dist/cjs/src/types/session.js.map +0 -1
  396. package/dist/cjs/src/types/template.d.ts +0 -30
  397. package/dist/cjs/src/types/template.d.ts.map +0 -1
  398. package/dist/cjs/src/types/tool.d.ts.map +0 -1
  399. package/dist/cjs/src/types/tool.js.map +0 -1
  400. package/dist/cjs/src/utils/clone.d.ts.map +0 -1
  401. package/dist/cjs/src/utils/clone.js.map +0 -1
  402. package/dist/cjs/src/utils/event.d.ts.map +0 -1
  403. package/dist/cjs/src/utils/event.js.map +0 -1
  404. package/dist/cjs/src/utils/history.d.ts.map +0 -1
  405. package/dist/cjs/src/utils/history.js.map +0 -1
  406. package/dist/cjs/src/utils/id.d.ts.map +0 -1
  407. package/dist/cjs/src/utils/id.js.map +0 -1
  408. package/dist/cjs/src/utils/index.d.ts.map +0 -1
  409. package/dist/cjs/src/utils/index.js.map +0 -1
  410. package/dist/cjs/src/utils/logger.d.ts.map +0 -1
  411. package/dist/cjs/src/utils/logger.js.map +0 -1
  412. package/dist/cjs/src/utils/retry.d.ts.map +0 -1
  413. package/dist/cjs/src/utils/retry.js.map +0 -1
  414. package/dist/cjs/src/utils/session.d.ts.map +0 -1
  415. package/dist/cjs/src/utils/session.js.map +0 -1
  416. package/dist/cjs/src/utils/template.d.ts.map +0 -1
  417. package/dist/cjs/src/utils/template.js.map +0 -1
  418. package/dist/src/adapters/MemoryAdapter.js.map +0 -1
  419. package/dist/src/adapters/MongoAdapter.js.map +0 -1
  420. package/dist/src/adapters/OpenSearchAdapter.js.map +0 -1
  421. package/dist/src/adapters/PostgreSQLAdapter.js.map +0 -1
  422. package/dist/src/adapters/PrismaAdapter.js.map +0 -1
  423. package/dist/src/adapters/RedisAdapter.js.map +0 -1
  424. package/dist/src/adapters/SQLiteAdapter.js.map +0 -1
  425. package/dist/src/adapters/index.js.map +0 -1
  426. package/dist/src/constants/index.js.map +0 -1
  427. package/dist/src/core/Agent.d.ts.map +0 -1
  428. package/dist/src/core/Agent.js.map +0 -1
  429. package/dist/src/core/Events.js.map +0 -1
  430. package/dist/src/core/PersistenceManager.js.map +0 -1
  431. package/dist/src/core/PromptComposer.d.ts.map +0 -1
  432. package/dist/src/core/PromptComposer.js.map +0 -1
  433. package/dist/src/core/ResponseEngine.js +0 -80
  434. package/dist/src/core/ResponseEngine.js.map +0 -1
  435. package/dist/src/core/ResponseModal.d.ts.map +0 -1
  436. package/dist/src/core/ResponseModal.js.map +0 -1
  437. package/dist/src/core/ResponsePipeline.d.ts.map +0 -1
  438. package/dist/src/core/ResponsePipeline.js.map +0 -1
  439. package/dist/src/core/Route.d.ts.map +0 -1
  440. package/dist/src/core/Route.js.map +0 -1
  441. package/dist/src/core/RoutingEngine.d.ts.map +0 -1
  442. package/dist/src/core/RoutingEngine.js.map +0 -1
  443. package/dist/src/core/SessionManager.js.map +0 -1
  444. package/dist/src/core/Step.d.ts.map +0 -1
  445. package/dist/src/core/Step.js.map +0 -1
  446. package/dist/src/core/ToolManager.js.map +0 -1
  447. package/dist/src/index.d.ts.map +0 -1
  448. package/dist/src/index.js.map +0 -1
  449. package/dist/src/providers/AnthropicProvider.js.map +0 -1
  450. package/dist/src/providers/GeminiProvider.js.map +0 -1
  451. package/dist/src/providers/OpenAIProvider.js.map +0 -1
  452. package/dist/src/providers/OpenRouterProvider.js.map +0 -1
  453. package/dist/src/providers/index.js.map +0 -1
  454. package/dist/src/types/agent.d.ts.map +0 -1
  455. package/dist/src/types/agent.js.map +0 -1
  456. package/dist/src/types/history.js.map +0 -1
  457. package/dist/src/types/index.js.map +0 -1
  458. package/dist/src/types/persistence.js.map +0 -1
  459. package/dist/src/types/route.d.ts.map +0 -1
  460. package/dist/src/types/template.d.ts +0 -30
  461. package/dist/src/types/template.d.ts.map +0 -1
  462. package/dist/src/types/tool.js.map +0 -1
  463. package/dist/src/utils/clone.js.map +0 -1
  464. package/dist/src/utils/event.js.map +0 -1
  465. package/dist/src/utils/history.js.map +0 -1
  466. package/dist/src/utils/id.js.map +0 -1
  467. package/dist/src/utils/index.d.ts.map +0 -1
  468. package/dist/src/utils/index.js.map +0 -1
  469. package/dist/src/utils/logger.js.map +0 -1
  470. package/dist/src/utils/retry.d.ts.map +0 -1
  471. package/dist/src/utils/retry.js.map +0 -1
  472. package/dist/src/utils/session.js.map +0 -1
  473. package/dist/src/utils/template.d.ts.map +0 -1
  474. package/dist/src/utils/template.js.map +0 -1
  475. /package/dist/{cjs/src/adapters → adapters}/MemoryAdapter.d.ts +0 -0
  476. /package/dist/{src/adapters → adapters}/MemoryAdapter.js +0 -0
  477. /package/dist/{cjs/src/adapters → adapters}/MongoAdapter.d.ts +0 -0
  478. /package/dist/{src/adapters → adapters}/MongoAdapter.js +0 -0
  479. /package/dist/{cjs/src/adapters → adapters}/OpenSearchAdapter.d.ts +0 -0
  480. /package/dist/{src/adapters → adapters}/OpenSearchAdapter.js +0 -0
  481. /package/dist/{cjs/src/adapters → adapters}/PostgreSQLAdapter.d.ts +0 -0
  482. /package/dist/{src/adapters → adapters}/PostgreSQLAdapter.js +0 -0
  483. /package/dist/{cjs/src/adapters → adapters}/PrismaAdapter.d.ts +0 -0
  484. /package/dist/{cjs/src/adapters → adapters}/RedisAdapter.d.ts +0 -0
  485. /package/dist/{cjs/src/adapters → adapters}/SQLiteAdapter.d.ts +0 -0
  486. /package/dist/{src/adapters → adapters}/SQLiteAdapter.js +0 -0
  487. /package/dist/{cjs/src/adapters → adapters}/index.d.ts +0 -0
  488. /package/dist/{src/adapters → adapters}/index.js +0 -0
  489. /package/dist/{src → cjs}/adapters/MemoryAdapter.d.ts +0 -0
  490. /package/dist/{src → cjs}/adapters/MemoryAdapter.d.ts.map +0 -0
  491. /package/dist/cjs/{src/adapters → adapters}/MemoryAdapter.js +0 -0
  492. /package/dist/{src → cjs}/adapters/MongoAdapter.d.ts +0 -0
  493. /package/dist/{src → cjs}/adapters/MongoAdapter.d.ts.map +0 -0
  494. /package/dist/cjs/{src/adapters → adapters}/MongoAdapter.js +0 -0
  495. /package/dist/{src → cjs}/adapters/OpenSearchAdapter.d.ts +0 -0
  496. /package/dist/{src → cjs}/adapters/OpenSearchAdapter.d.ts.map +0 -0
  497. /package/dist/cjs/{src/adapters → adapters}/OpenSearchAdapter.js +0 -0
  498. /package/dist/{src → cjs}/adapters/PostgreSQLAdapter.d.ts +0 -0
  499. /package/dist/{src → cjs}/adapters/PostgreSQLAdapter.d.ts.map +0 -0
  500. /package/dist/cjs/{src/adapters → adapters}/PostgreSQLAdapter.js +0 -0
  501. /package/dist/{src → cjs}/adapters/PrismaAdapter.d.ts +0 -0
  502. /package/dist/{src → cjs}/adapters/RedisAdapter.d.ts +0 -0
  503. /package/dist/{src → cjs}/adapters/RedisAdapter.d.ts.map +0 -0
  504. /package/dist/{src → cjs}/adapters/SQLiteAdapter.d.ts +0 -0
  505. /package/dist/{src → cjs}/adapters/SQLiteAdapter.d.ts.map +0 -0
  506. /package/dist/cjs/{src/adapters → adapters}/SQLiteAdapter.js +0 -0
  507. /package/dist/{src → cjs}/adapters/index.d.ts +0 -0
  508. /package/dist/{src → cjs}/adapters/index.d.ts.map +0 -0
  509. /package/dist/cjs/{src/adapters → adapters}/index.js +0 -0
  510. /package/dist/cjs/{src/constants → constants}/index.d.ts +0 -0
  511. /package/dist/{src → cjs}/constants/index.d.ts.map +0 -0
  512. /package/dist/cjs/{src/constants → constants}/index.js +0 -0
  513. /package/dist/cjs/{src/core → core}/Events.d.ts +0 -0
  514. /package/dist/{src → cjs}/core/Events.d.ts.map +0 -0
  515. /package/dist/cjs/{src/core → core}/Events.js +0 -0
  516. /package/dist/cjs/{src/core → core}/PersistenceManager.d.ts +0 -0
  517. /package/dist/{src → cjs}/core/PersistenceManager.d.ts.map +0 -0
  518. /package/dist/cjs/{src/core → core}/PersistenceManager.js +0 -0
  519. /package/dist/cjs/{src/core → core}/ResponseEngine.d.ts +0 -0
  520. /package/dist/cjs/{src/core → core}/SessionManager.d.ts +0 -0
  521. /package/dist/{src → cjs}/core/SessionManager.d.ts.map +0 -0
  522. /package/dist/cjs/{src/core → core}/SessionManager.js +0 -0
  523. /package/dist/cjs/{src/core → core}/ToolManager.d.ts +0 -0
  524. /package/dist/{src → cjs}/core/ToolManager.d.ts.map +0 -0
  525. /package/dist/cjs/{src/core → core}/ToolManager.js +0 -0
  526. /package/dist/cjs/{src/providers → providers}/AnthropicProvider.d.ts +0 -0
  527. /package/dist/{src → cjs}/providers/AnthropicProvider.d.ts.map +0 -0
  528. /package/dist/cjs/{src/providers → providers}/GeminiProvider.d.ts +0 -0
  529. /package/dist/cjs/{src/providers → providers}/OpenAIProvider.d.ts +0 -0
  530. /package/dist/{src → cjs}/providers/OpenAIProvider.d.ts.map +0 -0
  531. /package/dist/cjs/{src/providers → providers}/OpenRouterProvider.d.ts +0 -0
  532. /package/dist/{src → cjs}/providers/OpenRouterProvider.d.ts.map +0 -0
  533. /package/dist/cjs/{src/providers → providers}/index.d.ts +0 -0
  534. /package/dist/{src → cjs}/providers/index.d.ts.map +0 -0
  535. /package/dist/cjs/{src/providers → providers}/index.js +0 -0
  536. /package/dist/cjs/{src/types → types}/agent.js +0 -0
  537. /package/dist/cjs/{src/types → types}/ai.d.ts +0 -0
  538. /package/dist/{src → cjs}/types/ai.d.ts.map +0 -0
  539. /package/dist/cjs/{src/types → types}/ai.js +0 -0
  540. /package/dist/cjs/{src/types → types}/history.d.ts +0 -0
  541. /package/dist/{src → cjs}/types/history.d.ts.map +0 -0
  542. /package/dist/cjs/{src/types → types}/history.js +0 -0
  543. /package/dist/cjs/{src/types → types}/persistence.d.ts +0 -0
  544. /package/dist/{src → cjs}/types/persistence.d.ts.map +0 -0
  545. /package/dist/cjs/{src/types → types}/persistence.js +0 -0
  546. /package/dist/cjs/{src/types → types}/route.js +0 -0
  547. /package/dist/cjs/{src/types → types}/routing.d.ts +0 -0
  548. /package/dist/{src → cjs}/types/routing.d.ts.map +0 -0
  549. /package/dist/cjs/{src/types → types}/routing.js +0 -0
  550. /package/dist/{src → cjs}/types/routing.js.map +0 -0
  551. /package/dist/cjs/{src/types → types}/schema.d.ts +0 -0
  552. /package/dist/{src → cjs}/types/schema.d.ts.map +0 -0
  553. /package/dist/cjs/{src/types → types}/schema.js +0 -0
  554. /package/dist/{src → cjs}/types/schema.js.map +0 -0
  555. /package/dist/cjs/{src/types → types}/session.d.ts +0 -0
  556. /package/dist/{src → cjs}/types/session.d.ts.map +0 -0
  557. /package/dist/cjs/{src/types → types}/session.js +0 -0
  558. /package/dist/cjs/{src/types → types}/template.js +0 -0
  559. /package/dist/{src → cjs}/types/template.js.map +0 -0
  560. /package/dist/cjs/{src/types → types}/tool.d.ts +0 -0
  561. /package/dist/{src → cjs}/types/tool.d.ts.map +0 -0
  562. /package/dist/cjs/{src/types → types}/tool.js +0 -0
  563. /package/dist/cjs/{src/utils → utils}/clone.d.ts +0 -0
  564. /package/dist/{src → cjs}/utils/clone.d.ts.map +0 -0
  565. /package/dist/cjs/{src/utils → utils}/clone.js +0 -0
  566. /package/dist/cjs/{src/utils → utils}/event.d.ts +0 -0
  567. /package/dist/{src → cjs}/utils/event.d.ts.map +0 -0
  568. /package/dist/cjs/{src/utils → utils}/event.js +0 -0
  569. /package/dist/cjs/{src/utils → utils}/history.d.ts +0 -0
  570. /package/dist/{src → cjs}/utils/history.d.ts.map +0 -0
  571. /package/dist/cjs/{src/utils → utils}/history.js +0 -0
  572. /package/dist/cjs/{src/utils → utils}/id.d.ts +0 -0
  573. /package/dist/{src → cjs}/utils/id.d.ts.map +0 -0
  574. /package/dist/cjs/{src/utils → utils}/id.js +0 -0
  575. /package/dist/cjs/{src/utils → utils}/logger.d.ts +0 -0
  576. /package/dist/{src → cjs}/utils/logger.d.ts.map +0 -0
  577. /package/dist/cjs/{src/utils → utils}/logger.js +0 -0
  578. /package/dist/cjs/{src/utils → utils}/session.d.ts +0 -0
  579. /package/dist/{src → cjs}/utils/session.d.ts.map +0 -0
  580. /package/dist/cjs/{src/utils → utils}/session.js +0 -0
  581. /package/dist/{src/constants → constants}/index.d.ts +0 -0
  582. /package/dist/{src/constants → constants}/index.js +0 -0
  583. /package/dist/{src/core → core}/Events.d.ts +0 -0
  584. /package/dist/{src/core → core}/Events.js +0 -0
  585. /package/dist/{src/core → core}/PersistenceManager.d.ts +0 -0
  586. /package/dist/{src/core → core}/PersistenceManager.js +0 -0
  587. /package/dist/{src/core → core}/ResponseEngine.d.ts +0 -0
  588. /package/dist/{src/core → core}/SessionManager.d.ts +0 -0
  589. /package/dist/{src/core → core}/SessionManager.js +0 -0
  590. /package/dist/{src/core → core}/ToolManager.d.ts +0 -0
  591. /package/dist/{src/core → core}/ToolManager.js +0 -0
  592. /package/dist/{src/providers → providers}/AnthropicProvider.d.ts +0 -0
  593. /package/dist/{src/providers → providers}/GeminiProvider.d.ts +0 -0
  594. /package/dist/{src/providers → providers}/OpenAIProvider.d.ts +0 -0
  595. /package/dist/{src/providers → providers}/OpenRouterProvider.d.ts +0 -0
  596. /package/dist/{src/providers → providers}/index.d.ts +0 -0
  597. /package/dist/{src/providers → providers}/index.js +0 -0
  598. /package/dist/{src/types → types}/agent.js +0 -0
  599. /package/dist/{src/types → types}/ai.d.ts +0 -0
  600. /package/dist/{src/types → types}/ai.js +0 -0
  601. /package/dist/{src/types → types}/history.d.ts +0 -0
  602. /package/dist/{src/types → types}/history.js +0 -0
  603. /package/dist/{src/types → types}/persistence.d.ts +0 -0
  604. /package/dist/{src/types → types}/persistence.js +0 -0
  605. /package/dist/{src/types → types}/route.js +0 -0
  606. /package/dist/{src/types → types}/routing.d.ts +0 -0
  607. /package/dist/{src/types → types}/routing.js +0 -0
  608. /package/dist/{src/types → types}/schema.d.ts +0 -0
  609. /package/dist/{src/types → types}/schema.js +0 -0
  610. /package/dist/{src/types → types}/session.d.ts +0 -0
  611. /package/dist/{src/types → types}/session.js +0 -0
  612. /package/dist/{src/types → types}/template.js +0 -0
  613. /package/dist/{src/types → types}/tool.d.ts +0 -0
  614. /package/dist/{src/types → types}/tool.js +0 -0
  615. /package/dist/{src/utils → utils}/clone.d.ts +0 -0
  616. /package/dist/{src/utils → utils}/clone.js +0 -0
  617. /package/dist/{src/utils → utils}/event.d.ts +0 -0
  618. /package/dist/{src/utils → utils}/event.js +0 -0
  619. /package/dist/{src/utils → utils}/history.d.ts +0 -0
  620. /package/dist/{src/utils → utils}/history.js +0 -0
  621. /package/dist/{src/utils → utils}/id.d.ts +0 -0
  622. /package/dist/{src/utils → utils}/id.js +0 -0
  623. /package/dist/{src/utils → utils}/logger.d.ts +0 -0
  624. /package/dist/{src/utils → utils}/logger.js +0 -0
  625. /package/dist/{src/utils → utils}/session.d.ts +0 -0
  626. /package/dist/{src/utils → utils}/session.js +0 -0
@@ -0,0 +1,363 @@
1
+ # Data Extraction Flow Architecture
2
+
3
+ ## Overview
4
+
5
+ @falai/agent uses an **intelligent pre-extraction system** that captures data from user messages BEFORE entering conversation steps. This eliminates repetitive questions and creates efficient, natural conversations.
6
+
7
+ ## The Problem with Traditional Approaches
8
+
9
+ Traditional conversational AI follows a rigid step-by-step approach:
10
+
11
+ ```
12
+ User: "I want to book the Grand Hotel for 2 people next Friday"
13
+
14
+ Traditional Flow:
15
+ Step 1: "Which hotel?" → User already said this!
16
+ Step 2: "How many guests?" → User already said this!
17
+ Step 3: "What date?" → User already said this!
18
+ ```
19
+
20
+ This wastes user time and creates frustration.
21
+
22
+ ## Our Solution: Pre-Extraction + Smart Step Selection
23
+
24
+ ### Phase 1: Route Selection & Pre-Extraction
25
+
26
+ When a user message arrives:
27
+
28
+ 1. **Route Evaluation** - AI scores all routes based on user intent
29
+ 2. **Route Selection** - Best matching route is selected
30
+ 3. **Pre-Extraction** - If entering a NEW route that collects data:
31
+ - AI extracts ALL relevant data from the message
32
+ - Data is validated against the agent schema
33
+ - Collected data is merged into session
34
+
35
+ ```typescript
36
+ // User: "I want to book the Grand Hotel for 2 people next Friday"
37
+
38
+ // Pre-extraction automatically captures:
39
+ {
40
+ hotelName: "Grand Hotel",
41
+ guests: 2,
42
+ date: "next Friday"
43
+ }
44
+ ```
45
+
46
+ ### Phase 2: Route Completion Check
47
+
48
+ After pre-extraction, the system checks if the route is complete:
49
+
50
+ ```typescript
51
+ // Route defines required fields
52
+ agent.createRoute({
53
+ title: "Book Hotel",
54
+ requiredFields: ["hotelName", "guests", "date"],
55
+ // ...
56
+ });
57
+
58
+ // After pre-extraction, all required fields are present
59
+ // Route is marked as COMPLETE immediately
60
+ ```
61
+
62
+ **Key Insight:** Routes complete when `requiredFields` are collected, NOT when reaching END_ROUTE step.
63
+
64
+ ### Phase 3: Smart Step Selection
65
+
66
+ If route is NOT complete, determine which step to start at:
67
+
68
+ ```typescript
69
+ // Steps with skipIf conditions
70
+ steps: [
71
+ {
72
+ id: "ask_hotel",
73
+ collect: ["hotelName"],
74
+ skipIf: (data) => !!data.hotelName // ✅ SKIP - already have it
75
+ },
76
+ {
77
+ id: "ask_guests",
78
+ collect: ["guests"],
79
+ skipIf: (data) => data.guests !== undefined // ✅ SKIP - already have it
80
+ },
81
+ {
82
+ id: "ask_date",
83
+ collect: ["date"],
84
+ skipIf: (data) => !!data.date // ✅ SKIP - already have it
85
+ }
86
+ ]
87
+
88
+ // Result: All steps skipped → Route complete
89
+ ```
90
+
91
+ ### Phase 4: Response Generation
92
+
93
+ **If route is complete:**
94
+ - Generate completion message
95
+ - Mark step as END_ROUTE
96
+ - Exclude route from future selection
97
+
98
+ **If route is NOT complete:**
99
+ - Enter the first non-skipped step
100
+ - Generate response asking for missing data
101
+ - Continue conversation
102
+
103
+ ## Complete Flow Example
104
+
105
+ ### Scenario: User provides all data at once
106
+
107
+ ```typescript
108
+ // Turn 1
109
+ User: "I want to book the Grand Hotel for 2 people next Friday"
110
+
111
+ System:
112
+ 1. Routes to "Book Hotel" (AI scoring)
113
+ 2. Pre-extracts: { hotelName: "Grand Hotel", guests: 2, date: "next Friday" }
114
+ 3. Checks completion: All required fields present ✓
115
+ 4. Generates completion message
116
+ 5. Marks route as complete
117
+
118
+ AI: "Perfect! Booking confirmed for 2 guests at Grand Hotel on Friday!"
119
+
120
+ // Turn 2
121
+ User: "I'm feeling anxious about my visit"
122
+
123
+ System:
124
+ 1. Evaluates routes
125
+ 2. Excludes "Book Hotel" (already complete)
126
+ 3. Routes to "General Healthcare Questions"
127
+ 4. Generates response
128
+
129
+ AI: "I understand you're feeling anxious. How can I help?"
130
+ ```
131
+
132
+ ### Scenario: User provides partial data
133
+
134
+ ```typescript
135
+ // Turn 1
136
+ User: "I want to book the Grand Hotel"
137
+
138
+ System:
139
+ 1. Routes to "Book Hotel"
140
+ 2. Pre-extracts: { hotelName: "Grand Hotel" }
141
+ 3. Checks completion: Missing guests and date ✗
142
+ 4. Evaluates steps:
143
+ - ask_hotel: SKIP (have hotelName)
144
+ - ask_guests: ENTER (need guests)
145
+ 5. Enters ask_guests step
146
+
147
+ AI: "How many guests will be staying?"
148
+
149
+ // Turn 2
150
+ User: "2 people next Friday"
151
+
152
+ System:
153
+ 1. Already in "Book Hotel" route
154
+ 2. Pre-extracts: { guests: 2, date: "next Friday" }
155
+ 3. Checks completion: All required fields present ✓
156
+ 4. Generates completion message
157
+
158
+ AI: "Booking confirmed for 2 guests at Grand Hotel on Friday!"
159
+ ```
160
+
161
+ ## Key Design Decisions
162
+
163
+ ### 1. Pre-Extraction Triggers
164
+
165
+ Pre-extraction only happens when:
166
+ - Entering a NEW route (not already in it)
167
+ - Route has `requiredFields`, `optionalFields`, OR steps with `collect` arrays
168
+
169
+ This minimizes unnecessary AI calls for purely conversational routes.
170
+
171
+ ### 2. Route Completion Logic
172
+
173
+ A route is complete when:
174
+ - **All `requiredFields` are collected**, OR
175
+ - **Reached END_ROUTE marker in step flow**
176
+
177
+ Whichever comes first.
178
+
179
+ ### 3. Completed Route Exclusion
180
+
181
+ Once a route is 100% complete:
182
+ - It's excluded from future route selection
183
+ - Users won't be forced back into finished tasks
184
+ - System falls back to other routes or general conversation
185
+
186
+ ### 4. Step Skipping Logic
187
+
188
+ Steps are skipped when:
189
+ - `skipIf` condition evaluates to true
190
+ - `requires` fields are not yet collected
191
+ - Data for `collect` fields is already present
192
+
193
+ ## Configuration
194
+
195
+ ### Enable Pre-Extraction
196
+
197
+ Pre-extraction is automatic when you define:
198
+
199
+ ```typescript
200
+ // Option 1: Route-level required fields
201
+ agent.createRoute({
202
+ title: "Booking",
203
+ requiredFields: ["hotel", "date", "guests"],
204
+ // Pre-extraction enabled automatically
205
+ });
206
+
207
+ // Option 2: Route-level optional fields
208
+ agent.createRoute({
209
+ title: "Booking",
210
+ optionalFields: ["specialRequests"],
211
+ // Pre-extraction enabled automatically
212
+ });
213
+
214
+ // Option 3: Steps with collect arrays
215
+ agent.createRoute({
216
+ title: "Booking",
217
+ steps: [
218
+ {
219
+ id: "ask_hotel",
220
+ collect: ["hotel"], // Pre-extraction enabled automatically
221
+ }
222
+ ]
223
+ });
224
+ ```
225
+
226
+ ### Disable Pre-Extraction
227
+
228
+ For purely conversational routes (no data collection):
229
+
230
+ ```typescript
231
+ agent.createRoute({
232
+ title: "General Chat",
233
+ // No requiredFields, optionalFields, or collect arrays
234
+ // Pre-extraction skipped automatically
235
+ steps: [
236
+ {
237
+ id: "chat",
238
+ prompt: "Have a friendly conversation"
239
+ // No collect array
240
+ }
241
+ ]
242
+ });
243
+ ```
244
+
245
+ ## Performance Considerations
246
+
247
+ ### AI Call Optimization
248
+
249
+ Pre-extraction adds ONE additional AI call when entering a new data-collecting route:
250
+
251
+ ```
252
+ Traditional: N calls (one per step)
253
+ With Pre-Extraction: 1 + M calls (pre-extract + remaining steps)
254
+
255
+ Where M ≤ N (often M = 0 if all data extracted)
256
+ ```
257
+
258
+ **Net Result:** Usually FEWER total AI calls due to step skipping.
259
+
260
+ ### When to Use Pre-Extraction
261
+
262
+ ✅ **Use for:** Data collection flows (booking, forms, surveys)
263
+ ✅ **Use for:** Multi-field information gathering
264
+ ❌ **Skip for:** Pure Q&A or conversational routes
265
+ ❌ **Skip for:** Single-field collection
266
+
267
+ ## Advanced Patterns
268
+
269
+ ### Optional Fields
270
+
271
+ ```typescript
272
+ agent.createRoute({
273
+ title: "Booking",
274
+ requiredFields: ["hotel", "date"],
275
+ optionalFields: ["specialRequests", "dietaryRestrictions"],
276
+
277
+ // Route completes when required fields are collected
278
+ // Optional fields can be collected if user provides them
279
+ // But won't block completion
280
+ });
281
+ ```
282
+
283
+ ### Conditional Completion
284
+
285
+ ```typescript
286
+ agent.createRoute({
287
+ title: "Order",
288
+ requiredFields: ["items", "address"],
289
+
290
+ steps: [
291
+ // ... collection steps ...
292
+ {
293
+ id: "payment",
294
+ when: "Ready to process payment",
295
+ skipIf: (data) => data.paymentComplete,
296
+ // This step runs AFTER required fields are collected
297
+ // Allows post-completion actions
298
+ }
299
+ ]
300
+ });
301
+ ```
302
+
303
+ ### Progressive Disclosure
304
+
305
+ ```typescript
306
+ agent.createRoute({
307
+ title: "Support",
308
+ requiredFields: ["issueType"],
309
+ optionalFields: ["accountNumber", "orderNumber"],
310
+
311
+ steps: [
312
+ {
313
+ id: "ask_issue",
314
+ collect: ["issueType"],
315
+ },
316
+ {
317
+ id: "ask_account",
318
+ collect: ["accountNumber"],
319
+ when: (data) => data.issueType === "account",
320
+ // Only ask for account if issue is account-related
321
+ }
322
+ ]
323
+ });
324
+ ```
325
+
326
+ ## Debugging
327
+
328
+ Enable debug logging to see the extraction flow:
329
+
330
+ ```typescript
331
+ const agent = new Agent({
332
+ name: "Assistant",
333
+ provider: new GeminiProvider({ apiKey: "..." }),
334
+ debug: true // Enable detailed logging
335
+ });
336
+ ```
337
+
338
+ Look for these log messages:
339
+
340
+ ```
341
+ [ResponseModal] Pre-extracting data for route: Book Hotel
342
+ [ResponseModal] Pre-extracted data: { hotelName: "Grand Hotel", ... }
343
+ [ResponseModal] Route Book Hotel completed after pre-extraction
344
+ [RoutingEngine] Excluding completed route: Book Hotel (100% complete)
345
+ ```
346
+
347
+ ## Summary
348
+
349
+ The pre-extraction system creates efficient conversations by:
350
+
351
+ 1. **Extracting data early** - Before entering steps
352
+ 2. **Skipping unnecessary steps** - When data is already present
353
+ 3. **Completing automatically** - When required fields are collected
354
+ 4. **Protecting completed routes** - Preventing re-entry
355
+
356
+ This results in natural, efficient conversations that respect user time.
357
+
358
+ ---
359
+
360
+ **Next Steps:**
361
+ - [Route Configuration](../core/conversation-flows/routes.md)
362
+ - [Step Configuration](../core/conversation-flows/steps.md)
363
+ - [Schema Design](../guides/building-agents/schema-design.md)
@@ -0,0 +1,243 @@
1
+ # Multi-Step Execution Architecture
2
+
3
+ ## Overview
4
+
5
+ @falai/agent supports **multi-step execution**, enabling multiple consecutive Steps to execute in a single LLM call. This reduces unnecessary multi-turn conversations, minimizes LLM costs, and improves user experience when steps don't require new user input.
6
+
7
+ The core insight is simple: **if a Step's data requirements are already satisfied, there's no reason to pause and wait for user input**. By detecting which Steps can execute together and combining them into a single batch, we reduce LLM calls while improving conversation UX.
8
+
9
+ ## Design Priorities
10
+
11
+ 1. **Conversation UX** - Reduce unnecessary back-and-forth
12
+ 2. **LLM Cost Optimization** - Fewer calls for the same outcome
13
+ 3. **Predictability** - Clear, simple rules for when execution pauses
14
+ 4. **Framework Understandability** - Keep the Step/Route mental model intact
15
+
16
+ ## Batch Execution Flow
17
+
18
+ ```mermaid
19
+ flowchart TD
20
+ A[User Message] --> B[Pre-Extraction]
21
+ B --> C[Batch Determination]
22
+ C --> D{More Steps?}
23
+ D -->|Yes| E[Evaluate Step]
24
+ E --> F{Needs Input?}
25
+ F -->|No| G[Add to Batch]
26
+ G --> D
27
+ F -->|Yes| H[Stop Batch]
28
+ D -->|No| H
29
+ H --> I[Execute Prepare Hooks]
30
+ I --> J[Build Combined Prompt]
31
+ J --> K[Single LLM Call]
32
+ K --> L[Extract Response Data]
33
+ L --> M[Execute Finalize Hooks]
34
+ M --> N[Update Session]
35
+ N --> O[Return Response]
36
+ ```
37
+
38
+ ## Execution Phases
39
+
40
+ ### Phase 1: Pre-Extraction
41
+
42
+ When processing a user message, the engine performs **pre-extraction** before determining the batch. This phase:
43
+
44
+ 1. Attempts to extract data for all fields defined in the Route's `requiredFields` and `optionalFields`
45
+ 2. Merges pre-extracted data into session data
46
+ 3. Maximizes batching by satisfying Step requirements upfront
47
+
48
+ ```typescript
49
+ // User: "I want to book the Grand Hotel for 2 people next Friday"
50
+
51
+ // Pre-extraction automatically captures:
52
+ {
53
+ hotelName: "Grand Hotel",
54
+ guests: 2,
55
+ date: "next Friday"
56
+ }
57
+ ```
58
+
59
+ ### Phase 2: Batch Determination
60
+
61
+ The `BatchExecutor` walks through Steps using this algorithm:
62
+
63
+ ```
64
+ For each Step starting from current position:
65
+ a. Check if it's END_ROUTE → stop with 'end_route'
66
+ b. Evaluate skipIf condition
67
+ c. If skipIf is true → skip Step, continue to next
68
+ d. If skipIf throws error → treat as non-skippable
69
+ e. Evaluate needsInput(step, sessionDataAfterPreExtraction)
70
+ f. If needsInput is false → include Step in batch, continue to next
71
+ g. If needsInput is true → stop with 'needs_input'
72
+ ```
73
+
74
+ ### Phase 3: Hook Execution (Prepare)
75
+
76
+ Before the LLM call, all `prepare` hooks for batched Steps execute in Step order. If any prepare hook fails, batch execution stops immediately.
77
+
78
+ ### Phase 4: LLM Call
79
+
80
+ A single LLM call is made with a combined prompt that includes all Step prompts and collect fields.
81
+
82
+ ### Phase 5: Data Collection
83
+
84
+ All `collect` fields from all Steps in the batch are extracted from the LLM response and validated against the agent schema.
85
+
86
+ ### Phase 6: Hook Execution (Finalize)
87
+
88
+ After the LLM response, all `finalize` hooks execute in Step order. Finalize hook failures are logged but don't stop execution.
89
+
90
+ ## Needs-Input Detection Algorithm
91
+
92
+ The `needsInput` function implements the core execution rule:
93
+
94
+ ```typescript
95
+ function needsInput<TData>(
96
+ step: Step<unknown, TData>,
97
+ sessionDataAfterPreExtraction: Partial<TData>
98
+ ): boolean {
99
+ // Check requires - all must be present (after pre-extraction)
100
+ if (step.requires && step.requires.length > 0) {
101
+ const missingRequired = step.requires.some(
102
+ field => sessionDataAfterPreExtraction[field] === undefined
103
+ );
104
+ if (missingRequired) return true;
105
+ }
106
+
107
+ // Check collect - needs input if collecting and no data exists (after pre-extraction)
108
+ if (step.collect && step.collect.length > 0) {
109
+ const hasAnyCollectData = step.collect.some(
110
+ field => sessionDataAfterPreExtraction[field] !== undefined
111
+ );
112
+ if (!hasAnyCollectData) return true;
113
+ }
114
+
115
+ return false;
116
+ }
117
+ ```
118
+
119
+ A Step **needs input** when:
120
+
121
+ 1. It has `requires` fields and at least one is missing from session data (after pre-extraction)
122
+ 2. It has non-empty `collect` fields and none of those fields have data (after pre-extraction)
123
+
124
+ ## Pre-Extraction's Role in Batching
125
+
126
+ Pre-extraction is critical for maximizing batch size. Consider this scenario:
127
+
128
+ ```typescript
129
+ // Route with 3 steps
130
+ const route = agent.createRoute({
131
+ title: "Booking",
132
+ requiredFields: ["hotel", "date", "guests"],
133
+ steps: [
134
+ { prompt: "Which hotel?", collect: ["hotel"] },
135
+ { prompt: "What date?", collect: ["date"] },
136
+ { prompt: "How many guests?", collect: ["guests"] }
137
+ ]
138
+ });
139
+
140
+ // User message: "Book Grand Hotel for 2 people on Friday"
141
+ ```
142
+
143
+ **Without pre-extraction:**
144
+ - Step 1 needs input (no hotel data) → batch stops
145
+ - 3 separate LLM calls needed
146
+
147
+ **With pre-extraction:**
148
+ - Pre-extraction captures: `{ hotel: "Grand Hotel", date: "Friday", guests: 2 }`
149
+ - All steps have their data satisfied
150
+ - All 3 steps execute in a single batch
151
+ - 1 LLM call needed
152
+
153
+ ## Key Components
154
+
155
+ ### BatchExecutor
156
+
157
+ The core component responsible for:
158
+ - Determining which Steps can execute together (`determineBatch`)
159
+ - Executing prepare/finalize hooks (`executePrepareHooks`, `executeFinalizeHooks`)
160
+ - Collecting data from LLM responses (`collectBatchData`)
161
+ - Orchestrating complete batch execution (`executeBatch`)
162
+
163
+ ### BatchPromptBuilder
164
+
165
+ Combines multiple Step prompts into a single coherent prompt:
166
+ - Preserves each Step's individual prompt intent
167
+ - Includes data collection instructions for all `collect` fields
168
+ - Produces a single LLM call regardless of Step count
169
+
170
+ ## Example: Multi-Step Batch
171
+
172
+ ```typescript
173
+ // User provides all booking info at once
174
+ const response = await agent.respond(
175
+ "I want to book the Grand Hotel for 2 people next Friday"
176
+ );
177
+
178
+ // Response includes:
179
+ {
180
+ message: "Perfect! I've booked the Grand Hotel for 2 guests on Friday.",
181
+ executedSteps: [
182
+ { id: "ask-hotel", routeId: "booking" },
183
+ { id: "ask-date", routeId: "booking" },
184
+ { id: "ask-guests", routeId: "booking" }
185
+ ],
186
+ stoppedReason: "route_complete",
187
+ session: {
188
+ data: {
189
+ hotel: "Grand Hotel",
190
+ date: "Friday",
191
+ guests: 2
192
+ }
193
+ }
194
+ }
195
+ ```
196
+
197
+ ## Debugging
198
+
199
+ Enable debug mode to see batch execution decisions:
200
+
201
+ ```typescript
202
+ const agent = new Agent({
203
+ name: "Assistant",
204
+ provider: provider,
205
+ debug: true // Enable detailed logging
206
+ });
207
+ ```
208
+
209
+ Look for these log messages:
210
+
211
+ ```
212
+ [BatchExecutor] Starting batch determination from step index 0
213
+ [BatchExecutor] Including step ask-hotel in batch (all requirements satisfied)
214
+ [BatchExecutor] Including step ask-date in batch (all requirements satisfied)
215
+ [BatchExecutor] Step ask-guests needs input, stopping batch
216
+ [BatchExecutor] Batch determination complete. Steps: 2, Stopped reason: needs_input
217
+ ```
218
+
219
+ ## Event Emission
220
+
221
+ The BatchExecutor emits events for observability:
222
+
223
+ - `batch_start` - When batch determination begins
224
+ - `step_included` - When a step is included in the batch
225
+ - `step_skipped` - When a step is skipped (due to skipIf)
226
+ - `batch_stop` - When batch determination stops
227
+ - `batch_complete` - When batch execution completes
228
+
229
+ ```typescript
230
+ const executor = new BatchExecutor();
231
+
232
+ executor.addEventListener((event) => {
233
+ console.log(`[${event.type}]`, event.details);
234
+ });
235
+ ```
236
+
237
+ ---
238
+
239
+ **Related Documentation:**
240
+ - [Steps](../core/conversation-flows/steps.md) - Step configuration and batching
241
+ - [Step Transitions](../core/conversation-flows/step-transitions.md) - Stopping conditions
242
+ - [Data Collection](../core/conversation-flows/data-collection.md) - Pre-extraction details
243
+ - [Prompt Composition](../core/ai-integration/prompt-composition.md) - Combined prompts