pygeai 0.1.6__py3-none-any.whl → 0.6.0b15__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.

Potentially problematic release.


This version of pygeai might be problematic. Click here for more details.

Files changed (788) hide show
  1. pygeai/__init__.py +11 -2
  2. pygeai/_docs/Makefile +20 -0
  3. pygeai/_docs/make.bat +35 -0
  4. pygeai/_docs/source/conf.py +117 -0
  5. pygeai/_docs/source/content/ai_lab/cli.rst +747 -0
  6. pygeai/_docs/source/content/ai_lab/models.rst +1734 -0
  7. pygeai/_docs/source/content/ai_lab/runner.rst +253 -0
  8. pygeai/_docs/source/content/ai_lab/spec.rst +431 -0
  9. pygeai/_docs/source/content/ai_lab/usage.rst +1011 -0
  10. pygeai/_docs/source/content/ai_lab.rst +102 -0
  11. pygeai/_docs/source/content/analytics.rst +598 -0
  12. pygeai/_docs/source/content/api_reference/admin.rst +161 -0
  13. pygeai/_docs/source/content/api_reference/assistant.rst +326 -0
  14. pygeai/_docs/source/content/api_reference/auth.rst +379 -0
  15. pygeai/_docs/source/content/api_reference/chat.rst +754 -0
  16. pygeai/_docs/source/content/api_reference/embeddings.rst +154 -0
  17. pygeai/_docs/source/content/api_reference/evaluation.rst +590 -0
  18. pygeai/_docs/source/content/api_reference/feedback.rst +237 -0
  19. pygeai/_docs/source/content/api_reference/files.rst +592 -0
  20. pygeai/_docs/source/content/api_reference/gam.rst +401 -0
  21. pygeai/_docs/source/content/api_reference/health.rst +58 -0
  22. pygeai/_docs/source/content/api_reference/project.rst +738 -0
  23. pygeai/_docs/source/content/api_reference/proxy.rst +318 -0
  24. pygeai/_docs/source/content/api_reference/rag.rst +710 -0
  25. pygeai/_docs/source/content/api_reference/rerank.rst +94 -0
  26. pygeai/_docs/source/content/api_reference/secrets.rst +495 -0
  27. pygeai/_docs/source/content/api_reference/usage_limits.rst +390 -0
  28. pygeai/_docs/source/content/api_reference.rst +58 -0
  29. pygeai/_docs/source/content/authentication.rst +295 -0
  30. pygeai/_docs/source/content/chat_gui.rst +121 -0
  31. pygeai/_docs/source/content/cli.rst +203 -0
  32. pygeai/_docs/source/content/debugger.rst +651 -0
  33. pygeai/_docs/source/content/intro.rst +67 -0
  34. pygeai/_docs/source/content/migration.rst +929 -0
  35. pygeai/_docs/source/content/modules.rst +7 -0
  36. pygeai/_docs/source/content/quickstart.rst +143 -0
  37. pygeai/_docs/source/content/samples.rst +394 -0
  38. pygeai/_docs/source/index.rst +75 -0
  39. pygeai/_docs/source/modules.rst +7 -0
  40. pygeai/_docs/source/pygeai.admin.rst +29 -0
  41. pygeai/_docs/source/pygeai.analytics.rst +53 -0
  42. pygeai/_docs/source/pygeai.assistant.data.rst +21 -0
  43. pygeai/_docs/source/pygeai.assistant.data_analyst.rst +29 -0
  44. pygeai/_docs/source/pygeai.assistant.rag.rst +53 -0
  45. pygeai/_docs/source/pygeai.assistant.rst +55 -0
  46. pygeai/_docs/source/pygeai.auth.rst +29 -0
  47. pygeai/_docs/source/pygeai.chat.rst +69 -0
  48. pygeai/_docs/source/pygeai.cli.commands.flows.rst +10 -0
  49. pygeai/_docs/source/pygeai.cli.commands.lab.rst +53 -0
  50. pygeai/_docs/source/pygeai.cli.commands.rst +222 -0
  51. pygeai/_docs/source/pygeai.cli.rst +62 -0
  52. pygeai/_docs/source/pygeai.cli.texts.rst +21 -0
  53. pygeai/_docs/source/pygeai.core.base.rst +53 -0
  54. pygeai/_docs/source/pygeai.core.common.rst +37 -0
  55. pygeai/_docs/source/pygeai.core.embeddings.rst +61 -0
  56. pygeai/_docs/source/pygeai.core.feedback.rst +37 -0
  57. pygeai/_docs/source/pygeai.core.files.rst +61 -0
  58. pygeai/_docs/source/pygeai.core.llm.rst +29 -0
  59. pygeai/_docs/source/pygeai.core.plugins.rst +37 -0
  60. pygeai/_docs/source/pygeai.core.rerank.rst +53 -0
  61. pygeai/_docs/source/pygeai.core.rst +63 -0
  62. pygeai/_docs/source/pygeai.core.secrets.rst +29 -0
  63. pygeai/_docs/source/pygeai.core.services.llm.rst +29 -0
  64. pygeai/_docs/source/pygeai.core.services.rst +37 -0
  65. pygeai/_docs/source/pygeai.core.utils.rst +37 -0
  66. pygeai/_docs/source/pygeai.dbg.rst +21 -0
  67. pygeai/_docs/source/pygeai.evaluation.dataset.rst +29 -0
  68. pygeai/_docs/source/pygeai.evaluation.plan.rst +29 -0
  69. pygeai/_docs/source/pygeai.evaluation.result.rst +29 -0
  70. pygeai/_docs/source/pygeai.evaluation.rst +31 -0
  71. pygeai/_docs/source/pygeai.flows.rst +29 -0
  72. pygeai/_docs/source/pygeai.gam.rst +29 -0
  73. pygeai/_docs/source/pygeai.health.rst +29 -0
  74. pygeai/_docs/source/pygeai.lab.agents.rst +37 -0
  75. pygeai/_docs/source/pygeai.lab.processes.rst +37 -0
  76. pygeai/_docs/source/pygeai.lab.rst +65 -0
  77. pygeai/_docs/source/pygeai.lab.spec.rst +29 -0
  78. pygeai/_docs/source/pygeai.lab.strategies.rst +37 -0
  79. pygeai/_docs/source/pygeai.lab.tools.rst +37 -0
  80. pygeai/_docs/source/pygeai.man.man1.rst +10 -0
  81. pygeai/_docs/source/pygeai.man.rst +18 -0
  82. pygeai/_docs/source/pygeai.migration.rst +29 -0
  83. pygeai/_docs/source/pygeai.organization.limits.rst +45 -0
  84. pygeai/_docs/source/pygeai.organization.rst +61 -0
  85. pygeai/_docs/source/pygeai.proxy.rst +53 -0
  86. pygeai/_docs/source/pygeai.rst +35 -0
  87. pygeai/_docs/source/pygeai.tests.admin.rst +21 -0
  88. pygeai/_docs/source/pygeai.tests.analytics.rst +45 -0
  89. pygeai/_docs/source/pygeai.tests.assistants.rag.rst +37 -0
  90. pygeai/_docs/source/pygeai.tests.assistants.rst +45 -0
  91. pygeai/_docs/source/pygeai.tests.auth.rst +29 -0
  92. pygeai/_docs/source/pygeai.tests.chat.rst +45 -0
  93. pygeai/_docs/source/pygeai.tests.cli.commands.lab.rst +37 -0
  94. pygeai/_docs/source/pygeai.tests.cli.commands.rst +165 -0
  95. pygeai/_docs/source/pygeai.tests.cli.docker.rst +10 -0
  96. pygeai/_docs/source/pygeai.tests.cli.rst +46 -0
  97. pygeai/_docs/source/pygeai.tests.core.base.data.rst +29 -0
  98. pygeai/_docs/source/pygeai.tests.core.base.rst +45 -0
  99. pygeai/_docs/source/pygeai.tests.core.common.data.rst +10 -0
  100. pygeai/_docs/source/pygeai.tests.core.common.rst +37 -0
  101. pygeai/_docs/source/pygeai.tests.core.embeddings.rst +37 -0
  102. pygeai/_docs/source/pygeai.tests.core.feedback.rst +21 -0
  103. pygeai/_docs/source/pygeai.tests.core.files.rst +53 -0
  104. pygeai/_docs/source/pygeai.tests.core.llm.rst +21 -0
  105. pygeai/_docs/source/pygeai.tests.core.plugins.rst +21 -0
  106. pygeai/_docs/source/pygeai.tests.core.rerank.rst +37 -0
  107. pygeai/_docs/source/pygeai.tests.core.rst +39 -0
  108. pygeai/_docs/source/pygeai.tests.core.secrets.rst +21 -0
  109. pygeai/_docs/source/pygeai.tests.core.services.rst +21 -0
  110. pygeai/_docs/source/pygeai.tests.core.utils.rst +21 -0
  111. pygeai/_docs/source/pygeai.tests.dbg.rst +21 -0
  112. pygeai/_docs/source/pygeai.tests.evaluation.dataset.rst +21 -0
  113. pygeai/_docs/source/pygeai.tests.evaluation.plan.rst +21 -0
  114. pygeai/_docs/source/pygeai.tests.evaluation.result.rst +21 -0
  115. pygeai/_docs/source/pygeai.tests.evaluation.rst +20 -0
  116. pygeai/_docs/source/pygeai.tests.gam.rst +21 -0
  117. pygeai/_docs/source/pygeai.tests.health.rst +21 -0
  118. pygeai/_docs/source/pygeai.tests.integration.assistants.rag.rst +21 -0
  119. pygeai/_docs/source/pygeai.tests.integration.assistants.rst +18 -0
  120. pygeai/_docs/source/pygeai.tests.integration.chat.rst +21 -0
  121. pygeai/_docs/source/pygeai.tests.integration.lab.agents.rst +69 -0
  122. pygeai/_docs/source/pygeai.tests.integration.lab.processes.rst +77 -0
  123. pygeai/_docs/source/pygeai.tests.integration.lab.reasoning_strategies.rst +37 -0
  124. pygeai/_docs/source/pygeai.tests.integration.lab.rst +21 -0
  125. pygeai/_docs/source/pygeai.tests.integration.lab.tools.rst +77 -0
  126. pygeai/_docs/source/pygeai.tests.integration.rst +20 -0
  127. pygeai/_docs/source/pygeai.tests.lab.agents.rst +29 -0
  128. pygeai/_docs/source/pygeai.tests.lab.processes.rst +29 -0
  129. pygeai/_docs/source/pygeai.tests.lab.rst +49 -0
  130. pygeai/_docs/source/pygeai.tests.lab.spec.rst +29 -0
  131. pygeai/_docs/source/pygeai.tests.lab.strategies.rst +29 -0
  132. pygeai/_docs/source/pygeai.tests.lab.tools.rst +29 -0
  133. pygeai/_docs/source/pygeai.tests.migration.rst +29 -0
  134. pygeai/_docs/source/pygeai.tests.organization.limits.rst +29 -0
  135. pygeai/_docs/source/pygeai.tests.organization.rst +53 -0
  136. pygeai/_docs/source/pygeai.tests.proxy.rst +61 -0
  137. pygeai/_docs/source/pygeai.tests.rst +33 -0
  138. pygeai/admin/clients.py +14 -11
  139. pygeai/admin/endpoints.py +2 -2
  140. pygeai/analytics/clients.py +505 -0
  141. pygeai/analytics/endpoints.py +35 -0
  142. pygeai/analytics/managers.py +606 -0
  143. pygeai/analytics/mappers.py +207 -0
  144. pygeai/analytics/responses.py +240 -0
  145. pygeai/assistant/clients.py +48 -57
  146. pygeai/assistant/data/__init__.py +0 -0
  147. pygeai/assistant/data/clients.py +15 -0
  148. pygeai/assistant/data_analyst/__init__.py +0 -0
  149. pygeai/assistant/data_analyst/clients.py +75 -0
  150. pygeai/assistant/data_analyst/endpoints.py +2 -0
  151. pygeai/assistant/endpoints.py +0 -2
  152. pygeai/assistant/managers.py +738 -0
  153. pygeai/assistant/mappers.py +153 -0
  154. pygeai/assistant/rag/clients.py +132 -21
  155. pygeai/assistant/rag/mappers.py +228 -0
  156. pygeai/assistant/rag/models.py +396 -0
  157. pygeai/assistant/rag/responses.py +10 -0
  158. pygeai/auth/__init__.py +0 -0
  159. pygeai/auth/clients.py +129 -0
  160. pygeai/auth/endpoints.py +6 -0
  161. pygeai/chat/clients.py +406 -31
  162. pygeai/chat/endpoints.py +3 -0
  163. pygeai/chat/iris.py +17 -0
  164. pygeai/chat/managers.py +64 -0
  165. pygeai/chat/session.py +38 -0
  166. pygeai/chat/settings.py +6 -0
  167. pygeai/chat/ui.py +678 -0
  168. pygeai/cli/__init__.py +0 -1
  169. pygeai/cli/commands/admin.py +9 -12
  170. pygeai/cli/commands/analytics.py +533 -0
  171. pygeai/cli/commands/assistant.py +11 -11
  172. pygeai/cli/commands/auth.py +299 -0
  173. pygeai/cli/commands/base.py +201 -7
  174. pygeai/cli/commands/chat.py +875 -14
  175. pygeai/cli/commands/common.py +30 -26
  176. pygeai/cli/commands/configuration.py +84 -9
  177. pygeai/cli/commands/docs.py +105 -0
  178. pygeai/cli/commands/embeddings.py +187 -0
  179. pygeai/cli/commands/evaluation.py +2069 -0
  180. pygeai/cli/commands/feedback.py +93 -0
  181. pygeai/cli/commands/files.py +312 -0
  182. pygeai/cli/commands/flows/__init__.py +0 -0
  183. pygeai/cli/commands/gam.py +349 -0
  184. pygeai/cli/commands/lab/__init__.py +0 -0
  185. pygeai/cli/commands/lab/ai_lab.py +4110 -0
  186. pygeai/cli/commands/lab/common.py +135 -0
  187. pygeai/cli/commands/lab/options.py +8 -0
  188. pygeai/cli/commands/lab/spec.py +273 -0
  189. pygeai/cli/commands/lab/utils.py +13 -0
  190. pygeai/cli/commands/llm.py +164 -0
  191. pygeai/cli/commands/migrate.py +1198 -0
  192. pygeai/cli/commands/options.py +86 -0
  193. pygeai/cli/commands/organization.py +560 -98
  194. pygeai/cli/commands/rag.py +306 -10
  195. pygeai/cli/commands/rerank.py +108 -0
  196. pygeai/cli/commands/secrets.py +357 -0
  197. pygeai/cli/commands/usage_limits.py +583 -0
  198. pygeai/cli/commands/validators.py +209 -0
  199. pygeai/cli/commands/version.py +44 -0
  200. pygeai/cli/error_handler.py +151 -0
  201. pygeai/cli/geai.py +171 -30
  202. pygeai/cli/geai_proxy.py +318 -0
  203. pygeai/cli/install_man.py +107 -0
  204. pygeai/cli/parsers.py +78 -25
  205. pygeai/cli/texts/help.py +712 -55
  206. pygeai/core/__init__.py +9 -1
  207. pygeai/core/base/clients.py +61 -10
  208. pygeai/core/base/mappers.py +208 -30
  209. pygeai/core/base/models.py +8 -308
  210. pygeai/core/base/responses.py +18 -1
  211. pygeai/core/base/session.py +110 -17
  212. pygeai/core/common/config.py +98 -16
  213. pygeai/core/common/decorators.py +44 -0
  214. pygeai/core/common/exceptions.py +104 -4
  215. pygeai/core/embeddings/__init__.py +19 -0
  216. pygeai/core/embeddings/clients.py +93 -0
  217. pygeai/core/embeddings/endpoints.py +1 -0
  218. pygeai/core/embeddings/managers.py +62 -0
  219. pygeai/core/embeddings/mappers.py +52 -0
  220. pygeai/core/embeddings/models.py +14 -0
  221. pygeai/core/embeddings/responses.py +31 -0
  222. pygeai/core/feedback/__init__.py +0 -0
  223. pygeai/core/feedback/clients.py +50 -0
  224. pygeai/core/feedback/endpoints.py +1 -0
  225. pygeai/core/feedback/models.py +10 -0
  226. pygeai/core/files/__init__.py +0 -0
  227. pygeai/core/files/clients.py +156 -0
  228. pygeai/core/files/endpoints.py +5 -0
  229. pygeai/core/files/managers.py +224 -0
  230. pygeai/core/files/mappers.py +44 -0
  231. pygeai/core/files/models.py +24 -0
  232. pygeai/core/files/responses.py +19 -0
  233. pygeai/core/handlers.py +32 -0
  234. pygeai/core/llm/__init__.py +0 -0
  235. pygeai/core/llm/clients.py +53 -0
  236. pygeai/core/llm/endpoints.py +4 -0
  237. pygeai/core/models.py +799 -0
  238. pygeai/core/plugins/__init__.py +0 -0
  239. pygeai/core/plugins/clients.py +32 -0
  240. pygeai/core/plugins/endpoints.py +1 -0
  241. pygeai/core/plugins/models.py +86 -0
  242. pygeai/core/rerank/__init__.py +0 -0
  243. pygeai/core/rerank/clients.py +35 -0
  244. pygeai/core/rerank/endpoints.py +1 -0
  245. pygeai/core/rerank/managers.py +47 -0
  246. pygeai/core/rerank/mappers.py +23 -0
  247. pygeai/core/rerank/models.py +27 -0
  248. pygeai/core/responses.py +104 -0
  249. pygeai/core/secrets/__init__.py +0 -0
  250. pygeai/core/secrets/clients.py +212 -0
  251. pygeai/core/secrets/endpoints.py +7 -0
  252. pygeai/core/services/llm/__init__.py +0 -0
  253. pygeai/core/services/llm/model.py +186 -0
  254. pygeai/core/services/llm/providers.py +15 -0
  255. pygeai/core/services/response.py +18 -0
  256. pygeai/core/services/rest.py +311 -89
  257. pygeai/core/utils/__init__.py +0 -0
  258. pygeai/core/utils/console.py +83 -0
  259. pygeai/core/utils/parsers.py +32 -0
  260. pygeai/core/utils/validators.py +10 -0
  261. pygeai/dbg/__init__.py +3 -0
  262. pygeai/dbg/debugger.py +870 -0
  263. pygeai/evaluation/__init__.py +0 -0
  264. pygeai/evaluation/clients.py +19 -0
  265. pygeai/evaluation/dataset/__init__.py +0 -0
  266. pygeai/evaluation/dataset/clients.py +514 -0
  267. pygeai/evaluation/dataset/endpoints.py +26 -0
  268. pygeai/evaluation/plan/__init__.py +0 -0
  269. pygeai/evaluation/plan/clients.py +302 -0
  270. pygeai/evaluation/plan/endpoints.py +16 -0
  271. pygeai/evaluation/result/__init__.py +0 -0
  272. pygeai/evaluation/result/clients.py +70 -0
  273. pygeai/evaluation/result/endpoints.py +2 -0
  274. pygeai/flows/__init__.py +0 -0
  275. pygeai/flows/endpoints.py +362 -0
  276. pygeai/flows/models.py +1304 -0
  277. pygeai/gam/__init__.py +0 -0
  278. pygeai/gam/clients.py +178 -0
  279. pygeai/gam/endpoints.py +4 -0
  280. pygeai/health/__init__.py +0 -0
  281. pygeai/health/clients.py +24 -0
  282. pygeai/health/endpoints.py +1 -0
  283. pygeai/lab/__init__.py +0 -0
  284. pygeai/lab/agents/__init__.py +0 -0
  285. pygeai/lab/agents/clients.py +426 -0
  286. pygeai/lab/agents/endpoints.py +12 -0
  287. pygeai/lab/agents/mappers.py +319 -0
  288. pygeai/lab/clients.py +24 -0
  289. pygeai/lab/constants.py +3 -0
  290. pygeai/lab/managers.py +1558 -0
  291. pygeai/lab/models.py +1719 -0
  292. pygeai/lab/processes/__init__.py +0 -0
  293. pygeai/lab/processes/clients.py +1051 -0
  294. pygeai/lab/processes/endpoints.py +26 -0
  295. pygeai/lab/processes/mappers.py +395 -0
  296. pygeai/lab/runners.py +90 -0
  297. pygeai/lab/spec/__init__.py +0 -0
  298. pygeai/lab/spec/loader.py +24 -0
  299. pygeai/lab/spec/parsers.py +39 -0
  300. pygeai/lab/strategies/__init__.py +0 -0
  301. pygeai/lab/strategies/clients.py +212 -0
  302. pygeai/lab/strategies/endpoints.py +5 -0
  303. pygeai/lab/strategies/mappers.py +58 -0
  304. pygeai/lab/tools/__init__.py +0 -0
  305. pygeai/lab/tools/clients.py +465 -0
  306. pygeai/lab/tools/endpoints.py +13 -0
  307. pygeai/lab/tools/mappers.py +131 -0
  308. pygeai/man/__init__.py +1 -0
  309. pygeai/man/man1/__init__.py +1 -0
  310. pygeai/man/man1/geai-proxy.1 +246 -0
  311. pygeai/man/man1/geai.1 +2615 -0
  312. pygeai/migration/__init__.py +33 -0
  313. pygeai/migration/strategies.py +603 -0
  314. pygeai/migration/tools.py +180 -0
  315. pygeai/organization/clients.py +246 -18
  316. pygeai/organization/endpoints.py +17 -8
  317. pygeai/organization/limits/__init__.py +0 -0
  318. pygeai/organization/limits/clients.py +281 -0
  319. pygeai/organization/limits/endpoints.py +15 -0
  320. pygeai/organization/limits/managers.py +331 -0
  321. pygeai/organization/limits/mappers.py +21 -0
  322. pygeai/organization/managers.py +537 -0
  323. pygeai/organization/mappers.py +111 -46
  324. pygeai/organization/responses.py +61 -11
  325. pygeai/proxy/__init__.py +0 -0
  326. pygeai/proxy/clients.py +216 -0
  327. pygeai/proxy/config.py +128 -0
  328. pygeai/proxy/managers.py +232 -0
  329. pygeai/proxy/servers.py +304 -0
  330. pygeai/proxy/tool.py +69 -0
  331. pygeai/tests/admin/__init__.py +0 -0
  332. pygeai/tests/admin/test_clients.py +148 -0
  333. pygeai/tests/analytics/__init__.py +0 -0
  334. pygeai/tests/analytics/test_clients.py +86 -0
  335. pygeai/tests/analytics/test_managers.py +94 -0
  336. pygeai/tests/analytics/test_mappers.py +84 -0
  337. pygeai/tests/analytics/test_responses.py +73 -0
  338. pygeai/tests/assistants/rag/__init__.py +0 -0
  339. pygeai/tests/assistants/rag/test_clients.py +346 -0
  340. pygeai/tests/assistants/rag/test_mappers.py +189 -0
  341. pygeai/tests/assistants/rag/test_models.py +292 -0
  342. pygeai/tests/assistants/test_clients.py +176 -80
  343. pygeai/tests/assistants/test_managers.py +198 -0
  344. pygeai/tests/assistants/test_mappers.py +111 -0
  345. pygeai/tests/auth/__init__.py +0 -0
  346. pygeai/tests/auth/test_clients.py +289 -0
  347. pygeai/tests/auth/test_oauth.py +172 -0
  348. pygeai/tests/auth/test_session_logging.py +150 -0
  349. pygeai/tests/chat/__init__.py +0 -0
  350. pygeai/tests/chat/test_clients.py +393 -0
  351. pygeai/tests/chat/test_iris.py +38 -0
  352. pygeai/tests/chat/test_session.py +62 -0
  353. pygeai/tests/chat/test_ui.py +224 -0
  354. pygeai/tests/cli/__init__.py +0 -0
  355. pygeai/tests/cli/commands/__init__.py +0 -0
  356. pygeai/tests/cli/commands/lab/__init__.py +0 -0
  357. pygeai/tests/cli/commands/lab/test_ai_lab.py +786 -0
  358. pygeai/tests/cli/commands/lab/test_common.py +208 -0
  359. pygeai/tests/cli/commands/lab/test_spec.py +246 -0
  360. pygeai/tests/cli/commands/test_assistant.py +202 -0
  361. pygeai/tests/cli/commands/test_chat.py +130 -0
  362. pygeai/tests/cli/commands/test_common.py +350 -0
  363. pygeai/tests/cli/commands/test_embeddings.py +132 -0
  364. pygeai/tests/cli/commands/test_evaluation.py +656 -0
  365. pygeai/tests/cli/commands/test_feedback.py +65 -0
  366. pygeai/tests/cli/commands/test_files.py +161 -0
  367. pygeai/tests/cli/commands/test_gam.py +201 -0
  368. pygeai/tests/cli/commands/test_llm.py +114 -0
  369. pygeai/tests/cli/commands/test_migrate.py +176 -0
  370. pygeai/tests/cli/commands/test_organization.py +276 -0
  371. pygeai/tests/cli/commands/test_rag.py +266 -0
  372. pygeai/tests/cli/commands/test_rerank.py +110 -0
  373. pygeai/tests/cli/commands/test_secrets.py +171 -0
  374. pygeai/tests/cli/commands/test_show_help.py +41 -0
  375. pygeai/tests/cli/commands/test_usage_limits.py +412 -0
  376. pygeai/tests/cli/commands/test_validators.py +160 -0
  377. pygeai/tests/cli/commands/test_version.py +81 -0
  378. pygeai/tests/cli/docker/__init__.py +0 -0
  379. pygeai/tests/cli/test_credentials_flag.py +316 -0
  380. pygeai/tests/cli/test_error_handler.py +225 -0
  381. pygeai/tests/cli/test_geai_driver.py +154 -0
  382. pygeai/tests/cli/test_parsers.py +154 -0
  383. pygeai/tests/core/base/__init__.py +0 -0
  384. pygeai/tests/core/base/data/__init__.py +0 -0
  385. pygeai/tests/core/base/data/mappers.py +117 -0
  386. pygeai/tests/core/base/data/models.py +312 -0
  387. pygeai/tests/core/base/test_mappers.py +569 -0
  388. pygeai/tests/core/base/test_models.py +261 -0
  389. pygeai/tests/core/base/test_responses.py +53 -0
  390. pygeai/tests/core/common/__init__.py +0 -0
  391. pygeai/tests/core/common/data/__init__.py +0 -0
  392. pygeai/tests/core/common/test_config.py +186 -0
  393. pygeai/tests/core/common/test_decorators.py +69 -0
  394. pygeai/tests/core/embeddings/__init__.py +0 -0
  395. pygeai/tests/core/embeddings/test_clients.py +225 -0
  396. pygeai/tests/core/embeddings/test_managers.py +171 -0
  397. pygeai/tests/core/embeddings/test_mappers.py +142 -0
  398. pygeai/tests/core/feedback/__init__.py +0 -0
  399. pygeai/tests/core/feedback/test_clients.py +64 -0
  400. pygeai/tests/core/files/__init__.py +0 -0
  401. pygeai/tests/core/files/test_clients.py +128 -0
  402. pygeai/tests/core/files/test_managers.py +219 -0
  403. pygeai/tests/core/files/test_mappers.py +137 -0
  404. pygeai/tests/core/files/test_models.py +103 -0
  405. pygeai/tests/core/files/test_responses.py +122 -0
  406. pygeai/tests/core/llm/__init__.py +0 -0
  407. pygeai/tests/core/llm/test_clients.py +142 -0
  408. pygeai/tests/core/plugins/__init__.py +0 -0
  409. pygeai/tests/core/plugins/test_clients.py +66 -0
  410. pygeai/tests/core/rerank/__init__.py +0 -0
  411. pygeai/tests/core/rerank/test_clients.py +76 -0
  412. pygeai/tests/core/rerank/test_managers.py +99 -0
  413. pygeai/tests/core/rerank/test_mappers.py +54 -0
  414. pygeai/tests/core/secrets/__init__.py +0 -0
  415. pygeai/tests/core/secrets/test_clients.py +264 -0
  416. pygeai/tests/core/services/__init__.py +0 -0
  417. pygeai/tests/core/services/test_rest.py +273 -0
  418. pygeai/tests/core/test_handlers.py +66 -0
  419. pygeai/tests/core/utils/__init__.py +0 -0
  420. pygeai/tests/core/utils/test_console.py +80 -0
  421. pygeai/tests/dbg/__init__.py +0 -0
  422. pygeai/tests/dbg/test_debugger.py +591 -0
  423. pygeai/tests/evaluation/__init__.py +0 -0
  424. pygeai/tests/evaluation/dataset/__init__.py +0 -0
  425. pygeai/tests/evaluation/dataset/test_clients.py +265 -0
  426. pygeai/tests/evaluation/plan/__init__.py +0 -0
  427. pygeai/tests/evaluation/plan/test_clients.py +195 -0
  428. pygeai/tests/evaluation/result/__init__.py +0 -0
  429. pygeai/tests/evaluation/result/test_clients.py +66 -0
  430. pygeai/tests/gam/__init__.py +0 -0
  431. pygeai/tests/gam/test_clients.py +195 -0
  432. pygeai/tests/health/__init__.py +0 -0
  433. pygeai/tests/health/test_clients.py +41 -0
  434. pygeai/tests/integration/__init__.py +0 -0
  435. pygeai/tests/integration/assistants/__init__.py +0 -0
  436. pygeai/tests/integration/assistants/rag/__init__.py +0 -0
  437. pygeai/tests/integration/assistants/rag/test_create_rag.py +91 -0
  438. pygeai/tests/integration/chat/__init__.py +0 -0
  439. pygeai/tests/integration/chat/test_generate_image.py +158 -0
  440. pygeai/tests/integration/lab/__init__.py +0 -0
  441. pygeai/tests/integration/lab/agents/__init__.py +0 -0
  442. pygeai/tests/integration/lab/agents/test_agents_list.py +106 -0
  443. pygeai/tests/integration/lab/agents/test_create_agent.py +319 -0
  444. pygeai/tests/integration/lab/agents/test_create_sharing_link.py +70 -0
  445. pygeai/tests/integration/lab/agents/test_delete_agent.py +75 -0
  446. pygeai/tests/integration/lab/agents/test_get_agent.py +94 -0
  447. pygeai/tests/integration/lab/agents/test_publish_agent_revision.py +127 -0
  448. pygeai/tests/integration/lab/agents/test_update_agent.py +250 -0
  449. pygeai/tests/integration/lab/processes/__init__.py +0 -0
  450. pygeai/tests/integration/lab/processes/test_create_process.py +345 -0
  451. pygeai/tests/integration/lab/processes/test_create_task.py +211 -0
  452. pygeai/tests/integration/lab/processes/test_delete_process.py +111 -0
  453. pygeai/tests/integration/lab/processes/test_get_process.py +201 -0
  454. pygeai/tests/integration/lab/processes/test_list_process_instances.py +91 -0
  455. pygeai/tests/integration/lab/processes/test_list_processes.py +138 -0
  456. pygeai/tests/integration/lab/processes/test_publish_process_revision.py +232 -0
  457. pygeai/tests/integration/lab/processes/test_update_process.py +289 -0
  458. pygeai/tests/integration/lab/reasoning_strategies/__init__.py +0 -0
  459. pygeai/tests/integration/lab/reasoning_strategies/test_get_reasoning_strategy.py +70 -0
  460. pygeai/tests/integration/lab/reasoning_strategies/test_list_reasoning_strategies.py +93 -0
  461. pygeai/tests/integration/lab/reasoning_strategies/test_update_reasoning_strategy.py +149 -0
  462. pygeai/tests/integration/lab/tools/__init__.py +0 -0
  463. pygeai/tests/integration/lab/tools/test_create_tool.py +288 -0
  464. pygeai/tests/integration/lab/tools/test_delete_tool.py +87 -0
  465. pygeai/tests/integration/lab/tools/test_get_parameter.py +98 -0
  466. pygeai/tests/integration/lab/tools/test_get_tool.py +91 -0
  467. pygeai/tests/integration/lab/tools/test_list_tools.py +106 -0
  468. pygeai/tests/integration/lab/tools/test_publish_tool_revision.py +119 -0
  469. pygeai/tests/integration/lab/tools/test_set_parameter.py +114 -0
  470. pygeai/tests/integration/lab/tools/test_update_tool.py +267 -0
  471. pygeai/tests/lab/__init__.py +0 -0
  472. pygeai/tests/lab/agents/__init__.py +0 -0
  473. pygeai/tests/lab/agents/test_clients.py +481 -0
  474. pygeai/tests/lab/agents/test_mappers.py +440 -0
  475. pygeai/tests/lab/processes/__init__.py +0 -0
  476. pygeai/tests/lab/processes/test_clients.py +1416 -0
  477. pygeai/tests/lab/processes/test_mappers.py +1092 -0
  478. pygeai/tests/lab/spec/__init__.py +0 -0
  479. pygeai/tests/lab/spec/test_loader.py +59 -0
  480. pygeai/tests/lab/spec/test_parsers.py +182 -0
  481. pygeai/tests/lab/strategies/__init__.py +0 -0
  482. pygeai/tests/lab/strategies/test_clients.py +241 -0
  483. pygeai/tests/lab/strategies/test_mappers.py +132 -0
  484. pygeai/tests/lab/test_managers.py +553 -0
  485. pygeai/tests/lab/test_mappers.py +245 -0
  486. pygeai/tests/lab/test_models.py +1154 -0
  487. pygeai/tests/lab/tools/__init__.py +0 -0
  488. pygeai/tests/lab/tools/test_clients.py +521 -0
  489. pygeai/tests/lab/tools/test_mappers.py +198 -0
  490. pygeai/tests/migration/__init__.py +0 -0
  491. pygeai/tests/migration/test_strategies.py +405 -0
  492. pygeai/tests/migration/test_tools.py +159 -0
  493. pygeai/tests/organization/limits/__init__.py +0 -0
  494. pygeai/tests/organization/limits/test_clients.py +567 -0
  495. pygeai/tests/organization/limits/test_managers.py +402 -0
  496. pygeai/tests/organization/test_clients.py +615 -64
  497. pygeai/tests/organization/test_managers.py +424 -0
  498. pygeai/tests/organization/test_mappers.py +153 -0
  499. pygeai/tests/organization/test_responses.py +137 -0
  500. pygeai/tests/proxy/__init__.py +1 -0
  501. pygeai/tests/proxy/test_clients.py +397 -0
  502. pygeai/tests/proxy/test_config.py +171 -0
  503. pygeai/tests/proxy/test_integration.py +305 -0
  504. pygeai/tests/proxy/test_managers.py +312 -0
  505. pygeai/tests/proxy/test_servers.py +387 -0
  506. pygeai/tests/proxy/test_tool.py +176 -0
  507. pygeai/tests/snippets/__init__.py +0 -0
  508. pygeai/tests/snippets/analytics/__init__.py +0 -0
  509. pygeai/tests/snippets/analytics/get_agent_usage_per_user.py +16 -0
  510. pygeai/tests/snippets/analytics/get_agents_created_and_modified.py +11 -0
  511. pygeai/tests/snippets/analytics/get_average_cost_per_request.py +10 -0
  512. pygeai/tests/snippets/analytics/get_overall_error_rate.py +10 -0
  513. pygeai/tests/snippets/analytics/get_top_10_agents_by_requests.py +12 -0
  514. pygeai/tests/snippets/analytics/get_total_active_users.py +10 -0
  515. pygeai/tests/snippets/analytics/get_total_cost.py +10 -0
  516. pygeai/tests/snippets/analytics/get_total_requests_per_day.py +12 -0
  517. pygeai/tests/snippets/analytics/get_total_tokens.py +12 -0
  518. pygeai/tests/snippets/assistants/__init__.py +0 -0
  519. pygeai/tests/snippets/assistants/create_chat_assistant.py +54 -0
  520. pygeai/tests/snippets/assistants/create_text_assistant.py +51 -0
  521. pygeai/tests/snippets/assistants/data_analyst/__init__.py +0 -0
  522. pygeai/tests/snippets/assistants/data_analyst/extend_and_check.py +100 -0
  523. pygeai/tests/snippets/assistants/data_analyst/extend_dataset.py +9 -0
  524. pygeai/tests/snippets/assistants/data_analyst/get_status.py +9 -0
  525. pygeai/tests/snippets/assistants/file_summarizer_assistant.py +149 -0
  526. pygeai/tests/snippets/assistants/get_assistant_data.py +8 -0
  527. pygeai/tests/snippets/assistants/get_assistant_list.py +7 -0
  528. pygeai/tests/snippets/assistants/rag/__init__.py +0 -0
  529. pygeai/tests/snippets/assistants/rag/create_rag_assistant.py +65 -0
  530. pygeai/tests/snippets/assistants/rag/delete_al_documents.py +7 -0
  531. pygeai/tests/snippets/assistants/rag/delete_document.py +10 -0
  532. pygeai/tests/snippets/assistants/rag/delete_rag_assistant.py +8 -0
  533. pygeai/tests/snippets/assistants/rag/get_document.py +10 -0
  534. pygeai/tests/snippets/assistants/rag/get_documents.py +7 -0
  535. pygeai/tests/snippets/assistants/rag/get_rag_assistant_data.py +8 -0
  536. pygeai/tests/snippets/assistants/rag/update_rag_assistant.py +48 -0
  537. pygeai/tests/snippets/assistants/rag/upload_document.py +19 -0
  538. pygeai/tests/snippets/assistants/send_feedback.py +14 -0
  539. pygeai/tests/snippets/assistants/update_chat_assistant.py +63 -0
  540. pygeai/tests/snippets/auth/__init__.py +0 -0
  541. pygeai/tests/snippets/chat/__init__.py +0 -0
  542. pygeai/tests/snippets/chat/cancel_request.py +7 -0
  543. pygeai/tests/snippets/chat/chat_completion.py +28 -0
  544. pygeai/tests/snippets/chat/chat_completion_1.py +40 -0
  545. pygeai/tests/snippets/chat/chat_completion_2.py +60 -0
  546. pygeai/tests/snippets/chat/chat_completion_3.py +27 -0
  547. pygeai/tests/snippets/chat/chat_completion_4.py +67 -0
  548. pygeai/tests/snippets/chat/chat_completion_streaming.py +63 -0
  549. pygeai/tests/snippets/chat/chat_completion_with_reasoning_effort.py +18 -0
  550. pygeai/tests/snippets/chat/get_request_status.py +7 -0
  551. pygeai/tests/snippets/chat/get_response.py +15 -0
  552. pygeai/tests/snippets/chat/get_response_complete_example.py +67 -0
  553. pygeai/tests/snippets/chat/get_response_streaming.py +20 -0
  554. pygeai/tests/snippets/chat/get_response_with_files.py +16 -0
  555. pygeai/tests/snippets/chat/get_response_with_instructions.py +19 -0
  556. pygeai/tests/snippets/chat/get_response_with_metadata.py +24 -0
  557. pygeai/tests/snippets/chat/get_response_with_parallel_tools.py +58 -0
  558. pygeai/tests/snippets/chat/get_response_with_reasoning.py +21 -0
  559. pygeai/tests/snippets/chat/get_response_with_store.py +38 -0
  560. pygeai/tests/snippets/chat/get_response_with_tools.py +36 -0
  561. pygeai/tests/snippets/chat/get_response_with_truncation.py +24 -0
  562. pygeai/tests/snippets/chat/send_chat_request.py +33 -0
  563. pygeai/tests/snippets/dbg/__init__.py +0 -0
  564. pygeai/tests/snippets/dbg/basic_debugging.py +32 -0
  565. pygeai/tests/snippets/dbg/breakpoint_management.py +48 -0
  566. pygeai/tests/snippets/dbg/file_debugging.py +72 -0
  567. pygeai/tests/snippets/dbg/module_debugging.py +61 -0
  568. pygeai/tests/snippets/dbg/stack_navigation.py +45 -0
  569. pygeai/tests/snippets/dbg/stepping_example.py +40 -0
  570. pygeai/tests/snippets/embeddings/__init__.py +0 -0
  571. pygeai/tests/snippets/embeddings/cache_example.py +31 -0
  572. pygeai/tests/snippets/embeddings/cohere_example.py +41 -0
  573. pygeai/tests/snippets/embeddings/generate_embeddings.py +26 -0
  574. pygeai/tests/snippets/embeddings/openai_base64_example.py +27 -0
  575. pygeai/tests/snippets/embeddings/openai_example.py +30 -0
  576. pygeai/tests/snippets/embeddings/similarity_example.py +42 -0
  577. pygeai/tests/snippets/evaluation/__init__.py +0 -0
  578. pygeai/tests/snippets/evaluation/dataset/__init__.py +0 -0
  579. pygeai/tests/snippets/evaluation/dataset/complete_workflow_example.py +195 -0
  580. pygeai/tests/snippets/evaluation/dataset/create_dataset.py +26 -0
  581. pygeai/tests/snippets/evaluation/dataset/create_dataset_from_file.py +11 -0
  582. pygeai/tests/snippets/evaluation/dataset/create_dataset_row.py +17 -0
  583. pygeai/tests/snippets/evaluation/dataset/create_expected_source.py +18 -0
  584. pygeai/tests/snippets/evaluation/dataset/create_filter_variable.py +19 -0
  585. pygeai/tests/snippets/evaluation/dataset/delete_dataset.py +9 -0
  586. pygeai/tests/snippets/evaluation/dataset/delete_dataset_row.py +10 -0
  587. pygeai/tests/snippets/evaluation/dataset/delete_expected_source.py +15 -0
  588. pygeai/tests/snippets/evaluation/dataset/delete_filter_variable.py +15 -0
  589. pygeai/tests/snippets/evaluation/dataset/get_dataset.py +9 -0
  590. pygeai/tests/snippets/evaluation/dataset/get_dataset_row.py +10 -0
  591. pygeai/tests/snippets/evaluation/dataset/get_expected_source.py +15 -0
  592. pygeai/tests/snippets/evaluation/dataset/get_filter_variable.py +15 -0
  593. pygeai/tests/snippets/evaluation/dataset/list_dataset_rows.py +9 -0
  594. pygeai/tests/snippets/evaluation/dataset/list_datasets.py +6 -0
  595. pygeai/tests/snippets/evaluation/dataset/list_expected_sources.py +10 -0
  596. pygeai/tests/snippets/evaluation/dataset/list_filter_variables.py +10 -0
  597. pygeai/tests/snippets/evaluation/dataset/update_dataset.py +15 -0
  598. pygeai/tests/snippets/evaluation/dataset/update_dataset_row.py +20 -0
  599. pygeai/tests/snippets/evaluation/dataset/update_expected_source.py +18 -0
  600. pygeai/tests/snippets/evaluation/dataset/update_filter_variable.py +19 -0
  601. pygeai/tests/snippets/evaluation/dataset/upload_dataset_rows_file.py +10 -0
  602. pygeai/tests/snippets/evaluation/plan/__init__.py +0 -0
  603. pygeai/tests/snippets/evaluation/plan/add_plan_system_metric.py +13 -0
  604. pygeai/tests/snippets/evaluation/plan/complete_workflow_example.py +136 -0
  605. pygeai/tests/snippets/evaluation/plan/create_evaluation_plan.py +24 -0
  606. pygeai/tests/snippets/evaluation/plan/create_rag_evaluation_plan.py +22 -0
  607. pygeai/tests/snippets/evaluation/plan/delete_evaluation_plan.py +9 -0
  608. pygeai/tests/snippets/evaluation/plan/delete_plan_system_metric.py +13 -0
  609. pygeai/tests/snippets/evaluation/plan/execute_evaluation_plan.py +11 -0
  610. pygeai/tests/snippets/evaluation/plan/get_evaluation_plan.py +9 -0
  611. pygeai/tests/snippets/evaluation/plan/get_plan_system_metric.py +13 -0
  612. pygeai/tests/snippets/evaluation/plan/get_system_metric.py +9 -0
  613. pygeai/tests/snippets/evaluation/plan/list_evaluation_plans.py +7 -0
  614. pygeai/tests/snippets/evaluation/plan/list_plan_system_metrics.py +9 -0
  615. pygeai/tests/snippets/evaluation/plan/list_system_metrics.py +7 -0
  616. pygeai/tests/snippets/evaluation/plan/update_evaluation_plan.py +22 -0
  617. pygeai/tests/snippets/evaluation/plan/update_plan_system_metric.py +14 -0
  618. pygeai/tests/snippets/evaluation/result/__init__.py +0 -0
  619. pygeai/tests/snippets/evaluation/result/complete_workflow_example.py +150 -0
  620. pygeai/tests/snippets/evaluation/result/get_evaluation_result.py +26 -0
  621. pygeai/tests/snippets/evaluation/result/list_evaluation_results.py +17 -0
  622. pygeai/tests/snippets/files/__init__.py +0 -0
  623. pygeai/tests/snippets/files/delete_file.py +9 -0
  624. pygeai/tests/snippets/files/get_file_content.py +10 -0
  625. pygeai/tests/snippets/files/get_file_data.py +9 -0
  626. pygeai/tests/snippets/files/get_file_list.py +6 -0
  627. pygeai/tests/snippets/files/upload_file.py +13 -0
  628. pygeai/tests/snippets/gam/__init__.py +0 -0
  629. pygeai/tests/snippets/gam/gam_access_token.py +87 -0
  630. pygeai/tests/snippets/lab/__init__.py +0 -0
  631. pygeai/tests/snippets/lab/agentic_flow_example_1.py +326 -0
  632. pygeai/tests/snippets/lab/agentic_flow_example_2.py +206 -0
  633. pygeai/tests/snippets/lab/agentic_flow_example_3.py +486 -0
  634. pygeai/tests/snippets/lab/agentic_flow_example_4.py +446 -0
  635. pygeai/tests/snippets/lab/agents/__init__.py +0 -0
  636. pygeai/tests/snippets/lab/agents/create_agent.py +48 -0
  637. pygeai/tests/snippets/lab/agents/create_agent_2.py +48 -0
  638. pygeai/tests/snippets/lab/agents/create_agent_edge_case.py +48 -0
  639. pygeai/tests/snippets/lab/agents/create_agent_with_permissions.py +39 -0
  640. pygeai/tests/snippets/lab/agents/create_agent_with_properties.py +46 -0
  641. pygeai/tests/snippets/lab/agents/create_agent_without_instructions.py +48 -0
  642. pygeai/tests/snippets/lab/agents/delete_agent.py +12 -0
  643. pygeai/tests/snippets/lab/agents/get_agent.py +24 -0
  644. pygeai/tests/snippets/lab/agents/get_agent_with_new_fields.py +62 -0
  645. pygeai/tests/snippets/lab/agents/get_sharing_link.py +13 -0
  646. pygeai/tests/snippets/lab/agents/list_agents.py +18 -0
  647. pygeai/tests/snippets/lab/agents/publish_agent_revision.py +12 -0
  648. pygeai/tests/snippets/lab/agents/update_agent.py +50 -0
  649. pygeai/tests/snippets/lab/agents/update_agent_properties.py +50 -0
  650. pygeai/tests/snippets/lab/assistant_to_agent.py +191 -0
  651. pygeai/tests/snippets/lab/crud_ui.py +462 -0
  652. pygeai/tests/snippets/lab/processes/__init__.py +0 -0
  653. pygeai/tests/snippets/lab/processes/create_process.py +24 -0
  654. pygeai/tests/snippets/lab/processes/create_task.py +8 -0
  655. pygeai/tests/snippets/lab/processes/jobs/__init__.py +0 -0
  656. pygeai/tests/snippets/lab/processes/jobs/list_jobs.py +21 -0
  657. pygeai/tests/snippets/lab/processes/kbs/__init__.py +0 -0
  658. pygeai/tests/snippets/lab/processes/kbs/create_kb.py +18 -0
  659. pygeai/tests/snippets/lab/processes/kbs/get_kb.py +26 -0
  660. pygeai/tests/snippets/lab/processes/kbs/list_kbs.py +30 -0
  661. pygeai/tests/snippets/lab/processes/kbs/try_all.py +73 -0
  662. pygeai/tests/snippets/lab/processes/list_processes.py +10 -0
  663. pygeai/tests/snippets/lab/runner_1.py +212 -0
  664. pygeai/tests/snippets/lab/samples/__init__.py +0 -0
  665. pygeai/tests/snippets/lab/samples/summarize_files.py +162 -0
  666. pygeai/tests/snippets/lab/strategies/__init__.py +0 -0
  667. pygeai/tests/snippets/lab/strategies/create_reasoning_strategy.py +22 -0
  668. pygeai/tests/snippets/lab/strategies/get_reasoning_strategy.py +10 -0
  669. pygeai/tests/snippets/lab/strategies/list_reasoning_strategies.py +16 -0
  670. pygeai/tests/snippets/lab/strategies/update_reasoning_strategy.py +26 -0
  671. pygeai/tests/snippets/lab/tools/__init__.py +0 -0
  672. pygeai/tests/snippets/lab/tools/create_tool.py +48 -0
  673. pygeai/tests/snippets/lab/tools/create_tool_edge_case.py +50 -0
  674. pygeai/tests/snippets/lab/tools/delete_tool.py +21 -0
  675. pygeai/tests/snippets/lab/tools/get_parameter.py +21 -0
  676. pygeai/tests/snippets/lab/tools/get_tool.py +22 -0
  677. pygeai/tests/snippets/lab/tools/list_tools.py +23 -0
  678. pygeai/tests/snippets/lab/tools/publish_tool_revision.py +13 -0
  679. pygeai/tests/snippets/lab/tools/set_parameters.py +33 -0
  680. pygeai/tests/snippets/lab/tools/update_tool.py +52 -0
  681. pygeai/tests/snippets/lab/use_cases/__init__.py +0 -0
  682. pygeai/tests/snippets/lab/use_cases/c_code_fixer_agent_flow.py +238 -0
  683. pygeai/tests/snippets/lab/use_cases/create_cli_expert.py +1640 -0
  684. pygeai/tests/snippets/lab/use_cases/create_lab_expert.py +4541 -0
  685. pygeai/tests/snippets/lab/use_cases/create_tool_headless_web_browser.py +133 -0
  686. pygeai/tests/snippets/lab/use_cases/create_web_designer.py +189 -0
  687. pygeai/tests/snippets/lab/use_cases/create_web_reader.py +185 -0
  688. pygeai/tests/snippets/lab/use_cases/file_summarizer_example.py +157 -0
  689. pygeai/tests/snippets/lab/use_cases/file_summarizer_example_2.py +157 -0
  690. pygeai/tests/snippets/lab/use_cases/update_cli_expert.py +1773 -0
  691. pygeai/tests/snippets/lab/use_cases/update_lab_expert.py +4541 -0
  692. pygeai/tests/snippets/lab/use_cases/update_web_designer.py +188 -0
  693. pygeai/tests/snippets/lab/use_cases/update_web_reader.py +195 -0
  694. pygeai/tests/snippets/lab/use_cases/update_web_reader_with_tool.py +210 -0
  695. pygeai/tests/snippets/migrate/__init__.py +45 -0
  696. pygeai/tests/snippets/migrate/agent_migration.py +110 -0
  697. pygeai/tests/snippets/migrate/assistant_migration.py +64 -0
  698. pygeai/tests/snippets/migrate/orchestrator_examples.py +179 -0
  699. pygeai/tests/snippets/migrate/process_migration.py +64 -0
  700. pygeai/tests/snippets/migrate/project_migration.py +42 -0
  701. pygeai/tests/snippets/migrate/tool_migration.py +64 -0
  702. pygeai/tests/snippets/organization/__init__.py +0 -0
  703. pygeai/tests/snippets/organization/add_project_member.py +10 -0
  704. pygeai/tests/snippets/organization/add_project_member_batch.py +44 -0
  705. pygeai/tests/snippets/organization/create_project.py +23 -0
  706. pygeai/tests/snippets/organization/delete_project.py +7 -0
  707. pygeai/tests/snippets/organization/export_request_data.py +7 -0
  708. pygeai/tests/snippets/organization/get_memberships.py +12 -0
  709. pygeai/tests/snippets/organization/get_organization_members.py +6 -0
  710. pygeai/tests/snippets/organization/get_project_data.py +7 -0
  711. pygeai/tests/snippets/organization/get_project_list.py +8 -0
  712. pygeai/tests/snippets/organization/get_project_members.py +6 -0
  713. pygeai/tests/snippets/organization/get_project_memberships.py +12 -0
  714. pygeai/tests/snippets/organization/get_project_roles.py +6 -0
  715. pygeai/tests/snippets/organization/get_project_tokens.py +7 -0
  716. pygeai/tests/snippets/organization/update_project.py +14 -0
  717. pygeai/tests/snippets/rerank/__init__.py +0 -0
  718. pygeai/tests/snippets/rerank/rerank_chunks.py +19 -0
  719. pygeai/tests/snippets/secrets/__init__.py +0 -0
  720. pygeai/tests/snippets/usage_limit/__init__.py +0 -0
  721. pygeai/tests/snippets/usage_limit/delete_usage_limit.py +16 -0
  722. pygeai/tests/snippets/usage_limit/get_all_usage_limit_from_organization.py +12 -0
  723. pygeai/tests/snippets/usage_limit/get_usage_limit_from_organization.py +11 -0
  724. pygeai/tests/snippets/usage_limit/get_usage_limit_from_project.py +13 -0
  725. pygeai/tests/snippets/usage_limit/set_usage_limit_organization.py +22 -0
  726. pygeai/tests/snippets/usage_limit/set_usage_limit_project.py +23 -0
  727. pygeai/tests/snippets/usage_limit/update_usage_limit_organization.py +23 -0
  728. pygeai/tests/snippets/usage_limit/update_usage_limit_project.py +24 -0
  729. pygeai/vendor/a2a/__init__.py +1 -0
  730. pygeai/vendor/a2a/auth/__init__.py +0 -0
  731. pygeai/vendor/a2a/auth/user.py +31 -0
  732. pygeai/vendor/a2a/client/__init__.py +19 -0
  733. pygeai/vendor/a2a/client/client.py +425 -0
  734. pygeai/vendor/a2a/client/errors.py +33 -0
  735. pygeai/vendor/a2a/client/helpers.py +22 -0
  736. pygeai/vendor/a2a/py.typed +0 -0
  737. pygeai/vendor/a2a/server/__init__.py +1 -0
  738. pygeai/vendor/a2a/server/agent_execution/__init__.py +18 -0
  739. pygeai/vendor/a2a/server/agent_execution/agent_executor.py +44 -0
  740. pygeai/vendor/a2a/server/agent_execution/context.py +155 -0
  741. pygeai/vendor/a2a/server/agent_execution/request_context_builder.py +20 -0
  742. pygeai/vendor/a2a/server/agent_execution/simple_request_context_builder.py +77 -0
  743. pygeai/vendor/a2a/server/apps/__init__.py +16 -0
  744. pygeai/vendor/a2a/server/apps/jsonrpc/__init__.py +16 -0
  745. pygeai/vendor/a2a/server/apps/jsonrpc/fastapi_app.py +88 -0
  746. pygeai/vendor/a2a/server/apps/jsonrpc/jsonrpc_app.py +426 -0
  747. pygeai/vendor/a2a/server/apps/jsonrpc/starlette_app.py +123 -0
  748. pygeai/vendor/a2a/server/context.py +23 -0
  749. pygeai/vendor/a2a/server/events/__init__.py +21 -0
  750. pygeai/vendor/a2a/server/events/event_consumer.py +149 -0
  751. pygeai/vendor/a2a/server/events/event_queue.py +156 -0
  752. pygeai/vendor/a2a/server/events/in_memory_queue_manager.py +85 -0
  753. pygeai/vendor/a2a/server/events/queue_manager.py +35 -0
  754. pygeai/vendor/a2a/server/request_handlers/__init__.py +20 -0
  755. pygeai/vendor/a2a/server/request_handlers/default_request_handler.py +435 -0
  756. pygeai/vendor/a2a/server/request_handlers/jsonrpc_handler.py +327 -0
  757. pygeai/vendor/a2a/server/request_handlers/request_handler.py +161 -0
  758. pygeai/vendor/a2a/server/request_handlers/response_helpers.py +133 -0
  759. pygeai/vendor/a2a/server/tasks/__init__.py +20 -0
  760. pygeai/vendor/a2a/server/tasks/inmemory_push_notifier.py +62 -0
  761. pygeai/vendor/a2a/server/tasks/inmemory_task_store.py +51 -0
  762. pygeai/vendor/a2a/server/tasks/push_notifier.py +25 -0
  763. pygeai/vendor/a2a/server/tasks/result_aggregator.py +151 -0
  764. pygeai/vendor/a2a/server/tasks/task_manager.py +253 -0
  765. pygeai/vendor/a2a/server/tasks/task_store.py +22 -0
  766. pygeai/vendor/a2a/server/tasks/task_updater.py +155 -0
  767. pygeai/vendor/a2a/types.py +1624 -0
  768. pygeai/vendor/a2a/utils/__init__.py +40 -0
  769. pygeai/vendor/a2a/utils/artifact.py +72 -0
  770. pygeai/vendor/a2a/utils/errors.py +69 -0
  771. pygeai/vendor/a2a/utils/helpers.py +176 -0
  772. pygeai/vendor/a2a/utils/message.py +83 -0
  773. pygeai/vendor/a2a/utils/task.py +57 -0
  774. pygeai/vendor/a2a/utils/telemetry.py +299 -0
  775. pygeai-0.6.0b15.dist-info/METADATA +205 -0
  776. pygeai-0.6.0b15.dist-info/RECORD +799 -0
  777. {pygeai-0.1.6.dist-info → pygeai-0.6.0b15.dist-info}/WHEEL +1 -1
  778. pygeai-0.6.0b15.dist-info/entry_points.txt +5 -0
  779. {pygeai-0.1.6.dist-info → pygeai-0.6.0b15.dist-info/licenses}/LICENSE +13 -1
  780. {pygeai-0.1.6.dist-info → pygeai-0.6.0b15.dist-info}/top_level.txt +0 -1
  781. docs/source/conf.py +0 -45
  782. pygeai/core/clients.py +0 -240
  783. pygeai/tests/core/test_clients.py +0 -49
  784. pygeai-0.1.6.dist-info/METADATA +0 -92
  785. pygeai-0.1.6.dist-info/RECORD +0 -65
  786. pygeai-0.1.6.dist-info/SOURCES.sync-conflict-20241223-145950-3QD4F42.txt +0 -41
  787. pygeai-0.1.6.dist-info/entry_points.txt +0 -2
  788. /pygeai/{agent → analytics}/__init__.py +0 -0
