@stardust-bytes/agent-hub 0.1.0
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 +184 -0
- package/backend/.env.example +26 -0
- package/backend/dist/agent/agent.controller.d.ts +23 -0
- package/backend/dist/agent/agent.controller.js +114 -0
- package/backend/dist/agent/agent.controller.js.map +1 -0
- package/backend/dist/agent/agent.module.d.ts +2 -0
- package/backend/dist/agent/agent.module.js +128 -0
- package/backend/dist/agent/agent.module.js.map +1 -0
- package/backend/dist/agent/agent.service.d.ts +25 -0
- package/backend/dist/agent/agent.service.js +198 -0
- package/backend/dist/agent/agent.service.js.map +1 -0
- package/backend/dist/agent/dto/agent-action.dto.d.ts +10 -0
- package/backend/dist/agent/dto/agent-action.dto.js +73 -0
- package/backend/dist/agent/dto/agent-action.dto.js.map +1 -0
- package/backend/dist/agent/dto/agent-command.util.d.ts +4 -0
- package/backend/dist/agent/dto/agent-command.util.js +13 -0
- package/backend/dist/agent/dto/agent-command.util.js.map +1 -0
- package/backend/dist/agent/dto/agent-run-state.d.ts +21 -0
- package/backend/dist/agent/dto/agent-run-state.js +19 -0
- package/backend/dist/agent/dto/agent-run-state.js.map +1 -0
- package/backend/dist/agent/dto/agent-state.enum.d.ts +6 -0
- package/backend/dist/agent/dto/agent-state.enum.js +11 -0
- package/backend/dist/agent/dto/agent-state.enum.js.map +1 -0
- package/backend/dist/agent/dto/approve-tool.dto.d.ts +4 -0
- package/backend/dist/agent/dto/approve-tool.dto.js +25 -0
- package/backend/dist/agent/dto/approve-tool.dto.js.map +1 -0
- package/backend/dist/agent/dto/chat.dto.d.ts +6 -0
- package/backend/dist/agent/dto/chat.dto.js +35 -0
- package/backend/dist/agent/dto/chat.dto.js.map +1 -0
- package/backend/dist/agent/dto/execute-plan.dto.d.ts +4 -0
- package/backend/dist/agent/dto/execute-plan.dto.js +25 -0
- package/backend/dist/agent/dto/execute-plan.dto.js.map +1 -0
- package/backend/dist/agent/dto/permissions-config.d.ts +8 -0
- package/backend/dist/agent/dto/permissions-config.js +11 -0
- package/backend/dist/agent/dto/permissions-config.js.map +1 -0
- package/backend/dist/agent/dto/update-permissions.dto.d.ts +7 -0
- package/backend/dist/agent/dto/update-permissions.dto.js +46 -0
- package/backend/dist/agent/dto/update-permissions.dto.js.map +1 -0
- package/backend/dist/agent/dto/write-stream.interface.d.ts +3 -0
- package/backend/dist/agent/dto/write-stream.interface.js +3 -0
- package/backend/dist/agent/dto/write-stream.interface.js.map +1 -0
- package/backend/dist/agent/dto/yolo-config.dto.d.ts +5 -0
- package/backend/dist/agent/dto/yolo-config.dto.js +33 -0
- package/backend/dist/agent/dto/yolo-config.dto.js.map +1 -0
- package/backend/dist/agent/mcp/mcp-client.service.d.ts +15 -0
- package/backend/dist/agent/mcp/mcp-client.service.js +71 -0
- package/backend/dist/agent/mcp/mcp-client.service.js.map +1 -0
- package/backend/dist/agent/mcp/mcp.module.d.ts +2 -0
- package/backend/dist/agent/mcp/mcp.module.js +24 -0
- package/backend/dist/agent/mcp/mcp.module.js.map +1 -0
- package/backend/dist/agent/mcp/mcp.service.d.ts +23 -0
- package/backend/dist/agent/mcp/mcp.service.js +123 -0
- package/backend/dist/agent/mcp/mcp.service.js.map +1 -0
- package/backend/dist/agent/providers/llm-provider.interface.d.ts +41 -0
- package/backend/dist/agent/providers/llm-provider.interface.js +3 -0
- package/backend/dist/agent/providers/llm-provider.interface.js.map +1 -0
- package/backend/dist/agent/providers/ollama.provider.d.ts +5 -0
- package/backend/dist/agent/providers/ollama.provider.js +92 -0
- package/backend/dist/agent/providers/ollama.provider.js.map +1 -0
- package/backend/dist/agent/providers/openai.provider.d.ts +5 -0
- package/backend/dist/agent/providers/openai.provider.js +169 -0
- package/backend/dist/agent/providers/openai.provider.js.map +1 -0
- package/backend/dist/agent/services/agent-loop.service.d.ts +131 -0
- package/backend/dist/agent/services/agent-loop.service.js +764 -0
- package/backend/dist/agent/services/agent-loop.service.js.map +1 -0
- package/backend/dist/agent/services/approval-manager.service.d.ts +8 -0
- package/backend/dist/agent/services/approval-manager.service.js +50 -0
- package/backend/dist/agent/services/approval-manager.service.js.map +1 -0
- package/backend/dist/agent/services/context-builder.service.d.ts +32 -0
- package/backend/dist/agent/services/context-builder.service.js +118 -0
- package/backend/dist/agent/services/context-builder.service.js.map +1 -0
- package/backend/dist/agent/services/danger-patterns.config.d.ts +10 -0
- package/backend/dist/agent/services/danger-patterns.config.js +82 -0
- package/backend/dist/agent/services/danger-patterns.config.js.map +1 -0
- package/backend/dist/agent/services/denial-tracking.d.ts +12 -0
- package/backend/dist/agent/services/denial-tracking.js +34 -0
- package/backend/dist/agent/services/denial-tracking.js.map +1 -0
- package/backend/dist/agent/services/llm-controller.service.d.ts +19 -0
- package/backend/dist/agent/services/llm-controller.service.js +70 -0
- package/backend/dist/agent/services/llm-controller.service.js.map +1 -0
- package/backend/dist/agent/services/permissions.service.d.ts +24 -0
- package/backend/dist/agent/services/permissions.service.js +106 -0
- package/backend/dist/agent/services/permissions.service.js.map +1 -0
- package/backend/dist/agent/services/yolo-classifier.constants.d.ts +6 -0
- package/backend/dist/agent/services/yolo-classifier.constants.js +39 -0
- package/backend/dist/agent/services/yolo-classifier.constants.js.map +1 -0
- package/backend/dist/agent/services/yolo-classifier.service.d.ts +29 -0
- package/backend/dist/agent/services/yolo-classifier.service.js +139 -0
- package/backend/dist/agent/services/yolo-classifier.service.js.map +1 -0
- package/backend/dist/agent/subagent/subagent-tools.util.d.ts +3 -0
- package/backend/dist/agent/subagent/subagent-tools.util.js +37 -0
- package/backend/dist/agent/subagent/subagent-tools.util.js.map +1 -0
- package/backend/dist/agent/subagent/subagent.service.d.ts +17 -0
- package/backend/dist/agent/subagent/subagent.service.js +89 -0
- package/backend/dist/agent/subagent/subagent.service.js.map +1 -0
- package/backend/dist/agent-output/agent-output.controller.d.ts +20 -0
- package/backend/dist/agent-output/agent-output.controller.js +123 -0
- package/backend/dist/agent-output/agent-output.controller.js.map +1 -0
- package/backend/dist/agent-output/agent-output.module.d.ts +2 -0
- package/backend/dist/agent-output/agent-output.module.js +22 -0
- package/backend/dist/agent-output/agent-output.module.js.map +1 -0
- package/backend/dist/agent-profiles/agent-profiles.controller.d.ts +59 -0
- package/backend/dist/agent-profiles/agent-profiles.controller.js +70 -0
- package/backend/dist/agent-profiles/agent-profiles.controller.js.map +1 -0
- package/backend/dist/agent-profiles/agent-profiles.module.d.ts +2 -0
- package/backend/dist/agent-profiles/agent-profiles.module.js +23 -0
- package/backend/dist/agent-profiles/agent-profiles.module.js.map +1 -0
- package/backend/dist/agent-profiles/agent-profiles.service.d.ts +85 -0
- package/backend/dist/agent-profiles/agent-profiles.service.js +48 -0
- package/backend/dist/agent-profiles/agent-profiles.service.js.map +1 -0
- package/backend/dist/agent-profiles/dto/create-agent-profile.dto.d.ts +9 -0
- package/backend/dist/agent-profiles/dto/create-agent-profile.dto.js +52 -0
- package/backend/dist/agent-profiles/dto/create-agent-profile.dto.js.map +1 -0
- package/backend/dist/agent-profiles/dto/update-agent-profile.dto.d.ts +5 -0
- package/backend/dist/agent-profiles/dto/update-agent-profile.dto.js +9 -0
- package/backend/dist/agent-profiles/dto/update-agent-profile.dto.js.map +1 -0
- package/backend/dist/app.controller.d.ts +10 -0
- package/backend/dist/app.controller.js +39 -0
- package/backend/dist/app.controller.js.map +1 -0
- package/backend/dist/app.module.d.ts +2 -0
- package/backend/dist/app.module.js +68 -0
- package/backend/dist/app.module.js.map +1 -0
- package/backend/dist/connector/connector.controller.d.ts +67 -0
- package/backend/dist/connector/connector.controller.js +150 -0
- package/backend/dist/connector/connector.controller.js.map +1 -0
- package/backend/dist/connector/connector.module.d.ts +2 -0
- package/backend/dist/connector/connector.module.js +28 -0
- package/backend/dist/connector/connector.module.js.map +1 -0
- package/backend/dist/connector/connector.service.d.ts +61 -0
- package/backend/dist/connector/connector.service.js +63 -0
- package/backend/dist/connector/connector.service.js.map +1 -0
- package/backend/dist/connector/dto/oauth-confirm.dto.d.ts +4 -0
- package/backend/dist/connector/dto/oauth-confirm.dto.js +25 -0
- package/backend/dist/connector/dto/oauth-confirm.dto.js.map +1 -0
- package/backend/dist/connector/dto/update-connector.dto.d.ts +5 -0
- package/backend/dist/connector/dto/update-connector.dto.js +9 -0
- package/backend/dist/connector/dto/update-connector.dto.js.map +1 -0
- package/backend/dist/connector/dto/upsert-connector.dto.d.ts +6 -0
- package/backend/dist/connector/dto/upsert-connector.dto.js +35 -0
- package/backend/dist/connector/dto/upsert-connector.dto.js.map +1 -0
- package/backend/dist/connector/providers/google/gmail.service.d.ts +31 -0
- package/backend/dist/connector/providers/google/gmail.service.js +114 -0
- package/backend/dist/connector/providers/google/gmail.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-calendar.service.d.ts +37 -0
- package/backend/dist/connector/providers/google/google-calendar.service.js +105 -0
- package/backend/dist/connector/providers/google/google-calendar.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-drive.service.d.ts +22 -0
- package/backend/dist/connector/providers/google/google-drive.service.js +130 -0
- package/backend/dist/connector/providers/google/google-drive.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-oauth.service.d.ts +23 -0
- package/backend/dist/connector/providers/google/google-oauth.service.js +74 -0
- package/backend/dist/connector/providers/google/google-oauth.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-sheets.service.d.ts +29 -0
- package/backend/dist/connector/providers/google/google-sheets.service.js +246 -0
- package/backend/dist/connector/providers/google/google-sheets.service.js.map +1 -0
- package/backend/dist/cowork/cowork.controller.d.ts +37 -0
- package/backend/dist/cowork/cowork.controller.js +127 -0
- package/backend/dist/cowork/cowork.controller.js.map +1 -0
- package/backend/dist/cowork/cowork.module.d.ts +2 -0
- package/backend/dist/cowork/cowork.module.js +26 -0
- package/backend/dist/cowork/cowork.module.js.map +1 -0
- package/backend/dist/cowork/cowork.service.d.ts +40 -0
- package/backend/dist/cowork/cowork.service.js +116 -0
- package/backend/dist/cowork/cowork.service.js.map +1 -0
- package/backend/dist/cowork/dto/set-project.dto.d.ts +3 -0
- package/backend/dist/cowork/dto/set-project.dto.js +21 -0
- package/backend/dist/cowork/dto/set-project.dto.js.map +1 -0
- package/backend/dist/excel/excel.module.d.ts +2 -0
- package/backend/dist/excel/excel.module.js +26 -0
- package/backend/dist/excel/excel.module.js.map +1 -0
- package/backend/dist/excel/excel.service.d.ts +33 -0
- package/backend/dist/excel/excel.service.js +204 -0
- package/backend/dist/excel/excel.service.js.map +1 -0
- package/backend/dist/excel/executors/excel-add-sheet.executor.d.ts +12 -0
- package/backend/dist/excel/executors/excel-add-sheet.executor.js +64 -0
- package/backend/dist/excel/executors/excel-add-sheet.executor.js.map +1 -0
- package/backend/dist/excel/executors/excel-chart.executor.d.ts +12 -0
- package/backend/dist/excel/executors/excel-chart.executor.js +68 -0
- package/backend/dist/excel/executors/excel-chart.executor.js.map +1 -0
- package/backend/dist/excel/executors/list-excel-sheets.executor.d.ts +8 -0
- package/backend/dist/excel/executors/list-excel-sheets.executor.js +38 -0
- package/backend/dist/excel/executors/list-excel-sheets.executor.js.map +1 -0
- package/backend/dist/excel/executors/read-excel.executor.d.ts +8 -0
- package/backend/dist/excel/executors/read-excel.executor.js +40 -0
- package/backend/dist/excel/executors/read-excel.executor.js.map +1 -0
- package/backend/dist/excel/executors/write-excel.executor.d.ts +12 -0
- package/backend/dist/excel/executors/write-excel.executor.js +66 -0
- package/backend/dist/excel/executors/write-excel.executor.js.map +1 -0
- package/backend/dist/files/files.controller.d.ts +8 -0
- package/backend/dist/files/files.controller.js +53 -0
- package/backend/dist/files/files.controller.js.map +1 -0
- package/backend/dist/files/files.module.d.ts +2 -0
- package/backend/dist/files/files.module.js +20 -0
- package/backend/dist/files/files.module.js.map +1 -0
- package/backend/dist/http-exception.filter.d.ts +4 -0
- package/backend/dist/http-exception.filter.js +32 -0
- package/backend/dist/http-exception.filter.js.map +1 -0
- package/backend/dist/knowledge/dto/search.dto.d.ts +3 -0
- package/backend/dist/knowledge/dto/search.dto.js +21 -0
- package/backend/dist/knowledge/dto/search.dto.js.map +1 -0
- package/backend/dist/knowledge/knowledge.controller.d.ts +38 -0
- package/backend/dist/knowledge/knowledge.controller.js +91 -0
- package/backend/dist/knowledge/knowledge.controller.js.map +1 -0
- package/backend/dist/knowledge/knowledge.module.d.ts +2 -0
- package/backend/dist/knowledge/knowledge.module.js +25 -0
- package/backend/dist/knowledge/knowledge.module.js.map +1 -0
- package/backend/dist/knowledge/knowledge.service.d.ts +103 -0
- package/backend/dist/knowledge/knowledge.service.js +379 -0
- package/backend/dist/knowledge/knowledge.service.js.map +1 -0
- package/backend/dist/main.d.ts +1 -0
- package/backend/dist/main.js +33 -0
- package/backend/dist/main.js.map +1 -0
- package/backend/dist/memory/dto/create-memory.dto.d.ts +6 -0
- package/backend/dist/memory/dto/create-memory.dto.js +34 -0
- package/backend/dist/memory/dto/create-memory.dto.js.map +1 -0
- package/backend/dist/memory/dto/search-memory.dto.d.ts +5 -0
- package/backend/dist/memory/dto/search-memory.dto.js +32 -0
- package/backend/dist/memory/dto/search-memory.dto.js.map +1 -0
- package/backend/dist/memory/dto/update-memory.dto.d.ts +5 -0
- package/backend/dist/memory/dto/update-memory.dto.js +9 -0
- package/backend/dist/memory/dto/update-memory.dto.js.map +1 -0
- package/backend/dist/memory/memory-extraction.service.d.ts +19 -0
- package/backend/dist/memory/memory-extraction.service.js +87 -0
- package/backend/dist/memory/memory-extraction.service.js.map +1 -0
- package/backend/dist/memory/memory.constants.d.ts +9 -0
- package/backend/dist/memory/memory.constants.js +13 -0
- package/backend/dist/memory/memory.constants.js.map +1 -0
- package/backend/dist/memory/memory.controller.d.ts +53 -0
- package/backend/dist/memory/memory.controller.js +81 -0
- package/backend/dist/memory/memory.controller.js.map +1 -0
- package/backend/dist/memory/memory.gateway.d.ts +8 -0
- package/backend/dist/memory/memory.gateway.js +37 -0
- package/backend/dist/memory/memory.gateway.js.map +1 -0
- package/backend/dist/memory/memory.module.d.ts +2 -0
- package/backend/dist/memory/memory.module.js +25 -0
- package/backend/dist/memory/memory.module.js.map +1 -0
- package/backend/dist/memory/memory.service.d.ts +70 -0
- package/backend/dist/memory/memory.service.js +144 -0
- package/backend/dist/memory/memory.service.js.map +1 -0
- package/backend/dist/mode-policy/mode-policy.config.d.ts +20 -0
- package/backend/dist/mode-policy/mode-policy.config.js +17 -0
- package/backend/dist/mode-policy/mode-policy.config.js.map +1 -0
- package/backend/dist/mode-policy/mode-policy.module.d.ts +2 -0
- package/backend/dist/mode-policy/mode-policy.module.js +21 -0
- package/backend/dist/mode-policy/mode-policy.module.js.map +1 -0
- package/backend/dist/mode-policy/mode-policy.service.d.ts +18 -0
- package/backend/dist/mode-policy/mode-policy.service.js +66 -0
- package/backend/dist/mode-policy/mode-policy.service.js.map +1 -0
- package/backend/dist/notes/dto/create-note.dto.d.ts +4 -0
- package/backend/dist/notes/dto/create-note.dto.js +27 -0
- package/backend/dist/notes/dto/create-note.dto.js.map +1 -0
- package/backend/dist/notes/dto/update-note.dto.d.ts +5 -0
- package/backend/dist/notes/dto/update-note.dto.js +9 -0
- package/backend/dist/notes/dto/update-note.dto.js.map +1 -0
- package/backend/dist/notes/notes.controller.d.ts +35 -0
- package/backend/dist/notes/notes.controller.js +70 -0
- package/backend/dist/notes/notes.controller.js.map +1 -0
- package/backend/dist/notes/notes.gateway.d.ts +8 -0
- package/backend/dist/notes/notes.gateway.js +37 -0
- package/backend/dist/notes/notes.gateway.js.map +1 -0
- package/backend/dist/notes/notes.module.d.ts +2 -0
- package/backend/dist/notes/notes.module.js +24 -0
- package/backend/dist/notes/notes.module.js.map +1 -0
- package/backend/dist/notes/notes.service.d.ts +45 -0
- package/backend/dist/notes/notes.service.js +57 -0
- package/backend/dist/notes/notes.service.js.map +1 -0
- package/backend/dist/plans/plans.controller.d.ts +100 -0
- package/backend/dist/plans/plans.controller.js +80 -0
- package/backend/dist/plans/plans.controller.js.map +1 -0
- package/backend/dist/plans/plans.module.d.ts +2 -0
- package/backend/dist/plans/plans.module.js +23 -0
- package/backend/dist/plans/plans.module.js.map +1 -0
- package/backend/dist/plans/plans.service.d.ts +141 -0
- package/backend/dist/plans/plans.service.js +94 -0
- package/backend/dist/plans/plans.service.js.map +1 -0
- package/backend/dist/prisma/prisma.module.d.ts +2 -0
- package/backend/dist/prisma/prisma.module.js +22 -0
- package/backend/dist/prisma/prisma.module.js.map +1 -0
- package/backend/dist/prisma/prisma.service.d.ts +6 -0
- package/backend/dist/prisma/prisma.service.js +24 -0
- package/backend/dist/prisma/prisma.service.js.map +1 -0
- package/backend/dist/providers/dto/create-provider-model.dto.d.ts +3 -0
- package/backend/dist/providers/dto/create-provider-model.dto.js +22 -0
- package/backend/dist/providers/dto/create-provider-model.dto.js.map +1 -0
- package/backend/dist/providers/dto/create-provider.dto.d.ts +6 -0
- package/backend/dist/providers/dto/create-provider.dto.js +37 -0
- package/backend/dist/providers/dto/create-provider.dto.js.map +1 -0
- package/backend/dist/providers/dto/update-provider.dto.d.ts +5 -0
- package/backend/dist/providers/dto/update-provider.dto.js +9 -0
- package/backend/dist/providers/dto/update-provider.dto.js.map +1 -0
- package/backend/dist/providers/providers.controller.d.ts +60 -0
- package/backend/dist/providers/providers.controller.js +113 -0
- package/backend/dist/providers/providers.controller.js.map +1 -0
- package/backend/dist/providers/providers.module.d.ts +2 -0
- package/backend/dist/providers/providers.module.js +23 -0
- package/backend/dist/providers/providers.module.js.map +1 -0
- package/backend/dist/providers/providers.service.d.ts +86 -0
- package/backend/dist/providers/providers.service.js +100 -0
- package/backend/dist/providers/providers.service.js.map +1 -0
- package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.d.ts +13 -0
- package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.js +81 -0
- package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.js.map +1 -0
- package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.d.ts +5 -0
- package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.js +9 -0
- package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-cron.service.d.ts +8 -0
- package/backend/dist/schedule-tasks/schedule-cron.service.js +50 -0
- package/backend/dist/schedule-tasks/schedule-cron.service.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-runner.service.d.ts +25 -0
- package/backend/dist/schedule-tasks/schedule-runner.service.js +109 -0
- package/backend/dist/schedule-tasks/schedule-runner.service.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-tasks.controller.d.ts +108 -0
- package/backend/dist/schedule-tasks/schedule-tasks.controller.js +85 -0
- package/backend/dist/schedule-tasks/schedule-tasks.controller.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-tasks.module.d.ts +2 -0
- package/backend/dist/schedule-tasks/schedule-tasks.module.js +32 -0
- package/backend/dist/schedule-tasks/schedule-tasks.module.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-tasks.service.d.ts +141 -0
- package/backend/dist/schedule-tasks/schedule-tasks.service.js +80 -0
- package/backend/dist/schedule-tasks/schedule-tasks.service.js.map +1 -0
- package/backend/dist/sessions/sessions.controller.d.ts +40 -0
- package/backend/dist/sessions/sessions.controller.js +75 -0
- package/backend/dist/sessions/sessions.controller.js.map +1 -0
- package/backend/dist/sessions/sessions.module.d.ts +2 -0
- package/backend/dist/sessions/sessions.module.js +23 -0
- package/backend/dist/sessions/sessions.module.js.map +1 -0
- package/backend/dist/sessions/sessions.service.d.ts +55 -0
- package/backend/dist/sessions/sessions.service.js +73 -0
- package/backend/dist/sessions/sessions.service.js.map +1 -0
- package/backend/dist/settings/settings.controller.d.ts +14 -0
- package/backend/dist/settings/settings.controller.js +56 -0
- package/backend/dist/settings/settings.controller.js.map +1 -0
- package/backend/dist/settings/settings.module.d.ts +2 -0
- package/backend/dist/settings/settings.module.js +24 -0
- package/backend/dist/settings/settings.module.js.map +1 -0
- package/backend/dist/settings/settings.service.d.ts +10 -0
- package/backend/dist/settings/settings.service.js +49 -0
- package/backend/dist/settings/settings.service.js.map +1 -0
- package/backend/dist/tools/executors/convert-note-to-task.executor.d.ts +12 -0
- package/backend/dist/tools/executors/convert-note-to-task.executor.js +59 -0
- package/backend/dist/tools/executors/convert-note-to-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/create-note.executor.d.ts +8 -0
- package/backend/dist/tools/executors/create-note.executor.js +39 -0
- package/backend/dist/tools/executors/create-note.executor.js.map +1 -0
- package/backend/dist/tools/executors/create-plan.executor.d.ts +8 -0
- package/backend/dist/tools/executors/create-plan.executor.js +45 -0
- package/backend/dist/tools/executors/create-plan.executor.js.map +1 -0
- package/backend/dist/tools/executors/create-task.executor.d.ts +10 -0
- package/backend/dist/tools/executors/create-task.executor.js +53 -0
- package/backend/dist/tools/executors/create-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/delete-note.executor.d.ts +8 -0
- package/backend/dist/tools/executors/delete-note.executor.js +38 -0
- package/backend/dist/tools/executors/delete-note.executor.js.map +1 -0
- package/backend/dist/tools/executors/delete-tasks.executor.d.ts +8 -0
- package/backend/dist/tools/executors/delete-tasks.executor.js +33 -0
- package/backend/dist/tools/executors/delete-tasks.executor.js.map +1 -0
- package/backend/dist/tools/executors/get-task.executor.d.ts +8 -0
- package/backend/dist/tools/executors/get-task.executor.js +44 -0
- package/backend/dist/tools/executors/get-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/glob.executor.d.ts +10 -0
- package/backend/dist/tools/executors/glob.executor.js +82 -0
- package/backend/dist/tools/executors/glob.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-availability.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-calendar-availability.executor.js +46 -0
- package/backend/dist/tools/executors/google-calendar-availability.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-create.executor.d.ts +42 -0
- package/backend/dist/tools/executors/google-calendar-create.executor.js +48 -0
- package/backend/dist/tools/executors/google-calendar-create.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-list.executor.d.ts +22 -0
- package/backend/dist/tools/executors/google-calendar-list.executor.js +45 -0
- package/backend/dist/tools/executors/google-calendar-list.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-update.executor.d.ts +31 -0
- package/backend/dist/tools/executors/google-calendar-update.executor.js +50 -0
- package/backend/dist/tools/executors/google-calendar-update.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-create-folder.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-drive-create-folder.executor.js +44 -0
- package/backend/dist/tools/executors/google-drive-create-folder.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-list.executor.d.ts +18 -0
- package/backend/dist/tools/executors/google-drive-list.executor.js +44 -0
- package/backend/dist/tools/executors/google-drive-list.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-read.executor.d.ts +19 -0
- package/backend/dist/tools/executors/google-drive-read.executor.js +48 -0
- package/backend/dist/tools/executors/google-drive-read.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-search.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-drive-search.executor.js +46 -0
- package/backend/dist/tools/executors/google-drive-search.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-upload.executor.d.ts +30 -0
- package/backend/dist/tools/executors/google-drive-upload.executor.js +49 -0
- package/backend/dist/tools/executors/google-drive-upload.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-draft.executor.d.ts +30 -0
- package/backend/dist/tools/executors/google-gmail-draft.executor.js +45 -0
- package/backend/dist/tools/executors/google-gmail-draft.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-labels.executor.d.ts +13 -0
- package/backend/dist/tools/executors/google-gmail-labels.executor.js +39 -0
- package/backend/dist/tools/executors/google-gmail-labels.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-read.executor.d.ts +19 -0
- package/backend/dist/tools/executors/google-gmail-read.executor.js +43 -0
- package/backend/dist/tools/executors/google-gmail-read.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-search.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-gmail-search.executor.js +46 -0
- package/backend/dist/tools/executors/google-gmail-search.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-send.executor.d.ts +44 -0
- package/backend/dist/tools/executors/google-gmail-send.executor.js +47 -0
- package/backend/dist/tools/executors/google-gmail-send.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-add-tab.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-sheets-add-tab.executor.js +44 -0
- package/backend/dist/tools/executors/google-sheets-add-tab.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-append.executor.d.ts +30 -0
- package/backend/dist/tools/executors/google-sheets-append.executor.js +45 -0
- package/backend/dist/tools/executors/google-sheets-append.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-chart.executor.d.ts +40 -0
- package/backend/dist/tools/executors/google-sheets-chart.executor.js +48 -0
- package/backend/dist/tools/executors/google-sheets-chart.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-create.executor.d.ts +27 -0
- package/backend/dist/tools/executors/google-sheets-create.executor.js +44 -0
- package/backend/dist/tools/executors/google-sheets-create.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-format.executor.d.ts +57 -0
- package/backend/dist/tools/executors/google-sheets-format.executor.js +58 -0
- package/backend/dist/tools/executors/google-sheets-format.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-list-tabs.executor.d.ts +19 -0
- package/backend/dist/tools/executors/google-sheets-list-tabs.executor.js +43 -0
- package/backend/dist/tools/executors/google-sheets-list-tabs.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-read.executor.d.ts +27 -0
- package/backend/dist/tools/executors/google-sheets-read.executor.js +45 -0
- package/backend/dist/tools/executors/google-sheets-read.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-update.executor.d.ts +34 -0
- package/backend/dist/tools/executors/google-sheets-update.executor.js +46 -0
- package/backend/dist/tools/executors/google-sheets-update.executor.js.map +1 -0
- package/backend/dist/tools/executors/grep.executor.d.ts +9 -0
- package/backend/dist/tools/executors/grep.executor.js +82 -0
- package/backend/dist/tools/executors/grep.executor.js.map +1 -0
- package/backend/dist/tools/executors/list-directory.executor.d.ts +8 -0
- package/backend/dist/tools/executors/list-directory.executor.js +37 -0
- package/backend/dist/tools/executors/list-directory.executor.js.map +1 -0
- package/backend/dist/tools/executors/list-notes.executor.d.ts +8 -0
- package/backend/dist/tools/executors/list-notes.executor.js +37 -0
- package/backend/dist/tools/executors/list-notes.executor.js.map +1 -0
- package/backend/dist/tools/executors/list-tasks.executor.d.ts +8 -0
- package/backend/dist/tools/executors/list-tasks.executor.js +32 -0
- package/backend/dist/tools/executors/list-tasks.executor.js.map +1 -0
- package/backend/dist/tools/executors/read-file.executor.d.ts +8 -0
- package/backend/dist/tools/executors/read-file.executor.js +44 -0
- package/backend/dist/tools/executors/read-file.executor.js.map +1 -0
- package/backend/dist/tools/executors/resume-plan.executor.d.ts +8 -0
- package/backend/dist/tools/executors/resume-plan.executor.js +58 -0
- package/backend/dist/tools/executors/resume-plan.executor.js.map +1 -0
- package/backend/dist/tools/executors/run-command.executor.d.ts +5 -0
- package/backend/dist/tools/executors/run-command.executor.js +55 -0
- package/backend/dist/tools/executors/run-command.executor.js.map +1 -0
- package/backend/dist/tools/executors/search-knowledge.executor.d.ts +8 -0
- package/backend/dist/tools/executors/search-knowledge.executor.js +33 -0
- package/backend/dist/tools/executors/search-knowledge.executor.js.map +1 -0
- package/backend/dist/tools/executors/spawn-subagent.executor.d.ts +5 -0
- package/backend/dist/tools/executors/spawn-subagent.executor.js +27 -0
- package/backend/dist/tools/executors/spawn-subagent.executor.js.map +1 -0
- package/backend/dist/tools/executors/tool-executor.interface.d.ts +8 -0
- package/backend/dist/tools/executors/tool-executor.interface.js +3 -0
- package/backend/dist/tools/executors/tool-executor.interface.js.map +1 -0
- package/backend/dist/tools/executors/update-note.executor.d.ts +8 -0
- package/backend/dist/tools/executors/update-note.executor.js +43 -0
- package/backend/dist/tools/executors/update-note.executor.js.map +1 -0
- package/backend/dist/tools/executors/update-task.executor.d.ts +8 -0
- package/backend/dist/tools/executors/update-task.executor.js +50 -0
- package/backend/dist/tools/executors/update-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/web-fetch.executor.d.ts +8 -0
- package/backend/dist/tools/executors/web-fetch.executor.js +57 -0
- package/backend/dist/tools/executors/web-fetch.executor.js.map +1 -0
- package/backend/dist/tools/executors/web-search.executor.d.ts +8 -0
- package/backend/dist/tools/executors/web-search.executor.js +70 -0
- package/backend/dist/tools/executors/web-search.executor.js.map +1 -0
- package/backend/dist/tools/executors/write-file.executor.d.ts +10 -0
- package/backend/dist/tools/executors/write-file.executor.js +60 -0
- package/backend/dist/tools/executors/write-file.executor.js.map +1 -0
- package/backend/dist/tools/tools.controller.d.ts +37 -0
- package/backend/dist/tools/tools.controller.js +63 -0
- package/backend/dist/tools/tools.controller.js.map +1 -0
- package/backend/dist/tools/tools.module.d.ts +2 -0
- package/backend/dist/tools/tools.module.js +128 -0
- package/backend/dist/tools/tools.module.js.map +1 -0
- package/backend/dist/tools/tools.service.d.ts +55 -0
- package/backend/dist/tools/tools.service.js +49 -0
- package/backend/dist/tools/tools.service.js.map +1 -0
- package/backend/dist/usage/dto/create-usage.dto.d.ts +8 -0
- package/backend/dist/usage/dto/create-usage.dto.js +45 -0
- package/backend/dist/usage/dto/create-usage.dto.js.map +1 -0
- package/backend/dist/usage/usage.controller.d.ts +19 -0
- package/backend/dist/usage/usage.controller.js +43 -0
- package/backend/dist/usage/usage.controller.js.map +1 -0
- package/backend/dist/usage/usage.module.d.ts +2 -0
- package/backend/dist/usage/usage.module.js +24 -0
- package/backend/dist/usage/usage.module.js.map +1 -0
- package/backend/dist/usage/usage.service.d.ts +30 -0
- package/backend/dist/usage/usage.service.js +61 -0
- package/backend/dist/usage/usage.service.js.map +1 -0
- package/backend/dist/word/executors/edit-word.executor.d.ts +12 -0
- package/backend/dist/word/executors/edit-word.executor.js +65 -0
- package/backend/dist/word/executors/edit-word.executor.js.map +1 -0
- package/backend/dist/word/executors/read-word.executor.d.ts +10 -0
- package/backend/dist/word/executors/read-word.executor.js +49 -0
- package/backend/dist/word/executors/read-word.executor.js.map +1 -0
- package/backend/dist/word/executors/write-word.executor.d.ts +12 -0
- package/backend/dist/word/executors/write-word.executor.js +63 -0
- package/backend/dist/word/executors/write-word.executor.js.map +1 -0
- package/backend/dist/word/word.module.d.ts +2 -0
- package/backend/dist/word/word.module.js +21 -0
- package/backend/dist/word/word.module.js.map +1 -0
- package/backend/dist/word/word.service.d.ts +22 -0
- package/backend/dist/word/word.service.js +155 -0
- package/backend/dist/word/word.service.js.map +1 -0
- package/backend/dist/workspace/dto/watch.dto.d.ts +3 -0
- package/backend/dist/workspace/dto/watch.dto.js +22 -0
- package/backend/dist/workspace/dto/watch.dto.js.map +1 -0
- package/backend/dist/workspace/indexer.service.d.ts +24 -0
- package/backend/dist/workspace/indexer.service.js +109 -0
- package/backend/dist/workspace/indexer.service.js.map +1 -0
- package/backend/dist/workspace/workspace-watcher.service.d.ts +20 -0
- package/backend/dist/workspace/workspace-watcher.service.js +73 -0
- package/backend/dist/workspace/workspace-watcher.service.js.map +1 -0
- package/backend/dist/workspace/workspace.controller.d.ts +21 -0
- package/backend/dist/workspace/workspace.controller.js +72 -0
- package/backend/dist/workspace/workspace.controller.js.map +1 -0
- package/backend/dist/workspace/workspace.module.d.ts +2 -0
- package/backend/dist/workspace/workspace.module.js +27 -0
- package/backend/dist/workspace/workspace.module.js.map +1 -0
- package/backend/dist/workspace/workspace.service.d.ts +16 -0
- package/backend/dist/workspace/workspace.service.js +70 -0
- package/backend/dist/workspace/workspace.service.js.map +1 -0
- package/backend/package.json +80 -0
- package/backend/prisma/migrations/20260607051149_init/migration.sql +11 -0
- package/backend/prisma/migrations/20260607082131_add_settings/migration.sql +5 -0
- package/backend/prisma/migrations/20260607090628_add_knowledge_file/migration.sql +12 -0
- package/backend/prisma/migrations/20260607102620_add_sessions_chat_messages/migration.sql +17 -0
- package/backend/prisma/migrations/20260607160733_add_tool_fields_to_message/migration.sql +18 -0
- package/backend/prisma/migrations/20260608120000_add_providers/migration.sql +19 -0
- package/backend/prisma/migrations/20260608150513_add_tools/migration.sql +9 -0
- package/backend/prisma/migrations/20260608155121_add_tool_config/migration.sql +3 -0
- package/backend/prisma/migrations/20260609044217_add_error_message/migration.sql +2 -0
- package/backend/prisma/migrations/20260609110505_add_notes/migration.sql +8 -0
- package/backend/prisma/migrations/20260609151214_add_plan_tables/migration.sql +21 -0
- package/backend/prisma/migrations/20260610100714_add_agent_file/migration.sql +9 -0
- package/backend/prisma/migrations/20260611085424_add_session_mode/migration.sql +2 -0
- package/backend/prisma/migrations/20260611120000_add_memory_model/migration.sql +13 -0
- package/backend/prisma/migrations/20260612120000_add_usage_record/migration.sql +12 -0
- package/backend/prisma/migrations/20260612130000_add_project_model/migration.sql +7 -0
- package/backend/prisma/migrations/20260612130000_add_project_model/migration_lock.toml +5 -0
- package/backend/prisma/migrations/20260612140000_add_connector_model/migration.sql +9 -0
- package/backend/prisma/migrations/20260612173937_add_connector_services_account/migration.sql +24 -0
- package/backend/prisma/migrations/20260612181017_remove_connector_services/migration.sql +23 -0
- package/backend/prisma/migrations/20260613135109_add_schedule_tasks/migration.sql +45 -0
- package/backend/prisma/migrations/20260613140915_add_cron_days_of_week/migration.sql +2 -0
- package/backend/prisma/migrations/20260613142809_add_timezone/migration.sql +2 -0
- package/backend/prisma/migrations/20260613163408_remove_task_model/migration.sql +10 -0
- package/backend/prisma/migrations/20260620120025_add_agent_profile/migration.sql +17 -0
- package/backend/prisma/migrations/migration_lock.toml +3 -0
- package/backend/prisma/schema.prisma +208 -0
- package/backend/prisma/seed.cjs +132 -0
- package/bin/workspace-cli.js +296 -0
- package/frontend/dist/assets/index-DRtpgPPc.css +1 -0
- package/frontend/dist/assets/index-Dn28_pkr.js +101 -0
- package/frontend/dist/index.html +19 -0
- package/frontend/dist/logo.png +0 -0
- package/package.json +54 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.UpdateYoloConfigDto = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
class UpdateYoloConfigDto {
|
|
15
|
+
}
|
|
16
|
+
exports.UpdateYoloConfigDto = UpdateYoloConfigDto;
|
|
17
|
+
__decorate([
|
|
18
|
+
(0, class_validator_1.IsOptional)(),
|
|
19
|
+
(0, class_validator_1.IsArray)(),
|
|
20
|
+
(0, class_validator_1.IsString)({ each: true }),
|
|
21
|
+
__metadata("design:type", Array)
|
|
22
|
+
], UpdateYoloConfigDto.prototype, "disabledPatterns", void 0);
|
|
23
|
+
__decorate([
|
|
24
|
+
(0, class_validator_1.IsOptional)(),
|
|
25
|
+
(0, class_validator_1.IsBoolean)(),
|
|
26
|
+
__metadata("design:type", Boolean)
|
|
27
|
+
], UpdateYoloConfigDto.prototype, "failClosed", void 0);
|
|
28
|
+
__decorate([
|
|
29
|
+
(0, class_validator_1.IsOptional)(),
|
|
30
|
+
(0, class_validator_1.IsBoolean)(),
|
|
31
|
+
__metadata("design:type", Boolean)
|
|
32
|
+
], UpdateYoloConfigDto.prototype, "safeToolAllowlist", void 0);
|
|
33
|
+
//# sourceMappingURL=yolo-config.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"yolo-config.dto.js","sourceRoot":"","sources":["../../../src/agent/dto/yolo-config.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAA2E;AAE3E,MAAa,mBAAmB;CAa/B;AAbD,kDAaC;AATC;IAHC,IAAA,4BAAU,GAAE;IACZ,IAAA,yBAAO,GAAE;IACT,IAAA,0BAAQ,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;;6DACG;AAI5B;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,2BAAS,GAAE;;uDACS;AAIrB;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,2BAAS,GAAE;;8DACgB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export interface McpToolDefinition {
|
|
2
|
+
name: string;
|
|
3
|
+
description?: string;
|
|
4
|
+
inputSchema?: Record<string, unknown>;
|
|
5
|
+
}
|
|
6
|
+
export declare class McpClientService {
|
|
7
|
+
private client;
|
|
8
|
+
private transport;
|
|
9
|
+
isConnected(): boolean;
|
|
10
|
+
connectStdio(command: string, args?: string[]): Promise<void>;
|
|
11
|
+
connectSSE(url: string): Promise<void>;
|
|
12
|
+
listTools(): Promise<McpToolDefinition[]>;
|
|
13
|
+
callTool(name: string, args: Record<string, unknown>): Promise<string>;
|
|
14
|
+
disconnect(): Promise<void>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.McpClientService = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const index_js_1 = require("@modelcontextprotocol/sdk/client/index.js");
|
|
12
|
+
const stdio_js_1 = require("@modelcontextprotocol/sdk/client/stdio.js");
|
|
13
|
+
const sse_js_1 = require("@modelcontextprotocol/sdk/client/sse.js");
|
|
14
|
+
let McpClientService = class McpClientService {
|
|
15
|
+
constructor() {
|
|
16
|
+
this.client = null;
|
|
17
|
+
this.transport = null;
|
|
18
|
+
}
|
|
19
|
+
isConnected() {
|
|
20
|
+
return this.client !== null;
|
|
21
|
+
}
|
|
22
|
+
async connectStdio(command, args = []) {
|
|
23
|
+
this.transport = new stdio_js_1.StdioClientTransport({ command, args });
|
|
24
|
+
this.client = new index_js_1.Client({ name: 'workspace-agent', version: '0.1.0' }, { capabilities: {} });
|
|
25
|
+
await this.client.connect(this.transport);
|
|
26
|
+
}
|
|
27
|
+
async connectSSE(url) {
|
|
28
|
+
this.transport = new sse_js_1.SSEClientTransport(new URL(url));
|
|
29
|
+
this.client = new index_js_1.Client({ name: 'workspace-agent', version: '0.1.0' }, { capabilities: {} });
|
|
30
|
+
await this.client.connect(this.transport);
|
|
31
|
+
}
|
|
32
|
+
async listTools() {
|
|
33
|
+
if (!this.client)
|
|
34
|
+
return [];
|
|
35
|
+
const result = await this.client.listTools();
|
|
36
|
+
return result.tools.map(t => ({
|
|
37
|
+
name: t.name,
|
|
38
|
+
description: t.description,
|
|
39
|
+
inputSchema: t.inputSchema,
|
|
40
|
+
}));
|
|
41
|
+
}
|
|
42
|
+
async callTool(name, args) {
|
|
43
|
+
if (!this.client)
|
|
44
|
+
return 'Error: MCP client not connected.';
|
|
45
|
+
try {
|
|
46
|
+
const result = await this.client.callTool({
|
|
47
|
+
name,
|
|
48
|
+
arguments: args,
|
|
49
|
+
});
|
|
50
|
+
const content = (result.content ?? []);
|
|
51
|
+
return content
|
|
52
|
+
.map(c => (c.text ?? JSON.stringify(c)))
|
|
53
|
+
.join('\n');
|
|
54
|
+
}
|
|
55
|
+
catch (e) {
|
|
56
|
+
return `Error: MCP tool "${name}" failed: ${e instanceof Error ? e.message : 'Unknown error'}`;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
async disconnect() {
|
|
60
|
+
if (this.transport) {
|
|
61
|
+
await this.transport.close();
|
|
62
|
+
this.transport = null;
|
|
63
|
+
}
|
|
64
|
+
this.client = null;
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
exports.McpClientService = McpClientService;
|
|
68
|
+
exports.McpClientService = McpClientService = __decorate([
|
|
69
|
+
(0, common_1.Injectable)()
|
|
70
|
+
], McpClientService);
|
|
71
|
+
//# sourceMappingURL=mcp-client.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-client.service.js","sourceRoot":"","sources":["../../../src/agent/mcp/mcp-client.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.McpModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const mcp_service_1 = require("./mcp.service");
|
|
12
|
+
const mcp_client_service_1 = require("./mcp-client.service");
|
|
13
|
+
const workspace_module_1 = require("../../workspace/workspace.module");
|
|
14
|
+
let McpModule = class McpModule {
|
|
15
|
+
};
|
|
16
|
+
exports.McpModule = McpModule;
|
|
17
|
+
exports.McpModule = McpModule = __decorate([
|
|
18
|
+
(0, common_1.Module)({
|
|
19
|
+
imports: [workspace_module_1.WorkspaceModule],
|
|
20
|
+
providers: [mcp_service_1.McpService, mcp_client_service_1.McpClientService],
|
|
21
|
+
exports: [mcp_service_1.McpService, mcp_client_service_1.McpClientService],
|
|
22
|
+
})
|
|
23
|
+
], McpModule);
|
|
24
|
+
//# sourceMappingURL=mcp.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp.module.js","sourceRoot":"","sources":["../../../src/agent/mcp/mcp.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,+CAA2C;AAC3C,6DAAwD;AACxD,uEAAmE;AAO5D,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IALrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,kCAAe,CAAC;QAC1B,SAAS,EAAE,CAAC,wBAAU,EAAE,qCAAgB,CAAC;QACzC,OAAO,EAAE,CAAC,wBAAU,EAAE,qCAAgB,CAAC;KACxC,CAAC;GACW,SAAS,CAAG"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { OnModuleInit } from '@nestjs/common';
|
|
2
|
+
import { ConfigService } from '@nestjs/config';
|
|
3
|
+
import { WorkspaceService } from '../../workspace/workspace.service';
|
|
4
|
+
export declare class McpService implements OnModuleInit {
|
|
5
|
+
private readonly config;
|
|
6
|
+
private readonly workspace;
|
|
7
|
+
private readonly logger;
|
|
8
|
+
private servers;
|
|
9
|
+
constructor(config: ConfigService, workspace: WorkspaceService);
|
|
10
|
+
onModuleInit(): Promise<void>;
|
|
11
|
+
private ensurePlaywrightBrowsers;
|
|
12
|
+
private getCustomChromeUserDataDir;
|
|
13
|
+
private startPlaywrightServer;
|
|
14
|
+
tryExecute(name: string, args: Record<string, unknown>): Promise<string | null>;
|
|
15
|
+
getServers(): string[];
|
|
16
|
+
getAllTools(): Promise<Array<{
|
|
17
|
+
name: string;
|
|
18
|
+
description?: string;
|
|
19
|
+
parameters: Record<string, unknown>;
|
|
20
|
+
}>>;
|
|
21
|
+
addServer(id: string, command: string, args: string[]): Promise<void>;
|
|
22
|
+
removeServer(id: string): Promise<void>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var McpService_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.McpService = void 0;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const config_1 = require("@nestjs/config");
|
|
16
|
+
const mcp_client_service_1 = require("./mcp-client.service");
|
|
17
|
+
const workspace_service_1 = require("../../workspace/workspace.service");
|
|
18
|
+
const path = require("path");
|
|
19
|
+
const fs = require("fs");
|
|
20
|
+
const child_process_1 = require("child_process");
|
|
21
|
+
let McpService = McpService_1 = class McpService {
|
|
22
|
+
constructor(config, workspace) {
|
|
23
|
+
this.config = config;
|
|
24
|
+
this.workspace = workspace;
|
|
25
|
+
this.logger = new common_1.Logger(McpService_1.name);
|
|
26
|
+
this.servers = new Map();
|
|
27
|
+
}
|
|
28
|
+
async onModuleInit() {
|
|
29
|
+
await this.startPlaywrightServer();
|
|
30
|
+
}
|
|
31
|
+
async ensurePlaywrightBrowsers() {
|
|
32
|
+
try {
|
|
33
|
+
const result = (0, child_process_1.execSync)('npx playwright install chromium 2>&1', {
|
|
34
|
+
timeout: 120_000,
|
|
35
|
+
stdio: 'pipe',
|
|
36
|
+
windowsHide: true,
|
|
37
|
+
});
|
|
38
|
+
this.logger.log('Playwright Chromium installed/verified');
|
|
39
|
+
}
|
|
40
|
+
catch (e) {
|
|
41
|
+
this.logger.warn('Could not install Playwright browsers:', e.message);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
getCustomChromeUserDataDir() {
|
|
45
|
+
const dir = this.config.get('CHROME_USER_DATA_DIR');
|
|
46
|
+
return dir ? path.resolve(dir) : null;
|
|
47
|
+
}
|
|
48
|
+
async startPlaywrightServer() {
|
|
49
|
+
try {
|
|
50
|
+
await this.ensurePlaywrightBrowsers();
|
|
51
|
+
const root = this.workspace.getWorkspaceRoot();
|
|
52
|
+
const snapshotDir = path.resolve(root, 'mcp_data');
|
|
53
|
+
fs.mkdirSync(snapshotDir, { recursive: true });
|
|
54
|
+
const args = [
|
|
55
|
+
'@playwright/mcp',
|
|
56
|
+
`--user-data-dir=${path.resolve(root, 'playwright-profile')}`,
|
|
57
|
+
`--output-dir=${snapshotDir}`,
|
|
58
|
+
'--output-mode=file',
|
|
59
|
+
];
|
|
60
|
+
const customDataDir = this.getCustomChromeUserDataDir();
|
|
61
|
+
if (customDataDir) {
|
|
62
|
+
const isolatedDir = path.join(customDataDir, 'AgentWorkspace');
|
|
63
|
+
fs.mkdirSync(isolatedDir, { recursive: true });
|
|
64
|
+
args[1] = `--user-data-dir=${isolatedDir}`;
|
|
65
|
+
this.logger.log(`Using Chrome profile at: ${isolatedDir}`);
|
|
66
|
+
}
|
|
67
|
+
this.logger.log('Starting Playwright MCP server...');
|
|
68
|
+
const client = new mcp_client_service_1.McpClientService();
|
|
69
|
+
await client.connectStdio('npx', args);
|
|
70
|
+
this.servers.set('playwright', { id: 'playwright', client });
|
|
71
|
+
this.logger.log('Playwright MCP server started');
|
|
72
|
+
}
|
|
73
|
+
catch (e) {
|
|
74
|
+
this.logger.warn('Playwright MCP not available:', e.message);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
async tryExecute(name, args) {
|
|
78
|
+
const match = name.match(/^mcp__(.+)__(.+)$/);
|
|
79
|
+
if (!match)
|
|
80
|
+
return null;
|
|
81
|
+
const [, serverId, toolName] = match;
|
|
82
|
+
const server = this.servers.get(serverId);
|
|
83
|
+
if (!server)
|
|
84
|
+
return null;
|
|
85
|
+
return server.client.callTool(toolName, args);
|
|
86
|
+
}
|
|
87
|
+
getServers() {
|
|
88
|
+
return Array.from(this.servers.keys());
|
|
89
|
+
}
|
|
90
|
+
async getAllTools() {
|
|
91
|
+
const tools = [];
|
|
92
|
+
for (const [serverId, entry] of this.servers) {
|
|
93
|
+
const mcpTools = await entry.client.listTools();
|
|
94
|
+
for (const t of mcpTools) {
|
|
95
|
+
tools.push({
|
|
96
|
+
name: `mcp__${serverId}__${t.name}`,
|
|
97
|
+
description: t.description,
|
|
98
|
+
parameters: t.inputSchema ?? {},
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
return tools;
|
|
103
|
+
}
|
|
104
|
+
async addServer(id, command, args) {
|
|
105
|
+
const client = new mcp_client_service_1.McpClientService();
|
|
106
|
+
await client.connectStdio(command, args);
|
|
107
|
+
this.servers.set(id, { id, client });
|
|
108
|
+
}
|
|
109
|
+
async removeServer(id) {
|
|
110
|
+
const server = this.servers.get(id);
|
|
111
|
+
if (server) {
|
|
112
|
+
await server.client.disconnect();
|
|
113
|
+
this.servers.delete(id);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
exports.McpService = McpService;
|
|
118
|
+
exports.McpService = McpService = McpService_1 = __decorate([
|
|
119
|
+
(0, common_1.Injectable)(),
|
|
120
|
+
__metadata("design:paramtypes", [config_1.ConfigService,
|
|
121
|
+
workspace_service_1.WorkspaceService])
|
|
122
|
+
], McpService);
|
|
123
|
+
//# sourceMappingURL=mcp.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp.service.js","sourceRoot":"","sources":["../../../src/agent/mcp/mcp.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ToolDefinition } from '../services/context-builder.service';
|
|
2
|
+
export interface StreamChunk {
|
|
3
|
+
type: 'token' | 'tool_call' | 'thinking' | 'done' | 'error';
|
|
4
|
+
token?: string;
|
|
5
|
+
toolCall?: {
|
|
6
|
+
name: string;
|
|
7
|
+
arguments: unknown;
|
|
8
|
+
};
|
|
9
|
+
reasoningContent?: string;
|
|
10
|
+
thinking?: string;
|
|
11
|
+
error?: string;
|
|
12
|
+
usage?: {
|
|
13
|
+
promptTokens: number;
|
|
14
|
+
completionTokens: number;
|
|
15
|
+
totalTokens: number;
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export interface OllamaMessage {
|
|
19
|
+
role: 'system' | 'user' | 'assistant' | 'tool';
|
|
20
|
+
content: string;
|
|
21
|
+
reasoningContent?: string;
|
|
22
|
+
toolCallId?: string;
|
|
23
|
+
toolCalls?: Array<{
|
|
24
|
+
id?: string;
|
|
25
|
+
function: {
|
|
26
|
+
name: string;
|
|
27
|
+
arguments: unknown;
|
|
28
|
+
};
|
|
29
|
+
}>;
|
|
30
|
+
}
|
|
31
|
+
export interface StreamOptions {
|
|
32
|
+
model: string;
|
|
33
|
+
messages: OllamaMessage[];
|
|
34
|
+
tools: ToolDefinition[];
|
|
35
|
+
signal: AbortSignal;
|
|
36
|
+
baseUrl: string;
|
|
37
|
+
key?: string;
|
|
38
|
+
}
|
|
39
|
+
export interface LLMProvider {
|
|
40
|
+
stream(options: StreamOptions): AsyncGenerator<StreamChunk>;
|
|
41
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-provider.interface.js","sourceRoot":"","sources":["../../../src/agent/providers/llm-provider.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var OllamaProvider_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.OllamaProvider = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
let OllamaProvider = OllamaProvider_1 = class OllamaProvider {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.logger = new common_1.Logger(OllamaProvider_1.name);
|
|
15
|
+
}
|
|
16
|
+
async *stream(options) {
|
|
17
|
+
const { model, messages, tools, signal, baseUrl, key } = options;
|
|
18
|
+
if (signal.aborted)
|
|
19
|
+
return;
|
|
20
|
+
const msgs = messages.map(m => ({
|
|
21
|
+
role: m.role,
|
|
22
|
+
content: m.content,
|
|
23
|
+
...(m.toolCalls ? { tool_calls: m.toolCalls } : {}),
|
|
24
|
+
}));
|
|
25
|
+
const body = { model, messages: msgs, stream: true };
|
|
26
|
+
if (tools.length > 0)
|
|
27
|
+
body.tools = tools;
|
|
28
|
+
const headers = { 'Content-Type': 'application/json' };
|
|
29
|
+
if (key)
|
|
30
|
+
headers['Authorization'] = `Bearer ${key}`;
|
|
31
|
+
let res;
|
|
32
|
+
try {
|
|
33
|
+
res = await fetch(`${baseUrl}/api/chat`, {
|
|
34
|
+
method: 'POST', headers, body: JSON.stringify(body), signal,
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
catch {
|
|
38
|
+
if (signal.aborted)
|
|
39
|
+
return;
|
|
40
|
+
yield { type: 'error', error: 'ollama_unreachable' };
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
if (!res.ok) {
|
|
44
|
+
let detail = `ollama_error_${res.status}`;
|
|
45
|
+
try {
|
|
46
|
+
const errBody = await res.json();
|
|
47
|
+
if (errBody.error)
|
|
48
|
+
detail = errBody.error;
|
|
49
|
+
}
|
|
50
|
+
catch { }
|
|
51
|
+
yield { type: 'error', error: detail };
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
const reader = res.body.getReader();
|
|
55
|
+
const decoder = new TextDecoder();
|
|
56
|
+
let buf = '';
|
|
57
|
+
signal.addEventListener('abort', () => reader.cancel(), { once: true });
|
|
58
|
+
while (!signal.aborted) {
|
|
59
|
+
const { done, value } = await reader.read();
|
|
60
|
+
if (done)
|
|
61
|
+
break;
|
|
62
|
+
buf += decoder.decode(value, { stream: true });
|
|
63
|
+
const lines = buf.split('\n');
|
|
64
|
+
buf = lines.pop() ?? '';
|
|
65
|
+
for (const line of lines) {
|
|
66
|
+
if (!line.trim())
|
|
67
|
+
continue;
|
|
68
|
+
try {
|
|
69
|
+
const parsed = JSON.parse(line);
|
|
70
|
+
if (parsed.message?.content) {
|
|
71
|
+
yield { type: 'token', token: parsed.message.content };
|
|
72
|
+
}
|
|
73
|
+
if (parsed.message?.tool_calls) {
|
|
74
|
+
for (const tc of parsed.message.tool_calls) {
|
|
75
|
+
yield {
|
|
76
|
+
type: 'tool_call',
|
|
77
|
+
toolCall: { name: tc.function.name, arguments: tc.function.arguments },
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
catch { }
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
yield { type: 'done' };
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
exports.OllamaProvider = OllamaProvider;
|
|
89
|
+
exports.OllamaProvider = OllamaProvider = OllamaProvider_1 = __decorate([
|
|
90
|
+
(0, common_1.Injectable)()
|
|
91
|
+
], OllamaProvider);
|
|
92
|
+
//# sourceMappingURL=ollama.provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ollama.provider.js","sourceRoot":"","sources":["../../../src/agent/providers/ollama.provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var OpenAIProvider_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.OpenAIProvider = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
let OpenAIProvider = OpenAIProvider_1 = class OpenAIProvider {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.logger = new common_1.Logger(OpenAIProvider_1.name);
|
|
15
|
+
}
|
|
16
|
+
async *stream(options) {
|
|
17
|
+
const { model, messages, tools, signal, baseUrl, key } = options;
|
|
18
|
+
if (signal.aborted)
|
|
19
|
+
return;
|
|
20
|
+
const msgs = messages.map(m => ({
|
|
21
|
+
role: m.role,
|
|
22
|
+
content: m.content,
|
|
23
|
+
...(m.role === 'assistant' ? { reasoning_content: m.reasoningContent ?? '' } : {}),
|
|
24
|
+
...(m.toolCalls ? {
|
|
25
|
+
tool_calls: m.toolCalls.map(tc => ({
|
|
26
|
+
id: tc.id ?? `call_${Date.now()}`,
|
|
27
|
+
type: 'function',
|
|
28
|
+
function: {
|
|
29
|
+
name: tc.function.name,
|
|
30
|
+
arguments: typeof tc.function.arguments === 'string'
|
|
31
|
+
? tc.function.arguments
|
|
32
|
+
: JSON.stringify(tc.function.arguments),
|
|
33
|
+
},
|
|
34
|
+
})),
|
|
35
|
+
} : {}),
|
|
36
|
+
...(m.toolCallId ? { tool_call_id: m.toolCallId } : {}),
|
|
37
|
+
}));
|
|
38
|
+
const body = { model, messages: msgs, stream: true };
|
|
39
|
+
if (tools.length > 0)
|
|
40
|
+
body.tools = tools;
|
|
41
|
+
const headers = { 'Content-Type': 'application/json' };
|
|
42
|
+
if (key)
|
|
43
|
+
headers['Authorization'] = `Bearer ${key}`;
|
|
44
|
+
let res;
|
|
45
|
+
try {
|
|
46
|
+
res = await fetch(`${baseUrl}/chat/completions`, {
|
|
47
|
+
method: 'POST', headers, body: JSON.stringify(body), signal,
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
catch {
|
|
51
|
+
if (signal.aborted)
|
|
52
|
+
return;
|
|
53
|
+
yield { type: 'error', error: 'provider_unreachable' };
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (!res.ok) {
|
|
57
|
+
let detail = `provider_error_${res.status}`;
|
|
58
|
+
try {
|
|
59
|
+
const errBody = await res.json();
|
|
60
|
+
if (typeof errBody.error === 'string')
|
|
61
|
+
detail = errBody.error;
|
|
62
|
+
else if (errBody.error?.message)
|
|
63
|
+
detail = errBody.error.message;
|
|
64
|
+
}
|
|
65
|
+
catch { }
|
|
66
|
+
yield { type: 'error', error: detail };
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
const reader = res.body.getReader();
|
|
70
|
+
const decoder = new TextDecoder();
|
|
71
|
+
let buf = '';
|
|
72
|
+
const pendingToolCalls = new Map();
|
|
73
|
+
let reasoningContent = '';
|
|
74
|
+
let lastUsage;
|
|
75
|
+
signal.addEventListener('abort', () => reader.cancel(), { once: true });
|
|
76
|
+
while (!signal.aborted) {
|
|
77
|
+
const { done, value } = await reader.read();
|
|
78
|
+
if (done)
|
|
79
|
+
break;
|
|
80
|
+
buf += decoder.decode(value, { stream: true });
|
|
81
|
+
const lines = buf.split('\n');
|
|
82
|
+
buf = lines.pop() ?? '';
|
|
83
|
+
for (const line of lines) {
|
|
84
|
+
const trimmed = line.trim();
|
|
85
|
+
if (!trimmed || !trimmed.startsWith('data: '))
|
|
86
|
+
continue;
|
|
87
|
+
const payload = trimmed.slice(6);
|
|
88
|
+
if (payload === '[DONE]') {
|
|
89
|
+
for (const [, tc] of pendingToolCalls) {
|
|
90
|
+
let parsedArgs;
|
|
91
|
+
try {
|
|
92
|
+
parsedArgs = JSON.parse(tc.arguments);
|
|
93
|
+
}
|
|
94
|
+
catch {
|
|
95
|
+
parsedArgs = tc.arguments;
|
|
96
|
+
}
|
|
97
|
+
yield { type: 'tool_call', toolCall: { name: tc.name, arguments: parsedArgs }, reasoningContent };
|
|
98
|
+
}
|
|
99
|
+
pendingToolCalls.clear();
|
|
100
|
+
yield { type: 'done', usage: lastUsage };
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
try {
|
|
104
|
+
const parsed = JSON.parse(payload);
|
|
105
|
+
const choice = parsed.choices?.[0];
|
|
106
|
+
if (!choice)
|
|
107
|
+
continue;
|
|
108
|
+
if (choice.delta?.reasoning_content) {
|
|
109
|
+
reasoningContent += choice.delta.reasoning_content;
|
|
110
|
+
}
|
|
111
|
+
if (choice.delta?.content) {
|
|
112
|
+
yield { type: 'token', token: choice.delta.content, reasoningContent: choice.delta.reasoning_content || reasoningContent };
|
|
113
|
+
}
|
|
114
|
+
if (choice.delta?.tool_calls) {
|
|
115
|
+
for (const tc of choice.delta.tool_calls) {
|
|
116
|
+
const index = tc.index ?? 0;
|
|
117
|
+
const existing = pendingToolCalls.get(index) ?? { name: '', arguments: '' };
|
|
118
|
+
if (tc.function?.name)
|
|
119
|
+
existing.name += tc.function.name;
|
|
120
|
+
if (tc.function?.arguments)
|
|
121
|
+
existing.arguments += tc.function.arguments;
|
|
122
|
+
pendingToolCalls.set(index, existing);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
if (choice.finish_reason === 'tool_calls') {
|
|
126
|
+
for (const [, tc] of pendingToolCalls) {
|
|
127
|
+
let parsedArgs;
|
|
128
|
+
try {
|
|
129
|
+
parsedArgs = JSON.parse(tc.arguments);
|
|
130
|
+
}
|
|
131
|
+
catch {
|
|
132
|
+
parsedArgs = tc.arguments;
|
|
133
|
+
}
|
|
134
|
+
yield { type: 'tool_call', toolCall: { name: tc.name, arguments: parsedArgs }, reasoningContent };
|
|
135
|
+
}
|
|
136
|
+
pendingToolCalls.clear();
|
|
137
|
+
}
|
|
138
|
+
if (parsed.usage) {
|
|
139
|
+
lastUsage = {
|
|
140
|
+
promptTokens: parsed.usage.prompt_tokens,
|
|
141
|
+
completionTokens: parsed.usage.completion_tokens,
|
|
142
|
+
totalTokens: parsed.usage.total_tokens,
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
catch { }
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
if (pendingToolCalls.size > 0) {
|
|
150
|
+
for (const [, tc] of pendingToolCalls) {
|
|
151
|
+
let parsedArgs;
|
|
152
|
+
try {
|
|
153
|
+
parsedArgs = JSON.parse(tc.arguments);
|
|
154
|
+
}
|
|
155
|
+
catch {
|
|
156
|
+
parsedArgs = tc.arguments;
|
|
157
|
+
}
|
|
158
|
+
yield { type: 'tool_call', toolCall: { name: tc.name, arguments: parsedArgs }, reasoningContent };
|
|
159
|
+
}
|
|
160
|
+
pendingToolCalls.clear();
|
|
161
|
+
}
|
|
162
|
+
yield { type: 'done', usage: lastUsage };
|
|
163
|
+
}
|
|
164
|
+
};
|
|
165
|
+
exports.OpenAIProvider = OpenAIProvider;
|
|
166
|
+
exports.OpenAIProvider = OpenAIProvider = OpenAIProvider_1 = __decorate([
|
|
167
|
+
(0, common_1.Injectable)()
|
|
168
|
+
], OpenAIProvider);
|
|
169
|
+
//# sourceMappingURL=openai.provider.js.map
|