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.
Files changed (590) hide show
  1. agno/__init__.py +8 -0
  2. agno/agent/__init__.py +19 -27
  3. agno/agent/agent.py +3143 -4170
  4. agno/api/agent.py +11 -67
  5. agno/api/api.py +5 -46
  6. agno/api/evals.py +8 -19
  7. agno/api/os.py +17 -0
  8. agno/api/routes.py +6 -41
  9. agno/api/schemas/__init__.py +9 -0
  10. agno/api/schemas/agent.py +5 -21
  11. agno/api/schemas/evals.py +7 -16
  12. agno/api/schemas/os.py +14 -0
  13. agno/api/schemas/team.py +5 -21
  14. agno/api/schemas/utils.py +21 -0
  15. agno/api/schemas/workflows.py +11 -7
  16. agno/api/settings.py +53 -0
  17. agno/api/team.py +11 -66
  18. agno/api/workflow.py +28 -0
  19. agno/cloud/aws/base.py +214 -0
  20. agno/cloud/aws/s3/__init__.py +2 -0
  21. agno/cloud/aws/s3/api_client.py +43 -0
  22. agno/cloud/aws/s3/bucket.py +195 -0
  23. agno/cloud/aws/s3/object.py +57 -0
  24. agno/db/__init__.py +24 -0
  25. agno/db/base.py +245 -0
  26. agno/db/dynamo/__init__.py +3 -0
  27. agno/db/dynamo/dynamo.py +1743 -0
  28. agno/db/dynamo/schemas.py +278 -0
  29. agno/db/dynamo/utils.py +684 -0
  30. agno/db/firestore/__init__.py +3 -0
  31. agno/db/firestore/firestore.py +1432 -0
  32. agno/db/firestore/schemas.py +130 -0
  33. agno/db/firestore/utils.py +278 -0
  34. agno/db/gcs_json/__init__.py +3 -0
  35. agno/db/gcs_json/gcs_json_db.py +1001 -0
  36. agno/db/gcs_json/utils.py +194 -0
  37. agno/db/in_memory/__init__.py +3 -0
  38. agno/db/in_memory/in_memory_db.py +882 -0
  39. agno/db/in_memory/utils.py +172 -0
  40. agno/db/json/__init__.py +3 -0
  41. agno/db/json/json_db.py +1045 -0
  42. agno/db/json/utils.py +196 -0
  43. agno/db/migrations/v1_to_v2.py +162 -0
  44. agno/db/mongo/__init__.py +3 -0
  45. agno/db/mongo/mongo.py +1416 -0
  46. agno/db/mongo/schemas.py +77 -0
  47. agno/db/mongo/utils.py +204 -0
  48. agno/db/mysql/__init__.py +3 -0
  49. agno/db/mysql/mysql.py +1719 -0
  50. agno/db/mysql/schemas.py +124 -0
  51. agno/db/mysql/utils.py +297 -0
  52. agno/db/postgres/__init__.py +3 -0
  53. agno/db/postgres/postgres.py +1710 -0
  54. agno/db/postgres/schemas.py +124 -0
  55. agno/db/postgres/utils.py +280 -0
  56. agno/db/redis/__init__.py +3 -0
  57. agno/db/redis/redis.py +1367 -0
  58. agno/db/redis/schemas.py +109 -0
  59. agno/db/redis/utils.py +288 -0
  60. agno/db/schemas/__init__.py +3 -0
  61. agno/db/schemas/evals.py +33 -0
  62. agno/db/schemas/knowledge.py +40 -0
  63. agno/db/schemas/memory.py +46 -0
  64. agno/db/singlestore/__init__.py +3 -0
  65. agno/db/singlestore/schemas.py +116 -0
  66. agno/db/singlestore/singlestore.py +1712 -0
  67. agno/db/singlestore/utils.py +326 -0
  68. agno/db/sqlite/__init__.py +3 -0
  69. agno/db/sqlite/schemas.py +119 -0
  70. agno/db/sqlite/sqlite.py +1676 -0
  71. agno/db/sqlite/utils.py +268 -0
  72. agno/db/utils.py +88 -0
  73. agno/eval/__init__.py +14 -0
  74. agno/eval/accuracy.py +154 -48
  75. agno/eval/performance.py +88 -23
  76. agno/eval/reliability.py +73 -20
  77. agno/eval/utils.py +23 -13
  78. agno/integrations/discord/__init__.py +3 -0
  79. agno/{app → integrations}/discord/client.py +15 -11
  80. agno/knowledge/__init__.py +2 -2
  81. agno/{document → knowledge}/chunking/agentic.py +2 -2
  82. agno/{document → knowledge}/chunking/document.py +2 -2
  83. agno/{document → knowledge}/chunking/fixed.py +3 -3
  84. agno/{document → knowledge}/chunking/markdown.py +2 -2
  85. agno/{document → knowledge}/chunking/recursive.py +2 -2
  86. agno/{document → knowledge}/chunking/row.py +2 -2
  87. agno/knowledge/chunking/semantic.py +59 -0
  88. agno/knowledge/chunking/strategy.py +121 -0
  89. agno/knowledge/content.py +74 -0
  90. agno/knowledge/document/__init__.py +5 -0
  91. agno/{document → knowledge/document}/base.py +12 -2
  92. agno/knowledge/embedder/__init__.py +5 -0
  93. agno/{embedder → knowledge/embedder}/aws_bedrock.py +127 -1
  94. agno/{embedder → knowledge/embedder}/azure_openai.py +65 -1
  95. agno/{embedder → knowledge/embedder}/base.py +6 -0
  96. agno/{embedder → knowledge/embedder}/cohere.py +72 -1
  97. agno/{embedder → knowledge/embedder}/fastembed.py +17 -1
  98. agno/{embedder → knowledge/embedder}/fireworks.py +1 -1
  99. agno/{embedder → knowledge/embedder}/google.py +74 -1
  100. agno/{embedder → knowledge/embedder}/huggingface.py +36 -2
  101. agno/{embedder → knowledge/embedder}/jina.py +48 -2
  102. agno/knowledge/embedder/langdb.py +22 -0
  103. agno/knowledge/embedder/mistral.py +139 -0
  104. agno/{embedder → knowledge/embedder}/nebius.py +1 -1
  105. agno/{embedder → knowledge/embedder}/ollama.py +54 -3
  106. agno/knowledge/embedder/openai.py +223 -0
  107. agno/{embedder → knowledge/embedder}/sentence_transformer.py +16 -1
  108. agno/{embedder → knowledge/embedder}/together.py +1 -1
  109. agno/{embedder → knowledge/embedder}/voyageai.py +49 -1
  110. agno/knowledge/knowledge.py +1551 -0
  111. agno/knowledge/reader/__init__.py +7 -0
  112. agno/{document → knowledge}/reader/arxiv_reader.py +32 -4
  113. agno/knowledge/reader/base.py +88 -0
  114. agno/{document → knowledge}/reader/csv_reader.py +47 -65
  115. agno/knowledge/reader/docx_reader.py +83 -0
  116. agno/{document → knowledge}/reader/firecrawl_reader.py +42 -21
  117. agno/{document → knowledge}/reader/json_reader.py +30 -9
  118. agno/{document → knowledge}/reader/markdown_reader.py +58 -9
  119. agno/{document → knowledge}/reader/pdf_reader.py +71 -126
  120. agno/knowledge/reader/reader_factory.py +268 -0
  121. agno/knowledge/reader/s3_reader.py +101 -0
  122. agno/{document → knowledge}/reader/text_reader.py +31 -10
  123. agno/knowledge/reader/url_reader.py +128 -0
  124. agno/knowledge/reader/web_search_reader.py +366 -0
  125. agno/{document → knowledge}/reader/website_reader.py +37 -10
  126. agno/knowledge/reader/wikipedia_reader.py +59 -0
  127. agno/knowledge/reader/youtube_reader.py +78 -0
  128. agno/knowledge/remote_content/remote_content.py +88 -0
  129. agno/{reranker → knowledge/reranker}/base.py +1 -1
  130. agno/{reranker → knowledge/reranker}/cohere.py +2 -2
  131. agno/{reranker → knowledge/reranker}/infinity.py +2 -2
  132. agno/{reranker → knowledge/reranker}/sentence_transformer.py +2 -2
  133. agno/knowledge/types.py +30 -0
  134. agno/knowledge/utils.py +169 -0
  135. agno/media.py +269 -268
  136. agno/memory/__init__.py +2 -10
  137. agno/memory/manager.py +1003 -148
  138. agno/models/aimlapi/__init__.py +2 -2
  139. agno/models/aimlapi/aimlapi.py +6 -6
  140. agno/models/anthropic/claude.py +131 -131
  141. agno/models/aws/bedrock.py +110 -182
  142. agno/models/aws/claude.py +64 -18
  143. agno/models/azure/ai_foundry.py +73 -23
  144. agno/models/base.py +346 -290
  145. agno/models/cerebras/cerebras.py +84 -27
  146. agno/models/cohere/chat.py +106 -98
  147. agno/models/google/gemini.py +105 -46
  148. agno/models/groq/groq.py +97 -35
  149. agno/models/huggingface/huggingface.py +92 -27
  150. agno/models/ibm/watsonx.py +72 -13
  151. agno/models/litellm/chat.py +85 -13
  152. agno/models/message.py +46 -151
  153. agno/models/meta/llama.py +85 -49
  154. agno/models/metrics.py +120 -0
  155. agno/models/mistral/mistral.py +90 -21
  156. agno/models/ollama/__init__.py +0 -2
  157. agno/models/ollama/chat.py +85 -47
  158. agno/models/openai/chat.py +154 -37
  159. agno/models/openai/responses.py +178 -105
  160. agno/models/perplexity/perplexity.py +26 -2
  161. agno/models/portkey/portkey.py +0 -7
  162. agno/models/response.py +15 -9
  163. agno/models/utils.py +20 -0
  164. agno/models/vercel/__init__.py +2 -2
  165. agno/models/vercel/v0.py +1 -1
  166. agno/models/vllm/__init__.py +2 -2
  167. agno/models/vllm/vllm.py +3 -3
  168. agno/models/xai/xai.py +10 -10
  169. agno/os/__init__.py +3 -0
  170. agno/os/app.py +497 -0
  171. agno/os/auth.py +47 -0
  172. agno/os/config.py +103 -0
  173. agno/os/interfaces/agui/__init__.py +3 -0
  174. agno/os/interfaces/agui/agui.py +31 -0
  175. agno/{app/agui/async_router.py → os/interfaces/agui/router.py} +16 -16
  176. agno/{app → os/interfaces}/agui/utils.py +77 -33
  177. agno/os/interfaces/base.py +21 -0
  178. agno/os/interfaces/slack/__init__.py +3 -0
  179. agno/{app/slack/async_router.py → os/interfaces/slack/router.py} +3 -5
  180. agno/os/interfaces/slack/slack.py +32 -0
  181. agno/os/interfaces/whatsapp/__init__.py +3 -0
  182. agno/{app/whatsapp/async_router.py → os/interfaces/whatsapp/router.py} +4 -7
  183. agno/os/interfaces/whatsapp/whatsapp.py +29 -0
  184. agno/os/mcp.py +235 -0
  185. agno/os/router.py +1400 -0
  186. agno/os/routers/__init__.py +3 -0
  187. agno/os/routers/evals/__init__.py +3 -0
  188. agno/os/routers/evals/evals.py +393 -0
  189. agno/os/routers/evals/schemas.py +142 -0
  190. agno/os/routers/evals/utils.py +161 -0
  191. agno/os/routers/knowledge/__init__.py +3 -0
  192. agno/os/routers/knowledge/knowledge.py +850 -0
  193. agno/os/routers/knowledge/schemas.py +118 -0
  194. agno/os/routers/memory/__init__.py +3 -0
  195. agno/os/routers/memory/memory.py +410 -0
  196. agno/os/routers/memory/schemas.py +58 -0
  197. agno/os/routers/metrics/__init__.py +3 -0
  198. agno/os/routers/metrics/metrics.py +178 -0
  199. agno/os/routers/metrics/schemas.py +47 -0
  200. agno/os/routers/session/__init__.py +3 -0
  201. agno/os/routers/session/session.py +536 -0
  202. agno/os/schema.py +945 -0
  203. agno/{app/playground → os}/settings.py +7 -15
  204. agno/os/utils.py +270 -0
  205. agno/reasoning/azure_ai_foundry.py +4 -4
  206. agno/reasoning/deepseek.py +4 -4
  207. agno/reasoning/default.py +6 -11
  208. agno/reasoning/groq.py +4 -4
  209. agno/reasoning/helpers.py +4 -6
  210. agno/reasoning/ollama.py +4 -4
  211. agno/reasoning/openai.py +4 -4
  212. agno/run/agent.py +633 -0
  213. agno/run/base.py +53 -77
  214. agno/run/cancel.py +81 -0
  215. agno/run/team.py +243 -96
  216. agno/run/workflow.py +550 -12
  217. agno/session/__init__.py +10 -0
  218. agno/session/agent.py +244 -0
  219. agno/session/summary.py +225 -0
  220. agno/session/team.py +262 -0
  221. agno/{storage/session/v2 → session}/workflow.py +47 -24
  222. agno/team/__init__.py +15 -16
  223. agno/team/team.py +3260 -4824
  224. agno/tools/agentql.py +14 -5
  225. agno/tools/airflow.py +9 -4
  226. agno/tools/api.py +7 -3
  227. agno/tools/apify.py +2 -46
  228. agno/tools/arxiv.py +8 -3
  229. agno/tools/aws_lambda.py +7 -5
  230. agno/tools/aws_ses.py +7 -1
  231. agno/tools/baidusearch.py +4 -1
  232. agno/tools/bitbucket.py +4 -4
  233. agno/tools/brandfetch.py +14 -11
  234. agno/tools/bravesearch.py +4 -1
  235. agno/tools/brightdata.py +43 -23
  236. agno/tools/browserbase.py +13 -4
  237. agno/tools/calcom.py +12 -10
  238. agno/tools/calculator.py +10 -27
  239. agno/tools/cartesia.py +20 -17
  240. agno/tools/{clickup_tool.py → clickup.py} +12 -25
  241. agno/tools/confluence.py +8 -8
  242. agno/tools/crawl4ai.py +7 -1
  243. agno/tools/csv_toolkit.py +9 -8
  244. agno/tools/dalle.py +22 -12
  245. agno/tools/daytona.py +13 -16
  246. agno/tools/decorator.py +6 -3
  247. agno/tools/desi_vocal.py +17 -8
  248. agno/tools/discord.py +11 -8
  249. agno/tools/docker.py +30 -42
  250. agno/tools/duckdb.py +34 -53
  251. agno/tools/duckduckgo.py +8 -7
  252. agno/tools/e2b.py +62 -62
  253. agno/tools/eleven_labs.py +36 -29
  254. agno/tools/email.py +4 -1
  255. agno/tools/evm.py +7 -1
  256. agno/tools/exa.py +19 -14
  257. agno/tools/fal.py +30 -30
  258. agno/tools/file.py +9 -8
  259. agno/tools/financial_datasets.py +25 -44
  260. agno/tools/firecrawl.py +22 -22
  261. agno/tools/function.py +127 -18
  262. agno/tools/giphy.py +23 -11
  263. agno/tools/github.py +48 -126
  264. agno/tools/gmail.py +45 -61
  265. agno/tools/google_bigquery.py +7 -6
  266. agno/tools/google_maps.py +11 -26
  267. agno/tools/googlesearch.py +7 -2
  268. agno/tools/googlesheets.py +21 -17
  269. agno/tools/hackernews.py +9 -5
  270. agno/tools/jina.py +5 -4
  271. agno/tools/jira.py +18 -9
  272. agno/tools/knowledge.py +31 -32
  273. agno/tools/linear.py +19 -34
  274. agno/tools/linkup.py +5 -1
  275. agno/tools/local_file_system.py +8 -5
  276. agno/tools/lumalab.py +32 -20
  277. agno/tools/mcp.py +1 -2
  278. agno/tools/mem0.py +18 -12
  279. agno/tools/memori.py +14 -10
  280. agno/tools/mlx_transcribe.py +3 -2
  281. agno/tools/models/azure_openai.py +33 -15
  282. agno/tools/models/gemini.py +59 -32
  283. agno/tools/models/groq.py +30 -23
  284. agno/tools/models/nebius.py +28 -12
  285. agno/tools/models_labs.py +40 -16
  286. agno/tools/moviepy_video.py +7 -6
  287. agno/tools/neo4j.py +10 -8
  288. agno/tools/newspaper.py +7 -2
  289. agno/tools/newspaper4k.py +8 -3
  290. agno/tools/openai.py +58 -32
  291. agno/tools/openbb.py +12 -11
  292. agno/tools/opencv.py +63 -47
  293. agno/tools/openweather.py +14 -12
  294. agno/tools/pandas.py +11 -3
  295. agno/tools/postgres.py +4 -12
  296. agno/tools/pubmed.py +4 -1
  297. agno/tools/python.py +9 -22
  298. agno/tools/reasoning.py +35 -27
  299. agno/tools/reddit.py +11 -26
  300. agno/tools/replicate.py +55 -42
  301. agno/tools/resend.py +4 -1
  302. agno/tools/scrapegraph.py +15 -14
  303. agno/tools/searxng.py +10 -23
  304. agno/tools/serpapi.py +6 -3
  305. agno/tools/serper.py +13 -4
  306. agno/tools/shell.py +9 -2
  307. agno/tools/slack.py +12 -11
  308. agno/tools/sleep.py +3 -2
  309. agno/tools/spider.py +24 -4
  310. agno/tools/sql.py +7 -6
  311. agno/tools/tavily.py +6 -4
  312. agno/tools/telegram.py +12 -4
  313. agno/tools/todoist.py +11 -31
  314. agno/tools/toolkit.py +1 -1
  315. agno/tools/trafilatura.py +22 -6
  316. agno/tools/trello.py +9 -22
  317. agno/tools/twilio.py +10 -3
  318. agno/tools/user_control_flow.py +6 -1
  319. agno/tools/valyu.py +34 -5
  320. agno/tools/visualization.py +19 -28
  321. agno/tools/webbrowser.py +4 -3
  322. agno/tools/webex.py +11 -7
  323. agno/tools/website.py +15 -46
  324. agno/tools/webtools.py +12 -4
  325. agno/tools/whatsapp.py +5 -9
  326. agno/tools/wikipedia.py +20 -13
  327. agno/tools/x.py +14 -13
  328. agno/tools/yfinance.py +13 -40
  329. agno/tools/youtube.py +26 -20
  330. agno/tools/zendesk.py +7 -2
  331. agno/tools/zep.py +10 -7
  332. agno/tools/zoom.py +10 -9
  333. agno/utils/common.py +1 -19
  334. agno/utils/events.py +100 -123
  335. agno/utils/gemini.py +32 -2
  336. agno/utils/knowledge.py +29 -0
  337. agno/utils/log.py +54 -4
  338. agno/utils/mcp.py +68 -10
  339. agno/utils/media.py +39 -0
  340. agno/utils/message.py +12 -1
  341. agno/utils/models/aws_claude.py +1 -1
  342. agno/utils/models/claude.py +47 -4
  343. agno/utils/models/cohere.py +1 -1
  344. agno/utils/models/mistral.py +8 -7
  345. agno/utils/models/schema_utils.py +3 -3
  346. agno/utils/models/watsonx.py +1 -1
  347. agno/utils/openai.py +1 -1
  348. agno/utils/pprint.py +33 -32
  349. agno/utils/print_response/agent.py +779 -0
  350. agno/utils/print_response/team.py +1669 -0
  351. agno/utils/print_response/workflow.py +1451 -0
  352. agno/utils/prompts.py +14 -14
  353. agno/utils/reasoning.py +87 -0
  354. agno/utils/response.py +42 -42
  355. agno/utils/streamlit.py +481 -0
  356. agno/utils/string.py +8 -22
  357. agno/utils/team.py +50 -0
  358. agno/utils/timer.py +2 -2
  359. agno/vectordb/base.py +33 -21
  360. agno/vectordb/cassandra/cassandra.py +287 -23
  361. agno/vectordb/chroma/chromadb.py +482 -59
  362. agno/vectordb/clickhouse/clickhousedb.py +270 -63
  363. agno/vectordb/couchbase/couchbase.py +309 -29
  364. agno/vectordb/lancedb/lance_db.py +360 -21
  365. agno/vectordb/langchaindb/__init__.py +5 -0
  366. agno/vectordb/langchaindb/langchaindb.py +145 -0
  367. agno/vectordb/lightrag/__init__.py +5 -0
  368. agno/vectordb/lightrag/lightrag.py +374 -0
  369. agno/vectordb/llamaindex/llamaindexdb.py +127 -0
  370. agno/vectordb/milvus/milvus.py +242 -32
  371. agno/vectordb/mongodb/mongodb.py +200 -24
  372. agno/vectordb/pgvector/pgvector.py +319 -37
  373. agno/vectordb/pineconedb/pineconedb.py +221 -27
  374. agno/vectordb/qdrant/qdrant.py +334 -14
  375. agno/vectordb/singlestore/singlestore.py +286 -29
  376. agno/vectordb/surrealdb/surrealdb.py +187 -7
  377. agno/vectordb/upstashdb/upstashdb.py +342 -26
  378. agno/vectordb/weaviate/weaviate.py +227 -165
  379. agno/workflow/__init__.py +17 -13
  380. agno/workflow/{v2/condition.py → condition.py} +135 -32
  381. agno/workflow/{v2/loop.py → loop.py} +115 -28
  382. agno/workflow/{v2/parallel.py → parallel.py} +138 -108
  383. agno/workflow/{v2/router.py → router.py} +133 -32
  384. agno/workflow/{v2/step.py → step.py} +207 -49
  385. agno/workflow/{v2/steps.py → steps.py} +147 -66
  386. agno/workflow/types.py +482 -0
  387. agno/workflow/workflow.py +2410 -696
  388. agno-2.0.0.dist-info/METADATA +494 -0
  389. agno-2.0.0.dist-info/RECORD +515 -0
  390. agno-2.0.0.dist-info/licenses/LICENSE +201 -0
  391. agno/agent/metrics.py +0 -107
  392. agno/api/app.py +0 -35
  393. agno/api/playground.py +0 -92
  394. agno/api/schemas/app.py +0 -12
  395. agno/api/schemas/playground.py +0 -22
  396. agno/api/schemas/user.py +0 -35
  397. agno/api/schemas/workspace.py +0 -46
  398. agno/api/user.py +0 -160
  399. agno/api/workflows.py +0 -33
  400. agno/api/workspace.py +0 -175
  401. agno/app/agui/__init__.py +0 -3
  402. agno/app/agui/app.py +0 -17
  403. agno/app/agui/sync_router.py +0 -120
  404. agno/app/base.py +0 -186
  405. agno/app/discord/__init__.py +0 -3
  406. agno/app/fastapi/__init__.py +0 -3
  407. agno/app/fastapi/app.py +0 -107
  408. agno/app/fastapi/async_router.py +0 -457
  409. agno/app/fastapi/sync_router.py +0 -448
  410. agno/app/playground/app.py +0 -228
  411. agno/app/playground/async_router.py +0 -1050
  412. agno/app/playground/deploy.py +0 -249
  413. agno/app/playground/operator.py +0 -183
  414. agno/app/playground/schemas.py +0 -220
  415. agno/app/playground/serve.py +0 -55
  416. agno/app/playground/sync_router.py +0 -1042
  417. agno/app/playground/utils.py +0 -46
  418. agno/app/settings.py +0 -15
  419. agno/app/slack/__init__.py +0 -3
  420. agno/app/slack/app.py +0 -19
  421. agno/app/slack/sync_router.py +0 -92
  422. agno/app/utils.py +0 -54
  423. agno/app/whatsapp/__init__.py +0 -3
  424. agno/app/whatsapp/app.py +0 -15
  425. agno/app/whatsapp/sync_router.py +0 -197
  426. agno/cli/auth_server.py +0 -249
  427. agno/cli/config.py +0 -274
  428. agno/cli/console.py +0 -88
  429. agno/cli/credentials.py +0 -23
  430. agno/cli/entrypoint.py +0 -571
  431. agno/cli/operator.py +0 -357
  432. agno/cli/settings.py +0 -96
  433. agno/cli/ws/ws_cli.py +0 -817
  434. agno/constants.py +0 -13
  435. agno/document/__init__.py +0 -5
  436. agno/document/chunking/semantic.py +0 -45
  437. agno/document/chunking/strategy.py +0 -31
  438. agno/document/reader/__init__.py +0 -5
  439. agno/document/reader/base.py +0 -47
  440. agno/document/reader/docx_reader.py +0 -60
  441. agno/document/reader/gcs/pdf_reader.py +0 -44
  442. agno/document/reader/s3/pdf_reader.py +0 -59
  443. agno/document/reader/s3/text_reader.py +0 -63
  444. agno/document/reader/url_reader.py +0 -59
  445. agno/document/reader/youtube_reader.py +0 -58
  446. agno/embedder/__init__.py +0 -5
  447. agno/embedder/langdb.py +0 -80
  448. agno/embedder/mistral.py +0 -82
  449. agno/embedder/openai.py +0 -78
  450. agno/file/__init__.py +0 -5
  451. agno/file/file.py +0 -16
  452. agno/file/local/csv.py +0 -32
  453. agno/file/local/txt.py +0 -19
  454. agno/infra/app.py +0 -240
  455. agno/infra/base.py +0 -144
  456. agno/infra/context.py +0 -20
  457. agno/infra/db_app.py +0 -52
  458. agno/infra/resource.py +0 -205
  459. agno/infra/resources.py +0 -55
  460. agno/knowledge/agent.py +0 -702
  461. agno/knowledge/arxiv.py +0 -33
  462. agno/knowledge/combined.py +0 -36
  463. agno/knowledge/csv.py +0 -144
  464. agno/knowledge/csv_url.py +0 -124
  465. agno/knowledge/document.py +0 -223
  466. agno/knowledge/docx.py +0 -137
  467. agno/knowledge/firecrawl.py +0 -34
  468. agno/knowledge/gcs/__init__.py +0 -0
  469. agno/knowledge/gcs/base.py +0 -39
  470. agno/knowledge/gcs/pdf.py +0 -125
  471. agno/knowledge/json.py +0 -137
  472. agno/knowledge/langchain.py +0 -71
  473. agno/knowledge/light_rag.py +0 -273
  474. agno/knowledge/llamaindex.py +0 -66
  475. agno/knowledge/markdown.py +0 -154
  476. agno/knowledge/pdf.py +0 -164
  477. agno/knowledge/pdf_bytes.py +0 -42
  478. agno/knowledge/pdf_url.py +0 -148
  479. agno/knowledge/s3/__init__.py +0 -0
  480. agno/knowledge/s3/base.py +0 -64
  481. agno/knowledge/s3/pdf.py +0 -33
  482. agno/knowledge/s3/text.py +0 -34
  483. agno/knowledge/text.py +0 -141
  484. agno/knowledge/url.py +0 -46
  485. agno/knowledge/website.py +0 -179
  486. agno/knowledge/wikipedia.py +0 -32
  487. agno/knowledge/youtube.py +0 -35
  488. agno/memory/agent.py +0 -423
  489. agno/memory/classifier.py +0 -104
  490. agno/memory/db/__init__.py +0 -5
  491. agno/memory/db/base.py +0 -42
  492. agno/memory/db/mongodb.py +0 -189
  493. agno/memory/db/postgres.py +0 -203
  494. agno/memory/db/sqlite.py +0 -193
  495. agno/memory/memory.py +0 -22
  496. agno/memory/row.py +0 -36
  497. agno/memory/summarizer.py +0 -201
  498. agno/memory/summary.py +0 -19
  499. agno/memory/team.py +0 -415
  500. agno/memory/v2/__init__.py +0 -2
  501. agno/memory/v2/db/__init__.py +0 -1
  502. agno/memory/v2/db/base.py +0 -42
  503. agno/memory/v2/db/firestore.py +0 -339
  504. agno/memory/v2/db/mongodb.py +0 -196
  505. agno/memory/v2/db/postgres.py +0 -214
  506. agno/memory/v2/db/redis.py +0 -187
  507. agno/memory/v2/db/schema.py +0 -54
  508. agno/memory/v2/db/sqlite.py +0 -209
  509. agno/memory/v2/manager.py +0 -437
  510. agno/memory/v2/memory.py +0 -1097
  511. agno/memory/v2/schema.py +0 -55
  512. agno/memory/v2/summarizer.py +0 -215
  513. agno/memory/workflow.py +0 -38
  514. agno/models/ollama/tools.py +0 -430
  515. agno/models/qwen/__init__.py +0 -5
  516. agno/playground/__init__.py +0 -10
  517. agno/playground/deploy.py +0 -3
  518. agno/playground/playground.py +0 -3
  519. agno/playground/serve.py +0 -3
  520. agno/playground/settings.py +0 -3
  521. agno/reranker/__init__.py +0 -0
  522. agno/run/response.py +0 -467
  523. agno/run/v2/__init__.py +0 -0
  524. agno/run/v2/workflow.py +0 -567
  525. agno/storage/__init__.py +0 -0
  526. agno/storage/agent/__init__.py +0 -0
  527. agno/storage/agent/dynamodb.py +0 -1
  528. agno/storage/agent/json.py +0 -1
  529. agno/storage/agent/mongodb.py +0 -1
  530. agno/storage/agent/postgres.py +0 -1
  531. agno/storage/agent/singlestore.py +0 -1
  532. agno/storage/agent/sqlite.py +0 -1
  533. agno/storage/agent/yaml.py +0 -1
  534. agno/storage/base.py +0 -60
  535. agno/storage/dynamodb.py +0 -673
  536. agno/storage/firestore.py +0 -297
  537. agno/storage/gcs_json.py +0 -261
  538. agno/storage/in_memory.py +0 -234
  539. agno/storage/json.py +0 -237
  540. agno/storage/mongodb.py +0 -328
  541. agno/storage/mysql.py +0 -685
  542. agno/storage/postgres.py +0 -682
  543. agno/storage/redis.py +0 -336
  544. agno/storage/session/__init__.py +0 -16
  545. agno/storage/session/agent.py +0 -64
  546. agno/storage/session/team.py +0 -63
  547. agno/storage/session/v2/__init__.py +0 -5
  548. agno/storage/session/workflow.py +0 -61
  549. agno/storage/singlestore.py +0 -606
  550. agno/storage/sqlite.py +0 -646
  551. agno/storage/workflow/__init__.py +0 -0
  552. agno/storage/workflow/mongodb.py +0 -1
  553. agno/storage/workflow/postgres.py +0 -1
  554. agno/storage/workflow/sqlite.py +0 -1
  555. agno/storage/yaml.py +0 -241
  556. agno/tools/thinking.py +0 -73
  557. agno/utils/defaults.py +0 -57
  558. agno/utils/filesystem.py +0 -39
  559. agno/utils/git.py +0 -52
  560. agno/utils/json_io.py +0 -30
  561. agno/utils/load_env.py +0 -19
  562. agno/utils/py_io.py +0 -19
  563. agno/utils/pyproject.py +0 -18
  564. agno/utils/resource_filter.py +0 -31
  565. agno/workflow/v2/__init__.py +0 -21
  566. agno/workflow/v2/types.py +0 -357
  567. agno/workflow/v2/workflow.py +0 -3312
  568. agno/workspace/__init__.py +0 -0
  569. agno/workspace/config.py +0 -325
  570. agno/workspace/enums.py +0 -6
  571. agno/workspace/helpers.py +0 -52
  572. agno/workspace/operator.py +0 -757
  573. agno/workspace/settings.py +0 -158
  574. agno-1.8.1.dist-info/METADATA +0 -982
  575. agno-1.8.1.dist-info/RECORD +0 -566
  576. agno-1.8.1.dist-info/entry_points.txt +0 -3
  577. agno-1.8.1.dist-info/licenses/LICENSE +0 -375
  578. /agno/{app → db/migrations}/__init__.py +0 -0
  579. /agno/{app/playground/__init__.py → db/schemas/metrics.py} +0 -0
  580. /agno/{cli → integrations}/__init__.py +0 -0
  581. /agno/{cli/ws → knowledge/chunking}/__init__.py +0 -0
  582. /agno/{document/chunking → knowledge/remote_content}/__init__.py +0 -0
  583. /agno/{document/reader/gcs → knowledge/reranker}/__init__.py +0 -0
  584. /agno/{document/reader/s3 → os/interfaces}/__init__.py +0 -0
  585. /agno/{app → os/interfaces}/slack/security.py +0 -0
  586. /agno/{app → os/interfaces}/whatsapp/security.py +0 -0
  587. /agno/{file/local → utils/print_response}/__init__.py +0 -0
  588. /agno/{infra → vectordb/llamaindex}/__init__.py +0 -0
  589. {agno-1.8.1.dist-info → agno-2.0.0.dist-info}/WHEEL +0 -0
  590. {agno-1.8.1.dist-info → agno-2.0.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,130 @@
1
+ """Firestore collection schemas and related utilities"""
2
+
3
+ from typing import Any, Dict, List
4
+
5
+ SESSION_COLLECTION_SCHEMA = [
6
+ {"key": "session_id"},
7
+ {"key": "user_id"},
8
+ {"key": "session_type"},
9
+ {"key": "agent_id"},
10
+ {"key": "team_id"},
11
+ {"key": "workflow_id"},
12
+ {"key": "created_at"},
13
+ {"key": "updated_at"},
14
+ {"key": "session_data.session_name"},
15
+ # Composite indexes for get_sessions queries with sorting
16
+ # These match the actual query patterns: filters + created_at ordering
17
+ {"key": [("session_type", "ASCENDING"), ("created_at", "DESCENDING")], "collection_group": False},
18
+ {
19
+ "key": [("session_type", "ASCENDING"), ("agent_id", "ASCENDING"), ("created_at", "DESCENDING")],
20
+ "collection_group": False,
21
+ },
22
+ {
23
+ "key": [("session_type", "ASCENDING"), ("team_id", "ASCENDING"), ("created_at", "DESCENDING")],
24
+ "collection_group": False,
25
+ },
26
+ {
27
+ "key": [("session_type", "ASCENDING"), ("workflow_id", "ASCENDING"), ("created_at", "DESCENDING")],
28
+ "collection_group": False,
29
+ },
30
+ # For user-specific queries with sorting
31
+ {
32
+ "key": [("user_id", "ASCENDING"), ("session_type", "ASCENDING"), ("created_at", "DESCENDING")],
33
+ "collection_group": False,
34
+ },
35
+ {
36
+ "key": [
37
+ ("user_id", "ASCENDING"),
38
+ ("session_type", "ASCENDING"),
39
+ ("agent_id", "ASCENDING"),
40
+ ("created_at", "DESCENDING"),
41
+ ],
42
+ "collection_group": False,
43
+ },
44
+ {
45
+ "key": [
46
+ ("user_id", "ASCENDING"),
47
+ ("session_type", "ASCENDING"),
48
+ ("team_id", "ASCENDING"),
49
+ ("created_at", "DESCENDING"),
50
+ ],
51
+ "collection_group": False,
52
+ },
53
+ {
54
+ "key": [
55
+ ("user_id", "ASCENDING"),
56
+ ("session_type", "ASCENDING"),
57
+ ("workflow_id", "ASCENDING"),
58
+ ("created_at", "DESCENDING"),
59
+ ],
60
+ "collection_group": False,
61
+ },
62
+ ]
63
+
64
+ USER_MEMORY_COLLECTION_SCHEMA = [
65
+ {"key": "memory_id", "unique": True},
66
+ {"key": "user_id"},
67
+ {"key": "agent_id"},
68
+ {"key": "team_id"},
69
+ {"key": "topics"},
70
+ {"key": "updated_at"},
71
+ # Composite indexes for memory queries
72
+ {"key": [("user_id", "ASCENDING"), ("agent_id", "ASCENDING")], "collection_group": False},
73
+ {"key": [("user_id", "ASCENDING"), ("team_id", "ASCENDING")], "collection_group": False},
74
+ {"key": [("user_id", "ASCENDING"), ("workflow_id", "ASCENDING")], "collection_group": False},
75
+ ]
76
+
77
+ EVAL_COLLECTION_SCHEMA = [
78
+ {"key": "run_id", "unique": True},
79
+ {"key": "eval_type"},
80
+ {"key": "eval_input"},
81
+ {"key": "agent_id"},
82
+ {"key": "team_id"},
83
+ {"key": "workflow_id"},
84
+ {"key": "model_id"},
85
+ {"key": "created_at"},
86
+ {"key": "updated_at"},
87
+ ]
88
+
89
+ KNOWLEDGE_COLLECTION_SCHEMA = [
90
+ {"key": "id", "unique": True},
91
+ {"key": "name"},
92
+ {"key": "description"},
93
+ {"key": "type"},
94
+ {"key": "status"},
95
+ {"key": "status_message"},
96
+ {"key": "metadata"},
97
+ {"key": "size"},
98
+ {"key": "linked_to"},
99
+ {"key": "access_count"},
100
+ {"key": "created_at"},
101
+ {"key": "updated_at"},
102
+ {"key": "external_id"},
103
+ ]
104
+
105
+ METRICS_COLLECTION_SCHEMA = [
106
+ {"key": "id", "unique": True},
107
+ {"key": "date"},
108
+ {"key": "aggregation_period"},
109
+ {"key": "created_at"},
110
+ {"key": "updated_at"},
111
+ # Composite index for metrics uniqueness (same as MongoDB)
112
+ {"key": [("date", "ASCENDING"), ("aggregation_period", "ASCENDING")], "collection_group": False, "unique": True},
113
+ ]
114
+
115
+
116
+ def get_collection_indexes(collection_type: str) -> List[Dict[str, Any]]:
117
+ """Get the index definitions for a specific collection type."""
118
+ index_definitions = {
119
+ "sessions": SESSION_COLLECTION_SCHEMA,
120
+ "memories": USER_MEMORY_COLLECTION_SCHEMA,
121
+ "metrics": METRICS_COLLECTION_SCHEMA,
122
+ "evals": EVAL_COLLECTION_SCHEMA,
123
+ "knowledge": KNOWLEDGE_COLLECTION_SCHEMA,
124
+ }
125
+
126
+ indexes = index_definitions.get(collection_type)
127
+ if not indexes:
128
+ raise ValueError(f"Unknown collection type: {collection_type}")
129
+
130
+ return indexes # type: ignore
@@ -0,0 +1,278 @@
1
+ """Utility functions for the Firestore database class."""
2
+
3
+ import json
4
+ import time
5
+ from datetime import date, datetime, timedelta, timezone
6
+ from typing import Any, Dict, List, Optional
7
+ from uuid import uuid4
8
+
9
+ from agno.db.firestore.schemas import get_collection_indexes
10
+ from agno.utils.log import log_debug, log_error, log_info, log_warning
11
+
12
+ try:
13
+ from google.cloud.firestore import Client # type: ignore[import-untyped]
14
+ from google.cloud.firestore_admin_v1 import FirestoreAdminClient, Index # type: ignore[import-untyped]
15
+ except ImportError:
16
+ raise ImportError(
17
+ "`google-cloud-firestore` not installed. Please install it using `pip install google-cloud-firestore`"
18
+ )
19
+
20
+
21
+ # -- DB util methods --
22
+
23
+
24
+ def create_collection_indexes(client: Client, collection_name: str, collection_type: str) -> None:
25
+ """Create all required indexes for a collection including composite indexes.
26
+
27
+ This function automatically creates both single-field and composite indexes.
28
+ """
29
+ try:
30
+ indexes = get_collection_indexes(collection_type)
31
+ composite_indexes = []
32
+
33
+ # Get all composite indexes
34
+ for idx in indexes:
35
+ if isinstance(idx["key"], list):
36
+ composite_indexes.append(idx)
37
+
38
+ # Create composite indexes programmatically
39
+ if composite_indexes:
40
+ _create_composite_indexes(client, collection_name, composite_indexes)
41
+ log_debug(f"Collection '{collection_name}' initialized")
42
+
43
+ except Exception as e:
44
+ log_warning(f"Error processing indexes for {collection_type} collection: {e}")
45
+
46
+
47
+ def _create_composite_indexes(client: Client, collection_name: str, composite_indexes: List[Dict[str, Any]]) -> None:
48
+ """Create composite indexes using Firestore Admin API."""
49
+ try:
50
+ project_id = client.project
51
+ if not project_id:
52
+ log_warning("Cannot create composite indexes: project_id not available from client")
53
+ return
54
+
55
+ admin_client = FirestoreAdminClient()
56
+
57
+ created_count = 0
58
+ for idx_spec in composite_indexes:
59
+ try:
60
+ # Build index fields
61
+ fields = []
62
+ for field_name, direction in idx_spec["key"]:
63
+ field_direction = (
64
+ Index.IndexField.Order.ASCENDING
65
+ if direction == "ASCENDING"
66
+ else Index.IndexField.Order.DESCENDING
67
+ )
68
+ fields.append(Index.IndexField(field_path=field_name, order=field_direction))
69
+
70
+ # Create index definition
71
+ index = Index(
72
+ query_scope=Index.QueryScope.COLLECTION
73
+ if not idx_spec.get("collection_group", True)
74
+ else Index.QueryScope.COLLECTION_GROUP,
75
+ fields=fields,
76
+ )
77
+
78
+ # Note: Firestore doesn't support unique constraints on composite indexes
79
+ if idx_spec.get("unique", False):
80
+ log_debug(
81
+ f"Unique constraint on composite index ignored for {collection_name} - not supported by Firestore"
82
+ )
83
+
84
+ # Create the index
85
+ parent_path = f"projects/{project_id}/databases/(default)/collectionGroups/{collection_name}"
86
+ admin_client.create_index(parent=parent_path, index=index)
87
+ created_count += 1
88
+
89
+ except Exception as e:
90
+ if "already exists" in str(e).lower():
91
+ continue
92
+ else:
93
+ log_error(f"Error creating composite index: {e}")
94
+
95
+ except Exception as e:
96
+ log_warning(f"Error initializing Firestore Admin client for composite indexes: {e}")
97
+ log_info("Fallback: You can create composite indexes manually via Firebase Console or gcloud CLI")
98
+
99
+
100
+ def apply_sorting(query, sort_by: Optional[str] = None, sort_order: Optional[str] = None):
101
+ """Apply sorting to Firestore query."""
102
+ if sort_by is None:
103
+ return query
104
+
105
+ from google.cloud.firestore import Query
106
+
107
+ if sort_order == "asc":
108
+ return query.order_by(sort_by, direction=Query.ASCENDING)
109
+ else:
110
+ return query.order_by(sort_by, direction=Query.DESCENDING)
111
+
112
+
113
+ def apply_pagination(query, limit: Optional[int] = None, page: Optional[int] = None):
114
+ """Apply pagination to Firestore query."""
115
+ if limit is not None:
116
+ query = query.limit(limit)
117
+ if page is not None and page > 1:
118
+ # Note: Firestore pagination typically uses cursor-based pagination
119
+ # For offset-based pagination, we'd need to skip documents
120
+ offset = (page - 1) * limit
121
+ query = query.offset(offset)
122
+ return query
123
+
124
+
125
+ # -- Metrics util methods --
126
+
127
+
128
+ def calculate_date_metrics(date_to_process: date, sessions_data: dict) -> dict:
129
+ """Calculate metrics for the given single date."""
130
+ metrics = {
131
+ "users_count": 0,
132
+ "agent_sessions_count": 0,
133
+ "team_sessions_count": 0,
134
+ "workflow_sessions_count": 0,
135
+ "agent_runs_count": 0,
136
+ "team_runs_count": 0,
137
+ "workflow_runs_count": 0,
138
+ }
139
+ token_metrics = {
140
+ "input_tokens": 0,
141
+ "output_tokens": 0,
142
+ "total_tokens": 0,
143
+ "audio_total_tokens": 0,
144
+ "audio_input_tokens": 0,
145
+ "audio_output_tokens": 0,
146
+ "cache_read_tokens": 0,
147
+ "cache_write_tokens": 0,
148
+ "reasoning_tokens": 0,
149
+ }
150
+ model_counts: Dict[str, int] = {}
151
+
152
+ session_types = [
153
+ ("agent", "agent_sessions_count", "agent_runs_count"),
154
+ ("team", "team_sessions_count", "team_runs_count"),
155
+ ("workflow", "workflow_sessions_count", "workflow_runs_count"),
156
+ ]
157
+ all_user_ids = set()
158
+
159
+ for session_type, sessions_count_key, runs_count_key in session_types:
160
+ sessions = sessions_data.get(session_type, [])
161
+ metrics[sessions_count_key] = len(sessions)
162
+
163
+ for session in sessions:
164
+ if session.get("user_id"):
165
+ all_user_ids.add(session["user_id"])
166
+ runs = session.get("runs", []) or []
167
+ metrics[runs_count_key] += len(runs)
168
+
169
+ if runs := session.get("runs", []):
170
+ if isinstance(runs, str):
171
+ runs = json.loads(runs)
172
+ for run in runs:
173
+ if model_id := run.get("model"):
174
+ model_provider = run.get("model_provider", "")
175
+ model_counts[f"{model_id}:{model_provider}"] = (
176
+ model_counts.get(f"{model_id}:{model_provider}", 0) + 1
177
+ )
178
+
179
+ session_data = session.get("session_data", {})
180
+ if isinstance(session_data, str):
181
+ session_data = json.loads(session_data)
182
+ session_metrics = session_data.get("session_metrics", {})
183
+ for field in token_metrics:
184
+ token_metrics[field] += session_metrics.get(field, 0)
185
+
186
+ model_metrics = []
187
+ for model, count in model_counts.items():
188
+ model_id, model_provider = model.split(":")
189
+ model_metrics.append({"model_id": model_id, "model_provider": model_provider, "count": count})
190
+
191
+ metrics["users_count"] = len(all_user_ids)
192
+ current_time = int(time.time())
193
+
194
+ return {
195
+ "id": str(uuid4()),
196
+ "date": date_to_process,
197
+ "completed": date_to_process < datetime.now(timezone.utc).date(),
198
+ "token_metrics": token_metrics,
199
+ "model_metrics": model_metrics,
200
+ "created_at": current_time,
201
+ "updated_at": current_time,
202
+ "aggregation_period": "daily",
203
+ **metrics,
204
+ }
205
+
206
+
207
+ def fetch_all_sessions_data(
208
+ sessions: List[Dict[str, Any]], dates_to_process: list[date], start_timestamp: int
209
+ ) -> Optional[dict]:
210
+ """Return all session data for the given dates, for all session types."""
211
+ if not dates_to_process:
212
+ return None
213
+
214
+ all_sessions_data: Dict[str, Dict[str, List[Dict[str, Any]]]] = {
215
+ date_to_process.isoformat(): {"agent": [], "team": [], "workflow": []} for date_to_process in dates_to_process
216
+ }
217
+
218
+ for session in sessions:
219
+ session_date = (
220
+ datetime.fromtimestamp(session.get("created_at", start_timestamp), tz=timezone.utc).date().isoformat()
221
+ )
222
+ if session_date in all_sessions_data:
223
+ all_sessions_data[session_date][session["session_type"]].append(session)
224
+
225
+ return all_sessions_data
226
+
227
+
228
+ def get_dates_to_calculate_metrics_for(starting_date: date) -> list[date]:
229
+ """Return the list of dates to calculate metrics for."""
230
+ today = datetime.now(timezone.utc).date()
231
+ days_diff = (today - starting_date).days + 1
232
+ if days_diff <= 0:
233
+ return []
234
+ return [starting_date + timedelta(days=x) for x in range(days_diff)]
235
+
236
+
237
+ def bulk_upsert_metrics(collection_ref, metrics_records: List[Dict[str, Any]]) -> List[Dict[str, Any]]:
238
+ """Bulk upsert metrics into the database.
239
+
240
+ Args:
241
+ collection_ref: The Firestore collection reference to upsert the metrics into.
242
+ metrics_records (List[Dict[str, Any]]): The list of metrics records to upsert.
243
+
244
+ Returns:
245
+ The list of upserted metrics records.
246
+ """
247
+ if not metrics_records:
248
+ return []
249
+
250
+ results = []
251
+ batch = collection_ref._client.batch()
252
+
253
+ for i, record in enumerate(metrics_records):
254
+ record["date"] = record["date"].isoformat() if isinstance(record["date"], date) else record["date"]
255
+ try:
256
+ # Create a unique document ID based on date and aggregation period
257
+ doc_id = f"{record['date']}_{record['aggregation_period']}"
258
+ doc_ref = collection_ref.document(doc_id)
259
+ batch.set(doc_ref, record, merge=True)
260
+ results.append(record)
261
+
262
+ # Firestore batch limit is 500 operations
263
+ if (i + 1) % 500 == 0:
264
+ batch.commit()
265
+ batch = collection_ref._client.batch()
266
+
267
+ except Exception as e:
268
+ log_error(f"Error preparing metrics record for batch: {e}")
269
+ continue
270
+
271
+ # Commit remaining operations
272
+ if len(metrics_records) % 500 != 0:
273
+ try:
274
+ batch.commit()
275
+ except Exception as e:
276
+ log_error(f"Error committing metrics batch: {e}")
277
+
278
+ return results
@@ -0,0 +1,3 @@
1
+ from agno.db.gcs_json.gcs_json_db import GcsJsonDb
2
+
3
+ __all__ = ["GcsJsonDb"]