expxagents 0.25.1 → 0.25.2
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/assets/agents/_catalog.yaml +35 -0
- package/assets/agents/accounting/accountant.agent.md +41 -0
- package/assets/agents/accounting/audit-analyst.agent.md +41 -0
- package/assets/agents/accounting/financial-reporting.agent.md +41 -0
- package/assets/agents/accounting/fiscal-analyst.agent.md +41 -0
- package/assets/agents/accounting/payroll-specialist.agent.md +41 -0
- package/assets/agents/accounting/tax-compliance.agent.md +41 -0
- package/assets/agents/administrative/document-controller.agent.md +41 -0
- package/assets/agents/administrative/office-manager.agent.md +41 -0
- package/assets/agents/administrative/process-documentation-officer.agent.md +41 -0
- package/assets/agents/administrative/procurement-specialist.agent.md +41 -0
- package/assets/agents/board/board-report-writer.agent.md +41 -0
- package/assets/agents/board/business-intelligence.agent.md +41 -0
- package/assets/agents/board/governance-officer.agent.md +41 -0
- package/assets/agents/board/okr-manager.agent.md +41 -0
- package/assets/agents/board/risk-analyst.agent.md +41 -0
- package/assets/agents/board/strategic-advisor.agent.md +41 -0
- package/assets/agents/commercial/account-executive.agent.md +41 -0
- package/assets/agents/commercial/crm-manager.agent.md +41 -0
- package/assets/agents/commercial/pricing-strategist.agent.md +41 -0
- package/assets/agents/commercial/proposal-writer.agent.md +41 -0
- package/assets/agents/commercial/sdr.agent.md +41 -0
- package/assets/agents/compliance/compliance-officer.agent.md +41 -0
- package/assets/agents/compliance/data-privacy-specialist.agent.md +41 -0
- package/assets/agents/compliance/internal-auditor.agent.md +41 -0
- package/assets/agents/compliance/regulatory-monitor.agent.md +41 -0
- package/assets/agents/customer-success/churn-prevention.agent.md +41 -0
- package/assets/agents/customer-success/csm.agent.md +41 -0
- package/assets/agents/customer-success/expansion-manager.agent.md +41 -0
- package/assets/agents/customer-success/nps-analyst.agent.md +41 -0
- package/assets/agents/customer-success/renewal-manager.agent.md +41 -0
- package/assets/agents/development/android-developer.agent.md +41 -0
- package/assets/agents/development/backend-developer.agent.md +42 -0
- package/assets/agents/development/business-analyst.agent.md +41 -0
- package/assets/agents/development/code-reviewer.agent.md +41 -0
- package/assets/agents/development/cross-platform-mobile.agent.md +41 -0
- package/assets/agents/development/dba.agent.md +41 -0
- package/assets/agents/development/desktop-developer.agent.md +41 -0
- package/assets/agents/development/devops-engineer.agent.md +41 -0
- package/assets/agents/development/frontend-developer.agent.md +103 -0
- package/assets/agents/development/ios-developer.agent.md +41 -0
- package/assets/agents/development/product-manager.agent.md +41 -0
- package/assets/agents/development/qa-engineer.agent.md +41 -0
- package/assets/agents/development/scrum-master.agent.md +41 -0
- package/assets/agents/development/security-analyst.agent.md +41 -0
- package/assets/agents/development/tech-lead.agent.md +42 -0
- package/assets/agents/development/tech-writer.agent.md +41 -0
- package/assets/agents/development/ux-design-expert.agent.md +108 -0
- package/assets/agents/development/ux-designer.agent.md +41 -0
- package/assets/agents/finance/accounts-manager.agent.md +41 -0
- package/assets/agents/finance/billing-analyst.agent.md +41 -0
- package/assets/agents/finance/budget-planner.agent.md +41 -0
- package/assets/agents/finance/financial-controller.agent.md +41 -0
- package/assets/agents/hr/benefits-manager.agent.md +41 -0
- package/assets/agents/hr/hr-onboarding.agent.md +41 -0
- package/assets/agents/hr/interview-coordinator.agent.md +41 -0
- package/assets/agents/hr/people-culture.agent.md +41 -0
- package/assets/agents/hr/performance-analyst.agent.md +41 -0
- package/assets/agents/hr/recruiter.agent.md +41 -0
- package/assets/agents/implantation/deployment-manager.agent.md +41 -0
- package/assets/agents/implantation/environment-specialist.agent.md +41 -0
- package/assets/agents/implantation/go-live-coordinator.agent.md +41 -0
- package/assets/agents/implantation/integration-specialist.agent.md +41 -0
- package/assets/agents/implantation/migration-specialist.agent.md +41 -0
- package/assets/agents/legal/contract-manager.agent.md +41 -0
- package/assets/agents/legal/ip-specialist.agent.md +41 -0
- package/assets/agents/legal/labor-attorney.agent.md +41 -0
- package/assets/agents/legal/legal-counsel.agent.md +41 -0
- package/assets/agents/marketing/brand-guardian.agent.md +40 -0
- package/assets/agents/marketing/content-creator.agent.md +41 -0
- package/assets/agents/marketing/email-marketing.agent.md +41 -0
- package/assets/agents/marketing/landing-page-builder.agent.md +138 -0
- package/assets/agents/marketing/marketing-analyst.agent.md +41 -0
- package/assets/agents/marketing/paid-ads-manager.agent.md +41 -0
- package/assets/agents/marketing/seo-specialist.agent.md +41 -0
- package/assets/agents/marketing/social-media-manager.agent.md +41 -0
- package/assets/agents/rnd/benchmark-analyst.agent.md +41 -0
- package/assets/agents/rnd/innovation-scout.agent.md +41 -0
- package/assets/agents/rnd/market-researcher.agent.md +41 -0
- package/assets/agents/rnd/product-analyst.agent.md +41 -0
- package/assets/agents/rnd/prototype-builder.agent.md +41 -0
- package/assets/agents/support/knowledge-base-manager.agent.md +41 -0
- package/assets/agents/support/l1-support.agent.md +41 -0
- package/assets/agents/support/l2-support.agent.md +41 -0
- package/assets/agents/support/l3-support.agent.md +41 -0
- package/assets/agents/support/sla-monitor.agent.md +41 -0
- package/assets/agents/training/assessment-creator.agent.md +41 -0
- package/assets/agents/training/onboarding-coach.agent.md +41 -0
- package/assets/agents/training/training-designer.agent.md +41 -0
- package/assets/agents/training/workshop-facilitator.agent.md +41 -0
- package/assets/core/best-practices/_catalog.yaml +91 -0
- package/assets/core/best-practices/api-documentation.md +137 -0
- package/assets/core/best-practices/blog-post.md +86 -0
- package/assets/core/best-practices/blog-seo.md +91 -0
- package/assets/core/best-practices/code-review.md +97 -0
- package/assets/core/best-practices/copywriting.md +75 -0
- package/assets/core/best-practices/data-analysis.md +93 -0
- package/assets/core/best-practices/deploy-checklist.md +99 -0
- package/assets/core/best-practices/email-newsletter.md +84 -0
- package/assets/core/best-practices/email-sales.md +91 -0
- package/assets/core/best-practices/fullstack-page-generation.md +936 -0
- package/assets/core/best-practices/image-design.md +78 -0
- package/assets/core/best-practices/instagram-feed.md +70 -0
- package/assets/core/best-practices/instagram-reels.md +75 -0
- package/assets/core/best-practices/instagram-stories.md +68 -0
- package/assets/core/best-practices/landing-page-react.md +2263 -0
- package/assets/core/best-practices/landing-page.md +279 -0
- package/assets/core/best-practices/linkedin-article.md +83 -0
- package/assets/core/best-practices/linkedin-post.md +84 -0
- package/assets/core/best-practices/researching.md +89 -0
- package/assets/core/best-practices/review.md +95 -0
- package/assets/core/best-practices/sprint-planning.md +91 -0
- package/assets/core/best-practices/strategist.md +95 -0
- package/assets/core/best-practices/technical-writing.md +104 -0
- package/assets/core/best-practices/twitter-post.md +75 -0
- package/assets/core/best-practices/twitter-thread.md +92 -0
- package/assets/core/best-practices/whatsapp-broadcast.md +95 -0
- package/assets/core/best-practices/youtube-script.md +80 -0
- package/assets/core/best-practices/youtube-shorts.md +76 -0
- package/assets/core/prompts/insight-hunter.prompt.md +62 -0
- package/assets/core/runner.pipeline.md +200 -0
- package/assets/core/skills.engine.md +65 -0
- package/assets/core/solution-architect.agent.md +329 -0
- package/assets/mcps/_catalog.yaml +17 -0
- package/assets/mcps/figma.mcp.yaml +35 -0
- package/assets/mcps/github.mcp.yaml +44 -0
- package/assets/mcps/linear.mcp.yaml +37 -0
- package/assets/mcps/notion.mcp.yaml +37 -0
- package/assets/mcps/pencil.mcp.yaml +32 -0
- package/assets/mcps/postgresql.mcp.yaml +39 -0
- package/assets/mcps/sentry.mcp.yaml +41 -0
- package/assets/mcps/slack.mcp.yaml +37 -0
- package/assets/mcps/vercel.mcp.yaml +39 -0
- package/assets/templates/_expxagents/_memory/company.md +25 -0
- package/assets/templates/_expxagents/_memory/preferences.md +6 -0
- package/assets/templates/squads/_memory/memories.md +16 -0
- package/dist/dashboard/assets/BufferResource-D79vaoFm.js +185 -0
- package/dist/dashboard/assets/CanvasRenderer-BUoxTNKV.js +1 -0
- package/dist/dashboard/assets/JarvisView-DSN7xWMz.js +1 -0
- package/dist/dashboard/assets/RenderTargetSystem-B7rwTXA1.js +172 -0
- package/dist/dashboard/assets/ThreeBackground-BQTdScX-.js +1 -0
- package/dist/dashboard/assets/WebGLRenderer-DgdVNsZ9.js +156 -0
- package/dist/dashboard/assets/WebGPURenderer-DnQNvjEQ.js +41 -0
- package/dist/dashboard/assets/browserAll-Cbsk7DE4.js +14 -0
- package/dist/dashboard/assets/index-CrlhoBta.js +783 -0
- package/dist/dashboard/assets/index-DtbIzZ5n.css +1 -0
- package/dist/dashboard/assets/three-BZk_I9Ly.js +4057 -0
- package/dist/dashboard/assets/webworkerAll-BLmfReEj.js +83 -0
- package/dist/dashboard/index.html +13 -0
- package/dist/server/api/__tests__/cost-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/cost-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/cost-routes.test.js +54 -0
- package/dist/server/api/__tests__/cost-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/files-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/files-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/files-routes.test.js +85 -0
- package/dist/server/api/__tests__/files-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/graph-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/graph-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/graph-routes.test.js +105 -0
- package/dist/server/api/__tests__/graph-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/health-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/health-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/health-routes.test.js +22 -0
- package/dist/server/api/__tests__/health-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/integration-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/integration-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/integration-routes.test.js +243 -0
- package/dist/server/api/__tests__/integration-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/kanban-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/kanban-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/kanban-routes.test.js +316 -0
- package/dist/server/api/__tests__/kanban-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/log-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/log-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/log-routes.test.js +35 -0
- package/dist/server/api/__tests__/log-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/orgchart-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/orgchart-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/orgchart-routes.test.js +161 -0
- package/dist/server/api/__tests__/orgchart-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/settings-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/settings-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/settings-routes.test.js +177 -0
- package/dist/server/api/__tests__/settings-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/system-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/system-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/system-routes.test.js +79 -0
- package/dist/server/api/__tests__/system-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/team-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/team-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/team-routes.test.js +116 -0
- package/dist/server/api/__tests__/team-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/webhook-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/webhook-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/webhook-routes.test.js +111 -0
- package/dist/server/api/__tests__/webhook-routes.test.js.map +1 -0
- package/dist/server/api/activity-routes.d.ts +8 -0
- package/dist/server/api/activity-routes.d.ts.map +1 -0
- package/dist/server/api/activity-routes.js +34 -0
- package/dist/server/api/activity-routes.js.map +1 -0
- package/dist/server/api/chat-api-routes.d.ts +4 -0
- package/dist/server/api/chat-api-routes.d.ts.map +1 -0
- package/dist/server/api/chat-api-routes.js +28 -0
- package/dist/server/api/chat-api-routes.js.map +1 -0
- package/dist/server/api/cost-routes.d.ts +8 -0
- package/dist/server/api/cost-routes.d.ts.map +1 -0
- package/dist/server/api/cost-routes.js +39 -0
- package/dist/server/api/cost-routes.js.map +1 -0
- package/dist/server/api/dashboard-routes.d.ts +10 -0
- package/dist/server/api/dashboard-routes.d.ts.map +1 -0
- package/dist/server/api/dashboard-routes.js +128 -0
- package/dist/server/api/dashboard-routes.js.map +1 -0
- package/dist/server/api/files-routes.d.ts +5 -0
- package/dist/server/api/files-routes.d.ts.map +1 -0
- package/dist/server/api/files-routes.js +218 -0
- package/dist/server/api/files-routes.js.map +1 -0
- package/dist/server/api/graph-routes.d.ts +24 -0
- package/dist/server/api/graph-routes.d.ts.map +1 -0
- package/dist/server/api/graph-routes.js +208 -0
- package/dist/server/api/graph-routes.js.map +1 -0
- package/dist/server/api/health-routes.d.ts +9 -0
- package/dist/server/api/health-routes.d.ts.map +1 -0
- package/dist/server/api/health-routes.js +46 -0
- package/dist/server/api/health-routes.js.map +1 -0
- package/dist/server/api/integration-routes.d.ts +23 -0
- package/dist/server/api/integration-routes.d.ts.map +1 -0
- package/dist/server/api/integration-routes.js +326 -0
- package/dist/server/api/integration-routes.js.map +1 -0
- package/dist/server/api/kanban-routes.d.ts +8 -0
- package/dist/server/api/kanban-routes.d.ts.map +1 -0
- package/dist/server/api/kanban-routes.js +128 -0
- package/dist/server/api/kanban-routes.js.map +1 -0
- package/dist/server/api/knowledge-routes.d.ts +8 -0
- package/dist/server/api/knowledge-routes.d.ts.map +1 -0
- package/dist/server/api/knowledge-routes.js +82 -0
- package/dist/server/api/knowledge-routes.js.map +1 -0
- package/dist/server/api/log-routes.d.ts +8 -0
- package/dist/server/api/log-routes.d.ts.map +1 -0
- package/dist/server/api/log-routes.js +31 -0
- package/dist/server/api/log-routes.js.map +1 -0
- package/dist/server/api/orgchart-routes.d.ts +7 -0
- package/dist/server/api/orgchart-routes.d.ts.map +1 -0
- package/dist/server/api/orgchart-routes.js +154 -0
- package/dist/server/api/orgchart-routes.js.map +1 -0
- package/dist/server/api/permissions-routes.d.ts +8 -0
- package/dist/server/api/permissions-routes.d.ts.map +1 -0
- package/dist/server/api/permissions-routes.js +37 -0
- package/dist/server/api/permissions-routes.js.map +1 -0
- package/dist/server/api/registry-routes.d.ts +7 -0
- package/dist/server/api/registry-routes.d.ts.map +1 -0
- package/dist/server/api/registry-routes.js +51 -0
- package/dist/server/api/registry-routes.js.map +1 -0
- package/dist/server/api/settings-routes.d.ts +11 -0
- package/dist/server/api/settings-routes.d.ts.map +1 -0
- package/dist/server/api/settings-routes.js +167 -0
- package/dist/server/api/settings-routes.js.map +1 -0
- package/dist/server/api/squads-routes.d.ts +9 -0
- package/dist/server/api/squads-routes.d.ts.map +1 -0
- package/dist/server/api/squads-routes.js +171 -0
- package/dist/server/api/squads-routes.js.map +1 -0
- package/dist/server/api/system-routes.d.ts +9 -0
- package/dist/server/api/system-routes.d.ts.map +1 -0
- package/dist/server/api/system-routes.js +241 -0
- package/dist/server/api/system-routes.js.map +1 -0
- package/dist/server/api/team-routes.d.ts +8 -0
- package/dist/server/api/team-routes.d.ts.map +1 -0
- package/dist/server/api/team-routes.js +55 -0
- package/dist/server/api/team-routes.js.map +1 -0
- package/dist/server/api/users-routes.d.ts +8 -0
- package/dist/server/api/users-routes.d.ts.map +1 -0
- package/dist/server/api/users-routes.js +65 -0
- package/dist/server/api/users-routes.js.map +1 -0
- package/dist/server/api/webhook-routes.d.ts +9 -0
- package/dist/server/api/webhook-routes.d.ts.map +1 -0
- package/dist/server/api/webhook-routes.js +82 -0
- package/dist/server/api/webhook-routes.js.map +1 -0
- package/dist/server/app.d.ts +9 -0
- package/dist/server/app.d.ts.map +1 -0
- package/dist/server/app.js +265 -0
- package/dist/server/app.js.map +1 -0
- package/dist/server/auth/auth-middleware.d.ts +13 -0
- package/dist/server/auth/auth-middleware.d.ts.map +1 -0
- package/dist/server/auth/auth-middleware.js +25 -0
- package/dist/server/auth/auth-middleware.js.map +1 -0
- package/dist/server/auth/auth-routes.d.ts +9 -0
- package/dist/server/auth/auth-routes.d.ts.map +1 -0
- package/dist/server/auth/auth-routes.js +152 -0
- package/dist/server/auth/auth-routes.js.map +1 -0
- package/dist/server/auth/jwt.d.ts +14 -0
- package/dist/server/auth/jwt.d.ts.map +1 -0
- package/dist/server/auth/jwt.js +16 -0
- package/dist/server/auth/jwt.js.map +1 -0
- package/dist/server/auth/password.d.ts +3 -0
- package/dist/server/auth/password.d.ts.map +1 -0
- package/dist/server/auth/password.js +9 -0
- package/dist/server/auth/password.js.map +1 -0
- package/dist/server/bridge/__tests__/chat-handler.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/chat-handler.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/chat-handler.test.js +143 -0
- package/dist/server/bridge/__tests__/chat-handler.test.js.map +1 -0
- package/dist/server/bridge/__tests__/chat-integration.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/chat-integration.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/chat-integration.test.js +129 -0
- package/dist/server/bridge/__tests__/chat-integration.test.js.map +1 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.js +300 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.js.map +1 -0
- package/dist/server/bridge/__tests__/conversation.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/conversation.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/conversation.test.js +168 -0
- package/dist/server/bridge/__tests__/conversation.test.js.map +1 -0
- package/dist/server/bridge/__tests__/registry.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/registry.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/registry.test.js +45 -0
- package/dist/server/bridge/__tests__/registry.test.js.map +1 -0
- package/dist/server/bridge/__tests__/stream-parser.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/stream-parser.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/stream-parser.test.js +66 -0
- package/dist/server/bridge/__tests__/stream-parser.test.js.map +1 -0
- package/dist/server/bridge/chat-handler.d.ts +32 -0
- package/dist/server/bridge/chat-handler.d.ts.map +1 -0
- package/dist/server/bridge/chat-handler.js +356 -0
- package/dist/server/bridge/chat-handler.js.map +1 -0
- package/dist/server/bridge/claude-bridge.d.ts +21 -0
- package/dist/server/bridge/claude-bridge.d.ts.map +1 -0
- package/dist/server/bridge/claude-bridge.js +273 -0
- package/dist/server/bridge/claude-bridge.js.map +1 -0
- package/dist/server/bridge/conversation.d.ts +45 -0
- package/dist/server/bridge/conversation.d.ts.map +1 -0
- package/dist/server/bridge/conversation.js +78 -0
- package/dist/server/bridge/conversation.js.map +1 -0
- package/dist/server/bridge/engine-manager.d.ts +13 -0
- package/dist/server/bridge/engine-manager.d.ts.map +1 -0
- package/dist/server/bridge/engine-manager.js +54 -0
- package/dist/server/bridge/engine-manager.js.map +1 -0
- package/dist/server/bridge/engine.d.ts +37 -0
- package/dist/server/bridge/engine.d.ts.map +1 -0
- package/dist/server/bridge/engine.js +2 -0
- package/dist/server/bridge/engine.js.map +1 -0
- package/dist/server/bridge/factory.d.ts +4 -0
- package/dist/server/bridge/factory.d.ts.map +1 -0
- package/dist/server/bridge/factory.js +18 -0
- package/dist/server/bridge/factory.js.map +1 -0
- package/dist/server/bridge/opencode-bridge.d.ts +27 -0
- package/dist/server/bridge/opencode-bridge.d.ts.map +1 -0
- package/dist/server/bridge/opencode-bridge.js +163 -0
- package/dist/server/bridge/opencode-bridge.js.map +1 -0
- package/dist/server/bridge/registry.d.ts +19 -0
- package/dist/server/bridge/registry.d.ts.map +1 -0
- package/dist/server/bridge/registry.js +29 -0
- package/dist/server/bridge/registry.js.map +1 -0
- package/dist/server/bridge/session-journal.d.ts +25 -0
- package/dist/server/bridge/session-journal.d.ts.map +1 -0
- package/dist/server/bridge/session-journal.js +69 -0
- package/dist/server/bridge/session-journal.js.map +1 -0
- package/dist/server/bridge/stream-parser.d.ts +14 -0
- package/dist/server/bridge/stream-parser.d.ts.map +1 -0
- package/dist/server/bridge/stream-parser.js +26 -0
- package/dist/server/bridge/stream-parser.js.map +1 -0
- package/dist/server/config/engine-config.d.ts +4 -0
- package/dist/server/config/engine-config.d.ts.map +1 -0
- package/dist/server/config/engine-config.js +24 -0
- package/dist/server/config/engine-config.js.map +1 -0
- package/dist/server/config.d.ts +17 -0
- package/dist/server/config.d.ts.map +1 -0
- package/dist/server/config.js +39 -0
- package/dist/server/config.js.map +1 -0
- package/dist/server/db/__tests__/chat-tables.test.d.ts +2 -0
- package/dist/server/db/__tests__/chat-tables.test.d.ts.map +1 -0
- package/dist/server/db/__tests__/chat-tables.test.js +82 -0
- package/dist/server/db/__tests__/chat-tables.test.js.map +1 -0
- package/dist/server/db/__tests__/email-schema.test.d.ts +2 -0
- package/dist/server/db/__tests__/email-schema.test.d.ts.map +1 -0
- package/dist/server/db/__tests__/email-schema.test.js +53 -0
- package/dist/server/db/__tests__/email-schema.test.js.map +1 -0
- package/dist/server/db/__tests__/scheduler-schema.test.d.ts +2 -0
- package/dist/server/db/__tests__/scheduler-schema.test.d.ts.map +1 -0
- package/dist/server/db/__tests__/scheduler-schema.test.js +52 -0
- package/dist/server/db/__tests__/scheduler-schema.test.js.map +1 -0
- package/dist/server/db/connection.d.ts +4 -0
- package/dist/server/db/connection.d.ts.map +1 -0
- package/dist/server/db/connection.js +40 -0
- package/dist/server/db/connection.js.map +1 -0
- package/dist/server/db/migrations.d.ts +4 -0
- package/dist/server/db/migrations.d.ts.map +1 -0
- package/dist/server/db/migrations.js +47 -0
- package/dist/server/db/migrations.js.map +1 -0
- package/dist/server/db/schema.d.ts +2 -0
- package/dist/server/db/schema.d.ts.map +1 -0
- package/dist/server/db/schema.js +288 -0
- package/dist/server/db/schema.js.map +1 -0
- package/dist/server/email/__tests__/campaign-routes.test.d.ts +2 -0
- package/dist/server/email/__tests__/campaign-routes.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/campaign-routes.test.js +216 -0
- package/dist/server/email/__tests__/campaign-routes.test.js.map +1 -0
- package/dist/server/email/__tests__/campaign-service.test.d.ts +2 -0
- package/dist/server/email/__tests__/campaign-service.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/campaign-service.test.js +79 -0
- package/dist/server/email/__tests__/campaign-service.test.js.map +1 -0
- package/dist/server/email/__tests__/email-queue-worker.test.d.ts +2 -0
- package/dist/server/email/__tests__/email-queue-worker.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/email-queue-worker.test.js +93 -0
- package/dist/server/email/__tests__/email-queue-worker.test.js.map +1 -0
- package/dist/server/email/__tests__/email-utils.test.d.ts +2 -0
- package/dist/server/email/__tests__/email-utils.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/email-utils.test.js +36 -0
- package/dist/server/email/__tests__/email-utils.test.js.map +1 -0
- package/dist/server/email/__tests__/lead-routes.test.d.ts +2 -0
- package/dist/server/email/__tests__/lead-routes.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/lead-routes.test.js +180 -0
- package/dist/server/email/__tests__/lead-routes.test.js.map +1 -0
- package/dist/server/email/__tests__/lead-service.test.d.ts +2 -0
- package/dist/server/email/__tests__/lead-service.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/lead-service.test.js +113 -0
- package/dist/server/email/__tests__/lead-service.test.js.map +1 -0
- package/dist/server/email/__tests__/ses-client.test.d.ts +2 -0
- package/dist/server/email/__tests__/ses-client.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/ses-client.test.js +48 -0
- package/dist/server/email/__tests__/ses-client.test.js.map +1 -0
- package/dist/server/email/__tests__/sns-webhook.test.d.ts +2 -0
- package/dist/server/email/__tests__/sns-webhook.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/sns-webhook.test.js +40 -0
- package/dist/server/email/__tests__/sns-webhook.test.js.map +1 -0
- package/dist/server/email/campaign-routes.d.ts +8 -0
- package/dist/server/email/campaign-routes.d.ts.map +1 -0
- package/dist/server/email/campaign-routes.js +65 -0
- package/dist/server/email/campaign-routes.js.map +1 -0
- package/dist/server/email/campaign-service.d.ts +55 -0
- package/dist/server/email/campaign-service.d.ts.map +1 -0
- package/dist/server/email/campaign-service.js +89 -0
- package/dist/server/email/campaign-service.js.map +1 -0
- package/dist/server/email/email-queue-worker.d.ts +27 -0
- package/dist/server/email/email-queue-worker.d.ts.map +1 -0
- package/dist/server/email/email-queue-worker.js +119 -0
- package/dist/server/email/email-queue-worker.js.map +1 -0
- package/dist/server/email/email-utils.d.ts +5 -0
- package/dist/server/email/email-utils.d.ts.map +1 -0
- package/dist/server/email/email-utils.js +24 -0
- package/dist/server/email/email-utils.js.map +1 -0
- package/dist/server/email/lead-routes.d.ts +8 -0
- package/dist/server/email/lead-routes.d.ts.map +1 -0
- package/dist/server/email/lead-routes.js +56 -0
- package/dist/server/email/lead-routes.js.map +1 -0
- package/dist/server/email/lead-service.d.ts +66 -0
- package/dist/server/email/lead-service.d.ts.map +1 -0
- package/dist/server/email/lead-service.js +138 -0
- package/dist/server/email/lead-service.js.map +1 -0
- package/dist/server/email/ses-client.d.ts +27 -0
- package/dist/server/email/ses-client.d.ts.map +1 -0
- package/dist/server/email/ses-client.js +44 -0
- package/dist/server/email/ses-client.js.map +1 -0
- package/dist/server/email/sns-webhook.d.ts +10 -0
- package/dist/server/email/sns-webhook.d.ts.map +1 -0
- package/dist/server/email/sns-webhook.js +73 -0
- package/dist/server/email/sns-webhook.js.map +1 -0
- package/dist/server/index.d.ts +2 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +36 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/mcp/expxagents-mcp.d.ts +2 -0
- package/dist/server/mcp/expxagents-mcp.d.ts.map +1 -0
- package/dist/server/mcp/expxagents-mcp.js +230 -0
- package/dist/server/mcp/expxagents-mcp.js.map +1 -0
- package/dist/server/routes/__tests__/conversations.test.d.ts +2 -0
- package/dist/server/routes/__tests__/conversations.test.d.ts.map +1 -0
- package/dist/server/routes/__tests__/conversations.test.js +111 -0
- package/dist/server/routes/__tests__/conversations.test.js.map +1 -0
- package/dist/server/routes/conversations.d.ts +8 -0
- package/dist/server/routes/conversations.d.ts.map +1 -0
- package/dist/server/routes/conversations.js +36 -0
- package/dist/server/routes/conversations.js.map +1 -0
- package/dist/server/scheduler/__tests__/job-runner.test.d.ts +2 -0
- package/dist/server/scheduler/__tests__/job-runner.test.d.ts.map +1 -0
- package/dist/server/scheduler/__tests__/job-runner.test.js +488 -0
- package/dist/server/scheduler/__tests__/job-runner.test.js.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.d.ts +2 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.d.ts.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.js +167 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.js.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.d.ts +2 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.d.ts.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.js +207 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.js.map +1 -0
- package/dist/server/scheduler/job-runner.d.ts +73 -0
- package/dist/server/scheduler/job-runner.d.ts.map +1 -0
- package/dist/server/scheduler/job-runner.js +407 -0
- package/dist/server/scheduler/job-runner.js.map +1 -0
- package/dist/server/scheduler/scheduler-routes.d.ts +10 -0
- package/dist/server/scheduler/scheduler-routes.d.ts.map +1 -0
- package/dist/server/scheduler/scheduler-routes.js +105 -0
- package/dist/server/scheduler/scheduler-routes.js.map +1 -0
- package/dist/server/scheduler/scheduler-service.d.ts +55 -0
- package/dist/server/scheduler/scheduler-service.d.ts.map +1 -0
- package/dist/server/scheduler/scheduler-service.js +271 -0
- package/dist/server/scheduler/scheduler-service.js.map +1 -0
- package/dist/server/services/__tests__/cost-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/cost-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/cost-service.test.js +72 -0
- package/dist/server/services/__tests__/cost-service.test.js.map +1 -0
- package/dist/server/services/__tests__/execution-log-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/execution-log-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/execution-log-service.test.js +40 -0
- package/dist/server/services/__tests__/execution-log-service.test.js.map +1 -0
- package/dist/server/services/__tests__/integration-registry.test.d.ts +2 -0
- package/dist/server/services/__tests__/integration-registry.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/integration-registry.test.js +28 -0
- package/dist/server/services/__tests__/integration-registry.test.js.map +1 -0
- package/dist/server/services/__tests__/log-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/log-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/log-service.test.js +49 -0
- package/dist/server/services/__tests__/log-service.test.js.map +1 -0
- package/dist/server/services/__tests__/permissions-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/permissions-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/permissions-service.test.js +46 -0
- package/dist/server/services/__tests__/permissions-service.test.js.map +1 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.js +268 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.js.map +1 -0
- package/dist/server/services/__tests__/state-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/state-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/state-service.test.js +136 -0
- package/dist/server/services/__tests__/state-service.test.js.map +1 -0
- package/dist/server/services/activity-service.d.ts +35 -0
- package/dist/server/services/activity-service.d.ts.map +1 -0
- package/dist/server/services/activity-service.js +92 -0
- package/dist/server/services/activity-service.js.map +1 -0
- package/dist/server/services/cost-service.d.ts +55 -0
- package/dist/server/services/cost-service.d.ts.map +1 -0
- package/dist/server/services/cost-service.js +59 -0
- package/dist/server/services/cost-service.js.map +1 -0
- package/dist/server/services/execution-log-service.d.ts +20 -0
- package/dist/server/services/execution-log-service.d.ts.map +1 -0
- package/dist/server/services/execution-log-service.js +17 -0
- package/dist/server/services/execution-log-service.js.map +1 -0
- package/dist/server/services/integration-registry.d.ts +9 -0
- package/dist/server/services/integration-registry.d.ts.map +1 -0
- package/dist/server/services/integration-registry.js +14 -0
- package/dist/server/services/integration-registry.js.map +1 -0
- package/dist/server/services/log-service.d.ts +28 -0
- package/dist/server/services/log-service.d.ts.map +1 -0
- package/dist/server/services/log-service.js +34 -0
- package/dist/server/services/log-service.js.map +1 -0
- package/dist/server/services/permissions-service.d.ts +10 -0
- package/dist/server/services/permissions-service.d.ts.map +1 -0
- package/dist/server/services/permissions-service.js +48 -0
- package/dist/server/services/permissions-service.js.map +1 -0
- package/dist/server/services/pipeline-task-service.d.ts +79 -0
- package/dist/server/services/pipeline-task-service.d.ts.map +1 -0
- package/dist/server/services/pipeline-task-service.js +122 -0
- package/dist/server/services/pipeline-task-service.js.map +1 -0
- package/dist/server/services/squad-registry.d.ts +35 -0
- package/dist/server/services/squad-registry.d.ts.map +1 -0
- package/dist/server/services/squad-registry.js +141 -0
- package/dist/server/services/squad-registry.js.map +1 -0
- package/dist/server/services/state-service.d.ts +22 -0
- package/dist/server/services/state-service.d.ts.map +1 -0
- package/dist/server/services/state-service.js +114 -0
- package/dist/server/services/state-service.js.map +1 -0
- package/dist/server/types/a2ui.d.ts +27 -0
- package/dist/server/types/a2ui.d.ts.map +1 -0
- package/dist/server/types/a2ui.js +2 -0
- package/dist/server/types/a2ui.js.map +1 -0
- package/dist/server/utils/find-free-port.d.ts +2 -0
- package/dist/server/utils/find-free-port.d.ts.map +1 -0
- package/dist/server/utils/find-free-port.js +17 -0
- package/dist/server/utils/find-free-port.js.map +1 -0
- package/dist/server/watcher/__tests__/file-watcher.test.d.ts +2 -0
- package/dist/server/watcher/__tests__/file-watcher.test.d.ts.map +1 -0
- package/dist/server/watcher/__tests__/file-watcher.test.js +81 -0
- package/dist/server/watcher/__tests__/file-watcher.test.js.map +1 -0
- package/dist/server/watcher/file-watcher.d.ts +19 -0
- package/dist/server/watcher/file-watcher.d.ts.map +1 -0
- package/dist/server/watcher/file-watcher.js +105 -0
- package/dist/server/watcher/file-watcher.js.map +1 -0
- package/dist/server/watcher/state-parser.d.ts +77 -0
- package/dist/server/watcher/state-parser.d.ts.map +1 -0
- package/dist/server/watcher/state-parser.js +78 -0
- package/dist/server/watcher/state-parser.js.map +1 -0
- package/dist/server/ws/ws-auth.d.ts +4 -0
- package/dist/server/ws/ws-auth.d.ts.map +1 -0
- package/dist/server/ws/ws-auth.js +42 -0
- package/dist/server/ws/ws-auth.js.map +1 -0
- package/dist/server/ws/ws-handler.d.ts +12 -0
- package/dist/server/ws/ws-handler.d.ts.map +1 -0
- package/dist/server/ws/ws-handler.js +171 -0
- package/dist/server/ws/ws-handler.js.map +1 -0
- package/dist/server/ws/ws-rooms.d.ts +12 -0
- package/dist/server/ws/ws-rooms.d.ts.map +1 -0
- package/dist/server/ws/ws-rooms.js +52 -0
- package/dist/server/ws/ws-rooms.js.map +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { describe, it, expect, beforeAll, afterAll, beforeEach, vi } from 'vitest';
|
|
2
|
+
import { buildApp } from '../../app.js';
|
|
3
|
+
import fs from 'node:fs';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
import os from 'node:os';
|
|
6
|
+
let app;
|
|
7
|
+
let mockJobRunner;
|
|
8
|
+
let tmpSquadsDir;
|
|
9
|
+
beforeAll(async () => {
|
|
10
|
+
tmpSquadsDir = fs.mkdtempSync(path.join(os.tmpdir(), 'squads-'));
|
|
11
|
+
// Squad without secret
|
|
12
|
+
const squadDir = path.join(tmpSquadsDir, 'open-squad');
|
|
13
|
+
fs.mkdirSync(path.join(squadDir, 'agents'), { recursive: true });
|
|
14
|
+
fs.writeFileSync(path.join(squadDir, 'squad.yaml'), `squad:
|
|
15
|
+
code: open-squad
|
|
16
|
+
name: Open Squad
|
|
17
|
+
description: Test
|
|
18
|
+
icon: rocket
|
|
19
|
+
agents:
|
|
20
|
+
- id: worker
|
|
21
|
+
name: Worker
|
|
22
|
+
prompt: agents/worker.md
|
|
23
|
+
pipeline:
|
|
24
|
+
steps:
|
|
25
|
+
- id: step-01
|
|
26
|
+
agent: worker
|
|
27
|
+
label: Do work
|
|
28
|
+
`);
|
|
29
|
+
fs.writeFileSync(path.join(squadDir, 'agents/worker.md'), '# Worker');
|
|
30
|
+
// Squad with secret
|
|
31
|
+
const secretDir = path.join(tmpSquadsDir, 'secret-squad');
|
|
32
|
+
fs.mkdirSync(path.join(secretDir, 'agents'), { recursive: true });
|
|
33
|
+
fs.writeFileSync(path.join(secretDir, 'squad.yaml'), `squad:
|
|
34
|
+
code: secret-squad
|
|
35
|
+
name: Secret Squad
|
|
36
|
+
description: Test
|
|
37
|
+
icon: lock
|
|
38
|
+
agents:
|
|
39
|
+
- id: worker
|
|
40
|
+
name: Worker
|
|
41
|
+
prompt: agents/worker.md
|
|
42
|
+
pipeline:
|
|
43
|
+
steps:
|
|
44
|
+
- id: step-01
|
|
45
|
+
agent: worker
|
|
46
|
+
label: Do work
|
|
47
|
+
webhooks:
|
|
48
|
+
secret: correct-secret
|
|
49
|
+
`);
|
|
50
|
+
fs.writeFileSync(path.join(secretDir, 'agents/worker.md'), '# Worker');
|
|
51
|
+
mockJobRunner = {
|
|
52
|
+
run: vi.fn().mockResolvedValue('completed'),
|
|
53
|
+
isRunning: vi.fn().mockReturnValue(false),
|
|
54
|
+
stopAll: vi.fn(),
|
|
55
|
+
};
|
|
56
|
+
app = await buildApp({
|
|
57
|
+
config: {
|
|
58
|
+
jwtSecret: 'test-webhook-secret',
|
|
59
|
+
squadsDir: tmpSquadsDir,
|
|
60
|
+
},
|
|
61
|
+
jobRunner: mockJobRunner,
|
|
62
|
+
});
|
|
63
|
+
await app.ready();
|
|
64
|
+
});
|
|
65
|
+
afterAll(async () => {
|
|
66
|
+
await app.close();
|
|
67
|
+
fs.rmSync(tmpSquadsDir, { recursive: true, force: true });
|
|
68
|
+
});
|
|
69
|
+
beforeEach(() => vi.clearAllMocks());
|
|
70
|
+
describe('POST /api/webhooks/:squadName', () => {
|
|
71
|
+
it('returns 404 for non-existent squad', async () => {
|
|
72
|
+
const res = await app.inject({ method: 'POST', url: '/api/webhooks/nonexistent' });
|
|
73
|
+
expect(res.statusCode).toBe(404);
|
|
74
|
+
});
|
|
75
|
+
it('returns 202 and triggers job for squad with no secret configured', async () => {
|
|
76
|
+
const res = await app.inject({
|
|
77
|
+
method: 'POST',
|
|
78
|
+
url: '/api/webhooks/open-squad',
|
|
79
|
+
payload: { prompt: 'Run the daily report' },
|
|
80
|
+
});
|
|
81
|
+
expect(res.statusCode).toBe(202);
|
|
82
|
+
expect(res.json().status).toBe('triggered');
|
|
83
|
+
expect(res.json().squadName).toBe('open-squad');
|
|
84
|
+
await vi.waitFor(() => expect(mockJobRunner.run).toHaveBeenCalledWith(expect.objectContaining({ squadName: 'open-squad', prompt: 'Run the daily report' })));
|
|
85
|
+
});
|
|
86
|
+
it('uses default prompt when none provided', async () => {
|
|
87
|
+
await app.inject({ method: 'POST', url: '/api/webhooks/open-squad' });
|
|
88
|
+
await vi.waitFor(() => expect(mockJobRunner.run).toHaveBeenCalledWith(expect.objectContaining({ prompt: expect.stringContaining('open-squad') })));
|
|
89
|
+
});
|
|
90
|
+
it('returns 401 for squad with secret when no header provided', async () => {
|
|
91
|
+
const res = await app.inject({ method: 'POST', url: '/api/webhooks/secret-squad' });
|
|
92
|
+
expect(res.statusCode).toBe(401);
|
|
93
|
+
});
|
|
94
|
+
it('returns 401 for squad with secret when wrong secret provided', async () => {
|
|
95
|
+
const res = await app.inject({
|
|
96
|
+
method: 'POST',
|
|
97
|
+
url: '/api/webhooks/secret-squad',
|
|
98
|
+
headers: { 'x-webhook-secret': 'wrong' },
|
|
99
|
+
});
|
|
100
|
+
expect(res.statusCode).toBe(401);
|
|
101
|
+
});
|
|
102
|
+
it('returns 202 for squad with secret when correct secret provided', async () => {
|
|
103
|
+
const res = await app.inject({
|
|
104
|
+
method: 'POST',
|
|
105
|
+
url: '/api/webhooks/secret-squad',
|
|
106
|
+
headers: { 'x-webhook-secret': 'correct-secret' },
|
|
107
|
+
});
|
|
108
|
+
expect(res.statusCode).toBe(202);
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
//# sourceMappingURL=webhook-routes.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webhook-routes.test.js","sourceRoot":"","sources":["../../../src/api/__tests__/webhook-routes.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
|
|
2
|
+
import type Database from 'better-sqlite3';
|
|
3
|
+
interface ActivityRoutesOptions extends FastifyPluginOptions {
|
|
4
|
+
db: Database.Database;
|
|
5
|
+
}
|
|
6
|
+
export declare function activityRoutes(app: FastifyInstance, opts: ActivityRoutesOptions): Promise<void>;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=activity-routes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-routes.d.ts","sourceRoot":"","sources":["../../src/api/activity-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAO3C,UAAU,qBAAsB,SAAQ,oBAAoB;IAC1D,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;CACvB;AAED,wBAAsB,cAAc,CAClC,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,qBAAqB,GAC1B,OAAO,CAAC,IAAI,CAAC,CA0Cf"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { getActivitiesByDate, getDailySummary, getRecentActivities, } from '../services/activity-service.js';
|
|
2
|
+
export async function activityRoutes(app, opts) {
|
|
3
|
+
const { db } = opts;
|
|
4
|
+
// GET /api/activities?date=2026-03-14&squad=design-system
|
|
5
|
+
app.get('/api/activities', {
|
|
6
|
+
preHandler: [app.requireAuth],
|
|
7
|
+
}, async (request, reply) => {
|
|
8
|
+
const date = request.query.date ?? new Date().toISOString().slice(0, 10);
|
|
9
|
+
const squad = request.query.squad;
|
|
10
|
+
if (squad) {
|
|
11
|
+
const activities = getActivitiesByDate(db, date, squad);
|
|
12
|
+
return reply.send({ data: activities });
|
|
13
|
+
}
|
|
14
|
+
const activities = getActivitiesByDate(db, date);
|
|
15
|
+
return reply.send({ data: activities });
|
|
16
|
+
});
|
|
17
|
+
// GET /api/activities/summary?date=2026-03-14
|
|
18
|
+
app.get('/api/activities/summary', {
|
|
19
|
+
preHandler: [app.requireAuth],
|
|
20
|
+
}, async (request, reply) => {
|
|
21
|
+
const date = request.query.date ?? new Date().toISOString().slice(0, 10);
|
|
22
|
+
const summaries = getDailySummary(db, date);
|
|
23
|
+
return reply.send({ date, summaries });
|
|
24
|
+
});
|
|
25
|
+
// GET /api/activities/recent?limit=20
|
|
26
|
+
app.get('/api/activities/recent', {
|
|
27
|
+
preHandler: [app.requireAuth],
|
|
28
|
+
}, async (request, reply) => {
|
|
29
|
+
const limit = Math.min(parseInt(request.query.limit ?? '20', 10) || 20, 100);
|
|
30
|
+
const activities = getRecentActivities(db, limit);
|
|
31
|
+
return reply.send({ data: activities });
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=activity-routes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-routes.js","sourceRoot":"","sources":["../../src/api/activity-routes.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,mBAAmB,GACpB,MAAM,iCAAiC,CAAC;AAMzC,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,GAAoB,EACpB,IAA2B;IAE3B,MAAM,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC;IAEpB,0DAA0D;IAC1D,GAAG,CAAC,GAAG,CAEJ,iBAAiB,EAAE;QACpB,UAAU,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC;KAC9B,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QAC1B,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACzE,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC;QAElC,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,UAAU,GAAG,mBAAmB,CAAC,EAAE,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;YACxD,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAC1C,CAAC;QAED,MAAM,UAAU,GAAG,mBAAmB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QACjD,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,8CAA8C;IAC9C,GAAG,CAAC,GAAG,CAEJ,yBAAyB,EAAE;QAC5B,UAAU,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC;KAC9B,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QAC1B,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACzE,MAAM,SAAS,GAAG,eAAe,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QAC5C,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,sCAAsC;IACtC,GAAG,CAAC,GAAG,CAEJ,wBAAwB,EAAE;QAC3B,UAAU,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC;KAC9B,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,CAAC;QAC7E,MAAM,UAAU,GAAG,mBAAmB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;QAClD,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chat-api-routes.d.ts","sourceRoot":"","sources":["../../src/api/chat-api-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAQ7D,wBAAgB,aAAa,CAAC,GAAG,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,GAAG,IAAI,QA+B3F"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export function chatApiRoutes(app, getChatHandler) {
|
|
2
|
+
app.post('/api/chat/send', async (request, reply) => {
|
|
3
|
+
const handler = getChatHandler();
|
|
4
|
+
if (!handler) {
|
|
5
|
+
return reply.code(503).send({ success: false, error: 'Chat handler not ready' });
|
|
6
|
+
}
|
|
7
|
+
const { squadName, message, files } = request.body ?? {};
|
|
8
|
+
if (!squadName || !message) {
|
|
9
|
+
return reply.code(400).send({ success: false, error: 'squadName and message are required' });
|
|
10
|
+
}
|
|
11
|
+
handler.handleChatSend(squadName, message, files);
|
|
12
|
+
return reply.send({ success: true });
|
|
13
|
+
});
|
|
14
|
+
app.post('/api/chat/stop', async (request, reply) => {
|
|
15
|
+
const { squadName } = request.body ?? {};
|
|
16
|
+
if (!squadName) {
|
|
17
|
+
return reply.code(400).send({ success: false, error: 'squadName is required' });
|
|
18
|
+
}
|
|
19
|
+
const handler = getChatHandler();
|
|
20
|
+
if (!handler) {
|
|
21
|
+
return reply.code(503).send({ success: false, error: 'Chat handler not ready' });
|
|
22
|
+
}
|
|
23
|
+
// Expose stop method on ChatHandler
|
|
24
|
+
handler.stop(squadName);
|
|
25
|
+
return reply.send({ success: true });
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=chat-api-routes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chat-api-routes.js","sourceRoot":"","sources":["../../src/api/chat-api-routes.ts"],"names":[],"mappings":"AASA,MAAM,UAAU,aAAa,CAAC,GAAoB,EAAE,cAAwC;IAC1F,GAAG,CAAC,IAAI,CAAyB,gBAAgB,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QAC1E,MAAM,OAAO,GAAG,cAAc,EAAE,CAAC;QACjC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,wBAAwB,EAAE,CAAC,CAAC;QACnF,CAAC;QAED,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC;QACzD,IAAI,CAAC,SAAS,IAAI,CAAC,OAAO,EAAE,CAAC;YAC3B,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,oCAAoC,EAAE,CAAC,CAAC;QAC/F,CAAC;QAED,OAAO,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QAClD,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,IAAI,CAAkC,gBAAgB,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;QACnF,MAAM,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC;QACzC,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,uBAAuB,EAAE,CAAC,CAAC;QAClF,CAAC;QAED,MAAM,OAAO,GAAG,cAAc,EAAE,CAAC;QACjC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,wBAAwB,EAAE,CAAC,CAAC;QACnF,CAAC;QAED,oCAAoC;QACnC,OAA4D,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9E,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
|
|
2
|
+
import type Database from 'better-sqlite3';
|
|
3
|
+
interface CostRoutesOptions extends FastifyPluginOptions {
|
|
4
|
+
db: Database.Database;
|
|
5
|
+
}
|
|
6
|
+
export declare function costRoutes(app: FastifyInstance, opts: CostRoutesOptions): Promise<void>;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=cost-routes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost-routes.d.ts","sourceRoot":"","sources":["../../src/api/cost-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAG3C,UAAU,iBAAkB,SAAQ,oBAAoB;IACtD,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;CACvB;AAED,wBAAsB,UAAU,CAAC,GAAG,EAAE,eAAe,EAAE,IAAI,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC,CA0C7F"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { getSquadCosts, getSquadCostSummary } from '../services/cost-service.js';
|
|
2
|
+
export async function costRoutes(app, opts) {
|
|
3
|
+
const { db } = opts;
|
|
4
|
+
app.get('/api/squads/:code/costs', {
|
|
5
|
+
preHandler: [app.requireAuth],
|
|
6
|
+
}, async (request) => {
|
|
7
|
+
const { code } = request.params;
|
|
8
|
+
const { agent_id, since } = request.query;
|
|
9
|
+
return getSquadCosts(db, code, { agentId: agent_id, since });
|
|
10
|
+
});
|
|
11
|
+
app.get('/api/squads/:code/costs/summary', {
|
|
12
|
+
preHandler: [app.requireAuth],
|
|
13
|
+
}, async (request) => {
|
|
14
|
+
const { code } = request.params;
|
|
15
|
+
const { since } = request.query;
|
|
16
|
+
return getSquadCostSummary(db, code, since);
|
|
17
|
+
});
|
|
18
|
+
app.get('/api/squads/:code/budget', {
|
|
19
|
+
preHandler: [app.requireAuth],
|
|
20
|
+
}, async (request) => {
|
|
21
|
+
const { code } = request.params;
|
|
22
|
+
const now = new Date();
|
|
23
|
+
const monthStart = new Date(now.getFullYear(), now.getMonth(), 1).toISOString();
|
|
24
|
+
const summary = getSquadCostSummary(db, code, monthStart);
|
|
25
|
+
return { usedUsd: summary.totalCostUsd, byAgent: summary.byAgent, byModel: summary.byModel };
|
|
26
|
+
});
|
|
27
|
+
app.get('/api/costs/overview', {
|
|
28
|
+
preHandler: [app.requireAuth],
|
|
29
|
+
}, async () => {
|
|
30
|
+
const now = new Date();
|
|
31
|
+
const monthStart = new Date(now.getFullYear(), now.getMonth(), 1).toISOString();
|
|
32
|
+
const squads = db.prepare('SELECT DISTINCT squad_code FROM cost_entries WHERE created_at >= ?').all(monthStart);
|
|
33
|
+
return squads.map(({ squad_code }) => {
|
|
34
|
+
const summary = getSquadCostSummary(db, squad_code, monthStart);
|
|
35
|
+
return { squadCode: squad_code, ...summary };
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=cost-routes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost-routes.js","sourceRoot":"","sources":["../../src/api/cost-routes.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAMjF,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,GAAoB,EAAE,IAAuB;IAC5E,MAAM,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC;IAEpB,GAAG,CAAC,GAAG,CAAC,yBAAyB,EAAE;QACjC,UAAU,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC;KAC9B,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;QACnB,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAA0B,CAAC;QACpD,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,KAA8C,CAAC;QACnF,OAAO,aAAa,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CAAC,iCAAiC,EAAE;QACzC,UAAU,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC;KAC9B,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;QACnB,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAA0B,CAAC;QACpD,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,KAA2B,CAAC;QACtD,OAAO,mBAAmB,CAAC,EAAE,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CAAC,0BAA0B,EAAE;QAClC,UAAU,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC;KAC9B,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;QACnB,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAA0B,CAAC;QACpD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,UAAU,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAChF,MAAM,OAAO,GAAG,mBAAmB,CAAC,EAAE,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;QAC1D,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,YAAY,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC;IAC/F,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CAAC,qBAAqB,EAAE;QAC7B,UAAU,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC;KAC9B,EAAE,KAAK,IAAI,EAAE;QACZ,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,UAAU,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAChF,MAAM,MAAM,GAAG,EAAE,CAAC,OAAO,CACvB,oEAAoE,CACrE,CAAC,GAAG,CAAC,UAAU,CAA6B,CAAC;QAC9C,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE;YACnC,MAAM,OAAO,GAAG,mBAAmB,CAAC,EAAE,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;YAChE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,OAAO,EAAE,CAAC;QAC/C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
|
|
2
|
+
import type Database from 'better-sqlite3';
|
|
3
|
+
interface DashboardRoutesOptions extends FastifyPluginOptions {
|
|
4
|
+
db: Database.Database;
|
|
5
|
+
/** Optional kill callback — populated after bridges are created in app.ts */
|
|
6
|
+
kill?: (squadCode: string) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare function dashboardRoutes(app: FastifyInstance, opts: DashboardRoutesOptions): Promise<void>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=dashboard-routes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dashboard-routes.d.ts","sourceRoot":"","sources":["../../src/api/dashboard-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAE3C,UAAU,sBAAuB,SAAQ,oBAAoB;IAC3D,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;IACtB,6EAA6E;IAC7E,IAAI,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC;AAED,wBAAsB,eAAe,CACnC,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,sBAAsB,GAC3B,OAAO,CAAC,IAAI,CAAC,CAmNf"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
export async function dashboardRoutes(app, opts) {
|
|
2
|
+
const { db } = opts;
|
|
3
|
+
// GET /api/dashboard/stats — all metrics for the operations dashboard
|
|
4
|
+
app.get('/api/dashboard/stats', {
|
|
5
|
+
preHandler: [app.requireAuth],
|
|
6
|
+
}, async (_request, reply) => {
|
|
7
|
+
// ── KPI Cards ──────────────────────────────────────────
|
|
8
|
+
const open = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='planned'`).get().n;
|
|
9
|
+
const delayed = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='failed'`).get().n;
|
|
10
|
+
const doneToday = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='done' AND date(finished_at,'localtime')=date('now','localtime')`).get().n;
|
|
11
|
+
const inReview = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='executing'`).get().n;
|
|
12
|
+
const runningNow = db.prepare(`SELECT COUNT(*) AS n FROM squad_activities WHERE status='running'`).get().n;
|
|
13
|
+
const activeSquads = db.prepare(`SELECT COUNT(DISTINCT squad_code) AS n FROM squad_activities WHERE status='running'`).get().n;
|
|
14
|
+
const hoursTracked = Math.round((db.prepare(`SELECT COALESCE(SUM(CAST(duration_ms AS REAL)),0)/3600000.0 AS h
|
|
15
|
+
FROM squad_activities
|
|
16
|
+
WHERE started_at >= date('now','-7 days','localtime') AND duration_ms IS NOT NULL`).get().h) * 10) / 10;
|
|
17
|
+
const thisWeek = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='done' AND finished_at >= date('now','-7 days','localtime')`).get().n;
|
|
18
|
+
const lastWeek = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='done' AND finished_at >= date('now','-14 days','localtime') AND finished_at < date('now','-7 days','localtime')`).get().n;
|
|
19
|
+
const weekChange = lastWeek > 0
|
|
20
|
+
? Math.round(((thisWeek - lastWeek) / lastWeek) * 100)
|
|
21
|
+
: (thisWeek > 0 ? 100 : 0);
|
|
22
|
+
// ── Progress Metrics ────────────────────────────────────
|
|
23
|
+
const totalDone = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='done'`).get().n;
|
|
24
|
+
const totalFailed = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks WHERE status='failed'`).get().n;
|
|
25
|
+
const totalAll = db.prepare(`SELECT COUNT(*) AS n FROM kanban_tasks`).get().n;
|
|
26
|
+
const regularidade = totalAll > 0 ? Math.round((totalDone / totalAll) * 100) : 0;
|
|
27
|
+
const qualidade = (totalDone + totalFailed) > 0
|
|
28
|
+
? Math.round((totalDone / (totalDone + totalFailed)) * 100)
|
|
29
|
+
: 0;
|
|
30
|
+
const eficiencia = Math.round((regularidade + qualidade) / 2);
|
|
31
|
+
// ── 14-day completion rhythm ────────────────────────────
|
|
32
|
+
const rhythm14 = db.prepare(`SELECT date(finished_at,'localtime') AS day, COUNT(*) AS count
|
|
33
|
+
FROM kanban_tasks
|
|
34
|
+
WHERE status='done' AND finished_at >= date('now','-14 days','localtime')
|
|
35
|
+
GROUP BY day ORDER BY day`).all();
|
|
36
|
+
// ── Hourly rhythm ───────────────────────────────────────
|
|
37
|
+
const hourlyToday = db.prepare(`SELECT CAST(strftime('%H', finished_at, 'localtime') AS INTEGER) AS hour, COUNT(*) AS count
|
|
38
|
+
FROM kanban_tasks
|
|
39
|
+
WHERE status='done' AND date(finished_at,'localtime') = date('now','localtime')
|
|
40
|
+
GROUP BY hour ORDER BY hour`).all();
|
|
41
|
+
const hourlyLastWeek = db.prepare(`SELECT CAST(strftime('%H', finished_at, 'localtime') AS INTEGER) AS hour,
|
|
42
|
+
CAST(COUNT(*) AS REAL) / 7.0 AS avg_count
|
|
43
|
+
FROM kanban_tasks
|
|
44
|
+
WHERE status='done'
|
|
45
|
+
AND finished_at >= date('now','-7 days','localtime')
|
|
46
|
+
AND date(finished_at,'localtime') < date('now','localtime')
|
|
47
|
+
GROUP BY hour ORDER BY hour`).all();
|
|
48
|
+
// ── Running sessions (with current kanban task) ─────────
|
|
49
|
+
const runningSessions = db.prepare(`SELECT sa.id, sa.squad_code, sa.started_at,
|
|
50
|
+
(SELECT kt.title FROM kanban_tasks kt WHERE kt.activity_id = sa.id AND kt.status = 'executing' ORDER BY kt.position LIMIT 1) AS current_task,
|
|
51
|
+
(SELECT kt.agent_name FROM kanban_tasks kt WHERE kt.activity_id = sa.id AND kt.status = 'executing' ORDER BY kt.position LIMIT 1) AS current_agent,
|
|
52
|
+
(SELECT kt.step_id FROM kanban_tasks kt WHERE kt.activity_id = sa.id AND kt.status = 'executing' ORDER BY kt.position LIMIT 1) AS current_step,
|
|
53
|
+
(SELECT COUNT(*) FROM kanban_tasks kt WHERE kt.activity_id = sa.id AND kt.status = 'done') AS steps_done,
|
|
54
|
+
(SELECT COUNT(*) FROM kanban_tasks kt WHERE kt.activity_id = sa.id) AS steps_total
|
|
55
|
+
FROM squad_activities sa
|
|
56
|
+
WHERE sa.status='running'
|
|
57
|
+
ORDER BY sa.started_at ASC`).all();
|
|
58
|
+
let sessionAgents = [];
|
|
59
|
+
if (runningSessions.length > 0) {
|
|
60
|
+
const ids = runningSessions.map(s => s.id);
|
|
61
|
+
const placeholders = ids.map(() => '?').join(',');
|
|
62
|
+
sessionAgents = db.prepare(`SELECT kt.activity_id, kt.agent_name,
|
|
63
|
+
SUM(CASE WHEN kt.status='done' THEN 1 ELSE 0 END) AS done_count,
|
|
64
|
+
SUM(CASE WHEN kt.status='executing' THEN 1 ELSE 0 END) AS executing_count,
|
|
65
|
+
SUM(CASE WHEN kt.status='planned' THEN 1 ELSE 0 END) AS planned_count,
|
|
66
|
+
SUM(CASE WHEN kt.status='failed' THEN 1 ELSE 0 END) AS failed_count,
|
|
67
|
+
COUNT(*) AS total
|
|
68
|
+
FROM kanban_tasks kt
|
|
69
|
+
WHERE kt.activity_id IN (${placeholders})
|
|
70
|
+
AND kt.agent_name IS NOT NULL AND kt.agent_name != ''
|
|
71
|
+
GROUP BY kt.activity_id, kt.agent_name
|
|
72
|
+
ORDER BY kt.activity_id, MIN(kt.position)`).all(...ids);
|
|
73
|
+
}
|
|
74
|
+
// ── Squad performance ───────────────────────────────────
|
|
75
|
+
const squadPerf = db.prepare(`SELECT squad_code,
|
|
76
|
+
SUM(CASE WHEN status='done' THEN 1 ELSE 0 END) AS done,
|
|
77
|
+
SUM(CASE WHEN status='failed' THEN 1 ELSE 0 END) AS failed,
|
|
78
|
+
COUNT(*) AS total
|
|
79
|
+
FROM kanban_tasks
|
|
80
|
+
GROUP BY squad_code
|
|
81
|
+
ORDER BY done DESC
|
|
82
|
+
LIMIT 10`).all();
|
|
83
|
+
// ── Agent performance ───────────────────────────────────
|
|
84
|
+
const agentPerf = db.prepare(`SELECT agent_name,
|
|
85
|
+
SUM(CASE WHEN status='done' THEN 1 ELSE 0 END) AS done,
|
|
86
|
+
SUM(CASE WHEN status='failed' THEN 1 ELSE 0 END) AS failed,
|
|
87
|
+
COUNT(*) AS total
|
|
88
|
+
FROM kanban_tasks
|
|
89
|
+
WHERE agent_name IS NOT NULL AND agent_name != ''
|
|
90
|
+
GROUP BY agent_name
|
|
91
|
+
ORDER BY done DESC
|
|
92
|
+
LIMIT 10`).all();
|
|
93
|
+
return reply.send({
|
|
94
|
+
kpis: { open, delayed, doneToday, activeSquads, runningNow, hoursTracked, weekChange },
|
|
95
|
+
metrics: { regularidade, qualidade, eficiencia },
|
|
96
|
+
rhythm14,
|
|
97
|
+
hourlyToday,
|
|
98
|
+
hourlyLastWeek,
|
|
99
|
+
runningSessions,
|
|
100
|
+
sessionAgents,
|
|
101
|
+
squadPerf,
|
|
102
|
+
agentPerf,
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
// POST /api/dashboard/sessions/:id/kill — terminate a running pipeline
|
|
106
|
+
app.post('/api/dashboard/sessions/:id/kill', {
|
|
107
|
+
preHandler: [app.requireAuth],
|
|
108
|
+
}, async (request, reply) => {
|
|
109
|
+
const { id } = request.params;
|
|
110
|
+
const activity = db.prepare(`SELECT id, squad_code FROM squad_activities WHERE id = ? AND status = 'running'`).get(id);
|
|
111
|
+
if (!activity) {
|
|
112
|
+
return reply.code(404).send({ error: 'Session not found or already finished' });
|
|
113
|
+
}
|
|
114
|
+
// Best-effort: try to kill the Claude process via the bridge(s)
|
|
115
|
+
opts.kill?.(activity.squad_code);
|
|
116
|
+
// Mark the activity as cancelled
|
|
117
|
+
db.prepare(`UPDATE squad_activities
|
|
118
|
+
SET status = 'cancelled',
|
|
119
|
+
finished_at = datetime('now'),
|
|
120
|
+
duration_ms = CAST((julianday('now') - julianday(started_at)) * 86400000 AS INTEGER)
|
|
121
|
+
WHERE id = ?`).run(id);
|
|
122
|
+
// Mark any executing kanban tasks as failed
|
|
123
|
+
db.prepare(`UPDATE kanban_tasks SET status = 'failed', finished_at = datetime('now')
|
|
124
|
+
WHERE activity_id = ? AND status = 'executing'`).run(id);
|
|
125
|
+
return reply.send({ success: true, squad_code: activity.squad_code });
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=dashboard-routes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dashboard-routes.js","sourceRoot":"","sources":["../../src/api/dashboard-routes.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"files-routes.d.ts","sourceRoot":"","sources":["../../src/api/files-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAuG/C,wBAAsB,WAAW,CAC/B,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE;IAAE,SAAS,EAAE,MAAM,CAAA;CAAE,iBA0K5B"}
|