lfx-nightly 0.1.11.dev0__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.
- lfx/__init__.py +0 -0
- lfx/__main__.py +25 -0
- lfx/base/__init__.py +0 -0
- lfx/base/agents/__init__.py +0 -0
- lfx/base/agents/agent.py +268 -0
- lfx/base/agents/callback.py +130 -0
- lfx/base/agents/context.py +109 -0
- lfx/base/agents/crewai/__init__.py +0 -0
- lfx/base/agents/crewai/crew.py +231 -0
- lfx/base/agents/crewai/tasks.py +12 -0
- lfx/base/agents/default_prompts.py +23 -0
- lfx/base/agents/errors.py +15 -0
- lfx/base/agents/events.py +346 -0
- lfx/base/agents/utils.py +205 -0
- lfx/base/astra_assistants/__init__.py +0 -0
- lfx/base/astra_assistants/util.py +171 -0
- lfx/base/chains/__init__.py +0 -0
- lfx/base/chains/model.py +19 -0
- lfx/base/composio/__init__.py +0 -0
- lfx/base/composio/composio_base.py +1291 -0
- lfx/base/compressors/__init__.py +0 -0
- lfx/base/compressors/model.py +60 -0
- lfx/base/constants.py +46 -0
- lfx/base/curl/__init__.py +0 -0
- lfx/base/curl/parse.py +188 -0
- lfx/base/data/__init__.py +5 -0
- lfx/base/data/base_file.py +685 -0
- lfx/base/data/docling_utils.py +245 -0
- lfx/base/data/utils.py +198 -0
- lfx/base/document_transformers/__init__.py +0 -0
- lfx/base/document_transformers/model.py +43 -0
- lfx/base/embeddings/__init__.py +0 -0
- lfx/base/embeddings/aiml_embeddings.py +62 -0
- lfx/base/embeddings/model.py +26 -0
- lfx/base/flow_processing/__init__.py +0 -0
- lfx/base/flow_processing/utils.py +86 -0
- lfx/base/huggingface/__init__.py +0 -0
- lfx/base/huggingface/model_bridge.py +133 -0
- lfx/base/io/__init__.py +0 -0
- lfx/base/io/chat.py +20 -0
- lfx/base/io/text.py +22 -0
- lfx/base/langchain_utilities/__init__.py +0 -0
- lfx/base/langchain_utilities/model.py +35 -0
- lfx/base/langchain_utilities/spider_constants.py +1 -0
- lfx/base/langwatch/__init__.py +0 -0
- lfx/base/langwatch/utils.py +18 -0
- lfx/base/mcp/__init__.py +0 -0
- lfx/base/mcp/constants.py +2 -0
- lfx/base/mcp/util.py +1398 -0
- lfx/base/memory/__init__.py +0 -0
- lfx/base/memory/memory.py +49 -0
- lfx/base/memory/model.py +38 -0
- lfx/base/models/__init__.py +3 -0
- lfx/base/models/aiml_constants.py +51 -0
- lfx/base/models/anthropic_constants.py +47 -0
- lfx/base/models/aws_constants.py +151 -0
- lfx/base/models/chat_result.py +76 -0
- lfx/base/models/google_generative_ai_constants.py +70 -0
- lfx/base/models/groq_constants.py +134 -0
- lfx/base/models/model.py +375 -0
- lfx/base/models/model_input_constants.py +307 -0
- lfx/base/models/model_metadata.py +41 -0
- lfx/base/models/model_utils.py +8 -0
- lfx/base/models/novita_constants.py +35 -0
- lfx/base/models/ollama_constants.py +49 -0
- lfx/base/models/openai_constants.py +122 -0
- lfx/base/models/sambanova_constants.py +18 -0
- lfx/base/processing/__init__.py +0 -0
- lfx/base/prompts/__init__.py +0 -0
- lfx/base/prompts/api_utils.py +224 -0
- lfx/base/prompts/utils.py +61 -0
- lfx/base/textsplitters/__init__.py +0 -0
- lfx/base/textsplitters/model.py +28 -0
- lfx/base/tools/__init__.py +0 -0
- lfx/base/tools/base.py +26 -0
- lfx/base/tools/component_tool.py +325 -0
- lfx/base/tools/constants.py +49 -0
- lfx/base/tools/flow_tool.py +132 -0
- lfx/base/tools/run_flow.py +224 -0
- lfx/base/vectorstores/__init__.py +0 -0
- lfx/base/vectorstores/model.py +193 -0
- lfx/base/vectorstores/utils.py +22 -0
- lfx/base/vectorstores/vector_store_connection_decorator.py +52 -0
- lfx/cli/__init__.py +5 -0
- lfx/cli/commands.py +319 -0
- lfx/cli/common.py +650 -0
- lfx/cli/run.py +441 -0
- lfx/cli/script_loader.py +247 -0
- lfx/cli/serve_app.py +546 -0
- lfx/cli/validation.py +69 -0
- lfx/components/FAISS/__init__.py +34 -0
- lfx/components/FAISS/faiss.py +111 -0
- lfx/components/Notion/__init__.py +19 -0
- lfx/components/Notion/add_content_to_page.py +269 -0
- lfx/components/Notion/create_page.py +94 -0
- lfx/components/Notion/list_database_properties.py +68 -0
- lfx/components/Notion/list_pages.py +122 -0
- lfx/components/Notion/list_users.py +77 -0
- lfx/components/Notion/page_content_viewer.py +93 -0
- lfx/components/Notion/search.py +111 -0
- lfx/components/Notion/update_page_property.py +114 -0
- lfx/components/__init__.py +411 -0
- lfx/components/_importing.py +42 -0
- lfx/components/agentql/__init__.py +3 -0
- lfx/components/agentql/agentql_api.py +151 -0
- lfx/components/agents/__init__.py +34 -0
- lfx/components/agents/agent.py +558 -0
- lfx/components/agents/mcp_component.py +501 -0
- lfx/components/aiml/__init__.py +37 -0
- lfx/components/aiml/aiml.py +112 -0
- lfx/components/aiml/aiml_embeddings.py +37 -0
- lfx/components/amazon/__init__.py +36 -0
- lfx/components/amazon/amazon_bedrock_embedding.py +109 -0
- lfx/components/amazon/amazon_bedrock_model.py +124 -0
- lfx/components/amazon/s3_bucket_uploader.py +211 -0
- lfx/components/anthropic/__init__.py +34 -0
- lfx/components/anthropic/anthropic.py +187 -0
- lfx/components/apify/__init__.py +5 -0
- lfx/components/apify/apify_actor.py +325 -0
- lfx/components/arxiv/__init__.py +3 -0
- lfx/components/arxiv/arxiv.py +163 -0
- lfx/components/assemblyai/__init__.py +46 -0
- lfx/components/assemblyai/assemblyai_get_subtitles.py +83 -0
- lfx/components/assemblyai/assemblyai_lemur.py +183 -0
- lfx/components/assemblyai/assemblyai_list_transcripts.py +95 -0
- lfx/components/assemblyai/assemblyai_poll_transcript.py +72 -0
- lfx/components/assemblyai/assemblyai_start_transcript.py +188 -0
- lfx/components/azure/__init__.py +37 -0
- lfx/components/azure/azure_openai.py +95 -0
- lfx/components/azure/azure_openai_embeddings.py +83 -0
- lfx/components/baidu/__init__.py +32 -0
- lfx/components/baidu/baidu_qianfan_chat.py +113 -0
- lfx/components/bing/__init__.py +3 -0
- lfx/components/bing/bing_search_api.py +61 -0
- lfx/components/cassandra/__init__.py +40 -0
- lfx/components/cassandra/cassandra.py +264 -0
- lfx/components/cassandra/cassandra_chat.py +92 -0
- lfx/components/cassandra/cassandra_graph.py +238 -0
- lfx/components/chains/__init__.py +3 -0
- lfx/components/chroma/__init__.py +34 -0
- lfx/components/chroma/chroma.py +167 -0
- lfx/components/cleanlab/__init__.py +40 -0
- lfx/components/cleanlab/cleanlab_evaluator.py +155 -0
- lfx/components/cleanlab/cleanlab_rag_evaluator.py +254 -0
- lfx/components/cleanlab/cleanlab_remediator.py +131 -0
- lfx/components/clickhouse/__init__.py +34 -0
- lfx/components/clickhouse/clickhouse.py +135 -0
- lfx/components/cloudflare/__init__.py +32 -0
- lfx/components/cloudflare/cloudflare.py +81 -0
- lfx/components/cohere/__init__.py +40 -0
- lfx/components/cohere/cohere_embeddings.py +81 -0
- lfx/components/cohere/cohere_models.py +46 -0
- lfx/components/cohere/cohere_rerank.py +51 -0
- lfx/components/composio/__init__.py +74 -0
- lfx/components/composio/composio_api.py +268 -0
- lfx/components/composio/dropbox_compnent.py +11 -0
- lfx/components/composio/github_composio.py +11 -0
- lfx/components/composio/gmail_composio.py +38 -0
- lfx/components/composio/googlecalendar_composio.py +11 -0
- lfx/components/composio/googlemeet_composio.py +11 -0
- lfx/components/composio/googletasks_composio.py +8 -0
- lfx/components/composio/linear_composio.py +11 -0
- lfx/components/composio/outlook_composio.py +11 -0
- lfx/components/composio/reddit_composio.py +11 -0
- lfx/components/composio/slack_composio.py +582 -0
- lfx/components/composio/slackbot_composio.py +11 -0
- lfx/components/composio/supabase_composio.py +11 -0
- lfx/components/composio/todoist_composio.py +11 -0
- lfx/components/composio/youtube_composio.py +11 -0
- lfx/components/confluence/__init__.py +3 -0
- lfx/components/confluence/confluence.py +84 -0
- lfx/components/couchbase/__init__.py +34 -0
- lfx/components/couchbase/couchbase.py +102 -0
- lfx/components/crewai/__init__.py +49 -0
- lfx/components/crewai/crewai.py +107 -0
- lfx/components/crewai/hierarchical_crew.py +46 -0
- lfx/components/crewai/hierarchical_task.py +44 -0
- lfx/components/crewai/sequential_crew.py +52 -0
- lfx/components/crewai/sequential_task.py +73 -0
- lfx/components/crewai/sequential_task_agent.py +143 -0
- lfx/components/custom_component/__init__.py +34 -0
- lfx/components/custom_component/custom_component.py +31 -0
- lfx/components/data/__init__.py +64 -0
- lfx/components/data/api_request.py +544 -0
- lfx/components/data/csv_to_data.py +95 -0
- lfx/components/data/directory.py +113 -0
- lfx/components/data/file.py +577 -0
- lfx/components/data/json_to_data.py +98 -0
- lfx/components/data/news_search.py +164 -0
- lfx/components/data/rss.py +69 -0
- lfx/components/data/sql_executor.py +101 -0
- lfx/components/data/url.py +311 -0
- lfx/components/data/web_search.py +112 -0
- lfx/components/data/webhook.py +56 -0
- lfx/components/datastax/__init__.py +70 -0
- lfx/components/datastax/astra_assistant_manager.py +306 -0
- lfx/components/datastax/astra_db.py +75 -0
- lfx/components/datastax/astra_vectorize.py +124 -0
- lfx/components/datastax/astradb.py +1285 -0
- lfx/components/datastax/astradb_cql.py +314 -0
- lfx/components/datastax/astradb_graph.py +330 -0
- lfx/components/datastax/astradb_tool.py +414 -0
- lfx/components/datastax/astradb_vectorstore.py +1285 -0
- lfx/components/datastax/cassandra.py +92 -0
- lfx/components/datastax/create_assistant.py +58 -0
- lfx/components/datastax/create_thread.py +32 -0
- lfx/components/datastax/dotenv.py +35 -0
- lfx/components/datastax/get_assistant.py +37 -0
- lfx/components/datastax/getenvvar.py +30 -0
- lfx/components/datastax/graph_rag.py +141 -0
- lfx/components/datastax/hcd.py +314 -0
- lfx/components/datastax/list_assistants.py +25 -0
- lfx/components/datastax/run.py +89 -0
- lfx/components/deactivated/__init__.py +15 -0
- lfx/components/deactivated/amazon_kendra.py +66 -0
- lfx/components/deactivated/chat_litellm_model.py +158 -0
- lfx/components/deactivated/code_block_extractor.py +26 -0
- lfx/components/deactivated/documents_to_data.py +22 -0
- lfx/components/deactivated/embed.py +16 -0
- lfx/components/deactivated/extract_key_from_data.py +46 -0
- lfx/components/deactivated/json_document_builder.py +57 -0
- lfx/components/deactivated/list_flows.py +20 -0
- lfx/components/deactivated/mcp_sse.py +61 -0
- lfx/components/deactivated/mcp_stdio.py +62 -0
- lfx/components/deactivated/merge_data.py +93 -0
- lfx/components/deactivated/message.py +37 -0
- lfx/components/deactivated/metal.py +54 -0
- lfx/components/deactivated/multi_query.py +59 -0
- lfx/components/deactivated/retriever.py +43 -0
- lfx/components/deactivated/selective_passthrough.py +77 -0
- lfx/components/deactivated/should_run_next.py +40 -0
- lfx/components/deactivated/split_text.py +63 -0
- lfx/components/deactivated/store_message.py +24 -0
- lfx/components/deactivated/sub_flow.py +124 -0
- lfx/components/deactivated/vectara_self_query.py +76 -0
- lfx/components/deactivated/vector_store.py +24 -0
- lfx/components/deepseek/__init__.py +34 -0
- lfx/components/deepseek/deepseek.py +136 -0
- lfx/components/docling/__init__.py +43 -0
- lfx/components/docling/chunk_docling_document.py +186 -0
- lfx/components/docling/docling_inline.py +231 -0
- lfx/components/docling/docling_remote.py +193 -0
- lfx/components/docling/export_docling_document.py +117 -0
- lfx/components/documentloaders/__init__.py +3 -0
- lfx/components/duckduckgo/__init__.py +3 -0
- lfx/components/duckduckgo/duck_duck_go_search_run.py +92 -0
- lfx/components/elastic/__init__.py +37 -0
- lfx/components/elastic/elasticsearch.py +267 -0
- lfx/components/elastic/opensearch.py +243 -0
- lfx/components/embeddings/__init__.py +37 -0
- lfx/components/embeddings/similarity.py +76 -0
- lfx/components/embeddings/text_embedder.py +64 -0
- lfx/components/exa/__init__.py +3 -0
- lfx/components/exa/exa_search.py +68 -0
- lfx/components/firecrawl/__init__.py +43 -0
- lfx/components/firecrawl/firecrawl_crawl_api.py +88 -0
- lfx/components/firecrawl/firecrawl_extract_api.py +136 -0
- lfx/components/firecrawl/firecrawl_map_api.py +89 -0
- lfx/components/firecrawl/firecrawl_scrape_api.py +73 -0
- lfx/components/git/__init__.py +4 -0
- lfx/components/git/git.py +262 -0
- lfx/components/git/gitextractor.py +196 -0
- lfx/components/glean/__init__.py +3 -0
- lfx/components/glean/glean_search_api.py +173 -0
- lfx/components/google/__init__.py +17 -0
- lfx/components/google/gmail.py +192 -0
- lfx/components/google/google_bq_sql_executor.py +157 -0
- lfx/components/google/google_drive.py +92 -0
- lfx/components/google/google_drive_search.py +152 -0
- lfx/components/google/google_generative_ai.py +147 -0
- lfx/components/google/google_generative_ai_embeddings.py +141 -0
- lfx/components/google/google_oauth_token.py +89 -0
- lfx/components/google/google_search_api_core.py +68 -0
- lfx/components/google/google_serper_api_core.py +74 -0
- lfx/components/groq/__init__.py +34 -0
- lfx/components/groq/groq.py +136 -0
- lfx/components/helpers/__init__.py +52 -0
- lfx/components/helpers/calculator_core.py +89 -0
- lfx/components/helpers/create_list.py +40 -0
- lfx/components/helpers/current_date.py +42 -0
- lfx/components/helpers/id_generator.py +42 -0
- lfx/components/helpers/memory.py +251 -0
- lfx/components/helpers/output_parser.py +45 -0
- lfx/components/helpers/store_message.py +90 -0
- lfx/components/homeassistant/__init__.py +7 -0
- lfx/components/homeassistant/home_assistant_control.py +152 -0
- lfx/components/homeassistant/list_home_assistant_states.py +137 -0
- lfx/components/huggingface/__init__.py +37 -0
- lfx/components/huggingface/huggingface.py +197 -0
- lfx/components/huggingface/huggingface_inference_api.py +106 -0
- lfx/components/ibm/__init__.py +34 -0
- lfx/components/ibm/watsonx.py +203 -0
- lfx/components/ibm/watsonx_embeddings.py +135 -0
- lfx/components/icosacomputing/__init__.py +5 -0
- lfx/components/icosacomputing/combinatorial_reasoner.py +84 -0
- lfx/components/input_output/__init__.py +38 -0
- lfx/components/input_output/chat.py +120 -0
- lfx/components/input_output/chat_output.py +200 -0
- lfx/components/input_output/text.py +27 -0
- lfx/components/input_output/text_output.py +29 -0
- lfx/components/jigsawstack/__init__.py +23 -0
- lfx/components/jigsawstack/ai_scrape.py +126 -0
- lfx/components/jigsawstack/ai_web_search.py +136 -0
- lfx/components/jigsawstack/file_read.py +115 -0
- lfx/components/jigsawstack/file_upload.py +94 -0
- lfx/components/jigsawstack/image_generation.py +205 -0
- lfx/components/jigsawstack/nsfw.py +60 -0
- lfx/components/jigsawstack/object_detection.py +124 -0
- lfx/components/jigsawstack/sentiment.py +112 -0
- lfx/components/jigsawstack/text_to_sql.py +90 -0
- lfx/components/jigsawstack/text_translate.py +77 -0
- lfx/components/jigsawstack/vocr.py +107 -0
- lfx/components/langchain_utilities/__init__.py +109 -0
- lfx/components/langchain_utilities/character.py +53 -0
- lfx/components/langchain_utilities/conversation.py +59 -0
- lfx/components/langchain_utilities/csv_agent.py +107 -0
- lfx/components/langchain_utilities/fake_embeddings.py +26 -0
- lfx/components/langchain_utilities/html_link_extractor.py +35 -0
- lfx/components/langchain_utilities/json_agent.py +45 -0
- lfx/components/langchain_utilities/langchain_hub.py +126 -0
- lfx/components/langchain_utilities/language_recursive.py +49 -0
- lfx/components/langchain_utilities/language_semantic.py +138 -0
- lfx/components/langchain_utilities/llm_checker.py +39 -0
- lfx/components/langchain_utilities/llm_math.py +42 -0
- lfx/components/langchain_utilities/natural_language.py +61 -0
- lfx/components/langchain_utilities/openai_tools.py +53 -0
- lfx/components/langchain_utilities/openapi.py +48 -0
- lfx/components/langchain_utilities/recursive_character.py +60 -0
- lfx/components/langchain_utilities/retrieval_qa.py +83 -0
- lfx/components/langchain_utilities/runnable_executor.py +137 -0
- lfx/components/langchain_utilities/self_query.py +80 -0
- lfx/components/langchain_utilities/spider.py +142 -0
- lfx/components/langchain_utilities/sql.py +40 -0
- lfx/components/langchain_utilities/sql_database.py +35 -0
- lfx/components/langchain_utilities/sql_generator.py +78 -0
- lfx/components/langchain_utilities/tool_calling.py +59 -0
- lfx/components/langchain_utilities/vector_store_info.py +49 -0
- lfx/components/langchain_utilities/vector_store_router.py +33 -0
- lfx/components/langchain_utilities/xml_agent.py +71 -0
- lfx/components/langwatch/__init__.py +3 -0
- lfx/components/langwatch/langwatch.py +278 -0
- lfx/components/link_extractors/__init__.py +3 -0
- lfx/components/lmstudio/__init__.py +34 -0
- lfx/components/lmstudio/lmstudioembeddings.py +89 -0
- lfx/components/lmstudio/lmstudiomodel.py +129 -0
- lfx/components/logic/__init__.py +52 -0
- lfx/components/logic/conditional_router.py +171 -0
- lfx/components/logic/data_conditional_router.py +125 -0
- lfx/components/logic/flow_tool.py +110 -0
- lfx/components/logic/listen.py +29 -0
- lfx/components/logic/loop.py +125 -0
- lfx/components/logic/notify.py +88 -0
- lfx/components/logic/pass_message.py +35 -0
- lfx/components/logic/run_flow.py +71 -0
- lfx/components/logic/sub_flow.py +114 -0
- lfx/components/maritalk/__init__.py +32 -0
- lfx/components/maritalk/maritalk.py +52 -0
- lfx/components/mem0/__init__.py +3 -0
- lfx/components/mem0/mem0_chat_memory.py +136 -0
- lfx/components/milvus/__init__.py +34 -0
- lfx/components/milvus/milvus.py +115 -0
- lfx/components/mistral/__init__.py +37 -0
- lfx/components/mistral/mistral.py +114 -0
- lfx/components/mistral/mistral_embeddings.py +58 -0
- lfx/components/models/__init__.py +34 -0
- lfx/components/models/embedding_model.py +114 -0
- lfx/components/models/language_model.py +144 -0
- lfx/components/mongodb/__init__.py +34 -0
- lfx/components/mongodb/mongodb_atlas.py +213 -0
- lfx/components/needle/__init__.py +3 -0
- lfx/components/needle/needle.py +104 -0
- lfx/components/notdiamond/__init__.py +34 -0
- lfx/components/notdiamond/notdiamond.py +228 -0
- lfx/components/novita/__init__.py +32 -0
- lfx/components/novita/novita.py +130 -0
- lfx/components/nvidia/__init__.py +57 -0
- lfx/components/nvidia/nvidia.py +157 -0
- lfx/components/nvidia/nvidia_embedding.py +77 -0
- lfx/components/nvidia/nvidia_ingest.py +317 -0
- lfx/components/nvidia/nvidia_rerank.py +63 -0
- lfx/components/nvidia/system_assist.py +65 -0
- lfx/components/olivya/__init__.py +3 -0
- lfx/components/olivya/olivya.py +116 -0
- lfx/components/ollama/__init__.py +37 -0
- lfx/components/ollama/ollama.py +330 -0
- lfx/components/ollama/ollama_embeddings.py +106 -0
- lfx/components/openai/__init__.py +37 -0
- lfx/components/openai/openai.py +100 -0
- lfx/components/openai/openai_chat_model.py +176 -0
- lfx/components/openrouter/__init__.py +32 -0
- lfx/components/openrouter/openrouter.py +202 -0
- lfx/components/output_parsers/__init__.py +3 -0
- lfx/components/perplexity/__init__.py +34 -0
- lfx/components/perplexity/perplexity.py +75 -0
- lfx/components/pgvector/__init__.py +34 -0
- lfx/components/pgvector/pgvector.py +72 -0
- lfx/components/pinecone/__init__.py +34 -0
- lfx/components/pinecone/pinecone.py +134 -0
- lfx/components/processing/__init__.py +117 -0
- lfx/components/processing/alter_metadata.py +108 -0
- lfx/components/processing/batch_run.py +205 -0
- lfx/components/processing/combine_text.py +39 -0
- lfx/components/processing/converter.py +159 -0
- lfx/components/processing/create_data.py +110 -0
- lfx/components/processing/data_operations.py +438 -0
- lfx/components/processing/data_to_dataframe.py +70 -0
- lfx/components/processing/dataframe_operations.py +313 -0
- lfx/components/processing/extract_key.py +53 -0
- lfx/components/processing/filter_data.py +42 -0
- lfx/components/processing/filter_data_values.py +88 -0
- lfx/components/processing/json_cleaner.py +103 -0
- lfx/components/processing/lambda_filter.py +154 -0
- lfx/components/processing/llm_router.py +499 -0
- lfx/components/processing/merge_data.py +90 -0
- lfx/components/processing/message_to_data.py +36 -0
- lfx/components/processing/parse_data.py +70 -0
- lfx/components/processing/parse_dataframe.py +68 -0
- lfx/components/processing/parse_json_data.py +90 -0
- lfx/components/processing/parser.py +143 -0
- lfx/components/processing/prompt.py +67 -0
- lfx/components/processing/python_repl_core.py +98 -0
- lfx/components/processing/regex.py +82 -0
- lfx/components/processing/save_file.py +225 -0
- lfx/components/processing/select_data.py +48 -0
- lfx/components/processing/split_text.py +141 -0
- lfx/components/processing/structured_output.py +202 -0
- lfx/components/processing/update_data.py +160 -0
- lfx/components/prototypes/__init__.py +34 -0
- lfx/components/prototypes/python_function.py +73 -0
- lfx/components/qdrant/__init__.py +34 -0
- lfx/components/qdrant/qdrant.py +109 -0
- lfx/components/redis/__init__.py +37 -0
- lfx/components/redis/redis.py +89 -0
- lfx/components/redis/redis_chat.py +43 -0
- lfx/components/sambanova/__init__.py +32 -0
- lfx/components/sambanova/sambanova.py +84 -0
- lfx/components/scrapegraph/__init__.py +40 -0
- lfx/components/scrapegraph/scrapegraph_markdownify_api.py +64 -0
- lfx/components/scrapegraph/scrapegraph_search_api.py +64 -0
- lfx/components/scrapegraph/scrapegraph_smart_scraper_api.py +71 -0
- lfx/components/searchapi/__init__.py +34 -0
- lfx/components/searchapi/search.py +79 -0
- lfx/components/serpapi/__init__.py +3 -0
- lfx/components/serpapi/serp.py +115 -0
- lfx/components/supabase/__init__.py +34 -0
- lfx/components/supabase/supabase.py +76 -0
- lfx/components/tavily/__init__.py +4 -0
- lfx/components/tavily/tavily_extract.py +117 -0
- lfx/components/tavily/tavily_search.py +212 -0
- lfx/components/textsplitters/__init__.py +3 -0
- lfx/components/toolkits/__init__.py +3 -0
- lfx/components/tools/__init__.py +72 -0
- lfx/components/tools/calculator.py +108 -0
- lfx/components/tools/google_search_api.py +45 -0
- lfx/components/tools/google_serper_api.py +115 -0
- lfx/components/tools/python_code_structured_tool.py +327 -0
- lfx/components/tools/python_repl.py +97 -0
- lfx/components/tools/search_api.py +87 -0
- lfx/components/tools/searxng.py +145 -0
- lfx/components/tools/serp_api.py +119 -0
- lfx/components/tools/tavily_search_tool.py +344 -0
- lfx/components/tools/wikidata_api.py +102 -0
- lfx/components/tools/wikipedia_api.py +49 -0
- lfx/components/tools/yahoo_finance.py +129 -0
- lfx/components/twelvelabs/__init__.py +52 -0
- lfx/components/twelvelabs/convert_astra_results.py +84 -0
- lfx/components/twelvelabs/pegasus_index.py +311 -0
- lfx/components/twelvelabs/split_video.py +291 -0
- lfx/components/twelvelabs/text_embeddings.py +57 -0
- lfx/components/twelvelabs/twelvelabs_pegasus.py +408 -0
- lfx/components/twelvelabs/video_embeddings.py +100 -0
- lfx/components/twelvelabs/video_file.py +179 -0
- lfx/components/unstructured/__init__.py +3 -0
- lfx/components/unstructured/unstructured.py +121 -0
- lfx/components/upstash/__init__.py +34 -0
- lfx/components/upstash/upstash.py +124 -0
- lfx/components/vectara/__init__.py +37 -0
- lfx/components/vectara/vectara.py +97 -0
- lfx/components/vectara/vectara_rag.py +164 -0
- lfx/components/vectorstores/__init__.py +40 -0
- lfx/components/vectorstores/astradb.py +1285 -0
- lfx/components/vectorstores/astradb_graph.py +319 -0
- lfx/components/vectorstores/cassandra.py +264 -0
- lfx/components/vectorstores/cassandra_graph.py +238 -0
- lfx/components/vectorstores/chroma.py +167 -0
- lfx/components/vectorstores/clickhouse.py +135 -0
- lfx/components/vectorstores/couchbase.py +102 -0
- lfx/components/vectorstores/elasticsearch.py +267 -0
- lfx/components/vectorstores/faiss.py +111 -0
- lfx/components/vectorstores/graph_rag.py +141 -0
- lfx/components/vectorstores/hcd.py +314 -0
- lfx/components/vectorstores/local_db.py +261 -0
- lfx/components/vectorstores/milvus.py +115 -0
- lfx/components/vectorstores/mongodb_atlas.py +213 -0
- lfx/components/vectorstores/opensearch.py +243 -0
- lfx/components/vectorstores/pgvector.py +72 -0
- lfx/components/vectorstores/pinecone.py +134 -0
- lfx/components/vectorstores/qdrant.py +109 -0
- lfx/components/vectorstores/supabase.py +76 -0
- lfx/components/vectorstores/upstash.py +124 -0
- lfx/components/vectorstores/vectara.py +97 -0
- lfx/components/vectorstores/vectara_rag.py +164 -0
- lfx/components/vectorstores/weaviate.py +89 -0
- lfx/components/vertexai/__init__.py +37 -0
- lfx/components/vertexai/vertexai.py +71 -0
- lfx/components/vertexai/vertexai_embeddings.py +67 -0
- lfx/components/weaviate/__init__.py +34 -0
- lfx/components/weaviate/weaviate.py +89 -0
- lfx/components/wikipedia/__init__.py +4 -0
- lfx/components/wikipedia/wikidata.py +86 -0
- lfx/components/wikipedia/wikipedia.py +53 -0
- lfx/components/wolframalpha/__init__.py +3 -0
- lfx/components/wolframalpha/wolfram_alpha_api.py +54 -0
- lfx/components/xai/__init__.py +32 -0
- lfx/components/xai/xai.py +167 -0
- lfx/components/yahoosearch/__init__.py +3 -0
- lfx/components/yahoosearch/yahoo.py +137 -0
- lfx/components/youtube/__init__.py +52 -0
- lfx/components/youtube/channel.py +227 -0
- lfx/components/youtube/comments.py +231 -0
- lfx/components/youtube/playlist.py +33 -0
- lfx/components/youtube/search.py +120 -0
- lfx/components/youtube/trending.py +285 -0
- lfx/components/youtube/video_details.py +263 -0
- lfx/components/youtube/youtube_transcripts.py +118 -0
- lfx/components/zep/__init__.py +3 -0
- lfx/components/zep/zep.py +44 -0
- lfx/constants.py +6 -0
- lfx/custom/__init__.py +7 -0
- lfx/custom/attributes.py +86 -0
- lfx/custom/code_parser/__init__.py +3 -0
- lfx/custom/code_parser/code_parser.py +361 -0
- lfx/custom/custom_component/__init__.py +0 -0
- lfx/custom/custom_component/base_component.py +128 -0
- lfx/custom/custom_component/component.py +1808 -0
- lfx/custom/custom_component/component_with_cache.py +8 -0
- lfx/custom/custom_component/custom_component.py +588 -0
- lfx/custom/dependency_analyzer.py +165 -0
- lfx/custom/directory_reader/__init__.py +3 -0
- lfx/custom/directory_reader/directory_reader.py +359 -0
- lfx/custom/directory_reader/utils.py +171 -0
- lfx/custom/eval.py +12 -0
- lfx/custom/schema.py +32 -0
- lfx/custom/tree_visitor.py +21 -0
- lfx/custom/utils.py +877 -0
- lfx/custom/validate.py +488 -0
- lfx/events/__init__.py +1 -0
- lfx/events/event_manager.py +110 -0
- lfx/exceptions/__init__.py +0 -0
- lfx/exceptions/component.py +15 -0
- lfx/field_typing/__init__.py +91 -0
- lfx/field_typing/constants.py +215 -0
- lfx/field_typing/range_spec.py +35 -0
- lfx/graph/__init__.py +6 -0
- lfx/graph/edge/__init__.py +0 -0
- lfx/graph/edge/base.py +277 -0
- lfx/graph/edge/schema.py +119 -0
- lfx/graph/edge/utils.py +0 -0
- lfx/graph/graph/__init__.py +0 -0
- lfx/graph/graph/ascii.py +202 -0
- lfx/graph/graph/base.py +2238 -0
- lfx/graph/graph/constants.py +63 -0
- lfx/graph/graph/runnable_vertices_manager.py +133 -0
- lfx/graph/graph/schema.py +52 -0
- lfx/graph/graph/state_model.py +66 -0
- lfx/graph/graph/utils.py +1024 -0
- lfx/graph/schema.py +75 -0
- lfx/graph/state/__init__.py +0 -0
- lfx/graph/state/model.py +237 -0
- lfx/graph/utils.py +200 -0
- lfx/graph/vertex/__init__.py +0 -0
- lfx/graph/vertex/base.py +823 -0
- lfx/graph/vertex/constants.py +0 -0
- lfx/graph/vertex/exceptions.py +4 -0
- lfx/graph/vertex/param_handler.py +264 -0
- lfx/graph/vertex/schema.py +26 -0
- lfx/graph/vertex/utils.py +19 -0
- lfx/graph/vertex/vertex_types.py +489 -0
- lfx/helpers/__init__.py +1 -0
- lfx/helpers/base_model.py +71 -0
- lfx/helpers/custom.py +13 -0
- lfx/helpers/data.py +167 -0
- lfx/helpers/flow.py +194 -0
- lfx/inputs/__init__.py +68 -0
- lfx/inputs/constants.py +2 -0
- lfx/inputs/input_mixin.py +328 -0
- lfx/inputs/inputs.py +714 -0
- lfx/inputs/validators.py +19 -0
- lfx/interface/__init__.py +6 -0
- lfx/interface/components.py +489 -0
- lfx/interface/importing/__init__.py +5 -0
- lfx/interface/importing/utils.py +39 -0
- lfx/interface/initialize/__init__.py +3 -0
- lfx/interface/initialize/loading.py +224 -0
- lfx/interface/listing.py +26 -0
- lfx/interface/run.py +16 -0
- lfx/interface/utils.py +111 -0
- lfx/io/__init__.py +63 -0
- lfx/io/schema.py +289 -0
- lfx/load/__init__.py +8 -0
- lfx/load/load.py +256 -0
- lfx/load/utils.py +99 -0
- lfx/log/__init__.py +5 -0
- lfx/log/logger.py +385 -0
- lfx/memory/__init__.py +90 -0
- lfx/memory/stubs.py +283 -0
- lfx/processing/__init__.py +1 -0
- lfx/processing/process.py +238 -0
- lfx/processing/utils.py +25 -0
- lfx/py.typed +0 -0
- lfx/schema/__init__.py +66 -0
- lfx/schema/artifact.py +83 -0
- lfx/schema/content_block.py +62 -0
- lfx/schema/content_types.py +91 -0
- lfx/schema/data.py +308 -0
- lfx/schema/dataframe.py +210 -0
- lfx/schema/dotdict.py +74 -0
- lfx/schema/encoders.py +13 -0
- lfx/schema/graph.py +47 -0
- lfx/schema/image.py +131 -0
- lfx/schema/json_schema.py +141 -0
- lfx/schema/log.py +61 -0
- lfx/schema/message.py +473 -0
- lfx/schema/openai_responses_schemas.py +74 -0
- lfx/schema/properties.py +41 -0
- lfx/schema/schema.py +171 -0
- lfx/schema/serialize.py +13 -0
- lfx/schema/table.py +140 -0
- lfx/schema/validators.py +114 -0
- lfx/serialization/__init__.py +5 -0
- lfx/serialization/constants.py +2 -0
- lfx/serialization/serialization.py +314 -0
- lfx/services/__init__.py +23 -0
- lfx/services/base.py +28 -0
- lfx/services/cache/__init__.py +6 -0
- lfx/services/cache/base.py +183 -0
- lfx/services/cache/service.py +166 -0
- lfx/services/cache/utils.py +169 -0
- lfx/services/chat/__init__.py +1 -0
- lfx/services/chat/config.py +2 -0
- lfx/services/chat/schema.py +10 -0
- lfx/services/deps.py +129 -0
- lfx/services/factory.py +19 -0
- lfx/services/initialize.py +19 -0
- lfx/services/interfaces.py +103 -0
- lfx/services/manager.py +172 -0
- lfx/services/schema.py +20 -0
- lfx/services/session.py +82 -0
- lfx/services/settings/__init__.py +3 -0
- lfx/services/settings/auth.py +130 -0
- lfx/services/settings/base.py +539 -0
- lfx/services/settings/constants.py +31 -0
- lfx/services/settings/factory.py +23 -0
- lfx/services/settings/feature_flags.py +12 -0
- lfx/services/settings/service.py +35 -0
- lfx/services/settings/utils.py +40 -0
- lfx/services/shared_component_cache/__init__.py +1 -0
- lfx/services/shared_component_cache/factory.py +30 -0
- lfx/services/shared_component_cache/service.py +9 -0
- lfx/services/storage/__init__.py +5 -0
- lfx/services/storage/local.py +155 -0
- lfx/services/storage/service.py +54 -0
- lfx/services/tracing/__init__.py +1 -0
- lfx/services/tracing/service.py +21 -0
- lfx/settings.py +6 -0
- lfx/template/__init__.py +6 -0
- lfx/template/field/__init__.py +0 -0
- lfx/template/field/base.py +257 -0
- lfx/template/field/prompt.py +15 -0
- lfx/template/frontend_node/__init__.py +6 -0
- lfx/template/frontend_node/base.py +212 -0
- lfx/template/frontend_node/constants.py +65 -0
- lfx/template/frontend_node/custom_components.py +79 -0
- lfx/template/template/__init__.py +0 -0
- lfx/template/template/base.py +100 -0
- lfx/template/utils.py +217 -0
- lfx/type_extraction/__init__.py +19 -0
- lfx/type_extraction/type_extraction.py +75 -0
- lfx/type_extraction.py +80 -0
- lfx/utils/__init__.py +1 -0
- lfx/utils/async_helpers.py +42 -0
- lfx/utils/component_utils.py +154 -0
- lfx/utils/concurrency.py +60 -0
- lfx/utils/connection_string_parser.py +11 -0
- lfx/utils/constants.py +205 -0
- lfx/utils/data_structure.py +212 -0
- lfx/utils/exceptions.py +22 -0
- lfx/utils/helpers.py +28 -0
- lfx/utils/image.py +73 -0
- lfx/utils/lazy_load.py +15 -0
- lfx/utils/request_utils.py +18 -0
- lfx/utils/schemas.py +139 -0
- lfx/utils/util.py +481 -0
- lfx/utils/util_strings.py +56 -0
- lfx/utils/version.py +24 -0
- lfx_nightly-0.1.11.dev0.dist-info/METADATA +293 -0
- lfx_nightly-0.1.11.dev0.dist-info/RECORD +699 -0
- lfx_nightly-0.1.11.dev0.dist-info/WHEEL +4 -0
- lfx_nightly-0.1.11.dev0.dist-info/entry_points.txt +2 -0
@@ -0,0 +1,8 @@
|
|
1
|
+
from lfx.custom.custom_component.component import Component
|
2
|
+
from lfx.services.deps import get_shared_component_cache_service
|
3
|
+
|
4
|
+
|
5
|
+
class ComponentWithCache(Component):
|
6
|
+
def __init__(self, **data) -> None:
|
7
|
+
super().__init__(**data)
|
8
|
+
self._shared_component_cache = get_shared_component_cache_service()
|
@@ -0,0 +1,588 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
import uuid
|
4
|
+
from collections.abc import Callable, Sequence
|
5
|
+
from pathlib import Path
|
6
|
+
from typing import TYPE_CHECKING, Any, ClassVar
|
7
|
+
|
8
|
+
import yaml
|
9
|
+
from cachetools import TTLCache
|
10
|
+
from langchain_core.documents import Document
|
11
|
+
from pydantic import BaseModel
|
12
|
+
|
13
|
+
from lfx.custom import validate
|
14
|
+
from lfx.custom.custom_component.base_component import BaseComponent
|
15
|
+
from lfx.helpers.flow import list_flows, load_flow, run_flow
|
16
|
+
from lfx.log.logger import logger
|
17
|
+
from lfx.schema.data import Data
|
18
|
+
from lfx.services.deps import get_storage_service, get_variable_service, session_scope
|
19
|
+
from lfx.services.storage.service import StorageService
|
20
|
+
from lfx.template.utils import update_frontend_node_with_template_values
|
21
|
+
from lfx.type_extraction import post_process_type
|
22
|
+
from lfx.utils.async_helpers import run_until_complete
|
23
|
+
|
24
|
+
if TYPE_CHECKING:
|
25
|
+
from langchain.callbacks.base import BaseCallbackHandler
|
26
|
+
|
27
|
+
from lfx.graph.graph.base import Graph
|
28
|
+
from lfx.graph.vertex.base import Vertex
|
29
|
+
from lfx.schema.dotdict import dotdict
|
30
|
+
from lfx.schema.log import Log
|
31
|
+
from lfx.schema.schema import OutputValue
|
32
|
+
from lfx.services.storage.service import StorageService
|
33
|
+
from lfx.services.tracing.service import TracingService
|
34
|
+
|
35
|
+
|
36
|
+
class CustomComponent(BaseComponent):
|
37
|
+
"""Represents a custom component in Langflow.
|
38
|
+
|
39
|
+
Attributes:
|
40
|
+
name (Optional[str]): This attribute helps the frontend apply styles to known components.
|
41
|
+
display_name (Optional[str]): The display name of the custom component.
|
42
|
+
description (Optional[str]): The description of the custom component.
|
43
|
+
code (Optional[str]): The code of the custom component.
|
44
|
+
field_config (dict): The field configuration of the custom component.
|
45
|
+
code_class_base_inheritance (ClassVar[str]): The base class name for the custom component.
|
46
|
+
function_entrypoint_name (ClassVar[str]): The name of the function entrypoint for the custom component.
|
47
|
+
function (Optional[Callable]): The function associated with the custom component.
|
48
|
+
repr_value (Optional[Any]): The representation value of the custom component.
|
49
|
+
user_id (Optional[Union[UUID, str]]): The user ID associated with the custom component.
|
50
|
+
status (Optional[Any]): The status of the custom component.
|
51
|
+
_tree (Optional[dict]): The code tree of the custom component.
|
52
|
+
"""
|
53
|
+
|
54
|
+
# True constants that should be shared (using ClassVar)
|
55
|
+
_code_class_base_inheritance: ClassVar[str] = "CustomComponent"
|
56
|
+
function_entrypoint_name: ClassVar[str] = "build"
|
57
|
+
name: str | None = None
|
58
|
+
"""The name of the component used to styles. Defaults to None."""
|
59
|
+
display_name: str | None = None
|
60
|
+
"""The display name of the component. Defaults to None."""
|
61
|
+
description: str | None = None
|
62
|
+
"""The description of the component. Defaults to None."""
|
63
|
+
icon: str | None = None
|
64
|
+
"""The icon of the component. It should be an emoji. Defaults to None."""
|
65
|
+
priority: int | None = None
|
66
|
+
"""The priority of the component in the category. Lower priority means it will be displayed first. Defaults to None.
|
67
|
+
"""
|
68
|
+
|
69
|
+
def __init__(self, **data) -> None:
|
70
|
+
"""Initializes a new instance of the CustomComponent class.
|
71
|
+
|
72
|
+
Args:
|
73
|
+
**data: Additional keyword arguments to initialize the custom component.
|
74
|
+
"""
|
75
|
+
# Initialize instance-specific attributes first
|
76
|
+
self.is_input: bool | None = None
|
77
|
+
self.is_output: bool | None = None
|
78
|
+
self.add_tool_output: bool = False
|
79
|
+
self.field_config: dict = {}
|
80
|
+
self.field_order: list[str] | None = None
|
81
|
+
self.frozen: bool = False
|
82
|
+
self.build_parameters: dict | None = None
|
83
|
+
self._vertex: Vertex | None = None
|
84
|
+
self.function: Callable | None = None
|
85
|
+
self.repr_value: Any = ""
|
86
|
+
self.status: Any | None = None
|
87
|
+
|
88
|
+
# Initialize collections with empty defaults
|
89
|
+
self._flows_data: list[Data] | None = None
|
90
|
+
self._outputs: list[OutputValue] = []
|
91
|
+
self._logs: list[Log] = []
|
92
|
+
self._output_logs: dict[str, list[Log] | Log] = {}
|
93
|
+
self._tracing_service: TracingService | None = None
|
94
|
+
self._tree: dict | None = None
|
95
|
+
|
96
|
+
# Initialize additional instance state
|
97
|
+
self.cache: TTLCache = TTLCache(maxsize=1024, ttl=60)
|
98
|
+
self._results: dict = {}
|
99
|
+
self._artifacts: dict = {}
|
100
|
+
|
101
|
+
# Call parent's init after setting up our attributes
|
102
|
+
super().__init__(**data)
|
103
|
+
|
104
|
+
def set_attributes(self, parameters: dict) -> None:
|
105
|
+
pass
|
106
|
+
|
107
|
+
def set_parameters(self, parameters: dict) -> None:
|
108
|
+
self._parameters = parameters
|
109
|
+
self.set_attributes(self._parameters)
|
110
|
+
|
111
|
+
def get_vertex(self):
|
112
|
+
return self._vertex
|
113
|
+
|
114
|
+
def get_results(self):
|
115
|
+
return self._results
|
116
|
+
|
117
|
+
def get_artifacts(self):
|
118
|
+
return self._artifacts
|
119
|
+
|
120
|
+
def set_results(self, results: dict):
|
121
|
+
self._results = results
|
122
|
+
|
123
|
+
def set_artifacts(self, artifacts: dict):
|
124
|
+
self._artifacts = artifacts
|
125
|
+
|
126
|
+
@property
|
127
|
+
def trace_name(self) -> str:
|
128
|
+
if hasattr(self, "_id") and self._id is None:
|
129
|
+
msg = "Component id is not set"
|
130
|
+
raise ValueError(msg)
|
131
|
+
if hasattr(self, "_id"):
|
132
|
+
return f"{self.display_name} ({self._id})"
|
133
|
+
return f"{self.display_name}"
|
134
|
+
|
135
|
+
def stop(self, output_name: str | None = None) -> None:
|
136
|
+
if not output_name and self._vertex and len(self._vertex.outputs) == 1:
|
137
|
+
output_name = self._vertex.outputs[0]["name"]
|
138
|
+
elif not output_name:
|
139
|
+
msg = "You must specify an output name to call stop"
|
140
|
+
raise ValueError(msg)
|
141
|
+
if not self._vertex:
|
142
|
+
msg = "Vertex is not set"
|
143
|
+
raise ValueError(msg)
|
144
|
+
try:
|
145
|
+
self.graph.mark_branch(vertex_id=self._vertex.id, output_name=output_name, state="INACTIVE")
|
146
|
+
except Exception as e:
|
147
|
+
msg = f"Error stopping {self.display_name}: {e}"
|
148
|
+
raise ValueError(msg) from e
|
149
|
+
|
150
|
+
def start(self, output_name: str | None = None) -> None:
|
151
|
+
if not output_name and self._vertex and len(self._vertex.outputs) == 1:
|
152
|
+
output_name = self._vertex.outputs[0]["name"]
|
153
|
+
elif not output_name:
|
154
|
+
msg = "You must specify an output name to call start"
|
155
|
+
raise ValueError(msg)
|
156
|
+
if not self._vertex:
|
157
|
+
msg = "Vertex is not set"
|
158
|
+
raise ValueError(msg)
|
159
|
+
try:
|
160
|
+
self.graph.mark_branch(vertex_id=self._vertex.id, output_name=output_name, state="ACTIVE")
|
161
|
+
except Exception as e:
|
162
|
+
msg = f"Error starting {self.display_name}: {e}"
|
163
|
+
raise ValueError(msg) from e
|
164
|
+
|
165
|
+
@staticmethod
|
166
|
+
def resolve_path(path: str) -> str:
|
167
|
+
"""Resolves the path to an absolute path."""
|
168
|
+
if not path:
|
169
|
+
return path
|
170
|
+
path_object = Path(path)
|
171
|
+
|
172
|
+
if path_object.parts and path_object.parts[0] == "~":
|
173
|
+
path_object = path_object.expanduser()
|
174
|
+
elif path_object.is_relative_to("."):
|
175
|
+
path_object = path_object.resolve()
|
176
|
+
return str(path_object)
|
177
|
+
|
178
|
+
def get_full_path(self, path: str) -> str:
|
179
|
+
storage_svc: StorageService = get_storage_service()
|
180
|
+
|
181
|
+
flow_id, file_name = path.split("/", 1)
|
182
|
+
return storage_svc.build_full_path(flow_id, file_name)
|
183
|
+
|
184
|
+
@property
|
185
|
+
def graph(self):
|
186
|
+
return self._vertex.graph
|
187
|
+
|
188
|
+
@property
|
189
|
+
def user_id(self):
|
190
|
+
if hasattr(self, "_user_id") and self._user_id:
|
191
|
+
return self._user_id
|
192
|
+
return self.graph.user_id
|
193
|
+
|
194
|
+
@property
|
195
|
+
def flow_id(self):
|
196
|
+
return self.graph.flow_id
|
197
|
+
|
198
|
+
@property
|
199
|
+
def flow_name(self):
|
200
|
+
return self.graph.flow_name
|
201
|
+
|
202
|
+
@property
|
203
|
+
def tracing_service(self):
|
204
|
+
"""Lazily initialize tracing service only when accessed."""
|
205
|
+
if self._tracing_service is None:
|
206
|
+
from lfx.services.deps import get_tracing_service
|
207
|
+
|
208
|
+
try:
|
209
|
+
self._tracing_service = get_tracing_service()
|
210
|
+
except Exception: # noqa: BLE001
|
211
|
+
# Broad exception is intentional - we want to gracefully handle any service initialization error
|
212
|
+
self._tracing_service = None
|
213
|
+
return self._tracing_service
|
214
|
+
|
215
|
+
def _get_field_order(self):
|
216
|
+
return self.field_order or list(self.field_config.keys())
|
217
|
+
|
218
|
+
def get_field_order(self):
|
219
|
+
"""Get the field order for the component."""
|
220
|
+
return self._get_field_order()
|
221
|
+
|
222
|
+
def get_function_entrypoint_return_type(self) -> list[Any]:
|
223
|
+
"""Get the return type of the function entrypoint for the custom component."""
|
224
|
+
return self._get_function_entrypoint_return_type
|
225
|
+
|
226
|
+
def custom_repr(self):
|
227
|
+
"""Returns the custom representation of the custom component.
|
228
|
+
|
229
|
+
Returns:
|
230
|
+
str: The custom representation of the custom component.
|
231
|
+
"""
|
232
|
+
if self.repr_value == "":
|
233
|
+
self.repr_value = self.status
|
234
|
+
if isinstance(self.repr_value, dict):
|
235
|
+
return yaml.dump(self.repr_value)
|
236
|
+
if isinstance(self.repr_value, str):
|
237
|
+
return self.repr_value
|
238
|
+
if isinstance(self.repr_value, BaseModel) and not isinstance(self.repr_value, Data):
|
239
|
+
return str(self.repr_value)
|
240
|
+
return self.repr_value
|
241
|
+
|
242
|
+
def build_config(self):
|
243
|
+
"""Builds the configuration for the custom component.
|
244
|
+
|
245
|
+
Returns:
|
246
|
+
dict: The configuration for the custom component.
|
247
|
+
"""
|
248
|
+
return self.field_config
|
249
|
+
|
250
|
+
def update_build_config(
|
251
|
+
self,
|
252
|
+
build_config: dotdict,
|
253
|
+
field_value: Any,
|
254
|
+
field_name: str | None = None,
|
255
|
+
):
|
256
|
+
"""Updates the build configuration for the custom component.
|
257
|
+
|
258
|
+
Do not call directly as implementation can be a coroutine.
|
259
|
+
"""
|
260
|
+
build_config[field_name]["value"] = field_value
|
261
|
+
return build_config
|
262
|
+
|
263
|
+
@property
|
264
|
+
def tree(self):
|
265
|
+
"""Gets the code tree of the custom component.
|
266
|
+
|
267
|
+
Returns:
|
268
|
+
dict: The code tree of the custom component.
|
269
|
+
"""
|
270
|
+
return self.get_code_tree(self._code or "")
|
271
|
+
|
272
|
+
def to_data(self, data: Any, *, keys: list[str] | None = None, silent_errors: bool = False) -> list[Data]:
|
273
|
+
"""Converts input data into a list of Data objects.
|
274
|
+
|
275
|
+
Args:
|
276
|
+
data (Any): The input data to be converted. It can be a single item or a sequence of items.
|
277
|
+
If the input data is a Langchain Document, text_key and data_key are ignored.
|
278
|
+
|
279
|
+
keys (List[str], optional): The keys to access the text and data values in each item.
|
280
|
+
It should be a list of strings where the first element is the text key and the second element
|
281
|
+
is the data key.
|
282
|
+
Defaults to None, in which case the default keys "text" and "data" are used.
|
283
|
+
silent_errors (bool, optional): Whether to suppress errors when the specified keys are not found
|
284
|
+
in the data.
|
285
|
+
|
286
|
+
Returns:
|
287
|
+
List[Data]: A list of Data objects.
|
288
|
+
|
289
|
+
Raises:
|
290
|
+
ValueError: If the input data is not of a valid type or if the specified keys are not found in the data.
|
291
|
+
|
292
|
+
"""
|
293
|
+
if not keys:
|
294
|
+
keys = []
|
295
|
+
data_objects = []
|
296
|
+
if not isinstance(data, Sequence):
|
297
|
+
data = [data]
|
298
|
+
for item in data:
|
299
|
+
data_dict = {}
|
300
|
+
if isinstance(item, Document):
|
301
|
+
data_dict = item.metadata
|
302
|
+
data_dict["text"] = item.page_content
|
303
|
+
elif isinstance(item, BaseModel):
|
304
|
+
model_dump = item.model_dump()
|
305
|
+
for key in keys:
|
306
|
+
if silent_errors:
|
307
|
+
data_dict[key] = model_dump.get(key, "")
|
308
|
+
else:
|
309
|
+
try:
|
310
|
+
data_dict[key] = model_dump[key]
|
311
|
+
except KeyError as e:
|
312
|
+
msg = f"Key {key} not found in {item}"
|
313
|
+
raise ValueError(msg) from e
|
314
|
+
|
315
|
+
elif isinstance(item, str):
|
316
|
+
data_dict = {"text": item}
|
317
|
+
elif isinstance(item, dict):
|
318
|
+
data_dict = item.copy()
|
319
|
+
else:
|
320
|
+
msg = f"Invalid data type: {type(item)}"
|
321
|
+
raise TypeError(msg)
|
322
|
+
|
323
|
+
data_objects.append(Data(data=data_dict))
|
324
|
+
|
325
|
+
return data_objects
|
326
|
+
|
327
|
+
def get_method_return_type(self, method_name: str):
|
328
|
+
build_method = self.get_method(method_name)
|
329
|
+
if not build_method or not build_method.get("has_return"):
|
330
|
+
return []
|
331
|
+
return_type = build_method["return_type"]
|
332
|
+
|
333
|
+
return self._extract_return_type(return_type)
|
334
|
+
|
335
|
+
def create_references_from_data(self, data: list[Data], *, include_data: bool = False) -> str:
|
336
|
+
"""Create references from a list of data.
|
337
|
+
|
338
|
+
Args:
|
339
|
+
data (List[dict]): A list of data, where each record is a dictionary.
|
340
|
+
include_data (bool, optional): Whether to include data in the references. Defaults to False.
|
341
|
+
|
342
|
+
Returns:
|
343
|
+
str: A string containing the references in markdown format.
|
344
|
+
"""
|
345
|
+
if not data:
|
346
|
+
return ""
|
347
|
+
markdown_string = "---\n"
|
348
|
+
for value in data:
|
349
|
+
markdown_string += f"- Text: {value.get_text()}"
|
350
|
+
if include_data:
|
351
|
+
markdown_string += f" Data: {value.data}"
|
352
|
+
markdown_string += "\n"
|
353
|
+
return markdown_string
|
354
|
+
|
355
|
+
@property
|
356
|
+
def get_function_entrypoint_args(self) -> list:
|
357
|
+
"""Gets the arguments of the function entrypoint for the custom component.
|
358
|
+
|
359
|
+
Returns:
|
360
|
+
list: The arguments of the function entrypoint.
|
361
|
+
"""
|
362
|
+
build_method = self.get_method(self._function_entrypoint_name)
|
363
|
+
if not build_method:
|
364
|
+
return []
|
365
|
+
|
366
|
+
args = build_method["args"]
|
367
|
+
for arg in args:
|
368
|
+
if not arg.get("type") and arg.get("name") != "self":
|
369
|
+
# Set the type to Data
|
370
|
+
arg["type"] = "Data"
|
371
|
+
return args
|
372
|
+
|
373
|
+
def get_method(self, method_name: str):
|
374
|
+
"""Gets the build method for the custom component.
|
375
|
+
|
376
|
+
Returns:
|
377
|
+
dict: The build method for the custom component.
|
378
|
+
"""
|
379
|
+
if not self._code:
|
380
|
+
return {}
|
381
|
+
|
382
|
+
component_classes = [
|
383
|
+
cls for cls in self.tree["classes"] if "Component" in cls["bases"] or "CustomComponent" in cls["bases"]
|
384
|
+
]
|
385
|
+
if not component_classes:
|
386
|
+
return {}
|
387
|
+
|
388
|
+
# Assume the first Component class is the one we're interested in
|
389
|
+
component_class = component_classes[0]
|
390
|
+
build_methods = [method for method in component_class["methods"] if method["name"] == (method_name)]
|
391
|
+
|
392
|
+
return build_methods[0] if build_methods else {}
|
393
|
+
|
394
|
+
@property
|
395
|
+
def _get_function_entrypoint_return_type(self) -> list[Any]:
|
396
|
+
"""Gets the return type of the function entrypoint for the custom component.
|
397
|
+
|
398
|
+
Returns:
|
399
|
+
List[Any]: The return type of the function entrypoint.
|
400
|
+
"""
|
401
|
+
return self.get_method_return_type(self._function_entrypoint_name)
|
402
|
+
|
403
|
+
def _extract_return_type(self, return_type: Any) -> list[Any]:
|
404
|
+
return post_process_type(return_type)
|
405
|
+
|
406
|
+
@property
|
407
|
+
def get_main_class_name(self):
|
408
|
+
"""Gets the main class name of the custom component.
|
409
|
+
|
410
|
+
Returns:
|
411
|
+
str: The main class name of the custom component.
|
412
|
+
"""
|
413
|
+
if not self._code:
|
414
|
+
return ""
|
415
|
+
|
416
|
+
base_name = self._code_class_base_inheritance
|
417
|
+
method_name = self._function_entrypoint_name
|
418
|
+
|
419
|
+
classes = []
|
420
|
+
for item in self.tree.get("classes", []):
|
421
|
+
if base_name in item["bases"]:
|
422
|
+
method_names = [method["name"] for method in item["methods"]]
|
423
|
+
if method_name in method_names:
|
424
|
+
classes.append(item["name"])
|
425
|
+
|
426
|
+
# Get just the first item
|
427
|
+
return next(iter(classes), "")
|
428
|
+
|
429
|
+
@property
|
430
|
+
def template_config(self):
|
431
|
+
"""Gets the template configuration for the custom component.
|
432
|
+
|
433
|
+
Returns:
|
434
|
+
dict: The template configuration for the custom component.
|
435
|
+
"""
|
436
|
+
if not self._template_config:
|
437
|
+
self._template_config = self.build_template_config()
|
438
|
+
return self._template_config
|
439
|
+
|
440
|
+
def variables(self, name: str, field: str):
|
441
|
+
"""DEPRECATED - This is kept for backward compatibility. Use get_variables instead."""
|
442
|
+
return run_until_complete(self.get_variables(name, field))
|
443
|
+
|
444
|
+
async def get_variables(self, name: str, field: str):
|
445
|
+
"""DEPRECATED - This is kept for backward compatibility. Use get_variable instead."""
|
446
|
+
async with session_scope() as session:
|
447
|
+
return await self.get_variable(name, field, session)
|
448
|
+
|
449
|
+
async def get_variable(self, name: str, field: str, session):
|
450
|
+
"""Returns the variable for the current user with the specified name.
|
451
|
+
|
452
|
+
Raises:
|
453
|
+
ValueError: If the user id is not set.
|
454
|
+
|
455
|
+
Returns:
|
456
|
+
The variable for the current user with the specified name.
|
457
|
+
"""
|
458
|
+
if hasattr(self, "_user_id") and not self.user_id:
|
459
|
+
msg = f"User id is not set for {self.__class__.__name__}"
|
460
|
+
raise ValueError(msg)
|
461
|
+
|
462
|
+
# Check graph context for request-level variable overrides first
|
463
|
+
if hasattr(self, "graph") and self.graph and hasattr(self.graph, "context"):
|
464
|
+
context = self.graph.context
|
465
|
+
if context and "request_variables" in context:
|
466
|
+
request_variables = context["request_variables"]
|
467
|
+
if name in request_variables:
|
468
|
+
logger.debug(f"Found context override for variable '{name}': {request_variables[name]}")
|
469
|
+
return request_variables[name]
|
470
|
+
|
471
|
+
variable_service = get_variable_service() # Get service instance
|
472
|
+
# Retrieve and decrypt the variable by name for the current user
|
473
|
+
if isinstance(self.user_id, str):
|
474
|
+
user_id = uuid.UUID(self.user_id)
|
475
|
+
elif isinstance(self.user_id, uuid.UUID):
|
476
|
+
user_id = self.user_id
|
477
|
+
else:
|
478
|
+
msg = f"Invalid user id: {self.user_id}"
|
479
|
+
raise TypeError(msg)
|
480
|
+
return await variable_service.get_variable(user_id=user_id, name=name, field=field, session=session)
|
481
|
+
|
482
|
+
async def list_key_names(self):
|
483
|
+
"""Lists the names of the variables for the current user.
|
484
|
+
|
485
|
+
Raises:
|
486
|
+
ValueError: If the user id is not set.
|
487
|
+
|
488
|
+
Returns:
|
489
|
+
List[str]: The names of the variables for the current user.
|
490
|
+
"""
|
491
|
+
if hasattr(self, "_user_id") and not self.user_id:
|
492
|
+
msg = f"User id is not set for {self.__class__.__name__}"
|
493
|
+
raise ValueError(msg)
|
494
|
+
variable_service = get_variable_service()
|
495
|
+
|
496
|
+
async with session_scope() as session:
|
497
|
+
return await variable_service.list_variables(user_id=self.user_id, session=session)
|
498
|
+
|
499
|
+
def index(self, value: int = 0):
|
500
|
+
"""Returns a function that returns the value at the given index in the iterable.
|
501
|
+
|
502
|
+
Args:
|
503
|
+
value (int): The index value.
|
504
|
+
|
505
|
+
Returns:
|
506
|
+
Callable: A function that returns the value at the given index.
|
507
|
+
"""
|
508
|
+
|
509
|
+
def get_index(iterable: list[Any]):
|
510
|
+
return iterable[value] if iterable else iterable
|
511
|
+
|
512
|
+
return get_index
|
513
|
+
|
514
|
+
def get_function(self):
|
515
|
+
"""Gets the function associated with the custom component.
|
516
|
+
|
517
|
+
Returns:
|
518
|
+
Callable: The function associated with the custom component.
|
519
|
+
"""
|
520
|
+
return validate.create_function(self._code, self._function_entrypoint_name)
|
521
|
+
|
522
|
+
async def load_flow(self, flow_id: str, tweaks: dict | None = None) -> Graph:
|
523
|
+
if not self.user_id:
|
524
|
+
msg = "Session is invalid"
|
525
|
+
raise ValueError(msg)
|
526
|
+
return await load_flow(user_id=str(self.user_id), flow_id=flow_id, tweaks=tweaks)
|
527
|
+
|
528
|
+
async def run_flow(
|
529
|
+
self,
|
530
|
+
inputs: dict | list[dict] | None = None,
|
531
|
+
flow_id: str | None = None,
|
532
|
+
flow_name: str | None = None,
|
533
|
+
output_type: str | None = "chat",
|
534
|
+
tweaks: dict | None = None,
|
535
|
+
) -> Any:
|
536
|
+
return await run_flow(
|
537
|
+
inputs=inputs,
|
538
|
+
output_type=output_type,
|
539
|
+
flow_id=flow_id,
|
540
|
+
flow_name=flow_name,
|
541
|
+
tweaks=tweaks,
|
542
|
+
user_id=str(self.user_id),
|
543
|
+
run_id=self.graph.run_id,
|
544
|
+
)
|
545
|
+
|
546
|
+
def list_flows(self) -> list[Data]:
|
547
|
+
"""DEPRECATED - This is kept for backward compatibility. Using alist_flows instead is recommended."""
|
548
|
+
return run_until_complete(self.alist_flows())
|
549
|
+
|
550
|
+
async def alist_flows(self) -> list[Data]:
|
551
|
+
if not self.user_id:
|
552
|
+
msg = "Session is invalid"
|
553
|
+
raise ValueError(msg)
|
554
|
+
try:
|
555
|
+
return await list_flows(user_id=str(self.user_id))
|
556
|
+
except Exception as e:
|
557
|
+
msg = f"Error listing flows: {e}"
|
558
|
+
raise ValueError(msg) from e
|
559
|
+
|
560
|
+
def build(self, *args: Any, **kwargs: Any) -> Any:
|
561
|
+
"""Builds the custom component.
|
562
|
+
|
563
|
+
Args:
|
564
|
+
*args: The positional arguments.
|
565
|
+
**kwargs: The keyword arguments.
|
566
|
+
|
567
|
+
Returns:
|
568
|
+
Any: The result of the build process.
|
569
|
+
"""
|
570
|
+
raise NotImplementedError
|
571
|
+
|
572
|
+
def post_code_processing(self, new_frontend_node: dict, current_frontend_node: dict):
|
573
|
+
"""DEPRECATED - Kept for backward compatibility. Use update_frontend_node instead."""
|
574
|
+
run_until_complete(self.update_frontend_node(new_frontend_node, current_frontend_node))
|
575
|
+
|
576
|
+
async def update_frontend_node(self, new_frontend_node: dict, current_frontend_node: dict):
|
577
|
+
"""Updates the given new frontend node with values from the current frontend node.
|
578
|
+
|
579
|
+
This function is called after the code validation is done.
|
580
|
+
"""
|
581
|
+
return update_frontend_node_with_template_values(
|
582
|
+
frontend_node=new_frontend_node, raw_frontend_node=current_frontend_node
|
583
|
+
)
|
584
|
+
|
585
|
+
def get_langchain_callbacks(self) -> list[BaseCallbackHandler]:
|
586
|
+
if self.tracing_service and hasattr(self.tracing_service, "get_langchain_callbacks"):
|
587
|
+
return self.tracing_service.get_langchain_callbacks()
|
588
|
+
return []
|