agno 1.8.2__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/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 +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 +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 +128 -72
- 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 +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 +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 +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 +17 -18
- 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 +18 -33
- 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 +1 -1
- 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 +6 -12
- 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 -110
- 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 -1053
- agno/app/playground/deploy.py +0 -249
- agno/app/playground/operator.py +0 -183
- agno/app/playground/schemas.py +0 -223
- agno/app/playground/serve.py +0 -55
- agno/app/playground/sync_router.py +0 -1045
- 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 -3313
- 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.2.dist-info/METADATA +0 -982
- agno-1.8.2.dist-info/RECORD +0 -566
- agno-1.8.2.dist-info/entry_points.txt +0 -3
- agno-1.8.2.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.2.dist-info → agno-2.0.0.dist-info}/WHEEL +0 -0
- {agno-1.8.2.dist-info → agno-2.0.0.dist-info}/top_level.txt +0 -0
agno/storage/redis.py
DELETED
|
@@ -1,336 +0,0 @@
|
|
|
1
|
-
import json
|
|
2
|
-
import time
|
|
3
|
-
from dataclasses import asdict
|
|
4
|
-
from typing import List, Literal, Optional
|
|
5
|
-
from uuid import UUID
|
|
6
|
-
|
|
7
|
-
from agno.storage.base import Storage
|
|
8
|
-
from agno.storage.session import Session
|
|
9
|
-
from agno.storage.session.agent import AgentSession
|
|
10
|
-
from agno.storage.session.team import TeamSession
|
|
11
|
-
from agno.storage.session.v2.workflow import WorkflowSession as WorkflowSessionV2
|
|
12
|
-
from agno.storage.session.workflow import WorkflowSession
|
|
13
|
-
from agno.utils.log import log_debug, log_info, logger
|
|
14
|
-
|
|
15
|
-
try:
|
|
16
|
-
from redis import ConnectionError, Redis
|
|
17
|
-
except ImportError:
|
|
18
|
-
raise ImportError("`redis` not installed. Please install it using `pip install redis`")
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
class UUIDEncoder(json.JSONEncoder):
|
|
22
|
-
def default(self, obj):
|
|
23
|
-
if isinstance(obj, UUID):
|
|
24
|
-
return str(obj)
|
|
25
|
-
return super().default(obj)
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
class RedisStorage(Storage):
|
|
29
|
-
def __init__(
|
|
30
|
-
self,
|
|
31
|
-
prefix: str,
|
|
32
|
-
host: str = "localhost",
|
|
33
|
-
port: int = 6379,
|
|
34
|
-
db: int = 0,
|
|
35
|
-
password: Optional[str] = None,
|
|
36
|
-
mode: Optional[Literal["agent", "team", "workflow", "workflow_v2"]] = "agent",
|
|
37
|
-
ssl: Optional[bool] = False,
|
|
38
|
-
expire: Optional[int] = None,
|
|
39
|
-
):
|
|
40
|
-
"""
|
|
41
|
-
Initialize Redis storage for sessions.
|
|
42
|
-
|
|
43
|
-
Args:
|
|
44
|
-
prefix (str): Prefix for Redis keys to namespace the sessions
|
|
45
|
-
host (str): Redis host address
|
|
46
|
-
port (int): Redis port number
|
|
47
|
-
db (int): Redis database number
|
|
48
|
-
password (Optional[str]): Redis password if authentication is required
|
|
49
|
-
mode (Optional[Literal["agent", "team", "workflow", "workflow_v2"]]): Storage mode
|
|
50
|
-
ssl (Optional[bool]): Whether to use SSL for Redis connection
|
|
51
|
-
expire (Optional[int]): TTL (time to live) in seconds for Redis keys. None means no expiration.
|
|
52
|
-
"""
|
|
53
|
-
super().__init__(mode)
|
|
54
|
-
self.prefix = prefix
|
|
55
|
-
self.expire = expire
|
|
56
|
-
self.redis_client = Redis(
|
|
57
|
-
host=host,
|
|
58
|
-
port=port,
|
|
59
|
-
db=db,
|
|
60
|
-
password=password,
|
|
61
|
-
decode_responses=True, # Automatically decode responses to str
|
|
62
|
-
ssl=ssl,
|
|
63
|
-
)
|
|
64
|
-
log_debug(f"Created RedisStorage with prefix: '{self.prefix}'")
|
|
65
|
-
|
|
66
|
-
def _get_key(self, session_id: str) -> str:
|
|
67
|
-
"""Generate Redis key for a session."""
|
|
68
|
-
return f"{self.prefix}:{session_id}"
|
|
69
|
-
|
|
70
|
-
def serialize(self, data: dict) -> str:
|
|
71
|
-
"""Serialize data to JSON string."""
|
|
72
|
-
return json.dumps(data, ensure_ascii=False, cls=UUIDEncoder)
|
|
73
|
-
|
|
74
|
-
def deserialize(self, data: str) -> dict:
|
|
75
|
-
"""Deserialize JSON string to dict."""
|
|
76
|
-
return json.loads(data)
|
|
77
|
-
|
|
78
|
-
def create(self) -> None:
|
|
79
|
-
"""
|
|
80
|
-
Create storage if it doesn't exist.
|
|
81
|
-
For Redis, we don't need to create anything as it's schema-less.
|
|
82
|
-
"""
|
|
83
|
-
# Test connection
|
|
84
|
-
try:
|
|
85
|
-
self.redis_client.ping()
|
|
86
|
-
log_debug("Redis connection successful")
|
|
87
|
-
except ConnectionError as e:
|
|
88
|
-
logger.error(f"Could not connect to Redis: {e}")
|
|
89
|
-
raise
|
|
90
|
-
|
|
91
|
-
def read(self, session_id: str, user_id: Optional[str] = None) -> Optional[Session]:
|
|
92
|
-
"""Read a Session from Redis."""
|
|
93
|
-
try:
|
|
94
|
-
data = self.redis_client.get(self._get_key(session_id))
|
|
95
|
-
if data is None:
|
|
96
|
-
return None
|
|
97
|
-
|
|
98
|
-
session_data = self.deserialize(data) # type: ignore
|
|
99
|
-
if user_id and session_data.get("user_id") != user_id:
|
|
100
|
-
return None
|
|
101
|
-
|
|
102
|
-
if self.mode == "agent":
|
|
103
|
-
return AgentSession.from_dict(session_data)
|
|
104
|
-
elif self.mode == "team":
|
|
105
|
-
return TeamSession.from_dict(session_data)
|
|
106
|
-
elif self.mode == "workflow":
|
|
107
|
-
return WorkflowSession.from_dict(session_data)
|
|
108
|
-
elif self.mode == "workflow_v2":
|
|
109
|
-
return WorkflowSessionV2.from_dict(session_data)
|
|
110
|
-
|
|
111
|
-
except Exception as e:
|
|
112
|
-
logger.error(f"Error reading session: {e}")
|
|
113
|
-
return None
|
|
114
|
-
|
|
115
|
-
def get_all_session_ids(self, user_id: Optional[str] = None, entity_id: Optional[str] = None) -> List[str]:
|
|
116
|
-
"""Get all session IDs, optionally filtered by user_id and/or entity_id."""
|
|
117
|
-
session_ids = []
|
|
118
|
-
try:
|
|
119
|
-
# Get all keys matching the prefix pattern
|
|
120
|
-
pattern = f"{self.prefix}:*"
|
|
121
|
-
for key in self.redis_client.scan_iter(match=pattern):
|
|
122
|
-
data = self.deserialize(self.redis_client.get(key)) # type: ignore
|
|
123
|
-
|
|
124
|
-
if user_id or entity_id:
|
|
125
|
-
if user_id and entity_id:
|
|
126
|
-
if self.mode == "agent" and data["agent_id"] == entity_id and data["user_id"] == user_id:
|
|
127
|
-
session_ids.append(data["session_id"])
|
|
128
|
-
elif self.mode == "team" and data["team_id"] == entity_id and data["user_id"] == user_id:
|
|
129
|
-
session_ids.append(data["session_id"])
|
|
130
|
-
elif (
|
|
131
|
-
self.mode == "workflow" and data["workflow_id"] == entity_id and data["user_id"] == user_id
|
|
132
|
-
):
|
|
133
|
-
session_ids.append(data["session_id"])
|
|
134
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
135
|
-
session_ids.append(data["session_id"])
|
|
136
|
-
elif user_id and data["user_id"] == user_id:
|
|
137
|
-
session_ids.append(data["session_id"])
|
|
138
|
-
elif entity_id:
|
|
139
|
-
if self.mode == "agent" and data["agent_id"] == entity_id:
|
|
140
|
-
session_ids.append(data["session_id"])
|
|
141
|
-
elif self.mode == "team" and data["team_id"] == entity_id:
|
|
142
|
-
session_ids.append(data["session_id"])
|
|
143
|
-
elif self.mode == "workflow" and data["workflow_id"] == entity_id:
|
|
144
|
-
session_ids.append(data["session_id"])
|
|
145
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
146
|
-
session_ids.append(data["session_id"])
|
|
147
|
-
else:
|
|
148
|
-
# No filters applied, add all session_ids
|
|
149
|
-
session_ids.append(data["session_id"])
|
|
150
|
-
|
|
151
|
-
except Exception as e:
|
|
152
|
-
logger.error(f"Error getting session IDs: {e}")
|
|
153
|
-
|
|
154
|
-
return session_ids
|
|
155
|
-
|
|
156
|
-
def get_all_sessions(self, user_id: Optional[str] = None, entity_id: Optional[str] = None) -> List[Session]:
|
|
157
|
-
"""Get all sessions, optionally filtered by user_id and/or entity_id."""
|
|
158
|
-
sessions: List[Session] = []
|
|
159
|
-
try:
|
|
160
|
-
pattern = f"{self.prefix}:*"
|
|
161
|
-
for key in self.redis_client.scan_iter(match=pattern):
|
|
162
|
-
data = self.deserialize(self.redis_client.get(key)) # type: ignore
|
|
163
|
-
|
|
164
|
-
if user_id or entity_id:
|
|
165
|
-
_session: Optional[Session] = None
|
|
166
|
-
|
|
167
|
-
if user_id and entity_id:
|
|
168
|
-
if self.mode == "agent" and data["agent_id"] == entity_id and data["user_id"] == user_id:
|
|
169
|
-
_session = AgentSession.from_dict(data)
|
|
170
|
-
elif self.mode == "team" and data["team_id"] == entity_id and data["user_id"] == user_id:
|
|
171
|
-
_session = TeamSession.from_dict(data)
|
|
172
|
-
elif (
|
|
173
|
-
self.mode == "workflow" and data["workflow_id"] == entity_id and data["user_id"] == user_id
|
|
174
|
-
):
|
|
175
|
-
_session = WorkflowSession.from_dict(data)
|
|
176
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
177
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
178
|
-
elif user_id and data["user_id"] == user_id:
|
|
179
|
-
if self.mode == "agent":
|
|
180
|
-
_session = AgentSession.from_dict(data)
|
|
181
|
-
elif self.mode == "team":
|
|
182
|
-
_session = TeamSession.from_dict(data)
|
|
183
|
-
elif self.mode == "workflow":
|
|
184
|
-
_session = WorkflowSession.from_dict(data)
|
|
185
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
186
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
187
|
-
elif entity_id:
|
|
188
|
-
if self.mode == "agent" and data["agent_id"] == entity_id:
|
|
189
|
-
_session = AgentSession.from_dict(data)
|
|
190
|
-
elif self.mode == "team" and data["team_id"] == entity_id:
|
|
191
|
-
_session = TeamSession.from_dict(data)
|
|
192
|
-
elif self.mode == "workflow" and data["workflow_id"] == entity_id:
|
|
193
|
-
_session = WorkflowSession.from_dict(data)
|
|
194
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
195
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
196
|
-
|
|
197
|
-
if _session:
|
|
198
|
-
sessions.append(_session)
|
|
199
|
-
else:
|
|
200
|
-
_session = None
|
|
201
|
-
# No filters applied, add all sessions
|
|
202
|
-
if self.mode == "agent":
|
|
203
|
-
_session = AgentSession.from_dict(data)
|
|
204
|
-
elif self.mode == "team":
|
|
205
|
-
_session = TeamSession.from_dict(data)
|
|
206
|
-
elif self.mode == "workflow":
|
|
207
|
-
_session = WorkflowSession.from_dict(data)
|
|
208
|
-
elif self.mode == "workflow_v2":
|
|
209
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
210
|
-
if _session:
|
|
211
|
-
sessions.append(_session)
|
|
212
|
-
|
|
213
|
-
except Exception as e:
|
|
214
|
-
logger.error(f"Error getting all sessions: {e}")
|
|
215
|
-
|
|
216
|
-
return sessions
|
|
217
|
-
|
|
218
|
-
def get_recent_sessions(
|
|
219
|
-
self,
|
|
220
|
-
user_id: Optional[str] = None,
|
|
221
|
-
entity_id: Optional[str] = None,
|
|
222
|
-
limit: Optional[int] = 2,
|
|
223
|
-
) -> List[Session]:
|
|
224
|
-
"""Get the last N sessions, ordered by created_at descending.
|
|
225
|
-
|
|
226
|
-
Args:
|
|
227
|
-
num_history_sessions: Number of most recent sessions to return
|
|
228
|
-
user_id: Filter by user ID
|
|
229
|
-
entity_id: Filter by entity ID (agent_id, team_id, or workflow_id)
|
|
230
|
-
|
|
231
|
-
Returns:
|
|
232
|
-
List[Session]: List of most recent sessions
|
|
233
|
-
"""
|
|
234
|
-
sessions: List[Session] = []
|
|
235
|
-
# List of (created_at, data) tuples for sorting
|
|
236
|
-
session_data: List[tuple[int, dict]] = []
|
|
237
|
-
|
|
238
|
-
try:
|
|
239
|
-
pattern = f"{self.prefix}:*"
|
|
240
|
-
for key in self.redis_client.scan_iter(match=pattern):
|
|
241
|
-
try:
|
|
242
|
-
data = self.deserialize(self.redis_client.get(key)) # type: ignore
|
|
243
|
-
|
|
244
|
-
# Apply filters
|
|
245
|
-
if user_id and data["user_id"] != user_id:
|
|
246
|
-
continue
|
|
247
|
-
|
|
248
|
-
if entity_id:
|
|
249
|
-
if self.mode == "agent" and data["agent_id"] != entity_id:
|
|
250
|
-
continue
|
|
251
|
-
elif self.mode == "team" and data["team_id"] != entity_id:
|
|
252
|
-
continue
|
|
253
|
-
elif self.mode == "workflow" and data["workflow_id"] != entity_id:
|
|
254
|
-
continue
|
|
255
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] != entity_id:
|
|
256
|
-
continue
|
|
257
|
-
# Store with created_at for sorting
|
|
258
|
-
created_at = data.get("created_at", 0)
|
|
259
|
-
session_data.append((created_at, data))
|
|
260
|
-
|
|
261
|
-
except Exception as e:
|
|
262
|
-
logger.error(f"Error processing session data: {e}")
|
|
263
|
-
continue
|
|
264
|
-
|
|
265
|
-
# Sort by created_at descending and take only num_history_sessions
|
|
266
|
-
session_data.sort(key=lambda x: x[0], reverse=True)
|
|
267
|
-
if limit is not None:
|
|
268
|
-
session_data = session_data[:limit]
|
|
269
|
-
|
|
270
|
-
# Convert filtered and sorted data to Session objects
|
|
271
|
-
for _, data in session_data:
|
|
272
|
-
session: Optional[Session] = None
|
|
273
|
-
if self.mode == "agent":
|
|
274
|
-
session = AgentSession.from_dict(data)
|
|
275
|
-
elif self.mode == "team":
|
|
276
|
-
session = TeamSession.from_dict(data)
|
|
277
|
-
elif self.mode == "workflow":
|
|
278
|
-
session = WorkflowSession.from_dict(data)
|
|
279
|
-
elif self.mode == "workflow_v2":
|
|
280
|
-
session = WorkflowSessionV2.from_dict(data)
|
|
281
|
-
if session is not None:
|
|
282
|
-
sessions.append(session)
|
|
283
|
-
|
|
284
|
-
except Exception as e:
|
|
285
|
-
logger.error(f"Error getting last {limit} sessions: {e}")
|
|
286
|
-
|
|
287
|
-
return sessions
|
|
288
|
-
|
|
289
|
-
def upsert(self, session: Session) -> Optional[Session]:
|
|
290
|
-
"""Insert or update a Session in Redis."""
|
|
291
|
-
try:
|
|
292
|
-
if self.mode == "workflow_v2":
|
|
293
|
-
data = session.to_dict()
|
|
294
|
-
else:
|
|
295
|
-
data = asdict(session)
|
|
296
|
-
data["updated_at"] = int(time.time())
|
|
297
|
-
if "created_at" not in data or data["created_at"] is None:
|
|
298
|
-
data["created_at"] = data["updated_at"]
|
|
299
|
-
|
|
300
|
-
key = self._get_key(session.session_id)
|
|
301
|
-
if self.expire is not None:
|
|
302
|
-
self.redis_client.set(key, self.serialize(data), ex=self.expire)
|
|
303
|
-
else:
|
|
304
|
-
self.redis_client.set(key, self.serialize(data))
|
|
305
|
-
return session
|
|
306
|
-
except Exception as e:
|
|
307
|
-
logger.error(f"Error upserting session: {e}")
|
|
308
|
-
return None
|
|
309
|
-
|
|
310
|
-
def delete_session(self, session_id: Optional[str] = None):
|
|
311
|
-
"""Delete a session from Redis."""
|
|
312
|
-
if session_id is None:
|
|
313
|
-
return
|
|
314
|
-
try:
|
|
315
|
-
key = self._get_key(session_id)
|
|
316
|
-
self.redis_client.delete(key)
|
|
317
|
-
log_debug(f"Deleted session: {session_id}")
|
|
318
|
-
except Exception as e:
|
|
319
|
-
logger.error(f"Error deleting session: {e}")
|
|
320
|
-
|
|
321
|
-
def drop(self) -> None:
|
|
322
|
-
"""Drop all sessions from storage."""
|
|
323
|
-
try:
|
|
324
|
-
pattern = f"{self.prefix}:*"
|
|
325
|
-
for key in self.redis_client.scan_iter(match=pattern):
|
|
326
|
-
self.redis_client.delete(key)
|
|
327
|
-
log_info(f"Dropped all sessions with prefix: {self.prefix}")
|
|
328
|
-
except Exception as e:
|
|
329
|
-
logger.error(f"Error dropping sessions: {e}")
|
|
330
|
-
|
|
331
|
-
def upgrade_schema(self) -> None:
|
|
332
|
-
"""
|
|
333
|
-
Upgrade the schema of the storage.
|
|
334
|
-
For Redis, this is a no-op as it's schema-less.
|
|
335
|
-
"""
|
|
336
|
-
pass
|
agno/storage/session/__init__.py
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
from typing import Union
|
|
2
|
-
|
|
3
|
-
from agno.storage.session.agent import AgentSession
|
|
4
|
-
from agno.storage.session.team import TeamSession
|
|
5
|
-
from agno.storage.session.v2.workflow import WorkflowSession as WorkflowSessionV2
|
|
6
|
-
from agno.storage.session.workflow import WorkflowSession
|
|
7
|
-
|
|
8
|
-
Session = Union[AgentSession, TeamSession, WorkflowSession, WorkflowSessionV2]
|
|
9
|
-
|
|
10
|
-
__all__ = [
|
|
11
|
-
"AgentSession",
|
|
12
|
-
"TeamSession",
|
|
13
|
-
"WorkflowSession",
|
|
14
|
-
"WorkflowSessionV2",
|
|
15
|
-
"Session",
|
|
16
|
-
]
|
agno/storage/session/agent.py
DELETED
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
from __future__ import annotations
|
|
2
|
-
|
|
3
|
-
from dataclasses import asdict, dataclass
|
|
4
|
-
from typing import Any, Dict, Mapping, Optional
|
|
5
|
-
|
|
6
|
-
from agno.utils.log import logger
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
@dataclass
|
|
10
|
-
class AgentSession:
|
|
11
|
-
"""Agent Session that is stored in the database"""
|
|
12
|
-
|
|
13
|
-
# Session UUID
|
|
14
|
-
session_id: str
|
|
15
|
-
# ID of the user interacting with this agent
|
|
16
|
-
user_id: Optional[str] = None
|
|
17
|
-
# ID of the team session this agent session is associated with
|
|
18
|
-
team_session_id: Optional[str] = None
|
|
19
|
-
# ID of the workflow session this agent session is associated with
|
|
20
|
-
workflow_session_id: Optional[str] = None
|
|
21
|
-
# Agent Memory
|
|
22
|
-
memory: Optional[Dict[str, Any]] = None
|
|
23
|
-
# Session Data: session_name, session_state, images, videos, audio
|
|
24
|
-
session_data: Optional[Dict[str, Any]] = None
|
|
25
|
-
# Extra Data stored with this agent
|
|
26
|
-
extra_data: Optional[Dict[str, Any]] = None
|
|
27
|
-
# The unix timestamp when this session was created
|
|
28
|
-
created_at: Optional[int] = None
|
|
29
|
-
# The unix timestamp when this session was last updated
|
|
30
|
-
updated_at: Optional[int] = None
|
|
31
|
-
|
|
32
|
-
# ID of the agent that this session is associated with
|
|
33
|
-
agent_id: Optional[str] = None
|
|
34
|
-
# Agent Data: agent_id, name and model
|
|
35
|
-
agent_data: Optional[Dict[str, Any]] = None
|
|
36
|
-
|
|
37
|
-
def to_dict(self) -> Dict[str, Any]:
|
|
38
|
-
return asdict(self)
|
|
39
|
-
|
|
40
|
-
def telemetry_data(self) -> Dict[str, Any]:
|
|
41
|
-
return {
|
|
42
|
-
"model": self.agent_data.get("model") if self.agent_data else None,
|
|
43
|
-
"created_at": self.created_at,
|
|
44
|
-
"updated_at": self.updated_at,
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
@classmethod
|
|
48
|
-
def from_dict(cls, data: Mapping[str, Any]) -> Optional[AgentSession]:
|
|
49
|
-
if data is None or data.get("session_id") is None:
|
|
50
|
-
logger.warning("AgentSession is missing session_id")
|
|
51
|
-
return None
|
|
52
|
-
return cls(
|
|
53
|
-
session_id=data.get("session_id"), # type: ignore
|
|
54
|
-
agent_id=data.get("agent_id"),
|
|
55
|
-
team_session_id=data.get("team_session_id"),
|
|
56
|
-
workflow_session_id=data.get("workflow_session_id"),
|
|
57
|
-
user_id=data.get("user_id"),
|
|
58
|
-
memory=data.get("memory"),
|
|
59
|
-
agent_data=data.get("agent_data"),
|
|
60
|
-
session_data=data.get("session_data"),
|
|
61
|
-
extra_data=data.get("extra_data"),
|
|
62
|
-
created_at=data.get("created_at"),
|
|
63
|
-
updated_at=data.get("updated_at"),
|
|
64
|
-
)
|
agno/storage/session/team.py
DELETED
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
from __future__ import annotations
|
|
2
|
-
|
|
3
|
-
from dataclasses import asdict, dataclass
|
|
4
|
-
from typing import Any, Dict, Mapping, Optional
|
|
5
|
-
|
|
6
|
-
from agno.utils.log import logger
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
@dataclass
|
|
10
|
-
class TeamSession:
|
|
11
|
-
"""Team Session that is stored in the database"""
|
|
12
|
-
|
|
13
|
-
# Session UUID
|
|
14
|
-
session_id: str
|
|
15
|
-
# ID of the team session this team session is associated with (so for sub-teams)
|
|
16
|
-
team_session_id: Optional[str] = None
|
|
17
|
-
# ID of the workflow session this team session is associated with
|
|
18
|
-
workflow_session_id: Optional[str] = None
|
|
19
|
-
# ID of the team that this session is associated with
|
|
20
|
-
team_id: Optional[str] = None
|
|
21
|
-
# ID of the user interacting with this team
|
|
22
|
-
user_id: Optional[str] = None
|
|
23
|
-
# Team Memory
|
|
24
|
-
memory: Optional[Dict[str, Any]] = None
|
|
25
|
-
# Team Data: agent_id, name and model
|
|
26
|
-
team_data: Optional[Dict[str, Any]] = None
|
|
27
|
-
# Session Data: session_name, session_state, images, videos, audio
|
|
28
|
-
session_data: Optional[Dict[str, Any]] = None
|
|
29
|
-
# Extra Data stored with this agent
|
|
30
|
-
extra_data: Optional[Dict[str, Any]] = None
|
|
31
|
-
# The unix timestamp when this session was created
|
|
32
|
-
created_at: Optional[int] = None
|
|
33
|
-
# The unix timestamp when this session was last updated
|
|
34
|
-
updated_at: Optional[int] = None
|
|
35
|
-
|
|
36
|
-
def to_dict(self) -> Dict[str, Any]:
|
|
37
|
-
return asdict(self)
|
|
38
|
-
|
|
39
|
-
def telemetry_data(self) -> Dict[str, Any]:
|
|
40
|
-
return {
|
|
41
|
-
"model": self.team_data.get("model") if self.team_data else None,
|
|
42
|
-
"created_at": self.created_at,
|
|
43
|
-
"updated_at": self.updated_at,
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
@classmethod
|
|
47
|
-
def from_dict(cls, data: Mapping[str, Any]) -> Optional[TeamSession]:
|
|
48
|
-
if data is None or data.get("session_id") is None:
|
|
49
|
-
logger.warning("TeamSession is missing session_id")
|
|
50
|
-
return None
|
|
51
|
-
return cls(
|
|
52
|
-
session_id=data.get("session_id"), # type: ignore
|
|
53
|
-
team_id=data.get("team_id"),
|
|
54
|
-
team_session_id=data.get("team_session_id"),
|
|
55
|
-
workflow_session_id=data.get("workflow_session_id"),
|
|
56
|
-
user_id=data.get("user_id"),
|
|
57
|
-
memory=data.get("memory"),
|
|
58
|
-
team_data=data.get("team_data"),
|
|
59
|
-
session_data=data.get("session_data"),
|
|
60
|
-
extra_data=data.get("extra_data"),
|
|
61
|
-
created_at=data.get("created_at"),
|
|
62
|
-
updated_at=data.get("updated_at"),
|
|
63
|
-
)
|
agno/storage/session/workflow.py
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
from __future__ import annotations
|
|
2
|
-
|
|
3
|
-
from dataclasses import asdict, dataclass
|
|
4
|
-
from typing import Any, Dict, Mapping, Optional
|
|
5
|
-
|
|
6
|
-
from agno.utils.log import logger
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
@dataclass
|
|
10
|
-
class WorkflowSession:
|
|
11
|
-
"""Workflow Session that is stored in the database"""
|
|
12
|
-
|
|
13
|
-
# Session UUID
|
|
14
|
-
session_id: str
|
|
15
|
-
# ID of the user interacting with this agent
|
|
16
|
-
user_id: Optional[str] = None
|
|
17
|
-
# Agent Memory
|
|
18
|
-
memory: Optional[Dict[str, Any]] = None
|
|
19
|
-
# Session Data: session_name, session_state, images, videos, audio
|
|
20
|
-
session_data: Optional[Dict[str, Any]] = None
|
|
21
|
-
# Extra Data stored with this agent
|
|
22
|
-
extra_data: Optional[Dict[str, Any]] = None
|
|
23
|
-
# The unix timestamp when this session was created
|
|
24
|
-
created_at: Optional[int] = None
|
|
25
|
-
# The unix timestamp when this session was last updated
|
|
26
|
-
updated_at: Optional[int] = None
|
|
27
|
-
|
|
28
|
-
# ID of the workflow that this session is associated with
|
|
29
|
-
workflow_id: Optional[str] = None
|
|
30
|
-
# Workflow Data
|
|
31
|
-
workflow_data: Optional[Dict[str, Any]] = None
|
|
32
|
-
|
|
33
|
-
def to_dict(self) -> Dict[str, Any]:
|
|
34
|
-
return asdict(self)
|
|
35
|
-
|
|
36
|
-
def monitoring_data(self) -> Dict[str, Any]:
|
|
37
|
-
return asdict(self)
|
|
38
|
-
|
|
39
|
-
def telemetry_data(self) -> Dict[str, Any]:
|
|
40
|
-
return {
|
|
41
|
-
"created_at": self.created_at,
|
|
42
|
-
"updated_at": self.updated_at,
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
@classmethod
|
|
46
|
-
def from_dict(cls, data: Mapping[str, Any]) -> Optional[WorkflowSession]:
|
|
47
|
-
if data is None or data.get("session_id") is None:
|
|
48
|
-
logger.warning("WorkflowSession is missing session_id")
|
|
49
|
-
return None
|
|
50
|
-
|
|
51
|
-
return cls(
|
|
52
|
-
session_id=data.get("session_id"), # type: ignore
|
|
53
|
-
workflow_id=data.get("workflow_id"),
|
|
54
|
-
user_id=data.get("user_id"),
|
|
55
|
-
memory=data.get("memory"),
|
|
56
|
-
workflow_data=data.get("workflow_data"),
|
|
57
|
-
session_data=data.get("session_data"),
|
|
58
|
-
extra_data=data.get("extra_data"),
|
|
59
|
-
created_at=data.get("created_at"),
|
|
60
|
-
updated_at=data.get("updated_at"),
|
|
61
|
-
)
|