pygeai/core/models.py ADDED
@@ -0,0 +1,799 @@
1
+ from datetime import datetime
2
+
3
+ from pydantic import Field, field_validator, model_validator
4
+ from typing import Optional, Literal, Any, List, Union, Iterator
5
+
6
+ from pygeai.core import CustomBaseModel
7
+
8
+ """
9
+ In this modeling, the model_validate method from pydantic is dependant on the API REST responses from
10
+ the GEAI platform.
11
+ It's not expected that the user creates a dictionary to populate the models. If they wish to do so, they
12
+ should rely on the GEAI documentation to structure the dictionaries as API responses.
13
+ """
14
+
15
+
16
+ class AssistantRevisionMetadata(CustomBaseModel):
17
+ """
18
+ {
19
+ "key": "string",
20
+ "type": "string",
21
+ "value": "string"
22
+ }
23
+ """
24
+ key: str = Field(..., alias="key")
25
+ type: str = Field(..., alias="type")
26
+ value: str = Field(..., alias="value")
27
+
28
+ def to_dict(self):
29
+ return self.model_dump(by_alias=True, exclude_none=True)
30
+
31
+ def __str__(self):
32
+ return str(self.to_dict())
33
+
34
+
35
+ class AssistantRevision(CustomBaseModel):
36
+ """
37
+ {
38
+ "metadata": [
39
+ ...
40
+ ],
41
+ "modelId": "string",
42
+ "modelName": "string",
43
+ "prompt": "string",
44
+ "providerName": "string",
45
+ "revisionDescription": "string",
46
+ "revisionId": "string",
47
+ "revisionName": "string",
48
+ "timestamp": "timestamp"
49
+ }
50
+ """
51
+ metadata: Optional[list[AssistantRevisionMetadata]] = Field(default_factory=list, alias="metadata")
52
+ model_id: Optional[str] = Field(None, alias="modelId")
53
+ model_name: Optional[str] = Field(None, alias="modelName")
54
+ prompt: Optional[str] = Field(None, alias="prompt")
55
+ provider_name: Optional[str] = Field(None, alias="providerName")
56
+ revision_description: Optional[str] = Field(None, alias="revisionDescription")
57
+ revision_id: Optional[int] = Field(None, alias="revisionId")
58
+ revision_name: str = Field(..., alias="revisionName")
59
+ timestamp: Optional[datetime] = Field(None, alias="timestamp")
60
+
61
+ class Config:
62
+ protected_namespaces = ()
63
+
64
+ @field_validator("timestamp")
65
+ @classmethod
66
+ def validate_timestamp(cls, value: Optional[datetime]) -> Optional[datetime]:
67
+ if value is None:
68
+ return value
69
+ if isinstance(value, str):
70
+ return datetime.fromisoformat(value.replace("Z", "+00:00"))
71
+ return value
72
+
73
+ @field_validator("metadata", mode="before")
74
+ @classmethod
75
+ def normalize_metadata(cls, value):
76
+ if isinstance(value, list):
77
+ return [AssistantRevisionMetadata.model_validate(item) if isinstance(item, dict) else item for item in
78
+ value]
79
+ return value
80
+
81
+ def to_dict(self):
82
+ return self.model_dump(by_alias=True, exclude_none=True)
83
+
84
+ def __str__(self):
85
+ return str(self.to_dict())
86
+
87
+
88
+ class AssistantIntent(CustomBaseModel):
89
+ """
90
+ DEPRECATED: It's ignored in the modeling of the responses, since it's added complexity
91
+ that doesn't provide any benefit. From assistant, there will be a direct relationship
92
+ to revisions.
93
+ {
94
+ "assistantIntentDefaultRevision": "number",
95
+ "assistantIntentDescription": "string",
96
+ "assistantIntentId": "string",
97
+ "assistantIntentName": "string",
98
+ "revisions": [
99
+ ...
100
+ ]
101
+ }
102
+ """
103
+ default_revision: float
104
+ description: str
105
+ id: str
106
+ name: str
107
+ revisions: Optional[list[AssistantRevision]] = []
108
+
109
+ def __str__(self):
110
+ intent = {
111
+ "assistantIntentDefaultRevision": self.default_revision,
112
+ "assistantIntentDescription": self.description,
113
+ "assistantIntentId": self.id,
114
+ "assistantIntentName": self.name
115
+ }
116
+ if any(self.revisions):
117
+ intent["revisions"] = self.revisions
118
+
119
+ return str(intent)
120
+
121
+
122
+ class Organization(CustomBaseModel):
123
+ id: Optional[str] = Field(None, alias="organizationId")
124
+ name: Optional[str] = Field(None, alias="organizationName")
125
+
126
+ def to_dict(self):
127
+ return self.model_dump(by_alias=True, exclude_none=True)
128
+
129
+ def __str__(self):
130
+ organization = self.to_dict()
131
+ return str(organization)
132
+
133
+
134
+ class SearchProfile(CustomBaseModel):
135
+ """
136
+ {
137
+ "name": "string",
138
+ "description": "string"
139
+ }
140
+ """
141
+ name: str = Field(..., alias="name")
142
+ description: str = Field(..., alias="description")
143
+
144
+ def to_dict(self):
145
+ return self.model_dump(by_alias=True, exclude_none=True)
146
+
147
+ def __str__(self):
148
+ search_profile = self.to_dict()
149
+ return str(search_profile)
150
+
151
+
152
+ class ProjectToken(CustomBaseModel):
153
+ """
154
+ {
155
+ "description": "string",
156
+ "id": "string",
157
+ "name": "string",
158
+ "status": "string", /* Active, Blocked */
159
+ "timestamp": "timestamp"
160
+ }
161
+ """
162
+ description: Optional[str] = Field(None, alias="description")
163
+ token_id: str = Field(..., alias="id")
164
+ name: str = Field(..., alias="name")
165
+ status: str = Field(..., alias="status")
166
+ timestamp: datetime = Field(..., alias="timestamp")
167
+
168
+ def to_dict(self):
169
+ return self.model_dump(by_alias=True, exclude_none=True)
170
+
171
+ def __str__(self):
172
+ token = self.to_dict()
173
+ return str(token)
174
+
175
+
176
+ class UsageLimit(CustomBaseModel):
177
+ """
178
+ "hardLimit": "number", // Upper usage limit
179
+ "id": "string", // Usage limit ID
180
+ "relatedEntityName": "string", // Name of the related entity
181
+ "remainingUsage": "number", // Remaining usage
182
+ "renewalStatus": "string", // Renewal status (Renewable, NonRenewable)
183
+ "softLimit": "number", // Lower usage limit
184
+ "status": "integer", // Status (1: Active, 2: Expired, 3: Empty, 4: Cancelled)
185
+ "subscriptionType": "string", // Subscription type (Freemium, Daily, Weekly, Monthly)
186
+ "usageUnit": "string", // Usage unit (Requests, Cost)
187
+ "usedAmount": "number", // Amount used (decimal or scientific notation)
188
+ "validFrom": "timestamp", // Start date of the usage limit
189
+ "validUntil": "timestamp" // Expiration or renewal date
190
+ """
191
+ hard_limit: Optional[float] = Field(None, alias="hardLimit")
192
+ id: Optional[str] = Field(None, alias="id")
193
+ related_entity_name: Optional[str] = Field(None, alias="relatedEntityName")
194
+ remaining_usage: Optional[float] = Field(None, alias="remainingUsage")
195
+ renewal_status: Optional[Literal["Renewable", "NonRenewable"]] = Field(None, alias="renewalStatus")
196
+ soft_limit: Optional[float] = Field(None, alias="softLimit")
197
+ status: Optional[Literal[1, 2, 3, 4]] = Field(None, alias="status")
198
+ subscription_type: Optional[Literal["Freemium", "Daily", "Weekly", "Monthly"]] = Field(None, alias="subscriptionType")
199
+ usage_unit: Optional[Literal["Requests", "Cost"]] = Field(None, alias="usageUnit")
200
+ used_amount: Optional[float] = Field(None, alias="usedAmount")
201
+ valid_from: Optional[datetime] = Field(None, alias="validFrom")
202
+ valid_until: Optional[datetime] = Field(None, alias="validUntil")
203
+
204
+ def to_dict(self):
205
+ return self.model_dump(by_alias=True, exclude_none=True)
206
+
207
+ def __str__(self):
208
+ usage_limit = self.to_dict()
209
+ return str(usage_limit)
210
+
211
+
212
+ class Project(CustomBaseModel):
213
+ """
214
+ {
215
+ "projectActive": "boolean",
216
+ "projectDescription": "string",
217
+ "projectId": "string",
218
+ "projectName": "string",
219
+ "projectStatus": "integer", /* 0:Active, 2:Hidden */
220
+ }
221
+ """
222
+ organization: Optional[Organization] = None
223
+ active: Optional[bool] = Field(None, alias="projectActive")
224
+ description: Optional[str] = Field(None, alias="projectDescription")
225
+ id: Optional[str] = Field(None, alias="projectId")
226
+ name: Optional[str] = Field(None, alias="projectName")
227
+ email: Optional[str] = None
228
+ status: Optional[int] = Field(None, alias="projectStatus")
229
+ tokens: Optional[list[ProjectToken]] = []
230
+ usage_limit: Optional[UsageLimit] = None
231
+
232
+ @classmethod
233
+ def model_validate(cls, data: dict):
234
+ organization_data = {
235
+ "organizationId": data.get("organizationId"),
236
+ "organizationName": data.get("organizationName"),
237
+ }
238
+ organization = Organization.model_validate(organization_data) if any(value is not None for value in organization_data.values()) else None
239
+ return cls(organization=organization, **data)
240
+
241
+ def to_dict(self):
242
+ return self.model_dump(by_alias=True, exclude_none=True)
243
+
244
+ def __str__(self):
245
+ return str(self.to_dict())
246
+
247
+
248
+ class RequestItem(CustomBaseModel):
249
+ """
250
+ Represents a request item with metadata about an API interaction.
251
+ Follows a JSON schema with camelCase aliases for external compatibility.
252
+ """
253
+ api_token: str = Field(..., alias="apiToken")
254
+ assistant: str = Field(..., alias="assistant")
255
+ cost: float = Field(..., alias="cost")
256
+ elapsed_time_ms: int = Field(..., alias="elapsedTimeMs")
257
+ end_timestamp: datetime = Field(..., alias="endTimestamp")
258
+ feedback: Optional[str] = Field(None, alias="feedback")
259
+ intent: Optional[str] = Field(None, alias="intent")
260
+ module: str = Field(..., alias="module")
261
+ prompt: Optional[str] = Field(None, alias="prompt")
262
+ output: Optional[str] = Field(None, alias="output")
263
+ input_text: Optional[str] = Field(None, alias="inputText")
264
+ rag_sources_consulted: Optional[str] = Field(None, alias="ragSourcesConsulted")
265
+ session_id: str = Field(..., alias="sessionId")
266
+ start_timestamp: datetime = Field(..., alias="startTimestamp")
267
+ status: str = Field(..., alias="status")
268
+ timestamp: datetime = Field(..., alias="timestamp")
269
+
270
+ @model_validator(mode="after")
271
+ def validate_status(self):
272
+ valid_statuses = {"succeeded", "failed", "pending"}
273
+ if self.status not in valid_statuses:
274
+ raise ValueError(f"Status must be one of {valid_statuses}")
275
+ return self
276
+
277
+ def to_dict(self):
278
+ return self.model_dump(by_alias=True, exclude_none=True)
279
+
280
+ def __str__(self):
281
+ return str(self.to_dict())
282
+
283
+
284
+ class GuardrailSettings(CustomBaseModel):
285
+ llm_output: Optional[bool] = Field(False, alias="llmOutputGuardrail")
286
+ input_moderation: Optional[bool] = Field(False, alias="inputModerationGuardrail")
287
+ prompt_injection: Optional[bool] = Field(False, alias="promptInjectionGuardrail")
288
+
289
+ def to_dict(self):
290
+ return self.model_dump(by_alias=True, exclude_none=True)
291
+
292
+ def __str__(self):
293
+ settings = self.to_dict()
294
+ return str(settings)
295
+
296
+
297
+ class LlmSettings(CustomBaseModel):
298
+ """
299
+ "llmSettings": {
300
+ "providerName": "string",
301
+ "modelName": "string",
302
+ "temperature": "decimal",
303
+ "maxTokens": "integer",
304
+ "uploadFiles": "boolean",
305
+ "llmOutputGuardrail": "boolean",
306
+ "inputModerationGuardrail": "boolean",
307
+ "promptInjectionGuardrail": "boolean"
308
+ }
309
+ """
310
+ provider_name: Optional[str] = Field(None, alias="providerName")
311
+ model_name: Optional[str] = Field(None, alias="modelName")
312
+ temperature: Optional[float] = Field(None, alias="temperature")
313
+ max_tokens: Optional[int] = Field(None, alias="maxTokens")
314
+ frequency_penalty: Optional[float] = Field(None, alias="frequencyPenalty")
315
+ presence_penalty: Optional[float] = Field(None, alias="presencePenalty")
316
+ upload_files: Optional[bool] = Field(None, alias="uploadFiles")
317
+ guardrail_settings: Optional[GuardrailSettings] = Field(None, alias="guardrail_settings")
318
+ n: Optional[int] = None
319
+ stream: Optional[bool] = Field(None, alias="stream")
320
+ top_p: Optional[float] = Field(None, alias="topP")
321
+ type: Optional[str] = Field(None, alias="type")
322
+ cache: Optional[bool] = Field(None, alias="cache")
323
+ verbose: Optional[bool] = Field(None, alias="verbose")
324
+
325
+ class Config:
326
+ protected_namespaces = ()
327
+
328
+ @classmethod
329
+ def model_validate(cls, data: dict):
330
+ guardrail_data = {
331
+ "llmOutputGuardrail": data.get("llmOutputGuardrail"),
332
+ "inputModerationGuardrail": data.get("inputModerationGuardrail"),
333
+ "promptInjectionGuardrail": data.get("promptInjectionGuardrail")
334
+ }
335
+ guardrail_settings = GuardrailSettings.model_validate(guardrail_data) \
336
+ if any(value is not None for value in guardrail_data.values()) else None
337
+ return cls(guardrail_settings=guardrail_settings, **data)
338
+
339
+ def to_dict(self):
340
+ llm_data = self.model_dump(by_alias=True, exclude_none=True)
341
+ if 'guardrail_settings' in llm_data:
342
+ del llm_data["guardrail_settings"]
343
+ if self.guardrail_settings:
344
+ llm_data.update({
345
+ "llmOutputGuardrail": self.guardrail_settings.llm_output,
346
+ "inputModerationGuardrail": self.guardrail_settings.input_moderation,
347
+ "promptInjectionGuardrail": self.guardrail_settings.prompt_injection
348
+ })
349
+ return {k: v for k, v in llm_data.items() if v is not None}
350
+
351
+ def __str__(self):
352
+ llm_setting = self.to_dict()
353
+ return str(llm_setting)
354
+
355
+
356
+ class WelcomeDataFeature(CustomBaseModel):
357
+ """
358
+ {
359
+ "title": "string",
360
+ "description": "string"
361
+ }
362
+ """
363
+ title: str = Field(..., alias="title")
364
+ description: str = Field(..., alias="description")
365
+
366
+ def to_dict(self):
367
+ return self.model_dump(by_alias=True, exclude_none=True)
368
+
369
+ def __str__(self):
370
+ feature = self.to_dict()
371
+ return str(feature)
372
+
373
+
374
+ class WelcomeDataExamplePrompt(CustomBaseModel):
375
+ """
376
+ {
377
+ "title": "string",
378
+ "description": "string",
379
+ "promptText": "string"
380
+ }
381
+ """
382
+ title: str = Field(..., alias="title")
383
+ description: str = Field(..., alias="description")
384
+ prompt_text: str = Field(..., alias="promptText")
385
+
386
+ def to_dict(self):
387
+ return self.model_dump(by_alias=True, exclude_none=True)
388
+
389
+ def __str__(self):
390
+ example_prompt = self.to_dict()
391
+ return str(example_prompt)
392
+
393
+
394
+ class WelcomeData(CustomBaseModel):
395
+ """
396
+ "title": "string",
397
+ "description": "string",
398
+ "features": [
399
+ ],
400
+ "examplesPrompt": [
401
+ ]
402
+ }
403
+ """
404
+ title: Optional[str] = Field(None, alias="title")
405
+ description: Optional[str] = Field(None, alias="description")
406
+ features: Optional[list[WelcomeDataFeature]] = Field([], alias="features")
407
+ examples_prompt: Optional[list[WelcomeDataExamplePrompt]] = Field([], alias="examplesPrompt")
408
+
409
+ def to_dict(self):
410
+ return self.model_dump(by_alias=True, exclude_none=True)
411
+
412
+ def __str__(self):
413
+ welcome_data = self.to_dict()
414
+ return str(welcome_data)
415
+
416
+
417
+ class ChatMessage(CustomBaseModel):
418
+ role: str = Field(..., alias="role")
419
+ content: Union[str, List[Any]] = Field(..., alias="content")
420
+ function_call: Optional[Any] = Field(None, alias="function_call")
421
+ refusal: Optional[Any] = Field(None, alias="refusal")
422
+ tool_calls: Optional[Any] = Field(None, alias="tool_calls")
423
+ annotations: Optional[List[dict]] = Field(None, alias="annotations")
424
+
425
+ def to_dict(self):
426
+ return self.model_dump(by_alias=True, exclude_none=True)
427
+
428
+ def __str__(self):
429
+ message = self.to_dict()
430
+ return str(message)
431
+
432
+
433
+ class ChatMessageList(CustomBaseModel):
434
+ messages: List[ChatMessage] = Field(..., alias="messages", description="List of chat messages")
435
+
436
+ @field_validator("messages", mode="before")
437
+ @classmethod
438
+ def normalize_messages(cls, value):
439
+ if isinstance(value, list):
440
+ return [ChatMessage.model_validate(item) if isinstance(item, dict) else item for item in value]
441
+ return value
442
+
443
+ def to_list(self):
444
+ return [message.to_dict() for message in self.messages]
445
+
446
+ def __getitem__(self, index: int) -> ChatMessage:
447
+ if self.messages is None:
448
+ raise IndexError("ChatMessageList is empty")
449
+ return self.messages[index]
450
+
451
+ def __len__(self) -> int:
452
+ return len(self.messages) if self.messages else 0
453
+
454
+ def __iter__(self) -> Iterator[ChatMessage]:
455
+ """Make ChatMessageList iterable over its messages."""
456
+ if self.messages is None:
457
+ return iter([])
458
+ return iter(self.messages)
459
+
460
+ def append(self, item: ChatMessage) -> None:
461
+ """Append a ChatMessage instance to the messages list."""
462
+ if self.messages is None:
463
+ self.messages = []
464
+ self.messages.append(item)
465
+
466
+ def __str__(self):
467
+ return str(self.to_dict())
468
+
469
+
470
+ class ChatVariable(CustomBaseModel):
471
+ key: str = Field(..., alias="key")
472
+ value: str = Field(..., alias="value")
473
+
474
+ def to_dict(self):
475
+ return self.model_dump(by_alias=True, exclude_none=True)
476
+
477
+ def __str__(self):
478
+ variable = self.to_dict()
479
+ return str(variable)
480
+
481
+
482
+ class ChatVariableList(CustomBaseModel):
483
+ variables: List[ChatVariable] = Field(..., alias="variables", description="List of chat variables")
484
+
485
+ @field_validator("variables", mode="before")
486
+ @classmethod
487
+ def normalize_variables(cls, value):
488
+ if isinstance(value, list):
489
+ return [ChatVariable.model_validate(item) if isinstance(item, dict) else item for item in value]
490
+ return value
491
+
492
+ def to_list(self):
493
+ return [variable.to_dict() for variable in self.variables]
494
+
495
+ def __getitem__(self, index: int) -> ChatVariable:
496
+ if self.variables is None:
497
+ raise IndexError("ChatVariableList is empty")
498
+ return self.variables[index]
499
+
500
+ def __len__(self) -> int:
501
+ return len(self.variables) if self.variables else 0
502
+
503
+ def __iter__(self) -> Iterator[ChatVariable]:
504
+ """Make ChatVariableList iterable over its variables."""
505
+ if self.variables is None:
506
+ return iter([])
507
+ return iter(self.variables)
508
+
509
+ def append(self, item: ChatVariable) -> None:
510
+ """Append a ChatVariable instance to the variables list."""
511
+ if self.variables is None:
512
+ self.variables = []
513
+ self.variables.append(item)
514
+
515
+ def __str__(self):
516
+ return str(self.to_dict())
517
+
518
+
519
+ class ChatTool(CustomBaseModel):
520
+ name: str = Field(..., alias="name", max_length=64, pattern=r'^[a-zA-Z0-9_-]+$')
521
+ description: Optional[str] = Field(None, alias="description")
522
+ parameters: Optional[dict] = Field(None, alias="parameters")
523
+ strict: Optional[bool] = Field(None, alias="strict")
524
+
525
+ def to_dict(self):
526
+ return self.model_dump(by_alias=True, exclude_none=True)
527
+
528
+ def __str__(self):
529
+ tool = self.to_dict()
530
+ return str(tool)
531
+
532
+
533
+ class ChatToolList(CustomBaseModel):
534
+ tools: List[ChatTool] = Field(..., alias="tools", description="List of chat tools", max_items=128)
535
+
536
+ @field_validator("tools", mode="before")
537
+ @classmethod
538
+ def normalize_tools(cls, value):
539
+ if isinstance(value, list):
540
+ return [ChatTool.model_validate(item) if isinstance(item, dict) else item for item in value]
541
+ return value
542
+
543
+ def to_list(self):
544
+ return [tool.to_dict() for tool in self.tools]
545
+
546
+ def __getitem__(self, index: int) -> ChatTool:
547
+ if self.tools is None:
548
+ raise IndexError("ChatToolList is empty")
549
+ return self.tools[index]
550
+
551
+ def __len__(self) -> int:
552
+ return len(self.tools) if self.tools else 0
553
+
554
+ def __iter__(self) -> Iterator[ChatTool]:
555
+ """Make ChatToolList iterable over its tools."""
556
+ if self.tools is None:
557
+ return iter([])
558
+ return iter(self.tools)
559
+
560
+ def append(self, item: ChatTool) -> None:
561
+ """Append a ChatTool instance to the tools list."""
562
+ if self.tools is None:
563
+ self.tools = []
564
+ self.tools.append(item)
565
+
566
+ def __str__(self):
567
+ return str(self.to_list())
568
+
569
+
570
+ class ToolChoiceFunction(CustomBaseModel):
571
+ type: Optional[Literal["function"]] = Field("function", alias="type")
572
+ name: str = Field(..., alias="name")
573
+
574
+ @field_validator("type")
575
+ def validate_type(cls, v):
576
+ if v != "function":
577
+ raise ValueError("Type must be 'function'")
578
+ return v
579
+
580
+ def to_dict(self):
581
+ return self.model_dump(by_alias=True, exclude_none=True)
582
+
583
+ def __str__(self):
584
+ function = self.to_dict()
585
+ return str(function)
586
+
587
+
588
+ class ToolChoiceObject(CustomBaseModel):
589
+ function: ToolChoiceFunction = Field(..., alias="function")
590
+
591
+ def to_dict(self):
592
+ return self.model_dump(by_alias=True, exclude_none=True)
593
+
594
+ def __str__(self):
595
+ obj = self.to_dict()
596
+ return str(obj)
597
+
598
+
599
+ class ToolChoice(CustomBaseModel):
600
+ value: Union[str, ToolChoiceObject] = Field(..., alias="tool_choice")
601
+
602
+ @field_validator("value")
603
+ def validate_string_value(cls, v):
604
+ if isinstance(v, str) and v not in ["none", "auto", "required"]:
605
+ raise ValueError("String tool_choice must be 'none', 'auto', or 'required'")
606
+ return v
607
+
608
+ def to_dict(self):
609
+ return self.model_dump(by_alias=True, exclude_none=True)
610
+
611
+ def __str__(self):
612
+ choice = self.to_dict()
613
+ return str(choice)
614
+
615
+
616
+ class Assistant(CustomBaseModel):
617
+ id: Optional[str] = Field(None, alias="assistantId")
618
+ name: Optional[str] = Field(None, alias="assistantName")
619
+ description: Optional[str] = Field(None, alias="assistantDescription")
620
+ status: Optional[Literal[1, 2]] = Field(1, alias="assistantStatus")
621
+ priority: Optional[int] = Field(0, alias="assistantPriority")
622
+ type: Optional[str] = Field(None, alias="type")
623
+ prompt: Optional[str] = Field(None, alias="prompt")
624
+ default_revision: Optional[float] = Field(None, alias="assistantIntentDefaultRevision")
625
+ intent_description: Optional[str] = Field(None, alias="assistantIntentDescription")
626
+ intent_id: Optional[str] = Field(None, alias="assistantIntentId")
627
+ intent_name: Optional[str] = Field(None, alias="assistantIntentName")
628
+ revisions: Optional[List["AssistantRevision"]] = Field([], alias="revisions")
629
+ project: Optional["Project"] = Field(None, alias="project")
630
+ welcome_data: Optional["WelcomeData"] = Field(None, alias="welcomeData")
631
+ llm_settings: Optional["LlmSettings"] = Field(None, alias="llmSettings")
632
+
633
+ @field_validator("revisions", mode="before")
634
+ @classmethod
635
+ def normalize_revisions(cls, value):
636
+ if isinstance(value, list):
637
+ return [AssistantRevision.model_validate(item) if isinstance(item, dict) else item for item in value]
638
+ return value
639
+
640
+ @field_validator("welcome_data", mode="before")
641
+ @classmethod
642
+ def normalize_welcome_data(cls, value):
643
+ if isinstance(value, dict):
644
+ return WelcomeData.model_validate(value)
645
+ return value
646
+
647
+ @field_validator("llm_settings", mode="before")
648
+ @classmethod
649
+ def normalize_llm_settings(cls, value):
650
+ if isinstance(value, dict):
651
+ return LlmSettings.model_validate(value)
652
+ return value
653
+
654
+ def to_dict(self):
655
+ result = {
656
+ "assistantId": self.id,
657
+ "assistantName": self.name,
658
+ "assistantDescription": self.description,
659
+ "assistantStatus": self.status,
660
+ "assistantPriority": self.priority,
661
+ "type": self.type,
662
+ "prompt": self.prompt,
663
+ "assistantIntentDefaultRevision": self.default_revision,
664
+ "assistantIntentDescription": self.intent_description,
665
+ "assistantIntentId": self.intent_id,
666
+ "assistantIntentName": self.intent_name,
667
+ "revisions": [revision.to_dict() for revision in self.revisions] if self.revisions else None,
668
+ "project": self.project.to_dict() if self.project else None,
669
+ "welcomeData": self.welcome_data.to_dict() if self.welcome_data else None,
670
+ "llmSettings": self.llm_settings.to_dict() if self.llm_settings else None
671
+ }
672
+ return {k: v for k, v in result.items() if v is not None}
673
+
674
+ def __str__(self):
675
+ assistant = self.to_dict()
676
+ return str(assistant)
677
+
678
+
679
+ class TextAssistant(Assistant):
680
+ type: Literal["text"] = "text"
681
+
682
+
683
+ class ChatAssistant(Assistant):
684
+ type: Literal["chat"] = "chat"
685
+
686
+
687
+ class DataAnalystAssistant(Assistant):
688
+ pass
689
+
690
+
691
+ class ChatWithDataAssistant(Assistant):
692
+ type: Literal["ChatWithData"] = "ChatWithData"
693
+
694
+
695
+ class Role(CustomBaseModel):
696
+ """
697
+ {
698
+ "id": "string",
699
+ "name": "string",
700
+ "externalId": "string",
701
+ "type": "string",
702
+ "origin": "string"
703
+ }
704
+ """
705
+ id: str = Field(..., alias="id")
706
+ name: str = Field(..., alias="name")
707
+ external_id: Optional[str] = Field(None, alias="externalId")
708
+ type: Optional[str] = Field(None, alias="type")
709
+ origin: Optional[str] = Field(None, alias="origin")
710
+
711
+ def to_dict(self):
712
+ return self.model_dump(by_alias=True, exclude_none=True)
713
+
714
+ def __str__(self):
715
+ return str(self.to_dict())
716
+
717
+
718
+ class Member(CustomBaseModel):
719
+ """
720
+ {
721
+ "email": "string",
722
+ "roles": [...]
723
+ }
724
+ """
725
+ email: str = Field(..., alias="email")
726
+ roles: Optional[List[Role]] = Field(default_factory=list, alias="roles")
727
+
728
+ @field_validator("roles", mode="before")
729
+ @classmethod
730
+ def normalize_roles(cls, value):
731
+ if isinstance(value, list):
732
+ return [Role.model_validate(item) if isinstance(item, dict) else item for item in value]
733
+ return value
734
+
735
+ def to_dict(self):
736
+ return self.model_dump(by_alias=True, exclude_none=True)
737
+
738
+ def __str__(self):
739
+ return str(self.to_dict())
740
+
741
+
742
+ class ProjectMembership(CustomBaseModel):
743
+ """
744
+ {
745
+ "organizationId": "string",
746
+ "organizationName": "string",
747
+ "projectDescription": "string",
748
+ "projectId": "string",
749
+ "projectName": "string",
750
+ "roles": [...]
751
+ }
752
+ """
753
+ organization_id: Optional[str] = Field(None, alias="organizationId")
754
+ organization_name: Optional[str] = Field(None, alias="organizationName")
755
+ project_description: Optional[str] = Field(None, alias="projectDescription")
756
+ project_id: str = Field(..., alias="projectId")
757
+ project_name: str = Field(..., alias="projectName")
758
+ roles: Optional[List[Role]] = Field(default_factory=list, alias="roles")
759
+
760
+ @field_validator("roles", mode="before")
761
+ @classmethod
762
+ def normalize_roles(cls, value):
763
+ if isinstance(value, list):
764
+ return [Role.model_validate(item) if isinstance(item, dict) else item for item in value]
765
+ return value
766
+
767
+ def to_dict(self):
768
+ return self.model_dump(by_alias=True, exclude_none=True)
769
+
770
+ def __str__(self):
771
+ return str(self.to_dict())
772
+
773
+
774
+ class OrganizationMembership(CustomBaseModel):
775
+ """
776
+ {
777
+ "isStationAvailable": true,
778
+ "organizationId": "string",
779
+ "organizationName": "string",
780
+ "projects": [...]
781
+ }
782
+ """
783
+ is_station_available: Optional[bool] = Field(None, alias="isStationAvailable")
784
+ organization_id: str = Field(..., alias="organizationId")
785
+ organization_name: str = Field(..., alias="organizationName")
786
+ projects: Optional[List[ProjectMembership]] = Field(default_factory=list, alias="projects")
787
+
788
+ @field_validator("projects", mode="before")
789
+ @classmethod
790
+ def normalize_projects(cls, value):
791
+ if isinstance(value, list):
792
+ return [ProjectMembership.model_validate(item) if isinstance(item, dict) else item for item in value]
793
+ return value
794
+
795
+ def to_dict(self):
796
+ return self.model_dump(by_alias=True, exclude_none=True)
797
+
798
+ def __str__(self):
799
+ return str(self.to_dict())