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/models/basic.py
ADDED
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
from typing import Dict, Optional, Any
|
|
2
|
+
from enum import Enum
|
|
3
|
+
from pydantic import BaseModel, Field
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class OutputFormat(Enum):
|
|
7
|
+
"""Supported output formats for structured responses."""
|
|
8
|
+
JSON = "json"
|
|
9
|
+
XML = "xml"
|
|
10
|
+
CSV = "csv"
|
|
11
|
+
YAML = "yaml"
|
|
12
|
+
CODE = "code"
|
|
13
|
+
CUSTOM = "custom"
|
|
14
|
+
TEXT = "text"
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
class ToolCall(BaseModel):
|
|
18
|
+
"""Unified tool call representation."""
|
|
19
|
+
id: str
|
|
20
|
+
name: str
|
|
21
|
+
arguments: Dict[str, Any]
|
|
22
|
+
result: Optional[Any] = None
|
|
23
|
+
error: Optional[str] = None
|
|
24
|
+
execution_time: Optional[float] = None
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
class CompletionUsage(BaseModel):
|
|
28
|
+
"""Unified completion usage tracking across different LLM providers."""
|
|
29
|
+
|
|
30
|
+
# Core usage metrics (common across all providers)
|
|
31
|
+
prompt_tokens: int = 0
|
|
32
|
+
completion_tokens: int = 0
|
|
33
|
+
total_tokens: int = 0
|
|
34
|
+
|
|
35
|
+
# Timing information (optional, provider-specific)
|
|
36
|
+
completion_time: Optional[float] = None
|
|
37
|
+
prompt_time: Optional[float] = None
|
|
38
|
+
queue_time: Optional[float] = None
|
|
39
|
+
total_time: Optional[float] = None
|
|
40
|
+
|
|
41
|
+
# Cost information (optional)
|
|
42
|
+
estimated_cost: Optional[float] = None
|
|
43
|
+
|
|
44
|
+
# Provider-specific additional fields
|
|
45
|
+
extra_usage: Dict[str, Any] = Field(default_factory=dict)
|
|
46
|
+
|
|
47
|
+
@classmethod
|
|
48
|
+
def from_openai(cls, usage: Any) -> "CompletionUsage":
|
|
49
|
+
"""Create from OpenAI usage object."""
|
|
50
|
+
return cls(
|
|
51
|
+
prompt_tokens=getattr(usage, 'prompt_tokens', 0),
|
|
52
|
+
completion_tokens=getattr(usage, 'completion_tokens', 0),
|
|
53
|
+
total_tokens=getattr(usage, 'total_tokens', 0)
|
|
54
|
+
)
|
|
55
|
+
|
|
56
|
+
@classmethod
|
|
57
|
+
def from_groq(cls, usage: Any) -> "CompletionUsage":
|
|
58
|
+
"""Create from Groq usage object."""
|
|
59
|
+
return cls(
|
|
60
|
+
prompt_tokens=getattr(usage, 'prompt_tokens', 0),
|
|
61
|
+
completion_tokens=getattr(usage, 'completion_tokens', 0),
|
|
62
|
+
total_tokens=getattr(usage, 'total_tokens', 0),
|
|
63
|
+
completion_time=getattr(usage, 'completion_time', None),
|
|
64
|
+
prompt_time=getattr(usage, 'prompt_time', None),
|
|
65
|
+
queue_time=getattr(usage, 'queue_time', None),
|
|
66
|
+
total_time=getattr(usage, 'total_time', None)
|
|
67
|
+
)
|
|
68
|
+
|
|
69
|
+
@classmethod
|
|
70
|
+
def from_claude(cls, usage: Dict[str, Any]) -> "CompletionUsage":
|
|
71
|
+
"""Create from Claude usage dict."""
|
|
72
|
+
return cls(
|
|
73
|
+
prompt_tokens=usage.get('input_tokens', 0),
|
|
74
|
+
completion_tokens=usage.get('output_tokens', 0),
|
|
75
|
+
total_tokens=usage.get('input_tokens', 0) + usage.get('output_tokens', 0),
|
|
76
|
+
extra_usage=usage
|
|
77
|
+
)
|
|
78
|
+
|
|
79
|
+
@classmethod
|
|
80
|
+
def from_gemini(cls, usage: Dict[str, Any]) -> "CompletionUsage":
|
|
81
|
+
"""Create from Gemini/Vertex AI usage dict."""
|
|
82
|
+
# Handle both Gemini API format and Vertex AI format
|
|
83
|
+
prompt_tokens = usage.get('prompt_token_count', 0) or usage.get('prompt_tokens', 0)
|
|
84
|
+
completion_tokens = usage.get(
|
|
85
|
+
'candidates_token_count', 0
|
|
86
|
+
) or usage.get('completion_tokens', 0)
|
|
87
|
+
total_tokens = usage.get('total_token_count', 0) or usage.get('total_tokens', 0)
|
|
88
|
+
|
|
89
|
+
return cls(
|
|
90
|
+
prompt_tokens=prompt_tokens,
|
|
91
|
+
completion_tokens=completion_tokens,
|
|
92
|
+
total_tokens=total_tokens,
|
|
93
|
+
extra_usage=usage
|
|
94
|
+
)
|
|
95
|
+
|
|
96
|
+
@classmethod
|
|
97
|
+
def from_grok(cls, usage: Any) -> "CompletionUsage":
|
|
98
|
+
"""Create from Grok usage object."""
|
|
99
|
+
# usage can be a dict or an object
|
|
100
|
+
prompt_tokens = 0
|
|
101
|
+
completion_tokens = 0
|
|
102
|
+
total_tokens = 0
|
|
103
|
+
|
|
104
|
+
if isinstance(usage, dict):
|
|
105
|
+
prompt_tokens = usage.get('prompt_tokens', 0)
|
|
106
|
+
completion_tokens = usage.get('completion_tokens', 0)
|
|
107
|
+
total_tokens = usage.get('total_tokens', 0)
|
|
108
|
+
else:
|
|
109
|
+
prompt_tokens = getattr(usage, 'prompt_tokens', 0)
|
|
110
|
+
completion_tokens = getattr(usage, 'completion_tokens', 0)
|
|
111
|
+
total_tokens = getattr(usage, 'total_tokens', 0)
|
|
112
|
+
|
|
113
|
+
return cls(
|
|
114
|
+
prompt_tokens=prompt_tokens,
|
|
115
|
+
completion_tokens=completion_tokens,
|
|
116
|
+
total_tokens=total_tokens,
|
|
117
|
+
extra_usage=usage if isinstance(usage, dict) else usage.__dict__ if hasattr(usage, '__dict__') else {}
|
|
118
|
+
)
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
from typing import List, Optional, Tuple, Iterable, Set
|
|
2
|
+
from enum import Enum
|
|
3
|
+
import re
|
|
4
|
+
import unicodedata
|
|
5
|
+
from difflib import SequenceMatcher
|
|
6
|
+
from pydantic import BaseModel, Field
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class ComplianceStatus(str, Enum):
|
|
10
|
+
"""Possible compliance statuses for shelf checks"""
|
|
11
|
+
COMPLIANT = "compliant"
|
|
12
|
+
NON_COMPLIANT = "non_compliant"
|
|
13
|
+
MISSING = "missing"
|
|
14
|
+
MISPLACED = "misplaced"
|
|
15
|
+
|
|
16
|
+
# Enhanced compliance result models (add these to your compliance models)
|
|
17
|
+
class TextComplianceResult(BaseModel):
|
|
18
|
+
"""Result of text compliance checking"""
|
|
19
|
+
required_text: str
|
|
20
|
+
found: bool
|
|
21
|
+
matched_features: List[str] = Field(default_factory=list)
|
|
22
|
+
confidence: float
|
|
23
|
+
match_type: str
|
|
24
|
+
|
|
25
|
+
class BrandComplianceResult(BaseModel):
|
|
26
|
+
"""Result of brand logo compliance checking"""
|
|
27
|
+
expected_brand: str
|
|
28
|
+
found_brand: Optional[str] = None
|
|
29
|
+
found: bool = False
|
|
30
|
+
confidence: float = 0.0
|
|
31
|
+
|
|
32
|
+
class ComplianceResult(BaseModel):
|
|
33
|
+
"""Final compliance check result"""
|
|
34
|
+
shelf_level: str = Field(description="Shelf level being checked")
|
|
35
|
+
expected_products: List[str] = Field(description="Products expected on this shelf")
|
|
36
|
+
found_products: List[str] = Field(description="Products actually found")
|
|
37
|
+
missing_products: List[str] = Field(description="Expected but not found")
|
|
38
|
+
unexpected_products: List[str] = Field(description="Found but not expected")
|
|
39
|
+
compliance_status: ComplianceStatus = Field(
|
|
40
|
+
description="Overall compliance for this shelf"
|
|
41
|
+
)
|
|
42
|
+
compliance_score: float = Field(
|
|
43
|
+
ge=0.0,
|
|
44
|
+
le=1.0,
|
|
45
|
+
description="Compliance score"
|
|
46
|
+
)
|
|
47
|
+
text_compliance_results: List[TextComplianceResult] = Field(default_factory=list)
|
|
48
|
+
brand_compliance_result: Optional[BrandComplianceResult] = Field(
|
|
49
|
+
None, description="Result of the brand logo compliance check."
|
|
50
|
+
)
|
|
51
|
+
text_compliance_score: float = Field(default=1.0)
|
|
52
|
+
overall_text_compliant: bool = Field(default=True)
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
class TextMatcher:
|
|
56
|
+
"""
|
|
57
|
+
N-gram + fuzzy text matcher for planogram text compliance.
|
|
58
|
+
|
|
59
|
+
Public API:
|
|
60
|
+
TextMatcher.check_text_match(
|
|
61
|
+
required_text: str,
|
|
62
|
+
visual_features: List[str],
|
|
63
|
+
match_type: str = "contains", # "contains" | "regex" | "ngram" | "auto"
|
|
64
|
+
case_sensitive: bool = False,
|
|
65
|
+
confidence_threshold: float = 0.6, # used for "ngram"/"auto"
|
|
66
|
+
ngram_range: Tuple[int, int] = (1, 3),
|
|
67
|
+
min_token_len: int = 2,
|
|
68
|
+
) -> TextComplianceResult
|
|
69
|
+
"""
|
|
70
|
+
|
|
71
|
+
@staticmethod
|
|
72
|
+
def _strip_ocr_prefix(s: str) -> str:
|
|
73
|
+
return s[4:].strip() if isinstance(s, str) and s.lower().startswith("ocr:") else s
|
|
74
|
+
|
|
75
|
+
@staticmethod
|
|
76
|
+
def _normalize(s: str, *, keep_case: bool = False) -> str:
|
|
77
|
+
if s is None:
|
|
78
|
+
return ""
|
|
79
|
+
s = TextMatcher._strip_ocr_prefix(s)
|
|
80
|
+
# de-accent
|
|
81
|
+
s = unicodedata.normalize("NFKD", s)
|
|
82
|
+
s = "".join(ch for ch in s if not unicodedata.combining(ch))
|
|
83
|
+
if not keep_case:
|
|
84
|
+
s = s.lower()
|
|
85
|
+
# keep letters/digits/space
|
|
86
|
+
s = re.sub(r"[^0-9a-zA-Z]+", " ", s)
|
|
87
|
+
# collapse whitespace
|
|
88
|
+
s = re.sub(r"\s+", " ", s).strip()
|
|
89
|
+
return s
|
|
90
|
+
|
|
91
|
+
@staticmethod
|
|
92
|
+
def _tokenize(s: str, min_len: int = 2) -> List[str]:
|
|
93
|
+
return [t for t in s.split() if len(t) >= min_len]
|
|
94
|
+
|
|
95
|
+
@staticmethod
|
|
96
|
+
def _ngrams(tokens: List[str], n_from: int, n_to: int) -> Set[str]:
|
|
97
|
+
grams: Set[str] = set()
|
|
98
|
+
for n in range(max(1, n_from), max(n_from, n_to) + 1):
|
|
99
|
+
for i in range(0, max(0, len(tokens) - n + 1)):
|
|
100
|
+
grams.add(" ".join(tokens[i:i+n]))
|
|
101
|
+
return grams
|
|
102
|
+
|
|
103
|
+
@staticmethod
|
|
104
|
+
def _jaccard(a: Set[str], b: Set[str]) -> float:
|
|
105
|
+
if not a or not b:
|
|
106
|
+
return 0.0
|
|
107
|
+
inter = len(a & b)
|
|
108
|
+
if inter == 0:
|
|
109
|
+
return 0.0
|
|
110
|
+
union = len(a | b)
|
|
111
|
+
return inter / max(1, union)
|
|
112
|
+
|
|
113
|
+
@staticmethod
|
|
114
|
+
def _best_ngram_hits(req_grams: Set[str], feat_grams: Set[str], top_k: int = 5) -> List[str]:
|
|
115
|
+
hits = list(req_grams & feat_grams)
|
|
116
|
+
# sort by length desc to surface most informative matches
|
|
117
|
+
hits.sort(key=lambda x: (-len(x), x))
|
|
118
|
+
return hits[:top_k]
|
|
119
|
+
|
|
120
|
+
@classmethod
|
|
121
|
+
def check_text_match(
|
|
122
|
+
cls,
|
|
123
|
+
required_text: str,
|
|
124
|
+
visual_features: List[str],
|
|
125
|
+
match_type: str = "contains", # "contains" | "regex" | "ngram" | "auto"
|
|
126
|
+
case_sensitive: bool = False,
|
|
127
|
+
confidence_threshold: float = 0.6, # only used by ngram/auto
|
|
128
|
+
ngram_range: Tuple[int, int] = (1, 3),
|
|
129
|
+
min_token_len: int = 2,
|
|
130
|
+
):
|
|
131
|
+
# Normalize the required text for all algorithms except strict case-sensitive contains/regex
|
|
132
|
+
req_norm = cls._normalize(required_text, keep_case=False)
|
|
133
|
+
req_norm_cs = cls._normalize(required_text, keep_case=True)
|
|
134
|
+
req_tokens = cls._tokenize(req_norm, min_len=min_token_len)
|
|
135
|
+
req_grams = cls._ngrams(req_tokens, ngram_range[0], ngram_range[1])
|
|
136
|
+
|
|
137
|
+
# Normalize all feature strings; keep both raw and normalized for substring/case options
|
|
138
|
+
norm_features: List[str] = []
|
|
139
|
+
raw_features: List[str] = []
|
|
140
|
+
for f in (visual_features or []):
|
|
141
|
+
if not isinstance(f, str):
|
|
142
|
+
continue
|
|
143
|
+
raw_features.append(cls._strip_ocr_prefix(f))
|
|
144
|
+
norm_features.append(cls._normalize(f, keep_case=False))
|
|
145
|
+
|
|
146
|
+
# Helper to build the result
|
|
147
|
+
def _result(found: bool, confidence: float, match_kind: str, matched_feats: List[str]):
|
|
148
|
+
# TextComplianceResult(required_text, found, matched_features, confidence, match_type)
|
|
149
|
+
return TextComplianceResult(
|
|
150
|
+
required_text=required_text,
|
|
151
|
+
found=bool(found),
|
|
152
|
+
matched_features=matched_feats,
|
|
153
|
+
confidence=float(max(0.0, min(1.0, confidence))),
|
|
154
|
+
match_type=match_kind
|
|
155
|
+
)
|
|
156
|
+
|
|
157
|
+
# ----- 1) Regex (if explicitly requested)
|
|
158
|
+
if match_type == "regex":
|
|
159
|
+
flags = 0 if case_sensitive else re.IGNORECASE
|
|
160
|
+
try:
|
|
161
|
+
pattern = re.compile(required_text, flags)
|
|
162
|
+
except re.error:
|
|
163
|
+
# fall back to auto if invalid regex
|
|
164
|
+
match_type = "auto"
|
|
165
|
+
else:
|
|
166
|
+
for raw in raw_features:
|
|
167
|
+
if pattern.search(raw):
|
|
168
|
+
return _result(True, 1.0, "regex", [raw])
|
|
169
|
+
return _result(False, 0.0, "regex", [])
|
|
170
|
+
|
|
171
|
+
# ----- 2) Contains (fast path)
|
|
172
|
+
if match_type == "contains":
|
|
173
|
+
needle = req_norm_cs if case_sensitive else req_norm
|
|
174
|
+
for raw, norm in zip(raw_features, norm_features):
|
|
175
|
+
haystack = raw if case_sensitive else norm
|
|
176
|
+
if needle and needle in haystack:
|
|
177
|
+
return _result(True, 1.0, "contains", [needle])
|
|
178
|
+
return _result(False, 0.0, "contains", [])
|
|
179
|
+
|
|
180
|
+
# ----- 3) N-gram / Auto (n-gram + fuzzy + contains fallback)
|
|
181
|
+
# quick exact-substring fallback (case-insensitive)
|
|
182
|
+
for raw, norm in zip(raw_features, norm_features):
|
|
183
|
+
if req_norm and req_norm in norm:
|
|
184
|
+
return _result(True, 1.0, "contains", [required_text])
|
|
185
|
+
|
|
186
|
+
best_conf = 0.0
|
|
187
|
+
best_hits: List[str] = []
|
|
188
|
+
best_kind = "ngram"
|
|
189
|
+
|
|
190
|
+
for raw, norm in zip(raw_features, norm_features):
|
|
191
|
+
# n-gram containment
|
|
192
|
+
feat_tokens = cls._tokenize(norm, min_len=min_token_len)
|
|
193
|
+
feat_grams = cls._ngrams(feat_tokens, ngram_range[0], ngram_range[1])
|
|
194
|
+
jacc = cls._jaccard(req_grams, feat_grams)
|
|
195
|
+
|
|
196
|
+
# fuzzy ratio (sequence similarity)
|
|
197
|
+
fuzzy = SequenceMatcher(None, req_norm, norm).ratio()
|
|
198
|
+
|
|
199
|
+
conf = max(jacc, fuzzy)
|
|
200
|
+
if conf > best_conf:
|
|
201
|
+
best_conf = conf
|
|
202
|
+
# collect some concrete n-gram hits for debugging
|
|
203
|
+
hits = cls._best_ngram_hits(req_grams, feat_grams, top_k=5)
|
|
204
|
+
best_hits = hits if hits else ([required_text] if conf >= 1.0 else [])
|
|
205
|
+
best_kind = "ngram" if jacc >= fuzzy else "fuzzy"
|
|
206
|
+
|
|
207
|
+
found = best_conf >= confidence_threshold
|
|
208
|
+
return _result(found, best_conf, best_kind, best_hits)
|