lfx-nightly 0.2.0.dev25__py3-none-any.whl

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.

Potentially problematic release.


This version of lfx-nightly might be problematic. Click here for more details.

Files changed (769) hide show
  1. lfx/__init__.py +0 -0
  2. lfx/__main__.py +25 -0
  3. lfx/_assets/component_index.json +1 -0
  4. lfx/base/__init__.py +0 -0
  5. lfx/base/agents/__init__.py +0 -0
  6. lfx/base/agents/agent.py +375 -0
  7. lfx/base/agents/altk_base_agent.py +380 -0
  8. lfx/base/agents/altk_tool_wrappers.py +565 -0
  9. lfx/base/agents/callback.py +130 -0
  10. lfx/base/agents/context.py +109 -0
  11. lfx/base/agents/crewai/__init__.py +0 -0
  12. lfx/base/agents/crewai/crew.py +231 -0
  13. lfx/base/agents/crewai/tasks.py +12 -0
  14. lfx/base/agents/default_prompts.py +23 -0
  15. lfx/base/agents/errors.py +15 -0
  16. lfx/base/agents/events.py +430 -0
  17. lfx/base/agents/utils.py +237 -0
  18. lfx/base/astra_assistants/__init__.py +0 -0
  19. lfx/base/astra_assistants/util.py +171 -0
  20. lfx/base/chains/__init__.py +0 -0
  21. lfx/base/chains/model.py +19 -0
  22. lfx/base/composio/__init__.py +0 -0
  23. lfx/base/composio/composio_base.py +2584 -0
  24. lfx/base/compressors/__init__.py +0 -0
  25. lfx/base/compressors/model.py +60 -0
  26. lfx/base/constants.py +46 -0
  27. lfx/base/curl/__init__.py +0 -0
  28. lfx/base/curl/parse.py +188 -0
  29. lfx/base/data/__init__.py +5 -0
  30. lfx/base/data/base_file.py +810 -0
  31. lfx/base/data/docling_utils.py +338 -0
  32. lfx/base/data/storage_utils.py +192 -0
  33. lfx/base/data/utils.py +362 -0
  34. lfx/base/datastax/__init__.py +5 -0
  35. lfx/base/datastax/astradb_base.py +896 -0
  36. lfx/base/document_transformers/__init__.py +0 -0
  37. lfx/base/document_transformers/model.py +43 -0
  38. lfx/base/embeddings/__init__.py +0 -0
  39. lfx/base/embeddings/aiml_embeddings.py +62 -0
  40. lfx/base/embeddings/embeddings_class.py +113 -0
  41. lfx/base/embeddings/model.py +26 -0
  42. lfx/base/flow_processing/__init__.py +0 -0
  43. lfx/base/flow_processing/utils.py +86 -0
  44. lfx/base/huggingface/__init__.py +0 -0
  45. lfx/base/huggingface/model_bridge.py +133 -0
  46. lfx/base/io/__init__.py +0 -0
  47. lfx/base/io/chat.py +21 -0
  48. lfx/base/io/text.py +22 -0
  49. lfx/base/knowledge_bases/__init__.py +3 -0
  50. lfx/base/knowledge_bases/knowledge_base_utils.py +137 -0
  51. lfx/base/langchain_utilities/__init__.py +0 -0
  52. lfx/base/langchain_utilities/model.py +35 -0
  53. lfx/base/langchain_utilities/spider_constants.py +1 -0
  54. lfx/base/langwatch/__init__.py +0 -0
  55. lfx/base/langwatch/utils.py +18 -0
  56. lfx/base/mcp/__init__.py +0 -0
  57. lfx/base/mcp/constants.py +2 -0
  58. lfx/base/mcp/util.py +1659 -0
  59. lfx/base/memory/__init__.py +0 -0
  60. lfx/base/memory/memory.py +49 -0
  61. lfx/base/memory/model.py +38 -0
  62. lfx/base/models/__init__.py +3 -0
  63. lfx/base/models/aiml_constants.py +51 -0
  64. lfx/base/models/anthropic_constants.py +51 -0
  65. lfx/base/models/aws_constants.py +151 -0
  66. lfx/base/models/chat_result.py +76 -0
  67. lfx/base/models/cometapi_constants.py +54 -0
  68. lfx/base/models/google_generative_ai_constants.py +70 -0
  69. lfx/base/models/google_generative_ai_model.py +38 -0
  70. lfx/base/models/groq_constants.py +150 -0
  71. lfx/base/models/groq_model_discovery.py +265 -0
  72. lfx/base/models/model.py +375 -0
  73. lfx/base/models/model_input_constants.py +378 -0
  74. lfx/base/models/model_metadata.py +41 -0
  75. lfx/base/models/model_utils.py +108 -0
  76. lfx/base/models/novita_constants.py +35 -0
  77. lfx/base/models/ollama_constants.py +52 -0
  78. lfx/base/models/openai_constants.py +129 -0
  79. lfx/base/models/sambanova_constants.py +18 -0
  80. lfx/base/models/watsonx_constants.py +36 -0
  81. lfx/base/processing/__init__.py +0 -0
  82. lfx/base/prompts/__init__.py +0 -0
  83. lfx/base/prompts/api_utils.py +224 -0
  84. lfx/base/prompts/utils.py +61 -0
  85. lfx/base/textsplitters/__init__.py +0 -0
  86. lfx/base/textsplitters/model.py +28 -0
  87. lfx/base/tools/__init__.py +0 -0
  88. lfx/base/tools/base.py +26 -0
  89. lfx/base/tools/component_tool.py +325 -0
  90. lfx/base/tools/constants.py +49 -0
  91. lfx/base/tools/flow_tool.py +132 -0
  92. lfx/base/tools/run_flow.py +698 -0
  93. lfx/base/vectorstores/__init__.py +0 -0
  94. lfx/base/vectorstores/model.py +193 -0
  95. lfx/base/vectorstores/utils.py +22 -0
  96. lfx/base/vectorstores/vector_store_connection_decorator.py +52 -0
  97. lfx/cli/__init__.py +5 -0
  98. lfx/cli/commands.py +327 -0
  99. lfx/cli/common.py +650 -0
  100. lfx/cli/run.py +506 -0
  101. lfx/cli/script_loader.py +289 -0
  102. lfx/cli/serve_app.py +546 -0
  103. lfx/cli/validation.py +69 -0
  104. lfx/components/FAISS/__init__.py +34 -0
  105. lfx/components/FAISS/faiss.py +111 -0
  106. lfx/components/Notion/__init__.py +19 -0
  107. lfx/components/Notion/add_content_to_page.py +269 -0
  108. lfx/components/Notion/create_page.py +94 -0
  109. lfx/components/Notion/list_database_properties.py +68 -0
  110. lfx/components/Notion/list_pages.py +122 -0
  111. lfx/components/Notion/list_users.py +77 -0
  112. lfx/components/Notion/page_content_viewer.py +93 -0
  113. lfx/components/Notion/search.py +111 -0
  114. lfx/components/Notion/update_page_property.py +114 -0
  115. lfx/components/__init__.py +428 -0
  116. lfx/components/_importing.py +42 -0
  117. lfx/components/agentql/__init__.py +3 -0
  118. lfx/components/agentql/agentql_api.py +151 -0
  119. lfx/components/aiml/__init__.py +37 -0
  120. lfx/components/aiml/aiml.py +115 -0
  121. lfx/components/aiml/aiml_embeddings.py +37 -0
  122. lfx/components/altk/__init__.py +34 -0
  123. lfx/components/altk/altk_agent.py +193 -0
  124. lfx/components/amazon/__init__.py +36 -0
  125. lfx/components/amazon/amazon_bedrock_converse.py +195 -0
  126. lfx/components/amazon/amazon_bedrock_embedding.py +109 -0
  127. lfx/components/amazon/amazon_bedrock_model.py +130 -0
  128. lfx/components/amazon/s3_bucket_uploader.py +211 -0
  129. lfx/components/anthropic/__init__.py +34 -0
  130. lfx/components/anthropic/anthropic.py +187 -0
  131. lfx/components/apify/__init__.py +5 -0
  132. lfx/components/apify/apify_actor.py +325 -0
  133. lfx/components/arxiv/__init__.py +3 -0
  134. lfx/components/arxiv/arxiv.py +169 -0
  135. lfx/components/assemblyai/__init__.py +46 -0
  136. lfx/components/assemblyai/assemblyai_get_subtitles.py +83 -0
  137. lfx/components/assemblyai/assemblyai_lemur.py +183 -0
  138. lfx/components/assemblyai/assemblyai_list_transcripts.py +95 -0
  139. lfx/components/assemblyai/assemblyai_poll_transcript.py +72 -0
  140. lfx/components/assemblyai/assemblyai_start_transcript.py +188 -0
  141. lfx/components/azure/__init__.py +37 -0
  142. lfx/components/azure/azure_openai.py +95 -0
  143. lfx/components/azure/azure_openai_embeddings.py +83 -0
  144. lfx/components/baidu/__init__.py +32 -0
  145. lfx/components/baidu/baidu_qianfan_chat.py +113 -0
  146. lfx/components/bing/__init__.py +3 -0
  147. lfx/components/bing/bing_search_api.py +61 -0
  148. lfx/components/cassandra/__init__.py +40 -0
  149. lfx/components/cassandra/cassandra.py +264 -0
  150. lfx/components/cassandra/cassandra_chat.py +92 -0
  151. lfx/components/cassandra/cassandra_graph.py +238 -0
  152. lfx/components/chains/__init__.py +3 -0
  153. lfx/components/chroma/__init__.py +34 -0
  154. lfx/components/chroma/chroma.py +169 -0
  155. lfx/components/cleanlab/__init__.py +40 -0
  156. lfx/components/cleanlab/cleanlab_evaluator.py +155 -0
  157. lfx/components/cleanlab/cleanlab_rag_evaluator.py +254 -0
  158. lfx/components/cleanlab/cleanlab_remediator.py +131 -0
  159. lfx/components/clickhouse/__init__.py +34 -0
  160. lfx/components/clickhouse/clickhouse.py +135 -0
  161. lfx/components/cloudflare/__init__.py +32 -0
  162. lfx/components/cloudflare/cloudflare.py +81 -0
  163. lfx/components/cohere/__init__.py +40 -0
  164. lfx/components/cohere/cohere_embeddings.py +81 -0
  165. lfx/components/cohere/cohere_models.py +46 -0
  166. lfx/components/cohere/cohere_rerank.py +51 -0
  167. lfx/components/cometapi/__init__.py +32 -0
  168. lfx/components/cometapi/cometapi.py +166 -0
  169. lfx/components/composio/__init__.py +222 -0
  170. lfx/components/composio/agentql_composio.py +11 -0
  171. lfx/components/composio/agiled_composio.py +11 -0
  172. lfx/components/composio/airtable_composio.py +11 -0
  173. lfx/components/composio/apollo_composio.py +11 -0
  174. lfx/components/composio/asana_composio.py +11 -0
  175. lfx/components/composio/attio_composio.py +11 -0
  176. lfx/components/composio/bitbucket_composio.py +11 -0
  177. lfx/components/composio/bolna_composio.py +11 -0
  178. lfx/components/composio/brightdata_composio.py +11 -0
  179. lfx/components/composio/calendly_composio.py +11 -0
  180. lfx/components/composio/canva_composio.py +11 -0
  181. lfx/components/composio/canvas_composio.py +11 -0
  182. lfx/components/composio/coda_composio.py +11 -0
  183. lfx/components/composio/composio_api.py +278 -0
  184. lfx/components/composio/contentful_composio.py +11 -0
  185. lfx/components/composio/digicert_composio.py +11 -0
  186. lfx/components/composio/discord_composio.py +11 -0
  187. lfx/components/composio/dropbox_compnent.py +11 -0
  188. lfx/components/composio/elevenlabs_composio.py +11 -0
  189. lfx/components/composio/exa_composio.py +11 -0
  190. lfx/components/composio/figma_composio.py +11 -0
  191. lfx/components/composio/finage_composio.py +11 -0
  192. lfx/components/composio/firecrawl_composio.py +11 -0
  193. lfx/components/composio/fireflies_composio.py +11 -0
  194. lfx/components/composio/fixer_composio.py +11 -0
  195. lfx/components/composio/flexisign_composio.py +11 -0
  196. lfx/components/composio/freshdesk_composio.py +11 -0
  197. lfx/components/composio/github_composio.py +11 -0
  198. lfx/components/composio/gmail_composio.py +38 -0
  199. lfx/components/composio/googlebigquery_composio.py +11 -0
  200. lfx/components/composio/googlecalendar_composio.py +11 -0
  201. lfx/components/composio/googleclassroom_composio.py +11 -0
  202. lfx/components/composio/googledocs_composio.py +11 -0
  203. lfx/components/composio/googlemeet_composio.py +11 -0
  204. lfx/components/composio/googlesheets_composio.py +11 -0
  205. lfx/components/composio/googletasks_composio.py +8 -0
  206. lfx/components/composio/heygen_composio.py +11 -0
  207. lfx/components/composio/instagram_composio.py +11 -0
  208. lfx/components/composio/jira_composio.py +11 -0
  209. lfx/components/composio/jotform_composio.py +11 -0
  210. lfx/components/composio/klaviyo_composio.py +11 -0
  211. lfx/components/composio/linear_composio.py +11 -0
  212. lfx/components/composio/listennotes_composio.py +11 -0
  213. lfx/components/composio/mem0_composio.py +11 -0
  214. lfx/components/composio/miro_composio.py +11 -0
  215. lfx/components/composio/missive_composio.py +11 -0
  216. lfx/components/composio/notion_composio.py +11 -0
  217. lfx/components/composio/onedrive_composio.py +11 -0
  218. lfx/components/composio/outlook_composio.py +11 -0
  219. lfx/components/composio/pandadoc_composio.py +11 -0
  220. lfx/components/composio/peopledatalabs_composio.py +11 -0
  221. lfx/components/composio/perplexityai_composio.py +11 -0
  222. lfx/components/composio/reddit_composio.py +11 -0
  223. lfx/components/composio/serpapi_composio.py +11 -0
  224. lfx/components/composio/slack_composio.py +11 -0
  225. lfx/components/composio/slackbot_composio.py +11 -0
  226. lfx/components/composio/snowflake_composio.py +11 -0
  227. lfx/components/composio/supabase_composio.py +11 -0
  228. lfx/components/composio/tavily_composio.py +11 -0
  229. lfx/components/composio/timelinesai_composio.py +11 -0
  230. lfx/components/composio/todoist_composio.py +11 -0
  231. lfx/components/composio/wrike_composio.py +11 -0
  232. lfx/components/composio/youtube_composio.py +11 -0
  233. lfx/components/confluence/__init__.py +3 -0
  234. lfx/components/confluence/confluence.py +84 -0
  235. lfx/components/couchbase/__init__.py +34 -0
  236. lfx/components/couchbase/couchbase.py +102 -0
  237. lfx/components/crewai/__init__.py +49 -0
  238. lfx/components/crewai/crewai.py +108 -0
  239. lfx/components/crewai/hierarchical_crew.py +47 -0
  240. lfx/components/crewai/hierarchical_task.py +45 -0
  241. lfx/components/crewai/sequential_crew.py +53 -0
  242. lfx/components/crewai/sequential_task.py +74 -0
  243. lfx/components/crewai/sequential_task_agent.py +144 -0
  244. lfx/components/cuga/__init__.py +34 -0
  245. lfx/components/cuga/cuga_agent.py +730 -0
  246. lfx/components/custom_component/__init__.py +34 -0
  247. lfx/components/custom_component/custom_component.py +31 -0
  248. lfx/components/data/__init__.py +114 -0
  249. lfx/components/data_source/__init__.py +58 -0
  250. lfx/components/data_source/api_request.py +577 -0
  251. lfx/components/data_source/csv_to_data.py +101 -0
  252. lfx/components/data_source/json_to_data.py +106 -0
  253. lfx/components/data_source/mock_data.py +398 -0
  254. lfx/components/data_source/news_search.py +166 -0
  255. lfx/components/data_source/rss.py +71 -0
  256. lfx/components/data_source/sql_executor.py +101 -0
  257. lfx/components/data_source/url.py +311 -0
  258. lfx/components/data_source/web_search.py +326 -0
  259. lfx/components/datastax/__init__.py +76 -0
  260. lfx/components/datastax/astradb_assistant_manager.py +307 -0
  261. lfx/components/datastax/astradb_chatmemory.py +40 -0
  262. lfx/components/datastax/astradb_cql.py +288 -0
  263. lfx/components/datastax/astradb_graph.py +217 -0
  264. lfx/components/datastax/astradb_tool.py +378 -0
  265. lfx/components/datastax/astradb_vectorize.py +122 -0
  266. lfx/components/datastax/astradb_vectorstore.py +449 -0
  267. lfx/components/datastax/create_assistant.py +59 -0
  268. lfx/components/datastax/create_thread.py +33 -0
  269. lfx/components/datastax/dotenv.py +36 -0
  270. lfx/components/datastax/get_assistant.py +38 -0
  271. lfx/components/datastax/getenvvar.py +31 -0
  272. lfx/components/datastax/graph_rag.py +141 -0
  273. lfx/components/datastax/hcd.py +315 -0
  274. lfx/components/datastax/list_assistants.py +26 -0
  275. lfx/components/datastax/run.py +90 -0
  276. lfx/components/deactivated/__init__.py +15 -0
  277. lfx/components/deactivated/amazon_kendra.py +66 -0
  278. lfx/components/deactivated/chat_litellm_model.py +158 -0
  279. lfx/components/deactivated/code_block_extractor.py +26 -0
  280. lfx/components/deactivated/documents_to_data.py +22 -0
  281. lfx/components/deactivated/embed.py +16 -0
  282. lfx/components/deactivated/extract_key_from_data.py +46 -0
  283. lfx/components/deactivated/json_document_builder.py +57 -0
  284. lfx/components/deactivated/list_flows.py +20 -0
  285. lfx/components/deactivated/mcp_sse.py +61 -0
  286. lfx/components/deactivated/mcp_stdio.py +62 -0
  287. lfx/components/deactivated/merge_data.py +93 -0
  288. lfx/components/deactivated/message.py +37 -0
  289. lfx/components/deactivated/metal.py +54 -0
  290. lfx/components/deactivated/multi_query.py +59 -0
  291. lfx/components/deactivated/retriever.py +43 -0
  292. lfx/components/deactivated/selective_passthrough.py +77 -0
  293. lfx/components/deactivated/should_run_next.py +40 -0
  294. lfx/components/deactivated/split_text.py +63 -0
  295. lfx/components/deactivated/store_message.py +24 -0
  296. lfx/components/deactivated/sub_flow.py +124 -0
  297. lfx/components/deactivated/vectara_self_query.py +76 -0
  298. lfx/components/deactivated/vector_store.py +24 -0
  299. lfx/components/deepseek/__init__.py +34 -0
  300. lfx/components/deepseek/deepseek.py +136 -0
  301. lfx/components/docling/__init__.py +43 -0
  302. lfx/components/docling/chunk_docling_document.py +186 -0
  303. lfx/components/docling/docling_inline.py +238 -0
  304. lfx/components/docling/docling_remote.py +195 -0
  305. lfx/components/docling/export_docling_document.py +117 -0
  306. lfx/components/documentloaders/__init__.py +3 -0
  307. lfx/components/duckduckgo/__init__.py +3 -0
  308. lfx/components/duckduckgo/duck_duck_go_search_run.py +92 -0
  309. lfx/components/elastic/__init__.py +37 -0
  310. lfx/components/elastic/elasticsearch.py +267 -0
  311. lfx/components/elastic/opensearch.py +789 -0
  312. lfx/components/elastic/opensearch_multimodal.py +1575 -0
  313. lfx/components/embeddings/__init__.py +37 -0
  314. lfx/components/embeddings/similarity.py +77 -0
  315. lfx/components/embeddings/text_embedder.py +65 -0
  316. lfx/components/exa/__init__.py +3 -0
  317. lfx/components/exa/exa_search.py +68 -0
  318. lfx/components/files_and_knowledge/__init__.py +47 -0
  319. lfx/components/files_and_knowledge/directory.py +113 -0
  320. lfx/components/files_and_knowledge/file.py +841 -0
  321. lfx/components/files_and_knowledge/ingestion.py +694 -0
  322. lfx/components/files_and_knowledge/retrieval.py +264 -0
  323. lfx/components/files_and_knowledge/save_file.py +746 -0
  324. lfx/components/firecrawl/__init__.py +43 -0
  325. lfx/components/firecrawl/firecrawl_crawl_api.py +88 -0
  326. lfx/components/firecrawl/firecrawl_extract_api.py +136 -0
  327. lfx/components/firecrawl/firecrawl_map_api.py +89 -0
  328. lfx/components/firecrawl/firecrawl_scrape_api.py +73 -0
  329. lfx/components/flow_controls/__init__.py +58 -0
  330. lfx/components/flow_controls/conditional_router.py +208 -0
  331. lfx/components/flow_controls/data_conditional_router.py +126 -0
  332. lfx/components/flow_controls/flow_tool.py +111 -0
  333. lfx/components/flow_controls/listen.py +29 -0
  334. lfx/components/flow_controls/loop.py +163 -0
  335. lfx/components/flow_controls/notify.py +88 -0
  336. lfx/components/flow_controls/pass_message.py +36 -0
  337. lfx/components/flow_controls/run_flow.py +108 -0
  338. lfx/components/flow_controls/sub_flow.py +115 -0
  339. lfx/components/git/__init__.py +4 -0
  340. lfx/components/git/git.py +262 -0
  341. lfx/components/git/gitextractor.py +196 -0
  342. lfx/components/glean/__init__.py +3 -0
  343. lfx/components/glean/glean_search_api.py +173 -0
  344. lfx/components/google/__init__.py +17 -0
  345. lfx/components/google/gmail.py +193 -0
  346. lfx/components/google/google_bq_sql_executor.py +157 -0
  347. lfx/components/google/google_drive.py +92 -0
  348. lfx/components/google/google_drive_search.py +152 -0
  349. lfx/components/google/google_generative_ai.py +144 -0
  350. lfx/components/google/google_generative_ai_embeddings.py +141 -0
  351. lfx/components/google/google_oauth_token.py +89 -0
  352. lfx/components/google/google_search_api_core.py +68 -0
  353. lfx/components/google/google_serper_api_core.py +74 -0
  354. lfx/components/groq/__init__.py +34 -0
  355. lfx/components/groq/groq.py +143 -0
  356. lfx/components/helpers/__init__.py +154 -0
  357. lfx/components/homeassistant/__init__.py +7 -0
  358. lfx/components/homeassistant/home_assistant_control.py +152 -0
  359. lfx/components/homeassistant/list_home_assistant_states.py +137 -0
  360. lfx/components/huggingface/__init__.py +37 -0
  361. lfx/components/huggingface/huggingface.py +199 -0
  362. lfx/components/huggingface/huggingface_inference_api.py +106 -0
  363. lfx/components/ibm/__init__.py +34 -0
  364. lfx/components/ibm/watsonx.py +207 -0
  365. lfx/components/ibm/watsonx_embeddings.py +135 -0
  366. lfx/components/icosacomputing/__init__.py +5 -0
  367. lfx/components/icosacomputing/combinatorial_reasoner.py +84 -0
  368. lfx/components/input_output/__init__.py +40 -0
  369. lfx/components/input_output/chat.py +109 -0
  370. lfx/components/input_output/chat_output.py +184 -0
  371. lfx/components/input_output/text.py +27 -0
  372. lfx/components/input_output/text_output.py +29 -0
  373. lfx/components/input_output/webhook.py +56 -0
  374. lfx/components/jigsawstack/__init__.py +23 -0
  375. lfx/components/jigsawstack/ai_scrape.py +126 -0
  376. lfx/components/jigsawstack/ai_web_search.py +136 -0
  377. lfx/components/jigsawstack/file_read.py +115 -0
  378. lfx/components/jigsawstack/file_upload.py +94 -0
  379. lfx/components/jigsawstack/image_generation.py +205 -0
  380. lfx/components/jigsawstack/nsfw.py +60 -0
  381. lfx/components/jigsawstack/object_detection.py +124 -0
  382. lfx/components/jigsawstack/sentiment.py +112 -0
  383. lfx/components/jigsawstack/text_to_sql.py +90 -0
  384. lfx/components/jigsawstack/text_translate.py +77 -0
  385. lfx/components/jigsawstack/vocr.py +107 -0
  386. lfx/components/knowledge_bases/__init__.py +89 -0
  387. lfx/components/langchain_utilities/__init__.py +109 -0
  388. lfx/components/langchain_utilities/character.py +53 -0
  389. lfx/components/langchain_utilities/conversation.py +59 -0
  390. lfx/components/langchain_utilities/csv_agent.py +175 -0
  391. lfx/components/langchain_utilities/fake_embeddings.py +26 -0
  392. lfx/components/langchain_utilities/html_link_extractor.py +35 -0
  393. lfx/components/langchain_utilities/json_agent.py +100 -0
  394. lfx/components/langchain_utilities/langchain_hub.py +126 -0
  395. lfx/components/langchain_utilities/language_recursive.py +49 -0
  396. lfx/components/langchain_utilities/language_semantic.py +138 -0
  397. lfx/components/langchain_utilities/llm_checker.py +39 -0
  398. lfx/components/langchain_utilities/llm_math.py +42 -0
  399. lfx/components/langchain_utilities/natural_language.py +61 -0
  400. lfx/components/langchain_utilities/openai_tools.py +53 -0
  401. lfx/components/langchain_utilities/openapi.py +48 -0
  402. lfx/components/langchain_utilities/recursive_character.py +60 -0
  403. lfx/components/langchain_utilities/retrieval_qa.py +83 -0
  404. lfx/components/langchain_utilities/runnable_executor.py +137 -0
  405. lfx/components/langchain_utilities/self_query.py +80 -0
  406. lfx/components/langchain_utilities/spider.py +142 -0
  407. lfx/components/langchain_utilities/sql.py +40 -0
  408. lfx/components/langchain_utilities/sql_database.py +35 -0
  409. lfx/components/langchain_utilities/sql_generator.py +78 -0
  410. lfx/components/langchain_utilities/tool_calling.py +59 -0
  411. lfx/components/langchain_utilities/vector_store_info.py +49 -0
  412. lfx/components/langchain_utilities/vector_store_router.py +33 -0
  413. lfx/components/langchain_utilities/xml_agent.py +71 -0
  414. lfx/components/langwatch/__init__.py +3 -0
  415. lfx/components/langwatch/langwatch.py +278 -0
  416. lfx/components/link_extractors/__init__.py +3 -0
  417. lfx/components/llm_operations/__init__.py +46 -0
  418. lfx/components/llm_operations/batch_run.py +205 -0
  419. lfx/components/llm_operations/lambda_filter.py +218 -0
  420. lfx/components/llm_operations/llm_conditional_router.py +421 -0
  421. lfx/components/llm_operations/llm_selector.py +499 -0
  422. lfx/components/llm_operations/structured_output.py +244 -0
  423. lfx/components/lmstudio/__init__.py +34 -0
  424. lfx/components/lmstudio/lmstudioembeddings.py +89 -0
  425. lfx/components/lmstudio/lmstudiomodel.py +133 -0
  426. lfx/components/logic/__init__.py +181 -0
  427. lfx/components/maritalk/__init__.py +32 -0
  428. lfx/components/maritalk/maritalk.py +52 -0
  429. lfx/components/mem0/__init__.py +3 -0
  430. lfx/components/mem0/mem0_chat_memory.py +147 -0
  431. lfx/components/milvus/__init__.py +34 -0
  432. lfx/components/milvus/milvus.py +115 -0
  433. lfx/components/mistral/__init__.py +37 -0
  434. lfx/components/mistral/mistral.py +114 -0
  435. lfx/components/mistral/mistral_embeddings.py +58 -0
  436. lfx/components/models/__init__.py +89 -0
  437. lfx/components/models_and_agents/__init__.py +49 -0
  438. lfx/components/models_and_agents/agent.py +644 -0
  439. lfx/components/models_and_agents/embedding_model.py +423 -0
  440. lfx/components/models_and_agents/language_model.py +398 -0
  441. lfx/components/models_and_agents/mcp_component.py +594 -0
  442. lfx/components/models_and_agents/memory.py +268 -0
  443. lfx/components/models_and_agents/prompt.py +67 -0
  444. lfx/components/mongodb/__init__.py +34 -0
  445. lfx/components/mongodb/mongodb_atlas.py +213 -0
  446. lfx/components/needle/__init__.py +3 -0
  447. lfx/components/needle/needle.py +104 -0
  448. lfx/components/notdiamond/__init__.py +34 -0
  449. lfx/components/notdiamond/notdiamond.py +228 -0
  450. lfx/components/novita/__init__.py +32 -0
  451. lfx/components/novita/novita.py +130 -0
  452. lfx/components/nvidia/__init__.py +57 -0
  453. lfx/components/nvidia/nvidia.py +151 -0
  454. lfx/components/nvidia/nvidia_embedding.py +77 -0
  455. lfx/components/nvidia/nvidia_ingest.py +317 -0
  456. lfx/components/nvidia/nvidia_rerank.py +63 -0
  457. lfx/components/nvidia/system_assist.py +65 -0
  458. lfx/components/olivya/__init__.py +3 -0
  459. lfx/components/olivya/olivya.py +116 -0
  460. lfx/components/ollama/__init__.py +37 -0
  461. lfx/components/ollama/ollama.py +548 -0
  462. lfx/components/ollama/ollama_embeddings.py +103 -0
  463. lfx/components/openai/__init__.py +37 -0
  464. lfx/components/openai/openai.py +100 -0
  465. lfx/components/openai/openai_chat_model.py +176 -0
  466. lfx/components/openrouter/__init__.py +32 -0
  467. lfx/components/openrouter/openrouter.py +104 -0
  468. lfx/components/output_parsers/__init__.py +3 -0
  469. lfx/components/perplexity/__init__.py +34 -0
  470. lfx/components/perplexity/perplexity.py +75 -0
  471. lfx/components/pgvector/__init__.py +34 -0
  472. lfx/components/pgvector/pgvector.py +72 -0
  473. lfx/components/pinecone/__init__.py +34 -0
  474. lfx/components/pinecone/pinecone.py +134 -0
  475. lfx/components/processing/__init__.py +72 -0
  476. lfx/components/processing/alter_metadata.py +109 -0
  477. lfx/components/processing/combine_text.py +40 -0
  478. lfx/components/processing/converter.py +248 -0
  479. lfx/components/processing/create_data.py +111 -0
  480. lfx/components/processing/create_list.py +40 -0
  481. lfx/components/processing/data_operations.py +528 -0
  482. lfx/components/processing/data_to_dataframe.py +71 -0
  483. lfx/components/processing/dataframe_operations.py +313 -0
  484. lfx/components/processing/dataframe_to_toolset.py +259 -0
  485. lfx/components/processing/dynamic_create_data.py +357 -0
  486. lfx/components/processing/extract_key.py +54 -0
  487. lfx/components/processing/filter_data.py +43 -0
  488. lfx/components/processing/filter_data_values.py +89 -0
  489. lfx/components/processing/json_cleaner.py +104 -0
  490. lfx/components/processing/merge_data.py +91 -0
  491. lfx/components/processing/message_to_data.py +37 -0
  492. lfx/components/processing/output_parser.py +46 -0
  493. lfx/components/processing/parse_data.py +71 -0
  494. lfx/components/processing/parse_dataframe.py +69 -0
  495. lfx/components/processing/parse_json_data.py +91 -0
  496. lfx/components/processing/parser.py +148 -0
  497. lfx/components/processing/regex.py +83 -0
  498. lfx/components/processing/select_data.py +49 -0
  499. lfx/components/processing/split_text.py +141 -0
  500. lfx/components/processing/store_message.py +91 -0
  501. lfx/components/processing/update_data.py +161 -0
  502. lfx/components/prototypes/__init__.py +35 -0
  503. lfx/components/prototypes/python_function.py +73 -0
  504. lfx/components/qdrant/__init__.py +34 -0
  505. lfx/components/qdrant/qdrant.py +109 -0
  506. lfx/components/redis/__init__.py +37 -0
  507. lfx/components/redis/redis.py +89 -0
  508. lfx/components/redis/redis_chat.py +43 -0
  509. lfx/components/sambanova/__init__.py +32 -0
  510. lfx/components/sambanova/sambanova.py +84 -0
  511. lfx/components/scrapegraph/__init__.py +40 -0
  512. lfx/components/scrapegraph/scrapegraph_markdownify_api.py +64 -0
  513. lfx/components/scrapegraph/scrapegraph_search_api.py +64 -0
  514. lfx/components/scrapegraph/scrapegraph_smart_scraper_api.py +71 -0
  515. lfx/components/searchapi/__init__.py +34 -0
  516. lfx/components/searchapi/search.py +79 -0
  517. lfx/components/serpapi/__init__.py +3 -0
  518. lfx/components/serpapi/serp.py +115 -0
  519. lfx/components/supabase/__init__.py +34 -0
  520. lfx/components/supabase/supabase.py +76 -0
  521. lfx/components/tavily/__init__.py +4 -0
  522. lfx/components/tavily/tavily_extract.py +117 -0
  523. lfx/components/tavily/tavily_search.py +212 -0
  524. lfx/components/textsplitters/__init__.py +3 -0
  525. lfx/components/toolkits/__init__.py +3 -0
  526. lfx/components/tools/__init__.py +66 -0
  527. lfx/components/tools/calculator.py +109 -0
  528. lfx/components/tools/google_search_api.py +45 -0
  529. lfx/components/tools/google_serper_api.py +115 -0
  530. lfx/components/tools/python_code_structured_tool.py +328 -0
  531. lfx/components/tools/python_repl.py +98 -0
  532. lfx/components/tools/search_api.py +88 -0
  533. lfx/components/tools/searxng.py +145 -0
  534. lfx/components/tools/serp_api.py +120 -0
  535. lfx/components/tools/tavily_search_tool.py +345 -0
  536. lfx/components/tools/wikidata_api.py +103 -0
  537. lfx/components/tools/wikipedia_api.py +50 -0
  538. lfx/components/tools/yahoo_finance.py +130 -0
  539. lfx/components/twelvelabs/__init__.py +52 -0
  540. lfx/components/twelvelabs/convert_astra_results.py +84 -0
  541. lfx/components/twelvelabs/pegasus_index.py +311 -0
  542. lfx/components/twelvelabs/split_video.py +301 -0
  543. lfx/components/twelvelabs/text_embeddings.py +57 -0
  544. lfx/components/twelvelabs/twelvelabs_pegasus.py +408 -0
  545. lfx/components/twelvelabs/video_embeddings.py +100 -0
  546. lfx/components/twelvelabs/video_file.py +191 -0
  547. lfx/components/unstructured/__init__.py +3 -0
  548. lfx/components/unstructured/unstructured.py +121 -0
  549. lfx/components/upstash/__init__.py +34 -0
  550. lfx/components/upstash/upstash.py +124 -0
  551. lfx/components/utilities/__init__.py +43 -0
  552. lfx/components/utilities/calculator_core.py +89 -0
  553. lfx/components/utilities/current_date.py +42 -0
  554. lfx/components/utilities/id_generator.py +42 -0
  555. lfx/components/utilities/python_repl_core.py +98 -0
  556. lfx/components/vectara/__init__.py +37 -0
  557. lfx/components/vectara/vectara.py +97 -0
  558. lfx/components/vectara/vectara_rag.py +164 -0
  559. lfx/components/vectorstores/__init__.py +34 -0
  560. lfx/components/vectorstores/local_db.py +270 -0
  561. lfx/components/vertexai/__init__.py +37 -0
  562. lfx/components/vertexai/vertexai.py +71 -0
  563. lfx/components/vertexai/vertexai_embeddings.py +67 -0
  564. lfx/components/vlmrun/__init__.py +34 -0
  565. lfx/components/vlmrun/vlmrun_transcription.py +224 -0
  566. lfx/components/weaviate/__init__.py +34 -0
  567. lfx/components/weaviate/weaviate.py +89 -0
  568. lfx/components/wikipedia/__init__.py +4 -0
  569. lfx/components/wikipedia/wikidata.py +86 -0
  570. lfx/components/wikipedia/wikipedia.py +53 -0
  571. lfx/components/wolframalpha/__init__.py +3 -0
  572. lfx/components/wolframalpha/wolfram_alpha_api.py +54 -0
  573. lfx/components/xai/__init__.py +32 -0
  574. lfx/components/xai/xai.py +167 -0
  575. lfx/components/yahoosearch/__init__.py +3 -0
  576. lfx/components/yahoosearch/yahoo.py +137 -0
  577. lfx/components/youtube/__init__.py +52 -0
  578. lfx/components/youtube/channel.py +227 -0
  579. lfx/components/youtube/comments.py +231 -0
  580. lfx/components/youtube/playlist.py +33 -0
  581. lfx/components/youtube/search.py +120 -0
  582. lfx/components/youtube/trending.py +285 -0
  583. lfx/components/youtube/video_details.py +263 -0
  584. lfx/components/youtube/youtube_transcripts.py +206 -0
  585. lfx/components/zep/__init__.py +3 -0
  586. lfx/components/zep/zep.py +45 -0
  587. lfx/constants.py +6 -0
  588. lfx/custom/__init__.py +7 -0
  589. lfx/custom/attributes.py +87 -0
  590. lfx/custom/code_parser/__init__.py +3 -0
  591. lfx/custom/code_parser/code_parser.py +361 -0
  592. lfx/custom/custom_component/__init__.py +0 -0
  593. lfx/custom/custom_component/base_component.py +128 -0
  594. lfx/custom/custom_component/component.py +1890 -0
  595. lfx/custom/custom_component/component_with_cache.py +8 -0
  596. lfx/custom/custom_component/custom_component.py +650 -0
  597. lfx/custom/dependency_analyzer.py +165 -0
  598. lfx/custom/directory_reader/__init__.py +3 -0
  599. lfx/custom/directory_reader/directory_reader.py +359 -0
  600. lfx/custom/directory_reader/utils.py +171 -0
  601. lfx/custom/eval.py +12 -0
  602. lfx/custom/schema.py +32 -0
  603. lfx/custom/tree_visitor.py +21 -0
  604. lfx/custom/utils.py +877 -0
  605. lfx/custom/validate.py +523 -0
  606. lfx/events/__init__.py +1 -0
  607. lfx/events/event_manager.py +110 -0
  608. lfx/exceptions/__init__.py +0 -0
  609. lfx/exceptions/component.py +15 -0
  610. lfx/field_typing/__init__.py +91 -0
  611. lfx/field_typing/constants.py +216 -0
  612. lfx/field_typing/range_spec.py +35 -0
  613. lfx/graph/__init__.py +6 -0
  614. lfx/graph/edge/__init__.py +0 -0
  615. lfx/graph/edge/base.py +300 -0
  616. lfx/graph/edge/schema.py +119 -0
  617. lfx/graph/edge/utils.py +0 -0
  618. lfx/graph/graph/__init__.py +0 -0
  619. lfx/graph/graph/ascii.py +202 -0
  620. lfx/graph/graph/base.py +2298 -0
  621. lfx/graph/graph/constants.py +63 -0
  622. lfx/graph/graph/runnable_vertices_manager.py +133 -0
  623. lfx/graph/graph/schema.py +53 -0
  624. lfx/graph/graph/state_model.py +66 -0
  625. lfx/graph/graph/utils.py +1024 -0
  626. lfx/graph/schema.py +75 -0
  627. lfx/graph/state/__init__.py +0 -0
  628. lfx/graph/state/model.py +250 -0
  629. lfx/graph/utils.py +206 -0
  630. lfx/graph/vertex/__init__.py +0 -0
  631. lfx/graph/vertex/base.py +826 -0
  632. lfx/graph/vertex/constants.py +0 -0
  633. lfx/graph/vertex/exceptions.py +4 -0
  634. lfx/graph/vertex/param_handler.py +316 -0
  635. lfx/graph/vertex/schema.py +26 -0
  636. lfx/graph/vertex/utils.py +19 -0
  637. lfx/graph/vertex/vertex_types.py +489 -0
  638. lfx/helpers/__init__.py +141 -0
  639. lfx/helpers/base_model.py +71 -0
  640. lfx/helpers/custom.py +13 -0
  641. lfx/helpers/data.py +167 -0
  642. lfx/helpers/flow.py +308 -0
  643. lfx/inputs/__init__.py +68 -0
  644. lfx/inputs/constants.py +2 -0
  645. lfx/inputs/input_mixin.py +352 -0
  646. lfx/inputs/inputs.py +718 -0
  647. lfx/inputs/validators.py +19 -0
  648. lfx/interface/__init__.py +6 -0
  649. lfx/interface/components.py +897 -0
  650. lfx/interface/importing/__init__.py +5 -0
  651. lfx/interface/importing/utils.py +39 -0
  652. lfx/interface/initialize/__init__.py +3 -0
  653. lfx/interface/initialize/loading.py +317 -0
  654. lfx/interface/listing.py +26 -0
  655. lfx/interface/run.py +16 -0
  656. lfx/interface/utils.py +111 -0
  657. lfx/io/__init__.py +63 -0
  658. lfx/io/schema.py +295 -0
  659. lfx/load/__init__.py +8 -0
  660. lfx/load/load.py +256 -0
  661. lfx/load/utils.py +99 -0
  662. lfx/log/__init__.py +5 -0
  663. lfx/log/logger.py +411 -0
  664. lfx/logging/__init__.py +11 -0
  665. lfx/logging/logger.py +24 -0
  666. lfx/memory/__init__.py +70 -0
  667. lfx/memory/stubs.py +302 -0
  668. lfx/processing/__init__.py +1 -0
  669. lfx/processing/process.py +238 -0
  670. lfx/processing/utils.py +25 -0
  671. lfx/py.typed +0 -0
  672. lfx/schema/__init__.py +66 -0
  673. lfx/schema/artifact.py +83 -0
  674. lfx/schema/content_block.py +62 -0
  675. lfx/schema/content_types.py +91 -0
  676. lfx/schema/cross_module.py +80 -0
  677. lfx/schema/data.py +309 -0
  678. lfx/schema/dataframe.py +210 -0
  679. lfx/schema/dotdict.py +74 -0
  680. lfx/schema/encoders.py +13 -0
  681. lfx/schema/graph.py +47 -0
  682. lfx/schema/image.py +184 -0
  683. lfx/schema/json_schema.py +186 -0
  684. lfx/schema/log.py +62 -0
  685. lfx/schema/message.py +493 -0
  686. lfx/schema/openai_responses_schemas.py +74 -0
  687. lfx/schema/properties.py +41 -0
  688. lfx/schema/schema.py +180 -0
  689. lfx/schema/serialize.py +13 -0
  690. lfx/schema/table.py +142 -0
  691. lfx/schema/validators.py +114 -0
  692. lfx/serialization/__init__.py +5 -0
  693. lfx/serialization/constants.py +2 -0
  694. lfx/serialization/serialization.py +314 -0
  695. lfx/services/__init__.py +26 -0
  696. lfx/services/base.py +28 -0
  697. lfx/services/cache/__init__.py +6 -0
  698. lfx/services/cache/base.py +183 -0
  699. lfx/services/cache/service.py +166 -0
  700. lfx/services/cache/utils.py +169 -0
  701. lfx/services/chat/__init__.py +1 -0
  702. lfx/services/chat/config.py +2 -0
  703. lfx/services/chat/schema.py +10 -0
  704. lfx/services/database/__init__.py +5 -0
  705. lfx/services/database/service.py +25 -0
  706. lfx/services/deps.py +194 -0
  707. lfx/services/factory.py +19 -0
  708. lfx/services/initialize.py +19 -0
  709. lfx/services/interfaces.py +103 -0
  710. lfx/services/manager.py +185 -0
  711. lfx/services/mcp_composer/__init__.py +6 -0
  712. lfx/services/mcp_composer/factory.py +16 -0
  713. lfx/services/mcp_composer/service.py +1441 -0
  714. lfx/services/schema.py +21 -0
  715. lfx/services/session.py +87 -0
  716. lfx/services/settings/__init__.py +3 -0
  717. lfx/services/settings/auth.py +133 -0
  718. lfx/services/settings/base.py +668 -0
  719. lfx/services/settings/constants.py +43 -0
  720. lfx/services/settings/factory.py +23 -0
  721. lfx/services/settings/feature_flags.py +11 -0
  722. lfx/services/settings/service.py +35 -0
  723. lfx/services/settings/utils.py +40 -0
  724. lfx/services/shared_component_cache/__init__.py +1 -0
  725. lfx/services/shared_component_cache/factory.py +30 -0
  726. lfx/services/shared_component_cache/service.py +9 -0
  727. lfx/services/storage/__init__.py +5 -0
  728. lfx/services/storage/local.py +185 -0
  729. lfx/services/storage/service.py +177 -0
  730. lfx/services/tracing/__init__.py +1 -0
  731. lfx/services/tracing/service.py +21 -0
  732. lfx/settings.py +6 -0
  733. lfx/template/__init__.py +6 -0
  734. lfx/template/field/__init__.py +0 -0
  735. lfx/template/field/base.py +260 -0
  736. lfx/template/field/prompt.py +15 -0
  737. lfx/template/frontend_node/__init__.py +6 -0
  738. lfx/template/frontend_node/base.py +214 -0
  739. lfx/template/frontend_node/constants.py +65 -0
  740. lfx/template/frontend_node/custom_components.py +79 -0
  741. lfx/template/template/__init__.py +0 -0
  742. lfx/template/template/base.py +100 -0
  743. lfx/template/utils.py +217 -0
  744. lfx/type_extraction/__init__.py +19 -0
  745. lfx/type_extraction/type_extraction.py +75 -0
  746. lfx/type_extraction.py +80 -0
  747. lfx/utils/__init__.py +1 -0
  748. lfx/utils/async_helpers.py +42 -0
  749. lfx/utils/component_utils.py +154 -0
  750. lfx/utils/concurrency.py +60 -0
  751. lfx/utils/connection_string_parser.py +11 -0
  752. lfx/utils/constants.py +233 -0
  753. lfx/utils/data_structure.py +212 -0
  754. lfx/utils/exceptions.py +22 -0
  755. lfx/utils/helpers.py +34 -0
  756. lfx/utils/image.py +79 -0
  757. lfx/utils/langflow_utils.py +52 -0
  758. lfx/utils/lazy_load.py +15 -0
  759. lfx/utils/request_utils.py +18 -0
  760. lfx/utils/schemas.py +139 -0
  761. lfx/utils/ssrf_protection.py +384 -0
  762. lfx/utils/util.py +626 -0
  763. lfx/utils/util_strings.py +56 -0
  764. lfx/utils/validate_cloud.py +26 -0
  765. lfx/utils/version.py +24 -0
  766. lfx_nightly-0.2.0.dev25.dist-info/METADATA +312 -0
  767. lfx_nightly-0.2.0.dev25.dist-info/RECORD +769 -0
  768. lfx_nightly-0.2.0.dev25.dist-info/WHEEL +4 -0
  769. lfx_nightly-0.2.0.dev25.dist-info/entry_points.txt +2 -0
