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,77 @@
|
|
|
1
|
+
export interface AgentDesk {
|
|
2
|
+
col: number;
|
|
3
|
+
row: number;
|
|
4
|
+
}
|
|
5
|
+
export type AgentStatus = 'idle' | 'working' | 'delivering' | 'done' | 'checkpoint';
|
|
6
|
+
export interface Agent {
|
|
7
|
+
id: string;
|
|
8
|
+
name: string;
|
|
9
|
+
icon: string;
|
|
10
|
+
status: AgentStatus;
|
|
11
|
+
deliverTo: string | null;
|
|
12
|
+
desk: AgentDesk;
|
|
13
|
+
message?: string;
|
|
14
|
+
stepIndex?: number;
|
|
15
|
+
stepLabel?: string;
|
|
16
|
+
}
|
|
17
|
+
export interface Handoff {
|
|
18
|
+
from: string;
|
|
19
|
+
to: string;
|
|
20
|
+
message: string;
|
|
21
|
+
completedAt: string;
|
|
22
|
+
}
|
|
23
|
+
export type SquadStatus = 'idle' | 'running' | 'completed' | 'checkpoint';
|
|
24
|
+
export interface SquadState {
|
|
25
|
+
squad: string;
|
|
26
|
+
status: SquadStatus;
|
|
27
|
+
step: {
|
|
28
|
+
current: number;
|
|
29
|
+
total: number;
|
|
30
|
+
label: string;
|
|
31
|
+
};
|
|
32
|
+
agents: Agent[];
|
|
33
|
+
handoff: Handoff | null;
|
|
34
|
+
startedAt: string | null;
|
|
35
|
+
updatedAt: string;
|
|
36
|
+
}
|
|
37
|
+
export type StateEvent = {
|
|
38
|
+
type: 'squad:state';
|
|
39
|
+
squadName: string;
|
|
40
|
+
state: SquadState;
|
|
41
|
+
} | {
|
|
42
|
+
type: 'agent:status';
|
|
43
|
+
agentId: string;
|
|
44
|
+
agentName: string;
|
|
45
|
+
status: string;
|
|
46
|
+
position?: {
|
|
47
|
+
x: number;
|
|
48
|
+
y: number;
|
|
49
|
+
};
|
|
50
|
+
} | {
|
|
51
|
+
type: 'chat:agent_dm';
|
|
52
|
+
agentId: string;
|
|
53
|
+
agentName: string;
|
|
54
|
+
message: string;
|
|
55
|
+
} | {
|
|
56
|
+
type: 'agent:step_start';
|
|
57
|
+
squadName: string;
|
|
58
|
+
agentId: string;
|
|
59
|
+
agentName: string;
|
|
60
|
+
stepIndex: number;
|
|
61
|
+
stepLabel: string;
|
|
62
|
+
} | {
|
|
63
|
+
type: 'agent:step_complete';
|
|
64
|
+
squadName: string;
|
|
65
|
+
agentId: string;
|
|
66
|
+
agentName: string;
|
|
67
|
+
stepIndex: number;
|
|
68
|
+
stepLabel: string;
|
|
69
|
+
} | {
|
|
70
|
+
type: 'squad:checkpoint';
|
|
71
|
+
squadName: string;
|
|
72
|
+
agentId: string;
|
|
73
|
+
agentName: string;
|
|
74
|
+
question: string;
|
|
75
|
+
};
|
|
76
|
+
export declare function diffState(squadName: string, prev: SquadState | null, next: SquadState): StateEvent[];
|
|
77
|
+
//# sourceMappingURL=state-parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state-parser.d.ts","sourceRoot":"","sources":["../../src/watcher/state-parser.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,SAAS;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,SAAS,GAAG,YAAY,GAAG,MAAM,GAAG,YAAY,CAAC;AAEpF,MAAM,WAAW,KAAK;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,WAAW,CAAC;IACpB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,IAAI,EAAE,SAAS,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,OAAO;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,SAAS,GAAG,WAAW,GAAG,YAAY,CAAC;AAE1E,MAAM,WAAW,UAAU;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,WAAW,CAAC;IACpB,IAAI,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IACxD,MAAM,EAAE,KAAK,EAAE,CAAC;IAChB,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC;IACxB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,MAAM,UAAU,GAClB;IAAE,IAAI,EAAE,aAAa,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,UAAU,CAAA;CAAE,GAC7D;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,GACjH;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GAC9E;IAAE,IAAI,EAAE,kBAAkB,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,GACzH;IAAE,IAAI,EAAE,qBAAqB,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,GAC5H;IAAE,IAAI,EAAE,kBAAkB,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAE1G,wBAAgB,SAAS,CACvB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,UAAU,GAAG,IAAI,EACvB,IAAI,EAAE,UAAU,GACf,UAAU,EAAE,CAyFd"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
export function diffState(squadName, prev, next) {
|
|
2
|
+
const events = [];
|
|
3
|
+
// No previous state — emit full state
|
|
4
|
+
if (!prev) {
|
|
5
|
+
events.push({ type: 'squad:state', squadName, state: next });
|
|
6
|
+
return events;
|
|
7
|
+
}
|
|
8
|
+
// Squad-level changes
|
|
9
|
+
const prevAgentMap = new Map(prev.agents.map((a) => [a.id, a]));
|
|
10
|
+
const agentChanged = next.agents.some((a) => {
|
|
11
|
+
const pa = prevAgentMap.get(a.id);
|
|
12
|
+
return !pa || pa.status !== a.status;
|
|
13
|
+
});
|
|
14
|
+
const squadChanged = prev.status !== next.status ||
|
|
15
|
+
prev.step.current !== next.step.current ||
|
|
16
|
+
JSON.stringify(prev.handoff) !== JSON.stringify(next.handoff);
|
|
17
|
+
if (squadChanged || agentChanged) {
|
|
18
|
+
events.push({ type: 'squad:state', squadName, state: next });
|
|
19
|
+
}
|
|
20
|
+
// Checkpoint detection — when squad status transitions to 'checkpoint'
|
|
21
|
+
if (prev.status !== 'checkpoint' && next.status === 'checkpoint') {
|
|
22
|
+
const checkpointAgent = next.agents.find((a) => a.status === 'checkpoint');
|
|
23
|
+
if (checkpointAgent) {
|
|
24
|
+
events.push({
|
|
25
|
+
type: 'squad:checkpoint',
|
|
26
|
+
squadName,
|
|
27
|
+
agentId: checkpointAgent.id,
|
|
28
|
+
agentName: checkpointAgent.name,
|
|
29
|
+
question: checkpointAgent.message ?? '',
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// Agent-level changes
|
|
34
|
+
for (const agent of next.agents) {
|
|
35
|
+
const prevAgent = prevAgentMap.get(agent.id);
|
|
36
|
+
if (!prevAgent || prevAgent.status !== agent.status) {
|
|
37
|
+
events.push({
|
|
38
|
+
type: 'agent:status',
|
|
39
|
+
agentId: agent.id,
|
|
40
|
+
agentName: agent.name,
|
|
41
|
+
status: agent.status,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
// Step change detection
|
|
45
|
+
if (prevAgent &&
|
|
46
|
+
agent.stepIndex !== undefined &&
|
|
47
|
+
prevAgent.stepIndex !== undefined &&
|
|
48
|
+
prevAgent.stepIndex !== agent.stepIndex) {
|
|
49
|
+
events.push({
|
|
50
|
+
type: 'agent:step_complete',
|
|
51
|
+
squadName,
|
|
52
|
+
agentId: agent.id,
|
|
53
|
+
agentName: agent.name,
|
|
54
|
+
stepIndex: prevAgent.stepIndex,
|
|
55
|
+
stepLabel: prevAgent.stepLabel ?? '',
|
|
56
|
+
});
|
|
57
|
+
events.push({
|
|
58
|
+
type: 'agent:step_start',
|
|
59
|
+
squadName,
|
|
60
|
+
agentId: agent.id,
|
|
61
|
+
agentName: agent.name,
|
|
62
|
+
stepIndex: agent.stepIndex,
|
|
63
|
+
stepLabel: agent.stepLabel ?? '',
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
// Agent DM: message field populated when it wasn't before
|
|
67
|
+
if (agent.message && (!prevAgent || !prevAgent.message)) {
|
|
68
|
+
events.push({
|
|
69
|
+
type: 'chat:agent_dm',
|
|
70
|
+
agentId: agent.id,
|
|
71
|
+
agentName: agent.name,
|
|
72
|
+
message: agent.message,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return events;
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=state-parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state-parser.js","sourceRoot":"","sources":["../../src/watcher/state-parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { type AccessTokenPayload } from '../auth/jwt.js';
|
|
2
|
+
export declare function extractTokenFromUrl(url: string): string | null;
|
|
3
|
+
export declare function authenticateWs(url: string, cookieHeader: string | undefined, jwtSecret: string): AccessTokenPayload | null;
|
|
4
|
+
//# sourceMappingURL=ws-auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ws-auth.d.ts","sourceRoot":"","sources":["../../src/ws/ws-auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,KAAK,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAE5E,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAQ9D;AAED,wBAAgB,cAAc,CAC5B,GAAG,EAAE,MAAM,EACX,YAAY,EAAE,MAAM,GAAG,SAAS,EAChC,SAAS,EAAE,MAAM,GAChB,kBAAkB,GAAG,IAAI,CA8B3B"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { verifyAccessToken } from '../auth/jwt.js';
|
|
2
|
+
export function extractTokenFromUrl(url) {
|
|
3
|
+
if (!url)
|
|
4
|
+
return null;
|
|
5
|
+
try {
|
|
6
|
+
const searchParams = new URLSearchParams(url.split('?')[1] || '');
|
|
7
|
+
return searchParams.get('token') || null;
|
|
8
|
+
}
|
|
9
|
+
catch {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export function authenticateWs(url, cookieHeader, jwtSecret) {
|
|
14
|
+
// Try query param first (for WebSocket connections from browser)
|
|
15
|
+
const queryToken = extractTokenFromUrl(url);
|
|
16
|
+
if (queryToken) {
|
|
17
|
+
try {
|
|
18
|
+
return verifyAccessToken(queryToken, jwtSecret);
|
|
19
|
+
}
|
|
20
|
+
catch {
|
|
21
|
+
return null;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
// Try cookie
|
|
25
|
+
if (cookieHeader) {
|
|
26
|
+
const cookies = Object.fromEntries(cookieHeader.split(';').map((c) => {
|
|
27
|
+
const [key, ...vals] = c.trim().split('=');
|
|
28
|
+
return [key, vals.join('=')];
|
|
29
|
+
}));
|
|
30
|
+
const token = cookies['access_token'];
|
|
31
|
+
if (token) {
|
|
32
|
+
try {
|
|
33
|
+
return verifyAccessToken(token, jwtSecret);
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=ws-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ws-auth.js","sourceRoot":"","sources":["../../src/ws/ws-auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAA2B,MAAM,gBAAgB,CAAC;AAE5E,MAAM,UAAU,mBAAmB,CAAC,GAAW;IAC7C,IAAI,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IACtB,IAAI,CAAC;QACH,MAAM,YAAY,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QAClE,OAAO,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC;IAC3C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,GAAW,EACX,YAAgC,EAChC,SAAiB;IAEjB,iEAAiE;IACjE,MAAM,UAAU,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC;IAC5C,IAAI,UAAU,EAAE,CAAC;QACf,IAAI,CAAC;YACH,OAAO,iBAAiB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QAClD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,aAAa;IACb,IAAI,YAAY,EAAE,CAAC;QACjB,MAAM,OAAO,GAAG,MAAM,CAAC,WAAW,CAChC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YAChC,MAAM,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC3C,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QAC/B,CAAC,CAAC,CACH,CAAC;QACF,MAAM,KAAK,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;QACtC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC;gBACH,OAAO,iBAAiB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YAC7C,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { FastifyInstance } from 'fastify';
|
|
2
|
+
import { WsRooms } from './ws-rooms.js';
|
|
3
|
+
import type { ChatHandler } from '../bridge/chat-handler.js';
|
|
4
|
+
export interface WsContext {
|
|
5
|
+
rooms: WsRooms;
|
|
6
|
+
broadcastToSquad: (squadName: string, data: object) => void;
|
|
7
|
+
broadcastToAll: (data: object) => void;
|
|
8
|
+
setChatHandler: (handler: ChatHandler) => void;
|
|
9
|
+
getChatHandler: () => ChatHandler | null;
|
|
10
|
+
}
|
|
11
|
+
export declare function registerWebSocket(app: FastifyInstance, jwtSecret: string, squadsDir?: string): Promise<WsContext>;
|
|
12
|
+
//# sourceMappingURL=ws-handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ws-handler.d.ts","sourceRoot":"","sources":["../../src/ws/ws-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAM/C,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAExC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAO7D,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,OAAO,CAAC;IACf,gBAAgB,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5D,cAAc,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,cAAc,EAAE,CAAC,OAAO,EAAE,WAAW,KAAK,IAAI,CAAC;IAC/C,cAAc,EAAE,MAAM,WAAW,GAAG,IAAI,CAAC;CAC1C;AAED,wBAAsB,iBAAiB,CACrC,GAAG,EAAE,eAAe,EACpB,SAAS,EAAE,MAAM,EACjB,SAAS,GAAE,MAAW,GACrB,OAAO,CAAC,SAAS,CAAC,CA8DpB"}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import websocket from '@fastify/websocket';
|
|
2
|
+
import fs from 'fs';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { authenticateWs } from './ws-auth.js';
|
|
5
|
+
import { WsRooms } from './ws-rooms.js';
|
|
6
|
+
export async function registerWebSocket(app, jwtSecret, squadsDir = '') {
|
|
7
|
+
const rooms = new WsRooms();
|
|
8
|
+
let chatHandler = null;
|
|
9
|
+
await app.register(websocket);
|
|
10
|
+
app.get('/ws', { websocket: true }, (socket, request) => {
|
|
11
|
+
const user = authenticateWs(request.url, request.headers.cookie, jwtSecret);
|
|
12
|
+
if (!user) {
|
|
13
|
+
socket.close(4001, 'Authentication required');
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
// Attach user info to socket for reference
|
|
17
|
+
socket.user = user;
|
|
18
|
+
socket.on('message', (raw) => {
|
|
19
|
+
try {
|
|
20
|
+
const msg = JSON.parse(raw.toString());
|
|
21
|
+
handleMessage(socket, user, msg, rooms, chatHandler, squadsDir);
|
|
22
|
+
}
|
|
23
|
+
catch (err) {
|
|
24
|
+
console.error('[ws] Error handling message:', err);
|
|
25
|
+
// Try to send error back to client for chat messages
|
|
26
|
+
try {
|
|
27
|
+
const msg = JSON.parse(raw.toString());
|
|
28
|
+
if (msg.type === 'chat:send' && msg.squadName) {
|
|
29
|
+
const errorPayload = {
|
|
30
|
+
type: 'chat:error',
|
|
31
|
+
squadName: msg.squadName,
|
|
32
|
+
error: err instanceof Error ? err.message : 'Internal server error',
|
|
33
|
+
};
|
|
34
|
+
socket.send(JSON.stringify(errorPayload));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
catch { /* ignore */ }
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
socket.on('close', () => {
|
|
41
|
+
rooms.removeClient(socket);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
const broadcastToSquad = (squadName, data) => {
|
|
45
|
+
rooms.broadcast(`squad:${squadName}`, JSON.stringify(data));
|
|
46
|
+
};
|
|
47
|
+
const broadcastToAll = (data) => {
|
|
48
|
+
rooms.broadcastAll(JSON.stringify(data));
|
|
49
|
+
};
|
|
50
|
+
const setChatHandler = (handler) => {
|
|
51
|
+
chatHandler = handler;
|
|
52
|
+
};
|
|
53
|
+
const getChatHandler = () => chatHandler;
|
|
54
|
+
return { rooms, broadcastToSquad, broadcastToAll, setChatHandler, getChatHandler };
|
|
55
|
+
}
|
|
56
|
+
function findStateJson(squadsDir, squadName) {
|
|
57
|
+
if (!squadsDir)
|
|
58
|
+
return null;
|
|
59
|
+
// Fast path: direct child
|
|
60
|
+
const direct = path.join(squadsDir, squadName, 'state.json');
|
|
61
|
+
if (fs.existsSync(direct))
|
|
62
|
+
return direct;
|
|
63
|
+
// Walk for nested structures (setor/grupo/sessao/code)
|
|
64
|
+
function walk(dir, depth) {
|
|
65
|
+
if (depth > 4)
|
|
66
|
+
return null;
|
|
67
|
+
let entries;
|
|
68
|
+
try {
|
|
69
|
+
entries = fs.readdirSync(dir, { withFileTypes: true });
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
for (const entry of entries) {
|
|
75
|
+
if (!entry.isDirectory())
|
|
76
|
+
continue;
|
|
77
|
+
if (entry.name.startsWith('.') || entry.name.startsWith('_'))
|
|
78
|
+
continue;
|
|
79
|
+
const fullPath = path.join(dir, entry.name);
|
|
80
|
+
if (entry.name === squadName) {
|
|
81
|
+
const statePath = path.join(fullPath, 'state.json');
|
|
82
|
+
if (fs.existsSync(statePath))
|
|
83
|
+
return statePath;
|
|
84
|
+
}
|
|
85
|
+
const found = walk(fullPath, depth + 1);
|
|
86
|
+
if (found)
|
|
87
|
+
return found;
|
|
88
|
+
}
|
|
89
|
+
return null;
|
|
90
|
+
}
|
|
91
|
+
return walk(squadsDir, 0);
|
|
92
|
+
}
|
|
93
|
+
function handleMessage(ws, user, msg, rooms, chatHandler, squadsDir = '') {
|
|
94
|
+
switch (msg.type) {
|
|
95
|
+
case 'squad:subscribe':
|
|
96
|
+
if (typeof msg.squadName === 'string') {
|
|
97
|
+
rooms.subscribe(ws, `squad:${msg.squadName}`);
|
|
98
|
+
// Send current state immediately so the client doesn't miss existing squad activity
|
|
99
|
+
const statePath = findStateJson(squadsDir, msg.squadName);
|
|
100
|
+
if (statePath) {
|
|
101
|
+
try {
|
|
102
|
+
const raw = fs.readFileSync(statePath, 'utf-8');
|
|
103
|
+
const state = JSON.parse(raw);
|
|
104
|
+
ws.send(JSON.stringify({ type: 'squad:state', squadName: msg.squadName, state }));
|
|
105
|
+
}
|
|
106
|
+
catch {
|
|
107
|
+
// Invalid JSON — skip
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
break;
|
|
112
|
+
case 'squad:unsubscribe':
|
|
113
|
+
if (typeof msg.squadName === 'string') {
|
|
114
|
+
rooms.unsubscribe(ws, `squad:${msg.squadName}`);
|
|
115
|
+
}
|
|
116
|
+
break;
|
|
117
|
+
case 'chat:send':
|
|
118
|
+
if (typeof msg.squadName === 'string' && typeof msg.message === 'string' && chatHandler) {
|
|
119
|
+
if (user.role === 'viewer') {
|
|
120
|
+
ws.send(JSON.stringify({
|
|
121
|
+
type: 'chat:error',
|
|
122
|
+
squadName: msg.squadName,
|
|
123
|
+
error: 'Insufficient permissions',
|
|
124
|
+
}));
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
const files = Array.isArray(msg.files) ? msg.files : undefined;
|
|
128
|
+
chatHandler.handleChatSend(msg.squadName, msg.message, files);
|
|
129
|
+
}
|
|
130
|
+
break;
|
|
131
|
+
case 'chat:new_conversation':
|
|
132
|
+
if (typeof msg.squadName === 'string' && chatHandler) {
|
|
133
|
+
if (user.role === 'viewer') {
|
|
134
|
+
ws.send(JSON.stringify({
|
|
135
|
+
type: 'chat:error',
|
|
136
|
+
squadName: msg.squadName,
|
|
137
|
+
error: 'Insufficient permissions',
|
|
138
|
+
}));
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
chatHandler.handleNewConversation(msg.squadName);
|
|
142
|
+
}
|
|
143
|
+
break;
|
|
144
|
+
case 'squad:checkpoint_response':
|
|
145
|
+
if (typeof msg.squadName === 'string' && typeof msg.answer === 'string') {
|
|
146
|
+
if (user.role === 'viewer') {
|
|
147
|
+
ws.send(JSON.stringify({
|
|
148
|
+
type: 'squad:error',
|
|
149
|
+
squadName: msg.squadName,
|
|
150
|
+
error: 'Insufficient permissions',
|
|
151
|
+
}));
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
try {
|
|
155
|
+
const squadDir = path.join(squadsDir, msg.squadName);
|
|
156
|
+
const filePath = path.join(squadDir, 'checkpoint-response.json');
|
|
157
|
+
fs.writeFileSync(filePath, JSON.stringify({
|
|
158
|
+
answer: msg.answer,
|
|
159
|
+
timestamp: new Date().toISOString(),
|
|
160
|
+
}));
|
|
161
|
+
}
|
|
162
|
+
catch {
|
|
163
|
+
// Silently handle missing squad directories
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
break;
|
|
167
|
+
default:
|
|
168
|
+
break;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=ws-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ws-handler.js","sourceRoot":"","sources":["../../src/ws/ws-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { WebSocket } from 'ws';
|
|
2
|
+
export declare class WsRooms {
|
|
3
|
+
private rooms;
|
|
4
|
+
private clientRooms;
|
|
5
|
+
subscribe(ws: WebSocket, room: string): void;
|
|
6
|
+
unsubscribe(ws: WebSocket, room: string): void;
|
|
7
|
+
removeClient(ws: WebSocket): void;
|
|
8
|
+
broadcast(room: string, data: string): void;
|
|
9
|
+
broadcastAll(data: string): void;
|
|
10
|
+
getSubscribers(room: string): Set<WebSocket>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=ws-rooms.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ws-rooms.d.ts","sourceRoot":"","sources":["../../src/ws/ws-rooms.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AAEpC,qBAAa,OAAO;IAClB,OAAO,CAAC,KAAK,CAAqC;IAClD,OAAO,CAAC,WAAW,CAAqC;IAExD,SAAS,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI;IAY5C,WAAW,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI;IAK9C,YAAY,CAAC,EAAE,EAAE,SAAS,GAAG,IAAI;IAUjC,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI;IAU3C,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAYhC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,GAAG,CAAC,SAAS,CAAC;CAG7C"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
export class WsRooms {
|
|
2
|
+
rooms = new Map();
|
|
3
|
+
clientRooms = new Map();
|
|
4
|
+
subscribe(ws, room) {
|
|
5
|
+
if (!this.rooms.has(room)) {
|
|
6
|
+
this.rooms.set(room, new Set());
|
|
7
|
+
}
|
|
8
|
+
this.rooms.get(room).add(ws);
|
|
9
|
+
if (!this.clientRooms.has(ws)) {
|
|
10
|
+
this.clientRooms.set(ws, new Set());
|
|
11
|
+
}
|
|
12
|
+
this.clientRooms.get(ws).add(room);
|
|
13
|
+
}
|
|
14
|
+
unsubscribe(ws, room) {
|
|
15
|
+
this.rooms.get(room)?.delete(ws);
|
|
16
|
+
this.clientRooms.get(ws)?.delete(room);
|
|
17
|
+
}
|
|
18
|
+
removeClient(ws) {
|
|
19
|
+
const rooms = this.clientRooms.get(ws);
|
|
20
|
+
if (rooms) {
|
|
21
|
+
for (const room of rooms) {
|
|
22
|
+
this.rooms.get(room)?.delete(ws);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
this.clientRooms.delete(ws);
|
|
26
|
+
}
|
|
27
|
+
broadcast(room, data) {
|
|
28
|
+
const clients = this.rooms.get(room);
|
|
29
|
+
if (!clients)
|
|
30
|
+
return;
|
|
31
|
+
for (const ws of clients) {
|
|
32
|
+
if (ws.readyState === ws.OPEN) {
|
|
33
|
+
ws.send(data);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
broadcastAll(data) {
|
|
38
|
+
const sent = new Set();
|
|
39
|
+
for (const [, clients] of this.rooms) {
|
|
40
|
+
for (const ws of clients) {
|
|
41
|
+
if (!sent.has(ws) && ws.readyState === ws.OPEN) {
|
|
42
|
+
ws.send(data);
|
|
43
|
+
sent.add(ws);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
getSubscribers(room) {
|
|
49
|
+
return this.rooms.get(room) || new Set();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=ws-rooms.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ws-rooms.js","sourceRoot":"","sources":["../../src/ws/ws-rooms.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,OAAO;IACV,KAAK,GAAG,IAAI,GAAG,EAA0B,CAAC;IAC1C,WAAW,GAAG,IAAI,GAAG,EAA0B,CAAC;IAExD,SAAS,CAAC,EAAa,EAAE,IAAY;QACnC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QAClC,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE9B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,WAAW,CAAC,EAAa,EAAE,IAAY;QACrC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC;QACjC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,YAAY,CAAC,EAAa;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC;YACnC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,SAAS,CAAC,IAAY,EAAE,IAAY;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO;YAAE,OAAO;QACrB,KAAK,MAAM,EAAE,IAAI,OAAO,EAAE,CAAC;YACzB,IAAI,EAAE,CAAC,UAAU,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;gBAC9B,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC;QACH,CAAC;IACH,CAAC;IAED,YAAY,CAAC,IAAY;QACvB,MAAM,IAAI,GAAG,IAAI,GAAG,EAAa,CAAC;QAClC,KAAK,MAAM,CAAC,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACrC,KAAK,MAAM,EAAE,IAAI,OAAO,EAAE,CAAC;gBACzB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,UAAU,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;oBAC/C,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACd,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBACf,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,cAAc,CAAC,IAAY;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC;IAC3C,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "expxagents",
|
|
3
|
-
"version": "0.25.
|
|
3
|
+
"version": "0.25.2",
|
|
4
4
|
"description": "Multi-agent orchestration platform for AI squads",
|
|
5
5
|
"author": "ExpxAgents",
|
|
6
6
|
"license": "MIT",
|
|
@@ -33,7 +33,7 @@
|
|
|
33
33
|
},
|
|
34
34
|
"scripts": {
|
|
35
35
|
"build": "tsc && node scripts/copy-assets.js",
|
|
36
|
-
"prepublishOnly": "cd .. && npm run build && cd cli && npm run build",
|
|
36
|
+
"prepublishOnly": "cd .. && npm run build && cd cli && npm run build && node scripts/verify-bundle.js",
|
|
37
37
|
"dev": "tsc --watch",
|
|
38
38
|
"test": "vitest run",
|
|
39
39
|
"test:watch": "vitest"
|