@falai/agent 0.8.1 → 0.9.0-alpha-2

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 (665) hide show
  1. package/README.md +332 -147
  2. package/dist/{adapters → cjs/src/adapters}/MemoryAdapter.d.ts +4 -4
  3. package/dist/cjs/src/adapters/MemoryAdapter.d.ts.map +1 -0
  4. package/dist/cjs/{adapters → src/adapters}/MemoryAdapter.js +41 -21
  5. package/dist/cjs/src/adapters/MemoryAdapter.js.map +1 -0
  6. package/dist/{adapters → cjs/src/adapters}/MongoAdapter.d.ts +3 -3
  7. package/dist/cjs/src/adapters/MongoAdapter.d.ts.map +1 -0
  8. package/dist/cjs/{adapters → src/adapters}/MongoAdapter.js +2 -1
  9. package/dist/cjs/src/adapters/MongoAdapter.js.map +1 -0
  10. package/dist/cjs/{adapters → src/adapters}/OpenSearchAdapter.d.ts +3 -3
  11. package/dist/cjs/src/adapters/OpenSearchAdapter.d.ts.map +1 -0
  12. package/dist/cjs/{adapters → src/adapters}/OpenSearchAdapter.js +10 -13
  13. package/dist/cjs/src/adapters/OpenSearchAdapter.js.map +1 -0
  14. package/dist/cjs/{adapters → src/adapters}/PostgreSQLAdapter.d.ts +3 -3
  15. package/dist/cjs/src/adapters/PostgreSQLAdapter.d.ts.map +1 -0
  16. package/dist/cjs/{adapters → src/adapters}/PostgreSQLAdapter.js +1 -1
  17. package/dist/cjs/src/adapters/PostgreSQLAdapter.js.map +1 -0
  18. package/dist/cjs/{adapters → src/adapters}/PrismaAdapter.d.ts +3 -3
  19. package/dist/cjs/src/adapters/PrismaAdapter.d.ts.map +1 -0
  20. package/dist/cjs/{adapters → src/adapters}/PrismaAdapter.js +35 -5
  21. package/dist/cjs/src/adapters/PrismaAdapter.js.map +1 -0
  22. package/dist/cjs/{adapters → src/adapters}/RedisAdapter.d.ts +3 -3
  23. package/dist/cjs/src/adapters/RedisAdapter.d.ts.map +1 -0
  24. package/dist/cjs/{adapters → src/adapters}/RedisAdapter.js +3 -2
  25. package/dist/cjs/src/adapters/RedisAdapter.js.map +1 -0
  26. package/dist/{adapters → cjs/src/adapters}/SQLiteAdapter.d.ts +3 -3
  27. package/dist/cjs/src/adapters/SQLiteAdapter.d.ts.map +1 -0
  28. package/dist/cjs/{adapters → src/adapters}/SQLiteAdapter.js +2 -1
  29. package/dist/cjs/src/adapters/SQLiteAdapter.js.map +1 -0
  30. package/dist/cjs/src/adapters/index.d.ts.map +1 -0
  31. package/dist/cjs/src/adapters/index.js.map +1 -0
  32. package/dist/cjs/src/constants/index.d.ts.map +1 -0
  33. package/dist/cjs/src/constants/index.js.map +1 -0
  34. package/dist/cjs/src/core/Agent.d.ts +223 -0
  35. package/dist/cjs/src/core/Agent.d.ts.map +1 -0
  36. package/dist/cjs/src/core/Agent.js +1660 -0
  37. package/dist/cjs/src/core/Agent.js.map +1 -0
  38. package/dist/cjs/src/core/Events.d.ts +26 -0
  39. package/dist/cjs/src/core/Events.d.ts.map +1 -0
  40. package/dist/cjs/src/core/Events.js +144 -0
  41. package/dist/cjs/src/core/Events.js.map +1 -0
  42. package/dist/{core → cjs/src/core}/PersistenceManager.d.ts +21 -19
  43. package/dist/cjs/src/core/PersistenceManager.d.ts.map +1 -0
  44. package/dist/cjs/{core → src/core}/PersistenceManager.js +73 -20
  45. package/dist/cjs/src/core/PersistenceManager.js.map +1 -0
  46. package/dist/cjs/src/core/PromptComposer.d.ts +27 -0
  47. package/dist/cjs/src/core/PromptComposer.d.ts.map +1 -0
  48. package/dist/cjs/src/core/PromptComposer.js +157 -0
  49. package/dist/cjs/src/core/PromptComposer.js.map +1 -0
  50. package/dist/cjs/src/core/ResponseEngine.d.ts +32 -0
  51. package/dist/cjs/src/core/ResponseEngine.d.ts.map +1 -0
  52. package/dist/cjs/src/core/ResponseEngine.js +84 -0
  53. package/dist/cjs/src/core/ResponseEngine.js.map +1 -0
  54. package/dist/cjs/src/core/ResponsePipeline.d.ts +171 -0
  55. package/dist/cjs/src/core/ResponsePipeline.d.ts.map +1 -0
  56. package/dist/cjs/src/core/ResponsePipeline.js +514 -0
  57. package/dist/cjs/src/core/ResponsePipeline.js.map +1 -0
  58. package/dist/cjs/src/core/Route.d.ts +145 -0
  59. package/dist/cjs/src/core/Route.d.ts.map +1 -0
  60. package/dist/cjs/src/core/Route.js +343 -0
  61. package/dist/cjs/src/core/Route.js.map +1 -0
  62. package/dist/cjs/src/core/RoutingEngine.d.ts +129 -0
  63. package/dist/cjs/src/core/RoutingEngine.d.ts.map +1 -0
  64. package/dist/cjs/{core → src/core}/RoutingEngine.js +215 -117
  65. package/dist/cjs/src/core/RoutingEngine.js.map +1 -0
  66. package/dist/cjs/src/core/SessionManager.d.ts +86 -0
  67. package/dist/cjs/src/core/SessionManager.d.ts.map +1 -0
  68. package/dist/cjs/src/core/SessionManager.js +217 -0
  69. package/dist/cjs/src/core/SessionManager.js.map +1 -0
  70. package/dist/cjs/src/core/Step.d.ts +96 -0
  71. package/dist/cjs/src/core/Step.d.ts.map +1 -0
  72. package/dist/cjs/src/core/Step.js +206 -0
  73. package/dist/cjs/src/core/Step.js.map +1 -0
  74. package/dist/cjs/src/core/ToolExecutor.d.ts +45 -0
  75. package/dist/cjs/src/core/ToolExecutor.d.ts.map +1 -0
  76. package/dist/cjs/{core → src/core}/ToolExecutor.js +30 -19
  77. package/dist/cjs/src/core/ToolExecutor.js.map +1 -0
  78. package/dist/{index.d.ts → cjs/src/index.d.ts} +7 -15
  79. package/dist/cjs/src/index.d.ts.map +1 -0
  80. package/dist/cjs/{index.js → src/index.js} +21 -19
  81. package/dist/cjs/src/index.js.map +1 -0
  82. package/dist/cjs/{providers → src/providers}/AnthropicProvider.d.ts +1 -1
  83. package/dist/cjs/src/providers/AnthropicProvider.d.ts.map +1 -0
  84. package/dist/cjs/{providers → src/providers}/AnthropicProvider.js +54 -2
  85. package/dist/cjs/src/providers/AnthropicProvider.js.map +1 -0
  86. package/dist/{providers → cjs/src/providers}/GeminiProvider.d.ts +1 -1
  87. package/dist/cjs/src/providers/GeminiProvider.d.ts.map +1 -0
  88. package/dist/cjs/{providers → src/providers}/GeminiProvider.js +65 -0
  89. package/dist/cjs/src/providers/GeminiProvider.js.map +1 -0
  90. package/dist/cjs/{providers → src/providers}/OpenAIProvider.d.ts +1 -1
  91. package/dist/cjs/src/providers/OpenAIProvider.d.ts.map +1 -0
  92. package/dist/cjs/{providers → src/providers}/OpenAIProvider.js +70 -1
  93. package/dist/cjs/src/providers/OpenAIProvider.js.map +1 -0
  94. package/dist/{providers → cjs/src/providers}/OpenRouterProvider.d.ts +1 -1
  95. package/dist/cjs/src/providers/OpenRouterProvider.d.ts.map +1 -0
  96. package/dist/cjs/{providers → src/providers}/OpenRouterProvider.js +76 -0
  97. package/dist/cjs/src/providers/OpenRouterProvider.js.map +1 -0
  98. package/dist/cjs/src/providers/index.d.ts.map +1 -0
  99. package/dist/cjs/src/providers/index.js.map +1 -0
  100. package/dist/cjs/{types → src/types}/agent.d.ts +80 -41
  101. package/dist/cjs/src/types/agent.d.ts.map +1 -0
  102. package/dist/cjs/src/types/agent.js.map +1 -0
  103. package/dist/cjs/{types → src/types}/ai.d.ts +7 -0
  104. package/dist/cjs/src/types/ai.d.ts.map +1 -0
  105. package/dist/cjs/src/types/ai.js.map +1 -0
  106. package/dist/{types → cjs/src/types}/history.d.ts +76 -18
  107. package/dist/cjs/src/types/history.d.ts.map +1 -0
  108. package/dist/cjs/src/types/history.js +33 -0
  109. package/dist/cjs/src/types/history.js.map +1 -0
  110. package/dist/cjs/src/types/index.d.ts +20 -0
  111. package/dist/cjs/src/types/index.d.ts.map +1 -0
  112. package/dist/cjs/src/types/index.js +30 -0
  113. package/dist/cjs/src/types/index.js.map +1 -0
  114. package/dist/{types → cjs/src/types}/persistence.d.ts +38 -23
  115. package/dist/cjs/src/types/persistence.d.ts.map +1 -0
  116. package/dist/cjs/src/types/persistence.js.map +1 -0
  117. package/dist/cjs/src/types/route.d.ts +235 -0
  118. package/dist/cjs/src/types/route.d.ts.map +1 -0
  119. package/dist/cjs/{types → src/types}/route.js.map +1 -1
  120. package/dist/cjs/src/types/routing.d.ts.map +1 -0
  121. package/dist/{types → cjs/src/types}/routing.js.map +1 -1
  122. package/dist/cjs/src/types/schema.d.ts.map +1 -0
  123. package/dist/{types → cjs/src/types}/schema.js.map +1 -1
  124. package/dist/cjs/src/types/session.d.ts +65 -0
  125. package/dist/cjs/src/types/session.d.ts.map +1 -0
  126. package/dist/cjs/src/types/session.js +6 -0
  127. package/dist/cjs/src/types/session.js.map +1 -0
  128. package/dist/cjs/src/types/template.d.ts +30 -0
  129. package/dist/cjs/src/types/template.d.ts.map +1 -0
  130. package/dist/cjs/src/types/template.js +3 -0
  131. package/dist/cjs/src/types/template.js.map +1 -0
  132. package/dist/{types → cjs/src/types}/tool.d.ts +17 -13
  133. package/dist/cjs/src/types/tool.d.ts.map +1 -0
  134. package/dist/cjs/{types → src/types}/tool.js.map +1 -1
  135. package/dist/cjs/src/utils/clone.d.ts +8 -0
  136. package/dist/cjs/src/utils/clone.d.ts.map +1 -0
  137. package/dist/cjs/src/utils/clone.js +36 -0
  138. package/dist/cjs/src/utils/clone.js.map +1 -0
  139. package/dist/{utils → cjs/src/utils}/event.d.ts +1 -1
  140. package/dist/cjs/src/utils/event.d.ts.map +1 -0
  141. package/dist/cjs/{utils → src/utils}/event.js +2 -2
  142. package/dist/cjs/src/utils/event.js.map +1 -0
  143. package/dist/cjs/src/utils/history.d.ts +31 -0
  144. package/dist/cjs/src/utils/history.d.ts.map +1 -0
  145. package/dist/cjs/src/utils/history.js +128 -0
  146. package/dist/cjs/src/utils/history.js.map +1 -0
  147. package/dist/cjs/src/utils/id.d.ts.map +1 -0
  148. package/dist/cjs/src/utils/id.js.map +1 -0
  149. package/dist/cjs/src/utils/index.d.ts +13 -0
  150. package/dist/cjs/src/utils/index.d.ts.map +1 -0
  151. package/dist/cjs/src/utils/index.js +49 -0
  152. package/dist/cjs/src/utils/index.js.map +1 -0
  153. package/dist/cjs/src/utils/logger.d.ts.map +1 -0
  154. package/dist/cjs/src/utils/logger.js.map +1 -0
  155. package/dist/cjs/src/utils/retry.d.ts.map +1 -0
  156. package/dist/cjs/src/utils/retry.js.map +1 -0
  157. package/dist/cjs/src/utils/session.d.ts +51 -0
  158. package/dist/cjs/src/utils/session.d.ts.map +1 -0
  159. package/dist/cjs/{types → src/utils}/session.js +35 -32
  160. package/dist/cjs/src/utils/session.js.map +1 -0
  161. package/dist/cjs/src/utils/template.d.ts +107 -0
  162. package/dist/cjs/src/utils/template.d.ts.map +1 -0
  163. package/dist/cjs/src/utils/template.js +283 -0
  164. package/dist/cjs/src/utils/template.js.map +1 -0
  165. package/dist/{cjs → src}/adapters/MemoryAdapter.d.ts +4 -4
  166. package/dist/src/adapters/MemoryAdapter.d.ts.map +1 -0
  167. package/dist/{adapters → src/adapters}/MemoryAdapter.js +41 -21
  168. package/dist/src/adapters/MemoryAdapter.js.map +1 -0
  169. package/dist/{cjs → src}/adapters/MongoAdapter.d.ts +3 -3
  170. package/dist/src/adapters/MongoAdapter.d.ts.map +1 -0
  171. package/dist/{adapters → src/adapters}/MongoAdapter.js +2 -1
  172. package/dist/src/adapters/MongoAdapter.js.map +1 -0
  173. package/dist/{adapters → src/adapters}/OpenSearchAdapter.d.ts +3 -3
  174. package/dist/src/adapters/OpenSearchAdapter.d.ts.map +1 -0
  175. package/dist/{adapters → src/adapters}/OpenSearchAdapter.js +10 -13
  176. package/dist/src/adapters/OpenSearchAdapter.js.map +1 -0
  177. package/dist/{adapters → src/adapters}/PostgreSQLAdapter.d.ts +3 -3
  178. package/dist/src/adapters/PostgreSQLAdapter.d.ts.map +1 -0
  179. package/dist/{adapters → src/adapters}/PostgreSQLAdapter.js +1 -1
  180. package/dist/src/adapters/PostgreSQLAdapter.js.map +1 -0
  181. package/dist/{adapters → src/adapters}/PrismaAdapter.d.ts +3 -3
  182. package/dist/src/adapters/PrismaAdapter.d.ts.map +1 -0
  183. package/dist/{adapters → src/adapters}/PrismaAdapter.js +35 -5
  184. package/dist/src/adapters/PrismaAdapter.js.map +1 -0
  185. package/dist/{adapters → src/adapters}/RedisAdapter.d.ts +3 -3
  186. package/dist/src/adapters/RedisAdapter.d.ts.map +1 -0
  187. package/dist/{adapters → src/adapters}/RedisAdapter.js +3 -2
  188. package/dist/src/adapters/RedisAdapter.js.map +1 -0
  189. package/dist/{cjs → src}/adapters/SQLiteAdapter.d.ts +3 -3
  190. package/dist/src/adapters/SQLiteAdapter.d.ts.map +1 -0
  191. package/dist/{adapters → src/adapters}/SQLiteAdapter.js +2 -1
  192. package/dist/src/adapters/SQLiteAdapter.js.map +1 -0
  193. package/dist/src/adapters/index.js.map +1 -0
  194. package/dist/src/constants/index.js.map +1 -0
  195. package/dist/src/core/Agent.d.ts +223 -0
  196. package/dist/src/core/Agent.d.ts.map +1 -0
  197. package/dist/src/core/Agent.js +1656 -0
  198. package/dist/src/core/Agent.js.map +1 -0
  199. package/dist/src/core/Events.d.ts +26 -0
  200. package/dist/src/core/Events.d.ts.map +1 -0
  201. package/dist/src/core/Events.js +137 -0
  202. package/dist/src/core/Events.js.map +1 -0
  203. package/dist/{cjs → src}/core/PersistenceManager.d.ts +21 -19
  204. package/dist/src/core/PersistenceManager.d.ts.map +1 -0
  205. package/dist/{core → src/core}/PersistenceManager.js +71 -18
  206. package/dist/src/core/PersistenceManager.js.map +1 -0
  207. package/dist/src/core/PromptComposer.d.ts +27 -0
  208. package/dist/src/core/PromptComposer.d.ts.map +1 -0
  209. package/dist/src/core/PromptComposer.js +153 -0
  210. package/dist/src/core/PromptComposer.js.map +1 -0
  211. package/dist/src/core/ResponseEngine.d.ts +32 -0
  212. package/dist/src/core/ResponseEngine.d.ts.map +1 -0
  213. package/dist/src/core/ResponseEngine.js +80 -0
  214. package/dist/src/core/ResponseEngine.js.map +1 -0
  215. package/dist/src/core/ResponsePipeline.d.ts +171 -0
  216. package/dist/src/core/ResponsePipeline.d.ts.map +1 -0
  217. package/dist/src/core/ResponsePipeline.js +510 -0
  218. package/dist/src/core/ResponsePipeline.js.map +1 -0
  219. package/dist/src/core/Route.d.ts +145 -0
  220. package/dist/src/core/Route.d.ts.map +1 -0
  221. package/dist/src/core/Route.js +339 -0
  222. package/dist/src/core/Route.js.map +1 -0
  223. package/dist/src/core/RoutingEngine.d.ts +129 -0
  224. package/dist/src/core/RoutingEngine.d.ts.map +1 -0
  225. package/dist/{core → src/core}/RoutingEngine.js +211 -113
  226. package/dist/src/core/RoutingEngine.js.map +1 -0
  227. package/dist/src/core/SessionManager.d.ts +86 -0
  228. package/dist/src/core/SessionManager.d.ts.map +1 -0
  229. package/dist/src/core/SessionManager.js +213 -0
  230. package/dist/src/core/SessionManager.js.map +1 -0
  231. package/dist/src/core/Step.d.ts +96 -0
  232. package/dist/src/core/Step.d.ts.map +1 -0
  233. package/dist/src/core/Step.js +202 -0
  234. package/dist/src/core/Step.js.map +1 -0
  235. package/dist/src/core/ToolExecutor.d.ts +45 -0
  236. package/dist/src/core/ToolExecutor.d.ts.map +1 -0
  237. package/dist/src/core/ToolExecutor.js +80 -0
  238. package/dist/src/core/ToolExecutor.js.map +1 -0
  239. package/dist/{cjs → src}/index.d.ts +7 -15
  240. package/dist/src/index.d.ts.map +1 -0
  241. package/dist/{index.js → src/index.js} +6 -7
  242. package/dist/src/index.js.map +1 -0
  243. package/dist/{providers → src/providers}/AnthropicProvider.d.ts +1 -1
  244. package/dist/src/providers/AnthropicProvider.d.ts.map +1 -0
  245. package/dist/{providers → src/providers}/AnthropicProvider.js +54 -2
  246. package/dist/src/providers/AnthropicProvider.js.map +1 -0
  247. package/dist/{cjs → src}/providers/GeminiProvider.d.ts +1 -1
  248. package/dist/{cjs → src}/providers/GeminiProvider.d.ts.map +1 -1
  249. package/dist/{providers → src/providers}/GeminiProvider.js +65 -0
  250. package/dist/src/providers/GeminiProvider.js.map +1 -0
  251. package/dist/{providers → src/providers}/OpenAIProvider.d.ts +1 -1
  252. package/dist/{cjs → src}/providers/OpenAIProvider.d.ts.map +1 -1
  253. package/dist/{providers → src/providers}/OpenAIProvider.js +70 -1
  254. package/dist/src/providers/OpenAIProvider.js.map +1 -0
  255. package/dist/{cjs → src}/providers/OpenRouterProvider.d.ts +1 -1
  256. package/dist/{cjs → src}/providers/OpenRouterProvider.d.ts.map +1 -1
  257. package/dist/{providers → src/providers}/OpenRouterProvider.js +76 -0
  258. package/dist/src/providers/OpenRouterProvider.js.map +1 -0
  259. package/dist/src/providers/index.js.map +1 -0
  260. package/dist/{types → src/types}/agent.d.ts +80 -41
  261. package/dist/src/types/agent.d.ts.map +1 -0
  262. package/dist/src/types/agent.js.map +1 -0
  263. package/dist/{types → src/types}/ai.d.ts +7 -0
  264. package/dist/src/types/ai.d.ts.map +1 -0
  265. package/dist/{cjs → src}/types/ai.js.map +1 -1
  266. package/dist/{cjs → src}/types/history.d.ts +76 -18
  267. package/dist/src/types/history.d.ts.map +1 -0
  268. package/dist/src/types/history.js +30 -0
  269. package/dist/src/types/history.js.map +1 -0
  270. package/dist/src/types/index.d.ts +20 -0
  271. package/dist/src/types/index.d.ts.map +1 -0
  272. package/dist/src/types/index.js +10 -0
  273. package/dist/src/types/index.js.map +1 -0
  274. package/dist/{cjs → src}/types/persistence.d.ts +38 -23
  275. package/dist/src/types/persistence.d.ts.map +1 -0
  276. package/dist/src/types/persistence.js.map +1 -0
  277. package/dist/src/types/route.d.ts +235 -0
  278. package/dist/src/types/route.d.ts.map +1 -0
  279. package/dist/{types → src/types}/route.js.map +1 -1
  280. package/dist/src/types/session.d.ts +65 -0
  281. package/dist/src/types/session.d.ts.map +1 -0
  282. package/dist/src/types/session.js +5 -0
  283. package/dist/src/types/session.js.map +1 -0
  284. package/dist/src/types/template.d.ts +30 -0
  285. package/dist/src/types/template.d.ts.map +1 -0
  286. package/dist/src/types/template.js +2 -0
  287. package/dist/src/types/template.js.map +1 -0
  288. package/dist/{cjs → src}/types/tool.d.ts +17 -13
  289. package/dist/src/types/tool.d.ts.map +1 -0
  290. package/dist/{types → src/types}/tool.js.map +1 -1
  291. package/dist/src/utils/clone.d.ts +8 -0
  292. package/dist/src/utils/clone.d.ts.map +1 -0
  293. package/dist/src/utils/clone.js +33 -0
  294. package/dist/src/utils/clone.js.map +1 -0
  295. package/dist/{cjs → src}/utils/event.d.ts +1 -1
  296. package/dist/{cjs → src}/utils/event.d.ts.map +1 -1
  297. package/dist/{utils → src/utils}/event.js +1 -1
  298. package/dist/src/utils/event.js.map +1 -0
  299. package/dist/src/utils/history.d.ts +31 -0
  300. package/dist/src/utils/history.d.ts.map +1 -0
  301. package/dist/src/utils/history.js +121 -0
  302. package/dist/src/utils/history.js.map +1 -0
  303. package/dist/src/utils/id.js.map +1 -0
  304. package/dist/src/utils/index.d.ts +13 -0
  305. package/dist/src/utils/index.d.ts.map +1 -0
  306. package/dist/src/utils/index.js +19 -0
  307. package/dist/src/utils/index.js.map +1 -0
  308. package/dist/src/utils/logger.js.map +1 -0
  309. package/dist/src/utils/retry.js.map +1 -0
  310. package/dist/src/utils/session.d.ts +51 -0
  311. package/dist/src/utils/session.d.ts.map +1 -0
  312. package/dist/{types → src/utils}/session.js +33 -32
  313. package/dist/src/utils/session.js.map +1 -0
  314. package/dist/src/utils/template.d.ts +107 -0
  315. package/dist/src/utils/template.d.ts.map +1 -0
  316. package/dist/src/utils/template.js +276 -0
  317. package/dist/src/utils/template.js.map +1 -0
  318. package/docs/README.md +174 -68
  319. package/docs/{API_REFERENCE.md → api/README.md} +925 -255
  320. package/docs/api/overview.md +952 -0
  321. package/docs/core/agent/README.md +787 -0
  322. package/docs/{CONTEXT_MANAGEMENT.md → core/agent/context-management.md} +175 -102
  323. package/docs/{ARCHITECTURE.md → core/agent/session-management.md} +117 -69
  324. package/docs/core/ai-integration/prompt-composition.md +220 -0
  325. package/docs/core/ai-integration/providers.md +515 -0
  326. package/docs/core/ai-integration/response-processing.md +176 -0
  327. package/docs/core/conversation-flows/data-collection.md +623 -0
  328. package/docs/core/conversation-flows/route-dsl.md +502 -0
  329. package/docs/core/conversation-flows/routes.md +117 -0
  330. package/docs/core/conversation-flows/step-transitions.md +595 -0
  331. package/docs/core/conversation-flows/steps.md +154 -0
  332. package/docs/{ADAPTERS.md → core/persistence/adapters.md} +1 -1
  333. package/docs/core/persistence/session-storage.md +644 -0
  334. package/docs/core/routing/intelligent-routing.md +348 -0
  335. package/docs/core/tools/tool-definition.md +346 -0
  336. package/docs/core/tools/tool-execution.md +815 -0
  337. package/docs/core/tools/tool-scoping.md +628 -0
  338. package/docs/guides/getting-started/README.md +406 -0
  339. package/examples/{company-qna-agent.ts → advanced-patterns/knowledge-based-agent.ts} +139 -95
  340. package/examples/{persistent-onboarding.ts → advanced-patterns/persistent-onboarding.ts} +244 -137
  341. package/examples/{rules-prohibitions.ts → advanced-patterns/route-lifecycle-hooks.ts} +130 -84
  342. package/examples/{streaming-agent.ts → advanced-patterns/streaming-responses.ts} +116 -90
  343. package/examples/ai-providers/anthropic-integration.ts +384 -0
  344. package/examples/{openai-agent.ts → ai-providers/openai-integration.ts} +57 -63
  345. package/examples/conversation-flows/completion-transitions.ts +277 -0
  346. package/examples/core-concepts/basic-agent.ts +443 -0
  347. package/examples/core-concepts/schema-driven-extraction.ts +305 -0
  348. package/examples/core-concepts/session-management.ts +406 -0
  349. package/examples/integrations/database-integration.ts +630 -0
  350. package/examples/integrations/healthcare-integration.ts +609 -0
  351. package/examples/{opensearch-persistence.ts → integrations/search-integration.ts} +199 -171
  352. package/examples/integrations/server-session-management.ts +307 -0
  353. package/examples/persistence/custom-adapter.ts +529 -0
  354. package/examples/{prisma-persistence.ts → persistence/database-persistence.ts} +215 -272
  355. package/examples/persistence/memory-sessions.ts +495 -0
  356. package/examples/{prisma-schema.example.prisma → persistence/prisma-schema.example.prisma} +1 -1
  357. package/examples/persistence/redis-persistence.ts +490 -0
  358. package/examples/tools/basic-tools.ts +561 -0
  359. package/examples/{extracted-data-modification.ts → tools/data-enrichment-tools.ts} +128 -117
  360. package/package.json +14 -10
  361. package/src/adapters/MemoryAdapter.ts +74 -46
  362. package/src/adapters/MongoAdapter.ts +33 -24
  363. package/src/adapters/OpenSearchAdapter.ts +41 -37
  364. package/src/adapters/PostgreSQLAdapter.ts +35 -24
  365. package/src/adapters/PrismaAdapter.ts +69 -27
  366. package/src/adapters/RedisAdapter.ts +38 -26
  367. package/src/adapters/SQLiteAdapter.ts +32 -22
  368. package/src/core/Agent.ts +1431 -526
  369. package/src/core/Events.ts +100 -112
  370. package/src/core/PersistenceManager.ts +103 -49
  371. package/src/core/PromptComposer.ts +158 -85
  372. package/src/core/ResponseEngine.ts +128 -46
  373. package/src/core/ResponsePipeline.ts +830 -0
  374. package/src/core/Route.ts +222 -53
  375. package/src/core/RoutingEngine.ts +345 -229
  376. package/src/core/SessionManager.ts +265 -0
  377. package/src/core/Step.ts +157 -67
  378. package/src/core/ToolExecutor.ts +52 -43
  379. package/src/index.ts +31 -37
  380. package/src/providers/AnthropicProvider.ts +71 -5
  381. package/src/providers/GeminiProvider.ts +83 -2
  382. package/src/providers/OpenAIProvider.ts +95 -3
  383. package/src/providers/OpenRouterProvider.ts +102 -2
  384. package/src/types/agent.ts +81 -46
  385. package/src/types/ai.ts +7 -0
  386. package/src/types/history.ts +91 -18
  387. package/src/types/index.ts +45 -7
  388. package/src/types/persistence.ts +45 -28
  389. package/src/types/route.ts +122 -57
  390. package/src/types/session.ts +20 -220
  391. package/src/types/template.ts +36 -0
  392. package/src/types/tool.ts +23 -19
  393. package/src/utils/clone.ts +36 -0
  394. package/src/utils/event.ts +1 -1
  395. package/src/utils/history.ts +143 -0
  396. package/src/utils/index.ts +53 -0
  397. package/src/utils/session.ts +204 -0
  398. package/src/utils/template.ts +335 -0
  399. package/dist/adapters/MemoryAdapter.d.ts.map +0 -1
  400. package/dist/adapters/MemoryAdapter.js.map +0 -1
  401. package/dist/adapters/MongoAdapter.d.ts.map +0 -1
  402. package/dist/adapters/MongoAdapter.js.map +0 -1
  403. package/dist/adapters/OpenSearchAdapter.d.ts.map +0 -1
  404. package/dist/adapters/OpenSearchAdapter.js.map +0 -1
  405. package/dist/adapters/PostgreSQLAdapter.d.ts.map +0 -1
  406. package/dist/adapters/PostgreSQLAdapter.js.map +0 -1
  407. package/dist/adapters/PrismaAdapter.d.ts.map +0 -1
  408. package/dist/adapters/PrismaAdapter.js.map +0 -1
  409. package/dist/adapters/RedisAdapter.d.ts.map +0 -1
  410. package/dist/adapters/RedisAdapter.js.map +0 -1
  411. package/dist/adapters/SQLiteAdapter.d.ts.map +0 -1
  412. package/dist/adapters/SQLiteAdapter.js.map +0 -1
  413. package/dist/adapters/index.d.ts.map +0 -1
  414. package/dist/adapters/index.js.map +0 -1
  415. package/dist/cjs/adapters/MemoryAdapter.d.ts.map +0 -1
  416. package/dist/cjs/adapters/MemoryAdapter.js.map +0 -1
  417. package/dist/cjs/adapters/MongoAdapter.d.ts.map +0 -1
  418. package/dist/cjs/adapters/MongoAdapter.js.map +0 -1
  419. package/dist/cjs/adapters/OpenSearchAdapter.d.ts.map +0 -1
  420. package/dist/cjs/adapters/OpenSearchAdapter.js.map +0 -1
  421. package/dist/cjs/adapters/PostgreSQLAdapter.d.ts.map +0 -1
  422. package/dist/cjs/adapters/PostgreSQLAdapter.js.map +0 -1
  423. package/dist/cjs/adapters/PrismaAdapter.d.ts.map +0 -1
  424. package/dist/cjs/adapters/PrismaAdapter.js.map +0 -1
  425. package/dist/cjs/adapters/RedisAdapter.d.ts.map +0 -1
  426. package/dist/cjs/adapters/RedisAdapter.js.map +0 -1
  427. package/dist/cjs/adapters/SQLiteAdapter.d.ts.map +0 -1
  428. package/dist/cjs/adapters/SQLiteAdapter.js.map +0 -1
  429. package/dist/cjs/adapters/index.js.map +0 -1
  430. package/dist/cjs/constants/index.js.map +0 -1
  431. package/dist/cjs/core/Agent.d.ts +0 -197
  432. package/dist/cjs/core/Agent.d.ts.map +0 -1
  433. package/dist/cjs/core/Agent.js +0 -966
  434. package/dist/cjs/core/Agent.js.map +0 -1
  435. package/dist/cjs/core/DomainRegistry.d.ts +0 -36
  436. package/dist/cjs/core/DomainRegistry.d.ts.map +0 -1
  437. package/dist/cjs/core/DomainRegistry.js +0 -72
  438. package/dist/cjs/core/DomainRegistry.js.map +0 -1
  439. package/dist/cjs/core/Events.d.ts +0 -41
  440. package/dist/cjs/core/Events.d.ts.map +0 -1
  441. package/dist/cjs/core/Events.js +0 -99
  442. package/dist/cjs/core/Events.js.map +0 -1
  443. package/dist/cjs/core/PersistenceManager.d.ts.map +0 -1
  444. package/dist/cjs/core/PersistenceManager.js.map +0 -1
  445. package/dist/cjs/core/PromptComposer.d.ts +0 -24
  446. package/dist/cjs/core/PromptComposer.d.ts.map +0 -1
  447. package/dist/cjs/core/PromptComposer.js +0 -127
  448. package/dist/cjs/core/PromptComposer.js.map +0 -1
  449. package/dist/cjs/core/ResponseEngine.d.ts +0 -14
  450. package/dist/cjs/core/ResponseEngine.d.ts.map +0 -1
  451. package/dist/cjs/core/ResponseEngine.js +0 -56
  452. package/dist/cjs/core/ResponseEngine.js.map +0 -1
  453. package/dist/cjs/core/Route.d.ts +0 -90
  454. package/dist/cjs/core/Route.d.ts.map +0 -1
  455. package/dist/cjs/core/Route.js +0 -203
  456. package/dist/cjs/core/Route.js.map +0 -1
  457. package/dist/cjs/core/RoutingEngine.d.ts +0 -109
  458. package/dist/cjs/core/RoutingEngine.d.ts.map +0 -1
  459. package/dist/cjs/core/RoutingEngine.js.map +0 -1
  460. package/dist/cjs/core/Step.d.ts +0 -72
  461. package/dist/cjs/core/Step.d.ts.map +0 -1
  462. package/dist/cjs/core/Step.js +0 -150
  463. package/dist/cjs/core/Step.js.map +0 -1
  464. package/dist/cjs/core/Tool.d.ts +0 -39
  465. package/dist/cjs/core/Tool.d.ts.map +0 -1
  466. package/dist/cjs/core/Tool.js +0 -34
  467. package/dist/cjs/core/Tool.js.map +0 -1
  468. package/dist/cjs/core/ToolExecutor.d.ts +0 -29
  469. package/dist/cjs/core/ToolExecutor.d.ts.map +0 -1
  470. package/dist/cjs/core/ToolExecutor.js.map +0 -1
  471. package/dist/cjs/core/Transition.d.ts +0 -32
  472. package/dist/cjs/core/Transition.d.ts.map +0 -1
  473. package/dist/cjs/core/Transition.js +0 -89
  474. package/dist/cjs/core/Transition.js.map +0 -1
  475. package/dist/cjs/index.d.ts.map +0 -1
  476. package/dist/cjs/index.js.map +0 -1
  477. package/dist/cjs/providers/AnthropicProvider.d.ts.map +0 -1
  478. package/dist/cjs/providers/AnthropicProvider.js.map +0 -1
  479. package/dist/cjs/providers/GeminiProvider.js.map +0 -1
  480. package/dist/cjs/providers/OpenAIProvider.js.map +0 -1
  481. package/dist/cjs/providers/OpenRouterProvider.js.map +0 -1
  482. package/dist/cjs/providers/index.js.map +0 -1
  483. package/dist/cjs/types/agent.d.ts.map +0 -1
  484. package/dist/cjs/types/agent.js.map +0 -1
  485. package/dist/cjs/types/ai.d.ts.map +0 -1
  486. package/dist/cjs/types/history.d.ts.map +0 -1
  487. package/dist/cjs/types/history.js +0 -37
  488. package/dist/cjs/types/history.js.map +0 -1
  489. package/dist/cjs/types/index.d.ts +0 -12
  490. package/dist/cjs/types/index.d.ts.map +0 -1
  491. package/dist/cjs/types/index.js +0 -12
  492. package/dist/cjs/types/index.js.map +0 -1
  493. package/dist/cjs/types/persistence.d.ts.map +0 -1
  494. package/dist/cjs/types/persistence.js.map +0 -1
  495. package/dist/cjs/types/route.d.ts +0 -175
  496. package/dist/cjs/types/route.d.ts.map +0 -1
  497. package/dist/cjs/types/session.d.ts +0 -104
  498. package/dist/cjs/types/session.d.ts.map +0 -1
  499. package/dist/cjs/types/session.js.map +0 -1
  500. package/dist/cjs/types/tool.d.ts.map +0 -1
  501. package/dist/cjs/utils/event.js.map +0 -1
  502. package/dist/cjs/utils/id.js.map +0 -1
  503. package/dist/cjs/utils/logger.js.map +0 -1
  504. package/dist/cjs/utils/retry.js.map +0 -1
  505. package/dist/constants/index.d.ts.map +0 -1
  506. package/dist/constants/index.js.map +0 -1
  507. package/dist/core/Agent.d.ts +0 -197
  508. package/dist/core/Agent.d.ts.map +0 -1
  509. package/dist/core/Agent.js +0 -962
  510. package/dist/core/Agent.js.map +0 -1
  511. package/dist/core/DomainRegistry.d.ts +0 -36
  512. package/dist/core/DomainRegistry.d.ts.map +0 -1
  513. package/dist/core/DomainRegistry.js +0 -68
  514. package/dist/core/DomainRegistry.js.map +0 -1
  515. package/dist/core/Events.d.ts +0 -41
  516. package/dist/core/Events.d.ts.map +0 -1
  517. package/dist/core/Events.js +0 -94
  518. package/dist/core/Events.js.map +0 -1
  519. package/dist/core/PersistenceManager.d.ts.map +0 -1
  520. package/dist/core/PersistenceManager.js.map +0 -1
  521. package/dist/core/PromptComposer.d.ts +0 -24
  522. package/dist/core/PromptComposer.d.ts.map +0 -1
  523. package/dist/core/PromptComposer.js +0 -123
  524. package/dist/core/PromptComposer.js.map +0 -1
  525. package/dist/core/ResponseEngine.d.ts +0 -14
  526. package/dist/core/ResponseEngine.d.ts.map +0 -1
  527. package/dist/core/ResponseEngine.js +0 -52
  528. package/dist/core/ResponseEngine.js.map +0 -1
  529. package/dist/core/Route.d.ts +0 -90
  530. package/dist/core/Route.d.ts.map +0 -1
  531. package/dist/core/Route.js +0 -199
  532. package/dist/core/Route.js.map +0 -1
  533. package/dist/core/RoutingEngine.d.ts +0 -109
  534. package/dist/core/RoutingEngine.d.ts.map +0 -1
  535. package/dist/core/RoutingEngine.js.map +0 -1
  536. package/dist/core/Step.d.ts +0 -72
  537. package/dist/core/Step.d.ts.map +0 -1
  538. package/dist/core/Step.js +0 -146
  539. package/dist/core/Step.js.map +0 -1
  540. package/dist/core/Tool.d.ts +0 -39
  541. package/dist/core/Tool.d.ts.map +0 -1
  542. package/dist/core/Tool.js +0 -31
  543. package/dist/core/Tool.js.map +0 -1
  544. package/dist/core/ToolExecutor.d.ts +0 -29
  545. package/dist/core/ToolExecutor.d.ts.map +0 -1
  546. package/dist/core/ToolExecutor.js +0 -69
  547. package/dist/core/ToolExecutor.js.map +0 -1
  548. package/dist/core/Transition.d.ts +0 -32
  549. package/dist/core/Transition.d.ts.map +0 -1
  550. package/dist/core/Transition.js +0 -85
  551. package/dist/core/Transition.js.map +0 -1
  552. package/dist/index.d.ts.map +0 -1
  553. package/dist/index.js.map +0 -1
  554. package/dist/providers/AnthropicProvider.d.ts.map +0 -1
  555. package/dist/providers/AnthropicProvider.js.map +0 -1
  556. package/dist/providers/GeminiProvider.d.ts.map +0 -1
  557. package/dist/providers/GeminiProvider.js.map +0 -1
  558. package/dist/providers/OpenAIProvider.d.ts.map +0 -1
  559. package/dist/providers/OpenAIProvider.js.map +0 -1
  560. package/dist/providers/OpenRouterProvider.d.ts.map +0 -1
  561. package/dist/providers/OpenRouterProvider.js.map +0 -1
  562. package/dist/providers/index.d.ts.map +0 -1
  563. package/dist/providers/index.js.map +0 -1
  564. package/dist/types/agent.d.ts.map +0 -1
  565. package/dist/types/agent.js.map +0 -1
  566. package/dist/types/ai.d.ts.map +0 -1
  567. package/dist/types/ai.js.map +0 -1
  568. package/dist/types/history.d.ts.map +0 -1
  569. package/dist/types/history.js +0 -34
  570. package/dist/types/history.js.map +0 -1
  571. package/dist/types/index.d.ts +0 -12
  572. package/dist/types/index.d.ts.map +0 -1
  573. package/dist/types/index.js +0 -6
  574. package/dist/types/index.js.map +0 -1
  575. package/dist/types/persistence.d.ts.map +0 -1
  576. package/dist/types/persistence.js.map +0 -1
  577. package/dist/types/route.d.ts +0 -175
  578. package/dist/types/route.d.ts.map +0 -1
  579. package/dist/types/routing.d.ts.map +0 -1
  580. package/dist/types/schema.d.ts.map +0 -1
  581. package/dist/types/session.d.ts +0 -104
  582. package/dist/types/session.d.ts.map +0 -1
  583. package/dist/types/session.js.map +0 -1
  584. package/dist/types/tool.d.ts.map +0 -1
  585. package/dist/utils/event.d.ts.map +0 -1
  586. package/dist/utils/event.js.map +0 -1
  587. package/dist/utils/id.d.ts.map +0 -1
  588. package/dist/utils/id.js.map +0 -1
  589. package/dist/utils/logger.d.ts.map +0 -1
  590. package/dist/utils/logger.js.map +0 -1
  591. package/dist/utils/retry.d.ts.map +0 -1
  592. package/dist/utils/retry.js.map +0 -1
  593. package/docs/AGENT.md +0 -535
  594. package/docs/DOCS.md +0 -263
  595. package/docs/DOMAINS.md +0 -735
  596. package/docs/EXAMPLES.md +0 -467
  597. package/docs/GETTING_STARTED.md +0 -424
  598. package/docs/PERSISTENCE.md +0 -815
  599. package/docs/PROVIDERS.md +0 -612
  600. package/docs/ROUTES.md +0 -1085
  601. package/docs/STEPS.md +0 -883
  602. package/examples/business-onboarding.ts +0 -791
  603. package/examples/custom-database-persistence.ts +0 -574
  604. package/examples/declarative-agent.ts +0 -401
  605. package/examples/domain-scoping.ts +0 -366
  606. package/examples/healthcare-agent.ts +0 -511
  607. package/examples/redis-persistence.ts +0 -525
  608. package/examples/route-transitions.ts +0 -266
  609. package/examples/travel-agent.ts +0 -584
  610. package/src/core/DomainRegistry.ts +0 -80
  611. package/src/core/Tool.ts +0 -112
  612. package/src/core/Transition.ts +0 -115
  613. /package/dist/{adapters → cjs/src/adapters}/index.d.ts +0 -0
  614. /package/dist/cjs/{adapters → src/adapters}/index.js +0 -0
  615. /package/dist/cjs/{constants → src/constants}/index.d.ts +0 -0
  616. /package/dist/cjs/{constants → src/constants}/index.js +0 -0
  617. /package/dist/cjs/{providers → src/providers}/index.d.ts +0 -0
  618. /package/dist/cjs/{providers → src/providers}/index.js +0 -0
  619. /package/dist/cjs/{types → src/types}/agent.js +0 -0
  620. /package/dist/cjs/{types → src/types}/ai.js +0 -0
  621. /package/dist/cjs/{types → src/types}/persistence.js +0 -0
  622. /package/dist/cjs/{types → src/types}/route.js +0 -0
  623. /package/dist/cjs/{types → src/types}/routing.d.ts +0 -0
  624. /package/dist/cjs/{types → src/types}/routing.js +0 -0
  625. /package/dist/cjs/{types → src/types}/schema.d.ts +0 -0
  626. /package/dist/cjs/{types → src/types}/schema.js +0 -0
  627. /package/dist/cjs/{types → src/types}/tool.js +0 -0
  628. /package/dist/cjs/{utils → src/utils}/id.d.ts +0 -0
  629. /package/dist/cjs/{utils → src/utils}/id.js +0 -0
  630. /package/dist/cjs/{utils → src/utils}/logger.d.ts +0 -0
  631. /package/dist/cjs/{utils → src/utils}/logger.js +0 -0
  632. /package/dist/cjs/{utils → src/utils}/retry.d.ts +0 -0
  633. /package/dist/cjs/{utils → src/utils}/retry.js +0 -0
  634. /package/dist/{cjs → src}/adapters/index.d.ts +0 -0
  635. /package/dist/{cjs → src}/adapters/index.d.ts.map +0 -0
  636. /package/dist/{adapters → src/adapters}/index.js +0 -0
  637. /package/dist/{constants → src/constants}/index.d.ts +0 -0
  638. /package/dist/{cjs → src}/constants/index.d.ts.map +0 -0
  639. /package/dist/{constants → src/constants}/index.js +0 -0
  640. /package/dist/{providers → src/providers}/index.d.ts +0 -0
  641. /package/dist/{cjs → src}/providers/index.d.ts.map +0 -0
  642. /package/dist/{providers → src/providers}/index.js +0 -0
  643. /package/dist/{types → src/types}/agent.js +0 -0
  644. /package/dist/{types → src/types}/ai.js +0 -0
  645. /package/dist/{types → src/types}/persistence.js +0 -0
  646. /package/dist/{types → src/types}/route.js +0 -0
  647. /package/dist/{types → src/types}/routing.d.ts +0 -0
  648. /package/dist/{cjs → src}/types/routing.d.ts.map +0 -0
  649. /package/dist/{types → src/types}/routing.js +0 -0
  650. /package/dist/{cjs → src}/types/routing.js.map +0 -0
  651. /package/dist/{types → src/types}/schema.d.ts +0 -0
  652. /package/dist/{cjs → src}/types/schema.d.ts.map +0 -0
  653. /package/dist/{types → src/types}/schema.js +0 -0
  654. /package/dist/{cjs → src}/types/schema.js.map +0 -0
  655. /package/dist/{types → src/types}/tool.js +0 -0
  656. /package/dist/{utils → src/utils}/id.d.ts +0 -0
  657. /package/dist/{cjs → src}/utils/id.d.ts.map +0 -0
  658. /package/dist/{utils → src/utils}/id.js +0 -0
  659. /package/dist/{utils → src/utils}/logger.d.ts +0 -0
  660. /package/dist/{cjs → src}/utils/logger.d.ts.map +0 -0
  661. /package/dist/{utils → src/utils}/logger.js +0 -0
  662. /package/dist/{utils → src/utils}/retry.d.ts +0 -0
  663. /package/dist/{cjs → src}/utils/retry.d.ts.map +0 -0
  664. /package/dist/{utils → src/utils}/retry.js +0 -0
  665. /package/docs/{PUBLISHING.md → guides/advanced-patterns/publishing.md} +0 -0