@@ -0,0 +1,49 @@
1
+ from __future__ import annotations
2
+
3
+ from typing import TYPE_CHECKING, Any
4
+
5
+ from lfx.components._importing import import_mod
6
+
7
+ if TYPE_CHECKING:
8
+ from lfx.components.models_and_agents.agent import AgentComponent
9
+ from lfx.components.models_and_agents.embedding_model import EmbeddingModelComponent
10
+ from lfx.components.models_and_agents.language_model import LanguageModelComponent
11
+ from lfx.components.models_and_agents.mcp_component import MCPToolsComponent
12
+ from lfx.components.models_and_agents.memory import MemoryComponent
13
+ from lfx.components.models_and_agents.prompt import PromptComponent
14
+
15
+ _dynamic_imports = {
16
+ "AgentComponent": "agent",
17
+ "EmbeddingModelComponent": "embedding_model",
18
+ "LanguageModelComponent": "language_model",
19
+ "MCPToolsComponent": "mcp_component",
20
+ "MemoryComponent": "memory",
21
+ "PromptComponent": "prompt",
22
+ }
23
+
24
+ __all__ = [
25
+ "AgentComponent",
26
+ "EmbeddingModelComponent",
27
+ "LanguageModelComponent",
28
+ "MCPToolsComponent",
29
+ "MemoryComponent",
30
+ "PromptComponent",
31
+ ]
32
+
33
+
34
+ def __getattr__(attr_name: str) -> Any:
35
+ """Lazily import model and agent components on attribute access."""
36
+ if attr_name not in _dynamic_imports:
37
+ msg = f"module '{__name__}' has no attribute '{attr_name}'"
38
+ raise AttributeError(msg)
39
+ try:
40
+ result = import_mod(attr_name, _dynamic_imports[attr_name], __spec__.parent)
41
+ except (ModuleNotFoundError, ImportError, AttributeError) as e:
42
+ msg = f"Could not import '{attr_name}' from '{__name__}': {e}"
43
+ raise AttributeError(msg) from e
44
+ globals()[attr_name] = result
45
+ return result
46
+
47
+
48
+ def __dir__() -> list[str]:
49
+ return list(__all__)
@@ -0,0 +1,644 @@
1
+ import json
2
+ import re
3
+
4
+ from langchain_core.tools import StructuredTool, Tool
5
+ from pydantic import ValidationError
6
+
7
+ from lfx.base.agents.agent import LCToolsAgentComponent
8
+ from lfx.base.agents.events import ExceptionWithMessageError
9
+ from lfx.base.models.model_input_constants import (
10
+ ALL_PROVIDER_FIELDS,
11
+ MODEL_DYNAMIC_UPDATE_FIELDS,
12
+ MODEL_PROVIDERS_DICT,
13
+ MODEL_PROVIDERS_LIST,
14
+ MODELS_METADATA,
15
+ )
16
+ from lfx.base.models.model_utils import get_model_name
17
+ from lfx.components.helpers import CurrentDateComponent
18
+ from lfx.components.langchain_utilities.tool_calling import ToolCallingAgentComponent
19
+ from lfx.components.models_and_agents.memory import MemoryComponent
20
+ from lfx.custom.custom_component.component import get_component_toolkit
21
+ from lfx.custom.utils import update_component_build_config
22
+ from lfx.helpers.base_model import build_model_from_schema
23
+ from lfx.inputs.inputs import BoolInput, SecretStrInput, StrInput
24
+ from lfx.io import DropdownInput, IntInput, MessageTextInput, MultilineInput, Output, TableInput
25
+ from lfx.log.logger import logger
26
+ from lfx.schema.data import Data
27
+ from lfx.schema.dotdict import dotdict
28
+ from lfx.schema.message import Message
29
+ from lfx.schema.table import EditMode
30
+
31
+
32
+ def set_advanced_true(component_input):
33
+ component_input.advanced = True
34
+ return component_input
35
+
36
+
37
+ class AgentComponent(ToolCallingAgentComponent):
38
+ display_name: str = "Agent"
39
+ description: str = "Define the agent's instructions, then enter a task to complete using tools."
40
+ documentation: str = "https://docs.langflow.org/agents"
41
+ icon = "bot"
42
+ beta = False
43
+ name = "Agent"
44
+
45
+ memory_inputs = [set_advanced_true(component_input) for component_input in MemoryComponent().inputs]
46
+
47
+ # Filter out json_mode from OpenAI inputs since we handle structured output differently
48
+ if "OpenAI" in MODEL_PROVIDERS_DICT:
49
+ openai_inputs_filtered = [
50
+ input_field
51
+ for input_field in MODEL_PROVIDERS_DICT["OpenAI"]["inputs"]
52
+ if not (hasattr(input_field, "name") and input_field.name == "json_mode")
53
+ ]
54
+ else:
55
+ openai_inputs_filtered = []
56
+
57
+ inputs = [
58
+ DropdownInput(
59
+ name="agent_llm",
60
+ display_name="Model Provider",
61
+ info="The provider of the language model that the agent will use to generate responses.",
62
+ options=[*MODEL_PROVIDERS_LIST],
63
+ value="OpenAI",
64
+ real_time_refresh=True,
65
+ refresh_button=False,
66
+ input_types=[],
67
+ options_metadata=[MODELS_METADATA[key] for key in MODEL_PROVIDERS_LIST if key in MODELS_METADATA],
68
+ external_options={
69
+ "fields": {
70
+ "data": {
71
+ "node": {
72
+ "name": "connect_other_models",
73
+ "display_name": "Connect other models",
74
+ "icon": "CornerDownLeft",
75
+ }
76
+ }
77
+ },
78
+ },
79
+ ),
80
+ SecretStrInput(
81
+ name="api_key",
82
+ display_name="API Key",
83
+ info="The API key to use for the model.",
84
+ required=True,
85
+ ),
86
+ StrInput(
87
+ name="base_url",
88
+ display_name="Base URL",
89
+ info="The base URL of the API.",
90
+ required=True,
91
+ show=False,
92
+ ),
93
+ StrInput(
94
+ name="project_id",
95
+ display_name="Project ID",
96
+ info="The project ID of the model.",
97
+ required=True,
98
+ show=False,
99
+ ),
100
+ IntInput(
101
+ name="max_output_tokens",
102
+ display_name="Max Output Tokens",
103
+ info="The maximum number of tokens to generate.",
104
+ show=False,
105
+ ),
106
+ *openai_inputs_filtered,
107
+ MultilineInput(
108
+ name="system_prompt",
109
+ display_name="Agent Instructions",
110
+ info="System Prompt: Initial instructions and context provided to guide the agent's behavior.",
111
+ value="You are a helpful assistant that can use tools to answer questions and perform tasks.",
112
+ advanced=False,
113
+ ),
114
+ MessageTextInput(
115
+ name="context_id",
116
+ display_name="Context ID",
117
+ info="The context ID of the chat. Adds an extra layer to the local memory.",
118
+ value="",
119
+ advanced=True,
120
+ ),
121
+ IntInput(
122
+ name="n_messages",
123
+ display_name="Number of Chat History Messages",
124
+ value=100,
125
+ info="Number of chat history messages to retrieve.",
126
+ advanced=True,
127
+ show=True,
128
+ ),
129
+ MultilineInput(
130
+ name="format_instructions",
131
+ display_name="Output Format Instructions",
132
+ info="Generic Template for structured output formatting. Valid only with Structured response.",
133
+ value=(
134
+ "You are an AI that extracts structured JSON objects from unstructured text. "
135
+ "Use a predefined schema with expected types (str, int, float, bool, dict). "
136
+ "Extract ALL relevant instances that match the schema - if multiple patterns exist, capture them all. "
137
+ "Fill missing or ambiguous values with defaults: null for missing values. "
138
+ "Remove exact duplicates but keep variations that have different field values. "
139
+ "Always return valid JSON in the expected format, never throw errors. "
140
+ "If multiple objects can be extracted, return them all in the structured format."
141
+ ),
142
+ advanced=True,
143
+ ),
144
+ TableInput(
145
+ name="output_schema",
146
+ display_name="Output Schema",
147
+ info=(
148
+ "Schema Validation: Define the structure and data types for structured output. "
149
+ "No validation if no output schema."
150
+ ),
151
+ advanced=True,
152
+ required=False,
153
+ value=[],
154
+ table_schema=[
155
+ {
156
+ "name": "name",
157
+ "display_name": "Name",
158
+ "type": "str",
159
+ "description": "Specify the name of the output field.",
160
+ "default": "field",
161
+ "edit_mode": EditMode.INLINE,
162
+ },
163
+ {
164
+ "name": "description",
165
+ "display_name": "Description",
166
+ "type": "str",
167
+ "description": "Describe the purpose of the output field.",
168
+ "default": "description of field",
169
+ "edit_mode": EditMode.POPOVER,
170
+ },
171
+ {
172
+ "name": "type",
173
+ "display_name": "Type",
174
+ "type": "str",
175
+ "edit_mode": EditMode.INLINE,
176
+ "description": ("Indicate the data type of the output field (e.g., str, int, float, bool, dict)."),
177
+ "options": ["str", "int", "float", "bool", "dict"],
178
+ "default": "str",
179
+ },
180
+ {
181
+ "name": "multiple",
182
+ "display_name": "As List",
183
+ "type": "boolean",
184
+ "description": "Set to True if this output field should be a list of the specified type.",
185
+ "default": "False",
186
+ "edit_mode": EditMode.INLINE,
187
+ },
188
+ ],
189
+ ),
190
+ *LCToolsAgentComponent.get_base_inputs(),
191
+ # removed memory inputs from agent component
192
+ # *memory_inputs,
193
+ BoolInput(
194
+ name="add_current_date_tool",
195
+ display_name="Current Date",
196
+ advanced=True,
197
+ info="If true, will add a tool to the agent that returns the current date.",
198
+ value=True,
199
+ ),
200
+ ]
201
+ outputs = [
202
+ Output(name="response", display_name="Response", method="message_response"),
203
+ ]
204
+
205
+ async def get_agent_requirements(self):
206
+ """Get the agent requirements for the agent."""
207
+ llm_model, display_name = await self.get_llm()
208
+ if llm_model is None:
209
+ msg = "No language model selected. Please choose a model to proceed."
210
+ raise ValueError(msg)
211
+ self.model_name = get_model_name(llm_model, display_name=display_name)
212
+
213
+ # Get memory data
214
+ self.chat_history = await self.get_memory_data()
215
+ await logger.adebug(f"Retrieved {len(self.chat_history)} chat history messages")
216
+ if isinstance(self.chat_history, Message):
217
+ self.chat_history = [self.chat_history]
218
+
219
+ # Add current date tool if enabled
220
+ if self.add_current_date_tool:
221
+ if not isinstance(self.tools, list): # type: ignore[has-type]
222
+ self.tools = []
223
+ current_date_tool = (await CurrentDateComponent(**self.get_base_args()).to_toolkit()).pop(0)
224
+
225
+ if not isinstance(current_date_tool, StructuredTool):
226
+ msg = "CurrentDateComponent must be converted to a StructuredTool"
227
+ raise TypeError(msg)
228
+ self.tools.append(current_date_tool)
229
+
230
+ # Set shared callbacks for tracing the tools used by the agent
231
+ self.set_tools_callbacks(self.tools, self._get_shared_callbacks())
232
+
233
+ return llm_model, self.chat_history, self.tools
234
+
235
+ async def message_response(self) -> Message:
236
+ try:
237
+ llm_model, self.chat_history, self.tools = await self.get_agent_requirements()
238
+ # Set up and run agent
239
+ self.set(
240
+ llm=llm_model,
241
+ tools=self.tools or [],
242
+ chat_history=self.chat_history,
243
+ input_value=self.input_value,
244
+ system_prompt=self.system_prompt,
245
+ )
246
+ agent = self.create_agent_runnable()
247
+ result = await self.run_agent(agent)
248
+
249
+ # Store result for potential JSON output
250
+ self._agent_result = result
251
+
252
+ except (ValueError, TypeError, KeyError) as e:
253
+ await logger.aerror(f"{type(e).__name__}: {e!s}")
254
+ raise
255
+ except ExceptionWithMessageError as e:
256
+ await logger.aerror(f"ExceptionWithMessageError occurred: {e}")
257
+ raise
258
+ # Avoid catching blind Exception; let truly unexpected exceptions propagate
259
+ except Exception as e:
260
+ await logger.aerror(f"Unexpected error: {e!s}")
261
+ raise
262
+ else:
263
+ return result
264
+
265
+ def _preprocess_schema(self, schema):
266
+ """Preprocess schema to ensure correct data types for build_model_from_schema."""
267
+ processed_schema = []
268
+ for field in schema:
269
+ processed_field = {
270
+ "name": str(field.get("name", "field")),
271
+ "type": str(field.get("type", "str")),
272
+ "description": str(field.get("description", "")),
273
+ "multiple": field.get("multiple", False),
274
+ }
275
+ # Ensure multiple is handled correctly
276
+ if isinstance(processed_field["multiple"], str):
277
+ processed_field["multiple"] = processed_field["multiple"].lower() in [
278
+ "true",
279
+ "1",
280
+ "t",
281
+ "y",
282
+ "yes",
283
+ ]
284
+ processed_schema.append(processed_field)
285
+ return processed_schema
286
+
287
+ async def build_structured_output_base(self, content: str):
288
+ """Build structured output with optional BaseModel validation."""
289
+ json_pattern = r"\{.*\}"
290
+ schema_error_msg = "Try setting an output schema"
291
+
292
+ # Try to parse content as JSON first
293
+ json_data = None
294
+ try:
295
+ json_data = json.loads(content)
296
+ except json.JSONDecodeError:
297
+ json_match = re.search(json_pattern, content, re.DOTALL)
298
+ if json_match:
299
+ try:
300
+ json_data = json.loads(json_match.group())
301
+ except json.JSONDecodeError:
302
+ return {"content": content, "error": schema_error_msg}
303
+ else:
304
+ return {"content": content, "error": schema_error_msg}
305
+
306
+ # If no output schema provided, return parsed JSON without validation
307
+ if not hasattr(self, "output_schema") or not self.output_schema or len(self.output_schema) == 0:
308
+ return json_data
309
+
310
+ # Use BaseModel validation with schema
311
+ try:
312
+ processed_schema = self._preprocess_schema(self.output_schema)
313
+ output_model = build_model_from_schema(processed_schema)
314
+
315
+ # Validate against the schema
316
+ if isinstance(json_data, list):
317
+ # Multiple objects
318
+ validated_objects = []
319
+ for item in json_data:
320
+ try:
321
+ validated_obj = output_model.model_validate(item)
322
+ validated_objects.append(validated_obj.model_dump())
323
+ except ValidationError as e:
324
+ await logger.aerror(f"Validation error for item: {e}")
325
+ # Include invalid items with error info
326
+ validated_objects.append({"data": item, "validation_error": str(e)})
327
+ return validated_objects
328
+
329
+ # Single object
330
+ try:
331
+ validated_obj = output_model.model_validate(json_data)
332
+ return [validated_obj.model_dump()] # Return as list for consistency
333
+ except ValidationError as e:
334
+ await logger.aerror(f"Validation error: {e}")
335
+ return [{"data": json_data, "validation_error": str(e)}]
336
+
337
+ except (TypeError, ValueError) as e:
338
+ await logger.aerror(f"Error building structured output: {e}")
339
+ # Fallback to parsed JSON without validation
340
+ return json_data
341
+
342
+ async def json_response(self) -> Data:
343
+ """Convert agent response to structured JSON Data output with schema validation."""
344
+ # Always use structured chat agent for JSON response mode for better JSON formatting
345
+ try:
346
+ system_components = []
347
+
348
+ # 1. Agent Instructions (system_prompt)
349
+ agent_instructions = getattr(self, "system_prompt", "") or ""
350
+ if agent_instructions:
351
+ system_components.append(f"{agent_instructions}")
352
+
353
+ # 2. Format Instructions
354
+ format_instructions = getattr(self, "format_instructions", "") or ""
355
+ if format_instructions:
356
+ system_components.append(f"Format instructions: {format_instructions}")
357
+
358
+ # 3. Schema Information from BaseModel
359
+ if hasattr(self, "output_schema") and self.output_schema and len(self.output_schema) > 0:
360
+ try:
361
+ processed_schema = self._preprocess_schema(self.output_schema)
362
+ output_model = build_model_from_schema(processed_schema)
363
+ schema_dict = output_model.model_json_schema()
364
+ schema_info = (
365
+ "You are given some text that may include format instructions, "
366
+ "explanations, or other content alongside a JSON schema.\n\n"
367
+ "Your task:\n"
368
+ "- Extract only the JSON schema.\n"
369
+ "- Return it as valid JSON.\n"
370
+ "- Do not include format instructions, explanations, or extra text.\n\n"
371
+ "Input:\n"
372
+ f"{json.dumps(schema_dict, indent=2)}\n\n"
373
+ "Output (only JSON schema):"
374
+ )
375
+ system_components.append(schema_info)
376
+ except (ValidationError, ValueError, TypeError, KeyError) as e:
377
+ await logger.aerror(f"Could not build schema for prompt: {e}", exc_info=True)
378
+
379
+ # Combine all components
380
+ combined_instructions = "\n\n".join(system_components) if system_components else ""
381
+ llm_model, self.chat_history, self.tools = await self.get_agent_requirements()
382
+ self.set(
383
+ llm=llm_model,
384
+ tools=self.tools or [],
385
+ chat_history=self.chat_history,
386
+ input_value=self.input_value,
387
+ system_prompt=combined_instructions,
388
+ )
389
+
390
+ # Create and run structured chat agent
391
+ try:
392
+ structured_agent = self.create_agent_runnable()
393
+ except (NotImplementedError, ValueError, TypeError) as e:
394
+ await logger.aerror(f"Error with structured chat agent: {e}")
395
+ raise
396
+ try:
397
+ result = await self.run_agent(structured_agent)
398
+ except (
399
+ ExceptionWithMessageError,
400
+ ValueError,
401
+ TypeError,
402
+ RuntimeError,
403
+ ) as e:
404
+ await logger.aerror(f"Error with structured agent result: {e}")
405
+ raise
406
+ # Extract content from structured agent result
407
+ if hasattr(result, "content"):
408
+ content = result.content
409
+ elif hasattr(result, "text"):
410
+ content = result.text
411
+ else:
412
+ content = str(result)
413
+
414
+ except (
415
+ ExceptionWithMessageError,
416
+ ValueError,
417
+ TypeError,
418
+ NotImplementedError,
419
+ AttributeError,
420
+ ) as e:
421
+ await logger.aerror(f"Error with structured chat agent: {e}")
422
+ # Fallback to regular agent
423
+ content_str = "No content returned from agent"
424
+ return Data(data={"content": content_str, "error": str(e)})
425
+
426
+ # Process with structured output validation
427
+ try:
428
+ structured_output = await self.build_structured_output_base(content)
429
+
430
+ # Handle different output formats
431
+ if isinstance(structured_output, list) and structured_output:
432
+ if len(structured_output) == 1:
433
+ return Data(data=structured_output[0])
434
+ return Data(data={"results": structured_output})
435
+ if isinstance(structured_output, dict):
436
+ return Data(data=structured_output)
437
+ return Data(data={"content": content})
438
+
439
+ except (ValueError, TypeError) as e:
440
+ await logger.aerror(f"Error in structured output processing: {e}")
441
+ return Data(data={"content": content, "error": str(e)})
442
+
443
+ async def get_memory_data(self):
444
+ # TODO: This is a temporary fix to avoid message duplication. We should develop a function for this.
445
+ messages = (
446
+ await MemoryComponent(**self.get_base_args())
447
+ .set(
448
+ session_id=self.graph.session_id,
449
+ context_id=self.context_id,
450
+ order="Ascending",
451
+ n_messages=self.n_messages,
452
+ )
453
+ .retrieve_messages()
454
+ )
455
+ return [
456
+ message for message in messages if getattr(message, "id", None) != getattr(self.input_value, "id", None)
457
+ ]
458
+
459
+ async def get_llm(self):
460
+ if not isinstance(self.agent_llm, str):
461
+ return self.agent_llm, None
462
+
463
+ try:
464
+ provider_info = MODEL_PROVIDERS_DICT.get(self.agent_llm)
465
+ if not provider_info:
466
+ msg = f"Invalid model provider: {self.agent_llm}"
467
+ raise ValueError(msg)
468
+
469
+ component_class = provider_info.get("component_class")
470
+ display_name = component_class.display_name
471
+ inputs = provider_info.get("inputs")
472
+ prefix = provider_info.get("prefix", "")
473
+
474
+ return self._build_llm_model(component_class, inputs, prefix), display_name
475
+
476
+ except (AttributeError, ValueError, TypeError, RuntimeError) as e:
477
+ await logger.aerror(f"Error building {self.agent_llm} language model: {e!s}")
478
+ msg = f"Failed to initialize language model: {e!s}"
479
+ raise ValueError(msg) from e
480
+
481
+ def _build_llm_model(self, component, inputs, prefix=""):
482
+ model_kwargs = {}
483
+ for input_ in inputs:
484
+ if hasattr(self, f"{prefix}{input_.name}"):
485
+ model_kwargs[input_.name] = getattr(self, f"{prefix}{input_.name}")
486
+ return component.set(**model_kwargs).build_model()
487
+
488
+ def set_component_params(self, component):
489
+ provider_info = MODEL_PROVIDERS_DICT.get(self.agent_llm)
490
+ if provider_info:
491
+ inputs = provider_info.get("inputs")
492
+ prefix = provider_info.get("prefix")
493
+ # Filter out json_mode and only use attributes that exist on this component
494
+ model_kwargs = {}
495
+ for input_ in inputs:
496
+ if hasattr(self, f"{prefix}{input_.name}"):
497
+ model_kwargs[input_.name] = getattr(self, f"{prefix}{input_.name}")
498
+
499
+ return component.set(**model_kwargs)
500
+ return component
501
+
502
+ def delete_fields(self, build_config: dotdict, fields: dict | list[str]) -> None:
503
+ """Delete specified fields from build_config."""
504
+ for field in fields:
505
+ if build_config is not None and field in build_config:
506
+ build_config.pop(field, None)
507
+
508
+ def update_input_types(self, build_config: dotdict) -> dotdict:
509
+ """Update input types for all fields in build_config."""
510
+ for key, value in build_config.items():
511
+ if isinstance(value, dict):
512
+ if value.get("input_types") is None:
513
+ build_config[key]["input_types"] = []
514
+ elif hasattr(value, "input_types") and value.input_types is None:
515
+ value.input_types = []
516
+ return build_config
517
+
518
+ async def update_build_config(
519
+ self, build_config: dotdict, field_value: str, field_name: str | None = None
520
+ ) -> dotdict:
521
+ # Iterate over all providers in the MODEL_PROVIDERS_DICT
522
+ # Existing logic for updating build_config
523
+ if field_name in ("agent_llm",):
524
+ build_config["agent_llm"]["value"] = field_value
525
+ provider_info = MODEL_PROVIDERS_DICT.get(field_value)
526
+ if provider_info:
527
+ component_class = provider_info.get("component_class")
528
+ if component_class and hasattr(component_class, "update_build_config"):
529
+ # Call the component class's update_build_config method
530
+ build_config = await update_component_build_config(
531
+ component_class, build_config, field_value, "model_name"
532
+ )
533
+
534
+ provider_configs: dict[str, tuple[dict, list[dict]]] = {
535
+ provider: (
536
+ MODEL_PROVIDERS_DICT[provider]["fields"],
537
+ [
538
+ MODEL_PROVIDERS_DICT[other_provider]["fields"]
539
+ for other_provider in MODEL_PROVIDERS_DICT
540
+ if other_provider != provider
541
+ ],
542
+ )
543
+ for provider in MODEL_PROVIDERS_DICT
544
+ }
545
+ if field_value in provider_configs:
546
+ fields_to_add, fields_to_delete = provider_configs[field_value]
547
+
548
+ # Delete fields from other providers
549
+ for fields in fields_to_delete:
550
+ self.delete_fields(build_config, fields)
551
+
552
+ # Add provider-specific fields
553
+ if field_value == "OpenAI" and not any(field in build_config for field in fields_to_add):
554
+ build_config.update(fields_to_add)
555
+ else:
556
+ build_config.update(fields_to_add)
557
+ # Reset input types for agent_llm
558
+ build_config["agent_llm"]["input_types"] = []
559
+ build_config["agent_llm"]["display_name"] = "Model Provider"
560
+ elif field_value == "connect_other_models":
561
+ # Delete all provider fields
562
+ self.delete_fields(build_config, ALL_PROVIDER_FIELDS)
563
+ # # Update with custom component
564
+ custom_component = DropdownInput(
565
+ name="agent_llm",
566
+ display_name="Language Model",
567
+ info="The provider of the language model that the agent will use to generate responses.",
568
+ options=[*MODEL_PROVIDERS_LIST],
569
+ real_time_refresh=True,
570
+ refresh_button=False,
571
+ input_types=["LanguageModel"],
572
+ placeholder="Awaiting model input.",
573
+ options_metadata=[MODELS_METADATA[key] for key in MODEL_PROVIDERS_LIST if key in MODELS_METADATA],
574
+ external_options={
575
+ "fields": {
576
+ "data": {
577
+ "node": {
578
+ "name": "connect_other_models",
579
+ "display_name": "Connect other models",
580
+ "icon": "CornerDownLeft",
581
+ },
582
+ }
583
+ },
584
+ },
585
+ )
586
+ build_config.update({"agent_llm": custom_component.to_dict()})
587
+ # Update input types for all fields
588
+ build_config = self.update_input_types(build_config)
589
+
590
+ # Validate required keys
591
+ default_keys = [
592
+ "code",
593
+ "_type",
594
+ "agent_llm",
595
+ "tools",
596
+ "input_value",
597
+ "add_current_date_tool",
598
+ "system_prompt",
599
+ "agent_description",
600
+ "max_iterations",
601
+ "handle_parsing_errors",
602
+ "verbose",
603
+ ]
604
+ missing_keys = [key for key in default_keys if key not in build_config]
605
+ if missing_keys:
606
+ msg = f"Missing required keys in build_config: {missing_keys}"
607
+ raise ValueError(msg)
608
+ if (
609
+ isinstance(self.agent_llm, str)
610
+ and self.agent_llm in MODEL_PROVIDERS_DICT
611
+ and field_name in MODEL_DYNAMIC_UPDATE_FIELDS
612
+ ):
613
+ provider_info = MODEL_PROVIDERS_DICT.get(self.agent_llm)
614
+ if provider_info:
615
+ component_class = provider_info.get("component_class")
616
+ component_class = self.set_component_params(component_class)
617
+ prefix = provider_info.get("prefix")
618
+ if component_class and hasattr(component_class, "update_build_config"):
619
+ # Call each component class's update_build_config method
620
+ # remove the prefix from the field_name
621
+ if isinstance(field_name, str) and isinstance(prefix, str):
622
+ field_name = field_name.replace(prefix, "")
623
+ build_config = await update_component_build_config(
624
+ component_class, build_config, field_value, "model_name"
625
+ )
626
+ return dotdict({k: v.to_dict() if hasattr(v, "to_dict") else v for k, v in build_config.items()})
627
+
628
+ async def _get_tools(self) -> list[Tool]:
629
+ component_toolkit = get_component_toolkit()
630
+ tools_names = self._build_tools_names()
631
+ agent_description = self.get_tool_description()
632
+ # TODO: Agent Description Depreciated Feature to be removed
633
+ description = f"{agent_description}{tools_names}"
634
+
635
+ tools = component_toolkit(component=self).get_tools(
636
+ tool_name="Call_Agent",
637
+ tool_description=description,
638
+ # here we do not use the shared callbacks as we are exposing the agent as a tool
639
+ callbacks=self.get_langchain_callbacks(),
640
+ )
641
+ if hasattr(self, "tools_metadata"):
642
+ tools = component_toolkit(component=self, metadata=self.tools_metadata).update_tools_metadata(tools=tools)
643
+
644
+ return tools