ai-parrot 0.17.2__cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.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 (535) hide show
  1. agentui/.prettierrc +15 -0
  2. agentui/QUICKSTART.md +272 -0
  3. agentui/README.md +59 -0
  4. agentui/env.example +16 -0
  5. agentui/jsconfig.json +14 -0
  6. agentui/package-lock.json +4242 -0
  7. agentui/package.json +34 -0
  8. agentui/scripts/postinstall/apply-patches.mjs +260 -0
  9. agentui/src/app.css +61 -0
  10. agentui/src/app.d.ts +13 -0
  11. agentui/src/app.html +12 -0
  12. agentui/src/components/LoadingSpinner.svelte +64 -0
  13. agentui/src/components/ThemeSwitcher.svelte +159 -0
  14. agentui/src/components/index.js +4 -0
  15. agentui/src/lib/api/bots.ts +60 -0
  16. agentui/src/lib/api/chat.ts +22 -0
  17. agentui/src/lib/api/http.ts +25 -0
  18. agentui/src/lib/components/BotCard.svelte +33 -0
  19. agentui/src/lib/components/ChatBubble.svelte +63 -0
  20. agentui/src/lib/components/Toast.svelte +21 -0
  21. agentui/src/lib/config.ts +20 -0
  22. agentui/src/lib/stores/auth.svelte.ts +73 -0
  23. agentui/src/lib/stores/theme.svelte.js +64 -0
  24. agentui/src/lib/stores/toast.svelte.ts +31 -0
  25. agentui/src/lib/utils/conversation.ts +39 -0
  26. agentui/src/routes/+layout.svelte +20 -0
  27. agentui/src/routes/+page.svelte +232 -0
  28. agentui/src/routes/login/+page.svelte +200 -0
  29. agentui/src/routes/talk/[agentId]/+page.svelte +297 -0
  30. agentui/src/routes/talk/[agentId]/+page.ts +7 -0
  31. agentui/static/README.md +1 -0
  32. agentui/svelte.config.js +11 -0
  33. agentui/tailwind.config.ts +53 -0
  34. agentui/tsconfig.json +3 -0
  35. agentui/vite.config.ts +10 -0
  36. ai_parrot-0.17.2.dist-info/METADATA +472 -0
  37. ai_parrot-0.17.2.dist-info/RECORD +535 -0
  38. ai_parrot-0.17.2.dist-info/WHEEL +6 -0
  39. ai_parrot-0.17.2.dist-info/entry_points.txt +2 -0
  40. ai_parrot-0.17.2.dist-info/licenses/LICENSE +21 -0
  41. ai_parrot-0.17.2.dist-info/top_level.txt +6 -0
  42. crew-builder/.prettierrc +15 -0
  43. crew-builder/QUICKSTART.md +259 -0
  44. crew-builder/README.md +113 -0
  45. crew-builder/env.example +17 -0
  46. crew-builder/jsconfig.json +14 -0
  47. crew-builder/package-lock.json +4182 -0
  48. crew-builder/package.json +37 -0
  49. crew-builder/scripts/postinstall/apply-patches.mjs +260 -0
  50. crew-builder/src/app.css +62 -0
  51. crew-builder/src/app.d.ts +13 -0
  52. crew-builder/src/app.html +12 -0
  53. crew-builder/src/components/LoadingSpinner.svelte +64 -0
  54. crew-builder/src/components/ThemeSwitcher.svelte +149 -0
  55. crew-builder/src/components/index.js +9 -0
  56. crew-builder/src/lib/api/bots.ts +60 -0
  57. crew-builder/src/lib/api/chat.ts +80 -0
  58. crew-builder/src/lib/api/client.ts +56 -0
  59. crew-builder/src/lib/api/crew/crew.ts +136 -0
  60. crew-builder/src/lib/api/index.ts +5 -0
  61. crew-builder/src/lib/api/o365/auth.ts +65 -0
  62. crew-builder/src/lib/auth/auth.ts +54 -0
  63. crew-builder/src/lib/components/AgentNode.svelte +43 -0
  64. crew-builder/src/lib/components/BotCard.svelte +33 -0
  65. crew-builder/src/lib/components/ChatBubble.svelte +67 -0
  66. crew-builder/src/lib/components/ConfigPanel.svelte +278 -0
  67. crew-builder/src/lib/components/JsonTreeNode.svelte +76 -0
  68. crew-builder/src/lib/components/JsonViewer.svelte +24 -0
  69. crew-builder/src/lib/components/MarkdownEditor.svelte +48 -0
  70. crew-builder/src/lib/components/ThemeToggle.svelte +36 -0
  71. crew-builder/src/lib/components/Toast.svelte +67 -0
  72. crew-builder/src/lib/components/Toolbar.svelte +157 -0
  73. crew-builder/src/lib/components/index.ts +10 -0
  74. crew-builder/src/lib/config.ts +8 -0
  75. crew-builder/src/lib/stores/auth.svelte.ts +228 -0
  76. crew-builder/src/lib/stores/crewStore.ts +369 -0
  77. crew-builder/src/lib/stores/theme.svelte.js +145 -0
  78. crew-builder/src/lib/stores/toast.svelte.ts +69 -0
  79. crew-builder/src/lib/utils/conversation.ts +39 -0
  80. crew-builder/src/lib/utils/markdown.ts +122 -0
  81. crew-builder/src/lib/utils/talkHistory.ts +47 -0
  82. crew-builder/src/routes/+layout.svelte +20 -0
  83. crew-builder/src/routes/+page.svelte +539 -0
  84. crew-builder/src/routes/agents/+page.svelte +247 -0
  85. crew-builder/src/routes/agents/[agentId]/+page.svelte +288 -0
  86. crew-builder/src/routes/agents/[agentId]/+page.ts +7 -0
  87. crew-builder/src/routes/builder/+page.svelte +204 -0
  88. crew-builder/src/routes/crew/ask/+page.svelte +1052 -0
  89. crew-builder/src/routes/crew/ask/+page.ts +1 -0
  90. crew-builder/src/routes/integrations/o365/+page.svelte +304 -0
  91. crew-builder/src/routes/login/+page.svelte +197 -0
  92. crew-builder/src/routes/talk/[agentId]/+page.svelte +487 -0
  93. crew-builder/src/routes/talk/[agentId]/+page.ts +7 -0
  94. crew-builder/static/README.md +1 -0
  95. crew-builder/svelte.config.js +11 -0
  96. crew-builder/tailwind.config.ts +53 -0
  97. crew-builder/tsconfig.json +3 -0
  98. crew-builder/vite.config.ts +10 -0
  99. mcp_servers/calculator_server.py +309 -0
  100. parrot/__init__.py +27 -0
  101. parrot/__pycache__/__init__.cpython-310.pyc +0 -0
  102. parrot/__pycache__/version.cpython-310.pyc +0 -0
  103. parrot/_version.py +34 -0
  104. parrot/a2a/__init__.py +48 -0
  105. parrot/a2a/client.py +658 -0
  106. parrot/a2a/discovery.py +89 -0
  107. parrot/a2a/mixin.py +257 -0
  108. parrot/a2a/models.py +376 -0
  109. parrot/a2a/server.py +770 -0
  110. parrot/agents/__init__.py +29 -0
  111. parrot/bots/__init__.py +12 -0
  112. parrot/bots/a2a_agent.py +19 -0
  113. parrot/bots/abstract.py +3139 -0
  114. parrot/bots/agent.py +1129 -0
  115. parrot/bots/basic.py +9 -0
  116. parrot/bots/chatbot.py +669 -0
  117. parrot/bots/data.py +1618 -0
  118. parrot/bots/database/__init__.py +5 -0
  119. parrot/bots/database/abstract.py +3071 -0
  120. parrot/bots/database/cache.py +286 -0
  121. parrot/bots/database/models.py +468 -0
  122. parrot/bots/database/prompts.py +154 -0
  123. parrot/bots/database/retries.py +98 -0
  124. parrot/bots/database/router.py +269 -0
  125. parrot/bots/database/sql.py +41 -0
  126. parrot/bots/db/__init__.py +6 -0
  127. parrot/bots/db/abstract.py +556 -0
  128. parrot/bots/db/bigquery.py +602 -0
  129. parrot/bots/db/cache.py +85 -0
  130. parrot/bots/db/documentdb.py +668 -0
  131. parrot/bots/db/elastic.py +1014 -0
  132. parrot/bots/db/influx.py +898 -0
  133. parrot/bots/db/mock.py +96 -0
  134. parrot/bots/db/multi.py +783 -0
  135. parrot/bots/db/prompts.py +185 -0
  136. parrot/bots/db/sql.py +1255 -0
  137. parrot/bots/db/tools.py +212 -0
  138. parrot/bots/document.py +680 -0
  139. parrot/bots/hrbot.py +15 -0
  140. parrot/bots/kb.py +170 -0
  141. parrot/bots/mcp.py +36 -0
  142. parrot/bots/orchestration/README.md +463 -0
  143. parrot/bots/orchestration/__init__.py +1 -0
  144. parrot/bots/orchestration/agent.py +155 -0
  145. parrot/bots/orchestration/crew.py +3330 -0
  146. parrot/bots/orchestration/fsm.py +1179 -0
  147. parrot/bots/orchestration/hr.py +434 -0
  148. parrot/bots/orchestration/storage/__init__.py +4 -0
  149. parrot/bots/orchestration/storage/memory.py +100 -0
  150. parrot/bots/orchestration/storage/mixin.py +119 -0
  151. parrot/bots/orchestration/verify.py +202 -0
  152. parrot/bots/product.py +204 -0
  153. parrot/bots/prompts/__init__.py +96 -0
  154. parrot/bots/prompts/agents.py +155 -0
  155. parrot/bots/prompts/data.py +216 -0
  156. parrot/bots/prompts/output_generation.py +8 -0
  157. parrot/bots/scraper/__init__.py +3 -0
  158. parrot/bots/scraper/models.py +122 -0
  159. parrot/bots/scraper/scraper.py +1173 -0
  160. parrot/bots/scraper/templates.py +115 -0
  161. parrot/bots/stores/__init__.py +5 -0
  162. parrot/bots/stores/local.py +172 -0
  163. parrot/bots/webdev.py +81 -0
  164. parrot/cli.py +17 -0
  165. parrot/clients/__init__.py +16 -0
  166. parrot/clients/base.py +1491 -0
  167. parrot/clients/claude.py +1191 -0
  168. parrot/clients/factory.py +129 -0
  169. parrot/clients/google.py +4567 -0
  170. parrot/clients/gpt.py +1975 -0
  171. parrot/clients/grok.py +432 -0
  172. parrot/clients/groq.py +986 -0
  173. parrot/clients/hf.py +582 -0
  174. parrot/clients/models.py +18 -0
  175. parrot/conf.py +395 -0
  176. parrot/embeddings/__init__.py +9 -0
  177. parrot/embeddings/base.py +157 -0
  178. parrot/embeddings/google.py +98 -0
  179. parrot/embeddings/huggingface.py +74 -0
  180. parrot/embeddings/openai.py +84 -0
  181. parrot/embeddings/processor.py +88 -0
  182. parrot/exceptions.c +13868 -0
  183. parrot/exceptions.cpython-310-x86_64-linux-gnu.so +0 -0
  184. parrot/exceptions.pxd +22 -0
  185. parrot/exceptions.pxi +15 -0
  186. parrot/exceptions.pyx +44 -0
  187. parrot/generators/__init__.py +29 -0
  188. parrot/generators/base.py +200 -0
  189. parrot/generators/html.py +293 -0
  190. parrot/generators/react.py +205 -0
  191. parrot/generators/streamlit.py +203 -0
  192. parrot/generators/template.py +105 -0
  193. parrot/handlers/__init__.py +4 -0
  194. parrot/handlers/agent.py +861 -0
  195. parrot/handlers/agents/__init__.py +1 -0
  196. parrot/handlers/agents/abstract.py +900 -0
  197. parrot/handlers/bots.py +338 -0
  198. parrot/handlers/chat.py +915 -0
  199. parrot/handlers/creation.sql +192 -0
  200. parrot/handlers/crew/ARCHITECTURE.md +362 -0
  201. parrot/handlers/crew/README_BOTMANAGER_PERSISTENCE.md +303 -0
  202. parrot/handlers/crew/README_REDIS_PERSISTENCE.md +366 -0
  203. parrot/handlers/crew/__init__.py +0 -0
  204. parrot/handlers/crew/handler.py +801 -0
  205. parrot/handlers/crew/models.py +229 -0
  206. parrot/handlers/crew/redis_persistence.py +523 -0
  207. parrot/handlers/jobs/__init__.py +10 -0
  208. parrot/handlers/jobs/job.py +384 -0
  209. parrot/handlers/jobs/mixin.py +627 -0
  210. parrot/handlers/jobs/models.py +115 -0
  211. parrot/handlers/jobs/worker.py +31 -0
  212. parrot/handlers/models.py +596 -0
  213. parrot/handlers/o365_auth.py +105 -0
  214. parrot/handlers/stream.py +337 -0
  215. parrot/interfaces/__init__.py +6 -0
  216. parrot/interfaces/aws.py +143 -0
  217. parrot/interfaces/credentials.py +113 -0
  218. parrot/interfaces/database.py +27 -0
  219. parrot/interfaces/google.py +1123 -0
  220. parrot/interfaces/hierarchy.py +1227 -0
  221. parrot/interfaces/http.py +651 -0
  222. parrot/interfaces/images/__init__.py +0 -0
  223. parrot/interfaces/images/plugins/__init__.py +24 -0
  224. parrot/interfaces/images/plugins/abstract.py +58 -0
  225. parrot/interfaces/images/plugins/analisys.py +148 -0
  226. parrot/interfaces/images/plugins/classify.py +150 -0
  227. parrot/interfaces/images/plugins/classifybase.py +182 -0
  228. parrot/interfaces/images/plugins/detect.py +150 -0
  229. parrot/interfaces/images/plugins/exif.py +1103 -0
  230. parrot/interfaces/images/plugins/hash.py +52 -0
  231. parrot/interfaces/images/plugins/vision.py +104 -0
  232. parrot/interfaces/images/plugins/yolo.py +66 -0
  233. parrot/interfaces/images/plugins/zerodetect.py +197 -0
  234. parrot/interfaces/o365.py +978 -0
  235. parrot/interfaces/onedrive.py +822 -0
  236. parrot/interfaces/sharepoint.py +1435 -0
  237. parrot/interfaces/soap.py +257 -0
  238. parrot/loaders/__init__.py +8 -0
  239. parrot/loaders/abstract.py +1131 -0
  240. parrot/loaders/audio.py +199 -0
  241. parrot/loaders/basepdf.py +53 -0
  242. parrot/loaders/basevideo.py +1568 -0
  243. parrot/loaders/csv.py +409 -0
  244. parrot/loaders/docx.py +116 -0
  245. parrot/loaders/epubloader.py +316 -0
  246. parrot/loaders/excel.py +199 -0
  247. parrot/loaders/factory.py +55 -0
  248. parrot/loaders/files/__init__.py +0 -0
  249. parrot/loaders/files/abstract.py +39 -0
  250. parrot/loaders/files/html.py +26 -0
  251. parrot/loaders/files/text.py +63 -0
  252. parrot/loaders/html.py +152 -0
  253. parrot/loaders/markdown.py +442 -0
  254. parrot/loaders/pdf.py +373 -0
  255. parrot/loaders/pdfmark.py +320 -0
  256. parrot/loaders/pdftables.py +506 -0
  257. parrot/loaders/ppt.py +476 -0
  258. parrot/loaders/qa.py +63 -0
  259. parrot/loaders/splitters/__init__.py +10 -0
  260. parrot/loaders/splitters/base.py +138 -0
  261. parrot/loaders/splitters/md.py +228 -0
  262. parrot/loaders/splitters/token.py +143 -0
  263. parrot/loaders/txt.py +26 -0
  264. parrot/loaders/video.py +89 -0
  265. parrot/loaders/videolocal.py +218 -0
  266. parrot/loaders/videounderstanding.py +377 -0
  267. parrot/loaders/vimeo.py +167 -0
  268. parrot/loaders/web.py +599 -0
  269. parrot/loaders/youtube.py +504 -0
  270. parrot/manager/__init__.py +5 -0
  271. parrot/manager/manager.py +1030 -0
  272. parrot/mcp/__init__.py +28 -0
  273. parrot/mcp/adapter.py +105 -0
  274. parrot/mcp/cli.py +174 -0
  275. parrot/mcp/client.py +119 -0
  276. parrot/mcp/config.py +75 -0
  277. parrot/mcp/integration.py +842 -0
  278. parrot/mcp/oauth.py +933 -0
  279. parrot/mcp/server.py +225 -0
  280. parrot/mcp/transports/__init__.py +3 -0
  281. parrot/mcp/transports/base.py +279 -0
  282. parrot/mcp/transports/grpc_session.py +163 -0
  283. parrot/mcp/transports/http.py +312 -0
  284. parrot/mcp/transports/mcp.proto +108 -0
  285. parrot/mcp/transports/quic.py +1082 -0
  286. parrot/mcp/transports/sse.py +330 -0
  287. parrot/mcp/transports/stdio.py +309 -0
  288. parrot/mcp/transports/unix.py +395 -0
  289. parrot/mcp/transports/websocket.py +547 -0
  290. parrot/memory/__init__.py +16 -0
  291. parrot/memory/abstract.py +209 -0
  292. parrot/memory/agent.py +32 -0
  293. parrot/memory/cache.py +175 -0
  294. parrot/memory/core.py +555 -0
  295. parrot/memory/file.py +153 -0
  296. parrot/memory/mem.py +131 -0
  297. parrot/memory/redis.py +613 -0
  298. parrot/models/__init__.py +46 -0
  299. parrot/models/basic.py +118 -0
  300. parrot/models/compliance.py +208 -0
  301. parrot/models/crew.py +395 -0
  302. parrot/models/detections.py +654 -0
  303. parrot/models/generation.py +85 -0
  304. parrot/models/google.py +223 -0
  305. parrot/models/groq.py +23 -0
  306. parrot/models/openai.py +30 -0
  307. parrot/models/outputs.py +285 -0
  308. parrot/models/responses.py +938 -0
  309. parrot/notifications/__init__.py +743 -0
  310. parrot/openapi/__init__.py +3 -0
  311. parrot/openapi/components.yaml +641 -0
  312. parrot/openapi/config.py +322 -0
  313. parrot/outputs/__init__.py +32 -0
  314. parrot/outputs/formats/__init__.py +108 -0
  315. parrot/outputs/formats/altair.py +359 -0
  316. parrot/outputs/formats/application.py +122 -0
  317. parrot/outputs/formats/base.py +351 -0
  318. parrot/outputs/formats/bokeh.py +356 -0
  319. parrot/outputs/formats/card.py +424 -0
  320. parrot/outputs/formats/chart.py +436 -0
  321. parrot/outputs/formats/d3.py +255 -0
  322. parrot/outputs/formats/echarts.py +310 -0
  323. parrot/outputs/formats/generators/__init__.py +0 -0
  324. parrot/outputs/formats/generators/abstract.py +61 -0
  325. parrot/outputs/formats/generators/panel.py +145 -0
  326. parrot/outputs/formats/generators/streamlit.py +86 -0
  327. parrot/outputs/formats/generators/terminal.py +63 -0
  328. parrot/outputs/formats/holoviews.py +310 -0
  329. parrot/outputs/formats/html.py +147 -0
  330. parrot/outputs/formats/jinja2.py +46 -0
  331. parrot/outputs/formats/json.py +87 -0
  332. parrot/outputs/formats/map.py +933 -0
  333. parrot/outputs/formats/markdown.py +172 -0
  334. parrot/outputs/formats/matplotlib.py +237 -0
  335. parrot/outputs/formats/mixins/__init__.py +0 -0
  336. parrot/outputs/formats/mixins/emaps.py +855 -0
  337. parrot/outputs/formats/plotly.py +341 -0
  338. parrot/outputs/formats/seaborn.py +310 -0
  339. parrot/outputs/formats/table.py +397 -0
  340. parrot/outputs/formats/template_report.py +138 -0
  341. parrot/outputs/formats/yaml.py +125 -0
  342. parrot/outputs/formatter.py +152 -0
  343. parrot/outputs/templates/__init__.py +95 -0
  344. parrot/pipelines/__init__.py +0 -0
  345. parrot/pipelines/abstract.py +210 -0
  346. parrot/pipelines/detector.py +124 -0
  347. parrot/pipelines/models.py +90 -0
  348. parrot/pipelines/planogram.py +3002 -0
  349. parrot/pipelines/table.sql +97 -0
  350. parrot/plugins/__init__.py +106 -0
  351. parrot/plugins/importer.py +80 -0
  352. parrot/py.typed +0 -0
  353. parrot/registry/__init__.py +18 -0
  354. parrot/registry/registry.py +594 -0
  355. parrot/scheduler/__init__.py +1189 -0
  356. parrot/scheduler/models.py +60 -0
  357. parrot/security/__init__.py +16 -0
  358. parrot/security/prompt_injection.py +268 -0
  359. parrot/security/security_events.sql +25 -0
  360. parrot/services/__init__.py +1 -0
  361. parrot/services/mcp/__init__.py +8 -0
  362. parrot/services/mcp/config.py +13 -0
  363. parrot/services/mcp/server.py +295 -0
  364. parrot/services/o365_remote_auth.py +235 -0
  365. parrot/stores/__init__.py +7 -0
  366. parrot/stores/abstract.py +352 -0
  367. parrot/stores/arango.py +1090 -0
  368. parrot/stores/bigquery.py +1377 -0
  369. parrot/stores/cache.py +106 -0
  370. parrot/stores/empty.py +10 -0
  371. parrot/stores/faiss_store.py +1157 -0
  372. parrot/stores/kb/__init__.py +9 -0
  373. parrot/stores/kb/abstract.py +68 -0
  374. parrot/stores/kb/cache.py +165 -0
  375. parrot/stores/kb/doc.py +325 -0
  376. parrot/stores/kb/hierarchy.py +346 -0
  377. parrot/stores/kb/local.py +457 -0
  378. parrot/stores/kb/prompt.py +28 -0
  379. parrot/stores/kb/redis.py +659 -0
  380. parrot/stores/kb/store.py +115 -0
  381. parrot/stores/kb/user.py +374 -0
  382. parrot/stores/models.py +59 -0
  383. parrot/stores/pgvector.py +3 -0
  384. parrot/stores/postgres.py +2853 -0
  385. parrot/stores/utils/__init__.py +0 -0
  386. parrot/stores/utils/chunking.py +197 -0
  387. parrot/telemetry/__init__.py +3 -0
  388. parrot/telemetry/mixin.py +111 -0
  389. parrot/template/__init__.py +3 -0
  390. parrot/template/engine.py +259 -0
  391. parrot/tools/__init__.py +23 -0
  392. parrot/tools/abstract.py +644 -0
  393. parrot/tools/agent.py +363 -0
  394. parrot/tools/arangodbsearch.py +537 -0
  395. parrot/tools/arxiv_tool.py +188 -0
  396. parrot/tools/calculator/__init__.py +3 -0
  397. parrot/tools/calculator/operations/__init__.py +38 -0
  398. parrot/tools/calculator/operations/calculus.py +80 -0
  399. parrot/tools/calculator/operations/statistics.py +76 -0
  400. parrot/tools/calculator/tool.py +150 -0
  401. parrot/tools/cloudwatch.py +988 -0
  402. parrot/tools/codeinterpreter/__init__.py +127 -0
  403. parrot/tools/codeinterpreter/executor.py +371 -0
  404. parrot/tools/codeinterpreter/internals.py +473 -0
  405. parrot/tools/codeinterpreter/models.py +643 -0
  406. parrot/tools/codeinterpreter/prompts.py +224 -0
  407. parrot/tools/codeinterpreter/tool.py +664 -0
  408. parrot/tools/company_info/__init__.py +6 -0
  409. parrot/tools/company_info/tool.py +1138 -0
  410. parrot/tools/correlationanalysis.py +437 -0
  411. parrot/tools/database/abstract.py +286 -0
  412. parrot/tools/database/bq.py +115 -0
  413. parrot/tools/database/cache.py +284 -0
  414. parrot/tools/database/models.py +95 -0
  415. parrot/tools/database/pg.py +343 -0
  416. parrot/tools/databasequery.py +1159 -0
  417. parrot/tools/db.py +1800 -0
  418. parrot/tools/ddgo.py +370 -0
  419. parrot/tools/decorators.py +271 -0
  420. parrot/tools/dftohtml.py +282 -0
  421. parrot/tools/document.py +549 -0
  422. parrot/tools/ecs.py +819 -0
  423. parrot/tools/edareport.py +368 -0
  424. parrot/tools/elasticsearch.py +1049 -0
  425. parrot/tools/employees.py +462 -0
  426. parrot/tools/epson/__init__.py +96 -0
  427. parrot/tools/excel.py +683 -0
  428. parrot/tools/file/__init__.py +13 -0
  429. parrot/tools/file/abstract.py +76 -0
  430. parrot/tools/file/gcs.py +378 -0
  431. parrot/tools/file/local.py +284 -0
  432. parrot/tools/file/s3.py +511 -0
  433. parrot/tools/file/tmp.py +309 -0
  434. parrot/tools/file/tool.py +501 -0
  435. parrot/tools/file_reader.py +129 -0
  436. parrot/tools/flowtask/__init__.py +19 -0
  437. parrot/tools/flowtask/tool.py +761 -0
  438. parrot/tools/gittoolkit.py +508 -0
  439. parrot/tools/google/__init__.py +18 -0
  440. parrot/tools/google/base.py +169 -0
  441. parrot/tools/google/tools.py +1251 -0
  442. parrot/tools/googlelocation.py +5 -0
  443. parrot/tools/googleroutes.py +5 -0
  444. parrot/tools/googlesearch.py +5 -0
  445. parrot/tools/googlesitesearch.py +5 -0
  446. parrot/tools/googlevoice.py +2 -0
  447. parrot/tools/gvoice.py +695 -0
  448. parrot/tools/ibisworld/README.md +225 -0
  449. parrot/tools/ibisworld/__init__.py +11 -0
  450. parrot/tools/ibisworld/tool.py +366 -0
  451. parrot/tools/jiratoolkit.py +1718 -0
  452. parrot/tools/manager.py +1098 -0
  453. parrot/tools/math.py +152 -0
  454. parrot/tools/metadata.py +476 -0
  455. parrot/tools/msteams.py +1621 -0
  456. parrot/tools/msword.py +635 -0
  457. parrot/tools/multidb.py +580 -0
  458. parrot/tools/multistoresearch.py +369 -0
  459. parrot/tools/networkninja.py +167 -0
  460. parrot/tools/nextstop/__init__.py +4 -0
  461. parrot/tools/nextstop/base.py +286 -0
  462. parrot/tools/nextstop/employee.py +733 -0
  463. parrot/tools/nextstop/store.py +462 -0
  464. parrot/tools/notification.py +435 -0
  465. parrot/tools/o365/__init__.py +42 -0
  466. parrot/tools/o365/base.py +295 -0
  467. parrot/tools/o365/bundle.py +522 -0
  468. parrot/tools/o365/events.py +554 -0
  469. parrot/tools/o365/mail.py +992 -0
  470. parrot/tools/o365/onedrive.py +497 -0
  471. parrot/tools/o365/sharepoint.py +641 -0
  472. parrot/tools/openapi_toolkit.py +904 -0
  473. parrot/tools/openweather.py +527 -0
  474. parrot/tools/pdfprint.py +1001 -0
  475. parrot/tools/powerbi.py +518 -0
  476. parrot/tools/powerpoint.py +1113 -0
  477. parrot/tools/pricestool.py +146 -0
  478. parrot/tools/products/__init__.py +246 -0
  479. parrot/tools/prophet_tool.py +171 -0
  480. parrot/tools/pythonpandas.py +630 -0
  481. parrot/tools/pythonrepl.py +910 -0
  482. parrot/tools/qsource.py +436 -0
  483. parrot/tools/querytoolkit.py +395 -0
  484. parrot/tools/quickeda.py +827 -0
  485. parrot/tools/resttool.py +553 -0
  486. parrot/tools/retail/__init__.py +0 -0
  487. parrot/tools/retail/bby.py +528 -0
  488. parrot/tools/sandboxtool.py +703 -0
  489. parrot/tools/sassie/__init__.py +352 -0
  490. parrot/tools/scraping/__init__.py +7 -0
  491. parrot/tools/scraping/docs/select.md +466 -0
  492. parrot/tools/scraping/documentation.md +1278 -0
  493. parrot/tools/scraping/driver.py +436 -0
  494. parrot/tools/scraping/models.py +576 -0
  495. parrot/tools/scraping/options.py +85 -0
  496. parrot/tools/scraping/orchestrator.py +517 -0
  497. parrot/tools/scraping/readme.md +740 -0
  498. parrot/tools/scraping/tool.py +3115 -0
  499. parrot/tools/seasonaldetection.py +642 -0
  500. parrot/tools/shell_tool/__init__.py +5 -0
  501. parrot/tools/shell_tool/actions.py +408 -0
  502. parrot/tools/shell_tool/engine.py +155 -0
  503. parrot/tools/shell_tool/models.py +322 -0
  504. parrot/tools/shell_tool/tool.py +442 -0
  505. parrot/tools/site_search.py +214 -0
  506. parrot/tools/textfile.py +418 -0
  507. parrot/tools/think.py +378 -0
  508. parrot/tools/toolkit.py +298 -0
  509. parrot/tools/webapp_tool.py +187 -0
  510. parrot/tools/whatif.py +1279 -0
  511. parrot/tools/workday/MULTI_WSDL_EXAMPLE.md +249 -0
  512. parrot/tools/workday/__init__.py +6 -0
  513. parrot/tools/workday/models.py +1389 -0
  514. parrot/tools/workday/tool.py +1293 -0
  515. parrot/tools/yfinance_tool.py +306 -0
  516. parrot/tools/zipcode.py +217 -0
  517. parrot/utils/__init__.py +2 -0
  518. parrot/utils/helpers.py +73 -0
  519. parrot/utils/parsers/__init__.py +5 -0
  520. parrot/utils/parsers/toml.c +12078 -0
  521. parrot/utils/parsers/toml.cpython-310-x86_64-linux-gnu.so +0 -0
  522. parrot/utils/parsers/toml.pyx +21 -0
  523. parrot/utils/toml.py +11 -0
  524. parrot/utils/types.cpp +20936 -0
  525. parrot/utils/types.cpython-310-x86_64-linux-gnu.so +0 -0
  526. parrot/utils/types.pyx +213 -0
  527. parrot/utils/uv.py +11 -0
  528. parrot/version.py +10 -0
  529. parrot/yaml-rs/Cargo.lock +350 -0
  530. parrot/yaml-rs/Cargo.toml +19 -0
  531. parrot/yaml-rs/pyproject.toml +19 -0
  532. parrot/yaml-rs/python/yaml_rs/__init__.py +81 -0
  533. parrot/yaml-rs/src/lib.rs +222 -0
  534. requirements/docker-compose.yml +24 -0
  535. requirements/requirements-dev.txt +21 -0
