expxagents 0.24.2 → 0.25.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/src/commands/info.d.ts +1 -2
- package/dist/cli/src/commands/login.d.ts +1 -2
- package/dist/cli/src/commands/logout.d.ts +1 -2
- package/dist/cli/src/commands/outdated.d.ts +1 -2
- package/dist/cli/src/commands/publish.d.ts +1 -2
- package/dist/cli/src/commands/registry-install.d.ts +1 -2
- package/dist/cli/src/commands/search.d.ts +1 -2
- package/dist/cli/src/commands/update.d.ts +1 -2
- package/dist/cli/src/commands/whoami.d.ts +1 -2
- package/package.json +1 -1
- package/assets/agents/_catalog.yaml +0 -35
- package/assets/agents/accounting/accountant.agent.md +0 -41
- package/assets/agents/accounting/audit-analyst.agent.md +0 -41
- package/assets/agents/accounting/financial-reporting.agent.md +0 -41
- package/assets/agents/accounting/fiscal-analyst.agent.md +0 -41
- package/assets/agents/accounting/payroll-specialist.agent.md +0 -41
- package/assets/agents/accounting/tax-compliance.agent.md +0 -41
- package/assets/agents/administrative/document-controller.agent.md +0 -41
- package/assets/agents/administrative/office-manager.agent.md +0 -41
- package/assets/agents/administrative/process-documentation-officer.agent.md +0 -41
- package/assets/agents/administrative/procurement-specialist.agent.md +0 -41
- package/assets/agents/board/board-report-writer.agent.md +0 -41
- package/assets/agents/board/business-intelligence.agent.md +0 -41
- package/assets/agents/board/governance-officer.agent.md +0 -41
- package/assets/agents/board/okr-manager.agent.md +0 -41
- package/assets/agents/board/risk-analyst.agent.md +0 -41
- package/assets/agents/board/strategic-advisor.agent.md +0 -41
- package/assets/agents/commercial/account-executive.agent.md +0 -41
- package/assets/agents/commercial/crm-manager.agent.md +0 -41
- package/assets/agents/commercial/pricing-strategist.agent.md +0 -41
- package/assets/agents/commercial/proposal-writer.agent.md +0 -41
- package/assets/agents/commercial/sdr.agent.md +0 -41
- package/assets/agents/compliance/compliance-officer.agent.md +0 -41
- package/assets/agents/compliance/data-privacy-specialist.agent.md +0 -41
- package/assets/agents/compliance/internal-auditor.agent.md +0 -41
- package/assets/agents/compliance/regulatory-monitor.agent.md +0 -41
- package/assets/agents/customer-success/churn-prevention.agent.md +0 -41
- package/assets/agents/customer-success/csm.agent.md +0 -41
- package/assets/agents/customer-success/expansion-manager.agent.md +0 -41
- package/assets/agents/customer-success/nps-analyst.agent.md +0 -41
- package/assets/agents/customer-success/renewal-manager.agent.md +0 -41
- package/assets/agents/development/android-developer.agent.md +0 -41
- package/assets/agents/development/backend-developer.agent.md +0 -42
- package/assets/agents/development/business-analyst.agent.md +0 -41
- package/assets/agents/development/code-reviewer.agent.md +0 -41
- package/assets/agents/development/cross-platform-mobile.agent.md +0 -41
- package/assets/agents/development/dba.agent.md +0 -41
- package/assets/agents/development/desktop-developer.agent.md +0 -41
- package/assets/agents/development/devops-engineer.agent.md +0 -41
- package/assets/agents/development/frontend-developer.agent.md +0 -103
- package/assets/agents/development/ios-developer.agent.md +0 -41
- package/assets/agents/development/product-manager.agent.md +0 -41
- package/assets/agents/development/qa-engineer.agent.md +0 -41
- package/assets/agents/development/scrum-master.agent.md +0 -41
- package/assets/agents/development/security-analyst.agent.md +0 -41
- package/assets/agents/development/tech-lead.agent.md +0 -42
- package/assets/agents/development/tech-writer.agent.md +0 -41
- package/assets/agents/development/ux-design-expert.agent.md +0 -108
- package/assets/agents/development/ux-designer.agent.md +0 -41
- package/assets/agents/finance/accounts-manager.agent.md +0 -41
- package/assets/agents/finance/billing-analyst.agent.md +0 -41
- package/assets/agents/finance/budget-planner.agent.md +0 -41
- package/assets/agents/finance/financial-controller.agent.md +0 -41
- package/assets/agents/hr/benefits-manager.agent.md +0 -41
- package/assets/agents/hr/hr-onboarding.agent.md +0 -41
- package/assets/agents/hr/interview-coordinator.agent.md +0 -41
- package/assets/agents/hr/people-culture.agent.md +0 -41
- package/assets/agents/hr/performance-analyst.agent.md +0 -41
- package/assets/agents/hr/recruiter.agent.md +0 -41
- package/assets/agents/implantation/deployment-manager.agent.md +0 -41
- package/assets/agents/implantation/environment-specialist.agent.md +0 -41
- package/assets/agents/implantation/go-live-coordinator.agent.md +0 -41
- package/assets/agents/implantation/integration-specialist.agent.md +0 -41
- package/assets/agents/implantation/migration-specialist.agent.md +0 -41
- package/assets/agents/legal/contract-manager.agent.md +0 -41
- package/assets/agents/legal/ip-specialist.agent.md +0 -41
- package/assets/agents/legal/labor-attorney.agent.md +0 -41
- package/assets/agents/legal/legal-counsel.agent.md +0 -41
- package/assets/agents/marketing/brand-guardian.agent.md +0 -40
- package/assets/agents/marketing/content-creator.agent.md +0 -41
- package/assets/agents/marketing/email-marketing.agent.md +0 -41
- package/assets/agents/marketing/landing-page-builder.agent.md +0 -138
- package/assets/agents/marketing/marketing-analyst.agent.md +0 -41
- package/assets/agents/marketing/paid-ads-manager.agent.md +0 -41
- package/assets/agents/marketing/seo-specialist.agent.md +0 -41
- package/assets/agents/marketing/social-media-manager.agent.md +0 -41
- package/assets/agents/rnd/benchmark-analyst.agent.md +0 -41
- package/assets/agents/rnd/innovation-scout.agent.md +0 -41
- package/assets/agents/rnd/market-researcher.agent.md +0 -41
- package/assets/agents/rnd/product-analyst.agent.md +0 -41
- package/assets/agents/rnd/prototype-builder.agent.md +0 -41
- package/assets/agents/support/knowledge-base-manager.agent.md +0 -41
- package/assets/agents/support/l1-support.agent.md +0 -41
- package/assets/agents/support/l2-support.agent.md +0 -41
- package/assets/agents/support/l3-support.agent.md +0 -41
- package/assets/agents/support/sla-monitor.agent.md +0 -41
- package/assets/agents/training/assessment-creator.agent.md +0 -41
- package/assets/agents/training/onboarding-coach.agent.md +0 -41
- package/assets/agents/training/training-designer.agent.md +0 -41
- package/assets/agents/training/workshop-facilitator.agent.md +0 -41
- package/assets/core/best-practices/_catalog.yaml +0 -91
- package/assets/core/best-practices/api-documentation.md +0 -137
- package/assets/core/best-practices/blog-post.md +0 -86
- package/assets/core/best-practices/blog-seo.md +0 -91
- package/assets/core/best-practices/code-review.md +0 -97
- package/assets/core/best-practices/copywriting.md +0 -75
- package/assets/core/best-practices/data-analysis.md +0 -93
- package/assets/core/best-practices/deploy-checklist.md +0 -99
- package/assets/core/best-practices/email-newsletter.md +0 -84
- package/assets/core/best-practices/email-sales.md +0 -91
- package/assets/core/best-practices/fullstack-page-generation.md +0 -936
- package/assets/core/best-practices/image-design.md +0 -78
- package/assets/core/best-practices/instagram-feed.md +0 -70
- package/assets/core/best-practices/instagram-reels.md +0 -75
- package/assets/core/best-practices/instagram-stories.md +0 -68
- package/assets/core/best-practices/landing-page-react.md +0 -2263
- package/assets/core/best-practices/landing-page.md +0 -279
- package/assets/core/best-practices/linkedin-article.md +0 -83
- package/assets/core/best-practices/linkedin-post.md +0 -84
- package/assets/core/best-practices/researching.md +0 -89
- package/assets/core/best-practices/review.md +0 -95
- package/assets/core/best-practices/sprint-planning.md +0 -91
- package/assets/core/best-practices/strategist.md +0 -95
- package/assets/core/best-practices/technical-writing.md +0 -104
- package/assets/core/best-practices/twitter-post.md +0 -75
- package/assets/core/best-practices/twitter-thread.md +0 -92
- package/assets/core/best-practices/whatsapp-broadcast.md +0 -95
- package/assets/core/best-practices/youtube-script.md +0 -80
- package/assets/core/best-practices/youtube-shorts.md +0 -76
- package/assets/core/prompts/insight-hunter.prompt.md +0 -62
- package/assets/core/runner.pipeline.md +0 -200
- package/assets/core/skills.engine.md +0 -65
- package/assets/core/solution-architect.agent.md +0 -329
- package/assets/mcps/_catalog.yaml +0 -17
- package/assets/mcps/figma.mcp.yaml +0 -35
- package/assets/mcps/github.mcp.yaml +0 -44
- package/assets/mcps/linear.mcp.yaml +0 -37
- package/assets/mcps/notion.mcp.yaml +0 -37
- package/assets/mcps/pencil.mcp.yaml +0 -32
- package/assets/mcps/postgresql.mcp.yaml +0 -39
- package/assets/mcps/sentry.mcp.yaml +0 -41
- package/assets/mcps/slack.mcp.yaml +0 -37
- package/assets/mcps/vercel.mcp.yaml +0 -39
- package/assets/templates/_expxagents/_memory/company.md +0 -25
- package/assets/templates/_expxagents/_memory/preferences.md +0 -6
- package/assets/templates/squads/_memory/memories.md +0 -16
- package/dist/cli/src/__tests__/cli.test.d.ts +0 -1
- package/dist/cli/src/__tests__/cli.test.js +0 -23
- package/dist/cli/src/commands/__tests__/outdated.test.d.ts +0 -1
- package/dist/cli/src/commands/__tests__/outdated.test.js +0 -76
- package/dist/cli/src/mcp/__tests__/catalog.test.d.ts +0 -1
- package/dist/cli/src/mcp/__tests__/catalog.test.js +0 -101
- package/dist/cli/src/mcp/__tests__/detect.test.d.ts +0 -1
- package/dist/cli/src/mcp/__tests__/detect.test.js +0 -84
- package/dist/cli/src/mcp/__tests__/setup.test.d.ts +0 -1
- package/dist/cli/src/mcp/__tests__/setup.test.js +0 -75
- package/dist/cli/src/mcp/__tests__/validate.test.d.ts +0 -1
- package/dist/cli/src/mcp/__tests__/validate.test.js +0 -42
- package/dist/cli/src/pencil/__tests__/detect.test.d.ts +0 -1
- package/dist/cli/src/pencil/__tests__/detect.test.js +0 -71
- package/dist/cli/src/pencil/__tests__/property-mapper.test.d.ts +0 -1
- package/dist/cli/src/pencil/__tests__/property-mapper.test.js +0 -120
- package/dist/cli/src/pencil/__tests__/template-sync.test.d.ts +0 -1
- package/dist/cli/src/pencil/__tests__/template-sync.test.js +0 -95
- package/dist/cli/src/runners/__tests__/provider-registry.test.d.ts +0 -1
- package/dist/cli/src/runners/__tests__/provider-registry.test.js +0 -31
- package/dist/cli/src/runners/__tests__/provider-runner.test.d.ts +0 -1
- package/dist/cli/src/runners/__tests__/provider-runner.test.js +0 -86
- package/dist/cli/src/utils/__tests__/command-prefix.test.d.ts +0 -1
- package/dist/cli/src/utils/__tests__/command-prefix.test.js +0 -35
- package/dist/cli/src/utils/__tests__/global-install.test.d.ts +0 -1
- package/dist/cli/src/utils/__tests__/global-install.test.js +0 -25
- package/dist/dashboard/assets/BufferResource-RMf3hLtL.js +0 -185
- package/dist/dashboard/assets/CanvasRenderer-By9CeUeH.js +0 -1
- package/dist/dashboard/assets/JarvisView-DCkJVL5f.js +0 -1
- package/dist/dashboard/assets/RenderTargetSystem-Du3lfljq.js +0 -172
- package/dist/dashboard/assets/ThreeBackground-m9EgwJVc.js +0 -1
- package/dist/dashboard/assets/WebGLRenderer-BfDYJhYQ.js +0 -156
- package/dist/dashboard/assets/WebGPURenderer-CYzaDyV_.js +0 -41
- package/dist/dashboard/assets/browserAll-CFQKTPw8.js +0 -14
- package/dist/dashboard/assets/index-DPwnElYV.js +0 -1195
- package/dist/dashboard/assets/index-DtbIzZ5n.css +0 -1
- package/dist/dashboard/assets/three-BZk_I9Ly.js +0 -4057
- package/dist/dashboard/assets/webworkerAll-Cti2tnMb.js +0 -83
- package/dist/dashboard/index.html +0 -13
- package/dist/data/opensquad.db +0 -0
- package/dist/data/opensquad.db-shm +0 -0
- package/dist/data/opensquad.db-wal +0 -0
- package/dist/server/api/__tests__/cost-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/cost-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/cost-routes.test.js +0 -54
- package/dist/server/api/__tests__/cost-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/files-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/files-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/files-routes.test.js +0 -85
- package/dist/server/api/__tests__/files-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/graph-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/graph-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/graph-routes.test.js +0 -105
- package/dist/server/api/__tests__/graph-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/health-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/health-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/health-routes.test.js +0 -22
- package/dist/server/api/__tests__/health-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/integration-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/integration-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/integration-routes.test.js +0 -243
- package/dist/server/api/__tests__/integration-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/kanban-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/kanban-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/kanban-routes.test.js +0 -316
- package/dist/server/api/__tests__/kanban-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/log-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/log-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/log-routes.test.js +0 -35
- package/dist/server/api/__tests__/log-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/orgchart-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/orgchart-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/orgchart-routes.test.js +0 -161
- package/dist/server/api/__tests__/orgchart-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/settings-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/settings-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/settings-routes.test.js +0 -177
- package/dist/server/api/__tests__/settings-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/system-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/system-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/system-routes.test.js +0 -79
- package/dist/server/api/__tests__/system-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/team-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/team-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/team-routes.test.js +0 -116
- package/dist/server/api/__tests__/team-routes.test.js.map +0 -1
- package/dist/server/api/__tests__/webhook-routes.test.d.ts +0 -2
- package/dist/server/api/__tests__/webhook-routes.test.d.ts.map +0 -1
- package/dist/server/api/__tests__/webhook-routes.test.js +0 -111
- package/dist/server/api/__tests__/webhook-routes.test.js.map +0 -1
- package/dist/server/api/activity-routes.d.ts +0 -8
- package/dist/server/api/activity-routes.d.ts.map +0 -1
- package/dist/server/api/activity-routes.js +0 -34
- package/dist/server/api/activity-routes.js.map +0 -1
- package/dist/server/api/chat-api-routes.d.ts +0 -4
- package/dist/server/api/chat-api-routes.d.ts.map +0 -1
- package/dist/server/api/chat-api-routes.js +0 -28
- package/dist/server/api/chat-api-routes.js.map +0 -1
- package/dist/server/api/cost-routes.d.ts +0 -8
- package/dist/server/api/cost-routes.d.ts.map +0 -1
- package/dist/server/api/cost-routes.js +0 -39
- package/dist/server/api/cost-routes.js.map +0 -1
- package/dist/server/api/dashboard-routes.d.ts +0 -10
- package/dist/server/api/dashboard-routes.d.ts.map +0 -1
- package/dist/server/api/dashboard-routes.js +0 -128
- package/dist/server/api/dashboard-routes.js.map +0 -1
- package/dist/server/api/files-routes.d.ts +0 -5
- package/dist/server/api/files-routes.d.ts.map +0 -1
- package/dist/server/api/files-routes.js +0 -218
- package/dist/server/api/files-routes.js.map +0 -1
- package/dist/server/api/graph-routes.d.ts +0 -24
- package/dist/server/api/graph-routes.d.ts.map +0 -1
- package/dist/server/api/graph-routes.js +0 -208
- package/dist/server/api/graph-routes.js.map +0 -1
- package/dist/server/api/health-routes.d.ts +0 -9
- package/dist/server/api/health-routes.d.ts.map +0 -1
- package/dist/server/api/health-routes.js +0 -46
- package/dist/server/api/health-routes.js.map +0 -1
- package/dist/server/api/integration-routes.d.ts +0 -23
- package/dist/server/api/integration-routes.d.ts.map +0 -1
- package/dist/server/api/integration-routes.js +0 -326
- package/dist/server/api/integration-routes.js.map +0 -1
- package/dist/server/api/kanban-routes.d.ts +0 -8
- package/dist/server/api/kanban-routes.d.ts.map +0 -1
- package/dist/server/api/kanban-routes.js +0 -128
- package/dist/server/api/kanban-routes.js.map +0 -1
- package/dist/server/api/knowledge-routes.d.ts +0 -8
- package/dist/server/api/knowledge-routes.d.ts.map +0 -1
- package/dist/server/api/knowledge-routes.js +0 -82
- package/dist/server/api/knowledge-routes.js.map +0 -1
- package/dist/server/api/log-routes.d.ts +0 -8
- package/dist/server/api/log-routes.d.ts.map +0 -1
- package/dist/server/api/log-routes.js +0 -31
- package/dist/server/api/log-routes.js.map +0 -1
- package/dist/server/api/orgchart-routes.d.ts +0 -7
- package/dist/server/api/orgchart-routes.d.ts.map +0 -1
- package/dist/server/api/orgchart-routes.js +0 -154
- package/dist/server/api/orgchart-routes.js.map +0 -1
- package/dist/server/api/registry-routes.d.ts +0 -7
- package/dist/server/api/registry-routes.d.ts.map +0 -1
- package/dist/server/api/registry-routes.js +0 -51
- package/dist/server/api/registry-routes.js.map +0 -1
- package/dist/server/api/settings-routes.d.ts +0 -11
- package/dist/server/api/settings-routes.d.ts.map +0 -1
- package/dist/server/api/settings-routes.js +0 -167
- package/dist/server/api/settings-routes.js.map +0 -1
- package/dist/server/api/squads-routes.d.ts +0 -7
- package/dist/server/api/squads-routes.d.ts.map +0 -1
- package/dist/server/api/squads-routes.js +0 -165
- package/dist/server/api/squads-routes.js.map +0 -1
- package/dist/server/api/system-routes.d.ts +0 -9
- package/dist/server/api/system-routes.d.ts.map +0 -1
- package/dist/server/api/system-routes.js +0 -241
- package/dist/server/api/system-routes.js.map +0 -1
- package/dist/server/api/team-routes.d.ts +0 -8
- package/dist/server/api/team-routes.d.ts.map +0 -1
- package/dist/server/api/team-routes.js +0 -55
- package/dist/server/api/team-routes.js.map +0 -1
- package/dist/server/api/users-routes.d.ts +0 -8
- package/dist/server/api/users-routes.d.ts.map +0 -1
- package/dist/server/api/users-routes.js +0 -65
- package/dist/server/api/users-routes.js.map +0 -1
- package/dist/server/api/webhook-routes.d.ts +0 -9
- package/dist/server/api/webhook-routes.d.ts.map +0 -1
- package/dist/server/api/webhook-routes.js +0 -82
- package/dist/server/api/webhook-routes.js.map +0 -1
- package/dist/server/app.d.ts +0 -9
- package/dist/server/app.d.ts.map +0 -1
- package/dist/server/app.js +0 -263
- package/dist/server/app.js.map +0 -1
- package/dist/server/auth/auth-middleware.d.ts +0 -13
- package/dist/server/auth/auth-middleware.d.ts.map +0 -1
- package/dist/server/auth/auth-middleware.js +0 -25
- package/dist/server/auth/auth-middleware.js.map +0 -1
- package/dist/server/auth/auth-routes.d.ts +0 -9
- package/dist/server/auth/auth-routes.d.ts.map +0 -1
- package/dist/server/auth/auth-routes.js +0 -149
- package/dist/server/auth/auth-routes.js.map +0 -1
- package/dist/server/auth/jwt.d.ts +0 -14
- package/dist/server/auth/jwt.d.ts.map +0 -1
- package/dist/server/auth/jwt.js +0 -16
- package/dist/server/auth/jwt.js.map +0 -1
- package/dist/server/auth/password.d.ts +0 -3
- package/dist/server/auth/password.d.ts.map +0 -1
- package/dist/server/auth/password.js +0 -9
- package/dist/server/auth/password.js.map +0 -1
- package/dist/server/bridge/__tests__/chat-handler.test.d.ts +0 -2
- package/dist/server/bridge/__tests__/chat-handler.test.d.ts.map +0 -1
- package/dist/server/bridge/__tests__/chat-handler.test.js +0 -143
- package/dist/server/bridge/__tests__/chat-handler.test.js.map +0 -1
- package/dist/server/bridge/__tests__/chat-integration.test.d.ts +0 -2
- package/dist/server/bridge/__tests__/chat-integration.test.d.ts.map +0 -1
- package/dist/server/bridge/__tests__/chat-integration.test.js +0 -129
- package/dist/server/bridge/__tests__/chat-integration.test.js.map +0 -1
- package/dist/server/bridge/__tests__/claude-bridge.test.d.ts +0 -2
- package/dist/server/bridge/__tests__/claude-bridge.test.d.ts.map +0 -1
- package/dist/server/bridge/__tests__/claude-bridge.test.js +0 -300
- package/dist/server/bridge/__tests__/claude-bridge.test.js.map +0 -1
- package/dist/server/bridge/__tests__/conversation.test.d.ts +0 -2
- package/dist/server/bridge/__tests__/conversation.test.d.ts.map +0 -1
- package/dist/server/bridge/__tests__/conversation.test.js +0 -168
- package/dist/server/bridge/__tests__/conversation.test.js.map +0 -1
- package/dist/server/bridge/__tests__/registry.test.d.ts +0 -2
- package/dist/server/bridge/__tests__/registry.test.d.ts.map +0 -1
- package/dist/server/bridge/__tests__/registry.test.js +0 -45
- package/dist/server/bridge/__tests__/registry.test.js.map +0 -1
- package/dist/server/bridge/__tests__/stream-parser.test.d.ts +0 -2
- package/dist/server/bridge/__tests__/stream-parser.test.d.ts.map +0 -1
- package/dist/server/bridge/__tests__/stream-parser.test.js +0 -66
- package/dist/server/bridge/__tests__/stream-parser.test.js.map +0 -1
- package/dist/server/bridge/chat-handler.d.ts +0 -32
- package/dist/server/bridge/chat-handler.d.ts.map +0 -1
- package/dist/server/bridge/chat-handler.js +0 -356
- package/dist/server/bridge/chat-handler.js.map +0 -1
- package/dist/server/bridge/claude-bridge.d.ts +0 -21
- package/dist/server/bridge/claude-bridge.d.ts.map +0 -1
- package/dist/server/bridge/claude-bridge.js +0 -273
- package/dist/server/bridge/claude-bridge.js.map +0 -1
- package/dist/server/bridge/conversation.d.ts +0 -45
- package/dist/server/bridge/conversation.d.ts.map +0 -1
- package/dist/server/bridge/conversation.js +0 -78
- package/dist/server/bridge/conversation.js.map +0 -1
- package/dist/server/bridge/engine-manager.d.ts +0 -13
- package/dist/server/bridge/engine-manager.d.ts.map +0 -1
- package/dist/server/bridge/engine-manager.js +0 -54
- package/dist/server/bridge/engine-manager.js.map +0 -1
- package/dist/server/bridge/engine.d.ts +0 -37
- package/dist/server/bridge/engine.d.ts.map +0 -1
- package/dist/server/bridge/engine.js +0 -2
- package/dist/server/bridge/engine.js.map +0 -1
- package/dist/server/bridge/factory.d.ts +0 -4
- package/dist/server/bridge/factory.d.ts.map +0 -1
- package/dist/server/bridge/factory.js +0 -18
- package/dist/server/bridge/factory.js.map +0 -1
- package/dist/server/bridge/opencode-bridge.d.ts +0 -27
- package/dist/server/bridge/opencode-bridge.d.ts.map +0 -1
- package/dist/server/bridge/opencode-bridge.js +0 -163
- package/dist/server/bridge/opencode-bridge.js.map +0 -1
- package/dist/server/bridge/registry.d.ts +0 -19
- package/dist/server/bridge/registry.d.ts.map +0 -1
- package/dist/server/bridge/registry.js +0 -29
- package/dist/server/bridge/registry.js.map +0 -1
- package/dist/server/bridge/session-journal.d.ts +0 -25
- package/dist/server/bridge/session-journal.d.ts.map +0 -1
- package/dist/server/bridge/session-journal.js +0 -69
- package/dist/server/bridge/session-journal.js.map +0 -1
- package/dist/server/bridge/stream-parser.d.ts +0 -14
- package/dist/server/bridge/stream-parser.d.ts.map +0 -1
- package/dist/server/bridge/stream-parser.js +0 -26
- package/dist/server/bridge/stream-parser.js.map +0 -1
- package/dist/server/config/engine-config.d.ts +0 -4
- package/dist/server/config/engine-config.d.ts.map +0 -1
- package/dist/server/config/engine-config.js +0 -24
- package/dist/server/config/engine-config.js.map +0 -1
- package/dist/server/config.d.ts +0 -17
- package/dist/server/config.d.ts.map +0 -1
- package/dist/server/config.js +0 -39
- package/dist/server/config.js.map +0 -1
- package/dist/server/db/__tests__/chat-tables.test.d.ts +0 -2
- package/dist/server/db/__tests__/chat-tables.test.d.ts.map +0 -1
- package/dist/server/db/__tests__/chat-tables.test.js +0 -82
- package/dist/server/db/__tests__/chat-tables.test.js.map +0 -1
- package/dist/server/db/__tests__/email-schema.test.d.ts +0 -2
- package/dist/server/db/__tests__/email-schema.test.d.ts.map +0 -1
- package/dist/server/db/__tests__/email-schema.test.js +0 -53
- package/dist/server/db/__tests__/email-schema.test.js.map +0 -1
- package/dist/server/db/__tests__/scheduler-schema.test.d.ts +0 -2
- package/dist/server/db/__tests__/scheduler-schema.test.d.ts.map +0 -1
- package/dist/server/db/__tests__/scheduler-schema.test.js +0 -52
- package/dist/server/db/__tests__/scheduler-schema.test.js.map +0 -1
- package/dist/server/db/connection.d.ts +0 -4
- package/dist/server/db/connection.d.ts.map +0 -1
- package/dist/server/db/connection.js +0 -40
- package/dist/server/db/connection.js.map +0 -1
- package/dist/server/db/migrations.d.ts +0 -4
- package/dist/server/db/migrations.d.ts.map +0 -1
- package/dist/server/db/migrations.js +0 -47
- package/dist/server/db/migrations.js.map +0 -1
- package/dist/server/db/schema.d.ts +0 -2
- package/dist/server/db/schema.d.ts.map +0 -1
- package/dist/server/db/schema.js +0 -276
- package/dist/server/db/schema.js.map +0 -1
- package/dist/server/email/__tests__/campaign-routes.test.d.ts +0 -2
- package/dist/server/email/__tests__/campaign-routes.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/campaign-routes.test.js +0 -216
- package/dist/server/email/__tests__/campaign-routes.test.js.map +0 -1
- package/dist/server/email/__tests__/campaign-service.test.d.ts +0 -2
- package/dist/server/email/__tests__/campaign-service.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/campaign-service.test.js +0 -79
- package/dist/server/email/__tests__/campaign-service.test.js.map +0 -1
- package/dist/server/email/__tests__/email-queue-worker.test.d.ts +0 -2
- package/dist/server/email/__tests__/email-queue-worker.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/email-queue-worker.test.js +0 -93
- package/dist/server/email/__tests__/email-queue-worker.test.js.map +0 -1
- package/dist/server/email/__tests__/email-utils.test.d.ts +0 -2
- package/dist/server/email/__tests__/email-utils.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/email-utils.test.js +0 -36
- package/dist/server/email/__tests__/email-utils.test.js.map +0 -1
- package/dist/server/email/__tests__/lead-routes.test.d.ts +0 -2
- package/dist/server/email/__tests__/lead-routes.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/lead-routes.test.js +0 -180
- package/dist/server/email/__tests__/lead-routes.test.js.map +0 -1
- package/dist/server/email/__tests__/lead-service.test.d.ts +0 -2
- package/dist/server/email/__tests__/lead-service.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/lead-service.test.js +0 -113
- package/dist/server/email/__tests__/lead-service.test.js.map +0 -1
- package/dist/server/email/__tests__/ses-client.test.d.ts +0 -2
- package/dist/server/email/__tests__/ses-client.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/ses-client.test.js +0 -48
- package/dist/server/email/__tests__/ses-client.test.js.map +0 -1
- package/dist/server/email/__tests__/sns-webhook.test.d.ts +0 -2
- package/dist/server/email/__tests__/sns-webhook.test.d.ts.map +0 -1
- package/dist/server/email/__tests__/sns-webhook.test.js +0 -40
- package/dist/server/email/__tests__/sns-webhook.test.js.map +0 -1
- package/dist/server/email/campaign-routes.d.ts +0 -8
- package/dist/server/email/campaign-routes.d.ts.map +0 -1
- package/dist/server/email/campaign-routes.js +0 -65
- package/dist/server/email/campaign-routes.js.map +0 -1
- package/dist/server/email/campaign-service.d.ts +0 -55
- package/dist/server/email/campaign-service.d.ts.map +0 -1
- package/dist/server/email/campaign-service.js +0 -89
- package/dist/server/email/campaign-service.js.map +0 -1
- package/dist/server/email/email-queue-worker.d.ts +0 -27
- package/dist/server/email/email-queue-worker.d.ts.map +0 -1
- package/dist/server/email/email-queue-worker.js +0 -119
- package/dist/server/email/email-queue-worker.js.map +0 -1
- package/dist/server/email/email-utils.d.ts +0 -5
- package/dist/server/email/email-utils.d.ts.map +0 -1
- package/dist/server/email/email-utils.js +0 -24
- package/dist/server/email/email-utils.js.map +0 -1
- package/dist/server/email/lead-routes.d.ts +0 -8
- package/dist/server/email/lead-routes.d.ts.map +0 -1
- package/dist/server/email/lead-routes.js +0 -56
- package/dist/server/email/lead-routes.js.map +0 -1
- package/dist/server/email/lead-service.d.ts +0 -66
- package/dist/server/email/lead-service.d.ts.map +0 -1
- package/dist/server/email/lead-service.js +0 -138
- package/dist/server/email/lead-service.js.map +0 -1
- package/dist/server/email/ses-client.d.ts +0 -27
- package/dist/server/email/ses-client.d.ts.map +0 -1
- package/dist/server/email/ses-client.js +0 -44
- package/dist/server/email/ses-client.js.map +0 -1
- package/dist/server/email/sns-webhook.d.ts +0 -10
- package/dist/server/email/sns-webhook.d.ts.map +0 -1
- package/dist/server/email/sns-webhook.js +0 -73
- package/dist/server/email/sns-webhook.js.map +0 -1
- package/dist/server/index.d.ts +0 -2
- package/dist/server/index.d.ts.map +0 -1
- package/dist/server/index.js +0 -36
- package/dist/server/index.js.map +0 -1
- package/dist/server/mcp/expxagents-mcp.d.ts +0 -2
- package/dist/server/mcp/expxagents-mcp.d.ts.map +0 -1
- package/dist/server/mcp/expxagents-mcp.js +0 -230
- package/dist/server/mcp/expxagents-mcp.js.map +0 -1
- package/dist/server/routes/__tests__/conversations.test.d.ts +0 -2
- package/dist/server/routes/__tests__/conversations.test.d.ts.map +0 -1
- package/dist/server/routes/__tests__/conversations.test.js +0 -111
- package/dist/server/routes/__tests__/conversations.test.js.map +0 -1
- package/dist/server/routes/conversations.d.ts +0 -8
- package/dist/server/routes/conversations.d.ts.map +0 -1
- package/dist/server/routes/conversations.js +0 -36
- package/dist/server/routes/conversations.js.map +0 -1
- package/dist/server/scheduler/__tests__/job-runner.test.d.ts +0 -2
- package/dist/server/scheduler/__tests__/job-runner.test.d.ts.map +0 -1
- package/dist/server/scheduler/__tests__/job-runner.test.js +0 -488
- package/dist/server/scheduler/__tests__/job-runner.test.js.map +0 -1
- package/dist/server/scheduler/__tests__/scheduler-routes.test.d.ts +0 -2
- package/dist/server/scheduler/__tests__/scheduler-routes.test.d.ts.map +0 -1
- package/dist/server/scheduler/__tests__/scheduler-routes.test.js +0 -167
- package/dist/server/scheduler/__tests__/scheduler-routes.test.js.map +0 -1
- package/dist/server/scheduler/__tests__/scheduler-service.test.d.ts +0 -2
- package/dist/server/scheduler/__tests__/scheduler-service.test.d.ts.map +0 -1
- package/dist/server/scheduler/__tests__/scheduler-service.test.js +0 -207
- package/dist/server/scheduler/__tests__/scheduler-service.test.js.map +0 -1
- package/dist/server/scheduler/job-runner.d.ts +0 -73
- package/dist/server/scheduler/job-runner.d.ts.map +0 -1
- package/dist/server/scheduler/job-runner.js +0 -407
- package/dist/server/scheduler/job-runner.js.map +0 -1
- package/dist/server/scheduler/scheduler-routes.d.ts +0 -10
- package/dist/server/scheduler/scheduler-routes.d.ts.map +0 -1
- package/dist/server/scheduler/scheduler-routes.js +0 -105
- package/dist/server/scheduler/scheduler-routes.js.map +0 -1
- package/dist/server/scheduler/scheduler-service.d.ts +0 -55
- package/dist/server/scheduler/scheduler-service.d.ts.map +0 -1
- package/dist/server/scheduler/scheduler-service.js +0 -271
- package/dist/server/scheduler/scheduler-service.js.map +0 -1
- package/dist/server/services/__tests__/cost-service.test.d.ts +0 -2
- package/dist/server/services/__tests__/cost-service.test.d.ts.map +0 -1
- package/dist/server/services/__tests__/cost-service.test.js +0 -72
- package/dist/server/services/__tests__/cost-service.test.js.map +0 -1
- package/dist/server/services/__tests__/execution-log-service.test.d.ts +0 -2
- package/dist/server/services/__tests__/execution-log-service.test.d.ts.map +0 -1
- package/dist/server/services/__tests__/execution-log-service.test.js +0 -40
- package/dist/server/services/__tests__/execution-log-service.test.js.map +0 -1
- package/dist/server/services/__tests__/integration-registry.test.d.ts +0 -2
- package/dist/server/services/__tests__/integration-registry.test.d.ts.map +0 -1
- package/dist/server/services/__tests__/integration-registry.test.js +0 -28
- package/dist/server/services/__tests__/integration-registry.test.js.map +0 -1
- package/dist/server/services/__tests__/log-service.test.d.ts +0 -2
- package/dist/server/services/__tests__/log-service.test.d.ts.map +0 -1
- package/dist/server/services/__tests__/log-service.test.js +0 -49
- package/dist/server/services/__tests__/log-service.test.js.map +0 -1
- package/dist/server/services/__tests__/pipeline-task-service.test.d.ts +0 -2
- package/dist/server/services/__tests__/pipeline-task-service.test.d.ts.map +0 -1
- package/dist/server/services/__tests__/pipeline-task-service.test.js +0 -268
- package/dist/server/services/__tests__/pipeline-task-service.test.js.map +0 -1
- package/dist/server/services/__tests__/state-service.test.d.ts +0 -2
- package/dist/server/services/__tests__/state-service.test.d.ts.map +0 -1
- package/dist/server/services/__tests__/state-service.test.js +0 -136
- package/dist/server/services/__tests__/state-service.test.js.map +0 -1
- package/dist/server/services/activity-service.d.ts +0 -35
- package/dist/server/services/activity-service.d.ts.map +0 -1
- package/dist/server/services/activity-service.js +0 -92
- package/dist/server/services/activity-service.js.map +0 -1
- package/dist/server/services/cost-service.d.ts +0 -55
- package/dist/server/services/cost-service.d.ts.map +0 -1
- package/dist/server/services/cost-service.js +0 -59
- package/dist/server/services/cost-service.js.map +0 -1
- package/dist/server/services/execution-log-service.d.ts +0 -20
- package/dist/server/services/execution-log-service.d.ts.map +0 -1
- package/dist/server/services/execution-log-service.js +0 -17
- package/dist/server/services/execution-log-service.js.map +0 -1
- package/dist/server/services/integration-registry.d.ts +0 -9
- package/dist/server/services/integration-registry.d.ts.map +0 -1
- package/dist/server/services/integration-registry.js +0 -14
- package/dist/server/services/integration-registry.js.map +0 -1
- package/dist/server/services/log-service.d.ts +0 -28
- package/dist/server/services/log-service.d.ts.map +0 -1
- package/dist/server/services/log-service.js +0 -34
- package/dist/server/services/log-service.js.map +0 -1
- package/dist/server/services/pipeline-task-service.d.ts +0 -79
- package/dist/server/services/pipeline-task-service.d.ts.map +0 -1
- package/dist/server/services/pipeline-task-service.js +0 -122
- package/dist/server/services/pipeline-task-service.js.map +0 -1
- package/dist/server/services/squad-registry.d.ts +0 -35
- package/dist/server/services/squad-registry.d.ts.map +0 -1
- package/dist/server/services/squad-registry.js +0 -141
- package/dist/server/services/squad-registry.js.map +0 -1
- package/dist/server/services/state-service.d.ts +0 -22
- package/dist/server/services/state-service.d.ts.map +0 -1
- package/dist/server/services/state-service.js +0 -114
- package/dist/server/services/state-service.js.map +0 -1
- package/dist/server/types/a2ui.d.ts +0 -27
- package/dist/server/types/a2ui.d.ts.map +0 -1
- package/dist/server/types/a2ui.js +0 -2
- package/dist/server/types/a2ui.js.map +0 -1
- package/dist/server/utils/find-free-port.d.ts +0 -2
- package/dist/server/utils/find-free-port.d.ts.map +0 -1
- package/dist/server/utils/find-free-port.js +0 -17
- package/dist/server/utils/find-free-port.js.map +0 -1
- package/dist/server/watcher/__tests__/file-watcher.test.d.ts +0 -2
- package/dist/server/watcher/__tests__/file-watcher.test.d.ts.map +0 -1
- package/dist/server/watcher/__tests__/file-watcher.test.js +0 -81
- package/dist/server/watcher/__tests__/file-watcher.test.js.map +0 -1
- package/dist/server/watcher/file-watcher.d.ts +0 -19
- package/dist/server/watcher/file-watcher.d.ts.map +0 -1
- package/dist/server/watcher/file-watcher.js +0 -105
- package/dist/server/watcher/file-watcher.js.map +0 -1
- package/dist/server/watcher/state-parser.d.ts +0 -77
- package/dist/server/watcher/state-parser.d.ts.map +0 -1
- package/dist/server/watcher/state-parser.js +0 -78
- package/dist/server/watcher/state-parser.js.map +0 -1
- package/dist/server/ws/ws-auth.d.ts +0 -4
- package/dist/server/ws/ws-auth.d.ts.map +0 -1
- package/dist/server/ws/ws-auth.js +0 -42
- package/dist/server/ws/ws-auth.js.map +0 -1
- package/dist/server/ws/ws-handler.d.ts +0 -12
- package/dist/server/ws/ws-handler.d.ts.map +0 -1
- package/dist/server/ws/ws-handler.js +0 -171
- package/dist/server/ws/ws-handler.js.map +0 -1
- package/dist/server/ws/ws-rooms.d.ts +0 -12
- package/dist/server/ws/ws-rooms.d.ts.map +0 -1
- package/dist/server/ws/ws-rooms.js +0 -52
- package/dist/server/ws/ws-rooms.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/config.d.ts +0 -4
- package/node_modules/expxagents-knowledge/dist/config.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/config.js +0 -37
- package/node_modules/expxagents-knowledge/dist/config.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/db/connection.d.ts +0 -6
- package/node_modules/expxagents-knowledge/dist/db/connection.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/db/connection.js +0 -69
- package/node_modules/expxagents-knowledge/dist/db/connection.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/db/migrations.d.ts +0 -3
- package/node_modules/expxagents-knowledge/dist/db/migrations.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/db/migrations.js +0 -46
- package/node_modules/expxagents-knowledge/dist/db/migrations.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/db/schema.d.ts +0 -3
- package/node_modules/expxagents-knowledge/dist/db/schema.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/db/schema.js +0 -79
- package/node_modules/expxagents-knowledge/dist/db/schema.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/index.d.ts +0 -16
- package/node_modules/expxagents-knowledge/dist/index.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/index.js +0 -16
- package/node_modules/expxagents-knowledge/dist/index.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.d.ts +0 -10
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.js +0 -221
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.d.ts +0 -4
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.js +0 -56
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.d.ts +0 -4
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.js +0 -25
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.d.ts +0 -21
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.js +0 -54
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.d.ts +0 -16
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.js +0 -49
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.d.ts +0 -9
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.js +0 -116
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.d.ts +0 -27
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.js +0 -92
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.d.ts +0 -41
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.js +0 -62
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.d.ts +0 -31
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.js +0 -106
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/query/vector-search.d.ts +0 -26
- package/node_modules/expxagents-knowledge/dist/query/vector-search.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/query/vector-search.js +0 -57
- package/node_modules/expxagents-knowledge/dist/query/vector-search.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.d.ts +0 -10
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.js +0 -29
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/sources/watcher.d.ts +0 -6
- package/node_modules/expxagents-knowledge/dist/sources/watcher.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/sources/watcher.js +0 -42
- package/node_modules/expxagents-knowledge/dist/sources/watcher.js.map +0 -1
- package/node_modules/expxagents-knowledge/dist/types.d.ts +0 -138
- package/node_modules/expxagents-knowledge/dist/types.d.ts.map +0 -1
- package/node_modules/expxagents-knowledge/dist/types.js +0 -2
- package/node_modules/expxagents-knowledge/dist/types.js.map +0 -1
- package/node_modules/expxagents-knowledge/package.json +0 -7
|
@@ -1,407 +0,0 @@
|
|
|
1
|
-
import { logActivityStart, logActivityComplete, logActivityFail, } from '../services/activity-service.js';
|
|
2
|
-
import { createPipelineTasksFromYaml, markAllTasksDone, markAllTasksFailed, markTaskExecutingByPosition, } from '../services/pipeline-task-service.js';
|
|
3
|
-
import { findSquadDir } from '../services/squad-registry.js';
|
|
4
|
-
import { persistLog } from '../services/log-service.js';
|
|
5
|
-
import { appendExecutionLog } from '../services/execution-log-service.js';
|
|
6
|
-
import path from 'node:path';
|
|
7
|
-
import fs from 'node:fs';
|
|
8
|
-
import YAML from 'yaml';
|
|
9
|
-
const RETRY_BASE_MS = 30_000;
|
|
10
|
-
const HANDOFF_MAX_CHARS = 2000;
|
|
11
|
-
const DEFAULT_CHAIN_MAX_TURNS = 25;
|
|
12
|
-
const RETRY_MAX_MS = 300_000;
|
|
13
|
-
const SUMMARY_TIMEOUT_MS = 30_000;
|
|
14
|
-
const SUMMARY_INPUT_CHARS = 1000;
|
|
15
|
-
function getRetryDelay(attempt) {
|
|
16
|
-
return Math.min(RETRY_BASE_MS * Math.pow(2, attempt - 1), RETRY_MAX_MS);
|
|
17
|
-
}
|
|
18
|
-
export class JobRunner {
|
|
19
|
-
db;
|
|
20
|
-
_bridge;
|
|
21
|
-
broadcast;
|
|
22
|
-
broadcastToAll;
|
|
23
|
-
squadsDir;
|
|
24
|
-
runningSquads = new Set();
|
|
25
|
-
squadQueues = new Map();
|
|
26
|
-
summaryCounter = 0;
|
|
27
|
-
get bridge() {
|
|
28
|
-
return typeof this._bridge === 'function' ? this._bridge() : this._bridge;
|
|
29
|
-
}
|
|
30
|
-
constructor(config) {
|
|
31
|
-
this.db = config.db;
|
|
32
|
-
this._bridge = config.bridge;
|
|
33
|
-
this.broadcast = config.broadcast;
|
|
34
|
-
this.broadcastToAll = config.broadcastToAll;
|
|
35
|
-
this.squadsDir = config.squadsDir;
|
|
36
|
-
this.cleanupStaleRunningStates();
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* On server startup, any squad state.json left in status "running" from a previous
|
|
40
|
-
* server process is stale — the executor is dead. Mark them as "interrupted" so the
|
|
41
|
-
* UI doesn't show phantom running pipelines.
|
|
42
|
-
* Checks both <squad>/state.json and <squad>/_state/state.json patterns.
|
|
43
|
-
*/
|
|
44
|
-
cleanupStaleRunningStates() {
|
|
45
|
-
try {
|
|
46
|
-
const entries = fs.readdirSync(this.squadsDir, { withFileTypes: true });
|
|
47
|
-
for (const entry of entries) {
|
|
48
|
-
if (!entry.isDirectory())
|
|
49
|
-
continue;
|
|
50
|
-
const statePatterns = [
|
|
51
|
-
path.join(this.squadsDir, entry.name, 'state.json'),
|
|
52
|
-
path.join(this.squadsDir, entry.name, '_state', 'state.json'),
|
|
53
|
-
];
|
|
54
|
-
for (const statePath of statePatterns) {
|
|
55
|
-
if (!fs.existsSync(statePath))
|
|
56
|
-
continue;
|
|
57
|
-
try {
|
|
58
|
-
const raw = fs.readFileSync(statePath, 'utf-8');
|
|
59
|
-
const state = JSON.parse(raw);
|
|
60
|
-
if (state.status !== 'running')
|
|
61
|
-
continue;
|
|
62
|
-
state.status = 'interrupted';
|
|
63
|
-
state.interruptedAt = new Date().toISOString();
|
|
64
|
-
state.interruptReason = 'Server restarted — execution orphaned';
|
|
65
|
-
fs.writeFileSync(statePath, JSON.stringify(state, null, 2));
|
|
66
|
-
console.log(`[startup] Marked stale "running" state as "interrupted": ${entry.name}`);
|
|
67
|
-
}
|
|
68
|
-
catch {
|
|
69
|
-
// ignore parse errors on individual files
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
catch {
|
|
75
|
-
// squadsDir doesn't exist yet — ignore
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
async run(opts) {
|
|
79
|
-
if (this.runningSquads.has(opts.squadName)) {
|
|
80
|
-
if (opts.skipIfBusy) {
|
|
81
|
-
console.log(`[scheduler] "${opts.squadName}" is busy — skipping (skipIfBusy)`);
|
|
82
|
-
return 'skipped';
|
|
83
|
-
}
|
|
84
|
-
const queue = this.squadQueues.get(opts.squadName) ?? [];
|
|
85
|
-
queue.push(opts);
|
|
86
|
-
this.squadQueues.set(opts.squadName, queue);
|
|
87
|
-
console.log(`[queue] "${opts.squadName}" is busy — queued (position ${queue.length})`);
|
|
88
|
-
this.broadcast(opts.squadName, {
|
|
89
|
-
type: 'schedule:queued',
|
|
90
|
-
squadName: opts.squadName,
|
|
91
|
-
queuePosition: queue.length,
|
|
92
|
-
});
|
|
93
|
-
return 'queued';
|
|
94
|
-
}
|
|
95
|
-
this.runningSquads.add(opts.squadName);
|
|
96
|
-
// Resolve the actual squad directory (may be nested)
|
|
97
|
-
const squadDir = findSquadDir(this.squadsDir, opts.squadName) ?? path.join(this.squadsDir, opts.squadName);
|
|
98
|
-
const activity = logActivityStart(this.db, {
|
|
99
|
-
squadCode: opts.squadName,
|
|
100
|
-
userMessage: opts.prompt,
|
|
101
|
-
triggeredBy: 'schedule',
|
|
102
|
-
});
|
|
103
|
-
this.db.prepare('UPDATE squad_activities SET attempt = ? WHERE id = ?')
|
|
104
|
-
.run(opts.attempt, activity.id);
|
|
105
|
-
persistLog(this.db, { level: 'info', squadCode: opts.squadName, source: 'scheduler', message: `Pipeline started (attempt ${opts.attempt})` });
|
|
106
|
-
this.broadcast(opts.squadName, {
|
|
107
|
-
type: 'schedule:started',
|
|
108
|
-
squadName: opts.squadName,
|
|
109
|
-
jobId: activity.id,
|
|
110
|
-
attempt: opts.attempt,
|
|
111
|
-
});
|
|
112
|
-
// Create pipeline tasks from squad.yaml — mark first step as executing
|
|
113
|
-
const pipelineTasks = createPipelineTasksFromYaml(this.db, this.squadsDir, opts.squadName, activity.id, 'schedule');
|
|
114
|
-
if (pipelineTasks.length > 0) {
|
|
115
|
-
markTaskExecutingByPosition(this.db, { activityId: activity.id, position: 0 });
|
|
116
|
-
this.broadcastToAll({ type: 'kanban:task_updated', activityId: activity.id, squadName: opts.squadName });
|
|
117
|
-
}
|
|
118
|
-
return new Promise((resolve) => {
|
|
119
|
-
const key = `schedule:${opts.squadName}`;
|
|
120
|
-
this.bridge.send({
|
|
121
|
-
prompt: opts.prompt,
|
|
122
|
-
cwd: squadDir,
|
|
123
|
-
squadName: key,
|
|
124
|
-
maxTurns: opts.maxTurns,
|
|
125
|
-
onChunk: (text) => {
|
|
126
|
-
this.broadcast(opts.squadName, {
|
|
127
|
-
type: 'schedule:chunk',
|
|
128
|
-
squadName: opts.squadName,
|
|
129
|
-
jobId: activity.id,
|
|
130
|
-
delta: text,
|
|
131
|
-
});
|
|
132
|
-
// Persist chunk to execution_logs
|
|
133
|
-
appendExecutionLog(this.db, {
|
|
134
|
-
activityId: activity.id,
|
|
135
|
-
squadCode: opts.squadName,
|
|
136
|
-
chunk: text,
|
|
137
|
-
source: 'output',
|
|
138
|
-
});
|
|
139
|
-
},
|
|
140
|
-
onDone: async (fullText) => {
|
|
141
|
-
this.runningSquads.delete(opts.squadName);
|
|
142
|
-
this.processNextInQueue(opts.squadName);
|
|
143
|
-
logActivityComplete(this.db, activity.id, fullText.slice(0, 2000));
|
|
144
|
-
persistLog(this.db, { level: 'info', squadCode: opts.squadName, source: 'scheduler', message: 'Pipeline completed', detail: fullText.slice(0, 300) });
|
|
145
|
-
// Mark pipeline tasks done with output summary
|
|
146
|
-
if (pipelineTasks.length > 0) {
|
|
147
|
-
markAllTasksDone(this.db, { activityId: activity.id, result: fullText.slice(0, 2000) });
|
|
148
|
-
this.broadcastToAll({ type: 'kanban:task_updated', activityId: activity.id, status: 'done' });
|
|
149
|
-
}
|
|
150
|
-
this.broadcast(opts.squadName, {
|
|
151
|
-
type: 'schedule:done',
|
|
152
|
-
squadName: opts.squadName,
|
|
153
|
-
jobId: activity.id,
|
|
154
|
-
summary: fullText.slice(0, 2000),
|
|
155
|
-
attempt: opts.attempt,
|
|
156
|
-
});
|
|
157
|
-
this.db.prepare("UPDATE scheduled_jobs SET last_run_at = datetime('now'), last_result = 'success', updated_at = datetime('now') WHERE squad_name = ?").run(opts.squadName);
|
|
158
|
-
// Auto-trigger chained squads
|
|
159
|
-
try {
|
|
160
|
-
const chainTargets = this.readChainConfig(opts.squadName);
|
|
161
|
-
if (chainTargets.length > 0) {
|
|
162
|
-
// Generate intelligent L1 summary once for all chain targets
|
|
163
|
-
const l1Summary = await this.generateSummary(opts.squadName, fullText);
|
|
164
|
-
for (const ct of chainTargets) {
|
|
165
|
-
const targetDir = findSquadDir(this.squadsDir, ct.squadName);
|
|
166
|
-
if (!targetDir) {
|
|
167
|
-
console.error(`[chain] Target squad "${ct.squadName}" not found, skipping`);
|
|
168
|
-
continue;
|
|
169
|
-
}
|
|
170
|
-
// Save truncated summary to handoff file for reference
|
|
171
|
-
const outputDir = path.join(squadDir, '_output');
|
|
172
|
-
fs.mkdirSync(outputDir, { recursive: true });
|
|
173
|
-
const handoffFile = path.join(outputDir, `handoff-to-${ct.squadName}.md`);
|
|
174
|
-
const timestamp = new Date().toISOString();
|
|
175
|
-
const truncatedOutput = fullText.length > HANDOFF_MAX_CHARS
|
|
176
|
-
? fullText.slice(-HANDOFF_MAX_CHARS)
|
|
177
|
-
: fullText;
|
|
178
|
-
fs.writeFileSync(handoffFile, `# Handoff: ${opts.squadName} → ${ct.squadName}\n\n**Data:** ${timestamp}\n\n---\n\n${truncatedOutput}`, 'utf-8');
|
|
179
|
-
this.broadcast(opts.squadName, {
|
|
180
|
-
type: 'chain:triggered',
|
|
181
|
-
sourceSquad: opts.squadName,
|
|
182
|
-
targetSquad: ct.squadName,
|
|
183
|
-
handoffFile,
|
|
184
|
-
});
|
|
185
|
-
// L0 (description) + L1 (intelligent summary or fallback) + L2 (file reference)
|
|
186
|
-
const desc = ct.description
|
|
187
|
-
? ct.description
|
|
188
|
-
: `Continuação automática da squad "${opts.squadName}"`;
|
|
189
|
-
const summary = l1Summary ?? (fullText.length > 500 ? fullText.slice(-500) : fullText);
|
|
190
|
-
const chainPrompt = `${desc}\n\nResumo da squad anterior:\n${summary}\n\nContexto completo disponível em: ${handoffFile}`;
|
|
191
|
-
this.run({
|
|
192
|
-
squadName: ct.squadName,
|
|
193
|
-
prompt: chainPrompt,
|
|
194
|
-
timeoutMinutes: opts.timeoutMinutes,
|
|
195
|
-
retryOnFailure: 0,
|
|
196
|
-
attempt: 1,
|
|
197
|
-
maxTurns: ct.maxTurns ?? DEFAULT_CHAIN_MAX_TURNS,
|
|
198
|
-
});
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
catch (chainErr) {
|
|
203
|
-
console.error(`[chain] Error processing chain for "${opts.squadName}":`, chainErr);
|
|
204
|
-
}
|
|
205
|
-
this.scheduleRetryIfNeeded(opts.squadName, opts);
|
|
206
|
-
resolve('completed');
|
|
207
|
-
},
|
|
208
|
-
onError: (error) => {
|
|
209
|
-
this.runningSquads.delete(opts.squadName);
|
|
210
|
-
this.processNextInQueue(opts.squadName);
|
|
211
|
-
logActivityFail(this.db, activity.id, error.message);
|
|
212
|
-
// Mark pipeline tasks failed
|
|
213
|
-
if (pipelineTasks.length > 0) {
|
|
214
|
-
markAllTasksFailed(this.db, { activityId: activity.id, error: error.message });
|
|
215
|
-
this.broadcastToAll({ type: 'kanban:task_updated', activityId: activity.id, status: 'failed' });
|
|
216
|
-
}
|
|
217
|
-
const willRetry = opts.attempt < opts.retryOnFailure + 1;
|
|
218
|
-
persistLog(this.db, { level: 'error', squadCode: opts.squadName, source: 'scheduler', message: `Pipeline failed: ${error.message}`, detail: willRetry ? `Will retry (attempt ${opts.attempt})` : undefined });
|
|
219
|
-
this.broadcast(opts.squadName, {
|
|
220
|
-
type: 'schedule:error',
|
|
221
|
-
squadName: opts.squadName,
|
|
222
|
-
jobId: activity.id,
|
|
223
|
-
error: error.message,
|
|
224
|
-
attempt: opts.attempt,
|
|
225
|
-
willRetry,
|
|
226
|
-
});
|
|
227
|
-
this.db.prepare("UPDATE scheduled_jobs SET last_run_at = datetime('now'), last_result = 'failure', updated_at = datetime('now') WHERE squad_name = ?").run(opts.squadName);
|
|
228
|
-
if (willRetry) {
|
|
229
|
-
const delay = getRetryDelay(opts.attempt);
|
|
230
|
-
setTimeout(() => {
|
|
231
|
-
this.run({ ...opts, attempt: opts.attempt + 1 });
|
|
232
|
-
}, delay);
|
|
233
|
-
}
|
|
234
|
-
resolve('failed');
|
|
235
|
-
},
|
|
236
|
-
});
|
|
237
|
-
});
|
|
238
|
-
}
|
|
239
|
-
/**
|
|
240
|
-
* Generate an intelligent L1 summary via a micro-call to Claude.
|
|
241
|
-
* Returns null on failure (timeout, error) — caller should fallback to truncation.
|
|
242
|
-
*/
|
|
243
|
-
generateSummary(squadName, output) {
|
|
244
|
-
return new Promise((resolve) => {
|
|
245
|
-
const input = output.length > SUMMARY_INPUT_CHARS
|
|
246
|
-
? output.slice(-SUMMARY_INPUT_CHARS)
|
|
247
|
-
: output;
|
|
248
|
-
const summaryKey = `summary:${squadName}:${++this.summaryCounter}`;
|
|
249
|
-
console.log(`[chain] Generating L1 summary for "${squadName}" (${input.length} chars)`);
|
|
250
|
-
const timer = setTimeout(() => {
|
|
251
|
-
this.bridge.kill(summaryKey);
|
|
252
|
-
console.log(`[chain] L1 summary timed out for "${squadName}", using fallback`);
|
|
253
|
-
resolve(null);
|
|
254
|
-
}, SUMMARY_TIMEOUT_MS);
|
|
255
|
-
this.bridge.send({
|
|
256
|
-
prompt: `Resuma em 3 bullets curtos e objetivos o resultado abaixo. Responda APENAS os bullets, nada mais:\n\n${input}`,
|
|
257
|
-
cwd: findSquadDir(this.squadsDir, squadName) ?? path.join(this.squadsDir, squadName),
|
|
258
|
-
squadName: summaryKey,
|
|
259
|
-
maxTurns: 1,
|
|
260
|
-
onChunk: () => { },
|
|
261
|
-
onDone: (text) => {
|
|
262
|
-
clearTimeout(timer);
|
|
263
|
-
console.log(`[chain] L1 summary ready for "${squadName}" (${text.length} chars)`);
|
|
264
|
-
resolve(text.trim() || null);
|
|
265
|
-
},
|
|
266
|
-
onError: () => {
|
|
267
|
-
clearTimeout(timer);
|
|
268
|
-
console.log(`[chain] L1 summary failed for "${squadName}", using fallback`);
|
|
269
|
-
resolve(null);
|
|
270
|
-
},
|
|
271
|
-
});
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
/**
|
|
275
|
-
* Read chain targets from squad.yaml.
|
|
276
|
-
* Supports both formats:
|
|
277
|
-
* chain: "squad-name"
|
|
278
|
-
* chain: ["squad-a", "squad-b"]
|
|
279
|
-
* chain: [{ target_squad: "squad-a", trigger: "on_complete", description: "..." }]
|
|
280
|
-
*/
|
|
281
|
-
readChainConfig(squadName) {
|
|
282
|
-
try {
|
|
283
|
-
const chainSquadDir = findSquadDir(this.squadsDir, squadName);
|
|
284
|
-
const yamlPath = chainSquadDir ? path.join(chainSquadDir, 'squad.yaml') : path.join(this.squadsDir, squadName, 'squad.yaml');
|
|
285
|
-
if (!fs.existsSync(yamlPath))
|
|
286
|
-
return [];
|
|
287
|
-
const raw = fs.readFileSync(yamlPath, 'utf-8');
|
|
288
|
-
const parsed = YAML.parse(raw);
|
|
289
|
-
const chain = parsed?.squad?.chain;
|
|
290
|
-
if (!chain)
|
|
291
|
-
return [];
|
|
292
|
-
if (typeof chain === 'string')
|
|
293
|
-
return [{ squadName: chain }];
|
|
294
|
-
if (Array.isArray(chain)) {
|
|
295
|
-
return chain
|
|
296
|
-
.map((c) => {
|
|
297
|
-
if (typeof c === 'string')
|
|
298
|
-
return { squadName: c };
|
|
299
|
-
if (c && typeof c === 'object' && typeof c.target_squad === 'string') {
|
|
300
|
-
return {
|
|
301
|
-
squadName: c.target_squad,
|
|
302
|
-
description: typeof c.description === 'string' ? c.description : undefined,
|
|
303
|
-
maxTurns: typeof c.max_turns === 'number' ? c.max_turns : undefined,
|
|
304
|
-
};
|
|
305
|
-
}
|
|
306
|
-
return null;
|
|
307
|
-
})
|
|
308
|
-
.filter((c) => c !== null);
|
|
309
|
-
}
|
|
310
|
-
return [];
|
|
311
|
-
}
|
|
312
|
-
catch {
|
|
313
|
-
return [];
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
processNextInQueue(squadName) {
|
|
317
|
-
const queue = this.squadQueues.get(squadName);
|
|
318
|
-
if (!queue || queue.length === 0)
|
|
319
|
-
return;
|
|
320
|
-
const next = queue.shift();
|
|
321
|
-
if (queue.length === 0)
|
|
322
|
-
this.squadQueues.delete(squadName);
|
|
323
|
-
const delayMs = this.getSpacingDelayMs(squadName);
|
|
324
|
-
const logSuffix = delayMs > 0 ? `spacing window: waiting ${Math.ceil(delayMs / 1000)}s` : 'running immediately';
|
|
325
|
-
console.log(`[queue] "${squadName}" dequeuing (${logSuffix}, ${queue.length} remaining)`);
|
|
326
|
-
this.broadcast(squadName, {
|
|
327
|
-
type: 'schedule:dequeued',
|
|
328
|
-
squadName,
|
|
329
|
-
queueRemaining: queue.length,
|
|
330
|
-
retryInMs: delayMs,
|
|
331
|
-
});
|
|
332
|
-
setTimeout(() => this.run(next), delayMs);
|
|
333
|
-
}
|
|
334
|
-
/**
|
|
335
|
-
* Read last-published.json and return how many ms remain before the spacing window opens.
|
|
336
|
-
* Returns 0 if the window is already open or the file doesn't exist.
|
|
337
|
-
*/
|
|
338
|
-
getSpacingDelayMs(squadName) {
|
|
339
|
-
const SPACING_MS = 10 * 60_000;
|
|
340
|
-
try {
|
|
341
|
-
const resolvedDir = findSquadDir(this.squadsDir, squadName) ?? path.join(this.squadsDir, squadName);
|
|
342
|
-
const lastPublishedPath = path.join(resolvedDir, '_state', 'last-published.json');
|
|
343
|
-
if (!fs.existsSync(lastPublishedPath))
|
|
344
|
-
return 0;
|
|
345
|
-
const data = JSON.parse(fs.readFileSync(lastPublishedPath, 'utf-8'));
|
|
346
|
-
if (typeof data.published_at !== 'string')
|
|
347
|
-
return 0;
|
|
348
|
-
const elapsedMs = Date.now() - new Date(data.published_at).getTime();
|
|
349
|
-
return Math.max(0, SPACING_MS - elapsedMs);
|
|
350
|
-
}
|
|
351
|
-
catch {
|
|
352
|
-
return 0;
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
/**
|
|
356
|
-
* After a run completes, check if the agent wrote _state/retry-at.json requesting a
|
|
357
|
-
* scheduled one-shot retry (e.g. because the spacing window hadn't opened yet).
|
|
358
|
-
* Consumes the file immediately to prevent duplicate scheduling.
|
|
359
|
-
*/
|
|
360
|
-
scheduleRetryIfNeeded(squadName, opts) {
|
|
361
|
-
const retryDir = findSquadDir(this.squadsDir, squadName) ?? path.join(this.squadsDir, squadName);
|
|
362
|
-
const retryPath = path.join(retryDir, '_state', 'retry-at.json');
|
|
363
|
-
try {
|
|
364
|
-
if (!fs.existsSync(retryPath))
|
|
365
|
-
return;
|
|
366
|
-
const data = JSON.parse(fs.readFileSync(retryPath, 'utf-8'));
|
|
367
|
-
fs.unlinkSync(retryPath); // consume — prevent duplicate scheduling
|
|
368
|
-
if (typeof data.retry_at !== 'string')
|
|
369
|
-
return;
|
|
370
|
-
const delayMs = Math.max(0, new Date(data.retry_at).getTime() - Date.now());
|
|
371
|
-
const reason = typeof data.reason === 'string' ? data.reason : 'spacing';
|
|
372
|
-
const retryPrompt = typeof data.prompt === 'string'
|
|
373
|
-
? data.prompt
|
|
374
|
-
: 'Verificar fila pendente em _queue/pending.yaml e publicar próximo conteúdo agendado.';
|
|
375
|
-
console.log(`[retry] "${squadName}" scheduled retry in ${Math.ceil(delayMs / 1000)}s — reason: ${reason}`);
|
|
376
|
-
this.broadcast(squadName, {
|
|
377
|
-
type: 'schedule:retry_scheduled',
|
|
378
|
-
squadName,
|
|
379
|
-
retryInMs: delayMs,
|
|
380
|
-
reason,
|
|
381
|
-
});
|
|
382
|
-
setTimeout(() => {
|
|
383
|
-
this.run({
|
|
384
|
-
squadName,
|
|
385
|
-
prompt: retryPrompt,
|
|
386
|
-
timeoutMinutes: opts.timeoutMinutes,
|
|
387
|
-
retryOnFailure: 0,
|
|
388
|
-
attempt: 1,
|
|
389
|
-
maxTurns: opts.maxTurns,
|
|
390
|
-
});
|
|
391
|
-
}, delayMs);
|
|
392
|
-
}
|
|
393
|
-
catch {
|
|
394
|
-
// ignore — retry scheduling is best-effort
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
isRunning(squadName) {
|
|
398
|
-
return this.runningSquads.has(squadName);
|
|
399
|
-
}
|
|
400
|
-
stopAll() {
|
|
401
|
-
for (const squadName of this.runningSquads) {
|
|
402
|
-
this.bridge.kill(`schedule:${squadName}`);
|
|
403
|
-
}
|
|
404
|
-
this.runningSquads.clear();
|
|
405
|
-
}
|
|
406
|
-
}
|
|
407
|
-
//# sourceMappingURL=job-runner.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"job-runner.js","sourceRoot":"","sources":["../../src/scheduler/job-runner.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
|
|
2
|
-
import type Database from 'better-sqlite3';
|
|
3
|
-
import type { SchedulerService } from './scheduler-service.js';
|
|
4
|
-
interface SchedulerRoutesOptions extends FastifyPluginOptions {
|
|
5
|
-
db: Database.Database;
|
|
6
|
-
schedulerService: SchedulerService | null;
|
|
7
|
-
}
|
|
8
|
-
export declare function schedulerRoutes(app: FastifyInstance, opts: SchedulerRoutesOptions): Promise<void>;
|
|
9
|
-
export {};
|
|
10
|
-
//# sourceMappingURL=scheduler-routes.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"scheduler-routes.d.ts","sourceRoot":"","sources":["../../src/scheduler/scheduler-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,UAAU,sBAAuB,SAAQ,oBAAoB;IAC3D,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;IACtB,gBAAgB,EAAE,gBAAgB,GAAG,IAAI,CAAC;CAC3C;AAED,wBAAsB,eAAe,CACnC,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,sBAAsB,GAC3B,OAAO,CAAC,IAAI,CAAC,CA8Hf"}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
export async function schedulerRoutes(app, opts) {
|
|
2
|
-
const { db, schedulerService } = opts;
|
|
3
|
-
// GET /api/scheduler — list all scheduled jobs
|
|
4
|
-
app.get('/api/scheduler', {
|
|
5
|
-
preHandler: [app.requireAuth],
|
|
6
|
-
}, async (_request, reply) => {
|
|
7
|
-
const rows = db.prepare('SELECT * FROM scheduled_jobs ORDER BY squad_name').all();
|
|
8
|
-
return reply.send({ data: rows });
|
|
9
|
-
});
|
|
10
|
-
// GET /api/scheduler/:squad — job details
|
|
11
|
-
app.get('/api/scheduler/:squad', {
|
|
12
|
-
preHandler: [app.requireAuth],
|
|
13
|
-
}, async (request, reply) => {
|
|
14
|
-
const row = db.prepare('SELECT * FROM scheduled_jobs WHERE squad_name = ?')
|
|
15
|
-
.get(request.params.squad);
|
|
16
|
-
if (!row)
|
|
17
|
-
return reply.code(404).send({ error: 'Scheduled job not found' });
|
|
18
|
-
return reply.send({ data: row });
|
|
19
|
-
});
|
|
20
|
-
// POST /api/scheduler — create or update a scheduled job
|
|
21
|
-
app.post('/api/scheduler', {
|
|
22
|
-
preHandler: [app.requireAuth],
|
|
23
|
-
}, async (request, reply) => {
|
|
24
|
-
const { squad_name, cron_expression, prompt, timezone, timeout_minutes, retry_on_failure } = request.body;
|
|
25
|
-
if (!squad_name || typeof squad_name !== 'string' || !squad_name.trim()) {
|
|
26
|
-
return reply.code(400).send({ error: 'squad_name is required' });
|
|
27
|
-
}
|
|
28
|
-
if (!cron_expression || typeof cron_expression !== 'string' || !cron_expression.trim()) {
|
|
29
|
-
return reply.code(400).send({ error: 'cron_expression is required' });
|
|
30
|
-
}
|
|
31
|
-
if (!prompt || typeof prompt !== 'string' || !prompt.trim()) {
|
|
32
|
-
return reply.code(400).send({ error: 'prompt is required' });
|
|
33
|
-
}
|
|
34
|
-
if (schedulerService) {
|
|
35
|
-
const ok = schedulerService.registerDynamic(squad_name.trim(), {
|
|
36
|
-
cron: cron_expression.trim(),
|
|
37
|
-
prompt: prompt.trim(),
|
|
38
|
-
timezone: timezone?.trim() || undefined,
|
|
39
|
-
timeout_minutes: timeout_minutes ?? 30,
|
|
40
|
-
retry_on_failure: retry_on_failure ?? 0,
|
|
41
|
-
});
|
|
42
|
-
if (!ok) {
|
|
43
|
-
return reply.code(400).send({ error: 'Invalid cron expression' });
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
else {
|
|
47
|
-
// No scheduler service — just store in DB
|
|
48
|
-
db.prepare(`
|
|
49
|
-
INSERT INTO scheduled_jobs (squad_name, cron_expression, prompt, mode, timeout_minutes, retry_on_failure, timezone, status)
|
|
50
|
-
VALUES (?, ?, ?, 'autonomous', ?, ?, ?, 'active')
|
|
51
|
-
ON CONFLICT(squad_name) DO UPDATE SET
|
|
52
|
-
cron_expression = excluded.cron_expression,
|
|
53
|
-
prompt = excluded.prompt,
|
|
54
|
-
timeout_minutes = excluded.timeout_minutes,
|
|
55
|
-
retry_on_failure = excluded.retry_on_failure,
|
|
56
|
-
timezone = excluded.timezone,
|
|
57
|
-
status = 'active',
|
|
58
|
-
updated_at = datetime('now')
|
|
59
|
-
`).run(squad_name.trim(), cron_expression.trim(), prompt.trim(), timeout_minutes ?? 30, retry_on_failure ?? 0, timezone?.trim() || null);
|
|
60
|
-
}
|
|
61
|
-
const row = db.prepare('SELECT * FROM scheduled_jobs WHERE squad_name = ?').get(squad_name.trim());
|
|
62
|
-
return reply.code(201).send({ data: row });
|
|
63
|
-
});
|
|
64
|
-
// POST /api/scheduler/:squad/pause
|
|
65
|
-
app.post('/api/scheduler/:squad/pause', {
|
|
66
|
-
preHandler: [app.requireAuth],
|
|
67
|
-
}, async (request, reply) => {
|
|
68
|
-
if (schedulerService)
|
|
69
|
-
schedulerService.pause(request.params.squad);
|
|
70
|
-
return reply.send({ ok: true });
|
|
71
|
-
});
|
|
72
|
-
// POST /api/scheduler/:squad/resume
|
|
73
|
-
app.post('/api/scheduler/:squad/resume', {
|
|
74
|
-
preHandler: [app.requireAuth],
|
|
75
|
-
}, async (request, reply) => {
|
|
76
|
-
if (schedulerService)
|
|
77
|
-
schedulerService.resume(request.params.squad);
|
|
78
|
-
return reply.send({ ok: true });
|
|
79
|
-
});
|
|
80
|
-
// POST /api/scheduler/:squad/trigger
|
|
81
|
-
app.post('/api/scheduler/:squad/trigger', {
|
|
82
|
-
preHandler: [app.requireAuth],
|
|
83
|
-
}, async (request, reply) => {
|
|
84
|
-
if (schedulerService)
|
|
85
|
-
schedulerService.triggerNow(request.params.squad);
|
|
86
|
-
return reply.send({ ok: true, message: 'Triggered' });
|
|
87
|
-
});
|
|
88
|
-
// DELETE /api/scheduler/:squad
|
|
89
|
-
app.delete('/api/scheduler/:squad', {
|
|
90
|
-
preHandler: [app.requireAuth],
|
|
91
|
-
}, async (request, reply) => {
|
|
92
|
-
if (schedulerService)
|
|
93
|
-
schedulerService.unregister(request.params.squad);
|
|
94
|
-
return reply.send({ ok: true });
|
|
95
|
-
});
|
|
96
|
-
// GET /api/scheduler/:squad/history
|
|
97
|
-
app.get('/api/scheduler/:squad/history', {
|
|
98
|
-
preHandler: [app.requireAuth],
|
|
99
|
-
}, async (request, reply) => {
|
|
100
|
-
const limit = Math.min(parseInt(request.query.limit ?? '20', 10) || 20, 100);
|
|
101
|
-
const rows = db.prepare("SELECT * FROM squad_activities WHERE squad_code = ? AND triggered_by = 'schedule' ORDER BY started_at DESC LIMIT ?").all(request.params.squad, limit);
|
|
102
|
-
return reply.send({ data: rows });
|
|
103
|
-
});
|
|
104
|
-
}
|
|
105
|
-
//# sourceMappingURL=scheduler-routes.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"scheduler-routes.js","sourceRoot":"","sources":["../../src/scheduler/scheduler-routes.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import type Database from 'better-sqlite3';
|
|
2
|
-
import type { JobRunner } from './job-runner.js';
|
|
3
|
-
export interface ScheduleConfig {
|
|
4
|
-
enabled: boolean;
|
|
5
|
-
cron: string;
|
|
6
|
-
timezone?: string;
|
|
7
|
-
mode: 'autonomous';
|
|
8
|
-
prompt: string;
|
|
9
|
-
timeout_minutes?: number;
|
|
10
|
-
retry_on_failure?: number;
|
|
11
|
-
}
|
|
12
|
-
export interface SchedulerServiceConfig {
|
|
13
|
-
db: Database.Database;
|
|
14
|
-
jobRunner: JobRunner;
|
|
15
|
-
squadsDir: string;
|
|
16
|
-
broadcast?: (squadName: string, message: Record<string, unknown>) => void;
|
|
17
|
-
}
|
|
18
|
-
export interface SchedulerStatus {
|
|
19
|
-
squadName: string;
|
|
20
|
-
cronExpression: string;
|
|
21
|
-
timezone?: string;
|
|
22
|
-
status: 'active' | 'paused' | 'error';
|
|
23
|
-
lastRunAt?: string;
|
|
24
|
-
lastResult?: string;
|
|
25
|
-
nextRunAt?: string;
|
|
26
|
-
}
|
|
27
|
-
export declare class SchedulerService {
|
|
28
|
-
private db;
|
|
29
|
-
private jobRunner;
|
|
30
|
-
private squadsDir;
|
|
31
|
-
private broadcast?;
|
|
32
|
-
private jobs;
|
|
33
|
-
constructor(config: SchedulerServiceConfig);
|
|
34
|
-
start(): void;
|
|
35
|
-
private restoreFromDb;
|
|
36
|
-
stop(): void;
|
|
37
|
-
register(squadName: string): void;
|
|
38
|
-
unregister(squadName: string): void;
|
|
39
|
-
pause(squadName: string): void;
|
|
40
|
-
resume(squadName: string): void;
|
|
41
|
-
triggerNow(squadName: string): void;
|
|
42
|
-
reload(squadName: string): void;
|
|
43
|
-
/** Register a schedule from API data (not from YAML) */
|
|
44
|
-
registerDynamic(squadName: string, config: {
|
|
45
|
-
cron: string;
|
|
46
|
-
prompt: string;
|
|
47
|
-
timezone?: string;
|
|
48
|
-
timeout_minutes?: number;
|
|
49
|
-
retry_on_failure?: number;
|
|
50
|
-
}): boolean;
|
|
51
|
-
getStatus(): SchedulerStatus[];
|
|
52
|
-
getJob(squadName: string): SchedulerStatus | null;
|
|
53
|
-
private readScheduleConfig;
|
|
54
|
-
}
|
|
55
|
-
//# sourceMappingURL=scheduler-service.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"scheduler-service.d.ts","sourceRoot":"","sources":["../../src/scheduler/scheduler-service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAM3C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAGjD,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,YAAY,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,sBAAsB;IACrC,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;IACtB,SAAS,EAAE,SAAS,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;CAC3E;AAaD,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,QAAQ,GAAG,QAAQ,GAAG,OAAO,CAAC;IACtC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,EAAE,CAAoB;IAC9B,OAAO,CAAC,SAAS,CAAY;IAC7B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,SAAS,CAAC,CAAgE;IAClF,OAAO,CAAC,IAAI,CAAmC;gBAEnC,MAAM,EAAE,sBAAsB;IAO1C,KAAK,IAAI,IAAI;IAUb,OAAO,CAAC,aAAa;IAsDrB,IAAI,IAAI,IAAI;IAQZ,QAAQ,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAyEjC,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IASnC,KAAK,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAU9B,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAU/B,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAYnC,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAK/B,wDAAwD;IACxD,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE;QACzC,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;KAC3B,GAAG,OAAO;IA2DX,SAAS,IAAI,eAAe,EAAE;IAkB9B,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,eAAe,GAAG,IAAI;IAgBjD,OAAO,CAAC,kBAAkB;CAc3B"}
|