@@ -0,0 +1,348 @@
1
+ # Intelligent Routing System
2
+
3
+ The AI routing system is the core intelligence layer of @falai/agent that enables dynamic, context-aware conversation flows. Unlike traditional state machines, the routing system uses AI to intelligently select routes and steps based on user intent, conversation history, and collected data.
4
+
5
+ ## Overview
6
+
7
+ The `RoutingEngine` class powers two key decision-making processes:
8
+
9
+ 1. **Route Selection**: When multiple routes are available, AI analyzes the conversation to score and select the most appropriate route
10
+ 2. **Step Selection**: Within an active route, AI determines the best next step from available candidates
11
+
12
+ ## How It Works
13
+
14
+ ### Route Selection Process
15
+
16
+ When an agent has multiple routes defined, the routing engine:
17
+
18
+ 1. **Analyzes Context**: Evaluates conversation history, user intent, and current session state
19
+ 2. **Scores Routes**: Uses AI to score each route (0-100) based on relevance and semantic fit
20
+ 3. **Applies Thresholds**: Considers switching costs and maintains conversation continuity
21
+ 4. **Selects Winner**: Chooses the highest-scoring route or stays with the current route
22
+
23
+ ### Step Selection Process
24
+
25
+ Within an active route, the routing engine:
26
+
27
+ 1. **Finds Candidates**: Traverses the step chain to identify valid next steps
28
+ 2. **Evaluates Conditions**: Respects `skipIf` conditions and `requires` dependencies
29
+ 3. **AI Decision**: When multiple candidates exist, uses AI to select the optimal step
30
+ 4. **Handles Completion**: Detects route completion and manages transitions
31
+
32
+ ## Key Features
33
+
34
+ ### Intelligent Route Scoring
35
+
36
+ Routes are scored based on multiple factors:
37
+
38
+ ```typescript
39
+ // Routes receive scores 0-100 based on:
40
+ - Explicit keyword matches (90-100)
41
+ - Contextual evidence (70-89)
42
+ - Moderate relevance (50-69)
43
+ - Weak connections (30-49)
44
+ - Minimal relevance (0-29)
45
+ ```
46
+
47
+ ### Smart Step Traversal
48
+
49
+ The system intelligently traverses step chains:
50
+
51
+ - **Skip Logic**: Automatically skips steps where `skipIf` conditions are met
52
+ - **Dependency Checking**: Ensures required data is present before allowing step progression
53
+ - **Loop Prevention**: Uses visited sets to prevent infinite traversal
54
+ - **Branch Resolution**: Handles complex branching logic with AI assistance
55
+
56
+ ### Context-Aware Decisions
57
+
58
+ All routing decisions consider:
59
+
60
+ - **Conversation History**: Full dialogue context
61
+ - **Agent-Level Data**: Centralized information gathered across all routes
62
+ - **Session State**: Current route and step position with cross-route data access
63
+ - **Route Completion**: Progress toward required fields for each route
64
+ - **Agent Knowledge**: Guidelines, terms, and domain knowledge
65
+
66
+ ## Route Selection API
67
+
68
+ ### Single Route Optimization
69
+
70
+ For agents with only one route, the system optimizes by skipping expensive route scoring:
71
+
72
+ ```typescript
73
+ // Single route - direct step selection
74
+ const result = await routingEngine.decideSingleRouteStep({
75
+ route: userOnboardingRoute,
76
+ session,
77
+ history,
78
+ agentOptions,
79
+ provider,
80
+ context,
81
+ });
82
+ ```
83
+
84
+ ### Multi-Route Orchestration
85
+
86
+ For complex agents with multiple routes:
87
+
88
+ ```typescript
89
+ // Multiple routes - full AI-powered selection
90
+ const result = await routingEngine.decideRouteAndStep({
91
+ routes: [onboardingRoute, supportRoute, salesRoute],
92
+ session,
93
+ history,
94
+ agentOptions,
95
+ provider,
96
+ context,
97
+ });
98
+ ```
99
+
100
+ ## Step Candidate Logic
101
+
102
+ ### Finding Valid Steps
103
+
104
+ The `getCandidateSteps()` method implements sophisticated logic:
105
+
106
+ ```typescript
107
+ // Find valid next steps considering:
108
+ const candidates = routingEngine.getCandidateSteps(
109
+ route, // Current route
110
+ currentStep, // Current step (or null for route start)
111
+ agentData // Agent-level data collected across all routes
112
+ );
113
+ ```
114
+
115
+ ### SkipIf Processing
116
+
117
+ Steps are automatically filtered based on agent-level data conditions:
118
+
119
+ ```typescript
120
+ // Step definition with skipIf using agent data
121
+ initialStep: {
122
+ prompt: "What's your name?",
123
+ collect: ["name"],
124
+ skipIf: (data) => data.name !== undefined // Skip if name already collected by any route
125
+ }
126
+
127
+ // Cross-route skipping example
128
+ const emailStep = {
129
+ prompt: "What's your email?",
130
+ collect: ["email"],
131
+ skipIf: (data) => data.email !== undefined // Skip if collected in different route
132
+ }
133
+ ```
134
+
135
+ ### Recursive Traversal
136
+
137
+ The system recursively traverses step chains to find valid paths:
138
+
139
+ ```typescript
140
+ // Handles complex scenarios like:
141
+ // Step A (skipIf: condition) -> Step B -> Step C (requires: data)
142
+ // If Step A is skipped, system continues to Step B, then evaluates Step C
143
+ ```
144
+
145
+ ## Prompt Engineering
146
+
147
+ ### Route Selection Prompts
148
+
149
+ The system builds comprehensive prompts for route selection:
150
+
151
+ ```typescript
152
+ const routingPrompt = await routingEngine.buildRoutingPrompt({
153
+ history,
154
+ routes,
155
+ lastMessage,
156
+ agentOptions,
157
+ session,
158
+ activeRouteSteps,
159
+ context,
160
+ });
161
+ ```
162
+
163
+ Prompts include:
164
+
165
+ - Agent identity and personality
166
+ - Available routes with descriptions and required fields
167
+ - Session context and agent-level collected data
168
+ - Route completion progress (e.g., "2/3 required fields collected")
169
+ - Scoring guidelines (90-100 scale)
170
+ - Conversation history and directives
171
+
172
+ ### Step Selection Prompts
173
+
174
+ For step selection within routes:
175
+
176
+ ```typescript
177
+ const stepPrompt = await routingEngine.buildStepSelectionPrompt({
178
+ route,
179
+ currentStep,
180
+ candidates,
181
+ data: agent.getCollectedData(), // Agent-level data
182
+ history,
183
+ lastMessage,
184
+ agentOptions,
185
+ context,
186
+ session,
187
+ });
188
+ ```
189
+
190
+ ## Response Processing
191
+
192
+ ### Structured Scoring
193
+
194
+ AI responses use JSON schemas for reliable parsing:
195
+
196
+ ```typescript
197
+ // Route scoring schema
198
+ {
199
+ context: "Brief summary of user intent",
200
+ routes: {
201
+ "route-id-1": 85, // Score 0-100
202
+ "route-id-2": 72,
203
+ "route-id-3": 45
204
+ },
205
+ responseDirectives: ["Focus on pricing", "Be helpful"]
206
+ }
207
+ ```
208
+
209
+ ### Step Selection Schema
210
+
211
+ ```typescript
212
+ // Step selection schema
213
+ {
214
+ reasoning: "Why this step was selected",
215
+ selectedStepId: "step-id",
216
+ responseDirectives: ["Address concerns", "Provide options"]
217
+ }
218
+ ```
219
+
220
+ ## Integration with Agent Flow
221
+
222
+ ### Response Pipeline Integration
223
+
224
+ The routing engine integrates seamlessly with the response pipeline:
225
+
226
+ ```typescript
227
+ // In Agent.respondStream():
228
+ 1. Prepare context and session
229
+ 2. Call routingEngine.decideRouteAndStep()
230
+ 3. Execute prepare() functions on current step
231
+ 4. Generate AI response with selected route/step
232
+ 5. Process tool calls and data collection
233
+ 6. Handle route completion and transitions
234
+ ```
235
+
236
+ ### Session State Management
237
+
238
+ Routing decisions update session state:
239
+
240
+ ```typescript
241
+ // Session updates include:
242
+ - Current route transitions
243
+ - Step progression
244
+ - Initial data merging
245
+ - Route completion handling
246
+ - Pending transition management
247
+ ```
248
+
249
+ ## Performance Optimizations
250
+
251
+ ### Single Route Fast Path
252
+
253
+ For agents with one route, skips route scoring entirely:
254
+
255
+ ```typescript
256
+ if (routes.length === 1) {
257
+ return this.decideSingleRouteStep(/* optimized path */);
258
+ }
259
+ ```
260
+
261
+ ### Candidate Limiting
262
+
263
+ Applies configurable limits to prevent excessive AI calls:
264
+
265
+ ```typescript
266
+ const limited = maxCandidates ? entries.slice(0, maxCandidates) : entries;
267
+ ```
268
+
269
+ ## Error Handling & Resilience
270
+
271
+ ### Backup Model Support
272
+
273
+ When primary AI models fail, automatically tries backup models:
274
+
275
+ ```typescript
276
+ // Automatic fallback to backup models
277
+ // Error classification (rate limits, overloads, etc.)
278
+ // Timeout and retry logic
279
+ ```
280
+
281
+ ### Validation & Fallbacks
282
+
283
+ Robust validation ensures system stability:
284
+
285
+ ```typescript
286
+ // Invalid responses fallback to first candidate
287
+ // Missing data handled gracefully
288
+ // Circular dependencies prevented
289
+ ```
290
+
291
+ ## Configuration Options
292
+
293
+ ### Routing Engine Options
294
+
295
+ ```typescript
296
+ const routingEngine = new RoutingEngine({
297
+ allowRouteSwitch: true, // Allow switching between routes
298
+ switchThreshold: 70, // Minimum score to switch routes
299
+ maxCandidates: 5, // Limit AI evaluation candidates
300
+ });
301
+ ```
302
+
303
+ ## Best Practices
304
+
305
+ ### Route Design
306
+
307
+ 1. **Clear Conditions**: Define specific conditions for route activation
308
+ 2. **Distinct Purposes**: Ensure routes serve different user intents
309
+ 3. **Progressive Disclosure**: Use step dependencies to control information flow
310
+ 4. **Completion Handling**: Define clear end states and transitions
311
+
312
+ ### Step Design
313
+
314
+ 1. **Atomic Actions**: Each step should accomplish one clear goal
315
+ 2. **Smart Skipping**: Use `skipIf` to avoid redundant questions
316
+ 3. **Data Dependencies**: Use `requires` to enforce logical flow
317
+ 4. **Branch Wisely**: AI can handle branching but prefer linear flows when possible
318
+
319
+ ### Performance
320
+
321
+ 1. **Limit Routes**: Too many routes increase AI evaluation time
322
+ 2. **Optimize Prompts**: Keep route/step descriptions concise
323
+ 3. **Cache Context**: Reuse context when possible
324
+ 4. **Monitor Scores**: Track route selection accuracy and adjust conditions
325
+
326
+ ## Debugging & Monitoring
327
+
328
+ ### Route Selection Logging
329
+
330
+ ```typescript
331
+ // Debug logging shows:
332
+ - Route scores and reasoning
333
+ - Selected routes and steps
334
+ - Candidate evaluation process
335
+ - Context analysis results
336
+ ```
337
+
338
+ ### Performance Metrics
339
+
340
+ ```typescript
341
+ // Track:
342
+ - Route selection accuracy
343
+ - Step transition success rates
344
+ - AI call latency and costs
345
+ - User satisfaction scores
346
+ ```
347
+
348
+ The intelligent routing system transforms traditional conversation design from static flows into dynamic, AI-driven experiences that adapt to user needs and context.
@@ -0,0 +1,346 @@
1
+ # Tool Definition
2
+
3
+ Tools in @falai/agent enable AI agents to execute custom logic, access external APIs, and perform actions during conversations. This document covers tool creation, configuration, and integration.
4
+
5
+ ## Overview
6
+
7
+ Tools provide a way for agents to:
8
+
9
+ - Execute business logic and API calls
10
+ - Access external services and databases
11
+ - Perform calculations and data transformations
12
+ - Update conversation context and session data
13
+
14
+ ## Tool Creation
15
+
16
+ Tools are created as objects implementing the `Tool` interface:
17
+
18
+ ```typescript
19
+ import { Tool } from "@falai/agent";
20
+
21
+ const weatherTool: Tool<unknown, WeatherData, [], string> = {
22
+ id: "get_weather",
23
+ name: "Weather Forecast", // Human-readable name shown to AI models
24
+ description: "Get current weather and forecast for a location",
25
+ parameters: {
26
+ type: "object",
27
+ properties: {
28
+ location: { type: "string", description: "City or location name" },
29
+ date: { type: "string", description: "Date for forecast (YYYY-MM-DD)" },
30
+ },
31
+ required: ["location"],
32
+ },
33
+ handler: async ({ location, date }) => {
34
+ const weather = await weatherAPI.getForecast(location, date);
35
+ return {
36
+ data: `The weather in ${location} on ${date} is ${weather.condition}`,
37
+ contextUpdate: {
38
+ currentWeather: weather,
39
+ lastWeatherCheck: new Date().toISOString(),
40
+ },
41
+ };
42
+ },
43
+ };
44
+ ```
45
+
46
+ ## Tool Name
47
+
48
+ The optional `name` field provides a human-readable name for the tool that is displayed to AI models. When provided, this name takes precedence over the `id` field in AI provider interactions:
49
+
50
+ ```typescript
51
+ const calculatorTool: Tool<unknown, CalcData, [], string> = {
52
+ id: "math_calculator", // Internal identifier
53
+ name: "Math Calculator", // Display name for AI models
54
+ description: "Perform mathematical calculations",
55
+ // ... rest of tool definition
56
+ };
57
+ ```
58
+
59
+ **Benefits:**
60
+
61
+ - **Better AI Understanding**: Clear, descriptive names help AI models choose appropriate tools
62
+ - **User-Friendly**: More readable than cryptic IDs in AI responses and logs
63
+ - **Backward Compatible**: Falls back to `id` if `name` is not provided
64
+ - **Flexible**: Allows separation of internal IDs from user-facing names
65
+
66
+ ## Tool Parameters
67
+
68
+ Tool parameters are defined using JSON Schema:
69
+
70
+ ```typescript
71
+ const searchTool: Tool<unknown, SearchData, [], string> = {
72
+ id: "web_search",
73
+ name: "Web Search Engine",
74
+ description: "Search the web for information",
75
+ parameters: {
76
+ type: "object",
77
+ properties: {
78
+ query: {
79
+ type: "string",
80
+ description: "Search query",
81
+ minLength: 1,
82
+ maxLength: 200,
83
+ },
84
+ limit: {
85
+ type: "number",
86
+ description: "Maximum number of results",
87
+ minimum: 1,
88
+ maximum: 50,
89
+ default: 10,
90
+ },
91
+ },
92
+ required: ["query"],
93
+ },
94
+ handler: async ({ query, limit = 10 }) => {
95
+ const results = await searchAPI.query(query, limit);
96
+ return {
97
+ data: `Found ${results.length} results for "${query}"`,
98
+ contextUpdate: { searchResults: results },
99
+ };
100
+ },
101
+ };
102
+ ```
103
+
104
+ ## Tool Execution Context
105
+
106
+ Tools receive execution context including:
107
+
108
+ - **Current context** - Agent and route context
109
+ - **Session data** - Collected conversation data
110
+ - **Route information** - Current route and step details
111
+
112
+ ```typescript
113
+ const userProfileTool: Tool<unknown, UserData, [], string> = {
114
+ id: "get_user_profile",
115
+ description: "Retrieve user profile information",
116
+ parameters: {
117
+ type: "object",
118
+ properties: {
119
+ userId: {
120
+ type: "string",
121
+ description: "User ID (optional, uses context if not provided)",
122
+ },
123
+ },
124
+ },
125
+ handler: async (toolContext, args) => {
126
+ // Access current context
127
+ const currentUserId = toolContext.context.userId || args.userId;
128
+
129
+ // Access collected data
130
+ const preferences = toolContext.data.userPreferences;
131
+
132
+ const profile = await userAPI.getProfile(currentUserId);
133
+ return {
134
+ data: `Retrieved profile for ${profile.name}`,
135
+ dataUpdate: { userProfile: profile },
136
+ };
137
+ },
138
+ };
139
+ ```
140
+
141
+ ## Tool Response Format
142
+
143
+ Tools return structured responses with multiple components:
144
+
145
+ ```typescript
146
+ interface ToolResult {
147
+ success: boolean;
148
+ result?: {
149
+ data: unknown; // User-visible result
150
+ contextUpdate?: Partial<TContext>; // Context modifications
151
+ dataUpdate?: Partial<TData>; // Session data updates
152
+ };
153
+ error?: string; // Error message if failed
154
+ }
155
+ ```
156
+
157
+ ## Context Updates
158
+
159
+ Tools can modify conversation context:
160
+
161
+ ```typescript
162
+ const locationTool: Tool<unknown, LocationData, [], string> = {
163
+ id: "set_location",
164
+ description: "Update the user's location in context",
165
+ parameters: {
166
+ type: "object",
167
+ properties: {
168
+ location: { type: "string", description: "New location" },
169
+ },
170
+ required: ["location"],
171
+ },
172
+ handler: async (toolContext, args) => {
173
+ return {
174
+ data: `Location set to ${args.location}`,
175
+ contextUpdate: {
176
+ currentLocation: args.location,
177
+ locationSetAt: new Date().toISOString(),
178
+ locationHistory: (prev: string[]) => [...(prev || []), args.location],
179
+ },
180
+ };
181
+ },
182
+ };
183
+ ```
184
+
185
+ ## Data Collection Updates
186
+
187
+ Tools can update session data collected during conversation:
188
+
189
+ ```typescript
190
+ const validationTool: Tool<unknown, BookingData, [], string> = {
191
+ id: "validate_booking",
192
+ description: "Validate booking information and update session data",
193
+ parameters: {
194
+ type: "object",
195
+ properties: {},
196
+ },
197
+ handler: async (toolContext) => {
198
+ const validation = await bookingAPI.validate(toolContext.data.bookingInfo);
199
+
200
+ if (!validation.valid) {
201
+ return {
202
+ data: `Booking validation failed: ${validation.errors.join(", ")}`,
203
+ dataUpdate: {
204
+ bookingErrors: validation.errors,
205
+ bookingValid: false,
206
+ },
207
+ };
208
+ }
209
+
210
+ return {
211
+ data: "Booking validated successfully",
212
+ dataUpdate: {
213
+ bookingValid: true,
214
+ validatedAt: new Date().toISOString(),
215
+ },
216
+ };
217
+ },
218
+ };
219
+ ```
220
+
221
+ ## Error Handling
222
+
223
+ Tools should handle errors gracefully:
224
+
225
+ ```typescript
226
+ const apiTool: Tool<unknown, ApiData, [], string> = {
227
+ id: "call_external_api",
228
+ description: "Call an external API endpoint",
229
+ parameters: {
230
+ type: "object",
231
+ properties: {
232
+ endpoint: { type: "string", description: "API endpoint to call" },
233
+ },
234
+ required: ["endpoint"],
235
+ },
236
+ handler: async (toolContext, args) => {
237
+ try {
238
+ const result = await externalAPI.call(args.endpoint);
239
+ return {
240
+ data: `API call successful: ${result}`,
241
+ };
242
+ } catch (error) {
243
+ const errorMessage =
244
+ error instanceof Error ? error.message : "Unknown error";
245
+ return {
246
+ data: `API call failed: ${errorMessage}`,
247
+ contextUpdate: { lastApiError: errorMessage },
248
+ };
249
+ }
250
+ },
251
+ };
252
+ ```
253
+
254
+ ## Tool Scoping
255
+
256
+ Tools can be registered at different levels:
257
+
258
+ ### Agent-Level Tools
259
+
260
+ Available to all routes and steps:
261
+
262
+ ```typescript
263
+ const agent = new Agent({
264
+ name: "Assistant",
265
+ provider: openaiProvider,
266
+ tools: [globalSearchTool, userManagementTool],
267
+ });
268
+ ```
269
+
270
+ ### Route-Level Tools
271
+
272
+ Available only within specific routes:
273
+
274
+ ```typescript
275
+ const supportRoute = agent.createRoute({
276
+ title: "Customer Support",
277
+ tools: [ticketCreationTool, knowledgeBaseTool],
278
+ });
279
+ ```
280
+
281
+ ### Step-Level Tools
282
+
283
+ Available only in specific steps:
284
+
285
+ ```typescript
286
+ const bookingStep = route.initialStep.nextStep({
287
+ prompt: "Ready to book?",
288
+ tools: [paymentProcessingTool],
289
+ requires: ["bookingDetails"],
290
+ });
291
+ ```
292
+
293
+ ## Tool Resolution Priority
294
+
295
+ When multiple tools with the same name exist, priority is:
296
+
297
+ 1. **Step-level tools** (highest priority)
298
+ 2. **Route-level tools**
299
+ 3. **Agent-level tools** (lowest priority)
300
+
301
+ ## Async Tools
302
+
303
+ Tools support async operations and Promises:
304
+
305
+ ```typescript
306
+ const asyncTool: Tool<unknown, ProcessingData, [], string> = {
307
+ id: "process_data",
308
+ description: "Process data asynchronously with heavy computation",
309
+ parameters: {
310
+ type: "object",
311
+ properties: {
312
+ data: { type: "object", description: "Data to process" },
313
+ },
314
+ required: ["data"],
315
+ },
316
+ handler: async (toolContext, args) => {
317
+ // Simulate async processing
318
+ await new Promise((resolve) => setTimeout(resolve, 1000));
319
+
320
+ const processed = await heavyComputation(args.data);
321
+
322
+ return {
323
+ data: "Data processed successfully",
324
+ dataUpdate: { processedData: processed },
325
+ };
326
+ },
327
+ };
328
+ ```
329
+
330
+ ## Tool Validation
331
+
332
+ Tools are validated at registration time:
333
+
334
+ - **Schema validation** - Parameter schemas must be valid JSON Schema
335
+ - **Type checking** - TypeScript types must match schemas
336
+ - **Name uniqueness** - Tool names must be unique within scope
337
+
338
+ ## Best Practices
339
+
340
+ - **Keep tools focused** - Each tool should do one thing well
341
+ - **Use descriptive names** - Tool names should be clear and specific
342
+ - **Handle errors gracefully** - Provide meaningful error messages
343
+ - **Leverage context updates** - Use context to maintain conversation state
344
+ - **Validate parameters** - Use JSON Schema constraints effectively
345
+ - **Consider performance** - Avoid long-running operations when possible
346
+ - **Document thoroughly** - Provide clear descriptions for AI usage