agno 1.8.1__py3-none-any.whl → 2.0.0__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 +3143 -4170
- agno/api/agent.py +11 -67
- agno/api/api.py +5 -46
- agno/api/evals.py +8 -19
- 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 +11 -66
- 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 +1743 -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 +1432 -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 +882 -0
- agno/db/in_memory/utils.py +172 -0
- agno/db/json/__init__.py +3 -0
- agno/db/json/json_db.py +1045 -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 +1416 -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 +297 -0
- agno/db/postgres/__init__.py +3 -0
- agno/db/postgres/postgres.py +1710 -0
- agno/db/postgres/schemas.py +124 -0
- agno/db/postgres/utils.py +280 -0
- agno/db/redis/__init__.py +3 -0
- agno/db/redis/redis.py +1367 -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 +1712 -0
- agno/db/singlestore/utils.py +326 -0
- agno/db/sqlite/__init__.py +3 -0
- agno/db/sqlite/schemas.py +119 -0
- agno/db/sqlite/sqlite.py +1676 -0
- agno/db/sqlite/utils.py +268 -0
- agno/db/utils.py +88 -0
- agno/eval/__init__.py +14 -0
- agno/eval/accuracy.py +154 -48
- 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 +15 -11
- 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 +1551 -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 +47 -65
- agno/knowledge/reader/docx_reader.py +83 -0
- agno/{document → knowledge}/reader/firecrawl_reader.py +42 -21
- agno/{document → knowledge}/reader/json_reader.py +30 -9
- agno/{document → knowledge}/reader/markdown_reader.py +58 -9
- agno/{document → knowledge}/reader/pdf_reader.py +71 -126
- agno/knowledge/reader/reader_factory.py +268 -0
- agno/knowledge/reader/s3_reader.py +101 -0
- agno/{document → knowledge}/reader/text_reader.py +31 -10
- agno/knowledge/reader/url_reader.py +128 -0
- agno/knowledge/reader/web_search_reader.py +366 -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 +269 -268
- 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 +131 -131
- agno/models/aws/bedrock.py +110 -182
- agno/models/aws/claude.py +64 -18
- agno/models/azure/ai_foundry.py +73 -23
- agno/models/base.py +346 -290
- agno/models/cerebras/cerebras.py +84 -27
- agno/models/cohere/chat.py +106 -98
- agno/models/google/gemini.py +105 -46
- 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 +46 -151
- 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 +85 -47
- agno/models/openai/chat.py +154 -37
- agno/models/openai/responses.py +178 -105
- agno/models/perplexity/perplexity.py +26 -2
- agno/models/portkey/portkey.py +0 -7
- agno/models/response.py +15 -9
- 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 +497 -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 +77 -33
- 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 +32 -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 +29 -0
- agno/os/mcp.py +235 -0
- agno/os/router.py +1400 -0
- agno/os/routers/__init__.py +3 -0
- agno/os/routers/evals/__init__.py +3 -0
- agno/os/routers/evals/evals.py +393 -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 +850 -0
- agno/os/routers/knowledge/schemas.py +118 -0
- agno/os/routers/memory/__init__.py +3 -0
- agno/os/routers/memory/memory.py +410 -0
- agno/os/routers/memory/schemas.py +58 -0
- agno/os/routers/metrics/__init__.py +3 -0
- agno/os/routers/metrics/metrics.py +178 -0
- agno/os/routers/metrics/schemas.py +47 -0
- agno/os/routers/session/__init__.py +3 -0
- agno/os/routers/session/session.py +536 -0
- agno/os/schema.py +945 -0
- agno/{app/playground → os}/settings.py +7 -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/agent.py +633 -0
- agno/run/base.py +53 -77
- agno/run/cancel.py +81 -0
- agno/run/team.py +243 -96
- agno/run/workflow.py +550 -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 +3260 -4824
- 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 +43 -23
- agno/tools/browserbase.py +13 -4
- agno/tools/calcom.py +12 -10
- agno/tools/calculator.py +10 -27
- agno/tools/cartesia.py +20 -17
- agno/tools/{clickup_tool.py → clickup.py} +12 -25
- agno/tools/confluence.py +8 -8
- agno/tools/crawl4ai.py +7 -1
- agno/tools/csv_toolkit.py +9 -8
- agno/tools/dalle.py +22 -12
- agno/tools/daytona.py +13 -16
- agno/tools/decorator.py +6 -3
- agno/tools/desi_vocal.py +17 -8
- 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 +36 -29
- agno/tools/email.py +4 -1
- agno/tools/evm.py +7 -1
- agno/tools/exa.py +19 -14
- agno/tools/fal.py +30 -30
- agno/tools/file.py +9 -8
- agno/tools/financial_datasets.py +25 -44
- agno/tools/firecrawl.py +22 -22
- agno/tools/function.py +127 -18
- agno/tools/giphy.py +23 -11
- agno/tools/github.py +48 -126
- agno/tools/gmail.py +45 -61
- 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 +19 -34
- agno/tools/linkup.py +5 -1
- agno/tools/local_file_system.py +8 -5
- agno/tools/lumalab.py +32 -20
- agno/tools/mcp.py +1 -2
- 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 +33 -15
- agno/tools/models/gemini.py +59 -32
- agno/tools/models/groq.py +30 -23
- agno/tools/models/nebius.py +28 -12
- agno/tools/models_labs.py +40 -16
- agno/tools/moviepy_video.py +7 -6
- agno/tools/neo4j.py +10 -8
- agno/tools/newspaper.py +7 -2
- agno/tools/newspaper4k.py +8 -3
- agno/tools/openai.py +58 -32
- agno/tools/openbb.py +12 -11
- agno/tools/opencv.py +63 -47
- 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 +55 -42
- 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 +100 -123
- agno/utils/gemini.py +32 -2
- agno/utils/knowledge.py +29 -0
- agno/utils/log.py +54 -4
- agno/utils/mcp.py +68 -10
- agno/utils/media.py +39 -0
- agno/utils/message.py +12 -1
- agno/utils/models/aws_claude.py +1 -1
- agno/utils/models/claude.py +47 -4
- agno/utils/models/cohere.py +1 -1
- agno/utils/models/mistral.py +8 -7
- agno/utils/models/schema_utils.py +3 -3
- agno/utils/models/watsonx.py +1 -1
- agno/utils/openai.py +1 -1
- agno/utils/pprint.py +33 -32
- agno/utils/print_response/agent.py +779 -0
- agno/utils/print_response/team.py +1669 -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/streamlit.py +481 -0
- 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 +334 -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} +207 -49
- agno/workflow/{v2/steps.py → steps.py} +147 -66
- agno/workflow/types.py +482 -0
- agno/workflow/workflow.py +2410 -696
- agno-2.0.0.dist-info/METADATA +494 -0
- agno-2.0.0.dist-info/RECORD +515 -0
- agno-2.0.0.dist-info/licenses/LICENSE +201 -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 -702
- 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/response.py +0 -467
- 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.1.dist-info/METADATA +0 -982
- agno-1.8.1.dist-info/RECORD +0 -566
- agno-1.8.1.dist-info/entry_points.txt +0 -3
- agno-1.8.1.dist-info/licenses/LICENSE +0 -375
- /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.1.dist-info → agno-2.0.0.dist-info}/WHEEL +0 -0
- {agno-1.8.1.dist-info → agno-2.0.0.dist-info}/top_level.txt +0 -0
agno/db/sqlite/utils.py
ADDED
|
@@ -0,0 +1,268 @@
|
|
|
1
|
+
import json
|
|
2
|
+
import time
|
|
3
|
+
from datetime import date, datetime, timedelta, timezone
|
|
4
|
+
from typing import Any, Dict, List, Optional
|
|
5
|
+
from uuid import uuid4
|
|
6
|
+
|
|
7
|
+
from agno.db.sqlite.schemas import get_table_schema_definition
|
|
8
|
+
from agno.utils.log import log_debug, log_error, log_warning
|
|
9
|
+
|
|
10
|
+
try:
|
|
11
|
+
from sqlalchemy import Table
|
|
12
|
+
from sqlalchemy.dialects import sqlite
|
|
13
|
+
from sqlalchemy.engine import Engine
|
|
14
|
+
from sqlalchemy.inspection import inspect
|
|
15
|
+
from sqlalchemy.orm import Session
|
|
16
|
+
from sqlalchemy.sql.expression import text
|
|
17
|
+
except ImportError:
|
|
18
|
+
raise ImportError("`sqlalchemy` not installed. Please install it using `pip install sqlalchemy`")
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
# -- DB util methods --
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
def apply_sorting(stmt, table: Table, sort_by: Optional[str] = None, sort_order: Optional[str] = None):
|
|
25
|
+
"""Apply sorting to the given SQLAlchemy statement.
|
|
26
|
+
Args:
|
|
27
|
+
stmt: The SQLAlchemy statement to modify
|
|
28
|
+
table: The table being queried
|
|
29
|
+
sort_by: The field to sort by
|
|
30
|
+
sort_order: The sort order ('asc' or 'desc')
|
|
31
|
+
Returns:
|
|
32
|
+
The modified statement with sorting applied
|
|
33
|
+
"""
|
|
34
|
+
if sort_by is None:
|
|
35
|
+
return stmt
|
|
36
|
+
if not hasattr(table.c, sort_by):
|
|
37
|
+
log_debug(f"Invalid sort field: '{sort_by}'. Will not apply any sorting.")
|
|
38
|
+
return stmt
|
|
39
|
+
|
|
40
|
+
# Apply the given sorting
|
|
41
|
+
sort_column = getattr(table.c, sort_by)
|
|
42
|
+
if sort_order and sort_order == "asc":
|
|
43
|
+
return stmt.order_by(sort_column.asc())
|
|
44
|
+
else:
|
|
45
|
+
return stmt.order_by(sort_column.desc())
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
def is_table_available(session: Session, table_name: str, db_schema: Optional[str] = None) -> bool:
|
|
49
|
+
"""
|
|
50
|
+
Check if a table with the given name exists.
|
|
51
|
+
Note: db_schema parameter is ignored in SQLite but kept for API compatibility.
|
|
52
|
+
Returns:
|
|
53
|
+
bool: True if the table exists, False otherwise.
|
|
54
|
+
"""
|
|
55
|
+
try:
|
|
56
|
+
# SQLite uses sqlite_master instead of information_schema
|
|
57
|
+
exists_query = text("SELECT 1 FROM sqlite_master WHERE type = 'table' AND name = :table")
|
|
58
|
+
exists = session.execute(exists_query, {"table": table_name}).scalar() is not None
|
|
59
|
+
if not exists:
|
|
60
|
+
log_debug(f"Table {table_name} {'exists' if exists else 'does not exist'}")
|
|
61
|
+
return exists
|
|
62
|
+
except Exception as e:
|
|
63
|
+
log_error(f"Error checking if table exists: {e}")
|
|
64
|
+
return False
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
def is_valid_table(db_engine: Engine, table_name: str, table_type: str, db_schema: Optional[str] = None) -> bool:
|
|
68
|
+
"""
|
|
69
|
+
Check if the existing table has the expected column names.
|
|
70
|
+
Note: db_schema parameter is ignored in SQLite but kept for API compatibility.
|
|
71
|
+
Args:
|
|
72
|
+
db_engine (Engine): Database engine
|
|
73
|
+
table_name (str): Name of the table to validate
|
|
74
|
+
table_type (str): Type of table to get expected schema
|
|
75
|
+
db_schema (Optional[str]): Database schema name (ignored in SQLite)
|
|
76
|
+
Returns:
|
|
77
|
+
bool: True if table has all expected columns, False otherwise
|
|
78
|
+
"""
|
|
79
|
+
try:
|
|
80
|
+
expected_table_schema = get_table_schema_definition(table_type)
|
|
81
|
+
expected_columns = {col_name for col_name in expected_table_schema.keys() if not col_name.startswith("_")}
|
|
82
|
+
|
|
83
|
+
# Get existing columns (no schema parameter for SQLite)
|
|
84
|
+
inspector = inspect(db_engine)
|
|
85
|
+
existing_columns_info = inspector.get_columns(table_name) # No schema parameter
|
|
86
|
+
existing_columns = set(col["name"] for col in existing_columns_info)
|
|
87
|
+
|
|
88
|
+
# Check if all expected columns exist
|
|
89
|
+
missing_columns = expected_columns - existing_columns
|
|
90
|
+
if missing_columns:
|
|
91
|
+
log_warning(f"Missing columns {missing_columns} in table {table_name}")
|
|
92
|
+
return False
|
|
93
|
+
|
|
94
|
+
return True
|
|
95
|
+
except Exception as e:
|
|
96
|
+
log_error(f"Error validating table schema for {table_name}: {e}")
|
|
97
|
+
return False
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
# -- Metrics util methods --
|
|
101
|
+
|
|
102
|
+
|
|
103
|
+
def bulk_upsert_metrics(session: Session, table: Table, metrics_records: list[dict]) -> list[dict]:
|
|
104
|
+
"""Bulk upsert metrics into the database.
|
|
105
|
+
|
|
106
|
+
Args:
|
|
107
|
+
table (Table): The table to upsert into.
|
|
108
|
+
metrics_records (list[dict]): The metrics records to upsert.
|
|
109
|
+
|
|
110
|
+
Returns:
|
|
111
|
+
list[dict]: The upserted metrics records.
|
|
112
|
+
"""
|
|
113
|
+
if not metrics_records:
|
|
114
|
+
return []
|
|
115
|
+
|
|
116
|
+
results = []
|
|
117
|
+
stmt = sqlite.insert(table)
|
|
118
|
+
|
|
119
|
+
# Columns to update in case of conflict
|
|
120
|
+
update_columns = {
|
|
121
|
+
col.name: stmt.excluded[col.name]
|
|
122
|
+
for col in table.columns
|
|
123
|
+
if col.name not in ["id", "date", "created_at", "aggregation_period"]
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
stmt = stmt.on_conflict_do_update(index_elements=["date", "aggregation_period"], set_=update_columns).returning( # type: ignore
|
|
127
|
+
table
|
|
128
|
+
)
|
|
129
|
+
result = session.execute(stmt, metrics_records)
|
|
130
|
+
results = [row._mapping for row in result.fetchall()]
|
|
131
|
+
session.commit()
|
|
132
|
+
|
|
133
|
+
return results # type: ignore
|
|
134
|
+
|
|
135
|
+
|
|
136
|
+
def calculate_date_metrics(date_to_process: date, sessions_data: dict) -> dict:
|
|
137
|
+
"""Calculate metrics for the given single date.
|
|
138
|
+
|
|
139
|
+
Args:
|
|
140
|
+
date_to_process (date): The date to calculate metrics for.
|
|
141
|
+
sessions_data (dict): The sessions data to calculate metrics for.
|
|
142
|
+
|
|
143
|
+
Returns:
|
|
144
|
+
dict: The calculated metrics.
|
|
145
|
+
"""
|
|
146
|
+
metrics = {
|
|
147
|
+
"users_count": 0,
|
|
148
|
+
"agent_sessions_count": 0,
|
|
149
|
+
"team_sessions_count": 0,
|
|
150
|
+
"workflow_sessions_count": 0,
|
|
151
|
+
"agent_runs_count": 0,
|
|
152
|
+
"team_runs_count": 0,
|
|
153
|
+
"workflow_runs_count": 0,
|
|
154
|
+
}
|
|
155
|
+
token_metrics = {
|
|
156
|
+
"input_tokens": 0,
|
|
157
|
+
"output_tokens": 0,
|
|
158
|
+
"total_tokens": 0,
|
|
159
|
+
"audio_total_tokens": 0,
|
|
160
|
+
"audio_input_tokens": 0,
|
|
161
|
+
"audio_output_tokens": 0,
|
|
162
|
+
"cache_read_tokens": 0,
|
|
163
|
+
"cache_write_tokens": 0,
|
|
164
|
+
"reasoning_tokens": 0,
|
|
165
|
+
}
|
|
166
|
+
model_counts: Dict[str, int] = {}
|
|
167
|
+
|
|
168
|
+
session_types = [
|
|
169
|
+
("agent", "agent_sessions_count", "agent_runs_count"),
|
|
170
|
+
("team", "team_sessions_count", "team_runs_count"),
|
|
171
|
+
("workflow", "workflow_sessions_count", "workflow_runs_count"),
|
|
172
|
+
]
|
|
173
|
+
all_user_ids = set()
|
|
174
|
+
|
|
175
|
+
for session_type, sessions_count_key, runs_count_key in session_types:
|
|
176
|
+
sessions = sessions_data.get(session_type, [])
|
|
177
|
+
metrics[sessions_count_key] = len(sessions)
|
|
178
|
+
|
|
179
|
+
for session in sessions:
|
|
180
|
+
if session.get("user_id"):
|
|
181
|
+
all_user_ids.add(session["user_id"])
|
|
182
|
+
metrics[runs_count_key] += len(session.get("runs", []))
|
|
183
|
+
if runs := session.get("runs", []):
|
|
184
|
+
runs = json.loads(runs)
|
|
185
|
+
for run in runs:
|
|
186
|
+
if model_id := run.get("model"):
|
|
187
|
+
model_provider = run.get("model_provider", "")
|
|
188
|
+
model_counts[f"{model_id}:{model_provider}"] = (
|
|
189
|
+
model_counts.get(f"{model_id}:{model_provider}", 0) + 1
|
|
190
|
+
)
|
|
191
|
+
|
|
192
|
+
session_data = json.loads(session.get("session_data", {}))
|
|
193
|
+
session_metrics = session_data.get("session_metrics", {})
|
|
194
|
+
for field in token_metrics:
|
|
195
|
+
token_metrics[field] += session_metrics.get(field, 0)
|
|
196
|
+
|
|
197
|
+
model_metrics = []
|
|
198
|
+
for model, count in model_counts.items():
|
|
199
|
+
model_id, model_provider = model.split(":")
|
|
200
|
+
model_metrics.append({"model_id": model_id, "model_provider": model_provider, "count": count})
|
|
201
|
+
|
|
202
|
+
metrics["users_count"] = len(all_user_ids)
|
|
203
|
+
current_time = int(time.time())
|
|
204
|
+
|
|
205
|
+
return {
|
|
206
|
+
"id": str(uuid4()),
|
|
207
|
+
"date": date_to_process,
|
|
208
|
+
"completed": date_to_process < datetime.now(timezone.utc).date(),
|
|
209
|
+
"token_metrics": token_metrics,
|
|
210
|
+
"model_metrics": model_metrics,
|
|
211
|
+
"created_at": current_time,
|
|
212
|
+
"updated_at": current_time,
|
|
213
|
+
"aggregation_period": "daily",
|
|
214
|
+
**metrics,
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
|
|
218
|
+
def fetch_all_sessions_data(
|
|
219
|
+
sessions: List[Dict[str, Any]], dates_to_process: list[date], start_timestamp: int
|
|
220
|
+
) -> Optional[dict]:
|
|
221
|
+
"""Return all session data for the given dates, for all session types.
|
|
222
|
+
|
|
223
|
+
Args:
|
|
224
|
+
dates_to_process (list[date]): The dates to fetch session data for.
|
|
225
|
+
|
|
226
|
+
Returns:
|
|
227
|
+
dict: A dictionary with dates as keys and session data as values, for all session types.
|
|
228
|
+
|
|
229
|
+
Example:
|
|
230
|
+
{
|
|
231
|
+
"2000-01-01": {
|
|
232
|
+
"agent": [<session1>, <session2>, ...],
|
|
233
|
+
"team": [...],
|
|
234
|
+
"workflow": [...],
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
"""
|
|
238
|
+
if not dates_to_process:
|
|
239
|
+
return None
|
|
240
|
+
|
|
241
|
+
all_sessions_data: Dict[str, Dict[str, List[Dict[str, Any]]]] = {
|
|
242
|
+
date_to_process.isoformat(): {"agent": [], "team": [], "workflow": []} for date_to_process in dates_to_process
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
for session in sessions:
|
|
246
|
+
session_date = (
|
|
247
|
+
datetime.fromtimestamp(session.get("created_at", start_timestamp), tz=timezone.utc).date().isoformat()
|
|
248
|
+
)
|
|
249
|
+
if session_date in all_sessions_data:
|
|
250
|
+
all_sessions_data[session_date][session["session_type"]].append(session)
|
|
251
|
+
|
|
252
|
+
return all_sessions_data
|
|
253
|
+
|
|
254
|
+
|
|
255
|
+
def get_dates_to_calculate_metrics_for(starting_date: date) -> list[date]:
|
|
256
|
+
"""Return the list of dates to calculate metrics for.
|
|
257
|
+
|
|
258
|
+
Args:
|
|
259
|
+
starting_date (date): The starting date to calculate metrics for.
|
|
260
|
+
|
|
261
|
+
Returns:
|
|
262
|
+
list[date]: The list of dates to calculate metrics for.
|
|
263
|
+
"""
|
|
264
|
+
today = datetime.now(timezone.utc).date()
|
|
265
|
+
days_diff = (today - starting_date).days + 1
|
|
266
|
+
if days_diff <= 0:
|
|
267
|
+
return []
|
|
268
|
+
return [starting_date + timedelta(days=x) for x in range(days_diff)]
|
agno/db/utils.py
ADDED
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"""Logic shared across different database implementations"""
|
|
2
|
+
|
|
3
|
+
import json
|
|
4
|
+
from datetime import date, datetime
|
|
5
|
+
from uuid import UUID
|
|
6
|
+
|
|
7
|
+
from agno.db.base import SessionType
|
|
8
|
+
from agno.models.message import Message
|
|
9
|
+
from agno.models.metrics import Metrics
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
class CustomJSONEncoder(json.JSONEncoder):
|
|
13
|
+
"""Custom encoder to handle non JSON serializable types."""
|
|
14
|
+
|
|
15
|
+
def default(self, obj):
|
|
16
|
+
if isinstance(obj, UUID):
|
|
17
|
+
return str(obj)
|
|
18
|
+
elif isinstance(obj, (date, datetime)):
|
|
19
|
+
return obj.isoformat()
|
|
20
|
+
elif isinstance(obj, Message):
|
|
21
|
+
return obj.to_dict()
|
|
22
|
+
elif isinstance(obj, Metrics):
|
|
23
|
+
return obj.to_dict()
|
|
24
|
+
|
|
25
|
+
return super().default(obj)
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
def serialize_session_json_fields(session: dict) -> dict:
|
|
29
|
+
"""Serialize all JSON fields in the given Session dictionary.
|
|
30
|
+
|
|
31
|
+
Args:
|
|
32
|
+
data (dict): The dictionary to serialize JSON fields in.
|
|
33
|
+
|
|
34
|
+
Returns:
|
|
35
|
+
dict: The dictionary with JSON fields serialized.
|
|
36
|
+
"""
|
|
37
|
+
if session.get("session_data") is not None:
|
|
38
|
+
session["session_data"] = json.dumps(session["session_data"])
|
|
39
|
+
if session.get("agent_data") is not None:
|
|
40
|
+
session["agent_data"] = json.dumps(session["agent_data"])
|
|
41
|
+
if session.get("team_data") is not None:
|
|
42
|
+
session["team_data"] = json.dumps(session["team_data"])
|
|
43
|
+
if session.get("workflow_data") is not None:
|
|
44
|
+
session["workflow_data"] = json.dumps(session["workflow_data"])
|
|
45
|
+
if session.get("metadata") is not None:
|
|
46
|
+
session["metadata"] = json.dumps(session["metadata"])
|
|
47
|
+
if session.get("chat_history") is not None:
|
|
48
|
+
session["chat_history"] = json.dumps(session["chat_history"])
|
|
49
|
+
if session.get("summary") is not None:
|
|
50
|
+
session["summary"] = json.dumps(session["summary"], cls=CustomJSONEncoder)
|
|
51
|
+
if session.get("runs") is not None:
|
|
52
|
+
session["runs"] = json.dumps(session["runs"], cls=CustomJSONEncoder)
|
|
53
|
+
|
|
54
|
+
return session
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
def deserialize_session_json_fields(session: dict) -> dict:
|
|
58
|
+
"""Deserialize all JSON fields in the given Session dictionary.
|
|
59
|
+
|
|
60
|
+
Args:
|
|
61
|
+
session (dict): The dictionary to deserialize.
|
|
62
|
+
|
|
63
|
+
Returns:
|
|
64
|
+
dict: The dictionary with JSON fields deserialized.
|
|
65
|
+
"""
|
|
66
|
+
if session.get("agent_data") is not None:
|
|
67
|
+
session["agent_data"] = json.loads(session["agent_data"])
|
|
68
|
+
if session.get("team_data") is not None:
|
|
69
|
+
session["team_data"] = json.loads(session["team_data"])
|
|
70
|
+
if session.get("workflow_data") is not None:
|
|
71
|
+
session["workflow_data"] = json.loads(session["workflow_data"])
|
|
72
|
+
if session.get("metadata") is not None:
|
|
73
|
+
session["metadata"] = json.loads(session["metadata"])
|
|
74
|
+
if session.get("chat_history") is not None:
|
|
75
|
+
session["chat_history"] = json.loads(session["chat_history"])
|
|
76
|
+
if session.get("summary") is not None:
|
|
77
|
+
session["summary"] = json.loads(session["summary"])
|
|
78
|
+
if session.get("session_data") is not None and isinstance(session["session_data"], str):
|
|
79
|
+
session["session_data"] = json.loads(session["session_data"])
|
|
80
|
+
if session.get("runs") is not None:
|
|
81
|
+
if session["session_type"] == SessionType.AGENT.value:
|
|
82
|
+
session["runs"] = json.loads(session["runs"])
|
|
83
|
+
if session["session_type"] == SessionType.TEAM.value:
|
|
84
|
+
session["runs"] = json.loads(session["runs"])
|
|
85
|
+
if session["session_type"] == SessionType.WORKFLOW.value:
|
|
86
|
+
session["runs"] = json.loads(session["runs"])
|
|
87
|
+
|
|
88
|
+
return session
|
agno/eval/__init__.py
CHANGED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
from agno.eval.accuracy import AccuracyAgentResponse, AccuracyEval, AccuracyEvaluation, AccuracyResult
|
|
2
|
+
from agno.eval.performance import PerformanceEval, PerformanceResult
|
|
3
|
+
from agno.eval.reliability import ReliabilityEval, ReliabilityResult
|
|
4
|
+
|
|
5
|
+
__all__ = [
|
|
6
|
+
"AccuracyAgentResponse",
|
|
7
|
+
"AccuracyEvaluation",
|
|
8
|
+
"AccuracyResult",
|
|
9
|
+
"AccuracyEval",
|
|
10
|
+
"PerformanceEval",
|
|
11
|
+
"PerformanceResult",
|
|
12
|
+
"ReliabilityEval",
|
|
13
|
+
"ReliabilityResult",
|
|
14
|
+
]
|