@octo-cyber/ai 0.5.4 → 0.5.6
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/dist/shared/IClaudeCodeSessionManager.d.ts +151 -0
- package/dist/shared/IClaudeCodeSessionManager.d.ts.map +1 -0
- package/dist/shared/IClaudeCodeSessionManager.js +6 -0
- package/dist/shared/IClaudeCodeSessionManager.js.map +1 -0
- package/dist/src/BranchDecisionEngine.d.ts +73 -0
- package/dist/src/BranchDecisionEngine.d.ts.map +1 -0
- package/dist/src/BranchDecisionEngine.js +195 -0
- package/dist/src/BranchDecisionEngine.js.map +1 -0
- package/dist/src/agent/agent-approval.controller.d.ts +20 -0
- package/dist/src/agent/agent-approval.controller.d.ts.map +1 -0
- package/dist/src/agent/agent-approval.controller.js +101 -0
- package/dist/src/agent/agent-approval.controller.js.map +1 -0
- package/dist/src/agent/agent-approval.entity.d.ts +15 -0
- package/dist/src/agent/agent-approval.entity.d.ts.map +1 -0
- package/dist/src/agent/agent-approval.entity.js +63 -0
- package/dist/src/agent/agent-approval.entity.js.map +1 -0
- package/dist/src/agent/agent-approval.service.d.ts +35 -0
- package/dist/src/agent/agent-approval.service.d.ts.map +1 -0
- package/dist/src/agent/agent-approval.service.js +109 -0
- package/dist/src/agent/agent-approval.service.js.map +1 -0
- package/dist/src/agent/agent-gateway.controller.d.ts +30 -0
- package/dist/src/agent/agent-gateway.controller.d.ts.map +1 -0
- package/dist/src/agent/agent-gateway.controller.js +112 -0
- package/dist/src/agent/agent-gateway.controller.js.map +1 -0
- package/dist/src/agent/agent-gateway.service.d.ts +33 -0
- package/dist/src/agent/agent-gateway.service.d.ts.map +1 -0
- package/dist/src/agent/agent-gateway.service.js +84 -0
- package/dist/src/agent/agent-gateway.service.js.map +1 -0
- package/dist/src/agent/agent-registry.service.d.ts +30 -0
- package/dist/src/agent/agent-registry.service.d.ts.map +1 -0
- package/dist/src/agent/agent-registry.service.js +45 -0
- package/dist/src/agent/agent-registry.service.js.map +1 -0
- package/dist/src/agent/agent-run.controller.d.ts +42 -0
- package/dist/src/agent/agent-run.controller.d.ts.map +1 -0
- package/dist/src/agent/agent-run.controller.js +195 -0
- package/dist/src/agent/agent-run.controller.js.map +1 -0
- package/dist/src/agent/agent-run.entity.d.ts +35 -0
- package/dist/src/agent/agent-run.entity.d.ts.map +1 -0
- package/dist/src/agent/agent-run.entity.js +98 -0
- package/dist/src/agent/agent-run.entity.js.map +1 -0
- package/dist/src/agent/agent-run.service.d.ts +48 -0
- package/dist/src/agent/agent-run.service.d.ts.map +1 -0
- package/dist/src/agent/agent-run.service.js +155 -0
- package/dist/src/agent/agent-run.service.js.map +1 -0
- package/dist/src/agent/agent-session.controller.d.ts +20 -0
- package/dist/src/agent/agent-session.controller.d.ts.map +1 -0
- package/dist/src/agent/agent-session.controller.js +97 -0
- package/dist/src/agent/agent-session.controller.js.map +1 -0
- package/dist/src/agent/agent-session.entity.d.ts +13 -0
- package/dist/src/agent/agent-session.entity.d.ts.map +1 -0
- package/dist/src/agent/agent-session.entity.js +57 -0
- package/dist/src/agent/agent-session.entity.js.map +1 -0
- package/dist/src/agent/agent-session.service.d.ts +38 -0
- package/dist/src/agent/agent-session.service.d.ts.map +1 -0
- package/dist/src/agent/agent-session.service.js +112 -0
- package/dist/src/agent/agent-session.service.js.map +1 -0
- package/dist/src/agent/coding-tools.d.ts +7 -0
- package/dist/src/agent/coding-tools.d.ts.map +1 -0
- package/dist/src/agent/coding-tools.js +181 -0
- package/dist/src/agent/coding-tools.js.map +1 -0
- package/dist/src/agent/computer-use-tools.d.ts +15 -0
- package/dist/src/agent/computer-use-tools.d.ts.map +1 -0
- package/dist/src/agent/computer-use-tools.js +256 -0
- package/dist/src/agent/computer-use-tools.js.map +1 -0
- package/dist/src/agent/external-agent.controller.d.ts +41 -0
- package/dist/src/agent/external-agent.controller.d.ts.map +1 -0
- package/dist/src/agent/external-agent.controller.js +129 -0
- package/dist/src/agent/external-agent.controller.js.map +1 -0
- package/dist/src/agent/external-agent.entity.d.ts +22 -0
- package/dist/src/agent/external-agent.entity.d.ts.map +1 -0
- package/dist/src/agent/external-agent.entity.js +75 -0
- package/dist/src/agent/external-agent.entity.js.map +1 -0
- package/dist/src/agent/external-agent.service.d.ts +60 -0
- package/dist/src/agent/external-agent.service.d.ts.map +1 -0
- package/dist/src/agent/external-agent.service.js +143 -0
- package/dist/src/agent/external-agent.service.js.map +1 -0
- package/dist/src/ai.module.d.ts +22 -0
- package/dist/src/ai.module.d.ts.map +1 -0
- package/dist/src/ai.module.js +178 -0
- package/dist/src/ai.module.js.map +1 -0
- package/dist/{cli → src/cli}/adapters/antigravity.adapter.d.ts +2 -0
- package/dist/src/cli/adapters/antigravity.adapter.d.ts.map +1 -0
- package/dist/{cli → src/cli}/adapters/antigravity.adapter.js +78 -0
- package/dist/src/cli/adapters/antigravity.adapter.js.map +1 -0
- package/dist/src/cli/adapters/claude-cli.adapter.d.ts.map +1 -0
- package/dist/{cli → src/cli}/adapters/claude-cli.adapter.js +2 -0
- package/dist/src/cli/adapters/claude-cli.adapter.js.map +1 -0
- package/dist/src/cli/adapters/cli-proxy-api.adapter.d.ts +32 -0
- package/dist/src/cli/adapters/cli-proxy-api.adapter.d.ts.map +1 -0
- package/dist/src/cli/adapters/cli-proxy-api.adapter.js +239 -0
- package/dist/src/cli/adapters/cli-proxy-api.adapter.js.map +1 -0
- package/dist/src/cli/adapters/codex-cli.adapter.d.ts.map +1 -0
- package/dist/src/cli/adapters/codex-cli.adapter.js.map +1 -0
- package/dist/src/cli/adapters/detect-cli.d.ts.map +1 -0
- package/dist/src/cli/adapters/detect-cli.js.map +1 -0
- package/dist/src/cli/adapters/gemini-cli.adapter.d.ts.map +1 -0
- package/dist/src/cli/adapters/gemini-cli.adapter.js.map +1 -0
- package/dist/src/cli/adapters/index.d.ts.map +1 -0
- package/dist/src/cli/adapters/index.js.map +1 -0
- package/dist/{cli → src/cli}/cli-executor.service.d.ts +2 -0
- package/dist/src/cli/cli-executor.service.d.ts.map +1 -0
- package/dist/{cli → src/cli}/cli-executor.service.js +21 -1
- package/dist/src/cli/cli-executor.service.js.map +1 -0
- package/dist/src/cli/cli-registry.service.d.ts.map +1 -0
- package/dist/{cli → src/cli}/cli-registry.service.js +3 -1
- package/dist/src/cli/cli-registry.service.js.map +1 -0
- package/dist/{cli → src/cli}/controllers/ai-cli.controller.d.ts +4 -0
- package/dist/src/cli/controllers/ai-cli.controller.d.ts.map +1 -0
- package/dist/{cli → src/cli}/controllers/ai-cli.controller.js +33 -4
- package/dist/src/cli/controllers/ai-cli.controller.js.map +1 -0
- package/dist/{cli → src/cli}/index.d.ts +1 -1
- package/dist/src/cli/index.d.ts.map +1 -0
- package/dist/src/cli/index.js.map +1 -0
- package/dist/{cli → src/cli}/types.d.ts +23 -1
- package/dist/src/cli/types.d.ts.map +1 -0
- package/dist/{skill → src/cli}/types.js.map +1 -1
- package/dist/{cli → src/cli}/workspace.service.d.ts +11 -3
- package/dist/src/cli/workspace.service.d.ts.map +1 -0
- package/dist/{cli → src/cli}/workspace.service.js +61 -6
- package/dist/src/cli/workspace.service.js.map +1 -0
- package/dist/src/computer-use/computer-use.controller.d.ts +23 -0
- package/dist/src/computer-use/computer-use.controller.d.ts.map +1 -0
- package/dist/src/computer-use/computer-use.controller.js +87 -0
- package/dist/src/computer-use/computer-use.controller.js.map +1 -0
- package/dist/src/index.d.ts +12 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +51 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/orchestrator/orchestrator-plan.entity.d.ts +31 -0
- package/dist/src/orchestrator/orchestrator-plan.entity.d.ts.map +1 -0
- package/dist/src/orchestrator/orchestrator-plan.entity.js +69 -0
- package/dist/src/orchestrator/orchestrator-plan.entity.js.map +1 -0
- package/dist/src/orchestrator/orchestrator-plan.service.d.ts +27 -0
- package/dist/src/orchestrator/orchestrator-plan.service.d.ts.map +1 -0
- package/dist/src/orchestrator/orchestrator-plan.service.js +201 -0
- package/dist/src/orchestrator/orchestrator-plan.service.js.map +1 -0
- package/dist/src/orchestrator/orchestrator.controller.d.ts +29 -0
- package/dist/src/orchestrator/orchestrator.controller.d.ts.map +1 -0
- package/dist/src/orchestrator/orchestrator.controller.js +144 -0
- package/dist/src/orchestrator/orchestrator.controller.js.map +1 -0
- package/dist/src/orchestrator/workflow-feedback.entity.d.ts +12 -0
- package/dist/src/orchestrator/workflow-feedback.entity.d.ts.map +1 -0
- package/dist/src/orchestrator/workflow-feedback.entity.js +49 -0
- package/dist/src/orchestrator/workflow-feedback.entity.js.map +1 -0
- package/dist/src/orchestrator/workflow-feedback.service.d.ts +14 -0
- package/dist/src/orchestrator/workflow-feedback.service.d.ts.map +1 -0
- package/dist/src/orchestrator/workflow-feedback.service.js +51 -0
- package/dist/src/orchestrator/workflow-feedback.service.js.map +1 -0
- package/dist/src/session/claude-code-session-manager.service.d.ts +28 -0
- package/dist/src/session/claude-code-session-manager.service.d.ts.map +1 -0
- package/dist/src/session/claude-code-session-manager.service.js +177 -0
- package/dist/src/session/claude-code-session-manager.service.js.map +1 -0
- package/dist/src/skill/controllers/skill-market.controller.d.ts +18 -0
- package/dist/src/skill/controllers/skill-market.controller.d.ts.map +1 -0
- package/dist/src/skill/controllers/skill-market.controller.js +128 -0
- package/dist/src/skill/controllers/skill-market.controller.js.map +1 -0
- package/dist/{skill → src/skill}/controllers/skill.controller.d.ts +4 -0
- package/dist/src/skill/controllers/skill.controller.d.ts.map +1 -0
- package/dist/{skill → src/skill}/controllers/skill.controller.js +31 -0
- package/dist/src/skill/controllers/skill.controller.js.map +1 -0
- package/dist/src/skill/entities/octo-skill.entity.d.ts.map +1 -0
- package/dist/src/skill/entities/octo-skill.entity.js.map +1 -0
- package/dist/{skill → src/skill}/index.d.ts +3 -1
- package/dist/src/skill/index.d.ts.map +1 -0
- package/dist/{skill → src/skill}/index.js +5 -1
- package/dist/src/skill/index.js.map +1 -0
- package/dist/src/skill/services/skill-generator.service.d.ts.map +1 -0
- package/dist/src/skill/services/skill-generator.service.js.map +1 -0
- package/dist/{skill → src/skill}/services/skill-installer.service.d.ts +27 -0
- package/dist/src/skill/services/skill-installer.service.d.ts.map +1 -0
- package/dist/{skill → src/skill}/services/skill-installer.service.js +108 -0
- package/dist/src/skill/services/skill-installer.service.js.map +1 -0
- package/dist/src/skill/services/skill-market-helpers.d.ts +25 -0
- package/dist/src/skill/services/skill-market-helpers.d.ts.map +1 -0
- package/dist/src/skill/services/skill-market-helpers.js +22 -0
- package/dist/src/skill/services/skill-market-helpers.js.map +1 -0
- package/dist/src/skill/services/skill-market.service.d.ts +60 -0
- package/dist/src/skill/services/skill-market.service.d.ts.map +1 -0
- package/dist/src/skill/services/skill-market.service.js +228 -0
- package/dist/src/skill/services/skill-market.service.js.map +1 -0
- package/dist/{skill → src/skill}/services/skill-registry.service.d.ts +1 -0
- package/dist/src/skill/services/skill-registry.service.d.ts.map +1 -0
- package/dist/{skill → src/skill}/services/skill-registry.service.js +18 -6
- package/dist/src/skill/services/skill-registry.service.js.map +1 -0
- package/dist/{skill → src/skill}/types.d.ts +32 -1
- package/dist/src/skill/types.d.ts.map +1 -0
- package/dist/{cli → src/skill}/types.js.map +1 -1
- package/dist/src/workflow-design/DocumentExtractorAgent.d.ts +47 -0
- package/dist/src/workflow-design/DocumentExtractorAgent.d.ts.map +1 -0
- package/dist/src/workflow-design/DocumentExtractorAgent.js +118 -0
- package/dist/src/workflow-design/DocumentExtractorAgent.js.map +1 -0
- package/dist/src/workflow-design/N8nNodeKnowledgeBase.d.ts +26 -0
- package/dist/src/workflow-design/N8nNodeKnowledgeBase.d.ts.map +1 -0
- package/dist/src/workflow-design/N8nNodeKnowledgeBase.js +362 -0
- package/dist/src/workflow-design/N8nNodeKnowledgeBase.js.map +1 -0
- package/dist/src/workflow-design/OctoAgentClient.d.ts +42 -0
- package/dist/src/workflow-design/OctoAgentClient.d.ts.map +1 -0
- package/dist/src/workflow-design/OctoAgentClient.js +191 -0
- package/dist/src/workflow-design/OctoAgentClient.js.map +1 -0
- package/dist/src/workflow-design/WorkflowDesignOrchestrator.d.ts +45 -0
- package/dist/src/workflow-design/WorkflowDesignOrchestrator.d.ts.map +1 -0
- package/dist/src/workflow-design/WorkflowDesignOrchestrator.js +265 -0
- package/dist/src/workflow-design/WorkflowDesignOrchestrator.js.map +1 -0
- package/dist/src/workflow-design/agents/ActionChainAgent.d.ts +9 -0
- package/dist/src/workflow-design/agents/ActionChainAgent.d.ts.map +1 -0
- package/dist/src/workflow-design/agents/ActionChainAgent.js +79 -0
- package/dist/src/workflow-design/agents/ActionChainAgent.js.map +1 -0
- package/dist/src/workflow-design/agents/CodeScriptAgent.d.ts +15 -0
- package/dist/src/workflow-design/agents/CodeScriptAgent.d.ts.map +1 -0
- package/dist/src/workflow-design/agents/CodeScriptAgent.js +96 -0
- package/dist/src/workflow-design/agents/CodeScriptAgent.js.map +1 -0
- package/dist/src/workflow-design/agents/LogicFlowAgent.d.ts +9 -0
- package/dist/src/workflow-design/agents/LogicFlowAgent.d.ts.map +1 -0
- package/dist/src/workflow-design/agents/LogicFlowAgent.js +78 -0
- package/dist/src/workflow-design/agents/LogicFlowAgent.js.map +1 -0
- package/dist/src/workflow-design/agents/TriggerAnalystAgent.d.ts +9 -0
- package/dist/src/workflow-design/agents/TriggerAnalystAgent.d.ts.map +1 -0
- package/dist/src/workflow-design/agents/TriggerAnalystAgent.js +65 -0
- package/dist/src/workflow-design/agents/TriggerAnalystAgent.js.map +1 -0
- package/dist/src/workflow-design/agents/WorkflowValidatorAgent.d.ts +9 -0
- package/dist/src/workflow-design/agents/WorkflowValidatorAgent.d.ts.map +1 -0
- package/dist/src/workflow-design/agents/WorkflowValidatorAgent.js +117 -0
- package/dist/src/workflow-design/agents/WorkflowValidatorAgent.js.map +1 -0
- package/dist/src/workflow-design/index.d.ts +12 -0
- package/dist/src/workflow-design/index.d.ts.map +1 -0
- package/dist/src/workflow-design/index.js +23 -0
- package/dist/src/workflow-design/index.js.map +1 -0
- package/dist/src/workflow-design/types.d.ts +155 -0
- package/dist/src/workflow-design/types.d.ts.map +1 -0
- package/dist/src/workflow-design/types.js +6 -0
- package/dist/src/workflow-design/types.js.map +1 -0
- package/package.json +21 -15
- package/web/components/CreateWorkspaceDialog.tsx +157 -0
- package/web/components/DirBrowser.tsx +85 -0
- package/web/components/GithubTokenDialog.tsx +152 -0
- package/web/components/LocalPathSection.tsx +91 -0
- package/web/components/MarketInstallDialog.tsx +196 -0
- package/web/components/MarketSkillCard.tsx +74 -0
- package/web/components/RepoList.tsx +97 -0
- package/web/components/SearchResultsGrid.tsx +55 -0
- package/web/components/SkillCard.tsx +4 -1
- package/web/components/ToolCard.tsx +88 -0
- package/web/components/WorkspaceCard.tsx +146 -0
- package/web/components/WorkspaceItem.tsx +65 -0
- package/web/components/WorkspaceSelect.tsx +94 -0
- package/web/index.ts +18 -1
- package/web/manifest.ts +7 -0
- package/web/messages/en-US.json +231 -7
- package/web/messages/zh-CN.json +234 -7
- package/web/pages/AgentMarketPage.tsx +318 -0
- package/web/pages/AgentRunsPage.tsx +162 -0
- package/web/pages/AgentsPage.tsx +239 -0
- package/web/pages/AiCliToolsPage.tsx +17 -128
- package/web/pages/ApprovalsPage.tsx +260 -0
- package/web/pages/OrchestratorPage.tsx +384 -0
- package/web/pages/SessionsPage.tsx +248 -0
- package/web/pages/SkillMarketPage.tsx +25 -0
- package/web/pages/WorkspaceSection.tsx +13 -113
- package/web/pages/WorkspacesPage.tsx +29 -254
- package/web/services/agent-approval.service.ts +35 -0
- package/web/services/agent-gateway.service.ts +41 -0
- package/web/services/agent-run.service.ts +48 -0
- package/web/services/agent-session.service.ts +30 -0
- package/web/services/ai-cli-service.ts +33 -0
- package/web/services/external-agent.service.ts +38 -0
- package/web/services/orchestrator.service.ts +52 -0
- package/web/services/skill-market-service.ts +88 -0
- package/web/services/skill-service.ts +12 -0
- package/dist/ai.module.d.ts +0 -4
- package/dist/ai.module.d.ts.map +0 -1
- package/dist/ai.module.js +0 -59
- package/dist/ai.module.js.map +0 -1
- package/dist/cli/adapters/antigravity.adapter.d.ts.map +0 -1
- package/dist/cli/adapters/antigravity.adapter.js.map +0 -1
- package/dist/cli/adapters/claude-cli.adapter.d.ts.map +0 -1
- package/dist/cli/adapters/claude-cli.adapter.js.map +0 -1
- package/dist/cli/adapters/codex-cli.adapter.d.ts.map +0 -1
- package/dist/cli/adapters/codex-cli.adapter.js.map +0 -1
- package/dist/cli/adapters/detect-cli.d.ts.map +0 -1
- package/dist/cli/adapters/detect-cli.js.map +0 -1
- package/dist/cli/adapters/gemini-cli.adapter.d.ts.map +0 -1
- package/dist/cli/adapters/gemini-cli.adapter.js.map +0 -1
- package/dist/cli/adapters/index.d.ts.map +0 -1
- package/dist/cli/adapters/index.js.map +0 -1
- package/dist/cli/cli-executor.service.d.ts.map +0 -1
- package/dist/cli/cli-executor.service.js.map +0 -1
- package/dist/cli/cli-registry.service.d.ts.map +0 -1
- package/dist/cli/cli-registry.service.js.map +0 -1
- package/dist/cli/controllers/ai-cli.controller.d.ts.map +0 -1
- package/dist/cli/controllers/ai-cli.controller.js.map +0 -1
- package/dist/cli/index.d.ts.map +0 -1
- package/dist/cli/index.js.map +0 -1
- package/dist/cli/types.d.ts.map +0 -1
- package/dist/cli/workspace.service.d.ts.map +0 -1
- package/dist/cli/workspace.service.js.map +0 -1
- package/dist/index.d.ts +0 -5
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -23
- package/dist/index.js.map +0 -1
- package/dist/skill/controllers/skill.controller.d.ts.map +0 -1
- package/dist/skill/controllers/skill.controller.js.map +0 -1
- package/dist/skill/entities/octo-skill.entity.d.ts.map +0 -1
- package/dist/skill/entities/octo-skill.entity.js.map +0 -1
- package/dist/skill/index.d.ts.map +0 -1
- package/dist/skill/index.js.map +0 -1
- package/dist/skill/services/skill-generator.service.d.ts.map +0 -1
- package/dist/skill/services/skill-generator.service.js.map +0 -1
- package/dist/skill/services/skill-installer.service.d.ts.map +0 -1
- package/dist/skill/services/skill-installer.service.js.map +0 -1
- package/dist/skill/services/skill-registry.service.d.ts.map +0 -1
- package/dist/skill/services/skill-registry.service.js.map +0 -1
- package/dist/skill/types.d.ts.map +0 -1
- /package/dist/{cli → src/cli}/adapters/claude-cli.adapter.d.ts +0 -0
- /package/dist/{cli → src/cli}/adapters/codex-cli.adapter.d.ts +0 -0
- /package/dist/{cli → src/cli}/adapters/codex-cli.adapter.js +0 -0
- /package/dist/{cli → src/cli}/adapters/detect-cli.d.ts +0 -0
- /package/dist/{cli → src/cli}/adapters/detect-cli.js +0 -0
- /package/dist/{cli → src/cli}/adapters/gemini-cli.adapter.d.ts +0 -0
- /package/dist/{cli → src/cli}/adapters/gemini-cli.adapter.js +0 -0
- /package/dist/{cli → src/cli}/adapters/index.d.ts +0 -0
- /package/dist/{cli → src/cli}/adapters/index.js +0 -0
- /package/dist/{cli → src/cli}/cli-registry.service.d.ts +0 -0
- /package/dist/{cli → src/cli}/index.js +0 -0
- /package/dist/{cli → src/cli}/types.js +0 -0
- /package/dist/{skill → src/skill}/entities/octo-skill.entity.d.ts +0 -0
- /package/dist/{skill → src/skill}/entities/octo-skill.entity.js +0 -0
- /package/dist/{skill → src/skill}/services/skill-generator.service.d.ts +0 -0
- /package/dist/{skill → src/skill}/services/skill-generator.service.js +0 -0
- /package/dist/{skill → src/skill}/types.js +0 -0
|
@@ -0,0 +1,195 @@
|
|
|
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.AgentRunController = void 0;
|
|
13
|
+
const core_1 = require("@octo-cyber/core");
|
|
14
|
+
const agent_run_service_js_1 = require("./agent-run.service.js");
|
|
15
|
+
const MAX_ROUNDS_LIMIT = 50;
|
|
16
|
+
const MAX_ROUNDS_DEFAULT = 20;
|
|
17
|
+
const TIMEOUT_MS_DEFAULT = 300_000;
|
|
18
|
+
/**
|
|
19
|
+
* AgentRunController — async agent execution API.
|
|
20
|
+
*
|
|
21
|
+
* Endpoints:
|
|
22
|
+
* POST /api/v1/ai/agent/run — Submit a new agent run (returns runId immediately)
|
|
23
|
+
* GET /api/v1/ai/agent/run — List recent runs
|
|
24
|
+
* GET /api/v1/ai/agent/run/:id — Get run status + result
|
|
25
|
+
* POST /api/v1/ai/agent/run/:id/cancel — Cancel a pending/running run
|
|
26
|
+
* GET /api/v1/ai/agent/run/:id/events — SSE stream of run events
|
|
27
|
+
*/
|
|
28
|
+
let AgentRunController = class AgentRunController {
|
|
29
|
+
get service() {
|
|
30
|
+
return core_1.Container.get(agent_run_service_js_1.AgentRunService);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Submit a new agent run.
|
|
34
|
+
*
|
|
35
|
+
* Body:
|
|
36
|
+
* agentType {'computer-use'|'coding'|'cli'} — Agent type
|
|
37
|
+
* prompt {string} — Task description
|
|
38
|
+
* maxRounds {number?} — Max LLM rounds (default 20, max 50)
|
|
39
|
+
* timeoutMs {number?} — Timeout in ms (default 300 000)
|
|
40
|
+
* metadata {object?} — Adapter-specific config
|
|
41
|
+
*/
|
|
42
|
+
async submitRun(req, res) {
|
|
43
|
+
const { agentType, prompt, maxRounds, timeoutMs, metadata } = req.body;
|
|
44
|
+
if (!prompt || typeof prompt !== 'string' || prompt.trim().length === 0) {
|
|
45
|
+
throw core_1.AppError.badRequest('Missing or invalid prompt');
|
|
46
|
+
}
|
|
47
|
+
const validTypes = ['computer-use', 'coding', 'cli'];
|
|
48
|
+
const resolvedType = agentType ?? 'computer-use';
|
|
49
|
+
if (!validTypes.includes(resolvedType)) {
|
|
50
|
+
throw core_1.AppError.badRequest(`Invalid agentType: ${String(agentType)}`);
|
|
51
|
+
}
|
|
52
|
+
const run = await this.service.submit({
|
|
53
|
+
agentType: resolvedType,
|
|
54
|
+
prompt: prompt.trim(),
|
|
55
|
+
maxRounds: Math.min(typeof maxRounds === 'number' ? maxRounds : MAX_ROUNDS_DEFAULT, MAX_ROUNDS_LIMIT),
|
|
56
|
+
timeoutMs: typeof timeoutMs === 'number' ? timeoutMs : TIMEOUT_MS_DEFAULT,
|
|
57
|
+
metadata: metadata && typeof metadata === 'object' ? metadata : undefined,
|
|
58
|
+
});
|
|
59
|
+
res.json(core_1.ApiResponse.ok(this.service.toDto(run)));
|
|
60
|
+
}
|
|
61
|
+
/** List recent agent runs (newest first, max 20). */
|
|
62
|
+
async listRuns(_req, res) {
|
|
63
|
+
const runs = await this.service.list();
|
|
64
|
+
res.json(core_1.ApiResponse.ok(runs.map((r) => this.service.toDto(r))));
|
|
65
|
+
}
|
|
66
|
+
/** Get status and result of a specific run. */
|
|
67
|
+
async getRunStatus(req, res) {
|
|
68
|
+
const id = String(req.params['id'] ?? '');
|
|
69
|
+
const run = await this.service.getStatus(id);
|
|
70
|
+
if (!run)
|
|
71
|
+
throw core_1.AppError.notFound(`Agent run not found: ${id}`);
|
|
72
|
+
res.json(core_1.ApiResponse.ok(this.service.toDto(run)));
|
|
73
|
+
}
|
|
74
|
+
/** Cancel a pending or running agent run. */
|
|
75
|
+
async cancelRun(req, res) {
|
|
76
|
+
const id = String(req.params['id'] ?? '');
|
|
77
|
+
const cancelled = await this.service.cancel(id);
|
|
78
|
+
if (!cancelled) {
|
|
79
|
+
throw core_1.AppError.badRequest('Run not found or already in a terminal state');
|
|
80
|
+
}
|
|
81
|
+
res.json(core_1.ApiResponse.ok({ cancelled: true }));
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* SSE stream — emits run lifecycle events until terminal state.
|
|
85
|
+
*
|
|
86
|
+
* Events:
|
|
87
|
+
* status — {status, output?, error?} on every state transition
|
|
88
|
+
* done — final event when run reaches completed/failed/cancelled
|
|
89
|
+
*
|
|
90
|
+
* Clients should close the connection on receiving `done`.
|
|
91
|
+
*/
|
|
92
|
+
async streamRunEvents(req, res) {
|
|
93
|
+
const runId = String(req.params['id'] ?? '');
|
|
94
|
+
const run = await this.service.getStatus(runId);
|
|
95
|
+
if (!run)
|
|
96
|
+
throw core_1.AppError.notFound(`Agent run not found: ${runId}`);
|
|
97
|
+
// Disable socket timeout — SSE connections are long-lived
|
|
98
|
+
req.socket.setTimeout(0);
|
|
99
|
+
req.socket.setNoDelay(true);
|
|
100
|
+
req.socket.setKeepAlive(true);
|
|
101
|
+
res.writeHead(200, {
|
|
102
|
+
'Content-Type': 'text/event-stream',
|
|
103
|
+
'Cache-Control': 'no-cache',
|
|
104
|
+
Connection: 'keep-alive',
|
|
105
|
+
'X-Accel-Buffering': 'no',
|
|
106
|
+
});
|
|
107
|
+
const sendEvent = (event, data) => {
|
|
108
|
+
res.write(`event: ${event}\ndata: ${JSON.stringify(data)}\n\n`);
|
|
109
|
+
};
|
|
110
|
+
// If already in terminal state, emit and close immediately
|
|
111
|
+
const terminalStates = new Set(['completed', 'failed', 'cancelled']);
|
|
112
|
+
if (terminalStates.has(run.status)) {
|
|
113
|
+
sendEvent('status', this.service.toDto(run));
|
|
114
|
+
sendEvent('done', { status: run.status });
|
|
115
|
+
res.end();
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
// Poll until terminal state, emit SSE events on transitions
|
|
119
|
+
let lastStatus = run.status;
|
|
120
|
+
const POLL_INTERVAL_MS = 2000;
|
|
121
|
+
const MAX_POLL_DURATION_MS = 35 * 60 * 1000; // 35 minutes
|
|
122
|
+
const startAt = Date.now();
|
|
123
|
+
const interval = setInterval(async () => {
|
|
124
|
+
if (res.writableEnded) {
|
|
125
|
+
clearInterval(interval);
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
if (Date.now() - startAt > MAX_POLL_DURATION_MS) {
|
|
129
|
+
sendEvent('done', { status: 'timeout', error: 'SSE stream exceeded maximum duration' });
|
|
130
|
+
clearInterval(interval);
|
|
131
|
+
res.end();
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
try {
|
|
135
|
+
const current = await this.service.getStatus(runId);
|
|
136
|
+
if (!current) {
|
|
137
|
+
clearInterval(interval);
|
|
138
|
+
res.end();
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
if (current.status !== lastStatus) {
|
|
142
|
+
lastStatus = current.status;
|
|
143
|
+
sendEvent('status', this.service.toDto(current));
|
|
144
|
+
}
|
|
145
|
+
if (terminalStates.has(current.status)) {
|
|
146
|
+
sendEvent('done', { status: current.status });
|
|
147
|
+
clearInterval(interval);
|
|
148
|
+
res.end();
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
catch {
|
|
152
|
+
clearInterval(interval);
|
|
153
|
+
res.end();
|
|
154
|
+
}
|
|
155
|
+
}, POLL_INTERVAL_MS);
|
|
156
|
+
req.on('close', () => {
|
|
157
|
+
clearInterval(interval);
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
exports.AgentRunController = AgentRunController;
|
|
162
|
+
__decorate([
|
|
163
|
+
(0, core_1.Post)('/run'),
|
|
164
|
+
__metadata("design:type", Function),
|
|
165
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
166
|
+
__metadata("design:returntype", Promise)
|
|
167
|
+
], AgentRunController.prototype, "submitRun", null);
|
|
168
|
+
__decorate([
|
|
169
|
+
(0, core_1.Get)('/run'),
|
|
170
|
+
__metadata("design:type", Function),
|
|
171
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
172
|
+
__metadata("design:returntype", Promise)
|
|
173
|
+
], AgentRunController.prototype, "listRuns", null);
|
|
174
|
+
__decorate([
|
|
175
|
+
(0, core_1.Get)('/run/:id'),
|
|
176
|
+
__metadata("design:type", Function),
|
|
177
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
178
|
+
__metadata("design:returntype", Promise)
|
|
179
|
+
], AgentRunController.prototype, "getRunStatus", null);
|
|
180
|
+
__decorate([
|
|
181
|
+
(0, core_1.Post)('/run/:id/cancel'),
|
|
182
|
+
__metadata("design:type", Function),
|
|
183
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
184
|
+
__metadata("design:returntype", Promise)
|
|
185
|
+
], AgentRunController.prototype, "cancelRun", null);
|
|
186
|
+
__decorate([
|
|
187
|
+
(0, core_1.Get)('/run/:id/events'),
|
|
188
|
+
__metadata("design:type", Function),
|
|
189
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
190
|
+
__metadata("design:returntype", Promise)
|
|
191
|
+
], AgentRunController.prototype, "streamRunEvents", null);
|
|
192
|
+
exports.AgentRunController = AgentRunController = __decorate([
|
|
193
|
+
(0, core_1.Controller)('/api/v1/ai/agent')
|
|
194
|
+
], AgentRunController);
|
|
195
|
+
//# sourceMappingURL=agent-run.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-run.controller.js","sourceRoot":"","sources":["../../../src/agent/agent-run.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export type AgentRunStatus = 'pending' | 'running' | 'completed' | 'failed' | 'cancelled';
|
|
2
|
+
export type AgentRunType = 'computer-use' | 'coding' | 'cli' | 'dify' | 'remote';
|
|
3
|
+
/**
|
|
4
|
+
* AgentRun — persistent record of an async agent execution.
|
|
5
|
+
*
|
|
6
|
+
* Enables the async agent pattern:
|
|
7
|
+
* 1. Client submits a task → AgentRun row created (status: pending)
|
|
8
|
+
* 2. Background worker picks it up → status transitions to running
|
|
9
|
+
* 3. Worker completes → status: completed / failed, output / error filled
|
|
10
|
+
* 4. Clients poll GET /agent/run/:id or stream SSE /agent/run/:id/events
|
|
11
|
+
*/
|
|
12
|
+
export declare class AgentRun {
|
|
13
|
+
id: string;
|
|
14
|
+
/** Which kind of agent is executing this run. */
|
|
15
|
+
agentType: AgentRunType;
|
|
16
|
+
status: AgentRunStatus;
|
|
17
|
+
/** The user-supplied task prompt. */
|
|
18
|
+
prompt: string;
|
|
19
|
+
/** Final text output produced by the agent (set on completion). */
|
|
20
|
+
output: string | null;
|
|
21
|
+
/** Error message if the run failed. */
|
|
22
|
+
error: string | null;
|
|
23
|
+
/** Number of LLM reasoning rounds actually used. */
|
|
24
|
+
rounds: number;
|
|
25
|
+
/** Configured upper-bound for LLM reasoning rounds. */
|
|
26
|
+
maxRounds: number;
|
|
27
|
+
/** Wall-clock time when the agent loop started (ms after epoch). */
|
|
28
|
+
startedAt: Date | null;
|
|
29
|
+
/** Wall-clock time when the agent loop finished. */
|
|
30
|
+
endedAt: Date | null;
|
|
31
|
+
/** JSON blob for adapter-specific configuration (tool, model, workingDir…). */
|
|
32
|
+
metadata: string | null;
|
|
33
|
+
createdAt: Date;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=agent-run.entity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-run.entity.d.ts","sourceRoot":"","sources":["../../../src/agent/agent-run.entity.ts"],"names":[],"mappings":"AAOA,MAAM,MAAM,cAAc,GAAG,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,WAAW,CAAC;AAC1F,MAAM,MAAM,YAAY,GAAG,cAAc,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM,GAAG,QAAQ,CAAC;AAEjF;;;;;;;;GAQG;AACH,qBACa,QAAQ;IAEnB,EAAE,EAAG,MAAM,CAAC;IAEZ,iDAAiD;IAEjD,SAAS,EAAG,YAAY,CAAC;IAGzB,MAAM,EAAG,cAAc,CAAC;IAExB,qCAAqC;IAErC,MAAM,EAAG,MAAM,CAAC;IAEhB,mEAAmE;IAEnE,MAAM,EAAG,MAAM,GAAG,IAAI,CAAC;IAEvB,uCAAuC;IAEvC,KAAK,EAAG,MAAM,GAAG,IAAI,CAAC;IAEtB,oDAAoD;IAEpD,MAAM,EAAG,MAAM,CAAC;IAEhB,uDAAuD;IAEvD,SAAS,EAAG,MAAM,CAAC;IAEnB,oEAAoE;IAEpE,SAAS,EAAG,IAAI,GAAG,IAAI,CAAC;IAExB,oDAAoD;IAEpD,OAAO,EAAG,IAAI,GAAG,IAAI,CAAC;IAEtB,+EAA+E;IAE/E,QAAQ,EAAG,MAAM,GAAG,IAAI,CAAC;IAGzB,SAAS,EAAG,IAAI,CAAC;CAClB"}
|
|
@@ -0,0 +1,98 @@
|
|
|
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.AgentRun = void 0;
|
|
13
|
+
const core_1 = require("@octo-cyber/core");
|
|
14
|
+
/**
|
|
15
|
+
* AgentRun — persistent record of an async agent execution.
|
|
16
|
+
*
|
|
17
|
+
* Enables the async agent pattern:
|
|
18
|
+
* 1. Client submits a task → AgentRun row created (status: pending)
|
|
19
|
+
* 2. Background worker picks it up → status transitions to running
|
|
20
|
+
* 3. Worker completes → status: completed / failed, output / error filled
|
|
21
|
+
* 4. Clients poll GET /agent/run/:id or stream SSE /agent/run/:id/events
|
|
22
|
+
*/
|
|
23
|
+
let AgentRun = class AgentRun {
|
|
24
|
+
id;
|
|
25
|
+
/** Which kind of agent is executing this run. */
|
|
26
|
+
agentType;
|
|
27
|
+
status;
|
|
28
|
+
/** The user-supplied task prompt. */
|
|
29
|
+
prompt;
|
|
30
|
+
/** Final text output produced by the agent (set on completion). */
|
|
31
|
+
output;
|
|
32
|
+
/** Error message if the run failed. */
|
|
33
|
+
error;
|
|
34
|
+
/** Number of LLM reasoning rounds actually used. */
|
|
35
|
+
rounds;
|
|
36
|
+
/** Configured upper-bound for LLM reasoning rounds. */
|
|
37
|
+
maxRounds;
|
|
38
|
+
/** Wall-clock time when the agent loop started (ms after epoch). */
|
|
39
|
+
startedAt;
|
|
40
|
+
/** Wall-clock time when the agent loop finished. */
|
|
41
|
+
endedAt;
|
|
42
|
+
/** JSON blob for adapter-specific configuration (tool, model, workingDir…). */
|
|
43
|
+
metadata;
|
|
44
|
+
createdAt;
|
|
45
|
+
};
|
|
46
|
+
exports.AgentRun = AgentRun;
|
|
47
|
+
__decorate([
|
|
48
|
+
(0, core_1.PrimaryGeneratedColumn)('uuid'),
|
|
49
|
+
__metadata("design:type", String)
|
|
50
|
+
], AgentRun.prototype, "id", void 0);
|
|
51
|
+
__decorate([
|
|
52
|
+
(0, core_1.Column)({ type: 'varchar', length: 32, name: 'agent_type' }),
|
|
53
|
+
__metadata("design:type", String)
|
|
54
|
+
], AgentRun.prototype, "agentType", void 0);
|
|
55
|
+
__decorate([
|
|
56
|
+
(0, core_1.Column)({ type: 'varchar', length: 32, default: 'pending' }),
|
|
57
|
+
__metadata("design:type", String)
|
|
58
|
+
], AgentRun.prototype, "status", void 0);
|
|
59
|
+
__decorate([
|
|
60
|
+
(0, core_1.Column)({ type: 'text' }),
|
|
61
|
+
__metadata("design:type", String)
|
|
62
|
+
], AgentRun.prototype, "prompt", void 0);
|
|
63
|
+
__decorate([
|
|
64
|
+
(0, core_1.Column)({ type: 'text', nullable: true }),
|
|
65
|
+
__metadata("design:type", Object)
|
|
66
|
+
], AgentRun.prototype, "output", void 0);
|
|
67
|
+
__decorate([
|
|
68
|
+
(0, core_1.Column)({ type: 'text', nullable: true }),
|
|
69
|
+
__metadata("design:type", Object)
|
|
70
|
+
], AgentRun.prototype, "error", void 0);
|
|
71
|
+
__decorate([
|
|
72
|
+
(0, core_1.Column)({ type: 'integer', default: 0 }),
|
|
73
|
+
__metadata("design:type", Number)
|
|
74
|
+
], AgentRun.prototype, "rounds", void 0);
|
|
75
|
+
__decorate([
|
|
76
|
+
(0, core_1.Column)({ type: 'integer', name: 'max_rounds', default: 20 }),
|
|
77
|
+
__metadata("design:type", Number)
|
|
78
|
+
], AgentRun.prototype, "maxRounds", void 0);
|
|
79
|
+
__decorate([
|
|
80
|
+
(0, core_1.Column)({ type: 'datetime', nullable: true, name: 'started_at' }),
|
|
81
|
+
__metadata("design:type", Object)
|
|
82
|
+
], AgentRun.prototype, "startedAt", void 0);
|
|
83
|
+
__decorate([
|
|
84
|
+
(0, core_1.Column)({ type: 'datetime', nullable: true, name: 'ended_at' }),
|
|
85
|
+
__metadata("design:type", Object)
|
|
86
|
+
], AgentRun.prototype, "endedAt", void 0);
|
|
87
|
+
__decorate([
|
|
88
|
+
(0, core_1.Column)({ type: 'text', nullable: true }),
|
|
89
|
+
__metadata("design:type", Object)
|
|
90
|
+
], AgentRun.prototype, "metadata", void 0);
|
|
91
|
+
__decorate([
|
|
92
|
+
(0, core_1.CreateDateColumn)({ name: 'created_at' }),
|
|
93
|
+
__metadata("design:type", Date)
|
|
94
|
+
], AgentRun.prototype, "createdAt", void 0);
|
|
95
|
+
exports.AgentRun = AgentRun = __decorate([
|
|
96
|
+
(0, core_1.Entity)('agent_run')
|
|
97
|
+
], AgentRun);
|
|
98
|
+
//# sourceMappingURL=agent-run.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-run.entity.js","sourceRoot":"","sources":["../../../src/agent/agent-run.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAK0B;AAK1B;;;;;;;;GAQG;AAEI,IAAM,QAAQ,GAAd,MAAM,QAAQ;IAEnB,EAAE,CAAU;IAEZ,iDAAiD;IAEjD,SAAS,CAAgB;IAGzB,MAAM,CAAkB;IAExB,qCAAqC;IAErC,MAAM,CAAU;IAEhB,mEAAmE;IAEnE,MAAM,CAAiB;IAEvB,uCAAuC;IAEvC,KAAK,CAAiB;IAEtB,oDAAoD;IAEpD,MAAM,CAAU;IAEhB,uDAAuD;IAEvD,SAAS,CAAU;IAEnB,oEAAoE;IAEpE,SAAS,CAAe;IAExB,oDAAoD;IAEpD,OAAO,CAAe;IAEtB,+EAA+E;IAE/E,QAAQ,CAAiB;IAGzB,SAAS,CAAQ;CAClB,CAAA;AA7CY,4BAAQ;AAEnB;IADC,IAAA,6BAAsB,EAAC,MAAM,CAAC;;oCACnB;AAIZ;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;;2CACnC;AAGzB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;;wCACpC;AAIxB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;wCACT;AAIhB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;wCAClB;AAIvB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uCACnB;AAItB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;;wCACxB;AAIhB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;;2CAC1C;AAInB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;;2CACzC;AAIxB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;;yCACzC;AAItB;IADC,IAAA,aAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0CAChB;AAGzB;IADC,IAAA,uBAAgB,EAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC;8BAC7B,IAAI;2CAAC;mBA5CN,QAAQ;IADpB,IAAA,aAAM,EAAC,WAAW,CAAC;GACP,QAAQ,CA6CpB"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { Repository } from '@octo-cyber/core';
|
|
2
|
+
import { AgentRun } from './agent-run.entity.js';
|
|
3
|
+
import type { AgentRunStatus, AgentRunType } from './agent-run.entity.js';
|
|
4
|
+
export interface SubmitRunOptions {
|
|
5
|
+
agentType: AgentRunType;
|
|
6
|
+
prompt: string;
|
|
7
|
+
maxRounds?: number;
|
|
8
|
+
timeoutMs?: number;
|
|
9
|
+
metadata?: Record<string, unknown>;
|
|
10
|
+
}
|
|
11
|
+
export interface RunStatusDto {
|
|
12
|
+
id: string;
|
|
13
|
+
agentType: AgentRunType;
|
|
14
|
+
status: AgentRunStatus;
|
|
15
|
+
prompt: string;
|
|
16
|
+
output: string | null;
|
|
17
|
+
error: string | null;
|
|
18
|
+
rounds: number;
|
|
19
|
+
maxRounds: number;
|
|
20
|
+
startedAt: string | null;
|
|
21
|
+
endedAt: string | null;
|
|
22
|
+
createdAt: string;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* AgentRunService — manages async agent execution lifecycle.
|
|
26
|
+
*
|
|
27
|
+
* Workflow:
|
|
28
|
+
* submit() → creates AgentRun (pending) → enqueues background execution
|
|
29
|
+
* getStatus() / list() → read-only queries
|
|
30
|
+
* cancel() → marks running/pending run as cancelled
|
|
31
|
+
*/
|
|
32
|
+
export declare class AgentRunService {
|
|
33
|
+
private readonly logger;
|
|
34
|
+
private repo;
|
|
35
|
+
setRepository(repo: Repository<AgentRun>): void;
|
|
36
|
+
private getRepo;
|
|
37
|
+
/** Submit a new agent run and start it asynchronously. Returns the run ID immediately. */
|
|
38
|
+
submit(opts: SubmitRunOptions): Promise<AgentRun>;
|
|
39
|
+
getStatus(id: string): Promise<AgentRun | null>;
|
|
40
|
+
list(limit?: number): Promise<AgentRun[]>;
|
|
41
|
+
cancel(id: string): Promise<boolean>;
|
|
42
|
+
toDto(run: AgentRun): RunStatusDto;
|
|
43
|
+
private executeRun;
|
|
44
|
+
private dispatchAgent;
|
|
45
|
+
private runCodingAgent;
|
|
46
|
+
private runComputerUseAgent;
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=agent-run.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-run.service.d.ts","sourceRoot":"","sources":["../../../src/agent/agent-run.service.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAI1E,MAAM,WAAW,gBAAgB;IAC/B,SAAS,EAAE,YAAY,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,YAAY,CAAC;IACxB,MAAM,EAAE,cAAc,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;;;;;;GAOG;AACH,qBACa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAyD;IAChF,OAAO,CAAC,IAAI,CAAqC;IAEjD,aAAa,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC,GAAG,IAAI;IAI/C,OAAO,CAAC,OAAO;IAKf,0FAA0F;IACpF,MAAM,CAAC,IAAI,EAAE,gBAAgB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAsBjD,SAAS,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;IAI/C,IAAI,CAAC,KAAK,SAAK,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAOrC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAa1C,KAAK,CAAC,GAAG,EAAE,QAAQ,GAAG,YAAY;YAkBpB,UAAU;YA0BV,aAAa;YAeb,cAAc;YAWd,mBAAmB;CAWlC"}
|
|
@@ -0,0 +1,155 @@
|
|
|
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.AgentRunService = void 0;
|
|
10
|
+
const core_1 = require("@octo-cyber/core");
|
|
11
|
+
const OctoAgentClient_js_1 = require("../workflow-design/OctoAgentClient.js");
|
|
12
|
+
const computer_use_tools_js_1 = require("./computer-use-tools.js");
|
|
13
|
+
/**
|
|
14
|
+
* AgentRunService — manages async agent execution lifecycle.
|
|
15
|
+
*
|
|
16
|
+
* Workflow:
|
|
17
|
+
* submit() → creates AgentRun (pending) → enqueues background execution
|
|
18
|
+
* getStatus() / list() → read-only queries
|
|
19
|
+
* cancel() → marks running/pending run as cancelled
|
|
20
|
+
*/
|
|
21
|
+
let AgentRunService = class AgentRunService {
|
|
22
|
+
logger = core_1.Container.get(core_1.LoggerService).child('AgentRunService');
|
|
23
|
+
repo = null;
|
|
24
|
+
setRepository(repo) {
|
|
25
|
+
this.repo = repo;
|
|
26
|
+
}
|
|
27
|
+
getRepo() {
|
|
28
|
+
if (!this.repo)
|
|
29
|
+
throw new Error('AgentRunService: repository not initialized');
|
|
30
|
+
return this.repo;
|
|
31
|
+
}
|
|
32
|
+
/** Submit a new agent run and start it asynchronously. Returns the run ID immediately. */
|
|
33
|
+
async submit(opts) {
|
|
34
|
+
const repo = this.getRepo();
|
|
35
|
+
const run = repo.create({
|
|
36
|
+
agentType: opts.agentType,
|
|
37
|
+
status: 'pending',
|
|
38
|
+
prompt: opts.prompt,
|
|
39
|
+
maxRounds: opts.maxRounds ?? 20,
|
|
40
|
+
rounds: 0,
|
|
41
|
+
output: null,
|
|
42
|
+
error: null,
|
|
43
|
+
startedAt: null,
|
|
44
|
+
endedAt: null,
|
|
45
|
+
metadata: opts.metadata ? JSON.stringify(opts.metadata) : null,
|
|
46
|
+
});
|
|
47
|
+
const saved = await repo.save(run);
|
|
48
|
+
// Fire-and-forget: execute in background
|
|
49
|
+
void this.executeRun(saved.id, opts.timeoutMs ?? 300_000);
|
|
50
|
+
return saved;
|
|
51
|
+
}
|
|
52
|
+
async getStatus(id) {
|
|
53
|
+
return this.getRepo().findOne({ where: { id } });
|
|
54
|
+
}
|
|
55
|
+
async list(limit = 20) {
|
|
56
|
+
return this.getRepo().find({
|
|
57
|
+
order: { createdAt: 'DESC' },
|
|
58
|
+
take: limit,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
async cancel(id) {
|
|
62
|
+
const repo = this.getRepo();
|
|
63
|
+
const run = await repo.findOne({ where: { id } });
|
|
64
|
+
if (!run)
|
|
65
|
+
return false;
|
|
66
|
+
if (run.status !== 'pending' && run.status !== 'running')
|
|
67
|
+
return false;
|
|
68
|
+
await repo.update(id, {
|
|
69
|
+
status: 'cancelled',
|
|
70
|
+
endedAt: new Date(),
|
|
71
|
+
});
|
|
72
|
+
return true;
|
|
73
|
+
}
|
|
74
|
+
toDto(run) {
|
|
75
|
+
return {
|
|
76
|
+
id: run.id,
|
|
77
|
+
agentType: run.agentType,
|
|
78
|
+
status: run.status,
|
|
79
|
+
prompt: run.prompt,
|
|
80
|
+
output: run.output,
|
|
81
|
+
error: run.error,
|
|
82
|
+
rounds: run.rounds,
|
|
83
|
+
maxRounds: run.maxRounds,
|
|
84
|
+
startedAt: run.startedAt?.toISOString() ?? null,
|
|
85
|
+
endedAt: run.endedAt?.toISOString() ?? null,
|
|
86
|
+
createdAt: run.createdAt.toISOString(),
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
// ─── Background execution ────────────────────────────────────────────
|
|
90
|
+
async executeRun(runId, timeoutMs) {
|
|
91
|
+
const repo = this.getRepo();
|
|
92
|
+
const run = await repo.findOne({ where: { id: runId } });
|
|
93
|
+
if (!run || run.status === 'cancelled')
|
|
94
|
+
return;
|
|
95
|
+
await repo.update(runId, { status: 'running', startedAt: new Date() });
|
|
96
|
+
try {
|
|
97
|
+
const output = await this.dispatchAgent(run, timeoutMs);
|
|
98
|
+
await repo.update(runId, {
|
|
99
|
+
status: 'completed',
|
|
100
|
+
output,
|
|
101
|
+
endedAt: new Date(),
|
|
102
|
+
});
|
|
103
|
+
this.logger.info(`[AgentRunService] run ${runId} completed`);
|
|
104
|
+
}
|
|
105
|
+
catch (err) {
|
|
106
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
107
|
+
await repo.update(runId, {
|
|
108
|
+
status: 'failed',
|
|
109
|
+
error: message,
|
|
110
|
+
endedAt: new Date(),
|
|
111
|
+
});
|
|
112
|
+
this.logger.error(`[AgentRunService] run ${runId} failed: ${message}`);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
async dispatchAgent(run, timeoutMs) {
|
|
116
|
+
switch (run.agentType) {
|
|
117
|
+
case 'computer-use':
|
|
118
|
+
return this.runComputerUseAgent(run, timeoutMs);
|
|
119
|
+
case 'coding':
|
|
120
|
+
case 'cli':
|
|
121
|
+
case 'dify':
|
|
122
|
+
case 'remote':
|
|
123
|
+
// These types are dispatched via OctoAgentClient with a generic coding prompt
|
|
124
|
+
return this.runCodingAgent(run, timeoutMs);
|
|
125
|
+
default:
|
|
126
|
+
throw new Error(`Unsupported agentType: ${run.agentType}`);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
async runCodingAgent(run, timeoutMs) {
|
|
130
|
+
const client = new OctoAgentClient_js_1.OctoAgentClient();
|
|
131
|
+
return client.run({
|
|
132
|
+
systemPrompt: 'You are a helpful coding and task-execution agent. Complete the given task accurately and concisely.',
|
|
133
|
+
userMessage: run.prompt,
|
|
134
|
+
tools: [],
|
|
135
|
+
maxRounds: run.maxRounds,
|
|
136
|
+
timeoutMs,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
async runComputerUseAgent(run, timeoutMs) {
|
|
140
|
+
const client = new OctoAgentClient_js_1.OctoAgentClient();
|
|
141
|
+
const tools = (0, computer_use_tools_js_1.createComputerUseTools)();
|
|
142
|
+
return client.run({
|
|
143
|
+
systemPrompt: computer_use_tools_js_1.SYSTEM_PROMPT_COMPUTER_USE,
|
|
144
|
+
userMessage: run.prompt,
|
|
145
|
+
tools,
|
|
146
|
+
maxRounds: run.maxRounds,
|
|
147
|
+
timeoutMs,
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
};
|
|
151
|
+
exports.AgentRunService = AgentRunService;
|
|
152
|
+
exports.AgentRunService = AgentRunService = __decorate([
|
|
153
|
+
(0, core_1.Service)()
|
|
154
|
+
], AgentRunService);
|
|
155
|
+
//# sourceMappingURL=agent-run.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-run.service.js","sourceRoot":"","sources":["../../../src/agent/agent-run.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { Request, Response } from '@octo-cyber/core';
|
|
2
|
+
/**
|
|
3
|
+
* AgentSessionController — shared context session API.
|
|
4
|
+
*
|
|
5
|
+
* Endpoints:
|
|
6
|
+
* POST /api/v1/ai/agent/session — Create a new session
|
|
7
|
+
* GET /api/v1/ai/agent/session — List sessions (newest 20)
|
|
8
|
+
* GET /api/v1/ai/agent/session/:id — Get a session
|
|
9
|
+
* PATCH /api/v1/ai/agent/session/:id/context — Merge-update context
|
|
10
|
+
* POST /api/v1/ai/agent/session/:id/close — Close a session
|
|
11
|
+
*/
|
|
12
|
+
export declare class AgentSessionController {
|
|
13
|
+
private get service();
|
|
14
|
+
createSession(req: Request, res: Response): Promise<void>;
|
|
15
|
+
listSessions(_req: Request, res: Response): Promise<void>;
|
|
16
|
+
getSession(req: Request, res: Response): Promise<void>;
|
|
17
|
+
updateContext(req: Request, res: Response): Promise<void>;
|
|
18
|
+
closeSession(req: Request, res: Response): Promise<void>;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=agent-session.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-session.controller.d.ts","sourceRoot":"","sources":["../../../src/agent/agent-session.controller.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAG1D;;;;;;;;;GASG;AACH,qBACa,sBAAsB;IACjC,OAAO,KAAK,OAAO,GAElB;IAGK,aAAa,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAQzD,YAAY,CAAC,IAAI,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAMzD,UAAU,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAQtD,aAAa,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAWzD,YAAY,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;CAM/D"}
|