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,167 @@
|
|
1
|
+
from copy import deepcopy
|
2
|
+
from typing import TYPE_CHECKING
|
3
|
+
|
4
|
+
from chromadb.config import Settings
|
5
|
+
from langchain_chroma import Chroma
|
6
|
+
from typing_extensions import override
|
7
|
+
|
8
|
+
from lfx.base.vectorstores.model import LCVectorStoreComponent, check_cached_vector_store
|
9
|
+
from lfx.base.vectorstores.utils import chroma_collection_to_data
|
10
|
+
from lfx.inputs.inputs import BoolInput, DropdownInput, HandleInput, IntInput, StrInput
|
11
|
+
from lfx.schema.data import Data
|
12
|
+
|
13
|
+
if TYPE_CHECKING:
|
14
|
+
from lfx.schema.dataframe import DataFrame
|
15
|
+
|
16
|
+
|
17
|
+
class ChromaVectorStoreComponent(LCVectorStoreComponent):
|
18
|
+
"""Chroma Vector Store with search capabilities."""
|
19
|
+
|
20
|
+
display_name: str = "Chroma DB"
|
21
|
+
description: str = "Chroma Vector Store with search capabilities"
|
22
|
+
name = "Chroma"
|
23
|
+
icon = "Chroma"
|
24
|
+
|
25
|
+
inputs = [
|
26
|
+
StrInput(
|
27
|
+
name="collection_name",
|
28
|
+
display_name="Collection Name",
|
29
|
+
value="langflow",
|
30
|
+
),
|
31
|
+
StrInput(
|
32
|
+
name="persist_directory",
|
33
|
+
display_name="Persist Directory",
|
34
|
+
),
|
35
|
+
*LCVectorStoreComponent.inputs,
|
36
|
+
HandleInput(name="embedding", display_name="Embedding", input_types=["Embeddings"]),
|
37
|
+
StrInput(
|
38
|
+
name="chroma_server_cors_allow_origins",
|
39
|
+
display_name="Server CORS Allow Origins",
|
40
|
+
advanced=True,
|
41
|
+
),
|
42
|
+
StrInput(
|
43
|
+
name="chroma_server_host",
|
44
|
+
display_name="Server Host",
|
45
|
+
advanced=True,
|
46
|
+
),
|
47
|
+
IntInput(
|
48
|
+
name="chroma_server_http_port",
|
49
|
+
display_name="Server HTTP Port",
|
50
|
+
advanced=True,
|
51
|
+
),
|
52
|
+
IntInput(
|
53
|
+
name="chroma_server_grpc_port",
|
54
|
+
display_name="Server gRPC Port",
|
55
|
+
advanced=True,
|
56
|
+
),
|
57
|
+
BoolInput(
|
58
|
+
name="chroma_server_ssl_enabled",
|
59
|
+
display_name="Server SSL Enabled",
|
60
|
+
advanced=True,
|
61
|
+
),
|
62
|
+
BoolInput(
|
63
|
+
name="allow_duplicates",
|
64
|
+
display_name="Allow Duplicates",
|
65
|
+
advanced=True,
|
66
|
+
info="If false, will not add documents that are already in the Vector Store.",
|
67
|
+
),
|
68
|
+
DropdownInput(
|
69
|
+
name="search_type",
|
70
|
+
display_name="Search Type",
|
71
|
+
options=["Similarity", "MMR"],
|
72
|
+
value="Similarity",
|
73
|
+
advanced=True,
|
74
|
+
),
|
75
|
+
IntInput(
|
76
|
+
name="number_of_results",
|
77
|
+
display_name="Number of Results",
|
78
|
+
info="Number of results to return.",
|
79
|
+
advanced=True,
|
80
|
+
value=10,
|
81
|
+
),
|
82
|
+
IntInput(
|
83
|
+
name="limit",
|
84
|
+
display_name="Limit",
|
85
|
+
advanced=True,
|
86
|
+
info="Limit the number of records to compare when Allow Duplicates is False.",
|
87
|
+
),
|
88
|
+
]
|
89
|
+
|
90
|
+
@override
|
91
|
+
@check_cached_vector_store
|
92
|
+
def build_vector_store(self) -> Chroma:
|
93
|
+
"""Builds the Chroma object."""
|
94
|
+
try:
|
95
|
+
from chromadb import Client
|
96
|
+
from langchain_chroma import Chroma
|
97
|
+
except ImportError as e:
|
98
|
+
msg = "Could not import Chroma integration package. Please install it with `pip install langchain-chroma`."
|
99
|
+
raise ImportError(msg) from e
|
100
|
+
# Chroma settings
|
101
|
+
chroma_settings = None
|
102
|
+
client = None
|
103
|
+
if self.chroma_server_host:
|
104
|
+
chroma_settings = Settings(
|
105
|
+
chroma_server_cors_allow_origins=self.chroma_server_cors_allow_origins or [],
|
106
|
+
chroma_server_host=self.chroma_server_host,
|
107
|
+
chroma_server_http_port=self.chroma_server_http_port or None,
|
108
|
+
chroma_server_grpc_port=self.chroma_server_grpc_port or None,
|
109
|
+
chroma_server_ssl_enabled=self.chroma_server_ssl_enabled,
|
110
|
+
)
|
111
|
+
client = Client(settings=chroma_settings)
|
112
|
+
|
113
|
+
# Check persist_directory and expand it if it is a relative path
|
114
|
+
persist_directory = self.resolve_path(self.persist_directory) if self.persist_directory is not None else None
|
115
|
+
|
116
|
+
chroma = Chroma(
|
117
|
+
persist_directory=persist_directory,
|
118
|
+
client=client,
|
119
|
+
embedding_function=self.embedding,
|
120
|
+
collection_name=self.collection_name,
|
121
|
+
)
|
122
|
+
|
123
|
+
self._add_documents_to_vector_store(chroma)
|
124
|
+
self.status = chroma_collection_to_data(chroma.get(limit=self.limit))
|
125
|
+
return chroma
|
126
|
+
|
127
|
+
def _add_documents_to_vector_store(self, vector_store: "Chroma") -> None:
|
128
|
+
"""Adds documents to the Vector Store."""
|
129
|
+
ingest_data: list | Data | DataFrame = self.ingest_data
|
130
|
+
if not ingest_data:
|
131
|
+
self.status = ""
|
132
|
+
return
|
133
|
+
|
134
|
+
# Convert DataFrame to Data if needed using parent's method
|
135
|
+
ingest_data = self._prepare_ingest_data()
|
136
|
+
|
137
|
+
stored_documents_without_id = []
|
138
|
+
if self.allow_duplicates:
|
139
|
+
stored_data = []
|
140
|
+
else:
|
141
|
+
stored_data = chroma_collection_to_data(vector_store.get(limit=self.limit))
|
142
|
+
for value in deepcopy(stored_data):
|
143
|
+
del value.id
|
144
|
+
stored_documents_without_id.append(value)
|
145
|
+
|
146
|
+
documents = []
|
147
|
+
for _input in ingest_data or []:
|
148
|
+
if isinstance(_input, Data):
|
149
|
+
if _input not in stored_documents_without_id:
|
150
|
+
documents.append(_input.to_lc_document())
|
151
|
+
else:
|
152
|
+
msg = "Vector Store Inputs must be Data objects."
|
153
|
+
raise TypeError(msg)
|
154
|
+
|
155
|
+
if documents and self.embedding is not None:
|
156
|
+
self.log(f"Adding {len(documents)} documents to the Vector Store.")
|
157
|
+
# Filter complex metadata to prevent ChromaDB errors
|
158
|
+
try:
|
159
|
+
from langchain_community.vectorstores.utils import filter_complex_metadata
|
160
|
+
|
161
|
+
filtered_documents = filter_complex_metadata(documents)
|
162
|
+
vector_store.add_documents(filtered_documents)
|
163
|
+
except ImportError:
|
164
|
+
self.log("Warning: Could not import filter_complex_metadata. Adding documents without filtering.")
|
165
|
+
vector_store.add_documents(documents)
|
166
|
+
else:
|
167
|
+
self.log("No documents to add to the Vector Store.")
|
@@ -0,0 +1,40 @@
|
|
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 .cleanlab_evaluator import CleanlabEvaluator
|
9
|
+
from .cleanlab_rag_evaluator import CleanlabRAGEvaluator
|
10
|
+
from .cleanlab_remediator import CleanlabRemediator
|
11
|
+
|
12
|
+
_dynamic_imports = {
|
13
|
+
"CleanlabEvaluator": "cleanlab_evaluator",
|
14
|
+
"CleanlabRAGEvaluator": "cleanlab_rag_evaluator",
|
15
|
+
"CleanlabRemediator": "cleanlab_remediator",
|
16
|
+
}
|
17
|
+
|
18
|
+
__all__ = [
|
19
|
+
"CleanlabEvaluator",
|
20
|
+
"CleanlabRAGEvaluator",
|
21
|
+
"CleanlabRemediator",
|
22
|
+
]
|
23
|
+
|
24
|
+
|
25
|
+
def __getattr__(attr_name: str) -> Any:
|
26
|
+
"""Lazily import cleanlab components on attribute access."""
|
27
|
+
if attr_name not in _dynamic_imports:
|
28
|
+
msg = f"module '{__name__}' has no attribute '{attr_name}'"
|
29
|
+
raise AttributeError(msg)
|
30
|
+
try:
|
31
|
+
result = import_mod(attr_name, _dynamic_imports[attr_name], __spec__.parent)
|
32
|
+
except (ModuleNotFoundError, ImportError, AttributeError) as e:
|
33
|
+
msg = f"Could not import '{attr_name}' from '{__name__}': {e}"
|
34
|
+
raise AttributeError(msg) from e
|
35
|
+
globals()[attr_name] = result
|
36
|
+
return result
|
37
|
+
|
38
|
+
|
39
|
+
def __dir__() -> list[str]:
|
40
|
+
return list(__all__)
|
@@ -0,0 +1,155 @@
|
|
1
|
+
from cleanlab_tlm import TLM
|
2
|
+
|
3
|
+
from lfx.custom import Component
|
4
|
+
from lfx.io import (
|
5
|
+
DropdownInput,
|
6
|
+
MessageTextInput,
|
7
|
+
Output,
|
8
|
+
SecretStrInput,
|
9
|
+
)
|
10
|
+
from lfx.schema.message import Message
|
11
|
+
|
12
|
+
|
13
|
+
class CleanlabEvaluator(Component):
|
14
|
+
"""A component that evaluates the trustworthiness of LLM responses using Cleanlab.
|
15
|
+
|
16
|
+
This component takes a prompt and response pair, along with optional system instructions,
|
17
|
+
and uses Cleanlab's evaluation algorithms to generate a trust score and explanation.
|
18
|
+
|
19
|
+
Inputs:
|
20
|
+
- system_prompt (MessageTextInput): Optional system-level instructions prepended to the user prompt.
|
21
|
+
- prompt (MessageTextInput): The user's prompt or query sent to the LLM.
|
22
|
+
- response (MessageTextInput): The response generated by the LLM to be evaluated. This should come from the
|
23
|
+
LLM component, i.e. OpenAI, Gemini, etc.
|
24
|
+
- api_key (SecretStrInput): Your Cleanlab API key.
|
25
|
+
- model (DropdownInput): The model used by Cleanlab to evaluate the response (can differ from the
|
26
|
+
generation model).
|
27
|
+
- quality_preset (DropdownInput): Tradeoff setting for accuracy vs. speed and cost. Higher presets are
|
28
|
+
slower but more accurate.
|
29
|
+
|
30
|
+
Outputs:
|
31
|
+
- response_passthrough (Message): The original response, passed through for downstream use.
|
32
|
+
- score (number): A float between 0 and 1 indicating Cleanlab's trustworthiness score for the response.
|
33
|
+
- explanation (Message): A textual explanation of why the response received its score.
|
34
|
+
|
35
|
+
This component works well in conjunction with the CleanlabRemediator to create a complete trust evaluation
|
36
|
+
and remediation pipeline.
|
37
|
+
|
38
|
+
More details on the evaluation metrics can be found here: https://help.cleanlab.ai/tlm/tutorials/tlm/
|
39
|
+
"""
|
40
|
+
|
41
|
+
display_name = "Cleanlab Evaluator"
|
42
|
+
description = "Evaluates any LLM response using Cleanlab and outputs trust score and explanation."
|
43
|
+
icon = "Cleanlab"
|
44
|
+
name = "CleanlabEvaluator"
|
45
|
+
|
46
|
+
inputs = [
|
47
|
+
MessageTextInput(
|
48
|
+
name="system_prompt",
|
49
|
+
display_name="System Message",
|
50
|
+
info="System-level instructions prepended to the user query.",
|
51
|
+
value="",
|
52
|
+
),
|
53
|
+
MessageTextInput(
|
54
|
+
name="prompt",
|
55
|
+
display_name="Prompt",
|
56
|
+
info="The user's query to the model.",
|
57
|
+
required=True,
|
58
|
+
),
|
59
|
+
MessageTextInput(
|
60
|
+
name="response",
|
61
|
+
display_name="Response",
|
62
|
+
info="The response to the user's query.",
|
63
|
+
required=True,
|
64
|
+
),
|
65
|
+
SecretStrInput(
|
66
|
+
name="api_key",
|
67
|
+
display_name="Cleanlab API Key",
|
68
|
+
info="Your Cleanlab API key.",
|
69
|
+
required=True,
|
70
|
+
),
|
71
|
+
DropdownInput(
|
72
|
+
name="model",
|
73
|
+
display_name="Cleanlab Evaluation Model",
|
74
|
+
options=[
|
75
|
+
"gpt-4.1",
|
76
|
+
"gpt-4.1-mini",
|
77
|
+
"gpt-4.1-nano",
|
78
|
+
"o4-mini",
|
79
|
+
"o3",
|
80
|
+
"gpt-4.5-preview",
|
81
|
+
"gpt-4o-mini",
|
82
|
+
"gpt-4o",
|
83
|
+
"o3-mini",
|
84
|
+
"o1",
|
85
|
+
"o1-mini",
|
86
|
+
"gpt-4",
|
87
|
+
"gpt-3.5-turbo-16k",
|
88
|
+
"claude-3.7-sonnet",
|
89
|
+
"claude-3.5-sonnet-v2",
|
90
|
+
"claude-3.5-sonnet",
|
91
|
+
"claude-3.5-haiku",
|
92
|
+
"claude-3-haiku",
|
93
|
+
"nova-micro",
|
94
|
+
"nova-lite",
|
95
|
+
"nova-pro",
|
96
|
+
],
|
97
|
+
info="The model Cleanlab uses to evaluate the response. This does NOT need to be the same model that "
|
98
|
+
"generated the response.",
|
99
|
+
value="gpt-4o-mini",
|
100
|
+
required=True,
|
101
|
+
advanced=True,
|
102
|
+
),
|
103
|
+
DropdownInput(
|
104
|
+
name="quality_preset",
|
105
|
+
display_name="Quality Preset",
|
106
|
+
options=["base", "low", "medium", "high", "best"],
|
107
|
+
value="medium",
|
108
|
+
info="This determines the accuracy, latency, and cost of the evaluation. Higher quality is generally "
|
109
|
+
"slower but more accurate.",
|
110
|
+
required=True,
|
111
|
+
advanced=True,
|
112
|
+
),
|
113
|
+
]
|
114
|
+
|
115
|
+
outputs = [
|
116
|
+
Output(
|
117
|
+
display_name="Response",
|
118
|
+
name="response_passthrough",
|
119
|
+
method="pass_response",
|
120
|
+
types=["Message"],
|
121
|
+
),
|
122
|
+
Output(display_name="Trust Score", name="score", method="get_score", types=["number"]),
|
123
|
+
Output(
|
124
|
+
display_name="Explanation",
|
125
|
+
name="explanation",
|
126
|
+
method="get_explanation",
|
127
|
+
types=["Message"],
|
128
|
+
),
|
129
|
+
]
|
130
|
+
|
131
|
+
def _evaluate_once(self):
|
132
|
+
if not hasattr(self, "_cached_result"):
|
133
|
+
full_prompt = f"{self.system_prompt}\n\n{self.prompt}" if self.system_prompt else self.prompt
|
134
|
+
tlm = TLM(
|
135
|
+
api_key=self.api_key,
|
136
|
+
options={"log": ["explanation"], "model": self.model},
|
137
|
+
quality_preset=self.quality_preset,
|
138
|
+
)
|
139
|
+
self._cached_result = tlm.get_trustworthiness_score(full_prompt, self.response)
|
140
|
+
return self._cached_result
|
141
|
+
|
142
|
+
def get_score(self) -> float:
|
143
|
+
result = self._evaluate_once()
|
144
|
+
score = result.get("trustworthiness_score", 0.0)
|
145
|
+
self.status = f"Trust score: {score:.2f}"
|
146
|
+
return score
|
147
|
+
|
148
|
+
def get_explanation(self) -> Message:
|
149
|
+
result = self._evaluate_once()
|
150
|
+
explanation = result.get("log", {}).get("explanation", "No explanation returned.")
|
151
|
+
return Message(text=explanation)
|
152
|
+
|
153
|
+
def pass_response(self) -> Message:
|
154
|
+
self.status = "Passing through response."
|
155
|
+
return Message(text=self.response)
|
@@ -0,0 +1,254 @@
|
|
1
|
+
from cleanlab_tlm import TrustworthyRAG, get_default_evals
|
2
|
+
|
3
|
+
from lfx.custom import Component
|
4
|
+
from lfx.io import (
|
5
|
+
BoolInput,
|
6
|
+
DropdownInput,
|
7
|
+
MessageTextInput,
|
8
|
+
Output,
|
9
|
+
SecretStrInput,
|
10
|
+
)
|
11
|
+
from lfx.schema.message import Message
|
12
|
+
|
13
|
+
|
14
|
+
class CleanlabRAGEvaluator(Component):
|
15
|
+
"""A component that evaluates the quality of RAG (Retrieval-Augmented Generation) outputs using Cleanlab.
|
16
|
+
|
17
|
+
This component takes a query, retrieved context, and generated response from a RAG pipeline,
|
18
|
+
and uses Cleanlab's evaluation algorithms to assess various aspects of the RAG system's performance.
|
19
|
+
|
20
|
+
The component can evaluate:
|
21
|
+
- Overall trustworthiness of the LLM generated response
|
22
|
+
- Context sufficiency (whether the retrieved context contains information needed to answer the query)
|
23
|
+
- Response groundedness (whether the response is supported directly by the context)
|
24
|
+
- Response helpfulness (whether the response effectively addresses the user's query)
|
25
|
+
- Query ease (whether the user query seems easy for an AI system to properly handle, useful to diagnose
|
26
|
+
queries that are: complex, vague, tricky, or disgruntled-sounding)
|
27
|
+
|
28
|
+
Outputs:
|
29
|
+
- Trust Score: A score between 0-1 corresponding to the trustworthiness of the response. A higher score
|
30
|
+
indicates a higher confidence that the response is correct/good.
|
31
|
+
- Explanation: An LLM generated explanation of the trustworthiness assessment
|
32
|
+
- Other Evals: Additional evaluation metrics for selected evaluation types in the "Controls" tab
|
33
|
+
- Evaluation Summary: A comprehensive summary of context, query, response, and selected evaluation results
|
34
|
+
|
35
|
+
This component works well in conjunction with the CleanlabRemediator to create a complete trust evaluation
|
36
|
+
and remediation pipeline.
|
37
|
+
|
38
|
+
More details on the evaluation metrics can be found here: https://help.cleanlab.ai/tlm/use-cases/tlm_rag/
|
39
|
+
"""
|
40
|
+
|
41
|
+
display_name = "Cleanlab RAG Evaluator"
|
42
|
+
description = "Evaluates context, query, and response from a RAG pipeline using Cleanlab and outputs trust metrics."
|
43
|
+
icon = "Cleanlab"
|
44
|
+
name = "CleanlabRAGEvaluator"
|
45
|
+
|
46
|
+
inputs = [
|
47
|
+
SecretStrInput(
|
48
|
+
name="api_key",
|
49
|
+
display_name="Cleanlab API Key",
|
50
|
+
info="Your Cleanlab API key.",
|
51
|
+
required=True,
|
52
|
+
),
|
53
|
+
DropdownInput(
|
54
|
+
name="model",
|
55
|
+
display_name="Cleanlab Evaluation Model",
|
56
|
+
options=[
|
57
|
+
"gpt-4.1",
|
58
|
+
"gpt-4.1-mini",
|
59
|
+
"gpt-4.1-nano",
|
60
|
+
"o4-mini",
|
61
|
+
"o3",
|
62
|
+
"gpt-4.5-preview",
|
63
|
+
"gpt-4o-mini",
|
64
|
+
"gpt-4o",
|
65
|
+
"o3-mini",
|
66
|
+
"o1",
|
67
|
+
"o1-mini",
|
68
|
+
"gpt-4",
|
69
|
+
"gpt-3.5-turbo-16k",
|
70
|
+
"claude-3.7-sonnet",
|
71
|
+
"claude-3.5-sonnet-v2",
|
72
|
+
"claude-3.5-sonnet",
|
73
|
+
"claude-3.5-haiku",
|
74
|
+
"claude-3-haiku",
|
75
|
+
"nova-micro",
|
76
|
+
"nova-lite",
|
77
|
+
"nova-pro",
|
78
|
+
],
|
79
|
+
info="The model Cleanlab uses to evaluate the context, query, and response. This does NOT need to be "
|
80
|
+
"the same model that generated the response.",
|
81
|
+
value="gpt-4o-mini",
|
82
|
+
required=True,
|
83
|
+
advanced=True,
|
84
|
+
),
|
85
|
+
DropdownInput(
|
86
|
+
name="quality_preset",
|
87
|
+
display_name="Quality Preset",
|
88
|
+
options=["base", "low", "medium"],
|
89
|
+
value="medium",
|
90
|
+
info="This determines the accuracy, latency, and cost of the evaluation. Higher quality is generally "
|
91
|
+
"slower but more accurate.",
|
92
|
+
required=True,
|
93
|
+
advanced=True,
|
94
|
+
),
|
95
|
+
MessageTextInput(
|
96
|
+
name="context",
|
97
|
+
display_name="Context",
|
98
|
+
info="The context retrieved for the given query.",
|
99
|
+
required=True,
|
100
|
+
),
|
101
|
+
MessageTextInput(
|
102
|
+
name="query",
|
103
|
+
display_name="Query",
|
104
|
+
info="The user's query.",
|
105
|
+
required=True,
|
106
|
+
),
|
107
|
+
MessageTextInput(
|
108
|
+
name="response",
|
109
|
+
display_name="Response",
|
110
|
+
info="The response generated by the LLM.",
|
111
|
+
required=True,
|
112
|
+
),
|
113
|
+
BoolInput(
|
114
|
+
name="run_context_sufficiency",
|
115
|
+
display_name="Run Context Sufficiency",
|
116
|
+
value=False,
|
117
|
+
advanced=True,
|
118
|
+
),
|
119
|
+
BoolInput(
|
120
|
+
name="run_response_groundedness",
|
121
|
+
display_name="Run Response Groundedness",
|
122
|
+
value=False,
|
123
|
+
advanced=True,
|
124
|
+
),
|
125
|
+
BoolInput(
|
126
|
+
name="run_response_helpfulness",
|
127
|
+
display_name="Run Response Helpfulness",
|
128
|
+
value=False,
|
129
|
+
advanced=True,
|
130
|
+
),
|
131
|
+
BoolInput(
|
132
|
+
name="run_query_ease",
|
133
|
+
display_name="Run Query Ease",
|
134
|
+
value=False,
|
135
|
+
advanced=True,
|
136
|
+
),
|
137
|
+
]
|
138
|
+
|
139
|
+
outputs = [
|
140
|
+
Output(display_name="Response", name="response_passthrough", method="pass_response", types=["Message"]),
|
141
|
+
Output(display_name="Trust Score", name="trust_score", method="get_trust_score", types=["number"]),
|
142
|
+
Output(display_name="Explanation", name="trust_explanation", method="get_trust_explanation", types=["Message"]),
|
143
|
+
Output(display_name="Other Evals", name="other_scores", method="get_other_scores", types=["Data"]),
|
144
|
+
Output(
|
145
|
+
display_name="Evaluation Summary",
|
146
|
+
name="evaluation_summary",
|
147
|
+
method="get_evaluation_summary",
|
148
|
+
types=["Message"],
|
149
|
+
),
|
150
|
+
]
|
151
|
+
|
152
|
+
def _evaluate_once(self):
|
153
|
+
if not hasattr(self, "_cached_result"):
|
154
|
+
try:
|
155
|
+
self.status = "Configuring selected evals..."
|
156
|
+
default_evals = get_default_evals()
|
157
|
+
enabled_names = []
|
158
|
+
if self.run_context_sufficiency:
|
159
|
+
enabled_names.append("context_sufficiency")
|
160
|
+
if self.run_response_groundedness:
|
161
|
+
enabled_names.append("response_groundedness")
|
162
|
+
if self.run_response_helpfulness:
|
163
|
+
enabled_names.append("response_helpfulness")
|
164
|
+
if self.run_query_ease:
|
165
|
+
enabled_names.append("query_ease")
|
166
|
+
|
167
|
+
selected_evals = [e for e in default_evals if e.name in enabled_names]
|
168
|
+
|
169
|
+
validator = TrustworthyRAG(
|
170
|
+
api_key=self.api_key,
|
171
|
+
quality_preset=self.quality_preset,
|
172
|
+
options={"log": ["explanation"], "model": self.model},
|
173
|
+
evals=selected_evals,
|
174
|
+
)
|
175
|
+
|
176
|
+
self.status = f"Running evals: {[e.name for e in selected_evals]}"
|
177
|
+
self._cached_result = validator.score(
|
178
|
+
query=self.query,
|
179
|
+
context=self.context,
|
180
|
+
response=self.response,
|
181
|
+
)
|
182
|
+
self.status = "Evaluation complete."
|
183
|
+
|
184
|
+
except Exception as e: # noqa: BLE001
|
185
|
+
self.status = f"Evaluation failed: {e!s}"
|
186
|
+
self._cached_result = {}
|
187
|
+
return self._cached_result
|
188
|
+
|
189
|
+
def pass_response(self) -> Message:
|
190
|
+
self.status = "Passing through response."
|
191
|
+
return Message(text=self.response)
|
192
|
+
|
193
|
+
def get_trust_score(self) -> float:
|
194
|
+
score = self._evaluate_once().get("trustworthiness", {}).get("score", 0.0)
|
195
|
+
self.status = f"Trust Score: {score:.3f}"
|
196
|
+
return score
|
197
|
+
|
198
|
+
def get_trust_explanation(self) -> Message:
|
199
|
+
explanation = self._evaluate_once().get("trustworthiness", {}).get("log", {}).get("explanation", "")
|
200
|
+
self.status = "Trust explanation extracted."
|
201
|
+
return Message(text=explanation)
|
202
|
+
|
203
|
+
def get_other_scores(self) -> dict:
|
204
|
+
result = self._evaluate_once()
|
205
|
+
|
206
|
+
selected = {
|
207
|
+
"context_sufficiency": self.run_context_sufficiency,
|
208
|
+
"response_groundedness": self.run_response_groundedness,
|
209
|
+
"response_helpfulness": self.run_response_helpfulness,
|
210
|
+
"query_ease": self.run_query_ease,
|
211
|
+
}
|
212
|
+
|
213
|
+
filtered_scores = {key: result[key]["score"] for key, include in selected.items() if include and key in result}
|
214
|
+
|
215
|
+
self.status = f"{len(filtered_scores)} other evals returned."
|
216
|
+
return filtered_scores
|
217
|
+
|
218
|
+
def get_evaluation_summary(self) -> Message:
|
219
|
+
result = self._evaluate_once()
|
220
|
+
|
221
|
+
query_text = self.query.strip()
|
222
|
+
context_text = self.context.strip()
|
223
|
+
response_text = self.response.strip()
|
224
|
+
|
225
|
+
trust = result.get("trustworthiness", {}).get("score", 0.0)
|
226
|
+
trust_exp = result.get("trustworthiness", {}).get("log", {}).get("explanation", "")
|
227
|
+
|
228
|
+
selected = {
|
229
|
+
"context_sufficiency": self.run_context_sufficiency,
|
230
|
+
"response_groundedness": self.run_response_groundedness,
|
231
|
+
"response_helpfulness": self.run_response_helpfulness,
|
232
|
+
"query_ease": self.run_query_ease,
|
233
|
+
}
|
234
|
+
|
235
|
+
other_scores = {key: result[key]["score"] for key, include in selected.items() if include and key in result}
|
236
|
+
|
237
|
+
metrics = f"Trustworthiness: {trust:.3f}"
|
238
|
+
if trust_exp:
|
239
|
+
metrics += f"\nExplanation: {trust_exp}"
|
240
|
+
if other_scores:
|
241
|
+
metrics += "\n" + "\n".join(f"{k.replace('_', ' ').title()}: {v:.3f}" for k, v in other_scores.items())
|
242
|
+
|
243
|
+
summary = (
|
244
|
+
f"Query:\n{query_text}\n"
|
245
|
+
"-----\n"
|
246
|
+
f"Context:\n{context_text}\n"
|
247
|
+
"-----\n"
|
248
|
+
f"Response:\n{response_text}\n"
|
249
|
+
"------------------------------\n"
|
250
|
+
f"{metrics}"
|
251
|
+
)
|
252
|
+
|
253
|
+
self.status = "Evaluation summary built."
|
254
|
+
return Message(text=summary)
|