@johpaz/hive-agents 0.0.35 → 0.0.37
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.
- package/README.md +64 -39
- package/dist/hive.js +3231 -3189
- package/dist/tool-worker.js +218406 -0
- package/dist/ui/assets/{AgentCreateForm-B4eK7efF.js → AgentCreateForm-tJZv9FZC.js} +1 -1
- package/dist/ui/assets/{AgentDetailPage-BD2uoJWk.js → AgentDetailPage-Du-mRcAX.js} +1 -1
- package/dist/ui/assets/AgentNewPage-DIFYd_Ys.js +1 -0
- package/dist/ui/assets/{AgentsPage-4JUZXvkA.js → AgentsPage-YvSgWRiw.js} +6 -6
- package/dist/ui/assets/CanvasPage-DtMwGvxf.js +33 -0
- package/dist/ui/assets/{ChannelsPage-BUn7-nhV.js → ChannelsPage-BdBXWHjj.js} +1 -1
- package/dist/ui/assets/DashboardPage-ghl1ZguH.js +6 -0
- package/dist/ui/assets/{LoginPage-C8j_urUD.js → LoginPage-CAmSI9Vy.js} +1 -1
- package/dist/ui/assets/LogsPage-DAPBHkwK.js +1 -0
- package/dist/ui/assets/MeetingPage-WjjGOqqU.js +1 -0
- package/dist/ui/assets/{NotFound-Drh-sJPN.js → NotFound-BMeQSGcG.js} +1 -1
- package/dist/ui/assets/ProvidersPage-Ct6HsAi1.js +1 -0
- package/dist/ui/assets/{RecoverPage-DNb1Pr8h.js → RecoverPage-DpW3l-yv.js} +1 -1
- package/dist/ui/assets/SettingsPage-DBJ7_E6C.js +9 -0
- package/dist/ui/assets/SetupPage-DKmLVUaj.js +1 -0
- package/dist/ui/assets/{WebChatPage-R-YOwA4F.js → WebChatPage-CVRcKept.js} +2 -2
- package/dist/ui/assets/accordion-C5d5Rm5z.js +1 -0
- package/dist/ui/assets/{alert-U8FsgWi7.js → alert-C-NE-P3s.js} +1 -1
- package/dist/ui/assets/{alert-dialog-CRdMkkmk.js → alert-dialog-C5mzbHdP.js} +1 -1
- package/dist/ui/assets/{badge-Cli1jnH5.js → badge-ChpACfWO.js} +1 -1
- package/dist/ui/assets/chevron-up-BYhk0K2J.js +1 -0
- package/dist/ui/assets/{dialog-DQ3s-LuO.js → dialog-QnZ0ad8O.js} +1 -1
- package/dist/ui/assets/dropdown-menu-BK-CO3Od.js +1 -0
- package/dist/ui/assets/{es-DcMjrpbA.js → es-NQNoaWDx.js} +1 -1
- package/dist/ui/assets/index-B2fCYtTS.css +2 -0
- package/dist/ui/assets/index-DMCjjdqf.js +116 -0
- package/dist/ui/assets/{label-0BvGVXvZ.js → label-D2H1IR_J.js} +1 -1
- package/dist/ui/assets/progress-BherYzY6.js +1 -0
- package/dist/ui/assets/scroll-area-DkeyX32e.js +1 -0
- package/dist/ui/assets/{slider-D47dOrRa.js → slider-CsiUDxc3.js} +1 -1
- package/dist/ui/assets/switch-BDwN8RYV.js +1 -0
- package/dist/ui/assets/{table-DhowbNxQ.js → table-CSc8ubon.js} +1 -1
- package/dist/ui/assets/terminal-DN38Q456.js +1 -0
- package/dist/ui/assets/useProviders-C6_QHsEi.js +1 -0
- package/dist/ui/assets/{vendor-radix-JY4ncZrD.js → vendor-radix-cw1bQaVC.js} +4 -4
- package/dist/ui/assets/{vendor-react-CscwQerf.js → vendor-react-D4s9E-zj.js} +1 -1
- package/dist/ui/dist/assets/AgentCreateForm-tJZv9FZC.js +1 -0
- package/dist/ui/dist/assets/AgentDetailPage-Du-mRcAX.js +1 -0
- package/dist/ui/dist/assets/AgentNewPage-DIFYd_Ys.js +1 -0
- package/dist/ui/dist/assets/AgentsPage-YvSgWRiw.js +10 -0
- package/dist/ui/dist/assets/CanvasPage-DtMwGvxf.js +33 -0
- package/dist/ui/dist/assets/ChannelsPage-BdBXWHjj.js +8 -0
- package/dist/ui/dist/assets/DashboardPage-ghl1ZguH.js +6 -0
- package/dist/ui/dist/assets/LoginPage-CAmSI9Vy.js +1 -0
- package/dist/ui/dist/assets/LogsPage-DAPBHkwK.js +1 -0
- package/dist/ui/dist/assets/MeetingPage-WjjGOqqU.js +1 -0
- package/dist/ui/dist/assets/NotFound-BMeQSGcG.js +1 -0
- package/dist/ui/dist/assets/ProvidersPage-Ct6HsAi1.js +1 -0
- package/dist/ui/dist/assets/RecoverPage-DpW3l-yv.js +1 -0
- package/dist/ui/dist/assets/SettingsPage-DBJ7_E6C.js +9 -0
- package/dist/ui/dist/assets/SetupPage-DKmLVUaj.js +1 -0
- package/dist/ui/dist/assets/WebChatPage-CVRcKept.js +16 -0
- package/dist/ui/dist/assets/accordion-C5d5Rm5z.js +1 -0
- package/dist/ui/dist/assets/activity-c3pNngT_.js +1 -0
- package/dist/ui/dist/assets/alert-C-NE-P3s.js +1 -0
- package/dist/ui/dist/assets/alert-dialog-C5mzbHdP.js +1 -0
- package/dist/ui/dist/assets/arrow-left-CBcbX5EZ.js +1 -0
- package/dist/ui/dist/assets/badge-ChpACfWO.js +1 -0
- package/dist/ui/dist/assets/calendar-B-KZ9RQO.js +1 -0
- package/dist/ui/dist/assets/card-CNf6BS2e.js +1 -0
- package/dist/ui/dist/assets/chevron-left-D4U-5A27.js +1 -0
- package/dist/ui/dist/assets/chevron-right-CR4Skrf3.js +1 -0
- package/dist/ui/dist/assets/chevron-up-BYhk0K2J.js +1 -0
- package/dist/ui/dist/assets/circle-alert-CyHDwUj8.js +1 -0
- package/dist/ui/dist/assets/circle-check-Bb54Ebmu.js +1 -0
- package/dist/ui/dist/assets/cpu-Cdgc_B1K.js +1 -0
- package/dist/ui/dist/assets/dialog-QnZ0ad8O.js +1 -0
- package/dist/ui/dist/assets/download-C3ifGMjJ.js +1 -0
- package/dist/ui/dist/assets/dropdown-menu-BK-CO3Od.js +1 -0
- package/dist/ui/dist/assets/es-NQNoaWDx.js +1 -0
- package/dist/ui/dist/assets/external-link-BvxYeTP1.js +1 -0
- package/dist/ui/dist/assets/eye-DqNTU_GD.js +1 -0
- package/dist/ui/dist/assets/file-text-BT_9S9SM.js +1 -0
- package/dist/ui/dist/assets/folder-open-BhH8y9ac.js +1 -0
- package/dist/ui/dist/assets/format-GVHeOyWI.js +1 -0
- package/dist/ui/dist/assets/gateway-url-COCbW0IR.js +1 -0
- package/dist/ui/dist/assets/gauge-D_TMa4i9.js +1 -0
- package/dist/ui/dist/assets/globe-DeCQTCDJ.js +1 -0
- package/dist/ui/dist/assets/hexagon-DsGOUl-H.js +1 -0
- package/dist/ui/dist/assets/history-BSG-Ypqf.js +1 -0
- package/dist/ui/dist/assets/index-B2fCYtTS.css +2 -0
- package/dist/ui/dist/assets/index-DMCjjdqf.js +116 -0
- package/dist/ui/dist/assets/info-NwLoa2Mj.js +1 -0
- package/dist/ui/dist/assets/key-3EP0dhkT.js +1 -0
- package/dist/ui/dist/assets/label-D2H1IR_J.js +1 -0
- package/dist/ui/dist/assets/loader-circle-CZNax6kS.js +1 -0
- package/dist/ui/dist/assets/lock-Ei1_J-Nq.js +1 -0
- package/dist/ui/dist/assets/pause-BUqah9Bi.js +1 -0
- package/dist/ui/dist/assets/play-NcZ4swwL.js +1 -0
- package/dist/ui/dist/assets/plus-CX1xyhp5.js +1 -0
- package/dist/ui/dist/assets/progress-BherYzY6.js +1 -0
- package/dist/ui/dist/assets/refresh-cw-DaYdjQFk.js +1 -0
- package/dist/ui/dist/assets/rolldown-runtime-S-ySWqyJ.js +1 -0
- package/dist/ui/dist/assets/save-CUdYyHNy.js +1 -0
- package/dist/ui/dist/assets/scroll-area-DkeyX32e.js +1 -0
- package/dist/ui/dist/assets/send-B0H5SEIE.js +1 -0
- package/dist/ui/dist/assets/settings-Ds4SqD8s.js +1 -0
- package/dist/ui/dist/assets/slider-CsiUDxc3.js +14 -0
- package/dist/ui/dist/assets/sparkles-yUEb-7oH.js +1 -0
- package/dist/ui/dist/assets/square-BD81nFtN.js +1 -0
- package/dist/ui/dist/assets/switch-BDwN8RYV.js +1 -0
- package/dist/ui/dist/assets/table-CSc8ubon.js +1 -0
- package/dist/ui/dist/assets/terminal-DN38Q456.js +1 -0
- package/dist/ui/dist/assets/textarea-CXgXWKrT.js +1 -0
- package/dist/ui/dist/assets/trash-2-CNjMkoq6.js +1 -0
- package/dist/ui/dist/assets/triangle-alert-C9Y8Ub4X.js +1 -0
- package/dist/ui/dist/assets/useProviders-C6_QHsEi.js +1 -0
- package/dist/ui/dist/assets/utils-3pnRFmFe.js +1 -0
- package/dist/ui/dist/assets/vendor-charts-Bu2lyBKP.js +65 -0
- package/dist/ui/dist/assets/vendor-query-DsWPbQdG.js +1 -0
- package/dist/ui/dist/assets/vendor-radix-cw1bQaVC.js +63 -0
- package/dist/ui/dist/assets/vendor-react-D4s9E-zj.js +1 -0
- package/dist/ui/dist/assets/vendor-router-C9pIYwbJ.js +3 -0
- package/dist/ui/dist/assets/volume-2-CeSXNDv4.js +1 -0
- package/dist/ui/dist/assets/zap-hlXjpSeA.js +1 -0
- package/dist/ui/dist/favicon.ico +0 -0
- package/dist/ui/dist/index.html +40 -0
- package/dist/ui/dist/placeholder.svg +1 -0
- package/dist/ui/index.html +6 -6
- package/package.json +138 -13
- package/packages/cli/src/adapters/binary.ts +461 -0
- package/packages/cli/src/adapters/bun-global.ts +378 -0
- package/packages/cli/src/adapters/config.ts +314 -0
- package/packages/cli/src/adapters/docker.ts +308 -0
- package/packages/cli/src/adapters/factory.ts +168 -0
- package/packages/cli/src/adapters/index.ts +80 -0
- package/packages/cli/src/adapters/types.ts +218 -0
- package/packages/cli/src/commands/agent-run.ts +168 -0
- package/packages/cli/src/commands/agents.ts +398 -0
- package/packages/cli/src/commands/chat.ts +142 -0
- package/packages/cli/src/commands/config.ts +49 -0
- package/packages/cli/src/commands/cron.ts +487 -0
- package/packages/cli/src/commands/dev.ts +58 -0
- package/packages/cli/src/commands/doctor.ts +320 -0
- package/packages/cli/src/commands/gateway.ts +719 -0
- package/packages/cli/src/commands/logs.ts +57 -0
- package/packages/cli/src/commands/mcp.ts +175 -0
- package/packages/cli/src/commands/message.ts +77 -0
- package/packages/cli/src/commands/migrate.ts +90 -0
- package/packages/cli/src/commands/onboard.ts +1656 -0
- package/packages/cli/src/commands/security.ts +144 -0
- package/packages/cli/src/commands/service.ts +50 -0
- package/packages/cli/src/commands/sessions.ts +116 -0
- package/packages/cli/src/commands/skills.ts +215 -0
- package/packages/cli/src/commands/update.ts +203 -0
- package/packages/cli/src/index.ts +210 -0
- package/packages/cli/src/ui-bundle.generated.ts +3 -0
- package/packages/cli/src/utils/token.ts +6 -0
- package/packages/core/src/agent/agent-loop.ts +691 -0
- package/packages/core/src/agent/compaction.ts +240 -0
- package/packages/core/src/agent/context-compiler.ts +467 -0
- package/packages/core/src/agent/context-guard.ts +91 -0
- package/packages/core/src/agent/conversation-store.ts +244 -0
- package/packages/core/src/agent/curator.ts +158 -0
- package/packages/core/src/agent/hooks.ts +166 -0
- package/packages/core/src/agent/llm-client.ts +167 -0
- package/packages/core/src/agent/llm-providers/anthropic.ts +212 -0
- package/packages/core/src/agent/llm-providers/deepseek.ts +8 -0
- package/packages/core/src/agent/llm-providers/gemini.ts +215 -0
- package/packages/core/src/agent/llm-providers/groq.ts +5 -0
- package/packages/core/src/agent/llm-providers/interface.ts +195 -0
- package/packages/core/src/agent/llm-providers/kimi.ts +8 -0
- package/packages/core/src/agent/llm-providers/local-llama.ts +37 -0
- package/packages/core/src/agent/llm-providers/mistral.ts +5 -0
- package/packages/core/src/agent/llm-providers/nvidia.ts +5 -0
- package/packages/core/src/agent/llm-providers/ollama.ts +175 -0
- package/packages/core/src/agent/llm-providers/openai-compat-base.ts +379 -0
- package/packages/core/src/agent/llm-providers/openai.ts +5 -0
- package/packages/core/src/agent/llm-providers/openrouter.ts +5 -0
- package/packages/core/src/agent/llm-providers/qwen.ts +5 -0
- package/packages/core/src/agent/native-tools.ts +31 -0
- package/packages/core/src/agent/playbook-selector.ts +147 -0
- package/packages/core/src/agent/prompt-builder.ts +169 -0
- package/packages/core/src/agent/providers/index.ts +204 -0
- package/packages/core/src/agent/providers.ts +1 -0
- package/packages/core/src/agent/reflector.ts +200 -0
- package/packages/core/src/agent/service.ts +267 -0
- package/packages/core/src/agent/skill-selector.ts +479 -0
- package/packages/core/src/agent/stuck-loop.ts +133 -0
- package/packages/core/src/agent/tool-selector.ts +569 -0
- package/packages/core/src/agent/tracer.ts +100 -0
- package/packages/core/src/auth/auth.ts +108 -0
- package/packages/core/src/auth/index.ts +1 -0
- package/packages/core/src/canvas/a2ui-tools.ts +255 -0
- package/packages/core/src/canvas/canvas-manager.ts +390 -0
- package/packages/core/src/canvas/canvas-tools.ts +448 -0
- package/packages/core/src/canvas/emitter.ts +149 -0
- package/packages/core/src/canvas/index.ts +3 -0
- package/packages/core/src/channels/base.ts +154 -0
- package/packages/core/src/channels/discord.ts +273 -0
- package/packages/core/src/channels/index.ts +7 -0
- package/packages/core/src/channels/manager.ts +450 -0
- package/packages/core/src/channels/slack.ts +323 -0
- package/packages/core/src/channels/telegram.ts +612 -0
- package/packages/core/src/channels/webchat.ts +139 -0
- package/packages/core/src/channels/whatsapp.ts +548 -0
- package/packages/core/src/config/index.ts +12 -0
- package/packages/core/src/config/loader.ts +569 -0
- package/packages/core/src/events/agent-bus.ts +460 -0
- package/packages/core/src/events/event-bus.ts +169 -0
- package/packages/core/src/gateway/channel-notify.ts +64 -0
- package/packages/core/src/gateway/helpers/cors.ts +32 -0
- package/packages/core/src/gateway/helpers/index.ts +4 -0
- package/packages/core/src/gateway/helpers/narration.ts +57 -0
- package/packages/core/src/gateway/helpers/path.ts +13 -0
- package/packages/core/src/gateway/helpers/redact.ts +61 -0
- package/packages/core/src/gateway/index.ts +5 -0
- package/packages/core/src/gateway/initializer.ts +363 -0
- package/packages/core/src/gateway/lane-queue.ts +169 -0
- package/packages/core/src/gateway/llm-local/client.ts +94 -0
- package/packages/core/src/gateway/llm-local/detector.ts +321 -0
- package/packages/core/src/gateway/llm-local/downloader.ts +216 -0
- package/packages/core/src/gateway/llm-local/index.ts +34 -0
- package/packages/core/src/gateway/llm-local/manager.ts +186 -0
- package/packages/core/src/gateway/llm-local/models.ts +149 -0
- package/packages/core/src/gateway/llm-local/server.ts +179 -0
- package/packages/core/src/gateway/resolver.ts +108 -0
- package/packages/core/src/gateway/router.ts +124 -0
- package/packages/core/src/gateway/routes/agents.ts +210 -0
- package/packages/core/src/gateway/routes/auth.ts +244 -0
- package/packages/core/src/gateway/routes/channels.ts +484 -0
- package/packages/core/src/gateway/routes/chat.ts +241 -0
- package/packages/core/src/gateway/routes/config.ts +12 -0
- package/packages/core/src/gateway/routes/cron-api.ts +544 -0
- package/packages/core/src/gateway/routes/ethics.ts +46 -0
- package/packages/core/src/gateway/routes/llm-local.ts +271 -0
- package/packages/core/src/gateway/routes/mcp.ts +319 -0
- package/packages/core/src/gateway/routes/meeting.ts +232 -0
- package/packages/core/src/gateway/routes/models.ts +163 -0
- package/packages/core/src/gateway/routes/multimodal.ts +93 -0
- package/packages/core/src/gateway/routes/providers.ts +220 -0
- package/packages/core/src/gateway/routes/setup.ts +441 -0
- package/packages/core/src/gateway/routes/skills.ts +115 -0
- package/packages/core/src/gateway/routes/system.ts +469 -0
- package/packages/core/src/gateway/routes/tasks.ts +44 -0
- package/packages/core/src/gateway/routes/tools.ts +59 -0
- package/packages/core/src/gateway/routes/tts-local.ts +388 -0
- package/packages/core/src/gateway/routes/users.ts +122 -0
- package/packages/core/src/gateway/routes/voice.ts +189 -0
- package/packages/core/src/gateway/routes/workspace.ts +281 -0
- package/packages/core/src/gateway/server.ts +2744 -0
- package/packages/core/src/gateway/session.ts +95 -0
- package/packages/core/src/gateway/slash-commands.ts +207 -0
- package/packages/core/src/gateway/tts/README.md +94 -0
- package/packages/core/src/gateway/tts/package.json +25 -0
- package/packages/core/src/gateway/tts/src/client.ts +59 -0
- package/packages/core/src/gateway/tts/src/detect.ts +42 -0
- package/packages/core/src/gateway/tts/src/index.ts +15 -0
- package/packages/core/src/gateway/tts/src/install.ts +129 -0
- package/packages/core/src/gateway/tts/src/models.ts +50 -0
- package/packages/core/src/gateway/tts/src/server.ts +252 -0
- package/packages/core/src/gateway/tts/voices/.gitkeep +0 -0
- package/packages/core/src/heartbeat/index.ts +157 -0
- package/packages/core/src/index.ts +56 -0
- package/packages/core/src/mcp/hot-reload.ts +148 -0
- package/packages/core/src/mcp/singleton.ts +21 -0
- package/packages/core/src/mcp/tool-sync.ts +176 -0
- package/packages/core/src/multimodal/index.ts +2 -0
- package/packages/core/src/multimodal/types.ts +28 -0
- package/packages/core/src/multimodal/vision-service.ts +283 -0
- package/packages/core/src/plugins/api.ts +128 -0
- package/packages/core/src/plugins/index.ts +2 -0
- package/packages/core/src/plugins/loader.ts +365 -0
- package/packages/core/src/resilience/circuit-breaker.ts +225 -0
- package/packages/core/src/scheduler/CronScheduler.ts +699 -0
- package/packages/core/src/scheduler/dag/AgentExecutor.ts +53 -0
- package/packages/core/src/scheduler/dag/DAGScheduler.ts +250 -0
- package/packages/core/src/scheduler/dag/EventBridge.ts +122 -0
- package/packages/core/src/scheduler/dag/TaskGraph.ts +192 -0
- package/packages/core/src/scheduler/dag/TaskNode.ts +97 -0
- package/packages/core/src/scheduler/dag/TaskResult.ts +22 -0
- package/packages/core/src/scheduler/dag/errors.ts +37 -0
- package/packages/core/src/scheduler/dag/index.ts +26 -0
- package/packages/core/src/scheduler/dag/presets/ResearchPreset.ts +97 -0
- package/packages/core/src/scheduler/dag/strategies/ParallelStrategy.ts +21 -0
- package/packages/core/src/scheduler/dag/strategies/PriorityStrategy.ts +46 -0
- package/packages/core/src/scheduler/index.ts +22 -0
- package/packages/core/src/scheduler/integration.ts +237 -0
- package/packages/core/src/scheduler/types.ts +164 -0
- package/packages/core/src/security/google-chat.ts +269 -0
- package/packages/core/src/security/index.ts +192 -0
- package/packages/core/src/security/pairing.ts +250 -0
- package/packages/core/src/security/rate-limit.ts +270 -0
- package/packages/core/src/security/signal.ts +321 -0
- package/packages/core/src/state/store.ts +312 -0
- package/packages/core/src/storage/crypto.ts +197 -0
- package/packages/core/src/storage/migrate.ts +147 -0
- package/packages/core/src/storage/onboarding.ts +1506 -0
- package/packages/core/src/storage/schema.ts +666 -0
- package/packages/core/src/storage/seed.ts +628 -0
- package/packages/core/src/storage/sqlite.ts +407 -0
- package/packages/core/src/storage/usage.ts +374 -0
- package/packages/core/src/tool-runtime/index.ts +502 -0
- package/packages/core/src/tool-runtime/tool-worker.ts +125 -0
- package/packages/core/src/tools/agents/get-available-models.ts +118 -0
- package/packages/core/src/tools/agents/index.ts +610 -0
- package/packages/core/src/tools/canvas/index.ts +420 -0
- package/packages/core/src/tools/cli/index.ts +142 -0
- package/packages/core/src/tools/core/index.ts +478 -0
- package/packages/core/src/tools/cron/index.ts +635 -0
- package/packages/core/src/tools/filesystem/fs-delete.ts +78 -0
- package/packages/core/src/tools/filesystem/fs-edit.ts +106 -0
- package/packages/core/src/tools/filesystem/fs-exists.ts +63 -0
- package/packages/core/src/tools/filesystem/fs-glob.ts +108 -0
- package/packages/core/src/tools/filesystem/fs-list.ts +129 -0
- package/packages/core/src/tools/filesystem/fs-read.ts +72 -0
- package/packages/core/src/tools/filesystem/fs-write.ts +67 -0
- package/packages/core/src/tools/filesystem/index.ts +34 -0
- package/packages/core/src/tools/filesystem/workspace-guard.ts +62 -0
- package/packages/core/src/tools/index.ts +197 -0
- package/packages/core/src/tools/meeting/index.ts +363 -0
- package/packages/core/src/tools/office/index.ts +47 -0
- package/packages/core/src/tools/office/office-escribir-docx.ts +192 -0
- package/packages/core/src/tools/office/office-escribir-pdf.ts +172 -0
- package/packages/core/src/tools/office/office-escribir-pptx.ts +174 -0
- package/packages/core/src/tools/office/office-escribir-xlsx.ts +116 -0
- package/packages/core/src/tools/office/office-leer-docx.ts +93 -0
- package/packages/core/src/tools/office/office-leer-pdf.ts +114 -0
- package/packages/core/src/tools/office/office-leer-pptx.ts +136 -0
- package/packages/core/src/tools/office/office-leer-xlsx.ts +124 -0
- package/packages/core/src/tools/types.ts +39 -0
- package/packages/core/src/tools/voice/index.ts +104 -0
- package/packages/core/src/tools/web/browser-click.ts +78 -0
- package/packages/core/src/tools/web/browser-extract.ts +139 -0
- package/packages/core/src/tools/web/browser-navigate.ts +106 -0
- package/packages/core/src/tools/web/browser-screenshot.ts +87 -0
- package/packages/core/src/tools/web/browser-script.ts +88 -0
- package/packages/core/src/tools/web/browser-service.ts +554 -0
- package/packages/core/src/tools/web/browser-type.ts +101 -0
- package/packages/core/src/tools/web/browser-wait.ts +136 -0
- package/packages/core/src/tools/web/index.ts +41 -0
- package/packages/core/src/tools/web/web-fetch.ts +78 -0
- package/packages/core/src/tools/web/web-search.ts +123 -0
- package/packages/core/src/utils/benchmark.ts +80 -0
- package/packages/core/src/utils/crypto.ts +73 -0
- package/packages/core/src/utils/date.ts +42 -0
- package/packages/core/src/utils/index.ts +5 -0
- package/packages/core/src/utils/logger.ts +389 -0
- package/packages/core/src/utils/retry.ts +70 -0
- package/packages/core/src/utils/toon.ts +253 -0
- package/packages/core/src/voice/index.ts +643 -0
- package/packages/mcp/src/config.ts +13 -0
- package/packages/mcp/src/index.ts +1 -0
- package/packages/mcp/src/logger.ts +47 -0
- package/packages/mcp/src/manager.ts +439 -0
- package/packages/mcp/src/transports/index.ts +67 -0
- package/packages/mcp/src/transports/sse.ts +238 -0
- package/packages/mcp/src/transports/websocket.ts +159 -0
- package/packages/skills/src/bundled/agents/agent_spawner/SKILL.md +167 -0
- package/packages/skills/src/bundled/agents/code_delegator/SKILL.md +156 -0
- package/packages/skills/src/bundled/agents/memory_manager/SKILL.md +143 -0
- package/packages/skills/src/bundled/agents/research_and_remember/SKILL.md +139 -0
- package/packages/skills/src/bundled/agents/task_orchestrator/SKILL.md +198 -0
- package/packages/skills/src/bundled/canvas/a2ui_dashboard/SKILL.md +176 -0
- package/packages/skills/src/bundled/canvas/a2ui_form/SKILL.md +202 -0
- package/packages/skills/src/bundled/canvas/a2ui_interactive/SKILL.md +206 -0
- package/packages/skills/src/bundled/canvas/canvas_dashboard/SKILL.md +146 -0
- package/packages/skills/src/bundled/canvas/canvas_interact/SKILL.md +148 -0
- package/packages/skills/src/bundled/canvas/canvas_report/SKILL.md +146 -0
- package/packages/skills/src/bundled/cli/cli_pipeline/SKILL.md +136 -0
- package/packages/skills/src/bundled/cli/cli_safe_exec/SKILL.md +125 -0
- package/packages/skills/src/bundled/cron_manager/SKILL.md +188 -0
- package/packages/skills/src/bundled/cron_reminder/SKILL.md +112 -0
- package/packages/skills/src/bundled/filesystem/file_manager/SKILL.md +118 -0
- package/packages/skills/src/bundled/filesystem/file_read_and_summarize/SKILL.md +108 -0
- package/packages/skills/src/bundled/filesystem/file_writer/SKILL.md +135 -0
- package/packages/skills/src/bundled/meeting/meeting_transcription/SKILL.md +213 -0
- package/packages/skills/src/bundled/office/office_document_manager/SKILL.md +262 -0
- package/packages/skills/src/bundled/search_knowledge/busqueda_fts5/SKILL.md +74 -0
- package/packages/skills/src/bundled/voice/voice_assistant/SKILL.md +174 -0
- package/packages/skills/src/bundled/voice/voice_input/SKILL.md +146 -0
- package/packages/skills/src/bundled/voice/voice_output/SKILL.md +151 -0
- package/packages/skills/src/bundled/web/browser_automate/SKILL.md +120 -0
- package/packages/skills/src/bundled/web/browser_scrape/SKILL.md +109 -0
- package/packages/skills/src/bundled/web/web_monitor/SKILL.md +127 -0
- package/packages/skills/src/bundled/web/web_research/SKILL.md +119 -0
- package/packages/skills/src/bundled-data.generated.ts +1964 -0
- package/packages/skills/src/index.ts +1 -0
- package/packages/skills/src/loader.ts +388 -0
- package/dist/ui/assets/AgentNewPage-GB-tVN50.js +0 -1
- package/dist/ui/assets/BridgePage-DDcDILKu.js +0 -1
- package/dist/ui/assets/CanvasPage-oOk2sGOD.js +0 -33
- package/dist/ui/assets/DashboardPage-DV_2qWYJ.js +0 -6
- package/dist/ui/assets/LogsPage-DayYjh01.js +0 -1
- package/dist/ui/assets/MeetingPage-C01uPuqj.js +0 -1
- package/dist/ui/assets/ProjectsPage-B8_am_Ib.js +0 -1
- package/dist/ui/assets/ProvidersPage-DBzi66e4.js +0 -1
- package/dist/ui/assets/SettingsPage-CFA_Tknl.js +0 -9
- package/dist/ui/assets/SetupPage-BrUWbhvT.js +0 -1
- package/dist/ui/assets/accordion-DdAEfIXR.js +0 -1
- package/dist/ui/assets/chevron-down-DIosfU_U.js +0 -1
- package/dist/ui/assets/chevron-up-CI-W21Fy.js +0 -1
- package/dist/ui/assets/circle-S0-ouLz-.js +0 -1
- package/dist/ui/assets/circle-minus-CE0iJrl8.js +0 -1
- package/dist/ui/assets/circle-x-jUJ5zZvQ.js +0 -1
- package/dist/ui/assets/dropdown-menu-C2CXM1VE.js +0 -1
- package/dist/ui/assets/index-BN0875JH.css +0 -2
- package/dist/ui/assets/index-CH6sBa3Q.js +0 -116
- package/dist/ui/assets/pencil-5VdSj-h5.js +0 -1
- package/dist/ui/assets/progress-JN30I5fF.js +0 -1
- package/dist/ui/assets/scroll-area-BQQPitM8.js +0 -1
- package/dist/ui/assets/search-ChPgnVKj.js +0 -1
- package/dist/ui/assets/switch-C7W2-KEx.js +0 -1
- package/dist/ui/assets/terminal-C-R5Fckz.js +0 -1
- package/dist/ui/assets/useProviders-TBnWn-Hq.js +0 -1
- /package/dist/ui/assets/{card-DFKnZ6ky.js → card-CNf6BS2e.js} +0 -0
- /package/dist/ui/assets/{circle-alert-KuAm2FWh.js → circle-alert-CyHDwUj8.js} +0 -0
- /package/dist/ui/assets/{circle-check-6Ard1-2z.js → circle-check-Bb54Ebmu.js} +0 -0
- /package/dist/ui/assets/{cpu-KDy6-FAI.js → cpu-Cdgc_B1K.js} +0 -0
- /package/dist/ui/assets/{download-Cjbk4Rek.js → download-C3ifGMjJ.js} +0 -0
- /package/dist/ui/assets/{external-link-HtrFM63g.js → external-link-BvxYeTP1.js} +0 -0
- /package/dist/ui/assets/{eye-D1dB40_o.js → eye-DqNTU_GD.js} +0 -0
- /package/dist/ui/assets/{file-text-CE58EfH0.js → file-text-BT_9S9SM.js} +0 -0
- /package/dist/ui/assets/{folder-open-DIPKeiI_.js → folder-open-BhH8y9ac.js} +0 -0
- /package/dist/ui/assets/{format-BwdV8bB5.js → format-GVHeOyWI.js} +0 -0
- /package/dist/ui/assets/{gateway-url-D5uj6Nxg.js → gateway-url-COCbW0IR.js} +0 -0
- /package/dist/ui/assets/{gauge-DmQmJHEg.js → gauge-D_TMa4i9.js} +0 -0
- /package/dist/ui/assets/{globe-_hUGxQF4.js → globe-DeCQTCDJ.js} +0 -0
- /package/dist/ui/assets/{hexagon-BaNGQlQj.js → hexagon-DsGOUl-H.js} +0 -0
- /package/dist/ui/assets/{history-BfZVGlZa.js → history-BSG-Ypqf.js} +0 -0
- /package/dist/ui/assets/{info-CBZ5-AlC.js → info-NwLoa2Mj.js} +0 -0
- /package/dist/ui/assets/{key-Bv5DdTPh.js → key-3EP0dhkT.js} +0 -0
- /package/dist/ui/assets/{loader-circle-C4hhXLgp.js → loader-circle-CZNax6kS.js} +0 -0
- /package/dist/ui/assets/{lock-CkZYexqw.js → lock-Ei1_J-Nq.js} +0 -0
- /package/dist/ui/assets/{pause-Bpy1_s7y.js → pause-BUqah9Bi.js} +0 -0
- /package/dist/ui/assets/{play-Cj4osqJZ.js → play-NcZ4swwL.js} +0 -0
- /package/dist/ui/assets/{plus-BQhgZN3A.js → plus-CX1xyhp5.js} +0 -0
- /package/dist/ui/assets/{refresh-cw-BfREHVQM.js → refresh-cw-DaYdjQFk.js} +0 -0
- /package/dist/ui/assets/{save-FFTD4dMp.js → save-CUdYyHNy.js} +0 -0
- /package/dist/ui/assets/{settings-BdHKUL92.js → settings-Ds4SqD8s.js} +0 -0
- /package/dist/ui/assets/{sparkles-r4uJbJAl.js → sparkles-yUEb-7oH.js} +0 -0
- /package/dist/ui/assets/{square-G7Hyufqm.js → square-BD81nFtN.js} +0 -0
- /package/dist/ui/assets/{textarea-5kyuD04X.js → textarea-CXgXWKrT.js} +0 -0
- /package/dist/ui/assets/{trash-2-DXVBRWfh.js → trash-2-CNjMkoq6.js} +0 -0
- /package/dist/ui/assets/{triangle-alert-Bu5seg9O.js → triangle-alert-C9Y8Ub4X.js} +0 -0
- /package/dist/ui/assets/{vendor-router-CCECILJ0.js → vendor-router-C9pIYwbJ.js} +0 -0
- /package/dist/ui/assets/{volume-2-s9DuS696.js → volume-2-CeSXNDv4.js} +0 -0
- /package/dist/ui/assets/{zap-BPHZzXKV.js → zap-hlXjpSeA.js} +0 -0
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Conversation Store — persists message history in the `conversations` table.
|
|
3
|
+
* Replaces the LangGraph BunSqliteSaver + lg_checkpoints approach.
|
|
4
|
+
*
|
|
5
|
+
* Also manages: summaries, scratchpad.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { getDb } from "../storage/sqlite"
|
|
9
|
+
import { logger } from "../utils/logger"
|
|
10
|
+
import type { LLMMessage, ContentPart } from "./llm-client"
|
|
11
|
+
import { estimateTokens } from "../utils/toon"
|
|
12
|
+
|
|
13
|
+
const log = logger.child("conv-store")
|
|
14
|
+
|
|
15
|
+
// ─── Types ────────────────────────────────────────────────────────────────────
|
|
16
|
+
|
|
17
|
+
export interface StoredMessage {
|
|
18
|
+
id: number
|
|
19
|
+
thread_id: string
|
|
20
|
+
channel: string
|
|
21
|
+
role: "user" | "assistant" | "tool" | "system"
|
|
22
|
+
content: string
|
|
23
|
+
tool_calls_json: string | null
|
|
24
|
+
tool_call_id: string | null
|
|
25
|
+
reasoning_content: string | null // Kimi K2 thinking — must be round-tripped
|
|
26
|
+
content_multimodal: string | null // JSON array of ContentPart[]
|
|
27
|
+
token_count: number
|
|
28
|
+
created_at: number
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// ─── Message operations ───────────────────────────────────────────────────────
|
|
32
|
+
|
|
33
|
+
export function addMessage(
|
|
34
|
+
threadId: string,
|
|
35
|
+
role: StoredMessage["role"],
|
|
36
|
+
content: string | ContentPart[],
|
|
37
|
+
opts?: {
|
|
38
|
+
channel?: string
|
|
39
|
+
tool_calls?: LLMMessage["tool_calls"]
|
|
40
|
+
tool_call_id?: string
|
|
41
|
+
reasoning_content?: string
|
|
42
|
+
}
|
|
43
|
+
): number {
|
|
44
|
+
const db = getDb()
|
|
45
|
+
// Handle multimodal content by extracting text for the content column
|
|
46
|
+
const textContent = typeof content === "string"
|
|
47
|
+
? content
|
|
48
|
+
: Array.isArray(content)
|
|
49
|
+
? content.filter(p => p.type === "text").map(p => (p as any).text).join("\n")
|
|
50
|
+
: String(content)
|
|
51
|
+
|
|
52
|
+
const content_multimodal = Array.isArray(content) ? JSON.stringify(content) : null
|
|
53
|
+
const tool_calls_json = opts?.tool_calls ? JSON.stringify(opts.tool_calls) : null
|
|
54
|
+
|
|
55
|
+
const result = db.query(`
|
|
56
|
+
INSERT INTO conversations (thread_id, channel, role, content, content_multimodal, tool_calls_json, tool_call_id, reasoning_content, token_count, updated_at)
|
|
57
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, unixepoch())
|
|
58
|
+
RETURNING id
|
|
59
|
+
`).get(
|
|
60
|
+
threadId,
|
|
61
|
+
opts?.channel ?? "webchat",
|
|
62
|
+
role,
|
|
63
|
+
textContent,
|
|
64
|
+
content_multimodal,
|
|
65
|
+
tool_calls_json,
|
|
66
|
+
opts?.tool_call_id ?? null,
|
|
67
|
+
opts?.reasoning_content ?? null,
|
|
68
|
+
// Estimate tokens: content + tool_calls JSON
|
|
69
|
+
Math.max(1, estimateTokens(textContent) + estimateTokens(tool_calls_json ?? "")),
|
|
70
|
+
) as { id: number }
|
|
71
|
+
|
|
72
|
+
return result.id
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Returns all messages for the thread ordered oldest → newest.
|
|
77
|
+
*/
|
|
78
|
+
export function getHistory(threadId: string, limit = 200): StoredMessage[] {
|
|
79
|
+
const db = getDb()
|
|
80
|
+
return db.query(`
|
|
81
|
+
SELECT * FROM conversations
|
|
82
|
+
WHERE thread_id = ?
|
|
83
|
+
ORDER BY id ASC
|
|
84
|
+
LIMIT ?
|
|
85
|
+
`).all(threadId, limit) as StoredMessage[]
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Returns only the last N messages (oldest → newest order),
|
|
90
|
+
* with leading orphaned tool messages stripped from the window start.
|
|
91
|
+
*
|
|
92
|
+
* A tool message is "orphaned" when the assistant message that issued its
|
|
93
|
+
* tool_call_id is not present in the loaded window (it was compacted away).
|
|
94
|
+
* Sending orphaned tool messages to the LLM causes provider errors.
|
|
95
|
+
*/
|
|
96
|
+
export function getRecentMessages(threadId: string, n: number): StoredMessage[] {
|
|
97
|
+
const db = getDb()
|
|
98
|
+
const rows = db.query(`
|
|
99
|
+
SELECT * FROM conversations
|
|
100
|
+
WHERE thread_id = ?
|
|
101
|
+
ORDER BY id DESC
|
|
102
|
+
LIMIT ?
|
|
103
|
+
`).all(threadId, n) as StoredMessage[]
|
|
104
|
+
return stripLeadingOrphanedTools(rows.reverse())
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
function stripLeadingOrphanedTools(rows: StoredMessage[]): StoredMessage[] {
|
|
108
|
+
// Collect all tool_call_ids referenced by assistant messages in this window
|
|
109
|
+
const knownIds = new Set<string>()
|
|
110
|
+
for (const r of rows) {
|
|
111
|
+
if (r.role === "assistant" && r.tool_calls_json) {
|
|
112
|
+
try {
|
|
113
|
+
const tcs = JSON.parse(r.tool_calls_json) as Array<{ id: string }>
|
|
114
|
+
for (const tc of tcs) knownIds.add(tc.id)
|
|
115
|
+
} catch { /* ignore malformed JSON */ }
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
// Drop tool messages at the start of the window whose assistant is missing
|
|
120
|
+
let start = 0
|
|
121
|
+
while (
|
|
122
|
+
start < rows.length &&
|
|
123
|
+
rows[start].role === "tool" &&
|
|
124
|
+
rows[start].tool_call_id !== null &&
|
|
125
|
+
!knownIds.has(rows[start].tool_call_id!)
|
|
126
|
+
) {
|
|
127
|
+
start++
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
if (start > 0) {
|
|
131
|
+
log.warn(`[conv-store] Stripped ${start} leading orphaned tool message(s) from window (tool_call_ids outside window)`)
|
|
132
|
+
}
|
|
133
|
+
return start > 0 ? rows.slice(start) : rows
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
export function getMessageCount(threadId: string): number {
|
|
137
|
+
const db = getDb()
|
|
138
|
+
const row = db.query(
|
|
139
|
+
"SELECT COUNT(*) as cnt FROM conversations WHERE thread_id = ?"
|
|
140
|
+
).get(threadId) as { cnt: number }
|
|
141
|
+
return row.cnt
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
export function getTotalTokens(threadId: string): number {
|
|
145
|
+
const db = getDb()
|
|
146
|
+
const row = db.query(
|
|
147
|
+
"SELECT COALESCE(SUM(token_count), 0) as total FROM conversations WHERE thread_id = ?"
|
|
148
|
+
).get(threadId) as { total: number }
|
|
149
|
+
return row.total
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* Messages after a given message ID (for incremental summary updates).
|
|
154
|
+
*/
|
|
155
|
+
export function getMessagesAfter(threadId: string, afterId: number): StoredMessage[] {
|
|
156
|
+
const db = getDb()
|
|
157
|
+
return db.query(`
|
|
158
|
+
SELECT * FROM conversations
|
|
159
|
+
WHERE thread_id = ? AND id > ?
|
|
160
|
+
ORDER BY id ASC
|
|
161
|
+
`).all(threadId, afterId) as StoredMessage[]
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
// ─── Convert stored messages → LLMMessage array ───────────────────────────────
|
|
165
|
+
|
|
166
|
+
export function toAPIMessages(rows: StoredMessage[]): LLMMessage[] {
|
|
167
|
+
return rows.map((r) => {
|
|
168
|
+
let content: string | ContentPart[] = r.content
|
|
169
|
+
if (r.content_multimodal) {
|
|
170
|
+
try { content = JSON.parse(r.content_multimodal) } catch { /* ignore */ }
|
|
171
|
+
}
|
|
172
|
+
const msg: LLMMessage = { role: r.role, content }
|
|
173
|
+
if (r.tool_calls_json) {
|
|
174
|
+
try { msg.tool_calls = JSON.parse(r.tool_calls_json) } catch { /* ignore */ }
|
|
175
|
+
}
|
|
176
|
+
if (r.tool_call_id) msg.tool_call_id = r.tool_call_id
|
|
177
|
+
if (r.reasoning_content) msg.reasoning_content = r.reasoning_content
|
|
178
|
+
return msg
|
|
179
|
+
})
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
// ─── Summaries ────────────────────────────────────────────────────────────────
|
|
183
|
+
|
|
184
|
+
export interface Summary {
|
|
185
|
+
summary: string
|
|
186
|
+
last_message_id: number
|
|
187
|
+
messages_covered: number
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
export function getSummary(threadId: string): Summary | null {
|
|
191
|
+
const db = getDb()
|
|
192
|
+
return db.query(
|
|
193
|
+
"SELECT summary, last_message_id, messages_covered FROM summaries WHERE thread_id = ?"
|
|
194
|
+
).get(threadId) as Summary | null
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
export function saveSummary(
|
|
198
|
+
threadId: string,
|
|
199
|
+
summary: string,
|
|
200
|
+
messagesCovered: number,
|
|
201
|
+
lastMessageId: number
|
|
202
|
+
): void {
|
|
203
|
+
const db = getDb()
|
|
204
|
+
db.query(`
|
|
205
|
+
INSERT INTO summaries (thread_id, summary, messages_covered, last_message_id)
|
|
206
|
+
VALUES (?, ?, ?, ?)
|
|
207
|
+
ON CONFLICT(thread_id) DO UPDATE SET
|
|
208
|
+
summary = excluded.summary,
|
|
209
|
+
messages_covered = excluded.messages_covered,
|
|
210
|
+
last_message_id = excluded.last_message_id,
|
|
211
|
+
updated_at = unixepoch()
|
|
212
|
+
`).run(threadId, summary, messagesCovered, lastMessageId)
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
// ─── Scratchpad ───────────────────────────────────────────────────────────────
|
|
216
|
+
|
|
217
|
+
export function saveScratchpadNote(
|
|
218
|
+
threadId: string,
|
|
219
|
+
key: string,
|
|
220
|
+
value: string,
|
|
221
|
+
source?: string
|
|
222
|
+
): void {
|
|
223
|
+
const db = getDb()
|
|
224
|
+
db.query(`
|
|
225
|
+
INSERT INTO scratchpad (thread_id, key, value, source)
|
|
226
|
+
VALUES (?, ?, ?, ?)
|
|
227
|
+
ON CONFLICT(thread_id, key) DO UPDATE SET
|
|
228
|
+
value = excluded.value,
|
|
229
|
+
source = excluded.source,
|
|
230
|
+
updated_at = unixepoch()
|
|
231
|
+
`).run(threadId, key, value, source ?? null)
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
export function getScratchpad(threadId: string): Array<{ key: string; value: string }> {
|
|
235
|
+
const db = getDb()
|
|
236
|
+
return db.query(
|
|
237
|
+
"SELECT key, value FROM scratchpad WHERE thread_id = ? ORDER BY updated_at DESC"
|
|
238
|
+
).all(threadId) as Array<{ key: string; value: string }>
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
export function deleteScratchpadNote(threadId: string, key: string): void {
|
|
242
|
+
const db = getDb()
|
|
243
|
+
db.query("DELETE FROM scratchpad WHERE thread_id = ? AND key = ?").run(threadId, key)
|
|
244
|
+
}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ACE Curator — converts reflections into playbook rules.
|
|
3
|
+
*
|
|
4
|
+
* Runs after the Reflector. Performs incremental edits to the playbook:
|
|
5
|
+
* - New insights → new rules
|
|
6
|
+
* - Repeated patterns → increment helpful_count
|
|
7
|
+
* - Contradicted rules → increment harmful_count or deactivate
|
|
8
|
+
* - Deactivate rules where harmful_count > helpful_count
|
|
9
|
+
* - Archive unused workers
|
|
10
|
+
*
|
|
11
|
+
* Never rewrites the whole playbook — only incremental edits.
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
import { logger } from "../utils/logger"
|
|
15
|
+
|
|
16
|
+
const log = logger.child("curator")
|
|
17
|
+
|
|
18
|
+
const DAYS_BEFORE_ARCHIVE = 14 // archive workers not used in N days
|
|
19
|
+
const MAX_HARMFUL_BEFORE_PRUNE = 3
|
|
20
|
+
|
|
21
|
+
/** Entry point — called by reflector.ts after it inserts new reflections */
|
|
22
|
+
export async function runCurator(): Promise<void> {
|
|
23
|
+
try {
|
|
24
|
+
const { getDb } = await import("../storage/sqlite")
|
|
25
|
+
const db = getDb()
|
|
26
|
+
|
|
27
|
+
// Process unprocessed reflections (those newer than last run)
|
|
28
|
+
const lastProcessed = (db.query<any, []>(
|
|
29
|
+
"SELECT COALESCE(MAX(source_reflection_id), 0) as mid FROM playbook"
|
|
30
|
+
).get() as any)?.mid ?? 0
|
|
31
|
+
|
|
32
|
+
const reflections = (db.query as any)(
|
|
33
|
+
"SELECT * FROM reflections WHERE id > ? ORDER BY id ASC"
|
|
34
|
+
).all(lastProcessed)
|
|
35
|
+
|
|
36
|
+
if (reflections.length === 0) {
|
|
37
|
+
log.debug("[curator] No new reflections to process")
|
|
38
|
+
} else {
|
|
39
|
+
log.info(`[curator] Processing ${reflections.length} new reflections`)
|
|
40
|
+
for (const reflection of reflections) {
|
|
41
|
+
processReflection(db, reflection)
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// Prune rules where harmful > helpful (consistently bad rules)
|
|
46
|
+
db.query(`
|
|
47
|
+
UPDATE playbook
|
|
48
|
+
SET active = 0, updated_at = unixepoch()
|
|
49
|
+
WHERE active = 1
|
|
50
|
+
AND harmful_count > helpful_count
|
|
51
|
+
AND harmful_count >= ?
|
|
52
|
+
`).run(MAX_HARMFUL_BEFORE_PRUNE)
|
|
53
|
+
|
|
54
|
+
// Archive unused workers
|
|
55
|
+
const cutoff = Math.floor(Date.now() / 1000) - (DAYS_BEFORE_ARCHIVE * 86400)
|
|
56
|
+
const staleworkers = (db.query as any)(`
|
|
57
|
+
SELECT a.id, a.name
|
|
58
|
+
FROM agents a
|
|
59
|
+
WHERE a.role = 'worker'
|
|
60
|
+
AND a.status != 'archived'
|
|
61
|
+
AND a.enabled = 1
|
|
62
|
+
AND (
|
|
63
|
+
SELECT MAX(t.created_at) FROM traces t WHERE t.agent_id = a.id
|
|
64
|
+
) < ?
|
|
65
|
+
`).all(cutoff)
|
|
66
|
+
|
|
67
|
+
for (const worker of staleworkers) {
|
|
68
|
+
db.query(
|
|
69
|
+
"UPDATE agents SET status = 'archived', updated_at = unixepoch() WHERE id = ?"
|
|
70
|
+
).run(worker.id)
|
|
71
|
+
|
|
72
|
+
// Add playbook note about archival
|
|
73
|
+
addOrUpdateRule(db, {
|
|
74
|
+
rule: `Worker '${worker.name}' was archived due to inactivity (>${DAYS_BEFORE_ARCHIVE} days unused).`,
|
|
75
|
+
category: "agent_creation",
|
|
76
|
+
applicable_to: null,
|
|
77
|
+
sourceReflectionId: null,
|
|
78
|
+
})
|
|
79
|
+
|
|
80
|
+
log.info(`[curator] Archived inactive worker: ${worker.name} (${worker.id})`)
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
log.info("[curator] Playbook updated")
|
|
84
|
+
} catch (err) {
|
|
85
|
+
log.warn("[curator] Error:", err)
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
// ─── Process a single reflection ─────────────────────────────────────────────
|
|
90
|
+
|
|
91
|
+
function processReflection(db: any, reflection: any): void {
|
|
92
|
+
const category = mapInsightTypeToCategory(reflection.insight_type)
|
|
93
|
+
|
|
94
|
+
// Check if a similar rule already exists (fuzzy check by first 60 chars)
|
|
95
|
+
const prefix = reflection.description.substring(0, 60)
|
|
96
|
+
const existing = (db.query as any)(
|
|
97
|
+
"SELECT id, helpful_count FROM playbook WHERE rule LIKE ? AND active = 1 LIMIT 1"
|
|
98
|
+
).get(`${prefix}%`)
|
|
99
|
+
|
|
100
|
+
if (existing) {
|
|
101
|
+
// Reinforce existing rule
|
|
102
|
+
db.query(
|
|
103
|
+
"UPDATE playbook SET helpful_count = helpful_count + 1, updated_at = unixepoch() WHERE id = ?"
|
|
104
|
+
).run(existing.id)
|
|
105
|
+
return
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// Insert new rule
|
|
109
|
+
db.query(`
|
|
110
|
+
INSERT INTO playbook (rule, category, applicable_to, helpful_count, source_reflection_id)
|
|
111
|
+
VALUES (?, ?, ?, 1, ?)
|
|
112
|
+
`).run(
|
|
113
|
+
reflection.description,
|
|
114
|
+
category,
|
|
115
|
+
reflection.affected_tools
|
|
116
|
+
? JSON.stringify(JSON.parse(reflection.affected_tools))
|
|
117
|
+
: null,
|
|
118
|
+
reflection.id,
|
|
119
|
+
)
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
function mapInsightTypeToCategory(
|
|
123
|
+
type: string
|
|
124
|
+
): "tool_selection" | "response_quality" | "error_avoidance" | "optimization" | "agent_creation" {
|
|
125
|
+
const map: Record<string, any> = {
|
|
126
|
+
success_pattern: "tool_selection",
|
|
127
|
+
failure_pattern: "error_avoidance",
|
|
128
|
+
optimization: "optimization",
|
|
129
|
+
ethics_violation: "error_avoidance",
|
|
130
|
+
}
|
|
131
|
+
return map[type] ?? "optimization"
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
function addOrUpdateRule(
|
|
135
|
+
db: any,
|
|
136
|
+
opts: {
|
|
137
|
+
rule: string
|
|
138
|
+
category: string
|
|
139
|
+
applicable_to: string | null
|
|
140
|
+
sourceReflectionId: number | null
|
|
141
|
+
}
|
|
142
|
+
): void {
|
|
143
|
+
const prefix = opts.rule.substring(0, 60)
|
|
144
|
+
const existing = (db.query as any)(
|
|
145
|
+
"SELECT id FROM playbook WHERE rule LIKE ? LIMIT 1"
|
|
146
|
+
).get(`${prefix}%`)
|
|
147
|
+
|
|
148
|
+
if (existing) {
|
|
149
|
+
db.query(
|
|
150
|
+
"UPDATE playbook SET helpful_count = helpful_count + 1, updated_at = unixepoch() WHERE id = ?"
|
|
151
|
+
).run(existing.id)
|
|
152
|
+
} else {
|
|
153
|
+
db.query(`
|
|
154
|
+
INSERT INTO playbook (rule, category, applicable_to, helpful_count, source_reflection_id)
|
|
155
|
+
VALUES (?, ?, ?, 1, ?)
|
|
156
|
+
`).run(opts.rule, opts.category, opts.applicable_to, opts.sourceReflectionId)
|
|
157
|
+
}
|
|
158
|
+
}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import type { Config } from "../config/loader.ts";
|
|
2
|
+
import { logger } from "../utils/logger.ts";
|
|
3
|
+
import * as childProcess from "node:child_process";
|
|
4
|
+
|
|
5
|
+
export type HookName =
|
|
6
|
+
| "before_model_resolve"
|
|
7
|
+
| "before_prompt_build"
|
|
8
|
+
| "before_tool_call"
|
|
9
|
+
| "after_tool_call"
|
|
10
|
+
| "tool_result_persist"
|
|
11
|
+
| "before_compaction"
|
|
12
|
+
| "after_compaction"
|
|
13
|
+
| "message_received"
|
|
14
|
+
| "message_sending"
|
|
15
|
+
| "message_sent"
|
|
16
|
+
| "session_start"
|
|
17
|
+
| "session_end"
|
|
18
|
+
| "gateway_start"
|
|
19
|
+
| "gateway_stop";
|
|
20
|
+
|
|
21
|
+
export interface HookContext {
|
|
22
|
+
sessionId?: string;
|
|
23
|
+
agentId?: string;
|
|
24
|
+
data?: Record<string, unknown>;
|
|
25
|
+
timestamp: Date;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export type HookHandler = (context: HookContext) => Promise<Record<string, unknown> | void>;
|
|
29
|
+
|
|
30
|
+
export class HookPipeline {
|
|
31
|
+
private config: Config;
|
|
32
|
+
private log = logger.child("hooks");
|
|
33
|
+
private handlers: Map<HookName, HookHandler[]> = new Map();
|
|
34
|
+
private scriptCache: Map<HookName, string> = new Map();
|
|
35
|
+
|
|
36
|
+
constructor(config: Config) {
|
|
37
|
+
this.config = config;
|
|
38
|
+
this.loadScripts();
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
private loadScripts(): void {
|
|
42
|
+
const scripts = this.config.hooks?.scripts;
|
|
43
|
+
if (!scripts) return;
|
|
44
|
+
|
|
45
|
+
const hookNames: HookName[] = [
|
|
46
|
+
"before_model_resolve",
|
|
47
|
+
"before_prompt_build",
|
|
48
|
+
"before_tool_call",
|
|
49
|
+
"after_tool_call",
|
|
50
|
+
"tool_result_persist",
|
|
51
|
+
"before_compaction",
|
|
52
|
+
"after_compaction",
|
|
53
|
+
"message_received",
|
|
54
|
+
"message_sending",
|
|
55
|
+
"message_sent",
|
|
56
|
+
"session_start",
|
|
57
|
+
"session_end",
|
|
58
|
+
"gateway_start",
|
|
59
|
+
"gateway_stop",
|
|
60
|
+
];
|
|
61
|
+
|
|
62
|
+
for (const name of hookNames) {
|
|
63
|
+
const script = scripts[name];
|
|
64
|
+
if (script) {
|
|
65
|
+
this.scriptCache.set(name, script);
|
|
66
|
+
this.log.debug(`Loaded script for hook: ${name}`);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
registerHandler(name: HookName, handler: HookHandler): void {
|
|
72
|
+
const handlers = this.handlers.get(name) ?? [];
|
|
73
|
+
handlers.push(handler);
|
|
74
|
+
this.handlers.set(name, handlers);
|
|
75
|
+
this.log.debug(`Registered handler for hook: ${name}`);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
unregisterHandler(name: HookName, handler: HookHandler): boolean {
|
|
79
|
+
const handlers = this.handlers.get(name);
|
|
80
|
+
if (!handlers) return false;
|
|
81
|
+
|
|
82
|
+
const index = handlers.indexOf(handler);
|
|
83
|
+
if (index >= 0) {
|
|
84
|
+
handlers.splice(index, 1);
|
|
85
|
+
return true;
|
|
86
|
+
}
|
|
87
|
+
return false;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
async execute(name: HookName, context: HookContext): Promise<Record<string, unknown> | void> {
|
|
91
|
+
this.log.debug(`Executing hook: ${name}`, { sessionId: context.sessionId });
|
|
92
|
+
|
|
93
|
+
const handlers = this.handlers.get(name) ?? [];
|
|
94
|
+
for (const handler of handlers) {
|
|
95
|
+
try {
|
|
96
|
+
await handler(context);
|
|
97
|
+
} catch (error) {
|
|
98
|
+
this.log.error(`Handler failed for ${name}: ${(error as Error).message}`);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
const script = this.scriptCache.get(name);
|
|
103
|
+
if (script) {
|
|
104
|
+
try {
|
|
105
|
+
const result = await this.executeScript(script, context);
|
|
106
|
+
return result;
|
|
107
|
+
} catch (error) {
|
|
108
|
+
this.log.error(`Script failed for ${name}: ${(error as Error).message}`);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
private async executeScript(
|
|
114
|
+
scriptPath: string,
|
|
115
|
+
context: HookContext
|
|
116
|
+
): Promise<Record<string, unknown> | void> {
|
|
117
|
+
return new Promise((resolve, reject) => {
|
|
118
|
+
const payload = JSON.stringify(context);
|
|
119
|
+
|
|
120
|
+
const proc = childProcess.spawn(scriptPath, [], {
|
|
121
|
+
stdio: ["pipe", "pipe", "pipe"],
|
|
122
|
+
shell: true,
|
|
123
|
+
}) as any;
|
|
124
|
+
|
|
125
|
+
let stdout = "";
|
|
126
|
+
let stderr = "";
|
|
127
|
+
|
|
128
|
+
proc.stdout?.on("data", (data) => {
|
|
129
|
+
stdout += data.toString();
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
proc.stderr?.on("data", (data) => {
|
|
133
|
+
stderr += data.toString();
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
proc.on("close", (code) => {
|
|
137
|
+
if (code === 0 && stdout) {
|
|
138
|
+
try {
|
|
139
|
+
resolve(JSON.parse(stdout));
|
|
140
|
+
} catch {
|
|
141
|
+
resolve();
|
|
142
|
+
}
|
|
143
|
+
} else if (stderr) {
|
|
144
|
+
reject(new Error(stderr));
|
|
145
|
+
} else {
|
|
146
|
+
resolve();
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
proc.on("error", (error) => {
|
|
151
|
+
reject(error);
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
proc.stdin?.write(payload);
|
|
155
|
+
proc.stdin?.end();
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
hasHandlers(name: HookName): boolean {
|
|
160
|
+
return (this.handlers.get(name)?.length ?? 0) > 0 || this.scriptCache.has(name);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
export function createHookPipeline(config: Config): HookPipeline {
|
|
165
|
+
return new HookPipeline(config);
|
|
166
|
+
}
|