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/storage/yaml.py
DELETED
|
@@ -1,241 +0,0 @@
|
|
|
1
|
-
import time
|
|
2
|
-
from dataclasses import asdict
|
|
3
|
-
from pathlib import Path
|
|
4
|
-
from typing import List, Literal, Optional, Union
|
|
5
|
-
|
|
6
|
-
import yaml
|
|
7
|
-
|
|
8
|
-
from agno.storage.base import Storage
|
|
9
|
-
from agno.storage.session import Session
|
|
10
|
-
from agno.storage.session.agent import AgentSession
|
|
11
|
-
from agno.storage.session.team import TeamSession
|
|
12
|
-
from agno.storage.session.v2.workflow import WorkflowSession as WorkflowSessionV2
|
|
13
|
-
from agno.storage.session.workflow import WorkflowSession
|
|
14
|
-
from agno.utils.log import logger
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
class YamlStorage(Storage):
|
|
18
|
-
def __init__(
|
|
19
|
-
self, dir_path: Union[str, Path], mode: Optional[Literal["agent", "team", "workflow", "workflow_v2"]] = "agent"
|
|
20
|
-
):
|
|
21
|
-
super().__init__(mode)
|
|
22
|
-
self.dir_path = Path(dir_path)
|
|
23
|
-
self.dir_path.mkdir(parents=True, exist_ok=True)
|
|
24
|
-
|
|
25
|
-
def serialize(self, data: dict) -> str:
|
|
26
|
-
return yaml.dump(data, default_flow_style=False)
|
|
27
|
-
|
|
28
|
-
def deserialize(self, data: str) -> dict:
|
|
29
|
-
return yaml.safe_load(data)
|
|
30
|
-
|
|
31
|
-
def create(self) -> None:
|
|
32
|
-
"""Create the storage if it doesn't exist."""
|
|
33
|
-
if not self.dir_path.exists():
|
|
34
|
-
self.dir_path.mkdir(parents=True, exist_ok=True)
|
|
35
|
-
|
|
36
|
-
def read(self, session_id: str, user_id: Optional[str] = None) -> Optional[Session]:
|
|
37
|
-
"""Read a Session from storage."""
|
|
38
|
-
try:
|
|
39
|
-
with open(self.dir_path / f"{session_id}.yaml", "r", encoding="utf-8") as f:
|
|
40
|
-
data = self.deserialize(f.read())
|
|
41
|
-
if user_id and data["user_id"] != user_id:
|
|
42
|
-
return None
|
|
43
|
-
if self.mode == "agent":
|
|
44
|
-
return AgentSession.from_dict(data)
|
|
45
|
-
elif self.mode == "team":
|
|
46
|
-
return TeamSession.from_dict(data)
|
|
47
|
-
elif self.mode == "workflow":
|
|
48
|
-
return WorkflowSession.from_dict(data)
|
|
49
|
-
elif self.mode == "workflow_v2":
|
|
50
|
-
return WorkflowSessionV2.from_dict(data)
|
|
51
|
-
except FileNotFoundError:
|
|
52
|
-
return None
|
|
53
|
-
|
|
54
|
-
def get_all_session_ids(self, user_id: Optional[str] = None, entity_id: Optional[str] = None) -> List[str]:
|
|
55
|
-
"""Get all session IDs, optionally filtered by user_id and/or entity_id."""
|
|
56
|
-
session_ids = []
|
|
57
|
-
for file in self.dir_path.glob("*.yaml"):
|
|
58
|
-
with open(file, "r", encoding="utf-8") as f:
|
|
59
|
-
data = self.deserialize(f.read())
|
|
60
|
-
if user_id or entity_id:
|
|
61
|
-
if user_id and entity_id:
|
|
62
|
-
if self.mode == "agent" and data["agent_id"] == entity_id and data["user_id"] == user_id:
|
|
63
|
-
session_ids.append(data["session_id"])
|
|
64
|
-
elif self.mode == "team" and data["team_id"] == entity_id and data["user_id"] == user_id:
|
|
65
|
-
session_ids.append(data["session_id"])
|
|
66
|
-
elif (
|
|
67
|
-
self.mode == "workflow" and data["workflow_id"] == entity_id and data["user_id"] == user_id
|
|
68
|
-
):
|
|
69
|
-
session_ids.append(data["session_id"])
|
|
70
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
71
|
-
session_ids.append(data["session_id"])
|
|
72
|
-
elif user_id and data["user_id"] == user_id:
|
|
73
|
-
session_ids.append(data["session_id"])
|
|
74
|
-
elif entity_id:
|
|
75
|
-
if self.mode == "agent" and data["agent_id"] == entity_id:
|
|
76
|
-
session_ids.append(data["session_id"])
|
|
77
|
-
elif self.mode == "team" and data["team_id"] == entity_id:
|
|
78
|
-
session_ids.append(data["session_id"])
|
|
79
|
-
elif self.mode == "workflow" and data["workflow_id"] == entity_id:
|
|
80
|
-
session_ids.append(data["session_id"])
|
|
81
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
82
|
-
session_ids.append(data["session_id"])
|
|
83
|
-
else:
|
|
84
|
-
# No filters applied, add all session_ids
|
|
85
|
-
session_ids.append(data["session_id"])
|
|
86
|
-
return session_ids
|
|
87
|
-
|
|
88
|
-
def get_all_sessions(self, user_id: Optional[str] = None, entity_id: Optional[str] = None) -> List[Session]:
|
|
89
|
-
"""Get all sessions, optionally filtered by user_id and/or entity_id."""
|
|
90
|
-
sessions: List[Session] = []
|
|
91
|
-
for file in self.dir_path.glob("*.yaml"):
|
|
92
|
-
with open(file, "r", encoding="utf-8") as f:
|
|
93
|
-
data = self.deserialize(f.read())
|
|
94
|
-
if user_id or entity_id:
|
|
95
|
-
_session: Optional[Session] = None
|
|
96
|
-
if user_id and entity_id:
|
|
97
|
-
if self.mode == "agent" and data["agent_id"] == entity_id and data["user_id"] == user_id:
|
|
98
|
-
_session = AgentSession.from_dict(data)
|
|
99
|
-
elif self.mode == "team" and data["team_id"] == entity_id and data["user_id"] == user_id:
|
|
100
|
-
_session = TeamSession.from_dict(data)
|
|
101
|
-
elif (
|
|
102
|
-
self.mode == "workflow" and data["workflow_id"] == entity_id and data["user_id"] == user_id
|
|
103
|
-
):
|
|
104
|
-
_session = WorkflowSession.from_dict(data)
|
|
105
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
106
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
107
|
-
elif user_id and data["user_id"] == user_id:
|
|
108
|
-
if self.mode == "agent":
|
|
109
|
-
_session = AgentSession.from_dict(data)
|
|
110
|
-
elif self.mode == "team":
|
|
111
|
-
_session = TeamSession.from_dict(data)
|
|
112
|
-
elif self.mode == "workflow":
|
|
113
|
-
_session = WorkflowSession.from_dict(data)
|
|
114
|
-
elif self.mode == "workflow_v2":
|
|
115
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
116
|
-
elif entity_id:
|
|
117
|
-
if self.mode == "agent" and data["agent_id"] == entity_id:
|
|
118
|
-
_session = AgentSession.from_dict(data)
|
|
119
|
-
elif self.mode == "team" and data["team_id"] == entity_id:
|
|
120
|
-
_session = TeamSession.from_dict(data)
|
|
121
|
-
elif self.mode == "workflow" and data["workflow_id"] == entity_id:
|
|
122
|
-
_session = WorkflowSession.from_dict(data)
|
|
123
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] == entity_id:
|
|
124
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
125
|
-
if _session:
|
|
126
|
-
sessions.append(_session)
|
|
127
|
-
else:
|
|
128
|
-
# No filters applied, add all sessions
|
|
129
|
-
if self.mode == "agent":
|
|
130
|
-
_session = AgentSession.from_dict(data)
|
|
131
|
-
elif self.mode == "team":
|
|
132
|
-
_session = TeamSession.from_dict(data)
|
|
133
|
-
elif self.mode == "workflow":
|
|
134
|
-
_session = WorkflowSession.from_dict(data)
|
|
135
|
-
elif self.mode == "workflow_v2":
|
|
136
|
-
_session = WorkflowSessionV2.from_dict(data)
|
|
137
|
-
if _session:
|
|
138
|
-
sessions.append(_session)
|
|
139
|
-
return sessions
|
|
140
|
-
|
|
141
|
-
def get_recent_sessions(
|
|
142
|
-
self,
|
|
143
|
-
user_id: Optional[str] = None,
|
|
144
|
-
entity_id: Optional[str] = None,
|
|
145
|
-
limit: Optional[int] = 2,
|
|
146
|
-
) -> List[Session]:
|
|
147
|
-
"""Get the last N sessions, ordered by created_at descending.
|
|
148
|
-
|
|
149
|
-
Args:
|
|
150
|
-
num_history_sessions: Number of most recent sessions to return
|
|
151
|
-
user_id: Filter by user ID
|
|
152
|
-
entity_id: Filter by entity ID (agent_id, team_id, or workflow_id)
|
|
153
|
-
|
|
154
|
-
Returns:
|
|
155
|
-
List[Session]: List of most recent sessions
|
|
156
|
-
"""
|
|
157
|
-
sessions: List[Session] = []
|
|
158
|
-
# List of (created_at, data) tuples for sorting
|
|
159
|
-
session_data: List[tuple[int, dict]] = []
|
|
160
|
-
|
|
161
|
-
# First pass: collect and filter sessions
|
|
162
|
-
for file in self.dir_path.glob("*.yaml"):
|
|
163
|
-
try:
|
|
164
|
-
with open(file, "r", encoding="utf-8") as f:
|
|
165
|
-
data = self.deserialize(f.read())
|
|
166
|
-
|
|
167
|
-
if user_id and data["user_id"] != user_id:
|
|
168
|
-
continue
|
|
169
|
-
|
|
170
|
-
if entity_id:
|
|
171
|
-
if self.mode == "agent" and data["agent_id"] != entity_id:
|
|
172
|
-
continue
|
|
173
|
-
elif self.mode == "team" and data["team_id"] != entity_id:
|
|
174
|
-
continue
|
|
175
|
-
elif self.mode == "workflow" and data["workflow_id"] != entity_id:
|
|
176
|
-
continue
|
|
177
|
-
elif self.mode == "workflow_v2" and data["workflow_id"] != entity_id:
|
|
178
|
-
continue
|
|
179
|
-
# Store with created_at for sorting
|
|
180
|
-
created_at = data.get("created_at", 0)
|
|
181
|
-
session_data.append((created_at, data))
|
|
182
|
-
|
|
183
|
-
except Exception as e:
|
|
184
|
-
logger.error(f"Error reading session file {file}: {e}")
|
|
185
|
-
continue
|
|
186
|
-
|
|
187
|
-
# Sort by created_at descending and take only num_history_sessions
|
|
188
|
-
session_data.sort(key=lambda x: x[0], reverse=True)
|
|
189
|
-
if limit is not None:
|
|
190
|
-
session_data = session_data[:limit]
|
|
191
|
-
|
|
192
|
-
# Convert filtered and sorted data to Session objects
|
|
193
|
-
for _, data in session_data:
|
|
194
|
-
session: Optional[Session] = None
|
|
195
|
-
if self.mode == "agent":
|
|
196
|
-
session = AgentSession.from_dict(data)
|
|
197
|
-
elif self.mode == "team":
|
|
198
|
-
session = TeamSession.from_dict(data)
|
|
199
|
-
elif self.mode == "workflow":
|
|
200
|
-
session = WorkflowSession.from_dict(data)
|
|
201
|
-
elif self.mode == "workflow_v2":
|
|
202
|
-
session = WorkflowSessionV2.from_dict(data)
|
|
203
|
-
if session is not None:
|
|
204
|
-
sessions.append(session)
|
|
205
|
-
|
|
206
|
-
return sessions
|
|
207
|
-
|
|
208
|
-
def upsert(self, session: Session) -> Optional[Session]:
|
|
209
|
-
"""Insert or update an Session in storage."""
|
|
210
|
-
try:
|
|
211
|
-
if self.mode == "workflow_v2":
|
|
212
|
-
data = session.to_dict()
|
|
213
|
-
else:
|
|
214
|
-
data = asdict(session)
|
|
215
|
-
data["updated_at"] = int(time.time())
|
|
216
|
-
if "created_at" not in data or data["created_at"] is None:
|
|
217
|
-
data["created_at"] = data["updated_at"]
|
|
218
|
-
with open(self.dir_path / f"{session.session_id}.yaml", "w", encoding="utf-8") as f:
|
|
219
|
-
f.write(self.serialize(data))
|
|
220
|
-
return session
|
|
221
|
-
except Exception as e:
|
|
222
|
-
logger.error(f"Error upserting session: {e}")
|
|
223
|
-
return None
|
|
224
|
-
|
|
225
|
-
def delete_session(self, session_id: Optional[str] = None):
|
|
226
|
-
"""Delete a session from storage."""
|
|
227
|
-
if session_id is None:
|
|
228
|
-
return
|
|
229
|
-
try:
|
|
230
|
-
(self.dir_path / f"{session_id}.yaml").unlink(missing_ok=True)
|
|
231
|
-
except Exception as e:
|
|
232
|
-
logger.error(f"Error deleting session: {e}")
|
|
233
|
-
|
|
234
|
-
def drop(self) -> None:
|
|
235
|
-
"""Drop all sessions from storage."""
|
|
236
|
-
for file in self.dir_path.glob("*.yaml"):
|
|
237
|
-
file.unlink()
|
|
238
|
-
|
|
239
|
-
def upgrade_schema(self) -> None:
|
|
240
|
-
"""Upgrade the schema of the storage."""
|
|
241
|
-
pass
|
agno/tools/thinking.py
DELETED
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
from textwrap import dedent
|
|
2
|
-
from typing import Optional, Union
|
|
3
|
-
|
|
4
|
-
from agno.agent import Agent
|
|
5
|
-
from agno.team.team import Team
|
|
6
|
-
from agno.tools import Toolkit
|
|
7
|
-
from agno.utils.log import log_debug, logger
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
class ThinkingTools(Toolkit):
|
|
11
|
-
def __init__(
|
|
12
|
-
self,
|
|
13
|
-
think: bool = True,
|
|
14
|
-
instructions: Optional[str] = None,
|
|
15
|
-
add_instructions: bool = False,
|
|
16
|
-
**kwargs,
|
|
17
|
-
):
|
|
18
|
-
if instructions is None:
|
|
19
|
-
self.instructions = dedent("""\
|
|
20
|
-
## Using the think tool
|
|
21
|
-
Before taking any action or responding to the user after receiving tool results, use the think tool as a scratchpad to:
|
|
22
|
-
- List the specific rules that apply to the current request
|
|
23
|
-
- Check if all required information is collected
|
|
24
|
-
- Verify that the planned action complies with all policies
|
|
25
|
-
- Iterate over tool results for correctness
|
|
26
|
-
|
|
27
|
-
## Rules
|
|
28
|
-
- Use the think tool generously to jot down thoughts and ideas.\
|
|
29
|
-
""")
|
|
30
|
-
else:
|
|
31
|
-
self.instructions = instructions
|
|
32
|
-
|
|
33
|
-
tools = []
|
|
34
|
-
if think:
|
|
35
|
-
tools.append(self.think)
|
|
36
|
-
|
|
37
|
-
super().__init__(
|
|
38
|
-
name="thinking_tools",
|
|
39
|
-
instructions=self.instructions,
|
|
40
|
-
add_instructions=add_instructions,
|
|
41
|
-
tools=tools,
|
|
42
|
-
**kwargs,
|
|
43
|
-
)
|
|
44
|
-
|
|
45
|
-
def think(self, agent: Union[Agent, Team], thought: str) -> str:
|
|
46
|
-
"""Use the tool to think about something.
|
|
47
|
-
It will not obtain new information or take any actions, but just append the thought to the log and return the result.
|
|
48
|
-
Use it when complex reasoning or some cache memory or a scratchpad is needed.
|
|
49
|
-
|
|
50
|
-
:param thought: A thought to think about and log.
|
|
51
|
-
:return: The full log of thoughts and the new thought.
|
|
52
|
-
"""
|
|
53
|
-
try:
|
|
54
|
-
log_debug(f"Thought: {thought}")
|
|
55
|
-
|
|
56
|
-
# Add the thought to the Agent state
|
|
57
|
-
if agent.session_state is None:
|
|
58
|
-
agent.session_state = {}
|
|
59
|
-
if "thoughts" not in agent.session_state:
|
|
60
|
-
agent.session_state["thoughts"] = []
|
|
61
|
-
agent.session_state["thoughts"].append(thought)
|
|
62
|
-
|
|
63
|
-
# Return the full log of thoughts and the new thought
|
|
64
|
-
thoughts = "\n".join([f"- {t}" for t in agent.session_state["thoughts"]])
|
|
65
|
-
formatted_thoughts = dedent(
|
|
66
|
-
f"""Thoughts:
|
|
67
|
-
{thoughts}
|
|
68
|
-
"""
|
|
69
|
-
).strip()
|
|
70
|
-
return formatted_thoughts
|
|
71
|
-
except Exception as e:
|
|
72
|
-
logger.error(f"Error recording thought: {e}")
|
|
73
|
-
return f"Error recording thought: {e}"
|
agno/utils/defaults.py
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
# Don't import anything which may lead to circular imports
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
def get_default_ns_name(app_name: str) -> str:
|
|
5
|
-
return "{}-ns".format(app_name)
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
def get_default_ctx_name(app_name: str) -> str:
|
|
9
|
-
return "{}-ctx".format(app_name)
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
def get_default_sa_name(app_name: str) -> str:
|
|
13
|
-
return "{}-sa".format(app_name)
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
def get_default_cr_name(app_name: str) -> str:
|
|
17
|
-
return "{}-cr".format(app_name)
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
def get_default_crb_name(app_name: str) -> str:
|
|
21
|
-
return "{}-crb".format(app_name)
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
def get_default_pod_name(app_name: str) -> str:
|
|
25
|
-
return "{}-pod".format(app_name)
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
def get_default_container_name(app_name: str) -> str:
|
|
29
|
-
return "{}-container".format(app_name)
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
def get_default_service_name(app_name: str) -> str:
|
|
33
|
-
return "{}-svc".format(app_name)
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
def get_default_ingress_name(app_name: str) -> str:
|
|
37
|
-
return "{}-ingress".format(app_name)
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
def get_default_deploy_name(app_name: str) -> str:
|
|
41
|
-
return "{}-deploy".format(app_name)
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
def get_default_configmap_name(app_name: str) -> str:
|
|
45
|
-
return "{}-cm".format(app_name)
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
def get_default_secret_name(app_name: str) -> str:
|
|
49
|
-
return "{}-secret".format(app_name)
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
def get_default_volume_name(app_name: str) -> str:
|
|
53
|
-
return "{}-volume".format(app_name)
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
def get_default_pvc_name(app_name: str) -> str:
|
|
57
|
-
return "{}-pvc".format(app_name)
|
agno/utils/filesystem.py
DELETED
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
from pathlib import Path
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
def rmdir_recursive(dir_path: Path) -> bool:
|
|
5
|
-
"""Deletes dir_path recursively, including all files and dirs in that directory
|
|
6
|
-
Returns True if dir deleted successfully.
|
|
7
|
-
"""
|
|
8
|
-
|
|
9
|
-
if not dir_path.exists():
|
|
10
|
-
return True
|
|
11
|
-
|
|
12
|
-
if dir_path.is_dir():
|
|
13
|
-
from shutil import rmtree
|
|
14
|
-
|
|
15
|
-
rmtree(path=dir_path, ignore_errors=True)
|
|
16
|
-
elif dir_path.is_file():
|
|
17
|
-
dir_path.unlink(missing_ok=True)
|
|
18
|
-
|
|
19
|
-
return True if not dir_path.exists() else False
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
def delete_files_in_dir(dir: Path) -> None:
|
|
23
|
-
"""Deletes all files in a directory, but doesn't delete the directory"""
|
|
24
|
-
|
|
25
|
-
for item in dir.iterdir():
|
|
26
|
-
if item.is_dir():
|
|
27
|
-
rmdir_recursive(item)
|
|
28
|
-
else:
|
|
29
|
-
item.unlink()
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
def delete_from_fs(path_to_del: Path) -> bool:
|
|
33
|
-
if not path_to_del.exists():
|
|
34
|
-
return True
|
|
35
|
-
if path_to_del.is_dir():
|
|
36
|
-
return rmdir_recursive(path_to_del)
|
|
37
|
-
else:
|
|
38
|
-
path_to_del.unlink()
|
|
39
|
-
return True if not path_to_del.exists() else False
|
agno/utils/git.py
DELETED
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
from pathlib import Path
|
|
2
|
-
from typing import Optional
|
|
3
|
-
|
|
4
|
-
import git
|
|
5
|
-
|
|
6
|
-
from agno.utils.log import log_debug
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
def get_remote_origin_for_dir(
|
|
10
|
-
ws_root_path: Optional[Path],
|
|
11
|
-
) -> Optional[str]:
|
|
12
|
-
"""Returns the remote origin for a directory"""
|
|
13
|
-
|
|
14
|
-
if ws_root_path is None or not ws_root_path.exists() or not ws_root_path.is_dir():
|
|
15
|
-
return None
|
|
16
|
-
|
|
17
|
-
_remote_origin: Optional[git.Remote] = None
|
|
18
|
-
try:
|
|
19
|
-
_git_repo: git.Repo = git.Repo(path=ws_root_path)
|
|
20
|
-
_remote_origin = _git_repo.remote("origin")
|
|
21
|
-
except (git.InvalidGitRepositoryError, ValueError):
|
|
22
|
-
return None
|
|
23
|
-
except git.NoSuchPathError:
|
|
24
|
-
return None
|
|
25
|
-
|
|
26
|
-
if _remote_origin is None:
|
|
27
|
-
return None
|
|
28
|
-
|
|
29
|
-
# TODO: Figure out multiple urls for origin and how to only get the fetch url
|
|
30
|
-
# _remote_origin.urls returns a generator
|
|
31
|
-
_remote_origin_url: Optional[str] = None
|
|
32
|
-
for _remote_url in _remote_origin.urls:
|
|
33
|
-
_remote_origin_url = _remote_url
|
|
34
|
-
break
|
|
35
|
-
return _remote_origin_url
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
class GitCloneProgress(git.RemoteProgress):
|
|
39
|
-
# https://gitpython.readthedocs.io/en/stable/reference.html#module-git.remote
|
|
40
|
-
# def line_dropped(self, line):
|
|
41
|
-
# print("line dropped: {}".format(line))
|
|
42
|
-
|
|
43
|
-
def update(self, op_code, cur_count, max_count=None, message=""):
|
|
44
|
-
if op_code == 5:
|
|
45
|
-
log_debug("Starting copy")
|
|
46
|
-
if op_code == 10:
|
|
47
|
-
log_debug("Copy complete")
|
|
48
|
-
# log_debug(f"op_code: {op_code}")
|
|
49
|
-
# log_debug(f"cur_count: {cur_count}")
|
|
50
|
-
# log_debug(f"max_count: {max_count}")
|
|
51
|
-
# log_debug(f"message: {message}")
|
|
52
|
-
# print(self._cur_line)
|
agno/utils/json_io.py
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import json
|
|
2
|
-
from datetime import date, datetime
|
|
3
|
-
from pathlib import Path
|
|
4
|
-
from typing import Dict, List, Optional, Union
|
|
5
|
-
|
|
6
|
-
from agno.utils.log import log_debug
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class CustomJSONEncoder(json.JSONEncoder):
|
|
10
|
-
def default(self, o):
|
|
11
|
-
if isinstance(o, datetime) or isinstance(o, date):
|
|
12
|
-
return o.isoformat()
|
|
13
|
-
|
|
14
|
-
if isinstance(o, Path):
|
|
15
|
-
return str(o)
|
|
16
|
-
|
|
17
|
-
return json.JSONEncoder.default(self, o)
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
def read_json_file(file_path: Optional[Path]) -> Optional[Union[Dict, List]]:
|
|
21
|
-
if file_path is not None and file_path.exists() and file_path.is_file():
|
|
22
|
-
# log_debug(f"Reading {file_path}")
|
|
23
|
-
return json.loads(file_path.read_text())
|
|
24
|
-
return None
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
def write_json_file(file_path: Optional[Path], data: Optional[Union[Dict, List]], **kwargs) -> None:
|
|
28
|
-
if file_path is not None and data is not None:
|
|
29
|
-
log_debug(f"Writing {file_path}")
|
|
30
|
-
file_path.write_text(json.dumps(data, cls=CustomJSONEncoder, indent=4, **kwargs))
|
agno/utils/load_env.py
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
from pathlib import Path
|
|
2
|
-
from typing import Dict, Optional
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
def load_env(env: Optional[Dict[str, str]] = None, dotenv_dir: Optional[Path] = None) -> None:
|
|
6
|
-
from os import environ
|
|
7
|
-
|
|
8
|
-
if dotenv_dir is not None:
|
|
9
|
-
dotenv_file = dotenv_dir.joinpath(".env")
|
|
10
|
-
if dotenv_file is not None and dotenv_file.exists() and dotenv_file.is_file():
|
|
11
|
-
from dotenv.main import dotenv_values
|
|
12
|
-
|
|
13
|
-
dotenv_dict: Dict[str, Optional[str]] = dotenv_values(dotenv_file)
|
|
14
|
-
for key, value in dotenv_dict.items():
|
|
15
|
-
if value is not None:
|
|
16
|
-
environ[key] = value
|
|
17
|
-
|
|
18
|
-
if env is not None:
|
|
19
|
-
environ.update(env)
|
agno/utils/py_io.py
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
from pathlib import Path
|
|
2
|
-
from typing import Dict, Optional
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
def get_python_objects_from_module(module_path: Path) -> Dict:
|
|
6
|
-
"""Returns a dictionary of python objects from a module"""
|
|
7
|
-
import importlib.util
|
|
8
|
-
from importlib.machinery import ModuleSpec
|
|
9
|
-
|
|
10
|
-
# https://docs.python.org/3/library/importlib.html#importing-a-source-file-directly
|
|
11
|
-
# Create a ModuleSpec
|
|
12
|
-
module_spec: Optional[ModuleSpec] = importlib.util.spec_from_file_location("module", module_path)
|
|
13
|
-
# Using the ModuleSpec create a module
|
|
14
|
-
if module_spec:
|
|
15
|
-
module = importlib.util.module_from_spec(module_spec)
|
|
16
|
-
module_spec.loader.exec_module(module) # type: ignore
|
|
17
|
-
return module.__dict__
|
|
18
|
-
else:
|
|
19
|
-
return {}
|
agno/utils/pyproject.py
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
from pathlib import Path
|
|
2
|
-
from typing import Dict, Optional
|
|
3
|
-
|
|
4
|
-
from agno.utils.log import log_debug, logger
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
def read_pyproject_agno(pyproject_file: Path) -> Optional[Dict]:
|
|
8
|
-
log_debug(f"Reading {pyproject_file}")
|
|
9
|
-
try:
|
|
10
|
-
import tomli
|
|
11
|
-
|
|
12
|
-
pyproject_dict = tomli.loads(pyproject_file.read_text())
|
|
13
|
-
agno_conf = pyproject_dict.get("tool", {}).get("agno", None)
|
|
14
|
-
if agno_conf is not None and isinstance(agno_conf, dict):
|
|
15
|
-
return agno_conf
|
|
16
|
-
except Exception as e:
|
|
17
|
-
logger.error(f"Could not read {pyproject_file}: {e}")
|
|
18
|
-
return None
|
agno/utils/resource_filter.py
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
from typing import Optional, Tuple
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
def parse_resource_filter(
|
|
5
|
-
resource_filter: str,
|
|
6
|
-
) -> Tuple[Optional[str], Optional[str], Optional[str], Optional[str], Optional[str]]:
|
|
7
|
-
target_env: Optional[str] = None
|
|
8
|
-
target_infra: Optional[str] = None
|
|
9
|
-
target_group: Optional[str] = None
|
|
10
|
-
target_name: Optional[str] = None
|
|
11
|
-
target_type: Optional[str] = None
|
|
12
|
-
|
|
13
|
-
filters = resource_filter.split(":")
|
|
14
|
-
num_filters = len(filters)
|
|
15
|
-
if num_filters >= 1:
|
|
16
|
-
if filters[0] != "":
|
|
17
|
-
target_env = filters[0]
|
|
18
|
-
if num_filters >= 2:
|
|
19
|
-
if filters[1] != "":
|
|
20
|
-
target_infra = filters[1]
|
|
21
|
-
if num_filters >= 3:
|
|
22
|
-
if filters[2] != "":
|
|
23
|
-
target_group = filters[2]
|
|
24
|
-
if num_filters >= 4:
|
|
25
|
-
if filters[3] != "":
|
|
26
|
-
target_name = filters[3]
|
|
27
|
-
if num_filters >= 5:
|
|
28
|
-
if filters[4] != "":
|
|
29
|
-
target_type = filters[4]
|
|
30
|
-
|
|
31
|
-
return target_env, target_infra, target_group, target_name, target_type
|
agno/workflow/v2/__init__.py
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
from agno.workflow.v2.condition import Condition
|
|
2
|
-
from agno.workflow.v2.loop import Loop
|
|
3
|
-
from agno.workflow.v2.parallel import Parallel
|
|
4
|
-
from agno.workflow.v2.router import Router
|
|
5
|
-
from agno.workflow.v2.step import Step
|
|
6
|
-
from agno.workflow.v2.steps import Steps
|
|
7
|
-
from agno.workflow.v2.types import StepInput, StepOutput, WorkflowExecutionInput
|
|
8
|
-
from agno.workflow.v2.workflow import Workflow
|
|
9
|
-
|
|
10
|
-
__all__ = [
|
|
11
|
-
"Workflow",
|
|
12
|
-
"Steps",
|
|
13
|
-
"Step",
|
|
14
|
-
"Loop",
|
|
15
|
-
"Parallel",
|
|
16
|
-
"Condition",
|
|
17
|
-
"Router",
|
|
18
|
-
"WorkflowExecutionInput",
|
|
19
|
-
"StepInput",
|
|
20
|
-
"StepOutput",
|
|
21
|
-
]
|