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.
- agentui/.prettierrc +15 -0
- agentui/QUICKSTART.md +272 -0
- agentui/README.md +59 -0
- agentui/env.example +16 -0
- agentui/jsconfig.json +14 -0
- agentui/package-lock.json +4242 -0
- agentui/package.json +34 -0
- agentui/scripts/postinstall/apply-patches.mjs +260 -0
- agentui/src/app.css +61 -0
- agentui/src/app.d.ts +13 -0
- agentui/src/app.html +12 -0
- agentui/src/components/LoadingSpinner.svelte +64 -0
- agentui/src/components/ThemeSwitcher.svelte +159 -0
- agentui/src/components/index.js +4 -0
- agentui/src/lib/api/bots.ts +60 -0
- agentui/src/lib/api/chat.ts +22 -0
- agentui/src/lib/api/http.ts +25 -0
- agentui/src/lib/components/BotCard.svelte +33 -0
- agentui/src/lib/components/ChatBubble.svelte +63 -0
- agentui/src/lib/components/Toast.svelte +21 -0
- agentui/src/lib/config.ts +20 -0
- agentui/src/lib/stores/auth.svelte.ts +73 -0
- agentui/src/lib/stores/theme.svelte.js +64 -0
- agentui/src/lib/stores/toast.svelte.ts +31 -0
- agentui/src/lib/utils/conversation.ts +39 -0
- agentui/src/routes/+layout.svelte +20 -0
- agentui/src/routes/+page.svelte +232 -0
- agentui/src/routes/login/+page.svelte +200 -0
- agentui/src/routes/talk/[agentId]/+page.svelte +297 -0
- agentui/src/routes/talk/[agentId]/+page.ts +7 -0
- agentui/static/README.md +1 -0
- agentui/svelte.config.js +11 -0
- agentui/tailwind.config.ts +53 -0
- agentui/tsconfig.json +3 -0
- agentui/vite.config.ts +10 -0
- ai_parrot-0.17.2.dist-info/METADATA +472 -0
- ai_parrot-0.17.2.dist-info/RECORD +535 -0
- ai_parrot-0.17.2.dist-info/WHEEL +6 -0
- ai_parrot-0.17.2.dist-info/entry_points.txt +2 -0
- ai_parrot-0.17.2.dist-info/licenses/LICENSE +21 -0
- ai_parrot-0.17.2.dist-info/top_level.txt +6 -0
- crew-builder/.prettierrc +15 -0
- crew-builder/QUICKSTART.md +259 -0
- crew-builder/README.md +113 -0
- crew-builder/env.example +17 -0
- crew-builder/jsconfig.json +14 -0
- crew-builder/package-lock.json +4182 -0
- crew-builder/package.json +37 -0
- crew-builder/scripts/postinstall/apply-patches.mjs +260 -0
- crew-builder/src/app.css +62 -0
- crew-builder/src/app.d.ts +13 -0
- crew-builder/src/app.html +12 -0
- crew-builder/src/components/LoadingSpinner.svelte +64 -0
- crew-builder/src/components/ThemeSwitcher.svelte +149 -0
- crew-builder/src/components/index.js +9 -0
- crew-builder/src/lib/api/bots.ts +60 -0
- crew-builder/src/lib/api/chat.ts +80 -0
- crew-builder/src/lib/api/client.ts +56 -0
- crew-builder/src/lib/api/crew/crew.ts +136 -0
- crew-builder/src/lib/api/index.ts +5 -0
- crew-builder/src/lib/api/o365/auth.ts +65 -0
- crew-builder/src/lib/auth/auth.ts +54 -0
- crew-builder/src/lib/components/AgentNode.svelte +43 -0
- crew-builder/src/lib/components/BotCard.svelte +33 -0
- crew-builder/src/lib/components/ChatBubble.svelte +67 -0
- crew-builder/src/lib/components/ConfigPanel.svelte +278 -0
- crew-builder/src/lib/components/JsonTreeNode.svelte +76 -0
- crew-builder/src/lib/components/JsonViewer.svelte +24 -0
- crew-builder/src/lib/components/MarkdownEditor.svelte +48 -0
- crew-builder/src/lib/components/ThemeToggle.svelte +36 -0
- crew-builder/src/lib/components/Toast.svelte +67 -0
- crew-builder/src/lib/components/Toolbar.svelte +157 -0
- crew-builder/src/lib/components/index.ts +10 -0
- crew-builder/src/lib/config.ts +8 -0
- crew-builder/src/lib/stores/auth.svelte.ts +228 -0
- crew-builder/src/lib/stores/crewStore.ts +369 -0
- crew-builder/src/lib/stores/theme.svelte.js +145 -0
- crew-builder/src/lib/stores/toast.svelte.ts +69 -0
- crew-builder/src/lib/utils/conversation.ts +39 -0
- crew-builder/src/lib/utils/markdown.ts +122 -0
- crew-builder/src/lib/utils/talkHistory.ts +47 -0
- crew-builder/src/routes/+layout.svelte +20 -0
- crew-builder/src/routes/+page.svelte +539 -0
- crew-builder/src/routes/agents/+page.svelte +247 -0
- crew-builder/src/routes/agents/[agentId]/+page.svelte +288 -0
- crew-builder/src/routes/agents/[agentId]/+page.ts +7 -0
- crew-builder/src/routes/builder/+page.svelte +204 -0
- crew-builder/src/routes/crew/ask/+page.svelte +1052 -0
- crew-builder/src/routes/crew/ask/+page.ts +1 -0
- crew-builder/src/routes/integrations/o365/+page.svelte +304 -0
- crew-builder/src/routes/login/+page.svelte +197 -0
- crew-builder/src/routes/talk/[agentId]/+page.svelte +487 -0
- crew-builder/src/routes/talk/[agentId]/+page.ts +7 -0
- crew-builder/static/README.md +1 -0
- crew-builder/svelte.config.js +11 -0
- crew-builder/tailwind.config.ts +53 -0
- crew-builder/tsconfig.json +3 -0
- crew-builder/vite.config.ts +10 -0
- mcp_servers/calculator_server.py +309 -0
- parrot/__init__.py +27 -0
- parrot/__pycache__/__init__.cpython-310.pyc +0 -0
- parrot/__pycache__/version.cpython-310.pyc +0 -0
- parrot/_version.py +34 -0
- parrot/a2a/__init__.py +48 -0
- parrot/a2a/client.py +658 -0
- parrot/a2a/discovery.py +89 -0
- parrot/a2a/mixin.py +257 -0
- parrot/a2a/models.py +376 -0
- parrot/a2a/server.py +770 -0
- parrot/agents/__init__.py +29 -0
- parrot/bots/__init__.py +12 -0
- parrot/bots/a2a_agent.py +19 -0
- parrot/bots/abstract.py +3139 -0
- parrot/bots/agent.py +1129 -0
- parrot/bots/basic.py +9 -0
- parrot/bots/chatbot.py +669 -0
- parrot/bots/data.py +1618 -0
- parrot/bots/database/__init__.py +5 -0
- parrot/bots/database/abstract.py +3071 -0
- parrot/bots/database/cache.py +286 -0
- parrot/bots/database/models.py +468 -0
- parrot/bots/database/prompts.py +154 -0
- parrot/bots/database/retries.py +98 -0
- parrot/bots/database/router.py +269 -0
- parrot/bots/database/sql.py +41 -0
- parrot/bots/db/__init__.py +6 -0
- parrot/bots/db/abstract.py +556 -0
- parrot/bots/db/bigquery.py +602 -0
- parrot/bots/db/cache.py +85 -0
- parrot/bots/db/documentdb.py +668 -0
- parrot/bots/db/elastic.py +1014 -0
- parrot/bots/db/influx.py +898 -0
- parrot/bots/db/mock.py +96 -0
- parrot/bots/db/multi.py +783 -0
- parrot/bots/db/prompts.py +185 -0
- parrot/bots/db/sql.py +1255 -0
- parrot/bots/db/tools.py +212 -0
- parrot/bots/document.py +680 -0
- parrot/bots/hrbot.py +15 -0
- parrot/bots/kb.py +170 -0
- parrot/bots/mcp.py +36 -0
- parrot/bots/orchestration/README.md +463 -0
- parrot/bots/orchestration/__init__.py +1 -0
- parrot/bots/orchestration/agent.py +155 -0
- parrot/bots/orchestration/crew.py +3330 -0
- parrot/bots/orchestration/fsm.py +1179 -0
- parrot/bots/orchestration/hr.py +434 -0
- parrot/bots/orchestration/storage/__init__.py +4 -0
- parrot/bots/orchestration/storage/memory.py +100 -0
- parrot/bots/orchestration/storage/mixin.py +119 -0
- parrot/bots/orchestration/verify.py +202 -0
- parrot/bots/product.py +204 -0
- parrot/bots/prompts/__init__.py +96 -0
- parrot/bots/prompts/agents.py +155 -0
- parrot/bots/prompts/data.py +216 -0
- parrot/bots/prompts/output_generation.py +8 -0
- parrot/bots/scraper/__init__.py +3 -0
- parrot/bots/scraper/models.py +122 -0
- parrot/bots/scraper/scraper.py +1173 -0
- parrot/bots/scraper/templates.py +115 -0
- parrot/bots/stores/__init__.py +5 -0
- parrot/bots/stores/local.py +172 -0
- parrot/bots/webdev.py +81 -0
- parrot/cli.py +17 -0
- parrot/clients/__init__.py +16 -0
- parrot/clients/base.py +1491 -0
- parrot/clients/claude.py +1191 -0
- parrot/clients/factory.py +129 -0
- parrot/clients/google.py +4567 -0
- parrot/clients/gpt.py +1975 -0
- parrot/clients/grok.py +432 -0
- parrot/clients/groq.py +986 -0
- parrot/clients/hf.py +582 -0
- parrot/clients/models.py +18 -0
- parrot/conf.py +395 -0
- parrot/embeddings/__init__.py +9 -0
- parrot/embeddings/base.py +157 -0
- parrot/embeddings/google.py +98 -0
- parrot/embeddings/huggingface.py +74 -0
- parrot/embeddings/openai.py +84 -0
- parrot/embeddings/processor.py +88 -0
- parrot/exceptions.c +13868 -0
- parrot/exceptions.cpython-310-x86_64-linux-gnu.so +0 -0
- parrot/exceptions.pxd +22 -0
- parrot/exceptions.pxi +15 -0
- parrot/exceptions.pyx +44 -0
- parrot/generators/__init__.py +29 -0
- parrot/generators/base.py +200 -0
- parrot/generators/html.py +293 -0
- parrot/generators/react.py +205 -0
- parrot/generators/streamlit.py +203 -0
- parrot/generators/template.py +105 -0
- parrot/handlers/__init__.py +4 -0
- parrot/handlers/agent.py +861 -0
- parrot/handlers/agents/__init__.py +1 -0
- parrot/handlers/agents/abstract.py +900 -0
- parrot/handlers/bots.py +338 -0
- parrot/handlers/chat.py +915 -0
- parrot/handlers/creation.sql +192 -0
- parrot/handlers/crew/ARCHITECTURE.md +362 -0
- parrot/handlers/crew/README_BOTMANAGER_PERSISTENCE.md +303 -0
- parrot/handlers/crew/README_REDIS_PERSISTENCE.md +366 -0
- parrot/handlers/crew/__init__.py +0 -0
- parrot/handlers/crew/handler.py +801 -0
- parrot/handlers/crew/models.py +229 -0
- parrot/handlers/crew/redis_persistence.py +523 -0
- parrot/handlers/jobs/__init__.py +10 -0
- parrot/handlers/jobs/job.py +384 -0
- parrot/handlers/jobs/mixin.py +627 -0
- parrot/handlers/jobs/models.py +115 -0
- parrot/handlers/jobs/worker.py +31 -0
- parrot/handlers/models.py +596 -0
- parrot/handlers/o365_auth.py +105 -0
- parrot/handlers/stream.py +337 -0
- parrot/interfaces/__init__.py +6 -0
- parrot/interfaces/aws.py +143 -0
- parrot/interfaces/credentials.py +113 -0
- parrot/interfaces/database.py +27 -0
- parrot/interfaces/google.py +1123 -0
- parrot/interfaces/hierarchy.py +1227 -0
- parrot/interfaces/http.py +651 -0
- parrot/interfaces/images/__init__.py +0 -0
- parrot/interfaces/images/plugins/__init__.py +24 -0
- parrot/interfaces/images/plugins/abstract.py +58 -0
- parrot/interfaces/images/plugins/analisys.py +148 -0
- parrot/interfaces/images/plugins/classify.py +150 -0
- parrot/interfaces/images/plugins/classifybase.py +182 -0
- parrot/interfaces/images/plugins/detect.py +150 -0
- parrot/interfaces/images/plugins/exif.py +1103 -0
- parrot/interfaces/images/plugins/hash.py +52 -0
- parrot/interfaces/images/plugins/vision.py +104 -0
- parrot/interfaces/images/plugins/yolo.py +66 -0
- parrot/interfaces/images/plugins/zerodetect.py +197 -0
- parrot/interfaces/o365.py +978 -0
- parrot/interfaces/onedrive.py +822 -0
- parrot/interfaces/sharepoint.py +1435 -0
- parrot/interfaces/soap.py +257 -0
- parrot/loaders/__init__.py +8 -0
- parrot/loaders/abstract.py +1131 -0
- parrot/loaders/audio.py +199 -0
- parrot/loaders/basepdf.py +53 -0
- parrot/loaders/basevideo.py +1568 -0
- parrot/loaders/csv.py +409 -0
- parrot/loaders/docx.py +116 -0
- parrot/loaders/epubloader.py +316 -0
- parrot/loaders/excel.py +199 -0
- parrot/loaders/factory.py +55 -0
- parrot/loaders/files/__init__.py +0 -0
- parrot/loaders/files/abstract.py +39 -0
- parrot/loaders/files/html.py +26 -0
- parrot/loaders/files/text.py +63 -0
- parrot/loaders/html.py +152 -0
- parrot/loaders/markdown.py +442 -0
- parrot/loaders/pdf.py +373 -0
- parrot/loaders/pdfmark.py +320 -0
- parrot/loaders/pdftables.py +506 -0
- parrot/loaders/ppt.py +476 -0
- parrot/loaders/qa.py +63 -0
- parrot/loaders/splitters/__init__.py +10 -0
- parrot/loaders/splitters/base.py +138 -0
- parrot/loaders/splitters/md.py +228 -0
- parrot/loaders/splitters/token.py +143 -0
- parrot/loaders/txt.py +26 -0
- parrot/loaders/video.py +89 -0
- parrot/loaders/videolocal.py +218 -0
- parrot/loaders/videounderstanding.py +377 -0
- parrot/loaders/vimeo.py +167 -0
- parrot/loaders/web.py +599 -0
- parrot/loaders/youtube.py +504 -0
- parrot/manager/__init__.py +5 -0
- parrot/manager/manager.py +1030 -0
- parrot/mcp/__init__.py +28 -0
- parrot/mcp/adapter.py +105 -0
- parrot/mcp/cli.py +174 -0
- parrot/mcp/client.py +119 -0
- parrot/mcp/config.py +75 -0
- parrot/mcp/integration.py +842 -0
- parrot/mcp/oauth.py +933 -0
- parrot/mcp/server.py +225 -0
- parrot/mcp/transports/__init__.py +3 -0
- parrot/mcp/transports/base.py +279 -0
- parrot/mcp/transports/grpc_session.py +163 -0
- parrot/mcp/transports/http.py +312 -0
- parrot/mcp/transports/mcp.proto +108 -0
- parrot/mcp/transports/quic.py +1082 -0
- parrot/mcp/transports/sse.py +330 -0
- parrot/mcp/transports/stdio.py +309 -0
- parrot/mcp/transports/unix.py +395 -0
- parrot/mcp/transports/websocket.py +547 -0
- parrot/memory/__init__.py +16 -0
- parrot/memory/abstract.py +209 -0
- parrot/memory/agent.py +32 -0
- parrot/memory/cache.py +175 -0
- parrot/memory/core.py +555 -0
- parrot/memory/file.py +153 -0
- parrot/memory/mem.py +131 -0
- parrot/memory/redis.py +613 -0
- parrot/models/__init__.py +46 -0
- parrot/models/basic.py +118 -0
- parrot/models/compliance.py +208 -0
- parrot/models/crew.py +395 -0
- parrot/models/detections.py +654 -0
- parrot/models/generation.py +85 -0
- parrot/models/google.py +223 -0
- parrot/models/groq.py +23 -0
- parrot/models/openai.py +30 -0
- parrot/models/outputs.py +285 -0
- parrot/models/responses.py +938 -0
- parrot/notifications/__init__.py +743 -0
- parrot/openapi/__init__.py +3 -0
- parrot/openapi/components.yaml +641 -0
- parrot/openapi/config.py +322 -0
- parrot/outputs/__init__.py +32 -0
- parrot/outputs/formats/__init__.py +108 -0
- parrot/outputs/formats/altair.py +359 -0
- parrot/outputs/formats/application.py +122 -0
- parrot/outputs/formats/base.py +351 -0
- parrot/outputs/formats/bokeh.py +356 -0
- parrot/outputs/formats/card.py +424 -0
- parrot/outputs/formats/chart.py +436 -0
- parrot/outputs/formats/d3.py +255 -0
- parrot/outputs/formats/echarts.py +310 -0
- parrot/outputs/formats/generators/__init__.py +0 -0
- parrot/outputs/formats/generators/abstract.py +61 -0
- parrot/outputs/formats/generators/panel.py +145 -0
- parrot/outputs/formats/generators/streamlit.py +86 -0
- parrot/outputs/formats/generators/terminal.py +63 -0
- parrot/outputs/formats/holoviews.py +310 -0
- parrot/outputs/formats/html.py +147 -0
- parrot/outputs/formats/jinja2.py +46 -0
- parrot/outputs/formats/json.py +87 -0
- parrot/outputs/formats/map.py +933 -0
- parrot/outputs/formats/markdown.py +172 -0
- parrot/outputs/formats/matplotlib.py +237 -0
- parrot/outputs/formats/mixins/__init__.py +0 -0
- parrot/outputs/formats/mixins/emaps.py +855 -0
- parrot/outputs/formats/plotly.py +341 -0
- parrot/outputs/formats/seaborn.py +310 -0
- parrot/outputs/formats/table.py +397 -0
- parrot/outputs/formats/template_report.py +138 -0
- parrot/outputs/formats/yaml.py +125 -0
- parrot/outputs/formatter.py +152 -0
- parrot/outputs/templates/__init__.py +95 -0
- parrot/pipelines/__init__.py +0 -0
- parrot/pipelines/abstract.py +210 -0
- parrot/pipelines/detector.py +124 -0
- parrot/pipelines/models.py +90 -0
- parrot/pipelines/planogram.py +3002 -0
- parrot/pipelines/table.sql +97 -0
- parrot/plugins/__init__.py +106 -0
- parrot/plugins/importer.py +80 -0
- parrot/py.typed +0 -0
- parrot/registry/__init__.py +18 -0
- parrot/registry/registry.py +594 -0
- parrot/scheduler/__init__.py +1189 -0
- parrot/scheduler/models.py +60 -0
- parrot/security/__init__.py +16 -0
- parrot/security/prompt_injection.py +268 -0
- parrot/security/security_events.sql +25 -0
- parrot/services/__init__.py +1 -0
- parrot/services/mcp/__init__.py +8 -0
- parrot/services/mcp/config.py +13 -0
- parrot/services/mcp/server.py +295 -0
- parrot/services/o365_remote_auth.py +235 -0
- parrot/stores/__init__.py +7 -0
- parrot/stores/abstract.py +352 -0
- parrot/stores/arango.py +1090 -0
- parrot/stores/bigquery.py +1377 -0
- parrot/stores/cache.py +106 -0
- parrot/stores/empty.py +10 -0
- parrot/stores/faiss_store.py +1157 -0
- parrot/stores/kb/__init__.py +9 -0
- parrot/stores/kb/abstract.py +68 -0
- parrot/stores/kb/cache.py +165 -0
- parrot/stores/kb/doc.py +325 -0
- parrot/stores/kb/hierarchy.py +346 -0
- parrot/stores/kb/local.py +457 -0
- parrot/stores/kb/prompt.py +28 -0
- parrot/stores/kb/redis.py +659 -0
- parrot/stores/kb/store.py +115 -0
- parrot/stores/kb/user.py +374 -0
- parrot/stores/models.py +59 -0
- parrot/stores/pgvector.py +3 -0
- parrot/stores/postgres.py +2853 -0
- parrot/stores/utils/__init__.py +0 -0
- parrot/stores/utils/chunking.py +197 -0
- parrot/telemetry/__init__.py +3 -0
- parrot/telemetry/mixin.py +111 -0
- parrot/template/__init__.py +3 -0
- parrot/template/engine.py +259 -0
- parrot/tools/__init__.py +23 -0
- parrot/tools/abstract.py +644 -0
- parrot/tools/agent.py +363 -0
- parrot/tools/arangodbsearch.py +537 -0
- parrot/tools/arxiv_tool.py +188 -0
- parrot/tools/calculator/__init__.py +3 -0
- parrot/tools/calculator/operations/__init__.py +38 -0
- parrot/tools/calculator/operations/calculus.py +80 -0
- parrot/tools/calculator/operations/statistics.py +76 -0
- parrot/tools/calculator/tool.py +150 -0
- parrot/tools/cloudwatch.py +988 -0
- parrot/tools/codeinterpreter/__init__.py +127 -0
- parrot/tools/codeinterpreter/executor.py +371 -0
- parrot/tools/codeinterpreter/internals.py +473 -0
- parrot/tools/codeinterpreter/models.py +643 -0
- parrot/tools/codeinterpreter/prompts.py +224 -0
- parrot/tools/codeinterpreter/tool.py +664 -0
- parrot/tools/company_info/__init__.py +6 -0
- parrot/tools/company_info/tool.py +1138 -0
- parrot/tools/correlationanalysis.py +437 -0
- parrot/tools/database/abstract.py +286 -0
- parrot/tools/database/bq.py +115 -0
- parrot/tools/database/cache.py +284 -0
- parrot/tools/database/models.py +95 -0
- parrot/tools/database/pg.py +343 -0
- parrot/tools/databasequery.py +1159 -0
- parrot/tools/db.py +1800 -0
- parrot/tools/ddgo.py +370 -0
- parrot/tools/decorators.py +271 -0
- parrot/tools/dftohtml.py +282 -0
- parrot/tools/document.py +549 -0
- parrot/tools/ecs.py +819 -0
- parrot/tools/edareport.py +368 -0
- parrot/tools/elasticsearch.py +1049 -0
- parrot/tools/employees.py +462 -0
- parrot/tools/epson/__init__.py +96 -0
- parrot/tools/excel.py +683 -0
- parrot/tools/file/__init__.py +13 -0
- parrot/tools/file/abstract.py +76 -0
- parrot/tools/file/gcs.py +378 -0
- parrot/tools/file/local.py +284 -0
- parrot/tools/file/s3.py +511 -0
- parrot/tools/file/tmp.py +309 -0
- parrot/tools/file/tool.py +501 -0
- parrot/tools/file_reader.py +129 -0
- parrot/tools/flowtask/__init__.py +19 -0
- parrot/tools/flowtask/tool.py +761 -0
- parrot/tools/gittoolkit.py +508 -0
- parrot/tools/google/__init__.py +18 -0
- parrot/tools/google/base.py +169 -0
- parrot/tools/google/tools.py +1251 -0
- parrot/tools/googlelocation.py +5 -0
- parrot/tools/googleroutes.py +5 -0
- parrot/tools/googlesearch.py +5 -0
- parrot/tools/googlesitesearch.py +5 -0
- parrot/tools/googlevoice.py +2 -0
- parrot/tools/gvoice.py +695 -0
- parrot/tools/ibisworld/README.md +225 -0
- parrot/tools/ibisworld/__init__.py +11 -0
- parrot/tools/ibisworld/tool.py +366 -0
- parrot/tools/jiratoolkit.py +1718 -0
- parrot/tools/manager.py +1098 -0
- parrot/tools/math.py +152 -0
- parrot/tools/metadata.py +476 -0
- parrot/tools/msteams.py +1621 -0
- parrot/tools/msword.py +635 -0
- parrot/tools/multidb.py +580 -0
- parrot/tools/multistoresearch.py +369 -0
- parrot/tools/networkninja.py +167 -0
- parrot/tools/nextstop/__init__.py +4 -0
- parrot/tools/nextstop/base.py +286 -0
- parrot/tools/nextstop/employee.py +733 -0
- parrot/tools/nextstop/store.py +462 -0
- parrot/tools/notification.py +435 -0
- parrot/tools/o365/__init__.py +42 -0
- parrot/tools/o365/base.py +295 -0
- parrot/tools/o365/bundle.py +522 -0
- parrot/tools/o365/events.py +554 -0
- parrot/tools/o365/mail.py +992 -0
- parrot/tools/o365/onedrive.py +497 -0
- parrot/tools/o365/sharepoint.py +641 -0
- parrot/tools/openapi_toolkit.py +904 -0
- parrot/tools/openweather.py +527 -0
- parrot/tools/pdfprint.py +1001 -0
- parrot/tools/powerbi.py +518 -0
- parrot/tools/powerpoint.py +1113 -0
- parrot/tools/pricestool.py +146 -0
- parrot/tools/products/__init__.py +246 -0
- parrot/tools/prophet_tool.py +171 -0
- parrot/tools/pythonpandas.py +630 -0
- parrot/tools/pythonrepl.py +910 -0
- parrot/tools/qsource.py +436 -0
- parrot/tools/querytoolkit.py +395 -0
- parrot/tools/quickeda.py +827 -0
- parrot/tools/resttool.py +553 -0
- parrot/tools/retail/__init__.py +0 -0
- parrot/tools/retail/bby.py +528 -0
- parrot/tools/sandboxtool.py +703 -0
- parrot/tools/sassie/__init__.py +352 -0
- parrot/tools/scraping/__init__.py +7 -0
- parrot/tools/scraping/docs/select.md +466 -0
- parrot/tools/scraping/documentation.md +1278 -0
- parrot/tools/scraping/driver.py +436 -0
- parrot/tools/scraping/models.py +576 -0
- parrot/tools/scraping/options.py +85 -0
- parrot/tools/scraping/orchestrator.py +517 -0
- parrot/tools/scraping/readme.md +740 -0
- parrot/tools/scraping/tool.py +3115 -0
- parrot/tools/seasonaldetection.py +642 -0
- parrot/tools/shell_tool/__init__.py +5 -0
- parrot/tools/shell_tool/actions.py +408 -0
- parrot/tools/shell_tool/engine.py +155 -0
- parrot/tools/shell_tool/models.py +322 -0
- parrot/tools/shell_tool/tool.py +442 -0
- parrot/tools/site_search.py +214 -0
- parrot/tools/textfile.py +418 -0
- parrot/tools/think.py +378 -0
- parrot/tools/toolkit.py +298 -0
- parrot/tools/webapp_tool.py +187 -0
- parrot/tools/whatif.py +1279 -0
- parrot/tools/workday/MULTI_WSDL_EXAMPLE.md +249 -0
- parrot/tools/workday/__init__.py +6 -0
- parrot/tools/workday/models.py +1389 -0
- parrot/tools/workday/tool.py +1293 -0
- parrot/tools/yfinance_tool.py +306 -0
- parrot/tools/zipcode.py +217 -0
- parrot/utils/__init__.py +2 -0
- parrot/utils/helpers.py +73 -0
- parrot/utils/parsers/__init__.py +5 -0
- parrot/utils/parsers/toml.c +12078 -0
- parrot/utils/parsers/toml.cpython-310-x86_64-linux-gnu.so +0 -0
- parrot/utils/parsers/toml.pyx +21 -0
- parrot/utils/toml.py +11 -0
- parrot/utils/types.cpp +20936 -0
- parrot/utils/types.cpython-310-x86_64-linux-gnu.so +0 -0
- parrot/utils/types.pyx +213 -0
- parrot/utils/uv.py +11 -0
- parrot/version.py +10 -0
- parrot/yaml-rs/Cargo.lock +350 -0
- parrot/yaml-rs/Cargo.toml +19 -0
- parrot/yaml-rs/pyproject.toml +19 -0
- parrot/yaml-rs/python/yaml_rs/__init__.py +81 -0
- parrot/yaml-rs/src/lib.rs +222 -0
- requirements/docker-compose.yml +24 -0
- 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
|