agno 1.8.0__py3-none-any.whl → 2.0.0a1__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.
- agno/__init__.py +8 -0
- agno/agent/__init__.py +19 -27
- agno/agent/agent.py +2781 -4126
- agno/api/agent.py +9 -65
- agno/api/api.py +5 -46
- agno/api/evals.py +6 -17
- agno/api/os.py +17 -0
- agno/api/routes.py +6 -41
- agno/api/schemas/__init__.py +9 -0
- agno/api/schemas/agent.py +5 -21
- agno/api/schemas/evals.py +7 -16
- agno/api/schemas/os.py +14 -0
- agno/api/schemas/team.py +5 -21
- agno/api/schemas/utils.py +21 -0
- agno/api/schemas/workflows.py +11 -7
- agno/api/settings.py +53 -0
- agno/api/team.py +9 -64
- agno/api/workflow.py +28 -0
- agno/cloud/aws/base.py +214 -0
- agno/cloud/aws/s3/__init__.py +2 -0
- agno/cloud/aws/s3/api_client.py +43 -0
- agno/cloud/aws/s3/bucket.py +195 -0
- agno/cloud/aws/s3/object.py +57 -0
- agno/db/__init__.py +24 -0
- agno/db/base.py +245 -0
- agno/db/dynamo/__init__.py +3 -0
- agno/db/dynamo/dynamo.py +1749 -0
- agno/db/dynamo/schemas.py +278 -0
- agno/db/dynamo/utils.py +684 -0
- agno/db/firestore/__init__.py +3 -0
- agno/db/firestore/firestore.py +1438 -0
- agno/db/firestore/schemas.py +130 -0
- agno/db/firestore/utils.py +278 -0
- agno/db/gcs_json/__init__.py +3 -0
- agno/db/gcs_json/gcs_json_db.py +1001 -0
- agno/db/gcs_json/utils.py +194 -0
- agno/db/in_memory/__init__.py +3 -0
- agno/db/in_memory/in_memory_db.py +888 -0
- agno/db/in_memory/utils.py +172 -0
- agno/db/json/__init__.py +3 -0
- agno/db/json/json_db.py +1051 -0
- agno/db/json/utils.py +196 -0
- agno/db/migrations/v1_to_v2.py +162 -0
- agno/db/mongo/__init__.py +3 -0
- agno/db/mongo/mongo.py +1417 -0
- agno/db/mongo/schemas.py +77 -0
- agno/db/mongo/utils.py +204 -0
- agno/db/mysql/__init__.py +3 -0
- agno/db/mysql/mysql.py +1719 -0
- agno/db/mysql/schemas.py +124 -0
- agno/db/mysql/utils.py +298 -0
- agno/db/postgres/__init__.py +3 -0
- agno/db/postgres/postgres.py +1720 -0
- agno/db/postgres/schemas.py +124 -0
- agno/db/postgres/utils.py +281 -0
- agno/db/redis/__init__.py +3 -0
- agno/db/redis/redis.py +1371 -0
- agno/db/redis/schemas.py +109 -0
- agno/db/redis/utils.py +288 -0
- agno/db/schemas/__init__.py +3 -0
- agno/db/schemas/evals.py +33 -0
- agno/db/schemas/knowledge.py +40 -0
- agno/db/schemas/memory.py +46 -0
- agno/db/singlestore/__init__.py +3 -0
- agno/db/singlestore/schemas.py +116 -0
- agno/db/singlestore/singlestore.py +1722 -0
- agno/db/singlestore/utils.py +327 -0
- agno/db/sqlite/__init__.py +3 -0
- agno/db/sqlite/schemas.py +119 -0
- agno/db/sqlite/sqlite.py +1680 -0
- agno/db/sqlite/utils.py +269 -0
- agno/db/utils.py +88 -0
- agno/eval/__init__.py +14 -0
- agno/eval/accuracy.py +142 -43
- agno/eval/performance.py +88 -23
- agno/eval/reliability.py +73 -20
- agno/eval/utils.py +23 -13
- agno/integrations/discord/__init__.py +3 -0
- agno/{app → integrations}/discord/client.py +10 -10
- agno/knowledge/__init__.py +2 -2
- agno/{document → knowledge}/chunking/agentic.py +2 -2
- agno/{document → knowledge}/chunking/document.py +2 -2
- agno/{document → knowledge}/chunking/fixed.py +3 -3
- agno/{document → knowledge}/chunking/markdown.py +2 -2
- agno/{document → knowledge}/chunking/recursive.py +2 -2
- agno/{document → knowledge}/chunking/row.py +2 -2
- agno/knowledge/chunking/semantic.py +59 -0
- agno/knowledge/chunking/strategy.py +121 -0
- agno/knowledge/content.py +74 -0
- agno/knowledge/document/__init__.py +5 -0
- agno/{document → knowledge/document}/base.py +12 -2
- agno/knowledge/embedder/__init__.py +5 -0
- agno/{embedder → knowledge/embedder}/aws_bedrock.py +127 -1
- agno/{embedder → knowledge/embedder}/azure_openai.py +65 -1
- agno/{embedder → knowledge/embedder}/base.py +6 -0
- agno/{embedder → knowledge/embedder}/cohere.py +72 -1
- agno/{embedder → knowledge/embedder}/fastembed.py +17 -1
- agno/{embedder → knowledge/embedder}/fireworks.py +1 -1
- agno/{embedder → knowledge/embedder}/google.py +74 -1
- agno/{embedder → knowledge/embedder}/huggingface.py +36 -2
- agno/{embedder → knowledge/embedder}/jina.py +48 -2
- agno/knowledge/embedder/langdb.py +22 -0
- agno/knowledge/embedder/mistral.py +139 -0
- agno/{embedder → knowledge/embedder}/nebius.py +1 -1
- agno/{embedder → knowledge/embedder}/ollama.py +54 -3
- agno/knowledge/embedder/openai.py +223 -0
- agno/{embedder → knowledge/embedder}/sentence_transformer.py +16 -1
- agno/{embedder → knowledge/embedder}/together.py +1 -1
- agno/{embedder → knowledge/embedder}/voyageai.py +49 -1
- agno/knowledge/knowledge.py +1515 -0
- agno/knowledge/reader/__init__.py +7 -0
- agno/{document → knowledge}/reader/arxiv_reader.py +32 -4
- agno/knowledge/reader/base.py +88 -0
- agno/{document → knowledge}/reader/csv_reader.py +68 -15
- agno/knowledge/reader/docx_reader.py +83 -0
- agno/{document → knowledge}/reader/firecrawl_reader.py +42 -21
- agno/knowledge/reader/gcs_reader.py +67 -0
- agno/{document → knowledge}/reader/json_reader.py +30 -9
- agno/{document → knowledge}/reader/markdown_reader.py +36 -9
- agno/{document → knowledge}/reader/pdf_reader.py +79 -21
- agno/knowledge/reader/reader_factory.py +275 -0
- agno/knowledge/reader/s3_reader.py +171 -0
- agno/{document → knowledge}/reader/text_reader.py +31 -10
- agno/knowledge/reader/url_reader.py +84 -0
- agno/knowledge/reader/web_search_reader.py +389 -0
- agno/{document → knowledge}/reader/website_reader.py +37 -10
- agno/knowledge/reader/wikipedia_reader.py +59 -0
- agno/knowledge/reader/youtube_reader.py +78 -0
- agno/knowledge/remote_content/remote_content.py +88 -0
- agno/{reranker → knowledge/reranker}/base.py +1 -1
- agno/{reranker → knowledge/reranker}/cohere.py +2 -2
- agno/{reranker → knowledge/reranker}/infinity.py +2 -2
- agno/{reranker → knowledge/reranker}/sentence_transformer.py +2 -2
- agno/knowledge/types.py +30 -0
- agno/knowledge/utils.py +169 -0
- agno/media.py +2 -2
- agno/memory/__init__.py +2 -10
- agno/memory/manager.py +1003 -148
- agno/models/aimlapi/__init__.py +2 -2
- agno/models/aimlapi/aimlapi.py +6 -6
- agno/models/anthropic/claude.py +129 -82
- agno/models/aws/bedrock.py +107 -175
- agno/models/aws/claude.py +64 -18
- agno/models/azure/ai_foundry.py +73 -23
- agno/models/base.py +347 -287
- agno/models/cerebras/cerebras.py +84 -27
- agno/models/cohere/chat.py +106 -98
- agno/models/dashscope/dashscope.py +14 -5
- agno/models/google/gemini.py +123 -53
- agno/models/groq/groq.py +97 -35
- agno/models/huggingface/huggingface.py +92 -27
- agno/models/ibm/watsonx.py +72 -13
- agno/models/litellm/chat.py +85 -13
- agno/models/message.py +38 -144
- agno/models/meta/llama.py +85 -49
- agno/models/metrics.py +120 -0
- agno/models/mistral/mistral.py +90 -21
- agno/models/ollama/__init__.py +0 -2
- agno/models/ollama/chat.py +84 -46
- agno/models/openai/chat.py +135 -27
- agno/models/openai/responses.py +233 -115
- agno/models/perplexity/perplexity.py +26 -2
- agno/models/portkey/portkey.py +0 -7
- agno/models/response.py +14 -8
- agno/models/utils.py +20 -0
- agno/models/vercel/__init__.py +2 -2
- agno/models/vercel/v0.py +1 -1
- agno/models/vllm/__init__.py +2 -2
- agno/models/vllm/vllm.py +3 -3
- agno/models/xai/xai.py +10 -10
- agno/os/__init__.py +3 -0
- agno/os/app.py +393 -0
- agno/os/auth.py +47 -0
- agno/os/config.py +103 -0
- agno/os/interfaces/agui/__init__.py +3 -0
- agno/os/interfaces/agui/agui.py +31 -0
- agno/{app/agui/async_router.py → os/interfaces/agui/router.py} +16 -16
- agno/{app → os/interfaces}/agui/utils.py +65 -28
- agno/os/interfaces/base.py +21 -0
- agno/os/interfaces/slack/__init__.py +3 -0
- agno/{app/slack/async_router.py → os/interfaces/slack/router.py} +3 -5
- agno/os/interfaces/slack/slack.py +33 -0
- agno/os/interfaces/whatsapp/__init__.py +3 -0
- agno/{app/whatsapp/async_router.py → os/interfaces/whatsapp/router.py} +4 -7
- agno/os/interfaces/whatsapp/whatsapp.py +30 -0
- agno/os/router.py +843 -0
- agno/os/routers/__init__.py +3 -0
- agno/os/routers/evals/__init__.py +3 -0
- agno/os/routers/evals/evals.py +204 -0
- agno/os/routers/evals/schemas.py +142 -0
- agno/os/routers/evals/utils.py +161 -0
- agno/os/routers/knowledge/__init__.py +3 -0
- agno/os/routers/knowledge/knowledge.py +413 -0
- agno/os/routers/knowledge/schemas.py +118 -0
- agno/os/routers/memory/__init__.py +3 -0
- agno/os/routers/memory/memory.py +179 -0
- agno/os/routers/memory/schemas.py +58 -0
- agno/os/routers/metrics/__init__.py +3 -0
- agno/os/routers/metrics/metrics.py +58 -0
- agno/os/routers/metrics/schemas.py +47 -0
- agno/os/routers/session/__init__.py +3 -0
- agno/os/routers/session/session.py +163 -0
- agno/os/schema.py +892 -0
- agno/{app/playground → os}/settings.py +8 -15
- agno/os/utils.py +270 -0
- agno/reasoning/azure_ai_foundry.py +4 -4
- agno/reasoning/deepseek.py +4 -4
- agno/reasoning/default.py +6 -11
- agno/reasoning/groq.py +4 -4
- agno/reasoning/helpers.py +4 -6
- agno/reasoning/ollama.py +4 -4
- agno/reasoning/openai.py +4 -4
- agno/run/{response.py → agent.py} +144 -72
- agno/run/base.py +44 -58
- agno/run/cancel.py +83 -0
- agno/run/team.py +133 -77
- agno/run/workflow.py +537 -12
- agno/session/__init__.py +10 -0
- agno/session/agent.py +244 -0
- agno/session/summary.py +225 -0
- agno/session/team.py +262 -0
- agno/{storage/session/v2 → session}/workflow.py +47 -24
- agno/team/__init__.py +15 -16
- agno/team/team.py +2967 -4243
- agno/tools/agentql.py +14 -5
- agno/tools/airflow.py +9 -4
- agno/tools/api.py +7 -3
- agno/tools/apify.py +2 -46
- agno/tools/arxiv.py +8 -3
- agno/tools/aws_lambda.py +7 -5
- agno/tools/aws_ses.py +7 -1
- agno/tools/baidusearch.py +4 -1
- agno/tools/bitbucket.py +4 -4
- agno/tools/brandfetch.py +14 -11
- agno/tools/bravesearch.py +4 -1
- agno/tools/brightdata.py +42 -22
- agno/tools/browserbase.py +13 -4
- agno/tools/calcom.py +12 -10
- agno/tools/calculator.py +10 -27
- agno/tools/cartesia.py +18 -13
- agno/tools/{clickup_tool.py → clickup.py} +12 -25
- agno/tools/confluence.py +71 -18
- agno/tools/crawl4ai.py +7 -1
- agno/tools/csv_toolkit.py +9 -8
- agno/tools/dalle.py +18 -11
- agno/tools/daytona.py +13 -16
- agno/tools/decorator.py +6 -3
- agno/tools/desi_vocal.py +16 -7
- agno/tools/discord.py +11 -8
- agno/tools/docker.py +30 -42
- agno/tools/duckdb.py +34 -53
- agno/tools/duckduckgo.py +8 -7
- agno/tools/e2b.py +62 -62
- agno/tools/eleven_labs.py +35 -28
- agno/tools/email.py +4 -1
- agno/tools/evm.py +7 -1
- agno/tools/exa.py +19 -14
- agno/tools/fal.py +29 -29
- agno/tools/file.py +9 -8
- agno/tools/financial_datasets.py +25 -44
- agno/tools/firecrawl.py +22 -22
- agno/tools/function.py +68 -17
- agno/tools/giphy.py +22 -10
- agno/tools/github.py +48 -126
- agno/tools/gmail.py +46 -62
- agno/tools/google_bigquery.py +7 -6
- agno/tools/google_maps.py +11 -26
- agno/tools/googlesearch.py +7 -2
- agno/tools/googlesheets.py +21 -17
- agno/tools/hackernews.py +9 -5
- agno/tools/jina.py +5 -4
- agno/tools/jira.py +18 -9
- agno/tools/knowledge.py +31 -32
- agno/tools/linear.py +18 -33
- agno/tools/linkup.py +5 -1
- agno/tools/local_file_system.py +8 -5
- agno/tools/lumalab.py +31 -19
- agno/tools/mem0.py +18 -12
- agno/tools/memori.py +14 -10
- agno/tools/mlx_transcribe.py +3 -2
- agno/tools/models/azure_openai.py +32 -14
- agno/tools/models/gemini.py +58 -31
- agno/tools/models/groq.py +29 -20
- agno/tools/models/nebius.py +27 -11
- agno/tools/models_labs.py +39 -15
- agno/tools/moviepy_video.py +7 -6
- agno/tools/neo4j.py +134 -0
- agno/tools/newspaper.py +7 -2
- agno/tools/newspaper4k.py +8 -3
- agno/tools/openai.py +57 -26
- agno/tools/openbb.py +12 -11
- agno/tools/opencv.py +62 -46
- agno/tools/openweather.py +14 -12
- agno/tools/pandas.py +11 -3
- agno/tools/postgres.py +4 -12
- agno/tools/pubmed.py +4 -1
- agno/tools/python.py +9 -22
- agno/tools/reasoning.py +35 -27
- agno/tools/reddit.py +11 -26
- agno/tools/replicate.py +54 -41
- agno/tools/resend.py +4 -1
- agno/tools/scrapegraph.py +15 -14
- agno/tools/searxng.py +10 -23
- agno/tools/serpapi.py +6 -3
- agno/tools/serper.py +13 -4
- agno/tools/shell.py +9 -2
- agno/tools/slack.py +12 -11
- agno/tools/sleep.py +3 -2
- agno/tools/spider.py +24 -4
- agno/tools/sql.py +7 -6
- agno/tools/tavily.py +6 -4
- agno/tools/telegram.py +12 -4
- agno/tools/todoist.py +11 -31
- agno/tools/toolkit.py +1 -1
- agno/tools/trafilatura.py +22 -6
- agno/tools/trello.py +9 -22
- agno/tools/twilio.py +10 -3
- agno/tools/user_control_flow.py +6 -1
- agno/tools/valyu.py +34 -5
- agno/tools/visualization.py +19 -28
- agno/tools/webbrowser.py +4 -3
- agno/tools/webex.py +11 -7
- agno/tools/website.py +15 -46
- agno/tools/webtools.py +12 -4
- agno/tools/whatsapp.py +5 -9
- agno/tools/wikipedia.py +20 -13
- agno/tools/x.py +14 -13
- agno/tools/yfinance.py +13 -40
- agno/tools/youtube.py +26 -20
- agno/tools/zendesk.py +7 -2
- agno/tools/zep.py +10 -7
- agno/tools/zoom.py +10 -9
- agno/utils/common.py +1 -19
- agno/utils/events.py +95 -118
- agno/utils/knowledge.py +29 -0
- agno/utils/location.py +2 -2
- agno/utils/log.py +2 -2
- agno/utils/mcp.py +11 -5
- agno/utils/media.py +39 -0
- agno/utils/message.py +12 -1
- agno/utils/models/claude.py +6 -4
- agno/utils/models/mistral.py +8 -7
- agno/utils/models/schema_utils.py +3 -3
- agno/utils/pprint.py +33 -32
- agno/utils/print_response/agent.py +779 -0
- agno/utils/print_response/team.py +1565 -0
- agno/utils/print_response/workflow.py +1451 -0
- agno/utils/prompts.py +14 -14
- agno/utils/reasoning.py +87 -0
- agno/utils/response.py +42 -42
- agno/utils/string.py +8 -22
- agno/utils/team.py +50 -0
- agno/utils/timer.py +2 -2
- agno/vectordb/base.py +33 -21
- agno/vectordb/cassandra/cassandra.py +287 -23
- agno/vectordb/chroma/chromadb.py +482 -59
- agno/vectordb/clickhouse/clickhousedb.py +270 -63
- agno/vectordb/couchbase/couchbase.py +309 -29
- agno/vectordb/lancedb/lance_db.py +360 -21
- agno/vectordb/langchaindb/__init__.py +5 -0
- agno/vectordb/langchaindb/langchaindb.py +145 -0
- agno/vectordb/lightrag/__init__.py +5 -0
- agno/vectordb/lightrag/lightrag.py +374 -0
- agno/vectordb/llamaindex/llamaindexdb.py +127 -0
- agno/vectordb/milvus/milvus.py +242 -32
- agno/vectordb/mongodb/mongodb.py +200 -24
- agno/vectordb/pgvector/pgvector.py +319 -37
- agno/vectordb/pineconedb/pineconedb.py +221 -27
- agno/vectordb/qdrant/qdrant.py +356 -14
- agno/vectordb/singlestore/singlestore.py +286 -29
- agno/vectordb/surrealdb/surrealdb.py +187 -7
- agno/vectordb/upstashdb/upstashdb.py +342 -26
- agno/vectordb/weaviate/weaviate.py +227 -165
- agno/workflow/__init__.py +17 -13
- agno/workflow/{v2/condition.py → condition.py} +135 -32
- agno/workflow/{v2/loop.py → loop.py} +115 -28
- agno/workflow/{v2/parallel.py → parallel.py} +138 -108
- agno/workflow/{v2/router.py → router.py} +133 -32
- agno/workflow/{v2/step.py → step.py} +200 -42
- agno/workflow/{v2/steps.py → steps.py} +147 -66
- agno/workflow/types.py +482 -0
- agno/workflow/workflow.py +2394 -696
- agno-2.0.0a1.dist-info/METADATA +355 -0
- agno-2.0.0a1.dist-info/RECORD +514 -0
- agno/agent/metrics.py +0 -107
- agno/api/app.py +0 -35
- agno/api/playground.py +0 -92
- agno/api/schemas/app.py +0 -12
- agno/api/schemas/playground.py +0 -22
- agno/api/schemas/user.py +0 -35
- agno/api/schemas/workspace.py +0 -46
- agno/api/user.py +0 -160
- agno/api/workflows.py +0 -33
- agno/api/workspace.py +0 -175
- agno/app/agui/__init__.py +0 -3
- agno/app/agui/app.py +0 -17
- agno/app/agui/sync_router.py +0 -120
- agno/app/base.py +0 -186
- agno/app/discord/__init__.py +0 -3
- agno/app/fastapi/__init__.py +0 -3
- agno/app/fastapi/app.py +0 -107
- agno/app/fastapi/async_router.py +0 -457
- agno/app/fastapi/sync_router.py +0 -448
- agno/app/playground/app.py +0 -228
- agno/app/playground/async_router.py +0 -1050
- agno/app/playground/deploy.py +0 -249
- agno/app/playground/operator.py +0 -183
- agno/app/playground/schemas.py +0 -220
- agno/app/playground/serve.py +0 -55
- agno/app/playground/sync_router.py +0 -1042
- agno/app/playground/utils.py +0 -46
- agno/app/settings.py +0 -15
- agno/app/slack/__init__.py +0 -3
- agno/app/slack/app.py +0 -19
- agno/app/slack/sync_router.py +0 -92
- agno/app/utils.py +0 -54
- agno/app/whatsapp/__init__.py +0 -3
- agno/app/whatsapp/app.py +0 -15
- agno/app/whatsapp/sync_router.py +0 -197
- agno/cli/auth_server.py +0 -249
- agno/cli/config.py +0 -274
- agno/cli/console.py +0 -88
- agno/cli/credentials.py +0 -23
- agno/cli/entrypoint.py +0 -571
- agno/cli/operator.py +0 -357
- agno/cli/settings.py +0 -96
- agno/cli/ws/ws_cli.py +0 -817
- agno/constants.py +0 -13
- agno/document/__init__.py +0 -5
- agno/document/chunking/semantic.py +0 -45
- agno/document/chunking/strategy.py +0 -31
- agno/document/reader/__init__.py +0 -5
- agno/document/reader/base.py +0 -47
- agno/document/reader/docx_reader.py +0 -60
- agno/document/reader/gcs/pdf_reader.py +0 -44
- agno/document/reader/s3/pdf_reader.py +0 -59
- agno/document/reader/s3/text_reader.py +0 -63
- agno/document/reader/url_reader.py +0 -59
- agno/document/reader/youtube_reader.py +0 -58
- agno/embedder/__init__.py +0 -5
- agno/embedder/langdb.py +0 -80
- agno/embedder/mistral.py +0 -82
- agno/embedder/openai.py +0 -78
- agno/file/__init__.py +0 -5
- agno/file/file.py +0 -16
- agno/file/local/csv.py +0 -32
- agno/file/local/txt.py +0 -19
- agno/infra/app.py +0 -240
- agno/infra/base.py +0 -144
- agno/infra/context.py +0 -20
- agno/infra/db_app.py +0 -52
- agno/infra/resource.py +0 -205
- agno/infra/resources.py +0 -55
- agno/knowledge/agent.py +0 -698
- agno/knowledge/arxiv.py +0 -33
- agno/knowledge/combined.py +0 -36
- agno/knowledge/csv.py +0 -144
- agno/knowledge/csv_url.py +0 -124
- agno/knowledge/document.py +0 -223
- agno/knowledge/docx.py +0 -137
- agno/knowledge/firecrawl.py +0 -34
- agno/knowledge/gcs/__init__.py +0 -0
- agno/knowledge/gcs/base.py +0 -39
- agno/knowledge/gcs/pdf.py +0 -125
- agno/knowledge/json.py +0 -137
- agno/knowledge/langchain.py +0 -71
- agno/knowledge/light_rag.py +0 -273
- agno/knowledge/llamaindex.py +0 -66
- agno/knowledge/markdown.py +0 -154
- agno/knowledge/pdf.py +0 -164
- agno/knowledge/pdf_bytes.py +0 -42
- agno/knowledge/pdf_url.py +0 -148
- agno/knowledge/s3/__init__.py +0 -0
- agno/knowledge/s3/base.py +0 -64
- agno/knowledge/s3/pdf.py +0 -33
- agno/knowledge/s3/text.py +0 -34
- agno/knowledge/text.py +0 -141
- agno/knowledge/url.py +0 -46
- agno/knowledge/website.py +0 -179
- agno/knowledge/wikipedia.py +0 -32
- agno/knowledge/youtube.py +0 -35
- agno/memory/agent.py +0 -423
- agno/memory/classifier.py +0 -104
- agno/memory/db/__init__.py +0 -5
- agno/memory/db/base.py +0 -42
- agno/memory/db/mongodb.py +0 -189
- agno/memory/db/postgres.py +0 -203
- agno/memory/db/sqlite.py +0 -193
- agno/memory/memory.py +0 -22
- agno/memory/row.py +0 -36
- agno/memory/summarizer.py +0 -201
- agno/memory/summary.py +0 -19
- agno/memory/team.py +0 -415
- agno/memory/v2/__init__.py +0 -2
- agno/memory/v2/db/__init__.py +0 -1
- agno/memory/v2/db/base.py +0 -42
- agno/memory/v2/db/firestore.py +0 -339
- agno/memory/v2/db/mongodb.py +0 -196
- agno/memory/v2/db/postgres.py +0 -214
- agno/memory/v2/db/redis.py +0 -187
- agno/memory/v2/db/schema.py +0 -54
- agno/memory/v2/db/sqlite.py +0 -209
- agno/memory/v2/manager.py +0 -437
- agno/memory/v2/memory.py +0 -1097
- agno/memory/v2/schema.py +0 -55
- agno/memory/v2/summarizer.py +0 -215
- agno/memory/workflow.py +0 -38
- agno/models/ollama/tools.py +0 -430
- agno/models/qwen/__init__.py +0 -5
- agno/playground/__init__.py +0 -10
- agno/playground/deploy.py +0 -3
- agno/playground/playground.py +0 -3
- agno/playground/serve.py +0 -3
- agno/playground/settings.py +0 -3
- agno/reranker/__init__.py +0 -0
- agno/run/v2/__init__.py +0 -0
- agno/run/v2/workflow.py +0 -567
- agno/storage/__init__.py +0 -0
- agno/storage/agent/__init__.py +0 -0
- agno/storage/agent/dynamodb.py +0 -1
- agno/storage/agent/json.py +0 -1
- agno/storage/agent/mongodb.py +0 -1
- agno/storage/agent/postgres.py +0 -1
- agno/storage/agent/singlestore.py +0 -1
- agno/storage/agent/sqlite.py +0 -1
- agno/storage/agent/yaml.py +0 -1
- agno/storage/base.py +0 -60
- agno/storage/dynamodb.py +0 -673
- agno/storage/firestore.py +0 -297
- agno/storage/gcs_json.py +0 -261
- agno/storage/in_memory.py +0 -234
- agno/storage/json.py +0 -237
- agno/storage/mongodb.py +0 -328
- agno/storage/mysql.py +0 -685
- agno/storage/postgres.py +0 -682
- agno/storage/redis.py +0 -336
- agno/storage/session/__init__.py +0 -16
- agno/storage/session/agent.py +0 -64
- agno/storage/session/team.py +0 -63
- agno/storage/session/v2/__init__.py +0 -5
- agno/storage/session/workflow.py +0 -61
- agno/storage/singlestore.py +0 -606
- agno/storage/sqlite.py +0 -646
- agno/storage/workflow/__init__.py +0 -0
- agno/storage/workflow/mongodb.py +0 -1
- agno/storage/workflow/postgres.py +0 -1
- agno/storage/workflow/sqlite.py +0 -1
- agno/storage/yaml.py +0 -241
- agno/tools/thinking.py +0 -73
- agno/utils/defaults.py +0 -57
- agno/utils/filesystem.py +0 -39
- agno/utils/git.py +0 -52
- agno/utils/json_io.py +0 -30
- agno/utils/load_env.py +0 -19
- agno/utils/py_io.py +0 -19
- agno/utils/pyproject.py +0 -18
- agno/utils/resource_filter.py +0 -31
- agno/workflow/v2/__init__.py +0 -21
- agno/workflow/v2/types.py +0 -357
- agno/workflow/v2/workflow.py +0 -3312
- agno/workspace/__init__.py +0 -0
- agno/workspace/config.py +0 -325
- agno/workspace/enums.py +0 -6
- agno/workspace/helpers.py +0 -52
- agno/workspace/operator.py +0 -757
- agno/workspace/settings.py +0 -158
- agno-1.8.0.dist-info/METADATA +0 -979
- agno-1.8.0.dist-info/RECORD +0 -565
- agno-1.8.0.dist-info/entry_points.txt +0 -3
- /agno/{app → db/migrations}/__init__.py +0 -0
- /agno/{app/playground/__init__.py → db/schemas/metrics.py} +0 -0
- /agno/{cli → integrations}/__init__.py +0 -0
- /agno/{cli/ws → knowledge/chunking}/__init__.py +0 -0
- /agno/{document/chunking → knowledge/remote_content}/__init__.py +0 -0
- /agno/{document/reader/gcs → knowledge/reranker}/__init__.py +0 -0
- /agno/{document/reader/s3 → os/interfaces}/__init__.py +0 -0
- /agno/{app → os/interfaces}/slack/security.py +0 -0
- /agno/{app → os/interfaces}/whatsapp/security.py +0 -0
- /agno/{file/local → utils/print_response}/__init__.py +0 -0
- /agno/{infra → vectordb/llamaindex}/__init__.py +0 -0
- {agno-1.8.0.dist-info → agno-2.0.0a1.dist-info}/WHEEL +0 -0
- {agno-1.8.0.dist-info → agno-2.0.0a1.dist-info}/licenses/LICENSE +0 -0
- {agno-1.8.0.dist-info → agno-2.0.0a1.dist-info}/top_level.txt +0 -0
agno/knowledge/pdf_bytes.py
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import io
|
|
2
|
-
from typing import IO, AsyncIterator, Iterator, List, Union
|
|
3
|
-
|
|
4
|
-
from pydantic import Field
|
|
5
|
-
|
|
6
|
-
from agno.document import Document
|
|
7
|
-
from agno.document.reader.pdf_reader import PDFImageReader, PDFReader
|
|
8
|
-
from agno.knowledge.agent import AgentKnowledge
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
class PDFBytesKnowledgeBase(AgentKnowledge):
|
|
12
|
-
pdfs: Union[List[bytes], List[IO]]
|
|
13
|
-
|
|
14
|
-
exclude_files: List[str] = Field(default_factory=list)
|
|
15
|
-
|
|
16
|
-
reader: Union[PDFReader, PDFImageReader] = PDFReader()
|
|
17
|
-
|
|
18
|
-
@property
|
|
19
|
-
def document_lists(self) -> Iterator[List[Document]]:
|
|
20
|
-
"""Iterate over PDFs bytes and yield lists of documents.
|
|
21
|
-
Each object yielded by the iterator is a list of documents.
|
|
22
|
-
|
|
23
|
-
Returns:
|
|
24
|
-
Iterator[List[Document]]: Iterator yielding list of documents
|
|
25
|
-
"""
|
|
26
|
-
|
|
27
|
-
for pdf in self.pdfs:
|
|
28
|
-
_pdf = io.BytesIO(pdf) if isinstance(pdf, bytes) else pdf
|
|
29
|
-
yield self.reader.read(pdf=_pdf)
|
|
30
|
-
|
|
31
|
-
@property
|
|
32
|
-
async def async_document_lists(self) -> AsyncIterator[List[Document]]:
|
|
33
|
-
"""Iterate over PDFs bytes and yield lists of documents.
|
|
34
|
-
Each object yielded by the iterator is a list of documents.
|
|
35
|
-
|
|
36
|
-
Returns:
|
|
37
|
-
Iterator[List[Document]]: Iterator yielding list of documents
|
|
38
|
-
"""
|
|
39
|
-
|
|
40
|
-
for pdf in self.pdfs:
|
|
41
|
-
_pdf = io.BytesIO(pdf) if isinstance(pdf, bytes) else pdf
|
|
42
|
-
yield await self.reader.async_read(pdf=_pdf)
|
agno/knowledge/pdf_url.py
DELETED
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
from typing import Any, AsyncIterator, Dict, Iterator, List, Optional, Union
|
|
2
|
-
|
|
3
|
-
from agno.document import Document
|
|
4
|
-
from agno.document.reader.pdf_reader import PDFUrlImageReader, PDFUrlReader
|
|
5
|
-
from agno.knowledge.agent import AgentKnowledge
|
|
6
|
-
from agno.utils.log import log_info, logger
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class PDFUrlKnowledgeBase(AgentKnowledge):
|
|
10
|
-
urls: Optional[Union[List[str], List[Dict[str, Union[str, Dict[str, Any]]]]]] = None
|
|
11
|
-
formats: List[str] = [".pdf"]
|
|
12
|
-
reader: Union[PDFUrlReader, PDFUrlImageReader] = PDFUrlReader()
|
|
13
|
-
|
|
14
|
-
@property
|
|
15
|
-
def document_lists(self) -> Iterator[List[Document]]:
|
|
16
|
-
"""Iterate over PDF URLs and yield lists of documents."""
|
|
17
|
-
if self.urls is None:
|
|
18
|
-
raise ValueError("URLs are not set")
|
|
19
|
-
|
|
20
|
-
for item in self.urls:
|
|
21
|
-
if isinstance(item, dict) and "url" in item:
|
|
22
|
-
# Handle URL with metadata/password
|
|
23
|
-
url = item["url"]
|
|
24
|
-
config = item.get("metadata", {})
|
|
25
|
-
pdf_password = item.get("password")
|
|
26
|
-
if pdf_password is not None and not isinstance(pdf_password, str):
|
|
27
|
-
pdf_password = None
|
|
28
|
-
|
|
29
|
-
if self._is_valid_url(url): # type: ignore
|
|
30
|
-
documents = self.reader.read(url=url, password=pdf_password) # type: ignore
|
|
31
|
-
if config:
|
|
32
|
-
for doc in documents:
|
|
33
|
-
log_info(f"Adding metadata {config} to document from URL: {url}")
|
|
34
|
-
doc.meta_data.update(config) # type: ignore
|
|
35
|
-
yield documents
|
|
36
|
-
else:
|
|
37
|
-
# Handle simple URL - no password
|
|
38
|
-
if self._is_valid_url(item): # type: ignore
|
|
39
|
-
yield self.reader.read(url=item) # type: ignore
|
|
40
|
-
|
|
41
|
-
def _is_valid_url(self, url: str) -> bool:
|
|
42
|
-
"""Helper to check if URL is valid."""
|
|
43
|
-
if not url.endswith(".pdf"):
|
|
44
|
-
logger.error(f"Unsupported URL: {url}")
|
|
45
|
-
return False
|
|
46
|
-
return True
|
|
47
|
-
|
|
48
|
-
@property
|
|
49
|
-
async def async_document_lists(self) -> AsyncIterator[List[Document]]:
|
|
50
|
-
"""Iterate over PDF URLs and yield lists of documents asynchronously."""
|
|
51
|
-
if not self.urls:
|
|
52
|
-
raise ValueError("URLs are not set")
|
|
53
|
-
|
|
54
|
-
for item in self.urls:
|
|
55
|
-
if isinstance(item, dict) and "url" in item:
|
|
56
|
-
# Handle URL with metadata/password
|
|
57
|
-
url = item["url"]
|
|
58
|
-
config = item.get("metadata", {})
|
|
59
|
-
pdf_password = item.get("password")
|
|
60
|
-
if pdf_password is not None and not isinstance(pdf_password, str):
|
|
61
|
-
pdf_password = None
|
|
62
|
-
|
|
63
|
-
if self._is_valid_url(url): # type: ignore
|
|
64
|
-
documents = await self.reader.async_read(url=url, password=pdf_password) # type: ignore
|
|
65
|
-
if config:
|
|
66
|
-
for doc in documents:
|
|
67
|
-
log_info(f"Adding metadata {config} to document from URL: {url}")
|
|
68
|
-
doc.meta_data.update(config) # type: ignore
|
|
69
|
-
yield documents
|
|
70
|
-
else:
|
|
71
|
-
# Handle simple URL
|
|
72
|
-
if self._is_valid_url(item): # type: ignore
|
|
73
|
-
yield await self.reader.async_read(url=item) # type: ignore
|
|
74
|
-
|
|
75
|
-
def load_document(
|
|
76
|
-
self,
|
|
77
|
-
url: str,
|
|
78
|
-
metadata: Optional[Dict[str, Any]] = None,
|
|
79
|
-
recreate: bool = False,
|
|
80
|
-
upsert: bool = False,
|
|
81
|
-
skip_existing: bool = True,
|
|
82
|
-
) -> None:
|
|
83
|
-
"""Load documents from a single URL with specific metadata into the vector DB.
|
|
84
|
-
Args:
|
|
85
|
-
url (str): URL of the PDF to load.
|
|
86
|
-
metadata (Optional[Dict[str, Any]]): Metadata to associate with documents from this URL.
|
|
87
|
-
This will be merged into the 'meta_data' field of each document.
|
|
88
|
-
recreate (bool): If True, drops and recreates the collection before loading. Defaults to False.
|
|
89
|
-
upsert (bool): If True, upserts documents (insert or update). Requires vector_db support. Defaults to False.
|
|
90
|
-
skip_existing (bool): If True and not upserting, skips documents that already exist based on content hash. Defaults to True.
|
|
91
|
-
"""
|
|
92
|
-
if not url.endswith(".pdf"):
|
|
93
|
-
logger.error(f"Unsupported URL provided to load_url: {url}")
|
|
94
|
-
return
|
|
95
|
-
|
|
96
|
-
if not self.prepare_load(url, self.formats, metadata, recreate, is_url=True): # type: ignore
|
|
97
|
-
return
|
|
98
|
-
|
|
99
|
-
try:
|
|
100
|
-
documents = self.reader.read(url=url)
|
|
101
|
-
if not documents:
|
|
102
|
-
logger.warning(f"No documents were read from URL: {url}")
|
|
103
|
-
return
|
|
104
|
-
except Exception as e:
|
|
105
|
-
logger.exception(f"Failed to read documents from URL {url}: {e}")
|
|
106
|
-
return
|
|
107
|
-
|
|
108
|
-
# Process documents
|
|
109
|
-
self.process_documents(
|
|
110
|
-
documents=documents,
|
|
111
|
-
metadata=metadata,
|
|
112
|
-
upsert=upsert,
|
|
113
|
-
skip_existing=skip_existing,
|
|
114
|
-
source_info=str(url),
|
|
115
|
-
)
|
|
116
|
-
|
|
117
|
-
async def aload_document(
|
|
118
|
-
self,
|
|
119
|
-
url: str,
|
|
120
|
-
metadata: Optional[Dict[str, Any]] = None,
|
|
121
|
-
recreate: bool = False,
|
|
122
|
-
upsert: bool = False,
|
|
123
|
-
skip_existing: bool = True,
|
|
124
|
-
) -> None:
|
|
125
|
-
if not url.endswith(".pdf"):
|
|
126
|
-
logger.error(f"Unsupported URL provided to load_url: {url}")
|
|
127
|
-
return
|
|
128
|
-
|
|
129
|
-
if not await self.aprepare_load(url, self.formats, metadata, recreate, is_url=True): # type: ignore
|
|
130
|
-
return
|
|
131
|
-
|
|
132
|
-
try:
|
|
133
|
-
documents = await self.reader.async_read(url=url)
|
|
134
|
-
if not documents:
|
|
135
|
-
logger.warning(f"No documents were read from URL: {url}")
|
|
136
|
-
return
|
|
137
|
-
except Exception as e:
|
|
138
|
-
logger.exception(f"Failed to read documents from URL {url}: {e}")
|
|
139
|
-
return
|
|
140
|
-
|
|
141
|
-
# Process documents
|
|
142
|
-
await self.aprocess_documents(
|
|
143
|
-
documents=documents,
|
|
144
|
-
metadata=metadata,
|
|
145
|
-
upsert=upsert,
|
|
146
|
-
skip_existing=skip_existing,
|
|
147
|
-
source_info=str(url),
|
|
148
|
-
)
|
agno/knowledge/s3/__init__.py
DELETED
|
File without changes
|
agno/knowledge/s3/base.py
DELETED
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
from typing import AsyncIterator, Iterator, List, Optional
|
|
2
|
-
|
|
3
|
-
from agno.aws.resource.s3.bucket import S3Bucket # type: ignore
|
|
4
|
-
from agno.aws.resource.s3.object import S3Object # type: ignore
|
|
5
|
-
from agno.document import Document
|
|
6
|
-
from agno.knowledge.agent import AgentKnowledge
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class S3KnowledgeBase(AgentKnowledge):
|
|
10
|
-
# Provide either bucket or bucket_name
|
|
11
|
-
bucket: Optional[S3Bucket] = None
|
|
12
|
-
bucket_name: Optional[str] = None
|
|
13
|
-
|
|
14
|
-
# Provide either object or key
|
|
15
|
-
key: Optional[str] = None
|
|
16
|
-
object: Optional[S3Object] = None
|
|
17
|
-
|
|
18
|
-
# Filter objects by prefix
|
|
19
|
-
# Ignored if object or key is provided
|
|
20
|
-
prefix: Optional[str] = None
|
|
21
|
-
|
|
22
|
-
@property
|
|
23
|
-
def document_lists(self) -> Iterator[List[Document]]:
|
|
24
|
-
raise NotImplementedError
|
|
25
|
-
|
|
26
|
-
@property
|
|
27
|
-
def async_document_lists(self) -> AsyncIterator[List[Document]]:
|
|
28
|
-
raise NotImplementedError
|
|
29
|
-
|
|
30
|
-
@property
|
|
31
|
-
def s3_objects(self) -> List[S3Object]:
|
|
32
|
-
"""Iterate over PDFs in a s3 bucket and yield lists of documents.
|
|
33
|
-
Each object yielded by the iterator is a list of documents.
|
|
34
|
-
|
|
35
|
-
Returns:
|
|
36
|
-
Iterator[List[Document]]: Iterator yielding list of documents
|
|
37
|
-
"""
|
|
38
|
-
|
|
39
|
-
s3_objects_to_read: List[S3Object] = []
|
|
40
|
-
|
|
41
|
-
if self.bucket is None and self.bucket_name is None:
|
|
42
|
-
raise ValueError("No bucket or bucket_name provided")
|
|
43
|
-
|
|
44
|
-
if self.bucket is not None and self.bucket_name is not None:
|
|
45
|
-
raise ValueError("Provide either bucket or bucket_name")
|
|
46
|
-
|
|
47
|
-
if self.object is not None and self.key is not None:
|
|
48
|
-
raise ValueError("Provide either object or key")
|
|
49
|
-
|
|
50
|
-
if self.bucket_name is not None:
|
|
51
|
-
self.bucket = S3Bucket(name=self.bucket_name)
|
|
52
|
-
|
|
53
|
-
if self.bucket is not None:
|
|
54
|
-
if self.key is not None:
|
|
55
|
-
_object = S3Object(bucket_name=self.bucket.name, name=self.key)
|
|
56
|
-
s3_objects_to_read.append(_object)
|
|
57
|
-
elif self.object is not None:
|
|
58
|
-
s3_objects_to_read.append(self.object)
|
|
59
|
-
elif self.prefix is not None:
|
|
60
|
-
s3_objects_to_read.extend(self.bucket.get_objects(prefix=self.prefix))
|
|
61
|
-
else:
|
|
62
|
-
s3_objects_to_read.extend(self.bucket.get_objects())
|
|
63
|
-
|
|
64
|
-
return s3_objects_to_read
|
agno/knowledge/s3/pdf.py
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
from typing import AsyncIterator, Iterator, List
|
|
2
|
-
|
|
3
|
-
from agno.document import Document
|
|
4
|
-
from agno.document.reader.s3.pdf_reader import S3PDFReader
|
|
5
|
-
from agno.knowledge.s3.base import S3KnowledgeBase
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class S3PDFKnowledgeBase(S3KnowledgeBase):
|
|
9
|
-
reader: S3PDFReader = S3PDFReader()
|
|
10
|
-
|
|
11
|
-
@property
|
|
12
|
-
def document_lists(self) -> Iterator[List[Document]]:
|
|
13
|
-
"""Iterate over PDFs in a s3 bucket and yield lists of documents.
|
|
14
|
-
Each object yielded by the iterator is a list of documents.
|
|
15
|
-
|
|
16
|
-
Returns:
|
|
17
|
-
Iterator[List[Document]]: Iterator yielding list of documents
|
|
18
|
-
"""
|
|
19
|
-
for s3_object in self.s3_objects:
|
|
20
|
-
if s3_object.name.endswith(".pdf"):
|
|
21
|
-
yield self.reader.read(s3_object=s3_object)
|
|
22
|
-
|
|
23
|
-
@property
|
|
24
|
-
async def async_document_lists(self) -> AsyncIterator[List[Document]]:
|
|
25
|
-
"""Iterate over PDFs in a s3 bucket and yield lists of documents asynchronously.
|
|
26
|
-
Each object yielded by the iterator is a list of documents.
|
|
27
|
-
|
|
28
|
-
Returns:
|
|
29
|
-
AsyncIterator[List[Document]]: Async iterator yielding list of documents
|
|
30
|
-
"""
|
|
31
|
-
for s3_object in self.s3_objects:
|
|
32
|
-
if s3_object.name.endswith(".pdf"):
|
|
33
|
-
yield await self.reader.async_read(s3_object=s3_object)
|
agno/knowledge/s3/text.py
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
from typing import AsyncIterator, Iterator, List
|
|
2
|
-
|
|
3
|
-
from agno.document import Document
|
|
4
|
-
from agno.document.reader.s3.text_reader import S3TextReader
|
|
5
|
-
from agno.knowledge.s3.base import S3KnowledgeBase
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class S3TextKnowledgeBase(S3KnowledgeBase):
|
|
9
|
-
formats: List[str] = [".doc", ".docx"]
|
|
10
|
-
reader: S3TextReader = S3TextReader()
|
|
11
|
-
|
|
12
|
-
@property
|
|
13
|
-
def document_lists(self) -> Iterator[List[Document]]:
|
|
14
|
-
"""Iterate over text files in a s3 bucket and yield lists of documents.
|
|
15
|
-
Each object yielded by the iterator is a list of documents.
|
|
16
|
-
|
|
17
|
-
Returns:
|
|
18
|
-
Iterator[List[Document]]: Iterator yielding list of documents
|
|
19
|
-
"""
|
|
20
|
-
for s3_object in self.s3_objects:
|
|
21
|
-
if s3_object.name.endswith(tuple(self.formats)):
|
|
22
|
-
yield self.reader.read(s3_object=s3_object)
|
|
23
|
-
|
|
24
|
-
@property
|
|
25
|
-
async def async_document_lists(self) -> AsyncIterator[List[Document]]:
|
|
26
|
-
"""Iterate over text files in a s3 bucket and yield lists of documents asynchronously.
|
|
27
|
-
Each object yielded by the iterator is a list of documents.
|
|
28
|
-
|
|
29
|
-
Returns:
|
|
30
|
-
AsyncIterator[List[Document]]: Async iterator yielding list of documents
|
|
31
|
-
"""
|
|
32
|
-
for s3_object in self.s3_objects:
|
|
33
|
-
if s3_object.name.endswith(tuple(self.formats)):
|
|
34
|
-
yield await self.reader.async_read(s3_object=s3_object)
|
agno/knowledge/text.py
DELETED
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
from pathlib import Path
|
|
2
|
-
from typing import Any, AsyncIterator, Dict, Iterator, List, Optional, Union
|
|
3
|
-
|
|
4
|
-
from agno.document import Document
|
|
5
|
-
from agno.document.reader.text_reader import TextReader
|
|
6
|
-
from agno.knowledge.agent import AgentKnowledge
|
|
7
|
-
from agno.utils.log import log_info, logger
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
class TextKnowledgeBase(AgentKnowledge):
|
|
11
|
-
path: Optional[Union[str, Path, List[Dict[str, Union[str, Dict[str, Any]]]]]] = None
|
|
12
|
-
formats: List[str] = [".txt"]
|
|
13
|
-
reader: TextReader = TextReader()
|
|
14
|
-
|
|
15
|
-
@property
|
|
16
|
-
def document_lists(self) -> Iterator[List[Document]]:
|
|
17
|
-
"""Iterate over text files and yield lists of documents."""
|
|
18
|
-
if self.path is None:
|
|
19
|
-
raise ValueError("Path is not set")
|
|
20
|
-
|
|
21
|
-
if isinstance(self.path, list):
|
|
22
|
-
for item in self.path:
|
|
23
|
-
if isinstance(item, dict) and "path" in item:
|
|
24
|
-
# Handle path with metadata
|
|
25
|
-
file_path = item["path"]
|
|
26
|
-
config = item.get("metadata", {})
|
|
27
|
-
_file_path = Path(file_path) # type: ignore
|
|
28
|
-
if self._is_valid_text(_file_path):
|
|
29
|
-
documents = self.reader.read(file=_file_path)
|
|
30
|
-
if config:
|
|
31
|
-
for doc in documents:
|
|
32
|
-
log_info(f"Adding metadata {config} to document: {doc.name}")
|
|
33
|
-
doc.meta_data.update(config) # type: ignore
|
|
34
|
-
yield documents
|
|
35
|
-
else:
|
|
36
|
-
# Handle single path
|
|
37
|
-
_file_path = Path(self.path)
|
|
38
|
-
if _file_path.is_dir():
|
|
39
|
-
for _file in _file_path.glob("**/*"):
|
|
40
|
-
if self._is_valid_text(_file):
|
|
41
|
-
yield self.reader.read(file=_file)
|
|
42
|
-
elif self._is_valid_text(_file_path):
|
|
43
|
-
yield self.reader.read(file=_file_path)
|
|
44
|
-
|
|
45
|
-
def _is_valid_text(self, path: Path) -> bool:
|
|
46
|
-
"""Helper to check if path is a valid text file."""
|
|
47
|
-
return path.exists() and path.is_file() and path.suffix in self.formats
|
|
48
|
-
|
|
49
|
-
@property
|
|
50
|
-
async def async_document_lists(self) -> AsyncIterator[List[Document]]:
|
|
51
|
-
"""Iterate over text files and yield lists of documents asynchronously."""
|
|
52
|
-
if self.path is None:
|
|
53
|
-
raise ValueError("Path is not set")
|
|
54
|
-
|
|
55
|
-
if isinstance(self.path, list):
|
|
56
|
-
for item in self.path:
|
|
57
|
-
if isinstance(item, dict) and "path" in item:
|
|
58
|
-
# Handle path with metadata
|
|
59
|
-
file_path = item["path"]
|
|
60
|
-
config = item.get("metadata", {})
|
|
61
|
-
_file_path = Path(file_path) # type: ignore
|
|
62
|
-
if self._is_valid_text(_file_path):
|
|
63
|
-
documents = await self.reader.async_read(file=_file_path)
|
|
64
|
-
if config:
|
|
65
|
-
for doc in documents:
|
|
66
|
-
log_info(f"Adding metadata {config} to document: {doc.name}")
|
|
67
|
-
doc.meta_data.update(config) # type: ignore
|
|
68
|
-
yield documents
|
|
69
|
-
else:
|
|
70
|
-
# Handle single path
|
|
71
|
-
_file_path = Path(self.path)
|
|
72
|
-
if _file_path.is_dir():
|
|
73
|
-
for _file in _file_path.glob("**/*"):
|
|
74
|
-
if self._is_valid_text(_file):
|
|
75
|
-
yield await self.reader.async_read(file=_file)
|
|
76
|
-
elif self._is_valid_text(_file_path):
|
|
77
|
-
yield await self.reader.async_read(file=_file_path)
|
|
78
|
-
|
|
79
|
-
def load_document(
|
|
80
|
-
self,
|
|
81
|
-
path: Union[str, Path],
|
|
82
|
-
metadata: Optional[Dict[str, Any]] = None,
|
|
83
|
-
recreate: bool = False,
|
|
84
|
-
upsert: bool = False,
|
|
85
|
-
skip_existing: bool = True,
|
|
86
|
-
) -> None:
|
|
87
|
-
"""Load documents from a single text file with specific metadata into the vector DB."""
|
|
88
|
-
|
|
89
|
-
_file_path = Path(path) if isinstance(path, str) else path
|
|
90
|
-
|
|
91
|
-
# Validate file and prepare collection in one step
|
|
92
|
-
if not self.prepare_load(_file_path, self.formats, metadata, recreate):
|
|
93
|
-
return
|
|
94
|
-
|
|
95
|
-
# Read documents
|
|
96
|
-
try:
|
|
97
|
-
documents = self.reader.read(file=_file_path)
|
|
98
|
-
except Exception as e:
|
|
99
|
-
logger.exception(f"Failed to read documents from file {_file_path}: {e}")
|
|
100
|
-
return
|
|
101
|
-
|
|
102
|
-
# Process documents
|
|
103
|
-
self.process_documents(
|
|
104
|
-
documents=documents,
|
|
105
|
-
metadata=metadata,
|
|
106
|
-
upsert=upsert,
|
|
107
|
-
skip_existing=skip_existing,
|
|
108
|
-
source_info=str(_file_path),
|
|
109
|
-
)
|
|
110
|
-
|
|
111
|
-
async def aload_document(
|
|
112
|
-
self,
|
|
113
|
-
path: Union[str, Path],
|
|
114
|
-
metadata: Optional[Dict[str, Any]] = None,
|
|
115
|
-
recreate: bool = False,
|
|
116
|
-
upsert: bool = False,
|
|
117
|
-
skip_existing: bool = True,
|
|
118
|
-
) -> None:
|
|
119
|
-
"""Load documents from a single text file with specific metadata into the vector DB."""
|
|
120
|
-
|
|
121
|
-
_file_path = Path(path) if isinstance(path, str) else path
|
|
122
|
-
|
|
123
|
-
# Validate file and prepare collection in one step
|
|
124
|
-
if not await self.aprepare_load(_file_path, self.formats, metadata, recreate):
|
|
125
|
-
return
|
|
126
|
-
|
|
127
|
-
# Read documents
|
|
128
|
-
try:
|
|
129
|
-
documents = await self.reader.async_read(file=_file_path)
|
|
130
|
-
except Exception as e:
|
|
131
|
-
logger.exception(f"Failed to read documents from file {_file_path}: {e}")
|
|
132
|
-
return
|
|
133
|
-
|
|
134
|
-
# Process documents
|
|
135
|
-
await self.aprocess_documents(
|
|
136
|
-
documents=documents,
|
|
137
|
-
metadata=metadata,
|
|
138
|
-
upsert=upsert,
|
|
139
|
-
skip_existing=skip_existing,
|
|
140
|
-
source_info=str(_file_path),
|
|
141
|
-
)
|
agno/knowledge/url.py
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import asyncio
|
|
2
|
-
from typing import AsyncIterator, Iterator, List
|
|
3
|
-
|
|
4
|
-
from agno.document import Document
|
|
5
|
-
from agno.document.reader.url_reader import URLReader
|
|
6
|
-
from agno.knowledge.agent import AgentKnowledge
|
|
7
|
-
from agno.utils.log import logger
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
class UrlKnowledge(AgentKnowledge):
|
|
11
|
-
urls: List[str] = []
|
|
12
|
-
reader: URLReader = URLReader()
|
|
13
|
-
|
|
14
|
-
@property
|
|
15
|
-
def document_lists(self) -> Iterator[List[Document]]:
|
|
16
|
-
"""Iterate over URLs and yield lists of documents.
|
|
17
|
-
Each object yielded by the iterator is a list of documents.
|
|
18
|
-
|
|
19
|
-
Returns:
|
|
20
|
-
Iterator[List[Document]]: Iterator yielding list of documents
|
|
21
|
-
"""
|
|
22
|
-
for url in self.urls:
|
|
23
|
-
try:
|
|
24
|
-
yield self.reader.read(url=url)
|
|
25
|
-
except Exception as e:
|
|
26
|
-
logger.error(f"Error reading URL {url}: {str(e)}")
|
|
27
|
-
|
|
28
|
-
@property
|
|
29
|
-
async def async_document_lists(self) -> AsyncIterator[List[Document]]:
|
|
30
|
-
"""Async version of document_lists"""
|
|
31
|
-
|
|
32
|
-
async def process_url(url: str) -> List[Document]:
|
|
33
|
-
try:
|
|
34
|
-
return await self.reader.async_read(url=url)
|
|
35
|
-
except Exception as e:
|
|
36
|
-
logger.error(f"Error reading URL {url}: {str(e)}")
|
|
37
|
-
return []
|
|
38
|
-
|
|
39
|
-
# Process all URLs concurrently
|
|
40
|
-
tasks = [process_url(url) for url in self.urls]
|
|
41
|
-
results = await asyncio.gather(*tasks)
|
|
42
|
-
|
|
43
|
-
# Yield each result
|
|
44
|
-
for docs in results:
|
|
45
|
-
if docs:
|
|
46
|
-
yield docs
|