parrot/conf.py ADDED
@@ -0,0 +1,395 @@
1
+ import sys
2
+ import os
3
+ from pathlib import Path
4
+ from navconfig import config, BASE_DIR
5
+ from navconfig.logging import logging
6
+ from navigator.conf import default_dsn, CACHE_HOST, CACHE_PORT
7
+
8
+
9
+ # # disable debug on some libraries:
10
+ # logging.getLogger(name='httpcore').setLevel(logging.INFO)
11
+ # logging.getLogger(name='httpx').setLevel(logging.INFO)
12
+ # logging.getLogger(name='groq').setLevel(logging.INFO)
13
+ # logging.getLogger(name='selenium.webdriver').setLevel(logging.WARNING)
14
+ # logging.getLogger(name='selenium').setLevel(logging.INFO)
15
+ # logging.getLogger(name='matplotlib').setLevel(logging.WARNING)
16
+ # logging.getLogger(name='PIL').setLevel(logging.INFO)
17
+ logging.getLogger("grpc").setLevel(logging.ERROR)
18
+ os.environ['GRPC_VERBOSITY'] = 'ERROR'
19
+ # logging.getLogger("weasyprint").setLevel(logging.ERROR) # Suppress WeasyPrint warnings
20
+ # # Suppress tiktoken warnings
21
+ # logging.getLogger("tiktoken").setLevel(logging.ERROR)
22
+ # logging.getLogger("fontTools").setLevel(logging.ERROR)
23
+
24
+ # Project Root:
25
+ PROJECT_ROOT = BASE_DIR
26
+ # Plugins Directory:
27
+ PLUGINS_DIR = config.get('PLUGINS_DIR', fallback=BASE_DIR.joinpath('plugins'))
28
+ if isinstance(PLUGINS_DIR, str):
29
+ PLUGINS_DIR = Path(PLUGINS_DIR).resolve()
30
+ if not PLUGINS_DIR.exists():
31
+ PLUGINS_DIR.mkdir(parents=True, exist_ok=True)
32
+
33
+ # Static directory
34
+ STATIC_DIR = config.get('STATIC_DIR', fallback=BASE_DIR.joinpath('static'))
35
+ if isinstance(STATIC_DIR, str):
36
+ STATIC_DIR = Path(STATIC_DIR)
37
+
38
+
39
+ # Environment
40
+ ENVIRONMENT = config.get("ENVIRONMENT", fallback="development")
41
+ ENABLE_SWAGGER = config.getboolean("ENABLE_SWAGGER", fallback=True)
42
+
43
+
44
+ # Agents Directory
45
+ AGENTS_DIR = config.get('AGENTS_DIR', fallback=BASE_DIR.joinpath('agents'))
46
+ if isinstance(AGENTS_DIR, str):
47
+ AGENTS_DIR = Path(AGENTS_DIR).resolve()
48
+ if not AGENTS_DIR.exists():
49
+ AGENTS_DIR.mkdir(parents=True, exist_ok=True)
50
+
51
+ # Add AGENTS_DIR to sys.path for direct imports (e.g., from agents.troc import ...)
52
+ # Remove if already present to avoid duplicates, then insert at position 0
53
+ # This ensures AGENTS_DIR takes precedence over PLUGINS_DIR even if plugins/__init__.py
54
+ # has already inserted PLUGINS_DIR at position 0
55
+ agents_dir_str = str(AGENTS_DIR)
56
+ if agents_dir_str in sys.path:
57
+ sys.path.remove(agents_dir_str)
58
+ sys.path.insert(0, agents_dir_str)
59
+
60
+
61
+ # MCP Server Directory:
62
+ MCP_SERVER_DIR = config.get(
63
+ 'MCP_SERVER_DIR',
64
+ fallback=BASE_DIR.joinpath('mcp_servers')
65
+ )
66
+ if isinstance(MCP_SERVER_DIR, str):
67
+ MCP_SERVER_DIR = Path(MCP_SERVER_DIR).resolve()
68
+ if not MCP_SERVER_DIR.exists():
69
+ MCP_SERVER_DIR.mkdir(parents=True, exist_ok=True)
70
+
71
+ # MCP Server defaults
72
+ MCP_SERVER_TRANSPORT = config.get('MCP_SERVER_TRANSPORT', fallback='http')
73
+ MCP_SERVER_HOST = config.get('MCP_SERVER_HOST', fallback='127.0.0.1')
74
+ MCP_SERVER_PORT = config.getint('MCP_SERVER_PORT', fallback=9090)
75
+ MCP_SERVER_NAME = config.get('MCP_SERVER_NAME', fallback='ai-parrot-tools')
76
+ MCP_SERVER_DESCRIPTION = config.get(
77
+ 'MCP_SERVER_DESCRIPTION',
78
+ fallback='AI-Parrot MCP Tooling'
79
+ )
80
+ MCP_SERVER_LOG_LEVEL = config.get('MCP_SERVER_LOG_LEVEL', fallback='INFO')
81
+
82
+ # Default tools that should be started with the MCP server
83
+ MCP_STARTED_TOOLS = {
84
+ # 'MSTeamsToolkit': 'parrot.tools.msteams',
85
+ # 'PDFPrintTool': 'parrot.tools.pdfprint',
86
+ 'JiraToolkit': 'parrot.tools.jiratoolkit',
87
+ }
88
+
89
+ # Agents-Bots Prompt directory:
90
+ AGENTS_BOTS_PROMPT_DIR = config.get(
91
+ 'AGENTS_BOTS_PROMPT_DIR',
92
+ fallback=AGENTS_DIR.joinpath('prompts')
93
+ )
94
+ if isinstance(AGENTS_BOTS_PROMPT_DIR, str):
95
+ AGENTS_BOTS_PROMPT_DIR = Path(AGENTS_BOTS_PROMPT_DIR).resolve()
96
+ if not AGENTS_BOTS_PROMPT_DIR.exists():
97
+ AGENTS_BOTS_PROMPT_DIR.mkdir(parents=True, exist_ok=True)
98
+
99
+ # LLM Model
100
+ DEFAULT_LLM_MODEL_NAME = config.get('LLM_MODEL_NAME', fallback='gemini-2.5-pro')
101
+
102
+
103
+ ## MILVUS DB ##:
104
+ MILVUS_HOST = config.get('MILVUS_HOST', fallback='localhost')
105
+ MILVUS_PROTOCOL = config.get('MILVUS_PROTOCOL', fallback='http')
106
+ MILVUS_PORT = config.get('MILVUS_PORT', fallback=19530)
107
+ MILVUS_URL = config.get('MILVUS_URL')
108
+ MILVUS_TOKEN = config.get('MILVUS_TOKEN')
109
+ MILVUS_USER = config.get('MILVUS_USER')
110
+ MILVUS_PASSWORD = config.get('MILVUS_PASSWORD')
111
+ MILVUS_SECURE = config.getboolean('MILVUS_SECURE', fallback=False)
112
+ MILVUS_SERVER_NAME = config.get(
113
+ 'MILVUS_SERVER_NAME'
114
+ )
115
+ MILVUS_CA_CERT = config.get('MILVUS_CA_CERT', fallback=None)
116
+ MILVUS_SERVER_CERT = config.get('MILVUS_SERVER_CERT', fallback=None)
117
+ MILVUS_SERVER_KEY = config.get('MILVUS_SERVER_KEY', fallback=None)
118
+ MILVUS_USE_TLSv2 = config.getboolean('MILVUS_USE_TLSv2', fallback=False)
119
+
120
+ # Postgres Database:
121
+ DBHOST = config.get("DBHOST", fallback="localhost")
122
+ DBUSER = config.get("DBUSER")
123
+ DBPWD = config.get("DBPWD")
124
+ DBNAME = config.get("DBNAME", fallback="navigator")
125
+ DBPORT = config.get("DBPORT", fallback=5432)
126
+ # sqlalchemy+asyncpg connector:
127
+ default_sqlalchemy_pg = f"postgresql+asyncpg://{DBUSER}:{DBPWD}@{DBHOST}:{DBPORT}/{DBNAME}"
128
+
129
+ PG_USER = config.get('PG_USER', fallback=DBUSER)
130
+ PG_PWD = config.get('PG_PWD', fallback=DBPWD)
131
+ PG_HOST = config.get('PG_HOST', fallback=DBHOST)
132
+ PG_PORT = config.get('PG_PORT', fallback=DBPORT)
133
+ PG_DATABASE = config.get('PG_DATABASE', fallback=DBNAME)
134
+ # asyncpg url for sqlalchemy:
135
+ asyncpg_sqlalchemy_url = f"postgresql+asyncpg://{PG_USER}:{PG_PWD}@{PG_HOST}:{PG_PORT}/{PG_DATABASE}"
136
+
137
+ # ScyllaDB Database:
138
+ SCYLLADB_DRIVER = config.get('SCYLLADB_DRIVER', fallback='scylladb')
139
+ SCYLLADB_HOST = config.get('SCYLLADB_HOST', fallback='localhost')
140
+ SCYLLADB_PORT = config.getint('SCYLLADB_PORT', fallback=9042)
141
+ SCYLLADB_USERNAME = config.get('SCYLLADB_USERNAME', fallback='navigator')
142
+ SCYLLADB_PASSWORD = config.get('SCYLLADB_PASSWORD', fallback='navigator')
143
+ SCYLLADB_KEYSPACE = config.get('SCYLLADB_KEYSPACE', fallback='navigator')
144
+
145
+
146
+ # BigQuery Configuration:
147
+ BIGQUERY_CREDENTIALS = config.get('BIGQUERY_CREDENTIALS')
148
+ BIGQUERY_PROJECT_ID = config.get('BIGQUERY_PROJECT_ID', fallback='navigator')
149
+ BIGQUERY_DATASET = config.get('BIGQUERY_DATASET', fallback='navigator')
150
+
151
+ # Redis History Configuration:
152
+ REDIS_HOST = config.get('REDIS_HOST', fallback='localhost')
153
+ REDIS_PORT = config.get('REDIS_PORT', fallback=6379)
154
+ REDIS_DB = config.get('REDIS_DB', fallback=1)
155
+ REDIS_URL = config.get('REDIS_URL', fallback=f"redis://{REDIS_HOST}:{REDIS_PORT}/{REDIS_DB}")
156
+ REDIS_HISTORY_DB = config.get('REDIS_HISTORY_DB', fallback=3)
157
+ REDIS_HISTORY_URL = f"redis://{REDIS_HOST}:{REDIS_PORT}/{REDIS_HISTORY_DB}"
158
+ REDIS_SERVICES_URL = f"redis://{REDIS_HOST}:{REDIS_PORT}/4"
159
+
160
+ def resolve_cert(crt):
161
+ cert = Path(crt)
162
+ if not cert.is_absolute():
163
+ cert = BASE_DIR.joinpath(cert)
164
+ else:
165
+ cert.resolve()
166
+ return cert
167
+
168
+ if MILVUS_SERVER_CERT:
169
+ MILVUS_SERVER_CERT = str(resolve_cert(MILVUS_SERVER_CERT))
170
+ if MILVUS_CA_CERT:
171
+ MILVUS_CA_CERT = str(resolve_cert(MILVUS_CA_CERT))
172
+ if MILVUS_SERVER_KEY:
173
+ MILVUS_SERVER_KEY = str(resolve_cert(MILVUS_SERVER_KEY))
174
+
175
+ # QDRANT:
176
+ QDRANT_PROTOCOL = config.get('QDRANT_PROTOCOL', fallback='http')
177
+ QDRANT_HOST = config.get('QDRANT_HOST', fallback='localhost')
178
+ QDRANT_PORT = config.get('QDRANT_PORT', fallback=6333)
179
+ QDRANT_USE_HTTPS = config.getboolean('QDRANT_USE_HTTPS', fallback=False)
180
+ QDRANT_URL = config.get('QDRANT_URL')
181
+ # QDRANT Connection Type: server or cloud
182
+ QDRANT_CONN_TYPE = config.get('QDRANT_CONN_TYPE', fallback='server')
183
+
184
+ # ChromaDB:
185
+ CHROMADB_HOST = config.get('CHROMADB_HOST', fallback='localhost')
186
+ CHROMADB_PORT = config.get('CHROMADB_PORT', fallback=8000)
187
+
188
+ # Embedding Device:
189
+ EMBEDDING_DEVICE = config.get('EMBEDDING_DEVICE', fallback='cpu')
190
+ EMBEDDING_DEFAULT_MODEL = config.get(
191
+ 'EMBEDDING_DEFAULT_MODEL',
192
+ fallback='sentence-transformers/all-MiniLM-L12-v2'
193
+ )
194
+ KB_DEFAULT_MODEL = config.get(
195
+ 'KB_DEFAULT_MODEL',
196
+ fallback='sentence-transformers/paraphrase-MiniLM-L3-v2'
197
+ )
198
+ HUGGINGFACE_EMBEDDING_CACHE_DIR = config.get(
199
+ 'HUGGINGFACE_EMBEDDING_CACHE_DIR',
200
+ fallback=BASE_DIR.joinpath('model_cache', 'huggingface')
201
+ )
202
+ HUGGINGFACEHUB_API_TOKEN = config.get('HUGGINGFACEHUB_API_TOKEN')
203
+ MAX_VRAM_AVAILABLE = config.get('MAX_VRAM_AVAILABLE', fallback=20000)
204
+ RAM_AVAILABLE = config.get('RAM_AVAILABLE', fallback=819200)
205
+ CUDA_DEFAULT_DEVICE = config.get('CUDA_DEFAULT_DEVICE', fallback='cpu')
206
+ CUDA_DEFAULT_DEVICE_NUMBER = config.getint('CUDA_DEFAULT_DEVICE_NUMBER', fallback=0)
207
+ MAX_BATCH_SIZE = config.get('MAX_BATCH_SIZE', fallback=2048)
208
+
209
+ # Enable Teams Bot:
210
+ ENABLE_AZURE_BOT = config.getboolean('ENABLE_AZURE_BOT', fallback=True)
211
+
212
+ ## Google Services:
213
+ GOOGLE_API_KEY = config.get('GOOGLE_API_KEY')
214
+ ### Google Service Credentials:
215
+ GA_SERVICE_ACCOUNT_NAME = config.get('GA_SERVICE_ACCOUNT_NAME', fallback="google.json")
216
+ GA_SERVICE_PATH = config.get('GA_SERVICE_PATH', fallback="env/google/")
217
+ if isinstance(GA_SERVICE_PATH, str):
218
+ GA_SERVICE_PATH = Path(GA_SERVICE_PATH)
219
+
220
+ GOOGLE_TTS_SERVICE = config.get(
221
+ 'GOOGLE_TTS_SERVICE',
222
+ fallback=GA_SERVICE_PATH.joinpath('tts-service.json')
223
+ )
224
+ if isinstance(GOOGLE_TTS_SERVICE, str):
225
+ GOOGLE_TTS_SERVICE = Path(GOOGLE_TTS_SERVICE)
226
+ if not GOOGLE_TTS_SERVICE.is_absolute():
227
+ GOOGLE_TTS_SERVICE = BASE_DIR.joinpath(GOOGLE_TTS_SERVICE)
228
+ if not GOOGLE_TTS_SERVICE.exists():
229
+ GOOGLE_TTS_SERVICE = None
230
+
231
+ # BASE STATIC:
232
+ BASE_STATIC_URL = config.get(
233
+ 'BASE_STATIC_URL',
234
+ fallback='http://localhost:5000/static'
235
+ )
236
+
237
+ # Google SerpAPI:
238
+ SERPAPI_API_KEY = config.get('SERPAPI_API_KEY')
239
+
240
+ # Groq API Key:
241
+ GROQ_API_KEY = config.get('GROQ_API_KEY')
242
+ DEFAULT_GROQ_MODEL = config.get('DEFAULT_GROQ_MODEL', fallback='qwen/qwen3-32b')
243
+
244
+ # Ethical Principle:
245
+ ETHICAL_PRINCIPLE = config.get(
246
+ 'ETHICAL_PRINCIPLE',
247
+ fallback='The model should only talk about ethical and legal things.'
248
+ )
249
+
250
+ # Embedding Configuration:
251
+
252
+ # VERTEX
253
+ VERTEX_PROJECT_ID = config.get('VERTEX_PROJECT_ID')
254
+ VERTEX_REGION = config.get('VERTEX_REGION')
255
+
256
+ # OpenAI:
257
+ OPENAI_API_KEY = config.get('OPENAI_API_KEY')
258
+ OPENAI_ORGANIZATION = config.get('OPENAI_ORGANIZATION')
259
+
260
+ ## HTTPClioent
261
+ HTTPCLIENT_MAX_SEMAPHORE = config.getint("HTTPCLIENT_MAX_SEMAPHORE", fallback=5)
262
+ HTTPCLIENT_MAX_WORKERS = config.getint("HTTPCLIENT_MAX_WORKERS", fallback=1)
263
+
264
+ ## Google API:
265
+ GOOGLE_API_KEY = config.get('GOOGLE_API_KEY')
266
+ GOOGLE_SEARCH_API_KEY = config.get('GOOGLE_SEARCH_API_KEY')
267
+ GOOGLE_SEARCH_ENGINE_ID = config.get('GOOGLE_SEARCH_ENGINE_ID')
268
+ GOOGLE_PLACES_API_KEY = config.get('GOOGLE_PLACES_API_KEY')
269
+ GOOGLE_CREDENTIALS_FILE = Path(
270
+ config.get(
271
+ 'GOOGLE_CREDENTIALS_FILE',
272
+ fallback=BASE_DIR.joinpath('env', 'google', 'key.json')
273
+ )
274
+ )
275
+
276
+ ## LLM default config:
277
+ DEFAULT_LLM_MODEL = config.get('LLM_MODEL', fallback='gemini-2.5-flash')
278
+ DEFAULT_LLM_TEMPERATURE = config.get('LLM_TEMPERATURE', fallback=0.1)
279
+
280
+ """
281
+ Amazon AWS Credentials
282
+ """
283
+ aws_region = config.get("AWS_REGION", fallback="us-east-1")
284
+ aws_bucket = config.get("AWS_BUCKET", fallback="static-files")
285
+ aws_key = config.get("AWS_KEY")
286
+ aws_secret = config.get("AWS_SECRET")
287
+
288
+ AWS_ACCESS_KEY = config.get("AWS_ACCESS_KEY", fallback=aws_key)
289
+ AWS_SECRET_KEY = config.get("AWS_SECRET_KEY", fallback=aws_secret)
290
+ AWS_REGION_NAME = config.get("AWS_REGION_NAME", fallback=aws_region)
291
+ AWS_DEFAULT_CLOUDWATCH_LOG_GROUP = config.get("AWS_DEFAULT_CLOUDWATCH_LOG_GROUP", fallback="/parrot/logs")
292
+
293
+ AWS_CREDENTIALS = {
294
+ "default": {
295
+ "use_credentials": config.get("aws_credentials", fallback=False),
296
+ "aws_key": aws_key,
297
+ "aws_secret": aws_secret,
298
+ "region_name": aws_region,
299
+ "bucket_name": aws_bucket,
300
+ },
301
+ "monitoring": {
302
+ "use_credentials": config.get("aws_monitor_credentials", fallback=True),
303
+ "aws_key": AWS_ACCESS_KEY,
304
+ "aws_secret": AWS_SECRET_KEY,
305
+ "region_name": AWS_REGION_NAME,
306
+ },
307
+ "cloudwatch": {
308
+ "use_credentials": True,
309
+ "aws_key": config.get("AWS_CLOUDWATCH_KEY"),
310
+ "aws_secret": config.get("AWS_CLOUDWATCH_SECRET"),
311
+ "region_name": config.get("AWS_CLOUDWATCH_REGION", fallback="us-east-1"),
312
+ }
313
+ }
314
+
315
+ ## Tools:
316
+ OPENWEATHER_APPID = config.get('OPENWEATHER_APPID')
317
+
318
+ # NOTIFICATIONS:
319
+ TEAMS_NOTIFY_TENANT_ID = config.get("TEAMS_NOTIFY_TENANT_ID")
320
+ TEAMS_NOTIFY_CLIENT_ID = config.get("TEAMS_NOTIFY_CLIENT_ID")
321
+ TEAMS_NOTIFY_CLIENT_SECRET = config.get("TEAMS_NOTIFY_CLIENT_SECRET")
322
+ TEAMS_NOTIFY_USERNAME = config.get("TEAMS_NOTIFY_USERNAME")
323
+ TEAMS_NOTIFY_PASSWORD = config.get("TEAMS_NOTIFY_PASSWORD")
324
+ MS_TEAMS_DEFAULT_TEAMS_ID = config.get("MS_TEAMS_DEFAULT_TEAMS_ID")
325
+ MS_TEAMS_DEFAULT_CHANNEL_ID = config.get("MS_TEAMS_DEFAULT_CHANNEL_ID")
326
+
327
+ ## MS Teams Toolkit:
328
+ MS_TEAMS_CLIENT_SECRET = config.get('MS_TEAMS_CLIENT_SECRET')
329
+ MS_TEAMS_CLIENT_ID = config.get('MS_TEAMS_CLIENT_ID')
330
+ MS_TEAMS_TENANT_ID = config.get('MS_TEAMS_TENANT_ID')
331
+ MS_TEAMS_USERNAME = config.get('TEAMS_NOTIFY_USERNAME')
332
+ MS_TEAMS_PASSWORD = config.get('TEAMS_NOTIFY_PASSWORD')
333
+
334
+ ## Office 365:
335
+ O365_CLIENT_ID = config.get('O365_CLIENT_ID')
336
+ O365_CLIENT_SECRET = config.get('O365_CLIENT_SECRET')
337
+ O365_TENANT_ID = config.get('O365_TENANT_ID')
338
+
339
+ # Sharepoint:
340
+ SHAREPOINT_APP_ID = config.get('SHAREPOINT_APP_ID')
341
+ SHAREPOINT_APP_SECRET = config.get('SHAREPOINT_APP_SECRET')
342
+ SHAREPOINT_TENANT_ID = config.get('SHAREPOINT_TENANT_ID')
343
+ SHAREPOINT_TENANT_NAME = config.get('SHAREPOINT_TENANT_NAME')
344
+ SHAREPOINT_SITE_ID = config.get('SHAREPOINT_SITE_ID')
345
+ SHAREPOINT_DEFAULT_HOST = config.get('SHAREPOINT_DEFAULT_HOST')
346
+
347
+ # Employee Hierarchy Configuration:
348
+ EMPLOYEES_TABLE = config.get('EMPLOYEES_TABLE', fallback='troc.troc_employees')
349
+
350
+ # Workday SOAP settings
351
+ WORKDAY_DEFAULT_TENANT = config.get('WORKDAY_DEFAULT_TENANT', fallback='nav')
352
+ WORKDAY_CLIENT_ID = config.get("WORKDAY_CLIENT_ID")
353
+ WORKDAY_CLIENT_SECRET = config.get("WORKDAY_CLIENT_SECRET")
354
+ WORKDAY_TOKEN_URL = config.get("WORKDAY_TOKEN_URL")
355
+ WORKDAY_WSDL_PATH = config.get(
356
+ "WORKDAY_WSDL_PATH",
357
+ fallback=BASE_DIR.joinpath("env", "workday", "staffing_custom_44_2.wsdl")
358
+ )
359
+ WORKDAY_WSDL_TIME = config.get(
360
+ "WORKDAY_WSDL_TIME",
361
+ fallback=BASE_DIR.joinpath("env", "workday", "timetracking_custom_44_2.wsdl")
362
+ )
363
+ WORKDAY_WSDL_HUMAN_RESOURCES = config.get(
364
+ "WORKDAY_WSDL_HUMAN_RESOURCES",
365
+ fallback=BASE_DIR.joinpath("env", "workday", "humanresources_troc_44_2.wsdl")
366
+ )
367
+ WORKDAY_WSDL_FINANCIAL_MANAGEMENT = config.get(
368
+ "WORKDAY_WSDL_FINANCIAL_MANAGEMENT",
369
+ fallback=BASE_DIR.joinpath("env", "workday", "financial_management_45.wsdl")
370
+ )
371
+ WORKDAY_WSDL_RECRUITING = config.get(
372
+ "WORKDAY_WSDL_RECRUITING",
373
+ fallback=BASE_DIR.joinpath("env", "workday", "recruiting_44_2.wsdl")
374
+ )
375
+ WORKDAY_WSDL_ABSENCE_MANAGEMENT = config.get(
376
+ "WORKDAY_WSDL_ABSENCE_MANAGEMENT",
377
+ fallback=BASE_DIR.joinpath("env", "workday", "absence_management_45_custom.wsdl")
378
+ )
379
+ WORKDAY_REFRESH_TOKEN = config.get("WORKDAY_REFRESH_TOKEN", fallback=None)
380
+
381
+ WORKDAY_WSDL_PATHS = {
382
+ "human_resources": WORKDAY_WSDL_HUMAN_RESOURCES,
383
+ "absence_management": WORKDAY_WSDL_ABSENCE_MANAGEMENT,
384
+ "time_tracking": WORKDAY_WSDL_TIME,
385
+ "staffing": WORKDAY_WSDL_PATH,
386
+ "financial_management": WORKDAY_WSDL_FINANCIAL_MANAGEMENT,
387
+ "recruiting": WORKDAY_WSDL_RECRUITING
388
+ }
389
+
390
+ # Final sys.path adjustment: Ensure AGENTS_DIR takes precedence over PLUGINS_DIR
391
+ # This is necessary because parrot.plugins.__init__.py may have inserted PLUGINS_DIR
392
+ # at position 0 during module loading (after our initial AGENTS_DIR insertion above)
393
+ if agents_dir_str in sys.path:
394
+ sys.path.remove(agents_dir_str)
395
+ sys.path.insert(0, agents_dir_str)
@@ -0,0 +1,9 @@
1
+ from .huggingface import SentenceTransformerModel
2
+ from .google import GoogleEmbeddingModel
3
+ from .openai import OpenAIEmbeddingModel
4
+
5
+ supported_embeddings = {
6
+ 'huggingface': 'SentenceTransformerModel',
7
+ 'google': 'GoogleEmbeddingModel',
8
+ 'openai': 'OpenAIEmbeddingModel',
9
+ }
@@ -0,0 +1,157 @@
1
+ from abc import ABC, abstractmethod
2
+ from typing import List, Optional, Union, Any
3
+ import asyncio
4
+ from concurrent.futures import ThreadPoolExecutor
5
+ import numpy as np
6
+ from navconfig.logging import logging
7
+ from ..conf import (
8
+ EMBEDDING_DEVICE,
9
+ CUDA_DEFAULT_DEVICE
10
+ )
11
+
12
+
13
+ class EmbeddingModel(ABC):
14
+ """
15
+ Abstract base class for embedding models.
16
+ It ensures that embedding models can be used interchangeably.
17
+ """
18
+ def __init__(self, model_name: str, **kwargs):
19
+ self.model_name = model_name
20
+ self.logger = logging.getLogger(f"parrot.{self.__class__.__name__}")
21
+ self.executor = ThreadPoolExecutor(max_workers=4)
22
+ self._model_lock = asyncio.Lock()
23
+ self._dimension = None
24
+ # Lazy initialization
25
+ self._model = None
26
+ self._device = None
27
+ self._kwargs = kwargs
28
+
29
+ @property
30
+ def device(self):
31
+ if self._device is None:
32
+ _, self._device, self._dtype = self._get_device()
33
+ return self._device
34
+
35
+ @property
36
+ def model(self):
37
+ if self._model is None:
38
+ self._model = self._create_embedding(
39
+ model_name=self.model_name,
40
+ **self._kwargs
41
+ )
42
+ return self._model
43
+
44
+ def _get_device(
45
+ self,
46
+ device_type: str = None,
47
+ cuda_number: int = 0
48
+ ):
49
+ """Get Default device for Torch and transformers.
50
+
51
+ """
52
+ import torch
53
+ dev = torch.device("cpu")
54
+ pipe_dev = -1
55
+ dtype = torch.float32
56
+ if device_type == 'cpu':
57
+ pipe_dev = torch.device('cpu')
58
+ if CUDA_DEFAULT_DEVICE == 'cpu':
59
+ # Use CPU forced
60
+ pipe_dev = torch.device('cpu')
61
+ if torch.cuda.is_available():
62
+ dev = torch.device("cuda")
63
+ pipe_dev = 0 # first GPU
64
+ # prefer bf16 if supported; else fp16
65
+ if torch.cuda.is_bf16_supported():
66
+ dtype = torch.bfloat16
67
+ else:
68
+ dtype = torch.float16
69
+ pipe_dev = torch.device(f'cuda:{cuda_number}')
70
+ if device_type == 'cuda':
71
+ if torch.cuda.is_bf16_supported():
72
+ dtype = torch.bfloat16
73
+ else:
74
+ dtype = torch.float16
75
+ pipe_dev = torch.device(f'cuda:{cuda_number}')
76
+ if torch.backends.mps.is_available():
77
+ # Use CUDA Multi-Processing Service if available
78
+ dev = torch.device("mps")
79
+ pipe_dev = torch.device("mps")
80
+ dtype = torch.float32 # fp16 on MPS is still flaky
81
+ else:
82
+ pipe_dev = torch.device(EMBEDDING_DEVICE)
83
+ return pipe_dev, dev, dtype
84
+
85
+ def get_embedding_dimension(self) -> int:
86
+ return self._dimension
87
+
88
+ async def initialize_model(self):
89
+ """Async model initialization with GPU optimization"""
90
+ async with self._model_lock:
91
+ if self.model is None:
92
+ loop = asyncio.get_event_loop()
93
+ self.model = await loop.run_in_executor(
94
+ self.executor,
95
+ self._create_embedding
96
+ )
97
+
98
+
99
+ @abstractmethod
100
+ def _create_embedding(self, model_name: str, **kwargs) -> Any:
101
+ """
102
+ Loads and returns the embedding model instance.
103
+ """
104
+ pass
105
+
106
+ def embed_documents(
107
+ self,
108
+ texts: List[str],
109
+ batch_size: Optional[int] = None
110
+ ) -> List[List[float]]:
111
+ """
112
+ Generates embeddings for a list of documents.
113
+
114
+ Args:
115
+ texts: A list of document strings.
116
+
117
+ Returns:
118
+ A list of embedding vectors.
119
+ """
120
+ return self.model.encode(texts, convert_to_tensor=False).tolist()
121
+
122
+ def embed_query(
123
+ self,
124
+ text: str,
125
+ as_nparray: bool = False
126
+ ) -> Union[List[float], List[np.ndarray]]:
127
+ """
128
+ Generates an embedding for a single query string.
129
+
130
+ Args:
131
+ text: The query string.
132
+
133
+ Returns:
134
+ The embedding vector for the query.
135
+ """
136
+ embeddings = self.model.encode(
137
+ text,
138
+ convert_to_tensor=False,
139
+ normalize_embeddings=True,
140
+ show_progress_bar=False
141
+ )
142
+ if as_nparray:
143
+ return np.vstack(embeddings)
144
+ return embeddings.tolist()
145
+
146
+ def free(self):
147
+ """
148
+ Frees up resources used by the model.
149
+ """
150
+ import torch
151
+ self.model = None
152
+ if torch.cuda.is_available():
153
+ torch.cuda.empty_cache()
154
+
155
+ @abstractmethod
156
+ async def encode(self, texts: List[str], **kwargs) -> np.ndarray:
157
+ pass
@@ -0,0 +1,98 @@
1
+ from typing import Any, List, Union
2
+ import numpy as np
3
+ from navconfig import config
4
+ # This file is part of Parrot, an open-source project.
5
+ from .base import EmbeddingModel
6
+
7
+ class GoogleEmbeddingModel(EmbeddingModel):
8
+ """A wrapper class for Google Embedding models using the Gemini API.
9
+ """
10
+ model_name: str = "gemini-embedding-001"
11
+
12
+ def __init__(self, model_name: str = None, output_dimensionality: int = None, **kwargs):
13
+ self.api_key = kwargs.pop('api_key', config.get('GOOGLE_API_KEY'))
14
+ if model_name:
15
+ self.model_name = model_name
16
+ self.output_dimensionality = output_dimensionality
17
+ super().__init__(**kwargs)
18
+
19
+ def _create_embedding(self, model_name: str = None, **kwargs) -> Any:
20
+ """
21
+ Creates and returns a Google Embedding model instance.
22
+
23
+ Args:
24
+ model_name: The name of the Google model to load.
25
+
26
+ Returns:
27
+ An instance of Google Embedding model.
28
+ """
29
+ from google import genai
30
+ if model_name:
31
+ self.model_name = model_name
32
+ self.logger.info(
33
+ f"Loading embedding model '{self.model_name}'"
34
+ )
35
+ self.client = genai.Client(api_key=self.api_key)
36
+ return self.client
37
+
38
+ def _normalize_embeddings(self, embeddings: List[Any]) -> List[List[float]]:
39
+ if not self.output_dimensionality or self.output_dimensionality == 3072:
40
+ return [e.values for e in embeddings]
41
+
42
+ # Normalize embeddings for lower dimensions
43
+ normalized = []
44
+ for embedding in embeddings:
45
+ if hasattr(embedding, 'values'):
46
+ val = np.array(embedding.values)
47
+ else:
48
+ val = np.array(embedding)
49
+ norm = np.linalg.norm(val)
50
+ if norm > 0:
51
+ val = val / norm
52
+ normalized.append(val.tolist())
53
+ return normalized
54
+
55
+ async def encode(self, texts: List[str], **kwargs) -> List[List[float]]:
56
+ from google.genai import types
57
+
58
+ call_kwargs = {
59
+ "model": self.model_name,
60
+ "contents": texts
61
+ }
62
+ if self.output_dimensionality:
63
+ call_kwargs["config"] = types.EmbedContentConfig(
64
+ output_dimensionality=self.output_dimensionality
65
+ )
66
+
67
+ result = self.client.models.embed_content(**call_kwargs)
68
+ if self.output_dimensionality:
69
+ return self._normalize_embeddings(result.embeddings)
70
+ return [e.values for e in result.embeddings]
71
+
72
+ def embed_query(
73
+ self,
74
+ text: str,
75
+ as_nparray: bool = False
76
+ ) -> Union[List[float], List[np.ndarray]]:
77
+ from google.genai import types
78
+
79
+ call_kwargs = {
80
+ "model": self.model_name,
81
+ "contents": [text]
82
+ }
83
+ if self.output_dimensionality:
84
+ call_kwargs["config"] = types.EmbedContentConfig(
85
+ output_dimensionality=self.output_dimensionality
86
+ )
87
+
88
+ result = self.client.models.embed_content(**call_kwargs)
89
+
90
+ embeddings = result.embeddings
91
+ if self.output_dimensionality:
92
+ embeddings = self._normalize_embeddings(embeddings)
93
+ else:
94
+ embeddings = [e.values for e in embeddings]
95
+
96
+ if as_nparray:
97
+ return [np.array(embedding) for embedding in embeddings]
98
+ return embeddings